/* Dark, legible, modern UX */
:root{
  --bg:#0b1020;
  --panel:#121a33;
  --panel2:#0f1730;
  --text:#e7ebff;
  --muted:#9aa6d6;
  --accent:#6ea8fe;
  --danger:#ff5c7a;
  --ghost:#263156;
  --shadow: 0 14px 40px rgba(0,0,0,.45);
  --border: rgba(255,255,255,.10);
  --focus: rgba(110,168,254,.25);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  background: radial-gradient(1200px 700px at 10% 0%, rgba(110,168,254,.22), transparent 55%),
              radial-gradient(800px 500px at 90% 0%, rgba(255,92,122,.18), transparent 60%),
              var(--bg);
  background-repeat: no-repeat;
  background-position: top left;
  background-attachment: fixed;
  color:var(--text);
}

.app{
  width: min(1600px, calc(100vw - 24px));
  margin: 18px auto;
  display:flex;
  flex-direction:column;
  gap: 14px;
}

.topbar{
  display:flex;
  gap: 14px;
  align-items: stretch;
}

.trackbig{
  flex: 1;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 16px 18px;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 120px;
}

.trackbig__main{display:flex; flex-direction:column; gap:6px;}
.trackbig__turn{color: var(--muted); font-weight: 900; letter-spacing: .4px; font-size: 16px;}
.trackbig__phase{font-size: 34px; font-weight: 1000; line-height: 1.05;}

.trackbig__sub{display:flex; justify-content:space-between; align-items:center; gap: 12px;}
.trackbig__active{color: var(--muted); font-weight: 850; font-size: 13px;}
.trackbig__passes{display:flex; gap: 10px; align-items:center;}

.badge{
  min-width: 190px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  padding: 10px 12px;
  border-radius: 14px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 950;
  text-align: center;
}
.badge.is-passed{
  color: var(--text);
  border-color: rgba(110,168,254,.35);
  background: rgba(110,168,254,.12);
}
.badge--p2.is-passed{
  border-color: rgba(255,92,122,.35);
  background: rgba(255,92,122,.12);
}

.controlsCard{
  width: 360px;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 16px 18px;
  box-shadow: var(--shadow);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap: 12px;
}
.controlsCard__row{display:flex; gap: 10px;}
.controlsCard__row .btn{flex:1}
.controlsCard__help{color: var(--muted); font-size: 12px; line-height: 1.35; font-weight: 750;}

.brand{
  flex: 1;
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 16px 18px;
  box-shadow: var(--shadow);
}
.brand__title{font-weight:800; letter-spacing:.3px; font-size: 18px;}
.brand__subtitle{margin-top:6px; color:var(--muted); font-size: 13px;}

.turncard{
  width: 520px;
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 14px;
  box-shadow: var(--shadow);
  display:flex;
  flex-direction:column;
  gap: 10px;
}
.turncard__row{display:flex; justify-content:space-between; gap: 10px; align-items:center;}
.turncard__row--active{padding: 10px 12px; border-radius: 14px; background: rgba(110,168,254,.08); border: 1px solid rgba(110,168,254,.18)}
.turncard__activeLabel{color: var(--muted); font-size: 13px; font-weight: 600;}
.turncard__activeValue{font-size: 15px; font-weight: 800;}

.turncard__controls{display:flex; gap: 10px;}
.turncard__passRow{display:flex; justify-content:space-between; gap: 10px; margin-top:2px;}
.passstat{
  flex:1;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  padding: 10px 12px;
  border-radius: 14px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 650;
  text-align:center;
}
.passstat.is-passed{color: var(--text); border-color: rgba(110,168,254,.35); background: rgba(110,168,254,.12)}

.pill{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  font-size: 13px;
  font-weight: 700;
  color: var(--muted);
}
.pill--phase{flex:1; justify-content:center;}

