@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,600;700&family=Work+Sans:wght@400;500;700&display=swap";:root{--bg-top: #f8f2e6;--bg-bottom: #f2e7d3;--panel: rgba(255, 250, 239, .78);--panel-border: rgba(113, 86, 58, .22);--ink: #2b2418;--ink-soft: #564a3a;--accent: #17666b;--accent-soft: #3b8b90;--danger: #aa4c3f;--tile: #fff6e2;--tile-border: #c9b38d;--board-cell: #eadbc1;--board-cell-alt: #e4d2b3}*{box-sizing:border-box}html,body{margin:0;min-height:100%}body{font-family:Work Sans,Avenir Next,Segoe UI,sans-serif;color:var(--ink);background:radial-gradient(circle at 20% 18%,#fff9,#fff0 45%),radial-gradient(circle at 80% 82%,#ffd6996b,#ffd69900 35%),linear-gradient(180deg,var(--bg-top) 0%,var(--bg-bottom) 100%)}body.dragging-active{-webkit-user-select:none;user-select:none}body.overlay-open{overflow:hidden}#app{min-height:100vh;padding:clamp(.8rem,2.8vw,2rem)}.app-shell{width:min(1080px,100%);margin:0 auto;display:grid;gap:clamp(.9rem,2vw,1.3rem)}.header{display:flex;justify-content:space-between;align-items:end;gap:1rem;border:1px solid var(--panel-border);background:var(--panel);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:16px;padding:clamp(.9rem,2.2vw,1.4rem);box-shadow:0 8px 22px #4c381c1f}.eyebrow{margin:0;font-size:.72rem;text-transform:uppercase;letter-spacing:.11em;color:var(--accent);font-weight:700}h1{margin:.1rem 0 0;font-family:Fraunces,Georgia,serif;font-weight:700;font-size:clamp(1.5rem,3.1vw,2.2rem);line-height:1.12}.button,.text-input{appearance:none;border:1px solid rgba(61,50,33,.28);border-radius:10px;padding:.56rem .68rem;font:inherit;color:var(--ink);background:#fffaeff2}.layout{display:grid;grid-template-columns:1fr 340px;gap:clamp(.9rem,2.2vw,1.5rem)}.board-panel,.hud-panel{border:1px solid var(--panel-border);background:var(--panel);border-radius:16px;box-shadow:0 12px 28px #4d3a1e1f}.board-panel{padding:clamp(.65rem,1.8vw,1rem)}.board{width:100%;max-width:100%;aspect-ratio:1 / 1;position:relative;border-radius:14px;overflow:hidden;border:1px solid rgba(85,70,45,.35);background:var(--board-cell);touch-action:none}.board-cells{width:100%;height:100%;display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:repeat(12,1fr)}.board-cell{border:1px solid rgba(64,50,29,.1);background:var(--board-cell)}.board-cell-alt{background:var(--board-cell-alt)}.board-tiles{position:absolute;inset:0}.tile{display:grid;place-items:center;border-radius:22%;border:4px solid #8d6f44;background:#f8e8c8;color:#1f1f1f;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:800;line-height:.84;letter-spacing:-.04em;padding:0;box-shadow:none}.board-tile{position:absolute;top:0;left:0;cursor:grab;touch-action:none;transition:transform .12s ease,border-color .12s ease}.shelf-tile{position:relative;cursor:grab;touch-action:none;transition:transform .12s ease,border-color .12s ease}.board-tile:active,.shelf-tile:active{cursor:grabbing}.board-tile:hover,.shelf-tile:hover{border-color:#6f5736;transform:translateY(-1px)}.tile-proxy{position:fixed;left:0;top:0;z-index:50;pointer-events:none;transition:none;border-color:#6f5736;background:#f6e4c1;box-shadow:0 0 0 1px #281c0b0f}.tile-source-dragging{opacity:.28}.board-drag-active{outline:2px solid rgba(23,102,107,.4);outline-offset:2px}.hud-panel{padding:clamp(.7rem,1.8vw,1rem);display:grid;gap:.75rem;align-content:start}.hud-card{border:1px solid rgba(84,66,39,.15);border-radius:12px;background:#fffaf1db;padding:.75rem .85rem}.label{margin:0;color:var(--ink-soft);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700}.field-label{display:block;margin:.65rem 0 .28rem;color:var(--ink-soft);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700}.text-input{width:100%}.panel-hidden{display:none}.room-id-label{margin:.2rem 0 .6rem;font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.88rem;letter-spacing:.02em;word-break:break-all}.player-name-label{margin:.2rem 0 .5rem;font-family:Fraunces,Georgia,serif;font-size:1.06rem;font-weight:700}.status-text{margin:.2rem 0 0;font-size:1.24rem;font-family:Fraunces,Georgia,serif}.action-text{margin:.3rem 0 0;min-height:2.2em;color:var(--ink-soft);font-size:.93rem}.metric-number{margin:.15rem 0 .4rem;font-family:Fraunces,Georgia,serif;font-size:1.9rem}.metric-subtle{margin:.2rem 0 0;color:var(--ink-soft);font-size:.96rem}.player-list{margin:.5rem 0 0;padding-left:1rem;color:var(--ink-soft);display:grid;gap:.22rem}.player-list-item{font-size:.82rem}.room-list{margin:.55rem 0 0;padding:0;list-style:none;display:grid;gap:.45rem}.room-list-item{border:1px solid rgba(88,68,39,.2);border-radius:10px;background:#f9f2e5d1;padding:.5rem;display:grid;gap:.35rem}.room-list-heading{font-size:.75rem;color:var(--ink);line-height:1.25;word-break:break-all}.room-list-meta{font-size:.74rem;color:var(--ink-soft)}.room-list-empty{margin:0;color:var(--ink-soft);font-size:.86rem}.room-join-btn{width:100%;padding:.42rem .55rem;font-size:.82rem}.room-notice{margin:.55rem 0 0;min-height:1.2em;color:#265b60;font-size:.86rem;font-weight:500}.room-notice-error{color:#8a352d}.tile-shelf{margin-top:.5rem;min-height:82px;border:1px solid rgba(107,84,52,.22);border-radius:10px;background:#f5ebd7cc;padding:.6rem;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.tile-shelf-empty{margin:0;font-size:.9rem;color:var(--ink-soft)}.trade-zone{border:2px dashed rgba(23,102,107,.55);border-radius:12px;padding:.85rem;font-size:.92rem;color:#184f53;background:#a9dcd85c;min-height:76px;display:grid;align-content:center}.trade-zone-hover{background:#75ccc58c;border-color:#116268e0}.trade-zone-disabled{background:#cdb7a973;color:#775a49;border-color:#775a4973}#action-card{padding:.95rem 1rem 1rem}#action-card .trade-zone{margin-top:.4rem;padding:1rem;min-height:92px}#action-card #serve-row{margin-top:.45rem}.button-row{display:grid;grid-template-columns:1fr 1fr;gap:.55rem}.button-row-single{grid-template-columns:1fr}.button{cursor:pointer;font-weight:600;background:var(--accent);color:#f6fcfc;border-color:#0d4f54bf}.button:hover{background:var(--accent-soft)}.button:disabled{cursor:not-allowed;background:#7871628c;border-color:#766c587a}.button-muted{background:#fffaefeb;color:var(--ink)}.button-muted:hover{background:#f6ecdaeb}.overlay{position:fixed;inset:0;z-index:60;display:none;align-items:center;justify-content:center;padding:clamp(.8rem,3vw,1.4rem);background:#211a0f99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.overlay-visible{display:flex}.overlay-card{width:min(680px,100%);border:1px solid rgba(92,72,43,.34);border-radius:16px;background:#fff9ec;box-shadow:0 24px 48px #140e0759;padding:clamp(.9rem,2.5vw,1.4rem)}.overlay-title{margin:.2rem 0 0;font-family:Fraunces,Georgia,serif;font-size:clamp(1.35rem,3vw,1.9rem)}.overlay-subtitle{margin:.35rem 0 .75rem;color:var(--ink-soft);font-size:.94rem}.winning-table{width:min(100%,460px);margin:0 auto;border:1px solid rgba(85,70,45,.35);border-radius:12px;overflow:hidden;aspect-ratio:1 / 1;display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:repeat(12,1fr);background:var(--board-cell)}.winning-cell{border:1px solid rgba(64,50,29,.1);background:var(--board-cell);display:grid;place-items:center;padding:.08rem}.winning-cell-alt{background:var(--board-cell-alt)}.winning-letter{width:100%;height:100%;display:grid;place-items:center;border-radius:22%;border:2px solid #8d6f44;background:#f8e8c8;color:#1f1f1f;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:800;line-height:.84;letter-spacing:-.04em;font-size:clamp(.54rem,1.4vw,1rem)}.overlay-actions{margin-top:.9rem}@media(max-width:900px){.layout{grid-template-columns:1fr}.hud-panel{order:2}}@media(max-width:560px){#app{padding:.65rem}.header{flex-direction:column;align-items:stretch}}
