:root{--bg: #0d1117 !important;--bg-deep: #010409 !important;--bg-elev: #161b22 !important;--bg-elev-2: #21262d !important;--fg: #e6edf3 !important;--fg-dim: #8b949e !important;--fg-dimmer: #484f58 !important;--border: #30363d !important;--border-strong: #424a53 !important;--accent: #d4af37 !important;--accent-glow: rgba(212, 175, 55, .4) !important;--danger: #f85149 !important;--success: #3fb950 !important;--shadow-sm: 0 2px 8px rgba(0,0,0,.5) !important;--shadow-md: 0 8px 24px rgba(0,0,0,.6) !important;--shadow-glow: 0 0 20px var(--accent-glow) !important}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%!important;background-color:#0d1117!important}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans,Helvetica,Arial,sans-serif!important;background:var(--bg)!important;background-image:radial-gradient(circle at 50% -20%,rgba(212,175,55,.05),transparent 70%),radial-gradient(circle at 100% 100%,rgba(212,175,55,.02),transparent 50%)!important;background-attachment:fixed!important;color:var(--fg)!important;line-height:1.65!important;font-size:16px!important}.dojo-markdown-overhaul{color:#e6edf3!important;background-color:transparent!important;line-height:1.8!important}.dojo-markdown-overhaul h1{display:none!important}.dojo-markdown-overhaul h2,.dojo-markdown-overhaul h3,.dojo-markdown-overhaul h4{color:var(--accent)!important;border-bottom:1px solid var(--border)!important;margin-top:2rem!important;margin-bottom:1rem!important;position:relative;font-weight:700}.dojo-markdown-overhaul blockquote{margin:2rem 0!important;padding:1.5rem 2rem!important;background:var(--bg-elev)!important;border-left:4px solid var(--accent)!important;border-radius:0 12px 12px 0!important;font-style:italic!important;color:var(--fg)!important;box-shadow:var(--shadow-sm)!important;position:relative}.dojo-markdown-overhaul blockquote p{margin:0!important}.dojo-markdown-overhaul ul,.dojo-markdown-overhaul ol{padding-left:0!important;list-style:none!important}.dojo-markdown-overhaul li{background:var(--bg-elev-2)!important;margin-bottom:.75rem!important;padding:1rem 1.25rem!important;border-radius:10px!important;border:1px solid var(--border)!important;display:flex!important;align-items:center!important;gap:1rem!important;transition:transform .2s,border-color .2s!important}.dojo-markdown-overhaul li:hover{border-color:var(--accent)!important;transform:translate(4px)!important}.dojo-markdown-overhaul li:before{content:"◆"!important;color:var(--accent)!important;font-size:.8rem!important;flex-shrink:0!important}.dojo-markdown-overhaul li.task-list-item{display:flex!important;align-items:center!important}.dojo-markdown-overhaul li.task-list-item:before{display:none!important}.dojo-markdown-overhaul input[type=checkbox]{width:1.2rem!important;height:1.2rem!important;accent-color:var(--accent)!important;cursor:default!important}.dojo-markdown-overhaul code{background-color:var(--bg-deep)!important;color:#fc0!important;padding:.2rem .4rem!important;border-radius:4px!important;font-family:JetBrains Mono,ui-monospace,monospace!important;font-size:.9em!important;border:1px solid var(--border-strong)!important}.dojo-markdown-overhaul pre{background-color:var(--bg-deep)!important;padding:1.25rem!important;border-radius:12px!important;border:1px solid var(--accent-glow)!important;overflow:auto!important;box-shadow:inset 0 2px 10px #00000080!important}.dojo-markdown-overhaul pre code{background-color:transparent!important;padding:0!important;border:none!important;color:var(--fg)!important}.dojo-cta{box-shadow:0 0 15px var(--accent-glow)!important;font-weight:800!important;letter-spacing:.05em!important;text-transform:uppercase!important;border:2px solid var(--accent)!important}a{color:inherit}button{font-family:inherit;cursor:pointer}.app{min-height:100%;display:flex;flex-direction:column}.site-main{flex:1;max-width:980px;margin:0 auto;padding:40px 24px 60px;width:100%}.site-header{display:flex;align-items:center;gap:24px;padding:14px 28px;border-bottom:1px solid var(--border);background:var(--bg-elev);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.brand{display:flex;align-items:center;gap:10px;text-decoration:none}.brand-logo{width:36px;height:36px;border-radius:8px}.brand-name{font-weight:800;font-size:1.15rem;letter-spacing:-.01em}.brand-sub{font-size:.72rem;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.1em}.site-nav{display:flex;gap:22px;flex:1;margin-left:16px}.site-nav a{text-decoration:none;color:var(--fg-dim);font-size:.92rem;font-weight:500;padding:6px 0;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.site-nav a:hover{color:var(--fg)}.site-nav a.active{color:var(--fg);border-bottom-color:var(--accent)}.user-badge{padding:8px 14px;border-radius:999px;border:1px solid var(--border-strong);background:var(--bg-elev-2);color:var(--fg);font-size:.88rem;font-weight:500;transition:all .15s}.user-badge:hover{border-color:var(--accent);color:var(--accent)}.user-badge-form{display:flex;gap:6px;padding:4px}.user-badge-form input{background:transparent;border:none;color:var(--fg);outline:none;padding:4px 8px;font-size:.88rem;width:140px}.btn-tiny{background:var(--accent);color:#0b0f17;border:none;border-radius:999px;padding:4px 10px;font-size:.75rem;font-weight:700}.site-footer{text-align:center;padding:28px 20px;color:var(--fg-dimmer);font-size:.8rem;border-top:1px solid var(--border)}.footer-dot{margin:0 8px;opacity:.5}.btn{display:inline-block;padding:11px 22px;border-radius:8px;font-weight:600;font-size:.95rem;text-decoration:none;border:1px solid transparent;transition:all .15s;cursor:pointer}.btn-primary{background:var(--accent);color:#0b0f17;box-shadow:0 4px 14px color-mix(in srgb,var(--accent) 30%,transparent)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px color-mix(in srgb,var(--accent) 45%,transparent)}.btn-ghost{background:transparent;color:var(--fg-dim);border-color:var(--border-strong)}.btn-ghost:hover{color:var(--fg);border-color:var(--fg-dim)}.btn-large{padding:14px 28px;font-size:1rem}.breadcrumbs{font-size:.85rem;color:var(--fg-dim);margin-bottom:28px}.breadcrumbs a{text-decoration:none;color:var(--fg-dim);transition:color .15s}.breadcrumbs a:hover{color:var(--fg)}.breadcrumbs .current{color:var(--fg);font-weight:500}.breadcrumbs span{margin:0 8px;opacity:.5}.sensei{display:flex;align-items:center;gap:20px;background:var(--bg-elev);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:10px;padding:18px 20px;margin:28px 0}.sensei-lg{padding:24px 26px}.sensei-avatar{flex-shrink:0;width:64px;height:64px;border-radius:50%;overflow:hidden;border:2px solid var(--accent);box-shadow:0 0 12px var(--accent-glow)}.sensei-lg .sensei-avatar{width:80px;height:80px}.sensei-img{width:100%;height:100%;object-fit:cover}.sensei-quote{margin:0;padding:0;color:var(--fg);font-style:italic;font-size:.98rem;line-height:1.55}.sensei-lg .sensei-quote{font-size:1.1rem}.hero{position:relative;text-align:center;padding:60px 20px 40px;margin:-40px -24px 20px}.hero-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 30%,rgba(255,212,59,.18),transparent 60%);pointer-events:none}.hero-inner{position:relative}.hero-kanji{font-size:5rem;color:var(--accent);opacity:.15;font-weight:300;letter-spacing:.1em;line-height:1;margin-bottom:8px;font-family:serif}.hero-sensei{width:140px;height:140px;border-radius:50%;object-fit:cover;border:3px solid var(--accent);box-shadow:0 0 30px var(--accent-glow);margin-bottom:20px}.hero h1{font-size:3rem;margin:0 0 8px;font-weight:800;letter-spacing:-.02em}.hero .accent{color:var(--accent);text-shadow:0 0 40px rgba(255,212,59,.4)}.hero-brand{color:var(--fg-dim);font-size:.82rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin:0 0 16px}.tagline{color:var(--fg-dim);font-size:1.12rem;max-width:580px;margin:0 auto 14px}.hero-welcome{color:var(--fg);font-size:.95rem;margin-top:18px}.tracks{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px;margin:40px 0}.track-card{position:relative;text-decoration:none;background:var(--bg-elev);border:1px solid var(--border);border-radius:14px;padding:22px 22px 20px;transition:all .2s;overflow:hidden;display:flex;flex-direction:column;min-height:280px}.track-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent)}.track-card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 12px 32px #0006,0 0 0 1px var(--accent)}.track-kanji{position:absolute;top:16px;right:20px;font-size:4rem;line-height:1;color:var(--accent);opacity:.08;font-weight:300;font-family:serif}.track-header h2{margin:0 0 2px;font-size:1.5rem;font-weight:700}.track-tool{color:var(--accent);font-size:.78rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:14px}.track-blurb{color:var(--fg-dim);font-size:.88rem;margin:0 0 auto}.track-progress{margin:18px 0 14px}.mastery-bar{height:5px;background:var(--bg-deep);border-radius:99px;overflow:hidden;border:1px solid var(--border)}.mastery-fill{height:100%;background:linear-gradient(90deg,var(--accent),color-mix(in srgb,var(--accent) 60%,#fff));transition:width .4s;position:absolute;top:0;left:0}.mastery-fill.mastery-verified{background:linear-gradient(90deg,var(--success),#74d886)}.mastery-fill.mastery-self{background:repeating-linear-gradient(45deg,var(--accent),var(--accent) 4px,color-mix(in srgb,var(--accent) 60%,#000) 4px,color-mix(in srgb,var(--accent) 60%,#000) 8px);opacity:.7}.mastery-bar{position:relative}.mastery-self-label{color:var(--fg-dimmer);font-weight:400}.mastery-label{font-size:.78rem;color:var(--fg-dim);margin-top:6px}.track-cta{color:var(--fg);font-size:.88rem;font-weight:600}.track-card.locked{opacity:.5;cursor:not-allowed;filter:grayscale(.6)}.track-card.locked:before{background:var(--border-strong)}.track-card.locked:hover{transform:none;border-color:var(--border);box-shadow:none}.track-card.locked .track-cta{color:var(--fg-dim)}.how-it-works{margin-top:56px;padding:28px 0 12px;border-top:1px solid var(--border)}.how-it-works h3{font-size:1.25rem;margin:0 0 18px;color:var(--fg)}.steps-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:0;list-style:none;counter-reset:step}@media (max-width: 560px){.steps-grid{grid-template-columns:1fr}}.steps-grid li{counter-increment:step;background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:18px 18px 18px 52px;position:relative;font-size:.9rem;color:var(--fg-dim)}.steps-grid li:before{content:counter(step);position:absolute;left:16px;top:16px;width:26px;height:26px;border-radius:50%;background:var(--accent);color:#0b0f17;font-weight:800;font-size:.82rem;display:flex;align-items:center;justify-content:center}.steps-grid strong{color:var(--fg)}.teacher-cta{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:center;margin:48px 0 20px;padding:26px 28px;background:linear-gradient(135deg,var(--bg-elev),var(--bg-elev-2));border:1px solid var(--border-strong);border-left:4px solid var(--accent);border-radius:14px}.teacher-cta-icon{font-size:2.8rem;line-height:1;display:flex;align-items:center}.teacher-cta-logo{width:72px;height:72px;border-radius:14px}.teacher-cta-body h3{margin:0 0 8px;font-size:1.25rem;color:var(--fg)}.teacher-cta-body p{margin:0 0 14px;color:var(--fg-dim);font-size:.94rem}@media (max-width: 640px){.teacher-cta{grid-template-columns:1fr;text-align:center}}.video-guides{margin-top:56px;padding:28px 0 12px;border-top:1px solid var(--border)}.video-guides h3{font-size:1.25rem;margin:0 0 18px;color:var(--fg)}.video-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 640px){.video-grid{grid-template-columns:1fr}}.video-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:14px;padding:20px;overflow:hidden}.video-card h4{margin:0 0 6px;font-size:1.05rem;color:var(--accent);font-weight:700;letter-spacing:.02em}.video-card p{margin:0 0 14px;color:var(--fg-dim);font-size:.88rem}.video-card video{width:100%;border-radius:10px;border:1px solid var(--border);background:var(--bg-deep)}.track-header-big{display:flex;gap:24px;align-items:flex-start;padding:12px 0 20px}.track-icon-big{flex-shrink:0;width:80px;height:80px;border-radius:12px;background:linear-gradient(145deg,var(--bg-elev-2),var(--bg-elev));border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;font-size:2.4rem;color:var(--accent);font-family:serif;box-shadow:var(--shadow-glow)}.track-header-big h1{font-size:2.1rem;margin:0 0 6px;font-weight:800}.track-sub{color:var(--accent);font-size:.82rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.track-blurb-big{color:var(--fg-dim);margin:12px 0 14px}.track-mastery{display:flex;align-items:center;gap:12px}.track-mastery .mastery-bar{flex:1;max-width:300px}.track-mastery span{font-size:.82rem;color:var(--fg-dim)}.intro-card{display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:center;background:var(--bg-elev);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:12px;padding:18px 22px;margin:24px 0}.intro-card-icon{font-size:2rem}.intro-card-body h3{margin:0 0 4px;font-size:1.08rem}.intro-card-body p{margin:0;color:var(--fg-dim);font-size:.88rem}.belt-state{display:inline-block;padding:9px 16px;border-radius:8px;font-size:.85rem;font-weight:600;text-decoration:none;white-space:nowrap}.belt-state.primary{background:var(--accent);color:#0b0f17}.belt-state.primary:hover{filter:brightness(1.1)}.belt-state.done{background:transparent;color:var(--fg-dim);border:1px solid var(--border-strong)}.belt-state.done:hover{color:var(--fg);border-color:var(--fg-dim)}.belt-list{list-style:none;padding:0;margin:20px 0;display:flex;flex-direction:column;gap:10px}.belt-item a,.belt-locked-row{display:grid;grid-template-columns:52px 1fr auto;align-items:center;gap:16px;padding:16px 20px;background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;text-decoration:none;transition:all .15s}.belt-item a:hover{border-color:var(--accent);transform:translate(4px);box-shadow:-4px 0 0 var(--accent)}.belt-rank{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.05rem;background:var(--bg-deep);border:2px solid var(--accent);color:var(--accent)}.belt-item.done .belt-rank{background:var(--accent);color:#0b0f17}.belt-item.locked .belt-rank{border-color:var(--border-strong);color:var(--fg-dimmer);background:transparent}.belt-main{display:flex;flex-direction:column;gap:2px;min-width:0}.belt-num-label{font-size:.7rem;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.08em;font-weight:700}.belt-title{font-weight:600;color:var(--fg);font-size:1rem}.belt-arrow{color:var(--fg-dim);font-size:.85rem;font-weight:600}.belt-item.locked{opacity:.5}.belt-item.locked .belt-title{color:var(--fg-dim)}.belt-item.done .belt-arrow{color:var(--accent)}.intro{max-width:760px;margin:0 auto}.intro-hero{text-align:center;padding:20px 0 36px;border-bottom:1px solid var(--border)}.intro-badge{display:inline-block;padding:5px 14px;background:var(--bg-elev-2);border:1px solid var(--accent);border-radius:999px;color:var(--accent);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:18px}.intro-hero h1{font-size:2.3rem;margin:0 0 10px;font-weight:800}.intro-subtitle{color:var(--fg-dim);font-size:1.05rem;margin:0}.intro-section{margin:36px 0}.intro-section h2{font-size:1.35rem;font-weight:700;margin:0 0 16px;display:flex;align-items:center;gap:14px}.section-num{color:var(--accent);font-family:serif;font-size:1.6rem;opacity:.6;font-weight:300}.intro-section p{color:var(--fg);margin:10px 0}.tool-link{display:inline-block;margin-top:10px;color:var(--accent);font-weight:600;text-decoration:none;font-size:.95rem}.tool-link:hover{text-decoration:underline}.concept-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:14px}.concept-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.concept-card h4{margin:0 0 4px;color:var(--accent);font-size:.92rem;text-transform:uppercase;letter-spacing:.05em}.concept-card p{margin:0;font-size:.88rem;color:var(--fg-dim)}.intro-steps{padding-left:22px;counter-reset:istep;list-style:none}.intro-steps li{counter-increment:istep;position:relative;padding:8px 0 8px 28px;color:var(--fg);border-bottom:1px solid var(--border)}.intro-steps li:last-child{border-bottom:none}.intro-steps li:before{content:counter(istep);position:absolute;left:0;top:9px;width:20px;height:20px;border-radius:50%;background:var(--bg-elev-2);border:1px solid var(--border-strong);color:var(--fg);font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center}.storage-notice{display:flex;gap:14px;align-items:flex-start;margin:36px 0 0;padding:16px 18px;background:color-mix(in srgb,var(--accent) 8%,var(--bg-elev));border:1px solid color-mix(in srgb,var(--accent) 30%,var(--border));border-radius:10px}.storage-icon{font-size:1.4rem;flex-shrink:0;line-height:1.2}.storage-notice strong{color:var(--fg);font-size:.94rem;display:block;margin-bottom:4px}.storage-notice p{margin:0;color:var(--fg-dim);font-size:.86rem;line-height:1.6}.storage-notice em{color:var(--fg);font-style:normal;font-weight:600}.intro-cta{margin:40px 0 20px;padding:22px;text-align:center;background:var(--bg-elev);border:1px solid var(--border);border-radius:12px}.intro-done-row{display:flex;justify-content:center;align-items:center;gap:20px;flex-wrap:wrap}.intro-done-label{color:var(--success);font-weight:700}.belt-page{max-width:760px;margin:0 auto}.belt-header{text-align:center;margin-bottom:48px}.belt-title{font-size:2.25rem;font-weight:900;color:var(--accent);margin-bottom:32px;letter-spacing:-.02em}.belt-complete-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin:32px 0 0;padding:18px 22px;background:var(--bg-elev);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:10px;flex-wrap:wrap}.belt-complete-label{color:var(--fg);font-size:.94rem}.belt-complete-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.verif-badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:.68rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap;margin-left:8px}.verif-badge.verified{background:color-mix(in srgb,var(--success) 18%,transparent);color:var(--success);border:1px solid color-mix(in srgb,var(--success) 40%,transparent)}.verif-badge.self{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);cursor:help}.verif-hint{margin:14px 0 0;padding:12px 16px;font-size:.86rem;color:var(--fg-dim);background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;line-height:1.6}.verif-hint strong{color:var(--fg)}.verif-hint em{color:var(--success);font-style:normal;font-weight:700}.belt-nav{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}.belt-nav a,.nav-next.disabled{text-decoration:none;color:var(--fg);font-size:.92rem;font-weight:600;padding:10px 16px;border-radius:8px;transition:all .15s;border:1px solid var(--border)}.belt-nav a:hover{border-color:var(--accent);color:var(--accent)}.nav-next.disabled{opacity:.4;cursor:not-allowed;color:var(--fg-dim)}.markdown h1{display:none!important}.markdown h2{font-size:1.5rem;margin-top:40px;color:var(--accent);font-weight:700;padding-left:12px;border-left:2px solid var(--accent)}.markdown h3{font-size:1.2rem;margin-top:28px;font-weight:700;color:var(--fg)}.markdown p{margin:16px 0;line-height:1.8}.markdown code{background:var(--bg-deep)!important;color:#fc0!important;padding:.2rem .4rem!important;border-radius:4px!important;font-family:JetBrains Mono,ui-monospace,monospace!important;font-size:.9em!important;border:1px solid var(--border-strong)!important}.markdown pre{background:var(--bg-deep);border:1px solid var(--border);border-radius:12px;padding:20px;overflow-x:auto;line-height:1.6;box-shadow:inset 0 2px 10px #0006}.markdown pre code{background:transparent;padding:0;color:var(--fg);font-size:.88em;border:none}.markdown blockquote{border-left:5px solid var(--accent);padding:20px 24px;margin:30px 0;color:var(--fg);font-style:italic;background:var(--bg-elev);border-radius:0 12px 12px 0;box-shadow:var(--shadow-sm);font-size:1.1rem;position:relative}.markdown blockquote:before{content:"“";position:absolute;top:-10px;left:10px;font-size:3rem;color:var(--accent);opacity:.3;font-family:serif}.markdown blockquote p{margin:0}.markdown a{color:var(--accent);text-decoration:none;border-bottom:1px solid transparent;transition:all .2s}.markdown a:hover{border-bottom-color:var(--accent);background:#d4af371a}.markdown hr{border:none;border-top:2px solid var(--border);margin:40px 0}.markdown input[type=checkbox]{margin-right:12px;vertical-align:middle;width:20px;height:20px;accent-color:var(--accent)}.markdown ul,.markdown ol{padding-left:0;margin:20px 0;list-style:none}.markdown li{background:var(--bg-elev);border:1px solid var(--border);border-radius:12px;padding:16px 20px;margin-bottom:12px;display:flex!important;align-items:center!important;gap:12px;transition:transform .2s,border-color .2s;line-height:1.6}.markdown li:hover{border-color:var(--accent);transform:translate(4px);box-shadow:var(--shadow-sm)}.markdown li:not(.task-list-item):before{content:"◈";color:var(--accent);font-weight:700;flex-shrink:0}.markdown li.task-list-item:before{display:none!important}.dojo-cta{box-shadow:0 0 20px var(--accent-glow)!important;font-weight:800!important;letter-spacing:.05em!important;text-transform:uppercase!important;border:2px solid var(--accent)!important;transform:scale(1.02)}.markdown label{cursor:pointer}.setup-page{max-width:760px;margin:0 auto}.setup-hero{text-align:center;padding:20px 0 36px;border-bottom:1px solid var(--border)}.setup-badge{display:inline-block;padding:5px 14px;background:var(--bg-elev-2);border:1px solid var(--accent);border-radius:999px;color:var(--accent);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:18px}.setup-hero h1{font-size:2.3rem;margin:0 0 10px;font-weight:800}.setup-subtitle{color:var(--fg-dim);font-size:1.05rem;margin:0 0 20px}.setup-section{margin:36px 0}.setup-section h2{font-size:1.35rem;font-weight:700;margin:0 0 16px;display:flex;align-items:center;gap:14px}.setup-time{font-size:.78rem;color:var(--fg-dim);font-weight:400;background:var(--bg-elev-2);padding:3px 10px;border-radius:999px;border:1px solid var(--border)}.setup-steps{padding-left:22px;counter-reset:sstep;list-style:none}.setup-steps li{counter-increment:sstep;position:relative;padding:10px 0 10px 28px;color:var(--fg);border-bottom:1px solid var(--border)}.setup-steps li:last-child{border-bottom:none}.setup-steps li:before{content:counter(sstep);position:absolute;left:0;top:11px;width:20px;height:20px;border-radius:50%;background:var(--bg-elev-2);border:1px solid var(--border-strong);color:var(--fg);font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center}.setup-steps a{color:var(--accent)}.setup-steps code{background:var(--bg-deep);color:#fc0;padding:.15rem .35rem;border-radius:4px;font-size:.88em;border:1px solid var(--border-strong);font-family:JetBrains Mono,ui-monospace,monospace}.starter-downloads{margin-top:20px;padding:18px 22px;background:var(--bg-elev);border:1px solid var(--border);border-radius:12px}.starter-downloads h4{margin:0 0 12px;color:var(--accent);font-size:.92rem;text-transform:uppercase;letter-spacing:.05em}.starter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px}.starter-link{display:block;padding:10px 14px;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:8px;color:var(--fg);font-size:.85rem;font-weight:600;text-decoration:none;text-align:center;transition:all .15s}.starter-link:hover{border-color:var(--accent);color:var(--accent)}.quickstart-card{background:var(--bg-elev);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:12px;padding:22px 24px;margin:16px 0}.quickstart-card h3{margin:0 0 14px;font-size:1.1rem}.setup-table{width:100%;border-collapse:collapse;font-size:.9rem}.setup-table th{text-align:left;padding:10px 14px;background:var(--bg-elev-2);border:1px solid var(--border);color:var(--accent);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em}.setup-table td{padding:10px 14px;border:1px solid var(--border);color:var(--fg)}.setup-table .yes{color:var(--success);font-weight:700}.setup-table .no{color:var(--fg-dim)}.setup-footer-note{text-align:center;padding:28px 0;border-top:1px solid var(--border)}.setup-footer-note a{color:var(--accent)}@media print{.site-header,.site-footer,.breadcrumbs,.setup-hero button{display:none!important}.setup-page{max-width:100%;color:#000}.setup-page *{color:#000!important;background:#fff!important;border-color:#ccc!important}.setup-page h1,.setup-page h2,.setup-page h3,.setup-page h4{color:#000!important}.setup-badge{border:1px solid #000!important}.section-num{color:#666!important}.setup-table .yes{color:#228b22!important}.setup-table .no{color:#666!important}.starter-downloads{break-inside:avoid}}.badges-page{max-width:900px;margin:0 auto}.badges-section{margin:48px 0}.badges-section h2{font-size:1.4rem;font-weight:800;margin:0 0 6px}.badges-desc{color:var(--fg-dim);font-size:.9rem;margin:0 0 20px}.badges-grid{display:grid;gap:24px;justify-items:center}.badges-grid-single{grid-template-columns:1fr;max-width:350px;margin:0 auto}.badges-grid-levels{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.badges-grid-belts{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}.badge-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:16px;padding:20px;width:100%;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s}.badge-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #0006}.badge-card-gm{padding:30px}.badge-svg{width:100%;height:auto;max-width:280px}.badge-belt-svg{max-width:180px}.badge-grandmaster-svg{max-width:320px}@media print{.site-header,.site-footer,.breadcrumbs,.setup-hero button,.setup-hero .setup-badge{display:none!important}.badges-page{max-width:100%}.badges-page *{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.badge-card{background:#fff!important;border:1px solid #ddd!important;break-inside:avoid;page-break-inside:avoid}.badges-section{break-before:auto}.badges-grid-levels{grid-template-columns:repeat(2,1fr)}.badges-grid-belts{grid-template-columns:repeat(4,1fr)}.badges-section h2,.badges-desc,.setup-hero h1,.setup-subtitle{color:#000!important}}@media (max-width: 720px){.site-header{flex-wrap:wrap;padding:12px 16px}.site-nav{order:3;width:100%;margin:0;justify-content:space-between}.site-main{padding:24px 16px 40px}.hero h1{font-size:2.1rem}.hero-kanji{font-size:3.2rem}.hero-sensei{width:100px;height:100px}.track-header-big{flex-direction:column;gap:12px}.belt-item a,.belt-locked-row{grid-template-columns:40px 1fr auto;padding:14px 16px}.belt-rank{width:34px;height:34px;font-size:.9rem}.intro-card{grid-template-columns:1fr;text-align:center;gap:12px}}.belt-header-actions{display:flex;justify-content:center;margin:32px 0;padding:24px;background:var(--bg-elev);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-md)}.btn-large{padding:18px 36px!important;font-size:1.25rem!important;font-weight:800!important;letter-spacing:.05em!important;text-transform:uppercase!important;border-radius:8px!important}.dojo-cta{transition:transform .2s,box-shadow .2s,background-color .2s!important;text-decoration:none!important;display:inline-block!important;text-align:center!important}.dojo-cta:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px var(--accent-glow)!important;background-color:var(--accent)!important;color:#000!important}.btn-primary.dojo-cta{background-color:var(--accent)!important;color:#000!important}.btn-disabled{background:var(--bg-elev-2);color:var(--fg-dim);border:1px solid var(--border);cursor:not-allowed;opacity:.6}.dojo-cta-group{display:flex;flex-direction:column;align-items:center;gap:10px}.dojo-cta-hint{font-size:.88rem;color:var(--fg-dim);margin:0}:root{--header-height: 57px}main.site-main:has(.belt-page.split-view){max-width:none;padding:0;margin:0}.belt-page.split-view{display:flex;flex-direction:row;max-width:none;width:100%;height:calc(100vh - var(--header-height));overflow:hidden;padding:0;margin:0}.belt-page.split-view .belt-instructions-column{flex:0 0 40%;min-width:340px;overflow-y:auto;padding:24px 28px 40px;border-right:1px solid var(--border)}.belt-page.split-view .belt-editor-column{flex:1 1 60%;background:var(--bg-deep);position:relative;min-width:0}.belt-page.split-view .belt-editor-column iframe{display:block;width:100%;height:100%;border:0}.scratch-launch{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:40px 30px;text-align:center;gap:16px}.scratch-launch-img{width:120px;height:120px;border-radius:50%;object-fit:cover;border:3px solid var(--accent);box-shadow:0 0 24px var(--accent-glow)}.scratch-launch h3{margin:0;font-size:1.4rem;color:var(--fg)}.scratch-launch p{margin:0;color:var(--fg-dim);font-size:.92rem;max-width:360px}.scratch-launch-hint{font-size:.84rem!important;color:var(--fg-dimmer)!important;margin-top:8px!important}.scratch-launch-hint a{color:var(--accent);text-decoration:underline}.belt-page.split-view .belt-header-actions{margin:16px 0;padding:16px}.belt-page.split-view .btn-large{padding:12px 24px!important;font-size:1rem!important}@media (max-width: 1200px){.belt-page.split-view{flex-direction:column;height:auto;overflow:visible}.belt-page.split-view .belt-instructions-column{flex:1 1 auto;border-right:none;border-bottom:1px solid var(--border)}.belt-page.split-view .belt-editor-column{flex:0 0 600px;height:600px}}