.main{
  display:flex;
  gap: 14px;
  align-items: stretch;
}
.players{
  flex: 1;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.playercard{
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 14px;
  box-shadow: var(--shadow);
  display:flex;
  flex-direction:column;
  gap: 12px;
  min-height: 240px;
}
.playercard__head{display:flex; justify-content:space-between; gap: 10px; align-items:baseline;}
.playercard__name{font-weight:900; font-size: 16px;}
.playercard__tag{color: var(--muted); font-size: 12px; font-weight:700; border: 1px solid rgba(255,255,255,.12); padding: 6px 10px; border-radius: 999px; background: rgba(255,255,255,.04)}

.playercard[data-player="1"] .playercard__tag.is-active{border-color: rgba(110,168,254,.40); background: rgba(110,168,254,.12); color: var(--text)}
.playercard[data-player="2"] .playercard__tag.is-active{border-color: rgba(255,92,122,.35); background: rgba(255,92,122,.12); color: var(--text)}

.playercard{
  transition: border-color .15s ease, box-shadow .15s ease;
}

/* Active player's base card glow during Phase B */
.playercard.is-active-p1{
  border-color: rgba(110,168,254,.55);
  box-shadow: 0 0 0 1px rgba(110,168,254,.12), 0 0 40px rgba(110,168,254,.28), var(--shadow);
}

.playercard.is-active-p2{
  border-color: rgba(255,92,122,.50);
  box-shadow: 0 0 0 1px rgba(255,92,122,.12), 0 0 40px rgba(255,92,122,.25), var(--shadow);
}

.healthRow{display:flex; justify-content:space-between; align-items:baseline; gap: 10px; padding: 10px 12px; border-radius: 14px; border: 1px solid rgba(255,255,255,.10); background: rgba(0,0,0,.14)}
.healthRow__label{color: var(--muted); font-weight: 750; font-size: 13px;}
.hpDelta{
  min-height: 22px;
  margin-top: 2px;
  font-size: 22px;
  font-weight: 950;
  letter-spacing: .2px;
}
.hpDelta--pos{color: #4ee59a;}
.hpDelta--neg{color: var(--danger);}

.healthRow__value{font-size: 132px; font-weight: 950; letter-spacing: .5px;}

.quickBtns{display:flex; gap: 10px; justify-content:space-between;}
.quickBtns .btn{flex:1}

.rules{
  width: 520px;
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 14px;
  box-shadow: var(--shadow);
  display:flex;
  flex-direction:column;
  gap: 12px;
  min-height: 320px;
}
.rules__head{display:flex; justify-content:space-between; align-items:baseline; gap: 10px;}
.rules__title{font-size: 16px; font-weight: 950;}
.rules__hint{color: var(--muted); font-size: 12px;}

.rulesList{
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.14);
  padding: 10px;
  max-height: 360px;
  overflow:auto;
}

.ruleItem{
  padding: 10px 10px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  margin-bottom: 10px;
}
.ruleItem:last-child{margin-bottom:0}
.ruleItem__kw{font-weight: 900; font-size: 14px; display:flex; justify-content:space-between; gap: 10px;}
.ruleItem__kw span{color: var(--muted); font-weight: 800; font-size: 12px;}
.ruleItem__desc{margin-top: 6px; color: var(--text); font-size: 13px; line-height: 1.35;}

.footer{
  display:flex;
  justify-content:space-between;
  gap: 14px;
  align-items:flex-start;
}
.hotkeys{
  flex:1;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 14px;
  box-shadow: var(--shadow);
}
.hotkeys__title{font-weight: 950; margin-bottom: 10px;}
.hotkeys__grid{display:grid; grid-template-columns: repeat(3, 1fr); gap: 10px;}
.hk{
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.12);
  padding: 10px 12px;
  font-size: 13px;
  color: var(--muted);
  font-weight: 650;
  display:flex; justify-content:space-between; gap: 10px; align-items:center;
}

