/* ============================================================
   INFERNO — Dallas Halloween Block Party (WordPress theme)
   Ported from the approved prototype. Class-based rules are
   verbatim; bare-element selectors are namespaced so nothing
   leaks into wp-admin or unrelated contexts.
   ============================================================ */
:root{
  --black:#0a0604;
  --char:#160d08;
  --orange:#ff6a00;
  --amber:#ffb627;
  --ember:#e23b0e;
  --cream:#ffe9cf;
  --muted:#c9a384;
  --glass:rgba(20,10,5,.55);
  --line:rgba(255,106,0,.28);
  --display:'Arial Black','Helvetica Neue',Impact,sans-serif;
  --body:'Helvetica Neue',Helvetica,Arial,sans-serif;
  --header-h:78px;
}

html{scroll-behavior:smooth}

.wp-site-blocks{
  font-family:var(--body);
  color:var(--cream);
  background:var(--black);
  overflow-x:hidden;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
.wp-site-blocks img{display:block;max-width:100%;height:auto}
.wp-site-blocks a{text-decoration:none}
::selection{background:var(--ember);color:#fff}

/* Dusk -> midnight scroll layer (driven by JS via --dark 0..1) */
#skyShift{
  position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(120% 90% at 50% -10%, rgba(255,106,0,.20), rgba(226,59,14,.08) 35%, transparent 60%),
    linear-gradient(180deg, #1c0f06 0%, #120a05 40%, #0a0604 100%);
  transition:filter .2s linear;
}
#skyShift::after{
  content:"";position:absolute;inset:0;
  background:#000;
  opacity:calc(var(--dark, 0) * .75);
  transition:opacity .15s linear;
}

.wrap{max-width:1200px;margin:0 auto;padding:0 24px}
.dhbp-section{position:relative}

/* ---------- Display / headings ---------- */
.display{
  font-family:var(--display);
  text-transform:uppercase;
  letter-spacing:.5px;
  line-height:.98;
  background:linear-gradient(180deg,#fff5e8 0%,var(--amber) 38%,var(--orange) 70%,var(--ember) 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  text-shadow:0 0 38px rgba(255,106,0,.25);
}
.eyebrow{
  font-family:var(--display);text-transform:uppercase;letter-spacing:.32em;
  font-size:.72rem;color:var(--amber);margin-bottom:14px;
  display:inline-block;
}
.lead{color:var(--muted);font-size:1.06rem;max-width:62ch}

/* glowing ember divider */
.ember-line{
  height:2px;border:0;margin:0 auto;
  background:linear-gradient(90deg,transparent,var(--orange) 30%,var(--amber) 50%,var(--orange) 70%,transparent);
  box-shadow:0 0 14px rgba(255,106,0,.7);
  width:min(420px,70%);
}

/* ---------- Buttons (raw .btn + core button blocks) ---------- */
.btn,
.wp-block-button__link{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--display);text-transform:uppercase;letter-spacing:.12em;
  font-size:.92rem;padding:16px 30px;border-radius:50px;cursor:pointer;
  border:0;color:#1a0a02;
  background:linear-gradient(180deg,var(--amber),var(--orange) 55%,var(--ember));
  box-shadow:0 0 0 rgba(255,106,0,.6),0 10px 30px rgba(226,59,14,.35);
  transition:transform .2s ease,box-shadow .3s ease;
  animation:pulseGlow 2.6s ease-in-out infinite;
}
.btn:hover,
.wp-block-button__link:hover{transform:translateY(-3px) scale(1.03)}
.btn.ghost,
.ghost .wp-block-button__link,
.is-style-outline .wp-block-button__link{
  background:transparent;color:var(--amber);
  border:1.5px solid var(--line);box-shadow:none;animation:none;
}
.btn.ghost:hover,
.ghost .wp-block-button__link:hover,
.is-style-outline .wp-block-button__link:hover{border-color:var(--amber);box-shadow:0 0 20px rgba(255,106,0,.3)}
@keyframes pulseGlow{
  0%,100%{box-shadow:0 0 12px rgba(255,106,0,.5),0 10px 30px rgba(226,59,14,.35)}
  50%{box-shadow:0 0 34px rgba(255,150,40,.85),0 12px 40px rgba(226,59,14,.5)}
}

/* ============================================================
   HEADER — floating glass capsule
   ============================================================ */
.dhbp-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;justify-content:center;align-items:flex-start;
  padding:18px 24px 0;pointer-events:none;
  transition:padding .35s cubic-bezier(.4,0,.2,1);
}
.dhbp-header .capsule,
.dhbp-header > .capsule{pointer-events:auto}

