
:root {
  --bg: #0b0a0a;
  --bg-soft: rgba(255, 255, 255, 0.04);
  --panel: rgba(255, 255, 255, 0.055);
  --line: rgba(255, 255, 255, 0.11);
  --text: #f7f0e8;
  --muted: #d6c7bb;
  --orange: #ff8c2f;
  --orange-2: #ffb146;
  --orange-3: #ff5a1f;
  --glow: rgba(255, 138, 54, 0.28);
  --shadow: 0 18px 60px rgba(0, 0, 0, 0.35);
  --radius: 24px;
  --max: 1160px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-width: 320px;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at 12% 14%, rgba(255, 122, 26, 0.10), transparent 26%),
    radial-gradient(circle at 84% 20%, rgba(255, 186, 120, 0.07), transparent 18%),
    radial-gradient(circle at 68% 72%, rgba(255, 92, 32, 0.07), transparent 20%),
    #0b0a0a;
  color: var(--text);
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

#glitter {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none;
  opacity: 0.9;
}

.site-header,
main,
.section,
.hero { position: relative; z-index: 1; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 10;
  padding: 14px 18px 0;
  transition: transform 260ms ease, opacity 260ms ease;
  will-change: transform;
}

.site-header.nav--hidden {
  transform: translateY(-120%);
  opacity: 0;
}

/* ── Nav ── */
.nav {
  width: min(calc(100% - 120px), 980px);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 14px 18px;
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 999px;
  background: rgba(255,255,255,0.008);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.14),
    0 4px 18px rgba(0,0,0,0.06);
  backdrop-filter: blur(0.5px);
  -webkit-backdrop-filter: blur(0.5px);
  overflow: clip;
  clip-path: inset(0 round 999px);
  -webkit-clip-path: inset(0 round 999px);
  isolation: isolate;
}

.nav::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(105deg,
    rgba(255, 140, 180, 0.00) 0%,
    rgba(255, 180, 120, 0.10) 12%,
    rgba(255, 230, 120, 0.11) 22%,
    rgba(140, 240, 180, 0.12) 34%,
    rgba(120, 200, 255, 0.14) 46%,
    rgba(190, 150, 255, 0.12) 58%,
    rgba(255, 140, 220, 0.11) 70%,
    rgba(120, 230, 255, 0.10) 82%,
    rgba(255, 200, 140, 0.07) 92%,
    rgba(255, 140, 180, 0.00) 100%);
  background-size: 300% 100%;
  mix-blend-mode: screen;
  animation: navGlassShimmer 6.5s ease-in-out infinite alternate;
  pointer-events: none;
  z-index: -1;
}

.nav::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(180deg,
    rgba(255,255,255,0.09) 0%,
    rgba(255,255,255,0.02) 40%,
    rgba(255,255,255,0.00) 100%);
  z-index: -1;
}

@keyframes navGlassShimmer {
  0%   { background-position: 0% 0; opacity: 0.75; }
  100% { background-position: 100% 0; opacity: 1; }
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-weight: 700;
  font-size: 1.08rem;
  letter-spacing: 0.01em;
}

.brand-mark {
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border-radius: 0;
  box-shadow: none;
  overflow: hidden;
}

.brand-wedge {
  display: block;
  width: 26px;
  height: 26px;
  object-fit: contain;
  filter: drop-shadow(0 0 8px rgba(255, 156, 56, 0.22));
}

.brand-text { white-space: nowrap; }

.brand-text-wrap {
  display: flex;
  flex-direction: column;
  line-height: 1.05;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 22px;
  color: var(--muted);
  font-size: 0.98rem;
}
.nav-links a {
  position: relative;
  padding-bottom: 2px;
}
.nav-links a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -3px;
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--orange-2), transparent);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform 180ms ease;
}
.nav-links a:hover::after,
.nav-links a:focus-visible::after { transform: scaleX(1); }

/* ── Hero ── */
.hero {
  width: min(100%, 860px);
  margin: 0 auto;
  min-height: auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 32px;
  padding: 28px 32px 36px;
  row-gap: 28px;
}

.eyebrow {
  margin: 0 0 14px;
  color: #ffd4ab;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.78rem;
}

