/* ═══════════════════════════════════════
   LIVE.CSS — Page Live Game
═══════════════════════════════════════ */

/* Grain overlay */
body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");pointer-events:none;z-index:0;opacity:.5}

/* ── LAYOUT ── */
#app{display:flex;flex-direction:column;height:100vh;position:relative;z-index:1}

/* ── TOPBAR ── */
#topbar{
  height:56px;flex-shrink:0;
  display:flex;align-items:center;gap:16px;padding:0 16px;
  background:linear-gradient(180deg,var(--bg-base) 0%,var(--bg-dark) 100%);
  border-bottom:1px solid var(--border-gold);
  position:relative;
}

/* Logo */
.tb-brand{display:flex;align-items:center;gap:10px;flex-shrink:0;text-decoration:none}
.tb-brand-img{width:38px;height:38px;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--border-gold);box-shadow:var(--gold-glow);flex-shrink:0}
.tb-brand-img img{width:100%;height:100%;object-fit:cover;object-position:top center}
.tb-brand-name{font-family:var(--font-title);font-size:20px;letter-spacing:3px;line-height:1}
.tb-brand-sub{font-size:11px;font-weight:600;letter-spacing:2px;color:var(--gold-3);text-transform:uppercase;display:flex;align-items:center;gap:6px;margin-top:2px}

.tb-sep{width:1px;height:28px;background:var(--border-subtle);flex-shrink:0}

/* Timer */
.tb-timer{font-family:var(--font-title);font-size:30px;letter-spacing:4px;line-height:1;min-width:76px;text-align:center}
.tb-phase{font-size:11px;font-weight:700;letter-spacing:2px;color:var(--gold-3);text-transform:uppercase;border:1px solid var(--border-subtle);border-radius:var(--r-sm);padding:2px 8px;background:var(--gold-dim);white-space:nowrap}

/* Score central */
.tb-score{position:absolute;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:0}
.tb-team{display:flex;align-items:center;gap:12px;padding:0 20px}
.tb-team-label{font-size:12px;font-weight:800;letter-spacing:2px;text-transform:uppercase}
.tb-kills{font-family:var(--font-title);font-size:40px;letter-spacing:2px;line-height:1}
.tb-kills.blue{color:var(--blue);text-shadow:0 0 20px rgba(59,137,214,.5)}
.tb-kills.red{color:var(--red);text-shadow:0 0 20px rgba(232,64,87,.5)}
.tb-mid{display:flex;flex-direction:column;align-items:center;gap:3px}
.tb-vs{font-family:var(--font-title);font-size:15px;letter-spacing:2px;color:var(--text-muted)}
.tb-gdiff{font-size:12px;font-weight:700;font-family:var(--font-mono);padding:2px 8px;border-radius:var(--r-sm)}
.tb-gdiff.pos{color:var(--green-bright);background:rgba(26,255,140,.08);border:1px solid rgba(26,255,140,.2)}
.tb-gdiff.neg{color:var(--red);background:var(--red-dim);border:1px solid rgba(232,64,87,.2)}
.tb-gdiff.neu{color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border-dark)}

/* Right controls */
.tb-right{margin-left:auto;display:flex;align-items:center;gap:10px;flex-shrink:0}

/* Gold bar */
.gold-bar{position:absolute;bottom:0;left:0;right:0;height:2px;display:flex}
.gold-bar-blue{height:100%;background:linear-gradient(90deg,transparent,var(--blue));transition:width .6s}
.gold-bar-red{height:100%;background:linear-gradient(90deg,var(--red),transparent);transition:width .6s}

/* ── MAIN ── */
#main{flex:1;display:grid;grid-template-columns:360px 1fr;overflow:hidden}

/* ── LEFT PANEL ── */
#panel-left{
  background:linear-gradient(180deg,var(--bg-base) 0%,var(--bg-dark) 100%);
  border-right:1px solid var(--border-subtle);
  display:flex;flex-direction:column;overflow:hidden;
}

