:root{--bg-1: #0b1f24;--bg-2: #123b3a;--surface: #ffffff;--surface-2: #eef5f3;--ink: #0c2b28;--muted: #5d7a74;--primary: #0f766e;--primary-strong: #0b5a54;--primary-ink: #ffffff;--accent: #f59e0b;--accent-ink: #4a2c00;--line: #d8e6e2;--danger: #d4493f;--white-piece: #f5f7f6;--black-piece: #1c2b28;--radius: 16px;--radius-sm: 10px;--shadow: 0 16px 40px -22px rgba(2, 22, 26, .55);--shadow-card: 0 10px 30px -20px rgba(2, 22, 26, .45);--font: "Segoe UI", "Inter", system-ui, -apple-system, Roboto, Arial, sans-serif;--font-num: "Trebuchet MS", "Segoe UI", system-ui, sans-serif}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font);color:var(--ink);background:radial-gradient(120% 120% at 50% 0%,var(--bg-2) 0%,var(--bg-1) 70%);min-height:100vh;-webkit-font-smoothing:antialiased}.app{max-width:1180px;margin:0 auto;padding:clamp(16px,3vw,32px)}.app-header{margin-bottom:clamp(16px,2.5vw,26px)}.brand{display:flex;align-items:center;gap:14px}.brand-mark{display:grid;place-items:center;width:52px;height:52px;border-radius:14px;background:linear-gradient(150deg,var(--accent),#fbbf24);color:var(--accent-ink);font-size:30px;line-height:1;box-shadow:var(--shadow)}.brand-title{margin:0;font-size:clamp(26px,4vw,34px);letter-spacing:.5px;color:#fff}.brand-tagline{margin:2px 0 0;color:#b8d6d0;font-size:14px}.layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:clamp(16px,2.4vw,26px);align-items:start}.board-column{display:flex;flex-direction:column;gap:14px;min-width:0}.side-column{display:flex;flex-direction:column;gap:16px;min-width:0}@media (max-width: 880px){.layout{grid-template-columns:1fr}.side-column{order:2}}.board-frame{width:100%;max-width:560px;min-width:0;margin:0 auto;aspect-ratio:1 / 1;align-self:center}.status-bar{display:flex;align-items:center;gap:10px;padding:12px 18px;border-radius:var(--radius-sm);background:var(--surface);box-shadow:var(--shadow-card);font-weight:600;font-size:16px;border-left:5px solid var(--primary)}.status-bar--check{border-left-color:var(--accent);background:#fff8ec}.status-bar--over{border-left-color:var(--ink);background:var(--ink);color:#fff}.status-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--muted)}.status-dot--w{background:var(--white-piece)}.status-dot--b{background:var(--black-piece)}.controls{display:flex;flex-wrap:wrap;align-items:flex-end;gap:14px 20px;padding:16px 18px;border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-card)}.segmented{display:flex;flex-direction:column;gap:6px}.segmented-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}.segmented-track{display:inline-flex;padding:4px;gap:4px;background:var(--surface-2);border-radius:999px}.segmented-btn{border:0;background:transparent;padding:8px 16px;border-radius:999px;font:inherit;font-weight:600;font-size:14px;color:var(--muted);cursor:pointer;transition:background .15s,color .15s,box-shadow .15s}.segmented-btn.is-active{background:var(--primary);color:var(--primary-ink);box-shadow:0 6px 14px -8px #0f766ee6}.controls-actions{display:flex;flex-wrap:wrap;gap:10px;margin-left:auto}.btn{border:0;border-radius:var(--radius-sm);padding:10px 18px;font:inherit;font-weight:600;cursor:pointer;transition:transform .08s,background .15s,box-shadow .15s,opacity .15s}.btn:active{transform:translateY(1px)}.btn--primary{background:var(--primary);color:var(--primary-ink);box-shadow:0 10px 20px -12px #0f766ef2}.btn--primary:hover{background:var(--primary-strong)}.btn--ghost{background:var(--surface-2);color:var(--ink)}.btn--ghost:hover{background:#e2eeea}.btn:disabled{opacity:.45;cursor:not-allowed}.panel{padding:18px;border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-card)}.panel-title{margin:0 0 14px;font-size:18px}.panel-subtitle{margin:18px 0 8px;font-size:13px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.stat{display:flex;flex-direction:column;gap:2px;padding:12px 14px;border-radius:var(--radius-sm);background:var(--surface-2)}.stat--accent{background:linear-gradient(150deg,#0f766e,#149a8c);color:#fff}.stat-value{font-family:var(--font-num);font-size:26px;font-weight:700;line-height:1}.stat-label{font-size:12px;color:var(--muted)}.stat--accent .stat-label{color:#cdeae5}.moves-empty{margin:0;color:var(--muted);font-size:14px}.moves-list{list-style:none;margin:0;padding:0;max-height:220px;overflow-y:auto;border-radius:var(--radius-sm);border:1px solid var(--line)}.moves-row{display:grid;grid-template-columns:42px 1fr 1fr;gap:8px;padding:7px 12px;font-family:var(--font-num);font-size:15px}.moves-row:nth-child(odd){background:var(--surface-2)}.moves-no{color:var(--muted)}.howto-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.howto-step{display:grid;grid-template-columns:28px 1fr;gap:12px;align-items:start;font-size:14px;line-height:1.4}.howto-num{display:grid;place-items:center;width:28px;height:28px;border-radius:50%;background:var(--primary);color:#fff;font-weight:700;font-size:14px}.howto-offline{margin:18px 0 0;font-size:13px;color:var(--muted);line-height:1.5}.howto-offline-badge{display:inline-block;margin-right:8px;padding:3px 10px;border-radius:999px;background:#e7f6f1;color:var(--primary-strong);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.5px}.online-setup,.online-live{display:flex;flex-direction:column;gap:12px}.online .panel-subtitle{margin:0}.online-create,.online-leave{align-self:flex-start}.online-join{display:flex;gap:8px}.online-code-input{flex:1 1 auto;min-width:0;padding:10px 14px;border:1.5px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-2);font:inherit;font-weight:700;letter-spacing:4px;text-transform:uppercase;color:var(--ink);outline:none;transition:border-color .15s,background .15s}.online-code-input::placeholder{letter-spacing:normal;font-weight:600;color:var(--muted)}.online-code-input:focus{border-color:var(--primary);background:#fff}.online-code{font-family:var(--font-num);font-size:34px;font-weight:800;letter-spacing:8px;text-align:center;padding:14px 8px 14px 16px;border-radius:var(--radius-sm);background:var(--surface-2);color:var(--primary-strong)}.online-waiting{margin:0;color:var(--muted);font-weight:600}.online-error{margin:0;color:var(--danger);font-weight:600;font-size:14px}.online-status-row{display:flex;align-items:center;gap:10px}.online-connected{font-weight:700}.online-you{margin:0;color:var(--muted);font-weight:600}.online-turn{margin:0;padding:8px 12px;border-radius:var(--radius-sm);background:var(--surface-2);color:var(--muted);font-weight:700}.online-turn.is-mine{background:#ecfdf5;color:var(--primary-strong)}.gate-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:20px;background:#0714179e;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fade-in .15s ease-out}.gate-card{width:100%;max-width:390px;padding:26px 26px 20px;border-radius:22px;background:var(--surface);box-shadow:0 30px 70px -25px #0009;text-align:center;animation:pop-in .18s cubic-bezier(.2,.9,.3,1.2)}.gate-eyebrow{display:flex;align-items:center;justify-content:center;gap:8px;margin:0 0 4px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}.gate-side{width:14px;height:14px;border-radius:50%;border:2px solid var(--muted)}.gate-side--w{background:var(--white-piece)}.gate-side--b{background:var(--black-piece)}.gate-title{margin:0 0 4px;font-size:22px}.gate-move{margin:0 0 16px;color:var(--muted);font-size:14px}.gate-move strong{font-family:var(--font-num);color:var(--primary-strong);font-size:16px}.gate-question{display:flex;align-items:center;justify-content:center;gap:10px;margin:4px 0 20px;font-family:var(--font-num);font-weight:700}.gate-factor{font-size:52px;color:var(--primary);line-height:1}.gate-times,.gate-equals{font-size:34px;color:var(--muted)}.gate-blank{font-size:52px;color:var(--accent)}.gate-form{display:flex;gap:10px}.gate-input{flex:1;min-width:0;padding:14px 16px;border:2px solid var(--line);border-radius:var(--radius-sm);font-family:var(--font-num);font-size:24px;text-align:center;color:var(--ink);outline:none;transition:border-color .15s,box-shadow .15s}.gate-input:focus{border-color:var(--primary);box-shadow:0 0 0 4px #0f766e26}.gate-input--wrong{border-color:var(--danger);box-shadow:0 0 0 4px #d4493f26;animation:shake .3s ease}.gate-submit{white-space:nowrap}.gate-feedback{min-height:22px;margin:12px 0 4px;font-size:14px;font-weight:600}.gate-feedback--wrong{color:var(--danger)}.gate-cancel{width:100%}@keyframes fade-in{0%{opacity:0}}@keyframes pop-in{0%{opacity:0;transform:translateY(8px) scale(.96)}}@keyframes shake{10%,90%{transform:translate(-2px)}20%,80%{transform:translate(4px)}30%,50%,70%{transform:translate(-7px)}40%,60%{transform:translate(7px)}}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}