.section-kicker {
  margin: 0 0 10px;
  font-size: clamp(1.3rem, 2.4vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  background:
    linear-gradient(96deg,
      rgba(255, 188, 112, 0.92) 0%,
      rgba(255, 214, 150, 0.96) 24%,
      rgba(255, 157, 73, 0.9) 46%,
      rgba(255, 225, 178, 0.96) 68%,
      rgba(255, 176, 92, 0.92) 100%);
  background-size: 220% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 0 6px rgba(255, 140, 40, 0.16));
  animation: kickerShimmer 20s ease-in-out infinite alternate;
  position: relative;
}

.section-kicker::after {
  content: "";
}

@keyframes kickerShimmer {
  0%   { background-position: 100% 50%; filter: drop-shadow(0 0 5px rgba(255, 140, 40, 0.12)); }
  100% { background-position: 0% 50%; filter: drop-shadow(0 0 8px rgba(255, 170, 90, 0.18)); }
}

@keyframes sparkleSlide {
  0%   { background-position: 200% 0; opacity: 0.4; }
  40%  { opacity: 0.85; }
  100% { background-position: -100% 0; opacity: 0.4; }
}

.hero h1 {
  margin: 0;
  font-size: clamp(3rem, 7vw, 5.9rem);
  line-height: 1.02;
  letter-spacing: -0.04em;
  text-wrap: balance;
  padding-bottom: 0.11em;
  overflow: visible;
  background:
    linear-gradient(92deg,
      #fff1df 0%,
      #ffb96c 10%,
      #ff8ad4 24%,
      #91d8ff 40%,
      #9df3d3 54%,
      #d4bcff 68%,
      #ff9ee8 82%,
      #ffd274 92%,
      #fff1df 100%);
  background-size: 300% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 0 14px rgba(255, 182, 110, 0.12));
  animation: titleIridescence 5.8s ease-in-out infinite alternate;
}

@keyframes titleIridescence {
  0%   { background-position: 0% 50%;   filter: drop-shadow(0 0 12px rgba(255, 182, 110, 0.16)) saturate(1); }
  100% { background-position: 100% 50%; filter: drop-shadow(0 0 22px rgba(185, 230, 255, 0.22)) saturate(1.12); }
}

.lede {
  margin: 16px 0 0;
  font-size: clamp(1.2rem, 2vw, 1.65rem);
  color: #ffbd74;
  font-weight: 650;
}

.intro {
  max-width: 38rem;
  margin: 18px 0 0;
  color: var(--muted);
  font-size: 1.06rem;
  line-height: 1.75;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 22px;
  margin-top: 28px;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 18px;
  border-radius: 999px;
  font-weight: 650;
  letter-spacing: 0.01em;
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}
.button:hover,
.button:focus-visible { transform: translateY(-1px); }

.button-primary {
  color: #130d09;
  background: linear-gradient(180deg, #ffbc70, #ff8c2f 58%, #f86d25 100%);
  box-shadow: 0 10px 28px rgba(255, 127, 41, 0.35);
}
.button-secondary {
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.04);
  color: var(--text);
}

/* ── Hero card / orange ── */
.hero-card {
  justify-self: center;
  width: min(100%, 240px);
  aspect-ratio: 1 / 1;
  position: relative;
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,0.10);
  background:
    radial-gradient(circle at 70% 28%, rgba(255, 164, 77, 0.16), transparent 22%),
    linear-gradient(180deg, rgba(255,255,255,0.065), rgba(255,255,255,0.025));
  box-shadow:
    var(--shadow),
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 0 0 1px rgba(255, 189, 123, 0.04);
  overflow: visible;
}

.hero-card::before {
  content: "";
  position: absolute;
  inset: auto -8% -18% auto;
  width: 72%;
  height: 72%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,145,48,0.26), transparent 68%);
  filter: blur(18px);
}

.hero-card::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,0.085),
    inset 0 0 0 2px rgba(255, 190, 120, 0.035),
    inset 0 0 44px rgba(255, 183, 118, 0.045);
}

.hero-wedge-wrap {
  position: absolute;
  inset: 5% 4% 3% 4%;
  display: grid;
  place-items: center;
  isolation: isolate;
  overflow: visible;
}

