/* ===== MAFIA GAME - NEW DESIGN ===== */
@font-face{font-family:'Lifta';src:url('/fonts/Liftaswashfixed-Regular.otf') format('opentype');font-display:swap}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#06060B;--bg2:#0C0C14;--bg3:#14141E;
  --card:rgba(255,255,255,0.025);--card2:rgba(255,255,255,0.045);
  --b1:rgba(255,255,255,0.04);--b2:rgba(255,255,255,0.08);
  --t1:#E2DED6;--t2:#6E6A62;--t3:#3A3832;
  --accent:#C4A265;--accent2:#A08448;--accentDim:rgba(196,162,101,0.08);
  --red:#C03040;--redDim:rgba(192,48,64,0.1);
  --green:#2D9B64;--greenDim:rgba(45,155,100,0.1);--greenGlow:rgba(45,155,100,0.25);
  --h:'Lifta','Noto Kufi Arabic',sans-serif;
  --f:'Lifta','IBM Plex Sans Arabic',sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
}
html{scroll-behavior:smooth}
body{font-family:var(--f);color:var(--t1);background:var(--bg);min-height:100vh;
-webkit-font-smoothing:antialiased;overflow-x:hidden}
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.35;
background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.02'/%3E%3C/svg%3E")}
.hidden{display:none!important}

/* Screens */
.screen{display:none;min-height:100vh;position:relative;z-index:1}
.screen.active{display:flex}

/* ===== LANDING ===== */
.landing-wrapper{width:100%;display:flex;align-items:center;justify-content:center;min-height:100vh;padding:32px 20px;
background:radial-gradient(circle at 50% 40%,rgba(196,162,101,0.02),transparent 50%)}
.landing-logo-side{flex-shrink:0;text-align:center}
.landing-logo-img{width:260px;filter:drop-shadow(0 8px 32px rgba(0,0,0,.5))}
.landing-form-side{width:320px;flex-shrink:0}
.landing-card{background:var(--bg2);border:1px solid var(--b2);border-radius:16px;padding:26px;
display:flex;flex-direction:column;gap:0}
.form-label{font-size:10px;font-weight:600;color:var(--accent2);margin-bottom:6px;display:block;letter-spacing:.8px}
.form-section{margin-bottom:4px}
.landing-card input[type="text"]{width:100%;padding:12px 18px;background:rgba(255,255,255,0.025);border:1px solid var(--b2);
border-radius:8px;color:var(--t1);font-family:var(--f);font-size:13px;text-align:center;outline:none;transition:.3s}
.landing-card input:focus{border-color:rgba(196,162,101,0.3)}
.landing-card input::placeholder{color:var(--t3)}
.card-divider{height:1px;background:var(--b1);margin:16px 0}
.error-msg{text-align:center;color:var(--red);font-size:11px;margin-top:8px;padding:8px;background:var(--redDim);border-radius:8px}

.btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:12px;border:none;
border-radius:8px;font-family:var(--f);font-size:13px;font-weight:700;cursor:pointer;transition:.25s}
.btn-green{background:var(--accent2);color:#080808}
.btn-green:hover{background:var(--accent);transform:translateY(-1px)}
.btn-lg{padding:12px}
.btn-accent{background:var(--red);color:#fff}
.btn-accent:hover{filter:brightness(1.1);transform:translateY(-1px)}
.btn-ghost{background:var(--bg3);border:1px solid var(--b2);color:var(--t2);font-size:11px;padding:10px}
.btn-primary{background:var(--accent2);color:#080808;flex:1}
.btn-secondary{background:var(--bg3);border:1px solid var(--b2);color:var(--t2);flex:1}
.btn-icon-small{background:none;border:none;font-size:16px;cursor:pointer;opacity:.4;transition:.2s;padding:4px}

/* ===== LOBBY ===== */
#screen-lobby{justify-content:center;padding:36px 20px}
.lobby-container{max-width:560px;width:100%;animation:rise .5s var(--ease)}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.lobby-header{text-align:center;margin-bottom:24px}
.lobby-header h2{font-family:var(--h);font-size:20px;font-weight:800;margin-bottom:12px}
.room-code-display{display:inline-flex;align-items:center;gap:10px;background:var(--bg3);
border:1px solid var(--b2);border-radius:10px;padding:8px 20px}
.room-code-display span{font-family:var(--h);font-size:22px;font-weight:900;letter-spacing:6px;color:var(--accent)}
.lobby-players h3{font-size:14px;font-weight:700;color:var(--t2);margin-bottom:10px}
.lobby-players{margin-bottom:20px}
.players-grid{display:flex;flex-wrap:wrap;gap:6px}
.player-card{padding:8px 16px;background:var(--bg3);border:1px solid var(--b1);border-radius:6px;font-size:12px;font-weight:600}
.player-card.host{border-color:rgba(196,162,101,0.2);color:var(--accent)}
.host-badge{margin-right:6px;font-size:10px}
.btn-kick{background:none;border:none;color:var(--red);font-size:14px;cursor:pointer;margin-right:6px;opacity:.5;transition:.2s}
.btn-kick:hover{opacity:1}
.settings-panel{background:var(--bg2);border:1px solid var(--b2);border-radius:14px;padding:22px;margin-top:6px}
.settings-panel h3{font-family:var(--h);font-size:14px;font-weight:700;margin-bottom:14px}
.setting-group{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--b1)}
.setting-group:last-of-type{border:none}
.setting-group label{font-size:12px;color:var(--t2)}
.counter-control{display:flex;align-items:center;gap:10px}
.btn-counter{width:28px;height:28px;border-radius:6px;background:var(--bg3);border:1px solid var(--b2);
color:var(--t2);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.counter-control span{font-family:var(--h);font-size:14px;font-weight:700;min-width:28px;text-align:center}
.counter-input{width:52px;text-align:center;background:transparent;border:1px solid var(--b2);border-radius:6px;
color:var(--t1);font-family:var(--h);font-size:14px;font-weight:700;padding:4px;outline:none;
-moz-appearance:textfield;appearance:textfield}
.counter-input::-webkit-inner-spin-button,.counter-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.counter-input:focus{border-color:rgba(196,162,101,0.3)}
.roles-toggles{display:flex;flex-wrap:wrap;gap:4px;margin:8px 0}
.role-toggle{cursor:pointer}
.role-toggle input{display:none}
.role-badge{padding:5px 12px;border-radius:5px;background:var(--bg3);border:1px solid var(--b1);font-size:10px;font-weight:600;display:inline-block;transition:.2s}
.role-toggle input:checked+.role-badge{border-color:rgba(45,155,100,0.3);color:var(--green);background:var(--greenDim)}
.toggle-group{display:flex;gap:4px}
.btn-toggle{padding:5px 14px;border-radius:5px;background:var(--bg3);border:1px solid var(--b1);font-size:10px;font-weight:600;cursor:pointer;color:var(--t2);font-family:var(--f)}
.btn-toggle.active{border-color:rgba(196,162,101,0.3);color:var(--accent);background:var(--accentDim)}
.waiting-section{text-align:center;padding:30px;color:var(--t2);font-size:13px}
.waiting-spinner{width:28px;height:28px;border:2.5px solid var(--b2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 12px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== GAME ===== */
.game-container{width:100%;height:100vh;display:flex;flex-direction:column}
.game-topbar{display:flex;align-items:center;justify-content:space-between;padding:7px 14px;
background:rgba(6,6,11,0.88);backdrop-filter:blur(20px);border-bottom:1px solid var(--b1);flex-shrink:0}
.my-role-badge{padding:5px 14px;border-radius:8px;font-size:11px;font-weight:700;color:var(--green);
background:var(--greenDim);border:1px solid rgba(45,155,100,0.2)}
.timer-pill{display:inline-flex;align-items:center;gap:5px;padding:5px 14px;border-radius:8px;
font-family:var(--h);font-size:12px;font-weight:800;color:var(--accent);background:var(--accentDim);border:1px solid rgba(196,162,101,0.12)}
.timer-label{font-family:var(--f);font-size:9px;font-weight:600;color:var(--t2);margin-left:4px}
.timer-pill.timer-warning{animation:timer-pulse 1s infinite;border-color:var(--red)}
@keyframes timer-pulse{0%,100%{background:rgba(192,48,64,0.15)}50%{background:rgba(192,48,64,0.35)}}
.timer-icon{font-size:11px}
.day-badge{font-size:10px;font-weight:600;color:var(--t2);background:var(--bg3);padding:4px 10px;border-radius:5px}

.game-body{flex:1;display:flex;overflow:hidden}
.game-sidebar{width:230px;padding:10px;overflow-y:auto;border-left:1px solid var(--b1);display:flex;flex-direction:column;gap:8px;flex-shrink:0}
.game-players-area{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:20px;overflow-y:auto}

/* Side panels */
.side-panel{display:flex;flex-direction:column;gap:8px}
.info-card,.defense-card,.kamikaze-card,.observer-card{background:var(--bg2);border:1px solid var(--b1);border-radius:10px;padding:12px}
.info-card h3{font-family:var(--h);font-size:12px;font-weight:700;margin-bottom:4px}
.info-desc{font-size:10px;color:var(--t2);line-height:1.7}
.info-card-title{font-family:var(--h);font-size:11px;font-weight:700;margin-bottom:6px}
.accent-red{color:var(--red)!important}
.role-card{border-radius:10px;overflow:hidden;border:1px solid var(--b1)}
.role-card-inner{padding:18px;text-align:center;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,var(--bg3),var(--bg2))}
.role-card-icon{font-size:32px}
.role-card-glow{display:none}
.role-card-action{padding:7px;text-align:center;font-size:10px;font-weight:700;background:var(--bg3);color:var(--accent2)}
.role-card.mafia .role-card-inner{background:linear-gradient(160deg,#1A0A0E,#100508)}
.role-card.detective .role-card-inner{background:linear-gradient(160deg,#0A1820,#081418)}
.role-card.doctor .role-card-inner{background:linear-gradient(160deg,#0A1E14,#081610)}
.role-card.sniper .role-card-inner{background:linear-gradient(160deg,#101520,#0C1018)}
.role-card.serial_killer .role-card-inner{background:linear-gradient(160deg,#1A0E10,#140A0C)}
.role-card.citizen .role-card-inner{background:linear-gradient(160deg,#0E1520,#0A1018)}
.role-card.jester .role-card-inner{background:linear-gradient(160deg,#1E1A0A,#14100A)}
.role-card.kamikaze .role-card-inner{background:linear-gradient(160deg,#1E140A,#140E08)}
.role-card.mayor .role-card-inner{background:linear-gradient(160deg,#1E1A0A,#14100A)}
.role-card.observer .role-card-inner{background:linear-gradient(160deg,#14101E,#0E0A18)}
.defense-name{font-family:var(--h);font-size:16px;font-weight:800;color:var(--accent);margin:8px 0}
.revote-buttons{display:flex;gap:8px;margin-top:10px}
.revote-buttons .btn{flex:1}
.top-votes-list{display:flex;flex-direction:column;gap:3px}
.top-vote-item{font-size:10px;color:var(--t2);display:flex;align-items:center;gap:4px}
.top-vote-item .rank{font-weight:800;color:var(--accent);width:14px}
.votes-against-num{font-family:var(--h);font-size:24px;font-weight:900;color:var(--red);text-align:center;padding:6px 0}
.my-vote-display{font-size:10px;color:var(--green)}
.eliminated-card{background:var(--bg2);border:1px solid rgba(192,48,64,0.1);border-radius:10px;padding:12px}
.eliminated-list{display:flex;flex-wrap:wrap;gap:4px}
.eliminated-tag{background:var(--redDim);border:1px solid rgba(192,48,64,0.15);padding:2px 10px;border-radius:5px;font-size:9px;font-weight:600;color:var(--red)}
.side-targets{display:flex;flex-direction:column;gap:4px}
.target-btn{padding:8px;background:var(--bg3);border:1px solid var(--b2);border-radius:8px;color:var(--t1);font-family:var(--f);font-size:12px;font-weight:600;cursor:pointer;text-align:center;transition:.2s}
.target-btn.selected{border-color:var(--green);background:var(--greenDim);color:var(--green)}
.vote-count-badge{background:var(--red);color:#fff;font-size:9px;padding:1px 6px;border-radius:4px;margin-right:6px}
.waiting-box{text-align:center;padding:16px;color:var(--t2);font-size:11px}
.suspects-list{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}

/* Bottombar */
.game-bottombar{display:flex;align-items:center;justify-content:space-between;padding:7px 14px;
background:rgba(6,6,11,0.92);border-top:1px solid var(--b1);flex-shrink:0}
.roles-bar{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.roles-bar-label{font-size:9px;color:var(--t3);font-weight:600}
.roles-pills{display:flex;gap:3px;flex-wrap:wrap}
.role-pill{padding:3px 8px;border-radius:4px;font-size:8px;font-weight:600;background:var(--bg3);color:var(--t2);border:1px solid var(--b1)}
.voice-controls{display:flex;gap:5px}
.btn-voice{width:34px;height:34px;border-radius:7px;background:var(--bg3);border:1px solid var(--b2);
display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;color:var(--t2);transition:.2s}
.btn-voice.muted{background:var(--redDim);border-color:rgba(192,48,64,0.2);color:var(--red)}
.phase-orb{position:fixed;bottom:54px;left:10px;width:34px;height:34px;border-radius:8px;
display:flex;align-items:center;justify-content:center;z-index:50;font-size:16px;
background:var(--bg2);border:1px solid var(--b2)}

/* Announcement */
.announcement{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;
background:rgba(6,6,11,0.85);backdrop-filter:blur(8px)}
.announcement-content{text-align:center;padding:32px;max-width:400px}
.announcement-content p{font-family:var(--h);font-size:18px;font-weight:800;color:var(--accent)}

/* ===== PLAYER CARDS - NEW ===== */
.avatar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;max-width:520px;width:100%}
.avatar-card{cursor:default;transition:transform .2s var(--ease)}
.avatar-card:hover{transform:translateY(-3px)}
.avatar-body{position:relative;width:100%;aspect-ratio:.82;border-radius:14px;overflow:hidden;border:2px solid var(--b2);transition:all .25s;background:var(--bg2)}

.card-top{position:absolute;top:0;left:0;right:0;height:65%;display:flex;align-items:center;justify-content:center;overflow:hidden}
.card-bottom{position:absolute;bottom:0;left:0;right:0;height:35%;display:flex;align-items:center;justify-content:center;background:var(--bg3);border-top:1px solid rgba(0,0,0,.3)}
.avatar-status{position:absolute;top:7px;right:7px;width:7px;height:7px;border-radius:50%;z-index:5;box-shadow:0 0 6px currentColor}
.status-alive{background:var(--green);color:var(--green)}
.status-dead{background:var(--red);color:var(--red)}
.status-disconnected{background:#555;color:#555}
.avatar-role-icon{width:44px;height:44px;object-fit:contain;z-index:2;opacity:.9}
.avatar-name{font-family:var(--h);font-size:clamp(8px,2vw,11px);font-weight:700;color:var(--t1);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:85%}
.avatar-mic{position:absolute;bottom:6px;left:6px;z-index:5;width:22px;height:22px;object-fit:contain;opacity:.7;filter:drop-shadow(0 1px 2px rgba(0,0,0,.6))}
.avatar-votes{position:absolute;top:7px;left:7px;z-index:6;background:var(--red);color:#fff;font-size:8px;font-weight:900;font-family:var(--h);min-width:16px;height:16px;border-radius:4px;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 2px 6px rgba(0,0,0,.4)}
.avatar-card.selected .avatar-body{border-color:var(--green);box-shadow:0 0 20px var(--greenGlow)}
.avatar-selected-check{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;background:var(--green);width:28px;height:28px;border-radius:50%;display:none;align-items:center;justify-content:center;font-size:13px;font-weight:900;color:#fff;box-shadow:0 4px 16px rgba(0,0,0,.5)}
.avatar-card.selected .avatar-selected-check{display:flex}
.avatar-card.me .avatar-body{border-color:var(--green);box-shadow:0 0 14px rgba(45,155,100,0.12)}
.avatar-card.dead .avatar-body{opacity:.5;pointer-events:none}
.avatar-card.dead .card-top{filter:grayscale(.6)}
.avatar-card.dead:hover{transform:none}
.avatar-dead-x{display:none}
.avatar-suspect-badge{position:absolute;top:5px;right:5px;z-index:6;font-size:12px;animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}

/* Card themes */
.card-theme-unknown .card-top{background:linear-gradient(160deg,#1A2E42,#14243A)}
.card-theme-mafia .card-top{background:linear-gradient(160deg,#3A1420,#2A0C16)}
.card-theme-detective .card-top{background:linear-gradient(160deg,#0E2E2A,#0A2220)}
.card-theme-doctor .card-top{background:linear-gradient(160deg,#0E2A18,#082012)}
.card-theme-sniper .card-top{background:linear-gradient(160deg,#141824,#0E1420)}
.card-theme-serial_killer .card-top{background:linear-gradient(160deg,#2A1418,#1E0C10)}
.card-theme-jester .card-top{background:linear-gradient(160deg,#2A2210,#1E1A0A)}
.card-theme-kamikaze .card-top{background:linear-gradient(160deg,#2A1E10,#1E140A)}
.card-theme-mayor .card-top{background:linear-gradient(160deg,#2A2410,#1E1A0A)}
.card-theme-observer .card-top{background:linear-gradient(160deg,#1E182A,#14101E)}
.card-theme-citizen .card-top{background:linear-gradient(160deg,#142030,#0E1824)}
.card-theme-killed .card-top{background:linear-gradient(160deg,#1A1A22,#121218)}
.card-theme-voted .card-top{background:linear-gradient(160deg,#1E1A18,#161210)}
.card-theme-disconnected .card-top{background:linear-gradient(160deg,#1A1A1A,#141414)}

/* Game over */
.gameover-container{max-width:520px;width:100%;margin:0 auto;text-align:center;padding:40px 20px}
.gameover-result{margin-bottom:24px}
.gameover-result p{font-family:var(--h);font-size:18px;font-weight:800;color:var(--accent);margin-top:8px}
.gameover-roles{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:6px;margin-bottom:24px}
.gameover-role-card{background:var(--bg2);border:1px solid var(--b1);border-radius:8px;padding:10px;text-align:center}
.gameover-role-card.dead{opacity:.4}
.gameover-role-card .role-name{font-size:10px;color:var(--accent2);margin-top:3px}
#screen-gameover{justify-content:center;align-items:center}

/* Toast */
.toast-container{position:fixed;top:12px;left:50%;transform:translateX(-50%);z-index:1000;display:flex;flex-direction:column;gap:6px;pointer-events:none}
.toast{padding:10px 20px;border-radius:8px;font-size:11px;font-weight:600;animation:toastIn .3s ease;pointer-events:auto;backdrop-filter:blur(12px)}
.toast.info{background:rgba(196,162,101,0.12);border:1px solid rgba(196,162,101,0.2);color:var(--accent)}
.toast.success{background:var(--greenDim);border:1px solid rgba(45,155,100,0.2);color:var(--green)}
.toast.error{background:var(--redDim);border:1px solid rgba(192,48,64,0.2);color:var(--red)}
@keyframes toastIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}

@media(max-width:768px){
  .landing-wrapper{padding:20px}
  .landing-wrapper > div{flex-direction:column-reverse!important;gap:20px!important}
  .landing-logo-side .landing-logo-img{width:160px}
  .landing-form-side{width:100%;max-width:100%}
  
  /* Topbar mobile */
  .game-topbar{padding:5px 8px;flex-wrap:wrap;gap:4px}
  .my-role-badge{font-size:9px;padding:4px 8px}
  .my-role-badge img{width:12px!important;height:12px!important}
  .timer-pill{font-size:10px;padding:4px 10px}
  .timer-label{font-size:8px}
  .day-badge{font-size:9px;padding:3px 8px}
  
  /* Game body mobile */
  .game-body{flex-direction:column}
  .game-sidebar{width:100%;border-left:none;border-top:1px solid var(--b1);
    max-height:28vh;order:2;overflow-y:auto;padding:8px}
  .game-players-area{order:1;padding:10px;flex:1}
  
  /* Cards mobile */
  .avatar-grid{grid-template-columns:repeat(3,1fr);gap:8px;max-width:100%}
  .avatar-role-icon{width:32px;height:32px}
  .avatar-name{font-size:9px}
  .avatar-votes{font-size:7px;min-width:14px;height:14px}
  .avatar-status{width:6px;height:6px;top:5px;right:5px}
  .avatar-mic{width:18px;height:18px}
  
  /* Bottombar mobile */
  .game-bottombar{padding:5px 8px;flex-wrap:wrap;gap:4px}
  .roles-bar-label{font-size:8px}
  .role-pill{font-size:7px;padding:2px 6px}
  .btn-voice{width:30px;height:30px;font-size:12px}
  
  /* Phase orb mobile */
  .phase-orb{bottom:48px;left:6px;width:28px;height:28px;font-size:13px}
  
  /* Sidebar panels mobile */
  .info-card{padding:8px}
  .info-card h3{font-size:11px}
  .info-desc{font-size:9px}
  .target-btn{padding:6px;font-size:11px}
  .defense-name{font-size:14px}
  
  /* Lobby mobile */
  .lobby-container{padding:0 10px}
  .settings-panel{padding:14px}
  .setting-group label{font-size:11px}
  .counter-input{width:44px;font-size:12px}
  .btn-counter{width:26px;height:26px;font-size:12px}
  .role-badge{font-size:9px;padding:4px 10px}
  
  /* Announcement mobile */
  .announcement-content p{font-size:15px}
  
  /* Game over mobile */
  .gameover-container{padding:20px 10px}
  .gameover-roles{grid-template-columns:repeat(2,1fr)}
}