/* the floating pill */
.capsule{
  position:relative;
  display:flex;align-items:center;justify-content:space-between;gap:26px;
  width:100%;max-width:1180px;
  padding:11px 14px 11px 24px;
  border-radius:50px;
  background:linear-gradient(180deg,rgba(28,16,8,.55),rgba(12,7,4,.62));
  border:1px solid rgba(255,150,50,.16);
  backdrop-filter:blur(14px) saturate(1.2);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  box-shadow:
    0 1px 0 rgba(255,200,140,.10) inset,
    0 18px 50px -12px rgba(0,0,0,.7),
    0 0 0 rgba(255,106,0,0);
  transition:max-width .4s cubic-bezier(.4,0,.2,1),padding .35s ease,
    background .35s ease,border-color .35s ease,box-shadow .45s ease;
}
/* ember glow-ring drawn behind the capsule */
.capsule::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;
  background:linear-gradient(120deg,
    rgba(255,182,39,.0) 0%,rgba(255,182,39,.55) 25%,
    rgba(226,59,14,.55) 50%,rgba(255,106,0,.0) 78%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.5;background-size:220% 220%;
  animation:ringDrift 9s linear infinite;
  pointer-events:none;
}
@keyframes ringDrift{0%{background-position:0% 50%}100%{background-position:220% 50%}}

.dhbp-header.scrolled{padding-top:12px}
.dhbp-header.scrolled .capsule{
  max-width:1040px;
  background:linear-gradient(180deg,rgba(22,13,7,.82),rgba(10,6,4,.86));
  border-color:rgba(255,150,50,.26);
  box-shadow:
    0 1px 0 rgba(255,200,140,.12) inset,
    0 20px 55px -12px rgba(0,0,0,.8),
    0 0 34px -6px rgba(255,106,0,.35);
}
.dhbp-header.scrolled .capsule::before{opacity:.85}

/* brand */
.brand{display:flex;align-items:center;gap:12px;font-family:var(--display);
  text-transform:uppercase;letter-spacing:.06em;font-size:1rem;line-height:1.1;
  white-space:nowrap}
