@import url('admin_styles.css');

:root{
  --bg:#0e0f12;
  --panel:#151820;
  --muted:#8892a6;
  --text:#e8ecf1;
  --accent:#7aa2ff;
  --accent-2:#55d2a6;
  --danger:#ff6482;
  --yellow:#ffd166;
  --red:#ff5c5c;
  --green:#34d399;
  --black:#111;
}
*{box-sizing:border-box}
html,body,#app{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,Segoe UI,Roboto,Arial,Helvetica,sans-serif;
  color:var(--text);
  background:radial-gradient(1400px 900px at 50% -20%, #10161a 0%, #0b0e10 60%);
}
.view{display:none}
.view.active{display:block}

.app-header,.room-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid #232839;background:#0f1218cc;backdrop-filter:blur(6px);
  position:sticky;top:0;z-index:5
}
.brand,.room-title{display:flex;gap:12px;align-items:center}
.logo{font-size:22px}
h1{font-size:20px;margin:0}
.header-right{display:flex;gap:8px;align-items:center}

.lobby-grid{
  display:grid;grid-template-columns:repeat(3, minmax(260px, 1fr));
  gap:20px;padding:20px;max-width:1200px;margin:0 auto;
}
.panel{
  background:var(--panel);border:1px solid #232839;border-radius:12px;padding:16px;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
}
.panel h2{margin:6px 0 12px;font-size:16px}

