:root{--bg: #0c0e14;--bg-elevated: #12151f;--panel: #161a26;--panel-hover: #1c2130;--border: #2a3145;--border-strong: #3d465c;--text: #eef1f7;--muted: #8b95ab;--accent: #5fd4a4;--accent-dim: #3a9a74;--accent-2: #7ae8c0;--warn: #f0b429;--err: #f87171;--shadow-panel: 0 4px 24px rgba(0, 0, 0, .35), 0 0 0 1px rgba(255, 255, 255, .04);--shadow-die: 0 3px 0 #b8bcc4, 0 6px 12px rgba(0, 0, 0, .35);--r-sm: 6px;--r-md: 10px;--r-lg: 16px;--r-xl: 22px;--space-xs: .25rem;--space-sm: .5rem;--space-md: .85rem;--space-lg: 1.25rem;--space-xl: 1.75rem;font-family:DM Sans,Segoe UI,system-ui,sans-serif;line-height:1.45;color:var(--text);background-color:var(--bg);font-feature-settings:"tnum" 1}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(ellipse 120% 80% at 50% -20%,rgba(95,212,164,.12),transparent 50%),radial-gradient(ellipse 80% 50% at 100% 50%,rgba(122,232,192,.06),transparent 45%),radial-gradient(ellipse 60% 40% at 0% 80%,rgba(45,90,120,.08),transparent 40%),var(--bg)}#root{min-height:100vh}a{color:var(--accent)}.app{max-width:58rem;margin:0 auto;padding:var(--space-lg) var(--space-md)}.app--wide{max-width:72rem}.route-screen{display:grid;gap:var(--space-lg)}.site-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-sm) var(--space-lg);margin-bottom:var(--space-lg);padding:.75rem .9rem;border:1px solid var(--border);border-radius:var(--r-xl);background:linear-gradient(155deg,#ffffff14,#ffffff03 55%),var(--bg-elevated);box-shadow:var(--shadow-panel)}.brand{display:inline-flex;align-items:center;gap:var(--space-sm);text-decoration:none;color:var(--text);font-weight:700}.brand-mark{width:1.75rem;height:1.75rem;border-radius:50%;display:grid;place-items:center;font-size:.8rem;color:#061210;background:linear-gradient(165deg,var(--accent-2),var(--accent));box-shadow:0 4px 14px #5fd4a44d}.site-nav{display:inline-flex;flex-wrap:wrap;gap:var(--space-xs)}.site-nav-link{text-decoration:none;color:var(--muted);border:1px solid transparent;border-radius:999px;padding:.4rem .75rem;font-size:.875rem;transition:color .2s ease,background .2s ease,border-color .2s ease,transform .2s ease}.site-nav-link:hover{color:var(--text);background:#ffffff0d;border-color:var(--border);transform:translateY(-1px)}.site-nav-link.is-active{color:#061210;background:linear-gradient(165deg,var(--accent-2),var(--accent));border-color:transparent;box-shadow:0 2px 12px #5fd4a447}.hero{position:relative;overflow:hidden;padding:clamp(1.3rem,3.5vw,2.5rem);border:1px solid var(--border);border-radius:var(--r-xl);background:radial-gradient(circle at 90% -10%,rgba(122,232,192,.22),transparent 35%),linear-gradient(155deg,rgba(255,255,255,.08),transparent 45%),var(--panel);box-shadow:var(--shadow-panel)}.hero-kicker{margin:0 0 var(--space-sm);color:var(--accent-2);text-transform:uppercase;letter-spacing:.08em;font-size:.76rem;font-weight:700}.hero h1{margin:0;font-size:clamp(1.8rem,4.6vw,3rem);line-height:1.1}.hero-subtitle{margin:var(--space-md) 0 0;max-width:44rem;color:var(--muted);font-size:1rem}.hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-top:var(--space-lg)}.btn-link{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border:1px solid var(--border);color:var(--text);background:var(--bg-elevated);border-radius:var(--r-md);min-height:2.5rem;padding:.55rem 1rem;font-weight:600;transition:transform .2s ease,border-color .2s ease,background .2s ease}.btn-link:hover{transform:translateY(-1px);border-color:var(--border-strong);background:var(--panel-hover)}.btn-link--primary{color:#061210;border-color:transparent;background:linear-gradient(165deg,var(--accent-2),var(--accent) 45%,var(--accent-dim));box-shadow:0 2px 12px #5fd4a440}.feature-grid,.example-grid{display:grid;gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(12rem,1fr))}.feature-card,.example-card,.content-card{border:1px solid var(--border);border-radius:var(--r-lg);background:linear-gradient(155deg,rgba(255,255,255,.06),transparent 48%),var(--panel);box-shadow:var(--shadow-panel)}.feature-card,.example-card{padding:var(--space-lg)}.feature-card h2,.example-card strong,.content-card h2{margin-top:0}.content-card{padding:clamp(1rem,2.6vw,1.5rem)}.content-card h1{margin-top:0}.clean-list{margin:0;padding-left:1.2rem;display:grid;gap:.5rem}.clean-list--ordered{padding-left:1.35rem}.shell{background:linear-gradient(165deg,rgba(255,255,255,.04) 0%,transparent 42%),var(--panel);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-panel);padding:var(--space-xl) var(--space-lg);transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease}.shell:hover{border-color:var(--border-strong);box-shadow:0 5px 28px #0000005e,0 0 0 1px #ffffff0f}.shell--narrow{max-width:24rem;margin:0 auto}.shell+.shell{margin-top:var(--space-md)}.app-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:var(--space-md) var(--space-lg);margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--border)}.header-actions{display:inline-flex;align-items:center;gap:var(--space-sm)}.app-header h1{margin:0;flex:1 1 auto;min-width:0;font-size:clamp(1.35rem,3vw,1.75rem);font-weight:700;letter-spacing:-.02em;color:var(--text)}.app-header .title-block{display:flex;flex-direction:column;gap:var(--space-xs)}.app-header .subtitle{margin:0;font-size:.875rem;font-weight:400;color:var(--muted)}.lang-bar{flex:0 0 auto}.lang-label{display:inline-flex;align-items:center;gap:var(--space-sm);font-size:.875rem}.lang-select{font:inherit;padding:.4rem .65rem;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);border-radius:var(--r-md);min-width:4.75rem;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}.lang-select:hover{border-color:var(--border-strong)}h1{font-weight:700;margin:0 0 var(--space-sm);font-size:1.5rem}h2.section-title{margin:var(--space-lg) 0 var(--space-sm);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}button:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:focus:not(:focus-visible),input:focus:not(:focus-visible){outline:none}button{font:inherit;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);padding:.55rem 1.1rem;border-radius:var(--r-md);min-height:2.5rem;transition:background .15s ease,border-color .15s ease,transform .1s ease}button:hover:not(:disabled){background:var(--panel-hover);border-color:var(--border-strong)}button:active:not(:disabled){transform:scale(.98)}button:disabled{opacity:.45;cursor:not-allowed}button.small{min-height:auto;padding:.28rem .55rem;font-size:.75rem}.copy-code-btn{margin-left:var(--space-sm)}button.primary{border:1px solid transparent;background:linear-gradient(165deg,var(--accent-2),var(--accent) 45%,var(--accent-dim));color:#061210;box-shadow:0 2px 12px #5fd4a440}button.primary:hover:not(:disabled){filter:brightness(1.06);border-color:#fff3}input{font:inherit;padding:.55rem .75rem;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);border-radius:var(--r-md);max-width:100%;min-height:2.5rem;transition:border-color .15s ease}input:hover{border-color:var(--border-strong)}input::placeholder{color:var(--muted);opacity:.85}.muted{color:var(--muted);font-size:.9rem}.banner{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--r-md);font-size:.875rem;margin:var(--space-sm) 0;border:1px solid transparent}.banner--err{background:#f871711a;border-color:#f8717159;color:#fecaca}.banner--warn{background:#f0b4291a;border-color:#f0b42959;color:#fde68a}p.err,p.toast{margin:var(--space-sm) 0}p.err{padding:var(--space-sm) var(--space-md);border-radius:var(--r-md);background:#f871711a;border:1px solid rgba(248,113,113,.35);color:#fecaca;font-size:.875rem}p.toast{padding:var(--space-sm) var(--space-md);border-radius:var(--r-md);background:#f0b4291a;border:1px solid rgba(240,180,41,.35);color:#fde68a;font-size:.875rem}.lobby-row{display:flex;flex-wrap:wrap;gap:var(--space-sm);align-items:center;margin:var(--space-sm) 0}.lobby-row input{flex:1 1 10rem;min-width:0}.code-badge{display:inline-block;font-family:ui-monospace,Cascadia Code,monospace;font-weight:700;font-size:1.05rem;letter-spacing:.18em;padding:.35rem .65rem;border-radius:999px;background:linear-gradient(180deg,#1a2030,#121722);border:1px solid var(--border-strong);box-shadow:inset 0 1px #ffffff0f,0 0 20px #5fd4a414;color:var(--accent-2)}.pw-badge{display:inline-block;margin-left:var(--space-sm);padding:.15rem .45rem;border-radius:999px;border:1px solid rgba(240,180,41,.45);background:#f0b4291f;color:#fde68a;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700}.player-list{list-style:none;padding:0;margin:var(--space-md) 0 0}.player-list li{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) 0;border-bottom:1px solid var(--border)}.player-list li:last-child{border-bottom:none}.player-chip{flex-shrink:0;width:2.25rem;height:2.25rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#0a0c10;border:2px solid rgba(255,255,255,.15);box-shadow:0 2px 8px #00000040}.player-name{font-weight:500}.dice-row{display:flex;gap:var(--space-md);flex-wrap:wrap;margin:var(--space-lg) 0;padding:var(--space-lg);background:#0003;border-radius:var(--r-lg);border:1px solid var(--border);justify-content:center;align-items:center}@media (prefers-reduced-motion: no-preference){.route-enter{animation:route-enter .32s ease both}.dice-row--shake .die:not(.ghost){animation:die-shake .55s ease}}@keyframes route-enter{0%{opacity:0;transform:translateY(9px)}to{opacity:1;transform:translateY(0)}}@keyframes die-shake{0%,to{transform:rotate(0) translateY(0)}20%{transform:rotate(-6deg) translateY(-2px)}40%{transform:rotate(5deg) translateY(1px)}60%{transform:rotate(-4deg) translateY(-1px)}80%{transform:rotate(3deg) translateY(0)}}.die{width:3.25rem;height:3.25rem;border-radius:var(--r-md);background:linear-gradient(145deg,#fafbfc,#e4e6eb);color:#1a1d24;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.35rem;border:1px solid #c8ccd6;box-shadow:var(--shadow-die);cursor:default;-webkit-user-select:none;user-select:none;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.die.canToggle{cursor:pointer}.die.canToggle:hover:not(.hold){transform:translateY(-2px);box-shadow:0 4px #a8adb8,0 8px 16px #0000004d}.die.hold{border-color:var(--accent);box-shadow:0 0 0 2px #5fd4a480,0 3px #8a9aa0,0 6px 14px #5fd4a433;transform:translateY(-1px) scale(1.03)}.die.ghost{opacity:.35;border-style:dashed;background:linear-gradient(145deg,#2a3040,#1e2433);border-color:var(--border-strong);color:transparent;box-shadow:none}.die--pips{padding:.35rem}.die-pip-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:.12rem;width:100%;height:100%;min-height:0}.die-pip-cell{display:flex;align-items:center;justify-content:center}.die-pip{width:.45rem;height:.45rem;border-radius:50%;background:#1a1d24;box-shadow:inset 0 -1px 1px #ffffff40;opacity:0}.die-pip--on{opacity:1}.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg-elevated);margin-top:var(--space-md);box-shadow:inset 0 1px #ffffff08}table{width:100%;border-collapse:collapse;font-size:.875rem}thead{position:sticky;top:0;z-index:3}thead tr{background:linear-gradient(180deg,#1e2433,#181c28)}th,td{border-bottom:1px solid var(--border);padding:.45rem .55rem;text-align:left}th{color:var(--muted);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}thead th:first-child,tbody th:first-child,td:first-child{position:sticky;left:0;z-index:2;background:var(--bg-elevated);box-shadow:4px 0 8px -4px #0006}thead th:first-child{z-index:4;background:#1a1f2e}tbody th[scope=row]{text-align:left;font-weight:500;color:var(--text);background:#151924}tbody th[scope=row]:first-child{background:#151924}th.th--active,td.td--active{background:#5fd4a414;box-shadow:inset 0 0 0 1px #5fd4a433}thead th.th--active{background:#5fd4a41f;color:var(--accent-2)}tr:last-child td{border-bottom:none}td.num{text-align:right;font-variant-numeric:tabular-nums}tr.score-section-gap th,tr.score-section-gap td{border-top:2px solid var(--border-strong);padding-top:.65rem}tr.clickable{cursor:pointer;transition:background .12s ease}tr.clickable:hover td{background:#5fd4a40f}tr.clickable:hover td:first-child,tr.clickable:hover th:first-child{box-shadow:4px 0 8px -4px #0006,inset 3px 0 0 var(--accent)}tr.clickable:hover th:first-child{background:#5fd4a414}tr.disabled{opacity:.55;cursor:default}tr.disabled:hover td{background:transparent}tr.disabled:hover th:first-child{background:#151924;box-shadow:4px 0 8px -4px #0006}.preview-hint{font-size:.82em;font-weight:400}tr.row-total th,tr.row-total td{font-weight:600;background:#00000026}tr.row-total th:first-child,tr.row-total td:first-child{background:#141824}.ranking-list{list-style:none;padding:0;margin:var(--space-md) 0}.ranking-list li{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);margin-bottom:var(--space-sm);border-radius:var(--r-md);background:var(--bg-elevated);border:1px solid var(--border)}.rank-num{flex-shrink:0;width:1.75rem;text-align:center;font-weight:800;font-size:1.05rem;color:var(--muted)}.ranking-list li.rank-1{border-color:#eab30873;background:linear-gradient(90deg,rgba(234,179,8,.12),transparent)}.ranking-list li.rank-1 .rank-num{color:#fbbf24}.ranking-list li.rank-2{border-color:#9ca3af59}.ranking-list li.rank-2 .rank-num{color:#cbd5e1}.ranking-list li.rank-3{border-color:#b4530959}.ranking-list li.rank-3 .rank-num{color:#fdba74}.ranking-meta{flex:1;min-width:0}.ranking-name{font-weight:600}.ranking-pts{font-variant-numeric:tabular-nums;color:var(--accent-2);font-weight:700}.stack{display:flex;flex-direction:column;gap:var(--space-md)}.game-layout{display:grid;gap:var(--space-lg)}.game-main{min-width:0}.game-side{display:grid;gap:var(--space-md);align-content:start}.side-card{border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--space-md);background:var(--bg-elevated)}.side-card-title{margin:0 0 var(--space-sm)}.side-player-list{list-style:none;padding:0;margin:0;display:grid;gap:var(--space-sm)}.side-player-list li{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:var(--space-sm)}.side-player-name{font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.side-player-score{color:var(--accent-2);font-weight:700;font-variant-numeric:tabular-nums}.play-meta{display:flex;flex-wrap:wrap;align-items:baseline;gap:var(--space-sm) var(--space-md);margin-bottom:var(--space-sm)}.play-meta strong{color:var(--text);font-weight:600}.roll-actions{margin:var(--space-md) 0 var(--space-lg)}.reaction-panel{border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--space-md);background:var(--bg-elevated)}.reaction-panel-head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.reaction-title{margin:0}.reaction-toggle{padding:.35rem .65rem;min-height:auto;font-size:.8rem}.reaction-tray{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-top:var(--space-sm)}.reaction-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.38rem .62rem;min-height:auto;font-size:.8rem}.reaction-feed{margin:var(--space-md) 0 0;padding:0;list-style:none;display:grid;gap:var(--space-xs)}.reaction-feed li{display:flex;gap:var(--space-sm);align-items:baseline;padding:.35rem .45rem;border-radius:var(--r-sm);background:#ffffff08;border:1px solid rgba(255,255,255,.03)}.reaction-feed-player{font-weight:600}.reaction-feed-body{color:var(--muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:var(--space-lg);background:#080a10a6;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-card{width:min(100%,26rem);border:1px solid var(--border-strong);border-radius:var(--r-lg);background:linear-gradient(165deg,rgba(255,255,255,.06),transparent 40%),var(--panel);box-shadow:var(--shadow-panel);padding:var(--space-lg)}.modal-card h2{margin:0 0 var(--space-sm);font-size:1.1rem}.modal-card p{margin:0 0 var(--space-lg);color:var(--muted)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-sm)}@media (min-width: 62rem){.game-layout{grid-template-columns:minmax(0,1fr) 19rem;gap:var(--space-xl)}.game-side{position:sticky;top:var(--space-lg);align-self:start}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.die.canToggle:hover:not(.hold){transform:none}.shell:hover,.site-nav-link:hover,.btn-link:hover{transform:none}}