.brand .dot{width:13px;height:13px;border-radius:50%;flex:0 0 auto;
  background:radial-gradient(circle at 35% 35%,#fff,var(--amber) 40%,var(--ember));
  box-shadow:0 0 14px var(--orange),0 0 28px rgba(255,106,0,.5);animation:flick 3s infinite}
.brand span{background:linear-gradient(180deg,#fff,var(--amber));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.brand img{height:48px;width:auto;display:block;
  filter:drop-shadow(0 0 12px rgba(255,106,0,.45));
  transition:height .35s cubic-bezier(.4,0,.2,1)}
.dhbp-header.scrolled .brand img{height:40px}

/* desktop nav links */
.dhbp-nav ul{display:flex;gap:6px;list-style:none;margin:0;padding:0}
.dhbp-nav a{display:block;font-size:.8rem;text-transform:uppercase;letter-spacing:.13em;
  color:var(--muted);position:relative;padding:9px 14px;border-radius:30px;
  transition:color .25s ease,background .25s ease}
.dhbp-nav a:hover,.dhbp-nav a:focus-visible{color:var(--cream);
  background:radial-gradient(120% 140% at 50% 120%,rgba(255,106,0,.22),rgba(255,106,0,0) 70%)}
.dhbp-nav a::after{content:"";position:absolute;left:50%;bottom:5px;height:2px;width:0;
  transform:translateX(-50%);border-radius:2px;
  background:linear-gradient(90deg,var(--orange),var(--amber));transition:width .28s ease;
  box-shadow:0 0 8px var(--orange)}
.dhbp-nav a:hover::after,.dhbp-nav a:focus-visible::after{width:calc(100% - 28px)}

/* CTA inside the capsule */
.nav-cta{display:inline-flex;flex:0 0 auto;white-space:nowrap;padding:13px 26px;font-size:.82rem}

/* hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;
  padding:10px;margin-right:6px;z-index:101}
.hamburger span{width:26px;height:2.5px;background:var(--amber);border-radius:2px;
  transition:transform .3s,opacity .3s;box-shadow:0 0 6px var(--orange)}
.hamburger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ============================================================
   MOBILE — full-screen ember overlay
   ============================================================ */
.nav-overlay{
  position:fixed;inset:0;z-index:99;
  display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(120% 80% at 50% 0%,rgba(255,106,0,.22),rgba(226,59,14,.06) 40%,transparent 70%),
    linear-gradient(180deg,rgba(14,8,4,.97),rgba(8,4,2,.99));
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  opacity:0;visibility:hidden;
  clip-path:circle(0% at calc(100% - 44px) 40px);
  transition:opacity .35s ease,visibility .35s ease,clip-path .55s cubic-bezier(.5,0,.2,1);
}
.nav-overlay.open{opacity:1;visibility:visible;clip-path:circle(150% at calc(100% - 44px) 40px)}
.nav-overlay__menu{display:flex;flex-direction:column;align-items:center;gap:6px;width:100%;padding:0 28px}
.nav-overlay__menu a{
  font-family:var(--display);text-transform:uppercase;letter-spacing:.08em;
  font-size:clamp(1.6rem,7vw,2.4rem);color:var(--cream);padding:8px 0;line-height:1.1;
  opacity:0;transform:translateY(22px);
  transition:color .25s ease;
}
.nav-overlay.open .nav-overlay__menu a{
  animation:overlayIn .5s cubic-bezier(.2,.7,.2,1) forwards;
  animation-delay:calc(.12s + var(--i) * .06s);
}
.nav-overlay__menu a:not(.btn):hover{color:var(--amber)}
.nav-overlay__cta{margin-top:22px;font-size:1rem !important;color:#1a0a02 !important}
@keyframes overlayIn{to{opacity:1;transform:none}}

/* ============================================================
   HERO
   ============================================================ */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;padding:120px 20px 80px;position:relative}
.hero-bg{position:absolute;inset:-8% -4%;z-index:0;will-change:transform}
.hero-bg img{width:100%;height:115%;object-fit:cover;opacity:.30;
  filter:saturate(1.1) contrast(1.05)}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:radial-gradient(70% 70% at 50% 40%, transparent, rgba(10,6,4,.7) 70%, var(--black) 100%)}
.hero-glow{position:absolute;z-index:0;width:min(900px,120vw);height:min(900px,120vw);
  left:50%;top:42%;transform:translate(-50%,-50%);pointer-events:none;
  background:radial-gradient(circle,rgba(255,106,0,.28),rgba(226,59,14,.10) 40%,transparent 65%);
  animation:breathe 6s ease-in-out infinite}
@keyframes breathe{0%,100%{opacity:.7;transform:translate(-50%,-50%) scale(1)}
  50%{opacity:1;transform:translate(-50%,-50%) scale(1.08)}}
#embers{position:absolute;inset:0;z-index:1;pointer-events:none}
.hero-inner{position:relative;z-index:2;max-width:880px;margin:0 auto}
.hero-logo{width:min(640px,90%);margin:0 auto;
  filter:drop-shadow(0 0 40px rgba(255,106,0,.45));
  animation:flick 4.5s infinite, floaty 7s ease-in-out infinite}
@keyframes flick{
  0%,100%{filter:drop-shadow(0 0 36px rgba(255,106,0,.40)) brightness(1)}
  47%{filter:drop-shadow(0 0 30px rgba(255,106,0,.34)) brightness(1.04)}
  50%{filter:drop-shadow(0 0 52px rgba(255,170,50,.6)) brightness(1.1)}
  53%{filter:drop-shadow(0 0 30px rgba(255,106,0,.34)) brightness(1.02)}
}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hero-slogan{width:min(720px,95%);margin:22px auto 6px;opacity:.95;
  filter:drop-shadow(0 0 18px rgba(255,106,0,.3))}
.hero-meta{display:flex;gap:10px 26px;justify-content:center;flex-wrap:wrap;
  margin:26px 0 6px;color:var(--cream);font-size:.95rem;letter-spacing:.04em}
.hero-meta b{color:var(--amber)}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:30px}
.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;
  color:var(--muted);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase}
.scroll-hint .mouse{width:22px;height:36px;border:2px solid var(--line);border-radius:14px;
  margin:8px auto 0;position:relative}
.scroll-hint .mouse::after{content:"";position:absolute;left:50%;top:7px;width:4px;height:7px;
  margin-left:-2px;border-radius:2px;background:var(--amber);animation:wheel 1.6s infinite}
