/* ------------------------------
   Base & Theme
------------------------------ */
:root{
  --bg:#0b0b0b;
  --panel: rgba(255,255,255,0.06);
  --panel-strong: rgba(255,255,255,0.12);
  --glass-stroke: rgba(255,255,255,0.18);
  --txt:#f6f6f6;
  --muted:#c7c7c7;
  --orange:#ff7a18;
  --orange-strong:#ff8c32;
  --good:#39d98a;
  --loss:#ff5d5d;
  --shadow: 0 10px 30px rgba(0,0,0,0.45);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color:var(--txt);
  background: var(--bg);
  overflow-x:hidden;
}
.container{ width:min(1200px, 92vw); margin-inline:auto; }

/* ------------------------------
   Background
------------------------------ */
.bg-mesh{
  position:fixed; inset:-10vmax;
  background:
    radial-gradient(40vmax 40vmax at 15% 15%, rgba(255,122,24,0.15), transparent 60%),
    radial-gradient(50vmax 50vmax at 85% 25%, rgba(255,122,24,0.08), transparent 60%),
    radial-gradient(55vmax 55vmax at 50% 90%, rgba(255,255,255,0.06), transparent 60%),
    linear-gradient(180deg, #0b0b0b 0%, #0a0a0a 100%);
  filter: saturate(1.1);
  z-index:-3;
  animation: meshShift 20s ease-in-out infinite alternate;
}
@keyframes meshShift{ 0%{ transform: translateY(0); } 100%{ transform: translateY(-2vh); } }

.grid-overlay{
  position:fixed; inset:0; z-index:-2;
  background:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px) 0 0/40px 40px,
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px) 0 0/40px 40px;
  mask-image: radial-gradient(80% 60% at 50% 40%, rgba(0,0,0,0.9), transparent 80%);
  pointer-events:none;
}
.orbs{ position:fixed; inset:0; z-index:-1; pointer-events:none; }
.orb{
  position:absolute; width:28vmax; height:28vmax; border-radius:50%;
  background: radial-gradient(closest-side, rgba(255,122,24,0.20), rgba(255,122,24,0) 70%);
  filter: blur(30px);
  animation: float 14s ease-in-out infinite;
}
.o1{ top:10%; left:-8%; animation-delay:-2s; }
.o2{ bottom:-10%; right:-6%; animation-duration:18s; }
.o3{ top:55%; left:60%; width:22vmax; height:22vmax; animation-duration:16s; }
@keyframes float{ 0%{ transform:translate(0,0) scale(1) } 50%{ transform:translate(2vmax,-1vmax) scale(1.05) } 100%{ transform:translate(-1vmax,1vmax) scale(1) } }

/* ------------------------------
   Header
------------------------------ */
.header{
  display:flex; align-items:center; justify-content:space-between;
  padding:24px 0;
}
.brand{ display:flex; align-items:center; gap:.6rem; text-decoration:none; color:var(--txt);}
.logo{ height:80px; width:auto; display:block; }
.nav{ display:flex; gap:1rem; align-items:center; }
.nav a{
  color:var(--txt); text-decoration:none; opacity:.9;
  padding:.6rem .9rem; border-radius:10px; transition:all .25s ease;
}
.nav a:hover{ background: rgba(255,122,24,0.12); opacity:1; }

/* Profile chip */
.profile-chip{
  display:flex; align-items:center; gap:.5rem; text-decoration:none; color:var(--txt);
  padding:.45rem .65rem; border-radius:999px;
  background: rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.18);
  backdrop-filter: blur(8px); transition: all .25s ease;
}
.profile-chip .avatar{
  width:28px; height:28px; border-radius:50%;
  display:grid; place-items:center; background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.18);
}
.profile-chip:hover{ box-shadow: 0 10px 24px rgba(255,122,24,.2); border-color: rgba(255,122,24,.45); }

