:root{--bg: #0e0f11;--bg2: #16181c;--bg3: #1e2026;--border: #2a2d35;--border2: #363a44;--text: #e8eaf0;--text2: #9aa0b4;--text3: #5a6070;--accent: #c9a96e;--accent2: #e8c98a;--p1: #4a9eff;--p1b: #0f2a4a;--p2: #3ecf8e;--p2b: #0a2e1e;--p3: #f5a623;--p3b: #2e1e05;--p4: #a78bfa;--p4b: #1e1535;--p5: #f87171;--p5b: #2e0f0f;--p6: #94a3b8;--p6b: #1a1f2a;--radius: 10px;--radius-sm: 6px;--font: "DM Sans", sans-serif;--font-serif: "DM Serif Display", serif;--font-mono: "DM Mono", monospace;--sidebar-w: 240px;--header-h: 60px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);height:100vh;overflow:hidden;display:flex;flex-direction:column}#root{display:flex;flex-direction:column;height:100vh;overflow:hidden}.header{height:var(--header-h);background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:16px;flex-shrink:0;z-index:10}.logo{font-family:var(--font-serif);font-size:20px;color:var(--accent);letter-spacing:-.02em}.logo span{color:var(--text2);font-family:var(--font);font-size:13px;font-weight:400;margin-left:8px}.header-stats{margin-left:auto;display:flex;gap:24px}.hstat{text-align:right}.hstat-num{font-size:18px;font-weight:600;color:var(--accent);font-family:var(--font-mono)}.hstat-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.08em}.hamburger{display:none;background:none;border:1px solid var(--border);color:var(--text);cursor:pointer;font-size:16px;padding:5px 10px;border-radius:var(--radius-sm);line-height:1;transition:background .15s;flex-shrink:0}.hamburger:hover{background:var(--bg3)}.layout{display:flex;flex:1;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--bg2);border-right:1px solid var(--border);overflow-y:auto;flex-shrink:0}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;top:var(--header-h);background:#0000008c;z-index:99}.sidebar-search-wrap{position:relative;padding:10px 12px 4px;display:flex;align-items:center}.sidebar-search-icon{position:absolute;left:22px;font-size:11px;pointer-events:none;opacity:.5}.sidebar-search{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:12px;padding:7px 28px;outline:none;transition:border-color .15s}.sidebar-search:focus{border-color:var(--border2)}.sidebar-search::placeholder{color:var(--text3)}.sidebar-search::-webkit-search-cancel-button{display:none}.sidebar-search-clear{position:absolute;right:18px;background:none;border:none;color:var(--text3);cursor:pointer;font-size:10px;padding:4px;line-height:1;transition:color .1s}.sidebar-search-clear:hover{color:var(--text)}.search-results{padding-bottom:8px}.search-result-btn{flex-direction:column;align-items:flex-start!important;gap:1px!important;padding-left:16px!important}.search-result-info{display:flex;flex-direction:column;gap:1px}.search-result-name{font-size:12px;color:var(--text)}.search-result-phase{font-size:10px;font-family:var(--font-mono)}.search-empty{padding:24px 16px;font-size:12px;color:var(--text3);text-align:center;line-height:1.5}.phase-group{border-bottom:1px solid var(--border)}.phase-btn{width:100%;text-align:left;padding:12px 16px;background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:10px;transition:background .15s;color:var(--text)}.phase-btn:hover,.phase-btn.active{background:var(--bg3)}.phase-icon{width:28px;height:28px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0;font-family:var(--font-mono)}.phase-text{flex:1;min-width:0}.phase-name{font-size:12px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.phase-sub{font-size:10px;color:var(--text3);margin-top:1px}.phase-chevron{font-size:10px;color:var(--text3);transition:transform .2s;flex-shrink:0}.phase-chevron.open{transform:rotate(180deg)}.subject-list{display:none;background:var(--bg)}.subject-list.open{display:block}.subject-btn{position:relative;width:100%;text-align:left;padding:7px 16px 7px 54px;background:none;border:none;cursor:pointer;font-size:12px;color:var(--text2);transition:background .1s,color .1s;display:flex;align-items:center;justify-content:space-between;gap:8px;font-family:var(--font)}.subject-btn:hover{background:var(--bg2);color:var(--text)}.subject-btn.active{background:var(--bg2);color:var(--text);font-weight:500}.subject-btn.active:before{content:"";position:absolute;left:0;width:2px;height:20px;background:var(--accent);border-radius:0 2px 2px 0}.subj-xp{font-size:10px;color:var(--text3);font-family:var(--font-mono);flex-shrink:0}.main{flex:1;overflow-y:auto;padding:32px 36px}.main::-webkit-scrollbar{width:4px}.main::-webkit-scrollbar-track{background:transparent}.main::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 120px);text-align:center}.welcome-title{font-family:var(--font-serif);font-size:42px;color:var(--accent);letter-spacing:-.02em;margin-bottom:12px;line-height:1.1}.welcome-sub{font-size:15px;color:var(--text2);max-width:400px;line-height:1.6;margin-bottom:40px}.welcome-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:480px;margin-bottom:40px}.welcome-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:20px 16px;cursor:pointer;transition:border-color .15s,transform .15s}.welcome-card:hover{border-color:var(--accent);transform:translateY(-2px)}.welcome-card-num{font-size:28px;font-weight:600;color:var(--accent);font-family:var(--font-mono)}.welcome-card-label{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-top:4px}.welcome-boards{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.board-tag{font-size:11px;padding:4px 10px;border-radius:20px;border:1px solid;font-weight:500}.progress-bar{height:2px;background:var(--border);border-radius:1px;margin-bottom:28px}.progress-fill{height:2px;border-radius:1px;transition:width .4s ease}.breadcrumb{font-size:11px;color:var(--text3);margin-bottom:10px;display:flex;align-items:center;gap:6px;font-family:var(--font-mono)}.breadcrumb-sep{opacity:.4}.breadcrumb-pct{margin-left:auto;color:var(--text3);font-size:10px}.lesson-title{font-family:var(--font-serif);font-size:32px;color:var(--text);letter-spacing:-.02em;margin-bottom:14px;line-height:1.15}.lesson-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px;align-items:center}.badge{font-size:11px;padding:4px 10px;border-radius:20px;border:1px solid;font-weight:500;white-space:nowrap;font-family:var(--font-mono)}.badge-xp{background:#3ecf8e1a;color:#3ecf8e;border-color:#3ecf8e4d}.badge-time{background:var(--bg2);color:var(--text2);border-color:var(--border)}.badge-abrsm{background:#4a9eff1a;color:#4a9eff;border-color:#4a9eff4d;font-family:var(--font)}.badge-rcm{background:#3ecf8e1a;color:#3ecf8e;border-color:#3ecf8e4d;font-family:var(--font)}.badge-anzca{background:#f5a6231a;color:#f5a623;border-color:#f5a6234d;font-family:var(--font)}.badge-rsl{background:#f871711a;color:#f87171;border-color:#f871714d;font-family:var(--font)}.badge-all{background:var(--bg2);color:var(--text2);border-color:var(--border);font-family:var(--font)}.section{margin-bottom:28px}.section-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:12px;display:flex;align-items:center;gap:8px}.section-title:before{content:"";display:block;width:16px;height:1px;background:var(--border2)}.divider{height:1px;background:var(--border);margin:24px 0}.obj-list{list-style:none}.obj-list li{font-size:13px;color:var(--text2);padding:8px 0;border-bottom:1px solid var(--border);display:flex;gap:10px;align-items:flex-start;line-height:1.5}.obj-list li:last-child{border-bottom:none}.obj-list li:before{content:"→";color:var(--accent);flex-shrink:0;font-family:var(--font-mono);font-size:12px;margin-top:1px}.content-block{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;margin-bottom:8px}.content-block h4{font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px}.content-block p{font-size:13px;color:var(--text2);line-height:1.65}.ex-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.ex-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:16px;cursor:pointer;transition:border-color .15s,background .15s,transform .15s,box-shadow .15s;text-align:left;text-decoration:none;display:flex;flex-direction:column;gap:8px}.ex-card:hover{border-color:var(--accent);background:var(--bg3);transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.ex-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.ex-card-icon{font-size:22px;line-height:1;flex-shrink:0}.ex-card-badge{font-size:9px;padding:3px 7px;border-radius:10px;background:#c9a96e1a;border:1px solid rgba(201,169,110,.2);color:var(--accent);font-family:var(--font-mono);white-space:nowrap;line-height:1.4}.ex-card-title{font-size:13px;font-weight:600;color:var(--text);line-height:1.3}.ex-card-game{font-size:11.5px;color:var(--text2);line-height:1.55;flex:1}.ex-card-play{font-size:10px;color:var(--accent);font-family:var(--font-mono);margin-top:2px}.drill-list{list-style:none}.drill-list li{font-size:13px;color:var(--text2);padding:7px 0;border-bottom:1px solid var(--border);display:flex;gap:10px;line-height:1.5}.drill-list li:last-child{border-bottom:none}.drill-list li:before{content:"◦";color:var(--text3);flex-shrink:0;font-family:var(--font-mono)}.tip-list{list-style:none}.tip-list li{font-size:13px;color:var(--text2);padding:10px 14px;border-radius:var(--radius-sm);background:#c9a96e12;border:1px solid rgba(201,169,110,.2);margin-bottom:8px;display:flex;gap:10px;line-height:1.5}.tip-list li:before{content:"★";color:var(--accent);flex-shrink:0;font-size:11px;margin-top:2px}.res-list{list-style:none}.res-list li{font-size:12px;color:var(--text2);padding:6px 0;border-bottom:1px solid var(--border);display:flex;gap:10px;align-items:flex-start;line-height:1.5;font-family:var(--font-mono)}.res-list li:last-child{border-bottom:none}.res-list li:before{content:"↗";color:var(--text3);flex-shrink:0}.gam-panel{background:linear-gradient(135deg,#c9a96e12,#c9a96e08);border:1px solid rgba(201,169,110,.22);border-radius:14px;padding:22px;display:flex;flex-direction:column;gap:18px}.gam-mechanic-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.gam-mechanic-card{background:#ffffff08;border:1px solid var(--border);border-radius:var(--radius);padding:16px 10px;display:flex;flex-direction:column;align-items:center;gap:5px;text-align:center}.gam-mechanic-boss{border-color:#c9a96e47;background:#c9a96e0f}.gam-mechanic-icon{font-size:1.6rem;line-height:1}.gam-mechanic-value{font-size:.82rem;font-weight:700;color:var(--text);letter-spacing:.01em}.gam-mechanic-label{font-size:.68rem;color:var(--text3);line-height:1.3}.musesync-cta{display:flex;align-items:center;justify-content:center;gap:10px;background:var(--accent);color:#0e0f11;font-weight:700;font-size:.88rem;border-radius:var(--radius);padding:13px 20px;text-decoration:none;transition:opacity .15s,transform .15s;letter-spacing:.01em}.musesync-cta:hover{opacity:.88;transform:translateY(-1px)}.musesync-cta-arrow{font-size:1rem}.musesync-stores{display:flex;gap:12px;justify-content:center;align-items:center;padding-top:2px}.store-badge{display:flex;align-items:center}.store-badge img{height:34px;object-fit:contain;border-radius:6px;opacity:.9;transition:opacity .15s}.store-badge:hover img{opacity:1}.nav-btns{display:flex;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}.nav-btn{flex:1;padding:12px 16px;font-size:12px;cursor:pointer;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text2);transition:all .15s;display:flex;align-items:center;gap:8px;font-family:var(--font)}.nav-btn:hover{border-color:var(--accent);color:var(--text)}.nav-btn.next{justify-content:flex-end}.nav-btn-label{font-size:11px;color:var(--text3)}.nav-spacer{flex:1}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}@media (max-width: 768px){.hamburger{display:block}.hstat-hide-sm{display:none}.header{padding:0 16px;gap:10px}.logo{font-size:17px}.header-stats{gap:16px}.hstat-num{font-size:15px}.sidebar{position:fixed;top:var(--header-h);left:0;height:calc(100vh - var(--header-h));transform:translate(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);z-index:100;box-shadow:6px 0 24px #00000080}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.main{padding:20px 18px 32px}.gam-mechanic-grid{grid-template-columns:repeat(2,1fr)}.musesync-stores{flex-direction:column;gap:8px}.nav-btns{flex-direction:column}.nav-btn.next{justify-content:flex-start}.ex-grid{grid-template-columns:1fr}}