@keyframes wheel{0%{opacity:0;transform:translateY(-4px)}40%{opacity:1}100%{opacity:0;transform:translateY(10px)}}

/* ============================================================
   COUNTDOWN
   ============================================================ */
.count-sec{padding:80px 0 70px;text-align:center}
.countdown{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin-top:34px}
.ctile{
  min-width:120px;padding:22px 16px;border-radius:16px;
  background:linear-gradient(180deg,rgba(40,18,6,.9),rgba(18,10,5,.9));
  border:1px solid var(--line);
  box-shadow:0 0 30px rgba(255,106,0,.18),inset 0 0 22px rgba(255,106,0,.08);
  animation:tileGlow 3.5s ease-in-out infinite;
}
@keyframes tileGlow{0%,100%{box-shadow:0 0 24px rgba(255,106,0,.16),inset 0 0 18px rgba(255,106,0,.06)}
  50%{box-shadow:0 0 42px rgba(255,140,30,.4),inset 0 0 26px rgba(255,106,0,.14)}}
.ctile .num{font-family:var(--display);font-size:3rem;line-height:1;
  background:linear-gradient(180deg,#fff5e8,var(--amber) 55%,var(--orange));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  text-shadow:0 0 24px rgba(255,140,30,.35)}
.ctile .lab{margin-top:10px;font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:var(--muted)}

/* Compact countdown inside the hero — sits between the logo and the slogan */
.hero-countdown{margin:18px auto 6px}
.hero-countdown .countdown{margin-top:0}
.hero-countdown .ctile{min-width:88px;padding:14px 12px;border-radius:13px}
.hero-countdown .ctile .num{font-size:2.1rem}
.hero-countdown .ctile .lab{margin-top:6px;font-size:.62rem;letter-spacing:.22em}
@media (max-width:480px){
  .hero-countdown .ctile{min-width:calc(25% - 9px);padding:11px 6px}
  .hero-countdown .ctile .num{font-size:1.5rem}
  .hero-countdown .countdown{gap:9px}
}
/* Below the width where all 4 tiles fit one row, drop the Seconds tile
   and let Days/Hours/Minutes fill the row as a clean 3-up (no orphan). */
@media (max-width:560px){
  .hero-countdown .countdown{flex-wrap:nowrap}
  .hero-countdown .ctile{flex:1 1 0;min-width:0}
  .hero-countdown .ctile:last-child{display:none}
}

/* ============================================================
   STATS STRIP
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  padding:46px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  margin:10px 0 0}
.stat{text-align:center}
.stat .v{font-family:var(--display);font-size:2.6rem;
  background:linear-gradient(180deg,#fff5e8,var(--orange));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat .k{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-top:6px}

/* ============================================================
   ABOUT
   ============================================================ */
.about{padding:100px 0;display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.about h2{font-size:clamp(2.2rem,5vw,3.6rem);margin:8px 0 22px}
.about-art{position:relative;border-radius:18px;overflow:hidden;
  border:1px solid var(--line);box-shadow:0 20px 60px rgba(0,0,0,.6),0 0 50px rgba(255,106,0,.12)}
.about-art img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.about-art .ghost{position:absolute;right:-6%;bottom:-4%;width:46%;z-index:2;
  filter:drop-shadow(0 0 22px rgba(255,106,0,.3));animation:floaty 8s ease-in-out infinite;aspect-ratio:auto}

/* ============================================================
   FEATURES
   ============================================================ */
.features{padding:90px 0}
.sec-head{text-align:center;margin-bottom:54px}
.sec-head h2{font-size:clamp(2rem,5vw,3.4rem);margin:6px 0 18px}
.fgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.fcard{
  background:linear-gradient(180deg,rgba(34,16,7,.7),rgba(16,9,5,.7));
  border:1px solid rgba(255,106,0,.18);border-radius:18px;padding:34px 26px;
  transition:transform .35s ease,box-shadow .35s ease,border-color .35s;
  position:relative;overflow:hidden;
}
.fcard::before{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 80% at 50% -20%,rgba(255,106,0,.18),transparent 60%);
  opacity:0;transition:opacity .35s}
.fcard:hover{transform:translateY(-8px);border-color:var(--orange);
  box-shadow:0 18px 50px rgba(0,0,0,.55),0 0 36px rgba(255,106,0,.22)}
.fcard:hover::before{opacity:1}
.fcard .ic{font-size:2.4rem;margin-bottom:16px;filter:drop-shadow(0 0 12px rgba(255,106,0,.6))}
.fcard h3{font-family:var(--display);text-transform:uppercase;font-size:1.15rem;letter-spacing:.04em;
  margin-bottom:10px;color:var(--cream)}
.fcard p{color:var(--muted);font-size:.92rem;margin:0}

/* ============================================================
   SCHEDULE
   ============================================================ */
.schedule{padding:100px 0;position:relative}
.sched-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.sched-bg img{width:120%;height:130%;object-fit:cover;opacity:.16;will-change:transform}
.sched-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,var(--black),transparent 30%,var(--black))}
.sched-inner{position:relative;z-index:1;max-width:760px;margin:0 auto}
.timeline{margin-top:44px;position:relative;padding-left:34px}
.timeline::before{content:"";position:absolute;left:8px;top:6px;bottom:6px;width:2px;
  background:linear-gradient(180deg,var(--amber),var(--orange),var(--ember));
  box-shadow:0 0 12px rgba(255,106,0,.6)}
