*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#1a1a2e;--surface:#16213e;--surface2:#0f3460;--accent:#e94560;--accent2:#53d8fb;--text:#eaeaea;--text-muted:#888;--green:#4caf50;--radius:8px;--card-w:52px;--card-h:74px;--card-rank:17px;--card-suit:15px;--card-gap:6px}@media (min-width:480px){:root{--card-w:62px;--card-h:88px;--card-rank:20px;--card-suit:18px;--card-gap:8px}}@media (min-width:768px){:root{--card-w:72px;--card-h:100px;--card-rank:22px;--card-suit:20px;--card-gap:10px}}body{background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,sans-serif;min-height:100dvh;-webkit-text-size-adjust:100%}button{cursor:pointer;border:none;border-radius:var(--radius);padding:14px 20px;min-height:48px;font-size:15px;font-weight:600;transition:opacity .15s,transform .1s;-webkit-tap-highlight-color:transparent}button:hover:not(:disabled){opacity:.85}button:active:not(:disabled){transform:scale(.97)}button:disabled{opacity:.4;cursor:default}input{background:var(--surface2);border:1px solid #333;border-radius:var(--radius);color:var(--text);font-size:16px;padding:14px;outline:none;width:100%;min-height:48px}input:focus{border-color:var(--accent2)}input::placeholder{color:var(--text-muted)}.card{width:var(--card-w);height:var(--card-h);border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:700;-webkit-user-select:none;-moz-user-select:none;user-select:none;flex-shrink:0;transition:transform .15s,box-shadow .15s}.card--face-up{background:#fff;border:2px solid #ccc}.card--red{color:#d32f2f}.card--black{color:#212121}.card--face-down{background:linear-gradient(135deg,#1565c0 25%,#0d47a1);border:2px solid #1e88e5}.card--face-down:after{content:"🂠";font-size:32px;color:hsla(0,0%,100%,.25)}.card--empty{background:hsla(0,0%,100%,.04);border:2px dashed hsla(0,0%,100%,.15)}.card--clickable{cursor:pointer}.card--clickable:active{transform:translateY(-6px);box-shadow:0 6px 20px rgba(233,69,96,.5);border-color:var(--accent)}@media (hover:hover){.card--clickable:hover{transform:translateY(-8px);box-shadow:0 8px 24px rgba(233,69,96,.5);border-color:var(--accent)}}.card__rank{font-size:var(--card-rank);line-height:1}.card__suit{font-size:var(--card-suit);line-height:1}.container{padding:16px}@media (min-width:768px){.container{max-width:960px;margin:0 auto;padding:24px 20px}}.panel{background:var(--surface);border-radius:12px;padding:16px;border:1px solid hsla(0,0%,100%,.07)}@media (min-width:480px){.panel{padding:20px}}.row{gap:10px}.col,.row{display:flex}.col{flex-direction:column;gap:12px}.label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:2px}.btn-primary{background:var(--accent);color:#fff}.btn-secondary{background:var(--surface2);color:var(--text)}.btn-success{background:var(--green);color:#fff}.error-box{background:rgba(233,69,96,.15);border:1px solid var(--accent);border-radius:var(--radius);color:var(--accent);padding:10px 14px;font-size:14px}.room-header{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}@media (min-width:600px){.room-header{flex-direction:row;align-items:center;justify-content:space-between}}.room-layout{display:flex;flex-direction:column;gap:16px}@media (min-width:768px){.room-layout{display:grid;grid-template-columns:1fr 280px;align-items:start}}.game-layout{display:flex;flex-direction:column;gap:16px}@media (min-width:768px){.game-layout{display:grid;grid-template-columns:1fr 220px;align-items:start}}.game-main,.game-sidebar{display:flex;flex-direction:column;gap:12px}.hand-section{display:flex;flex-direction:column;gap:8px}.cards-row{display:flex;gap:var(--card-gap);overflow-x:auto;-webkit-overflow-scrolling:touch;padding-top:12px;margin-top:-4px;padding-bottom:4px}.cards-row::-webkit-scrollbar{height:4px}.cards-row::-webkit-scrollbar-track{background:transparent}.cards-row::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.15);border-radius:2px}.chat{display:flex;flex-direction:column;height:200px;background:var(--surface);border-radius:var(--radius);border:1px solid hsla(0,0%,100%,.07);overflow:hidden}@media (min-width:768px){.chat{height:auto;min-height:280px}}.chat__messages{flex:1 1;overflow-y:auto;padding:10px 12px;display:flex;flex-direction:column;gap:4px}.chat__message{font-size:13px;line-height:1.4}.chat__message--system{color:var(--text-muted);font-style:italic}.chat__name{font-weight:700;color:var(--accent2);margin-right:4px}.chat__input-row{display:flex;border-top:1px solid hsla(0,0%,100%,.07)}.chat__input{flex:1 1;border:none;background:transparent;font-size:14px;padding:10px 12px}.chat__input,.chat__send{border-radius:0;min-height:44px}.chat__send{padding:10px 16px;font-size:13px;background:var(--surface2)}.roster{display:flex;flex-direction:column;gap:6px}.roster__item{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:var(--radius);background:hsla(0,0%,100%,.04);font-size:14px;min-height:44px}.roster__item--active{background:rgba(233,69,96,.15);border:1px solid rgba(233,69,96,.4)}.badge{font-size:11px;font-weight:700;padding:2px 6px;border-radius:4px;background:var(--accent);color:#fff}.badge--turn{background:var(--accent2);color:#000}.turn-indicator{text-align:center;padding:14px 12px;border-radius:var(--radius);font-weight:700;font-size:15px}.turn-indicator--mine{background:rgba(233,69,96,.2);border:1px solid var(--accent);color:var(--accent)}.turn-indicator--waiting{background:hsla(0,0%,100%,.05);color:var(--text-muted)}.result-banner{text-align:center;padding:20px 16px;border-radius:12px;margin-bottom:16px}.result-banner--win{background:rgba(76,175,80,.2);border:2px solid var(--green);color:var(--green)}.result-banner--lose{background:rgba(233,69,96,.2);border:2px solid var(--accent);color:var(--accent)}.result-banner__title{font-size:32px;font-weight:900;letter-spacing:.05em}.result-banner__subtitle{font-size:14px;margin-top:4px;opacity:.8}@media (min-width:480px){.result-banner__title{font-size:40px}.result-banner__subtitle{font-size:16px}}h1{font-size:26px;font-weight:900}h2{font-size:18px}h2,h3{font-weight:700}h3{font-size:15px}@media (min-width:480px){h1{font-size:30px}h2{font-size:20px}}.code-display{font-size:36px;font-weight:900;letter-spacing:.2em;color:var(--accent2);font-family:monospace}.divider{border:none;border-top:1px solid hsla(0,0%,100%,.1)}.landing{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:16px}.landing__card{background:var(--surface);border-radius:16px;padding:24px 20px;width:100%;max-width:420px;border:1px solid hsla(0,0%,100%,.07);display:flex;flex-direction:column;gap:20px}@media (min-width:480px){.landing__card{padding:36px 32px;gap:24px}}.landing__title{text-align:center}.landing__subtitle{color:var(--text-muted);font-size:14px;text-align:center;margin-top:4px}