
/* case-cyber-overrides-v5.css — load AFTER ACS-CS.css */

/* Tokens */
:root{
  --bg:#0f172a; --surf:#0d1220; --ring:#334155;
  --text:#e5e7eb; --muted:#a0b4cc;
  --accent:#22d3ee; --accent2:#a855f7; --link:#7dd3fc;
}

/* Page */
body.case-cyber{
  color:var(--text);
  background:
    radial-gradient(1200px 800px at 80% -10%, rgba(168,85,247,.08), transparent),
    radial-gradient(1000px 700px at -10% 10%, rgba(34,211,238,.06), transparent),
    var(--bg);
}
body.case-cyber a{ color: var(--link); text-decoration:none; }
body.case-cyber a:hover{ text-decoration:none; }

/* HERO */
body.case-cyber section.hero{ background:transparent !important; }
body.case-cyber section.hero .hero-container{
  background: linear-gradient(180deg, rgba(34,211,238,.08), rgba(168,85,247,.06)), var(--surf) !important;
  border:1px solid var(--ring) !important; border-radius:16px !important; padding:28px 24px !important;
}
body.case-cyber section.hero .hero-title,
body.case-cyber section.hero h1.hero-title{ color:var(--text) !important; opacity:1 !important; }
body.case-cyber section.hero .hero-subtitle{ color:var(--muted) !important; opacity:1 !important; }
body.case-cyber section.hero .hero-image img{ border-radius:12px; box-shadow:0 16px 48px rgba(0,0,0,.45); }

/* Global reset INSIDE content sections (fix washed text & light backgrounds) */
body.case-cyber .content-section,
body.case-cyber .content-section .container{
  background: transparent !important;
  color: var(--text);
}
/* Typography reset */
body.case-cyber .content-section *{ text-shadow:none; }
body.case-cyber .content-section h1,
body.case-cyber .content-section h2,
body.case-cyber .content-section h3,
body.case-cyber .content-section h4{ color:var(--text) !important; opacity:1 !important; }
body.case-cyber .content-section p,
body.case-cyber .content-section li{ color:var(--muted) !important; opacity:1 !important; }

/* Common "white card" fixes */
body.case-cyber .content-section .card,
body.case-cyber .content-section .panel,
body.case-cyber .content-section .box,
body.case-cyber .content-section .section-box,
body.case-cyber .content-section .content-card{
  background: var(--surf) !important;
  border: 1px solid var(--ring) !important;
  border-radius: 12px !important;
  color: var(--text) !important;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
}

/* Meta grid */
body.case-cyber .meta-grid{ gap:16px; }
body.case-cyber .meta-item{
  background:var(--surf) !important; border:1px solid var(--ring) !important; border-radius:12px !important;
  color:var(--muted) !important; padding:16px !important;
}
body.case-cyber .meta-item h3{ color:var(--text) !important; }

/* Problem/Solution */
body.case-cyber .problem-solution{ display:grid; gap:24px; grid-template-columns:1fr; }
@media (min-width:960px){ body.case-cyber .problem-solution{ grid-template-columns:1fr 1fr; } }
body.case-cyber .problem-box, body.case-cyber .solution-box{
  background:var(--surf) !important; border:1px solid var(--ring) !important; border-radius:12px !important; padding:16px !important;
}
body.case-cyber img.problem-box{ background:none !important; border:0 !important; padding:0 !important; box-shadow:none !important; }
body.case-cyber .problem-box img, body.case-cyber .solution-box img{
  display:block; width:100%; height:auto; border-radius:10px; border:1px solid var(--ring);
  box-shadow:0 6px 18px rgba(0,0,0,.25);
}