.hero-aura {
  position: absolute;
  width: 92%;
  height: 92%;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 52%,
      rgba(255, 214, 130, 0.22) 0%,
      rgba(255, 146, 48, 0.28) 26%,
      rgba(255, 95, 28, 0.22) 44%,
      rgba(255, 95, 28, 0.00) 72%);
  filter: blur(34px) saturate(150%);
  z-index: 1;
  animation: auraPulse 4.8s ease-in-out infinite alternate;
}

.hero-wedge {
  position: relative;
  z-index: 4;
  width: 100%;
  max-width: 388px;
  transform: rotate(9deg) translateY(18px);
  filter: drop-shadow(0 18px 22px rgba(0,0,0,0.22));
  cursor: pointer;
  transform-origin: center bottom;
  touch-action: none;
}

.hero-wedge.wedge--tap {
  animation: wedgeBounce 380ms ease-out forwards;
}

@keyframes wedgeBounce {
  0%   { transform: rotate(9deg)  translateY(18px) scale(1);    }
  30%  { transform: rotate(10deg) translateY(13px) scale(1.04); }
  65%  { transform: rotate(8.5deg) translateY(17px) scale(0.98); }
  100% { transform: rotate(9deg)  translateY(18px) scale(1);    }
}

/* ── Flames ── */
.flame {
  position: absolute;
  z-index: 3;
  pointer-events: none;
  transform-origin: center bottom;
}

/* Centre — tall tapered flame */
.flame-a {
  width: 52px; height: 130px;
  left: calc(50% - 26px); top: -14%;
  border-radius: 50% 50% 30% 30% / 60% 60% 40% 40%;
  background: radial-gradient(ellipse 60% 90% at 50% 95%,
    rgba(255,70,0,1) 0%, rgba(255,130,20,1) 28%,
    rgba(255,190,50,0.85) 55%, rgba(255,230,120,0.4) 76%, transparent 100%);
  filter:
    blur(0.8px)
    drop-shadow(0 0 14px rgba(255,110,15,0.90))
    drop-shadow(0 0 30px rgba(255,160,40,0.55))
    drop-shadow(0 0 50px rgba(255,80,0,0.28));
  animation: flameA 2.1s ease-in-out infinite alternate;
}
.flame-a::after {
  content: "";
  position: absolute;
  inset: 20% 25% 5% 25%;
  border-radius: inherit;
  background: radial-gradient(ellipse 55% 75% at 50% 90%,
    rgba(255,252,200,0.95) 0%, rgba(255,215,80,0.7) 40%, transparent 100%);
  filter: blur(1px);
}

/* Left — shorter, leans left */
.flame-b {
  width: 36px; height: 82px;
  left: calc(30% - 18px); top: 10%;
  border-radius: 48% 42% 32% 36% / 58% 54% 46% 44%;
  background: radial-gradient(ellipse 58% 88% at 52% 94%,
    rgba(255,80,5,1) 0%, rgba(255,140,22,0.9) 32%,
    rgba(255,195,55,0.6) 62%, transparent 100%);
  filter:
    blur(1px)
    drop-shadow(0 0 10px rgba(255,100,10,0.80))
    drop-shadow(0 0 22px rgba(255,150,30,0.40));
  animation: flameB 1.6s ease-in-out infinite alternate;
}
.flame-b::after {
  content: "";
  position: absolute;
  inset: 22% 20% 8% 22%;
  border-radius: inherit;
  background: radial-gradient(ellipse 50% 70% at 50% 88%,
    rgba(255,240,150,0.85) 0%, rgba(255,200,60,0.4) 55%, transparent 100%);
  filter: blur(0.8px);
}

/* Right — slightly taller, leans right */
.flame-c {
  width: 40px; height: 96px;
  left: calc(68% - 20px); top: 6%;
  border-radius: 42% 48% 36% 32% / 54% 58% 44% 46%;
  background: radial-gradient(ellipse 58% 88% at 48% 94%,
    rgba(255,80,5,1) 0%, rgba(255,140,22,0.9) 32%,
    rgba(255,195,55,0.6) 62%, transparent 100%);
  filter:
    blur(1px)
    drop-shadow(0 0 10px rgba(255,100,10,0.80))
    drop-shadow(0 0 22px rgba(255,150,30,0.40));
  animation: flameC 1.85s ease-in-out infinite alternate;
}
.flame-c::after {
  content: "";
  position: absolute;
  inset: 22% 22% 8% 20%;
  border-radius: inherit;
  background: radial-gradient(ellipse 50% 70% at 50% 88%,
    rgba(255,240,150,0.85) 0%, rgba(255,200,60,0.4) 55%, transparent 100%);
  filter: blur(0.8px);
}

