@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--canvas:#0b0d16;--surface:#151a28;--surface-elevated:#1c2334;--text-strong:#f2eee7;--text-soft:#beb8ab;--line:#ffffff14;--gold:#c6932d;--gold-bright:#f4d685;--shadow-lg:0 12px 30px #00000052;color:var(--text-strong);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at top,#c6932d1a,#0000 24%),linear-gradient(#101521 0%,#090b11 100%);font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:15px;font-weight:400;line-height:1.45}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:0 0;min-width:320px;min-height:100vh;margin:0}body,button,input,select,textarea{font-family:inherit}textarea{font-size:16px}button{border:1px solid color-mix(in srgb, var(--line) 86%, transparent);border-bottom-width:3px;border-radius:7px;transition:transform .13s,border-color .13s,filter .13s,box-shadow .13s;box-shadow:0 1px #ffffff0f}button:hover:not(:disabled){transform:translateY(-1px)}button:active:not(:disabled){border-bottom-width:2px;transform:translateY(1px)}a{color:inherit}button:disabled{opacity:.55;cursor:not-allowed;transform:none}#root{width:100%;min-height:100vh}h1,h2,h3,h4{letter-spacing:-.015em;font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.15}h2{font-size:clamp(1.5rem,2.8vw,2.1rem)}h3{font-size:clamp(1.05rem,1.8vw,1.35rem)}p,small,li,td,th,label{font-family:inherit}.shell{--theme-primary:var(--gold);--theme-accent:var(--gold-bright);--theme-mist:#f4eee8;background:radial-gradient(circle at top left, color-mix(in srgb, var(--theme-primary) 18%, transparent), transparent 34%), radial-gradient(circle at bottom right, color-mix(in srgb, var(--theme-accent) 14%, transparent), transparent 36%), linear-gradient(180deg, color-mix(in srgb, var(--theme-primary) 8%, #111827), #090b11 100%);grid-template-columns:280px minmax(0,1fr);width:100%;min-height:100vh;display:grid}.shell.is-standalone-pwa{--pwa-top-banner-height:max(20px, env(safe-area-inset-top));padding-top:var(--pwa-top-banner-height)}.shell.is-standalone-pwa:before{content:"";height:var(--pwa-top-banner-height);background:linear-gradient(135deg, var(--theme-primary), var(--theme-secondary));z-index:120;pointer-events:none;position:fixed;top:0;left:0;right:0}.shell.is-standalone-pwa .sidebar{top:var(--pwa-top-banner-height);min-height:calc(100vh - var(--pwa-top-banner-height))}.sidebar{border-right:1px solid var(--line);background:radial-gradient(circle at top, color-mix(in srgb, var(--theme-primary) 16%, transparent), transparent 34%), linear-gradient(180deg, #10141ff7, #0a0d16fc);flex-direction:column;gap:20px;min-height:100vh;padding:24px 18px;display:flex;position:sticky;top:0}.brand-block{align-items:flex-start;gap:12px;display:flex}.brand-mark{background:linear-gradient(135deg, var(--theme-primary), var(--theme-accent));color:#fffaf2;width:44px;height:44px;box-shadow:0 10px 22px color-mix(in srgb, var(--theme-primary) 30%, transparent);border-radius:12px;place-items:center;font-size:1.18rem;font-weight:700;display:grid}.sidebar h1,.panel h2,.panel h3,.panel h4{margin:0}.sidebar h1{letter-spacing:-.01em;font-size:1.36rem}.sidebar-group{gap:8px;display:grid}.meta-label{color:var(--text-soft);letter-spacing:.08em;text-transform:uppercase;margin:0;font-size:.73rem}.sidebar-footnote{background:color-mix(in srgb, var(--theme-primary) 10%, #ffffff05);border:1px solid color-mix(in srgb, var(--theme-primary) 22%, #ffffff14);border-radius:12px;margin-top:auto;padding:14px}.language-pill{background:color-mix(in srgb, var(--theme-primary) 9%, #ffffff0a);border:1px solid color-mix(in srgb, var(--theme-primary) 20%, #ffffff14);box-shadow:inset 0 1px 0 color-mix(in srgb, var(--theme-mist) 12%, transparent);border-radius:8px;flex-direction:column;gap:2px;padding:10px 12px;display:inline-flex}.language-pill-title{font-size:1.4em}.language-pill-btn{cursor:pointer;text-align:left;width:100%;color:var(--text-strong);transition:background .14s,border-color .14s;position:relative}.language-pill-btn:hover{background:color-mix(in srgb, var(--theme-primary) 14%, #ffffff0f);border-color:color-mix(in srgb, var(--theme-accent) 34%, #ffffff2e)}.language-pill-caret{opacity:.5;font-size:.75rem;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.lang-modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lang-modal{background:var(--surface);border:1px solid var(--line);border-radius:16px;flex-direction:column;gap:16px;width:min(340px,90vw);padding:20px;display:flex}.lang-modal-title{color:var(--text-strong);margin:0;font-size:1.05rem;font-weight:700}.lang-modal-grid{gap:10px;padding:1px 1em 1px 1px;display:grid}.lang-option{color:var(--text-strong);border:1px solid var(--line);cursor:pointer;text-align:left;background:#ffffff0a;border-bottom-width:3px;border-radius:8px;align-items:center;gap:10px;padding:14px 16px;transition:transform .13s,background .13s,border-color .13s,box-shadow .13s;display:flex;position:relative}.lang-option:hover{background:#ffffff17;border-color:#ffffff2e;transform:translateY(-1px)}.lang-option.is-active{background:color-mix(in srgb, var(--lang-accent,var(--gold-bright)) 15%, transparent);border-color:color-mix(in srgb, var(--lang-accent,var(--gold-bright)) 50%, transparent)}.lang-option-label{color:var(--text-strong);font-size:.97rem;font-weight:600}.lang-option-native{color:var(--text-soft);font-size:.88rem}.lang-option-check{color:var(--lang-accent,var(--gold-bright));margin-left:auto;font-weight:700}.lang-modal-close{align-self:flex-end}.sidebar-nav{gap:6px;display:grid}.sidebar-nav a{color:var(--text-soft);border:1px solid #0000;border-radius:10px;align-items:center;padding:9px 11px;font-size:.93rem;text-decoration:none;transition:all .16s;display:flex}.sidebar-nav a.active,.sidebar-nav a:hover{color:var(--text-strong);background:color-mix(in srgb, var(--theme-primary) 13%, #ffffff08);border-color:color-mix(in srgb, var(--theme-accent) 28%, #ffffff14);box-shadow:inset 3px 0 0 color-mix(in srgb, var(--theme-accent) 78%, transparent)}.content-area{width:100%;min-width:0;padding:12px 12px 20px}.topbar{align-items:center;gap:14px;padding:8px 6px 14px;display:flex}.topbar .eyebrow{letter-spacing:0;font-size:1.2em;font-weight:700}.topbar-copy{color:var(--text-soft);margin:0;font-size:.92rem}.menu-button{justify-content:center;align-items:center;width:44px;height:44px;padding:0;display:none}.menu-button-icon{gap:4px;width:18px;display:inline-grid}.menu-button-icon span{background:currentColor;border-radius:999px;width:100%;height:2px;transition:transform .15s,opacity .15s}.menu-button.is-open .menu-button-icon span:first-child{transform:translateY(6px)rotate(45deg)}.menu-button.is-open .menu-button-icon span:nth-child(2){opacity:0}.menu-button.is-open .menu-button-icon span:nth-child(3){transform:translateY(-6px)rotate(-45deg)}.sidebar-backdrop{display:none}.page-stack{gap:12px;display:grid}.panel{background:linear-gradient(180deg, color-mix(in srgb, var(--theme-mist) 5%, #ffffff05), #ffffff04);border:1px solid var(--line);box-shadow:var(--shadow-lg), inset 0 1px 0 color-mix(in srgb, var(--theme-mist) 8%, transparent);border-radius:12px;gap:12px;padding:16px;display:grid;position:relative;overflow:hidden}.panel-hero{background-position:50%;background-size:cover;grid-template-columns:minmax(0,1.5fr) minmax(230px,.8fr);align-items:end;min-height:250px}.compact-hero{min-height:180px}.hero-metrics{align-self:stretch;gap:10px;display:grid}.hero-metrics>div{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f12209e;border:1px solid #ffffff1a;border-radius:8px;align-content:center;gap:1px;padding:7px 10px;display:grid}.hero-metrics span{color:var(--text-strong);font-size:clamp(1rem,1.5vw,1.35rem);font-weight:650;line-height:1}.dashboard-grid,.chart-grid,.lesson-grid,.narrow-grid{gap:12px;display:grid}.dashboard-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.dashboard-grid.narrow-grid,.chart-grid,.lesson-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.quote-card,.fact-card{justify-content:space-between;gap:10px}.progress-pulse-card{align-content:start}.progress-meter{background:color-mix(in srgb, var(--theme-primary) 18%, #ffffff0d);border:1px solid color-mix(in srgb, var(--theme-primary) 28%, #ffffff1a);border-radius:999px;width:100%;height:10px;overflow:hidden}.progress-meter-fill{background:linear-gradient(90deg, var(--theme-primary), var(--theme-accent));height:100%;box-shadow:0 0 16px color-mix(in srgb, var(--theme-accent) 44%, transparent);border-radius:999px;display:block}.meter-meta-row{color:var(--text-soft);justify-content:space-between;align-items:center;gap:8px;font-size:.84rem;display:flex}.meter-meta-row strong{color:var(--text-strong)}.dashboard-progress-spotlight{gap:14px}.spotlight-stats-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.spotlight-stat-chip{border:1px solid var(--line);background:color-mix(in srgb, var(--theme-primary) 9%, #ffffff08);border-radius:10px;gap:4px;padding:10px;display:grid}.spotlight-stat-chip span{text-transform:uppercase;letter-spacing:.08em;color:var(--text-soft);font-size:.76rem}.spotlight-stat-chip strong{color:var(--text-strong);font-size:1.08rem;line-height:1.25}.empty-progress-state{border:1px dashed color-mix(in srgb, var(--theme-accent) 46%, #fff3);background:color-mix(in srgb, var(--theme-primary) 10%, #ffffff05);color:var(--text-soft);border-radius:10px;margin:0;padding:12px}.primary-text{font-size:2em}.secondary-text{margin:0;font-size:.85em}.stat-list{color:var(--text-soft);gap:7px;margin:0;padding-left:16px;display:grid}.section-header,.split-header,.action-row,.lesson-card-foot{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.section-nav-panel{gap:10px}.section-nav{flex-wrap:wrap;gap:8px;display:flex}.section-nav .secondary-button{text-decoration:none}.section-nav .secondary-button.is-active{background:color-mix(in srgb, var(--theme-accent) 16%, #ffffff0f);border-color:color-mix(in srgb, var(--theme-accent) 45%, var(--line));color:var(--text-strong)}.lesson-card{min-height:220px;color:var(--text-strong);background-position:50%;background-size:cover;padding:26px}.lesson-card>*{z-index:1;position:relative}.lesson-card.is-completed{border-color:#22c55e73;box-shadow:0 12px 28px #0c101a85,inset 0 0 0 1px #22c55e3d}.lesson-card.is-completed:before{content:"";pointer-events:none;z-index:0;background:linear-gradient(#10b98129,#22c55e38);position:absolute;inset:0}.lesson-card-foot{margin-top:auto}.lesson-card .lesson-title{margin:.2em 0;font-size:1.8rem;font-weight:600}.lesson-meta{gap:6px;display:grid}.lesson-status-badge{letter-spacing:.02em;border:1px solid #0000;border-radius:999px;align-items:center;gap:6px;width:fit-content;padding:4px 9px;font-size:.76rem;font-weight:600;display:inline-flex}.lesson-status-dot{border-radius:999px;place-items:center;width:15px;height:15px;font-size:.72rem;font-weight:800;line-height:1;display:inline-grid}.lesson-status-badge.is-ready{color:#ecf6fff2;background:#60a5fa2e;border-color:#60a5fa80}.lesson-status-badge.is-ready .lesson-status-dot{color:#bfdbfef2;background:#60a5fa47}.lesson-status-badge.is-completed{color:#dcfce7f2;background:#22c55e33;border-color:#22c55e8f}.lesson-status-badge.is-completed .lesson-status-dot{color:#dcfce7;background:#22c55e59}.topic-filter,.choice-grid,.hint-strip,.token-bank{flex-wrap:wrap;gap:8px;display:flex}.topic-filter{width:100%}.topic-filter-mobile-trigger.choice{width:100%;display:none}.topic-label-clamp,.topic-option-label,.lessons-topic-option-label{-webkit-line-clamp:2;line-clamp:2;text-overflow:ellipsis;white-space:normal;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.lessons-topic-option{text-align:left;justify-content:flex-start;width:100%}.topic-modal .lang-modal-grid,.lessons-topic-modal .lang-modal-grid{max-height:min(52vh,420px);padding-right:4px;overflow-y:auto}.lessons-section-header,.lessons-topic-filter-desktop .choice{align-items:flex-start}.lessons-topic-filter-desktop .topic-label-clamp,.topic-filter-desktop .topic-label-clamp{max-width:11rem}.choice-grid{grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.compact-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.choice,.primary-button,.secondary-button,.text-button,.token,.menu-button{cursor:pointer;font:inherit;border:1px solid #0000;border-bottom-width:3px;border-radius:7px;font-size:.92rem;transition:all .14s}.choice,.secondary-button,.token,.menu-button{background:color-mix(in srgb, var(--theme-primary) 8%, #ffffff08);color:var(--text-strong);border:1px solid var(--line);padding:9px 12px}.choice{text-align:left;justify-content:flex-start;align-items:center;gap:8px;min-height:38px;display:inline-flex}.topic-icon{font-size:.96rem;line-height:1}.focus-topic{align-items:center;gap:7px;display:inline-flex}.choice:before{content:"";box-sizing:border-box;background:0 0;border:2px solid #f2eee799;border-radius:999px;flex:0 0 13px;width:13px;height:13px;transition:all .14s}.choice.is-selected,.choice:hover,.secondary-button:hover,.token:hover,.menu-button:hover{background:color-mix(in srgb, var(--choice-primary,var(--theme-primary)) 14%, #ffffff0d);border-color:color-mix(in srgb, var(--choice-accent,var(--theme-accent)) 30%, var(--line));transform:translateY(-1px)}.choice.is-selected{border-color:color-mix(in srgb, var(--choice-accent,var(--theme-accent)) 48%, transparent);background:color-mix(in srgb, var(--choice-accent,var(--theme-accent)) 15%, transparent);color:var(--text-strong)}.choice.is-selected:before{border-color:var(--choice-accent,var(--theme-accent));background:radial-gradient(circle at center, var(--choice-accent,var(--theme-accent)) 0 45%, transparent 47% 100%)}.choice:focus-visible,.primary-button:focus-visible,.secondary-button:focus-visible,.menu-button:focus-visible,.token:focus-visible,.text-button:focus-visible{outline:2px solid color-mix(in srgb, var(--theme-accent) 80%, white);outline-offset:2px}.primary-button{color:#fffaf2;background:linear-gradient(135deg, var(--theme-primary), var(--theme-accent));box-shadow:0 8px 18px color-mix(in srgb, var(--theme-primary) 26%, transparent);justify-content:center;align-items:center;gap:8px;padding:10px 13px;text-decoration:none;display:inline-flex}.primary-button:hover{filter:saturate(1.06);transform:translateY(-1px)}.primary-button:disabled,.secondary-button:disabled,.token:disabled,.choice:disabled{cursor:not-allowed;opacity:.52;filter:none;transform:none}.button-spinner{border:2px solid #fffaf259;border-top-color:#fffaf2;border-radius:999px;width:.9rem;height:.9rem;animation:.7s linear infinite button-spinner-rotate}@keyframes button-spinner-rotate{to{transform:rotate(360deg)}}.lesson-cta{justify-content:center;min-width:132px;font-weight:640}.lesson-cta.start{color:#fffaf2;background:linear-gradient(135deg, var(--theme-primary), color-mix(in srgb, var(--theme-accent) 88%, white))}.lesson-cta.replay{color:#d1fae5;background:linear-gradient(135deg,#10b9815c,#05966975);border:1px solid #22c55e99;box-shadow:0 8px 20px #05966940}.text-button{color:var(--theme-accent);background:0 0;padding:0}.eyebrow{text-transform:uppercase;letter-spacing:.12em;color:var(--theme-accent);margin:0;font-size:.68rem}.reading-passage,.token-answer,.sample-answer,.translation-card{border:1px solid var(--line);white-space:pre-wrap;background:#ffffff0a;border-radius:10px;padding:12px}.vocab-quiz{flex-direction:column;gap:16px;display:flex}.vocab-quiz-header{justify-content:space-between;align-items:center;display:flex}.vocab-progress{color:var(--text-soft);font-size:.85rem}.vocab-card{border:1px solid var(--line);text-align:center;background:#ffffff0a;border-radius:12px;flex-direction:column;align-items:center;gap:6px;padding:32px 16px;display:flex}.vocab-word{color:var(--text-strong);margin:0;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:700}.vocab-reading{color:var(--text-soft);margin:0;font-size:1rem}.vocab-reveal-btn{width:100%}.vocab-translation{text-align:center;color:var(--text-strong);font-size:1.1rem;font-weight:500}.vocab-decision-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.vocab-missed-btn,.vocab-knew-btn{cursor:pointer;border-radius:8px;flex-direction:column;align-items:center;gap:6px;padding:16px;font-size:.95rem;font-weight:600;display:flex}.vocab-btn-icon{font-size:1.5rem;line-height:1}.vocab-missed-btn{color:#ef4444;background:#ef444426;border:1px solid #ef444466}.vocab-missed-btn:hover{background:#ef444440}.vocab-knew-btn{color:#22c55e;background:#22c55e26;border:1px solid #22c55e66}.vocab-knew-btn:hover{background:#22c55e40}.word-of-day-panel{gap:14px}.word-of-day-actions{margin-top:2px}.word-of-day-result{text-align:center;margin:0}.writing-box,.vocab-form input,select,.search-input,.settings-panel input[type=file]{box-sizing:border-box;border:1px solid var(--line);width:100%;color:var(--text-strong);background:#ffffff0a;border-radius:9px;padding:10px 12px;font-size:.93rem}.settings-panel select{appearance:none;background-image:linear-gradient(45deg, transparent 50%, var(--text-soft) 50%), linear-gradient(135deg, var(--text-soft) 50%, transparent 50%);background-position:calc(100% - 18px) calc(50% - 2px),calc(100% - 12px) calc(50% - 2px);background-repeat:no-repeat;background-size:6px 6px,6px 6px;padding-right:34px}option{color:var(--text-soft);background:var(--surface)}.settings-panel select:hover{border-color:color-mix(in srgb, var(--theme-accent) 38%, var(--line));background-color:color-mix(in srgb, var(--theme-primary) 8%, #ffffff0a)}.writing-box{resize:vertical;min-height:110px}.translate-preview{object-fit:contain;border:1px solid var(--line);background:#ffffff08;border-radius:10px;width:100%;max-height:260px}.pressed-word-popover{z-index:250;border:1px solid color-mix(in srgb, var(--theme-accent) 35%, var(--line));background:color-mix(in srgb, var(--surface) 84%, #080a12eb);border-radius:10px;gap:10px;width:min(320px,100vw - 22px);padding:12px;display:grid;position:fixed;box-shadow:0 14px 34px #05070d7a}.pressed-word-highlight{z-index:240;pointer-events:none;border:1px solid color-mix(in srgb, var(--theme-accent) 72%, transparent);background:color-mix(in srgb, var(--theme-accent) 28%, transparent);box-shadow:0 0 0 1px color-mix(in srgb, var(--theme-accent) 22%, transparent), 0 6px 14px color-mix(in srgb, var(--theme-accent) 20%, transparent);border-radius:6px;position:fixed}.pressed-word-header{justify-content:space-between;align-items:center;gap:10px;display:flex}.pressed-word-header strong{color:var(--text-strong);font-size:1.1rem}.vocab-form,.settings-panel{align-content:start}.vocab-form label{gap:6px;font-size:.9rem;display:grid}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid var(--line);padding:9px 8px;font-size:.9rem}.phrasebook-groups{flex-direction:column;align-items:start;gap:12px;display:flex}.phrasebook-group{border:1px solid var(--line);background:color-mix(in srgb, var(--theme-primary) 7%, #ffffff05);border-radius:10px;align-content:start;gap:8px;min-width:0;padding:10px;display:grid}.phrasebook-group h4{color:var(--text-strong);margin:0;font-size:.95rem}.phrasebook-card{border:1px solid var(--line);background:#ffffff0a;border-radius:10px;width:100%;padding:10px}.phrasebook-card p,.phrasebook-card small{margin:4px 0 0}.exercise-card{gap:14px}.question-stack{gap:12px;display:grid}.question-block{border:1px solid var(--line);background:#ffffff08;border-radius:10px;gap:10px;padding:12px;display:grid}.question-meta,.question-prompt{margin:0}.question-meta{text-transform:uppercase;letter-spacing:.08em;color:var(--text-soft);font-size:.76rem}.question-prompt{color:var(--text-strong);white-space:pre-wrap;font-weight:600}.exercise-prompt,.feedback-note{color:var(--text-soft);margin:0}.chart-wrap{width:100%;height:220px}.feedback-note{background:color-mix(in srgb, var(--theme-primary) 14%, transparent);color:color-mix(in srgb, var(--theme-accent) 82%, white);border-radius:9px;padding:9px 11px}.feedback-banner{border-radius:10px;flex-direction:column;gap:8px;margin-top:4px;padding:14px 16px;display:flex}.feedback-banner p{opacity:.9;margin:0;font-size:.9rem}.feedback-detail{white-space:pre-wrap;font-style:italic;font-weight:600;opacity:1!important}.feedback-banner.is-correct{color:#22c55e;background:#22c55e26;border:1px solid #22c55e73}.feedback-banner.is-wrong{color:#ef4444;background:#ef444426;border:1px solid #ef444473}.continue-button{cursor:pointer;border-radius:7px;align-self:flex-end;margin-top:4px;padding:8px 22px;font-size:.9rem;font-weight:600}.feedback-banner.is-correct .continue-button{color:#fff;background:#22c55e}.feedback-banner.is-wrong .continue-button{color:#fff;background:#ef4444}.settings-layout{grid-template-columns:190px minmax(0,1fr);gap:12px;display:grid}.settings-nav{align-content:start;gap:8px;display:grid}.settings-tab{border:1px solid var(--line);color:var(--text-soft);text-align:left;font:inherit;cursor:pointer;background:#ffffff08;border-bottom-width:3px;border-radius:8px;padding:10px 12px;font-size:.92rem;transition:all .14s}.settings-tab:hover{color:var(--text-strong);background:#ffffff0f}.settings-tab.is-active{background:color-mix(in srgb, var(--theme-accent) 14%, transparent);border-color:color-mix(in srgb, var(--theme-accent) 48%, transparent);color:var(--text-strong)}.settings-tab:focus-visible{outline:2px solid color-mix(in srgb, var(--theme-accent) 80%, white);outline-offset:2px}.settings-content{min-width:0}.settings-stack{gap:12px;display:grid}.notification-permission-row{color:var(--text-soft);align-items:center;gap:8px;margin:0;display:flex}.notification-permission-row strong{color:var(--text-strong)}.notification-list{gap:10px;display:grid}.notification-option{border:1px solid var(--line);background:#ffffff08;border-radius:10px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px;display:grid}.notification-label{color:var(--text-strong);margin:0;font-weight:600}.notification-description{color:var(--text-soft);margin:4px 0 0;font-size:.86rem}.notification-toggle{border:1px solid var(--line);color:var(--text-soft);min-width:110px;font:inherit;cursor:pointer;background:#ffffff08;border-bottom-width:3px;border-radius:999px;padding:8px 14px;font-size:.85rem;font-weight:600;transition:all .14s}.notification-toggle:hover{color:var(--text-strong);background:#ffffff0f}.notification-toggle.is-on{color:#102214;background:linear-gradient(#88e191,#50c162);border-color:#72d97f}@media (width<=1100px){.shell{grid-template-columns:1fr}.sidebar{z-index:30;width:min(84vw,280px);transition:transform .18s;position:fixed;inset:0 auto 0 0;transform:translate(-100%)}.shell.is-standalone-pwa .sidebar{inset:var(--pwa-top-banner-height) auto 0 0;min-height:auto}.sidebar.is-open{transform:translate(0)}.sidebar-backdrop.is-open{z-index:20;background:#06080e6b;border:0;padding:0;display:block;position:fixed;inset:0}.shell.is-standalone-pwa .sidebar-backdrop.is-open{top:var(--pwa-top-banner-height)}.menu-button{display:inline-flex}.dashboard-grid,.chart-grid,.lesson-grid,.dashboard-grid.narrow-grid,.panel-hero,.settings-layout{grid-template-columns:1fr}.settings-nav{grid-template-columns:repeat(3,minmax(0,1fr))}.notification-option,.spotlight-stats-grid{grid-template-columns:1fr}}@media (width<=720px){.content-area{padding:10px 10px 20px}.panel{border-radius:10px;padding:12px}.choice-grid,.compact-grid,.settings-nav{grid-template-columns:1fr}.topbar{align-items:flex-start}.lessons-topic-filter-desktop,.topic-filter-desktop{display:none}.topic-filter-mobile-trigger.choice{align-items:flex-start;display:inline-flex}.topic-modal,.lessons-topic-modal{width:min(380px,92vw)}}
