@import url("https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=JetBrains+Mono:wght@400;500&family=Instrument+Serif:ital@0;1&display=swap");*,:after,:before{--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:rgba(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:rgba(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: }

/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-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{line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){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,pre,samp{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,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.mb-3{margin-bottom:.75rem}.mb-6{margin-bottom:1.5rem}.ml-1{margin-left:.25rem}.mr-2{margin-right:.5rem}.mt-1{margin-top:.25rem}.mt-5{margin-top:1.25rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.min-w-0{min-width:0}.flex-1{flex:1 1 0%}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes spin{to{transform:rotate(1turn)}}.animate-spin{animation:spin 1s linear infinite}.resize{resize:both}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.border{border-width:1px}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.font-serif{font-family:ui-serif,Georgia,Cambria,Times New Roman,Times,serif}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.leading-relaxed{line-height:1.625}.text-\[var\(--accent\)\]{color:var(--accent)}.text-\[var\(--text-secondary\)\]{color:var(--text-secondary)}.text-\[var\(--text-tertiary\)\]{color:var(--text-tertiary)}.opacity-50{opacity:.5}.opacity-80{opacity:.8}.outline{outline-style:solid}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.blur{--tw-blur:blur(8px)}.blur,.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,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root{--bg-primary:#f7f6f3;--bg-secondary:#edeae5;--bg-tertiary:#e2dfd9;--bg-card:#fff;--bg-elevated:#fff;--bg-overlay:rgba(0,0,0,.4);--text-primary:#1a1a1c;--text-secondary:#3a3a3c;--text-tertiary:#636366;--text-inverse:#fff;--accent:#2952a3;--accent-hover:#1e3f82;--accent-soft:rgba(41,82,163,.08);--accent-glow:rgba(41,82,163,.14);--accent-warm:#b5842a;--accent-warm-hover:#9a7023;--accent-warm-soft:rgba(181,132,42,.08);--success:#2a7d4f;--success-soft:rgba(42,125,79,.08);--error:#c53030;--error-soft:rgba(197,48,48,.08);--warning:#b7791f;--warning-soft:rgba(183,121,31,.08);--border:rgba(0,0,0,.1);--border-strong:rgba(0,0,0,.18);--shadow-sm:0 1px 3px rgba(0,0,0,.05),0 1px 2px rgba(0,0,0,.04);--shadow-md:0 4px 12px rgba(0,0,0,.07),0 1px 3px rgba(0,0,0,.05);--shadow-lg:0 8px 24px rgba(0,0,0,.09),0 2px 6px rgba(0,0,0,.05);--shadow-xl:0 16px 48px rgba(0,0,0,.11);--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--sidebar-width:240px;--sidebar-collapsed:64px}.dark{--bg-primary:#0b0d13;--bg-secondary:#131620;--bg-tertiary:#1a1e2c;--bg-card:#151924;--bg-elevated:#1e2336;--bg-overlay:rgba(0,0,0,.7);--text-primary:#eae8e4;--text-secondary:#a09ca6;--text-tertiary:#6b6773;--text-inverse:#0b0d13;--accent:#7c9fd6;--accent-hover:#96b4e2;--accent-soft:rgba(124,159,214,.12);--accent-glow:rgba(124,159,214,.2);--accent-warm:#d4a853;--accent-warm-hover:#e0b96a;--accent-warm-soft:rgba(212,168,83,.12);--success:#48bb78;--success-soft:rgba(72,187,120,.12);--error:#fc8181;--error-soft:hsla(0,95%,75%,.12);--warning:#f6e05e;--warning-soft:rgba(246,224,94,.12);--border:hsla(0,0%,100%,.07);--border-strong:hsla(0,0%,100%,.14);--shadow-sm:0 1px 2px rgba(0,0,0,.3);--shadow-md:0 2px 8px rgba(0,0,0,.4);--shadow-lg:0 8px 30px rgba(0,0,0,.5);--shadow-xl:0 20px 60px rgba(0,0,0,.6)}.study-panel{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--border-strong);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg);background:var(--bg-card)}.study-panel .practice-left{position:static;padding:0;border-right:1px solid var(--border)}.study-panel .practice-left .question-card,.study-panel .practice-right .chat-panel{border:none;border-radius:0;box-shadow:none}.study-panel .practice-right .chat-panel{min-height:450px}@media (max-width:1024px){.study-panel{grid-template-columns:1fr}.study-panel .practice-left{border-right:none;border-bottom:1px solid var(--border)}}*{box-sizing:border-box}html{font-family:DM Sans,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{background:var(--bg-primary);color:var(--text-primary);margin:0;min-height:100vh}::selection{background:var(--accent-soft);color:var(--accent)}.font-serif{font-family:"Instrument Serif",serif}.font-mono{font-family:JetBrains Mono,monospace}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);padding:32px;max-width:100%;transition:margin-left .25s ease}@media (max-width:768px){.main-content{margin-left:0;padding:16px 16px 80px}}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:40;transition:width .25s ease}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-logo{padding:20px 16px;justify-content:space-between;border-bottom:1px solid var(--border);min-height:64px}.logo-link,.sidebar-logo{display:flex;align-items:center}.logo-link{gap:10px;text-decoration:none;color:var(--text-primary)}.logo-mark{width:32px;height:32px;background:var(--accent);color:var(--text-inverse);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;flex-shrink:0}.dark .logo-mark{color:#0f1117}.logo-text{font-weight:600;font-size:15px;letter-spacing:-.02em}.sidebar-collapse-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.sidebar-collapse-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.sidebar-level{padding:12px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}.level-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);font-weight:500}.level-badge{font-family:"Instrument Serif",serif;font-size:18px;color:var(--accent)}.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:450;transition:all .15s}.nav-item:hover{background:var(--accent-soft);color:var(--text-primary)}.nav-item.active{background:var(--accent-soft);color:var(--accent);font-weight:550}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border);gap:12px}.sidebar-footer,.sidebar-user{display:flex;align-items:center}.sidebar-user{gap:10px;flex:1;min-width:0}.user-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.dark .user-avatar{color:#0f1117}.user-info{display:flex;flex-direction:column;min-width:0}.user-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-plan{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em}.theme-toggle{width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;flex-shrink:0}.theme-toggle:hover{background:var(--bg-secondary);color:var(--text-primary)}@media (max-width:768px){.sidebar{display:none}}.question-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-sm)}.question-card-no-bottom-radius .question-card{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom:none}.topic-badge{padding:4px 10px;background:var(--accent-soft);color:var(--accent);font-size:11px;letter-spacing:.02em}.difficulty-badge,.topic-badge{display:inline-block;border-radius:100px;font-weight:600}.difficulty-badge{padding:3px 8px;font-size:10px;text-transform:uppercase;letter-spacing:.06em}.difficulty-badge[data-difficulty=easy]{background:var(--success-soft);color:var(--success)}.difficulty-badge[data-difficulty=medium]{background:var(--warning-soft);color:var(--warning)}.difficulty-badge[data-difficulty=hard]{background:var(--error-soft);color:var(--error)}.bookmark-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.bookmark-btn:hover{background:var(--bg-secondary);color:var(--accent)}.question-text{font-size:16px;line-height:1.7;color:var(--text-primary);margin-bottom:24px}.option-btn{width:100%;display:flex;align-items:flex-start;gap:14px;padding:14px 16px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);text-align:left;cursor:pointer;font-size:14px;line-height:1.5;transition:all .15s}.option-btn.selected,.option-btn:hover:not(:disabled){border-color:var(--accent);background:var(--accent-soft)}.option-btn.selected{box-shadow:0 0 0 1px var(--accent)}.option-btn.correct{border-color:var(--success);background:var(--success-soft)}.option-btn.incorrect{border-color:var(--error);background:var(--error-soft)}.option-btn.revealed{opacity:.5}.option-btn:disabled{cursor:default}.option-label{width:26px;height:26px;border-radius:50%;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px;color:var(--text-secondary);flex-shrink:0;transition:all .15s}.option-btn.selected .option-label{background:var(--accent);color:var(--text-inverse)}.dark .option-btn.selected .option-label{color:#0f1117}.option-btn.correct .option-label{background:var(--success);color:#fff}.option-btn.incorrect .option-label{background:var(--error);color:#fff}.option-text{flex:1;padding-top:2px}.option-icon{flex-shrink:0;margin-top:3px}.option-icon.correct{color:var(--success)}.option-icon.incorrect{color:var(--error)}.result-banner{padding:14px 18px;border-radius:var(--radius-md);font-size:14px}.result-banner.correct{background:var(--success-soft);color:var(--success);border:1px solid rgba(42,125,79,.2)}.result-banner.incorrect{background:var(--error-soft);color:var(--error);border:1px solid rgba(197,48,48,.2)}.btn-primary{padding:12px 24px;border-radius:var(--radius-md);border:none;background:var(--accent);color:var(--text-inverse);font-size:14px;font-weight:550;cursor:pointer;transition:all .2s}.dark .btn-primary{color:#0f1117}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{padding:10px 20px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.btn-secondary:hover{background:var(--bg-secondary);border-color:var(--border-strong)}.chat-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}.question-summary{border-bottom:1px solid var(--border);flex-shrink:0}.question-summary-toggle{width:100%;padding:12px 18px;display:flex;align-items:center;justify-content:space-between;border:none;background:transparent;cursor:pointer;color:var(--text-secondary);font-size:13px;transition:background .15s}.question-summary-toggle:hover{background:var(--bg-secondary)}.summary-topic-badge{padding:2px 8px;border-radius:100px;background:var(--accent-soft);color:var(--accent);font-size:10px;font-weight:600;flex-shrink:0}.summary-result{font-size:11px;font-weight:600;flex-shrink:0}.summary-result.correct{color:var(--success)}.summary-result.incorrect{color:var(--error)}.question-summary-body{padding:0 18px 14px}.summary-option{display:flex;align-items:flex-start;padding:4px 8px;border-radius:var(--radius-sm);color:var(--text-secondary)}.summary-option.correct{background:var(--success-soft);color:var(--success)}.summary-option.incorrect{background:var(--error-soft);color:var(--error)}.chat-messages{flex:1;overflow-y:auto;padding:18px;gap:16px}.chat-empty,.chat-messages{display:flex;flex-direction:column}.chat-empty{text-align:center;padding:30px 20px;flex:1}.chat-empty,.chat-empty-icon{align-items:center;justify-content:center}.chat-empty-icon{width:44px;height:44px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:flex;margin-bottom:14px}.chat-empty-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.chat-empty-subtitle{font-size:13px;color:var(--text-tertiary);max-width:300px;line-height:1.5;margin-bottom:20px}.suggested-prompts{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.suggested-prompt-btn{padding:9px 18px;border-radius:100px;border:1px solid var(--accent);background:var(--accent-soft);color:var(--accent);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.suggested-prompt-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.chat-message{display:flex;gap:10px;align-items:flex-start}.chat-message.user{flex-direction:row-reverse}.chat-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.chat-bubble{max-width:85%;padding:12px 16px;border-radius:var(--radius-md);font-size:14px;line-height:1.65}.chat-message.assistant .chat-bubble{background:var(--bg-secondary);color:var(--text-primary);border-bottom-left-radius:4px}.chat-message.user .chat-bubble{background:var(--accent);color:var(--text-inverse);border-bottom-right-radius:4px}.dark .chat-message.user .chat-bubble{color:#0f1117}.chat-content strong{font-weight:600}.chat-content code{font-family:JetBrains Mono,monospace;font-size:12px;padding:2px 5px;border-radius:3px;background:var(--bg-tertiary)}.typing-indicator{display:flex;align-items:center;gap:8px;color:var(--text-tertiary);font-size:13px}.feedback-buttons{display:flex;gap:4px;margin-top:6px}.feedback-btn{width:24px;height:24px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.feedback-btn:hover{background:var(--bg-tertiary)}.feedback-btn.active-up{color:var(--success);background:var(--success-soft)}.feedback-btn.active-down{color:var(--error);background:var(--error-soft)}.chat-input-container{padding:14px 16px;border-top:1px solid var(--border);flex-shrink:0}.chat-input-wrapper{display:flex;align-items:flex-end;gap:10px;background:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius-lg);padding:6px 6px 6px 16px;transition:all .2s}.chat-input-wrapper:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.chat-input{flex:1;border:none;background:transparent;color:var(--text-primary);font-size:15px;font-family:DM Sans,sans-serif;resize:none;outline:none;min-height:44px;max-height:140px;padding:10px 0;line-height:1.5}.chat-input::placeholder{color:var(--text-tertiary)}.chat-send-btn{width:40px;height:40px;border-radius:var(--radius-md);border:none;background:var(--accent);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;flex-shrink:0}.chat-send-btn:hover:not(:disabled){transform:scale(1.05)}.dark .chat-send-btn{color:#0f1117}.chat-send-btn:hover:not(:disabled){background:var(--accent-hover)}.chat-send-btn:disabled{opacity:.3;cursor:not-allowed}.formula-toggle-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.formula-toggle-btn:hover{border-color:var(--accent);color:var(--accent)}.formula-overlay{position:fixed;inset:0;background:var(--bg-overlay);z-index:50}.formula-drawer{position:fixed;right:0;top:0;bottom:0;width:360px;max-width:90vw;background:var(--bg-card);border-left:1px solid var(--border);box-shadow:var(--shadow-xl);z-index:51;display:flex;flex-direction:column}.formula-drawer-header{padding:20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start}.formula-drawer-title{font-size:16px;font-weight:600;color:var(--text-primary)}.formula-drawer-subtitle{font-size:12px;color:var(--text-tertiary);margin-top:2px}.formula-close-btn{width:32px;height:32px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.formula-close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.formula-drawer-body{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:10px}.formula-card{padding:12px 14px;border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border)}.formula-name{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.formula-content{font-family:JetBrains Mono,monospace;font-size:13px;color:var(--text-primary);line-height:1.5}.study-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}@media (min-width:640px){.study-stats-grid{grid-template-columns:repeat(4,1fr)}}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow-sm)}.stat-card.full-width{grid-column:1/-1;flex-direction:column;align-items:flex-start}.stat-card-header{gap:8px;font-size:13px;font-weight:550;color:var(--text-primary);margin-bottom:12px}.stat-card-header,.stat-icon{display:flex;align-items:center}.stat-icon{width:38px;height:38px;border-radius:var(--radius-md);justify-content:center;flex-shrink:0}.stat-icon.orange{background:#fff3e0;color:#e65100}.dark .stat-icon.orange{background:rgba(230,81,0,.15)}.stat-icon.blue{background:#e3f2fd;color:#1565c0}.dark .stat-icon.blue{background:rgba(21,101,192,.15)}.stat-icon.green{background:#e8f5e9;color:#2e7d32}.dark .stat-icon.green{background:rgba(46,125,50,.15)}.stat-icon.purple{background:#f3e5f5;color:#7b1fa2}.dark .stat-icon.purple{background:rgba(123,31,162,.15)}.stat-value{font-size:22px;font-weight:700;color:var(--text-primary);line-height:1;letter-spacing:-.02em}.stat-label{font-size:12px;color:var(--text-tertiary);margin-top:3px}.topic-bars{width:100%;display:flex;flex-direction:column;gap:8px}.topic-bar-row{display:flex;align-items:center;gap:10px}.topic-bar-label{width:140px;font-size:12px;color:var(--text-secondary);flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topic-bar-track{flex:1;height:6px;border-radius:3px;background:var(--bg-tertiary);overflow:hidden}.topic-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}.topic-bar-fill[data-accuracy=good]{background:var(--success)}.topic-bar-fill[data-accuracy=medium]{background:var(--warning)}.topic-bar-fill[data-accuracy=weak]{background:var(--error)}.topic-bar-value{width:36px;font-size:12px;font-weight:600;color:var(--text-secondary);text-align:right;font-family:JetBrains Mono,monospace}.weak-areas{width:100%;display:flex;flex-direction:column;gap:8px}.weak-area-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-radius:var(--radius-sm);background:var(--error-soft)}.weak-area-topic{font-size:13px;color:var(--text-primary)}.weak-area-accuracy{font-size:13px;font-weight:600;color:var(--error)}.exam-timer,.weak-area-accuracy{font-family:JetBrains Mono,monospace}.exam-timer{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary)}.exam-timer.low{border-color:var(--warning);color:var(--warning)}.exam-timer.critical{border-color:var(--error);color:var(--error);animation:pulse-border 1s infinite}.exam-timer-display{font-size:15px;font-weight:600}.timer-warning{animation:pulse 1.5s infinite}@keyframes pulse-border{0%,to{border-color:var(--error)}50%{border-color:transparent}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.progress-bar-container{width:100%}.progress-bar-header{display:flex;justify-content:space-between;margin-bottom:6px}.progress-bar-label{font-size:12px;color:var(--text-secondary)}.progress-bar-count{font-size:12px;color:var(--text-tertiary);font-family:JetBrains Mono,monospace}.progress-bar-track{width:100%;height:4px;border-radius:2px;background:var(--bg-tertiary);overflow:hidden}.progress-bar-fill{height:100%;border-radius:2px;background:var(--accent);transition:width .4s ease}.page-header{margin-bottom:28px}.page-title{font-family:"Instrument Serif",serif;font-size:30px;font-weight:400;color:var(--text-primary);line-height:1.2;letter-spacing:-.01em}.page-subtitle{font-size:14px;color:var(--text-tertiary);margin-top:6px}.practice-layout{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:20px}.practice-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.dashboard-grid{display:grid;gap:20px}.exam-layout{max-width:720px;margin:0 auto}.exam-header{justify-content:space-between;margin-bottom:24px;padding:16px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg)}.exam-header,.landing-hero{display:flex;align-items:center}.landing-hero{flex-direction:column;justify-content:center;text-align:center;min-height:100vh;padding:60px 24px;background:var(--bg-primary);position:relative;overflow:hidden}.landing-hero:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse at 60% 40%,var(--accent-glow) 0,transparent 50%);pointer-events:none}.landing-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:100px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);font-size:12px;font-weight:500;margin-bottom:30px;position:relative}.landing-title{font-family:"Instrument Serif",serif;font-size:clamp(40px,7vw,72px);font-weight:400;line-height:1.05;color:var(--text-primary);max-width:700px;margin-bottom:20px;position:relative;letter-spacing:-.02em}.landing-title em{color:var(--accent);font-style:italic}.landing-subtitle{font-size:17px;color:var(--text-secondary);max-width:480px;line-height:1.6;margin-bottom:36px;position:relative}.landing-cta{display:flex;gap:12px;position:relative}.landing-cta .btn-primary{padding:14px 32px;font-size:15px}.landing-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;max-width:900px;margin-top:80px;position:relative}.feature-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;text-align:left}.feature-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:14px}.feature-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.feature-desc{font-size:13px;color:var(--text-tertiary);line-height:1.5}.landing-footer{margin-top:80px;padding-top:24px;border-top:1px solid var(--border);font-size:12px;color:var(--text-tertiary);position:relative}.review-filters{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.filter-btn{padding:6px 14px;border-radius:100px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.filter-btn.active,.filter-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.review-list{display:flex;flex-direction:column;gap:10px}.review-item{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all .15s}.review-item:hover{border-color:var(--accent);background:var(--accent-soft)}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-top:1px solid var(--border);padding:8px 0 env(safe-area-inset-bottom,8px);z-index:40}.mobile-nav-inner{display:flex;justify-content:space-around}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 12px;color:var(--text-tertiary);text-decoration:none;font-size:10px;font-weight:500;transition:color .15s}.mobile-nav-item.active{color:var(--accent)}@media (max-width:768px){.mobile-nav{display:block}}.animate-fade-in{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.skeleton{background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-tertiary) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.topic-chips{display:flex;flex-wrap:wrap;gap:6px}.topic-chip{padding:5px 12px;border-radius:100px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);font-size:11px;font-weight:500;cursor:pointer;transition:all .15s}.topic-chip:hover{border-color:var(--border-strong)}.topic-chip.active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.practice-two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}.practice-left{gap:12px}.practice-left,.practice-right{position:sticky;top:24px;display:flex;flex-direction:column}.practice-right{min-height:0}.practice-right .chat-panel{min-height:400px}.chat-messages{max-height:calc(100vh - 260px)}@media (max-width:1024px){.practice-two-col{grid-template-columns:1fr}.practice-left,.practice-right{position:static}.practice-right .chat-panel{min-height:350px}.chat-messages{max-height:500px}}@media (max-width:768px){.practice-right .chat-panel{max-height:500px;min-height:350px}.chat-input-container{padding-bottom:env(safe-area-inset-bottom,8px)}.chat-messages{-webkit-overflow-scrolling:touch}.question-summary{max-height:none!important}.question-summary-toggle{display:none}}.session-progress-bar{margin-bottom:16px}.session-progress-info{display:flex;justify-content:space-between;margin-bottom:6px;font-size:13px;font-weight:500}.session-progress-info span:first-child{color:var(--text-primary)}.session-progress-info span:last-child{color:var(--text-tertiary);font-family:JetBrains Mono,monospace;font-size:12px}.shortcut-hint{display:flex;align-items:center;gap:8px;padding:8px 14px;margin-bottom:14px;border-radius:var(--radius-md);background:var(--accent-soft);color:var(--text-secondary);font-size:12px}.shortcut-hint kbd{display:inline-block;padding:1px 6px;border-radius:4px;background:var(--bg-card);border:1px solid var(--border);font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600;color:var(--text-primary);margin:0 1px}@media (max-width:768px){.shortcut-hint{display:none}}.session-setup{max-width:640px;margin:0 auto;display:flex;flex-direction:column;gap:16px}.setup-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}.setup-section{margin-bottom:24px}.setup-section:last-of-type{margin-bottom:16px}.setup-label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.setup-hint{font-size:12px;color:var(--text-tertiary);margin-bottom:12px;line-height:1.5}.count-selector{display:flex;gap:8px}.count-btn{flex:1;padding:10px 16px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);font-size:15px;font-weight:600;cursor:pointer;transition:all .15s;font-family:JetBrains Mono,monospace}.count-btn:hover{border-color:var(--border-strong)}.count-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 1px var(--accent)}.setup-keyboard-hint{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-tertiary);font-size:12px;margin-bottom:4px}.setup-keyboard-hint kbd{display:inline-block;padding:1px 5px;border-radius:3px;background:var(--bg-card);border:1px solid var(--border);font-family:JetBrains Mono,monospace;font-size:10px;font-weight:600;color:var(--text-secondary);margin:0 1px}@media (max-width:768px){.setup-keyboard-hint{display:none}}.session-score-ring{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:26px;font-weight:700;font-family:JetBrains Mono,monospace}.session-score-ring.good{background:var(--success-soft);color:var(--success)}.session-score-ring.ok{background:var(--warning-soft);color:var(--warning)}.session-score-ring.weak{background:var(--error-soft);color:var(--error)}.session-wrong-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);background:var(--error-soft)}.formula-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.formula-panel-toggle{width:100%;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;border:none;background:transparent;cursor:pointer;color:var(--text-secondary);font-size:13px;font-weight:500;transition:background .15s}.formula-panel-toggle:hover{background:var(--bg-secondary)}.formula-panel-count{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--accent-soft);color:var(--accent);font-size:10px;font-weight:700}.formula-panel-body{overflow:hidden}.formula-panel-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 14px 14px}@media (max-width:1200px){.formula-panel-grid{grid-template-columns:1fr}}.formula-panel-item{padding:10px 12px;border-radius:var(--radius-sm);background:var(--bg-secondary);border:1px solid var(--border)}.formula-panel-item .formula-name{font-size:11px;margin-bottom:4px}.formula-panel-item .formula-content{font-size:12px}.coaching-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-sm)}.coaching-recommendation{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;border-radius:var(--radius-md);background:var(--accent-soft);border:1px solid var(--accent);border-opacity:.2}.coaching-recommendation-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--accent);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;flex-shrink:0}.dark .coaching-recommendation-icon{color:#0f1117}.coaching-recommendation-text{font-size:14px;color:var(--text-primary);font-weight:500;line-height:1.5}.coaching-recommendation-detail{font-size:12px;color:var(--text-secondary);margin-top:2px;font-weight:400}.exam-date-input{padding:8px 12px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-family:DM Sans,sans-serif;font-size:13px;outline:none;transition:border-color .15s}.exam-date-input:focus{border-color:var(--accent)}.days-countdown{font-family:"Instrument Serif",serif;font-size:48px;color:var(--accent);line-height:1;letter-spacing:-.02em}.days-countdown-label{font-size:13px;color:var(--text-tertiary);margin-top:4px}.dashboard-two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width:900px){.dashboard-two-col{grid-template-columns:1fr}}.auth-input{width:100%;padding:10px 14px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-size:14px;font-family:DM Sans,sans-serif;outline:none;transition:border-color .15s,box-shadow .15s}.auth-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.auth-input::placeholder{color:var(--text-tertiary)}.vignette-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}.vignette-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:14px;border-bottom:1px solid var(--border);margin-bottom:16px}.vignette-passage{overflow:hidden;margin-bottom:16px}.level-grid{display:flex;gap:12px}.level-grid>button{flex:1}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}@media (max-width:480px){.level-grid{flex-direction:column;gap:8px}.level-grid>button{padding:14px 16px!important}.features-grid{grid-template-columns:1fr;gap:16px}.landing-nav{padding:8px 14px!important}.landing-hero-text{padding:14px 14px 0!important}.comparison-table td,.comparison-table th{padding:8px 10px!important;font-size:12px!important}}@media (max-width:768px){.features-grid{grid-template-columns:1fr;gap:16px}}.group:hover .group-hover\:translate-x-0\.5{--tw-translate-x:0.125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@media (min-width:640px){.sm\:inline{display:inline}}