/* Process steps */
body.case-cyber .process-step,
body.case-cyber .process-steps .process-step{
  background:var(--surf) !important; border:1px solid var(--ring) !important; border-radius:12px !important; color:var(--text) !important;
}
body.case-cyber .process-step *, 
body.case-cyber .process-step h3,
body.case-cyber .process-step p{ opacity:1 !important; color:var(--text) !important; }
body.case-cyber .process-step p{ color:var(--muted) !important; }
body.case-cyber .step-number{ background: linear-gradient(180deg, var(--accent2), var(--accent)) !important; color:#fff !important; }
body.case-cyber .artifacts-button{ background:transparent !important; color:var(--text) !important; border:1px solid var(--ring) !important; border-radius:10px !important; padding:10px 14px !important; }
body.case-cyber .artifacts-button:hover{ border-color:var(--accent) !important; box-shadow:0 0 0 2px rgba(34,211,238,.25) !important; }

/* Metrics */
body.case-cyber .metric-card{ background:var(--surf) !important; border:1px solid var(--ring) !important; border-radius:12px !important; color:var(--text) !important; }

/* Personas */
body.case-cyber .persona-card{ background:var(--surf) !important; border:1px solid var(--ring) !important; border-radius:12px !important; }
body.case-cyber .persona-content p{ color:var(--muted) !important; }

/* Quotes */
body.case-cyber .quote-card{ background:var(--surf) !important; border:1px solid var(--ring) !important; color:var(--text) !important; }
body.case-cyber .quote-card .quote-text{ color:#dfe7f5 !important; }
body.case-cyber .quote-card .quote-mark{ color:#b4c7e4 !important; }
body.case-cyber .quote-card .quote-attribution{ color:#e5e7eb !important; }
body.case-cyber .quote-card hr, body.case-cyber .quote-card .divider{ background:#a9c1e2 !important; opacity:1 !important; }

/* Interactions & decisions — big, stacked */
body.case-cyber #interactions-and-decisions{ padding:24px 0; }
body.case-cyber #interactions-and-decisions .cs-artifacts{ display:grid; grid-template-columns:1fr; gap:32px; }
body.case-cyber #interactions-and-decisions .cs-card{
  background:var(--surf) !important; border:1px solid var(--ring) !important; border-radius:16px !important; overflow:hidden !important;
  box-shadow:0 10px 30px rgba(0,0,0,.35), 0 0 0 1px rgba(31,42,64,.5) inset;
  max-width:1280px; margin:0 auto;
}
body.case-cyber #interactions-and-decisions .cs-card img{ width:100%; height:auto; display:block; }
body.case-cyber #interactions-and-decisions .cs-card figcaption{ font-size:10px; color:var(--muted); padding:12px 16px; border-top:1px solid var(--ring); }
body.case-cyber .cs-kicker{ color:var(--accent); text-transform:uppercase; letter-spacing:.2em; font-weight:700; font-size:12px; }
/* === Cyber overrides v6: hero + project-meta fix === */

/* HERO — no full-frame panel; keep dark canvas + shadow only behind the image */
body.case-cyber section.hero{
  background: transparent !important;
  padding: 0 !important;
}
body.case-cyber section.hero .hero-container{
  background: transparent !important;        /* remove the big light box */
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}
/* Text colors & opacity — win all specificity fights */
body.case-cyber section.hero .hero-content .hero-title,
body.case-cyber section.hero h1.hero-title{
  color: #e5e7eb !important;
  opacity: 1 !important;
}
body.case-cyber section.hero .hero-content .hero-subtitle{
  color: #a0b4cc !important;
  opacity: 1 !important;
}
/* Only style the image card so it pops */
body.case-cyber section.hero .hero-image img{
  border-radius: 12px !important;
  box-shadow: 0 18px 48px rgba(0,0,0,.45) !important;
  border: 1px solid #334155 !important;
}

/* PROJECT META — kill light strip + make cards sit on dark canvas */
body.case-cyber section.project-meta{
  background: transparent !important;        /* remove light background bar */
  border: 0 !important;
  padding-top: 24px !important;
  padding-bottom: 8px !important;
}
body.case-cyber section.project-meta .container{
  background: transparent !important;
}
body.case-cyber .meta-grid{
  gap: 18px !important;
}
body.case-cyber .meta-item{
  background: #0d1220 !important;
  border: 1px solid #334155 !important;
  border-radius: 12px !important;
  color: #a0b4cc !important;
}
body.case-cyber .meta-item h3{
  color: #e5e7eb !important;
}
/* === Hero hard reset (no light slab), keep only the image card === */
body.case-cyber section#hero,
body.case-cyber section#hero *,
body.case-cyber section.hero,
body.case-cyber section.hero *,
body.case-cyber #hero,
body.case-cyber #hero *,
body.case-cyber .hero,
body.case-cyber .hero * {
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}

/* Put back ONLY the image styling so it still looks elevated */
body.case-cyber section#hero .hero-image img,
body.case-cyber section.hero .hero-image img,
body.case-cyber #hero .hero-image img,
body.case-cyber .hero .hero-image img {
  border-radius: 12px !important;
  border: 1px solid #334155 !important;
  box-shadow: 0 18px 48px rgba(0,0,0,.45) !important;
}

/* Title + subtitle should NOT be washed out */
body.case-cyber section#hero .hero-title,
body.case-cyber section.hero .hero-title,
body.case-cyber #hero .hero-title,
body.case-cyber .hero .hero-title {
  color: #e5e7eb !important;
  opacity: 1 !important;
}

body.case-cyber section#hero .hero-subtitle,
body.case-cyber section.hero .hero-subtitle,
body.case-cyber #hero .hero-subtitle,
body.case-cyber .hero .hero-subtitle {
  color: #a0b4cc !important;
  opacity: 1 !important;
}

/* Optional: tighten vertical whitespace if your base sheet left padding */
body.case-cyber section#hero,
body.case-cyber section.hero,
body.case-cyber #hero,
body.case-cyber .hero {
  padding-top: 24px !important;
  padding-bottom: 8px !important;
}
/* Bigger artifacts + wider container just for this section */
#interactions-and-decisions .container { max-width: 1400px !important; }
#interactions-and-decisions .cs-artifacts { grid-template-columns: 1fr !important; gap: 32px !important; }
#interactions-and-decisions .cs-card { max-width: 1400px !important; margin: 0 auto; }
#interactions-and-decisions .cs-card img { width: 100%; height: auto; display: block; }


/* Two-column layout, chart fixed width */
.tryme-wrap {
  display: grid; gap: 28px; align-items: start;
  grid-template-columns: 380px minmax(0, 1fr);
}
@media (max-width: 980px){ .tryme-wrap { grid-template-columns: 1fr; } }

/* Chart card — exact same scale as original */
.demo-card {
  width: 380px; padding:14px 14px 12px; margin:0;
  background:#0d1220; border:1px solid #334155; border-radius:14px;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}
.demo-head { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
.muted { color:#94a3b8; }
.small { font-size:12px; }

/* Reuse your existing .chartWrap/.btn/.legend/.grid/.tile/... rules */
/* Layout: fixed card + notes */
#sites-status-tryme .tryme-wrap{
  display:grid; gap:28px; align-items:start;
  grid-template-columns: 380px minmax(0,1fr);
}
@media (max-width: 980px){ #sites-status-tryme .tryme-wrap{ grid-template-columns: 1fr; } }

#sites-status-tryme .demo-card{
  width:380px; margin:0; padding:14px 14px 12px;
  background:#0d1220; border:1px solid #334155; border-radius:14px;
  box-shadow:0 10px 30px rgba(0,0,0,.35);
}
#sites-status-tryme .demo-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
#sites-status-tryme .muted{ color:#94a3b8; }
#sites-status-tryme .small{ font-size:12px; }

#sites-status-tryme .chartWrap{ height:300px; margin-bottom:20px; }
#sites-status-tryme .centerTotal{ font:700 18px/1 ui-sans-serif,system-ui; fill:#cbd5e1; text-anchor:middle; }
#sites-status-tryme .centerLabel{ font:12px/1 ui-sans-serif,system-ui; fill:#94a3b8; text-anchor:middle; }

/* Buttons */
#sites-status-tryme .reset{ all:unset; color:#93c5fd; font-size:12px; cursor:pointer; }
#sites-status-tryme .reset[disabled]{ opacity:.45; cursor:default; }
#sites-status-tryme .btn{
  all:unset; cursor:pointer; user-select:none;
  border:1px solid #334155; padding:6px 10px; border-radius:8px; font-size:12px;
  color:#cbd5e1; background:#0b1222; transition:background .14s,border-color .14s;
}
#sites-status-tryme .btn:hover{ border-color:#3b82f6; background:#0f1730; }

/* Legend */
#sites-status-tryme .legend{
  display:none; border:1px solid #1f2937; background:#0b1222;
  border-radius:10px; padding:8px; margin:6px 0 2px;
}
#sites-status-tryme .legendHeader{
  font-size:12px; color:#94a3b8; margin-bottom:6px;
  display:flex; justify-content:space-between; align-items:center;
}
#sites-status-tryme .legendList{ display:flex; flex-direction:column; gap:6px; max-height:110px; overflow:auto; }
#sites-status-tryme .legendItem{
  display:flex; align-items:center; gap:10px; font-size:12px; cursor:pointer;
  padding:6px; border-radius:8px; transition:background .14s ease;
}
#sites-status-tryme .legendItem:hover{ background:#101a2e; }
#sites-status-tryme .swatch{ width:14px; height:14px; border-radius:3px; border:1px solid #0d1117; flex:none; }
#sites-status-tryme .liLabel{ color:#e2e8f0; flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
#sites-status-tryme .liValue{ color:#cbd5e1; font-variant-numeric:tabular-nums; }
#sites-status-tryme .liPct{ color:#94a3b8; min-width:36px; text-align:right; font-variant-numeric:tabular-nums; }

/* Quick filter tiles */
#sites-status-tryme .grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin-top:18px; }
#sites-status-tryme .tile{
  background:#0b1222; border:1px solid #1f2937; border-radius:10px; padding:10px;
  display:flex; align-items:center; gap:10px; cursor:pointer; user-select:none;
  transition: background .14s, border-color .14s, box-shadow .14s;
}
#sites-status-tryme .tile:hover{ background:#101a2e; }
#sites-status-tryme .tile.active{ border-color:#3b82f6; box-shadow:inset 0 0 0 1px #3b82f6; background:#0e162a; }
#sites-status-tryme .badge{ width:24px; height:24px; border-radius:6px; display:grid; place-items:center; }
#sites-status-tryme .b-err{ background:#ef4444; }
#sites-status-tryme .b-disc{ background:#9ca3af; }
#sites-status-tryme .b-warn{ background:#f59e0b; }
#sites-status-tryme .b-ok{ background:#22c55e; }
#sites-status-tryme .count{ font-weight:700; font-variant-numeric:tabular-nums; min-width:28px; text-align:right; color:#e5e7eb;}
#sites-status-tryme .label{ color:#94a3b8; font-size:12px; margin-left:auto; }

/* Slices */
#sites-status-tryme .slice{ cursor:pointer; transition: opacity .18s ease; stroke:#0b1222; stroke-width:1; stroke-linejoin:round; stroke-linecap:round; }
#sites-status-tryme .slice.dim{ opacity:.35; }

/* Notes column typography */
#sites-status-tryme .tryme-notes h3{ margin:6px 0 8px; }
#sites-status-tryme .tryme-notes .decisions{ padding-left: 1.2rem; line-height:1.45; }
#sites-status-tryme .tryme-notes .decisions li{ margin: 6px 0; }

/* Interactions section – figure cards & captions */
.case-cyber #interactions-and-decisions .cs-card{
  background:#0b1222;
  border:1px solid #1f2937;
  border-radius:12px;
  padding:14px;
}