/* ------------------------------
   Banner (Subscription)
------------------------------ */
.banner{
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding:1rem; border-radius:20px; margin-bottom:16px;
}
.banner.pro .left{ display:grid; gap:.35rem; }
.banner .headline{ display:flex; align-items:baseline; gap:.6rem; }
.banner .headline h2{ margin:.1rem 0 0; }
.banner .price-tag{
  display:inline-block; padding:.2rem .5rem; border-radius:10px; font-weight:800;
  background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.18);
}
.pill{ display:inline-block; padding:.25rem .55rem; border-radius:999px; font-size:.85rem;
  background: rgba(255,122,24,.18); border:1px solid rgba(255,122,24,.45); width:fit-content; white-space:nowrap }
.pill.pro-badge{
  background: linear-gradient(135deg, rgba(255,180,120,.25), rgba(255,122,24,.18));
  border-color: rgba(255,122,24,.55);
  box-shadow: 0 0 24px rgba(255,122,24,.25);
  font-weight:800;
}
.banner .muted{ margin:0; }
.benefits{
  display:flex; gap:.5rem; flex-wrap:wrap; padding:0; margin:.2rem 0 0; list-style:none;
}
.benefits li{
  padding:.3rem .55rem; border-radius:999px; font-size:.9rem;
  background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.18);
}
.banner-cta{ display:flex; align-items:center; gap:.6rem; }
.banner .upgrade{ min-width:140px; }

/* ------------------------------
   Buttons
------------------------------ */
.btn{
  display:inline-block; text-decoration:none; color:var(--txt);
  padding:.9rem 1.2rem; border-radius:14px;
  border:1px solid var(--glass-stroke);
  background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
  backdrop-filter: blur(10px);
  transform: translateZ(0);
  box-shadow: var(--shadow);
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
}
.btn:hover{
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(255,122,24,0.25), var(--shadow);
}
.btn.primary{
  background: linear-gradient(135deg, var(--orange) 0%, var(--orange-strong) 100%);
  border-color: var(--orange-strong);
  color:#fff;
  box-shadow: 0 0 20px rgba(255,122,24,.35);
}
.btn.primary:hover{ box-shadow: 0 0 28px rgba(255,122,24,.55); }
.btn.outline{ background:transparent; border-color: rgba(255,255,255,0.22); }
.btn.ghost{ background:transparent; border-color: rgba(255,255,255,0.18); }
/* Upgrade button styling */
.btn.upgrade {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .6rem;                       /* space between icon and text */
  font-weight: 800;
  font-size: 1rem;
  letter-spacing: .3px;
  padding: 1rem 1.6rem;
  border-radius: 14px;
  background: linear-gradient(135deg, #ff7a18, #ff8c32);
  border: 1px solid rgba(255,122,24,.6);
  color: #fff;
  text-decoration: none;
  box-shadow:
    0 4px 12px rgba(255,122,24,.25),
    0 0 20px rgba(255,122,24,.35);
  overflow: hidden;
  transition: transform .2s ease, box-shadow .3s ease;
  position: relative;
}

.btn.upgrade svg {
  width: 20px;
  height: 20px;
  stroke: #fff;
  flex-shrink: 0;
}

/* subtle moving glow overlay */
.btn.upgrade::after {
  content:"";
  position:absolute; inset:0;
  border-radius: inherit;
  background: linear-gradient(120deg, rgba(255,255,255,.25), transparent 70%);
  transform: translateX(-100%);
  transition: transform .6s ease;
}

.btn.upgrade:hover {
  transform: translateY(-3px);
  box-shadow:
    0 8px 20px rgba(255,122,24,.45),
    0 0 40px rgba(255,122,24,.55);
}

.btn.upgrade:hover::after {
  transform: translateX(100%);
}

.btn.upgrade:active {
  transform: translateY(0);
  box-shadow: 0 3px 12px rgba(255,122,24,.4);
}
.tiny-link,
.tiny-link:link,
.tiny-link:visited{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  font-weight:700;
  font-size:.95rem;
  color:var(--txt);
  text-decoration:none;
  padding:.42rem .8rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: border-color .2s ease, box-shadow .25s ease, transform .15s ease;
}
.tiny-link::after{ content:"›"; font-weight:800; transform: translateX(0); transition: transform .2s ease, opacity .2s ease; opacity:.9; }
.tiny-link:hover{
  border-color: rgba(255,122,24,.45);
  box-shadow: 0 10px 26px rgba(255,122,24,.25), var(--shadow);
  transform: translateY(-1px);
}
.tiny-link:hover::after{ transform: translateX(2px); }
.tiny-link:active{ transform: translateY(0); box-shadow:none; }
.tiny-link:focus-visible{
  outline: none;
  box-shadow: 0 0 0 3px rgba(255,122,24,.45);
  border-color: rgba(255,122,24,.55);
}

/* ------------------------------
   Cards / Grid
------------------------------ */
.grid{
  display:grid; gap:1rem;
  grid-template-columns: 1.2fr .8fr;
  grid-auto-rows: 1fr;
  padding-bottom: 30px;
}
.glass{
  background: var(--panel);
  border: 1px solid var(--glass-stroke);
  border-radius: 22px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--shadow);
}
.card{ padding:1rem; }
.card-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:.4rem; }

