/* YOURTHEVIRUS.ONLINE v10.1 */
:root{
  --bg:#07070a;
  --panel:#0b0b12;
  --panel2:#0f0f1a;
  --text:#f4f6ff;
  --muted:#a7abcf;
  --border:#1d1d2c;
  --accent:#ff2bd6;
  --good:#2bffb2;
  --bad:#ff2bd6;
  --shadow: 0 18px 60px rgba(0,0,0,.45);
  --radius: 18px;
  --glow: 0 0 18px rgba(255,43,214,.35);
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
}

/* Themes */
:root[data-theme="neon"]{ --accent:#00d8ff; --glow:0 0 18px rgba(0,216,255,.35); }
:root[data-theme="glitch"]{ --accent:#ff2bd6; --glow:0 0 18px rgba(255,43,214,.35); }
:root[data-theme="void"]{ --accent:#a78bfa; --glow:0 0 18px rgba(167,139,250,.35); }
:root[data-theme="ember"]{ --accent:#ff7a18; --glow:0 0 18px rgba(255,122,24,.35); }
:root[data-theme="ice"]{ --accent:#7dd3fc; --glow:0 0 18px rgba(125,211,252,.35); }
:root[data-theme="classic"]{ --accent:#34d399; --glow:0 0 18px rgba(52,211,153,.30); }

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
}

a{color:inherit}
code{font-family:var(--mono); font-size:.95em}
.muted{color:var(--muted)}
.tiny{font-size:.85rem}
.h1{margin:0 0 .25rem}
.h2{margin:1.2rem 0 .6rem}
.wrap{max-width:1100px; margin:0 auto; padding:22px 18px 40px}
.topbar{
  position:sticky; top:0; z-index:10;
  backdrop-filter: blur(12px);
  background: rgba(7,7,10,.68);
  border-bottom:1px solid rgba(255,255,255,.06);
  display:flex; justify-content:space-between; align-items:center;
  padding:14px 16px;
}
.brand{display:flex; gap:12px; align-items:center; text-decoration:none}
.logo{display:inline-flex; width:38px; height:38px; align-items:center; justify-content:center;
  border-radius:12px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
  box-shadow: var(--glow);
}
.brandtext{display:flex; flex-direction:column; line-height:1}
.brandtext .name{font-weight:900; letter-spacing:.08em}
.brandtext .tagline{font-size:.82rem; color:var(--muted); margin-top:4px}
.nav{display:flex; gap:12px; align-items:center}
.nav a{opacity:.9; text-decoration:none; font-size:.95rem}
.nav a:hover{opacity:1; text-shadow: var(--glow)}
.pill{padding:8px 10px; border-radius:999px; border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.04)}

.bg{position:fixed; inset:0; pointer-events:none; z-index:0}
#particles{width:100%; height:100%; display:block; opacity:.75}
.scanlines{
  position:absolute; inset:0;
  background: repeating-linear-gradient(to bottom, rgba(255,255,255,.04), rgba(255,255,255,.04) 1px, rgba(0,0,0,0) 2px, rgba(0,0,0,0) 5px);
  opacity:.12;
  mix-blend-mode: overlay;
}
.vignette{
  position:absolute; inset:-30px;
  background: radial-gradient(circle at 50% 20%, rgba(255,255,255,.06), rgba(0,0,0,0) 38%),
              radial-gradient(circle at 50% 60%, rgba(0,0,0,0), rgba(0,0,0,.85) 70%);
}

main.wrap{position:relative; z-index:1}

.card, .panel{
  background: rgba(11,11,18,.92);
  border:1px solid rgba(255,255,255,.08);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding:18px;
}
.panel.subtle{background: rgba(11,11,18,.72)}
.card.inner{box-shadow:none}
.prose{line-height:1.55}
.prose h1{margin-top:0}
.prose ul, .prose ol{padding-left:1.2rem}
.prose a{color:var(--accent)}

.hero{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:18px;
  margin-top:8px;
}
@media(max-width:920px){ .hero{grid-template-columns:1fr} }

.badge{
  display:inline-flex; gap:10px; align-items:center;
  padding:8px 12px; border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  margin-bottom:12px;
}
.badge .dot{
  width:10px; height:10px; border-radius:999px;
  background: var(--accent);
  box-shadow: var(--glow);
}
.badge.good .dot{background:var(--good); box-shadow:0 0 18px rgba(43,255,178,.35)}
.badge.bad .dot{background:var(--bad); box-shadow:0 0 18px rgba(255,43,214,.35)}

.lead{font-size:1.06rem; color:var(--muted); margin-top:0}

.actions{display:flex; gap:10px; flex-wrap:wrap; margin:14px 0 12px}
.btn{
  appearance:none;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  color:var(--text);
  padding:10px 14px;
  border-radius: 14px;
  cursor:pointer;
  text-decoration:none;
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px;
  font-weight:700;
}
.btn:hover{border-color: rgba(255,255,255,.24); transform: translateY(-1px)}
.btn:active{transform: translateY(0)}
.btn.primary{
  background: linear-gradient(135deg, rgba(255,43,214,.22), rgba(255,43,214,.06));
  border-color: rgba(255,43,214,.55);
  box-shadow: var(--glow);
}
.btn.ghost{background: rgba(255,255,255,.02)}
.btn.danger{border-color: rgba(255,80,80,.55); background: rgba(255,80,80,.08)}
.btn.small{padding:8px 10px; border-radius:12px; font-size:.92rem}

.iconbtn{
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  color:var(--text);
  border-radius: 12px;
  padding:8px 10px;
  cursor:pointer;
}
.iconbtn:hover{border-color: rgba(255,255,255,.22)}

.copyRow{display:flex; gap:10px; align-items:stretch; margin:10px 0}
.copyBox{flex:1; padding:10px 12px; border-radius:14px; background: rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08)}
.copyLabel{font-size:.84rem; color:var(--muted); margin-bottom:6px}
.copyValue{font-family:var(--mono); font-size:.92rem; word-break:break-all}
.details summary{cursor:pointer; color:var(--accent); margin-top:10px}
.details .muted{margin:8px 0 0}

.panelTop{display:flex; justify-content:space-between; align-items:center; gap:14px}
.panelTitle{font-weight:900; letter-spacing:.06em}
.panelTitle2{font-weight:900; letter-spacing:.05em; margin-top:16px}
.panelPill{font-size:.88rem; color:var(--muted)}

.stats{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:10px;
  margin-top:12px;
}
.stats.big{grid-template-columns: repeat(4, minmax(0,1fr))}
@media(max-width:900px){ .stats.big{grid-template-columns: repeat(2, minmax(0,1fr))} }
.stat{
  padding:12px 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
}
.stat .num{font-size:1.45rem; font-weight:900}
.stat .lab{font-size:.9rem; color:var(--muted); margin-top:4px}

.grid2{display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:18px}
@media(max-width:900px){ .grid2{grid-template-columns:1fr} }

.ol{padding-left:1.15rem; color:var(--muted)}
.bullets{padding-left:1.15rem; color:var(--muted)}
.row{display:flex; gap:10px; align-items:center}
.stack{display:flex; flex-direction:column; gap:10px}
.lab{font-weight:800; color:var(--muted)}
.input, .textarea, .select{
  width:100%;
  padding:10px 12px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.25);
  color: var(--text);
  outline: none;
}
.textarea{font-family:var(--mono)}
.select{appearance:none}
.narrow{max-width:520px; margin:0 auto}

.alert{padding:10px 12px; border-radius:14px; border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.03)}
.alert.good{border-color: rgba(43,255,178,.35)}
.alert.bad{border-color: rgba(255,80,80,.45)}

.tableWrap{overflow:auto; border-radius:16px; border:1px solid rgba(255,255,255,.08); margin-top:12px}
.table{width:100%; border-collapse:collapse; min-width:740px; background:rgba(11,11,18,.85)}
.table th,.table td{padding:12px 12px; border-bottom:1px solid rgba(255,255,255,.06); text-align:left}
.table th{font-size:.9rem; color:var(--muted); font-weight:900}
.table tr:hover td{background: rgba(255,255,255,.02)}
.pill.bad{border-color: rgba(255,43,214,.55)}
.pill.good{border-color: rgba(43,255,178,.45)}

.footer{
  position:relative; z-index:1;
  border-top:1px solid rgba(255,255,255,.06);
  padding:24px 18px;
  background: rgba(7,7,10,.78);
}
.footergrid{max-width:1100px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:18px}
@media(max-width:900px){ .footergrid{grid-template-columns:1fr} }
.footbrand{font-weight:900; letter-spacing:.06em}
.footmuted{color:var(--muted); margin-top:8px}
.footlinks{display:flex; gap:12px; flex-wrap:wrap; justify-content:flex-end}
@media(max-width:900px){ .footlinks{justify-content:flex-start} }
.linkbtn{border:none; background:none; color:var(--accent); cursor:pointer; padding:0}
.footmini{max-width:1100px; margin:12px auto 0; color:rgba(255,255,255,.55); font-size:.9rem}

.modal[hidden]{display:none !important}
.modal{
  position:fixed; inset:0; z-index:50;
  display:flex; align-items:center; justify-content:center;
  background: rgba(0,0,0,.62);
  padding:18px;
}
.modalCard{
  width:min(740px, 100%);
  border-radius: 18px;
  background: rgba(11,11,18,.95);
  border:1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.modalTop{
  display:flex; justify-content:space-between; align-items:center;
  padding:14px 14px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.modalTitle{font-weight:900; letter-spacing:.04em}
.modalBody{padding:14px 14px}
.modalActions{padding:14px; display:flex; gap:10px; justify-content:flex-end; border-top:1px solid rgba(255,255,255,.06)}
.themeGrid{
  display:grid; grid-template-columns: repeat(3, minmax(0,1fr));
  gap:10px;
}
@media(max-width:640px){ .themeGrid{grid-template-columns: repeat(2, minmax(0,1fr));} }
.themeBtn{
  border-radius:16px;
  padding:14px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  cursor:pointer;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.themeBtn:hover{border-color: rgba(255,255,255,.22); box-shadow: var(--glow)}

.toast{
  position: fixed;
  left:50%; bottom:22px;
  transform: translateX(-50%);
  background: rgba(10,10,16,.95);
  border:1px solid rgba(255,255,255,.10);
  padding:10px 14px;
  border-radius: 14px;
  z-index:60;
  box-shadow: var(--shadow);
  max-width: min(640px, 92vw);
}

.ad{margin:16px 0; padding:12px; border-radius:16px; border:1px dashed rgba(255,255,255,.18); color:rgba(255,255,255,.65)}
.ad-header,.ad-footer{background: rgba(255,255,255,.02)}
.ad-inline{margin-top:14px}

.adminTop{display:flex; justify-content:space-between; gap:12px; align-items:flex-start}
.adminnav{display:flex; gap:10px; flex-wrap:wrap}
.adminnav a{padding:8px 10px; border-radius:999px; border:1px solid rgba(255,255,255,.10); text-decoration:none; font-weight:800; font-size:.92rem; opacity:.92}
.adminnav a.on, .adminnav a:hover{border-color: rgba(255,255,255,.22); opacity:1}
.lbTop{display:flex; justify-content:space-between; gap:12px; align-items:flex-start}
.statusTop{display:flex; justify-content:space-between; gap:12px; align-items:flex-start; flex-wrap:wrap}

/* Glitch */
.glitch{
  position:relative;
  font-weight:1000;
  letter-spacing:.08em;
  margin:0;
  font-size: clamp(2rem, 3.6vw, 3.2rem);
  text-transform: uppercase;
  text-shadow: 0 0 12px rgba(255,255,255,.08), var(--glow);
}
.glitch:before, .glitch:after{
  content: attr(data-text);
  position:absolute; left:0; top:0;
  width:100%; overflow:hidden;
  clip-path: inset(0 0 0 0);
  opacity:.75;
}
.glitch:before{
  transform: translate(2px, -1px);
  color: var(--accent);
  animation: glitch 2.6s infinite linear alternate-reverse;
}
.glitch:after{
  transform: translate(-2px, 1px);
  color: #00ffea;
  animation: glitch 1.9s infinite linear alternate-reverse;
}
@keyframes glitch{
  0%{clip-path: inset(0 0 95% 0)}
  10%{clip-path: inset(12% 0 50% 0)}
  20%{clip-path: inset(70% 0 12% 0)}
  30%{clip-path: inset(20% 0 65% 0)}
  40%{clip-path: inset(45% 0 35% 0)}
  50%{clip-path: inset(8% 0 78% 0)}
  60%{clip-path: inset(60% 0 18% 0)}
  70%{clip-path: inset(30% 0 50% 0)}
  80%{clip-path: inset(75% 0 10% 0)}
  90%{clip-path: inset(18% 0 70% 0)}
  100%{clip-path: inset(0 0 95% 0)}
}

.achGrid{display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:10px; margin-top:10px}
@media(max-width:720px){ .achGrid{grid-template-columns: 1fr} }
.ach{
  padding:12px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
}
.achName{font-weight:900}
.achDesc{color:var(--muted); margin-top:6px}


/* v7 components */
.chart{
  display:flex;
  gap:6px;
  align-items:flex-end;
  height:160px;
  padding:10px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  overflow:hidden;
}
.bar{flex:1; display:flex; flex-direction:column; align-items:center; gap:6px; min-width:10px}
.barFill{
  width:100%;
  height:10%;
  border-radius:10px 10px 6px 6px;
  background: var(--accent);
  box-shadow: 0 0 16px rgba(255,43,214,.18);
}
.barFill.alt{ background:#2bffb2; box-shadow: 0 0 16px rgba(43,255,178,.18);}
.barLab{font-size:11px; color:rgba(255,255,255,.52); transform: rotate(-30deg); transform-origin:center; white-space:nowrap}

.feed{
  margin-top:10px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  overflow:hidden;
}
.feedRow{
  display:flex;
  justify-content:space-between;
  gap:14px;
  padding:12px 14px;
  border-top:1px solid rgba(255,255,255,.06);
}
.feedRow:first-child{border-top:none}
.feedMsg{line-height:1.25}
.feedWhen{white-space:nowrap; color:rgba(255,255,255,.5); font-size:12px}
.mono{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;}

.progress{margin-top:12px}
.progressBar{
  height:12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  overflow:hidden;
}
.progressFill{
  height:100%;
  width:0%;
  background: var(--accent);
  box-shadow: 0 0 18px rgba(255,43,214,.18);
}

.mission{
  margin-top:12px;
  padding:12px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.18);
}
.missionTop{display:flex; justify-content:space-between; align-items:center; gap:12px}
.missionTitle{font-weight:900}
.missionDesc{margin-top:8px; color:var(--muted)}

.shareGrid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:10px;
  margin-top:12px;
}
@media(max-width:720px){ .shareGrid{grid-template-columns: repeat(2, minmax(0,1fr));} }
.shareBtn{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:12px 10px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color: var(--text);
  text-decoration:none;
  font-weight:800;
}
.shareBtn:hover{border-color:rgba(255,255,255,.20); background: rgba(255,255,255,.06);}
.shareBtn .ico{font-size:18px}

.check{display:flex; gap:10px; align-items:center; color: rgba(255,255,255,.85);}
.check input{width:18px; height:18px}



/* v10.1 polish */
.bgvideo{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.18; filter: blur(1px) saturate(1.1);}
@media (max-width: 720px){ .bgvideo{display:none;} }

.logo img{width:22px; height:22px; display:block; filter: drop-shadow(0 0 10px rgba(255,43,214,.55));}

.nav a{white-space:nowrap}
.topbar{backdrop-filter: blur(10px);}


/* v9 additions: tighter responsiveness, better panels, and share UI */
@media (max-width: 980px){
  .grid2{grid-template-columns:1fr}
  .hero{grid-template-columns:1fr; gap:16px}
  .statusTop{flex-direction:column; align-items:flex-start; gap:12px}
  .actions{width:100%; flex-wrap:wrap}
  .copyRow{grid-template-columns:1fr; gap:10px}
}
@media (max-width: 520px){
  .navlinks{display:none}
  .brandTitle{font-size:14px}
  .btn{padding:10px 12px}
  .glitch{letter-spacing:.06em}
}
.ach{border:1px solid rgba(255,255,255,.08); background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));}
.missionProgress{margin-top:10px}
.panelTop{align-items:center}
.panelPill code{font-size:12px}
.ad{border-radius:14px}
.ad:before{content:'AD'; position:absolute; top:8px; right:10px; font-size:11px; letter-spacing:.2em; opacity:.35}
.ad{position:relative}
.footergrid{gap:18px}


.navToggle{display:none}
@media (max-width: 720px){
  .navToggle{display:inline-flex}
  .topbar .nav a{display:none}
  .topbar .nav .pill{display:none}
}
.drawerLinks{display:grid; gap:10px}
.drawerLink{display:block; padding:12px 12px; border-radius:12px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08)}
.drawerLink:hover{background:rgba(255,255,255,.06)}