.case-cyber #interactions-and-decisions .cs-card img{
  width:100%;
  height:auto;
  display:block;
  border-radius:8px;
}

.case-cyber #interactions-and-decisions .cs-card > figcaption{
  margin-top:10px;
  line-height:1.45;
  font-size:13px;
  color:#94a3b8;         /* muted */
}

.case-cyber #interactions-and-decisions .cs-card > figcaption .cs-kicker{
  display:inline-block;
  margin-bottom:4px;
  font-weight:600;
  font-size:12px;
  letter-spacing:.02em;
  color:#cbd5e1;         /* brighter than body text */
  text-transform:uppercase;
}
/* Scoped to the try-me widget */
#sites-status-tryme .hint{
  margin-top: 8px;
  font-size: 12px;
  line-height: 1.5;
  color: var(--muted);           /* #94a3b8 from your palette */
  letter-spacing: 0;
  font-weight: 400;
}
/* Coachmark / help banner */
.coach{
  display:flex; align-items:flex-start; gap:10px;
  background:#0b1222; border:1px solid #334155;
  border-radius:10px; padding:10px 12px; margin:8px 0 6px;
  box-shadow:0 6px 18px rgba(0,0,0,.28);
  color:#cbd5e1; font-size:12px; line-height:1.45;
}
.coach[hidden]{ display:none !important; }
.coach__text{ flex:1; }
.coach__close{
  all:unset; cursor:pointer; width:22px; height:22px; line-height:22px;
  text-align:center; border-radius:6px; color:#94a3b8;
}
.coach__close:hover{ background:#101a2e; color:#e5e7eb; }
.coach__close:focus-visible{ outline:2px solid #93c5fd; outline-offset:2px; }

/* gentle appear */
@media (prefers-reduced-motion: no-preference){
  .coach{ animation: coachIn .22s ease-out both; }
  @keyframes coachIn{
    from{ opacity:0; transform: translateY(4px); }
    to  { opacity:1; transform: translateY(0); }
  }
}


/* Safety: if you previously added margins to .key-decisions, neutralize them */
#tryme-row .key-decisions{ margin-left: 0; }
#tryme-row{
  display:grid;
  grid-template-columns:420px minmax(0,1fr);
  column-gap:100px;
  align-items:start;
}
@media (max-width:980px){
  #tryme-row{ grid-template-columns:1fr; row-gap:24px; column-gap:0; }
}
#tryme-row .demo-card{ position:relative; } /* for any popovers */
/* ===== Waveform Hero (scoped) ===== */
#wave-hero.wave-hero{
  position:relative;
  overflow:hidden;
  padding: clamp(36px, 6vw, 72px) 0;
  background: radial-gradient(1200px 600px at 10% -10%, rgba(59,130,246,0.14), transparent 60%),
              radial-gradient(900px 500px at 100% 0%, rgba(236,72,153,0.12), transparent 55%),
              #0b1222;
  border-bottom: 1px solid #0f1b2e;
  isolation:isolate;
}