/* Hero Play Card */
.hero{
  display:grid; grid-template-columns: 1.1fr .9fr; align-items:center;
}
.copy h1{ margin:.2rem 0 .4rem; font-size: clamp(1.6rem, 3.8vw, 2.6rem);}
.accent{ color: var(--orange-strong); text-shadow: 0 0 16px rgba(255,122,24,.35); }
.chips{ display:flex; gap:.4rem; flex-wrap:wrap; margin:.6rem 0 .2rem; }
.chip{
  padding:.45rem .7rem; border-radius:999px; border:1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.06); color:var(--txt); cursor:pointer;
  transition: all .2s ease;
}
.chip:hover{ border-color: rgba(255,122,24,.45); box-shadow: 0 6px 18px rgba(255,122,24,.25); }
.cta{ display:flex; gap:.7rem; margin-top:.6rem; }
.play{ font-weight:800; letter-spacing:.2px; }

/* Gauge Viz */
.viz{ display:grid; place-items:center; min-height:220px; }
.gauge{ position:relative; width:220px; height:220px; }
.ring,.r2{
  position:absolute; inset:0; border-radius:50%;
  border: 10px solid transparent;
  background:
    conic-gradient(from 0deg, rgba(255,122,24,.0) 0 55%, rgba(255,122,24,.7) 55% 72%, rgba(255,122,24,.0) 72% 100%)
    border-box;
  -webkit-mask: 
    radial-gradient(farthest-side, transparent calc(100% - 10px), #000 0);
  mask: 
    radial-gradient(farthest-side, transparent calc(100% - 10px), #000 0);
  filter: blur(.3px) saturate(1.1);
  animation: sweep 6s ease-in-out infinite;
}
.r2{ transform: scale(.86) rotate(20deg); animation-duration: 7.5s; opacity:.8; }
.spark{
  position:absolute; inset:0; border-radius:50%;
  background: radial-gradient(closest-side, rgba(255,122,24,.25), transparent 70%);
  filter: blur(10px); animation: pulse 3.5s ease-in-out infinite;
}
.center{
  position:absolute; inset:0; display:grid; place-items:center; text-align:center;
  margin: 55px;
  border-radius:20px; border:1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.06); backdrop-filter: blur(8px);
}
.center strong{ font-size:1.6rem; }
@keyframes sweep{ 0%,100%{ rotate:0deg } 50%{ rotate:180deg } }
@keyframes pulse{ 0%,100%{ transform:scale(1) } 50%{ transform:scale(1.05) } }

/* Lists / Tables */
.list{ list-style:none; margin:0; padding:0; display:grid; gap:.45rem; }
.row{
  display:flex; align-items:center; justify-content:space-between; gap:.6rem;
  padding:.6rem .7rem; border-radius:12px;
  background: rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.14);
}
.dot{
  width:10px; height:10px; border-radius:50%; background: rgba(255,255,255,.35);
  box-shadow: 0 0 0 0 rgba(255,122,24,0.0);
}
.dot.done{ background: var(--good); }
.pill.small{ font-size:.85rem; padding:.25rem .5rem; }
.pill.good{ background: rgba(57,217,138,0.12); border-color: rgba(57,217,138,0.45); }