/* Objectives bar */
#obj-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:6px 12px;border-bottom:1px solid var(--border-subtle);
  background:rgba(0,0,0,.2);flex-shrink:0;
}
.obj-side{display:flex;gap:10px;align-items:center}
.obj-item{display:flex;align-items:center;gap:4px}
.obj-img{width:22px;height:22px;flex-shrink:0}
.obj-img img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 0 3px rgba(200,155,60,.4)) brightness(1.1)}
.obj-val{font-family:var(--font-title);font-size:17px;color:var(--text-muted);letter-spacing:.5px}
.obj-val.active{color:var(--text-primary)}

/* Dragons row */
#drag-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:5px 12px;border-bottom:1px solid var(--border-subtle);
  background:rgba(155,105,255,.04);flex-shrink:0;
}
.drag-pips{display:flex;gap:4px;align-items:center;min-height:24px}
.drag-pip{width:24px;height:24px}
.drag-pip img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 0 4px rgba(155,105,255,.5))}
.drag-soul{font-size:11px;font-weight:700;letter-spacing:1px;color:var(--purple);text-transform:uppercase;border:1px solid rgba(155,105,255,.3);border-radius:var(--r-sm);padding:2px 6px;background:var(--purple-dim)}

/* Gold bar row */
#gold-row{
  display:flex;align-items:center;gap:8px;
  padding:5px 12px;border-bottom:1px solid var(--border-subtle);flex-shrink:0;
}
.gn{font-family:var(--font-title);font-size:16px;letter-spacing:1px;min-width:50px}
.gn.blue{color:var(--blue)}.gn.red{color:var(--red);text-align:right}
.gold-track{flex:1;height:3px;background:var(--bg-card);border-radius:2px;overflow:hidden;display:flex}
.gold-fill-blue{height:100%;background:linear-gradient(90deg,var(--blue),rgba(59,137,214,.4));transition:width .6s}
.gold-fill-red{height:100%;background:linear-gradient(90deg,rgba(232,64,87,.4),var(--red));transition:width .6s}

/* Scoreboard — face-à-face par rôle */
#scoreboard{flex:1;overflow-y:auto;display:flex;flex-direction:column}
.sb-hdr{display:flex;align-items:center;padding:5px 8px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}
.sb-hdr-side{flex:1;display:flex;align-items:center;gap:5px}
.sb-hdr-side.red{justify-content:flex-end}
.sb-team-label{font-family:var(--font-title);font-size:13px;letter-spacing:2px}
.sb-team-label.blue{color:var(--blue)}.sb-team-label.red{color:var(--red)}
.sb-team-gold{font-family:var(--font-mono);font-size:13px;color:var(--gold-1)}
.sb-hdr-mid{width:48px;text-align:center;font-size:10px;letter-spacing:.5px;color:var(--text-muted);text-transform:uppercase}

/* Matchup row */
.sb-matchup{display:flex;align-items:center;padding:5px 6px;border-bottom:1px solid rgba(255,255,255,.03);transition:background var(--t-fast);cursor:default}
.sb-matchup:hover{background:var(--bg-hover)}
.sb-matchup.is-me{background:rgba(200,155,60,.05)}

.sb-half{flex:1;display:flex;align-items:center;gap:5px;min-width:0;overflow:hidden}
.sb-half.red{flex-direction:row-reverse}
.sb-half.red .sb-info{text-align:right}

.sb-champ-wrap{position:relative;flex-shrink:0}
.sb-champ{width:36px;height:36px;border-radius:5px;object-fit:cover;border:1px solid var(--border-dark);display:block}
.sb-lvl{position:absolute;bottom:-3px;right:-3px;width:14px;height:14px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border-gold);font-size:9px;font-weight:700;font-family:var(--font-mono);display:flex;align-items:center;justify-content:center;color:var(--gold-1)}
.sb-half.red .sb-lvl{right:auto;left:-3px}

