:root{--font-en:"Hanken Grotesk", "Zen Kaku Gothic New", system-ui, sans-serif;--font-jp:"Zen Kaku Gothic New", "Hanken Grotesk", system-ui, sans-serif;--bg:#f4f1ea;--surface:#fff;--surface-2:#faf8f3;--surface-3:#f0ece2;--ink:#23241f;--ink-2:#5e6057;--ink-3:#8d8f84;--line:#e7e2d6;--line-2:#efebe1;--primary:#2f7d5b;--primary-deep:#245f46;--primary-ink:#1f5440;--primary-soft:#e6f0ea;--primary-tint:#f0f6f2;--speak:#2f7d5b;--speak-soft:#e6f0ea;--speak-ink:#1f5440;--listen:#3f72a6;--listen-soft:#e8eef6;--listen-ink:#2b507c;--write:#c07a3c;--write-soft:#f6ecdf;--write-ink:#8c531f;--read:#8a5fa6;--read-soft:#f0e9f5;--read-ink:#5f3d78;--amber:#d98a3d;--amber-soft:#f8ecdc;--good:#2f7d5b;--good-soft:#e6f0ea;--bad:#c2533f;--bad-soft:#f6e6e1;--r-xs:8px;--r-sm:12px;--r:16px;--r-lg:22px;--r-xl:28px;--pill:999px;--sh-sm:0 1px 2px #28261e0d, 0 1px 3px #28261e0a;--sh:0 2px 6px #28261e0d, 0 6px 18px #28261e0d;--sh-lg:0 8px 30px #28261e1a;--sidebar-w:248px;--maxw:1080px;--bottomnav-h:64px;--topbar-h:56px}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font-en);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;line-height:1.5}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,textarea{font-family:inherit}a{color:inherit;text-decoration:none}:lang(ja),.jp{font-family:var(--font-jp)}.en{font-family:var(--font-en);letter-spacing:-.01em}::selection{background:var(--primary-soft)}.app{width:100%;min-height:100vh}.shell-scroll{margin-left:var(--sidebar-w);min-width:0}.page{max-width:var(--maxw);margin:0 auto;padding:40px 48px 96px}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--line);z-index:20;flex-direction:column;flex-shrink:0;height:100vh;padding:22px 16px 18px;display:flex;position:fixed;top:0;left:0}.brand{align-items:center;gap:10px;padding:6px 10px 22px;display:flex}.brand-mark{background:var(--primary);color:#fff;border-radius:10px;flex-shrink:0;place-items:center;width:34px;height:34px;display:grid;box-shadow:0 2px 8px #2f7d5b59}.brand-name{letter-spacing:-.02em;font-size:19px;font-weight:800}.brand-name .k{color:var(--primary)}.nav{flex-direction:column;gap:3px;display:flex}.nav-item{border-radius:var(--r-sm);color:var(--ink-2);text-align:left;align-items:center;gap:12px;width:100%;padding:10px 12px;font-size:14.5px;font-weight:600;transition:background .14s,color .14s;display:flex}.nav-item svg{flex-shrink:0;width:20px;height:20px}.nav-item:hover{background:var(--surface-2);color:var(--ink)}.nav-item.active{background:var(--primary-soft);color:var(--primary-ink)}.nav-item.active svg{stroke:var(--primary)}.nav-label{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);padding:18px 12px 8px;font-size:11px;font-weight:700}.sidebar-foot{margin-top:auto}.streak-chip{background:var(--amber-soft);border-radius:var(--r);border:1px solid #f0e2cd;align-items:center;gap:11px;padding:12px 14px;display:flex}.streak-flame{width:36px;height:36px;color:var(--amber);background:#fff;border-radius:10px;flex-shrink:0;place-items:center;display:grid}.streak-num{font-size:18px;font-weight:800;line-height:1}.streak-cap{color:var(--ink-2);font-size:11.5px;font-weight:600}.topbar,.bottom-nav{display:none}.topbar-brand{align-items:center;gap:9px;display:flex}.topbar-brand .brand-mark{border-radius:9px;width:30px;height:30px}.topbar-brand .brand-name{font-size:17px}.topbar-actions{align-items:center;gap:10px;display:flex}.topbar-streak{background:var(--amber-soft);color:var(--amber);border-radius:var(--pill);align-items:center;gap:6px;padding:5px 10px;font-size:13px;font-weight:800;display:inline-flex}.topbar-gear{border-radius:var(--pill);width:38px;height:38px;color:var(--ink-2);place-items:center;display:grid}.topbar-gear:hover{background:var(--surface-2);color:var(--ink)}.topbar-gear.active{color:var(--primary)}.bottom-nav-item{border-radius:var(--r-sm);color:var(--ink-3);flex-direction:column;flex:1;align-items:center;gap:3px;min-width:0;padding:7px 0 4px;font-size:10.5px;font-weight:700;display:flex;position:relative}.bottom-nav-item svg{width:23px;height:23px}.bottom-nav-item.active{color:var(--primary)}.bottom-nav-badge{background:var(--amber);color:#fff;border-radius:var(--pill);text-align:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:800;line-height:16px;position:absolute;top:2px;left:calc(50% + 8px)}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm)}.card-pad{padding:22px 24px}.h-eyebrow{letter-spacing:.1em;text-transform:uppercase;color:var(--primary);font-size:12px;font-weight:700}.h1{letter-spacing:-.025em;margin:0;font-size:30px;font-weight:800;line-height:1.15}.h2{letter-spacing:-.02em;margin:0;font-size:21px;font-weight:800}.h3{letter-spacing:-.01em;margin:0;font-size:16px;font-weight:700}.muted{color:var(--ink-2)}.faint{color:var(--ink-3)}.tnum{font-variant-numeric:tabular-nums}.section-title{justify-content:space-between;align-items:center;margin:0 0 14px;display:flex}.section-title h2{letter-spacing:-.02em;font-size:18px;font-weight:800}.btn{border-radius:var(--pill);white-space:nowrap;justify-content:center;align-items:center;gap:8px;padding:11px 18px;font-size:14.5px;font-weight:700;transition:transform 80ms,background .14s,box-shadow .14s,border-color .14s;display:inline-flex}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn svg{width:18px;height:18px}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 10px #2f7d5b47}.btn-primary:hover{background:var(--primary-deep)}.btn-ghost{background:var(--surface-2);color:var(--ink);border:1px solid var(--line)}.btn-ghost:hover{background:var(--surface-3)}.btn-soft{background:var(--primary-soft);color:var(--primary-ink)}.btn-soft:hover{background:#dce9e1}.btn-lg{padding:14px 24px;font-size:16px}.btn-sm{padding:8px 14px;font-size:13px}.btn-block{width:100%}.btn-icon{border-radius:var(--pill);background:var(--surface-2);border:1px solid var(--line);width:40px;height:40px;color:var(--ink);justify-content:center;align-items:center;padding:0;display:inline-flex}.btn-icon:hover{background:var(--surface-3)}.pill{border-radius:var(--pill);background:var(--surface-2);color:var(--ink-2);border:1px solid var(--line);white-space:nowrap;align-items:center;gap:6px;padding:5px 11px;font-size:12.5px;font-weight:700;display:inline-flex}.pill svg{width:14px;height:14px}.skill-badge{border-radius:8px;justify-content:center;align-items:center;width:26px;height:26px;font-size:12.5px;font-weight:800;display:inline-flex}.sb-s{background:var(--speak-soft);color:var(--speak-ink)}.sb-l{background:var(--listen-soft);color:var(--listen-ink)}.sb-w{background:var(--write-soft);color:var(--write-ink)}.sb-r{background:var(--read-soft);color:var(--read-ink)}.skill-badge.dim{background:var(--surface-3);color:var(--ink-3)}.bar{border-radius:var(--pill);background:var(--surface-3);height:8px;overflow:hidden}.bar>i{border-radius:var(--pill);background:var(--primary);height:100%;display:block}.chip{border-radius:var(--pill);background:var(--surface);border:1px solid var(--line);color:var(--ink-2);align-items:center;gap:7px;padding:7px 13px;font-size:13.5px;font-weight:600;transition:all .14s;display:inline-flex}.chip:hover{border-color:var(--primary);color:var(--primary-ink);background:var(--primary-tint)}.chip.on{background:var(--primary);color:#fff;border-color:var(--primary)}.grid{gap:18px;display:grid}.g-2{grid-template-columns:1fr 1fr}.g-3{grid-template-columns:repeat(3,1fr)}.row{align-items:center;gap:12px;display:flex}.row.wrap{flex-wrap:wrap}.spread{justify-content:space-between;align-items:center;gap:12px;display:flex}.stack{flex-direction:column;display:flex}.ph{border-radius:var(--r);color:#a9a293;background:repeating-linear-gradient(45deg,#eee9dd 0 10px,#f3efe5 10px 20px);border:1px dashed #d8d1c0;place-items:center;font-family:ui-monospace,monospace;font-size:11px;display:grid}.page-head{margin-bottom:26px}.page-head .h1{margin-bottom:6px}.page-head.spread{align-items:flex-end}.back-row{align-items:center;gap:10px;margin-bottom:18px;display:flex}.back-btn{color:var(--ink-2);border-radius:var(--pill);align-items:center;gap:6px;padding:6px 12px 6px 8px;font-size:14px;font-weight:600;display:inline-flex}.back-btn:hover{background:var(--surface-2);color:var(--ink)}.back-btn svg{width:18px;height:18px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.08)}}@keyframes viewIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.view-in{animation:.26s viewIn}.tabs{background:var(--surface-3);border-radius:var(--pill);gap:4px;padding:4px;display:inline-flex}.tab{border-radius:var(--pill);color:var(--ink-2);white-space:nowrap;padding:9px 18px;font-size:14px;font-weight:700;transition:all .14s}.tab:hover{color:var(--ink)}.tab.on{background:var(--surface);color:var(--ink);box-shadow:var(--sh-sm)}.seg{background:var(--surface-3);border-radius:var(--pill);padding:3px;display:inline-flex}.seg button{border-radius:var(--pill);color:var(--ink-2);white-space:nowrap;padding:6px 13px;font-size:12.5px;font-weight:700}.seg button.on{background:var(--surface);color:var(--ink);box-shadow:var(--sh-sm)}.shell-scroll::-webkit-scrollbar{width:11px}.shell-scroll::-webkit-scrollbar-thumb{border:3px solid var(--bg);background:#ddd6c8;border-radius:99px}.shell-scroll::-webkit-scrollbar-track{background:0 0}.lift{transition:transform .16s,box-shadow .16s,border-color .16s}.lift:hover{box-shadow:var(--sh);border-color:#ddd6c7;transform:translateY(-2px)}.clickable{cursor:pointer}.only-mobile{display:none}@media (width<=767px){.sidebar{display:none}.only-mobile{display:revert}.only-desktop{display:none!important}.shell-scroll{margin-left:0}.page{max-width:100%;padding:18px 16px calc(var(--bottomnav-h) + 24px + env(safe-area-inset-bottom,0px))}.topbar{z-index:30;height:var(--topbar-h);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);background:#ffffffeb;justify-content:space-between;align-items:center;padding:0 14px;display:flex;position:sticky;top:0}.bottom-nav{z-index:30;background:var(--surface);border-top:1px solid var(--line);padding:6px 6px calc(6px + env(safe-area-inset-bottom,0px));gap:2px;display:flex;position:fixed;bottom:0;left:0;right:0}.grid.g-2,.grid.g-3{grid-template-columns:1fr}.h1{font-size:25px}.card-pad{padding:18px}.page-head{margin-bottom:20px}.page-head.spread{flex-direction:column;align-items:flex-start;gap:14px}.tabs{-webkit-overflow-scrolling:touch;max-width:100%;display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{padding:9px 14px}}@media (width<=479px){.h1{font-size:23px}.btn-lg{padding:13px 18px;font-size:15px}}