.tline{position:relative;display:flex;gap:24px;align-items:baseline;padding:16px 0;
  border-bottom:1px solid rgba(255,106,0,.1)}
.tline::before{content:"";position:absolute;left:-30px;top:24px;width:13px;height:13px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%,#fff,var(--amber) 45%,var(--ember));
  box-shadow:0 0 14px var(--orange)}
.tline .time{font-family:var(--display);color:var(--amber);min-width:104px;font-size:1.05rem;margin:0}
.tline .ev{font-size:1.05rem;color:var(--cream);margin:0}
.lineup-note{text-align:center;color:var(--muted);font-size:.8rem;letter-spacing:.16em;
  text-transform:uppercase;margin-top:30px}

/* ============================================================
   PARTNERS
   ============================================================ */
.partners{padding:90px 0;text-align:center}
.plogos{display:flex;gap:42px;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:40px}
.plogos img{height:62px;width:auto;opacity:.78;filter:brightness(0) invert(1) drop-shadow(0 0 1px rgba(0,0,0,.5));
  transition:opacity .3s,transform .3s,filter .3s}
.plogos img:hover{opacity:1;transform:scale(1.06);filter:drop-shadow(0 0 14px rgba(255,106,0,.5))}
.plogos figure{margin:0}
.tagline-graphic{margin:42px auto 0;max-width:420px;opacity:.85;
  filter:brightness(0) invert(1) drop-shadow(0 0 12px rgba(255,106,0,.4))}

/* ============================================================
   VENDOR
   ============================================================ */
.vendor{padding:100px 0}
.vendor-card{
  position:relative;overflow:hidden;border-radius:24px;padding:70px 50px;text-align:center;
  border:1px solid var(--line);
  background:linear-gradient(120deg,rgba(40,18,6,.85),rgba(16,9,5,.9));
  box-shadow:0 0 60px rgba(255,106,0,.14),inset 0 0 40px rgba(255,106,0,.05)}
.vendor-card::before{content:"";position:absolute;width:420px;height:420px;border-radius:50%;
  right:-120px;top:-160px;background:radial-gradient(circle,rgba(255,106,0,.25),transparent 70%)}
.vendor-card h2{font-size:clamp(2rem,5vw,3.2rem);margin:8px 0 18px;position:relative}
.vendor-card p{position:relative;max-width:60ch;margin:0 auto 30px;color:var(--muted)}

/* ============================================================
   NEWSLETTER / COVEN
   ============================================================ */
.coven{padding:90px 0 110px}
.coven-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.coven h2{font-size:clamp(2rem,5vw,3.2rem);margin:8px 0 18px}
.coven-form{display:flex;flex-direction:column;gap:16px;max-width:440px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.field input{
  background:rgba(10,6,4,.7);border:1px solid var(--line);border-radius:12px;
  padding:15px 16px;color:var(--cream);font-size:1rem;font-family:var(--body);
  transition:border-color .25s,box-shadow .25s}
.field input:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,106,0,.18)}
.note{font-size:.8rem;color:var(--muted)}
.confirm{display:none;margin-top:8px;padding:16px 18px;border-radius:12px;
  background:linear-gradient(90deg,rgba(255,106,0,.18),rgba(226,59,14,.12));
  border:1px solid var(--orange);color:var(--cream);font-size:.95rem}
