:root{color:#172033;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:#f4f1ea;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-height:100vh;margin:0}button,input,select{font:inherit}button{color:#fff;cursor:pointer;background:#4f46e5;border:0;border-radius:14px;padding:.9rem 1.1rem;font-weight:800;box-shadow:0 10px 24px #4f46e52e}button:disabled{cursor:not-allowed;opacity:.55}button.secondary{color:#3730a3;box-shadow:none;background:#ebe9ff}button.small{border-radius:999px;padding:.5rem .75rem;font-size:.9rem}input,select{color:#172033;background:#fffaf2;border:1px solid #ddd6c7;border-radius:14px;width:100%;padding:.85rem 1rem}input:disabled,select:disabled{opacity:.75}label{gap:.45rem;font-weight:700;display:grid}.app-shell{width:min(1120px,100% - 32px);margin:0 auto;padding:16px 0 48px}.card{background:#ffffffd1;border:1px solid #ddd6c7cc;border-radius:28px;padding:24px;box-shadow:0 18px 48px #3a2a1414}.card.inset{box-shadow:none;background:#fffaf2;margin-top:18px}.hero{background:linear-gradient(135deg,#fff 0%,#f6edff 100%);margin-bottom:18px}.hero h1,.card h1{letter-spacing:-.06em;margin:.15em 0;font-size:clamp(2rem,7vw,4.5rem);line-height:.95}h2,h3{letter-spacing:-.03em;margin:0 0 12px}.eyebrow{color:#7c3aed;text-transform:uppercase;letter-spacing:.12em;margin:0;font-size:.76rem;font-weight:950}.muted{color:#6b7280}.grid{align-items:start;gap:18px;display:grid}.grid.two,.game-grid{grid-template-columns:minmax(0,1.4fr) minmax(280px,.8fr)}.form{gap:16px;display:grid}.row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.check{align-items:center;gap:.65rem;font-weight:600;display:flex}.check input{width:auto}.actions,.copy-row,.submit-word{gap:10px;display:flex}.copy-row input,.submit-word input{flex:1}.card-title-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.card-title-row h3{margin:0}.players{gap:10px;display:grid}.player{background:#fffaf2;border-radius:16px;justify-content:space-between;align-items:center;gap:12px;padding:12px;display:flex}.status{background:#f87171;border-radius:999px;width:9px;height:9px;margin-right:8px;display:inline-block}.status.online{background:#22c55e}.badge{color:#92400e;background:#fef3c7;border-radius:999px;margin-left:8px;padding:.18rem .5rem;font-size:.78rem;font-weight:900}.topline{justify-content:space-between;align-items:start;gap:18px;display:flex}.game-topbar{z-index:20;-webkit-backdrop-filter:saturate(140%)blur(10px);background:#f4f1eaf0;border:1px solid #ddd6c7cc;border-radius:20px;grid-column:1/-1;justify-content:space-between;align-items:center;gap:16px;padding:12px 18px;display:flex;position:sticky;top:0;box-shadow:0 8px 20px #3a2a1414}.game-word{letter-spacing:-.05em;overflow-wrap:anywhere;min-width:0;margin:0;font-size:clamp(1.5rem,5.2vw,2.6rem);line-height:1}.timer{text-align:center;letter-spacing:-.06em;color:#4f46e5;min-width:150px;font-size:clamp(2.2rem,7vw,4rem);font-weight:950}.game-topbar .timer{flex:none;min-width:130px}.submit-block{gap:4px;display:grid}.local-error{color:#991b1b;min-height:1.15em;padding-left:4px;font-size:.95rem;font-weight:800}.chips{flex-wrap:wrap;gap:8px;display:flex}.chip{color:#3730a3;background:#eef2ff;border-radius:999px;padding:.42rem .75rem;font-weight:800}.chip.success{color:#166534;background:#dcfce7}.chip.duplicate{color:#991b1b;background:#fee2e2}.results{gap:14px;margin:18px 0;display:grid}.result{background:#fffaf2;border:1px solid #eee3d1;border-radius:20px;padding:16px}.result-head{justify-content:space-between;gap:12px;margin-bottom:10px;display:flex}.score{color:#fff;background:#4f46e5;border-radius:999px;place-items:center;min-width:38px;height:38px;font-weight:950;display:grid}.notice{z-index:40;border-radius:16px;width:min(560px,100% - 28px);padding:12px 14px;font-weight:800;position:fixed;bottom:18px;left:50%;transform:translate(-50%);box-shadow:0 12px 32px #0000001f}.notice.error{color:#991b1b;cursor:pointer;background:#fee2e2}.notice.toast{color:#3730a3;background:#e0e7ff}@media (width<=820px){.app-shell{width:min(100% - 20px,1120px);padding-top:10px}.grid.two,.game-grid{grid-template-columns:1fr}.row,.actions,.copy-row,.submit-word,.topline{flex-direction:column;grid-template-columns:1fr}.game-topbar{gap:10px;padding:10px 12px}.game-word{font-size:clamp(1.2rem,7vw,1.8rem)}.game-topbar .timer{text-align:right;min-width:88px;font-size:clamp(1.4rem,8vw,2.2rem)}.card{border-radius:22px;padding:18px}.player{flex-direction:column;align-items:start}.timer{text-align:left}}
