*,:before,:after,::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.grow{flex-grow:1}.resize{resize:both}.border{border-width:1px}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.outline{outline-style:solid}.blur{--tw-blur:blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}:root{--color-primary:#0095b5;--color-primary-hover:#007692;--color-primary-dark:#2478b5;--color-primary-highlight:#cff2fe;--color-bg:#f6fbff;--color-surface:#fff;--color-text:#1a2b3c;--color-text-muted:#5a7189;--color-text-subtle:#8aa0b5;--color-success:#278733;--color-warning:#dd8736;--color-info:#008e95;--color-error:#cf4047;--ao1:#7c3aed;--ao2:#2563eb;--ao3:#0d9488;--ao1-bg:#7c3aed26;--ao2-bg:#2563eb21;--ao3-bg:#0d948821;--font-display:"Satoshi", "Inter", system-ui, sans-serif;--font-body:"Inter", system-ui, sans-serif;--font-hand:"Caveat", cursive;--font-serif:"Lora", Georgia, serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:22px;--radius-full:999px;--shadow-sm:0 1px 2px #1a2b3c0f, 0 1px 0 #1a2b3c08;--shadow-md:0 4px 16px #1a2b3c14, 0 1px 2px #1a2b3c0a;--shadow-lg:0 12px 32px #1a2b3c1f, 0 4px 8px #1a2b3c0f;--shadow-hero:0 40px 80px #3ca0dc2e, 0 12px 32px #3ca0dc1a;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--space-20:80px;--space-24:96px;--sidebar-w:240px;--topbar-h:60px;--app-radius:14px;--row-border:#1a2b3c12;--row-hover:#3b9edb0f}@supports (color:lab(0% 0 0)){:root{--color-primary:lab(56.5296% -28.7363 -30.4295);--color-primary-hover:lab(44.9116% -29.167 -32.4647);--color-primary-highlight:lab(93.2768% -10.0244 -9.74146);--color-success:lab(49.5829% -42.1882 35.8774);--color-warning:lab(64.6349% 29.1705 55.612);--color-info:lab(52.5215% -40.453 -16.5377);--color-error:lab(49.4139% 57.3948 29.9528)}}*,:before,:after{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font-body);color:var(--color-text);background:var(--color-surface);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.5}img,svg{max-width:100%;display:block}button{font:inherit;cursor:pointer;color:inherit;background:0 0;border:none;padding:0}a{color:inherit;text-decoration:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);letter-spacing:-.02em;color:var(--color-text);margin:0;line-height:1.1}p{margin:0}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 24px}.eyebrow{font-family:var(--font-display);letter-spacing:.14em;text-transform:uppercase;color:var(--color-primary);font-size:12px;font-weight:500}.section-heading{font-family:var(--font-display);letter-spacing:-.025em;margin-top:12px;font-size:clamp(28px,3.4vw,44px);font-weight:700;line-height:1.1}.btn{font-family:var(--font-display);border-radius:var(--radius-full);white-space:nowrap;justify-content:center;align-items:center;gap:8px;height:44px;padding:0 22px;font-size:15px;font-weight:600;transition:background .18s,color .18s,transform .18s,box-shadow .18s;display:inline-flex}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 6px 18px #3b9edb52,inset 0 1px #fff6}.btn-primary:hover{background:var(--color-primary-hover);transform:translateY(-1px)}.btn-ghost{color:var(--color-text)}.btn-ghost:hover{color:var(--color-primary)}.btn-outline{color:var(--color-text);background:#fff;border:1.5px solid #1a2b3c29}.btn-outline:hover{border-color:var(--color-primary);color:var(--color-primary)}.btn-lg{height:50px;padding:0 26px;font-size:16px}.btn-sm{height:36px;padding:0 14px;font-size:13.5px}.pill-badge{background:var(--color-primary-highlight);color:var(--color-primary-dark);font-family:var(--font-display);letter-spacing:.01em;border-radius:var(--radius-full);border:1px solid #3b9edb2e;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;display:inline-flex}.nav{z-index:100;-webkit-backdrop-filter:blur(12px)saturate(160%);background:#ffffffd9;transition:box-shadow .2s;position:sticky;top:0}.nav.scrolled{box-shadow:0 1px #1a2b3c14}.nav-inner{justify-content:space-between;align-items:center;height:68px;display:flex}.nav-brand{font-family:var(--font-display);letter-spacing:-.02em;align-items:center;gap:10px;font-size:19px;font-weight:700;display:flex}.nav-logo{background:var(--color-primary);border-radius:9px;place-items:center;width:32px;height:32px;display:grid;box-shadow:0 4px 12px #3b9edb59}.nav-links{font-family:var(--font-display);color:var(--color-text-muted);gap:32px;font-size:14px;font-weight:500;display:flex}.nav-links a{transition:color .15s}.nav-links a:hover{color:var(--color-primary)}.nav-actions{align-items:center;gap:12px;display:flex}.nav-cta{height:40px;padding:0 18px;font-size:14px}@media (max-width:760px){.nav-links{display:none}}.hero{background:radial-gradient(90% 70% at 50% 20%,#e0f2ff 0%,#bfe0fa 45%,#97cbee 100%);min-height:90vh;padding:56px 0 96px;position:relative;overflow:hidden}.hero:before{content:"";opacity:.18;pointer-events:none;mix-blend-mode:overlay;background-image:radial-gradient(#fff9 1px,#0000 1px);background-size:24px 24px;position:absolute;inset:0}.hero-grain{pointer-events:none;opacity:.04;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2'/></filter><rect width='200' height='200' filter='url(%23n)' opacity='1'/></svg>");position:absolute;inset:0}.hero-inner{text-align:center;align-items:start;gap:56px;display:grid;position:relative}.hero-text{justify-items:center;gap:20px;max-width:760px;margin:0 auto;display:grid}.hero-h1{font-family:var(--font-display);letter-spacing:-.03em;font-size:clamp(40px,5.4vw,64px);font-weight:700;line-height:1.04}.hero-h1 em{background:linear-gradient(120deg, var(--color-primary-dark), #56c0f0);color:#0000;-webkit-background-clip:text;background-clip:text;font-style:normal}.hero-sub{color:var(--color-text-muted);max-width:60ch;font-size:18px;line-height:1.6}.hero-cta-row{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:4px;display:flex}.hero-mockup-wrap{perspective:1400px;width:100%;max-width:1140px;margin:0 auto;padding:0 8px;animation:6s ease-in-out infinite float;position:relative;overflow:visible}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.paper-card{-webkit-backdrop-filter:blur(20px)saturate(180%);border-radius:var(--radius-2xl);box-shadow:var(--shadow-hero);background:#ffffffc7;border:1px solid #ffffffb3;grid-template-columns:1fr 1fr;gap:0;display:grid;position:relative;overflow:hidden;transform:rotateX(2deg)}.paper-panel{background-image:repeating-linear-gradient(#0000 0 27px,#1a2b3c0f 27px 28px);background-position:0 36px;background-size:100% 28px;min-height:540px;padding:32px 36px 28px;position:relative}.paper-panel.left{background-color:#fdfdfc;border-right:1px dashed #1a2b3c1a}.paper-panel.right{background-color:#fafcff}.paper-panel:before{content:"";background:#dc4c3a52;width:1px;position:absolute;top:0;bottom:0;left:64px}.paper-panel.right:before{background:#3b9edb40}.paper-q{font-family:var(--font-serif);color:#3a4a5c;margin-bottom:18px;padding-left:28px;font-size:12.5px;line-height:1.65;position:relative}.paper-q-head{color:#1a2b3c;justify-content:space-between;align-items:baseline;margin-bottom:6px;font-weight:600;display:flex}.paper-q-marks{font-family:var(--font-display);color:var(--color-text-muted);letter-spacing:.04em;font-size:11px}.paper-q-text{font-style:italic}.handwritten-answer{font-family:var(--font-hand);color:#1f3147;letter-spacing:.01em;padding-left:28px;font-size:18px;line-height:1.75}.handwritten-answer p{margin:0 0 14px}.ao-toolbar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-full);width:fit-content;box-shadow:var(--shadow-sm);background:#ffffffd9;border:1px solid #1a2b3c14;flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:18px;margin-left:28px;padding:8px 12px;display:flex}.ao-toolbar .label{font-family:var(--font-display);color:var(--color-text);align-items:center;gap:8px;font-size:12.5px;font-weight:500;display:flex}.toggle{background:#1a2b3c2e;border-radius:999px;width:32px;height:18px;transition:background .18s;position:relative}.toggle:after{content:"";background:#fff;border-radius:50%;width:14px;height:14px;transition:left .18s;position:absolute;top:2px;left:2px;box-shadow:0 1px 2px #0000002e}.toggle[aria-checked=true]{background:var(--color-primary)}.toggle[aria-checked=true]:after{left:16px}.ao-legend{font-family:var(--font-display);color:var(--color-text-muted);border-left:1px solid #1a2b3c1a;gap:10px;padding-left:10px;font-size:11.5px;font-weight:500;display:flex}.ao-legend .dot{align-items:center;gap:5px;display:inline-flex}.ao-legend .dot:before{content:"";background:currentColor;border-radius:50%;width:8px;height:8px}.ao-legend .ao1{color:var(--ao1)}.ao-legend .ao2{color:var(--ao2)}.ao-legend .ao3{color:var(--ao3)}.answer-converted{font-family:var(--font-body);color:var(--color-text);padding-left:28px;padding-right:8px;font-size:13px;line-height:1.95}.answer-converted p{margin-bottom:9px}.ao-highlight{cursor:pointer;border-radius:3px;outline:1.5px solid #0000;padding:1px 3px;transition:background-color .2s,outline .15s;display:inline;position:relative}.show-ao .ao-highlight[data-ao=AO1]{background:var(--ao1-bg)}.show-ao .ao-highlight[data-ao=AO2]{background:var(--ao2-bg)}.show-ao .ao-highlight[data-ao=AO3]{background:var(--ao3-bg)}.show-ao .ao-highlight[data-ao=AO1]:hover,.show-ao .ao-highlight[data-ao=AO1].active{outline-color:var(--ao1)}.show-ao .ao-highlight[data-ao=AO2]:hover,.show-ao .ao-highlight[data-ao=AO2].active{outline-color:var(--ao2)}.show-ao .ao-highlight[data-ao=AO3]:hover,.show-ao .ao-highlight[data-ao=AO3].active{outline-color:var(--ao3)}.summary-strip{background:linear-gradient(180deg, var(--color-primary-highlight), #eaf6fe);border-radius:var(--radius-lg);border:1px solid #3b9edb2e;margin:18px 28px 4px;padding:14px 16px 16px}.summary-head{justify-content:space-between;align-items:center;gap:14px;margin-bottom:12px;display:flex}.score-block .label{letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);font-size:11px;font-family:var(--font-display);margin-bottom:2px;font-weight:500}.score-block .val{font-family:var(--font-display);color:var(--color-primary-dark);letter-spacing:-.02em;font-size:26px;font-weight:700;line-height:1}.score-block .score-of{color:var(--color-text-muted);margin-left:2px;font-size:15px;font-weight:600}.ap-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.ap-block{border-radius:var(--radius-md);background:#ffffffb3;border:1px solid #ffffffe6;padding:10px 12px}.ap-block .ap-title{font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;align-items:center;gap:6px;margin-bottom:6px;font-size:11px;font-weight:600;display:flex}.ap-block .ap-title svg{width:12px;height:12px}.ap-block.ap-good .ap-title{color:var(--color-success)}.ap-block.ap-improve .ap-title{color:var(--color-primary-dark)}.ap-block ul{color:var(--color-text);gap:3px;margin:0;padding:0;font-size:12px;line-height:1.45;list-style:none;display:grid}.ap-block li{padding-left:12px;position:relative}.ap-block.ap-good li:before{content:"✓";color:var(--color-success);font-size:11px;font-weight:700;position:absolute;left:0}.ap-block.ap-improve li:before{content:"→";color:var(--color-primary-dark);font-size:11px;font-weight:700;position:absolute;left:0}.sent-chip{font-family:var(--font-display);color:#fff;background:var(--color-success);border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:6px;padding:5px 10px;font-size:11px;font-weight:600;display:inline-flex}.reviews-bar{background:#fff;border-top:1px solid #1a2b3c12;border-bottom:1px solid #1a2b3c12;align-items:center;height:88px;display:flex;position:relative;overflow:hidden}.reviews-bar:before,.reviews-bar:after{content:"";z-index:2;pointer-events:none;width:80px;position:absolute;top:0;bottom:0}.reviews-bar:before{background:linear-gradient(90deg,#fff,#0000);left:0}.reviews-bar:after{background:linear-gradient(270deg,#fff,#0000);right:0}.reviews-track{gap:18px;width:max-content;padding-left:18px;animation:60s linear infinite marquee-left;display:flex}.reviews-bar:hover .reviews-track{animation-play-state:paused}@keyframes marquee-left{0%{transform:translate(0)}to{transform:translate(-50%)}}.review-pill{border-radius:var(--radius-full);color:var(--color-text);white-space:nowrap;background:#fff;border:1px solid #1a2b3c14;align-items:center;gap:10px;padding:8px 16px;font-size:13px;display:flex}.review-pill .stars{color:#f59e0b;letter-spacing:1px;font-size:12px}.review-pill .quote{font-style:italic}.review-pill .who{color:var(--color-text-muted);font-size:12px}.section{padding:clamp(80px,9vw,128px) 0}.section-tint{background:var(--color-bg)}.section-head{text-align:center;margin-bottom:56px}.section-head p{color:var(--color-text-muted);max-width:56ch;margin-top:14px;margin-left:auto;margin-right:auto;font-size:17px}.how-grid{grid-template-columns:repeat(4,1fr);gap:24px;display:grid;position:relative}.how-grid:before{content:"";z-index:0;border-top:2px dashed #3b9edb59;height:1px;position:absolute;top:96px;left:10%;right:10%}@media (max-width:1100px){.how-grid{grid-template-columns:repeat(2,1fr)}.how-grid:before{display:none}}@media (max-width:620px){.how-grid{grid-template-columns:1fr}}.how-card{border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);z-index:1;background:#fff;border:1px solid #1a2b3c0d;padding:32px 28px 28px;position:relative;overflow:hidden}.how-card .ghost-num{font-family:var(--font-display);color:var(--color-primary-highlight);letter-spacing:-.05em;pointer-events:none;font-size:96px;font-weight:800;line-height:1;position:absolute;top:4px;right:16px}.how-card .icon-wrap{background:var(--color-primary-highlight);width:44px;height:44px;color:var(--color-primary-dark);z-index:1;border-radius:12px;place-items:center;margin-bottom:20px;display:grid;position:relative}.how-card h3{font-family:var(--font-display);z-index:1;margin-bottom:8px;font-size:19px;font-weight:600;position:relative}.how-card p{color:var(--color-text-muted);z-index:1;font-size:14.5px;line-height:1.6;position:relative}.tech-grid{grid-template-columns:1.05fr 1fr;align-items:start;gap:64px;display:grid}@media (max-width:940px){.tech-grid{grid-template-columns:1fr;gap:40px}}.tech-left p{color:var(--color-text-muted);max-width:56ch;margin-bottom:18px;font-size:16px;line-height:1.65}.tech-panel{border-radius:var(--radius-xl);background:linear-gradient(#dcf0fb8c,#dcf0fb40);border:1px solid #3b9edb29;padding:24px;box-shadow:0 12px 32px #3b9edb1a}.tech-row{border-bottom:1px dashed #1a2b3c1a;grid-template-columns:44px 1fr;align-items:center;gap:16px;padding:16px 6px;display:grid}.tech-row:last-child{border-bottom:none}.tech-row .ti{width:44px;height:44px;color:var(--color-primary-dark);background:#fff;border:1px solid #1a2b3c0f;border-radius:11px;place-items:center;display:grid}.tech-row .tl-title{font-family:var(--font-display);color:var(--color-text);margin-bottom:2px;font-size:14.5px;font-weight:600}.tech-row .tl-note{color:var(--color-text-muted);font-size:13px;line-height:1.45}.board-pills{border-top:1px solid #1a2b3c14;flex-wrap:wrap;gap:8px;margin-top:8px;padding-top:18px;display:flex}.board-pill{font-family:var(--font-display);color:var(--color-text-muted);border-radius:var(--radius-full);background:#fff;border:1px solid #1a2b3c24;padding:5px 12px;font-size:12px;font-weight:500}.pricing-grid{grid-template-columns:repeat(3,1fr);align-items:stretch;gap:22px;display:grid}@media (max-width:940px){.pricing-grid{grid-template-columns:1fr}}.price-card{border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);background:#fff;border:1px solid #1a2b3c14;flex-direction:column;padding:28px 26px;display:flex;position:relative}.price-card.popular{border:2px solid var(--color-primary);box-shadow:var(--shadow-md);background:linear-gradient(#fff 70%,#dcf0fb66);transform:translateY(-8px)}.price-card .pop-badge{background:var(--color-primary);color:#fff;font-family:var(--font-display);letter-spacing:.06em;border-radius:var(--radius-full);text-transform:uppercase;padding:6px 14px;font-size:11px;font-weight:600;position:absolute;top:-14px;left:50%;transform:translate(-50%)}.price-tier{font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;color:var(--color-primary-dark);margin-bottom:4px;font-size:13px;font-weight:600}.price-name{font-family:var(--font-display);color:var(--color-text);margin-bottom:14px;font-size:22px;font-weight:700}.price-amount{font-family:var(--font-display);letter-spacing:-.02em;color:var(--color-text);margin-bottom:6px;font-size:36px;font-weight:700;line-height:1}.price-amount .per{color:var(--color-text-muted);font-size:14px;font-weight:500}.price-blurb{color:var(--color-text-muted);margin-bottom:18px;font-size:13px;line-height:1.5}.price-features{gap:9px;margin:0 0 24px;padding:0;list-style:none;display:grid}.price-features li{color:var(--color-text);align-items:flex-start;gap:10px;font-size:14px;line-height:1.45;display:flex}.price-features li svg{width:16px;height:16px;color:var(--color-primary);flex:none;margin-top:3px}.price-cta{margin-top:auto}.price-foot{text-align:center;color:var(--color-text-muted);margin-top:36px;font-size:13px}.cta-banner{color:#fff;text-align:center;background:linear-gradient(135deg,#2478b5 0%,#3b9edb 50%,#56c0f0 100%);padding:clamp(64px,8vw,112px) 24px;position:relative;overflow:hidden}.cta-banner:before{content:"";opacity:.6;pointer-events:none;background-image:radial-gradient(#ffffff1a 1px,#0000 1px);background-size:22px 22px;position:absolute;inset:0}.cta-banner h2{color:#fff;max-width:18ch;margin:0 auto 16px;font-size:clamp(32px,4vw,52px)}.cta-banner p{color:#ffffffd1;max-width:52ch;margin:0 auto 28px;font-size:17px;line-height:1.55}.cta-button{color:var(--color-primary-dark);font-family:var(--font-display);border-radius:var(--radius-full);background:#fff;align-items:center;gap:8px;height:54px;padding:0 30px;font-size:16px;font-weight:600;transition:transform .18s;display:inline-flex;box-shadow:0 6px 22px #0000002e}.cta-button:hover{transform:translateY(-2px)}.about-grid{grid-template-columns:1fr;gap:32px;max-width:900px;margin:0 auto;display:grid}.about-lede{color:var(--color-text-muted);max-width:60ch;font-size:17px;line-height:1.65}.founder-card{border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);background:#fff;border:1px solid #1a2b3c0f;grid-template-columns:80px 1fr;align-items:start;gap:24px;padding:28px;display:grid}@media (max-width:640px){.founder-card{grid-template-columns:1fr}}.founder-avatar{background:linear-gradient(135deg, var(--color-primary) 0%, #56c0f0 100%);color:#fff;width:80px;height:80px;font-family:var(--font-display);border-radius:50%;place-items:center;font-size:34px;font-weight:700;display:grid;box-shadow:0 8px 20px #3b9edb59}.founder-head{flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:14px;display:flex}.founder-head h3{font-family:var(--font-display);font-size:22px;font-weight:700}.founder-tag{font-family:var(--font-display);color:var(--color-primary-dark);background:var(--color-primary-highlight);border-radius:var(--radius-full);padding:5px 11px;font-size:12px;font-weight:500}.founder-bio{color:var(--color-text-muted);margin-bottom:16px;font-size:15px;line-height:1.65}.cred-chips{flex-wrap:wrap;gap:10px;display:flex}.cred-chip{font-family:var(--font-display);color:var(--color-text);border-radius:var(--radius-full);background:#f1f6fb;border:1px solid #1a2b3c0f;align-items:center;gap:6px;padding:6px 12px;font-size:12.5px;font-weight:500;display:inline-flex}.about-contact{text-align:center;color:var(--color-text-muted);margin-top:18px;font-size:14px}.about-contact a{color:var(--color-primary-dark);text-underline-offset:3px;text-decoration:underline}.footer{color:#ffffffc7;background:#1a2b3c;padding:64px 0 28px}.footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;display:grid}@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr}}@media (max-width:540px){.footer-grid{grid-template-columns:1fr}}.footer h4{font-family:var(--font-display);color:#fff;letter-spacing:.06em;text-transform:uppercase;margin-bottom:18px;font-size:13px;font-weight:600}.footer ul{gap:10px;margin:0;padding:0;font-size:14px;list-style:none;display:grid}.footer a{color:#ffffffa6;transition:color .15s}.footer a:hover{color:#fff}.footer-brand p{color:#fff9;max-width:32ch;margin:10px 0 18px;font-size:14px;line-height:1.55}.footer-social{gap:10px;display:flex}.footer-social a{color:#ffffffb3;background:#ffffff0f;border:1px solid #ffffff14;border-radius:50%;place-items:center;width:36px;height:36px;display:grid}.footer-social a:hover{color:#fff;background:#ffffff1f}.footer-bottom{text-align:center;color:#fff6;border-top:1px solid #ffffff14;margin-top:48px;padding-top:22px;font-size:12px}.login-shell{background:radial-gradient(80% 60% at 50% 20%,#e0f2ff 0%,#bfe0fa 45%,#97cbee 100%);place-items:center;min-height:100vh;padding:40px 24px;display:grid;position:relative;overflow:hidden}.login-shell:before{content:"";opacity:.22;pointer-events:none;mix-blend-mode:overlay;background-image:radial-gradient(#ffffff8c 1px,#0000 1px);background-size:22px 22px;position:absolute;inset:0}.login-card{-webkit-backdrop-filter:blur(18px)saturate(180%);backdrop-filter:blur(18px)saturate(180%);width:100%;max-width:460px;box-shadow:var(--shadow-hero);text-align:center;background:#ffffffeb;border:1px solid #ffffffe6;border-radius:22px;padding:44px 36px 36px;transition:transform .32s cubic-bezier(.16,1,.3,1),opacity .28s;position:relative}.login-card.leaving{opacity:0;transform:scale(.96)translateY(-6px)}.login-brand{font-family:var(--font-display);letter-spacing:-.02em;align-items:center;gap:10px;margin-bottom:28px;font-size:22px;font-weight:700;display:inline-flex}.login-brand .nav-logo{border-radius:10px;width:36px;height:36px}.login-card h1{font-family:var(--font-display);letter-spacing:-.02em;margin-bottom:6px;font-size:24px;font-weight:700}.login-card .sub{color:var(--color-text-muted);margin-bottom:26px;font-size:14px}.pin-row{justify-content:center;gap:10px;margin-bottom:18px;display:flex}.pin-box{width:52px;height:64px;font-family:var(--font-mono);text-align:center;color:var(--color-text);background:#fff;border:1.5px solid #1a2b3c24;border-radius:12px;outline:none;font-size:26px;font-weight:600;transition:border-color .15s,background .15s,transform .2s}.pin-box:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px #3b9edb26}.pin-box.filled{border-color:var(--color-primary);background:#f4f9fe}.pin-row.success .pin-box{color:#006915;color:lab(37.9407% -42.3641 37.5694);background:#2eb8661f;border-color:#278733;border-color:lab(49.5829% -42.1882 35.8774)}.pin-row.error .pin-box{color:#ba2936;color:lab(42.4397% 57.4845 30.7602);background:#dc3c3214;border-color:#de4d52;border-color:lab(54.0619% 57.3416 29.5581);animation:.4s cubic-bezier(.36,.07,.19,.97) shake}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.login-foot{color:var(--color-text-subtle);margin-top:8px;font-size:12px}.login-hint{color:var(--color-text-muted);font-size:11.5px;font-family:var(--font-mono);background:#3b9edb1a;border:1px dashed #3b9edb52;border-radius:999px;align-items:center;gap:6px;margin-top:20px;padding:5px 10px;display:inline-flex}.app-bg{background:#f4f8fc;min-height:100vh}.app-shell{grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--row-border);z-index:30;background:#fff;flex-direction:column;height:100vh;padding:22px 16px 16px;display:flex;position:sticky;top:0}.sidebar-brand{font-family:var(--font-display);letter-spacing:-.02em;border-bottom:1px solid var(--row-border);align-items:center;gap:10px;margin-bottom:14px;padding:4px 8px 18px;font-size:18px;font-weight:700;display:flex}.sidebar-nav{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.sidebar-nav a{font-family:var(--font-display);color:var(--color-text-muted);border-radius:10px;align-items:center;gap:12px;padding:9px 12px;font-size:14px;font-weight:500;transition:background .15s,color .15s;display:flex}.sidebar-nav a svg{color:currentColor;flex:none;width:17px;height:17px}.sidebar-nav a:hover{color:var(--color-text);background:#3b9edb14}.sidebar-nav a.active{background:var(--color-primary-highlight);color:var(--color-primary-dark);font-weight:600}.sidebar-nav a.active svg{color:var(--color-primary-dark)}.sidebar-foot{border-top:1px solid var(--row-border);align-items:center;gap:10px;margin-top:auto;padding-top:14px;display:flex}.tutor-avatar{background:linear-gradient(135deg, var(--color-primary) 0%, #56c0f0 100%);color:#fff;width:36px;height:36px;font-family:var(--font-display);border-radius:50%;flex:none;place-items:center;font-size:13px;font-weight:600;display:grid;box-shadow:0 4px 10px #3b9edb47}.tutor-meta{min-width:0;line-height:1.25}.tutor-name{font-family:var(--font-display);color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.plan-badge{font-family:var(--font-display);letter-spacing:.05em;text-transform:uppercase;color:var(--color-primary-dark);background:var(--color-primary-highlight);border-radius:4px;margin-left:4px;padding:1px 6px;font-size:10px;font-weight:600}.help-icon{width:30px;height:30px;color:var(--color-text-muted);background:#f4f8fc;border-radius:50%;place-items:center;margin-left:auto;display:grid}.main{flex-direction:column;min-width:0;display:flex}.topbar{height:var(--topbar-h);-webkit-backdrop-filter:blur(12px)saturate(160%);backdrop-filter:blur(12px)saturate(160%);border-bottom:1px solid var(--row-border);z-index:20;background:#ffffffd9;justify-content:space-between;align-items:center;padding:0 28px;display:flex;position:sticky;top:0}.breadcrumb{font-family:var(--font-display);color:var(--color-text);align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.breadcrumb .sep{color:var(--color-text-subtle);font-weight:400}.breadcrumb .crumb-link{color:var(--color-text-muted);cursor:pointer}.breadcrumb .crumb-link:hover{color:var(--color-primary-dark)}.topbar-right{align-items:center;gap:12px;display:flex}.icon-btn{width:36px;height:36px;color:var(--color-text-muted);background:0 0;border-radius:10px;place-items:center;transition:background .15s,color .15s;display:grid;position:relative}.icon-btn:hover{color:var(--color-primary-dark);background:#3b9edb14}.icon-btn .badge{color:#fff;min-width:16px;height:16px;font-family:var(--font-display);background:#de4d52;background:lab(54.0619% 57.3416 29.5581);border:2px solid #fff;border-radius:999px;place-items:center;padding:0 4px;font-size:10px;font-weight:700;display:grid;position:absolute;top:6px;right:6px}.view-wrap{flex:1;min-width:0;padding:28px}.view-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:22px;display:flex}.view-head h1{font-family:var(--font-display);letter-spacing:-.02em;font-size:28px;font-weight:700}.view-head .sub{color:var(--color-text-muted);margin-top:4px;font-size:14px}.card{border:1px solid var(--row-border);border-radius:var(--app-radius);box-shadow:var(--shadow-sm);background:#fff}.card-pad{padding:20px 22px}.kpi-row{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px;display:grid}@media (max-width:1080px){.kpi-row{grid-template-columns:repeat(2,1fr)}}.kpi{border:1px solid var(--row-border);border-radius:var(--app-radius);box-shadow:var(--shadow-sm);background:#fff;padding:18px 20px;position:relative;overflow:hidden}.kpi .kpi-label{font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);align-items:center;gap:6px;margin-bottom:10px;font-size:12px;font-weight:500;display:flex}.kpi .kpi-value{font-family:var(--font-display);letter-spacing:-.02em;font-size:32px;font-weight:700;line-height:1}.kpi .kpi-value .unit{color:var(--color-text-muted);margin-left:4px;font-size:16px;font-weight:500}.kpi .delta{font-family:var(--font-display);border-radius:999px;align-items:center;gap:3px;margin-top:10px;padding:2px 8px;font-size:12px;font-weight:600;display:inline-flex}.kpi .delta.up{color:#006915;color:lab(37.9407% -42.3641 37.5694);background:#2eb8661f}.kpi .delta.down{color:#ba2936;color:lab(42.4397% 57.4845 30.7602);background:#dc3c321a}.sparkline{align-items:flex-end;gap:3px;height:28px;display:flex;position:absolute;bottom:14px;right:16px}.sparkline span{background:linear-gradient(180deg, var(--color-primary), #93c5fd);opacity:.7;border-radius:2px;width:4px}.quick-row{grid-template-columns:1.4fr 1fr;gap:16px;margin-bottom:22px;display:grid}@media (max-width:880px){.quick-row{grid-template-columns:1fr}}.qa-primary{color:#fff;border-radius:var(--app-radius);cursor:pointer;background:radial-gradient(80% 100% at 100% 0,#ffffff2e 0%,#0000 60%),linear-gradient(135deg,#2478b5 0%,#3b9edb 50%,#56c0f0 100%);padding:26px;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden;box-shadow:0 12px 32px #3b9edb47}.qa-primary:after{content:"";opacity:.45;pointer-events:none;background-image:radial-gradient(#ffffff2e 1px,#0000 1px);background-size:18px 18px;position:absolute;inset:0}.qa-primary:hover{transform:translateY(-2px);box-shadow:0 16px 40px #3b9edb5c}.qa-primary .qa-icon{z-index:1;background:#ffffff2e;border:1px solid #ffffff52;border-radius:12px;place-items:center;width:48px;height:48px;margin-bottom:14px;display:grid;position:relative}.qa-primary h3{font-family:var(--font-display);color:#fff;z-index:1;letter-spacing:-.02em;margin-bottom:6px;font-size:22px;font-weight:700;position:relative}.qa-primary p{color:#ffffffd9;z-index:1;max-width:36ch;font-size:14px;line-height:1.5;position:relative}.qa-secondary{border:1px solid var(--row-border);border-radius:var(--app-radius);cursor:pointer;background:#fff;flex-direction:column;padding:22px;transition:border-color .18s,transform .18s;display:flex}.qa-secondary:hover{border-color:var(--color-primary);transform:translateY(-2px)}.qa-secondary .qa-icon{background:var(--color-primary-highlight);width:38px;height:38px;color:var(--color-primary-dark);border-radius:10px;place-items:center;margin-bottom:12px;display:grid}.qa-secondary h3{font-family:var(--font-display);margin-bottom:4px;font-size:16px;font-weight:600}.qa-secondary p{color:var(--color-text-muted);font-size:13px}.dash-split{grid-template-columns:1.6fr 1fr;gap:16px;display:grid}@media (max-width:1080px){.dash-split{grid-template-columns:1fr}}.card-head{border-bottom:1px solid var(--row-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-head h2{font-family:var(--font-display);letter-spacing:-.01em;align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.card-head a.link{font-family:var(--font-display);color:var(--color-primary-dark);cursor:pointer;font-size:13px;font-weight:500}.card-head a.link:hover{text-decoration:underline}.tbl-wrap{border-radius:0 0 var(--app-radius) var(--app-radius);overflow:auto}.tbl{border-collapse:separate;border-spacing:0;width:100%;font-size:13.5px}.tbl thead th{text-align:left;font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);border-bottom:1px solid var(--row-border);white-space:nowrap;background:#fafcfe;padding:11px 16px;font-size:11.5px;font-weight:600;position:sticky;top:0}.tbl thead th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.tbl thead th.sortable:hover{color:var(--color-primary-dark)}.tbl tbody td{border-bottom:1px solid var(--row-border);color:var(--color-text);vertical-align:middle;white-space:nowrap;padding:12px 16px}.tbl tbody tr:nth-child(2n) td{background:#fbfcfe}.tbl tbody tr{cursor:pointer;transition:background .12s}.tbl tbody tr:hover td{background:var(--row-hover)}.tbl tbody tr:last-child td{border-bottom:none}.tbl tbody td.num{font-family:var(--font-mono);color:var(--color-text-muted)}.student-cell{align-items:center;gap:10px;display:flex}.mini-avatar{color:#fff;width:28px;height:28px;font-family:var(--font-display);background:linear-gradient(135deg,#2478b5,#56c0f0);border-radius:50%;flex:none;place-items:center;font-size:11px;font-weight:600;display:grid}.mini-avatar.v2{background:linear-gradient(135deg,#7c3aed,#c4b5fd)}.mini-avatar.v3{background:linear-gradient(135deg,#0d9488,#5eead4)}.mini-avatar.v4{background:linear-gradient(135deg,#dc4c3a,#fca5a5)}.mini-avatar.v5{background:linear-gradient(135deg,#f59e0b,#fcd34d)}.mini-avatar.v6{background:linear-gradient(135deg,#4f46e5,#93c5fd)}.student-cell .sname{font-family:var(--font-display);color:var(--color-text);font-size:13.5px;font-weight:600}.student-cell .ssub{color:var(--color-text-muted);font-size:11.5px}.pill{font-family:var(--font-display);white-space:nowrap;border:1px solid #0000;border-radius:999px;align-items:center;gap:5px;padding:3px 9px;font-size:11px;font-weight:600;display:inline-flex}.pill.subtle{color:var(--color-text);background:#f1f6fb;border-color:#1a2b3c14}.pill.level{color:#4338ca;background:#eef2ff}.pill.board{color:#0f766e;background:#f0fdfa}.pill.draft{color:#5a7189;background:#7882911f}.pill.marked{color:#006915;color:lab(37.9407% -42.3641 37.5694);background:#2eb8661f}.pill.sent{color:var(--color-primary-dark);background:#3b9edb24}.pill.error{color:#ba2936;color:lab(42.4397% 57.4845 30.7602);background:#dc3c321a}.grade-chip{width:30px;height:24px;font-family:var(--font-display);color:#fff;border-radius:6px;place-items:center;font-size:12px;font-weight:700;display:inline-grid}.grade-A,.grade-Astar{background:#278733;background:lab(49.5829% -42.1882 35.8774)}.grade-B{background:var(--color-primary)}.grade-C{color:#533;background:#dd8736;background:lab(64.6349% 29.1705 55.612)}.grade-D,.grade-E,.grade-U{background:#de4d52;background:lab(54.0619% 57.3416 29.5581)}.score-cell{font-family:var(--font-mono);font-size:13px;font-weight:600}.score-cell .of{color:var(--color-text-muted);font-weight:400}.tbl-act{width:30px;height:30px;color:var(--color-text-muted);background:0 0;border-radius:8px;place-items:center;transition:background .12s,color .12s;display:inline-grid}.tbl-act:hover{background:var(--color-primary-highlight);color:var(--color-primary-dark)}.tbl-act.danger:hover{color:#ba2936;color:lab(42.4397% 57.4845 30.7602);background:#dc3c321a}.tbl-controls{border-bottom:1px solid var(--row-border);border-radius:var(--app-radius) var(--app-radius) 0 0;background:#fff;flex-wrap:wrap;align-items:center;gap:10px;padding:14px 18px;display:flex}.tbl-controls .spacer{flex:1}.search-input{background:#f4f8fc;border:1px solid #0000;border-radius:10px;align-items:center;gap:8px;min-width:220px;height:36px;padding:0 12px;transition:border-color .15s,background .15s;display:flex}.search-input:focus-within{border-color:var(--color-primary);background:#fff}.search-input svg{width:14px;height:14px;color:var(--color-text-muted)}.search-input input{font:inherit;color:var(--color-text);background:0 0;border:none;outline:none;width:100%;font-size:13.5px}.select-input,.filter-btn{height:36px;font-family:var(--font-display);color:var(--color-text);cursor:pointer;background:#fff;border:1px solid #1a2b3c1a;border-radius:10px;align-items:center;gap:6px;padding:0 12px;font-size:13px;font-weight:500;display:inline-flex}.filter-btn:hover{border-color:var(--color-primary)}.filter-btn svg{width:14px;height:14px;color:var(--color-text-muted)}.pagination{border-top:1px solid var(--row-border);font-family:var(--font-display);color:var(--color-text-muted);justify-content:space-between;align-items:center;padding:12px 18px;font-size:13px;display:flex}.pagination .pg-btns{gap:8px;display:flex}.pagination .pg-btn{cursor:pointer;background:#fff;border:1px solid #1a2b3c1a;border-radius:8px;align-items:center;gap:4px;height:30px;padding:0 12px;font-size:12.5px;display:inline-flex}.pagination .pg-btn:hover{border-color:var(--color-primary);color:var(--color-primary-dark)}.ap-list{padding:6px 8px 12px}.ap-item{border-radius:10px;grid-template-columns:32px 1fr auto;align-items:start;gap:12px;padding:12px;display:grid}.ap-item:hover{background:var(--row-hover)}.ap-item .ap-dot{background:var(--color-primary);border-radius:50%;width:8px;height:8px;margin:7px}.ap-item .ap-body{color:var(--color-text);font-size:13px;line-height:1.45}.ap-item .ap-meta{color:var(--color-text-muted);margin-top:3px;font-size:11.5px}.ap-item .ap-meta .subj{color:var(--color-primary-dark);font-weight:600}.ap-item .ap-act{font-family:var(--font-display);color:var(--color-primary-dark);white-space:nowrap;cursor:pointer;font-size:12px;font-weight:600}.class-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.class-card{border:1px solid var(--row-border);border-radius:var(--app-radius);cursor:pointer;box-shadow:var(--shadow-sm);background:#fff;flex-direction:column;min-height:200px;padding:20px;transition:border-color .18s,transform .18s;display:flex;position:relative}.class-card:hover{border-color:var(--color-primary);transform:translateY(-2px)}.class-card .cc-head{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:12px;display:flex}.class-card h3{font-family:var(--font-display);letter-spacing:-.01em;font-size:17px;font-weight:700}.class-card .cc-meta{flex-wrap:wrap;gap:6px;margin-bottom:14px;display:flex}.class-card .cc-stats{border-top:1px dashed var(--row-border);color:var(--color-text-muted);justify-content:space-between;gap:12px;margin-top:auto;padding-top:14px;font-size:12px;display:flex}.class-card .cc-stats b{color:var(--color-text);font-family:var(--font-display);margin-bottom:1px;font-size:16px;font-weight:700;display:block}.avatar-stack{margin-bottom:14px;display:flex}.avatar-stack .mini-avatar{border:2px solid #fff;margin-left:-8px}.avatar-stack .mini-avatar:first-child{margin-left:0}.avatar-stack .more{width:28px;height:28px;color:var(--color-text-muted);font-family:var(--font-display);background:#f4f8fc;border:2px solid #fff;border-radius:50%;place-items:center;margin-left:-8px;font-size:11px;font-weight:600;display:inline-grid}.class-create{border-radius:var(--app-radius);color:var(--color-primary-dark);font-family:var(--font-display);cursor:pointer;background:0 0;border:2px dashed #3b9edb52;place-items:center;min-height:200px;font-size:14px;font-weight:600;transition:background .15s,border-color .15s;display:grid}.class-create:hover{border-color:var(--color-primary);background:#3b9edb0a}.class-create .plus-circle{background:var(--color-primary-highlight);width:42px;height:42px;color:var(--color-primary-dark);border-radius:50%;place-items:center;margin-bottom:8px;display:grid}.modal-backdrop{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;background:#14243c66;place-items:center;padding:32px 16px;display:grid;position:fixed;inset:0}.modal{background:#fff;border-radius:18px;flex-direction:column;width:100%;max-width:560px;max-height:calc(100vh - 64px);display:flex;position:relative;box-shadow:0 40px 80px #14243c47,0 8px 24px #14243c29}.modal.lg{max-width:920px}.modal-head{border-bottom:1px solid var(--row-border);justify-content:space-between;align-items:flex-start;gap:16px;padding:20px 24px;display:flex}.modal-head h2{font-family:var(--font-display);letter-spacing:-.02em;font-size:19px;font-weight:700}.modal-head .sub{color:var(--color-text-muted);margin-top:4px;font-size:13px}.modal-close{width:32px;height:32px;color:var(--color-text-muted);border-radius:8px;place-items:center;transition:background .12s;display:grid}.modal-close:hover{color:var(--color-text);background:#f4f8fc}.modal-body{flex:1;padding:22px 24px;overflow:auto}.modal-foot{border-top:1px solid var(--row-border);align-items:center;gap:10px;padding:16px 24px;display:flex}.modal-foot .grow{flex:1}.field{margin-bottom:18px}.field-label{font-family:var(--font-display);color:var(--color-text);align-items:center;gap:8px;margin-bottom:6px;font-size:13px;font-weight:600;display:flex}.field-label .opt{color:var(--color-text-muted);font-size:11.5px;font-weight:400}.text-input{width:100%;height:42px;font:inherit;color:var(--color-text);background:#fff;border:1px solid #1a2b3c1f;border-radius:10px;outline:none;padding:0 12px;font-size:14px;transition:border-color .15s,box-shadow .15s}.text-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px #3b9edb26}.text-area{resize:vertical;height:auto;min-height:88px;padding:10px 12px;line-height:1.5}.segmented{background:#f4f8fc;border:1px solid #1a2b3c14;border-radius:10px;gap:2px;padding:3px;display:inline-flex}.segmented button{font-family:var(--font-display);color:var(--color-text-muted);border-radius:7px;padding:7px 14px;font-size:13px;font-weight:600;transition:background .15s,color .15s}.segmented button.active{color:var(--color-primary-dark);background:#fff;box-shadow:0 1px 3px #14243c14}.dropzone{text-align:center;cursor:pointer;background:#f4f9fe;border:2px dashed #3b9edb59;border-radius:12px;padding:22px;transition:background .15s,border-color .15s}.dropzone:hover,.dropzone.active-drag{border-color:var(--color-primary);background:#eaf4fc}.dropzone .dz-icon{background:var(--color-primary-highlight);width:44px;height:44px;color:var(--color-primary-dark);border-radius:12px;place-items:center;margin:0 auto 10px;display:grid}.dropzone .dz-title{font-family:var(--font-display);margin-bottom:4px;font-size:14px;font-weight:600}.dropzone .dz-hint{color:var(--color-text-muted);font-size:12px}.dropzone.small{padding:14px}.dropzone.small .dz-icon{width:32px;height:32px;margin-bottom:6px}.file-row{gap:8px;padding:10px 2px 4px;display:flex;overflow-x:auto}.file-card{border:1px solid var(--row-border);background:#fff;border-radius:10px;flex:none;width:110px;padding:8px;position:relative}.file-card .thumb{height:70px;color:var(--color-primary-dark);background:repeating-linear-gradient(135deg,#f4f8fc 0 8px,#eaf1f8 8px 16px);border-radius:6px;place-items:center;margin-bottom:6px;display:grid}.file-card .fname{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.file-card .fx{color:#fff;cursor:pointer;background:#14243cb3;border-radius:50%;place-items:center;width:18px;height:18px;font-size:11px;display:grid;position:absolute;top:4px;right:4px}.processing{text-align:center;padding:40px 24px}.processing .pulse-logo{background:var(--color-primary);color:#fff;border-radius:16px;place-items:center;width:64px;height:64px;margin:0 auto 22px;animation:1.8s ease-in-out infinite pulse;display:grid;box-shadow:0 8px 22px #3b9edb73}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 8px 22px #3b9edb73}50%{transform:scale(1.06);box-shadow:0 12px 32px #3b9edb8c}}.processing h3{font-family:var(--font-display);margin-bottom:4px;font-size:19px;font-weight:700}.processing .proc-step{color:var(--color-text-muted);min-height:22px;margin-bottom:22px;font-size:14px;transition:opacity .24s}.proc-bar{background:#3b9edb29;border-radius:999px;width:80%;max-width:360px;height:6px;margin:0 auto;overflow:hidden}.proc-bar-fill{background:linear-gradient(90deg,#2478b5,#56c0f0);border-radius:999px;width:0%;height:100%;transition:width 1.2s}.result-hero{border-bottom:1px solid var(--row-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:20px 24px;display:flex}.result-hero h2{font-family:var(--font-display);letter-spacing:-.02em;margin-bottom:4px;font-size:20px;font-weight:700}.result-hero .meta{color:var(--color-text-muted);font-size:12.5px}.result-hero .right{align-items:center;gap:14px;display:flex}.result-score-badge{background:var(--color-primary-highlight);text-align:center;border:1px solid #3b9edb3d;border-radius:14px;padding:6px 14px}.result-score-badge .lbl{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);font-size:10px;font-weight:500}.result-score-badge .val{font-family:var(--font-display);color:var(--color-primary-dark);font-size:22px;font-weight:700;line-height:1.05}.result-score-badge .val .of{color:var(--color-text-muted);font-size:14px}.result-body{padding:18px 18px 4px}.result-paper{border:1px solid var(--row-border);background:#fff;border-radius:14px;grid-template-columns:1fr 1fr;gap:0;display:grid;overflow:hidden}@media (max-width:880px){.result-paper{grid-template-columns:1fr}}.result-paper .paper-panel{min-height:420px;padding:22px 24px}.send-modal .preview{border:1px solid var(--row-border);color:var(--color-text-muted);background:#f4f8fc;border-radius:10px;max-height:180px;margin-top:10px;padding:14px;font-size:12.5px;line-height:1.6;overflow:auto}.copy-link{border:1px solid var(--row-border);font-family:var(--font-mono);color:var(--color-text-muted);background:#f4f8fc;border-radius:10px;align-items:center;gap:6px;padding:4px 4px 4px 12px;font-size:12px;display:flex}.copy-link input{font:inherit;color:var(--color-text);background:0 0;border:none;outline:none;flex:1;font-size:12px}.copy-link button{border:1px solid var(--row-border);height:30px;font-family:var(--font-display);color:var(--color-primary-dark);cursor:pointer;background:#fff;border-radius:8px;padding:0 12px;font-size:12px;font-weight:600}.heatmap{border-collapse:separate;border-spacing:4px;width:100%;font-size:12px}.heatmap th{font-family:var(--font-display);color:var(--color-text-muted);text-align:center;white-space:nowrap;padding:6px;font-size:11.5px;font-weight:600}.heatmap th.row-h{text-align:left;min-width:160px;padding-right:12px}.heatmap td{text-align:center;width:60px;height:38px;font-family:var(--font-mono);color:#fff;border-radius:6px;font-size:12.5px;font-weight:600}.heatmap td.empty{color:var(--color-text-subtle);background:#f1f4f8;font-weight:400}.heat-low{background:#de4d52;background:lab(54.0619% 57.3416 29.5581)}.heat-mid{color:#4a2a0f;background:#dd8736;background:lab(64.6349% 29.1705 55.612)}.heat-good{background:#4e9a52;background:lab(57.505% -36.4483 30.0272)}.heat-best{background:#107823;background:lab(43.7637% -42.2611 36.5581)}.weakness-list{gap:8px;display:grid}.weakness{border:1px solid var(--row-border);background:#fff;border-radius:10px;grid-template-columns:1fr auto;align-items:center;gap:12px;padding:12px 14px;display:grid}.weakness .title{font-family:var(--font-display);font-size:14px;font-weight:600}.weakness .seen{color:var(--color-text-muted);margin-top:2px;font-size:12px}.weakness .view{font-family:var(--font-display);color:var(--color-primary-dark);cursor:pointer;font-size:12.5px;font-weight:600}.bar-mini{background:#eaf1f8;border-radius:999px;width:100%;max-width:220px;height:6px;margin-top:6px;display:inline-flex;overflow:hidden}.bar-mini .fill{background:linear-gradient(90deg, var(--color-primary-dark), var(--color-primary));border-radius:999px}.settings-shell{grid-template-columns:220px 1fr;gap:24px;display:grid}@media (max-width:880px){.settings-shell{grid-template-columns:1fr}}.settings-nav{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.settings-nav button{font-family:var(--font-display);color:var(--color-text-muted);text-align:left;border-radius:8px;align-items:center;gap:10px;width:100%;padding:8px 12px;font-size:13.5px;font-weight:500;display:flex}.settings-nav button:hover{background:var(--row-hover);color:var(--color-text)}.settings-nav button.active{background:var(--color-primary-highlight);color:var(--color-primary-dark);font-weight:600}.settings-section{margin-bottom:22px}.settings-section h3{font-family:var(--font-display);letter-spacing:-.01em;margin-bottom:12px;font-size:18px;font-weight:700}.toggle-row{border-bottom:1px dashed var(--row-border);justify-content:space-between;align-items:center;padding:14px 0;display:flex}.toggle-row:last-child{border-bottom:none}.toggle-row .lbl-block .lbl{font-family:var(--font-display);font-size:14px;font-weight:600}.toggle-row .lbl-block .desc{color:var(--color-text-muted);margin-top:2px;font-size:12.5px}.empty-state{text-align:center;padding:60px 30px}.empty-state .ico{background:var(--color-primary-highlight);width:64px;height:64px;color:var(--color-primary-dark);border-radius:16px;place-items:center;margin:0 auto 16px;display:grid}.empty-state h3{font-family:var(--font-display);margin-bottom:6px;font-size:18px;font-weight:600}.empty-state p{color:var(--color-text-muted);margin-bottom:16px;font-size:14px}.profile-head{border:1px solid var(--row-border);border-radius:var(--app-radius);background:#fff;grid-template-columns:80px 1fr auto;align-items:center;gap:20px;margin-bottom:18px;padding:22px 24px;display:grid}.profile-head .big-avatar{background:linear-gradient(135deg, var(--color-primary), #56c0f0);color:#fff;width:80px;height:80px;font-family:var(--font-display);border-radius:50%;place-items:center;font-size:30px;font-weight:700;display:grid;box-shadow:0 8px 20px #3b9edb52}.profile-head h1{font-family:var(--font-display);letter-spacing:-.02em;margin-bottom:6px;font-size:26px;font-weight:700}.profile-meta{color:var(--color-text-muted);flex-wrap:wrap;gap:16px;font-size:13px;display:flex}.profile-tags{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.tabs{border-bottom:1px solid var(--row-border);gap:4px;margin-bottom:18px;padding:0;display:flex}.tabs button{font-family:var(--font-display);color:var(--color-text-muted);border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 14px;font-size:13.5px;font-weight:600}.tabs button.active{color:var(--color-primary-dark);border-color:var(--color-primary)}.tabs button:hover{color:var(--color-text)}.subj-card-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-bottom:18px;display:grid}.subj-card{border:1px solid var(--row-border);background:#fff;border-radius:12px;padding:14px}.subj-card .sname{font-family:var(--font-display);margin-bottom:6px;font-size:13.5px;font-weight:600}.subj-card .savg{font-family:var(--font-display);letter-spacing:-.02em;font-size:22px;font-weight:700}.subj-card .smeta{color:var(--color-text-muted);justify-content:space-between;margin-top:6px;font-size:11.5px;display:flex}.sw-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (max-width:720px){.sw-grid{grid-template-columns:1fr}}.sw-panel{border:1px solid var(--row-border);background:#fff;border-radius:12px;padding:16px}.sw-panel h4{font-family:var(--font-display);letter-spacing:.04em;text-transform:uppercase;align-items:center;gap:6px;margin-bottom:10px;font-size:13px;font-weight:700;display:flex}.sw-panel.good h4{color:#006915;color:lab(37.9407% -42.3641 37.5694)}.sw-panel.improve h4{color:#ba2936;color:lab(42.4397% 57.4845 30.7602)}.sw-panel ul{gap:6px;margin:0;padding:0;font-size:13px;list-style:none;display:grid}.sw-panel li{padding-left:16px;line-height:1.45;position:relative}.sw-panel.good li:before{content:"✓";color:#006915;color:lab(37.9407% -42.3641 37.5694);font-weight:700;position:absolute;left:0}.sw-panel.improve li:before{content:"→";color:#ba2936;color:lab(42.4397% 57.4845 30.7602);font-weight:700;position:absolute;left:0}.chart-card{border:1px solid var(--row-border);background:#fff;border-radius:12px;margin-bottom:16px;padding:18px}.chart-card h4{font-family:var(--font-display);justify-content:space-between;align-items:center;margin-bottom:12px;font-size:14px;font-weight:600;display:flex}.line-chart{width:100%;height:240px}.grade-timeline{flex-wrap:wrap;gap:6px;display:flex}.toast{color:#fff;font-family:var(--font-display);z-index:200;background:#1a2b3c;border-radius:10px;align-items:center;gap:10px;padding:12px 18px;font-size:13.5px;font-weight:500;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 12px 32px #14243c52}@media (max-width:960px){:root{--sidebar-w:64px}.sidebar-nav a span,.sidebar-brand span:not(.nav-logo-wrap){display:none}.sidebar{align-items:center;padding:22px 8px 12px}.sidebar-nav a{justify-content:center}.tutor-meta,.help-icon{display:none}.sidebar-foot{justify-content:center}}@media (max-width:760px){.paper-card{grid-template-columns:1fr}.paper-panel.left{border-bottom:1px dashed #1a2b3c1a;border-right:none}.ao-toolbar{margin-left:16px}.answer-converted{padding-left:16px}.summary-strip{margin-left:16px;margin-right:16px}.paper-q,.handwritten-answer{padding-left:16px}}.collapse-toggle{color:var(--color-primary-dark);font-family:var(--font-display);cursor:pointer;align-items:center;gap:6px;font-size:13px;font-weight:600;display:inline-flex}.collapse-toggle:hover{text-decoration:underline}.field-foot{color:var(--color-text-muted);text-align:center;margin-top:8px;font-size:12px}@keyframes spin{to{transform:rotate(360deg)}}.modal.xl{max-width:1100px;max-height:calc(100vh - 32px)}.result-new-body{flex:1;grid-template-columns:1fr;display:grid;overflow:hidden}.result-main{flex-direction:column;gap:14px;padding:18px 22px;display:flex;overflow-y:auto}.result-question-box{border:1px solid var(--row-border);background:#f6fbff;border-radius:10px;padding:14px 16px}.result-question-label{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);justify-content:space-between;align-items:center;margin-bottom:8px;font-size:11px;font-weight:600;display:flex}.result-question-text{color:var(--color-text);font-size:14px;line-height:1.65}.result-answer-box{border:1px solid var(--row-border);border-radius:10px;overflow:hidden}.result-answer-label{border-bottom:1px solid var(--row-border);background:#fafcfe;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.result-answer-label span{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);font-size:11px;font-weight:600}.result-answer-text{color:var(--color-text);padding:16px;font-size:13.5px;line-height:2.1}.result-answer-text .ao-highlight[data-ao=AO1]{background:var(--ao1-bg);border-radius:3px;padding:1px 3px}.result-answer-text .ao-highlight[data-ao=AO2]{background:var(--ao2-bg);border-radius:3px;padding:1px 3px}.result-answer-text .ao-highlight[data-ao=AO3]{background:var(--ao3-bg);border-radius:3px;padding:1px 3px}.result-answer-text .ao-highlight.incorrect{text-decoration-skip-ink:none;-webkit-text-decoration:underline wavy #cf4047;text-decoration:underline wavy #cf4047;-webkit-text-decoration:underline wavy lab(49.4139% 57.3948 29.9528);text-decoration:underline wavy lab(49.4139% 57.3948 29.9528)}.result-answer-text .ao-highlight.partial{text-decoration-skip-ink:none;-webkit-text-decoration:underline wavy #d6812e;text-decoration:underline wavy #d6812e;-webkit-text-decoration:underline wavy lab(62.3061% 29.3153 56.2499);text-decoration:underline wavy lab(62.3061% 29.3153 56.2499)}.result-answer-text .ao-highlight{cursor:pointer;outline:1.5px solid #0000;transition:outline .15s;display:inline;position:relative}.result-answer-text .ao-highlight[data-ao=AO1]:hover,.result-answer-text .ao-highlight[data-ao=AO1].active{outline:1.5px solid var(--ao1);border-radius:3px}.result-answer-text .ao-highlight[data-ao=AO2]:hover,.result-answer-text .ao-highlight[data-ao=AO2].active{outline:1.5px solid var(--ao2);border-radius:3px}.result-answer-text .ao-highlight[data-ao=AO3]:hover,.result-answer-text .ao-highlight[data-ao=AO3].active{outline:1.5px solid var(--ao3);border-radius:3px}.confidence-strip{font-family:var(--font-display);color:var(--color-text-muted);border:1px solid var(--row-border);background:#fafcff;border-radius:8px;align-items:center;gap:10px;padding:8px 12px;font-size:12px;display:flex}.confidence-bar{background:#1a2b3c1a;border-radius:999px;width:72px;height:4px;overflow:hidden}.confidence-bar-fill{border-radius:999px;height:100%}.confidence-bar-fill.high{background:#278733;background:lab(49.5829% -42.1882 35.8774);width:100%}.confidence-bar-fill.medium{background:#dd8736;background:lab(64.6349% 29.1705 55.612);width:60%}.confidence-bar-fill.low{background:#cf4047;background:lab(49.4139% 57.3948 29.9528);width:28%}.confidence-strip .conf-label{text-transform:capitalize;font-weight:600}.confidence-strip .conf-label.high{color:#006915;color:lab(37.9407% -42.3641 37.5694)}.confidence-strip .conf-label.medium{color:#bb6802;color:lab(52.9853% 29.9699 60.1556)}.confidence-strip .conf-label.low{color:#ba2936;color:lab(42.4397% 57.4845 30.7602)}.comment-panel{border-left:1px solid var(--row-border);background:#fafcff;flex-direction:column;display:flex;overflow:hidden}.comment-panel-head{border-bottom:1px solid var(--row-border);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.comment-panel-title{font-family:var(--font-display);color:var(--color-text);font-size:13px;font-weight:700}.comment-panel-count{font-family:var(--font-display);color:var(--color-text-muted);font-size:12px}.comment-panel-scroll{flex:1;padding:8px;overflow-y:auto}.comment-item{border:1px solid var(--row-border);background:#fff;border-radius:10px;margin-bottom:8px;padding:10px 12px;position:relative}.comment-item .ci-ao{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;border-radius:4px;margin-bottom:6px;padding:2px 6px;font-size:10px;font-weight:700;display:inline-block}.comment-item .ci-ao.ao1{background:var(--ao1-bg);color:var(--ao1)}.comment-item .ci-ao.ao2{background:var(--ao2-bg);color:var(--ao2)}.comment-item .ci-ao.ao3{background:var(--ao3-bg);color:var(--ao3)}.comment-item .ci-span{color:var(--color-text);margin-bottom:5px;padding-right:20px;font-size:12px;font-style:italic;line-height:1.4}.comment-item .ci-feedback{color:var(--color-text-muted);font-size:12px;line-height:1.5}.comment-item .ci-delete{width:20px;height:20px;color:var(--color-text-muted);cursor:pointer;background:#f4f8fc;border-radius:50%;place-items:center;font-size:12px;line-height:1;display:grid;position:absolute;top:8px;right:8px}.comment-item .ci-delete:hover{color:#ba2936;color:lab(42.4397% 57.4845 30.7602);background:#dc3c321a}.question-nav{border-bottom:2px solid var(--row-border);background:#f4f8fd;flex-shrink:0;gap:6px;padding:12px 18px 0;display:flex;overflow-x:auto}.question-nav button{font-family:var(--font-display);color:var(--color-text);border:1.5px solid var(--row-border);white-space:nowrap;background:#fff;border-bottom:none;border-radius:10px 10px 0 0;margin-bottom:-2px;padding:8px 18px;font-size:13.5px;font-weight:700;transition:background .12s,color .12s,border-color .12s;box-shadow:0 -1px 4px #1a2b3c0f}.question-nav button.active{color:var(--color-primary-dark);border-color:var(--color-primary);background:var(--color-primary-highlight);box-shadow:0 -2px 6px #3b9edb26}.question-nav button:hover:not(.active){color:var(--color-primary-dark);background:#eef6ff;border-color:#3b9edb66}.question-nav-score{font-family:var(--font-mono);color:var(--color-text-muted);margin-left:5px;font-size:11.5px;font-weight:500}.question-nav button.active .question-nav-score{color:var(--color-primary-dark);opacity:.7}.question-nav-total{font-family:var(--font-display);color:var(--color-text);white-space:nowrap;border-left:1px solid var(--row-border);margin-left:auto;padding:8px 0 8px 16px;font-size:13px;font-weight:700}.question-nav-total .qnt-score{color:var(--color-primary-dark)}.search-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:300;background:#14243c73;place-items:start center;padding-top:72px;display:grid;position:fixed;inset:0}.search-box{background:#fff;border-radius:18px;width:100%;max-width:580px;overflow:hidden;box-shadow:0 40px 80px #14243c4d}.search-input-row{border-bottom:1px solid var(--row-border);align-items:center;gap:10px;height:56px;padding:0 18px;display:flex}.search-input-row input{font:inherit;color:var(--color-text);background:0 0;border:none;outline:none;flex:1;font-size:16px}.search-input-row svg{color:var(--color-text-muted);flex:none}.search-results{max-height:420px;overflow-y:auto}.search-section-label{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);padding:10px 18px 4px;font-size:11px;font-weight:600}.search-result-item{cursor:pointer;align-items:center;gap:12px;padding:10px 18px;transition:background .12s;display:flex}.search-result-item:hover{background:var(--row-hover)}.search-result-item .sri-icon{background:var(--color-primary-highlight);width:32px;height:32px;color:var(--color-primary-dark);border-radius:8px;flex:none;place-items:center;display:grid}.search-result-item .sri-main{font-family:var(--font-display);color:var(--color-text);font-size:13.5px;font-weight:600}.search-result-item .sri-sub{color:var(--color-text-muted);font-size:12px}.search-empty{text-align:center;color:var(--color-text-muted);padding:36px;font-size:14px}.search-hint{color:var(--color-text-muted);border-top:1px solid var(--row-border);align-items:center;gap:8px;padding:14px 18px;font-size:12.5px;display:flex}.search-hint kbd{font-family:var(--font-mono);color:var(--color-text);background:#f4f8fc;border:1px solid #1a2b3c1f;border-radius:5px;align-items:center;padding:2px 6px;font-size:11px;display:inline-flex}.icon-btn-wrap{position:relative}.notif-dropdown{border:1px solid var(--row-border);width:320px;box-shadow:var(--shadow-lg);z-index:200;background:#fff;border-radius:14px;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden}.notif-dropdown-head{border-bottom:1px solid var(--row-border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.notif-dropdown-head h3{font-family:var(--font-display);font-size:14px;font-weight:700}.notif-item{border-bottom:1px solid var(--row-border);cursor:pointer;grid-template-columns:36px 1fr;align-items:start;gap:10px;padding:12px 16px;transition:background .12s;display:grid}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--row-hover)}.notif-item .ni-dot{background:var(--color-primary-highlight);border-radius:50%;flex:none;place-items:center;width:36px;height:36px;font-size:15px;display:grid}.notif-item .ni-title{font-family:var(--font-display);color:var(--color-text);font-size:13px;font-weight:600;line-height:1.35}.notif-item .ni-sub{color:var(--color-text-muted);margin-top:2px;font-size:12px}.notif-empty{text-align:center;color:var(--color-text-muted);padding:28px;font-size:13px}.inline-create{background:#f6fbff;border:1px solid #3b9edb38;border-radius:10px;gap:10px;margin-top:8px;padding:14px;display:grid}.inline-create-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.inline-create .field{margin-bottom:0}.create-modal{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:300;background:#14243c73;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.create-modal-box{background:#fff;border-radius:18px;flex-direction:column;width:100%;max-width:460px;display:flex;box-shadow:0 40px 80px #14243c47}.time-saved-note{color:var(--color-text-subtle);margin-top:6px;font-size:11px}.sub-questions-scroll{flex-direction:column;gap:0;display:flex;overflow-y:auto}.sub-question-card{border-bottom:2px solid var(--row-border);flex-direction:column;gap:14px;padding:20px 24px 24px;display:flex}.sub-question-card:last-child{border-bottom:none}.sub-question-header{align-items:center;gap:12px;display:flex}.sq-num{font-family:var(--font-mono);color:var(--color-primary-dark);background:var(--color-primary-highlight);white-space:nowrap;border:1px solid #3b9edb40;border-radius:6px;flex:none;padding:3px 8px;font-size:12px;font-weight:700}.sq-marks-edit{flex:none;align-items:center;gap:5px;display:flex}.sq-marks-input{width:44px;font-family:var(--font-mono);color:var(--color-primary-dark);background:var(--color-primary-highlight);text-align:center;appearance:textfield;border:1.5px solid #3b9edb59;border-radius:6px;outline:none;padding:3px 6px;font-size:14px;font-weight:700}.sq-marks-input::-webkit-inner-spin-button{appearance:none}.sq-marks-input::-webkit-outer-spin-button{appearance:none}.sq-marks-input:focus{border-color:var(--color-primary);background:#fff}.sq-marks-of{font-family:var(--font-display);color:var(--color-text-muted);white-space:nowrap;font-size:13px}.sq-body{align-items:flex-start;gap:18px;display:flex}.sq-content{flex-direction:column;flex:1;gap:14px;min-width:0;display:flex}.sq-comments{flex-direction:column;flex:none;gap:8px;width:230px;display:flex}.sq-comment-item{border:1px solid var(--row-border);cursor:pointer;background:#fff;border-radius:10px;padding:10px 12px;transition:border-color .15s,box-shadow .15s;position:relative}.sq-comment-item:hover{border-color:#3b9edb66;box-shadow:0 2px 8px #3b9edb14}.sq-comment-item.active{border-color:var(--color-primary);background:var(--color-primary-highlight);box-shadow:0 2px 10px #3b9edb26}.sq-ci-header{align-items:center;gap:6px;margin-bottom:6px;display:flex}.sq-ci-status{font-size:11px;font-weight:600}.sq-ci-status.incorrect{color:#ba2936;color:lab(42.4397% 57.4845 30.7602)}.sq-ci-status.partial{color:#bb6802;color:lab(52.9853% 29.9699 60.1556)}.sq-ci-delete{width:18px;height:18px;color:var(--color-text-muted);opacity:0;background:0 0;border-radius:50%;flex:none;place-items:center;margin-left:auto;transition:opacity .15s,background .15s,color .15s;display:grid}.sq-comment-item:hover .sq-ci-delete{opacity:1}.sq-ci-delete:hover{background:#dc3c321a;color:#ba2936!important;color:lab(42.4397% 57.4845 30.7602)!important}.sq-comment-item .ci-ao{font-family:var(--font-display);letter-spacing:.07em;text-transform:uppercase;border-radius:4px;padding:2px 7px;font-size:10px;font-weight:700;display:inline-block}.sq-comment-item .ci-ao.ao1{background:var(--ao1-bg);color:var(--ao1)}.sq-comment-item .ci-ao.ao2{background:var(--ao2-bg);color:var(--ao2)}.sq-comment-item .ci-ao.ao3{background:var(--ao3-bg);color:var(--ao3)}.sq-comment-item .ci-span{font-family:var(--font-body);color:var(--color-text);border-left:2px solid var(--row-border);margin:5px 0 4px;padding-left:6px;padding-right:20px;font-size:11.5px;font-style:italic;line-height:1.45}.select-wrap{display:block;position:relative}.select-wrap select{appearance:none;cursor:pointer;width:100%;padding-right:28px}.select-icon{pointer-events:none;color:var(--color-text-muted);position:absolute;top:50%;right:9px;transform:translateY(-50%)}.cp-dropzone{border:2px dashed var(--row-border);border-radius:var(--radius-lg);cursor:pointer;text-align:center;background:var(--color-bg);flex-direction:column;justify-content:center;align-items:center;min-height:110px;padding:24px 16px;transition:border-color .15s,background .15s;display:flex}.cp-dropzone:hover,.cp-dropzone--active{border-color:var(--color-primary);background:var(--color-primary-highlight)}.cp-dropzone--filled{background:var(--color-surface);border-style:solid;border-color:var(--color-primary);min-height:unset;cursor:default;flex-direction:row;justify-content:flex-start;gap:10px;padding:14px 16px}.cp-dz-name{text-align:left;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;font-weight:500;overflow:hidden}.cp-dz-clear{color:var(--color-text-muted);flex-shrink:0;margin-left:auto}.cp-dz-clear:hover{color:var(--color-error)}.cp-qtable{border-top:1px solid var(--row-border)}.cp-qrow{border-bottom:1px solid var(--row-border);grid-template-columns:72px 1fr 160px 72px 60px;align-items:center;gap:0;display:grid}.cp-qrow--head{background:var(--color-bg);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);font-size:11px;font-weight:600}.cp-qblock{background:var(--color-surface)}.cp-qblock:hover{background:var(--row-hover)}.cp-qcell{padding:10px 12px}.cp-qcell--num{font-family:var(--font-mono)}.cp-qcell--marks{text-align:center}.cp-qcell--actions{justify-content:flex-end;align-items:center;gap:4px;padding-right:12px;display:flex}.cp-rubric-toggle{border-radius:var(--radius-sm);width:26px;height:26px;color:var(--color-text-muted);place-items:center;transition:background .12s,color .12s;display:grid}.cp-rubric-toggle:hover{background:var(--row-hover);color:var(--color-text)}.cp-rubric{border-top:1px dashed var(--row-border);background:var(--color-bg);padding:12px 16px 16px}.cp-rubric-pre{font-family:var(--font-mono);white-space:pre-wrap;color:var(--color-text);margin:0;font-size:12px;line-height:1.5}.cp-rubric-editor{resize:vertical;width:100%;min-height:90px;font-family:var(--font-mono);font-size:12px;line-height:1.5}.rq-grid{grid-template-columns:1fr 1fr;align-items:start;gap:16px;display:grid}@media (max-width:960px){.rq-grid{grid-template-columns:1fr}}.rq-section-label{text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted);align-items:center;gap:6px;margin-bottom:8px;font-size:11px;font-weight:700;display:flex}.spinning{animation:1.2s linear infinite spin}.cs-file-row{background:var(--color-bg);border:1px solid var(--row-border);border-radius:var(--radius-md);align-items:center;gap:10px;padding:10px 12px;display:flex}.cs-file-info{flex:1;min-width:0}.cs-script-select{border:1px solid var(--row-border);border-radius:var(--radius-md);max-height:240px;overflow:hidden auto}.cs-ss-header{background:var(--color-bg);border-bottom:1px solid var(--row-border);padding:8px 12px}.cs-ss-row{border-bottom:1px solid var(--row-border);cursor:pointer;align-items:center;gap:10px;padding:8px 12px;font-size:13px;display:flex}.cs-ss-row:last-child{border-bottom:none}.cs-ss-row:hover{background:var(--row-hover)}.cs-stepper{flex-wrap:wrap;align-items:center;gap:12px 0;display:flex}.cs-step{align-items:center;gap:6px;display:flex;position:relative}.cs-step-dot{border:2px solid var(--row-border);background:var(--color-surface);width:26px;height:26px;color:var(--color-text-muted);border-radius:50%;flex-shrink:0;place-items:center;font-size:11px;font-weight:700;transition:background .2s,border-color .2s,color .2s;display:grid}.cs-step-dot.done{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.cs-step-dot.current{background:var(--color-primary);border-color:var(--color-primary);color:#fff;box-shadow:0 0 0 3px var(--color-primary-highlight)}.cs-step-dot.review{background:var(--color-warning);border-color:var(--color-warning);color:#fff}.cs-step-dot.failed{background:var(--color-error);border-color:var(--color-error);color:#fff}.cs-step-label{color:var(--color-text-muted);white-space:nowrap;font-size:11.5px}.cs-step-line{background:var(--row-border);flex-shrink:0;width:28px;height:2px;margin:0 4px;transition:background .2s}.cs-step-line.done{background:var(--color-primary)}.cp-save-bar{background:var(--color-surface);border:1px solid var(--row-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);justify-content:space-between;align-items:center;gap:12px;margin-top:16px;padding:12px 16px;display:flex;position:sticky;bottom:16px}.sq-comment-item.active .ci-span{border-left-color:var(--color-primary)}.sq-comment-item .ci-feedback{font-family:var(--font-body);color:var(--color-text-muted);font-size:11.5px;line-height:1.55}.tbl-check{width:44px!important;padding-left:16px!important;padding-right:4px!important}.tbl-check input[type=checkbox]{cursor:pointer;width:15px;height:15px;accent-color:var(--color-primary-dark);border-radius:4px}.tbl tbody tr.row-selected td{background:#3b9edb12!important}.tbl tbody tr.row-selected:hover td{background:#3b9edb1f!important}.bulk-bar{background:var(--color-primary-highlight);border-top:1px solid #3b9edb2e;flex-wrap:wrap;align-items:center;gap:12px;padding:10px 18px;display:flex}.bulk-count{font-family:var(--font-display);color:var(--color-primary-dark);flex:1;font-size:13px;font-weight:600}.bulk-actions{gap:8px;display:flex}.bulk-clear{height:32px;font-family:var(--font-display);color:var(--color-text-muted);border-radius:8px;align-items:center;gap:4px;padding:0 10px;font-size:12.5px;font-weight:500;transition:background .12s,color .12s;display:inline-flex}.bulk-clear:hover{color:var(--color-text);background:#3b9edb1f}.btn-danger{color:#ba2936;color:lab(42.4397% 57.4845 30.7602);background:#dc3c320f;border:1.5px solid #dc3c3238}.btn-danger:hover{background:#dc3c321f;border-color:#de4d52;border-color:lab(54.0619% 57.3416 29.5581)}@keyframes apSpin{to{transform:rotate(360deg)}}.ap-gen-toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:18px;display:flex}.ap-gen-subjects{flex-wrap:wrap;flex:1;gap:6px;display:flex}.ap-subject-active{border-color:var(--color-primary)!important;color:var(--color-primary-dark)!important;background:var(--color-primary-highlight)!important}.ap-gen-cta{text-align:center;border:1px solid var(--row-border);border-radius:var(--app-radius);box-shadow:var(--shadow-sm);background:#fff;padding:52px 28px}.ap-gen-cta-icon{color:#ca6900;color:lab(54.9626% 41.5821 98.6221);background:#f59e0b1a;border-radius:14px;place-items:center;width:56px;height:56px;margin:0 auto 14px;display:grid}.ap-gen-cta h3{font-family:var(--font-display);letter-spacing:-.01em;margin-bottom:8px;font-size:19px;font-weight:700}.ap-gen-cta p{color:var(--color-text-muted);max-width:48ch;margin:0 auto;font-size:14px;line-height:1.6}.ap-gen-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;display:grid}@media (max-width:760px){.ap-gen-grid{grid-template-columns:1fr}}.ap-gen-card{border:1px solid var(--row-border);border-radius:var(--app-radius);box-shadow:var(--shadow-sm);background:#fff;flex-direction:column;gap:13px;padding:18px 20px;transition:border-color .15s,box-shadow .15s;display:flex}.ap-gen-card:hover{box-shadow:var(--shadow-md);border-color:#3b9edb4d}.ap-gen-card-header{align-items:center;gap:8px;display:flex}.ap-dismiss{width:28px;height:28px;color:var(--color-text-muted);border-radius:7px;flex:none;place-items:center;transition:background .12s,color .12s;display:grid}.ap-dismiss:hover{color:#ba2936;color:lab(42.4397% 57.4845 30.7602);background:#dc3c3214}.ap-priority{font-family:var(--font-display);white-space:nowrap;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600}.ap-priority-high{color:#ba2936;color:lab(42.4397% 57.4845 30.7602);background:#dc3c321a}.ap-priority-medium{color:#ac5800;color:lab(46.9481% 36.9752 83.9758);background:#f59e0b1f}.ap-priority-low{color:#006915;color:lab(37.9407% -42.3641 37.5694);background:#2eb8661a}.ap-gen-topic{font-family:var(--font-display);letter-spacing:-.015em;color:var(--color-text);font-size:17px;font-weight:700;line-height:1.25}.ap-gen-ao{background:#f4f8fc;border-radius:8px;flex-wrap:wrap;align-items:center;gap:8px;padding:8px 12px;display:flex}.ap-ao-badge{font-family:var(--font-display);background:var(--color-primary);color:#fff;letter-spacing:.04em;border-radius:5px;flex:none;padding:2px 8px;font-size:11px;font-weight:700}.ap-ao-label{font-family:var(--font-display);color:var(--color-text-muted);font-size:12.5px;font-weight:600}.ap-ao-meta{color:var(--color-text-subtle);white-space:nowrap;margin-left:auto;font-size:11.5px}.ap-gen-section{border-top:1px solid var(--row-border);padding-top:12px}.ap-gen-section-label{font-family:var(--font-display);letter-spacing:.07em;text-transform:uppercase;color:var(--color-text-muted);align-items:center;gap:5px;margin-bottom:6px;font-size:10.5px;font-weight:600;display:flex}.ap-gen-section-body{color:var(--color-text);font-size:13.5px;line-height:1.5}.ap-gen-resource{background:var(--color-primary-highlight);border:1px solid #3b9edb2e;border-radius:10px;align-items:center;gap:8px;padding:9px 12px;display:flex}.ap-resource-type{font-family:var(--font-display);color:var(--color-primary-dark);white-space:nowrap;background:#3b9edb29;border-radius:5px;flex:none;padding:2px 8px;font-size:11.5px;font-weight:600}.ap-resource-title{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:12.5px;overflow:hidden}.ap-resource-link{font-family:var(--font-display);color:var(--color-primary-dark);cursor:pointer;white-space:nowrap;flex:none;font-size:12px;font-weight:600}.ap-resource-link:hover{text-decoration:underline}.ap-gen-footer{border-top:1px solid var(--row-border);gap:8px;padding-top:12px;display:flex}.ap-sent-btn{color:#006915!important;color:lab(37.9407% -42.3641 37.5694)!important;cursor:default!important;background:#2eb86614!important;border:1.5px solid #2eb86647!important}
