.signin-page{--signin-bg: #f5f8fd;--signin-surface: #ffffff;--signin-border: #dbe6f4;--signin-text: #18263d;--signin-muted: #5f7088;--signin-orange: #e8720c;min-height:100vh;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:1.3rem;background:radial-gradient(circle at 6% 4%,rgba(255,211,173,.5),transparent 36%),radial-gradient(circle at 96% 10%,rgba(188,224,255,.45),transparent 34%),linear-gradient(180deg,#fbfdff 0%,var(--signin-bg) 100%);font-family:Be Vietnam Pro,system-ui,sans-serif}.signin-glow{position:absolute;border-radius:999px;z-index:0;filter:blur(5px);pointer-events:none;animation:signinPulse 9s ease-in-out infinite}.signin-glow-top{width:340px;height:340px;top:-130px;right:-120px;background:radial-gradient(circle,#e8720c3d,#e8720c00)}.signin-glow-bottom{width:380px;height:380px;left:-120px;bottom:-170px;background:radial-gradient(circle,#3b82f630,#3b82f600);animation-delay:1.2s}.signin-shell{width:min(1040px,100%);position:relative;z-index:1;display:grid;grid-template-columns:1.06fr .94fr;border:1px solid var(--signin-border);border-radius:26px;background:#ffffffe6;box-shadow:0 30px 55px -46px #0f172abf;overflow:hidden}.signin-intro{padding:2rem;background:linear-gradient(160deg,#f6fbff,#fdf7f1)}.signin-home-link{display:inline-flex;align-items:center;gap:.35rem;text-decoration:none;color:#4e617b;font-size:.83rem;font-weight:700;margin-bottom:1rem;transition:color .2s ease,transform .2s ease}.signin-home-link:hover{color:#273a56;transform:translate(-2px)}.signin-pill{display:inline-flex;align-items:center;gap:.33rem;border-radius:999px;border:1px solid #ffd6b4;background:#fff2e5;color:#aa550b;font-size:.75rem;font-weight:700;padding:.3rem .72rem}.signin-intro h1{margin:1rem 0 0;color:var(--signin-text);font-size:clamp(1.72rem,3.2vw,2.5rem);line-height:1.16;letter-spacing:-.025em}.signin-intro p{margin:.82rem 0 0;color:var(--signin-muted);font-size:.95rem;line-height:1.65;max-width:58ch}.signin-benefits{margin-top:1.2rem;display:grid;gap:.66rem}.signin-benefit-card{display:grid;grid-template-columns:auto 1fr;align-items:start;gap:.66rem;border:1px solid #dbe6f3;border-radius:14px;background:#fff;padding:.75rem;transition:transform .22s ease,box-shadow .22s ease}.signin-benefit-card:hover{transform:translateY(-2px);box-shadow:0 15px 25px -20px #0f172a6b}.signin-benefit-icon{width:33px;height:33px;border-radius:11px;display:inline-flex;align-items:center;justify-content:center;background:#fff0e3;color:#cd660f}.signin-benefit-card h3{margin:0;color:#1b2a43;font-size:.86rem}.signin-benefit-card p{margin:.3rem 0 0;color:#61728a;font-size:.78rem;line-height:1.52}.signin-card{padding:2rem;background:#fff;border-left:1px solid #e2ebf6;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.signin-logo-wrap{width:70px;height:70px;border-radius:20px;background:linear-gradient(135deg,#fff4e8,#fff);border:1px solid #ffd7b7;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 14px 28px -24px #e8720ce6}.signin-logo{width:48px;height:48px;object-fit:contain}.signin-card h2{margin:.9rem 0 0;color:#16253a;font-size:clamp(1.56rem,2.4vw,1.95rem);letter-spacing:-.02em}.signin-card-sub{margin:.52rem 0 1.15rem;color:#60728a;line-height:1.58;max-width:34ch;font-size:.88rem}.signin-google-btn{width:min(350px,100%);border:1px solid #d7e3f2;border-radius:14px;background:#fff;color:#112138;height:52px;font-weight:700;font-size:.95rem;display:inline-flex;align-items:center;justify-content:center;gap:.55rem;cursor:pointer;transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease}.signin-google-btn:hover{transform:translateY(-2px);border-color:#bfd2eb;box-shadow:0 18px 28px -24px #0f172ab3}.signin-google-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.signin-loading{margin:.85rem 0 0;color:#b85f12;font-size:.81rem;font-weight:700;display:inline-flex;align-items:center;gap:.45rem}.signin-loading-dot{width:8px;height:8px;border-radius:999px;background:#eb7d1d;animation:signinBlink 1.2s ease-in-out infinite}.signin-error{margin-top:.95rem;width:min(350px,100%);text-align:left;border:1px solid #fdc9c9;background:#fff3f3;border-radius:12px;padding:.72rem;color:#b42318;font-size:.82rem;line-height:1.5;display:grid;grid-template-columns:auto 1fr;gap:.5rem}.signin-disclaimer{margin:1.05rem 0 0;max-width:37ch;color:#6a7b92;font-size:.74rem;line-height:1.58}.signin-legal{margin-top:.9rem;display:inline-flex;align-items:center;gap:.6rem;flex-wrap:wrap;justify-content:center}.signin-legal a{text-decoration:none;font-size:.75rem;color:#5f7188}.signin-legal a:hover{color:var(--signin-orange)}.signin-legal-dot{color:#9eb0c8;font-size:.58rem}.signin-enter{opacity:0;transform:translateY(18px) scale(.99);animation:signinIn .64s cubic-bezier(.2,.84,.25,1) forwards}@keyframes signinIn{to{opacity:1;transform:translateY(0) scale(1)}}@keyframes signinBlink{0%,to{opacity:1}50%{opacity:.35}}@keyframes signinPulse{0%,to{transform:scale(.95);opacity:.78}50%{transform:scale(1.03);opacity:1}}@media (max-width: 980px){.signin-shell{grid-template-columns:1fr}.signin-card{border-left:0;border-top:1px solid #e2ebf6}}@media (max-width: 560px){.signin-page{padding:.7rem}.signin-intro,.signin-card{padding:1rem}.signin-shell{border-radius:18px}.signin-google-btn,.signin-error{width:100%}}.welcome-page{--welcome-bg: #f6f8fb;--welcome-bg-alt: #ffffff;--welcome-border: #dfe7f2;--welcome-text: #1e293b;--welcome-muted: #5f6f85;--welcome-orange: #e8720c;--welcome-orange-soft: #fff1e4;--welcome-blue-soft: #eaf2ff;--welcome-green-soft: #e9fbf1;min-height:100vh;position:relative;overflow:clip;background:radial-gradient(circle at 4% 6%,rgba(255,210,167,.45),transparent 42%),radial-gradient(circle at 92% 16%,rgba(186,220,255,.4),transparent 36%),linear-gradient(180deg,#fbfcff 0%,var(--welcome-bg) 48%,#f3f7fd 100%);color:var(--welcome-text);font-family:Be Vietnam Pro,system-ui,sans-serif}.welcome-glow{position:absolute;border-radius:999px;filter:blur(4px);z-index:0;pointer-events:none;animation:welcomePulse 8.5s ease-in-out infinite}.welcome-glow-one{width:360px;height:360px;background:radial-gradient(circle,#e8720c33,#e8720c00);top:-120px;left:-100px}.welcome-glow-two{width:420px;height:420px;background:radial-gradient(circle,#3b82f629,#3b82f600);right:-120px;bottom:-160px;animation-delay:1.2s}.welcome-nav{position:sticky;top:0;z-index:10;height:72px;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(221,232,246,.9);background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.welcome-brand{text-decoration:none;color:inherit;display:inline-flex;align-items:center;gap:10px}.welcome-brand img{width:36px;height:36px;object-fit:contain}.welcome-brand span{font-size:1.08rem;font-weight:800;letter-spacing:-.01em;color:#172338}.welcome-brand em{color:var(--welcome-orange);font-style:normal}.welcome-nav-link{display:inline-flex;align-items:center;gap:5px;text-decoration:none;font-size:.86rem;font-weight:600;color:var(--text-secondary);padding:.4rem .75rem;border-radius:8px;transition:background .15s,color .15s}.welcome-nav-link:hover{background:#f1f5f9;color:#1e3a5f}.welcome-signin-link{text-decoration:none;background:#fff;border:1px solid #d9e3f1;color:#233049;padding:.58rem 1.15rem;border-radius:999px;font-weight:700;font-size:.86rem;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}.welcome-signin-link:hover{transform:translateY(-1px);border-color:#c4d5eb;box-shadow:0 10px 20px -14px #0f172a73}.welcome-main{position:relative;z-index:1;max-width:1160px;margin:0 auto;padding:2.8rem 2rem 3.2rem}.welcome-hero{display:grid;grid-template-columns:1.08fr .92fr;gap:1.4rem;align-items:stretch}.welcome-copy{background:var(--welcome-bg-alt);border:1px solid var(--welcome-border);border-radius:24px;padding:2rem;box-shadow:0 30px 60px -52px #1e293b8c}.welcome-pill{display:inline-flex;align-items:center;gap:.35rem;background:#fff4ea;color:#a8530a;border:1px solid #ffd8ba;border-radius:999px;padding:.32rem .78rem;font-size:.77rem;font-weight:700;letter-spacing:.01em}.welcome-copy h1{margin:1.05rem 0 0;font-size:clamp(1.95rem,4vw,3.2rem);line-height:1.15;letter-spacing:-.03em;color:#132236}.welcome-copy h1 span{display:inline-block;color:#d66b10}.welcome-copy p{margin:1rem 0 0;color:var(--welcome-muted);font-size:1rem;line-height:1.72;max-width:62ch}.welcome-actions{margin-top:1.45rem;display:flex;flex-wrap:wrap;gap:.68rem}.welcome-cta-primary,.welcome-cta-secondary{display:inline-flex;align-items:center;gap:.4rem;text-decoration:none;border-radius:12px;padding:.76rem 1.1rem;font-size:.9rem;font-weight:700;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}.welcome-cta-primary{background:linear-gradient(135deg,#eb7c1a,#f59f50);color:#fff;box-shadow:0 14px 20px -15px #e8720cbf}.welcome-cta-primary:hover{transform:translateY(-2px);box-shadow:0 18px 26px -16px #e8720cd1}.welcome-cta-secondary{color:#243249;border:1px solid #d3deed;background:#fff}.welcome-cta-secondary:hover{transform:translateY(-2px);border-color:#bed0e8}.welcome-stats{margin-top:1.45rem;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.7rem}.welcome-stat-card{background:#f9fbff;border:1px solid #e0e9f5;border-radius:14px;padding:.82rem}.welcome-stat-card strong{display:block;font-size:1rem;color:#18243a;font-weight:800}.welcome-stat-card span{margin-top:.2rem;display:block;color:#64748b;font-size:.74rem;line-height:1.45}.welcome-showcase{border-radius:24px;border:1px solid #dbe7f7;background:linear-gradient(170deg,#fff,#f3f8ff);box-shadow:0 26px 50px -44px #0f172aa6;padding:1.45rem;animation:welcomeFloat 7s ease-in-out infinite}.welcome-showcase-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.7rem;margin-bottom:.85rem}.welcome-showcase-head h3{margin:0;font-size:1.2rem;color:#19253c;letter-spacing:-.015em}.welcome-showcase-head span{color:#17803f;font-size:.75rem;font-weight:700;padding:.2rem .55rem;border-radius:999px;background:#eaf8ef;border:1px solid #c8ead4}.welcome-showcase-list{display:grid;gap:.62rem}.welcome-showcase-row{border:1px solid #dce7f6;border-radius:14px;background:#fff;padding:.72rem}.welcome-showcase-row p{margin:.42rem 0 0;font-size:.84rem;color:#4f6079;line-height:1.5}.welcome-tag{display:inline-flex;align-items:center;font-size:.69rem;font-weight:700;letter-spacing:.01em;border-radius:999px;padding:.18rem .6rem}.welcome-tag-orange{background:var(--welcome-orange-soft);color:#ba5e0d}.welcome-tag-blue{background:var(--welcome-blue-soft);color:#2563eb}.welcome-tag-green{background:var(--welcome-green-soft);color:#15803d}.welcome-features{margin-top:2rem}.welcome-features-head{max-width:760px;margin:0 auto 1.2rem;text-align:center}.welcome-features-head h2{margin:0;color:#16253b;font-size:clamp(1.45rem,2.3vw,2.1rem);letter-spacing:-.02em}.welcome-features-head p{margin:.72rem 0 0;color:#60718a;font-size:.97rem;line-height:1.62}.welcome-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(245px,1fr));gap:.9rem}.welcome-feature-card{background:#fff;border:1px solid #dde7f4;border-radius:18px;padding:1.05rem;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}.welcome-feature-card:hover{transform:translateY(-4px);border-color:#c8d7eb;box-shadow:0 18px 30px -24px #1e293b73}.welcome-feature-icon{width:42px;height:42px;border-radius:12px;background:#fff1e7;color:#de7110;display:inline-flex;align-items:center;justify-content:center}.welcome-feature-card h3{margin:.82rem 0 0;font-size:.98rem;color:#18243a}.welcome-feature-card p{margin:.5rem 0 0;color:#62728a;font-size:.84rem;line-height:1.54}.welcome-public-section{margin-top:2rem}.welcome-public-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.5rem}.welcome-public-card{display:flex;align-items:flex-start;gap:1.1rem;padding:1.4rem 1.6rem;border-radius:18px;border:1px solid #dbe5f3;border-left-width:4px;background:#fff;text-decoration:none;color:inherit;cursor:pointer;transition:transform .18s,box-shadow .18s,border-color .18s;box-shadow:0 2px 8px #0f28500f}.welcome-public-card--blue{border-left-color:#2563eb}.welcome-public-card--green{border-left-color:#16a34a}.welcome-public-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0f28501f;border-color:#b6cef0;border-left-width:4px}.welcome-public-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.welcome-public-card h3{margin:0 0 .25rem;font-size:1.05rem;font-weight:800;color:#15243a}.welcome-public-card p{margin:0;font-size:.82rem;color:#62728a;line-height:1.5}.welcome-public-arrow{margin-left:auto;flex-shrink:0;color:#94a3b8;display:flex;align-items:center}.welcome-public-card:hover .welcome-public-arrow{color:#2563eb}.welcome-public-cta{display:inline-flex;align-items:center;gap:4px;margin-top:.65rem;font-size:.82rem;font-weight:700;color:#2563eb;text-decoration:underline;text-underline-offset:3px}.welcome-cta-panel{margin-top:1.8rem;border-radius:22px;border:1px solid #d6e3f6;padding:1.6rem;background:linear-gradient(120deg,#eef5ff,#fef2e7);text-align:center}.welcome-cta-panel h2{margin:0;font-size:clamp(1.32rem,2.2vw,1.9rem);color:#15243a;letter-spacing:-.02em}.welcome-cta-panel p{margin:.72rem 0 1rem;color:#5d6e86}.welcome-footer{margin-top:2rem;border-top:1px solid #dbe5f3;padding:1rem 2rem 1.5rem;color:#64748b;font-size:.8rem;display:flex;justify-content:space-between;gap:.85rem;flex-wrap:wrap}.welcome-footer div{display:inline-flex;flex-wrap:wrap;gap:.9rem}.welcome-footer a{color:#607089;text-decoration:none}.welcome-footer a:hover{color:var(--welcome-orange)}.welcome-enter{opacity:0;transform:translateY(16px) scale(.99);animation:welcomeIn .62s cubic-bezier(.2,.85,.25,1) forwards}@keyframes welcomeIn{to{opacity:1;transform:translateY(0) scale(1)}}@keyframes welcomePulse{0%,to{transform:scale(.96);opacity:.85}50%{transform:scale(1.04);opacity:1}}@keyframes welcomeFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@media (max-width: 980px){.welcome-main{padding:2rem 1.2rem 2.4rem}.welcome-nav{padding:0 1.2rem}.welcome-hero,.welcome-stats{grid-template-columns:1fr}}@media (max-width: 560px){.welcome-nav{height:auto;padding:.85rem 1rem;gap:.8rem;flex-wrap:wrap}.welcome-brand span{font-size:1rem}.welcome-copy,.welcome-showcase,.welcome-cta-panel{border-radius:18px;padding:1rem}.welcome-public-grid{grid-template-columns:1fr}.welcome-actions{gap:.55rem}.welcome-cta-primary,.welcome-cta-secondary{width:100%;justify-content:center}.welcome-footer{padding:1rem}}:root{--react-pdf-annotation-layer: 1;--annotation-unfocused-field-background: url("data:image/svg+xml;charset=UTF-8,<svg width='1px' height='1px' xmlns='http://www.w3.org/2000/svg'><rect width='100%' height='100%' style='fill:rgba(0, 54, 255, 0.13);'/></svg>");--input-focus-border-color: Highlight;--input-focus-outline: 1px solid Canvas;--input-unfocused-border-color: transparent;--input-disabled-border-color: transparent;--input-hover-border-color: black;--link-outline: none}@media screen and (forced-colors: active){:root{--input-focus-border-color: CanvasText;--input-unfocused-border-color: ActiveText;--input-disabled-border-color: GrayText;--input-hover-border-color: Highlight;--link-outline: 1.5px solid LinkText}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid selectedItem}.annotationLayer .linkAnnotation:hover{-webkit-backdrop-filter:invert(100%);backdrop-filter:invert(100%)}}.annotationLayer{position:absolute;top:0;left:0;pointer-events:none;transform-origin:0 0;z-index:3}.annotationLayer[data-main-rotation="90"] .norotate{transform:rotate(270deg) translate(-100%)}.annotationLayer[data-main-rotation="180"] .norotate{transform:rotate(180deg) translate(-100%,-100%)}.annotationLayer[data-main-rotation="270"] .norotate{transform:rotate(90deg) translateY(-100%)}.annotationLayer canvas{position:absolute;width:100%;height:100%}.annotationLayer section{position:absolute;text-align:initial;pointer-events:auto;box-sizing:border-box;margin:0;transform-origin:0 0}.annotationLayer .linkAnnotation{outline:var(--link-outline)}.textLayer.selecting~.annotationLayer section{pointer-events:none}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a{position:absolute;font-size:1em;top:0;left:0;width:100%;height:100%}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a:hover{opacity:.2;background:#ff0;box-shadow:0 2px 10px #ff0}.annotationLayer .textAnnotation img{position:absolute;cursor:pointer;width:100%;height:100%;top:0;left:0}.annotationLayer .textWidgetAnnotation :is(input,textarea),.annotationLayer .choiceWidgetAnnotation select,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{background-image:var(--annotation-unfocused-field-background);border:2px solid var(--input-unfocused-border-color);box-sizing:border-box;font:calc(9px * var(--total-scale-factor)) sans-serif;height:100%;margin:0;vertical-align:top;width:100%}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid red}.annotationLayer .choiceWidgetAnnotation select option{padding:0}.annotationLayer .buttonWidgetAnnotation.radioButton input{border-radius:50%}.annotationLayer .textWidgetAnnotation textarea{resize:none}.annotationLayer .textWidgetAnnotation :is(input,textarea)[disabled],.annotationLayer .choiceWidgetAnnotation select[disabled],.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input[disabled]{background:none;border:2px solid var(--input-disabled-border-color);cursor:not-allowed}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:hover{border:2px solid var(--input-hover-border-color)}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation.checkBox input:hover{border-radius:2px}.annotationLayer .textWidgetAnnotation :is(input,textarea):focus,.annotationLayer .choiceWidgetAnnotation select:focus{background:none;border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) :focus{background-image:none;background-color:transparent}.annotationLayer .buttonWidgetAnnotation.checkBox :focus{border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.radioButton :focus{border:2px solid var(--input-focus-border-color);outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after,.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{background-color:CanvasText;content:"";display:block;position:absolute}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{height:80%;left:45%;width:1px}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before{transform:rotate(45deg)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{transform:rotate(-45deg)}.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{border-radius:50%;height:50%;left:30%;top:20%;width:50%}.annotationLayer .textWidgetAnnotation input.comb{font-family:monospace;padding-left:2px;padding-right:0}.annotationLayer .textWidgetAnnotation input.comb:focus{width:103%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{-webkit-appearance:none;-moz-appearance:none;appearance:none}.annotationLayer .popupTriggerArea{height:100%;width:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{position:absolute;font-size:calc(9px * var(--total-scale-factor));width:100%;min-width:calc(180px * var(--total-scale-factor));pointer-events:none}.annotationLayer .popup{position:absolute;max-width:calc(180px * var(--total-scale-factor));background-color:#ff9;box-shadow:0 calc(2px * var(--total-scale-factor)) calc(5px * var(--total-scale-factor)) #888;border-radius:calc(2px * var(--total-scale-factor));padding:calc(6px * var(--total-scale-factor));margin-left:calc(5px * var(--total-scale-factor));cursor:pointer;font:message-box;white-space:normal;word-wrap:break-word;pointer-events:auto}.annotationLayer .popup>*{font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .popup h1{display:inline-block}.annotationLayer .popupDate{display:inline-block;margin-left:calc(5px * var(--total-scale-factor))}.annotationLayer .popupContent{border-top:1px solid rgba(51,51,51,1);margin-top:calc(2px * var(--total-scale-factor));padding-top:calc(2px * var(--total-scale-factor))}.annotationLayer .richText>*{white-space:pre-wrap;font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .highlightAnnotation,.annotationLayer .underlineAnnotation,.annotationLayer .squigglyAnnotation,.annotationLayer .strikeoutAnnotation,.annotationLayer .freeTextAnnotation,.annotationLayer .lineAnnotation svg line,.annotationLayer .squareAnnotation svg rect,.annotationLayer .circleAnnotation svg ellipse,.annotationLayer .polylineAnnotation svg polyline,.annotationLayer .polygonAnnotation svg polygon,.annotationLayer .caretAnnotation,.annotationLayer .inkAnnotation svg polyline,.annotationLayer .stampAnnotation,.annotationLayer .fileAttachmentAnnotation{cursor:pointer}.annotationLayer section svg{position:absolute;width:100%;height:100%;top:0;left:0}.annotationLayer .annotationTextContent{position:absolute;width:100%;height:100%;opacity:0;color:transparent;-webkit-user-select:none;user-select:none;pointer-events:none}.annotationLayer .annotationTextContent span{width:100%;display:inline-block}:root{--react-pdf-text-layer: 1;--highlight-bg-color: rgba(180, 0, 170, 1);--highlight-selected-bg-color: rgba(0, 100, 0, 1)}@media screen and (forced-colors: active){:root{--highlight-bg-color: Highlight;--highlight-selected-bg-color: ButtonText}}[data-main-rotation="90"]{transform:rotate(90deg) translateY(-100%)}[data-main-rotation="180"]{transform:rotate(180deg) translate(-100%,-100%)}[data-main-rotation="270"]{transform:rotate(270deg) translate(-100%)}.textLayer{position:absolute;text-align:initial;top:0;right:0;bottom:0;left:0;overflow:hidden;line-height:1;text-size-adjust:none;forced-color-adjust:none;transform-origin:0 0;z-index:2}.textLayer :is(span,br){color:transparent;position:absolute;white-space:pre;cursor:text;margin:0;transform-origin:0 0}.textLayer span.markedContent{top:0;height:0}.textLayer .highlight{margin:-1px;padding:1px;background-color:var(--highlight-bg-color);border-radius:4px}.textLayer .highlight.appended{position:initial}.textLayer .highlight.begin{border-radius:4px 0 0 4px}.textLayer .highlight.end{border-radius:0 4px 4px 0}.textLayer .highlight.middle{border-radius:0}.textLayer .highlight.selected{background-color:var(--highlight-selected-bg-color)}.textLayer br::selection{background:transparent}.textLayer .endOfContent{display:block;position:absolute;top:100%;right:0;bottom:0;left:0;z-index:-1;cursor:default;-webkit-user-select:none;user-select:none}.textLayer.selecting .endOfContent{top:0}.hiddenCanvasElement{position:absolute;top:0;left:0;width:0;height:0;display:none}/**
 * Copyright (c) 2014 The xterm.js authors. All rights reserved.
 * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License)
 * https://github.com/chjj/term.js
 * @license MIT
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 *
 * Originally forked from (with the author's permission):
 *   Fabrice Bellard's javascript vt100 for jslinux:
 *   http://bellard.org/jslinux/
 *   Copyright (c) 2011 Fabrice Bellard
 *   The original design remains. The terminal itself
 *   has been extended to include xterm CSI codes, among
 *   other features.
 */.xterm{cursor:text;position:relative;user-select:none;-ms-user-select:none;-webkit-user-select:none}.xterm.focus,.xterm:focus{outline:none}.xterm .xterm-helpers{position:absolute;top:0;z-index:5}.xterm .xterm-helper-textarea{padding:0;border:0;margin:0;position:absolute;opacity:0;left:-9999em;top:0;width:0;height:0;z-index:-5;white-space:nowrap;overflow:hidden;resize:none}.xterm .composition-view{background:#000;color:#fff;display:none;position:absolute;white-space:nowrap;z-index:1}.xterm .composition-view.active{display:block}.xterm .xterm-viewport{background-color:#000;overflow-y:scroll;cursor:default;position:absolute;right:0;left:0;top:0;bottom:0}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{position:absolute;left:0;top:0}.xterm-char-measure-element{display:inline-block;visibility:hidden;position:absolute;top:0;left:-9999em;line-height:normal}.xterm.enable-mouse-events{cursor:default}.xterm.xterm-cursor-pointer,.xterm .xterm-cursor-pointer{cursor:pointer}.xterm.column-select.focus{cursor:crosshair}.xterm .xterm-accessibility:not(.debug),.xterm .xterm-message{position:absolute;left:0;top:0;bottom:0;right:0;z-index:10;color:transparent;pointer-events:none}.xterm .xterm-accessibility-tree:not(.debug) *::selection{color:transparent}.xterm .xterm-accessibility-tree{font-family:monospace;-webkit-user-select:text;user-select:text;white-space:pre}.xterm .xterm-accessibility-tree>div{transform-origin:left;width:fit-content}.xterm .live-region{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{text-decoration:double underline}.xterm-underline-3{text-decoration:wavy underline}.xterm-underline-4{text-decoration:dotted underline}.xterm-underline-5{text-decoration:dashed underline}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:overline underline}.xterm-overline.xterm-underline-2{text-decoration:overline double underline}.xterm-overline.xterm-underline-3{text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{text-decoration:overline dashed underline}.xterm-strikethrough{text-decoration:line-through}.xterm-screen .xterm-decoration-container .xterm-decoration{z-index:6;position:absolute}.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer{z-index:7}.xterm-decoration-overview-ruler{z-index:8;position:absolute;top:0;right:0;pointer-events:none}.xterm-decoration-top{z-index:2;position:relative}.xterm .xterm-scrollable-element>.scrollbar{cursor:default}.xterm .xterm-scrollable-element>.scrollbar>.scra{cursor:pointer;font-size:11px!important}.xterm .xterm-scrollable-element>.visible{opacity:1;background:#0000;transition:opacity .1s linear;z-index:11}.xterm .xterm-scrollable-element>.invisible{opacity:0;pointer-events:none}.xterm .xterm-scrollable-element>.invisible.fade{transition:opacity .8s linear}.xterm .xterm-scrollable-element>.shadow{position:absolute;display:none}.xterm .xterm-scrollable-element>.shadow.top{display:block;top:0;left:3px;height:3px;width:100%;box-shadow:var(--vscode-scrollbar-shadow, #000) 0 6px 6px -6px inset}.xterm .xterm-scrollable-element>.shadow.left{display:block;top:3px;left:0;height:100%;width:3px;box-shadow:var(--vscode-scrollbar-shadow, #000) 6px 0 6px -6px inset}.xterm .xterm-scrollable-element>.shadow.top-left-corner{display:block;top:0;left:0;height:3px;width:3px}.xterm .xterm-scrollable-element>.shadow.top.left{box-shadow:var(--vscode-scrollbar-shadow, #000) 6px 0 6px -6px inset}.camera-page{display:flex;flex-direction:column;gap:1.25rem}.camera-page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.camera-page-header h1{margin:0;font-size:1.75rem;letter-spacing:-.02em}.camera-page-header p{margin:.35rem 0 0;color:var(--text-secondary)}.camera-header-actions{display:flex;gap:.65rem;flex-wrap:wrap}.camera-grid-top,.camera-grid-bottom{display:grid;gap:1rem}.camera-grid-top{grid-template-columns:1.15fr .85fr}.camera-grid-bottom{grid-template-columns:1fr .95fr}.camera-card{background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid var(--border-color);border-radius:18px;box-shadow:var(--shadow-sm);min-height:240px;display:flex;flex-direction:column;overflow:hidden}.camera-card-head{padding:1rem 1rem .9rem;border-bottom:1px solid #e7eef8;display:flex;justify-content:space-between;align-items:flex-start;gap:.8rem}.camera-card-head h2{margin:0;display:inline-flex;align-items:center;gap:.4rem;font-size:1rem}.camera-card-head p{margin:.25rem 0 0;color:var(--text-secondary);font-size:.85rem}.live-frame{margin:1rem;border-radius:14px;overflow:hidden;border:1px solid #d6e5f8;background:#111827;min-height:320px}.live-frame img{width:100%;height:100%;display:block;object-fit:cover}.log-state{border-radius:999px;padding:.2rem .55rem;font-size:.72rem;font-weight:700;text-transform:capitalize;display:inline-flex;align-items:center;gap:.35rem}.log-state.connected{color:#065f46;background:#d1fae5}.log-state.connecting,.log-state.disconnected{color:#7c2d12;background:#ffedd5}.logs-list{padding:.8rem;max-height:360px;overflow:auto;display:flex;flex-direction:column;gap:.55rem}.log-item{border:1px solid #e2e8f0;border-radius:12px;background:#fff;padding:.6rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.log-item-main{min-width:0;flex:1}.log-meta-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.log-time{color:var(--text-muted);font-size:.8rem}.log-student{margin-top:.3rem;font-size:.82rem;display:inline-flex;align-items:center;gap:.3rem;color:var(--text-secondary)}.log-type{font-size:.72rem;border-radius:999px;padding:.2rem .55rem;font-weight:700;text-transform:uppercase}.log-type.success{color:#065f46;background:#d1fae5}.log-type.info{color:#1e40af;background:#dbeafe}.log-type.warning{color:#92400e;background:#fef3c7}.log-type.danger{color:#991b1b;background:#fee2e2}.log-type.neutral{color:#334155;background:#e2e8f0}.log-face-thumb{width:54px;height:54px;border-radius:10px;object-fit:cover;border:1px solid #dbeafe}.faces-toolbar{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}.faces-toolbar select,.gesture-panel select{border:1px solid var(--border-color);border-radius:10px;padding:.55rem .75rem;font-family:inherit;font-size:1rem;background:#fff;cursor:pointer}.faces-grid{padding:.9rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.65rem;max-height:390px;height:390px;overflow-y:auto;overflow-x:hidden}.faces-grid.few-1{grid-template-columns:1fr}.faces-grid.few-2{grid-template-columns:repeat(2,minmax(220px,1fr))}.faces-grid.few-3{grid-template-columns:repeat(3,minmax(180px,1fr))}.face-card{border:1px solid #dbe7f6;border-radius:12px;overflow:hidden;background:#fff;display:flex;flex-direction:column;cursor:zoom-in;transition:transform .2s ease,box-shadow .2s ease}.faces-grid .face-card.face-card-full{min-height:206px}.face-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.face-card img{width:100%;height:132px;object-fit:cover;display:block;flex-shrink:0}.faces-grid .face-card.face-card-full img{height:132px!important}.faces-grid.few-1 .face-card img,.faces-grid.few-2 .face-card img,.faces-grid.few-3 .face-card img{height:210px}.face-card-body{padding:.5rem;background:#f8fbff;border-top:1px solid #e7eef8;min-height:62px;display:block}.face-card-top{display:flex;justify-content:space-between;align-items:center;gap:.4rem}.faces-grid .face-card .face-card-body{display:block!important;visibility:visible!important;opacity:1!important}.face-card-body p{margin:.38rem 0 0;font-size:.75rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.face-card-meta{margin:.28rem 0 0;font-size:.7rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.icon-btn{border:1px solid #fecaca;background:#fff1f2;color:#be123c;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;padding:.25rem;cursor:pointer}.faces-pagination{border-top:1px solid #e7eef8;padding:.72rem .9rem;display:flex;justify-content:space-between;align-items:center;gap:.8rem;flex-wrap:wrap;color:var(--text-secondary);font-size:.85rem}.pager-actions{display:flex;gap:.4rem}.gesture-panel{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:.75rem;padding:1rem}.gesture-panel label{display:flex;flex-direction:column;gap:.38rem;font-size:.82rem;color:var(--text-secondary);font-weight:600}.gesture-summary{margin:0 1rem;border:1px solid #e4ebf5;border-radius:12px;padding:.75rem;background:#f8fbff;display:grid;grid-template-columns:1fr 1fr;gap:.8rem}.gesture-summary h4{margin:0;font-size:.82rem;color:var(--text-muted)}.gesture-summary p{margin:.25rem 0 0;font-size:.85rem;color:var(--text-primary)}.gesture-notes{padding:.8rem 1rem 0}.gesture-notes .warn,.gesture-notes .ok{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;font-weight:600}.gesture-notes .warn{color:#b45309}.gesture-notes .ok{color:#0f766e}.gesture-actions{padding:.95rem 1rem 1rem;display:flex;justify-content:flex-end;gap:.55rem;flex-wrap:wrap}.last-checked{font-size:.75rem;color:var(--text-muted)}.empty-state{min-height:100px;border:1px dashed #dbeafe;border-radius:12px;color:var(--text-secondary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;padding:.8rem;text-align:center;font-size:.86rem}.danger-soft{color:#be123c;border-color:#fecaca;background:#fff1f2}.face-preview-wrap{display:flex;flex-direction:column;gap:.85rem}.face-preview-image{width:100%;max-height:340px;border-radius:12px;object-fit:contain;background:#0f172a}.face-preview-meta{border:1px solid var(--border-color);border-radius:12px;padding:.75rem;background:#f8fafc}.face-preview-meta p{margin:.25rem 0;word-break:break-word;color:var(--text-secondary)}@media (max-width: 1180px){.camera-grid-top,.camera-grid-bottom{grid-template-columns:1fr}}@media (max-width: 720px){.camera-header-actions{width:100%}.camera-header-actions .btn{flex:1;justify-content:center}.gesture-panel,.gesture-summary{grid-template-columns:1fr}.faces-pagination{flex-direction:column;align-items:flex-start}.faces-grid.few-2,.faces-grid.few-3{grid-template-columns:1fr}}:root{--primary-color: #1E293B;--secondary-color: #334155;--accent-color: #E8720C;--accent-light: #FF9643;--accent-bg: rgba(232, 114, 12, .08);--accent-bg-hover: rgba(232, 114, 12, .14);--background-color: #F1F5F9;--card-bg: #ffffff;--surface-raised: #ffffff;--surface-hover: #F8FAFC;--text-primary: #1E293B;--text-secondary: #64748B;--text-muted: #94A3B8;--border-color: #E2E8F0;--border-light: #F1F5F9;--success: #10B981;--success-bg: #ECFDF5;--warning: #F59E0B;--warning-bg: #FFFBEB;--danger: #EF4444;--danger-bg: #FEF2F2;--info: #3B82F6;--info-bg: #EFF6FF;--sidebar-width: 234px;--header-height: 54px;--page-max-width: 1116px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -1px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -2px rgba(0, 0, 0, .04);font-family:Be Vietnam Pro,system-ui,-apple-system,sans-serif;line-height:1.6;background-color:var(--background-color);color:var(--text-primary)}html{font-size:80%}*{box-sizing:border-box}svg.lucide{flex-shrink:0}body{margin:0;min-height:100vh}#root{display:flex;flex-direction:column;min-height:100vh}.app-layout{display:flex;min-height:100vh}.app-layout.no-sidebar{display:flex;flex-direction:column}.main-content{flex:1;padding:2rem;margin-left:var(--sidebar-width);margin-top:var(--header-height);transition:margin-left .3s ease}.main-content.no-sidebar{margin-left:0}.page-container{max-width:var(--page-max-width);width:100%;margin:0 auto}input[type=number].no-spinner::-webkit-outer-spin-button,input[type=number].no-spinner::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number].no-spinner{-moz-appearance:textfield}.kanban-scroll-container::-webkit-scrollbar{height:10px}.kanban-scroll-container::-webkit-scrollbar-track{background:#f1f5f9;border-radius:10px}.kanban-scroll-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px;border:2px solid #f1f5f9}.kanban-scroll-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}.custom-scrollbar{scrollbar-width:thin;scrollbar-color:#e2e8f0 transparent}.custom-scrollbar::-webkit-scrollbar{width:2px;height:2px}.custom-scrollbar::-webkit-scrollbar-track{background:transparent}.custom-scrollbar::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:99px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:#cbd5e1}.page-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.page-header h1{margin:0;font-size:2.25rem;font-weight:800;letter-spacing:-.02em;color:var(--text-primary);line-height:1.2}.page-header p{color:var(--text-secondary);margin:6px 0 0;font-size:1rem;font-weight:500}.top-header{height:var(--header-height);background:var(--card-bg);border-bottom:1px solid var(--border-color);position:fixed;left:0;right:0;top:0;display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;z-index:1001}.header-left{display:flex;align-items:center;gap:1.5rem;flex:1}.header-center{flex:1;display:flex;justify-content:center}.header-right{flex:1;display:flex;justify-content:flex-end;gap:16px;align-items:center;padding-right:8px}.header-brand{display:flex;align-items:center;gap:10px;flex-shrink:0}.header-logo-text{font-size:1.15rem;font-weight:800;color:var(--accent-color);margin:0;letter-spacing:-.3px}.header-nav{display:flex;align-items:center;gap:4px}.header-nav-link{display:flex;align-items:center;gap:7px;padding:8px 14px;font-size:.85rem;font-weight:600;color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-sm);transition:all .2s ease;white-space:nowrap;position:relative}.header-nav-link:hover{color:var(--text-primary);background:var(--accent-bg)}.header-nav-link.active{color:var(--accent-color);background:var(--accent-bg)}.header-nav-link.active:after{content:"";position:absolute;bottom:-12px;left:12%;right:12%;height:3px;background:var(--accent-color);border-radius:3px 3px 0 0}.header-search{position:relative;width:100%;max-width:380px}.header-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.header-search-input{width:100%;padding:7px 12px 7px 36px;border-radius:var(--radius-full);border:1px solid var(--border-color);background:var(--background-color);font-size:.85rem;outline:none;transition:all .2s ease;font-family:inherit;color:var(--text-primary)}.header-search-input:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #e8720c1a;background:#fff}.header-icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:none;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all .2s}.header-icon-btn:hover{background:var(--accent-bg);color:var(--accent-color)}.header-user{display:flex;align-items:center;gap:10px;cursor:pointer;padding:6px 12px;border-radius:var(--radius-sm);transition:background .2s}.header-user:hover{background:var(--surface-hover)}.header-user-info{text-align:right;max-width:160px;min-width:0}.header-user-name{display:block;font-size:.85rem;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-user-role{display:block;font-size:.7rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--accent-color),var(--accent-light));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.sidebar{width:var(--sidebar-width);background:#f8fafc;color:#334155;position:fixed;height:calc(100vh - var(--header-height));left:0;top:var(--header-height);z-index:1000;display:flex;flex-direction:column;border-right:1px solid #e2e8f0}.sidebar-header{padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0}.sidebar-brand{display:flex;align-items:center;gap:12px}.sidebar-brand-icon{width:36px;height:36px;border-radius:var(--radius-md);background:var(--accent-color);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 4px 10px #e8720c40}.sidebar-title{color:#1e293b;margin:0;font-size:.95rem;font-weight:700}.sidebar-subtitle{font-size:.7rem;color:#94a3b8;font-weight:500}.sidebar-nav{padding:.75rem 0;flex:1;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.sidebar-nav::-webkit-scrollbar{display:none}.sidebar-section-label{padding:1rem 1.5rem .5rem;font-size:.6rem;font-weight:800;color:#b0bec5;text-transform:uppercase;letter-spacing:1.5px}.sidebar-link{display:flex;align-items:center;gap:12px;padding:.7rem 1.5rem;color:#64748b;text-decoration:none;font-size:.875rem;font-weight:500;transition:all .15s ease;border-left:3px solid transparent;background-color:transparent}.sidebar-link:hover{color:#1e293b;background:#eef2f6}.sidebar-link.active{color:var(--accent-color);background:#e8720c12;border-left-color:var(--accent-color);font-weight:700}.sidebar-link-icon{display:flex;align-items:center;justify-content:center;width:20px}.sidebar-link-label{flex:1}.sidebar-footer{padding:1rem 1.5rem;border-top:1px solid #e2e8f0}.sidebar-dev-link{display:flex;align-items:center;gap:10px;color:#ffffff4d;text-decoration:none;font-size:.78rem;transition:color .2s}.sidebar-dev-link:hover{color:#fff9}.card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1.5rem;box-shadow:var(--shadow-xs);margin-bottom:1.5rem;transition:box-shadow .2s ease,transform .2s ease}.card:hover{box-shadow:var(--shadow-sm)}.card-body{padding:1.5rem;flex:1}.card-footer{padding:1rem 1.5rem;background:var(--surface-hover);border-top:1px solid var(--border-light);display:flex;justify-content:space-between;align-items:center}.card-interactive{cursor:pointer;padding:0;display:flex;flex-direction:column}.card-interactive:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}h1{font-size:2.25rem;font-weight:800;letter-spacing:-.02em;line-height:1.2}h2{font-size:1.75rem;font-weight:800;letter-spacing:-.01em}h3{font-size:1.15rem;font-weight:700}h4{font-size:1rem;font-weight:700}a{color:var(--accent-color);text-decoration:none;transition:color .2s}a:hover{color:var(--primary-color)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.badge-accent{background:var(--accent-bg);color:var(--accent-color)}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-muted{background:var(--border-light);color:var(--text-secondary)}.tag{display:inline-flex;align-items:center;padding:4px 10px;background:var(--background-color);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:9px 20px;font-size:.875rem;font-weight:600;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;border:1px solid transparent;outline:none;font-family:inherit}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent-color);color:#fff;box-shadow:0 2px 8px #e8720c40}.btn-primary:hover:not(:disabled){background:#d4670b;box-shadow:0 4px 14px #e8720c59;transform:translateY(-1px)}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none;box-shadow:none;transform:none}.btn-secondary{background:var(--background-color);color:var(--text-secondary);border-color:var(--border-color)}.btn-secondary:hover{background:var(--border-color);color:var(--text-primary)}.btn-outline{background:transparent;color:var(--accent-color);border-color:var(--accent-color)}.btn-outline:hover{background:var(--accent-bg);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-secondary);border:none;padding:6px 12px}.btn-ghost:hover{background:var(--accent-bg);color:var(--accent-color)}.btn-danger{background:#e11d48;color:#fff;border-color:#e11d48;box-shadow:0 2px 8px #e11d4840}.btn-danger:hover:not(:disabled){background:#be123c;border-color:#be123c;box-shadow:0 4px 14px #e11d4859;transform:translateY(-1px)}.stat-widget{display:flex;align-items:center;gap:1rem;padding:1.25rem}.stat-widget-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-widget-label{font-size:.8rem;color:var(--text-secondary);margin:0}.stat-widget-value{font-size:1.35rem;font-weight:700;color:var(--text-primary);margin:0}.progress-bar-track{height:6px;background:var(--border-light);border-radius:3px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-color),var(--accent-light));border-radius:3px;transition:width .5s ease-out}.avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.avatar-sm{width:24px;height:24px;font-size:.65rem}.avatar-md{width:36px;height:36px;font-size:.85rem}.avatar-lg{width:48px;height:48px;font-size:1.1rem}.avatar-brand{background:var(--primary-color);color:#fff}.avatar-accent{background:linear-gradient(135deg,var(--accent-color),var(--accent-light));color:#fff}.section-title{font-size:.7rem;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 1rem}.empty-state{text-align:center;padding:3rem 2rem;display:flex;flex-direction:column;align-items:center}.empty-state-icon{width:72px;height:72px;border-radius:50%;background:var(--border-light);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;color:var(--text-muted)}.empty-state h2{font-size:1.3rem;margin-bottom:.5rem}.empty-state p{color:var(--text-secondary);margin-bottom:1.5rem}.form-group{margin-bottom:1.5rem}.form-label{display:block;margin-bottom:.5rem;font-size:.85rem;font-weight:600;color:var(--text-secondary)}.form-input{width:100%;padding:10px 14px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;transition:all .2s;background-color:#fff;font-family:inherit;color:var(--text-primary)}.form-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #e8720c1a}.form-input::placeholder{color:var(--text-muted)}.filter-chip{padding:7px 18px;border-radius:var(--radius-full);font-size:.82rem;font-weight:600;white-space:nowrap;cursor:pointer;border:1px solid var(--border-color);background:#fff;color:var(--text-secondary);transition:all .2s;font-family:inherit}.filter-chip:hover{border-color:var(--accent-color);color:var(--accent-color)}.filter-chip.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.main-content{margin-left:0}.top-header{left:0}.header-nav-link span{display:none}.header-search{max-width:160px}.header-user-info{display:none}}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#1e293b66;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10000;animation:overlayFadeIn .4s cubic-bezier(.16,1,.3,1)}.premium-loader{position:relative;width:80px;height:80px}.premium-loader div{position:absolute;box-sizing:border-box;width:100%;height:100%;border:4px solid transparent;border-top-color:var(--accent-color);border-radius:50%;animation:premiumRotate 1.2s cubic-bezier(.5,0,.5,1) infinite}.premium-loader div:nth-child(1){border-top-color:var(--accent-color);animation-delay:-.45s}.premium-loader div:nth-child(2){border-top-color:var(--accent-light);width:70%;height:70%;top:15%;left:15%;animation-delay:-.3s;animation-direction:reverse}.premium-loader div:nth-child(3){border-top-color:#fff;width:40%;height:40%;top:30%;left:30%;animation-delay:-.15s}.loading-text{margin-top:32px;font-size:1.1rem;font-weight:700;color:#fff;letter-spacing:.5px;text-shadow:0 2px 4px rgba(0,0,0,.2);animation:pulseText 2s ease-in-out infinite}.loading-subtext{margin-top:8px;font-size:.85rem;color:#ffffffb3;font-weight:500}@keyframes premiumRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes overlayFadeIn{0%{opacity:0;background:#1e293b00;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}to{opacity:1;background:#1e293b66;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}@keyframes pulseText{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.02)}}.spinner{animation:rotate 1s linear infinite;display:inline-block}.pulse{animation:pulse-animation 1.5s infinite}.animate-spin{animation:rotate 1s linear infinite}@keyframes rotate{to{transform:rotate(360deg)}}.table-container{width:100%;overflow-x:auto;border-radius:var(--radius-md)}.table{width:100%;border-collapse:collapse;font-size:.875rem;text-align:left}.table thead{background:#f8fafc;border-bottom:2px solid var(--border-color);position:sticky;top:0;z-index:10}.table th{padding:16px 20px;font-weight:800;color:#334155;text-transform:uppercase;font-size:.7rem;letter-spacing:.075em;white-space:nowrap;vertical-align:middle}.table td{padding:14px 16px;border-bottom:1px solid var(--border-color);color:var(--text-primary);vertical-align:middle}.table tbody tr{transition:background-color .2s ease,transform .1s ease}.table tbody tr:hover{background:#fbfcfd}.table-row-active{background:var(--accent-bg)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:5000;animation:fadeIn .2s ease-out}.modal-container{background:#fff;width:95%;max-width:780px;max-height:90vh;border-radius:var(--radius-lg);box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;position:relative;overflow:hidden;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.modal-header{padding:1.25rem 2rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.modal-body{padding:2rem;overflow-y:auto;flex:1}.modal-footer{padding:1.25rem 2rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:12px;background:var(--surface-hover)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pulse-animation{0%{box-shadow:0 0 #e8720c66}to{box-shadow:0 0 0 10px #e8720c00}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-subtle{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.fade-in{animation:fadeIn .3s ease-out forwards}.um-add-form{margin-bottom:1.5rem;border-left:4px solid var(--accent-color);animation:um-slide-down .25s ease-out}@keyframes um-slide-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes notiSlideIn{0%{opacity:0;transform:translateY(-10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.um-form-grid{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:1rem;align-items:flex-end}.um-form-field{display:flex;flex-direction:column;gap:6px}.um-form-field label{font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:6px}.um-form-field .form-input{padding:.65rem .85rem;border-radius:var(--radius-sm);border:1.5px solid var(--border-color);font-size:.9rem;outline:none;transition:border-color .2s,box-shadow .2s;font-family:inherit;width:100%;background:#fff}.um-form-field .form-input:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #e8720c14}.um-form-actions{display:flex;align-items:flex-end;padding-bottom:1px}.um-alert{padding:.7rem 1rem;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:8px;margin-bottom:1rem}.um-alert-error{background:var(--danger-bg);color:var(--danger)}.um-alert-success{background:var(--success-bg);color:var(--success)}.um-table-wrapper{border-radius:var(--radius-md);border:1px solid var(--border-color)}.um-table{width:100%;border-collapse:collapse;font-size:.9rem}.um-table thead{background:var(--background-color)}.um-table th{padding:.7rem 1rem;text-align:left;font-size:.7rem;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color)}.um-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-light);vertical-align:middle}.um-row{cursor:pointer;transition:background .15s}.um-row:hover{background:var(--surface-hover)}.um-row-expanded{background:var(--accent-bg)!important}.um-confirm-row td{padding:0!important;border-bottom:1px solid var(--danger-bg)}.um-confirm-bar{display:flex;align-items:center;gap:10px;padding:.6rem 1rem;background:var(--danger-bg);font-size:.85rem;animation:um-slide-down .2s ease-out}.um-detail-row td{padding:0!important;border-bottom:1px solid var(--border-color)}.um-detail-panel{padding:1.5rem;background:linear-gradient(135deg,var(--background-color),white);animation:um-slide-down .2s ease-out}.um-detail-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.um-detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem}.um-detail-item{display:flex;flex-direction:column;gap:4px;min-width:0}.um-detail-value{min-width:0;overflow-wrap:anywhere;word-break:break-word;line-height:1.35}.um-detail-label{font-size:.68rem;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;display:flex;align-items:center;gap:4px}@media (max-width: 900px){.um-form-grid,.um-edit-grid{grid-template-columns:1fr}}.um-edit-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}@keyframes appSelectMenuIn{0%{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.bk-card{background:#fff;border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow-xs)}.bk-scroll{scrollbar-width:thin;scrollbar-color:#e2e8f0 transparent}.bk-scroll::-webkit-scrollbar{width:2px;height:2px}.bk-scroll::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:99px}.bk-scroll::-webkit-scrollbar-thumb:hover{background:#cbd5e1}.bk-scroll::-webkit-scrollbar-track{background:transparent}@keyframes bk-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.bk-fade-in{animation:bk-fade-in .2s ease-out both}@keyframes bk-pulse{0%,to{box-shadow:0 0 #e8720c59}50%{box-shadow:0 0 0 6px #e8720c00}}.bk-pulse{animation:bk-pulse 1.8s ease-in-out infinite}.bk-kanban-col{flex:1 1 220px;min-width:220px;max-width:340px;display:flex;flex-direction:column;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0;overflow:hidden}.bk-cal-cell{transition:background .12s}.bk-cal-cell:hover{background:var(--surface-hover)!important}.bk-cal-event:hover{filter:brightness(.96)}.icon-btn{width:34px;height:34px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border-color);background:#fff;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}.icon-btn:hover{background:var(--surface-hover);color:var(--text-primary)}