.sb-info{flex:1;min-width:0}
.sb-pname{font-size:12px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:.2px;line-height:1.3}
.sb-pname.is-me{color:var(--gold-1)}
.sb-pkda{font-size:11px;font-family:var(--font-mono);color:var(--text-secondary);line-height:1.3}
.sb-pkda .k{color:var(--blue-light)}.sb-pkda .d{color:var(--red-light)}.sb-pkda .sep{color:var(--text-muted)}
.sb-pstats{font-size:10px;color:var(--text-muted);font-family:var(--font-mono)}
.sb-pstats .cs{color:var(--text-secondary)}.sb-pstats .gold{color:var(--gold-2)}

.sb-center{width:48px;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:0 2px}
.sb-gdiff{font-size:11px;font-weight:700;font-family:var(--font-mono);padding:2px 5px;border-radius:3px;white-space:nowrap;text-align:center}
.sb-gdiff.pos{color:var(--blue-light);background:rgba(79,158,237,.15)}
.sb-gdiff.neg{color:var(--red-light);background:rgba(232,64,87,.12)}
.sb-gdiff.neu{color:var(--text-muted)}

/* Timers */
#timers-row{
  display:flex;gap:8px;padding:6px 12px;
  border-top:1px solid var(--border-subtle);flex-shrink:0;
  background:rgba(0,0,0,.15);
}
.timer-chip{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:5px 8px;border-radius:var(--r-md);
  background:var(--bg-card);border:1px solid var(--border-dark);
  transition:all var(--t-base);
}
.timer-chip.active{border-color:var(--border-gold);background:var(--gold-dim)}
.timer-chip.active .tc-time{color:var(--gold-1)}
.timer-chip.danger{border-color:var(--red);background:var(--red-dim);animation:pulse .8s infinite}
.timer-chip.danger .tc-time{color:var(--red)}
.tc-icon{font-size:16px;line-height:1}
.tc-icon img{width:18px;height:18px;object-fit:contain}
.tc-label{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted)}
.tc-time{font-family:var(--font-mono);font-size:14px;font-weight:600;color:var(--text-secondary)}

/* ── CENTER ── */
#panel-center{display:flex;flex-direction:column;overflow:hidden;background:var(--bg-void)}

/* Stream */
#stream-wrap{position:relative;background:#000;flex-shrink:0;overflow:hidden}
#stream-wrap iframe{width:100%;height:100%;border:none;display:block}
.stream-badge{position:absolute;top:10px;left:10px;display:flex;align-items:center;gap:6px;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);border:1px solid var(--border-gold);border-radius:var(--r-sm);padding:4px 10px;font-size:12px;font-weight:700;letter-spacing:1px;pointer-events:none;z-index:5}

/* Events */
#events-wrap{flex:1;overflow:hidden;display:flex;flex-direction:column}
.events-hdr{display:flex;align-items:center;justify-content:space-between;padding:6px 14px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}
.events-title{font-family:var(--font-title);font-size:14px;letter-spacing:2px;color:var(--gold-1)}
#events-feed{flex:1;overflow-y:auto;padding:6px 0}
.ev-empty{text-align:center;color:var(--text-muted);font-size:13px;padding:20px;letter-spacing:.5px}
.ev-row{display:flex;align-items:center;gap:8px;padding:5px 14px;border-bottom:1px solid rgba(255,255,255,.02);transition:background var(--t-fast);min-height:28px}
.ev-row:hover{background:var(--bg-hover)}
.ev-row.new{animation:ev-in .3s ease}
@keyframes ev-in{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:none}}
.ev-time{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);min-width:32px;flex-shrink:0}
.ev-icon{width:20px;height:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.ev-icon img{width:18px;height:18px;object-fit:contain;filter:drop-shadow(0 0 4px rgba(155,105,255,.4))}
.ev-text{font-size:13px;color:var(--text-secondary);flex:1;line-height:1;display:flex;align-items:center;gap:4px;flex-wrap:nowrap;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.ev-text strong{color:var(--text-primary);white-space:nowrap}
.ev-text img{width:16px;height:16px;border-radius:2px;flex-shrink:0;vertical-align:middle}

/* Summary */
#summary-wrap{
  padding:8px 14px;border-top:1px solid var(--border-subtle);flex-shrink:0;
  background:var(--bg-surface);
}
.summary-title{font-size:11px;font-weight:700;letter-spacing:2px;color:var(--gold-3);text-transform:uppercase;margin-bottom:5px}
#summary-text{font-size:13px;color:var(--text-secondary);line-height:1.6}
.summary-item{display:flex;align-items:center;gap:6px;padding:2px 0}
.summary-dot{width:5px;height:5px;border-radius:50%;background:var(--gold-1);flex-shrink:0}

/* ── RIGHT PANEL — Chat ── */
#panel-right{
  background:linear-gradient(180deg,var(--bg-base) 0%,var(--bg-dark) 100%);
  border-left:1px solid var(--border-subtle);
  display:flex;flex-direction:column;overflow:hidden;
}
#chat-hdr{padding:8px 14px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
#chat-title{font-family:var(--font-title);font-size:16px;letter-spacing:2px;display:flex;align-items:center;gap:8px}
.twitch-icon{width:8px;height:8px;border-radius:50%;background:var(--purple);box-shadow:0 0 8px var(--purple)}
#chat-body{flex:1;overflow:hidden;display:flex;flex-direction:column}
#chat-frame{flex:1;overflow:hidden}
#chat-frame iframe{width:100%;height:100%;border:none}
#chat-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:24px;text-align:center}
.chat-ph-icon{font-size:28px;color:var(--purple)}
.chat-ph-text{font-size:13px;color:var(--text-muted);line-height:1.7}
.chat-ph-text strong{color:var(--text-primary)}