label{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--muted)}
input,select{background:#0f1218;border:1px solid #232839;color:var(--text);border-radius:10px;padding:10px 12px;font-size:13px}
.grid-2{display:grid;grid-template-columns:repeat(2, 1fr);gap:10px}

button{cursor:pointer;border:1px solid transparent;border-radius:10px;padding:10px 12px;color:var(--text);background:#212838;font-size:13px;transition:all .15s ease}
button:hover{filter:brightness(1.15)}
button:active{transform:scale(.97)}
button.primary{background:linear-gradient(180deg, #6d8cff, #4c6bff);border-color:#405de6}
button.secondary{background:#23293b;border-color:#2e3550}
button.ghost{background:transparent;border-color:#2a2f45}
button.trump{color:#111;font-weight:700;padding:12px 18px;font-size:14px}
button.trump.red{background:var(--red)}
button.trump.green{background:var(--green)}
button.trump.yellow{background:var(--yellow)}
button.trump.black{background:#444;color:#eee}

.list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.list li{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border:1px solid #232839;border-radius:10px;background:#0f1218}
.list.compact li{padding:6px 8px;font-size:12px}

.table-layout{display:grid;grid-template-columns:280px 1fr;gap:18px;padding:18px}
.score-panel{background:var(--panel);border:1px solid #232839;border-radius:12px;padding:14px;max-height:calc(100vh - 110px);overflow:auto}
.score-panel h3{margin:10px 0 8px;font-size:14px;color:var(--accent);border-bottom:1px solid #1e2436;padding-bottom:4px}
.kv{display:flex;justify-content:space-between;gap:12px;padding:4px 0;color:#c8d0df;font-size:13px}
.kv span{color:var(--muted)}

.table{
  position:relative;min-height:70vh;
  background:
    radial-gradient(800px 400px at 30% 20%, rgba(255,255,255,.05), rgba(0,0,0,0) 60%),
    radial-gradient(900px 500px at 70% 80%, rgba(255,255,255,.05), rgba(0,0,0,0) 60%),
    repeating-linear-gradient(45deg, rgba(0,0,0,.06) 0, rgba(0,0,0,.06) 2px, rgba(0,0,0,0) 2px, rgba(0,0,0,0) 8px),
    linear-gradient(180deg,#1e6a3a,#165630);
  border-radius:20px;
  border:10px solid transparent;
  padding:10px;
  box-shadow:
    0 0 0 12px #6a4b2b inset,
    0 0 0 14px #583e23 inset,
    0 18px 40px rgba(0,0,0,.45);
}
.table:after{content:"";position:absolute;inset:0;border-radius:12px;pointer-events:none;opacity:.35;
  background:
    radial-gradient(1px 1px at 10% 15%, rgba(255,255,255,.06), rgba(0,0,0,0) 2px),
    radial-gradient(1px 1px at 20% 55%, rgba(255,255,255,.06), rgba(0,0,0,0) 2px),
    radial-gradient(1px 1px at 35% 30%, rgba(255,255,255,.06), rgba(0,0,0,0) 2px),
    radial-gradient(1px 1px at 60% 70%, rgba(255,255,255,.06), rgba(0,0,0,0) 2px),
    radial-gradient(1px 1px at 80% 40%, rgba(255,255,255,.06), rgba(0,0,0,0) 2px);
  mix-blend-mode: overlay;
}

.seat{position:absolute;display:flex;flex-direction:column;align-items:center;gap:8px}
.seat .seat-name{padding:4px 10px;background:#0f1218;border:1px solid #232839;border-radius:999px;font-size:12px;color:#cbd5e1}
.seat .hand{display:flex;flex-wrap:nowrap;justify-content:center}
.seat .hand .card:not(:first-child){margin-left:-45px}
.pos-bottom .hand .card:not(:first-child){margin-left:-25px}
.pos-left .hand, .pos-right .hand { flex-direction: column; }
.pos-left .hand .card, .pos-right .hand .card { transform: rotate(90deg); }
.pos-left .hand .card:not(:first-child), .pos-right .hand .card:not(:first-child) { margin-left: 0; margin-top: -75px; }

.pos-top{top:8px;left:50%;transform:translateX(-50%)}
.pos-bottom{bottom:8px;left:50%;transform:translateX(-50%)}
.pos-right{right:8px;top:50%;transform:translateY(-50%); flex-direction: row-reverse;}
.pos-left{left:8px;top:50%;transform:translateY(-50%); flex-direction: row;}

.seat.active-turn .seat-name {
  border-color: #ffd700;
  background: #2a2000;
  color: #fff;
  box-shadow: 0 0 10px rgba(255,215,0,0.5);
}

.center{position:absolute;top:40%;left:50%;transform:translate(-50%, -50%);display:flex;flex-direction:column;gap:12px;align-items:center}

.bidding{display:none;flex-direction:column;gap:10px;align-items:center;background:#0f1218ee;border:1px solid #2f3754;border-radius:12px;padding:14px 16px;backdrop-filter:blur(4px)}
.bidding-row{display:flex;gap:10px;align-items:center}
.bidding-info{font-size:13px;color:#cbd5e1;text-align:center;max-width:320px}
.pending-bid-display{background:#1a2030;border:1px solid #2e3550;border-radius:8px;padding:6px 14px;color:var(--yellow);font-size:15px;font-weight:700;min-width:80px;text-align:center}

.trump-select{display:none;flex-direction:column;gap:10px;align-items:center;background:#0f1218ee;border:1px solid #2f3754;border-radius:12px;padding:14px 16px;backdrop-filter:blur(4px)}
.trump-buttons{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}

.kitty{display:none;flex-direction:column;gap:8px;align-items:stretch;background:#0f1218ee;border:1px solid #2f3754;border-radius:12px;padding:14px 16px;min-width:520px;backdrop-filter:blur(4px)}
.kitty-row{display:flex;gap:10px;align-items:center}
.kitty-row span{min-width:100px;color:#cbd5e1;font-size:13px}
.cards{display:flex;gap:8px;flex-wrap:wrap}
.droppable{min-height:84px;border:1px dashed #2e3550;border-radius:8px;padding:8px}

.trick{display:none;background:#0f1218ee;border:1px solid #2f3754;border-radius:12px;padding:12px;min-width:400px;backdrop-filter:blur(4px)}
.trick-grid{display:grid;grid-template-areas:". p-top ." "p-left . p-right" ". p-bottom ."; gap:6px; justify-items:center; align-items:center}
.play{width:110px;height:100px;border:1px solid #2e3550;border-radius:10px;background:#0e1a12;display:flex;flex-direction:column;gap:4px;align-items:center;justify-content:center}
.play-label{font-size:11px;color:#8892a6;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:90%}
.play-label.empty{opacity:0.5}
.turn-indicator{margin-top:6px;color:#cbd5e1;font-size:13px;text-align:center}
.trick-message{margin-top:4px;color:var(--accent);font-size:13px;font-weight:600;text-align:center;min-height:16px}

.card{
  --c:#111;
  width:64px;height:92px;border-radius:10px;border:1px solid #d9dee8;background:#f7f9fc;display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 2px 8px rgba(0,0,0,.35);
  user-select:none;color:#111;cursor:pointer;transition:transform .12s ease, box-shadow .12s ease;
}
.card:hover:not(.back):not(.disabled){transform:translateY(-4px);box-shadow:0 6px 16px rgba(0,0,0,.45)}
.card.back{background:repeating-linear-gradient(135deg,#e6ecf5 0,#e6ecf5 6px,#d9e1ef 6px,#d9e1ef 12px);border-color:#c2cbe0;cursor:default}
.card[data-color="Red"]{--c:#d62d2d}
.card[data-color="Green"]{--c:#1aa36b}
.card[data-color="Yellow"]{--c:#c69519}
.card[data-color="Black"]{--c:#111}
.card[data-color="Rook"]{--c:#8b5e3c;background:#fff8ec;border-color:#e8d6b7}
.card .corner{position:absolute;display:flex;flex-direction:column;align-items:center;gap:1px;color:var(--c)}
.card .corner .r{font-weight:800;font-size:16px;line-height:1}
.card .corner .suit-sym{font-size:12px;line-height:1;color:var(--c)}
.card .corner .p{width:8px;height:8px;border-radius:50%;background:var(--c)}
.card .corner.tl{top:5px;left:5px}
.card .corner.br{bottom:5px;right:5px;transform:rotate(180deg)}
.card .center-mark{color:var(--c);font-weight:800;font-size:22px;opacity:.9}
.card.rook{background:#fff8ec;border-color:#e8d6b7}
.card .pips{display:grid;place-items:center;gap:4px}
.card .pip{width:10px;height:10px;border-radius:50%;background:var(--c);box-shadow:0 0 0 1px #00000010 inset, 0 1px 0 rgba(255,255,255,.4) inset}
.card.rook .rook-icon{width:30px;height:30px;color:var(--c)}
.card.selected{outline:3px solid var(--accent);outline-offset:1px}
.card.playable{box-shadow:0 0 0 2px #4c6bff88,0 0 12px 2px rgba(76,107,255,.25)}
.card.disabled{opacity:.45;filter:grayscale(.2);cursor:default;pointer-events:none}

.tag{padding:2px 6px;border-radius:999px;border:1px solid #2e3550;background:#0f1218;color:#cbd5e1;font-size:11px}

.modal{position:fixed;inset:0;background:#00000080;backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;z-index:20}
.modal.show{display:flex}
.modal-card{width:min(720px, 92vw);max-height:90vh;overflow-y:auto;background:#141822;border:1px solid #2a2f45;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.5);display:flex;flex-direction:column}
.modal-head{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid #232839}
.modal-head h3{margin:0;font-size:16px}
.modal-body{padding:14px;gap:10px}
.modal-foot{display:flex;align-items:center;gap:10px;padding:12px 14px;border-top:1px solid #232839}
.muted{color:var(--muted)}
.spacer{flex:1}
.rules-details{margin:10px 0}
.rules-details summary{cursor:pointer;color:var(--accent);font-weight:600;font-size:13px;padding:6px 0}

h4{color:#cbd5e1;font-size:13px;margin:12px 0 6px}

@media (max-width: 1100px){
  .lobby-grid{grid-template-columns:1fr}
  .table-layout{grid-template-columns:1fr}
  .seat .hand{max-width:90vw}
  .kitty{min-width:unset}
}

@media (max-width: 800px) {
  .split-layout { flex-direction: column; padding: 16px; }
  .room-layout { flex-direction: column; overflow-y: auto; overflow-x: hidden; height: auto; min-height: 100vh; }
  .room-sidebar { width: 100%; height: auto; max-height: 35vh; border-right: none; border-bottom: 1px solid #1e2436; flex-shrink: 0; }
  .table { min-height: 550px; padding: 8px; overflow: hidden; flex: none; margin-bottom: 20px; }
  .table:before { inset: 8px; border-radius: 16px; box-shadow: 0 0 0 8px #583e23 inset, 0 8px 20px rgba(0,0,0,.45); }
  
  .pos-top { top: 8px; transform: translateX(-50%) scale(0.65); transform-origin: top center; }
  .pos-bottom { bottom: 8px; transform: translateX(-50%) scale(0.65); transform-origin: bottom center; }
  .pos-left { left: 4px; transform: translateY(-50%) scale(0.65); transform-origin: left center; }
  .pos-right { right: 4px; transform: translateY(-50%) scale(0.65); transform-origin: right center; }
  
  .center { top: 46%; transform: translate(-50%, -50%) scale(0.65); width: 90vw; }
  .trick { min-width: auto; width: 100%; }
}
