:root{color-scheme:dark;--bg:#090807;--jade:#0f5b4b;--deep-jade:#07362f;--patina:#3d8c7a;--burgundy:#8e2f2c;--cinnabar:#c45132;--brass:#c7a35a;--bulb:#f4d37a;--felt:#0c7b3d;--table-wood:#9b5521;--table-wood-dark:#5d2b10;--porcelain:#f7e9c8;--paper:#efe0bd;--ink:#17110d;--shadow-brown:#3a2418;--panel:rgba(9,42,35,.9);--panel-strong:rgba(13,55,46,.97);--line:rgba(199,163,90,.36);--text:#f9edd2;--muted:#c7b99a;--shadow:0 24px 80px rgba(0,0,0,.46)}*{box-sizing:border-box}html{min-height:100%;background:var(--bg)}body{min-height:100dvh;margin:0;background:linear-gradient(135deg,rgba(199,163,90,.08) 25%,transparent 0) 0 0 /58px 58px,linear-gradient(225deg,rgba(199,163,90,.055) 25%,transparent 0) 0 0 /58px 58px,radial-gradient(circle at 18% 14%,rgba(142,47,44,.38),transparent 25rem),radial-gradient(circle at 86% 8%,rgba(61,140,122,.28),transparent 22rem),linear-gradient(145deg,#090807,#10241d 52%,#26150f);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}a{color:inherit;text-decoration:none}button{font:inherit}.app-shell{position:relative;min-height:100dvh;display:flex;flex-direction:column}.eyebrow{margin:0 0 .35rem;color:var(--bulb);font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.page{flex:1;min-height:0}.version-badge{position:absolute;top:.65rem;right:.8rem;z-index:45;display:inline-flex;align-items:center;justify-content:center;min-width:4.2rem;min-height:1.8rem;padding:0 .75rem;border:1px solid rgba(199,163,90,.58);border-radius:999px;background:linear-gradient(180deg,hsla(42,75%,88%,.09),rgba(0,0,0,.18)),rgba(30,18,10,.72);color:var(--porcelain);box-shadow:inset 0 1px 0 rgba(255,247,211,.16),0 .35rem 1.1rem rgba(0,0,0,.28);font-size:.78rem;font-weight:800;letter-spacing:.04em;pointer-events:none}.game-layout{height:100dvh;display:grid;grid-template-columns:minmax(0,1fr) minmax(310px,380px);align-items:stretch;gap:clamp(.65rem,1.2vw,.95rem);padding:0 clamp(.65rem,1.3vw,1rem) 0 0}.game-layout,.table-panel{min-height:0;overflow:hidden}.table-panel{position:relative;height:100%;background:linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.38) 72%,rgba(0,0,0,.58)),url(/backgrounds/shanghai-mahjong-house-1980s.jpg) 50% /cover no-repeat,#070504}.mahjong-canvas{width:100%;height:100%;min-height:0}.table-loading{min-height:0;height:100%;display:grid;place-items:center;color:var(--muted);background:#07110f}.brand-masthead{position:absolute;top:clamp(.35rem,1.2vw,.85rem);left:50%;z-index:6;width:min(43vw,30rem);min-width:18rem;transform:translateX(-50%);pointer-events:none;filter:drop-shadow(0 .75rem 1rem rgba(0,0,0,.4))}.brand-masthead img{display:block;width:100%;height:auto}.hand-rail{position:absolute;left:clamp(1.4rem,3vw,2.1rem);right:clamp(1.4rem,3vw,2.1rem);bottom:clamp(2.2rem,4.8vh,3.2rem);z-index:5;display:grid;grid-template-columns:repeat(auto-fit,minmax(2.8rem,1fr));gap:clamp(.22rem,.7vw,.42rem);padding:.48rem;border:1px solid rgba(246,178,63,.26);border-radius:.45rem;background:linear-gradient(180deg,rgba(19,129,66,.76),rgba(4,82,41,.9)),rgba(4,82,41,.9);backdrop-filter:blur(2px);box-shadow:inset 0 0 0 1px rgba(255,247,211,.08),inset 0 1.2rem 2rem hsla(0,0%,100%,.05),0 .7rem 1.4rem rgba(0,0,0,.24)}.hand-tile-button{min-width:0;height:clamp(4rem,8.2vw,5.6rem);padding:0;border:0;border-radius:.2rem;background:transparent;color:transparent;cursor:pointer;filter:drop-shadow(0 .12rem .03rem rgba(255,246,211,.16)) drop-shadow(0 .42rem .22rem rgba(10,5,1,.46))}.hand-tile-image{display:block;width:100%;height:100%;object-fit:contain;transform:translateY(0);transition:transform .15s ease,filter .15s ease}.hand-tile-button:hover .hand-tile-image,.hand-tile-selected .hand-tile-image{transform:translateY(-.28rem) scale(1.04);filter:drop-shadow(0 0 .22rem rgba(246,178,63,.6)) drop-shadow(0 .52rem .25rem rgba(10,5,1,.32))}.hand-tile-button:disabled{cursor:not-allowed;opacity:.54}.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.control-panel{min-height:0;max-height:100%;overflow:auto;overscroll-behavior:contain;scrollbar-gutter:stable;display:grid;align-content:start;gap:.8rem;padding:clamp(.75rem,1.6vw,1rem) .15rem clamp(.75rem,1.6vw,1rem) 0}.panel-section{position:relative;border:1px solid rgba(199,163,90,.36);border-radius:.5rem;background:linear-gradient(135deg,hsla(44,85%,72%,.07) 0 12%,transparent 12% 88%,rgba(142,47,44,.1) 88%),linear-gradient(180deg,rgba(15,91,75,.9),rgba(6,31,26,.94));box-shadow:0 16px 50px rgba(0,0,0,.22);padding:1rem}.panel-section:before{content:"";position:absolute;inset:.35rem;pointer-events:none;border:1px solid hsla(42,75%,88%,.08);border-radius:.35rem}.status-panel h1{margin:0 0 1rem;color:var(--porcelain);font-size:clamp(1.45rem,4vw,2.2rem);line-height:1.02;letter-spacing:0}.result-grid,.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(6.7rem,1fr));gap:.6rem}.result-grid div,.status-grid div{min-width:0;padding:.75rem;border:1px solid rgba(199,163,90,.16);border-radius:.4rem;background:linear-gradient(180deg,hsla(42,75%,88%,.05),rgba(0,0,0,.08)),rgba(7,54,47,.74)}.mini-line span,.result-grid span,.status-grid span{display:block;margin-bottom:.25rem;color:var(--muted);font-size:.75rem}.mini-line strong,.result-grid strong,.status-grid strong{display:block;overflow-wrap:anywhere;color:var(--porcelain);font-size:.96rem}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.85rem}.ghost-button,.primary-button,.secondary-button,.win-button{min-height:2.7rem;border-radius:.45rem;border:1px solid transparent;cursor:pointer;transition:transform .16s ease,border-color .16s ease,background .16s ease,box-shadow .16s ease}.ghost-button:hover,.primary-button:hover,.secondary-button:hover,.win-button:hover{transform:translateY(-1px)}.primary-button:disabled{cursor:not-allowed;opacity:.42;transform:none}.secondary-button:disabled{cursor:not-allowed;opacity:.45}.primary-button{width:100%;background:linear-gradient(180deg,#f7d985,#bd8f3f),var(--brass);color:#211407;font-weight:830;box-shadow:inset 0 0 0 1px rgba(255,250,210,.28),0 0 18px hsla(44,85%,72%,.12)}.ghost-button,.secondary-button{background:linear-gradient(180deg,hsla(42,75%,88%,.06),rgba(0,0,0,.08)),rgba(15,91,75,.5);border-color:rgba(199,163,90,.34);color:var(--paper)}.ghost-button{min-height:2.2rem;padding:0 .75rem;color:var(--paper)}.win-button{background:radial-gradient(circle at 30% 20%,hsla(44,85%,72%,.14),transparent 38%),var(--burgundy);border-color:hsla(44,85%,72%,.42);color:#ffe6bd;font-weight:780}.action-list{margin-top:.6rem}.action-list,.tool-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem}.tool-row{margin-top:.7rem}.hint-line,.selected-line{margin:0 0 .65rem;color:var(--muted);font-size:.88rem}.hint-line{margin:.7rem 0 0;color:var(--bulb)}.claim-banner{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.25rem .7rem;align-items:center;margin-bottom:.7rem;padding:.75rem;border:1px solid hsla(44,85%,72%,.34);border-radius:.45rem;background:radial-gradient(circle at right,hsla(44,85%,72%,.12),transparent 45%),rgba(142,47,44,.28)}.claim-banner small,.claim-banner span{color:var(--muted);font-size:.76rem}.claim-banner strong{color:var(--bulb);font-size:1.25rem}.claim-banner small{grid-column:1/-1}.score-list{display:grid;gap:.45rem}.mini-line,.score-row{display:flex;align-items:center;justify-content:space-between;gap:.8rem;padding:.55rem 0;border-bottom:1px solid rgba(199,163,90,.16)}.mini-line:last-child,.score-row:last-child{border-bottom:0}.score-row span{color:var(--muted)}.score-row strong{color:var(--porcelain)}.muted{margin:0;color:var(--muted)}.round-modal{position:fixed;inset:0;z-index:60;display:grid;place-items:center;padding:1rem;background:radial-gradient(circle at center,rgba(15,91,75,.25),transparent 34rem),rgba(0,0,0,.66);backdrop-filter:blur(10px)}.round-dialog{width:min(100%,440px);border:1px solid hsla(44,85%,72%,.46);border-radius:.55rem;background:linear-gradient(90deg,rgba(142,47,44,.26),transparent 30%,rgba(199,163,90,.16)),var(--panel-strong);box-shadow:var(--shadow);padding:1.2rem}.round-dialog h2{margin:0;color:var(--porcelain);font-size:1.8rem;line-height:1.08}.compact-dialog{width:min(100%,360px)}.dialog-actions{display:grid;grid-template-columns:1fr 1fr;gap:.65rem;margin-top:1rem}.rules-dialog{width:min(100%,560px)}.rules-copy{display:grid;gap:.75rem;margin:1rem 0;color:var(--muted);line-height:1.55}.rules-copy p{margin:0}.pattern-line{margin:.8rem 0;color:var(--bulb);font-weight:760}@media (max-width:1080px){.game-layout{height:auto;min-height:100dvh;grid-template-columns:1fr;gap:.75rem;padding:0;overflow:visible}.table-panel{height:clamp(500px,62dvh,620px)}.mahjong-canvas,.table-loading{height:100%;min-height:0}.control-panel{max-height:none;overflow:visible;grid-template-columns:repeat(2,minmax(0,1fr));padding:0 .75rem .75rem}}@media (max-width:720px){.game-layout{padding:0;min-height:0}.table-panel{height:clamp(360px,52dvh,440px)}.brand-masthead{top:.3rem;width:min(82vw,21rem);min-width:0}.version-badge{top:.4rem;right:.45rem;min-width:3.4rem;min-height:1.55rem;padding:0 .55rem;font-size:.68rem}.mahjong-canvas,.table-loading{height:100%;min-height:0}.hand-rail{left:.7rem;right:.7rem;bottom:1.45rem;grid-template-columns:repeat(auto-fit,minmax(2.2rem,1fr));gap:.22rem;padding:.34rem}.hand-tile-button{height:clamp(3.1rem,12vw,4rem)}.control-panel{padding:0 .75rem .75rem}.action-list,.control-panel,.dialog-actions,.result-grid,.status-grid,.tool-row{grid-template-columns:1fr}}