.streak{
  margin-top:.7rem; display:grid; grid-template-columns: auto 1fr 1fr; align-items:center; gap:.7rem;
}
.flame{
  width:36px; height:36px; border-radius:12px;
  background:
    radial-gradient(circle at 50% 30%, rgba(255,200,120,.9), rgba(255,150,60,.7) 40%, rgba(255,122,24,.4) 60%, transparent 70%),
    linear-gradient(180deg, rgba(255,122,24,.3), rgba(255,255,255,.08));
  border:1px solid rgba(255,122,24,.45);
  box-shadow: inset 0 0 20px rgba(255,122,24,.3), 0 10px 24px rgba(255,122,24,.2);
  animation: breathe 3s ease-in-out infinite;
}
.label{ color:var(--muted); font-size:.9rem; }
.big{ font-size:1.2rem; font-weight:800; }
.meter{ height:10px; border-radius:999px; background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.18); overflow:hidden; }
.meter span{ display:block; height:100%; width:var(--p,50%); background: linear-gradient(90deg, rgba(255,122,24,.25), rgba(255,122,24,.85)); animation: widthy 2.8s ease-in-out infinite alternate; }
@keyframes widthy{ 0%{ width: calc(var(--p) - 10%); } 100%{ width: var(--p); } }

/* Recent table */
.table{ list-style:none; margin:0; padding:0; display:grid; gap:.45rem; }
.table .row{ grid-template-columns: 40px 1fr auto 60px; display:grid; }
.pos{
  display:grid; place-items:center; font-weight:800; border-radius:10px;
  background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.18);
}
.pos.win{ color:var(--good); border-color: rgba(57,217,138,.45); }
.pos.loss{ color:var(--loss); border-color: rgba(255,93,93,.45); }
.pts{ justify-self:end; font-weight:800; color: var(--orange-strong); text-shadow: 0 0 12px rgba(255,122,24,.35); }

/* Board */
.board{ list-style:none; margin:0; padding:0; display:grid; gap:.45rem; counter-reset: r; }
.board li{
  display:grid; grid-template-columns: 40px 1fr 70px; align-items:center; gap:.6rem;
  background: rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.14);
  padding:.6rem .7rem; border-radius:12px;
}
.rank{ font-weight:800; text-align:center; }
.user.you{ font-weight:800; }
.score{ justify-self:end; color: var(--orange-strong); }

/* Tips */
.tips{ list-style:none; margin:0; padding:0; display:grid; gap:.5rem; }
.tips li{ display:flex; gap:.6rem; align-items:flex-start; background: rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.14); padding:.6rem .7rem; border-radius:12px;}
.tips .icon{ width:26px; height:26px; display:grid; place-items:center; border-radius:8px; background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.18); }

/* Footer */
.footer{
  display:flex; align-items:center; justify-content:space-between;
  padding: 18px 0 40px;
  color:var(--muted);
}
.foot-nav{ display:flex; gap:1rem; }
.foot-nav a{ color:var(--muted); text-decoration:none; }
.foot-nav a:hover{ color:var(--txt); }

/* Motion Utilities */
.fade-in{ opacity:0; transform: translateY(16px); animation: fadeUp .9s ease-out forwards; }
@keyframes fadeUp{ to{ opacity:1; transform: translateY(0); } }
.float-up{ transform: translateY(8px); animation: floatUp 1s ease-out forwards; }
@keyframes floatUp{ 0%{ opacity:0; transform: translateY(12px) scale(.98); } 100%{ opacity:1; transform: translateY(0) scale(1); } }
@keyframes breathe{ 0%,100%{ box-shadow: 0 0 0 0 rgba(255,122,24,0.28), var(--shadow); } 50%{ box-shadow: 0 0 35px 4px rgba(255,122,24,0.38), var(--shadow); } }

/* Responsive */
@media (max-width: 980px){
  .grid{ grid-template-columns: 1fr; }
  .hero{ grid-template-columns: 1fr; }
}
@media (max-width: 640px){
  .nav a:not(.btn){ display:none; }
  .banner{ flex-direction:column; align-items:flex-start; }
}