@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Noto+Serif+SC:wght@500;600;700;800&display=swap";:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#eef2f7;--bg-2:#e4ebf4;--panel:#ffffffd6;--panel-solid:#fff;--line:#0f172a14;--line-strong:#0f172a24;--text:#101828;--muted:#667085;--accent:#0f766e;--accent-2:#2563eb;--gold:#9a6700;--danger:#dc2626;--shadow:0 28px 72px #0f172a1f;--shadow-soft:0 12px 28px #0f172a14;--radius:30px;--font-title:"Noto Serif SC", "Songti SC", serif;--font-body:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%}body{color:var(--text);font-family:var(--font-body);background:radial-gradient(circle at top left, #2563eb24, transparent 30%), radial-gradient(circle at top right, #0f766e1f, transparent 28%), linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%);margin:0}body:before{content:"";pointer-events:none;background:linear-gradient(#ffffff24,#fff0),radial-gradient(circle,#0000 68%,#0f172a0f 100%);position:fixed;inset:0}a{color:inherit;text-decoration:none}button,input,select{font:inherit}button{border:0}#root{min-height:100svh}p{margin:0;line-height:1.72}h1,h2,h3{font-family:var(--font-title);letter-spacing:-.02em;margin:0}h1{font-size:clamp(1.8rem,3vw,3.2rem)}h2{font-size:clamp(1.2rem,1.8vw,1.75rem)}h3{font-size:1rem}.app-shell{width:min(1440px,100%);margin:0 auto;padding:18px 16px 34px}.card,.game-hero,.history-box,.side-card{border:1px solid var(--line);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(#ffffffeb,#f8fafcdb)}.topbar{border-radius:var(--radius);grid-template-columns:minmax(0,1.15fr) auto auto;align-items:center;gap:14px;padding:16px 18px;display:grid}.brand-zone{align-items:center;gap:14px;display:flex}.brand-mark{color:#fff;letter-spacing:.04em;width:56px;height:56px;box-shadow:var(--shadow-soft);background:linear-gradient(145deg,#0f766e,#2563eb);border-radius:18px;place-items:center;margin:0;font-size:1rem;font-weight:800;display:grid}.brand-zone p:not(.brand-mark),.hero-desc,.muted{color:var(--muted)}.brand-zone h1{font-size:clamp(1.15rem,2vw,1.75rem)}.brand-zone p:last-child{margin-top:4px;font-size:.88rem}.main-nav{flex-wrap:wrap;gap:8px;display:flex}.nav-link,.btn,.room-row,.room-action{transition:transform .18s,box-shadow .18s,border-color .18s,background .18s}.nav-link{color:var(--muted);background:#fff9;border:1px solid #b5947547;border-radius:999px;padding:9px 14px}.nav-link:hover,.btn:hover,.room-row:hover{box-shadow:var(--shadow-soft);transform:translateY(-1px)}.nav-link.active{color:#fff;background:linear-gradient(145deg,#0f766e,#2563eb);border-color:#0000}.user-zone{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.me-pill,.flash-box,.status-chip,.result-pill,.notice-pill{border:1px solid var(--line);background:#ffffffe6;border-radius:999px;padding:8px 12px}.flash-box{box-shadow:var(--shadow-soft);border-radius:18px;margin-top:14px;animation:.22s slide-in}.main-content{gap:14px;margin-top:14px;display:grid}.page-block{border-radius:var(--radius);padding:22px}.eyebrow{color:var(--accent);text-transform:uppercase;letter-spacing:.14em;margin:0 0 10px;font-size:.74rem;font-weight:700}.small{font-size:.82rem}.error-text{color:var(--danger)}.btn{color:var(--text);cursor:pointer;background:#ffffffeb;border:1px solid #b5947547;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:10px 15px;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.btn.primary{color:#fff;background:linear-gradient(145deg,#0f766e,#2563eb);border-color:#0000}.btn.warm{color:#fff;background:linear-gradient(145deg,#2563eb,#0f766e);border-color:#0000}.btn.ghost{background:#ffffffd1}.home-page,.game-layout,.admin-page{gap:14px;display:grid}.home-page{grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr)}.hero-panel,.home-side,.game-hero{border-radius:30px;padding:24px}.hero-desc{max-width:68ch;margin-top:12px}.hero-actions,.toolbar-actions,.row-actions,.search-inline{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.hero-actions{margin-top:18px}.feature-grid,.metric-grid,.overview-grid{gap:12px;display:grid}.feature-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:20px}.feature-grid article,.metric-grid article,.overview-grid article{border:1px solid var(--line);background:#ffffffd6;border-radius:20px;padding:16px}.panel-head,.section-head,.game-title-row{justify-content:space-between;align-items:center;gap:10px;display:flex}.mini-rank,.history-list,.my-games,.room-list{gap:10px;display:grid}.mini-rank{margin:18px 0 0;padding:0;list-style:none}.mini-rank li,.my-games li,.room-row{grid-template-columns:auto 1fr auto;align-items:center;gap:10px;display:grid}.room-row{border:1px solid var(--line);width:100%;color:inherit;background:#ffffffdb;border-radius:18px;padding:12px 14px}.recent-room{text-align:left}.room-action{text-align:left;color:inherit;cursor:pointer;background:0 0;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:0;display:grid}.room-watch{white-space:nowrap}.game-page{gap:14px;display:grid}.game-hero{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:16px;display:grid}.status-panel{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;min-width:min(740px,100%);display:grid}.status-panel>div,.meta-pill{border:1px solid var(--line);background:#ffffffd6;border-radius:18px;padding:12px 14px}.status-panel span,.meta-pill span{color:var(--muted);margin-bottom:4px;font-size:.78rem;display:block}.status-chip.live{color:var(--accent)}.status-chip.thinking{color:var(--gold)}.status-chip.done{color:#6b7280}.game-layout{grid-template-columns:minmax(0,1.14fr) minmax(310px,.86fr);align-items:start}.game-main,.game-side{gap:14px;min-width:0;display:grid}.board-shell{gap:10px;width:100%;display:grid}.board-stage{grid-template-columns:auto minmax(0,1fr);align-items:stretch;gap:10px;display:grid}.board-grid-wrap{justify-content:center;width:100%;min-width:0;display:flex}.board-files,.board-ranks{color:var(--muted);-webkit-user-select:none;user-select:none;font-size:.75rem}.board-files{grid-template-columns:repeat(9,1fr);padding:0 8px;display:grid}.board-files.top{margin-bottom:8px}.board-files.bottom{margin-top:8px}.board-ranks{align-content:space-between;height:100%;min-height:100%;margin:4px 0;padding:8px 0;display:grid}.board-ranks span{place-items:center;width:18px;height:10%;display:grid}.board-grid{aspect-ratio:9/10;background:linear-gradient(#fffcf8fa,#e8ecf3f5),#d6dce5;border:1px solid #6c46222e;border-radius:28px;grid-template-rows:repeat(10,1fr);grid-template-columns:repeat(9,1fr);width:min(100%,720px);max-width:100%;display:grid;position:relative;overflow:clip;box-shadow:inset 0 0 0 1px #ffffff80,0 24px 60px #0f172a29}.board-grid:before{content:"";pointer-events:none;background-color:#0000;background-image:linear-gradient(#4755693d 1px,#0000 1px),linear-gradient(90deg,#4755693d 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:11.1111% 10%;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;position:absolute;inset:0}.board-cell{cursor:pointer;background:0 0;border:0;outline:none;min-width:0;min-height:0;padding:0;position:relative}.board-cell:hover:not(:disabled){background:#2563eb14}.board-cell.selected{background:#0f766e1f}.board-cell.target{background:#2563eb1a}.board-cell.last-from,.board-cell.last-to{box-shadow:inset 0 0 0 2px #0f766e47}.move-dot{background:#2563ebeb;border-radius:999px;width:clamp(8px,1.2vw,12px);height:clamp(8px,1.2vw,12px);position:absolute;inset:50% auto auto 50%;transform:translate(-50%,-50%)}.piece{letter-spacing:.02em;border-radius:50%;place-items:center;width:clamp(28px,4.2vw,56px);height:clamp(28px,4.2vw,56px);font-size:clamp(.8rem,1.5vw,1.08rem);font-weight:800;display:grid;position:absolute;inset:50% auto auto 50%;transform:translate(-50%,-50%);box-shadow:0 8px 18px #0f172a1f,inset 0 1px #ffffff5c}.piece.red{color:#b91c1c;background:linear-gradient(#fff 0%,#f8fafc 100%);border:1px solid #b91c1c24}.piece.black{color:#0f172a;background:linear-gradient(#fff 0%,#edf2f7 100%);border:1px solid #0f172a1f}.river-tag{color:#4755696b;font-size:clamp(1rem,2vw,1.8rem);font-family:var(--font-title);pointer-events:none;z-index:1;position:absolute;top:50%;transform:translateY(-50%)}.river-tag.left{left:50%;transform:translate(-140%,-50%)}.river-tag.right{left:50%;transform:translate(40%,-50%)}.history-box,.side-card{border-radius:24px;padding:18px}.field{gap:8px;display:grid}.compact-field{margin-bottom:8px}.side-card .toolbar-actions{margin-top:10px}.field span{color:var(--muted);font-size:.82rem}.field input,.field select,.search-inline input{border:1px solid var(--line);width:100%;color:var(--text);background:#fffffff5;border-radius:14px;padding:12px 14px}.field input:focus,.field select:focus,.search-inline input:focus{outline-offset:2px;outline:2px solid #b15d2529}.history-list{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.result-pill,.notice-pill{color:var(--text);border-radius:16px;margin-top:12px}.table-wrap{border:1px solid var(--line);background:#ffffffd6;border-radius:20px;overflow:auto}.rank-table{border-collapse:collapse;width:100%}.rank-table th,.rank-table td{border-bottom:1px solid var(--line);text-align:left;vertical-align:top;padding:14px 12px}.rank-table thead th{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;background:#fffaf4f0;font-size:.8rem}.rank-table tbody tr.mine{background:#b15d250f}.player-cell{align-items:center;gap:10px;display:flex}.avatar-mini{color:#fff;background:linear-gradient(145deg,#0f766e,#2563eb);border-radius:50%;place-items:center;width:36px;height:36px;display:grid}.member-row{align-items:center;gap:10px;margin-top:10px;display:flex}.member-row:first-of-type{margin-top:0}.member-avatar{flex:none}.score-cell{font-weight:700}.overview-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.leaderboard-metrics,.room-summary-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.clock-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.clock-card{border:1px solid var(--line);background:#ffffffdb;border-radius:22px;padding:18px 20px}.clock-card.active{border-color:#2563eb38;box-shadow:0 16px 36px #2563eb1a}.clock-card strong{letter-spacing:.04em;margin-top:8px;font-size:clamp(1.5rem,3vw,2.3rem);display:block}.rank-progress{gap:12px;display:grid}.rank-progress-bar{background:#0f172a14;border-radius:999px;width:100%;height:14px;overflow:hidden}.rank-progress-bar span{border-radius:inherit;background:linear-gradient(145deg,#0f766e,#2563eb);height:100%;display:block}.rank-progress-meta{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.home-season-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:18px}.room-result-list{gap:10px;display:grid}.room-result-list article{border:1px solid var(--line);background:#ffffffd6;border-radius:18px;padding:14px 16px}.room-result-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.compact-list{gap:8px}.room-result-head a{color:var(--accent);font-weight:700}.report-layout{gap:14px;display:grid}.report-hero{border:1px solid var(--line);background:#ffffffe0;border-radius:24px;padding:20px}.report-grid,.rating-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.rule-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.rule-grid article{border:1px solid var(--line);background:#ffffffd6;border-radius:18px;padding:16px}.timeline-list{gap:10px;display:grid}.timeline-item{border:1px solid var(--line);background:#fffc;border-radius:16px;grid-template-columns:auto 1fr;align-items:start;gap:12px;padding:12px 14px;display:grid}.timeline-dot{background:linear-gradient(145deg,#0f766e,#2563eb);border-radius:50%;width:10px;height:10px;margin-top:6px;box-shadow:0 0 0 5px #2563eb14}.room-timeline-box,.report-stream{border-radius:24px}.report-stream{padding:18px}.rule-grid strong{margin-bottom:8px;display:block}.compact article{padding:12px 14px}.home-subhead{margin-top:18px}.home-side .room-result-list{margin-top:10px}.pager{justify-content:space-between;align-items:center;gap:12px;margin-top:14px;display:flex}@keyframes slide-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media (width<=1120px){.topbar,.home-page,.game-layout,.game-hero{grid-template-columns:1fr}.status-panel{grid-template-columns:1fr 1fr;min-width:0}.feature-grid,.overview-grid,.leaderboard-metrics,.room-summary-grid,.clock-grid,.report-grid,.rating-grid{grid-template-columns:1fr 1fr}.board-stage{grid-template-columns:1fr}.board-ranks{display:none}.board-grid{width:100%;max-width:760px}}@media (width<=760px){.app-shell{padding:12px 10px 26px}.topbar,.hero-panel,.home-side,.game-hero,.page-block,.history-box,.side-card{border-radius:22px;padding:16px}.brand-zone{align-items:flex-start}.brand-mark{border-radius:16px;width:48px;height:48px}.main-nav{gap:6px}.nav-link,.btn{padding:8px 12px}.feature-grid,.overview-grid,.leaderboard-metrics,.room-summary-grid,.clock-grid,.history-list,.status-panel{grid-template-columns:1fr}.board-grid{border-radius:20px;width:100%}.board-files{padding:0 4px;font-size:.7rem}.river-tag{font-size:.92rem}.room-row,.room-action,.mini-rank li,.my-games li{grid-template-columns:1fr;align-items:stretch}.timeline-item{grid-template-columns:1fr}.timeline-dot{display:none}.room-action small{display:block}.room-watch{width:100%}.pager{flex-direction:column;align-items:stretch}}