.flame-d { display: none; }

/* Embers */
.ember {
  position: absolute;
  z-index: 5;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,240,180,1), rgba(255,146,39,0.90) 55%, rgba(255,140,35,0) 72%);
  box-shadow: 0 0 10px rgba(255,160,60,0.60);
  opacity: 0.85;
}
.ember-a { left: 58%; top: 18%; animation: emberFloatA 3.2s linear infinite; }
.ember-b { left: 36%; top: 24%; animation: emberFloatB 4.0s linear infinite 0.6s; }
.ember-c { left: 62%; top: 32%; animation: emberFloatC 2.8s linear infinite 1.1s; }
.ember-d { left: 44%; top: 40%; animation: emberFloatD 3.6s linear infinite 0.3s; }

/* Idle dance */
@keyframes flameA {
  0%   { transform: scaleX(0.88) scaleY(0.94) translateY(5px)   rotate(-2deg); opacity: 0.85; }
  35%  { transform: scaleX(1.06) scaleY(1.08) translateY(-5px)  rotate(1.5deg); opacity: 1; }
  70%  { transform: scaleX(0.94) scaleY(1.14) translateY(-9px)  rotate(-1deg); opacity: 0.95; }
  100% { transform: scaleX(1.02) scaleY(1.18) translateY(-12px) rotate(2deg);  opacity: 0.98; }
}
@keyframes flameB {
  0%   { transform: scaleX(0.85) scaleY(0.90) translateY(4px)  rotate(5deg);  opacity: 0.65; }
  50%  { transform: scaleX(1.08) scaleY(1.10) translateY(-7px) rotate(-2deg); opacity: 0.88; }
  100% { transform: scaleX(0.92) scaleY(1.14) translateY(-9px) rotate(4deg);  opacity: 0.80; }
}
@keyframes flameC {
  0%   { transform: scaleX(0.87) scaleY(0.91) translateY(3px)   rotate(-5deg); opacity: 0.68; }
  40%  { transform: scaleX(1.05) scaleY(1.08) translateY(-6px)  rotate(2deg);  opacity: 0.90; }
  100% { transform: scaleX(0.93) scaleY(1.15) translateY(-10px) rotate(-3deg); opacity: 0.84; }
}

/* Tap flare */
.hero-wedge-wrap.flame--flare .flame-a { animation: flareA 520ms cubic-bezier(.2,.8,.3,1) forwards; }
.hero-wedge-wrap.flame--flare .flame-b { animation: flareB 480ms cubic-bezier(.2,.8,.3,1) forwards; }
.hero-wedge-wrap.flame--flare .flame-c { animation: flareC 500ms cubic-bezier(.2,.8,.3,1) forwards; }

@keyframes flareA {
  0%   { transform: scaleX(1) scaleY(1) translateY(0);
         filter: blur(0.8px) drop-shadow(0 0 14px rgba(255,110,15,0.90)) drop-shadow(0 0 30px rgba(255,160,40,0.55)); }
  20%  { transform: scaleX(1.14) scaleY(1.30) translateY(-16px);
         filter: blur(0.3px) drop-shadow(0 0 24px rgba(255,220,80,1)) drop-shadow(0 0 44px rgba(255,140,20,0.65)); }
  100% { transform: scaleX(0.88) scaleY(0.94) translateY(5px);
         filter: blur(0.8px) drop-shadow(0 0 14px rgba(255,110,15,0.90)) drop-shadow(0 0 30px rgba(255,160,40,0.55)); }
}
@keyframes flareB {
  0%   { transform: scaleX(1) scaleY(1) translateY(0) rotate(5deg); }
  22%  { transform: scaleX(1.16) scaleY(1.26) translateY(-12px) rotate(-2deg);
         filter: drop-shadow(0 0 16px rgba(255,210,70,0.9)); }
  100% { transform: scaleX(0.85) scaleY(0.90) translateY(4px) rotate(5deg); }
}
@keyframes flareC {
  0%   { transform: scaleX(1) scaleY(1) translateY(0) rotate(-5deg); }
  20%  { transform: scaleX(1.14) scaleY(1.28) translateY(-13px) rotate(2deg);
         filter: drop-shadow(0 0 16px rgba(255,210,70,0.9)); }
  100% { transform: scaleX(0.87) scaleY(0.91) translateY(3px) rotate(-5deg); }
}

