*,: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}.static{position:static}.relative{position:relative}.block{display:block}.inline{display:inline}.flex{display:flex}.grid{display:grid}.resize{resize:both}.border{border-width:1px}.outline{outline-style:solid}.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)}body{overflow:hidden}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}button,input,textarea,select{font-family:inherit;font-size:inherit;line-height:inherit;appearance:none;color:inherit;cursor:pointer;background:0 0;border:none;outline:none}a{color:inherit;text-decoration:none}textarea{cursor:text}:root{--bg-base:#fdf0f5;--bg-surface:#fae8f0;--bg-raised:#f7d6e6;--bg-hover:#f2c2d8;--bg-active:#edaecb;--bg-card:#fae8f0;--border:#3d1f2a0f;--border-soft:#3d1f2a1c;--border-mid:#3d1f2a33;--border-pixel:#3d1f2a61;--text-1:#3d1f2a;--text-2:#6b3050;--text-3:#a84e6e;--accent:#c96b8a;--accent-hi:#d880a0;--accent-pale:#e8a4bc;--accent-dim:#c96b8a1a;--accent-mid:#c96b8a38;--accent-gradient:linear-gradient(90deg,#c96b8a 0%,#e8a4bc 60%,#c96b8a 100%);--secondary:#1a8a42;--secondary-hi:#28aa54;--secondary-dim:#1a8a421a;--secondary-mid:#1a8a423d;--correct:#1a7838;--correct-bg:#1a783814;--correct-bd:#1a78384d;--incorrect:#a82020;--incorrect-bg:#a8202014;--incorrect-bd:#a820204d;--s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:20px;--s6:24px;--s7:28px;--s8:32px;--s10:40px;--s12:48px;--font-pixel:"Press Start 2P", monospace;--font-body:"M PLUS Rounded 1c", system-ui, sans-serif;--font-mono:"Courier New", monospace;--sidebar-w:224px;--toolbar-h:44px;--chat-max:800px;--ease:cubic-bezier(.4,0,.2,1)}html{height:100%;font-size:15px}body{height:100%;font-family:var(--font-body);background:var(--bg-base);color:var(--text-1);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;transition:background .2s var(--ease), color .2s var(--ease);line-height:1.7;overflow:hidden}:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.app{width:100%;height:100%;display:flex;position:relative;overflow:hidden}.app:before{content:"";background:var(--accent-gradient);z-index:1000;pointer-events:none;height:4px;position:fixed;top:0;left:0;right:0}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--bg-surface);border-right:1px solid var(--border-soft);transition:background .2s var(--ease);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.sidebar-logo{padding:16px var(--s4) 14px;border-bottom:1px solid var(--border-soft);flex-shrink:0;align-items:center;gap:10px;display:flex}.logo-text-wrap{align-items:center;display:flex}.logo-title{font-family:var(--font-pixel);color:var(--text-1);letter-spacing:1px;font-size:18px;line-height:1}.new-chat-btn{margin:var(--s3) var(--s3) var(--s2);background:var(--secondary-dim);border:1px solid var(--secondary-mid);height:36px;color:var(--secondary);font-family:var(--font-pixel);letter-spacing:.5px;transition:background .15s var(--ease), border-color .15s var(--ease);flex-shrink:0;justify-content:center;align-items:center;gap:8px;padding:0;font-size:7.5px;display:flex}.new-chat-btn:hover{background:var(--secondary-mid)}.sidebar-search{margin:0 var(--s3) var(--s2);background:var(--bg-raised);border:1px solid #0000;flex-shrink:0;align-items:center;gap:8px;padding:7px 10px;transition:border-color .15s;display:flex}.sidebar-search:focus-within{border-color:var(--accent-mid)}.sidebar-search svg{color:var(--text-3);flex-shrink:0}.sidebar-search-input{color:var(--text-1);cursor:text;background:0 0;flex:1;font-size:13px}.sidebar-search-input::placeholder{color:var(--text-3);opacity:.8}.sidebar-chats{min-height:0;padding:2px var(--s2);scrollbar-width:thin;scrollbar-color:var(--accent-pale) transparent;flex:1;overflow:hidden auto}.sidebar-chats::-webkit-scrollbar{width:3px}.sidebar-chats::-webkit-scrollbar-thumb{background:var(--accent-pale)}.chat-list{flex-direction:column;gap:1px;display:flex}.chat-list-empty{font-family:var(--font-pixel);color:var(--text-3);padding:var(--s8) var(--s2);text-align:center;white-space:pre-line;font-size:7px;line-height:2.8}.chat-item{padding:8px var(--s2) 8px 6px;min-height:36px;transition:background .12s var(--ease), border-color .12s var(--ease);cursor:pointer;border:1px solid #0000;border-left-width:2px;align-items:center;gap:6px;display:flex;position:relative}.chat-item:hover{background:var(--bg-hover)}.chat-item.active{background:var(--bg-active);border-color:var(--border-mid);border-left-color:var(--accent)}.chat-item-name{color:var(--text-2);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:13px;line-height:1.35;overflow:hidden}.chat-item.active .chat-item-name{color:var(--text-1);font-weight:500}.chat-item-name.editing{background:var(--bg-raised);border:1px solid var(--accent-mid);color:var(--text-1);cursor:text;width:100%;padding:1px 5px;font-size:12px}.chat-item-summary{color:var(--text-3);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:10px;display:block;overflow:hidden}.chat-item-actions{opacity:0;right:var(--s1);background:var(--bg-hover);flex-shrink:0;gap:1px;transition:opacity .12s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.chat-item:hover .chat-item-actions,.chat-item.active .chat-item-actions{opacity:1}.chat-action-btn{width:20px;height:20px;color:var(--text-3);flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:color .12s;display:flex}.chat-action-btn:hover{color:var(--secondary)}.chat-action-btn.delete:hover{color:var(--incorrect)}.chat-pin-dot{background:var(--accent);clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%);flex-shrink:0;align-self:center;width:5px;min-width:5px;height:5px;margin-right:2px}.chat-color-dot{flex-shrink:0;align-self:center;width:5px;min-width:5px;height:5px;margin-right:2px}.search-highlight{background:var(--accent-dim);color:var(--accent);font-style:normal}mark.chat-search-hl{background:var(--accent-dim);color:var(--accent)}mark.chat-search-hl.active{background:var(--accent);color:#fff}.sidebar-footer{flex-direction:column;flex-shrink:0;display:flex}.pomodoro{background:var(--bg-raised);border-top:1px solid var(--border-soft);flex-shrink:0}.pomodoro-header{padding:8px var(--s3);border-bottom:1px solid var(--border-soft);align-items:center;gap:6px;display:flex}.pomodoro-label{font-family:var(--font-pixel);letter-spacing:1.5px;color:var(--accent);flex-shrink:0;font-size:7px}.pomodoro-dots{flex:1;justify-content:center;gap:4px;display:flex}.pom-dot{background:var(--border-mid);width:6px;height:6px;transition:background .2s}.pom-dot.done{background:var(--accent)}.pom-header-actions{flex-shrink:0;align-items:center;gap:2px;display:flex}.pom-icon-btn{width:24px;height:24px;color:var(--text-3);border:1px solid #0000;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:color .12s,background .12s,border-color .12s;display:flex}.pom-icon-btn:hover{color:var(--text-1);background:var(--bg-hover);border-color:var(--border-soft)}.pom-collapse-btn{transition:transform .2s,color .12s}.pom-mini-time{display:none}.pomodoro.pom-collapsed .pom-expanded-only,.pomodoro.pom-collapsed .pom-body{display:none!important}.pomodoro.pom-collapsed .pom-mini-time{font-family:var(--font-pixel);color:var(--text-1);letter-spacing:2px;flex-shrink:0;font-size:11px;display:block!important}.pomodoro.pom-collapsed .pomodoro-header{padding:6px var(--s3);border-bottom:none}.pomodoro.pom-collapsed .pom-collapse-btn{margin-left:auto;transform:rotate(180deg)}.pom-body{padding:var(--s3);gap:var(--s2);flex-direction:column;display:flex}.pomodoro-time{font-family:var(--font-pixel);color:var(--text-1);letter-spacing:2px;text-align:center;font-size:20px;line-height:1.2}.pomodoro-time.break{color:var(--secondary)}.pomodoro-time.warning{color:var(--incorrect);animation:1s ease-in-out infinite softPulse}.pomodoro-mode-label{font-family:var(--font-pixel);letter-spacing:2px;color:var(--text-3);text-align:center;font-size:6.5px}.pomodoro-controls{justify-content:center;align-items:center;gap:8px;display:flex}.pom-btn{background:var(--bg-surface);border:1px solid var(--border-mid);width:32px;height:32px;color:var(--text-2);flex-shrink:0;justify-content:center;align-items:center;transition:background .12s,border-color .12s,color .12s;display:flex}.pom-btn:hover{background:var(--bg-hover);border-color:var(--border-pixel);color:var(--text-1)}.pom-btn-main{background:var(--accent-dim);border-color:var(--accent-mid);width:40px;height:40px;color:var(--accent)}.pom-btn-main:hover{background:var(--accent-mid);color:var(--text-1)}.pom-skip{opacity:.5}.pom-skip:hover{opacity:1}.pomodoro-edit{gap:var(--s2);padding-top:var(--s2);border-top:1px solid var(--border-soft);flex-direction:column;display:none}.pomodoro-edit.visible{display:flex}.pom-edit-row{align-items:center;gap:var(--s2);display:flex}.pom-edit-label{color:var(--text-2);flex:1;font-size:12px;line-height:1.4}.pom-edit-input{background:var(--bg-surface);border:1px solid var(--border-mid);width:44px;color:var(--text-1);text-align:center;cursor:text;padding:4px 6px;font-size:13px}.pom-edit-unit{color:var(--text-3);font-size:12px}.pom-edit-apply{background:var(--accent-dim);border:1px solid var(--accent-mid);color:var(--accent);font-family:var(--font-pixel);letter-spacing:.3px;align-self:flex-end;padding:5px 12px;font-size:6.5px;transition:background .12s,color .12s}.pom-edit-apply:hover{background:var(--accent-mid);color:var(--text-1)}#pom-history-row{padding:var(--s1) var(--s3) var(--s2);flex-direction:column;flex-shrink:0;align-items:center;gap:3px;display:flex}.pom-today-row{justify-content:center;align-items:center;gap:5px;display:flex}.pom-today-count{font-family:var(--font-pixel);color:var(--accent);letter-spacing:.5px;font-size:7px}.pom-today-label{font-family:var(--font-pixel);color:var(--text-3);letter-spacing:.5px;text-transform:uppercase;font-size:6.5px}.pom-streak{font-family:var(--font-pixel);color:var(--accent);letter-spacing:.3px;background:var(--accent-dim);border:1px solid var(--accent-mid);padding:2px 5px;font-size:6px}.user-row{display:none}.user-dropdown{display:none!important}.toolbar{padding:0 var(--s4);background:var(--bg-surface);border-bottom:1px solid var(--border-soft);height:var(--toolbar-h);z-index:50;flex-shrink:0;align-items:center;gap:2px;display:flex;position:relative;overflow:visible}.tb-divider{background:var(--border-soft);width:1px;height:18px;margin:0 var(--s1);flex-shrink:0}.tb-group{position:relative}.tb-btn{height:30px;color:var(--text-2);font-family:var(--font-body);white-space:nowrap;transition:background .12s var(--ease), border-color .12s var(--ease), color .12s var(--ease);cursor:pointer;letter-spacing:0;background:0 0;border:1px solid #0000;flex-shrink:0;align-items:center;gap:6px;padding:0 10px;font-size:13px;font-weight:400;display:flex}.tb-btn:hover{background:var(--bg-raised);border-color:var(--border-soft);color:var(--text-1)}.tb-btn:active{opacity:.75}.tb-btn svg{opacity:.6;flex-shrink:0;transition:opacity .12s}.tb-btn:hover svg{opacity:1}.tb-icon-only{padding:0 9px}.tb-chevron{opacity:.45;transition:transform .15s var(--ease)}.tb-group.open>.tb-btn{background:var(--accent-dim);border-color:var(--accent-mid);color:var(--accent)}.tb-group.open>.tb-btn svg{opacity:1}.tb-group.open>.tb-btn .tb-chevron{opacity:.8;transform:rotate(180deg)}.tb-dropdown{background:var(--bg-surface);border:1px solid var(--border-pixel);box-shadow:3px 4px 0 var(--border-mid);z-index:200;min-width:210px;animation:ddIn .12s var(--ease) both;flex-direction:column;display:none;position:absolute;top:calc(100% + 5px);left:0}@keyframes ddIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.tb-group.open .tb-dropdown{display:flex}.tb-dd-item{padding:10px var(--s3);text-align:left;width:100%;color:var(--text-1);border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:10px;font-size:13px;transition:background .1s;display:flex}.tb-dd-item:last-child{border-bottom:none}.tb-dd-item:hover{background:var(--bg-raised)}.tb-dd-item:hover svg{color:var(--accent)}.tb-dd-item svg{color:var(--text-3);flex-shrink:0;transition:color .1s}.tb-dd-hint{color:var(--text-3);padding-left:var(--s3);white-space:nowrap;margin-left:auto;font-size:10.5px;font-style:italic}.tb-account{flex-shrink:0;margin-left:auto;position:relative}.tb-account-btn{height:30px;color:var(--text-2);font-family:var(--font-body);white-space:nowrap;transition:background .12s var(--ease), border-color .12s var(--ease), color .12s var(--ease);cursor:pointer;background:0 0;border:1px solid #0000;flex-shrink:0;align-items:center;gap:8px;padding:0 10px;font-size:13px;display:flex}.tb-account-btn:hover{background:var(--bg-raised);border-color:var(--border-soft);color:var(--text-1)}.tb-account-avatar{background:var(--accent-dim);border:1px solid var(--accent-mid);width:22px;height:22px;font-family:var(--font-pixel);color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;font-size:8px;line-height:1;display:flex}.tb-account-name{color:inherit;font-size:13px;font-weight:500}.tb-account.open>.tb-account-btn{background:var(--accent-dim);border-color:var(--accent-mid);color:var(--accent)}.tb-account-dd{background:var(--bg-surface);border:1px solid var(--border-pixel);box-shadow:3px 4px 0 var(--border-mid);z-index:200;min-width:180px;animation:ddIn .12s var(--ease) both;flex-direction:column;display:none;position:absolute;top:calc(100% + 5px);right:0}.tb-account.open .tb-account-dd{display:flex}.tb-account-dd-item{padding:10px var(--s3);text-align:left;width:100%;color:var(--text-1);border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:10px;font-size:13px;transition:background .1s;display:flex}.tb-account-dd-item:last-child{border-bottom:none}.tb-account-dd-item:hover{background:var(--bg-raised)}.tb-account-dd-item svg{color:var(--text-3);flex-shrink:0}.tb-account-dd-item.danger:hover{color:var(--incorrect)}.tb-account-dd-divider{background:var(--border-soft);height:1px}.main{flex-direction:column;flex:1;min-width:0;height:100%;display:flex;overflow:hidden}.chat-wrap{flex-direction:column;flex:1;width:100%;display:flex;overflow:hidden}.chat-log{padding:var(--s6) var(--s6) var(--s6);scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--accent-pale) transparent;flex-direction:column;flex:1;display:flex;overflow:hidden auto}.chat-log::-webkit-scrollbar{width:4px}.chat-log::-webkit-scrollbar-thumb{background:var(--accent-pale)}.input-area{padding:var(--s2) var(--s6) var(--s3);flex-shrink:0}.empty-state{text-align:center;min-height:360px;padding:var(--s12) 0;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:0;display:flex}.empty-sprite{margin-bottom:var(--s5);image-rendering:pixelated;animation:3s ease-in-out infinite floatBob}@keyframes floatBob{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.empty-title{font-family:var(--font-pixel);color:var(--text-2);margin-bottom:var(--s3);letter-spacing:.5px;font-size:11px;line-height:2}.empty-sub{color:var(--text-3);max-width:360px;margin-bottom:var(--s6);font-size:13.5px;line-height:1.8}.suggestions{gap:var(--s2);flex-wrap:wrap;justify-content:center;max-width:520px;display:flex}.chip{border:1px solid var(--border-mid);background:var(--bg-surface);color:var(--text-2);transition:background .12s var(--ease), border-color .12s var(--ease), color .12s var(--ease);cursor:pointer;padding:8px 14px;font-size:12.5px;line-height:1.4}.chip:hover{background:var(--secondary-dim);border-color:var(--secondary-mid);color:var(--secondary)}.message{padding:var(--s4) 0;border-bottom:1px solid var(--border);animation:msgIn .15s var(--ease) both;gap:0;display:flex}.message:last-child{border-bottom:none}@keyframes msgIn{0%{opacity:0;transform:translateY(3px)}to{opacity:1;transform:none}}.message.user{flex-direction:row-reverse;position:relative}.avatar{display:none}.message.user .bubble{background:var(--accent-dim);border:1px solid var(--accent-mid);max-width:72%;padding:10px var(--s4);color:var(--text-1);word-break:break-word;align-self:flex-start;margin-left:auto;font-size:14px;line-height:1.65}.message.assistant .bubble{min-width:0;padding:4px 0 4px calc(var(--s4) + 3px);color:var(--text-1);background:0 0;border-left:none;flex:1;font-size:14.5px;line-height:1.85;position:relative}.message.assistant .bubble:before{content:"";background:linear-gradient(to bottom, var(--accent) 0%, var(--secondary) 50%, var(--accent) 100%);opacity:1;width:4px;position:absolute;top:0;bottom:0;left:0}.msg-attachment{border:1px solid var(--border-mid);margin-bottom:var(--s2);background:var(--bg-raised);color:var(--text-2);align-items:center;gap:6px;padding:3px 8px;font-size:11px;line-height:1.4;display:inline-flex}.bubble p{margin-bottom:var(--s4);line-height:1.85}.bubble p:last-child{margin-bottom:0}.bubble h1,.bubble h2,.bubble h3{font-family:var(--font-pixel);margin:var(--s6) 0 var(--s3);color:var(--text-2);font-weight:400;line-height:2.2}.bubble h1{font-size:12.5px}.bubble h2{font-size:11px}.bubble h3{color:var(--text-3);font-size:9.5px}.bubble h1:first-child,.bubble h2:first-child,.bubble h3:first-child{margin-top:0}.bubble ul,.bubble ol{padding-left:var(--s5);margin-bottom:var(--s3)}.bubble li{margin-bottom:var(--s1);line-height:1.8}.bubble li::marker{color:var(--accent)}.bubble strong{color:var(--text-1);font-weight:700}.bubble em{color:var(--text-2);font-style:italic}.bubble a{color:var(--secondary-hi);text-underline-offset:2px;text-decoration:underline}.bubble hr{border:none;border-top:1px solid var(--border-soft);margin:var(--s6) 0}.bubble code{font-family:var(--font-mono);background:var(--bg-raised);border:1px solid var(--border-mid);color:var(--text-2);word-break:break-word;padding:1px 5px;font-size:12px}.bubble pre{background:var(--bg-raised);border:1px solid var(--border-soft);border-left:3px solid var(--secondary-mid);padding:var(--s4);margin:var(--s4) 0;scrollbar-width:thin;overflow-x:auto}.bubble pre code{color:var(--text-2);background:0 0;border:none;padding:0;font-size:12px}.bubble blockquote{border-left:3px solid var(--secondary-mid);padding:var(--s3) var(--s5);margin:var(--s4) 0;color:var(--text-2);background:var(--secondary-dim);line-height:1.8}.bubble table{border-collapse:collapse;width:100%;margin:var(--s3) 0;font-size:13px}.bubble th,.bubble td{padding:var(--s2) var(--s3);text-align:left;border:1px solid var(--border-soft)}.bubble th{background:var(--secondary-dim);color:var(--secondary);font-size:12px;font-weight:600}.bubble tr:nth-child(2n) td{background:var(--border)}.typing .bubble{padding:var(--s2) 0 var(--s2) var(--s4)!important}.dots{align-items:center;gap:5px;display:flex}.dots span{width:6px;height:6px;animation:1.4s ease-in-out infinite softDot}.dots span:first-child{background:var(--accent)}.dots span:nth-child(2){background:var(--secondary-hi);animation-delay:.2s}.dots span:nth-child(3){background:var(--accent);animation-delay:.4s}@keyframes softDot{0%,to{opacity:.3;transform:translateY(0)}50%{opacity:.9;transform:translateY(-3px)}}.attachment-preview{padding-bottom:var(--s2)}.attachment-preview.hidden{display:none}.image-preview-wrap{padding-bottom:var(--s2)}.image-preview-wrap.hidden{display:none}.attachment-pill{border:1px solid var(--accent-mid);background:var(--accent-dim);color:var(--text-2);align-items:center;gap:7px;max-width:100%;padding:4px 10px;font-size:12px;display:inline-flex}.attachment-pill span{white-space:nowrap;text-overflow:ellipsis;max-width:240px;overflow:hidden}.remove-btn{width:16px;height:16px;color:var(--text-3);flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:color .12s;display:flex}.remove-btn:hover{color:var(--incorrect)}.input-box{align-items:flex-end;gap:var(--s1);background:var(--bg-surface);border:1.5px solid var(--border-mid);padding:var(--s2) var(--s2) var(--s2) var(--s3);transition:border-color .15s;display:flex}.input-box:focus-within{border-color:var(--accent)}#pdf-input{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}#user-input{color:var(--text-1);font-family:var(--font-body);resize:none;scrollbar-width:thin;cursor:text;background:0 0;flex:1;max-height:160px;padding:5px 0 4px;font-size:14px;line-height:1.65;overflow-y:auto}#user-input::placeholder{color:var(--text-3)}#user-input:focus,#user-input:focus-visible{outline:none}.input-right-btns{flex-shrink:0;align-items:flex-end;gap:2px;padding-bottom:2px;display:flex}.input-icon-btn{width:30px;height:30px;color:var(--text-3);flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:color .12s;display:flex}.input-icon-btn:hover{color:var(--accent)}.attach-btn:hover{color:var(--secondary-hi)}.input-icon-btn.listening{animation:1s ease-in-out infinite micPulse;color:var(--incorrect)!important}@keyframes micPulse{0%,to{opacity:1}50%{opacity:.4}}.send-btn{background:var(--accent);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;padding:0;transition:background .12s;display:flex}.send-btn:hover:not(:disabled){background:var(--accent-hi)}.send-btn:disabled{opacity:.3;cursor:not-allowed}.input-hint{display:none}@keyframes pulseUrgent{0%,to{opacity:1}50%{opacity:.7}}.exam-banner-manage{font-family:var(--font-pixel);letter-spacing:.3px;background:var(--bg-raised);border:1px solid var(--border-mid);color:var(--text-3);flex-shrink:0;padding:3px 8px;font-size:6.5px;transition:color .12s,background .12s}.weekly-banner{align-items:center;gap:var(--s3);padding:var(--s3) var(--s6);background:var(--accent-dim);border-bottom:2px solid var(--accent-mid);flex-wrap:wrap;flex-shrink:0;display:flex}.weekly-banner-icon{flex-shrink:0}.weekly-banner-body{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.weekly-banner-title{font-family:var(--font-pixel);color:var(--text-2);letter-spacing:.3px;font-size:7px}.weekly-banner-stats{gap:var(--s3);flex-wrap:wrap;display:flex}.weekly-stat{color:var(--text-3);font-size:11px}.weekly-stat-ok{color:var(--secondary)}.weekly-banner-actions{align-items:center;gap:var(--s2);flex-shrink:0;display:flex}.weekly-plan-btn{font-family:var(--font-pixel);letter-spacing:.3px;background:var(--accent);color:#fff;padding:5px 12px;font-size:7px;transition:opacity .12s}.weekly-plan-btn:hover{opacity:.85}.weekly-dismiss{width:22px;height:22px;color:var(--text-3);justify-content:center;align-items:center;transition:color .12s;display:flex}.weekly-dismiss:hover{color:var(--text-1)}.chat-msg-search{align-items:center;gap:var(--s2);padding:6px var(--s6);background:var(--bg-raised);border-bottom:1px solid var(--border-mid);flex-shrink:0;display:flex}.chat-msg-search.hidden{display:none}.chat-msg-search svg{color:var(--text-3);flex-shrink:0}#chat-msg-search-input{color:var(--text-1);cursor:text;background:0 0;flex:1;font-size:13px}#chat-msg-search-input::placeholder{color:var(--text-3)}.chat-msg-search-count{color:var(--text-3);white-space:nowrap;flex-shrink:0;font-size:11px}#chat-msg-search-prev,#chat-msg-search-next{width:22px;height:22px;color:var(--text-3);background:var(--bg-surface);border:1px solid var(--border-soft);justify-content:center;align-items:center;font-size:12px;transition:color .1s,border-color .1s;display:flex}#chat-msg-search-prev:hover,#chat-msg-search-next:hover{color:var(--text-1);border-color:var(--border-mid)}#chat-msg-search-close{color:var(--text-3);padding:2px;transition:color .1s}#chat-msg-search-close:hover{color:var(--incorrect)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}.modal-overlay{z-index:100;padding:var(--s6);animation:fadeIn .15s var(--ease);background:#00000052;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay.hidden{display:none}.modal-panel{background:var(--bg-surface);border:1px solid var(--border-pixel);box-shadow:4px 4px 0 var(--border-mid);width:100%;max-height:88vh;animation:slideUp .18s var(--ease);flex-direction:column;display:flex}.modal-header{padding:var(--s4) var(--s5);border-bottom:1px solid var(--border-soft);flex-shrink:0;justify-content:space-between;align-items:center;display:flex;position:relative;overflow:hidden}.modal-header:before{content:"";background:var(--accent-gradient);opacity:.6;pointer-events:none;height:3px;position:absolute;top:0;left:0;right:0}.modal-title{font-family:var(--font-pixel);color:var(--text-2);letter-spacing:.5px;font-size:10px}.modal-close{width:28px;height:28px;color:var(--text-3);border:1px solid #0000;justify-content:center;align-items:center;transition:color .12s,background .12s,border-color .12s;display:flex}.modal-close:hover{color:var(--text-1);background:var(--bg-hover);border-color:var(--border-soft)}.modal-body{padding:var(--s5);scrollbar-width:thin;flex:1;font-size:14px;line-height:1.7;overflow-y:auto}.modal-body::-webkit-scrollbar{width:4px}.modal-body::-webkit-scrollbar-thumb{background:var(--accent-pale)}.settings-overlay{z-index:100;padding:var(--s6);animation:fadeIn .15s var(--ease);background:#00000052;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.settings-overlay.hidden{display:none}.settings-panel{background:var(--bg-surface);border:1px solid var(--border-pixel);box-shadow:4px 4px 0 var(--border-mid);scrollbar-width:thin;width:100%;max-width:540px;max-height:88vh;animation:slideUp .18s var(--ease);overflow-y:auto}.settings-header{padding:var(--s4) var(--s5);border-bottom:1px solid var(--border-soft);background:var(--bg-surface);z-index:1;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.settings-title{font-family:var(--font-pixel);color:var(--text-2);letter-spacing:.5px;font-size:10px}.settings-close{width:28px;height:28px;color:var(--text-3);border:1px solid #0000;justify-content:center;align-items:center;transition:color .12s,background .12s,border-color .12s;display:flex}.settings-close:hover{color:var(--text-1);background:var(--bg-hover);border-color:var(--border-soft)}.settings-body{padding:var(--s5);gap:var(--s6);flex-direction:column;display:flex}.settings-section-title{font-family:var(--font-pixel);letter-spacing:1px;color:var(--text-3);margin-bottom:var(--s3);text-transform:uppercase;font-size:7.5px}.mode-row{gap:var(--s3);display:flex}.mode-btn{padding:var(--s3);border:1px solid var(--border-mid);background:var(--bg-raised);color:var(--text-2);align-items:center;gap:var(--s2);flex-direction:column;flex:1;transition:background .12s,border-color .12s;display:flex}.mode-btn:hover{background:var(--bg-hover);border-color:var(--border-pixel)}.mode-btn.active{border-color:var(--accent);background:var(--accent-dim);color:var(--accent)}.mode-btn-icon{width:36px;height:24px;image-rendering:pixelated;display:block}.mode-btn-label{font-family:var(--font-pixel);letter-spacing:.5px;font-size:7.5px}.theme-grid{gap:var(--s2);grid-template-columns:repeat(auto-fill,minmax(100px,1fr));display:grid}.theme-card{background:0 0;border:2px solid #0000;flex-direction:column;align-items:center;gap:6px;padding:2px;transition:border-color .12s;display:flex}.theme-card:hover{border-color:var(--border-pixel)}.theme-card.active{border-color:var(--accent)}.theme-preview{aspect-ratio:4/3;border:1px solid var(--border-soft);width:100%;image-rendering:pixelated;grid-template-rows:6px 1fr 8px;display:grid;overflow:hidden}.theme-preview-top{border-bottom:1px solid #00000014}.theme-preview-middle{grid-template-columns:40% 1fr;display:grid}.theme-preview-sidebar{border-right:1px solid #00000014}.theme-preview-content{flex-direction:column;gap:2px;padding:3px 4px;display:flex}.theme-preview-line{opacity:.5;height:2px}.theme-preview-bottom{border-top:1px solid #00000014}.theme-name{font-family:var(--font-pixel);letter-spacing:.3px;color:var(--text-3);text-align:center;font-size:7px}.theme-card.active .theme-name{color:var(--accent)}.library-overlay{z-index:100;padding:var(--s6);animation:fadeIn .15s var(--ease);background:#00000052;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.library-overlay.hidden{display:none}.library-panel{background:var(--bg-surface);border:1px solid var(--border-pixel);box-shadow:4px 4px 0 var(--border-mid);width:100%;max-width:680px;max-height:88vh;animation:slideUp .18s var(--ease);flex-direction:column;display:flex}.library-header{padding:var(--s4) var(--s5);border-bottom:1px solid var(--border-soft);flex-shrink:0;justify-content:space-between;align-items:center;display:flex;position:relative;overflow:hidden}.library-header:before{content:"";background:var(--accent-gradient);opacity:.6;pointer-events:none;height:3px;position:absolute;top:0;left:0;right:0}.library-title{font-family:var(--font-pixel);color:var(--text-2);letter-spacing:.5px;font-size:10px}.library-close{width:28px;height:28px;color:var(--text-3);border:1px solid #0000;justify-content:center;align-items:center;transition:color .12s,background .12s,border-color .12s;display:flex}.library-close:hover{color:var(--text-1);background:var(--bg-hover);border-color:var(--border-soft)}.library-body{padding:var(--s5);scrollbar-width:thin;flex:1;overflow-y:auto}.library-body::-webkit-scrollbar{width:4px}.library-body::-webkit-scrollbar-thumb{background:var(--accent-pale)}.library-empty{padding:var(--s12) var(--s6);text-align:center;justify-content:center;align-items:center;gap:var(--s4);flex-direction:column;display:flex}.library-empty-icon{opacity:.55}.library-empty-title{font-family:var(--font-pixel);color:var(--text-3);font-size:9px;line-height:2}.library-empty-sub{color:var(--text-3);max-width:300px;font-size:13px;line-height:1.7}.library-grid{gap:var(--s3);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.library-set-card{background:var(--bg-card);border:1px solid var(--border-soft);padding:var(--s4);gap:var(--s2);cursor:pointer;text-align:left;flex-direction:column;transition:background .12s,border-color .12s,transform .12s;display:flex}.library-set-card:hover{background:var(--bg-hover);border-color:var(--border-pixel);transform:translate(-1px,-1px)}.library-set-title{font-family:var(--font-pixel);color:var(--text-1);letter-spacing:.3px;font-size:8px;line-height:1.8}.library-set-meta{color:var(--text-3);flex-direction:column;gap:2px;font-size:11px;display:flex}.library-set-count{font-family:var(--font-pixel);color:var(--accent);letter-spacing:.3px;font-size:7px}.library-set-actions{gap:var(--s1);flex-wrap:wrap;margin-top:auto;display:flex}.library-study-btn{text-align:center;background:var(--accent-dim);border:1px solid var(--accent-mid);min-width:0;color:var(--accent);font-family:var(--font-pixel);letter-spacing:.3px;white-space:nowrap;flex:1;padding:5px 6px;font-size:7px;transition:background .12s,color .12s}.library-study-btn:hover{background:var(--accent-mid);color:var(--text-1)}.library-delete-btn{border:1px solid var(--border-soft);width:26px;height:26px;color:var(--text-3);justify-content:center;align-items:center;transition:color .12s,border-color .12s;display:flex}.library-delete-btn:hover{color:var(--incorrect);border-color:var(--incorrect-bd)}.library-viewer{flex-direction:column;display:none}.library-viewer.visible{display:flex}.library-viewer-back{align-items:center;gap:var(--s2);padding:0 0 var(--s4);border-bottom:1px solid var(--border-soft);margin-bottom:var(--s4);color:var(--text-2);font-family:var(--font-pixel);letter-spacing:.3px;background:0 0;border-top:none;border-left:none;border-right:none;font-size:8px;transition:color .12s;display:flex}.library-viewer-title{font-family:var(--font-pixel);color:var(--text-2);margin-bottom:var(--s4);font-size:9px;line-height:2}.srs-due-badge{font-family:var(--font-pixel);letter-spacing:.3px;background:var(--accent-dim);border:1px solid var(--accent-mid);color:var(--accent);align-items:center;padding:2px 7px;font-size:7px;display:inline-flex}.srs-due-badge.srs-due-none{background:var(--secondary-dim);border-color:var(--secondary-mid);color:var(--secondary)}.srs-review-btn{background:var(--accent-dim)!important;border-color:var(--accent-mid)!important;color:var(--accent)!important}.srs-header{padding-bottom:var(--s3);border-bottom:1px solid var(--border-soft);margin-bottom:var(--s3);justify-content:space-between;align-items:center;gap:var(--s3);display:flex}.srs-progress-label{font-family:var(--font-pixel);color:var(--text-3);font-size:8px}.srs-mode-label{font-family:var(--font-pixel);color:var(--text-3);letter-spacing:.3px;opacity:.7;font-size:7px}.srs-bar-wrap{background:var(--border-soft);height:3px;margin-bottom:var(--s4);overflow:hidden}.srs-bar{background:var(--accent-gradient);height:100%;transition:width .4s var(--ease)}.srs-flip-row{margin-top:var(--s3);justify-content:center;display:flex}.srs-flip-btn{background:var(--accent-dim);border:1px solid var(--accent-mid);color:var(--accent);font-family:var(--font-pixel);letter-spacing:.3px;padding:8px 32px;font-size:7.5px;transition:background .12s,color .12s}.srs-flip-btn:hover{background:var(--accent-mid);color:var(--text-1)}.srs-rating-row{gap:var(--s2);margin-top:var(--s3);flex-wrap:wrap;justify-content:center;display:flex}.srs-rate-btn{min-width:60px;max-width:100px;padding:var(--s2);font-family:var(--font-pixel);letter-spacing:.3px;border:1px solid;flex-direction:column;flex:1;align-items:center;gap:4px;font-size:7.5px;transition:background .12s,color .12s;display:flex}.srs-interval-hint{font-family:var(--font-pixel);opacity:.65;letter-spacing:.2px;font-size:6.5px}.srs-again{background:var(--incorrect-bg);border-color:var(--incorrect-bd);color:var(--incorrect)}.srs-again:hover{background:var(--incorrect-bd);color:#fff}.srs-hard{background:var(--bg-raised);border-color:var(--border-pixel);color:var(--text-2)}.srs-hard:hover{background:var(--bg-hover);color:var(--text-1)}.srs-good{background:var(--accent-dim);border-color:var(--accent-mid);color:var(--accent)}.srs-good:hover{background:var(--accent-mid);color:var(--text-1)}.srs-easy{background:var(--secondary-dim);border-color:var(--secondary-mid);color:var(--secondary)}.srs-easy:hover{background:var(--secondary-mid);color:var(--text-1)}.srs-complete{padding:var(--s8) var(--s6);text-align:center;align-items:center;gap:var(--s5);flex-direction:column;display:flex}.srs-complete-icon{animation:3s ease-in-out infinite floatBob}.srs-complete-title{font-family:var(--font-pixel);color:var(--secondary);letter-spacing:.5px;font-size:11px;line-height:2}.srs-complete-stats{gap:var(--s5);padding:var(--s4) var(--s6);background:var(--bg-raised);border:1px solid var(--border-soft);flex-wrap:wrap;justify-content:center;display:flex}.srs-stat{flex-direction:column;align-items:center;gap:4px;min-width:56px;display:flex}.srs-stat-val{font-family:var(--font-pixel);color:var(--text-1);font-size:13px;line-height:1.5}.srs-stat-label{font-family:var(--font-pixel);color:var(--text-3);letter-spacing:.3px;font-size:6.5px}.srs-complete-next{color:var(--text-3);font-size:13px}.srs-complete-actions{gap:var(--s3);display:flex}.flashcard-block{background:var(--bg-card);border:1px solid var(--border-soft);padding:var(--s4);margin:var(--s3) 0;-webkit-user-select:none;user-select:none}.flashcard-title{font-family:var(--font-pixel);letter-spacing:.3px;color:var(--text-3);flex:1;min-width:0;font-size:8px}.flashcard-counter{font-family:var(--font-pixel);color:var(--text-3);flex-shrink:0;font-size:8px}.fc-save-btn{font-family:var(--font-pixel);letter-spacing:.3px;background:var(--accent-dim);border:1px solid var(--accent-mid);color:var(--accent);flex-shrink:0;padding:4px 8px;font-size:7px;transition:background .12s,color .12s}.fc-save-btn:hover{background:var(--accent-mid);color:var(--text-1)}.fc-save-btn.saved{background:var(--secondary-dim);border-color:var(--secondary-mid);color:var(--secondary)}.fc-scene{width:100%;height:240px;margin-bottom:var(--s4);position:relative}.fc-card{width:100%;height:100%;position:relative}.fc-face{border:1px solid var(--border-mid);scrollbar-width:thin;flex-direction:column;display:flex;position:absolute;inset:0;overflow-y:auto}.fc-front{background:var(--bg-surface);text-align:center;padding:var(--s5) var(--s6);z-index:1;justify-content:center;align-items:center}.fc-back{background:var(--bg-surface);border-color:var(--accent-pale);border-left:3px solid var(--accent);text-align:left;padding:var(--s4);z-index:0;justify-content:flex-start;align-items:stretch}.fc-card.flipped .fc-front{z-index:0}.fc-card.flipped .fc-back{z-index:1}.fc-label{font-family:var(--font-pixel);letter-spacing:.5px;color:var(--text-3);text-align:center;width:100%;margin-bottom:var(--s3);flex-shrink:0;font-size:7.5px}.fc-front-text{color:var(--text-1);text-align:center;width:100%;font-size:15px;line-height:1.65}.fc-answer-box{background:var(--accent-dim);border:1px solid var(--accent-mid);padding:var(--s3) var(--s4);margin-bottom:var(--s3);text-align:center;flex-shrink:0}.fc-answer-label{font-family:var(--font-pixel);color:var(--accent);letter-spacing:.5px;margin-bottom:var(--s2);font-size:7px}.fc-answer-text{color:var(--text-1);font-size:15px;font-weight:700;line-height:1.6}.fc-explanation-label{font-family:var(--font-pixel);color:var(--text-3);letter-spacing:.5px;margin-bottom:var(--s2);flex-shrink:0;font-size:7px}.fc-explanation-text{color:var(--text-2);flex:1;font-size:13px;line-height:1.65}.fc-hint{color:var(--text-3);text-align:center;margin-bottom:var(--s3);font-size:10px}.fc-nav{justify-content:center;align-items:center;gap:var(--s3);display:flex}.fc-nav-btn{background:var(--bg-raised);border:1px solid var(--border-mid);width:34px;height:34px;color:var(--text-2);flex-shrink:0;justify-content:center;align-items:center;transition:background .12s,border-color .12s,color .12s;display:flex}.fc-nav-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-pixel);color:var(--text-1)}.fc-nav-btn:disabled{opacity:.25}.fc-flip-btn{background:var(--accent-dim);border:1px solid var(--accent-mid);color:var(--accent);font-family:var(--font-pixel);letter-spacing:.3px;padding:7px 16px;font-size:7.5px;transition:background .12s,color .12s}.fc-flip-btn:hover{background:var(--accent-mid);color:var(--text-1)}.fc-review-btn{background:var(--secondary-dim);border:1px solid var(--secondary-mid);color:var(--secondary);font-family:var(--font-pixel);letter-spacing:.3px;padding:7px 12px;font-size:7.5px;transition:background .12s,color .12s}.fc-review-btn:hover{background:var(--secondary-mid);color:var(--text-1)}.fc-progress{margin-top:var(--s3);flex-wrap:wrap;justify-content:center;gap:5px;display:flex}.fc-dot{background:var(--border-mid);width:6px;height:6px;transition:background .15s}.fc-dot.active{background:var(--accent)}.fc-dot.seen{background:var(--secondary-hi)}.quiz-block{background:var(--bg-card);border:1px solid var(--border-soft);padding:var(--s4);margin:var(--s3) 0}.quiz-header{margin-bottom:var(--s4);justify-content:space-between;align-items:center;gap:var(--s2);flex-wrap:wrap;display:flex}.quiz-title{font-family:var(--font-pixel);letter-spacing:.3px;color:var(--text-3);font-size:8px}.quiz-score-pill{font-family:var(--font-pixel);border:1px solid var(--accent-mid);color:var(--accent);background:var(--accent-dim);padding:3px 8px;font-size:7.5px}.quiz-question{background:var(--bg-raised);border:1px solid var(--border-soft);padding:var(--s4);margin-bottom:var(--s3);transition:border-color .15s}.quiz-question.correct{border-color:var(--correct-bd);background:var(--correct-bg)}.quiz-question.incorrect{border-color:var(--incorrect-bd);background:var(--incorrect-bg)}.quiz-q-header{align-items:flex-start;gap:var(--s3);margin-bottom:var(--s3);display:flex}.quiz-q-num{background:var(--bg-surface);border:1px solid var(--border-mid);width:22px;height:22px;font-family:var(--font-pixel);color:var(--text-3);flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;font-size:8.5px;display:flex}.quiz-q-num.correct{border-color:var(--correct-bd);color:var(--correct);background:var(--correct-bg)}.quiz-q-num.incorrect{border-color:var(--incorrect-bd);color:var(--incorrect);background:var(--incorrect-bg)}.quiz-q-text{color:var(--text-1);flex:1;font-size:14px;line-height:1.65}.quiz-type-badge{font-family:var(--font-pixel);border:1px solid var(--border-soft);color:var(--text-3);background:var(--bg-surface);flex-shrink:0;margin-top:2px;padding:2px 5px;font-size:7px}.quiz-options{gap:var(--s2);margin-bottom:var(--s3);flex-direction:column;display:flex}.quiz-option{align-items:center;gap:var(--s3);padding:var(--s2) var(--s3);border:1px solid var(--border-soft);background:var(--bg-surface);color:var(--text-1);text-align:left;width:100%;font-size:13.5px;line-height:1.5;transition:background .12s,border-color .12s;display:flex}.quiz-option:hover:not(:disabled){border-color:var(--accent-mid);background:var(--accent-dim)}.quiz-option:disabled{cursor:default}.quiz-option.selected{border-color:var(--accent-mid);background:var(--accent-dim)}.quiz-option.correct{border-color:var(--correct-bd);background:var(--correct-bg);color:var(--correct);font-weight:600}.quiz-option.incorrect{border-color:var(--incorrect-bd);background:var(--incorrect-bg);color:var(--incorrect);font-weight:600}.option-letter{background:var(--bg-raised);border:1px solid var(--border-soft);width:20px;height:20px;font-family:var(--font-pixel);color:var(--text-3);flex-shrink:0;justify-content:center;align-items:center;font-size:8px;display:flex}.quiz-option.correct .option-letter{border-color:var(--correct-bd);color:var(--correct);background:var(--correct-bg)}.quiz-option.incorrect .option-letter{border-color:var(--incorrect-bd);color:var(--incorrect);background:var(--incorrect-bg)}.quiz-tf{gap:var(--s2);margin-bottom:var(--s3);display:flex}.quiz-tf-btn{padding:var(--s2) var(--s3);border:1px solid var(--border-soft);background:var(--bg-surface);color:var(--text-1);flex:1;font-size:13.5px;font-weight:600;transition:background .12s,border-color .12s}.quiz-tf-btn:hover:not(:disabled){border-color:var(--accent-mid);background:var(--accent-dim)}.quiz-tf-btn:disabled{cursor:default}.quiz-tf-btn.correct{border-color:var(--correct-bd);background:var(--correct-bg);color:var(--correct)}.quiz-tf-btn.incorrect{border-color:var(--incorrect-bd);background:var(--incorrect-bg);color:var(--incorrect)}.quiz-typed{gap:var(--s2);margin-bottom:var(--s3);display:flex}.quiz-typed-input{background:var(--bg-surface);border:1px solid var(--border-soft);padding:var(--s2) var(--s3);color:var(--text-1);font-size:13.5px;font-family:var(--font-body);cursor:text;flex:1;transition:border-color .12s}.quiz-typed-input::placeholder{color:var(--text-3)}.quiz-typed-input:focus{border-color:var(--accent-mid)}.quiz-typed-input:disabled{opacity:.6;cursor:default}.quiz-typed-input.correct{border-color:var(--correct-bd);background:var(--correct-bg)}.quiz-typed-input.incorrect{border-color:var(--incorrect-bd);background:var(--incorrect-bg)}.quiz-submit-btn{padding:var(--s2) var(--s4);border:1px solid var(--accent-mid);background:var(--accent-dim);color:var(--accent);font-family:var(--font-pixel);letter-spacing:.3px;white-space:nowrap;flex-shrink:0;font-size:7.5px;transition:background .12s,color .12s}.quiz-submit-btn:hover:not(:disabled){background:var(--accent-mid);color:var(--text-1)}.quiz-submit-btn:disabled{opacity:.3}.quiz-feedback{margin-top:var(--s3);padding:var(--s3) var(--s4);border:1px solid;font-size:13px;line-height:1.65;display:none}.quiz-feedback.visible{display:block}.quiz-feedback.correct{border-color:var(--correct-bd);background:var(--correct-bg)}.quiz-feedback.incorrect{border-color:var(--incorrect-bd);background:var(--incorrect-bg)}.quiz-feedback-label{font-family:var(--font-pixel);letter-spacing:.3px;margin-bottom:var(--s2);font-size:7.5px}.quiz-feedback.correct .quiz-feedback-label{color:var(--correct)}.quiz-feedback.incorrect .quiz-feedback-label{color:var(--incorrect)}.quiz-complete{margin-top:var(--s4);padding:var(--s5);border:1px solid var(--secondary-mid);background:var(--secondary-dim);text-align:center;display:none}.quiz-complete.visible{display:block}.quiz-complete-score{font-family:var(--font-pixel);color:var(--secondary);margin-bottom:var(--s2);font-size:13px;line-height:2}.quiz-complete-label{color:var(--text-3);margin-bottom:var(--s4);font-size:13px;line-height:1.6}.quiz-retry-btn{background:var(--bg-raised);border:1px solid var(--border-pixel);color:var(--text-2);font-family:var(--font-pixel);letter-spacing:.3px;padding:8px 20px;font-size:8px;transition:background .12s,color .12s}.quiz-retry-btn:hover{background:var(--bg-hover);color:var(--text-1)}.code-block-wrap{margin:var(--s4) 0;border:1px solid var(--border-mid);overflow:hidden}.code-block-header{background:var(--bg-raised);border-bottom:1px solid var(--border-mid);justify-content:space-between;align-items:center;padding:6px 12px;display:flex}.code-lang-label{font-family:var(--font-pixel);color:var(--text-3);letter-spacing:.5px;text-transform:lowercase;font-size:7px}.code-copy-btn{font-family:var(--font-pixel);letter-spacing:.3px;color:var(--text-3);border:1px solid var(--border-soft);cursor:pointer;background:0 0;align-items:center;gap:5px;padding:3px 8px;font-size:6px;transition:color .12s,border-color .12s,background .12s;display:flex}.code-copy-btn:hover{color:var(--accent);border-color:var(--accent-mid);background:var(--accent-dim)}.code-block-pre{overflow-x:auto;padding:var(--s4)!important;background:#282c34!important;border:none!important;border-radius:0!important;margin:0!important;font-size:13px!important;line-height:1.6!important}.bubble .code-block-wrap pre{background:#282c34;border:none}.bubble .code-block-wrap code{color:inherit;background:0 0;border:none;padding:0;font-size:13px}[data-mode=dark] .code-block-wrap{border-color:var(--border-pixel)}[data-mode=dark] .code-block-header{background:var(--bg-raised)}.graph-coord-bar{height:18px;padding:0 var(--s3);background:var(--bg-raised);border-top:1px solid var(--border-soft);align-items:center;display:flex}.graph-coord-text{font-family:var(--font-mono);color:var(--accent);letter-spacing:.3px;min-width:160px;font-size:10.5px}.graph-ctrl-btns{gap:var(--s2);display:flex}.math-block{background:var(--bg-raised);border:1px solid var(--border-soft);border-left:3px solid var(--accent-mid);padding:var(--s5) var(--s6);margin:var(--s5) 0;text-align:center;display:block;overflow-x:auto}.bubble u{text-underline-offset:2px;text-decoration:underline}.bubble s,.bubble del{color:var(--text-3);text-decoration:line-through}.bubble mark{background:var(--accent-dim);color:var(--text-1);padding:0 3px}mjx-container[display=true]{overflow-x:auto;margin:var(--s2) 0!important}mjx-container:not([display=true]){vertical-align:middle;margin:0 2px;display:inline}.graph-block{background:var(--bg-card);border:1px solid var(--border-soft);padding:var(--s4) var(--s5) var(--s3);margin:var(--s3) 0}.graph-canvas-wrap canvas:focus{outline:1px solid var(--accent-mid);outline-offset:-1px}.graph-controls{margin-top:var(--s3);padding:0 var(--s1);justify-content:space-between;align-items:center;gap:var(--s2);display:flex}.graph-hint{color:var(--text-3);opacity:.7;flex:1;font-size:10px}.graph-reset-btn{font-family:var(--font-pixel);color:var(--text-2);background:var(--bg-raised);border:1px solid var(--border-mid);letter-spacing:.3px;padding:4px 10px;font-size:7.5px;transition:background .12s,color .12s,border-color .12s}.graph-reset-btn:hover{background:var(--bg-hover);border-color:var(--border-pixel);color:var(--text-1)}.tb-hint{color:var(--text-3);margin-bottom:var(--s4);font-size:12.5px;line-height:1.65}.task-add-row{gap:var(--s2);margin-bottom:var(--s3);display:flex}.task-add-input{background:var(--bg-raised);border:1px solid var(--border-mid);padding:var(--s2) var(--s3);color:var(--text-1);font-size:13px;font-family:var(--font-body);cursor:text;flex:1;transition:border-color .12s}.task-add-input::placeholder{color:var(--text-3)}.task-add-input:focus{border-color:var(--accent-mid)}.task-add-btn{padding:var(--s2) var(--s4);background:var(--accent-dim);border:1px solid var(--accent-mid);color:var(--accent);font-family:var(--font-pixel);letter-spacing:.3px;flex-shrink:0;font-size:7.5px;transition:background .12s,color .12s}.task-add-btn:hover{background:var(--accent-mid);color:var(--text-1)}.task-list-inner{flex-direction:column;gap:2px;display:flex}.task-item{align-items:center;gap:var(--s3);padding:var(--s2) var(--s3);background:var(--bg-raised);border:1px solid var(--border-soft);display:flex}.task-item.done{opacity:.5}.task-check{background:var(--bg-surface);border:1px solid var(--border-mid);flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;transition:background .12s,border-color .12s;display:flex}.task-check:hover{border-color:var(--accent-mid)}.task-check.checked{background:var(--accent-dim);border-color:var(--accent-mid)}.task-check svg{display:none}.task-check.checked svg{color:var(--accent);display:block}.task-text{color:var(--text-1);word-break:break-word;flex:1;font-size:13px;line-height:1.5}.task-del-btn{width:22px;height:22px;color:var(--text-3);opacity:0;flex-shrink:0;justify-content:center;align-items:center;transition:opacity .12s,color .12s;display:flex}.task-item:hover .task-del-btn{opacity:1}.task-del-btn:hover{color:var(--incorrect)}.task-empty{font-family:var(--font-pixel);color:var(--text-3);text-align:center;padding:var(--s8) var(--s4);font-size:8px;line-height:2.5}.task-footer{padding-top:var(--s3);border-top:1px solid var(--border-soft);margin-top:var(--s3);justify-content:space-between;align-items:center;display:flex}.task-count{font-family:var(--font-pixel);color:var(--text-3);letter-spacing:.3px;font-size:7.5px}.task-clear-btn{font-family:var(--font-pixel);color:var(--text-3);letter-spacing:.3px;font-size:7px;transition:color .12s}.task-clear-btn:hover{color:var(--incorrect)}.tb-selects-row{gap:var(--s2);margin-bottom:var(--s3);display:flex}.tb-select{background:var(--bg-raised);border:1px solid var(--border-mid);padding:var(--s2) var(--s3);color:var(--text-1);font-size:12.5px;font-family:var(--font-body);transition:border-color .12s}.tb-select:focus{border-color:var(--accent-mid)}.tb-upload-row{margin-bottom:var(--s3)}.tb-upload-btn{padding:var(--s2) var(--s5);background:var(--accent-dim);border:1px solid var(--accent-mid);color:var(--accent);font-family:var(--font-pixel);letter-spacing:.3px;font-size:7.5px;transition:background .12s,color .12s}.tb-upload-btn:hover:not(:disabled){background:var(--accent-mid);color:var(--text-1)}.tb-upload-btn:disabled{opacity:.4}.tb-progress{gap:var(--s2);padding:var(--s3);background:var(--bg-raised);border:1px solid var(--border-soft);margin-bottom:var(--s3);flex-direction:column;display:none}.tb-progress.visible{display:flex}.tb-progress-bar-wrap{background:var(--border-soft);height:4px;overflow:hidden}.tb-progress-bar{background:var(--accent-gradient);height:100%;transition:width .3s var(--ease)}.tb-progress-label{font-family:var(--font-pixel);color:var(--text-3);letter-spacing:.3px;font-size:7px}.tb-section-title{font-family:var(--font-pixel);letter-spacing:.8px;color:var(--text-3);margin-bottom:var(--s3);text-transform:uppercase;font-size:7.5px}.tb-list{gap:var(--s2);flex-direction:column;display:flex}.tb-item{align-items:flex-start;gap:var(--s3);padding:var(--s3) var(--s4);background:var(--bg-raised);border:1px solid var(--border-soft);display:flex}.tb-item-icon{flex-shrink:0;margin-top:2px}.tb-item-info{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.tb-item-name{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.tb-item-tags{gap:var(--s2);flex-wrap:wrap;display:flex}.tb-item-subject{font-family:var(--font-pixel);background:var(--accent-dim);border:1px solid var(--accent-mid);color:var(--accent);padding:2px 6px;font-size:7px}.tb-item-unit{font-family:var(--font-pixel);background:var(--secondary-dim);border:1px solid var(--secondary-mid);color:var(--secondary);padding:2px 6px;font-size:7px}.tb-item-meta{color:var(--text-3);font-size:11px}.tb-item-del{width:28px;height:28px;color:var(--text-3);border:1px solid var(--border-soft);flex-shrink:0;justify-content:center;align-items:center;transition:color .12s,border-color .12s;display:flex}.tb-item-del:hover{color:var(--incorrect);border-color:var(--incorrect-bd)}.tb-empty{font-family:var(--font-pixel);color:var(--text-3);text-align:center;padding:var(--s8) var(--s4);font-size:8px;line-height:2.5}.exam-date-input{background:var(--bg-raised);border:1px solid var(--border-mid);padding:var(--s2) var(--s3);color:var(--text-1);font-size:12.5px;font-family:var(--font-body);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;cursor:text;flex:1;min-width:120px;transition:border-color .12s}@media (prefers-color-scheme:dark){.exam-date-input{--lightningcss-light: ;--lightningcss-dark:initial}}.exam-list{gap:var(--s2);flex-direction:column;display:flex}.exam-del-btn{opacity:0;transition:opacity .12s}.msg-actions-row{margin-top:var(--s3);opacity:0;align-items:center;gap:4px;transition:opacity .15s;display:flex}.message.assistant:hover .msg-actions-row,.msg-actions-row:focus-within{opacity:1}.msg-action-btn{width:24px;height:24px;color:var(--text-3);cursor:pointer;background:0 0;border:1px solid #0000;flex-shrink:0;justify-content:center;align-items:center;transition:color .12s,border-color .12s,background .12s;display:inline-flex}.msg-action-btn:hover{color:var(--text-1);background:var(--bg-raised);border-color:var(--border-soft)}.msg-dots-wrap{position:relative}.msg-dots-menu{background:var(--bg-surface);border:1px solid var(--border-pixel);box-shadow:3px 4px 0 var(--border-mid);z-index:100;min-width:172px;animation:ddIn .1s var(--ease) both;flex-direction:column;display:flex;position:absolute;bottom:calc(100% + 4px);left:0}.msg-dots-menu.hidden{display:none}.msg-dots-item{color:var(--text-2);text-align:left;border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:8px;padding:9px 14px;font-size:13px;transition:background .1s,color .1s;display:flex}.msg-dots-item:last-child{border-bottom:none}.msg-dots-item:hover{background:var(--accent-dim);color:var(--accent)}.msg-dots-icon{color:var(--text-3);flex-shrink:0;width:14px;font-size:11px}.user-edit-btn{width:22px;height:22px;color:var(--text-3);opacity:0;cursor:pointer;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;transition:opacity .15s,color .12s,border-color .12s,background .12s;display:flex;position:absolute;top:6px;right:-28px}.message.user:hover .user-edit-btn{opacity:1}.user-edit-btn:hover{color:var(--text-1);background:var(--bg-raised);border-color:var(--border-soft)}.conf-star{color:var(--border-mid);padding:0 1px;font-size:16px;line-height:1;transition:color .1s}.conf-star.hover,.conf-star.selected{color:var(--accent)}.highlight-popup{background:var(--bg-surface);border:1px solid var(--border-pixel);box-shadow:3px 3px 0 var(--border-mid);z-index:300;flex-wrap:wrap;gap:2px;max-width:280px;padding:4px;display:flex;position:fixed}.highlight-popup.hidden{display:none}.highlight-opt{font-family:var(--font-pixel);letter-spacing:.3px;color:var(--text-2);background:var(--bg-raised);border:1px solid var(--border-soft);white-space:nowrap;padding:5px 9px;font-size:7px;transition:background .1s,color .1s,border-color .1s}.highlight-opt:hover{background:var(--accent-dim);color:var(--accent);border-color:var(--accent-mid)}.quick-review-popup{bottom:100px;right:var(--s5);background:var(--bg-surface);border:1px solid var(--border-pixel);width:300px;box-shadow:4px 4px 0 var(--border-mid);z-index:80;padding:var(--s4);animation:slideUp .18s var(--ease);position:fixed}.qrp-header{margin-bottom:var(--s3);justify-content:space-between;align-items:center;display:flex}.qrp-title{font-family:var(--font-pixel);color:var(--text-3);letter-spacing:.3px;font-size:8px}.qrp-close{width:22px;height:22px;color:var(--text-3);justify-content:center;align-items:center;transition:color .12s;display:flex}.qrp-close:hover{color:var(--incorrect)}.qrp-front{color:var(--text-1);margin-bottom:var(--s3);font-size:14px;line-height:1.6}.qrp-answer{color:var(--text-2);background:var(--accent-dim);border:1px solid var(--accent-mid);padding:var(--s2) var(--s3);margin-bottom:var(--s3);font-size:13px}.qrp-actions{gap:var(--s2);display:flex}.qrp-btn{font-family:var(--font-pixel);letter-spacing:.3px;border:1px solid var(--border-mid);background:var(--bg-raised);color:var(--text-2);flex:1;padding:6px;font-size:7px;transition:background .12s}.qrp-show{background:var(--accent-dim);border-color:var(--accent-mid);color:var(--accent)}.qrp-again{background:var(--incorrect-bg);border-color:var(--incorrect-bd);color:var(--incorrect)}.qrp-good{background:var(--accent-dim);border-color:var(--accent-mid);color:var(--accent)}.qrp-easy{background:var(--secondary-dim);border-color:var(--secondary-mid);color:var(--secondary)}.memory-add-row{gap:var(--s2);margin-bottom:var(--s3);display:flex}.memory-add-input{background:var(--bg-raised);border:1px solid var(--border-mid);padding:var(--s2) var(--s3);color:var(--text-1);font-size:12.5px;font-family:var(--font-body);cursor:text;flex:1;transition:border-color .12s}.memory-add-input::placeholder{color:var(--text-3)}.memory-add-input:focus{border-color:var(--accent-mid)}.memory-add-btn{padding:var(--s2) var(--s3);background:var(--accent-dim);border:1px solid var(--accent-mid);color:var(--accent);font-family:var(--font-pixel);letter-spacing:.3px;flex-shrink:0;font-size:7.5px;transition:background .12s,color .12s}.memory-add-btn:hover{background:var(--accent-mid);color:var(--text-1)}.memory-list{flex-direction:column;gap:2px;display:flex}.memory-item{align-items:center;gap:var(--s2);padding:var(--s2) var(--s3);background:var(--bg-raised);border:1px solid var(--border-soft);display:flex}.memory-item-bullet{color:var(--accent);flex-shrink:0;font-size:11px}.memory-item-text{color:var(--text-2);flex:1;font-size:12.5px;line-height:1.5}.memory-item-del{width:20px;height:20px;color:var(--text-3);flex-shrink:0;justify-content:center;align-items:center;transition:color .12s;display:flex}.memory-item-del:hover{color:var(--incorrect)}.memory-empty{font-family:var(--font-pixel);color:var(--text-3);text-align:center;padding:var(--s5) var(--s4);font-size:7.5px;line-height:2.5}.formula-add-row{gap:var(--s2);margin-bottom:var(--s3);flex-wrap:wrap;display:flex}.formula-add-input{background:var(--bg-raised);border:1px solid var(--border-mid);min-width:160px;padding:var(--s2) var(--s3);color:var(--text-1);font-size:13px;font-family:var(--font-body);cursor:text;flex:1;transition:border-color .12s}.formula-add-input::placeholder{color:var(--text-3)}.formula-add-input:focus{border-color:var(--accent-mid)}.formula-tag-filter{margin-bottom:var(--s3);padding-bottom:var(--s3);border-bottom:1px solid var(--border-soft);flex-wrap:wrap;gap:4px;display:flex}.formula-filter-btn{font-family:var(--font-pixel);letter-spacing:.3px;color:var(--text-3);background:var(--bg-raised);border:1px solid var(--border-soft);padding:3px 8px;font-size:7px;transition:color .12s,border-color .12s,background .12s}.formula-filter-btn:hover{border-color:var(--border-mid);color:var(--text-2)}.formula-filter-btn.active{background:var(--accent-dim);border-color:var(--accent-mid);color:var(--accent)}.formula-list{gap:var(--s2);flex-direction:column;display:flex}.formula-item{align-items:flex-start;gap:var(--s3);padding:var(--s3) var(--s4);background:var(--bg-raised);border:1px solid var(--border-soft);border-left:3px solid var(--accent);display:flex}.formula-item-body{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.formula-tag-pill{font-family:var(--font-pixel);letter-spacing:.3px;background:var(--accent-dim);border:1px solid var(--accent-mid);color:var(--accent);align-self:flex-start;padding:2px 6px;font-size:6.5px}.formula-text{color:var(--text-1);word-break:break-word;font-size:13.5px;line-height:1.6}.formula-del{opacity:0;flex-shrink:0;transition:opacity .12s}.formula-item:hover .formula-del{opacity:1}.profile-form{gap:var(--s4);flex-direction:column;display:flex}.profile-row{gap:var(--s2);flex-direction:column;display:flex}.profile-label{font-family:var(--font-pixel);letter-spacing:.5px;color:var(--text-3);text-transform:uppercase;font-size:7.5px}.profile-textarea{background:var(--bg-raised);border:1px solid var(--border-mid);padding:var(--s2) var(--s3);color:var(--text-1);font-size:13px;font-family:var(--font-body);resize:vertical;cursor:text;line-height:1.6;transition:border-color .12s}.profile-textarea::placeholder{color:var(--text-3)}.profile-textarea:focus{border-color:var(--accent-mid)}.profile-subjects{flex-wrap:wrap;gap:6px;display:flex}.selected-subjects{flex-wrap:wrap;gap:6px;min-height:4px;margin-top:4px;display:flex}.profile-subject-chip{color:var(--text-3);background:var(--bg-raised);border:1px solid var(--border-soft);cursor:pointer;padding:4px 10px;font-size:12px;transition:color .12s,border-color .12s,background .12s}.profile-subject-chip:hover{border-color:var(--accent-mid);color:var(--accent)}.profile-subject-chip.active{background:var(--accent-dim);border-color:var(--accent-mid);color:var(--accent)}.subject-search-wrap{position:relative}.subject-search-input{background:var(--bg-raised);border:1px solid var(--border-mid);width:100%;padding:8px var(--s3);color:var(--text-1);font-size:13px;font-family:var(--font-body);outline:none;transition:border-color .12s}.subject-search-input:focus{border-color:var(--accent)}.subject-dropdown{background:var(--bg-surface);border:1px solid var(--border-pixel);box-shadow:3px 4px 0 var(--border-mid);z-index:200;max-height:220px;animation:ddIn .1s var(--ease) both;flex-direction:column;display:flex;position:absolute;top:calc(100% + 2px);left:0;right:0;overflow-y:auto}.subject-dropdown.hidden{display:none}.subject-dropdown-item{padding:9px var(--s3);color:var(--text-2);text-align:left;border:none;border-bottom:1px solid var(--border);cursor:pointer;background:0 0;font-size:13px;transition:background .1s,color .1s}.subject-dropdown-item:last-child{border-bottom:none}.subject-dropdown-item:hover{background:var(--accent-dim);color:var(--accent)}.profile-style-row{flex-wrap:wrap;gap:8px;display:flex}.profile-style-btn{min-width:80px;font-family:var(--font-body);color:var(--text-2);background:var(--bg-raised);border:1px solid var(--border-mid);cursor:pointer;text-align:center;flex:1;padding:8px 12px;font-size:13px;font-weight:500;transition:background .12s,border-color .12s,color .12s}.profile-style-btn:hover{background:var(--bg-hover);border-color:var(--border-pixel);color:var(--text-1)}.profile-style-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.qh-retry-btn{font-family:var(--font-pixel);color:var(--accent);background:var(--accent-dim);border:1px solid var(--accent-mid);letter-spacing:.3px;flex-shrink:0;padding:4px 10px;font-size:7px;transition:background .12s}.mistake-header-row{margin-bottom:var(--s3);padding-bottom:var(--s3);border-bottom:1px solid var(--border-soft);justify-content:space-between;align-items:center;display:flex}.mistake-list{gap:var(--s2);flex-direction:column;display:flex}.mistake-item{align-items:flex-start;gap:var(--s3);padding:var(--s3) var(--s4);background:var(--bg-raised);border:1px solid var(--border-soft);border-left:3px solid var(--incorrect-bd);display:flex}.mistake-item-body{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.mistake-q{color:var(--text-1);font-size:13px;line-height:1.5}.mistake-a{color:var(--text-2);font-size:12px}.mistake-ctx{color:var(--text-3);font-size:11px;font-style:italic}.mistake-item-meta{color:var(--text-3);flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;font-size:10px;display:flex}.mistake-retry-btn{font-family:var(--font-pixel);letter-spacing:.3px;color:var(--accent);background:var(--accent-dim);border:1px solid var(--accent-mid);white-space:nowrap;padding:3px 7px;font-size:6.5px;transition:background .12s}.mistake-retry-btn:hover{background:var(--accent-mid)}.mistake-reattempt{padding:var(--s2) var(--s3);border-top:1px solid var(--border);background:var(--bg-raised)}.mistake-reattempt-q{color:var(--text-2);margin-bottom:var(--s2);font-size:12px;line-height:1.5}.mistake-reattempt-row{gap:var(--s1);display:flex}.mistake-reattempt-input{background:var(--bg-surface);border:1px solid var(--border-mid);color:var(--text-1);cursor:text;flex:1;padding:5px 8px;font-size:13px;transition:border-color .12s}.mistake-reattempt-input:focus{border-color:var(--accent)}.mistake-reattempt-check{font-family:var(--font-pixel);letter-spacing:.3px;background:var(--accent);color:#fff;padding:5px 10px;font-size:6.5px;transition:opacity .12s}.mistake-reattempt-check:hover{opacity:.85}.mistake-reattempt-check:disabled{opacity:.4;cursor:default}.mistake-reattempt-feedback{margin-top:var(--s1);padding:5px 8px;font-size:12px}.mistake-reattempt-feedback.correct{color:var(--correct);background:var(--correct-bg)}.mistake-reattempt-feedback.incorrect{color:var(--incorrect);background:var(--incorrect-bg)}.pom-settings-form{flex-direction:column;gap:4px;display:flex}.pom-settings-row{background:var(--bg-raised);border:1px solid var(--border-soft);align-items:center;gap:16px;padding:16px;display:flex}.pom-settings-row+.pom-settings-row{border-top:none}.pom-settings-icon{flex-shrink:0;justify-content:center;align-items:center;width:36px;display:flex}.pom-settings-field{flex-direction:column;flex:1;gap:6px;display:flex}.pom-settings-label{color:var(--text-1);font-size:14px;font-weight:500;line-height:1.4}.pom-settings-desc{color:var(--text-3);font-size:12px;line-height:1.4}.pom-settings-input-row{align-items:center;gap:10px;display:flex}.pom-settings-input{background:var(--bg-surface);border:1px solid var(--border-mid);width:64px;color:var(--text-1);text-align:center;font-size:18px;font-weight:500;font-family:var(--font-pixel);letter-spacing:1px;-moz-appearance:textfield;cursor:text;padding:8px 10px}.pom-settings-input::-webkit-outer-spin-button{-webkit-appearance:none}.pom-settings-input::-webkit-inner-spin-button{-webkit-appearance:none}.pom-settings-input:focus{border-color:var(--accent-mid)}.pom-settings-unit{color:var(--text-3);font-size:13px}.pom-settings-apply{background:var(--secondary-dim);border:1px solid var(--secondary-mid);color:var(--secondary);font-family:var(--font-pixel);letter-spacing:.5px;width:100%;margin-top:4px;padding:12px;font-size:8px;transition:background .12s,color .12s}.pom-settings-apply:hover{background:var(--secondary-mid);color:var(--text-1)}.pom-si-focus{color:var(--accent)}.pom-si-short,.pom-si-long{color:var(--secondary)}.music-url-row{gap:var(--s2);display:flex}.music-url-input{background:var(--bg-surface);border:1px solid var(--border-mid);color:var(--text-1);cursor:text;flex:1;padding:7px 10px;font-size:13px;transition:border-color .12s}.music-url-input:focus{border-color:var(--accent)}.music-load-btn{font-family:var(--font-pixel);letter-spacing:.3px;background:var(--accent);color:#fff;white-space:nowrap;padding:7px 14px;font-size:6.5px;transition:opacity .12s}.music-load-btn:hover{opacity:.85}.music-controls{align-items:center;gap:var(--s3);padding:var(--s2) 0;flex-wrap:wrap;display:flex}.music-play-btn{background:var(--accent);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:opacity .12s;display:flex}.music-play-btn:hover{opacity:.85}.music-vol-row{align-items:center;gap:var(--s2);color:var(--text-3);flex:1;display:flex}.px-slider{-webkit-user-select:none;user-select:none;flex:1;align-items:center;height:16px;display:flex;position:relative}.px-slider-track{background:var(--border-mid);outline:1px solid var(--border-pixel);outline-offset:-1px;height:4px;position:absolute;left:0;right:0}.px-slider-fill{background:var(--accent);pointer-events:none;height:100%}.px-slider-handle{background:var(--text-1);pointer-events:none;width:8px;height:12px;position:absolute;top:50%;transform:translate(-50%,-50%)}.music-vol-label{color:var(--text-3);text-align:right;min-width:28px;font-size:11px}.music-status{color:var(--text-3);white-space:nowrap;font-size:11px}.music-hint{color:var(--text-3);margin-top:var(--s3);border-top:1px solid var(--border);padding-top:var(--s2);font-size:11px;line-height:1.5}.chat-color-picker{background:var(--bg-surface);border:1px solid var(--border-pixel);box-shadow:3px 3px 0 var(--border-mid);z-index:200;flex-wrap:wrap;gap:4px;max-width:160px;padding:6px;display:flex;position:fixed}.chat-color-swatch{border:1px solid var(--border-mid);flex-shrink:0;width:18px;height:18px;transition:transform .1s}.chat-color-swatch:hover{border-color:var(--border-pixel);transform:scale(1.2)}.swatch-none{background:var(--bg-raised);position:relative}.swatch-none:after{content:"×";color:var(--text-3);justify-content:center;align-items:center;font-size:12px;display:flex;position:absolute;inset:0}body.focus-mode .sidebar{display:none}.focus-mode-btn{width:28px;height:28px;color:var(--text-3);justify-content:center;align-items:center;transition:color .12s;display:flex}.focus-mode-btn:hover{color:var(--accent)}.tristan-msg{background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-style:italic;font-weight:700}.tristan-sig{background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.hidden{display:none!important}@keyframes softPulse{0%,to{opacity:1}50%{opacity:.4}}@media (max-width:700px){:root{--sidebar-w:200px}.chat-log,.input-area{padding-left:var(--s4);padding-right:var(--s4)}}@media (max-width:480px){.sidebar{display:none}.chat-log,.input-area{padding-left:var(--s3);padding-right:var(--s3)}}.pix-toast{background:var(--bg-surface);border:1px solid var(--border-pixel);box-shadow:3px 3px 0 var(--border-mid);font-family:var(--font-pixel);letter-spacing:.3px;color:var(--text-1);z-index:9999;opacity:0;transition:opacity .2s var(--ease), transform .2s var(--ease);white-space:nowrap;pointer-events:none;padding:10px 20px;font-size:6.5px;position:fixed;bottom:80px;left:50%;transform:translate(-50%)translateY(12px)}.pix-toast-show{opacity:1;transform:translate(-50%)translateY(0)}.pix-toast-error{border-color:var(--incorrect-bd);color:var(--incorrect);background:var(--incorrect-bg)}.pix-toast-success{border-color:var(--correct-bd);color:var(--correct);background:var(--correct-bg)}.theme-swatch{border:2px solid var(--border-soft);background:var(--bg-raised);cursor:pointer;flex-direction:column;align-items:center;gap:6px;padding:8px 6px;transition:border-color .15s;display:flex}.theme-swatch:hover{border-color:var(--border-pixel)}.theme-swatch.active{border-color:var(--accent);background:var(--accent-dim)}.theme-swatch-preview{width:52px;height:32px;position:relative;overflow:hidden}.theme-swatch-sidebar{width:14px;position:absolute;top:0;bottom:0;left:0}.theme-swatch-accent{border-radius:50%;width:12px;height:12px;position:absolute;bottom:6px;right:6px}.theme-swatch-label{font-family:var(--font-pixel);color:var(--text-3);text-align:center;letter-spacing:.3px;font-size:6px;line-height:1.4}.suggestion-chip{border:1px solid var(--border-mid);background:var(--bg-surface);color:var(--text-2);cursor:pointer;transition:background .12s var(--ease), border-color .12s var(--ease), color .12s var(--ease);padding:8px 14px;font-size:12.5px;line-height:1.4}.suggestion-chip:hover{background:var(--secondary-dim);border-color:var(--secondary-mid);color:var(--secondary)}.empty-pix-sprite{margin-bottom:var(--s4)}.chat-empty{height:100%;padding:var(--s8);text-align:center;animation:msgIn .2s var(--ease) both;flex-direction:column;justify-content:center;align-items:center;display:flex}.chat-empty-title{font-family:var(--font-pixel);color:var(--text-1);margin:var(--s4) 0 var(--s2);letter-spacing:.5px;font-size:15px}.chat-empty-sub{color:var(--text-3);margin-bottom:var(--s5);font-size:14px}.chat-item-title{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.chat-item-del{opacity:0;width:18px;height:18px;color:var(--text-3);flex-shrink:0;justify-content:center;align-items:center;transition:color .12s,opacity .12s;display:flex}.chat-item:hover .chat-item-del,.chat-item.active .chat-item-del{opacity:1}.chat-item-del:hover{color:var(--incorrect)}.library-card{padding:var(--s4);background:var(--bg-card);border:1px solid var(--border-soft);cursor:pointer;animation:msgIn .15s var(--ease) both;transition:border-color .12s,background .12s;position:relative}.library-card:hover{border-color:var(--accent);background:var(--accent-dim)}.library-card-title{color:var(--text-1);margin-bottom:4px;font-size:13px;font-weight:500}.library-card-meta{font-family:var(--font-pixel);color:var(--text-3);letter-spacing:.3px;font-size:7px}.library-card-delete{opacity:0;color:var(--text-3);transition:opacity .12s,color .12s;position:absolute;top:8px;right:8px}.library-card:hover .library-card-delete{opacity:1}.library-card-delete:hover{color:var(--incorrect)}.library-viewer-back{color:var(--text-3);cursor:pointer;align-items:center;gap:6px;padding:4px 0;font-size:12px;transition:color .12s;display:inline-flex}.library-viewer-back:hover{color:var(--accent)}.katex{font-size:1em!important}.katex-display{overflow-x:auto;margin:8px 0!important}.task-input{background:var(--bg-raised);border:1px solid var(--border-mid);color:var(--text-1);font-family:var(--font-body);outline:none;padding:8px 10px;font-size:13px;transition:border-color .12s}.task-input:focus{border-color:var(--accent)}.task-section-label{font-family:var(--font-pixel);color:var(--text-3);letter-spacing:.4px;text-transform:uppercase;padding:4px 0 6px;font-size:7px}.task-item{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:8px 0;display:flex}.task-item:last-child{border-bottom:none}.task-item.done .task-text{color:var(--text-3);text-decoration:line-through}.task-check{width:14px;height:14px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.task-text{color:var(--text-1);flex:1;font-size:13px}.task-del{opacity:0;color:var(--text-3);flex-shrink:0;padding:2px;transition:color .12s,opacity .12s}.task-item:hover .task-del{opacity:1}.task-del:hover{color:var(--incorrect)}.flashcard-wrap{margin:var(--s3) 0}.flashcard-header{margin-bottom:var(--s4);justify-content:space-between;align-items:center;gap:var(--s2);display:flex}.flashcard-count{font-family:var(--font-pixel);color:var(--text-3);flex-shrink:0;font-size:8px}.flashcard-scene{perspective:1000px;width:100%;min-height:160px;margin-bottom:var(--s3);transform-style:preserve-3d;position:relative}.flashcard{cursor:pointer;width:100%;min-height:160px;transform-style:preserve-3d;border:1px solid var(--border-mid);transition:transform .45s;position:relative}.flashcard.flipped{transform:rotateY(180deg)}.flashcard-face{backface-visibility:hidden;flex-direction:column;justify-content:center;align-items:center;padding:20px;display:flex;position:absolute;inset:0;overflow-y:auto}.flashcard-front{background:var(--bg-surface);z-index:1}.flashcard-back{background:var(--accent-dim);border:1px solid var(--accent-pale);border-left:3px solid var(--accent);z-index:0;transform:rotateY(180deg)}.flashcard.flipped .flashcard-front{z-index:0}.flashcard.flipped .flashcard-back{z-index:1}.flashcard-face-label{font-family:var(--font-pixel);color:var(--accent);letter-spacing:.4px;text-transform:uppercase;margin-bottom:10px;font-size:7px}.flashcard-text{color:var(--text-1);text-align:center;font-size:14px;line-height:1.6}.flashcard-explanation{color:var(--text-3);text-align:center;margin-top:8px;font-size:12px}.flashcard-controls{justify-content:center;align-items:center;gap:var(--s3);margin-bottom:var(--s3);display:flex}.flashcard-nav{background:var(--bg-raised);border:1px solid var(--border-mid);width:34px;height:34px;color:var(--text-2);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;transition:background .12s,border-color .12s,color .12s;display:flex}.flashcard-nav:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-pixel);color:var(--text-1)}.flashcard-nav:disabled{opacity:.25;cursor:not-allowed}.flashcard-flip-btn{background:var(--accent-dim);border:1px solid var(--accent-mid);color:var(--accent);font-family:var(--font-pixel);letter-spacing:.3px;cursor:pointer;padding:7px 16px;font-size:7.5px;transition:background .12s,color .12s}.flashcard-flip-btn:hover{background:var(--accent-mid);color:var(--text-1)}.flashcard-save-btn{width:100%;font-family:var(--font-pixel);letter-spacing:.3px;background:var(--accent-dim);border:1px solid var(--accent-mid);color:var(--accent);cursor:pointer;padding:8px;font-size:7px;transition:background .12s,color .12s}.flashcard-save-btn:hover:not(:disabled){background:var(--accent-mid);color:var(--text-1)}.flashcard-save-btn.saved{background:var(--secondary-dim);border-color:var(--secondary-mid);color:var(--secondary)}.flashcard-save-btn:disabled{cursor:not-allowed}.dots{align-items:center;gap:5px;padding:4px 0;display:flex}.dots span{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:1.2s infinite dotPulse}.dots span:nth-child(2){animation-delay:.2s}.dots span:nth-child(3){animation-delay:.4s}@keyframes dotPulse{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.msg-text{display:inline}.msg.msg-ai{padding:var(--s3) var(--s4);display:flex}.quiz-wrap{margin:var(--s3) 0}.quiz-count{font-family:var(--font-pixel);color:var(--text-3);flex-shrink:0;font-size:7.5px}.quiz-nav-row{gap:var(--s2);margin-top:var(--s3);justify-content:center;display:flex}.quiz-nav-btn{background:var(--bg-raised);border:1px solid var(--border-mid);color:var(--text-2);cursor:pointer;padding:6px 16px;font-size:12px;transition:background .12s,border-color .12s}.quiz-nav-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-pixel)}.quiz-nav-btn:disabled{opacity:.3;cursor:not-allowed}.quiz-opt-letter{background:var(--bg-surface);border:1px solid var(--border-mid);width:22px;height:22px;font-family:var(--font-pixel);color:var(--text-3);flex-shrink:0;justify-content:center;align-items:center;font-size:8.5px;display:flex}.quiz-opt-icon{flex-shrink:0;margin-left:auto}.quiz-solution{padding:var(--s3) var(--s4);margin-top:var(--s2);border:1px solid;font-size:13px;line-height:1.65}.quiz-solution.correct{border-color:var(--correct-bd);background:var(--correct-bg);color:var(--correct)}.quiz-solution.incorrect{border-color:var(--incorrect-bd);background:var(--incorrect-bg);color:var(--incorrect)}.quiz-solution-label{font-family:var(--font-pixel);letter-spacing:.3px;margin-right:8px;font-size:7px}.quiz-typed-wrap{gap:var(--s2);margin-bottom:var(--s3);display:flex}.quiz-typed-submit{padding:var(--s2) var(--s4);border:1px solid var(--accent-mid);background:var(--accent-dim);color:var(--accent);font-family:var(--font-pixel);letter-spacing:.3px;white-space:nowrap;cursor:pointer;flex-shrink:0;font-size:7.5px;transition:background .12s,color .12s}.quiz-typed-submit:hover{background:var(--accent-mid);color:var(--text-1)}.exam-subject-sel{background:var(--bg-raised);border:1px solid var(--border-mid);padding:var(--s2) var(--s3);color:var(--text-1);font-size:12.5px;font-family:var(--font-body);transition:border-color .12s}.exam-subject-sel:focus{border-color:var(--accent-mid)}.exam-banner{padding:7px var(--s6);justify-content:space-between;align-items:center;gap:var(--s3);background:var(--secondary-dim);border-bottom:1px solid var(--secondary-mid);flex-shrink:0;display:flex}.exam-banner.exam-soon{background:#c8780014;border-color:#c8780040}.exam-banner.exam-urgent{background:#b4282814;border-color:#b4282847}.exam-banner.exam-today{background:#b4282824;border-color:#b4282866;animation:2s ease-in-out infinite pulseUrgent}.exam-banner-text{align-items:center;gap:var(--s2);flex-wrap:wrap;flex:1;display:flex}.exam-banner-subject{font-family:var(--font-pixel);color:var(--text-2);letter-spacing:.3px;font-size:7.5px}.exam-banner-sep{color:var(--text-3);font-size:11px}.exam-banner-days{font-family:var(--font-pixel);color:var(--secondary);font-size:7px}.exam-banner.exam-soon .exam-banner-days{color:#a06000}.exam-banner.exam-urgent .exam-banner-days,.exam-banner.exam-today .exam-banner-days{color:var(--incorrect)}.exam-banner-more{color:var(--text-3);font-size:10px}.exam-banner-manage{font-family:var(--font-pixel);letter-spacing:.3px;background:var(--bg-raised);border:1px solid var(--border-mid);color:var(--text-3);cursor:pointer;flex-shrink:0;padding:3px 8px;font-size:6.5px;transition:color .12s,background .12s}.exam-banner-manage:hover{color:var(--text-1);background:var(--bg-hover)}.exam-add-row{gap:var(--s2);margin-bottom:var(--s4);flex-wrap:wrap;display:flex}.exam-date-input{background:var(--bg-raised);border:1px solid var(--border-mid);padding:var(--s2) var(--s3);color:var(--text-1);font-size:12.5px;font-family:var(--font-body);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;cursor:text;outline:none;flex:1;min-width:120px;transition:border-color .12s}@media (prefers-color-scheme:dark){.exam-date-input{--lightningcss-light: ;--lightningcss-dark:initial}}.exam-date-input:focus{border-color:var(--accent-mid)}.exam-list{gap:var(--s2);margin-top:var(--s2);flex-direction:column;display:flex}.exam-item{align-items:center;gap:var(--s3);padding:var(--s3) var(--s4);background:var(--bg-raised);border:1px solid var(--border-soft);display:flex}.exam-item-info{flex-direction:column;flex:1;gap:3px;display:flex}.exam-item-subject{font-family:var(--font-pixel);color:var(--text-1);letter-spacing:.3px;font-size:8px}.exam-item-date{color:var(--text-3);font-size:11px}.exam-days-pill{font-family:var(--font-pixel);letter-spacing:.3px;border:1px solid;flex-shrink:0;padding:3px 7px;font-size:7px}.exam-days-none{background:var(--secondary-dim);border-color:var(--secondary-mid);color:var(--secondary)}.exam-days-soon{color:#a06000;background:#c878001a;border-color:#c8780047}.exam-days-urgent,.exam-days-today{background:var(--incorrect-bg);border-color:var(--incorrect-bd);color:var(--incorrect)}.exam-days-past{background:var(--bg-hover);border-color:var(--border-mid);color:var(--text-3)}.exam-del-btn{opacity:0;cursor:pointer;color:var(--text-3);transition:opacity .12s}.exam-item:hover .exam-del-btn{opacity:1}.qh-stats{gap:var(--s5);padding:var(--s4) var(--s6);background:var(--bg-raised);border:1px solid var(--border-soft);margin-bottom:var(--s4);flex-wrap:wrap;justify-content:center;display:flex}.qh-list{gap:var(--s2);flex-direction:column;display:flex}.qh-item{align-items:center;gap:var(--s3);padding:var(--s3) var(--s4);background:var(--bg-raised);border:1px solid var(--border-soft);display:flex}.qh-item-info{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.qh-title{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.qh-date{color:var(--text-3);font-size:11px}.qh-score{font-family:var(--font-pixel);letter-spacing:.3px;border:1px solid;flex-shrink:0;padding:4px 8px;font-size:9px}.qh-pct{opacity:.8;font-size:5.5px}.qh-score-good{background:var(--secondary-dim);border-color:var(--secondary-mid);color:var(--secondary)}.qh-score-ok{color:#906000;background:#b478001a;border-color:#b4780047}.qh-score-poor{background:var(--incorrect-bg);border-color:var(--incorrect-bd);color:var(--incorrect)}.qh-retry-btn{font-family:var(--font-pixel);color:var(--accent);background:var(--accent-dim);border:1px solid var(--accent-mid);letter-spacing:.3px;cursor:pointer;flex-shrink:0;padding:4px 10px;font-size:7px;transition:background .12s}.qh-retry-btn:hover{background:var(--accent-mid)}.confidence-rater{margin-top:var(--s2);border-top:1px solid var(--border-soft);align-items:center;gap:4px;padding:5px 0;display:flex}.confidence-label{font-family:var(--font-pixel);letter-spacing:.3px;color:var(--text-3);flex-shrink:0;margin-right:4px;font-size:6.5px}.conf-star{color:var(--border-mid);cursor:pointer;background:0 0;border:none;padding:0 1px;font-size:16px;line-height:1;transition:color .1s}.conf-star.selected{color:var(--accent)}#scratchpad-textarea{border:1px solid var(--border-mid);cursor:text;outline:none;transition:border-color .12s}#scratchpad-textarea:focus{border-color:var(--accent-mid)}.login-page{min-height:100vh;font-family:var(--font-body);background:var(--bg-base);color:var(--text-1)}.login-dot-grid{pointer-events:none;z-index:0;background-image:radial-gradient(var(--bg-hover) 1px, transparent 1px);opacity:.5;background-size:24px 24px;position:fixed;inset:0}.login-page .page{z-index:1;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative}.login-page .card{background:var(--bg-surface);border:2px solid var(--border-pixel);width:100%;max-width:380px;box-shadow:5px 5px 0 var(--bg-hover);flex-direction:column;padding:36px 32px 32px;animation:.2s both cardIn;display:flex;position:relative}@keyframes cardIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.login-page .card:before{content:"";background:linear-gradient(90deg, var(--accent) 0%, var(--accent-pale) 60%, var(--accent) 100%);height:3px;position:absolute;top:0;left:0;right:0}.login-page .logo{align-items:center;gap:14px;margin-bottom:28px;display:flex}.login-page .logo-name{font-family:var(--font-pixel);color:var(--text-1);letter-spacing:3px;font-size:9px}.login-page .logo-tagline{font-family:var(--font-pixel);color:var(--text-3);letter-spacing:.5px;font-size:4.5px}.login-page .card-title{font-family:var(--font-pixel);color:var(--text-1);letter-spacing:.5px;margin-bottom:6px;font-size:8px;line-height:2}.login-page .card-sub{color:var(--text-3);margin-bottom:24px;font-size:13px;line-height:1.6}.login-page .form{flex-direction:column;gap:14px;display:flex}.login-page .field{flex-direction:column;gap:6px;display:flex}.login-page .field label{font-family:var(--font-pixel);color:var(--text-3);letter-spacing:.5px;font-size:5.5px}.login-page .field input{background:var(--bg-raised);border:1px solid var(--border-mid);width:100%;color:var(--text-1);font-size:14px;font-family:var(--font-body);outline:none;padding:10px 12px;line-height:1.5;transition:border-color .15s}.login-page .field input::placeholder{color:var(--text-3);opacity:.7}.login-page .field input:focus{border-color:var(--accent)}.login-page .error-msg{color:var(--incorrect);background:#a8202012;border:1px solid #a8202047;padding:8px 12px;font-size:12px;line-height:1.6;display:none}.login-page .error-msg.visible{display:block}.login-page .submit-btn{background:var(--accent);color:#fff;width:100%;font-family:var(--font-pixel);letter-spacing:.5px;border:2px solid var(--border-pixel);box-shadow:3px 3px 0 var(--bg-hover);cursor:pointer;margin-top:4px;padding:11px;font-size:6.5px;transition:opacity .15s}.login-page .submit-btn:hover:not(:disabled){opacity:.88}.login-page .submit-btn:disabled{opacity:.5;cursor:default}.login-page .card-footer{text-align:center;margin-top:20px}.login-page .back-link{color:var(--text-3);align-items:center;gap:6px;font-size:12px;text-decoration:none;transition:color .12s;display:inline-flex}.login-page .back-link:hover{color:var(--text-1)}.srs-stat{flex-direction:column;align-items:center;gap:4px;display:flex}.srs-stat-val{font-family:var(--font-pixel);color:var(--accent);letter-spacing:.5px;font-size:16px}.srs-stat-label{font-family:var(--font-pixel);color:var(--text-3);letter-spacing:.3px;text-transform:uppercase;font-size:6px}
