@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;700;900&family=Space+Grotesk:wght@400;500;600;700&display=swap');

:root {
  --bg:       #080810;
  --s1:       #0f0f1a;
  --s2:       #161625;
  --s3:       #1e1e30;
  --b1:       #252538;
  --b2:       #2e2e48;
  --red:      #c0392b;
  --red2:     #e84040;
  --blue:     #1565c0;
  --blue2:    #2196f3;
  --pur:      #7b1fa2;
  --pur2:     #ce93d8;
  --gold:     #f5c842;
  --gold2:    #ffd54f;
  --golddim:  #8a7020;
  --text:     #e8e4dc;
  --text2:    #a09898;
  --text3:    #5a5468;
  --text-dim: #5a5468;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{background:var(--bg);color:var(--text);font-family:'Space Grotesk','Noto Serif SC',sans-serif;min-height:100vh;overflow-x:hidden;}

/* ── SCREENS ── */
.screen{display:none;min-height:100vh;flex-direction:column;}
.screen.active{display:flex;}

/* ── GAME HEADER (shared across screens) ── */
.game-header{width:100%;padding:56px 24px 36px;text-align:center;position:relative;overflow:hidden;}

/* ── SETUP ── */
#screen-setup{align-items:center;padding-bottom:40px;}

.kanji-deco{position:absolute;font-size:min(60vw,420px);font-weight:900;
  font-family:'Noto Serif SC',serif;color:rgba(245,200,66,.03);top:50%;left:50%;
  transform:translate(-50%,-50%);pointer-events:none;line-height:1;
  animation:kanji-breathe 6s ease-in-out infinite;}
@keyframes kanji-breathe{0%,100%{opacity:.03;}50%{opacity:.065;}}

.game-title{font-family:'Noto Serif SC',serif;font-size:clamp(2.8em,9vw,4.4em);font-weight:900;
  letter-spacing:.12em;background:linear-gradient(155deg,#fff 0%,var(--gold) 45%,#d05020 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:fade-up .5s .05s cubic-bezier(.34,1.2,.64,1) both;}

.game-subtitle{font-size:.78em;letter-spacing:.35em;color:var(--text3);margin-top:8px;text-transform:uppercase;}

.setup-form{width:100%;max-width:580px;padding:0 20px;}

.setup-section-title{font-size:.67em;letter-spacing:.3em;color:var(--gold);text-transform:uppercase;margin-bottom:16px;
  display:flex;align-items:center;gap:10px;}
.setup-section-title::after{content:'';flex:1;height:1px;background:var(--b2);}

.player-count-row{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.player-count-row label{font-size:.88em;color:var(--text2);}

.count-btn{width:48px;height:48px;background:var(--s3);border:1px solid var(--b2);color:var(--text2);
  font-size:1.4em;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;
  border-radius:10px;}
.count-btn:hover{background:var(--b2);color:var(--gold);}

#player-count-display{min-width:48px;text-align:center;font-size:1.6em;font-weight:700;color:var(--gold);line-height:48px;}

.player-names-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:16px;}
.player-name-input{display:flex;align-items:center;gap:8px;background:var(--s3);border:1px solid var(--b1);
  border-radius:10px;padding:10px 13px;transition:border-color .2s;}
.player-name-input:focus-within{border-color:var(--gold);}
.player-name-input .idx{font-size:.68em;color:var(--text3);min-width:17px;font-weight:600;}
.player-name-input input{flex:1;background:transparent;border:none;outline:none;color:var(--text);
  font-family:inherit;font-size:.9em;}
.player-name-input input::placeholder{color:var(--text3);}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;
  border:none;border-radius:10px;font-family:inherit;font-size:.86em;font-weight:600;
  cursor:pointer;letter-spacing:.06em;transition:all .15s;white-space:nowrap;}
.btn:active{transform:scale(.97);}

.btn-primary{background:linear-gradient(135deg,#7a0000,#c0392b,#e84040);color:#fff;
  position:relative;overflow:hidden;letter-spacing:.18em;}
.btn-primary::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent,rgba(255,255,255,.07));}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(192,57,43,.45);}