@keyframes auraPulse {
  0%   { transform: scale(0.94); opacity: 0.72; }
  100% { transform: scale(1.09); opacity: 1; }
}
@keyframes emberFloatA {
  0%   { transform: translate(0,0) scale(0.9);  opacity: 0; }
  10%  { opacity: 0.90; }
  100% { transform: translate(12px,-36px) scale(0.6); opacity: 0; }
}
@keyframes emberFloatB {
  0%   { transform: translate(0,0) scale(0.8);  opacity: 0; }
  12%  { opacity: 0.80; }
  100% { transform: translate(-14px,-28px) scale(0.5); opacity: 0; }
}
@keyframes emberFloatC {
  0%   { transform: translate(0,0) scale(0.9);  opacity: 0; }
  10%  { opacity: 0.85; }
  100% { transform: translate(8px,-32px) scale(0.55); opacity: 0; }
}
@keyframes emberFloatD {
  0%   { transform: translate(0,0) scale(0.8);  opacity: 0; }
  15%  { opacity: 0.75; }
  100% { transform: translate(-10px,-30px) scale(0.5); opacity: 0; }
}

@keyframes auraPulse {
  0%   { transform: scale(0.94); opacity: 0.72; }
  100% { transform: scale(1.09); opacity: 1; }
}
@keyframes emberFloatA {
  0%   { transform: translate(0,0) scale(0.9);  opacity: 0; }
  10%  { opacity: 0.90; }
  100% { transform: translate(12px,-36px) scale(0.6); opacity: 0; }
}
@keyframes emberFloatB {
  0%   { transform: translate(0,0) scale(0.8);  opacity: 0; }
  12%  { opacity: 0.80; }
  100% { transform: translate(-14px,-28px) scale(0.5); opacity: 0; }
}
@keyframes emberFloatC {
  0%   { transform: translate(0,0) scale(0.9);  opacity: 0; }
  10%  { opacity: 0.85; }
  100% { transform: translate(8px,-32px) scale(0.55); opacity: 0; }
}
@keyframes emberFloatD {
  0%   { transform: translate(0,0) scale(0.8);  opacity: 0; }
  15%  { opacity: 0.75; }
  100% { transform: translate(-10px,-30px) scale(0.5); opacity: 0; }
}

/* ── Sections ── */
.section {
  width: min(100%, 860px);
  margin: 0 auto;
  padding: 36px 32px;
}

.section-heading {
  max-width: 760px;
  margin: 0 auto 24px;
  text-align: left;
}

/* Duplicate gradient used on .section-heading h2 — consolidated into .section-kicker above */

/* ── Content boxes (about, pillars, contact) ── */
.about-card,
.pillar,
.contact-item {
  position: relative;
  overflow: hidden;
  background: transparent;
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: var(--radius);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.18),
    inset 0 0 0 1px rgba(255,255,255,0.04),
    0 8px 28px rgba(0,0,0,0.22);
}

/* Rainbow shimmer — fixed to always fill the full box */
.about-card::before,
.pillar::before,
.contact-item::before {
  content: "";
  position: absolute;
  /* Extend slightly beyond box edges so the pulsing scale never reveals a gap */
  inset: -10%;
  pointer-events: none;
  background: linear-gradient(
    var(--iridescence-angle, 118deg),
    rgba(255, 120, 160, 0.00) 0%,
    rgba(255, 180, 100, 0.09) 16%,
    rgba(100, 240, 180, 0.10) 33%,
    rgba(100, 190, 255, 0.11) 50%,
    rgba(180, 130, 255, 0.10) 67%,
    rgba(255, 120, 220, 0.09) 84%,
    rgba(255, 120, 160, 0.00) 100%);
  background-size: 220% 220%;
  background-position: 0% 50%;
  opacity: 0.92;
  animation: boxIridescence var(--iridescence-speed, 11.5s) ease-in-out infinite alternate;
}

