@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);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}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.container{width:100%}@media (width>=40rem){.container{max-width:40rem}}@media (width>=48rem){.container{max-width:48rem}}@media (width>=64rem){.container{max-width:64rem}}@media (width>=80rem){.container{max-width:80rem}}@media (width>=96rem){.container{max-width:96rem}}.block{display:block}.flex{display:flex}.hidden{display:none}.inline-block{display:inline-block}.table{display:table}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.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,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.select-all{-webkit-user-select:all;user-select:all}}:root,[data-theme=dark]{--bg-base:#0f172a;--bg-gradient:linear-gradient(160deg, #0f172a 0%, #1e293b 50%, #0f172a 100%);--bg-surface:#0f172ad9;--bg-surface-2:#0f172a99;--bg-surface-3:#1e293bcc;--bg-card:#ffffff08;--bg-card-hover:#ffffff0f;--bg-input:#ffffff0a;--bg-input-focus:#ffffff0f;--bg-input-dark:#0003;--bg-input-deep:#0000004d;--bg-hover:#ffffff0f;--bg-overlay:#0f172abf;--bg-glow-1:#6366f126;--bg-glow-2:#10b98114;--bg-glow-3:#8b5cf61f;--bg-glow-4:#3b82f60f;--bg-btn-secondary:#ffffff0f;--bg-btn-google:#ffffff0d;--bg-btn-google-hover:#ffffff1a;--bg-topbar:linear-gradient(135deg, #0f172afa, #1e293bfa);--text-primary:#f1f5f9;--text-secondary:#e2e8f0;--text-muted:#94a3b8;--text-dimmed:#64748b;--text-faint:#475569;--text-card-title:#e2e8f0;--text-card-body:#94a3b8;--text-label:#cbd5e1;--border-primary:#ffffff0f;--border-secondary:#ffffff14;--border-tertiary:#ffffff1f;--border-input:#ffffff14;--border-input-hover:#fff3;--primary-color:#6366f1;--primary-hover:#7c7ff0;--primary-glow:#6366f14d;--primary-subtle:#6366f11f;--primary-border:#6366f140;--accent-purple:#8b5cf6;--accent-indigo-light:#818cf8;--accent-indigo-lighter:#a5b4fc;--accent-lavender:#a78bfa;--accent-green:#34d399;--accent-green-light:#6ee7b7;--shadow-card:0 25px 80px #00000080, 0 0 60px #8b5cf60d;--shadow-card-hover:0 12px 40px #0000004d;--shadow-btn:0 4px 20px #6366f14d;--shadow-btn-hover:0 8px 30px #6366f173;--shadow-nav:0 2px 16px #0000004d;--surface-light:#0f172a;--public-card-bg:#0f172a99;--public-card-shadow:0 4px 6px -1px #0000004d;--public-card-shadow-hover:0 10px 15px -3px #00000080}[data-theme=light]{--bg-base:#f8fafc;--bg-gradient:linear-gradient(160deg, #f0f4f8 0%, #e2e8f0 50%, #f0f4f8 100%);--bg-surface:#ffffffeb;--bg-surface-2:#fffc;--bg-surface-3:#f1f5f9f2;--bg-card:#ffffffb3;--bg-card-hover:#ffffffe6;--bg-input:#f1f5f9cc;--bg-input-focus:#fff;--bg-input-dark:#f1f5f9e6;--bg-input-deep:#f1f5f9;--bg-hover:#6366f10d;--bg-overlay:#ffffffd9;--bg-glow-1:#6366f114;--bg-glow-2:#10b9810f;--bg-glow-3:#8b5cf60f;--bg-glow-4:#3b82f60a;--bg-btn-secondary:#6366f10f;--bg-btn-google:#00000008;--bg-btn-google-hover:#0000000f;--bg-topbar:linear-gradient(135deg, #fffffff2, #f1f5f9f2);--text-primary:#1e293b;--text-secondary:#334155;--text-muted:#64748b;--text-dimmed:#94a3b8;--text-faint:#cbd5e1;--text-card-title:#1e293b;--text-card-body:#64748b;--text-label:#475569;--border-primary:#0000000f;--border-secondary:#00000014;--border-tertiary:#0000001f;--border-input:#0000001a;--border-input-hover:#6366f14d;--primary-color:#4f46e5;--primary-hover:#6366f1;--primary-glow:#4f46e533;--primary-subtle:#4f46e514;--primary-border:#4f46e533;--accent-purple:#7c3aed;--accent-indigo-light:#6366f1;--accent-indigo-lighter:#818cf8;--accent-lavender:#8b5cf6;--accent-green:#059669;--accent-green-light:#10b981;--shadow-card:0 10px 40px #00000014, 0 0 0 1px #0000000a;--shadow-card-hover:0 20px 50px #0000001f;--shadow-btn:0 4px 14px #4f46e533;--shadow-btn-hover:0 8px 25px #4f46e54d;--shadow-nav:0 2px 12px #0000000f;--surface-light:#f8fafc;--public-card-bg:#ffffffe6;--public-card-shadow:0 4px 6px -1px #0000000d;--public-card-shadow-hover:0 10px 15px -3px #0000001a}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg-base);min-width:320px;min-height:100vh;color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0;transition:background-color .35s,color .35s}#root{width:100%}.theme-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;background:0 0;border:none;outline:none;align-items:center;gap:8px;padding:4px;display:flex;position:relative}.theme-toggle-track{border:1px solid var(--border-secondary);background:#ffffff1a;border-radius:26px;justify-content:space-between;align-items:center;width:48px;height:26px;padding:0 5px;transition:all .35s cubic-bezier(.4,0,.2,1);display:flex;position:relative}[data-theme=light] .theme-toggle-track{background:#6366f11a;border-color:#6366f133}.theme-toggle-thumb{z-index:2;background:linear-gradient(135deg,#818cf8,#6366f1);border-radius:50%;width:20px;height:20px;transition:all .35s cubic-bezier(.4,0,.2,1);position:absolute;top:2px;left:2px;box-shadow:0 2px 8px #6366f166}[data-theme=light] .theme-toggle-thumb{background:linear-gradient(135deg,#f59e0b,#f97316);left:calc(100% - 22px);box-shadow:0 2px 8px #f59e0b66}.theme-toggle-icon{z-index:1;font-size:12px;transition:all .3s}.theme-toggle-icon.moon{color:#a5b4fc}.theme-toggle-icon.sun{color:#fbbf24}[data-theme=light] .theme-toggle-icon.moon{color:#94a3b8}[data-theme=light] .theme-toggle-icon.sun{color:#f59e0b}.text-theme-muted{color:var(--text-muted)}.text-theme-dimmed{color:var(--text-dimmed)}.text-theme-faint{color:var(--text-faint)}.text-theme-secondary{color:var(--text-secondary)}.text-theme-label{color:var(--text-label)}.text-theme-primary{color:var(--text-primary)}.text-theme-error{color:#fca5a5}.text-theme-warning{color:#fbbf24}.text-theme-success{color:#34d399}.text-theme-link-icon{color:var(--text-faint)}[data-theme=light] .text-theme-error{color:#dc2626}[data-theme=light] .text-theme-warning{color:#d97706}[data-theme=light] .text-theme-success{color:#059669}.alert-themed{border-radius:10px;margin-bottom:24px;padding:12px 16px;font-size:14px}.alert-themed.alert-error{color:#fca5a5;background:#ef44441a;border:1px solid #ef444433}.alert-themed.alert-warning{color:#fbbf24;background:#f59e0b1a;border:1px solid #f59e0b33}[data-theme=light] .alert-themed.alert-error{color:#dc2626;background:#ef44440f}[data-theme=light] .alert-themed.alert-warning{color:#d97706;background:#f59e0b0f}.hint-text{color:var(--text-dimmed);font-size:12px}.hint-text-sm{color:var(--text-dimmed);font-size:11px}.hint-text-md{color:var(--text-dimmed);font-size:13px}.btn-edit-key{background:var(--bg-btn-secondary);border:1px solid var(--border-secondary);color:var(--text-secondary);border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.btn-edit-key:hover{background:var(--bg-hover);border-color:var(--border-tertiary);color:var(--text-primary)}.placeholder-text{color:var(--text-dimmed)}.submitting-overlay{z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;background:#0f172acc;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}[data-theme=light] .submitting-overlay{color:var(--text-primary);background:#ffffffd9}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}.home-page{background:var(--bg-gradient);min-height:100vh;color:var(--text-primary);flex-direction:column;transition:background .35s,color .35s;display:flex}.home-navbar{z-index:50;background:var(--bg-overlay);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border-primary);padding:0 24px;transition:background .35s;position:sticky;top:0}.navbar-inner{justify-content:space-between;align-items:center;max-width:1100px;height:60px;margin:0 auto;display:flex}.navbar-brand{letter-spacing:-.01em;color:var(--text-primary);font-size:16px;font-weight:700}.navbar-actions{align-items:center;gap:12px;display:flex}.nav-link{color:var(--text-muted);border-radius:8px;padding:6px 14px;font-size:13px;font-weight:600;text-decoration:none;transition:all .2s}.nav-link:hover{color:var(--text-primary);background:var(--bg-hover)}.nav-link-primary{background:linear-gradient(135deg, var(--primary-color), var(--accent-purple));border:none;color:#fff!important}.nav-link-primary:hover{box-shadow:0 4px 16px var(--primary-glow);background:linear-gradient(135deg, var(--primary-hover), #9d78f8)!important}.user-menu{align-items:center;gap:10px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--primary-color), var(--accent-purple));color:#fff;letter-spacing:.02em;width:38px;height:38px;box-shadow:0 2px 12px var(--primary-glow);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.user-nickname{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:140px;font-size:14px;font-weight:600;overflow:hidden}.btn-signout{background:var(--bg-btn-secondary);border:1px solid var(--border-secondary);color:var(--text-muted);cursor:pointer;border-radius:8px;align-items:center;padding:8px;font-size:14px;transition:all .2s;display:flex}.btn-signout:hover{color:#f87171;background:#f871711a;border-color:#f8717133}.welcome-avatar{background:linear-gradient(135deg, var(--primary-color), var(--accent-purple), var(--accent-lavender));color:#fff;width:72px;height:72px;box-shadow:0 8px 32px var(--primary-glow);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 20px;font-size:26px;font-weight:800;animation:2s ease-in-out infinite avatar-pulse;display:flex}@keyframes avatar-pulse{0%,to{box-shadow:0 8px 32px var(--primary-glow)}50%{box-shadow:0 8px 48px #6366f180}}.hero-section{justify-content:center;align-items:center;min-height:65vh;padding:80px 24px 60px;display:flex;position:relative;overflow:hidden}.hero-glow{background:radial-gradient(circle, var(--bg-glow-1) 0%, var(--bg-glow-2) 40%, transparent 70%);pointer-events:none;filter:blur(60px);width:700px;height:700px;position:absolute;top:-120px;left:50%;transform:translate(-50%)}.hero-content{text-align:center;z-index:1;max-width:720px;position:relative}.hero-badge{background:var(--primary-subtle);border:1px solid var(--primary-border);color:var(--accent-indigo-lighter);letter-spacing:.02em;border-radius:20px;margin-bottom:24px;padding:6px 18px;font-size:13px;font-weight:600;display:inline-block}.hero-title{letter-spacing:-.03em;color:var(--text-primary);margin:0 0 20px;font-size:44px;font-weight:800;line-height:1.2}.gradient-text{background:linear-gradient(135deg, var(--accent-indigo-light), var(--accent-green));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-description{color:var(--text-muted);margin:0 0 36px;max-width:560px;margin-inline:auto;font-size:17px;line-height:1.7}.hero-actions{flex-wrap:wrap;justify-content:center;gap:14px;display:flex}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:12px;align-items:center;gap:8px;padding:12px 28px;font-size:15px;font-weight:600;text-decoration:none;transition:all .25s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--primary-color), var(--accent-purple));color:#fff;box-shadow:var(--shadow-btn)}.btn-primary:hover{box-shadow:var(--shadow-btn-hover);transform:translateY(-2px)}.btn-primary .btn-arrow{transition:transform .2s}.btn-primary:hover .btn-arrow{transform:translate(3px)}.btn-secondary{background:var(--bg-btn-secondary);border:1px solid var(--border-tertiary);color:var(--text-label)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-input-hover);color:var(--text-primary);transform:translateY(-2px)}.features-section{width:100%;max-width:1000px;margin:0 auto;padding:60px 24px 80px}.section-title{text-align:center;letter-spacing:-.02em;color:var(--text-primary);margin:0 0 40px;font-size:28px;font-weight:700}.features-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;display:grid}.feature-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:16px;padding:28px 24px;transition:all .25s}.feature-card:hover{background:var(--bg-card-hover);border-color:var(--border-tertiary);box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}.feature-icon{border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:16px;font-size:20px;display:flex}.icon-blue{color:#60a5fa;background:#3b82f626}.icon-green{color:#34d399;background:#10b98126}.icon-amber{color:#fbbf24;background:#f59e0b26}.icon-purple{color:#a78bfa;background:#8b5cf626}[data-theme=light] .icon-blue{color:#3b82f6;background:#3b82f61a}[data-theme=light] .icon-green{color:#059669;background:#10b9811a}[data-theme=light] .icon-amber{color:#d97706;background:#f59e0b1a}[data-theme=light] .icon-purple{color:#7c3aed;background:#8b5cf61a}.feature-card h3{color:var(--text-card-title);margin:0 0 8px;font-size:16px;font-weight:600}.feature-card p{color:var(--text-card-body);margin:0;font-size:13px;line-height:1.6}.home-footer{border-top:1px solid var(--border-primary);margin-top:auto;padding:20px 24px}.footer-inner{max-width:1000px;color:var(--text-dimmed);justify-content:space-between;align-items:center;margin:0 auto;font-size:13px;display:flex}.footer-link{color:var(--text-dimmed);align-items:center;gap:6px;text-decoration:none;transition:color .15s;display:flex}.footer-link:hover{color:var(--text-muted)}@media (width<=640px){.hero-title{font-size:30px}.hero-description{font-size:15px}.section-title{font-size:22px}.user-nickname{display:none}.welcome-avatar{width:56px;height:56px;font-size:20px}}.login-page{background:var(--bg-gradient);justify-content:center;align-items:center;min-height:100vh;padding:24px;transition:background .35s;display:flex;position:relative;overflow:hidden}.login-glow{background:radial-gradient(circle, var(--bg-glow-3) 0%, var(--bg-glow-4) 50%, transparent 70%);pointer-events:none;filter:blur(80px);width:600px;height:600px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.login-card{background:var(--bg-surface);border:1px solid var(--border-secondary);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);width:100%;max-width:440px;box-shadow:var(--shadow-card);border-radius:20px;padding:40px 36px;transition:background .35s,border-color .35s;animation:.4s cubic-bezier(.16,1,.3,1) card-appear;position:relative}@keyframes card-appear{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.login-back{color:var(--text-dimmed);align-items:center;gap:6px;margin-bottom:28px;font-size:13px;text-decoration:none;transition:color .15s;display:inline-flex}.login-back:hover{color:var(--text-muted)}.login-header{text-align:center;margin-bottom:28px}.login-logo{margin-bottom:12px;font-size:40px}.login-header h1{color:var(--text-primary);margin:0 0 6px;font-size:24px;font-weight:700}.login-header p{color:var(--text-dimmed);margin:0;font-size:14px}.google-btn{border:1px solid var(--border-input);background:var(--bg-btn-google);width:100%;color:var(--text-secondary);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;gap:10px;padding:12px 24px;font-family:inherit;font-size:14px;font-weight:600;transition:all .25s;display:flex}.google-btn:hover{background:var(--bg-btn-google-hover);border-color:var(--border-input-hover);transform:translateY(-1px);box-shadow:0 4px 16px #00000026}.google-btn svg{color:#ea4335;font-size:16px}.divider span{color:var(--text-faint);white-space:nowrap;text-transform:uppercase;letter-spacing:.04em;font-size:12px}.auth-error{color:#fca5a5;text-align:center;background:#ef44441a;border:1px solid #ef444440;border-radius:10px;margin-bottom:16px;padding:10px 14px;font-size:13px;animation:.3s ease-in-out shake}[data-theme=light] .auth-error{color:#dc2626;background:#ef44440f}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.auth-success{color:#86efac;text-align:center;background:#22c55e1a;border:1px solid #22c55e40;border-radius:10px;margin-bottom:16px;padding:10px 14px;font-size:13px}[data-theme=light] .auth-success{color:#059669;background:#22c55e0f}.login-form{flex-direction:column;gap:18px;display:flex}.form-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}.input-icon{color:var(--text-faint);pointer-events:none;z-index:1;font-size:14px;position:absolute;left:14px}.input-wrapper input{border:1px solid var(--border-input);background:var(--bg-input);width:100%;color:var(--text-secondary);border-radius:10px;outline:none;padding:12px 14px 12px 42px;font-family:inherit;font-size:14px;transition:all .2s}.input-wrapper input::placeholder{color:var(--text-faint)}.password-toggle{color:var(--text-faint);cursor:pointer;background:0 0;border:none;padding:4px;font-size:14px;transition:color .15s;position:absolute;right:12px}.password-toggle:hover{color:var(--text-muted)}.login-submit-btn{background:linear-gradient(135deg, var(--primary-color), var(--accent-purple));color:#fff;cursor:pointer;width:100%;box-shadow:var(--shadow-btn);border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;min-height:48px;margin-top:4px;padding:13px 24px;font-family:inherit;font-size:15px;font-weight:600;transition:all .25s;display:flex}.login-submit-btn:hover:not(:disabled){box-shadow:var(--shadow-btn-hover);transform:translateY(-1px)}.login-submit-btn:disabled{opacity:.7;cursor:not-allowed}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{text-align:center;border-top:1px solid var(--border-primary);color:var(--text-dimmed);justify-content:center;gap:6px;margin-top:28px;padding-top:20px;font-size:13px;display:flex}.register-link{color:var(--accent-indigo-light);font-weight:600;text-decoration:none;transition:color .15s}.register-link:hover{color:var(--accent-indigo-lighter)}@media (width<=480px){.login-card{padding:32px 24px}.login-header h1{font-size:20px}}.public-exams-page{background:var(--bg-gradient);min-height:100vh;color:var(--text-primary);padding:40px 20px;transition:background .35s,color .35s}.public-exams-container{max-width:1000px;margin:0 auto}.public-exams-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.public-exams-header-left{flex-direction:column;gap:12px;display:flex}.public-exams-header-left h1{color:var(--text-primary);align-items:center;gap:12px;margin:0;font-size:28px;display:flex}.public-exams-subtitle{color:var(--text-muted);margin-top:0;margin-bottom:32px;font-size:16px}.public-exam-card{background:var(--public-card-bg);box-shadow:var(--public-card-shadow);border:1px solid var(--border-secondary);border-radius:16px;justify-content:space-between;align-items:center;padding:24px;transition:all .3s;display:flex}.public-exam-card:hover{box-shadow:var(--public-card-shadow-hover);border-color:var(--primary-color);transform:translateY(-4px)}.exam-card-actions{align-items:center;gap:12px;display:flex}.btn-play{background:linear-gradient(135deg, var(--primary-color), var(--accent-purple));color:#fff;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.btn-play:hover{background:linear-gradient(135deg, var(--primary-hover), var(--accent-purple));transform:translateY(-2px)}.btn-copy{background:var(--bg-btn-secondary);width:40px;height:40px;color:var(--text-muted);border:1px solid var(--border-secondary);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.btn-copy:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-copy.copied{color:#fff;background:#10b981;border-color:#10b981}.meta-date{color:var(--text-dimmed);font-size:13px}.create-exam-page{background:var(--bg-gradient);min-height:100vh;color:var(--text-primary);padding:40px 24px;transition:background .35s,color .35s}.create-exam-container{background:var(--bg-surface-2);border:1px solid var(--border-secondary);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);max-width:800px;box-shadow:var(--shadow-card);border-radius:20px;margin:0 auto;padding:40px;transition:background .35s,border-color .35s}.create-exam-header{align-items:center;gap:16px;margin-bottom:32px;display:flex}.btn-back{color:var(--text-muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:0;font-size:14px;font-weight:600;text-decoration:none;transition:color .2s;display:inline-flex}.btn-back:hover{color:var(--text-secondary)}.create-exam-header h1{background:linear-gradient(135deg, var(--accent-indigo-light), var(--accent-green));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:28px;font-weight:800}.stepper{margin-bottom:40px;display:flex;position:relative}.stepper:before{content:"";background:var(--border-input);z-index:1;height:2px;position:absolute;top:15px;left:0;right:0}.step{text-align:center;z-index:2;color:var(--text-dimmed);flex-direction:column;flex:1;align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex;position:relative}.step.active{color:var(--accent-indigo-light)}.step.completed{color:var(--accent-green)}.step-circle{background:var(--bg-input-dark);border:2px solid var(--border-input);border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;transition:all .3s;display:flex}.step.active .step-circle{border-color:var(--accent-indigo-light);background:#818cf81a;box-shadow:0 0 15px #818cf84d}.step.completed .step-circle{border-color:var(--accent-green);background:var(--accent-green);color:#0f172a}.form-group{margin-bottom:24px}.form-group label{color:var(--text-label);margin-bottom:8px;font-size:14px;font-weight:600;display:block}.form-input{background:var(--bg-input-dark);border:1px solid var(--border-input);width:100%;color:var(--text-primary);border-radius:10px;padding:12px 16px;font-size:15px;transition:all .2s}.form-input:focus{border-color:var(--accent-indigo-light);outline:none;box-shadow:0 0 0 3px #818cf826}textarea.form-input{resize:vertical;min-height:80px}.file-upload-zone{border:2px dashed var(--border-tertiary);text-align:center;cursor:pointer;background:var(--bg-input-dark);border-radius:12px;padding:40px 20px;transition:all .2s}.file-upload-zone:hover,.file-upload-zone.drag-active{border-color:var(--accent-indigo-light);background:#818cf80d}.file-upload-zone .upload-icon{color:var(--accent-indigo-light);margin-bottom:12px;font-size:32px}.file-upload-zone .upload-text{color:var(--text-label);margin:0 0 8px;font-size:15px}.file-upload-zone .upload-hint{color:var(--text-dimmed);margin:0;font-size:13px}.file-info{color:var(--accent-green);background:#10b9811a;border:1px solid #10b98133;border-radius:10px;justify-content:space-between;align-items:center;padding:16px;display:flex}.file-info-left{align-items:center;gap:12px;display:flex}.file-info .file-name{font-size:14px;font-weight:600}.btn-remove-file{color:#ef4444;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;display:flex}.btn-remove-file:hover{background:#ef44441a}.toggle-group{background:var(--bg-input-dark);border-radius:12px;gap:16px;margin-bottom:24px;padding:6px;display:flex}.toggle-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:10px;font-weight:600;transition:all .2s}.toggle-btn.active{background:var(--bg-surface-3);color:var(--text-primary);box-shadow:0 2px 8px #0003}.answer-section{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:12px;margin-bottom:24px;padding:24px}.answer-section h3{color:var(--text-secondary);justify-content:space-between;align-items:center;margin:0 0 16px;font-size:16px;display:flex}.points-input{background:var(--bg-input-deep);border:1px solid var(--border-input);width:60px;color:var(--text-primary);text-align:center;border-radius:6px;padding:4px 8px;font-size:14px}.tn-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;display:grid}.question-row{align-items:center;gap:8px;display:flex}.q-label{width:24px;color:var(--text-muted);font-size:14px;font-weight:600}.tn-options{gap:4px;display:flex}.tn-opt{border:1px solid var(--border-tertiary);width:28px;height:28px;color:var(--text-label);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:600;transition:all .2s;display:flex}.tn-opt:hover{border-color:var(--accent-indigo-light);background:#818cf81a}.tn-opt.selected{background:var(--accent-indigo-light);border-color:var(--accent-indigo-light);color:#fff}.ds-grid{flex-direction:column;gap:16px;display:flex}.ds-row{background:var(--bg-input-dark);border-radius:8px;flex-direction:column;gap:8px;padding:12px;display:flex}.ds-row-title{color:var(--text-secondary);font-size:14px;font-weight:600}.ds-options{gap:16px;display:flex}.ds-sub-opt{align-items:center;gap:8px;display:flex}.ds-sub-label{color:var(--text-muted);font-size:14px}.ds-toggle{border:1px solid var(--border-input);border-radius:6px;display:flex;overflow:hidden}.ds-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px 12px;font-size:13px;font-weight:600;transition:all .2s}.ds-btn.active.t-d{color:#0f172a;background:#34d399}.ds-btn.active.t-s{color:#fff;background:#ef4444}.tln-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;display:grid}.tln-input{background:var(--bg-input-deep);border:1px solid var(--border-input);color:var(--text-primary);border-radius:6px;flex:1;padding:6px 12px;font-size:14px}.graduated-scoring{grid-template-columns:repeat(4,1fr);gap:8px;margin-top:12px;display:grid}.graduated-item{background:var(--bg-input-dark);border-radius:8px;flex-direction:column;align-items:center;gap:4px;padding:8px;display:flex}.graduated-item label{color:var(--text-muted);font-size:12px}.graduated-item input{text-align:center;width:100%}.step-actions{border-top:1px solid var(--border-primary);justify-content:space-between;margin-top:40px;padding-top:24px;display:flex}.btn-secondary{background:var(--bg-btn-secondary);border:1px solid var(--border-input);color:var(--text-primary);cursor:pointer;border-radius:8px;padding:10px 24px;font-weight:600;transition:all .2s}.btn-secondary:hover:not(:disabled){background:var(--bg-hover)}.btn-primary{background:linear-gradient(135deg, var(--primary-color), var(--accent-purple));color:#fff;cursor:pointer;box-shadow:var(--shadow-btn);border:none;border-radius:8px;padding:10px 24px;font-weight:600;transition:all .2s}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-btn-hover);transform:translateY(-2px)}.btn:disabled{opacity:.5;cursor:not-allowed}.settings-section{align-items:center;gap:12px;margin-bottom:24px;display:flex}.checkbox-label{cursor:pointer;color:var(--text-secondary);align-items:center;gap:10px;font-size:15px;display:flex}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-indigo-light)}.publish-success{text-align:center;padding:40px 20px}.success-icon{color:var(--accent-green);margin-bottom:24px;font-size:64px}.publish-success h2{color:var(--text-primary);margin:0 0 16px;font-size:24px}.link-box{background:var(--bg-input-deep);border:1px solid var(--border-input);border-radius:8px;align-items:center;gap:12px;max-width:400px;margin:24px auto;padding:12px 16px;display:flex}.link-text{color:var(--accent-indigo-light);text-align:left;text-overflow:ellipsis;white-space:nowrap;flex:1;font-family:monospace;font-size:16px;overflow:hidden}.btn-icon{background:var(--bg-hover);color:var(--text-primary);cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.btn-icon:hover{background:var(--accent-indigo-light);color:#fff}.spinner{vertical-align:middle;border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin;display:inline-block}.total-points-card{text-align:center;background:linear-gradient(135deg,#6366f11a,#8b5cf61a);border:1px solid #6366f133;border-radius:12px;margin-bottom:24px;padding:16px}.total-points-card .val{color:var(--accent-lavender);font-size:32px;font-weight:800}.total-points-card .lbl{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:14px}.app-container{--toolbar-bg:#0f172aeb;--toolbar-border:#ffffff14;--tool-active-pencil:#3b82f6;--tool-active-bubble:#10b981;--tool-active-eraser:#ef4444;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-dim:#64748b;--as-bg-subtle:#ffffff0d;--as-bg-hover:#ffffff1a;--as-bg-faint:#ffffff08;--as-bg-panel:linear-gradient(160deg, #1e1b4b 0%, #0f172a 40%, #1e293b 100%);--as-border-subtle:#ffffff0f;--as-border-mid:#ffffff14;--as-border-strong:#ffffff1f;--as-scrollbar:#fff3;--as-scrollbar-hover:#ffffff4d;--as-container-bg:linear-gradient(160deg, #0f172a 0%, #1e293b 50%, #0f172a 100%);--as-pdf-bg:#333639;--as-resize-bg:#ffffff0a;--as-resize-dot:#ffffff40;--as-range-bg:#ffffff26;--as-range-thumb:#e2e8f0;--as-kbd-bg:#ffffff0f;--as-kbd-border:#ffffff1a;--as-shadow-toolbar:0 4px 30px #0000004d;--as-shadow-canvas:0 0 0 1px #0000001a, 0 25px 80px #00000040, 0 10px 30px #00000026;--as-overlay-bg:#000000a6;--as-panel-border:#8b5cf640;--as-panel-shadow:0 25px 80px #0009, 0 0 60px #8b5cf614, inset 0 1px 0 #ffffff0f;--as-header-bg:#ffffff05;--as-section-bg:#8b5cf60f;--as-section-border:#8b5cf626;--as-ds-error-icon-bg:#1e1b4b}[data-theme=light] .app-container{--toolbar-bg:#ffffffeb;--toolbar-border:#00000014;--text-primary:#1e293b;--text-secondary:#475569;--text-dim:#94a3b8;--as-bg-subtle:#0000000a;--as-bg-hover:#00000014;--as-bg-faint:#00000005;--as-bg-panel:linear-gradient(160deg, #f8fafc 0%, #fff 40%, #f1f5f9 100%);--as-border-subtle:#0000000f;--as-border-mid:#00000014;--as-border-strong:#0000001f;--as-scrollbar:#00000026;--as-scrollbar-hover:#00000040;--as-container-bg:linear-gradient(160deg, #e2e8f0 0%, #f1f5f9 50%, #e2e8f0 100%);--as-pdf-bg:#d1d5db;--as-resize-bg:#00000008;--as-resize-dot:#0003;--as-range-bg:#0000001f;--as-range-thumb:#475569;--as-kbd-bg:#0000000d;--as-kbd-border:#0000001a;--as-shadow-toolbar:0 2px 16px #00000014;--as-shadow-canvas:0 0 0 1px #00000014, 0 12px 40px #0000001a, 0 4px 16px #0000000f;--as-overlay-bg:#ffffffb3;--as-panel-border:#6366f133;--as-panel-shadow:0 25px 80px #00000026, 0 0 60px #6366f10a, inset 0 1px 0 #fffc;--as-header-bg:#00000005;--as-section-bg:#6366f10f;--as-section-border:#6366f126;--as-ds-error-icon-bg:#f8fafc}*{font-family:Inter,system-ui,-apple-system,sans-serif}.toolbar{z-index:50;-webkit-backdrop-filter:blur(20px)saturate(180%);background:var(--toolbar-bg);border-bottom:1px solid var(--toolbar-border);width:100%;box-shadow:var(--as-shadow-toolbar);justify-content:center;padding:12px 16px;display:flex;position:sticky;top:0}.toolbar-inner{flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;display:flex}.toolbar-title{color:var(--text-primary);white-space:nowrap;letter-spacing:-.02em;margin-right:8px;font-size:16px;font-weight:700}.toolbar-title span{background:linear-gradient(135deg,#60a5fa,#34d399);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.toolbar-divider{background:var(--as-border-strong);width:1px;height:28px;margin:0 4px}.tool-btn{cursor:pointer;color:var(--text-secondary);background:var(--as-bg-subtle);white-space:nowrap;border:1.5px solid #0000;border-radius:10px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.tool-btn:hover{background:var(--as-bg-hover);color:var(--text-primary)}.tool-btn.active-pencil{color:#93c5fd;background:#3b82f626;border-color:#3b82f666;box-shadow:0 0 20px #3b82f626}.tool-btn.active-bubble{color:#6ee7b7;background:#10b98126;border-color:#10b98166;box-shadow:0 0 20px #10b98126}.tool-btn.active-eraser{color:#fca5a5;background:#ef444426;border-color:#ef444466;box-shadow:0 0 20px #ef444426}.tool-btn.active-pan{color:#fcd34d;background:#f59e0b26;border-color:#f59e0b66;box-shadow:0 0 20px #f59e0b26}[data-theme=light] .tool-btn.active-pencil{color:#2563eb}[data-theme=light] .tool-btn.active-bubble{color:#059669}[data-theme=light] .tool-btn.active-eraser{color:#dc2626}[data-theme=light] .tool-btn.active-pan{color:#d97706}.tool-btn .icon{font-size:15px}.action-btn{cursor:pointer;color:var(--text-dim);white-space:nowrap;background:0 0;border:1.5px solid #0000;border-radius:10px;align-items:center;gap:6px;padding:8px 12px;font-size:13px;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.action-btn:hover:not(:disabled){background:var(--as-bg-subtle);color:var(--text-secondary)}.action-btn:disabled{opacity:.3;cursor:not-allowed}.action-btn .icon{font-size:14px}.size-control{align-items:center;gap:8px;padding:0 8px;display:flex}.size-control label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;font-size:11px}.size-control input[type=range]{appearance:none;background:var(--as-range-bg);border-radius:4px;outline:none;width:80px;height:4px}.size-control input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--as-range-thumb);cursor:pointer;border-radius:50%;width:14px;height:14px;transition:transform .15s;box-shadow:0 0 6px #0000004d}.size-control input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}.size-value{color:var(--text-secondary);text-align:center;font-variant-numeric:tabular-nums;min-width:20px;font-size:12px;font-weight:600}.zoom-controls{align-items:center;gap:2px;display:flex}.zoom-btn{cursor:pointer;width:32px;height:32px;color:var(--text-secondary);background:var(--as-bg-subtle);border:1.5px solid #0000;border-radius:8px;justify-content:center;align-items:center;font-size:13px;transition:all .15s;display:flex}.zoom-btn:hover:not(:disabled){background:var(--as-bg-hover);color:var(--text-primary)}.zoom-btn:disabled{opacity:.25;cursor:not-allowed}.zoom-btn:active:not(:disabled){transform:scale(.92)}.zoom-label{border:1.5px solid var(--as-border-mid);font-variant-numeric:tabular-nums;cursor:pointer;min-width:52px;height:32px;color:var(--text-primary);background:var(--as-bg-subtle);border-radius:8px;justify-content:center;align-items:center;padding:0 8px;font-size:12px;font-weight:600;transition:all .15s;display:flex}.zoom-label:hover{background:var(--as-bg-hover);border-color:var(--as-border-strong)}.canvas-wrapper{box-shadow:var(--as-shadow-canvas);text-align:left;background:#fff;border-radius:4px;flex-shrink:0;width:fit-content;display:inline-block;position:relative;overflow:hidden}.canvas-wrapper img{-webkit-user-select:none;user-select:none;pointer-events:none;display:block}.canvas-wrapper canvas{touch-action:none;width:100%;height:100%;position:absolute;top:0;left:0}.cursor-preview{pointer-events:none;z-index:10;border-radius:50%;transition:width 80ms,height 80ms,opacity .15s;position:absolute;transform:translate(-50%,-50%)}.cursor-preview.pencil{background:#3b82f614;border:1.5px solid #3b82f6b3}.cursor-preview.bubble{background:#10b9810f;border:2px dashed #10b981b3}.cursor-preview.eraser{background:#ef44440f;border:1.5px solid #ef4444b3}.shortcut-badge{background:var(--as-bg-subtle);min-width:18px;height:18px;color:var(--text-dim);border:1px solid var(--as-border-subtle);border-radius:4px;justify-content:center;align-items:center;margin-left:2px;padding:0 4px;font-size:10px;font-weight:600;display:inline-flex}.footer-tips{text-align:center;color:var(--text-dim);padding:16px 60px 16px 16px;font-size:12px;line-height:1.6;position:relative}.footer-tips kbd{background:var(--as-kbd-bg);border:1px solid var(--as-kbd-border);color:var(--text-secondary);border-radius:4px;margin:0 2px;padding:1px 6px;font-family:inherit;font-size:11px;display:inline-block}.tips-toggle-btn{cursor:pointer;border:none;transition:all .2s}.tips-toggle-btn.tips-close{background:var(--as-bg-subtle);color:var(--text-dim);border-radius:6px;justify-content:center;align-items:center;padding:4px 12px;font-size:12px;font-weight:500;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.tips-toggle-btn.tips-close:hover{color:#fca5a5;background:#ef444426}.tips-toggle-btn.tips-show{background:var(--toolbar-bg);border:1px solid var(--toolbar-border);color:var(--text-dim);z-index:50;border-radius:20px;padding:6px 14px;font-size:12px;font-weight:500;position:fixed;bottom:12px;right:16px;box-shadow:0 4px 16px #0006}.tips-toggle-btn.tips-show:hover{filter:brightness(1.3);color:var(--text-secondary);transform:translateY(-2px);box-shadow:0 6px 20px #00000080}.app-container{background:var(--as-container-bg);flex-direction:column;align-items:center;height:100vh;min-height:100vh;display:flex;overflow:hidden}.main-content{flex:1;width:100%;display:flex;position:relative;overflow:hidden}.pdf-pane{background:var(--as-pdf-bg);border-right:none;flex:1;min-width:150px;display:flex;position:relative}.pane-resize-handle{background:var(--as-resize-bg);border-left:1px solid var(--toolbar-border);border-right:1px solid var(--toolbar-border);cursor:col-resize;z-index:10;flex-shrink:0;justify-content:center;align-items:center;width:8px;transition:background .15s;display:flex;position:relative}.pane-resize-handle:hover{background:#3b82f626;border-color:#3b82f64d}.pane-resize-handle:active{background:#3b82f640}.resize-handle-dots{flex-direction:column;gap:3px;display:flex}.resize-handle-dots span{background:var(--as-resize-dot);border-radius:50%;width:3px;height:3px;transition:background .15s;display:block}.pane-resize-handle:hover .resize-handle-dots span{background:#3b82f6b3}.pdf-pane.minimized{background:var(--toolbar-bg);border:1px solid var(--toolbar-border);cursor:pointer;z-index:100;border-radius:12px;flex:none;align-items:center;width:auto;height:auto;padding:12px 20px;transition:all .2s;display:flex;position:absolute;bottom:24px;left:24px;box-shadow:0 10px 40px #00000080}.pdf-pane.minimized:hover{background:var(--toolbar-bg);filter:brightness(1.3);transform:translateY(-2px);box-shadow:0 14px 50px #0009}.pdf-minimized-content{align-items:center;gap:12px;display:flex}.canvas-area{text-align:center;scrollbar-width:thin;scrollbar-color:var(--as-scrollbar) transparent;flex:1;width:100%;padding:24px 16px 16px;overflow:auto}.canvas-area::-webkit-scrollbar{width:10px;height:10px}.canvas-area::-webkit-scrollbar-track{background:0 0}.canvas-area::-webkit-scrollbar-thumb{background:var(--as-scrollbar);background-clip:padding-box;border:2px solid #0000;border-radius:10px}.canvas-area::-webkit-scrollbar-thumb:hover{background:var(--as-scrollbar-hover);background-clip:padding-box}.canvas-area::-webkit-scrollbar-corner{background:0 0}@media (width<=768px){.toolbar-title{margin-right:4px;font-size:14px}.tool-btn{padding:6px 10px;font-size:12px}.tool-btn .label,.shortcut-badge,.toolbar-divider{display:none}.size-control input[type=range]{width:60px}.action-btn .label{display:none}}.drawing-cursor-none{cursor:none!important}.pencil-overlay{pointer-events:none;z-index:20;transform-origin:4px 11px;filter:drop-shadow(0 2px 6px #00000059);animation:.1s ease-in-out infinite alternate pencil-wobble;position:absolute;transform:translate(-4px,-11px)rotate(-32deg)}@keyframes pencil-wobble{0%{transform:translate(-4px,-11px)rotate(-33.5deg)}to{transform:translate(-4px,-11px)rotate(-30.5deg)}}.bubble-fill-boundary{pointer-events:none;z-index:9;background:#10b9810a;border:2px dashed #10b981cc;border-radius:50%;animation:.8s ease-in-out infinite alternate bubble-boundary-pulse;position:absolute;transform:translate(-50%,-50%);box-shadow:0 0 0 3px #10b98114,0 0 12px #10b98126}@keyframes bubble-boundary-pulse{0%{border-color:#10b981cc;box-shadow:0 0 0 3px #10b98114,0 0 12px #10b98126}to{border-color:#10b98173;box-shadow:0 0 0 5px #10b9810a,0 0 20px #10b9811a}}.parse-btn{position:relative;overflow:hidden;box-shadow:0 0 20px #8b5cf61f;color:#c4b5fd!important;background:linear-gradient(135deg,#8b5cf626,#3b82f626)!important;border-color:#8b5cf666!important}.parse-btn:hover:not(:disabled){box-shadow:0 0 30px #8b5cf633;color:#ddd6fe!important;background:linear-gradient(135deg,#8b5cf640,#3b82f640)!important}[data-theme=light] .parse-btn{color:#7c3aed!important}[data-theme=light] .parse-btn:hover:not(:disabled){color:#6d28d9!important}.parse-btn.parsing{animation:1.2s ease-in-out infinite parsing-pulse}@keyframes parsing-pulse{0%,to{box-shadow:0 0 20px #8b5cf626}50%{box-shadow:0 0 40px #8b5cf659}}.result-panel-overlay{background:var(--as-overlay-bg);-webkit-backdrop-filter:blur(8px);z-index:200;justify-content:center;align-items:center;animation:.25s overlay-fade-in;display:flex;position:fixed;inset:0}@keyframes overlay-fade-in{0%{opacity:0}to{opacity:1}}.result-panel{background:var(--as-bg-panel);border:1px solid var(--as-panel-border);width:90%;max-width:720px;max-height:85vh;box-shadow:var(--as-panel-shadow);border-radius:20px;flex-direction:column;animation:.35s cubic-bezier(.16,1,.3,1) panel-slide-up;display:flex;overflow:hidden}@keyframes panel-slide-up{0%{opacity:0;transform:translateY(30px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.result-panel-header{border-bottom:1px solid var(--as-border-mid);background:var(--as-header-bg);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.result-panel-header h2{background:linear-gradient(135deg,#c4b5fd,#93c5fd);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;align-items:center;gap:10px;margin:0;font-size:18px;font-weight:700;display:flex}.result-panel-actions{align-items:center;gap:8px;display:flex}.result-action-btn{border:1px solid var(--as-border-strong);background:var(--as-bg-subtle);color:var(--text-secondary);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:7px 14px;font-size:12px;font-weight:500;transition:all .15s;display:flex}.result-action-btn:hover{background:var(--as-bg-hover);color:var(--text-primary);border-color:var(--as-border-strong)}.result-close-btn{border:1px solid var(--as-border-mid);background:var(--as-bg-subtle);width:32px;height:32px;color:var(--text-dim);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;margin-left:4px;font-size:14px;transition:all .15s;display:flex}.result-close-btn:hover{color:#fca5a5;background:#ef444426;border-color:#ef44444d}.result-panel-body{scrollbar-width:thin;scrollbar-color:var(--as-scrollbar) transparent;padding:20px 24px;overflow-y:auto}.result-panel-body::-webkit-scrollbar{width:6px}.result-panel-body::-webkit-scrollbar-track{background:0 0}.result-panel-body::-webkit-scrollbar-thumb{background:var(--as-scrollbar);border-radius:6px}.result-section{margin-bottom:24px}.result-section:last-child{margin-bottom:0}.result-section-header{background:var(--as-section-bg);border:1px solid var(--as-section-border);border-radius:14px;gap:24px;padding:20px;display:flex}.result-field{flex-direction:column;flex:1;gap:6px;display:flex}.result-field-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);font-size:11px;font-weight:600}.result-field-value{font-variant-numeric:tabular-nums;letter-spacing:.15em;color:var(--text-primary);font-size:28px;font-weight:800}.sbd-value{background:linear-gradient(135deg,#fbbf24,#f59e0b);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.md-value{background:linear-gradient(135deg,#34d399,#10b981);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.result-section-title{color:var(--text-secondary);border-bottom:1px solid var(--as-border-subtle);margin:0 0 12px;padding-bottom:8px;font-size:14px;font-weight:600}.result-tn-grid{grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:6px;display:grid}.result-tn-item{background:var(--as-bg-faint);border:1px solid var(--as-border-subtle);border-radius:8px;justify-content:space-between;align-items:center;padding:6px 10px;transition:all .15s;display:flex}.result-tn-item.filled{background:#10b98114;border-color:#10b98133}.result-tn-item.empty{opacity:.4}.result-tn-item .q-num{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:11px;font-weight:600}.result-tn-item .q-ans{color:var(--text-dim);font-size:14px;font-weight:700}.result-tn-item .q-ans.ans-A{color:#f87171}.result-tn-item .q-ans.ans-B{color:#60a5fa}.result-tn-item .q-ans.ans-C{color:#34d399}.result-tn-item .q-ans.ans-D{color:#fbbf24}.result-ds-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;display:grid}.result-ds-item{background:var(--as-bg-faint);border:1px solid var(--as-border-subtle);border-radius:10px;align-items:center;gap:10px;padding:8px 12px;display:flex}.result-ds-item .q-num{color:var(--text-dim);min-width:18px;font-size:12px;font-weight:700}.ds-letters{gap:4px;display:flex}.ds-letter{border:1px solid var(--as-border-mid);background:var(--as-bg-faint);border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:flex}.ds-letter.ds-dung{color:#6ee7b7;background:#10b98126;border-color:#10b98159}.ds-letter.ds-sai{color:#fca5a5;background:#ef444426;border-color:#ef444459}.ds-letter.ds-empty{color:var(--text-dim);opacity:.4}.result-tln-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px;display:grid}.result-tln-item{background:var(--as-bg-faint);border:1px solid var(--as-border-subtle);border-radius:10px;align-items:center;gap:12px;padding:10px 14px;display:flex}.result-tln-item.filled{background:#3b82f614;border-color:#3b82f633}.result-tln-item.empty{opacity:.4}.result-tln-item .q-num{color:var(--text-dim);min-width:18px;font-size:12px;font-weight:700}.tln-value{font-variant-numeric:tabular-nums;color:#93c5fd;font-size:16px;font-weight:700}.result-tln-item.empty .tln-value{color:var(--text-dim)}@media (width<=640px){.result-panel{border-radius:16px;width:95%;max-height:90vh}.result-panel-header{padding:16px}.result-panel-header h2{font-size:15px}.result-panel-body{padding:16px}.result-section-header{flex-direction:column;gap:12px}.result-field-value{font-size:22px}.result-tn-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr))}.result-ds-grid,.result-tln-grid{grid-template-columns:1fr}.result-action-btn .label{display:none}}.error-count-badge{-webkit-text-fill-color:#fca5a5;color:#fca5a5;background:#ef444433;border:1px solid #ef444466;border-radius:20px;align-items:center;gap:5px;margin-left:10px;padding:3px 10px;font-size:12px;font-weight:700;animation:2s ease-in-out infinite error-badge-pulse;display:inline-flex}@keyframes error-badge-pulse{0%,to{box-shadow:0 0 #ef444400}50%{box-shadow:0 0 12px 2px #ef444433}}.error-banner{background:#ef444414;border:1px solid #ef444440;border-radius:12px;margin-bottom:20px;padding:16px;animation:.3s error-banner-in}@keyframes error-banner-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.error-banner-header{color:#fca5a5;align-items:center;gap:10px;margin-bottom:10px;font-size:13px;font-weight:500;display:flex}.error-banner-header>svg{color:#f87171;flex-shrink:0;font-size:16px}.error-banner-header strong{color:#fca5a5;font-weight:700}.error-inline-icon{color:#f59e0b;vertical-align:middle;margin:0 2px;font-size:10px;display:inline-flex}.error-list{margin:0;padding:0 0 0 20px;list-style:none}.error-list li{color:var(--text-secondary);padding:4px 0;font-size:12px;line-height:1.5;position:relative}.error-list li:before{content:"•";color:#f87171;font-weight:700;position:absolute;left:-14px}.result-field.has-error{background:#ef44440f;border:1px solid #ef444433;border-radius:10px;padding:12px}.field-error-icon{color:#f59e0b;vertical-align:middle;margin-left:6px;font-size:11px;display:inline-flex}.field-error-messages{flex-direction:column;gap:2px;margin-top:6px;display:flex}.field-error-msg{color:#fca5a5;font-size:11px;font-weight:500;line-height:1.4}.section-error-badge{color:#fca5a5;background:#ef444426;border:1px solid #ef44444d;border-radius:12px;align-items:center;gap:4px;margin-left:8px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.section-error-badge svg{font-size:10px}.result-tn-item.has-error{opacity:1!important;background:#ef44441f!important;border-color:#ef444459!important}.result-tn-item.has-error .q-num{color:#fca5a5}.item-error-icon{color:#f59e0b;vertical-align:middle;margin-left:3px;font-size:9px;animation:2s ease-in-out infinite error-icon-blink;display:inline-flex}@keyframes error-icon-blink{0%,to{opacity:1}50%{opacity:.4}}.result-ds-item.has-error{background:#ef444414;border-color:#ef444440}.ds-letter.ds-error{position:relative;color:#fbbf24!important;background:#f59e0b33!important;border-color:#f59e0b80!important}.ds-error-icon{color:#f59e0b;background:var(--as-ds-error-icon-bg);border-radius:50%;padding:1px;font-size:7px;position:absolute;top:-3px;right:-3px}.result-tln-item.has-error{flex-wrap:wrap;opacity:1!important;background:#ef444414!important;border-color:#ef444440!important}.result-tln-item.has-error .q-num{color:#fca5a5}.tln-error-details{border-top:1px solid #ef444426;flex-direction:column;gap:2px;width:100%;margin-top:4px;padding-top:6px;display:flex}[data-theme=light] .result-panel-header h2{background:linear-gradient(135deg,#7c3aed,#2563eb);-webkit-background-clip:text;background-clip:text}[data-theme=light] .tln-value{color:#2563eb}[data-theme=light] .result-tn-item .q-ans.ans-A{color:#dc2626}[data-theme=light] .result-tn-item .q-ans.ans-B{color:#2563eb}[data-theme=light] .result-tn-item .q-ans.ans-C{color:#059669}[data-theme=light] .result-tn-item .q-ans.ans-D{color:#d97706}[data-theme=light] .ds-letter.ds-dung{color:#059669}[data-theme=light] .ds-letter.ds-sai,[data-theme=light] .error-banner-header,[data-theme=light] .error-banner-header>svg{color:#dc2626}[data-theme=light] .error-banner-header strong{color:#b91c1c}[data-theme=light] .field-error-msg{color:#dc2626}[data-theme=light] .error-count-badge{-webkit-text-fill-color:#dc2626;color:#dc2626}[data-theme=light] .section-error-badge,[data-theme=light] .result-tn-item.has-error .q-num,[data-theme=light] .result-tln-item.has-error .q-num,[data-theme=light] .error-list li:before{color:#dc2626}[data-theme=light] .result-close-btn:hover,[data-theme=light] .tips-toggle-btn.tips-close:hover{color:#dc2626;background:#ef444414}[data-theme=light] .pdf-pane.minimized{box-shadow:0 10px 40px #0000001f}[data-theme=light] .pdf-pane.minimized:hover{box-shadow:0 14px 50px #0000002e}[data-theme=light] .tips-toggle-btn.tips-show{box-shadow:0 4px 16px #0000001a}[data-theme=light] .tips-toggle-btn.tips-show:hover{box-shadow:0 6px 20px #00000026}.exam-sim-root{flex-direction:column;width:100%;height:100vh;display:flex;position:relative;overflow:hidden}.exam-sim-root .app-container{flex:1;height:auto;min-height:0}.exam-sim-root.submitted .app-container{pointer-events:none;opacity:.45;filter:grayscale(.4);transition:all .5s}.exam-sim-top-bar{background:var(--bg-topbar);border-bottom:1px solid var(--border-secondary);box-shadow:var(--shadow-nav);z-index:60;flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 20px;transition:background .35s;display:flex}.exam-sim-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:40vw;font-size:15px;font-weight:600;overflow:hidden}.exam-sim-timer{background:#3b82f61a;border:1px solid #3b82f640;border-radius:12px;align-items:center;gap:10px;padding:6px 16px;transition:all .3s;display:flex}.exam-sim-timer.urgent{background:#f59e0b1f;border-color:#f59e0b66}.exam-sim-timer.critical{background:#ef444426;border-color:#ef444480;animation:1s ease-in-out infinite timer-critical-pulse}@keyframes timer-critical-pulse{0%,to{box-shadow:0 0 #ef444400}50%{box-shadow:0 0 20px 4px #ef444440}}.exam-sim-timer-icon{font-size:18px}.exam-sim-timer-display{flex-direction:column;gap:3px;display:flex}.exam-sim-timer-time{font-variant-numeric:tabular-nums;color:var(--text-secondary);letter-spacing:.05em;font-family:Inter,system-ui,monospace;font-size:20px;font-weight:800}[data-theme=light] .exam-sim-timer-time{color:#1e40af}.exam-sim-timer.urgent .exam-sim-timer-time{color:#fbbf24}.exam-sim-timer.critical .exam-sim-timer-time{color:#f87171;animation:.8s ease-in-out infinite timer-text-blink}@keyframes timer-text-blink{0%,to{opacity:1}50%{opacity:.4}}.exam-sim-timer-bar{background:var(--border-input);border-radius:3px;width:100px;height:3px;overflow:hidden}.exam-sim-timer-bar-fill{background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:3px;height:100%;transition:width 1s linear}.exam-sim-timer.urgent .exam-sim-timer-bar-fill{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.exam-sim-timer.critical .exam-sim-timer-bar-fill{background:linear-gradient(90deg,#ef4444,#f87171)}.exam-sim-submit-btn{color:#6ee7b7;cursor:pointer;letter-spacing:-.01em;background:linear-gradient(135deg,#10b98126,#34d3991a);border:1.5px solid #10b98180;border-radius:12px;align-items:center;gap:8px;padding:10px 24px;font-family:Inter,system-ui,sans-serif;font-size:14px;font-weight:700;transition:all .2s;display:flex}[data-theme=light] .exam-sim-submit-btn{color:#059669}.exam-sim-submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#10b98140,#34d39933);transform:translateY(-1px);box-shadow:0 0 24px #10b98133}.exam-sim-submit-btn:active:not(:disabled){transform:translateY(0)}.exam-sim-submit-btn:disabled{opacity:.4;cursor:not-allowed;border-color:var(--border-tertiary);background:var(--bg-btn-secondary);color:var(--text-muted)}.exam-sim-submitted-overlay{z-index:150;animation:.5s cubic-bezier(.16,1,.3,1) submitted-in;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes submitted-in{0%{opacity:0;transform:translate(-50%,-50%)scale(.8)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}.exam-sim-submitted-msg{background:var(--bg-surface);color:#6ee7b7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid #10b98159;border-radius:20px;align-items:center;gap:14px;padding:20px 36px;font-size:18px;font-weight:700;display:flex;box-shadow:0 20px 60px #0009,0 0 40px #10b9811a}[data-theme=light] .exam-sim-submitted-msg{color:#059669}.exam-sim-submitted-icon{font-size:28px}.exam-sim-dialog-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:300;background:#000000b3;justify-content:center;align-items:center;animation:.2s overlay-fade-in;display:flex;position:fixed;inset:0}[data-theme=light] .exam-sim-dialog-overlay{background:#0006}.exam-sim-dialog{background:var(--bg-surface);text-align:center;width:90%;max-width:420px;box-shadow:var(--shadow-card);border:1px solid #f59e0b4d;border-radius:20px;padding:32px 28px 24px;animation:.35s cubic-bezier(.16,1,.3,1) panel-slide-up}.exam-sim-dialog-icon{color:#f59e0b;margin-bottom:12px;font-size:36px}.exam-sim-dialog-title{color:var(--text-primary);margin:0 0 8px;font-size:20px;font-weight:800}.exam-sim-dialog-text{color:var(--text-muted);margin:0 0 4px;font-size:14px;line-height:1.6}.exam-sim-dialog-time{color:#fbbf24;font-weight:700}[data-theme=light] .exam-sim-dialog-time{color:#d97706}.exam-sim-dialog-note{color:var(--text-dimmed);margin:8px 0 20px;font-size:12px}.exam-sim-dialog-note strong{color:#fca5a5}[data-theme=light] .exam-sim-dialog-note strong{color:#dc2626}.exam-sim-dialog-actions{justify-content:center;gap:10px;display:flex}.exam-sim-dialog-btn{cursor:pointer;border:1.5px solid #0000;border-radius:10px;align-items:center;gap:6px;padding:10px 20px;font-family:Inter,system-ui,sans-serif;font-size:13px;font-weight:600;transition:all .2s;display:flex}.exam-sim-dialog-btn.cancel{background:var(--bg-btn-secondary);border-color:var(--border-tertiary);color:var(--text-muted)}.exam-sim-dialog-btn.cancel:hover{background:var(--bg-hover);color:var(--text-secondary)}.exam-sim-dialog-btn.confirm{color:#6ee7b7;background:linear-gradient(135deg,#10b98133,#34d39926);border-color:#10b98180}[data-theme=light] .exam-sim-dialog-btn.confirm{color:#059669}.exam-sim-dialog-btn.confirm:hover{background:linear-gradient(135deg,#10b98159,#34d39940);box-shadow:0 0 20px #10b98133}.exam-sim-error{color:#fca5a5;background:var(--bg-gradient);border:1px solid #ef444440;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:300px;padding:40px;font-size:15px;font-weight:500;display:flex}[data-theme=light] .exam-sim-error{color:#dc2626}.exam-sim-error-icon{font-size:40px}@media (width<=640px){.exam-sim-top-bar{padding:6px 12px}.exam-sim-timer-time{font-size:16px}.exam-sim-timer-bar{width:60px}.exam-sim-submit-btn{padding:8px 16px;font-size:13px}.exam-sim-submit-btn span{display:none}}.take-exam-page{background:var(--bg-base);min-height:100vh;color:var(--text-primary);justify-content:center;align-items:center;transition:background .35s,color .35s;display:flex}.take-exam-welcome{background:var(--bg-surface-3);border:1px solid var(--border-input);text-align:center;width:100%;max-width:500px;box-shadow:var(--shadow-card);border-radius:20px;margin:20px;padding:40px;transition:background .35s}.welcome-title{color:var(--text-primary);margin:0 0 8px;font-size:24px}.welcome-desc{color:var(--text-muted);margin:0 0 24px;font-size:14px}.student-form{text-align:left;flex-direction:column;gap:16px;display:flex}.student-form label{color:var(--text-label);font-size:14px;font-weight:600}.student-input{background:var(--bg-input-deep);border:1px solid var(--border-input);width:100%;color:var(--text-primary);border-radius:10px;padding:12px 16px;font-size:15px}.student-input:focus{border-color:var(--accent-indigo-light);outline:none}.btn-start{background:linear-gradient(135deg, var(--primary-color), var(--accent-purple));color:#fff;cursor:pointer;border:none;border-radius:10px;margin-top:10px;padding:14px;font-size:16px;font-weight:600;transition:all .2s}.btn-start:hover:not(:disabled){box-shadow:var(--shadow-btn-hover);transform:translateY(-2px)}.btn-start:disabled{opacity:.5;cursor:not-allowed}.result-screen{background:var(--bg-surface);border:1px solid var(--border-input);text-align:center;width:100%;max-width:600px;box-shadow:var(--shadow-card);border-radius:20px;margin:20px;padding:40px;transition:background .35s}.result-icon{color:var(--accent-green);margin-bottom:20px;font-size:64px}.score-display{background:var(--bg-input-deep);border:1px solid var(--border-primary);border-radius:16px;margin:30px 0;padding:30px}.score-value{color:var(--accent-lavender);margin-bottom:8px;font-size:64px;font-weight:800;line-height:1}.score-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:16px}.score-breakdown{border-top:1px solid var(--border-input);justify-content:center;gap:30px;margin-top:20px;padding-top:20px;display:flex}.breakdown-item{flex-direction:column;display:flex}.bd-val{color:var(--text-primary);font-size:20px;font-weight:700}.bd-lbl{color:var(--text-dimmed);font-size:12px}.spinner-large{border:3px solid var(--border-input);border-top-color:var(--accent-indigo-light);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}.my-exams-page{background:var(--bg-gradient);min-height:100vh;color:var(--text-primary);padding:40px 24px;transition:background .35s,color .35s}.my-exams-container{max-width:900px;margin:0 auto}.my-exams-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:32px;display:flex}.my-exams-header-left{align-items:center;gap:16px;display:flex}.my-exams-header h1{background:linear-gradient(135deg, var(--accent-indigo-light), var(--accent-green));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:28px;font-weight:800}.btn-back-link{color:var(--text-muted);align-items:center;gap:8px;font-size:14px;font-weight:600;text-decoration:none;transition:color .2s;display:inline-flex}.btn-back-link:hover{color:var(--text-secondary)}.btn-create-new{background:linear-gradient(135deg, var(--primary-color), var(--accent-purple));color:#fff;cursor:pointer;box-shadow:var(--shadow-btn);border:none;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.btn-create-new:hover{box-shadow:var(--shadow-btn-hover);transform:translateY(-2px)}.exam-cards-grid{flex-direction:column;gap:16px;display:flex}.exam-card{background:var(--bg-surface-2);border:1px solid var(--border-secondary);color:inherit;cursor:pointer;border-radius:16px;justify-content:space-between;align-items:center;gap:20px;padding:24px;text-decoration:none;transition:all .2s;display:flex}.exam-card:hover{background:var(--bg-surface-3);box-shadow:var(--shadow-card-hover);border-color:#818cf833;transform:translateY(-2px)}.exam-card-info{flex:1;min-width:0}.exam-card-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin:0 0 6px;font-size:16px;font-weight:700;overflow:hidden}.exam-card-meta{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.meta-item{color:var(--text-muted);align-items:center;gap:6px;font-size:13px;display:flex}.meta-item svg{font-size:12px}.exam-card-stats{flex-shrink:0;align-items:center;gap:16px;display:flex}.stat-box{background:var(--bg-input-dark);border-radius:10px;flex-direction:column;align-items:center;min-width:60px;padding:8px 16px;display:flex}.stat-value{color:var(--accent-indigo-light);font-size:20px;font-weight:800}.stat-label{color:var(--text-dimmed);text-transform:uppercase;letter-spacing:.04em;font-size:11px}.status-badge{border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.status-badge.published{color:#34d399;background:#10b98126}.status-badge.draft{color:#fbbf24;background:#f59e0b26}[data-theme=light] .status-badge.published{color:#059669}[data-theme=light] .status-badge.draft{color:#d97706}.exam-card-arrow{color:var(--text-faint);font-size:14px;transition:transform .2s}.exam-card:hover .exam-card-arrow{color:var(--accent-indigo-light);transform:translate(4px)}.empty-state{text-align:center;color:var(--text-dimmed);padding:80px 20px}.empty-icon{opacity:.5;margin-bottom:20px;font-size:48px}.empty-state h2{color:var(--text-muted);margin:0 0 12px;font-size:20px}.empty-state p{margin:0 0 24px;font-size:14px}.loading-center{justify-content:center;align-items:center;min-height:300px;display:flex}.spinner-lg{border:3px solid var(--border-input);border-top-color:var(--accent-indigo-light);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@media (width<=640px){.exam-card{flex-direction:column;align-items:flex-start}.exam-card-stats{justify-content:flex-start;width:100%}.my-exams-header{flex-direction:column;align-items:flex-start}}.exam-manage-page{background:var(--bg-gradient);min-height:100vh;color:var(--text-primary);padding:40px 24px;transition:background .35s,color .35s}.exam-manage-container{max-width:1000px;margin:0 auto}.exam-manage-header{margin-bottom:32px}.exam-manage-nav{align-items:center;gap:12px;margin-bottom:16px;display:flex}.exam-manage-header h1{color:var(--text-primary);margin:0 0 8px;font-size:26px;font-weight:800}.exam-manage-header-meta{flex-wrap:wrap;align-items:center;gap:20px;display:flex}.exam-info-row{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:32px;display:grid}.info-card{background:var(--bg-surface-2);border:1px solid var(--border-primary);text-align:center;border-radius:14px;padding:20px;transition:background .35s}.info-card-value{color:var(--accent-indigo-light);font-size:28px;font-weight:800}.info-card-label{color:var(--text-dimmed);text-transform:uppercase;letter-spacing:.05em;margin-top:4px;font-size:12px}.exam-link-section{background:var(--bg-input-dark);border:1px solid var(--border-primary);border-radius:12px;align-items:center;gap:12px;margin-bottom:32px;padding:16px 20px;display:flex}.exam-link-section .link-label{color:var(--text-dimmed);white-space:nowrap;font-size:13px}.exam-link-section .link-url{color:var(--accent-indigo-light);text-overflow:ellipsis;white-space:nowrap;flex:1;font-family:monospace;font-size:14px;overflow:hidden}.btn-copy-sm{background:var(--bg-btn-secondary);color:var(--text-muted);cursor:pointer;border:none;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;transition:all .2s;display:flex}.btn-copy-sm:hover{background:var(--accent-indigo-light);color:#fff}.actions-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.actions-bar h2{color:var(--text-secondary);margin:0;font-size:18px;font-weight:700}.btn-grade{color:#6ee7b7;cursor:pointer;background:linear-gradient(135deg,#10b98133,#34d39926);border:1.5px solid #10b98166;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}[data-theme=light] .btn-grade{color:#059669}.btn-grade:hover:not(:disabled){background:linear-gradient(135deg,#10b98159,#34d39940);transform:translateY(-1px);box-shadow:0 0 20px #10b98126}.btn-grade:disabled{opacity:.5;cursor:not-allowed}.submissions-table-wrapper{background:var(--bg-surface-2);border:1px solid var(--border-primary);border-radius:16px;transition:background .35s;overflow:hidden}.submissions-table{border-collapse:collapse;width:100%;font-size:14px}.submissions-table thead{background:var(--bg-input-dark)}.submissions-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-primary);padding:14px 16px;font-size:12px;font-weight:600}.submissions-table td{border-bottom:1px solid var(--border-primary);color:var(--text-label);padding:14px 16px}.submissions-table tbody tr{transition:background .15s}.submissions-table tbody tr:hover{background:var(--bg-card)}.submissions-table tbody tr:last-child td{border-bottom:none}.score-cell{font-size:16px;font-weight:700}.score-cell.has-score{color:var(--accent-lavender)}.score-cell.no-score{color:var(--text-dimmed);font-size:13px;font-weight:400}.row-number{color:var(--text-faint);font-variant-numeric:tabular-nums;font-weight:600}.time-cell{color:var(--text-dimmed);font-variant-numeric:tabular-nums}.date-cell{color:var(--text-dimmed);font-size:13px}.empty-submissions{text-align:center;color:var(--text-dimmed);padding:60px 20px}.empty-submissions-icon{opacity:.5;margin-bottom:16px;font-size:40px}.empty-submissions h3{color:var(--text-muted);margin:0 0 8px}.empty-submissions p{margin:0;font-size:14px}.grade-toast{color:#fff;z-index:999;background:#10b981f2;border-radius:12px;align-items:center;gap:10px;padding:14px 24px;font-size:14px;font-weight:600;animation:.3s ease-out toast-in;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 8px 30px #10b9814d}@keyframes toast-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.no-key-banner{color:#fbbf24;background:#f59e0b1a;border:1px solid #f59e0b40;border-radius:12px;align-items:center;gap:12px;margin-bottom:24px;padding:16px 20px;font-size:14px;display:flex}[data-theme=light] .no-key-banner{color:#d97706}.no-key-banner svg{flex-shrink:0;font-size:20px}.submissions-table-wrapper.subs-loading{position:relative}.submissions-table-wrapper.subs-loading:after{content:"";-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:2;background:#0f172a80;border-radius:16px;animation:.15s fade-in;position:absolute;inset:0}[data-theme=light] .submissions-table-wrapper.subs-loading:after{background:#ffffff80}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.pagination-bar{border-top:1px solid var(--border-primary);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.pagination-info{color:var(--text-dimmed);font-variant-numeric:tabular-nums;font-size:13px}.pagination-controls{align-items:center;gap:4px;display:flex}.page-btn{border:1px solid var(--border-secondary);width:36px;height:36px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.page-btn:hover:not(:disabled):not(.active){background:var(--bg-hover);color:var(--text-secondary);border-color:var(--border-tertiary)}.page-btn.active{background:linear-gradient(135deg, var(--primary-color), var(--accent-indigo-light));color:#fff;box-shadow:0 2px 10px var(--primary-glow);border-color:#0000}.page-btn:disabled{opacity:.3;cursor:not-allowed}.page-dots{text-align:center;width:28px;color:var(--text-faint);-webkit-user-select:none;user-select:none;font-size:14px}@media (width<=768px){.submissions-table th:nth-child(4),.submissions-table td:nth-child(4){display:none}.submissions-table th,.submissions-table td{padding:10px 12px}.exam-link-section{flex-direction:column;align-items:flex-start}.pagination-bar{justify-content:center}.pagination-info{text-align:center;width:100%}}.submission-detail-page{background:var(--bg-gradient);min-height:100vh;color:var(--text-primary);padding:40px 24px;transition:background .35s,color .35s}.submission-detail-container{max-width:900px;margin:0 auto}.sd-header{margin-bottom:32px}.sd-nav{align-items:center;gap:12px;margin-bottom:16px;display:flex}.sd-title{color:var(--text-primary);margin:0 0 8px;font-size:24px;font-weight:800}.sd-student-name{color:var(--accent-indigo-light);margin:0 0 16px;font-size:28px;font-weight:800}.sd-meta{color:var(--text-muted);gap:20px;font-size:14px;display:flex}.sd-meta-item{align-items:center;gap:6px;display:flex}.sd-overview{background:var(--bg-surface-2);border:1px solid var(--border-secondary);border-radius:16px;align-items:center;gap:32px;margin-bottom:32px;padding:24px;transition:background .35s;display:flex}.sd-score-box{background:var(--bg-input-dark);border:1px solid #818cf833;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;padding:20px 30px;display:flex}.sd-score-val{color:var(--accent-lavender);margin-bottom:8px;font-size:48px;font-weight:900;line-height:1}.sd-score-lbl{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:13px}.sd-section{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:16px;margin-bottom:24px;padding:24px;transition:background .35s}.sd-section h3{color:var(--text-secondary);border-bottom:1px solid var(--border-input);margin:0 0 20px;padding-bottom:12px;font-size:18px}.sd-tn-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px;display:grid}.sd-item{background:var(--bg-input-dark);border:1px solid var(--border-primary);border-radius:8px;flex-direction:column;gap:8px;padding:12px;display:flex}.sd-item.correct{background:#34d3990d;border-color:#34d3994d}.sd-item.incorrect{background:#ef44440d;border-color:#ef44444d}.sd-item-header{color:var(--text-label);justify-content:space-between;align-items:center;font-size:14px;font-weight:600;display:flex}.sd-item-body{justify-content:space-between;font-size:14px;display:flex}.sd-ans-student{font-weight:700}.sd-ans-correct{color:var(--accent-green);font-weight:700}.sd-ds-list{flex-direction:column;gap:16px;display:flex}.sd-ds-item{background:var(--bg-input-dark);border:1px solid var(--border-primary);border-radius:8px;padding:16px}.sd-ds-title{color:var(--text-secondary);margin-bottom:12px;font-weight:600}.sd-ds-parts{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.sd-ds-part{background:var(--bg-card);border-radius:6px;flex-direction:column;align-items:center;gap:4px;padding:8px;display:flex}.sd-ds-part-lbl{color:var(--text-muted);font-size:12px}.sd-ds-part-val{font-size:14px;font-weight:700}.text-correct{color:var(--accent-green)}.text-incorrect{color:#f87171}[data-theme=light] .text-incorrect{color:#dc2626}@media (width<=640px){.sd-overview{flex-direction:column;align-items:flex-start;gap:20px}.sd-ds-parts{grid-template-columns:repeat(2,1fr)}}.profile-page{background:var(--bg-gradient);min-height:100vh;color:var(--text-primary);justify-content:center;align-items:center;padding:24px;transition:background .35s,color .35s;display:flex;position:relative;overflow:hidden}.profile-glow{background:radial-gradient(circle, var(--bg-glow-1) 0%, var(--bg-glow-3) 50%, transparent 70%);pointer-events:none;filter:blur(80px);width:700px;height:700px;position:absolute;top:40%;left:50%;transform:translate(-50%,-50%)}.profile-container{z-index:1;width:100%;max-width:500px}.profile-header-actions{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.btn-back,.btn-logout-text{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 12px;font-size:14px;text-decoration:none;transition:all .2s;display:inline-flex}.btn-back:hover{color:var(--text-primary);background:var(--bg-hover)}.btn-logout-text:hover{color:#f87171;background:#f871711a}.profile-card{background:var(--bg-surface);border:1px solid var(--border-secondary);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:var(--shadow-card);border-radius:24px;padding:40px;transition:background .35s,border-color .35s;animation:.4s ease-out fade-in-up}@keyframes fade-in-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.profile-avatar-section{text-align:center;margin-bottom:30px}.profile-avatar-large{background:linear-gradient(135deg, var(--primary-color), var(--accent-purple));color:#fff;width:88px;height:88px;box-shadow:0 8px 24px var(--primary-glow);border:4px solid var(--border-primary);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 16px;font-size:32px;font-weight:700;display:flex}.profile-avatar-section h2{color:var(--text-primary);margin:0 0 4px;font-size:22px;font-weight:700}.profile-email{color:var(--text-muted);margin:0;font-size:14px}.divider{align-items:center;gap:12px;margin:24px 0;display:flex}.divider:before,.divider:after{content:"";background:var(--border-secondary);flex:1;height:1px}.divider span{color:var(--text-dimmed);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}.alert{border-radius:12px;align-items:center;gap:8px;margin-bottom:20px;padding:12px 16px;font-size:14px;display:flex}.alert-error{color:#fca5a5;background:#ef44441a;border:1px solid #ef444433}.alert-success{color:#6ee7b7;background:#10b9811a;border:1px solid #10b98133}[data-theme=light] .alert-error{color:#dc2626}[data-theme=light] .alert-success{color:#059669}.profile-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:var(--text-label);font-size:13px;font-weight:600}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-dimmed);pointer-events:none;font-size:14px;position:absolute;left:14px}.input-wrapper input{border:1px solid var(--border-input);background:var(--bg-input);width:100%;color:var(--text-primary);border-radius:12px;outline:none;padding:12px 14px 12px 42px;font-size:15px;transition:all .2s}.input-wrapper input:focus{background:var(--bg-input-focus);border-color:#6366f180;box-shadow:0 0 0 3px #6366f126}.input-disabled input{background:var(--bg-input-dark);color:var(--text-dimmed);cursor:not-allowed;border-color:#0000}.profile-actions{margin-top:10px}.btn-save{background:linear-gradient(135deg, var(--primary-color), var(--accent-purple));color:#fff;cursor:pointer;width:100%;box-shadow:var(--shadow-btn);border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:14px;font-size:15px;font-weight:600;transition:all .2s;display:flex}.btn-save:hover:not(:disabled){box-shadow:var(--shadow-btn-hover);transform:translateY(-2px)}.btn-save:disabled{opacity:.7;cursor:not-allowed}.spinner-small{border-width:2px;width:18px;height:18px}