kbd{
  background: rgba(110,168,254,.14);
  border: 1px solid rgba(110,168,254,.25);
  border-bottom-color: rgba(110,168,254,.45);
  padding: 4px 8px;
  border-radius: 10px;
  color: var(--text);
  font-weight: 850;
  font-size: 12px;
}

.footer__note{
  width: 520px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 14px;
  box-shadow: var(--shadow);
  color: var(--muted);
  font-size: 13px;
  line-height: 1.4;
  display:flex;
  flex-direction:column;
  gap: 12px;
}

.footer__tip{color: var(--muted);}

.initiativeCard{
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.14);
  padding: 12px;
  transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}
.initiativeCard__title{font-weight: 950; font-size: 13px; margin-bottom: 8px;}
.initiativeCard__value{font-weight: 1000; font-size: 22px; letter-spacing: .2px; transition: transform .15s ease;}
.initiativeCard__controls{display:flex; gap: 10px; margin-top: 10px;}

.initiativeCard.is-roll{transform: translateY(-1px);}
.initiativeCard.is-p1{
  border-color: rgba(110,168,254,.45);
  box-shadow: 0 0 0 1px rgba(110,168,254,.12), 0 0 28px rgba(110,168,254,.22);
}
.initiativeCard.is-p2{
  border-color: rgba(255,92,122,.45);
  box-shadow: 0 0 0 1px rgba(255,92,122,.12), 0 0 28px rgba(255,92,122,.20);
}

@keyframes initiativeFlip {
  0% { transform: translateY(0) rotate(0deg); }
  40% { transform: translateY(-1px) rotate(-8deg); }
  70% { transform: translateY(0) rotate(8deg); }
  100% { transform: translateY(0) rotate(0deg); }
}

.initiativeCard.is-roll .initiativeCard__value{
  animation: initiativeFlip .18s ease-in-out;
}

.initiativeSlot__strip{
  display:flex;
  flex-direction:column;
  transition: transform 70ms linear;
}

.reveal{
  opacity:0;
  transform: translateY(14px);
  filter: blur(4px);
  transition: opacity .7s ease, transform .7s ease, filter .7s ease;
  will-change: opacity, transform, filter;
}

.revealed{
  opacity:1;
  transform: translateY(0);
  filter: blur(0);
}

.btn{
  border: 1px solid rgba(255,255,255,.14);
  color: var(--text);
  background: rgba(255,255,255,.05);
  border-radius: 14px;
  padding: 10px 12px;
  font-weight: 900;
  cursor:pointer;
  transition: transform .06s ease, background .15s ease, border-color .15s ease;
  user-select:none;
}
.btn:hover{background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.22)}
.btn:active{transform: translateY(1px)}
.btn:focus{outline:none; box-shadow: 0 0 0 4px var(--focus)}

.btn--primary{background: rgba(110,168,254,.16); border-color: rgba(110,168,254,.32)}
.btn--primary:hover{background: rgba(110,168,254,.22)}
.btn--danger{background: rgba(255,92,122,.14); border-color: rgba(255,92,122,.30)}
.btn--danger:hover{background: rgba(255,92,122,.20)}
.btn--ghost{background: rgba(38,49,86,.65); border-color: rgba(255,255,255,.12)}
.btn--mini{padding: 12px 10px; font-size: 14px;}

.searchRow{display:flex; gap: 10px; align-items:center;}
.search{
  flex:1;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.14);
  color: var(--text);
  font-size: 14px;
  font-weight: 650;
}
.search::placeholder{color: rgba(154,166,214,.7)}
#btnClearSearch{white-space:nowrap}

@media (max-width: 1200px){
  .topbar{flex-direction:column}
  .turncard{width:auto}
  .controlsCard{width:auto}
  .trackbig__phase{font-size: 28px;}
  .main{flex-direction:column}
  .players{grid-template-columns: 1fr}
  .rules{width:auto}
  .footer{flex-direction:column}
  .footer__note{width:auto}
  .hotkeys__grid{grid-template-columns: 1fr 1fr}
}
