:root{--bg:#f3f5f8;--panel:#ffffffb8;--ink:#0f172a;--muted:#5b6474;--accent:#2563eb;--line:#0f172a14;--shadow:0 28px 80px #0f172a1a;color:var(--ink);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at top,#5687ff24,#0000 28%),linear-gradient(#f5f7fb 0%,#eff2f7 100%);font:16px/1.5 SF Pro Display,SF Pro Text,-apple-system,BlinkMacSystemFont,Helvetica Neue,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:radial-gradient(circle at 20% 0,#5687ff24,#0000 26%),linear-gradient(#f7f9fc 0%,#eff2f7 100%);min-width:320px;margin:0}a,button,input,textarea,select{font:inherit}button{color:inherit;cursor:pointer}#root{width:100%;min-height:100vh}h1,h2,h3{color:var(--ink);letter-spacing:-.05em;margin:0;font-weight:700;line-height:.98}h1{max-width:none;font-size:clamp(2.2rem,6vw,4rem)}h2{max-width:none;font-size:clamp(1.8rem,4vw,2.8rem)}h3{font-size:1.35rem}p{margin:0}.app-preview-page{place-items:center;min-height:100vh;padding:18px 0 28px;display:grid}.device-stage{width:min(100%,458px)}.device-shell{background:linear-gradient(#fffffff2,#f1f5f9fa),radial-gradient(circle at top,#60a5fa1f,#0000 45%);border:1px solid #0f172a14;border-radius:42px;grid-template-rows:auto auto minmax(0,1fr) auto;gap:12px;height:min(900px,100vh - 36px);padding:14px;display:grid;overflow:hidden;box-shadow:0 30px 80px #0f172a2e,inset 0 1px #ffffffb3}.status-bar,.app-header,.section-top,.welcome-meta,.card-meta,.link-row,.profile-top,.bottom-nav,.nav-item,.belt-chip,.technique-item,.summary-top{display:flex}.status-bar,.section-top,.welcome-meta,.link-row,.summary-top,.bottom-nav{justify-content:space-between}.status-bar,.app-header,.nav-item,.profile-top,.tournament-hero,.technique-detail{align-items:center}.app-header,.screen-stack,.welcome-card,.welcome-copy,.quick-card,.section-card,.module-grid,.module-card,.media-card,.media-copy,.timeline-list,.timeline-card,.card-list,.info-card,.mini-points,.kyu-hero,.kyu-hero-copy,.belt-switcher,.belt-layout,.belt-summary,.summary-points,.technique-list,.technique-item>div,.technique-detail,.technique-copy,.detail-box,.tournament-hero>div,.profile-card,.profile-grid,.media-inline{gap:12px;display:grid}.status-bar{color:#667085;padding:2px 8px 0;font-size:.8rem;font-weight:700}.app-header{grid-template-columns:1fr auto;padding:2px 4px 0}.brand-block{align-items:center;gap:.85rem;display:flex}.brand-logo{object-fit:cover;object-position:center top;border:2px solid #ffffffd9;border-radius:999px;width:3.25rem;height:3.25rem;box-shadow:0 10px 24px #0f172a2e}.app-header h1,.welcome-card h2,.section-card h2,.section-card h3,.profile-card h3,.technique-copy h4{color:#0f172a;letter-spacing:0;margin:0;line-height:1.02}.app-header h1{font-size:2.5rem}.screen-scroll{padding:4px 2px;overflow:auto}.screen-scroll::-webkit-scrollbar{width:0;height:0}.screen-stack{gap:14px}.eyebrow{text-transform:uppercase;letter-spacing:.1em;color:#2563eb;margin:0;font-size:.73rem;font-weight:700}.eyebrow-invert{color:#ffffffb3}.avatar-pill{color:#fff;background:linear-gradient(#111827,#374151);border-radius:50%;place-items:center;width:44px;height:44px;font-weight:700;display:grid}.welcome-card,.section-card,.quick-card,.info-card,.technique-item,.profile-card,.tournament-hero{background:#ffffffd6;border:1px solid #0f172a12;border-radius:28px;padding:16px}.welcome-card{color:#fff;background:radial-gradient(circle at 100% 0,#3b82f633,#0000 32%),linear-gradient(#111827,#0f172a 68%,#172554);border:0;gap:18px}.welcome-copy p,.section-text,.module-card p,.info-card p,.media-copy p,.timeline-card p,.mini-points p,.kyu-hero-copy p,.belt-summary p,.technique-item p,.technique-copy p,.tournament-hero p,.profile-card p{color:#667085;margin:0}.welcome-copy p:last-child,.welcome-meta span,.accent-card p,.welcome-card h2{color:#fff}.welcome-card h2,.section-card h2{font-size:1.7rem}.welcome-meta{flex-wrap:wrap;gap:8px}.welcome-meta span,.pill,.filter-chip,.belt-chip strong,.belt-chip small{font-size:.78rem}.welcome-meta span,.pill{border-radius:999px;justify-content:center;align-items:center;min-height:32px;padding:0 12px;font-weight:700;display:inline-flex}.welcome-meta span{background:#ffffff1f}.quick-grid,.profile-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.mode-switcher,.favorite-strip{gap:8px;display:grid}.mode-switcher{grid-template-columns:repeat(3,minmax(0,1fr))}.favorite-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.quick-card{text-align:left;cursor:pointer;background:#ffffffe6;border:0}.quick-kicker,.summary-label,.detail-box span,.card-meta,.stat-card span,.profile-grid span{text-transform:uppercase;letter-spacing:.06em;color:#6b7280;font-size:.76rem;font-weight:700}.quick-card strong,.module-card strong,.info-card strong,.media-copy h3,.timeline-card span,.belt-summary strong,.technique-item strong,.technique-copy h4,.detail-box strong,.profile-grid strong,.tournament-hero h3{color:#0f172a}.quick-card p,.accent-card strong,.accent-card .quick-kicker{margin:0}.accent-card{background:linear-gradient(#dbeafe,#bfdbfe)}.section-card{background:#ffffffdb}.compact-card{gap:8px}.section-top{flex-wrap:wrap;align-items:flex-start;gap:12px}.section-top>div{min-width:0}.pill{color:#1d4ed8;white-space:normal;text-align:center;background:#2563eb1a;max-width:100%}.pill.dark{color:#fff;background:#111827}.module-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.module-card,.timeline-card,.stat-card,.detail-box,.profile-grid article{background:#f8fafceb;border-radius:22px;padding:14px}.media-card,.media-inline,.kyu-hero,.tournament-hero,.technique-detail{overflow:hidden}.media-card img,.media-inline img,.kyu-hero img,.technique-detail img,.tournament-hero img{object-fit:cover;border-radius:22px;width:100%}.media-card img{height:240px}.media-inline img,.tournament-hero img{height:180px}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.link-row{gap:10px}.link-row a,.kyu-hero-copy a{color:#1d4ed8;font-weight:700;text-decoration:none}.timeline-card{grid-template-columns:auto 1fr;align-items:start}.timeline-card span{color:#1d4ed8;background:#dbeafe;border-radius:50%;place-items:center;width:38px;height:38px;display:grid}.filter-row{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.filter-chip{color:#64748b;background:#ffffffc7;border:0;border-radius:18px;min-height:42px;font-weight:700}.filter-chip.active{color:#fff;background:#0f172a}.time-line{color:#0f172a;font-size:1rem;font-weight:700}.mini-points p+p{border-top:1px solid #0f172a14;padding-top:10px}.favorite-card{background:#f8fafcf5;border-radius:20px;padding:14px}.favorite-card p{color:#667085;margin:0}.kyu-hero{background:linear-gradient(#f8fbff,#edf4ff);border:1px solid #3b82f61f;border-radius:28px;padding:16px}.kyu-hero img{object-position:center top;height:220px}.belt-switcher{grid-template-columns:repeat(2,minmax(0,1fr))}.belt-chip{background:#f8fafcf5;border:1px solid #0000;border-radius:22px;flex-direction:column;align-items:center;gap:10px;padding:10px}.belt-chip strong,.belt-chip small{line-height:1.1;display:block}.belt-chip small{color:#6b7280;overflow-wrap:anywhere;text-align:center}.belt-dot{border-radius:50%;width:18px;height:18px}.belt-chip.yellow .belt-dot{background:linear-gradient(#fde047,#facc15)}.belt-chip.white .belt-dot{background:linear-gradient(#fff,#d1d5db);border:1px solid #0f172a1f}.belt-chip.orange .belt-dot{background:linear-gradient(#fb923c,#ea580c)}.belt-chip.green .belt-dot{background:linear-gradient(#22c55e,#16a34a)}.belt-chip.blue .belt-dot{background:linear-gradient(#60a5fa,#2563eb)}.belt-chip.brown .belt-dot{background:linear-gradient(#a16207,#713f12)}.belt-chip.black .belt-dot{background:linear-gradient(#111827,#020617)}.belt-chip.active{border-color:#3b82f63d;box-shadow:inset 0 0 0 1px #3b82f61a}.belt-layout{grid-template-columns:1fr;align-items:start}.belt-summary,.technique-list{background:#f8fafceb;border-radius:24px;padding:14px}.summary-points p+p{border-top:1px solid #0f172a14;padding-top:8px}.technique-item{text-align:left;background:linear-gradient(90deg,#22c55e1f,#facc151f);border:0;border-radius:16px;grid-template-columns:42px minmax(0,1fr);align-items:center;gap:10px;width:100%;padding:10px}.technique-item span{color:#0f172a;text-align:center;background:#ffffffe6;border-radius:50%;place-items:center;width:38px;height:38px;font-size:.8rem;font-weight:700;display:grid}.technique-item strong{overflow-wrap:anywhere;font-size:.98rem;line-height:1.14;display:block}.technique-item p{overflow-wrap:anywhere;font-size:.82rem;line-height:1.2}.belt-summary strong,.technique-copy h4{overflow-wrap:anywhere;line-height:1.12}.technique-item.active{outline:2px solid #2563eb2e}.technique-detail{grid-template-columns:1fr}.technique-detail img{object-position:center top;height:300px}.technique-copy{padding:4px 2px 0}.latin-caption{color:#94a3b8;font-size:.92rem}.tournament-hero{gap:14px;padding:16px}.favorite-toggle{color:#0f172a;background:#0f172a14;border:0;border-radius:999px;min-height:34px;padding:0 12px;font-size:.78rem;font-weight:700}.favorite-toggle.active{color:#fff;background:#0f172a}.profile-card{background:radial-gradient(circle at 100% 0,#bfdbfeb3,#0000 32%),#ffffffe0}.profile-avatar{color:#fff;background:linear-gradient(#111827,#334155);border-radius:50%;place-items:center;width:56px;height:56px;font-weight:700;display:grid}.profile-top{grid-template-columns:auto 1fr;gap:14px}.bottom-nav{background:#ffffffe6;border:1px solid #0f172a0f;border-radius:26px;gap:8px;padding:8px}.nav-item{color:#6b7280;background:0 0;border:0;border-radius:18px;flex-direction:column;flex:1 1 0;justify-content:center;gap:6px;min-height:58px;font-size:.76rem;font-weight:700}.nav-item.active{color:#1d4ed8;background:#eff6ff}.nav-dot{background:currentColor;border-radius:50%;width:10px;height:10px}@media (width<=720px){.app-preview-page{padding:0}.device-stage{width:100%}.device-shell{border-radius:0;height:100vh;padding:12px}}@media (width<=520px){.quick-grid,.module-grid,.belt-layout,.profile-grid{grid-template-columns:1fr}.belt-switcher,.filter-row{grid-template-columns:repeat(2,minmax(0,1fr))}.mode-switcher,.favorite-strip{grid-template-columns:1fr}.media-card img,.kyu-hero img,.technique-detail img{height:220px}}