#wave-hero .wave-hero__bg{
  position:absolute; inset:0; pointer-events:none; z-index:0;
}
#wave-hero .wave-hero__svg{ width:100%; height:100%; display:block; }

#wave-hero .wave-hero__haze{
  fill: url(#waveGrad);
  opacity: .10;
  filter: url(#waveGlow);
}

#wave-hero .wave-hero__wave{
  fill:none;
  stroke: url(#waveGrad);
  stroke-width: 2;
  filter: url(#waveGlow);
  stroke-linecap: round;
  stroke-dasharray: 8 10;
  animation: waveDash 8s linear infinite;
  opacity: .85;
}
#wave-hero .wave-hero__wave--2{ stroke-width: 1.6; opacity:.72; animation-duration: 10s; animation-direction: reverse; }
#wave-hero .wave-hero__wave--3{ stroke-width: 2.8; opacity:.58; animation-duration: 12s; }

@keyframes waveDash {
  to { stroke-dashoffset: -600; }
}

@media (prefers-reduced-motion: reduce){
  #wave-hero .wave-hero__wave{ animation: none; }
}

/* Content grid */
#wave-hero .wave-hero__wrap{
  position:relative; z-index:1;
  max-width: 1200px; margin: 0 auto; padding: 0 20px;
  display:grid; grid-template-columns: 1.05fr 1fr; gap: clamp(24px, 5vw, 60px);
  align-items: center;
}
@media (max-width: 980px){
  #wave-hero .wave-hero__wrap{ grid-template-columns: 1fr; }
}

/* Typography */
#wave-hero .wave-hero__title{
  margin:0 0 10px;
  font-size: clamp(28px, 4.6vw, 48px);
  line-height:1.08; letter-spacing:.2px;
  color:#e5e7eb;
  text-shadow: 0 0 22px rgba(96,165,250,.18);
}
#wave-hero .wave-hero__subtitle{
  margin:0 0 18px; color:#a5b4fc; font-size: clamp(14px, 1.6vw, 18px);
}

