@import "https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,600;700&family=Manrope:wght@400;500;600;700;800&family=Noto+Sans+JP:wght@400;500;700&display=swap";:root{color:#221d1a;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at 0 0,#ffffffe0,#0000 38%),linear-gradient(135deg,#efe4d8 0%,#f5f1ea 48%,#ebeef7 100%);font-family:Manrope,Noto Sans JP,sans-serif}*{box-sizing:border-box}html{min-height:100%}body{min-height:100vh;margin:0}body:before{content:"";pointer-events:none;background-color:#0000;background-image:linear-gradient(90deg,#ffffff0f 1px,#0000 1px),linear-gradient(#ffffff0f 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:4.5rem 4.5rem;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;position:fixed;inset:0;-webkit-mask-image:linear-gradient(#000000a6,#0000 92%);mask-image:linear-gradient(#000000a6,#0000 92%)}button,input,select{font:inherit}button{cursor:pointer}#root{min-height:100vh}.app-shell{grid-template-columns:17rem minmax(0,1fr) 18rem;gap:1rem;min-height:100vh;padding:1rem;display:grid}.workspace{gap:1rem;display:grid}.panel{background:var(--surface-tint,#ffffffc7);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid #221d1a14;border-radius:1.75rem;animation:.56s cubic-bezier(.18,.8,.24,1) both panel-rise;position:relative;overflow:hidden;box-shadow:0 24px 80px #221d1a14}.panel:after{content:"";pointer-events:none;background:linear-gradient(140deg,#ffffff59,#0000 45%);position:absolute;inset:0}.sidebar,.inspector{align-self:start;padding:1.5rem;position:sticky;top:1rem}.sidebar{min-height:calc(100vh - 2rem)}.eyebrow{letter-spacing:.18em;text-transform:uppercase;color:var(--accent,#0f766e);margin:0 0 .5rem;font-size:.74rem;font-weight:700}h1,h2,h3,h4,strong{color:#171210}h1,h2{margin:0;font-family:Fraunces,Noto Sans JP,serif;font-weight:700;line-height:1}h1{font-size:clamp(2rem,2.4vw,2.7rem)}h2{letter-spacing:-.04em;font-size:clamp(2rem,4vw,3.4rem)}h3,h4,p{margin:0}.sidebar-copy,.inspector-copy,.muted-copy,.lesson-row p,.lesson-status span,.section-note,.browser-row span,.mini-stat span{color:#665e58}.nav-stack{gap:.65rem;margin-top:1.5rem;display:grid}.nav-button,.primary-button,.secondary-button,.tone-button,.audio-button,.pair-tile,.browser-row,.danger-button{border:0;transition:transform .18s,background-color .18s,box-shadow .18s,color .18s}.nav-button{background:#fff6;border-radius:1rem;justify-content:space-between;align-items:center;padding:.95rem 1rem;display:flex}.nav-button.is-active,.nav-button:hover,.browser-row.is-selected,.pair-tile.is-selected{background:var(--accent-soft,#0f766e26);transform:translateY(-1px)}.nav-badge,.section-note{background:#ffffffbf;border-radius:999px;justify-content:center;align-items:center;min-width:2rem;padding:.15rem .6rem;display:inline-flex}.hero-panel,.section-panel,.split-panel,.review-panel,.browser-panel,.settings-panel{padding:1.5rem}.metric-grid,.answer-grid,.settings-grid,.pair-grid,.inspector-stack{gap:.85rem;display:grid}.metric-grid{grid-template-columns:repeat(4,minmax(0,1fr));margin-top:1.35rem}.hero-actions{gap:.75rem;margin-top:1.1rem;display:flex}.metric,.mini-stat{background:#ffffff9e;border-radius:1.2rem;padding:1rem}.metric span,.mini-stat span,.answer-grid span,.detail-strip span{color:#6f655d;margin-bottom:.35rem;font-size:.8rem;display:block}.metric strong,.mini-stat strong,.answer-grid strong{font-size:1.4rem}.section-header{justify-content:space-between;align-items:start;gap:1rem;margin-bottom:1rem;display:flex}.lesson-list,.browser-list,.weak-list{gap:.8rem;display:grid}.lesson-row,.weak-row{border-top:1px solid #221d1a14;grid-template-columns:minmax(0,1fr) auto;gap:1rem;padding:1rem 0;display:grid}.lesson-row:first-child{border-top:0}.lesson-meta{color:var(--accent,#0f766e);margin-bottom:.35rem;font-size:.8rem}.lesson-status{text-align:right}.lesson-meter,.meter-track,.browser-meter{background:#221d1a14;border-radius:999px;height:.45rem;overflow:hidden}.lesson-meter{grid-column:1/-1}.lesson-meter span,.meter-fill,.browser-meter span{border-radius:inherit;background:linear-gradient(90deg, var(--accent,#0f766e), #fff);height:100%;display:block}.split-panel{grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.meter{margin-top:1rem}.meter-row{justify-content:space-between;align-items:center;margin-bottom:.4rem;display:flex}.review-panel .card-stage{gap:1.1rem;display:grid}.card-head{justify-content:space-between;align-items:start;gap:1rem;display:flex}.card-submeta,.detail-strip{flex-wrap:wrap;gap:.7rem;display:flex}.card-submeta span{background:#ffffffa6;border-radius:999px;padding:.35rem .7rem}.answer-field,.settings-grid label{gap:.45rem;display:grid}.search-input,select,input[type=text],.answer-field input{background:#ffffffc7;border:1px solid #221d1a1f;border-radius:1rem;width:100%;padding:.9rem 1rem}.primary-button,.secondary-button,.audio-button,.tone-button,.danger-button{border-radius:1rem;padding:.9rem 1.1rem}.primary-button,.audio-button.is-speaking{color:#fff;background:var(--accent,#0f766e)}.secondary-button,.tone-button,.audio-button,.danger-button,.browser-row,.pair-tile{background:#ffffff9e}.answer-sheet,.browser-detail{background:#ffffffad;border-radius:1.2rem;gap:1rem;padding:1rem;display:grid}.answer-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.detail-strip{justify-content:space-between}.score-row,.filter-row{gap:.75rem;display:grid}.score-row{grid-template-columns:repeat(4,minmax(0,1fr))}.filter-row{grid-template-columns:2.2fr repeat(3,1fr);margin-bottom:1rem}.browser-list{content-visibility:auto}.browser-row,.pair-tile{text-align:left;border-radius:1.2rem;grid-template-columns:minmax(0,1fr) minmax(0,1fr) 8rem;align-items:center;gap:1rem;padding:1rem;display:grid}.browser-meter{width:100%}.inspector-copy{margin:0 0 1rem;font-weight:600}.pair-grid{grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:1rem}.settings-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:1rem}.empty-state{text-align:center;place-items:center;gap:.5rem;min-height:18rem;display:grid}@keyframes panel-rise{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@media (width<=1100px){.app-shell{grid-template-columns:1fr}.sidebar,.inspector{min-height:unset;position:static}.metric-grid,.answer-grid,.settings-grid,.split-panel,.pair-grid,.filter-row,.browser-row,.score-row{grid-template-columns:1fr}.hero-actions{flex-direction:column}}.auth-panel{background:#ffffff8c;border:1px solid #0f172a0f;border-radius:1.2rem;flex-direction:column;gap:.75rem;padding:1.1rem 1.2rem;display:flex}.auth-panel--signed-in{background:var(--accent-soft,#0f766e1f)}.auth-hint{color:#1e293bbf;margin:0;font-size:.88rem;line-height:1.5}.auth-field{color:#1e293bd9;flex-direction:column;gap:.35rem;font-size:.85rem;font-weight:500;display:flex}.auth-field input{background:#fff;border:1px solid #0f172a1f;border-radius:.65rem;padding:.55rem .75rem;font-size:.95rem}.auth-field input:focus{outline:2px solid var(--accent,#0f766e);outline-offset:1px;border-color:#0000}.auth-button{background:var(--accent,#0f766e);color:#fff;cursor:pointer;border:0;border-radius:999px;align-self:flex-start;padding:.55rem 1.1rem;font-weight:600;transition:transform .18s,box-shadow .18s,opacity .18s}.auth-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #0f172a24}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-button--secondary{color:var(--accent,#0f766e);border:1px solid var(--accent,#0f766e);background:0 0}.sync-status{margin:0;font-size:.85rem;font-weight:500}.sync-status--local{color:#64748be6}.sync-status--cloud{color:var(--accent,#0f766e)}.auth-success{color:#059669;margin:0;font-size:.9rem}.auth-error{color:#b91c1c;margin:0;font-size:.9rem}.modal-backdrop{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a8c;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:1.25rem;flex-direction:column;gap:1rem;width:100%;max-width:420px;padding:1.75rem;display:flex;box-shadow:0 24px 60px #0f172a59}.modal-hint{color:#1e293bbf;margin:0;font-size:.92rem}.diagnostic-word{text-align:center;background:var(--accent-soft,#0f766e24);border-radius:1rem;flex-direction:column;align-items:center;gap:.35rem;padding:1.25rem;display:flex}.diagnostic-word strong{color:#0f172a;font-size:2.2rem;font-weight:700}.diagnostic-word span{color:#1e293bbf;text-transform:uppercase;letter-spacing:.08em;font-size:.8rem}.diagnostic-word em{color:#1e293ba6;font-size:.95rem;font-style:normal}.modal-actions{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.modal-actions .primary-button,.modal-actions .secondary-button{cursor:pointer;border:0;border-radius:999px;padding:.7rem 1rem;font-weight:600}.modal-actions .primary-button{background:var(--accent,#0f766e);color:#fff}.modal-actions .secondary-button{color:var(--accent,#0f766e);border:1px solid var(--accent,#0f766e);background:0 0}.modal-footer{color:#1e293bb3;justify-content:space-between;align-items:center;font-size:.85rem;display:flex}.link-button{color:#1e293bcc;cursor:pointer;background:0 0;border:0;padding:0;font-size:.85rem;text-decoration:underline}.cloze-prompt{word-break:break-word;font-size:1.35rem;line-height:1.5}.cloze-hint{color:#1e293bb3;margin:.25rem 0 0;font-size:.88rem}.cloze-hint strong{color:#1e293bf2;font-weight:600}.settings-actions{flex-wrap:wrap;gap:.75rem;display:flex}.discriminate-options{flex-direction:column;gap:.6rem;display:flex}.discriminate-option{text-align:left;cursor:pointer;background:#fff;border:1px solid #0f172a1f;border-radius:.9rem;flex-direction:column;align-items:flex-start;gap:.25rem;padding:.8rem 1rem;transition:transform .18s,border-color .18s,background-color .18s;display:flex}.discriminate-option:hover{border-color:var(--accent,#0f766e);transform:translateY(-1px)}.discriminate-option.is-selected{border-color:var(--accent,#0f766e);background:var(--accent-soft,#0f766e1f)}.discriminate-option strong{font-size:1.05rem}.discriminate-option span{color:#1e293bbf;font-size:.85rem;line-height:1.4}.insights-panel{flex-direction:column;gap:1rem;display:flex}.insight-grid{grid-template-columns:repeat(4,1fr);gap:.9rem;display:grid}.insight{background:#ffffff8c;border:1px solid #0f172a0f;border-radius:1rem;flex-direction:column;gap:.3rem;padding:1rem;display:flex}.insight span{color:#1e293bbf;text-transform:uppercase;letter-spacing:.06em;font-size:.82rem}.insight strong{color:#0f172a;font-size:1.6rem;font-weight:700}.insight strong em{color:#1e293bb3;margin-left:.3rem;font-size:.85rem;font-style:normal;font-weight:500}@media (width<=900px){.insight-grid{grid-template-columns:repeat(2,1fr)}}.language-pick-grid{grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}.language-pick-tile{cursor:pointer;background:#ffffffe6;border:1px solid #0f172a1f;border-radius:1rem;flex-direction:column;justify-content:center;align-items:center;gap:.25rem;padding:1.1rem .9rem;transition:transform .18s,border-color .18s,box-shadow .18s,background-color .18s;display:flex}.language-pick-tile:hover{border-color:var(--accent,#0f766e);transform:translateY(-2px);box-shadow:0 10px 24px #0f172a1f}.language-pick-tile strong{color:#0f172a;font-size:1.4rem;font-weight:700}.language-pick-tile span{color:#1e293bb3;font-size:.8rem}.multilingual-hint{color:#1e293ba6;font-size:.85rem;line-height:1.5}@media (width<=500px){.language-pick-grid{grid-template-columns:1fr}}