.ad-sticky{position:fixed; left:12px; right:12px; bottom:12px; z-index:60; padding:12px; max-width:980px; margin:0 auto; box-shadow:0 10px 40px rgba(0,0,0,.55)}
@media (min-width: 980px){.ad-sticky{left:auto; right:24px; width:360px; bottom:24px}}

/* =========================================================
   v10.1 VISUAL OVERDRIVE — Styles-only mega upgrade
   (glitch status text effect intentionally unchanged)
   ========================================================= */

:root{
  --bg0:#05050a;
  --bg1:#07070a;
  --bg2:#0b0b12;
  --ring: rgba(255,255,255,.14);
  --ring2: rgba(255,255,255,.22);
  --glass: rgba(12,12,20,.62);
  --glass2: rgba(12,12,20,.80);
  --shine: linear-gradient(135deg, rgba(255,255,255,.18), rgba(255,255,255,0));
  --ease: cubic-bezier(.2,.8,.2,1);
}

html{scroll-behavior:smooth}

/* Background layers */
.bg{background: radial-gradient(1200px 900px at 20% 10%, rgba(255,43,214,.10), rgba(0,0,0,0) 55%),
               radial-gradient(1200px 900px at 80% 15%, rgba(0,216,255,.10), rgba(0,0,0,0) 55%),
               radial-gradient(1200px 900px at 50% 90%, rgba(167,139,250,.10), rgba(0,0,0,0) 55%),
               var(--bg1);
}
.bgvideo{
  position:absolute; inset:-4px;
  width:calc(100% + 8px); height:calc(100% + 8px);
  object-fit:cover;
  opacity:.32;
  filter: saturate(1.25) contrast(1.15) brightness(.92);
  mix-blend-mode: screen;
}
.bgmesh, .bggrid, .bgnoise, .bgpulse{
  position:absolute; inset:0; pointer-events:none;
}
.bgmesh{
  background: url(/assets/img/mesh.svg) center/cover no-repeat;
  opacity:.42;
  mix-blend-mode: screen;
  filter: blur(0px) saturate(1.2);
}
.bggrid{
  background: url(/assets/img/grid.png) center/512px 512px repeat;
  opacity:.18;
  mix-blend-mode: overlay;
}
.bgpulse{
  background: url(/assets/media/gifs/aura.gif) center/360px 200px repeat;
  opacity:.20;
  mix-blend-mode: screen;
  filter: blur(0px) saturate(1.25);
  animation: drift 16s linear infinite;
}
.bgnoise{
  background: url(/assets/img/noise.png) center/256px 256px repeat;
  opacity:.18;
  mix-blend-mode: overlay;
}
@keyframes drift{
  0%{transform: translate3d(0,0,0)}
  100%{transform: translate3d(-60px, 30px, 0)}
}