.confirm.show{display:block;animation:fadeUp .5s ease both}
.coven-art{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line);
  box-shadow:0 20px 60px rgba(0,0,0,.6)}
.coven-art img{width:100%;aspect-ratio:1/1;object-fit:cover;opacity:.85}

/* ============================================================
   FOOTER
   ============================================================ */
.dhbp-footer{position:relative;padding:130px 0 40px;overflow:hidden;margin-top:20px}
.footer-bg{position:absolute;inset:0;z-index:0}
.footer-bg img{width:100%;height:100%;object-fit:cover;opacity:.5}
.footer-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,var(--black),rgba(10,6,4,.5) 40%,var(--black))}
.footer-zombies{position:absolute;left:0;right:0;bottom:0;z-index:1;width:100%;
  opacity:.9;will-change:transform}
.footer-inner{position:relative;z-index:2;text-align:center}
.footer-inner .fname{font-family:var(--display);text-transform:uppercase;
  font-size:clamp(1.6rem,4vw,2.6rem);margin-bottom:12px}
.footer-inner .floc{color:var(--muted);margin-bottom:24px}
.socials{display:flex;gap:18px;justify-content:center;margin-bottom:34px}
.socials a{width:46px;height:46px;border-radius:50%;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--amber);
  transition:transform .25s,box-shadow .25s,border-color .25s,background .25s}
.socials a:hover{transform:translateY(-3px);border-color:var(--orange);
  box-shadow:0 0 20px rgba(255,106,0,.5);background:rgba(255,106,0,.1)}
.socials svg{width:20px;height:20px;fill:currentColor}
.credit{color:var(--muted);font-size:.82rem;letter-spacing:.04em;
  border-top:1px solid rgba(255,106,0,.12);padding-top:26px;margin-top:10px}
.credit-link{color:var(--amber);transition:color .25s,text-shadow .25s}
.credit-link:hover{color:var(--cream);text-shadow:0 0 12px rgba(255,106,0,.6)}
.credit-social{display:inline-flex;align-items:center;justify-content:center;
  width:26px;height:26px;margin-left:8px;border-radius:50%;vertical-align:middle;
  border:1px solid var(--line);color:var(--amber);
  transition:color .25s,border-color .25s,transform .25s,box-shadow .25s}
.credit-social svg{width:14px;height:14px;fill:currentColor}
.credit-social:hover{color:var(--cream);border-color:var(--orange);
  transform:translateY(-2px);box-shadow:0 0 16px rgba(255,106,0,.4)}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.scale{transform:scale(.92)}
.reveal.scale.in{transform:none}
.reveal[data-d="1"]{transition-delay:.1s}
.reveal[data-d="2"]{transition-delay:.2s}
.reveal[data-d="3"]{transition-delay:.3s}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .about,.coven-grid{grid-template-columns:1fr;gap:40px}
  .fgrid{grid-template-columns:repeat(2,1fr)}
  .about-art{order:-1}
}
@media (max-width:980px){
  .dhbp-nav,.nav-cta{display:none}
  .hamburger{display:flex}
  .dhbp-header.scrolled .capsule{max-width:1180px}
  .capsule{padding:9px 8px 9px 20px}
  .brand{font-size:.9rem}
}
@media (max-width:768px){
  .stats{grid-template-columns:repeat(2,1fr);gap:30px 18px}
  .plogos{gap:28px}
  .plogos img{height:48px}
  .vendor-card{padding:50px 26px}
}
/* Keep the two hero buttons side-by-side on phones (shrink to fit). */
@media (max-width:560px){
  .hero-cta{flex-wrap:nowrap;gap:10px}
  .hero-cta .wp-block-button{flex:1 1 0;min-width:0}
  .hero-cta .wp-block-button__link{
    width:100%;justify-content:center;text-align:center;
    padding:14px 10px;font-size:.74rem;letter-spacing:.05em;gap:0}
}
@media (max-width:480px){
  .fgrid{grid-template-columns:1fr}
  .ctile{min-width:calc(50% - 12px)}
  .countdown{gap:12px}
  .ctile .num{font-size:2.4rem}
  .tline{flex-direction:column;gap:4px}
}

/* Reduced motion: kill movement, keep everything visible */
@media (prefers-reduced-motion:reduce){
  .wp-site-blocks *,.wp-site-blocks *::before,.wp-site-blocks *::after{animation:none !important;transition:none !important}
  .reveal{opacity:1 !important;transform:none !important}
  html{scroll-behavior:auto}
}