/* Meta chips */
#wave-hero .wave-hero__meta{
  list-style:none; padding:0; margin:16px 0 0 0;
  display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:12px;
}
@media (max-width:640px){
  #wave-hero .wave-hero__meta{ grid-template-columns: 1fr; }
}
#wave-hero .wave-hero__meta li{
  background:#0b1222; border:1px solid #1f2937; border-radius:12px;
  padding:10px 12px; box-shadow:0 6px 18px rgba(0,0,0,.25);
}
#wave-hero .wave-hero__meta li span{ display:block; color:#94a3b8; font-size:12px; margin-bottom:4px; }
#wave-hero .wave-hero__meta li strong{ color:#e2e8f0; font-weight:600; font-size:14px; }

/* Hero art card */
#wave-hero .wave-hero__art{
  position:relative; border-radius:14px; overflow:hidden;
  border:1px solid #1f2937;
  background: linear-gradient(180deg, rgba(16,24,40,.5), rgba(2,6,23,.5));
  box-shadow: 0 10px 30px rgba(0,0,0,.35), 0 0 0 1px rgba(59,130,246,.15) inset;
}
#wave-hero .wave-hero__art img{ display:block; width:100%; height:auto; border-radius:12px; }
@media (hover:hover) and (pointer:fine){
  #wave-hero .wave-hero__art:hover{
    box-shadow: 0 16px 40px rgba(0,0,0,.38), 0 0 0 1px rgba(59,130,246,.25) inset;
    transform: translateY(-1px);
    transition: box-shadow .2s ease, transform .2s ease;
  }
}
/* ===== p5 Waveform Hero (scoped) ===== */
#p5-hero{
  position: relative;
  overflow: hidden;
  background:#0A0014; /* cyber purple */
  border-bottom:1px solid #0f1b2e;
}
#p5-hero .p5hero-wrap{
  position: relative;
  min-height: 420px;
  height: 68vh;
  max-height: 760px;
}