.btn-secondary{background:transparent;border:1px solid var(--b2);color:var(--text2);}
.btn-secondary:hover{border-color:var(--text2);color:var(--text);}

.btn-danger{background:rgba(200,40,40,.18);border:1px solid rgba(200,40,40,.45);color:#ff7070;}
.btn-danger:hover{background:rgba(200,40,40,.3);border-color:var(--red2);}

.btn-info{background:rgba(33,150,243,.13);border:1px solid rgba(33,150,243,.38);color:#64b5f6;}
.btn-info:hover{background:rgba(33,150,243,.25);}

.btn-gold{background:linear-gradient(135deg,#b8860b,#f5c842);border:none;color:#1a1400;font-weight:700;}
.btn-gold:hover{box-shadow:0 4px 16px rgba(245,200,66,.3);transform:translateY(-1px);}

.btn-purple{background:rgba(206,147,216,.13);border:1px solid rgba(206,147,216,.38);color:var(--pur2);}
.btn-purple:hover{background:rgba(206,147,216,.25);}

.btn-sm{padding:6px 13px;font-size:.78em;}
.btn-lg{padding:13px 26px;font-size:1em;}

/* ── ROUND BADGE ── */
.round-badge{display:inline-flex;align-items:center;background:var(--s2);border:1px solid var(--b2);
  border-radius:999px;padding:5px 14px;font-size:.73em;color:var(--gold);letter-spacing:.08em;}

/* ── DEAL SCREEN ── */
#screen-deal{background:var(--bg);}

.deal-instructions{margin:12px 0;padding:11px 15px;background:rgba(245,200,66,.05);
  border:1px solid rgba(245,200,66,.13);border-radius:10px;font-size:.8em;color:var(--text2);
  line-height:1.5;text-align:center;}

.current-player-banner{margin:0 0 14px;background:var(--s1);border:1px solid var(--b2);
  border-radius:20px;padding:18px;text-align:center;position:relative;overflow:hidden;}
.current-player-banner::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;}

.player-name{font-size:1.3em;font-weight:700;}

/* ── FACTION BADGE ── */
.faction-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 14px;
  border-radius:999px;font-size:.78em;font-weight:600;letter-spacing:.07em;}
.faction-red   {background:rgba(232,64,64,.13); border:1px solid var(--red2);  color:#ff7070;}
.faction-blue  {background:rgba(33,150,243,.13);border:1px solid var(--blue2); color:#64b5f6;}
.faction-purple{background:rgba(206,147,216,.13);border:1px solid var(--pur2); color:var(--pur2);}

/* ── NINJA CARDS DISPLAY ── */
.ninja-cards-display{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:14px;}

/* ── NINJA CARD ── */
.ninja-card{width:126px;min-height:182px;border-radius:15px;position:relative;cursor:pointer;
  transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .22s;user-select:none;
  display:flex;flex-direction:column;overflow:hidden;
  background:var(--s2);border:1px solid rgba(255,255,255,.07);}
.ninja-card::after{content:'';position:absolute;inset:0;border-radius:15px;
  background:linear-gradient(135deg,rgba(255,255,255,.045) 0%,transparent 45%,rgba(255,255,255,.03) 100%);pointer-events:none;}

.ninja-card:hover{transform:translateY(-8px) scale(1.04);}
.ninja-card.selected{transform:translateY(-8px) scale(1.06);
  border-color:var(--gold);box-shadow:0 0 0 2px var(--gold),0 12px 36px rgba(245,200,66,.22);}

.ninja-card[data-tag="spy"]:hover     {box-shadow:0 12px 28px rgba(33,150,243,.2);}
.ninja-card[data-tag="assassin"]:hover{box-shadow:0 12px 28px rgba(239,83,80,.22);}
.ninja-card[data-tag="jounin"]:hover  {box-shadow:0 12px 28px rgba(255,112,67,.2);}
.ninja-card[data-tag="trickster"]:hover{box-shadow:0 12px 28px rgba(171,71,188,.2);}
.ninja-card.passive:hover             {box-shadow:0 12px 28px rgba(144,164,174,.15);}

.ninja-cards-display .ninja-card:nth-child(1){animation:fade-up .28s .04s ease both;}
.ninja-cards-display .ninja-card:nth-child(2){animation:fade-up .28s .11s ease both;}
.ninja-cards-display .ninja-card:nth-child(3){animation:fade-up .28s .18s ease both;}

.passive-badge{position:absolute;top:7px;right:7px;font-size:.52em;letter-spacing:.08em;
  background:rgba(144,164,174,.18);border:1px solid rgba(144,164,174,.3);color:#b0bec5;
  padding:2px 5px;border-radius:4px;z-index:2;text-transform:uppercase;}

.card-type{position:absolute;top:8px;left:9px;font-size:.6em;font-weight:700;
  color:rgba(255,255,255,.28);z-index:2;line-height:1;}
.card-icon{flex:1;display:flex;align-items:center;justify-content:center;font-size:2.4em;padding:14px 0 6px;}
.card-name{font-size:.78em;font-weight:700;text-align:center;color:var(--text);padding:0 7px 4px;line-height:1.2;}
.card-num{font-size:.6em;color:var(--text3);text-align:center;padding:0 7px 2px;}
.card-effect{font-size:.6em;color:var(--text3);text-align:center;padding:0 7px 10px;line-height:1.35;}

/* card top band by data-tag */
.ninja-card::before{content:'';display:block;height:3px;width:100%;flex-shrink:0;border-radius:15px 15px 0 0;}
.ninja-card[data-tag="spy"]::before       {background:linear-gradient(90deg,#1565c0,#42a5f5);}
.ninja-card[data-tag="hermit"]::before    {background:linear-gradient(90deg,#00695c,#26a69a);}
.ninja-card[data-tag="trickster"]::before {background:linear-gradient(90deg,#6a1b9a,#ab47bc);}
.ninja-card[data-tag="assassin"]::before  {background:linear-gradient(90deg,#b71c1c,#ef5350);}
.ninja-card[data-tag="jounin"]::before    {background:linear-gradient(90deg,#e65100,#ff7043);}
.ninja-card[data-tag="martyr"]::before    {background:linear-gradient(90deg,#37474f,#90a4ae);}
.ninja-card[data-tag="counter"]::before   {background:linear-gradient(90deg,#37474f,#90a4ae);}
.ninja-card[data-tag="chief"]::before     {background:linear-gradient(90deg,#37474f,#90a4ae);}
.ninja-card.passive::before               {background:linear-gradient(90deg,#37474f,#90a4ae);}

/* ── ACTION PANEL ── */
.action-panel{background:var(--s1);border:1px solid var(--b2);border-radius:20px;padding:18px;margin-top:12px;}
.action-title{font-size:.9em;font-weight:700;margin-bottom:8px;}
.action-buttons{display:flex;gap:8px;flex-wrap:wrap;}
.mt-12{margin-top:12px;}

/* ── PHASE SCREEN ── */
#screen-phase{background:var(--bg);}

.phase-steps{display:flex;padding:12px 0;overflow-x:auto;scrollbar-width:none;margin-bottom:12px;}
.phase-steps::-webkit-scrollbar{display:none;}

.phase-step{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:7px 3px;border-bottom:2px solid var(--b1);transition:all .2s;
  font-size:.76em;color:var(--text3);white-space:nowrap;}
.phase-step.done{border-color:rgba(40,167,69,.35);color:rgba(40,167,69,.65);}
.phase-step.active{border-color:var(--gold);color:var(--gold);}

/* ── PLAYERS GRID ── */
.players-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:9px;margin-bottom:12px;}

.player-token{background:var(--s1);border:1px solid var(--b1);border-radius:14px;
  padding:13px 9px 10px;text-align:center;position:relative;transition:all .2s;overflow:hidden;}
.player-token::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;}
.player-token[data-faction="red"]::before   {background:linear-gradient(90deg,transparent,var(--red2),transparent);}
.player-token[data-faction="blue"]::before  {background:linear-gradient(90deg,transparent,var(--blue2),transparent);}
.player-token[data-faction="ronin"]::before {background:linear-gradient(90deg,transparent,var(--pur2),transparent);}

.player-token.eliminated{opacity:.28;border-style:dashed;}
.player-token.eliminated::after{content:'出局';position:absolute;inset:0;display:flex;align-items:center;
  justify-content:center;font-size:.75em;font-weight:700;color:var(--red);letter-spacing:.1em;
  background:rgba(8,8,16,.55);}

.pt-av{width:34px;height:34px;border-radius:50%;margin:0 auto 7px;display:flex;
  align-items:center;justify-content:center;font-size:.88em;font-weight:700;
  border:2px solid var(--b2);color:var(--text2);background:var(--s3);}
.player-token[data-faction="red"] .pt-av  {border-color:var(--red2);background:rgba(232,64,64,.09);color:#ff7070;}
.player-token[data-faction="blue"] .pt-av {border-color:var(--blue2);background:rgba(33,150,243,.09);color:#64b5f6;}
.player-token[data-faction="ronin"] .pt-av{border-color:var(--pur2);background:rgba(206,147,216,.09);color:var(--pur2);}

.pt-name{font-size:.8em;font-weight:600;margin-bottom:2px;}
.pt-faction{font-size:.63em;color:var(--text3);margin-bottom:4px;}
.pt-honor{font-size:.66em;color:var(--gold);}
.pt-cards{display:flex;gap:3px;justify-content:center;flex-wrap:wrap;margin-top:4px;}
.mini-card{font-size:.56em;padding:2px 4px;border-radius:3px;background:var(--s3);border:1px solid var(--b2);color:var(--text3);}

/* ── LOG PANEL ── */
.log-panel{background:var(--s1);border:1px solid var(--b1);border-radius:12px;overflow:hidden;margin-bottom:12px;}
.log-title{padding:9px 13px 7px;font-size:.62em;letter-spacing:.25em;color:var(--text3);
  text-transform:uppercase;border-bottom:1px solid var(--b1);}
#game-log,#action-log{max-height:115px;overflow-y:auto;padding:5px 13px;scrollbar-width:thin;scrollbar-color:var(--b2) transparent;}
#game-log::-webkit-scrollbar,#action-log::-webkit-scrollbar{width:3px;}
#game-log::-webkit-scrollbar-thumb,#action-log::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px;}

.log-entry{font-size:.76em;padding:3px 0;color:var(--text3);border-bottom:1px solid rgba(37,37,56,.45);
  line-height:1.4;display:flex;gap:6px;align-items:flex-start;}
.log-entry:last-child{border-bottom:none;}
.log-icon{flex-shrink:0;}
.log-kill{color:#ff6b6b;}
.log-info{color:#64b5f6;}
.log-system{color:var(--gold);}

/* ── RESULT SCREEN ── */
#screen-result{align-items:center;padding-bottom:40px;}

.result-box{background:var(--s1);border:1px solid var(--b1);border-radius:20px;padding:22px;
  width:100%;max-width:560px;}
.result-winner{font-family:'Noto Serif SC',serif;font-size:clamp(1.7em,5.5vw,2.4em);font-weight:900;
  letter-spacing:.1em;line-height:1.2;text-align:center;margin-bottom:10px;}

.separator{height:1px;background:var(--b1);margin:16px 0;}

.result-players{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:18px;}
.result-player-card{background:var(--s3);border:1px solid var(--b1);border-radius:12px;
  padding:13px 11px;text-align:center;}
.result-player-card.winner-card{border-color:var(--gold);background:rgba(245,200,66,.05);}
.rp-name{font-weight:700;font-size:.88em;margin-bottom:3px;}
.rp-faction{font-size:.7em;color:var(--text3);margin-bottom:4px;}
.rp-score{font-size:.8em;font-weight:700;color:var(--gold);}

/* ── SCORES SCREEN ── */
#screen-scores{align-items:center;padding:22px 20px 40px;}

.score-table{width:100%;border-collapse:collapse;background:var(--s1);border:1px solid var(--b1);border-radius:12px;overflow:hidden;}
.score-table th{padding:10px 14px;font-size:.72em;letter-spacing:.15em;color:var(--text3);
  text-transform:uppercase;text-align:left;border-bottom:1px solid var(--b1);}
.score-table td{padding:10px 14px;font-size:.88em;border-bottom:1px solid var(--b1);}
.score-table tr:last-child td{border-bottom:none;}
.score-table .champion{background:rgba(245,200,66,.055);}
.score-table .champion td{color:var(--gold);font-weight:700;}

.score-bar{height:3px;background:var(--b2);border-radius:2px;overflow:hidden;margin-top:4px;}
.score-bar-fill{height:100%;background:linear-gradient(90deg,#8b0000,var(--gold));border-radius:2px;transition:width .6s ease;}

/* ── MODAL ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:100;
  align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(5px);}
.modal-overlay.active{display:flex;}

.modal-box{background:var(--s1);border:1px solid var(--b2);border-radius:20px;padding:26px 22px;
  max-width:440px;width:100%;max-height:84vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--b2) transparent;}
.modal-box::-webkit-scrollbar{width:3px;}
.modal-box::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px;}

.modal-title{font-size:.95em;font-weight:700;color:var(--gold);margin-bottom:12px;text-align:center;letter-spacing:.07em;}
.modal-body{font-size:.88em;color:var(--text2);line-height:1.7;margin-bottom:18px;text-align:center;}
.modal-actions{display:flex;gap:9px;justify-content:center;flex-wrap:wrap;}

/* ── PRIVATE INFO / REVEAL ── */
.private-info{background:var(--s3);border:1px solid var(--b2);border-radius:13px;padding:16px;
  margin:10px 0;text-align:center;animation:card-reveal .38s cubic-bezier(.34,1.2,.64,1) both;}
@keyframes card-reveal{0%{transform:rotateY(90deg) scale(.8);opacity:0;}
  60%{transform:rotateY(-6deg) scale(1.02);}100%{transform:rotateY(0) scale(1);opacity:1;}}

.reveal-big{font-size:1.75em;font-weight:700;margin:5px 0;}

/* ── WARN / INFO BOXES ── */
.warn-box{background:rgba(245,200,66,.08);border:1px solid rgba(245,200,66,.2);border-radius:8px;
  padding:8px 12px;margin:8px 0;color:var(--gold);font-size:.82em;}
.info-box{background:rgba(33,150,243,.08);border:1px solid rgba(33,150,243,.2);border-radius:8px;
  padding:8px 12px;margin:8px 0;color:#64b5f6;font-size:.82em;}

/* ── CHOOSE ROW (target selection) ── */
.choose-row{display:flex;gap:7px;flex-wrap:wrap;justify-content:center;margin:10px 0;}
.choose-btn{padding:8px 16px;background:var(--s3);border:1px solid var(--b2);border-radius:9px;
  color:var(--text);font-family:inherit;font-size:.86em;cursor:pointer;transition:all .15s;}
.choose-btn:hover{border-color:var(--gold);color:var(--gold);background:rgba(245,200,66,.05);}

/* ── AUTH FORM ── */
.auth-form{display:flex;flex-direction:column;gap:10px;}

/* ── ROOM PLAYERS LIST ── */
.room-players-list{display:flex;flex-direction:column;gap:8px;}
.room-player-item{display:flex;align-items:center;gap:10px;background:var(--s1);border:1px solid var(--b1);
  border-radius:12px;padding:12px 14px;animation:fade-up .25s ease both;}
.rp-avatar{width:32px;height:32px;border-radius:50%;background:var(--s3);border:2px solid var(--b2);
  display:flex;align-items:center;justify-content:center;font-size:.82em;font-weight:700;color:var(--text2);}
.rp-name{flex:1;font-weight:600;font-size:.9em;}
.rp-host{font-size:.65em;background:rgba(245,200,66,.15);border:1px solid var(--golddim);color:var(--gold);
  padding:2px 8px;border-radius:999px;letter-spacing:.05em;}
.rp-status{font-size:.72em;color:var(--text3);}
.rp-status.ready{color:#4ade80;}

/* ── MY INFO PANEL ── */
.my-info-panel{background:var(--s1);border:1px solid var(--b2);border-radius:16px;padding:14px 16px;margin:12px 0;
  border-left:3px solid var(--gold);}
.my-info-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px;}
.my-name{font-weight:700;font-size:1em;}
.my-score{font-size:.78em;color:var(--gold);margin-left:auto;}
.my-cards{display:flex;gap:6px;flex-wrap:wrap;}
.my-card-chip{font-size:.72em;background:var(--s3);border:1px solid var(--b2);border-radius:6px;
  padding:3px 8px;color:var(--text2);}

/* ── CHAT INPUT ── */
.chat-input-row{display:flex;gap:6px;padding:8px 13px;border-top:1px solid var(--b1);}
.chat-input-row input{flex:1;background:var(--s3);border:1px solid var(--b1);border-radius:8px;
  padding:7px 10px;color:var(--text);font-family:inherit;font-size:.82em;outline:none;}
.chat-input-row input:focus{border-color:var(--gold);}
.chat-input-row input::placeholder{color:var(--text3);}

/* ── COLOR HELPERS ── */
.cr{color:#ff7070;}.cb{color:#64b5f6;}.cp{color:var(--pur2);}.cg{color:var(--gold);}.cd{color:var(--text3);}

/* ── ANIMATIONS ── */
@keyframes fade-up{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}
@keyframes scale-in{from{opacity:0;transform:scale(.92);}to{opacity:1;transform:scale(1);}}

/* ══════════════════════════════════════
   PC 端 (>768px) 适配
   ══════════════════════════════════════ */
@media (min-width: 769px) {
  body {
    display: flex;
    justify-content: center;
    align-items: flex-start;
  }
  .screen {
    max-width: 520px;
    width: 100%;
    margin: 0 auto;
    min-height: 100vh;
    border-left: 1px solid var(--b1);
    border-right: 1px solid var(--b1);
    box-shadow: 0 0 60px rgba(0,0,0,.5);
  }
  .game-header {
    padding: 48px 24px 32px;
  }
  .game-title {
    font-size: 3em;
  }
  .setup-form {
    max-width: 400px;
    margin: 0 auto;
    padding: 0 24px;
  }
  .players-grid {
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  }
  .ninja-cards-display {
    gap: 16px;
  }
  .ninja-card {
    width: 140px;
    min-height: 196px;
  }
  .modal-box {
    max-width: 480px;
  }
  .log-panel {
    max-height: 260px;
  }
  #game-log {
    max-height: 160px;
    overflow-y: auto;
  }
}

/* ══════════════════════════════════════
   超宽屏 (>1200px) — 背景装饰
   ══════════════════════════════════════ */
@media (min-width: 1201px) {
  body::before {
    content: '忍';
    position: fixed;
    font-size: 30vw;
    font-family: 'Noto Serif SC', serif;
    font-weight: 900;
    color: rgba(245, 200, 66, .015);
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    pointer-events: none;
    z-index: -1;
  }
}

/* ══════════════════════════════════════
   小屏幕 (<480px) 微调
   ══════════════════════════════════════ */
@media (max-width: 480px) {
  .game-header { padding: 40px 16px 24px; }
  .game-title { font-size: clamp(2.2em, 8vw, 3em); }
  .ninja-card { width: 105px; min-height: 155px; }
  .card-icon { font-size: 2em; padding: 10px 0 4px; }
  .card-name { font-size: .72em; }
  .card-effect { font-size: .55em; }
  .players-grid { grid-template-columns: repeat(auto-fill, minmax(95px, 1fr)); gap: 7px; }
  .player-token { padding: 10px 6px 8px; }
  .pt-av { width: 28px; height: 28px; font-size: .75em; }
  .pt-name { font-size: .72em; }
  .pt-faction { font-size: .58em; }
  .pt-honor { font-size: .6em; }
}
