:root{--bg: #0a0e17;--bg-soft: #111726;--panel: #141b2d;--panel-2: #1a2336;--border: #243049;--text: #e6ecf5;--muted: #a3b1cc;--accent: #6c8cff;--accent-2: #8b5cf6;--eth: #627eea;--green: #34d399;--green-dim: #1f7a5c;--amber: #fbbf24;--amber-dim: #8a6516;--red: #f87171;--radius: 14px;--shadow: 0 8px 30px rgba(0, 0, 0, .4);font-synthesis:none}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Sans,Hiragino Kaku Gothic ProN,Noto Sans JP,Meiryo,Roboto,Helvetica,Arial,sans-serif;line-height:1.65;-webkit-font-smoothing:antialiased}a{color:var(--accent)}.app{max-width:1080px;margin:0 auto;padding:0 20px 80px}.app:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(900px 500px at 15% -10%,rgba(108,140,255,.12),transparent 60%),radial-gradient(800px 500px at 100% 0%,rgba(139,92,246,.1),transparent 55%);z-index:0}.app>*{position:relative;z-index:1}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:14px;padding:14px 0;margin-bottom:8px;background:linear-gradient(to bottom,#0a0e17f2,#0a0e17bf);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px}.brand .logo{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:18px;font-weight:800}.topbar .spacer{flex:1}.lang-toggle{border:1px solid var(--border);background:var(--panel);color:var(--text);padding:7px 14px;border-radius:999px;cursor:pointer;font-size:13px;font-weight:600;transition:all .15s}.lang-toggle:hover{border-color:var(--accent);color:var(--accent)}.nav{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0 28px}.nav button{border:1px solid var(--border);background:var(--panel);color:var(--muted);padding:8px 14px;border-radius:999px;cursor:pointer;font-size:13.5px;font-weight:600;transition:all .15s}.nav button:hover{color:var(--text);border-color:#36456a}.nav button.active{color:#fff;background:linear-gradient(135deg,#6c8cffe6,#8b5cf6e6);border-color:transparent}.hero{padding:34px 0 10px}.hero h1{font-size:clamp(40px,7vw,64px);margin:0 0 6px;letter-spacing:-1.5px;background:linear-gradient(135deg,#fff 20%,var(--accent) 90%);-webkit-background-clip:text;background-clip:text;color:transparent}.hero .subtitle{font-size:19px;color:var(--text);margin:0 0 10px;font-weight:600}.hero .tagline{color:var(--muted);max-width:680px;font-size:15px}.section{padding:22px 0 8px;scroll-margin-top:80px}.section h2{font-size:26px;margin:0 0 8px;letter-spacing:-.5px}.section .lead{color:var(--muted);max-width:760px;margin:0 0 20px;font-size:14.5px}.card{background:linear-gradient(180deg,var(--panel),var(--bg-soft));border:1px solid var(--border);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);margin-bottom:18px}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:720px){.grid2{grid-template-columns:1fr}}.mini{background:var(--panel-2);border:1px solid var(--border);border-radius:12px;padding:16px 18px}.mini h3{margin:0 0 6px;font-size:16px}.mini.ffg h3{color:var(--green)}.mini.ghost h3{color:var(--accent)}.mini p{margin:0;color:var(--muted);font-size:14px}.controls{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;align-items:center}.btn{border:1px solid var(--border);background:var(--panel-2);color:var(--text);padding:8px 16px;border-radius:10px;cursor:pointer;font-size:14px;font-weight:600;transition:all .12s}.btn:hover{border-color:var(--accent);transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));border-color:transparent;color:#fff}.btn.ghost-btn{background:transparent}.stat-row{display:flex;flex-wrap:wrap;gap:18px;margin:6px 0 18px}.stat{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:10px 16px;min-width:110px}.stat .k{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.5px}.stat .v{font-size:22px;font-weight:700;font-variant-numeric:tabular-nums}.epoch-block{margin-bottom:14px}.epoch-label{font-size:13px;color:var(--muted);margin-bottom:6px;font-weight:600}.slots{display:grid;grid-template-columns:repeat(16,1fr);gap:5px}@media(max-width:720px){.slots{grid-template-columns:repeat(8,1fr)}}.slot{aspect-ratio:1;border-radius:6px;background:var(--panel-2);border:1px solid var(--border);display:grid;place-items:center;font-size:11px;color:var(--muted);position:relative;transition:all .18s}@media(max-width:540px){.slot{font-size:0}.slot .cp-dot{font-size:9px}}.slot.checkpoint{border-color:var(--amber);box-shadow:inset 0 0 0 1px var(--amber-dim)}.slot.proposed{background:#6c8cff40;border-color:var(--accent);color:#fff}.slot.checkpoint.proposed{background:#fbbf2440;border-color:var(--amber)}.slot.missed{background:#f871711f;border-color:var(--red)}.slot.current{outline:2px solid #fff;outline-offset:1px;transform:scale(1.12);z-index:2}.slot .cp-dot{position:absolute;top:2px;right:3px;font-size:8px;color:var(--amber)}.legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:14px;font-size:12.5px;color:var(--muted)}.legend .item{display:flex;align-items:center;gap:6px}.legend .swatch{width:14px;height:14px;border-radius:4px;border:1px solid var(--border)}.swatch.cp{border-color:var(--amber);background:#fbbf2440}.swatch.normal{background:var(--panel-2)}.swatch.prop{background:#6c8cff40;border-color:var(--accent)}.swatch.miss{background:#f871711f;border-color:var(--red)}.swatch.just{background:#fbbf2440;border-color:var(--amber)}.swatch.fin{background:#34d39938;border-color:var(--green)}.val-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:6px;margin:10px 0 4px}@media(max-width:540px){.val-grid{grid-template-columns:repeat(6,1fr)}}.val{aspect-ratio:1;border-radius:8px;background:var(--panel-2);border:1px solid var(--border);cursor:pointer;display:grid;place-items:center;font-size:14px;transition:all .14s;padding:0;font-family:inherit;color:inherit}.val:hover{border-color:var(--accent)}.val.voted{background:#34d39938;border-color:var(--green)}.val.voted:after{content:"✓";color:var(--green);font-weight:800}.bar-wrap{margin:18px 0 8px}.bar-track{position:relative;height:34px;background:var(--panel-2);border:1px solid var(--border);border-radius:10px;overflow:hidden}.bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width .35s cubic-bezier(.2,.8,.2,1);display:grid;place-items:center}.bar-fill.justified{background:linear-gradient(90deg,var(--green-dim),var(--green))}.bar-threshold{position:absolute;top:-4px;bottom:-4px;width:2px;background:var(--amber)}.bar-threshold .tlabel{position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:11px;color:var(--amber);white-space:nowrap}.bar-pct{font-weight:700;font-size:13px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.link-diagram{display:flex;align-items:center;justify-content:center;gap:12px;margin:8px 0 16px;flex-wrap:wrap}.cp-node{border:2px solid var(--amber);background:#fbbf241f;border-radius:10px;padding:10px 16px;text-align:center;min-width:92px}.cp-node .role{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.cp-node .name{font-weight:700;font-size:15px}.cp-node.justified{border-color:var(--green);background:#34d39926}.cp-node.justified .name{color:var(--green)}.link-arrow{font-size:26px;color:var(--accent)}.link-arrow.lit{color:var(--green);text-shadow:0 0 10px rgba(52,211,153,.6)}.status-banner{padding:12px 16px;border-radius:10px;font-weight:600;font-size:14px;border:1px solid var(--border);background:var(--panel-2);color:var(--muted)}.status-banner.ok{color:var(--green);border-color:var(--green-dim);background:#34d3991a}.cp-track{display:flex;align-items:stretch;gap:0;overflow-x:auto;padding:8px 0 14px}.cp-card{flex:1 1 0;min-width:120px;border:2px solid var(--border);background:var(--panel-2);border-radius:12px;padding:14px 12px;text-align:center;transition:all .3s;position:relative}.cp-card .ep{font-size:12px;color:var(--muted)}.cp-card .cp-name{font-size:18px;font-weight:800;margin:4px 0}.cp-card .state-tag{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:2px 8px;border-radius:999px;display:inline-block}.cp-card .state-tag.none{background:var(--border);color:var(--muted)}.cp-card.justified{border-color:var(--amber);background:#fbbf241a}.cp-card.justified .state-tag{background:#fbbf2433;color:var(--amber)}.cp-card.finalized{border-color:var(--green);background:#34d3991f;box-shadow:0 0 20px #34d39926}.cp-card.finalized .state-tag{background:#34d39938;color:var(--green)}.cp-connector{display:flex;align-items:center;color:var(--border);font-size:20px;padding:0 2px}.cp-connector.lit{color:var(--amber)}.step-explainer{background:var(--panel-2);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:8px;padding:14px 16px;margin-top:8px;min-height:60px;font-size:14.5px}.step-meta{color:var(--muted);font-size:13px;margin-bottom:16px}.ghost-wrap{overflow-x:auto;padding:8px 0}.tree-svg{display:block;margin:0 auto;width:100%;height:auto}.ghost-node-label{font-size:12px}.ghost-legend{display:flex;gap:18px;flex-wrap:wrap;margin-top:10px;font-size:12.5px;color:var(--muted)}.ghost-dot{width:12px;height:12px;border-radius:50%;display:inline-block;margin-right:6px;vertical-align:middle}.gloss{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:720px){.gloss{grid-template-columns:1fr}}.gloss .term{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:12px 14px}.gloss .term .t{font-weight:700;color:var(--accent);margin-bottom:2px}.gloss .term .d{color:var(--muted);font-size:13.5px}.note{font-size:13px;color:var(--muted);border-left:3px solid var(--accent-2);padding:4px 0 4px 12px;margin-top:14px}.hint{font-size:12.5px;color:var(--muted);margin-bottom:10px;font-style:italic}.layer-badge{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.3px;padding:4px 12px;border-radius:999px;margin-bottom:10px;border:1px solid var(--border);cursor:help}.badge-ffg{color:var(--green);background:#34d3991f;border-color:var(--green-dim)}.badge-ghost{color:var(--accent);background:#6c8cff1f;border-color:#36456a}.badge-shared{color:var(--muted);background:var(--panel-2)}.cp-node .cp-sub{font-size:10px;color:var(--muted);margin-top:2px}.calc-box{background:var(--panel-2);border:1px solid var(--border);border-radius:12px;padding:16px 18px;margin-top:16px}.calc-box h3{margin:0 0 8px;font-size:15px;color:var(--accent)}.calc-intro{margin:0 0 12px;font-size:13.5px;color:var(--text)}.calc-step{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;margin-bottom:10px}.calc-num{flex:none;width:22px;height:22px;display:grid;place-items:center;border-radius:50%;background:var(--accent);color:#fff;font-weight:800;font-size:12px}.calc-example{margin:8px 0 0;font-size:13px;color:var(--muted);border-left:3px solid var(--accent-2);padding-left:12px}.about-card{display:flex;gap:20px;align-items:center}@media(max-width:540px){.about-card{flex-direction:column;text-align:center}}.about-avatar{width:96px;height:96px;border-radius:50%;border:2px solid var(--border);flex:none;object-fit:cover}.about-body{flex:1;min-width:0}.about-name{font-size:20px;font-weight:800}.about-org{color:var(--accent);font-size:14px;font-weight:600;margin-top:2px}.about-bio{color:var(--muted);font-size:14px;margin:10px 0 14px}.about-links{display:flex;flex-wrap:wrap;gap:10px}@media(max-width:540px){.about-links{justify-content:center}}.about-link{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:999px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);text-decoration:none;font-size:14px;font-weight:600;transition:all .14s}.about-link:hover{transform:translateY(-1px);border-color:var(--accent)}.about-link.x span{font-size:16px}.about-link.yt span{color:#f44}.footer{margin-top:50px;padding-top:20px;border-top:1px solid var(--border);color:var(--muted);font-size:13px;text-align:center}.footer a{color:var(--accent)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}g[role=button]:focus-visible{outline:none}g[role=button]:focus-visible circle:nth-of-type(1){stroke:var(--accent)}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}