/* Canvas host fills the hero */
#p5-hero #p5-canvas-host{
  position:absolute; inset:0; z-index:0; pointer-events:none;
}

/* Content */
#p5-hero .p5hero-content{
  position:relative; z-index:2;
  height:100%;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:2rem 1rem;
}
#p5-hero h1{
  margin:0 0 .5rem; font-weight:800;
  font-size:clamp(28px, 5vw, 56px); line-height:1.05;
  color:#fff; text-shadow:0 0 22px rgba(96,165,250,.2);
}
#p5-hero p{
  margin:.25rem 0 1.25rem; max-width:640px;
  font-size:clamp(14px, 1.6vw, 18px); color:#cfd3ff; line-height:1.6;
}
#p5-hero .p5hero-meta{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:12px;
  max-width:920px; width:100%;
}
@media (max-width: 720px){
  #p5-hero .p5hero-meta{ grid-template-columns:1fr; }
}
#p5-hero .p5hero-meta li{
  background:#0b1222; border:1px solid #1f2937; border-radius:12px;
  padding:10px 12px; color:#e2e8f0; box-shadow:0 6px 18px rgba(0,0,0,.25);
}
#p5-hero .p5hero-meta li span{ display:block; color:#94a3b8; font-size:12px; margin-bottom:4px; }

/* Slider */
#p5-hero .p5hero-slider{
  position:absolute; left:50%; bottom:10%; transform:translateX(-50%);
  z-index:3; width:min(320px, 70vw);
}
#p5-hero .p5hero-slider input[type=range]{
  -webkit-appearance:none; width:100%; background:transparent; cursor:pointer;
}
#p5-hero .p5hero-slider input[type=range]::-webkit-slider-runnable-track{
  height:4px; background:rgba(255,0,150,.5); border-radius:5px;
}
#p5-hero .p5hero-slider input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none; width:20px; height:20px; border-radius:50%;
  border:2px solid #0A0014; background:#00d0ff; margin-top:-8px;
  box-shadow:0 0 10px #00d0ff, 0 0 15px #00d0ff;
}
#p5-hero .p5hero-slider input[type=range]::-moz-range-track{
  height:4px; background:rgba(255,0,150,.5); border-radius:5px;
}
#p5-hero .p5hero-slider input[type=range]::-moz-range-thumb{
  width:20px; height:20px; border-radius:50%; border:2px solid #0A0014; background:#00d0ff;
  box-shadow:0 0 10px #00d0ff, 0 0 15px #00d0ff;
}

/* A11y helper */
.visually-hidden{ position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