/* ── LOADING OVERLAY ── */
#loading{
  position:fixed;inset:0;background:rgba(1,10,19,.95);
  display:none;align-items:center;justify-content:center;
  z-index:999;backdrop-filter:blur(8px);
}
.loading-box{text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}
.loading-title{font-family:var(--font-title);font-size:28px;letter-spacing:4px;color:var(--gold-1)}
.loading-sub{font-size:13px;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase}

/* ── STREAM LAYOUT CALC ── */
#stream-wrap{height:calc((100vw - 360px) * 9 / 16);max-height:50vh;min-height:200px}

/* ═══════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════ */
@media (max-width:900px){
  .tb-brand-sub{display:none}
  .tb-phase{display:none}
  .tb-kills{font-size:30px}
  .tb-team{padding:0 10px;gap:8px}
  .tb-timer{font-size:24px;min-width:60px}
}

@media (max-width:768px){
  /* Body scrollable */
  body{overflow-y:auto;height:auto}
  #app{height:auto;min-height:100dvh}

  /* Topbar: empile le score sur une 2e ligne */
  #topbar{height:auto;flex-wrap:wrap;padding:8px 10px;gap:6px 10px}
  .tb-score{position:static;transform:none;order:10;width:100%;justify-content:center;padding:4px 0 2px}
  .tb-kills{font-size:24px}
  .tb-right{order:9;margin-left:auto}
  .tb-sep{display:none}
  .tb-timer{font-size:20px;min-width:52px}
  .tb-brand-name{font-size:16px;letter-spacing:2px}
  .gold-bar{position:static;order:11;width:100%}

  /* Main: colonne */
  #main{display:flex !important;flex-direction:column;overflow-y:auto;overflow-x:hidden;height:auto}
  #panel-center{order:1}
  #panel-left{order:2;border-right:none;border-top:1px solid var(--border-subtle)}

  /* Stream pleine largeur */
  #stream-wrap{height:calc(100vw * 9 / 16) !important;max-height:none;min-height:0}

  /* Events: hauteur limitée */
  #events-wrap{height:260px;min-height:260px}

  /* Scoreboard: pas de overflow caché */
  #scoreboard{overflow:visible;flex:none}

  /* Topbar controls: boutons plus petits */
  .tb-right .btn{padding:4px 10px;font-size:12px}
}

@media (max-width:480px){
  .tb-team-label{display:none}
  .tb-kills{font-size:20px}
  .tb-brand-img{width:30px;height:30px}
  #topbar{padding:6px 8px}
  .sb-pname{font-size:11px}
}
