:root{--font-sans: "Onest", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display: "Unbounded", var(--font-sans);--radius-sm: 10px;--radius: 16px;--radius-lg: 22px;--radius-pill: 999px;--transition-fast: .15s ease;--transition-medium: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1);--shell-max: 1180px}:root,[data-theme=dark]{--bg-base: #131210;--bg-surface: #1b1a16;--bg-elevated: #232019;--bg-card: #1f1d18;--bg-card-glass: #1f1d18;--bg-inset: rgba(255, 255, 255, .04);--bg-inset-strong: rgba(255, 255, 255, .07);--border-light: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .16);--border-active: rgba(52, 179, 160, .55);--text-primary: #f2eee6;--text-secondary: #b7ae9d;--text-muted: #847c6d;--accent-primary: #34b3a0;--accent-primary-strong: #45c4b1;--accent-primary-soft: rgba(52, 179, 160, .16);--accent-primary-glow: rgba(52, 179, 160, .3);--accent-secondary: #e6b143;--accent-secondary-soft: rgba(230, 177, 67, .16);--accent-success: #57c08a;--accent-success-soft: rgba(87, 192, 138, .16);--accent-danger: #f06a4f;--accent-danger-soft: rgba(240, 106, 79, .16);--accent-warning: #e6b143;--on-accent: #08221d;--shadow-card: 0 12px 40px -16px rgba(0, 0, 0, .7);--shadow-pop: 0 18px 50px -12px rgba(0, 0, 0, .75);--atmo-1: rgba(52, 179, 160, .16);--atmo-2: rgba(230, 177, 67, .12);color-scheme:dark}[data-theme=light]{--bg-base: #f4f1e9;--bg-surface: #faf8f2;--bg-elevated: #ffffff;--bg-card: #ffffff;--bg-card-glass: #ffffff;--bg-inset: rgba(31, 27, 20, .04);--bg-inset-strong: rgba(31, 27, 20, .07);--border-light: rgba(31, 27, 20, .12);--border-strong: rgba(31, 27, 20, .2);--border-active: rgba(19, 124, 110, .5);--text-primary: #1f1b14;--text-secondary: #574f42;--text-muted: #8a8072;--accent-primary: #137c6e;--accent-primary-strong: #0f6a5e;--accent-primary-soft: rgba(19, 124, 110, .12);--accent-primary-glow: rgba(19, 124, 110, .22);--accent-secondary: #a9741a;--accent-secondary-soft: rgba(169, 116, 26, .14);--accent-success: #2e885f;--accent-success-soft: rgba(46, 136, 95, .14);--accent-danger: #c2452d;--accent-danger-soft: rgba(194, 69, 45, .12);--accent-warning: #a9741a;--on-accent: #ffffff;--shadow-card: 0 14px 40px -22px rgba(40, 33, 20, .45);--shadow-pop: 0 20px 50px -16px rgba(40, 33, 20, .4);--atmo-1: rgba(19, 124, 110, .1);--atmo-2: rgba(169, 116, 26, .1);color-scheme:light}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;width:100%;overflow:hidden;position:fixed;background-color:var(--bg-base)}#root,.app-container{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}body{font-family:var(--font-sans);color:var(--text-primary);position:relative;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition-medium),color var(--transition-medium)}body:before,body:after{content:"";position:fixed;border-radius:50%;z-index:-1;pointer-events:none;filter:blur(90px)}body:before{width:46vw;height:46vw;background:radial-gradient(circle,var(--atmo-1) 0%,transparent 70%);top:-12vw;left:-8vw}body:after{width:50vw;height:50vw;background:radial-gradient(circle,var(--atmo-2) 0%,transparent 70%);bottom:-16vw;right:-10vw}.font-display{font-family:var(--font-display);letter-spacing:-.01em}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:9999px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:var(--text-muted);background-clip:padding-box}button,input,select,textarea{font-family:inherit;color:inherit}button{cursor:pointer;border:none;background:none}input,textarea,select{font-size:1rem}.glass-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow-card);transition:border-color var(--transition-medium),box-shadow var(--transition-medium),background var(--transition-medium),transform var(--transition-medium)}.glass-card:focus-within{border-color:var(--border-active)}.glass-input{width:100%;padding:14px 18px;background:var(--bg-inset);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;transition:border-color var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast)}.glass-input::placeholder{color:var(--text-muted)}.glass-input:focus{border-color:var(--accent-primary);background:var(--bg-inset-strong);box-shadow:0 0 0 3px var(--accent-primary-soft)}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 22px;background:var(--accent-primary);color:var(--on-accent);font-weight:700;border-radius:var(--radius-sm);box-shadow:0 6px 18px -8px var(--accent-primary-glow);transition:all var(--transition-fast)}.btn-primary:hover{background:var(--accent-primary-strong);transform:translateY(-2px);box-shadow:0 10px 24px -8px var(--accent-primary-glow)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 22px;background:var(--bg-inset);border:1px solid var(--border-light);color:var(--text-primary);font-weight:600;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.btn-secondary:hover{background:var(--bg-inset-strong);border-color:var(--border-strong)}@keyframes slideUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%,to{opacity:.45}50%{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}.animate-slide-up{animation:slideUp var(--transition-medium) forwards}.animate-fade-in{animation:fadeIn var(--transition-medium) forwards}.pulse-animation{animation:pulse 1.5s infinite}.spin-animation{animation:spin .9s linear infinite}.typing-indicator{display:inline-flex;align-items:center;gap:5px}.typing-indicator .dot{width:8px;height:8px;border-radius:50%;background:var(--accent-primary);animation:pulse 1s infinite}.flashcard-container{width:100%;max-width:600px;height:350px;perspective:1200px;cursor:pointer;min-height:350px;flex-shrink:0}.flashcard-inner{position:relative;width:100%;height:100%;text-align:center;transition:transform .6s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}.flashcard-container.flipped .flashcard-inner{transform:rotateY(180deg)}.flashcard-front,.flashcard-back{position:absolute;width:100%;height:100%;-webkit-backface-visibility:hidden;backface-visibility:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--radius-lg);border:1px solid var(--border-light)}.flashcard-front{background:var(--bg-card);box-shadow:var(--shadow-card)}.flashcard-back{background:linear-gradient(150deg,var(--bg-card) 0%,var(--accent-primary-soft) 100%);transform:rotateY(180deg);border-color:var(--border-active)}.stage-step-btn{transition:transform .18s ease,box-shadow .18s ease,filter .18s ease}.stage-step-btn:not(:disabled):hover{transform:translateY(-2px) scale(1.12)!important;filter:brightness(1.08);box-shadow:0 4px 14px -4px var(--accent-primary-glow)!important}.stage-step-btn:disabled{cursor:default}.rating-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px 12px;border-radius:var(--radius);font-weight:700;font-size:1.05rem;transition:all .2s ease;border:1px solid transparent}.rating-btn:hover:not(:disabled){transform:translateY(-4px)}.rating-btn:disabled{opacity:.5;cursor:not-allowed}.btn-again{background:var(--accent-danger-soft);border-color:var(--accent-danger);color:var(--accent-danger)}.btn-hard{background:var(--accent-secondary-soft);border-color:var(--accent-secondary);color:var(--accent-secondary)}.btn-good{background:var(--accent-success-soft);border-color:var(--accent-success);color:var(--accent-success)}.btn-easy{background:var(--accent-primary-soft);border-color:var(--accent-primary);color:var(--accent-primary)}.app-shell{display:flex;width:100%;height:100%;overflow:hidden}.sidebar-nav{width:240px;flex-shrink:0;display:flex;flex-direction:column;gap:6px;padding:22px 16px;background:var(--bg-surface);border-right:1px solid var(--border-light)}.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:800;font-size:1.15rem;letter-spacing:-.02em;color:var(--text-primary);padding:4px 10px 20px}.brand-mark{width:34px;height:34px;border-radius:10px;flex-shrink:0;display:grid;place-items:center;font-size:1.1rem;background:var(--accent-primary);color:var(--on-accent);box-shadow:0 6px 16px -8px var(--accent-primary-glow)}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--radius-sm);color:var(--text-secondary);font-weight:600;font-size:.95rem;transition:all var(--transition-fast);text-align:left;width:100%}.nav-item:hover{background:var(--bg-inset);color:var(--text-primary)}.nav-item.active{background:var(--accent-primary-soft);color:var(--accent-primary)}.nav-item .nav-badge{margin-left:auto;background:var(--accent-secondary);color:var(--on-accent);font-size:.7rem;font-weight:800;padding:1px 8px;border-radius:var(--radius-pill)}.shell-main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.topbar{display:flex;align-items:center;gap:14px;padding:14px 24px;border-bottom:1px solid var(--border-light);background:var(--bg-surface)}.topbar-spacer{flex:1}.icon-btn{display:grid;place-items:center;width:40px;height:40px;border-radius:var(--radius-sm);color:var(--text-secondary);border:1px solid var(--border-light);background:var(--bg-inset);transition:all var(--transition-fast)}.icon-btn:hover{color:var(--text-primary);border-color:var(--border-strong)}.shell-content{flex:1;overflow-y:auto;overflow-x:hidden}.page{max-width:var(--shell-max);margin:0 auto;padding:28px 24px 40px;width:100%}.mobile-bottom-nav{display:none}.dashboard-container{display:grid;grid-template-columns:300px 1fr;gap:20px;height:100%;width:100%;padding:20px;overflow:hidden}.dashboard-container.vocab-mode,.dashboard-container.sidebar-collapsed{grid-template-columns:1fr}.dashboard-container.sidebar-collapsed .panel-left{display:none}.appshell-main{height:100%;overflow:hidden;min-width:0}.appshell-page{height:100%;width:100%;display:flex;flex-direction:column;overflow:hidden}.header-icon-btn{display:grid;place-items:center;width:38px;height:38px;flex-shrink:0;border-radius:var(--radius-sm);color:var(--text-secondary);border:1px solid var(--border-light);background:var(--bg-inset);transition:all var(--transition-fast);cursor:pointer}.header-icon-btn:hover{color:var(--text-primary);border-color:var(--border-strong);background:var(--bg-inset-strong)}.stat-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:var(--radius-pill);background:var(--bg-inset);border:1px solid var(--border-light);font-size:.8rem;font-weight:700;color:var(--text-primary);white-space:nowrap}.stat-chip .stat-chip-ico{font-size:.95rem;line-height:1}.level-picker{position:relative}.level-picker-trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:10px 12px;border-radius:var(--radius-sm);background:var(--bg-inset);border:1px solid var(--border-light);color:var(--text-primary);font-weight:600;font-size:.9rem;transition:all var(--transition-fast);cursor:pointer}.level-picker-trigger:hover{border-color:var(--border-strong);background:var(--bg-inset-strong)}.level-popover{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:60;padding:12px;border-radius:var(--radius-sm);background:var(--bg-surface);border:1px solid var(--border-light);box-shadow:0 16px 40px -16px #0000008c;animation:fadeIn var(--transition-fast) forwards}.panel-center{padding:24px;gap:18px}.chat-head-divider{width:1px;align-self:stretch;min-height:28px;background:var(--border-light)}.exercise-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998;background:#0000008c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn var(--transition-fast) forwards}.exercise-modal{width:100%;max-width:680px;max-height:90vh;overflow-y:auto;background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:0 24px 60px -20px #0009}.exercise-modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border-light);position:sticky;top:0;background:var(--bg-surface);z-index:1}.user-menu{position:absolute;top:calc(100% + 6px);right:0;z-index:60;min-width:190px;white-space:nowrap;padding:6px;border-radius:var(--radius-sm);background:var(--bg-surface);border:1px solid var(--border-light);box-shadow:0 16px 40px -16px #0000008c;animation:fadeIn var(--transition-fast) forwards}.user-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;border-radius:8px;cursor:pointer;font-size:.88rem;font-weight:600;color:var(--accent-danger);transition:background var(--transition-fast)}.user-menu-item:hover{background:var(--accent-danger-soft)}.topic-list{display:flex;flex-direction:column;gap:3px;overflow-y:auto;flex:1;padding-right:4px}.topic-item{display:flex;flex-direction:column;gap:8px;padding:9px 11px;border-radius:var(--radius-sm);border:1px solid transparent;transition:background var(--transition-fast),border-color var(--transition-fast)}.topic-item.clickable{cursor:pointer}.topic-item.clickable:hover{background:var(--bg-inset)}.topic-item.active{background:var(--accent-primary-soft);border-color:var(--border-active)}.topic-row{display:flex;align-items:center;gap:10px}.topic-num{width:22px;height:22px;flex-shrink:0;border-radius:50%;display:grid;place-items:center;font-size:.72rem;font-weight:700;background:var(--bg-inset-strong);color:var(--text-secondary)}.topic-item.active .topic-num{background:var(--accent-primary);color:var(--on-accent)}.topic-item.completed .topic-num{background:var(--accent-success);color:var(--on-accent)}.topic-name{flex:1;min-width:0;font-size:.85rem;font-weight:600;color:var(--text-secondary);line-height:1.3}.topic-item.active .topic-name{color:var(--text-primary)}.topic-item.completed .topic-name{color:var(--text-muted);font-weight:500}.topic-cta{flex-shrink:0;color:var(--text-muted);display:grid;place-items:center;opacity:0;transition:opacity var(--transition-fast)}.topic-item.clickable:hover .topic-cta{opacity:1}.topic-grammar{display:inline-flex;align-items:center;gap:6px;margin-left:32px;font-size:.72rem;color:var(--accent-primary);font-weight:500}.topic-desc{margin-left:32px;font-size:.75rem;color:var(--text-muted);line-height:1.45}.topic-actions{display:flex;gap:8px;margin-top:2px}.btn-sm{padding:8px 14px;font-size:.82rem;border-radius:9px}.btn-accent{background:var(--accent-primary-soft);border:1px solid var(--accent-primary);color:var(--accent-primary);font-weight:600}.btn-accent:hover{background:var(--accent-primary-soft);border-color:var(--accent-primary);filter:brightness(1.08)}@media (max-width: 980px){.sidebar-nav{display:none}.shell-content{padding-bottom:78px}.page{padding:18px 16px 32px}.topbar{padding:12px 16px}.mobile-bottom-nav{display:flex;justify-content:space-around;align-items:center;position:fixed;bottom:0;left:0;right:0;z-index:100;padding:8px max(8px,env(safe-area-inset-left)) calc(8px + env(safe-area-inset-bottom));background:var(--bg-surface);border-top:1px solid var(--border-light);box-shadow:0 -8px 24px -16px #0006}.nav-btn{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--text-muted);font-size:.6rem;font-weight:600;padding:6px 2px;border-radius:var(--radius-sm);transition:all var(--transition-fast);flex:1;min-width:0}.nav-btn span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-btn.active{color:var(--accent-primary)}.dashboard-container{display:flex;flex-direction:column;padding:0 0 78px;gap:0}.panel-left,.panel-center,.panel-right{display:none!important;border-radius:0!important;border:none!important;background:transparent!important;box-shadow:none!important;width:100%!important;height:100%!important}.active-tab{display:flex!important}.appshell-main{display:flex!important;flex:1;height:100%;width:100%}.appshell-main .panel-center{display:flex!important}.panel-left.mobile-open{display:flex!important;position:fixed;top:0;bottom:0;left:0;width:86%!important;max-width:340px;height:100%!important;z-index:200;background:var(--bg-surface)!important;box-shadow:0 0 40px -8px #0009!important;overflow-y:auto;padding-bottom:90px}.mobile-plan-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:150;background:#00000080}.desktop-only{display:none!important}.panel-center{padding:12px 12px 0!important;gap:12px}.chat-head{padding-bottom:12px!important}.chat-title{font-size:1.05rem!important}.actions-pill-label{display:none}.exercise-modal-overlay{padding:0}.exercise-modal{max-width:100%;max-height:100%;height:100%;border-radius:0}.vocab-page{padding:16px!important}.vocab-title-h{font-size:1.15rem!important}}.grammar-report-content{color:var(--text-primary);line-height:1.8;font-size:1.05rem}.grammar-report-content h1,.grammar-report-content h2,.grammar-report-content h3,.grammar-report-content h4{font-family:var(--font-display);color:var(--accent-primary);margin-top:1.4em;margin-bottom:.5em;letter-spacing:-.01em;line-height:1.25}.grammar-report-content p{margin-bottom:1em}.grammar-report-content ul,.grammar-report-content ol{margin-bottom:1em;padding-left:22px}.grammar-report-content li{margin-bottom:.5em}.grammar-report-content strong,.grammar-report-content em{color:var(--text-primary);background:var(--accent-secondary-soft);padding:0 5px;border-radius:5px;font-style:normal}.grammar-report-content .highlight{color:var(--accent-secondary);font-weight:700}.grammar-report-content .grammar-table{width:100%;border-collapse:collapse;margin:1.5em 0;background:var(--bg-inset);border-radius:var(--radius-sm);overflow:hidden}.grammar-report-content .grammar-table th,.grammar-report-content .grammar-table td{padding:12px 16px;border:1px solid var(--border-light);text-align:left}.grammar-report-content .grammar-table th{background:var(--accent-primary-soft);color:var(--accent-primary);font-weight:700}.grammar-report-content .example-box{background:var(--accent-success-soft);border-left:4px solid var(--accent-success);padding:16px;margin:1.5em 0;border-radius:0 var(--radius-sm) var(--radius-sm) 0}.grammar-report-content .alert-box{background:var(--accent-danger-soft);border-left:4px solid var(--accent-danger);padding:16px;margin:1.5em 0;border-radius:0 var(--radius-sm) var(--radius-sm) 0}@media (max-width: 600px){.flashcard-container{height:370px}.flashcard-front,.flashcard-back{padding:50px 16px 38px;gap:4px}.flashcard-inner h2{font-size:1.85rem!important;line-height:1.15;overflow-wrap:anywhere;max-width:100%}.flashcard-inner h3{font-size:1.1rem!important;margin-bottom:10px!important;overflow-wrap:anywhere;max-width:100%}.flashcard-front>span,.flashcard-back>span{top:12px!important;font-size:.66rem!important;padding:3px 8px!important}.flashcard-front>span:first-of-type,.flashcard-back>span:first-of-type{left:12px!important;max-width:56%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.flashcard-front>span:nth-of-type(2),.flashcard-back>span:nth-of-type(2){right:12px!important}.flashcards-view{padding:14px 14px 20px!important}.flashcards-card-area{gap:18px!important;overflow-y:auto;padding-bottom:12px;flex-basis:auto;height:auto}.rating-grid{grid-template-columns:repeat(2,1fr)!important;gap:8px!important}.rating-btn{padding:11px 6px;font-size:.9rem}.rating-sub{display:none!important}.summary-stats-grid{grid-template-columns:repeat(2,1fr)!important}.summary-cols{grid-template-columns:1fr!important}}