/* Topbar polish */
.topbar{
  padding: calc(12px + env(safe-area-inset-top)) 16px 12px;
  background: rgba(7,7,10,.50);
}
.nav a{
  padding:8px 10px;
  border-radius: 999px;
  border: 1px solid transparent;
  transition: all .18s var(--ease);
}
.nav a:hover{border-color: rgba(255,255,255,.12); background: rgba(255,255,255,.03)}
.nav .pill{transition: all .18s var(--ease)}

/* Cards: deeper glass + subtle shine */
.card, .panel{
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0)) , var(--glass2);
  border: 1px solid rgba(255,255,255,.10);
}
.panel.subtle{background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0)) , var(--glass)}
.card::before, .panel::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  background: radial-gradient(900px 260px at 12% 0%, rgba(255,255,255,.08), rgba(255,255,255,0) 60%);
  opacity:.65;
  pointer-events:none;
}
.card, .panel{position:relative; overflow:hidden}

/* Typography + spacing */
.h1{font-size: clamp(1.65rem, 2.6vw, 2.35rem); letter-spacing: -.02em}
.lead{font-size: clamp(1.02rem, 1.1vw, 1.12rem)}

/* Buttons: premium glow, shine and ripple */
.btn, .iconbtn, .themeBtn, .drawerLink, .adminnav a{
  transition: transform .18s var(--ease), border-color .18s var(--ease), background .18s var(--ease), box-shadow .18s var(--ease);
}
.btn:hover{box-shadow: 0 14px 50px rgba(0,0,0,.35)}
.btn.primary{
  background: linear-gradient(135deg, rgba(255,43,214,.26), rgba(0,216,255,.08));
  border-color: rgba(255,43,214,.65);
}
.btn.primary::after{
  content:""; position:absolute; inset:-2px;
  border-radius: inherit;
  background: radial-gradient(400px 140px at 30% 0%, rgba(255,255,255,.18), rgba(255,255,255,0) 60%);
  opacity:.55;
  pointer-events:none;
}
.btn{position:relative; overflow:hidden}
.ripple{
  position:absolute;
  border-radius: 999px;
  transform: translate(-50%,-50%);
  background: rgba(255,255,255,.22);
  animation: ripple .7s var(--ease) forwards;
  pointer-events:none;
}
@keyframes ripple{
  from{width:0; height:0; opacity:.75}
  to{width:520px; height:520px; opacity:0}
}

/* Inputs */
.input, .textarea, .select{
  background: rgba(0,0,0,.30);
  border-color: rgba(255,255,255,.14);
}
.input:focus, .textarea:focus, .select:focus{border-color: rgba(255,255,255,.26); box-shadow: 0 0 0 6px rgba(255,43,214,.10)}

/* Modals: cinematic */
.modalCard{
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,0)) , rgba(10,10,16,.96);
  border: 1px solid rgba(255,255,255,.12);
}
.modal{backdrop-filter: blur(16px)}

/* Share grid: bigger tap targets */
.shareBtn{min-height:52px}

/* Scrollbar */
*{scrollbar-width: thin; scrollbar-color: rgba(255,255,255,.18) rgba(0,0,0,0)}
::-webkit-scrollbar{height:10px; width:10px}
::-webkit-scrollbar-thumb{background: rgba(255,255,255,.16); border-radius: 999px}
::-webkit-scrollbar-thumb:hover{background: rgba(255,255,255,.22)}

/* Reduced motion: respect user preference */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .bgvideo, #particles, .bgpulse{display:none !important}
  .btn:hover{transform:none}
  .ripple{display:none}
}
