:root{--ink: #111111;--paper: #f8f4ec;--accent: #0f6a54}*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,sans-serif;color:var(--ink);background:radial-gradient(circle at 20% 20%,#fff9ef 0%,var(--paper) 48%,#e9e1d3 100%)}.app-shell{min-height:100dvh;padding:1rem;max-width:720px;margin:0 auto}h1{margin:0;font-size:clamp(1.8rem,4vw,2.4rem)}.panel{margin-top:1.25rem;padding:1rem;border-radius:14px;background:#fffc;border:1px solid #d8cfbf}.panel h2{margin-top:0;color:var(--accent)}header{display:flex;align-items:center;justify-content:space-between;gap:1rem}button.primary{margin-top:.75rem;padding:.65rem 1.1rem;border:none;border-radius:10px;background:var(--accent);color:#fff;font-size:1rem;cursor:pointer}button.primary:disabled{opacity:.5;cursor:default}button.link{background:none;border:none;color:var(--accent);cursor:pointer;text-decoration:underline;font-size:.9rem}button.link.active{color:#b3261e;font-weight:700}.gate-form label{display:block;font-size:.9rem;margin-bottom:.5rem}.gate-form input{display:block;width:100%;margin-top:.25rem;padding:.6rem;border-radius:8px;border:1px solid #c9bfae;font-size:1rem}.error{color:#b3261e;font-weight:600}.muted{color:#6b6256}.your-turn{color:var(--accent);font-weight:700}.win{font-size:1.2rem;font-weight:700;color:var(--accent)}.scorebar{display:flex;justify-content:space-between;font-weight:600;margin-bottom:.5rem}.scores{width:100%;border-collapse:collapse;font-size:.95rem}.scores td{padding:.35rem .25rem;border-bottom:1px solid #eee3d3}.scores .active-row{background:#eaf6f1;font-weight:700}.hand{display:flex;flex-wrap:wrap;gap:.4rem;margin:.5rem 0}.trick{display:flex;flex-wrap:wrap;gap:.75rem}.trick-card{display:flex;flex-direction:column;align-items:center;gap:.2rem;font-size:.75rem}.card{width:62px;height:88px;border-radius:8px;border:1px solid #b9ae9b;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:700;cursor:pointer;padding:0}.card .rank,.card .suit{font-size:2rem;line-height:1}.card.red{color:#b3261e}.card.black{color:#111}.card.selected{outline:3px solid var(--accent);transform:translateY(-6px)}.card:disabled{cursor:default;opacity:.85}.card.dimmed{opacity:.35;filter:grayscale(.6)}.game-topbar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-top:.75rem;font-size:.9rem;color:#4a4336}.table{position:relative;margin:.75rem auto;width:100%;max-width:520px;aspect-ratio:1 / 1;background:radial-gradient(circle at 50% 45%,#1f8a6d,#14654e 70%,#0d4b39);border-radius:24px;border:6px solid #8a5a2b;box-shadow:inset 0 0 30px #00000059}.seat{position:absolute;display:flex;flex-direction:column;align-items:center;gap:2px;width:92px;color:#f4f1e9;text-align:center}.seat-info{display:flex;flex-direction:column;align-items:center;gap:2px;width:100%;flex-shrink:0}.seat.south{bottom:6px;left:50%;transform:translate(-50%)}.seat.north{top:6px;left:50%;transform:translate(-50%)}.seat.west{left:6px;top:50%;transform:translateY(-50%)}.seat.east{right:6px;top:50%;transform:translateY(-50%)}.avatar{width:46px;height:46px;border-radius:50%;background:#0b3a2c;border:2px solid #f4f1e9aa;display:flex;align-items:center;justify-content:center;font-size:1.6rem}.active-seat .avatar{border-color:#ffd54a;box-shadow:0 0 12px #ffd54a}.seat-name{font-weight:700;font-size:.85rem;max-width:92px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.seat-score{font-size:.78rem;opacity:.9}.played{position:absolute;margin-top:0;transition:transform .5s ease,opacity .5s ease;z-index:10}.seat.south .played{bottom:85px;left:50%;transform:translate(-50%)}.seat.north .played{top:85px;left:50%;transform:translate(-50%)}.seat.west .played{left:85px;top:50%;transform:translateY(-50%)}.seat.east .played{right:85px;top:50%;transform:translateY(-50%)}.played .card{width:44px;height:62px}.played .card .rank,.played .card .suit{font-size:1.35rem}.played.winner .card{outline:3px solid #ffd54a;box-shadow:0 0 14px #ffd54a}.played.collecting{animation:collect 1.6s ease forwards}@keyframes collect{0%{transform:scale(1);opacity:1}45%{transform:scale(1);opacity:1}to{transform:scale(.15);opacity:0}}.table-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#f4f1e9;min-width:120px}.center-msg{font-weight:700;font-size:1rem;color:#f4f1e9}.center-msg.your-turn{color:#ffd54a}.table-center .win{font-size:1.2rem;font-weight:800;color:#ffd54a}.hand-area{margin-top:.75rem;padding:.75rem;border-radius:14px;background:#fffc;border:1px solid #d8cfbf}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#f8f4ecf7;display:flex;flex-direction:column;z-index:50}.overlay-head{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid #d8cfbf}.overlay-head h2{margin:0;color:var(--accent)}.overlay-body{flex:1;overflow-y:auto;padding:.75rem 1rem}.history-table{display:flex;flex-direction:column;gap:.5rem}.history-row-header,.history-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:.5rem;text-align:center}.history-col-header{font-weight:700;font-size:.85rem;padding:.35rem;border-bottom:2px solid #4a4336;color:var(--accent)}.history-col{padding:.35rem;border:1px solid #eee3d3;border-radius:6px;background:#fff;min-height:1.8rem;display:flex;align-items:center;justify-content:center}.history-card{font-weight:700;font-size:1.1rem;padding:.1rem .35rem;border-radius:6px;border:1px solid #cdbfa8;background:#fff}.history-card.red{color:#b3261e}.history-card.black{color:#111}.history-card.winner{outline:2px solid #0f6a54;box-shadow:0 0 8px #0f6a5488}.debug-panel{display:flex;flex-direction:column;gap:1rem;font-family:Courier New,monospace;font-size:.85rem}.debug-section{border:1px solid #cdbfa8;border-radius:6px;padding:.75rem;background:#f9f7f3}.debug-section h3{margin:0 0 .5rem;font-size:.95rem;color:#5a4a3a}.debug-robot-hand{margin-bottom:.5rem;padding:.5rem;background:#fff;border-radius:4px;border-left:3px solid #0f6a54}.debug-robot-hand strong{display:block;margin-bottom:.35rem;color:#1f3a2f}.debug-cards{display:flex;flex-wrap:wrap;gap:.35rem}.debug-card{display:inline-block;padding:.25rem .5rem;background:#e8f0ec;border-radius:3px;border:1px solid #0f6a54;font-weight:700;color:#1f3a2f}.debug-log{max-height:400px;overflow-y:auto;background:#fff;border-radius:4px;padding:.5rem}.debug-log-entry{margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #eee3d3}.debug-log-entry:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.log-header{margin-bottom:.35rem;font-weight:700;color:#1f3a2f;font-size:.8rem}.log-detail{margin-bottom:.25rem;display:flex;gap:.5rem}.log-detail span{font-weight:700;color:#5a4a3a;min-width:110px}.log-detail code{background:#f0e8e0;padding:.15rem .35rem;border-radius:3px;color:#b3261e;word-break:break-all;flex:1}.log-detail em{color:#0f6a54;font-style:italic;flex:1}