.about-card {
  --iridescence-angle: 112deg;
  --iridescence-speed: 14s;
  margin: 0;
  padding: 18px 24px;
  color: var(--muted);
  line-height: 1.6;
}
.about-card p { margin: 0; }

.pillar:nth-child(1) { --iridescence-angle: 102deg; --iridescence-speed: 9.2s; }
.pillar:nth-child(2) { --iridescence-angle: 131deg; --iridescence-speed: 12.4s; }
.pillar:nth-child(3) { --iridescence-angle: 118deg; --iridescence-speed: 10.6s; }

.contact-item:nth-child(1) { --iridescence-angle: 120deg; --iridescence-speed: 13.2s; }
.contact-item:nth-child(2) { --iridescence-angle: 96deg;  --iridescence-speed: 10.1s; }
.contact-item:nth-child(3) { --iridescence-angle: 138deg; --iridescence-speed: 11.7s; }

@keyframes boxIridescence {
  0% {
    opacity: 0.60;
    background-position: 0% 30%;
    filter: saturate(0.95) brightness(0.94) hue-rotate(-8deg);
  }
  50% {
    opacity: 0.88;
    background-position: 50% 50%;
    filter: saturate(1.08) brightness(1.02) hue-rotate(4deg);
  }
  100% {
    opacity: 1;
    background-position: 100% 70%;
    filter: saturate(1.14) brightness(1.06) hue-rotate(10deg);
  }
}

/* ── Pillars grid — with gaps between boxes ── */
.pillars {
  margin-top: 20px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
.pillar {
  padding: 20px 22px;
}
.pillar h3 {
  margin: 0 0 8px;
  font-size: 1.05rem;
}
.pillar p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.6;
}

