@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Fira+Mono:wght@400;500;700&display=swap";#spotlight-overlay{position:fixed;inset:0;background-color:#0009;backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:flex-start;justify-content:center;padding-top:15vh;opacity:0;pointer-events:none;transition:opacity .2s ease}#spotlight-overlay.active{opacity:1;pointer-events:auto}.spotlight-container{width:90%;max-width:640px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 20px 60px #0006;overflow:hidden;transform:translateY(-20px) scale(.95);transition:all .2s ease}#spotlight-overlay.active .spotlight-container{transform:translateY(0) scale(1)}.spotlight-search{display:flex;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);gap:1rem}.spotlight-search-icon{color:var(--text-tertiary);flex-shrink:0}.spotlight-input{flex:1;background:none;border:none;outline:none;font-size:1.125rem;color:var(--text-primary);font-weight:500}.spotlight-input::-moz-placeholder{color:var(--text-tertiary)}.spotlight-input::placeholder{color:var(--text-tertiary)}.spotlight-results{max-height:400px;overflow-y:auto;padding:.5rem}.spotlight-results::-webkit-scrollbar{width:6px}.spotlight-results::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.spotlight-result-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:8px;cursor:pointer;transition:all .15s ease;margin-bottom:.25rem}.spotlight-result-item:hover,.spotlight-result-item.selected{background-color:var(--accent-light)}.spotlight-result-item.selected{border-left:3px solid var(--accent-primary);padding-left:calc(1rem - 3px)}.spotlight-result-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;background-color:var(--accent-light);color:var(--accent-primary);flex-shrink:0}.spotlight-result-content{flex:1;min-width:0}.spotlight-result-title{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:.125rem;display:flex;align-items:center;gap:.5rem}.spotlight-result-code{font-family:Courier New,monospace;font-weight:700;color:var(--accent-primary)}.spotlight-result-meta{font-size:.75rem;color:var(--text-secondary);display:flex;align-items:center;gap:.375rem}.spotlight-result-separator{color:var(--text-tertiary)}.spotlight-highlight{background-color:var(--accent-light);color:var(--accent-primary);font-weight:600;padding:0 2px;border-radius:2px}.spotlight-empty{padding:3rem 2rem;text-align:center;color:var(--text-secondary)}.spotlight-empty-icon{width:64px;height:64px;margin:0 auto 1rem;color:var(--text-tertiary)}.spotlight-empty-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.spotlight-empty-text{font-size:.875rem}.spotlight-footer{padding:.75rem 1.5rem;border-top:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;font-size:.75rem;color:var(--text-tertiary)}.spotlight-footer-hint{display:flex;align-items:center;gap:1rem}.spotlight-kbd{display:inline-block;padding:.125rem .375rem;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;font-family:Courier New,monospace;font-size:.6875rem;font-weight:600;color:var(--text-secondary)}.spotlight-loading{padding:2rem;text-align:center}.spotlight-spinner{width:24px;height:24px;border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}@media(max-width:640px){#spotlight-overlay{padding-top:10vh}.spotlight-container{width:95%;max-width:none}.spotlight-results{max-height:300px}.spotlight-footer-hint{display:none}}@keyframes spotlightFadeIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes spotlightFadeOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-20px) scale(.95)}}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 0 0 0 var(--accent-primary)}50%{transform:scale(1.02);box-shadow:0 0 0 10px #ff6b2b00}}[data-topic-code]{scroll-margin-top:100px}[data-topic-code].highlight{animation:pulse .5s ease}#in-app-notification-container{position:fixed;top:50px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:12px;max-width:420px;min-width:380px}.in-app-notification{border-radius:16px;box-shadow:0 12px 35px #0000004d;display:flex;flex-direction:column;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.notification-bounceIn{animation:bounceIn .5s cubic-bezier(.34,1.56,.64,1)}.notification-shakeIn{animation:shakeIn .5s cubic-bezier(.34,1.56,.64,1)}.notification-pulseIn{animation:pulseIn .5s cubic-bezier(.34,1.56,.64,1)}.notification-slideIn{animation:slideIn .5s cubic-bezier(.34,1.56,.64,1)}.notification-sparkleIn{animation:sparkleIn .5s cubic-bezier(.34,1.56,.64,1)}.notification-exit{animation:slideOut .3s ease-in forwards}@keyframes bounceIn{0%{transform:translate(400px) scale(.8);opacity:0}50%{transform:translate(-10px) scale(1.05)}to{transform:translate(0) scale(1);opacity:1}}@keyframes shakeIn{0%{transform:translate(400px) rotate(0);opacity:0}25%{transform:translate(10px) rotate(-5deg)}50%{transform:translate(-10px) rotate(5deg)}75%{transform:translate(5px) rotate(-3deg)}to{transform:translate(0) rotate(0);opacity:1}}@keyframes pulseIn{0%{transform:translate(400px) scale(.8);opacity:0}50%{transform:translate(0) scale(1.1)}to{transform:translate(0) scale(1);opacity:1}}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes sparkleIn{0%{transform:translate(400px) rotate(-10deg) scale(.5);opacity:0}50%{transform:translate(10px) rotate(5deg) scale(1.1)}to{transform:translate(0) rotate(0) scale(1);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(450px);opacity:0}}.icon-bounce svg{animation:iconBounce .6s ease-in-out infinite}@keyframes iconBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.icon-shake svg{animation:iconShake .5s ease-in-out infinite}@keyframes iconShake{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}.icon-pulse svg{animation:iconPulse 1.5s ease-in-out infinite}@keyframes iconPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}.icon-smooth svg{animation:iconSmooth 2s ease-in-out infinite}@keyframes iconSmooth{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.icon-sparkle svg{animation:iconSparkle 1s ease-in-out infinite}@keyframes iconSparkle{0%,to{transform:rotate(0) scale(1);filter:brightness(1)}25%{transform:rotate(-15deg) scale(1.15);filter:brightness(1.3)}75%{transform:rotate(15deg) scale(1.15);filter:brightness(1.3)}}@media(max-width:640px){#in-app-notification-container{right:10px;left:10px;max-width:none;min-width:auto}}*,:before,:after{--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: rgb(59 130 246 / .5);--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: }::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: rgb(59 130 246 / .5);--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-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings: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:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-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{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,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{display:block;vertical-align:middle}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}}.invisible{visibility:hidden!important}.static{position:static!important}.fixed{position:fixed!important}.absolute{position:absolute!important}.relative{position:relative!important}.sticky{position:sticky!important}.mb-2{margin-bottom:.5rem!important}.mb-4{margin-bottom:1rem!important}.mb-6{margin-bottom:1.5rem!important}.mt-4{margin-top:1rem!important}.\!block,.block{display:block!important}.inline{display:inline!important}.flex{display:flex!important}.table{display:table!important}.grid{display:grid!important}.contents{display:contents!important}.h-10{height:2.5rem!important}.h-12{height:3rem!important}.h-16{height:4rem!important}.h-4{height:1rem!important}.h-5{height:1.25rem!important}.h-6{height:1.5rem!important}.h-full{height:100%!important}.w-10{width:2.5rem!important}.w-12{width:3rem!important}.w-16{width:4rem!important}.w-4{width:1rem!important}.w-5{width:1.25rem!important}.w-6{width:1.5rem!important}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))!important}.flex-col{flex-direction:column!important}.items-center{align-items:center!important}.justify-center{justify-content:center!important}.justify-between{justify-content:space-between!important}.overflow-hidden{overflow:hidden!important}.rounded-2xl{border-radius:1rem!important}.rounded-full{border-radius:9999px!important}.border{border-width:1px!important}.border-b{border-bottom-width:1px!important}.border-dashed{border-style:dashed!important}.bg-blue-500{--tw-bg-opacity: 1 !important;background-color:rgb(59 130 246 / var(--tw-bg-opacity, 1))!important}.bg-emerald-500{--tw-bg-opacity: 1 !important;background-color:rgb(16 185 129 / var(--tw-bg-opacity, 1))!important}.bg-green-600{--tw-bg-opacity: 1 !important;background-color:rgb(22 163 74 / var(--tw-bg-opacity, 1))!important}.bg-indigo-500{--tw-bg-opacity: 1 !important;background-color:rgb(99 102 241 / var(--tw-bg-opacity, 1))!important}.bg-indigo-600{--tw-bg-opacity: 1 !important;background-color:rgb(79 70 229 / var(--tw-bg-opacity, 1))!important}.bg-orange-500{--tw-bg-opacity: 1 !important;background-color:rgb(249 115 22 / var(--tw-bg-opacity, 1))!important}.bg-pink-500{--tw-bg-opacity: 1 !important;background-color:rgb(236 72 153 / var(--tw-bg-opacity, 1))!important}.bg-purple-500{--tw-bg-opacity: 1 !important;background-color:rgb(168 85 247 / var(--tw-bg-opacity, 1))!important}.bg-rose-500{--tw-bg-opacity: 1 !important;background-color:rgb(244 63 94 / var(--tw-bg-opacity, 1))!important}.bg-slate-600{--tw-bg-opacity: 1 !important;background-color:rgb(71 85 105 / var(--tw-bg-opacity, 1))!important}.bg-teal-500{--tw-bg-opacity: 1 !important;background-color:rgb(20 184 166 / var(--tw-bg-opacity, 1))!important}.bg-yellow-500{--tw-bg-opacity: 1 !important;background-color:rgb(234 179 8 / var(--tw-bg-opacity, 1))!important}.p-4{padding:1rem!important}.py-20{padding-top:5rem!important;padding-bottom:5rem!important}.pb-4{padding-bottom:1rem!important}.text-center{text-align:center!important}.text-2xl{font-size:1.5rem!important;line-height:2rem!important}.text-lg{font-size:1.125rem!important;line-height:1.75rem!important}.text-sm{font-size:.875rem!important;line-height:1.25rem!important}.font-bold{font-weight:700!important}.font-semibold{font-weight:600!important}.uppercase{text-transform:uppercase!important}.tracking-widest{letter-spacing:.1em!important}.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)!important}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter!important;transition-timing-function:cubic-bezier(.4,0,.2,1)!important;transition-duration:.15s!important}@media(min-width:768px){.md\:mb-8{margin-bottom:2rem!important}.md\:p-8{padding:2rem!important}.md\:text-3xl{font-size:1.875rem!important;line-height:2.25rem!important}.md\:text-base{font-size:1rem!important;line-height:1.5rem!important}}.ds-card{position:relative;overflow:hidden;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--r);box-shadow:var(--shadow-sm);transition:border-color .16s ease,transform .16s ease}.ds-card:after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--accent-primary);transition:width .22s ease}.ds-card:hover{transform:translateY(-2px)}.ds-card:hover:after{width:100%}.ds-card-head{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--border-color)}.ds-card-body{padding:var(--space-4) var(--space-5)}.ds-card-foot{display:flex;gap:var(--space-4);padding:var(--space-3) var(--space-5);border-top:1px solid var(--border-color)}.ds-info{border-left:3px solid var(--accent-primary);background:rgba(var(--accent-primary-rgb),.07);border-radius:0 var(--r-sm) var(--r-sm) 0;padding:var(--space-3) var(--space-4)}.ds-info-title{font-family:Fira Mono,monospace;font-size:.7rem;color:var(--accent-secondary);text-transform:lowercase;margin-bottom:5px}.ds-tag{font-family:Fira Mono,monospace;font-size:.72rem;color:var(--accent-secondary);background:var(--accent-light);border:1px solid var(--accent-primary);border-radius:var(--r-pill);padding:2px 9px}.ds-tag-muted{font-family:Fira Mono,monospace;font-size:.72rem;color:var(--text-tertiary);border:1px solid var(--border-hover);border-radius:var(--r-pill);padding:2px 9px;background:transparent}.ds-prog{height:5px;border-radius:var(--r-pill);background:var(--bg-tertiary);overflow:hidden}.ds-prog-fill{height:100%;background:var(--accent-primary);border-radius:var(--r-pill);transition:width .4s ease}.ds-check{width:22px;height:22px;border-radius:6px;border:2px solid var(--border-hover);display:grid;place-items:center;flex:0 0 auto;color:transparent;font-size:.8rem;cursor:pointer;transition:border-color .15s,background-color .15s}.ds-check:hover{border-color:var(--accent-primary)}.ds-check.done{background:var(--success);border-color:var(--success);color:#fff}.ds-check--sm{width:18px;height:18px;border-radius:5px;font-size:.62rem}.is-active{border-color:var(--accent-primary);background:var(--accent-light)}.is-done,.is-correct{border-color:var(--success);background:var(--success-bg)}.is-wrong{border-color:var(--error);background:var(--error-bg)}.light,:root{color-scheme:light;--sidebar-bg: #F7F7F5;--main-bg: #FFFFFF;--card-bg: #FFFFFF;--sidebar-text: #1B1915;--heading-text: #1B1915;--body-text: #56524A;--muted-text: #8E8A7F;--card-text: #1B1915;--border-color: #ECEAE4;--border-hover: #DCD9D0;--accent-primary: #CA8A04;--accent-primary-rgb: 202, 138, 4;--accent-hover: #A77407;--accent-secondary: #8A5A00;--accent-light: #FBF3DD;--success: #10B981;--success-light: #D1FAE5;--success-bg: #ECFDF5;--warning: #F59E0B;--error: #EF4444;--shadow-sm: 0 1px 2px 0 rgba(20, 16, 8, .05);--shadow-md: 0 4px 6px -1px rgba(20, 16, 8, .1);--shadow-lg: 0 12px 32px -14px rgba(20, 16, 8, .18);--bg-primary: var(--main-bg);--bg-secondary: #F7F7F5;--bg-tertiary: #F2F1EC;--text-primary: var(--heading-text);--text-secondary: var(--body-text);--text-tertiary: var(--muted-text);--r: 12px;--r-sm: 8px;--r-pill: 999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--error-bg: #FEF2F2;--warning-bg: #FFFBEB}.dark{color-scheme:dark;--sidebar-bg: #161618;--main-bg: #0D0D0E;--card-bg: #161618;--sidebar-text: #F4F2ED;--heading-text: #F4F2ED;--body-text: #BBB7AD;--muted-text: #8E8A80;--card-text: #F4F2ED;--border-color: #262629;--border-hover: #36363B;--accent-primary: #ECB22E;--accent-primary-rgb: 236, 178, 46;--accent-hover: #D89E1F;--accent-secondary: #F6CE6A;--accent-light: #2A2208;--success: #10B981;--success-light: #064E3B;--success-bg: #022C22;--warning: #F59E0B;--error: #EF4444;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 16px 36px -16px rgba(0, 0, 0, .7);--bg-primary: var(--main-bg);--bg-secondary: #1E1E20;--bg-tertiary: #232327;--text-primary: var(--heading-text);--text-secondary: var(--body-text);--text-tertiary: var(--muted-text);--error-bg: #2A1414;--warning-bg: #2A2008}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-user-select:none;-moz-user-select:none;user-select:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;color:var(--text-primary)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}a{color:var(--accent-primary);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-hover)}button{font-family:inherit;cursor:pointer;border:none;background:none;transition:all .2s}button:disabled{opacity:.5;cursor:not-allowed}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.hidden{display:none!important}.visible{display:block!important}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fade-in{animation:fadeIn .3s ease-out}.slide-in{animation:slideIn .3s ease-out}.spin{animation:spin 1s linear infinite}#app{display:flex;height:calc(100vh - 32px);overflow:hidden}#main-content{flex:1;overflow-y:auto;background-color:var(--bg-primary);width:100%}*:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}::-moz-selection{background-color:var(--accent-primary);color:#fff}::selection{background-color:var(--accent-primary);color:#fff}#app{flex-direction:column}#topnav{flex-shrink:0;position:relative;height:60px;display:flex;align-items:center;gap:28px;padding:0 24px;background-color:var(--main-bg);border-bottom:1px solid var(--border-color)}#topnav .brand{font-family:Fira Mono,ui-monospace,monospace;font-weight:700;font-size:1.05rem;color:var(--heading-text);letter-spacing:-.02em;white-space:nowrap;cursor:pointer;background:none;border:none}#topnav .brand-dot{color:var(--accent-primary)}#topnav .nav-links{display:flex;gap:2px;position:absolute;left:50%;transform:translate(-50%)}html[data-nav=pill] #topnav{border-bottom-color:transparent}html[data-nav=pill] #topnav .nav-links{background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:999px;padding:5px;box-shadow:var(--shadow-lg)}#topnav .nav-links .nav-button{width:auto;height:auto;padding:8px 14px;border-radius:999px;font-size:.92rem;font-weight:500;text-transform:lowercase;color:var(--text-secondary)}#topnav .nav-links .nav-button:hover{background-color:var(--bg-secondary);color:var(--text-primary)}#topnav .nav-links .nav-button.active{background-color:var(--accent-light);color:var(--accent-secondary)}#topnav .nav-button.active:before{display:none}#topnav .nav-tools{margin-left:auto;display:flex;align-items:center;gap:4px}#topnav .nav-tool{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:999px;color:var(--text-tertiary)}#topnav .nav-tool:hover{background-color:var(--bg-secondary);color:var(--text-primary)}#topnav .nav-tool.active{background-color:var(--accent-light);color:var(--accent-secondary)}#topnav #nav-profile{border:none;cursor:pointer;flex-shrink:0}#topnav .nav-profile-avatar{width:40px;height:40px;border-radius:999px;background:var(--accent-primary);color:var(--accent-contrast, #1B1407);font-family:Fira Mono,monospace;font-weight:700;font-size:.92rem;display:flex;align-items:center;justify-content:center;transition:filter .15s,transform .15s}#topnav .nav-profile-avatar:hover{filter:brightness(1.06);transform:translateY(-1px)}#topnav .nav-signin{height:38px;padding:0 18px;border-radius:999px;background:var(--accent-primary);color:var(--accent-contrast, #1B1407);font-family:Fira Mono,monospace;font-weight:600;font-size:.85rem;text-transform:lowercase;display:inline-flex;align-items:center;transition:filter .15s}#topnav .nav-signin:hover{filter:brightness(1.06)}#theme-toggle .th-moon{display:none}#theme-toggle .th-sun,html.dark #theme-toggle .th-moon{display:block}html.dark #theme-toggle .th-sun{display:none}.theme-toggle-group{display:inline-flex;gap:4px;padding:4px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px}.theme-opt{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:8px;font-size:.875rem;font-weight:500;color:var(--text-secondary);background:transparent;cursor:pointer;transition:color .18s,background-color .18s}.theme-opt:hover{color:var(--text-primary)}.theme-opt.active{background:var(--card-bg);color:var(--accent-secondary);box-shadow:var(--shadow-sm)}#topnav .nav-hamburger{display:none}@media(max-width:820px){#topnav .nav-hamburger{display:flex}html[data-nav] #topnav .nav-links{position:absolute;top:100%;left:0;right:0;transform:none;flex-direction:column;align-items:stretch;gap:4px;padding:10px 12px;background:var(--card-bg);border:1px solid var(--border-color);border-top:none;border-radius:0 0 14px 14px;box-shadow:var(--shadow-lg);display:none}html[data-nav] #topnav.menu-open .nav-links{display:flex}#topnav .nav-links .nav-button{width:100%;justify-content:flex-start}}.subjects-hint{color:var(--muted-text);font-weight:400;font-size:.85em}.subject-choices{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.subject-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:999px;border:1px solid var(--border-color);background:var(--card-bg);color:var(--body-text);font-size:.85rem;cursor:pointer;transition:border-color .15s,background-color .15s,color .15s}.subject-chip:hover{border-color:var(--accent-primary);color:var(--text-primary)}.subject-chip.selected{border-color:var(--accent-primary);background:var(--accent-light);color:var(--accent-secondary)}.subject-chip-code{font-family:Fira Mono,monospace;font-size:.72em;opacity:.7}.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.board-switcher{position:relative;display:inline-block}.board-switcher-trigger{display:inline-flex;align-items:center;gap:8px;height:38px;padding:0 14px;cursor:pointer;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:999px;color:var(--text-primary);font-weight:600;font-size:.9rem}.board-switcher-trigger:hover{border-color:var(--accent-primary)}.board-switcher .bs-chev{color:var(--text-tertiary);font-size:.7rem;transition:transform .2s}.board-switcher.open .bs-chev{transform:rotate(180deg)}.board-switcher-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:240px;z-index:40;background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:6px;box-shadow:var(--shadow-lg);opacity:0;transform:translateY(-8px);pointer-events:none;transition:opacity .18s,transform .18s}.board-switcher.open .board-switcher-menu{opacity:1;transform:none;pointer-events:auto}.board-opt{width:100%;display:flex;align-items:center;gap:8px;padding:9px 11px;border:none;border-radius:8px;background:transparent;color:var(--text-primary);font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color .15s}.board-opt:hover{background:var(--bg-secondary)}.board-opt.sel{background:var(--accent-light)}.board-opt .bo-name{flex:1;text-align:left}.board-opt .bo-default{font-family:Fira Mono,monospace;font-size:.6rem;letter-spacing:.04em;text-transform:lowercase;color:var(--accent-secondary);background:var(--accent-light);border:1px solid var(--accent-primary);border-radius:999px;padding:2px 7px}.board-opt .bo-org{font-family:Fira Mono,monospace;font-size:.66rem;color:var(--muted-text);border:1px solid var(--border-color);border-radius:999px;padding:2px 7px}.subject-list{margin-top:8px;border-top:1px solid var(--border-color)}.subject-row{display:flex;align-items:center;gap:18px;padding:19px 12px;border-bottom:1px solid var(--border-color);cursor:pointer;position:relative}.subject-row:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent-primary);transform:scaleY(0);transition:transform .18s}.subject-row:hover{background:var(--bg-secondary)}.subject-row:hover:before{transform:scaleY(1)}.subject-row .sr-name{flex:0 0 200px;font-size:1.06rem;font-weight:600;color:var(--text-primary)}.subject-row .sr-code{flex:0 0 64px;font-family:Fira Mono,monospace;font-size:.78rem;color:var(--muted-text)}.subject-row .sr-meta{flex:1;min-width:0;color:var(--muted-text);font-size:.9rem}.subject-row .sr-status{flex:0 0 auto;min-width:52px;text-align:right;font-family:Fira Mono,monospace;font-size:.72rem;color:var(--accent-secondary)}.subject-row .sr-go{flex:0 0 auto;color:var(--accent-secondary);font-size:1.1rem;transition:transform .18s}.subject-row:hover .sr-go{transform:translate(4px)}.subject-row.muted{cursor:default;opacity:.6}.subject-row.muted:hover{background:transparent}.subject-row.muted:hover:before{transform:scaleY(0)}.subject-row.muted .sr-go{color:var(--muted-text)}.subject-row .sr-badge{font-family:Fira Mono,monospace;font-size:.64rem;color:var(--muted-text);border:1px solid var(--border-hover);border-radius:999px;padding:2px 8px;text-transform:lowercase}@media(max-width:600px){.subject-row{gap:12px;padding:16px 10px}.subject-row .sr-name{flex:1 1 auto}.subject-row .sr-code{flex:0 0 auto}}.subject-add{margin-top:18px}.subject-add-btn{display:inline-flex;align-items:center;gap:6px;font-family:Fira Mono,monospace;font-size:.8rem;color:var(--accent-secondary);background:transparent;border:1px dashed var(--border-hover);border-radius:999px;padding:7px 14px;cursor:pointer;transition:border-color .15s,background-color .15s}.subject-add-btn:hover{border-color:var(--accent-primary);background:var(--accent-light)}.subject-unselected{margin-top:14px;border-top:1px solid var(--border-color)}.su-toggle{display:flex;align-items:center;gap:8px;width:100%;padding:12px 2px;background:transparent;border:none;cursor:pointer;font-family:Fira Mono,monospace;font-size:.78rem;color:var(--muted-text);text-transform:lowercase}.su-toggle:hover{color:var(--text-primary)}.su-count{font-size:.66rem;color:var(--muted-text);border:1px solid var(--border-color);border-radius:999px;padding:1px 7px}.su-chev{margin-left:auto;font-size:.66rem;transition:transform .2s}.subject-unselected.open .su-chev{transform:rotate(180deg)}.su-body{display:none;padding-bottom:8px}.subject-unselected.open .su-body{display:block}.su-search{width:100%;box-sizing:border-box;margin:4px 0 8px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:9px 12px;font-size:.88rem;color:var(--text-primary)}.su-search:focus{outline:none;border-color:var(--accent-primary)}.su-row{cursor:pointer;opacity:.78}.su-row:hover{opacity:1}.su-row .su-add{flex:0 0 auto;font-family:Fira Mono,monospace;font-size:.7rem;color:var(--accent-secondary)}.su-row:hover .su-add{color:var(--accent-primary)}.as-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#14100873;padding:20px;backdrop-filter:blur(2px)}.as-modal{width:100%;max-width:440px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;box-shadow:var(--shadow-lg);padding:24px}.as-title{font-size:1.2rem;font-weight:700;color:var(--text-primary);margin:0 0 4px}.as-sub{font-size:.9rem;color:var(--text-secondary);margin:0 0 18px}.as-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:22px}.as-chip{display:inline-flex;align-items:center;gap:6px;cursor:pointer;background:var(--bg-secondary);border:1.5px solid var(--border-color);border-radius:999px;padding:8px 14px;font-size:.9rem;font-weight:500;color:var(--text-primary);transition:border-color .15s,background-color .15s}.as-chip:hover{border-color:var(--accent-primary)}.as-chip.selected{background:var(--accent-light);border-color:var(--accent-primary);color:var(--accent-secondary)}.as-chip-code{font-family:Fira Mono,monospace;font-size:.7rem;color:var(--muted-text)}.as-chip.selected .as-chip-code{color:var(--accent-secondary)}.as-actions{display:flex;justify-content:flex-end;gap:10px}.as-btn{cursor:pointer;border-radius:999px;padding:9px 18px;font-size:.9rem;font-weight:600;border:1px solid var(--border-hover);background:transparent;color:var(--text-primary);transition:all .15s}.as-cancel:hover{background:var(--bg-secondary)}.as-save{background:var(--accent-primary);border-color:transparent;color:var(--accent-contrast, #1B1407)}.as-save:hover{background:var(--accent-hover)}.pp-board-switch{padding:12px 14px;border-bottom:1px solid var(--border-color)}#custom-titlebar{-webkit-app-region:drag;height:32px;display:flex;align-items:center;position:fixed;top:0;left:0;right:0;z-index:100;background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);transition:background-color .2s}#custom-titlebar.mac-style{padding-left:12px}#custom-titlebar.windows-style{padding-left:12px;justify-content:flex-end;flex-direction:row-reverse}.window-controls{-webkit-app-region:no-drag;display:flex;gap:8px}.traffic-light{width:12px;height:12px;border-radius:50%;cursor:pointer;transition:opacity .2s}.traffic-light:hover{opacity:.8}.traffic-light.close{background-color:#ff5f56;border:1px solid #e0443e}.traffic-light.minimize{background-color:#ffbd2e;border:1px solid #dea123}.traffic-light.maximize{background-color:#27c93f;border:1px solid #1aab29}.window-btn{width:46px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s;border:none;background:none;color:var(--text-secondary);font-size:12px;font-weight:600}.window-btn:hover{background-color:var(--bg-tertiary)}.window-btn.close:hover{background-color:#e81123;color:#fff}.window-btn.minimize:hover,.window-btn.maximize:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.nav-button{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:12px;color:var(--text-secondary);transition:all .2s;position:relative}.nav-button:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.nav-button.active{background-color:var(--accent-light);color:var(--accent-primary)}.nav-button.active:before{content:"";position:absolute;left:-12px;width:3px;height:24px;background-color:var(--accent-primary);border-radius:0 3px 3px 0}.card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;transition:all .2s}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}.card-interactive{cursor:pointer}.card-interactive:hover{transform:translateY(-2px)}.progress-bar{width:100%;height:8px;background-color:var(--bg-tertiary);border-radius:4px;overflow:hidden;margin:.5rem 0}.progress-fill{height:100%;background-color:var(--accent-primary);border-radius:4px;transition:width .5s ease-out}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;background-color:var(--accent-light);color:var(--accent-primary)}.badge-success{background-color:var(--success-light);color:var(--success)}.modal-overlay{position:fixed;inset:0;background-color:#00000080;backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s}.modal-content{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;padding:2rem;max-width:500px;width:90%;box-shadow:var(--shadow-lg);animation:slideIn .3s}.modal-header{margin-bottom:1.5rem}.modal-title{font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.btn{padding:.75rem 1.5rem;border-radius:8px;font-weight:500;font-size:.875rem;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem}.btn-primary{background-color:var(--accent-primary);color:#fff}.btn-primary:hover{background-color:var(--accent-hover)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover{background-color:var(--border-hover)}.btn-ghost{background-color:transparent;color:var(--text-secondary)}.btn-ghost:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}input[type=text],input[type=password],input[type=email],input[type=date],input[type=time],textarea,select{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;font-family:inherit;transition:all .2s;cursor:text}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-light)}input:disabled,textarea:disabled,select:disabled{opacity:.5;cursor:not-allowed;background-color:var(--bg-tertiary)}textarea{resize:vertical;min-height:100px}.spinner{width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.checkbox{width:20px;height:20px;border:2px solid var(--border-color);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.checkbox.checked{background-color:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.planner-banner{background:linear-gradient(135deg,var(--accent-light) 0%,var(--bg-secondary) 100%);border:1px solid var(--border-color);border-radius:12px;padding:1rem 1.5rem;margin:0 auto 1.5rem;animation:slideDown .3s ease-out;box-sizing:border-box;max-width:900px}.planner-banner-content{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.icon-button{padding:.5rem;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:6px;transition:all .2s;display:inline-flex;align-items:center;justify-content:center}.icon-button:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}#questionnaire-overlay .modal-content{animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.planner-tab{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:8px;border:1px solid transparent;background-color:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all .2s;white-space:nowrap;font-size:.875rem}.planner-tab:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.planner-tab.active{background-color:var(--accent-light);color:var(--accent-primary);border-color:var(--accent-primary);font-weight:500}.planner-tab i{width:16px;height:16px;flex-shrink:0}.planner-day-card{padding:1rem;border-radius:12px;border:2px solid var(--border-color);background-color:var(--bg-secondary);cursor:pointer;transition:all .2s;text-align:center;min-height:120px;display:flex;flex-direction:column;justify-content:center}.planner-day-card:hover{border-color:var(--accent-primary);background-color:var(--bg-tertiary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.planner-day-card.selected{border-color:var(--accent-primary);background-color:var(--accent-light);box-shadow:0 0 0 3px var(--accent-light)}.planner-day-card.today{border-color:var(--accent-primary);border-width:3px}.planner-day-card.today:before{content:"";display:block;width:6px;height:6px;border-radius:50%;background-color:var(--accent-primary);margin:0 auto .5rem}.success-light{background-color:#dcfce7}@media(max-width:768px){.planner-banner-content{flex-direction:column;align-items:stretch}.planner-banner-content>div:last-child{justify-content:stretch}.planner-banner-content button{flex:1}}#app{height:100vh}.route-stub{padding:var(--space-4, 24px);color:var(--muted, #8e8a7f)}.route-stub h1{color:var(--ink, #1b1915);font-weight:700;letter-spacing:-.02em;margin-bottom:8px}.nav-profile-menu .np-item{width:100%;text-align:left;background:transparent;border:none;padding:8px 10px;cursor:pointer;color:var(--text-secondary);border-radius:8px;font-size:.85rem}.nav-profile-menu .np-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.onboarding-step.active .onboarding-caption,.onboarding-step.active .onboarding-buttons,.onboarding-step.active .onboarding-guest-link,.onboarding-step.active .onboarding-form,.onboarding-step.active .onboarding-stats,.onboarding-step.active .onboarding-error{opacity:1;transform:none}
