:root{font-family:Inter,ui-sans-serif,-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans SC,sans-serif;color:#17332d;background:#f3f0e7;font-synthesis:none;--ink: #17332d;--forest: #11352d;--forest-2: #205448;--cream: #f3f0e7;--paper: #fcfbf6;--line: #d8d4c8;--muted: #6d7973;--gold: #e6b84a;--gold-light: #f7e6b3;--red: #b74b3e;--red-light: #fae5df;--green-light: #deeee7;--shadow: 0 18px 60px rgba(25, 48, 41, .09)}*{box-sizing:border-box}html{min-height:100%;background:var(--cream)}body{margin:0;min-width:320px;min-height:100vh}button,input{font:inherit}button,a{-webkit-tap-highlight-color:transparent}a{color:inherit;text-decoration:none}p,h1,h2,h3,blockquote{margin-top:0}button{color:inherit}.app-loading{min-height:100vh;display:grid;place-content:center;justify-items:center;gap:14px;color:var(--muted)}.logo-mark,.brand-mark{display:grid;place-items:center;width:42px;height:42px;border-radius:13px;background:var(--gold);color:var(--forest);font-size:24px;font-weight:800;box-shadow:inset 0 -3px #482c061f}.app-shell{min-height:100vh;display:grid;grid-template-columns:240px 1fr}.sidebar{position:fixed;inset:0 auto 0 0;width:240px;display:flex;flex-direction:column;padding:28px 22px 22px;background:var(--forest);color:#f7f4e9;z-index:20}.brand{display:flex;align-items:center;gap:12px}.brand strong{display:block;font-size:20px;line-height:1;letter-spacing:-.03em}.brand small{display:block;margin-top:5px;color:#aabcb5;font-size:10px;letter-spacing:.12em;text-transform:uppercase}.nav-list{display:grid;gap:6px;margin-top:48px}.nav-item{display:flex;align-items:center;gap:14px;min-height:46px;padding:0 14px;border-radius:12px;color:#aebeb9;font-size:14px;font-weight:500;transition:.16s ease}.nav-item>span:first-child{width:20px;color:#d9e1dd;font-size:19px;text-align:center}.nav-item:hover,.nav-item.router-link-exact-active{background:#ffffff17;color:#fff}.nav-item.router-link-exact-active{box-shadow:inset 3px 0 0 var(--gold)}.sync-panel{display:flex;align-items:flex-start;gap:10px;margin-top:auto;padding:14px;border:1px solid rgba(255,255,255,.09);border-radius:13px;background:#ffffff0b}.sync-panel strong,.sync-panel small{display:block}.sync-panel strong{font-size:12px}.sync-panel small{margin-top:3px;color:#91a49e;font-size:10px}.status-dot{width:8px;height:8px;margin-top:4px;border-radius:50%;background:#79d8a5;box-shadow:0 0 0 4px #79d8a517}.status-dot.offline{background:var(--gold)}.main-content{grid-column:2;min-width:0}.page{width:min(1180px,100%);margin:0 auto;padding:54px 52px 76px}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;margin-bottom:36px}.eyebrow{margin-bottom:11px;color:#8e712b;font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase}.eyebrow.light{color:#e5c36f}.page-header h1{margin-bottom:8px;font-family:Georgia,"Noto Serif SC",serif;font-size:clamp(30px,4vw,44px);font-weight:500;letter-spacing:-.035em;line-height:1.12}.page-description{max-width:620px;margin-bottom:0;color:var(--muted);font-size:14px}.button{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 20px;border:0;border-radius:11px;cursor:pointer;font-size:13px;font-weight:700;transition:transform .15s ease,background .15s ease,opacity .15s ease}.button:hover:not(:disabled){transform:translateY(-1px)}.button:disabled{cursor:not-allowed;opacity:.48}.button.primary{background:var(--forest);color:#fff;box-shadow:0 8px 24px #11352d29}.button.primary:hover:not(:disabled){background:var(--forest-2)}.button.secondary{border:1px solid var(--line);background:var(--paper)}.button.ghost{background:transparent}.button.wide{width:100%}.hero-grid{display:grid;grid-template-columns:minmax(330px,2fr) 1fr 1fr;gap:16px}.focus-card,.metric-card,.panel,.word-row,.stats-grid article,.format-note{border:1px solid var(--line);border-radius:18px;background:var(--paper);box-shadow:0 8px 32px #19302909}.focus-card{display:flex;justify-content:space-between;gap:22px;min-height:202px;padding:28px;background:radial-gradient(circle at 85% 10%,rgba(230,184,74,.2),transparent 32%),var(--forest);color:#fff}.focus-card h2{margin:8px 0 0;font-family:Georgia,serif;font-size:62px;font-weight:400;line-height:1}.focus-card p{color:#b7c8c2;font-size:13px}.focus-breakdown{display:grid;align-content:end;gap:8px;min-width:125px}.focus-breakdown span{padding-top:8px;border-top:1px solid rgba(255,255,255,.12);color:#aebfb9;font-size:11px}.focus-breakdown strong{margin-right:5px;color:#fff;font-size:15px}.metric-card{min-height:202px;padding:24px}.metric-icon{display:inline-grid;place-items:center;width:36px;height:36px;margin-bottom:24px;border-radius:50%;background:var(--green-light);color:var(--forest);font-size:20px}.metric-icon.gold{background:var(--gold-light)}.metric-card p{margin-bottom:4px;color:var(--muted);font-size:12px}.metric-card strong{display:block;font-family:Georgia,serif;font-size:36px;font-weight:400}.metric-card small{color:#8a928f;font-size:10px}.section-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:16px;margin-top:16px}.panel{padding:26px}.panel-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:20px}.panel-heading h3,.settings-section h3,.format-note h3{margin-bottom:0;font-family:Georgia,serif;font-size:22px;font-weight:500}.panel-heading>span{color:var(--muted);font-size:11px}.learning-order{display:grid;gap:0;margin:0;padding:0;list-style:none}.learning-order li{display:flex;gap:18px;padding:15px 0;border-top:1px solid #e5e1d6}.learning-order li>span{color:#9e8341;font-family:Georgia,serif;font-size:13px}.learning-order strong{font-size:13px}.learning-order p{margin:4px 0 0;color:var(--muted);font-size:11px}.quote-panel{background:#e9e5d8}.quote-panel blockquote{margin:40px 0 28px;font-family:Georgia,"Noto Serif SC",serif;font-size:21px;line-height:1.65}.quote-panel a,.text-link{color:#8e712b;font-size:12px;font-weight:700}.mobile-header,.bottom-nav{display:none}.auth-layout{min-height:100vh;display:grid;grid-template-columns:minmax(360px,1.1fr) minmax(420px,.9fr)}.auth-story{display:flex;flex-direction:column;justify-content:space-between;min-height:100vh;padding:44px clamp(38px,7vw,100px);background:radial-gradient(circle at 100% 0,rgba(230,184,74,.18),transparent 38%),linear-gradient(145deg,#0e3129,#153f35);color:#fff}.brand.light small{color:#9eb2ab}.auth-story h1{max-width:680px;margin-bottom:24px;font-family:Georgia,"Noto Serif SC",serif;font-size:clamp(38px,5.2vw,70px);font-weight:400;letter-spacing:-.045em;line-height:1.14}.auth-story>div>p:last-child{max-width:560px;color:#abc0b8;line-height:1.8}.story-metric{display:flex;align-items:baseline;gap:12px}.story-metric strong{color:var(--gold);font-family:Georgia,serif;font-size:42px;font-weight:400}.story-metric span{color:#9fb3ac;font-size:12px}.auth-form-wrap{display:grid;place-items:center;padding:40px;background:var(--paper)}.auth-form{width:min(410px,100%)}.auth-form h2{margin-bottom:10px;font-family:Georgia,"Noto Serif SC",serif;font-size:32px;font-weight:500}.auth-form>p:not(.eyebrow,.form-error){margin-bottom:34px;color:var(--muted);font-size:13px}label{display:grid;gap:8px;margin-bottom:18px;color:#465951;font-size:12px;font-weight:600}input{width:100%;min-height:46px;padding:0 14px;border:1px solid var(--line);border-radius:10px;outline:none;background:#fffefa;color:var(--ink);transition:border .14s ease,box-shadow .14s ease}input:focus{border-color:#8eaa9f;box-shadow:0 0 0 3px #3d6d5e17}.form-error{padding:11px 13px;border-radius:9px;background:var(--red-light);color:var(--red);font-size:12px}.study-page{min-height:100vh;display:flex;flex-direction:column;padding:28px 40px 50px;background:linear-gradient(rgba(229,225,211,.44) 1px,transparent 1px),linear-gradient(90deg,rgba(229,225,211,.44) 1px,transparent 1px),var(--cream);background-size:32px 32px}.study-header{width:min(920px,100%);display:grid;grid-template-columns:1fr minmax(200px,340px) 1fr;align-items:center;gap:24px;margin:0 auto 36px}.study-header>:last-child{justify-self:end}.study-progress>span{display:block;margin-bottom:7px;color:var(--muted);font-size:10px;text-align:center}.progress-track{height:5px;overflow:hidden;border-radius:5px;background:#dcd7c9}.progress-track i{display:block;height:100%;border-radius:inherit;background:var(--gold);transition:width .22s ease}.online-badge,.pill{display:inline-flex;align-items:center;min-height:26px;padding:0 10px;border-radius:100px;background:var(--green-light);color:var(--forest-2);font-size:10px;font-weight:700}.study-card{width:min(760px,100%);min-height:610px;display:flex;flex-direction:column;margin:auto;padding:30px 38px;border:1px solid #d4d0c4;border-radius:24px;background:#fffef9fa;box-shadow:var(--shadow)}.study-card-top{display:flex;justify-content:space-between}.icon-button,.sound-button,.favorite-button{border:0;background:transparent;cursor:pointer}.icon-button{width:38px;height:38px;border-radius:50%;background:var(--green-light)}.question-area{padding:34px 0 30px;text-align:center}.question-label{margin-bottom:15px;color:var(--muted);font-size:11px}.question-area h1{max-width:650px;margin:0 auto 10px;font-family:Georgia,"Noto Serif SC",serif;font-size:clamp(34px,6vw,58px);font-weight:400;line-height:1.24}.phonetic{color:#76857f;font-size:14px}.answer-area{display:grid;gap:18px;margin-top:auto}.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}.choice{min-height:66px;display:flex;align-items:center;gap:12px;padding:10px 14px;border:1px solid var(--line);border-radius:12px;background:#fff;cursor:pointer;text-align:left}.choice span{display:grid;place-items:center;flex:0 0 28px;height:28px;border-radius:7px;background:#eeece5;color:var(--muted);font-size:10px}.choice:hover,.choice.selected{border-color:var(--forest-2);background:#f0f6f3}.choice.selected span{background:var(--forest);color:#fff}.answer-input{min-height:70px;font-family:Georgia,serif;font-size:28px;text-align:center}.feedback{margin-top:auto;padding:22px;border-radius:15px}.feedback.correct{background:var(--green-light)}.feedback.wrong{background:var(--red-light)}.feedback-title{display:flex;align-items:center;gap:13px}.feedback-title>span{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:var(--forest);color:#fff}.wrong .feedback-title>span{background:var(--red)}.feedback-title p{margin-bottom:2px;color:var(--muted);font-size:10px}.feedback-title strong{font-size:20px}.example{margin:18px 0 0;padding-top:16px;border-top:1px solid rgba(23,51,45,.1);font-family:Georgia,serif;font-size:14px;line-height:1.6}.example small{display:block;color:var(--muted);font-family:Noto Sans SC,sans-serif}.grade-row{display:flex;gap:9px;margin-top:18px}.grade{flex:1;min-height:52px;border:1px solid rgba(23,51,45,.12);border-radius:10px;background:#ffffff8c;cursor:pointer;font-size:12px;font-weight:700}.grade small{display:block;margin-top:3px;color:var(--muted);font-size:9px;font-weight:400}.grade.good{background:var(--forest);color:#fff}.grade.good small{color:#b9c9c4}.completion-card,.empty-state{width:min(620px,100%);margin:auto;padding:60px 34px;text-align:center}.completion-card{border:1px solid var(--line);border-radius:24px;background:var(--paper);box-shadow:var(--shadow)}.completion-mark{display:grid;place-items:center;width:66px;height:66px;margin:0 auto 26px;border-radius:50%;background:var(--green-light);font-size:28px}.completion-card h1{font-family:Georgia,"Noto Serif SC",serif;font-size:36px;font-weight:400}.completion-card p:not(.eyebrow){margin-bottom:28px;color:var(--muted)}.toolbar{display:flex;gap:10px;margin-bottom:18px}.search-input{flex:1;background:var(--paper)}.filter-button{padding:0 16px;border:1px solid var(--line);border-radius:10px;background:var(--paper);cursor:pointer}.filter-button.active{border-color:var(--gold);background:var(--gold-light)}.word-list{display:grid;gap:8px}.word-row{display:grid;grid-template-columns:40px 1fr auto 40px;align-items:center;gap:14px;padding:16px 18px}.sound-button{width:38px;height:38px;border-radius:50%;background:var(--green-light)}.word-main>div{display:flex;align-items:baseline;gap:10px}.word-main h3{margin-bottom:3px;font-family:Georgia,serif;font-size:21px;font-weight:500}.word-main span,.word-main small,.word-main p{color:var(--muted);font-size:11px}.word-main p{margin:0}.priority{padding:4px 7px;border-radius:6px;background:#ece9df;color:var(--muted);font-size:9px;font-weight:700}.favorite-button{font-size:20px}.favorite-button.active{color:#c58e08}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}.stats-grid article{padding:22px}.stats-grid p{margin-bottom:18px;color:var(--muted);font-size:11px}.stats-grid strong{display:block;font-family:Georgia,serif;font-size:34px;font-weight:400}.stats-grid small{color:#8b938f;font-size:9px}.chart-panel{min-height:330px}.bar-chart{height:220px;display:flex;align-items:flex-end;gap:5px;padding-top:18px;border-bottom:1px solid var(--line)}.bar-column{height:100%;flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:7px}.bar-column i{width:min(16px,70%);min-height:4px;border-radius:4px 4px 0 0;background:var(--forest-2)}.bar-column small{height:18px;color:var(--muted);font-size:7px;writing-mode:vertical-rl}.insight-card,.success-banner,.info-box{display:flex;gap:14px;margin-top:16px;padding:18px;border-radius:13px;background:var(--green-light)}.insight-card>span{display:grid;place-items:center;flex:0 0 28px;height:28px;border-radius:50%;background:var(--forest);color:#fff;font-family:Georgia,serif}.insight-card strong{font-size:12px}.insight-card p,.info-box p{margin:4px 0 0;color:var(--muted);font-size:11px;line-height:1.6}.drop-zone{display:grid;place-items:center;padding:50px;border:1.5px dashed #a9aea6;border-radius:20px;background:#fcfbf6a6;cursor:pointer;text-align:center;transition:.15s ease}.drop-zone.active,.drop-zone:hover{border-color:var(--forest-2);background:var(--green-light)}.drop-zone>span{display:grid;place-items:center;width:52px;height:52px;margin-bottom:16px;border-radius:50%;background:var(--gold-light);font-size:23px}.drop-zone h3{margin-bottom:7px;font-family:Georgia,serif;font-size:22px;font-weight:500}.drop-zone p{margin-bottom:20px;color:var(--muted);font-size:11px}.validation-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:16px;margin-top:16px}.pill.danger{background:var(--red-light);color:var(--red)}.issue-list{max-height:190px;overflow:auto;margin:0 0 20px;padding:0;list-style:none}.issue-list li{padding:8px 0;border-top:1px solid var(--line);color:#8b712f;font-size:11px}.issue-list li.error{color:var(--red)}.preview-list>div{position:relative;padding:11px 0;border-top:1px solid var(--line)}.preview-list strong{font-family:Georgia,serif}.preview-list span{float:right;color:var(--muted);font-size:9px}.preview-list p{margin:3px 0 0;color:var(--muted);font-size:10px}.format-note{margin-top:16px;padding:24px}.format-note code{display:block;overflow-x:auto;margin:18px 0;padding:12px;border-radius:8px;background:#e9e5d8;color:#5e674f;font-size:10px;white-space:nowrap}.format-note p{margin:0;color:var(--muted);font-size:11px}.settings-layout{display:grid;grid-template-columns:1fr 1fr;gap:16px}.settings-section{display:grid;align-content:start;gap:18px}.settings-section:nth-child(3){grid-column:1 / -1}.settings-section label{margin:0}.field-with-unit{position:relative}.field-with-unit span{position:absolute;top:50%;right:14px;transform:translateY(-50%);color:var(--muted);font-size:11px}.range{min-height:28px;padding:0;accent-color:var(--forest)}.retention-scale{display:flex;justify-content:space-between;margin-top:-16px;color:var(--muted);font-size:9px}.info-box{display:block;margin:0}.danger-text{color:var(--red)}.settings-actions{grid-column:1 / -1;display:flex;align-items:center;justify-content:flex-end;gap:14px}.saved-message{color:var(--forest-2);font-size:12px}.empty-state{color:var(--muted)}.empty-state.compact{padding:70px 20px}@media(max-width:950px){.app-shell{display:block}.sidebar{display:none}.main-content{min-height:100vh;padding-bottom:68px}.mobile-header{position:sticky;top:0;z-index:15;display:flex;align-items:center;justify-content:space-between;min-height:64px;padding:0 22px;border-bottom:1px solid rgba(216,212,200,.8);background:#f3f0e7e6;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.mobile-header .brand-mark{width:32px;height:32px;border-radius:9px;font-size:18px}.bottom-nav{position:fixed;right:0;bottom:0;left:0;z-index:30;display:flex;justify-content:space-around;height:66px;padding-bottom:env(safe-area-inset-bottom);border-top:1px solid var(--line);background:#fcfbf6f0;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px)}.bottom-nav a{min-width:55px;display:grid;place-content:center;justify-items:center;gap:2px;color:#77817d}.bottom-nav span{font-size:19px}.bottom-nav small{font-size:9px}.bottom-nav .router-link-exact-active{color:var(--forest)}.page{padding:34px 24px 60px}.hero-grid{grid-template-columns:1fr 1fr}.focus-card{grid-column:1 / -1}.stats-grid{grid-template-columns:1fr 1fr}.auth-layout{grid-template-columns:1fr}.auth-story{min-height:360px;padding:32px}.auth-story h1{font-size:40px}.story-metric{display:none}}@media(max-width:650px){.page{padding-right:18px;padding-left:18px}.page-header{display:block}.page-header .button{margin-top:22px}.hero-grid,.section-grid,.validation-grid,.settings-layout{grid-template-columns:1fr}.settings-section:nth-child(3),.settings-actions{grid-column:auto}.study-page{padding:20px 12px 30px}.study-header{grid-template-columns:auto 1fr auto;gap:12px;margin-bottom:18px}.study-header .text-link{font-size:0}.study-header .text-link:before{content:"←";font-size:20px}.study-card{min-height:calc(100vh - 120px);padding:22px 18px;border-radius:20px}.question-area{padding:28px 0 24px}.choice-grid{grid-template-columns:1fr}.grade-row{flex-wrap:wrap}.grade{min-width:90px}.word-row{grid-template-columns:36px 1fr 34px;padding:14px 12px}.word-row .priority{display:none}.stats-grid{grid-template-columns:1fr 1fr}.stats-grid article{padding:17px}.drop-zone{padding:38px 18px}.auth-story{min-height:290px}.auth-story h1{font-size:34px}.auth-story>div>p:last-child{display:none}.auth-form-wrap{min-height:calc(100vh - 290px);padding:34px 22px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important}}