/* ── Contact grid ── */
.contact-grid {
  margin-top: 20px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
.contact-item {
  padding: 16px 18px;
}
.label {
  display: block;
  margin-bottom: 10px;
  color: #ffd4ab;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.73rem;
}
.contact-item p,
.contact-item a {
  margin: 0;
  font-size: 1.02rem;
  color: var(--text);
}

.status {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.status-icon {
  width: 16px; height: 16px;
  object-fit: contain;
  transform: rotate(5deg);
  filter: drop-shadow(0 0 8px rgba(255, 140, 47, 0.45));
  animation: statusBlink 1.7s steps(2, end) infinite;
}
@keyframes statusBlink {
  0%, 65%, 100% { opacity: 1; }
  66%, 82%      { opacity: 0.35; }
}

.back-top {
  display: inline-block;
  margin-top: 28px;
  color: #ffca93;
}
.copyright {
  margin: 20px 0 0;
  color: rgba(247,240,232,0.58);
  font-size: 0.95rem;
}

/* ── Hero divider ── */
.hero-divider-wrap {
  width: min(calc(100% - 120px), 980px);
  margin: 6px auto 0;
  display: flex;
  justify-content: center;
  pointer-events: none;
}

.hero-divider {
  width: 100%;
  height: 14px;
  border-radius: 999px;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background: rgba(255,255,255,0.04);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.16),
    inset 0 -1px 0 rgba(255,255,255,0.06),
    0 0 22px rgba(255, 157, 57, 0.28),
    0 0 40px rgba(151, 226, 255, 0.22),
    0 0 60px rgba(240, 138, 255, 0.16);
  animation: dividerPulse 3s ease-in-out infinite alternate;
}

@keyframes dividerPulse {
  0%   { filter: hue-rotate(0deg)   brightness(0.90) saturate(1.2); }
  33%  { filter: hue-rotate(60deg)  brightness(0.96) saturate(1.3); }
  66%  { filter: hue-rotate(160deg) brightness(0.93) saturate(1.3); }
  100% { filter: hue-rotate(280deg) brightness(0.98) saturate(1.4); }
}

.hero-divider::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(90deg,
    #ffb56f, #ffd97e, #ff9bdd,
    #9de9ff, #8bffd1, #c6a6ff,
    #ffb77a, #9feeff, #ffb56f);
  background-size: 200% 100%;
  filter: saturate(1.1) brightness(0.88);
  opacity: 0.90;
  animation: dividerScroll 8s linear infinite;
}

.hero-divider::after {
  content: "";
  position: absolute;
  inset: -55% -16%;
  border-radius: inherit;
  background:
    linear-gradient(108deg,
      rgba(255,255,255,0.00) 10%,
      rgba(255,246,225,0.28) 28%,
      rgba(255,255,255,0.06) 40%,
      rgba(181,239,255,0.22) 52%,
      rgba(255,197,247,0.20) 62%,
      rgba(255,255,255,0.06) 72%,
      rgba(255,255,255,0.00) 88%);
  filter: blur(6px) saturate(160%);
  mix-blend-mode: screen;
  animation: dividerShimmer 1.8s ease-in-out infinite alternate;
}

@keyframes dividerScroll {
  0%   { background-position: 0% 0; }
  100% { background-position: -200% 0; }
}
@keyframes dividerShimmer {
  0%   { transform: translate3d(-12%,0,0) scaleY(1.1); opacity: 0.7; }
  100% { transform: translate3d(12%,0,0)  scaleY(1.4); opacity: 1; }
}

/* ── Juice splash ── */
.juice-splash {
  position: fixed;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 30;
}

.juice-drop {
  position: absolute;
  width: 88px;
  height: 116px;
  border-radius: 58% 42% 62% 38% / 42% 58% 42% 58%;
  background:
    radial-gradient(circle at 34% 28%, rgba(255,245,210,0.95) 0%, rgba(255,245,210,0.62) 12%, rgba(255,245,210,0.00) 28%),
    linear-gradient(180deg, rgba(255,198,92,0.98) 0%, rgba(255,141,34,0.98) 48%, rgba(247,92,18,0.96) 100%);
  box-shadow:
    0 0 22px rgba(255,138,54,0.28),
    inset 0 1px 0 rgba(255,255,255,0.35);
  filter: blur(0.2px);
  opacity: 0;
  transform: translate(-50%, -50%) scale(0.4) rotate(0deg);
  animation: juiceDropBurst 760ms cubic-bezier(.18,.82,.22,1) forwards;
}

.juice-drop::after {
  content: "";
  position: absolute;
  inset: auto 28% -16% 28%;
  height: 34%;
  border-radius: 0 0 50% 50%;
  background: inherit;
  transform: rotate(12deg);
  opacity: 0.9;
}

@keyframes juiceDropBurst {
  0%   { opacity: 0;  transform: translate(-50%,-50%) scale(0.3) rotate(-6deg); }
  12%  { opacity: 1; }
  100% { opacity: 0;  transform: translate(var(--dx), var(--dy)) scale(1.12) rotate(var(--rot)); }
}

/* ── Tap counter ── */
.juice-tap-counter {
  position: fixed;
  z-index: 40;
  pointer-events: none;
  font-family: inherit;
  font-size: 1.05rem;
  font-weight: 700;
  color: #fff8ee;
  background: rgba(255, 130, 30, 0.88);
  border: 1px solid rgba(255,255,255,0.22);
  border-radius: 999px;
  padding: 5px 14px;
  transform: translate(-50%, -50%);
  box-shadow: 0 4px 18px rgba(255,110,20,0.38);
  opacity: 0;
  transition: opacity 300ms ease, transform 300ms ease;
}
.juice-tap-counter--show {
  opacity: 1;
  transform: translate(-50%, -60%);
}
.juice-tap-counter--hide {
  opacity: 0;
  transform: translate(-50%, -80%);
}

/* ── Responsive: medium ── */
@media (max-width: 900px) {
  .hero {
    min-height: auto;
    grid-template-columns: 1fr;
    padding-top: 26px;
  }
  .hero-card {
    justify-self: center;
    width: min(100%, 280px);
  }
  .pillars,
  .contact-grid {
    grid-template-columns: 1fr;
  }
  .hero-divider-wrap {
    width: min(calc(100% - 44px), 980px);
    margin: 10px auto 36px;
  }
  .hero-divider { height: 12px; }
}

/* ── Responsive: small ── */
@media (max-width: 640px) {
  .hero h1{
    max-width: 8.2ch;
    line-height: 1.10;
  }

  .section + .section { margin-top: 18px; }

  .site-header { padding: 8px 12px 0; }
  .nav {
    width: calc(100% - 24px);
    margin: 0 auto;
    padding: 8px 14px;
    gap: 4px;
    border-radius: 18px;
    align-items: flex-start;
    flex-direction: column;
    clip-path: inset(0 round 18px);
    -webkit-clip-path: inset(0 round 18px);
  }
  .nav-links { gap: 22px; flex-wrap: wrap; }
  .brand-text { font-size: 0.98rem; }
  .brand-wedge { width: 22px; height: 22px; }

  .hero,
  .section { padding-inline: 18px; }
  .hero { padding-top: 28px; padding-bottom: 22px; }

  /* ── Bigger hero title on mobile ── */
  .hero h1 {
    font-size: clamp(52px, 13vw, 72px);
    margin-top: 18px;
  }

  .hero-card {
    width: min(100%, 260px);
    border-radius: 24px;
    overflow: visible;
  }
  .hero-wedge-wrap { inset: 3% 2% 1% 2%; }
  .hero-wedge { max-width: 345px; transform: rotate(9deg) translateY(22px); }

  .flame-a { width: 46px; height: 106px; left: calc(50% - 23px); top: 5%; }
  .flame-b { width: 30px; height: 68px;  left: calc(32% - 15px); top: 22%; }
  .flame-c { width: 34px; height: 76px;  left: calc(64% - 17px); top: 18%; }

  .hero-divider-wrap { width: calc(100% - 36px); margin: 6px auto 28px; }
  .hero-divider { height: 10px; }

  .pillars,
  .contact-grid { gap: 14px; }
}

/* ── Global squeeze counter (always visible) ── */
.juice-global-counter {
  position: fixed;
  bottom: 22px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 35;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 18px;
  border-radius: 999px;
  border: 1px solid rgba(255, 160, 60, 0.28);
  background: rgba(20, 12, 4, 0.72);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow:
    0 0 18px rgba(255, 120, 20, 0.18),
    inset 0 1px 0 rgba(255,255,255,0.10);
  pointer-events: none;
  white-space: nowrap;
}

.juice-global-counter__icon {
  font-size: 0.95rem;
  line-height: 1;
}

.juice-global-counter__text {
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  color: #ffd4a0;
}


/* ── Buttons — clean hover only, no shimmer/burn ── */
.button-primary:hover,
.button-primary:focus-visible {
  background: linear-gradient(180deg, #ffc57a, #ff973a 54%, #ff6f22 100%);
  box-shadow: 0 14px 32px rgba(255, 127, 41, 0.45);
  transform: translateY(-1px);
}

.button-secondary:hover,
.button-secondary:focus-visible {
  border-color: rgba(255,255,255,0.24);
  background: rgba(255,255,255,0.07);
  transform: translateY(-1px);
}

/* ── Every-5-taps screen flash ── */
.juice-flash {
  position: fixed;
  inset: 0;
  z-index: 50;
  pointer-events: none;
  opacity: 0;
}
.juice-flash--active {
  animation: juiceFlash 900ms ease-out forwards;
}
@keyframes juiceFlash {
  0%   { opacity: 0; background: radial-gradient(ellipse at 50% 50%, rgba(255,200,80,0.22) 0%, rgba(255,120,200,0.18) 30%, rgba(120,200,255,0.16) 60%, rgba(180,100,255,0.12) 100%); }
  8%   { opacity: 1; }
  35%  { opacity: 0.7; background: radial-gradient(ellipse at 50% 50%, rgba(255,240,120,0.28) 0%, rgba(255,140,220,0.22) 30%, rgba(100,220,255,0.20) 60%, rgba(200,120,255,0.16) 100%); }
  100% { opacity: 0; }
}

/* ── Global squeeze counter bounce ── */
.counter-bounce {
  animation: counterBounce 380ms cubic-bezier(.2,.9,.2,1);
}
@keyframes counterBounce {
  0%   { transform: translateX(-50%) scale(1); }
  40%  { transform: translateX(-50%) scale(1.10); }
  70%  { transform: translateX(-50%) scale(0.97); }
  100% { transform: translateX(-50%) scale(1); }
}
