/* GoalFX — visual language matched to alvarcreations.com (warm black + gold, Inter, sharp radii) */
:root {
  --bg: #100C08;
  --panel: #1a1410;
  --elevated: #221c16;
  --text: #f5f0eb;
  --muted: #a89f95;
  --faint: #8a827b;
  --accent: #c5a028;
  --accent-hover: #d9b53e;
  --accent-glow: rgba(201, 162, 39, 0.22);
  --border: rgba(255, 255, 255, 0.06);
  --border-hover: rgba(255, 255, 255, 0.12);
  --radius: 6px;
  --radius-sm: 4px;
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; background: var(--bg); color: var(--text);
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  line-height: 1.6; font-size: 16px;
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3 { line-height: 1.1; font-weight: 800; letter-spacing: -0.02em; }
a { color: inherit; }

/* Keyboard focus: one visible ring across all interactive elements */
a:focus-visible, button:focus-visible, input:focus-visible,
textarea:focus-visible, select:focus-visible, summary:focus-visible,
[tabindex]:focus-visible {
  outline: 2px solid var(--accent-hover); outline-offset: 3px;
  border-radius: 2px;
}

/* Header / footer chrome */
/* Sticky bar: the wrapper pins (its parent is the page body), the header gets the glass look */
#chrome-header { position: sticky; top: 0; z-index: 100; }
.site-header {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding: 1.1rem 2rem;
  border-bottom: 1px solid var(--border);
  background: rgba(16, 12, 8, 0.82);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
}
.site-footer {
  color: var(--muted); margin-top: 5rem;
  border-top: 1px solid var(--border); padding: 4rem 2rem 2rem;
  font-size: .9rem; background: #0c0906;
}
.site-footer a { color: var(--muted); text-decoration: none; transition: color .3s var(--ease); }
.site-footer a:hover { color: var(--accent-hover); }
.footer-main {
  max-width: 1180px; margin: 0 auto; display: grid; gap: 2.4rem;
  grid-template-columns: minmax(220px, 1.25fr) repeat(3, minmax(120px, .7fr)) minmax(240px, 1.25fr);
}
.footer-brand p, .footer-offer p {
  color: var(--muted); margin: 1rem 0 1.4rem; max-width: 18rem; line-height: 1.65;
}
.footer-logo {
  display: inline-flex; align-items: center; gap: .45rem; color: var(--text);
  text-decoration: none; font-size: 1.05rem; letter-spacing: .02em;
}
.footer-logo strong { color: var(--accent-hover); }
.footer-mark {
  display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px; border: 1px solid var(--accent-glow);
  color: var(--accent-hover); font-weight: 800; border-radius: 50%;
  box-shadow: 0 0 24px var(--accent-glow);
}
.footer-socials { display: flex; gap: .6rem; }
.footer-social {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border: 1px solid var(--border-hover);
  border-radius: 50%; color: var(--muted);
  transition: color .3s var(--ease), border-color .3s var(--ease), background .3s var(--ease), transform .3s var(--ease);
}
.footer-social:hover {
  color: var(--accent-hover); border-color: var(--accent-glow);
  background: rgba(217,181,62,.08); transform: translateY(-1px);
}
.footer-social svg { width: 15px; height: 15px; display: block; fill: currentColor; }
.footer-col h3, .footer-offer h3 {
  margin: 0 0 1.2rem; color: var(--text); font-size: .68rem;
  letter-spacing: .22em; text-transform: uppercase;
}
.footer-col { display: flex; flex-direction: column; gap: .9rem; }
.footer-col a { color: var(--faint); }
.footer-offer form { display: grid; gap: .75rem; }
.footer-offer input {
  width: 100%; min-height: 48px; background: var(--panel);
  border: 1px solid var(--border-hover); border-radius: var(--radius-sm);
  color: var(--text); font: inherit; padding: 0 1rem;
  outline: none; transition: border-color .3s var(--ease), box-shadow .3s var(--ease);
}
.footer-offer input:focus { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent-glow); }
.footer-offer .btn { width: 100%; min-height: 50px; padding: 0 1.2rem; }
.footer-bottom {
  max-width: 1180px; margin: 3.2rem auto 0; padding-top: 1.4rem;
  border-top: 1px solid var(--border);
  display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap;
  color: var(--faint); font-size: .78rem;
}
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
@media (max-width: 980px) {
  .footer-main { grid-template-columns: 1fr 1fr; }
  .footer-offer { grid-column: 1 / -1; max-width: 420px; }
}
@media (max-width: 620px) {
  .site-footer { padding: 3rem 1.4rem 1.6rem; }
  .footer-main { grid-template-columns: 1fr; gap: 2rem; }
  .footer-offer { max-width: none; }
}
.brand {
  font-weight: 800; letter-spacing: .14em; text-transform: uppercase;
  text-decoration: none; font-size: .95rem; color: var(--accent);
}
.nav a {
  margin-left: 1.6rem; text-decoration: none; color: var(--muted);
  font-size: .78rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 500;
  transition: color .3s var(--ease);
}
.nav a:hover { color: var(--text); }

/* Sale banner */
.sale-banner {
  display: flex; align-items: center; justify-content: center; gap: 1rem;
  background: linear-gradient(to right, #1e1800, #2a2104, #1e1800);
  color: var(--accent-hover); border-bottom: 1px solid var(--accent-glow);
  padding: .55rem 1rem; font-size: .75rem; letter-spacing: .16em;
  text-transform: uppercase; font-weight: 600;
}
.sale-timer { font-variant-numeric: tabular-nums; color: var(--text); }

/* Hero */
.hero {
  display: grid; gap: 3rem; align-items: center;
  grid-template-columns: 1fr; padding: 4.5rem 2rem 5rem;
  max-width: 1140px; margin: 0 auto;
}
@media (min-width: 820px) { .hero { grid-template-columns: 1fr 1.1fr; } }
.hero h1 {
  font-size: clamp(2.4rem, 6vw, 4rem); margin: 0 0 1rem;
  text-transform: uppercase; letter-spacing: -0.01em;
}
.hero-copy p { color: var(--muted); font-size: 1rem; max-width: 26rem; }
.hero-cta { display: flex; gap: .9rem; flex-wrap: wrap; margin-top: 2rem; }
.hero-copy .hero-proof {
  margin: 1rem 0 0; color: var(--accent-hover);
  font-size: .72rem; letter-spacing: .12em; text-transform: uppercase;
  font-weight: 700; max-width: 32rem;
}

/* Buttons — Alvar gold gradient sweep */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 14px 32px; border-radius: var(--radius-sm); border: 0;
  font-family: inherit; font-weight: 600; font-size: .78rem;
  letter-spacing: .14em; text-transform: uppercase;
  text-decoration: none; cursor: pointer;
}
.btn-buy, .btn-free {
  color: #100C08;
  background: linear-gradient(to right, #e8c84a, #f0d060 49.9%, #b8860b 50%, #d4af37, #c9a227);
  background-size: 210% 100%; background-repeat: no-repeat; background-position: 100% 0;
  transition: background-position .5s var(--ease), box-shadow .3s var(--ease);
  box-shadow: 0 0 0 1px #c9a22759, 0 8px 40px #c9a22733;
}
.btn-buy:hover, .btn-free:hover { background-position: 0 0; box-shadow: 0 0 0 1px #c9a227aa, 0 8px 48px #c9a22755; }
.btn-ghost {
  background: transparent; border: 1px solid var(--border-hover); color: var(--text);
  transition: border-color .3s var(--ease), color .3s var(--ease);
}
.btn-ghost:hover { border-color: var(--accent); color: var(--accent-hover); }
.btn-disabled { background: var(--elevated); color: var(--faint); cursor: not-allowed; border: 1px solid var(--border); }

/* Sections */
section { max-width: 1140px; margin: 0 auto; padding: 3.5rem 2rem; }
section > h2 {
  font-size: clamp(1.7rem, 4vw, 2.4rem); text-transform: uppercase;
  margin-top: 0;
}
.grid { display: grid; gap: 1.4rem; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); }

/* Cards */
.card {
  background: var(--panel); border-radius: var(--radius); overflow: hidden;
  padding-bottom: 1.2rem; border: 1px solid var(--border);
  transition: border-color .3s var(--ease), transform .3s var(--ease), box-shadow .3s var(--ease);
}
.card:hover { border-color: var(--border-hover); transform: translateY(-3px); box-shadow: 0 18px 50px rgba(0,0,0,.5), 0 0 0 1px var(--accent-glow); }
.card-media { aspect-ratio: 16 / 9; }
.card-title { margin: 1rem 1.2rem .15rem; font-size: 1rem; font-weight: 700; }
.card-type { margin: 0 1.2rem; color: var(--accent); text-transform: uppercase; font-size: .65rem; letter-spacing: .18em; font-weight: 600; }
.card-price { margin: .4rem 1.2rem .9rem; font-weight: 800; font-size: 1.05rem; }
.card .btn { margin: 0 1.2rem; padding: 11px 22px; font-size: .72rem; }

/* Before/after slider (mechanics unchanged) */
.ba {
  position: relative; width: 100%; height: 100%; overflow: hidden;
  touch-action: none; user-select: none; background: #000;
}
.ba-hero { aspect-ratio: 16 / 9; border-radius: var(--radius); border: 1px solid var(--border); box-shadow: 0 30px 80px rgba(0,0,0,.6), 0 0 60px var(--accent-glow); }
.ba-img { position: absolute; inset: 0; }
.ba-img img, .ba-img picture { width: 100%; height: 100%; object-fit: cover; display: block; }
.ba-hero .ba-img img { object-position: 50% 18%; }
.ba-after { clip-path: inset(0 0 0 calc(var(--pos, 50) * 1%)); }
.ba-handle {
  position: absolute; top: 0; bottom: 0; width: 2px; background: var(--accent-hover);
  left: calc(var(--pos, 50) * 1%); transform: translateX(-1px); pointer-events: none;
  box-shadow: 0 0 14px var(--accent-glow);
}
.ba-handle::after {
  content: ""; position: absolute; top: 50%; left: 50%;
  width: 34px; height: 34px; transform: translate(-50%, -50%);
  border-radius: 50%; background: var(--accent-hover); box-shadow: 0 0 0 2px rgba(0,0,0,.35), 0 0 22px var(--accent-glow);
}
.ba-range {
  position: absolute; inset: 0; width: 100%; height: 100%; margin: 0;
  opacity: 0; cursor: ew-resize;
}

/* Video slots */
.video-slot { aspect-ratio: 16 / 9; background: #000; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--border); }
.video-slot iframe { width: 100%; height: 100%; border: 0; display: block; }
.video-placeholder {
  display: flex; align-items: center; justify-content: center;
  color: var(--faint); font-size: .8rem; letter-spacing: .14em; text-transform: uppercase;
  background: repeating-linear-gradient(45deg, #16110d, #16110d 14px, #1a1410 14px, #1a1410 28px);
}

/* Featured pack */
.featured-pack {
  display: grid; gap: 1.6rem; background: var(--panel);
  border: 1px solid var(--border); border-radius: var(--radius); padding: 1.6rem;
  transition: border-color .3s var(--ease);
}
.featured-pack:hover { border-color: var(--accent-glow); }
@media (min-width: 820px) { .featured-pack { grid-template-columns: 1.2fr 1fr; align-items: center; } }
.featured-info h3 { font-size: 1.35rem; margin: 0 0 .4rem; text-transform: uppercase; }
.featured-desc { color: var(--muted); }
.featured-info .card-price { margin-left: 0; }
.featured-info .btn { margin-top: .6rem; }

/* Shop filter */
.filter-bar { display: flex; gap: .6rem; flex-wrap: wrap; margin: 1.2rem 0 2rem; }
.filter-bar button {
  background: transparent; border: 1px solid var(--border-hover); color: var(--muted);
  font-family: inherit; font-size: .68rem; letter-spacing: .16em; text-transform: uppercase;
  font-weight: 600; padding: .5rem 1.1rem; border-radius: var(--radius-sm); cursor: pointer;
  transition: all .3s var(--ease);
}
.filter-bar button:hover { color: var(--text); border-color: var(--accent); }
.filter-bar button[aria-pressed="true"] {
  background: linear-gradient(to right, #d4af37, #c9a227); color: #100C08; border-color: transparent;
  box-shadow: 0 0 0 1px #c9a22759, 0 4px 24px #c9a22733;
}

/* Gallery */
.gallery-item {
  margin: 0; background: var(--panel); border-radius: var(--radius);
  overflow: hidden; border: 1px solid var(--border);
  transition: border-color .3s var(--ease);
}
.gallery-item:hover { border-color: var(--border-hover); }
.gallery-item figcaption { padding: .7rem 1.2rem; color: var(--muted); font-size: .8rem; letter-spacing: .04em; }

/* Reviews */
.review-card {
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 1.4rem;
}
.review-card footer { color: var(--accent); margin-top: .6rem; font-size: .8rem; letter-spacing: .08em; }

/* Join early / CTA */
.join-early { text-align: center; padding: 5rem 2rem; }
.join-early h2 { font-size: clamp(1.9rem, 5vw, 2.8rem); text-transform: uppercase; }
.join-early p { color: var(--muted); max-width: 32rem; margin: 0 auto 1.6rem; }

/* Creator proof / about */
.creator-proof {
  display: grid; gap: 2rem; align-items: center;
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
}
@media (min-width: 900px) { .creator-proof { grid-template-columns: .95fr 1.05fr; } }
.eyebrow {
  color: var(--accent); font-size: .72rem; letter-spacing: .2em;
  text-transform: uppercase; font-weight: 800; margin: 0 0 .8rem;
}
.creator-copy h2 {
  font-size: clamp(1.9rem, 4vw, 3rem); text-transform: uppercase;
  margin: 0 0 1rem;
}
.creator-copy p { color: var(--muted); max-width: 34rem; }
.creator-copy ul {
  list-style: none; padding: 0; margin: 1.4rem 0 0; display: grid; gap: .7rem;
}
.creator-copy li {
  position: relative; padding-left: 1.35rem; color: var(--text);
  font-weight: 500;
}
.creator-copy li::before {
  content: ""; position: absolute; left: 0; top: .68em;
  width: 6px; height: 6px; border-radius: 50%; background: var(--accent);
  box-shadow: 0 0 18px var(--accent-glow);
}
.stat-grid { display: grid; gap: .9rem; grid-template-columns: 1fr; }
@media (min-width: 560px) { .stat-grid { grid-template-columns: repeat(2, 1fr); } }
.stat-card {
  position: relative; overflow: hidden;
  min-height: 154px; display: flex; flex-direction: column; justify-content: space-between;
  background:
    radial-gradient(circle at 82% 12%, rgba(217,181,62,.13), transparent 32%),
    linear-gradient(135deg, rgba(255,255,255,.09), rgba(255,255,255,0) 34%),
    linear-gradient(180deg, var(--elevated), var(--panel));
  border: 1px solid var(--border); border-radius: var(--radius);
  padding: 1.25rem; box-shadow: 0 18px 55px rgba(0,0,0,.35);
  opacity: 0; transform: translateY(18px) scale(.985);
  transition:
    opacity .85s var(--ease),
    border-color .35s var(--ease),
    transform .85s var(--ease),
    box-shadow .35s var(--ease);
  transition-delay: calc(var(--stat-index, 0) * 90ms);
}
.stat-card::before {
  content: ""; position: absolute; inset: -1px; pointer-events: none;
  background: linear-gradient(120deg, transparent 0%, rgba(217,181,62,.16) 45%, transparent 70%);
  transform: translateX(-120%); opacity: 0;
}
.stat-card::after {
  content: ""; position: absolute; inset: auto 1.15rem 1.05rem 1.15rem; height: 1px;
  background: linear-gradient(to right, transparent, rgba(217,181,62,.42), transparent);
  opacity: .45;
}
.creator-proof.is-visible .stat-card {
  opacity: 1; transform: translateY(0) scale(1);
}
.stat-card:hover {
  transform: translateY(-3px);
  border-color: var(--accent-glow);
  box-shadow: 0 22px 65px rgba(0,0,0,.48), 0 0 34px var(--accent-glow);
}
.stat-card:hover::before { opacity: 1; animation: stat-sheen 1.15s var(--ease); }
.stat-card.is-complete-sweep::before {
  opacity: 1;
  animation: stat-complete-sheen 1.05s var(--ease) both;
}
@keyframes stat-sheen { to { transform: translateX(120%); } }
@keyframes stat-complete-sheen {
  0% { transform: translateX(-125%); opacity: 0; }
  18% { opacity: .9; }
  100% { transform: translateX(125%); opacity: 0; }
}
.stat-top {
  position: relative; z-index: 1;
  display: flex; justify-content: space-between; align-items: center; gap: .75rem;
  color: var(--muted); font-size: .68rem; letter-spacing: .16em;
  text-transform: uppercase; font-weight: 700;
}
.stat-live {
  color: #101010; background: var(--accent-hover); border-radius: 999px;
  padding: .18rem .5rem; font-size: .58rem; letter-spacing: .12em;
}
.stat-card strong {
  position: relative; z-index: 1;
  display: block; width: 100%; margin: .9rem 0 .35rem;
  font-size: clamp(2rem, 5vw, 3.15rem);
  line-height: .95; color: #d8b85d; letter-spacing: 0;
  white-space: nowrap; font-variant-numeric: tabular-nums;
  text-shadow: 0 0 30px rgba(217,181,62,.2);
  filter: blur(var(--digit-blur, 0));
  transition: color 1100ms var(--ease), text-shadow 1100ms var(--ease), transform 900ms var(--ease), filter 320ms var(--ease);
}
.stat-card strong.is-counting {
  color: #d9b53e;
  text-shadow: 0 0 16px rgba(217,181,62,.32), 0 0 38px rgba(217,181,62,.13);
}
.stat-card strong.is-blurring::after {
  content: attr(data-ghost);
  position: absolute; left: 0; top: 0; width: 100%;
  color: rgba(217,181,62,.26); pointer-events: none;
  transform: translateY(.1em); filter: blur(3.4px);
  opacity: .72; transition: opacity 420ms var(--ease), filter 420ms var(--ease);
}
.stat-card strong.is-settling {
  transform: none;
  color: #dfc464;
  text-shadow: 0 0 18px rgba(217,181,62,.28), 0 0 42px rgba(217,181,62,.12);
  animation: stat-value-settle 1200ms var(--ease) both;
}
.stat-card strong.has-counted {
  color: #d5b96f;
  text-shadow: 0 0 13px rgba(217,181,62,.14);
}
@keyframes stat-value-settle {
  0% { color: #d9b53e; text-shadow: 0 0 20px rgba(217,181,62,.3), 0 0 48px rgba(217,181,62,.14); }
  48% { color: #e2c765; text-shadow: 0 0 24px rgba(217,181,62,.34), 0 0 54px rgba(217,181,62,.15); }
  100% { color: #d5b96f; text-shadow: 0 0 13px rgba(217,181,62,.14); }
}
.stat-card p { position: relative; z-index: 1; color: var(--faint); margin: 0; font-size: .78rem; }
.stat-card.is-live { border-color: var(--accent-glow); box-shadow: 0 18px 55px rgba(0,0,0,.35), 0 0 34px var(--accent-glow); }
.stat-card[data-stat-key="revenue"] strong {
  font-size: clamp(1.65rem, 3.8vw, 2.45rem);
  letter-spacing: -.01em;
}
.stat-card[data-stat-key="subscribers"] strong {
  font-size: clamp(1.85rem, 4.3vw, 2.8rem);
}
/* Views shows the full live number (9 digits) — keep it from overflowing */
.stat-card[data-stat-key="views"] strong {
  font-size: clamp(1.5rem, 3.4vw, 2.3rem);
  letter-spacing: -.01em;
}
@media (max-width: 420px) {
  .stat-card { padding: 1.1rem; }
  .stat-card[data-stat-key="revenue"] strong { font-size: clamp(1.55rem, 8vw, 2rem); }
  .stat-card[data-stat-key="subscribers"] strong { font-size: clamp(1.65rem, 8.5vw, 2.2rem); }
  .stat-card[data-stat-key="views"] strong { font-size: clamp(1.2rem, 6vw, 1.7rem); }
}

/* FAQ */
.faq details {
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius);
  padding: .9rem 1.2rem; margin-bottom: .7rem;
  transition: border-color .3s var(--ease);
}
.faq details:hover, .faq details[open] { border-color: var(--border-hover); }
.faq summary { cursor: pointer; font-weight: 600; font-size: .92rem; }
.faq details p { color: var(--muted); }
.contact {
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 1.4rem 1.6rem;
}
.contact a { color: var(--accent-hover); }

/* Portrait frames (e.g. the Ronaldo pair) keep the face in view inside 16:9 crops */
.card-media .ba-img img { object-position: 50% 18%; }

/* Looping preview video in card media */
.loop-video { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ---- One-page: video before/after, big looks, single pack ---- */
.ba-media { width: 100%; height: 100%; object-fit: cover; display: block; }
.ba-video { background: #000; }

.section-lead { color: var(--muted); max-width: 40rem; margin: -0.5rem 0 2rem; }

/* Big, easy-to-read look comparisons */
.cc-looks { display: grid; gap: 2rem; grid-template-columns: 1fr; }
@media (min-width: 940px) { .cc-looks { grid-template-columns: repeat(2, 1fr); gap: 2.4rem; } }
.cc-look { display: flex; flex-direction: column; gap: .7rem; }
.cc-look-name {
  margin: 0; font-size: .8rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--accent); font-weight: 700;
}
.cc-look .ba {
  aspect-ratio: 16 / 9; border-radius: var(--radius); overflow: hidden;
  border: 1px solid var(--border); box-shadow: 0 16px 50px rgba(0,0,0,.5);
}
.cc-look:hover .ba { border-color: var(--accent-glow); }

/* Single pack block */
.pack-section { display: flex; justify-content: center; }
.pack-card {
  width: 100%; max-width: 640px; text-align: center;
  background: linear-gradient(180deg, var(--elevated), var(--panel));
  border: 1px solid var(--accent-glow); border-radius: var(--radius);
  padding: 2.6rem 2rem; box-shadow: 0 24px 70px rgba(0,0,0,.55), 0 0 60px var(--accent-glow);
}
.pack-card h2 { margin: 0 0 .6rem; font-size: clamp(1.8rem, 4vw, 2.6rem); text-transform: uppercase; }
.pack-desc { color: var(--muted); max-width: 34rem; margin: 0 auto 1.4rem; }
.pack-price { font-size: 2rem; font-weight: 800; color: var(--accent-hover); margin: 0 0 1.4rem; }
.pack-card .btn { font-size: .85rem; padding: 16px 44px; }

/* ---- Product page (pack.html) ---- */
.pp {
  display: grid; gap: clamp(2rem, 5vw, 4rem); max-width: 1160px;
  margin: 0 auto; padding: clamp(3rem, 6vw, 5rem) 2rem 2.4rem;
}
@media (min-width: 940px) { .pp { grid-template-columns: minmax(0, 1.08fr) minmax(330px, .92fr); align-items: start; } }
.pp-gallery { min-width: 0; position: relative; isolation: isolate; }
.pp-gallery::before {
  content: ""; position: absolute; inset: -16% -14%;
  z-index: -1; pointer-events: none; opacity: .78;
  background:
    radial-gradient(circle at 58% 68%, rgba(217,181,62,.30), transparent 38%),
    radial-gradient(circle at 34% 18%, rgba(240,202,61,.20), transparent 34%);
  filter: blur(38px); transform: translate3d(0,0,0);
  animation: heroAmbientGold 8s ease-in-out infinite alternate;
}
.pp-cover {
  position: relative; margin: 0; overflow: hidden; border-radius: var(--radius);
  padding: 1px; border: 0;
  background: linear-gradient(115deg,
    rgba(217,181,62,.28),
    rgba(255,232,154,.90),
    rgba(217,181,62,.18),
    rgba(240,202,61,.74),
    rgba(217,181,62,.26));
  background-size: 260% 260%;
  box-shadow: 0 34px 100px rgba(0,0,0,.68), 0 0 92px rgba(217,181,62,.22);
  isolation: isolate;
  animation: heroBorderSweep 5.8s ease-in-out infinite;
}
.pp-cover::before {
  content: ""; position: absolute; inset: -1px; z-index: -1; pointer-events: none;
  border-radius: inherit;
  background: inherit;
  background-size: inherit;
  filter: blur(.2px);
}
.pp-cover::after {
  content: ""; position: absolute; inset: 1px; z-index: 2; pointer-events: none;
  border-radius: calc(var(--radius) - 1px);
  box-shadow: inset 0 0 0 1px rgba(255,238,162,.22);
}
.pp-cover img {
  display: block; width: 100%; aspect-ratio: 1 / 1; object-fit: cover;
  border-radius: calc(var(--radius) - 1px);
}
.pp-info {
  padding: clamp(1.4rem, 3vw, 2rem); border: 1px solid rgba(217,181,62,.13);
  border-radius: var(--radius); background: linear-gradient(180deg, rgba(26,20,16,.82), rgba(16,12,8,.56));
  box-shadow: 0 20px 70px rgba(0,0,0,.34);
}
.pp-thumbs { display: flex; gap: .5rem; flex-wrap: wrap; margin-top: .9rem; }
.pp-thumb {
  background: transparent; border: 1px solid var(--border-hover); color: var(--muted);
  font-family: inherit; font-size: .68rem; letter-spacing: .14em; text-transform: uppercase;
  font-weight: 600; padding: .5rem 1rem; border-radius: var(--radius-sm); cursor: pointer;
  transition: all .3s var(--ease);
}
.pp-thumb:hover { color: var(--text); border-color: var(--accent); }
.pp-thumb[aria-pressed="true"] {
  background: linear-gradient(to right, #d4af37, #c9a227); color: #100C08; border-color: transparent;
  box-shadow: 0 0 0 1px #c9a22759, 0 4px 24px #c9a22733;
}
.pp-title { margin: 0 0 .4rem; font-size: clamp(1.8rem, 4vw, 2.6rem); text-transform: uppercase; }
.pp-rating {
  display: inline-flex; align-items: center; gap: .5rem; width: fit-content;
  margin: .2rem 0 .8rem; padding: .42rem .62rem;
  border: 1px solid rgba(217,181,62,.18); border-radius: 999px;
  background: rgba(217,181,62,.055); color: var(--text); text-decoration: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 10px 28px rgba(0,0,0,.18);
  transition: border-color .25s var(--ease), background .25s var(--ease), transform .25s var(--ease);
}
.pp-rating:hover {
  transform: translateY(-1px); border-color: rgba(217,181,62,.34); background: rgba(217,181,62,.085);
}
.pp-rating-score {
  color: var(--accent-hover); font-weight: 900; font-size: .92rem; letter-spacing: 0;
  font-variant-numeric: tabular-nums;
}
.pp-rating-stars {
  display: inline-flex; align-items: center; gap: .08rem;
  line-height: 1; font-size: .9rem; letter-spacing: 0;
}
.pp-rating-star {
  position: relative; display: inline-block; color: rgba(245,240,235,.18);
}
.pp-rating-star::before {
  content: "★"; position: absolute; inset: 0; width: calc(var(--fill) * 100%);
  overflow: hidden; color: var(--accent-hover);
  text-shadow: 0 0 12px rgba(217,181,62,.38);
}
.pp-rating-count {
  color: var(--muted); font-size: .72rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase;
}
.pp-rating-empty .pp-rating-score {
  padding: .16rem .42rem; border-radius: 999px;
  background: rgba(217,181,62,.12); font-size: .72rem; letter-spacing: .12em;
  text-transform: uppercase;
}
.pp-price { font-size: 1.9rem; font-weight: 800; color: var(--accent-hover); margin: 0 0 1rem; }
.pp-desc { color: var(--muted); margin: 0 0 1.2rem; }
.pp-included { list-style: none; padding: 0; margin: 0 0 1.6rem; display: grid; gap: .45rem; }
.pp-included li { padding-left: 1.4rem; position: relative; color: var(--text); }
.pp-included li::before { content: "✓"; position: absolute; left: 0; color: var(--accent); font-weight: 700; }
.pp-more { margin: -0.6rem 0 1.3rem; }
.pp-more a {
  color: var(--accent-hover); font-size: .82rem; font-weight: 800;
  letter-spacing: .08em; text-transform: uppercase; text-decoration: none;
}
.pp-more a:hover { color: var(--accent); text-decoration: underline; text-underline-offset: 4px; }
.pp-buy .btn { font-size: .85rem; padding: 16px 44px; width: 100%; }
.pp-note { color: var(--faint); font-size: .8rem; margin-top: .8rem; text-align: center; }
.pp-preview {
  max-width: 1140px; margin: 0 auto; padding: 3rem 2rem;
}
.home-cc-preview { padding-top: 1rem; max-width: 820px; }
.home-cc-preview .pp-preview-shell {
  box-shadow: 0 26px 90px rgba(0,0,0,.48), 0 0 70px rgba(217,181,62,.1);
}
.pp-preview-shell {
  position: relative; overflow: hidden; border: 1px solid rgba(217,181,62,.14);
  border-radius: var(--radius); padding: clamp(1rem, 2.6vw, 1.6rem);
  background:
    radial-gradient(circle at 72% 0%, rgba(217,181,62,.13), transparent 36%),
    linear-gradient(180deg, rgba(26,20,16,.76), rgba(12,9,6,.86));
  box-shadow: 0 22px 80px rgba(0,0,0,.44);
}
.pp-preview-head {
  display: grid; gap: .35rem; margin-bottom: 1rem;
}
.pp-preview-head h2 {
  margin: 0; text-transform: uppercase; font-size: clamp(1.8rem, 4vw, 3rem);
}
.pp-preview-head p:not(.eyebrow) { margin: 0; max-width: 47rem; color: var(--muted); }
.pp-preview-main .ba {
  aspect-ratio: 16 / 9; border-radius: var(--radius); overflow: hidden;
  border: 1px solid var(--border); box-shadow: 0 24px 70px rgba(0,0,0,.55), 0 0 50px var(--accent-glow);
}
.pp-preview-tabs {
  margin-top: 1rem; padding-top: 1rem; border-top: 1px solid rgba(255,255,255,.06);
}
.pack-question {
  max-width: 760px; margin: 0 auto; padding: 3rem 2rem 4.6rem;
  text-align: center; position: relative;
}
.pack-question::before {
  content: ""; position: absolute; inset: 10% 14% 0; z-index: -1;
  background: radial-gradient(circle at 50% 35%, rgba(217,181,62,.13), transparent 58%);
  filter: blur(22px); pointer-events: none;
}
.pack-question-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 48px; height: 48px; margin-bottom: 1rem; border-radius: 50%;
  border: 1px solid rgba(217,181,62,.42);
  background: linear-gradient(180deg, rgba(217,181,62,.16), rgba(26,20,16,.72));
  color: var(--accent-hover); font-size: 1.35rem; font-weight: 900;
  box-shadow: 0 0 0 6px rgba(217,181,62,.06), 0 18px 54px rgba(0,0,0,.42);
}
.pack-question h2 {
  margin: .2rem 0 .7rem; text-transform: uppercase;
  font-size: clamp(1.8rem, 4vw, 2.7rem);
}
.pack-question p:not(.eyebrow) {
  color: var(--muted); max-width: 38rem; margin: 0 auto 1.5rem;
}
.pack-question .hero-cta { justify-content: center; margin-top: 0; }
.pp-details {
  max-width: 1140px; margin: 0 auto; padding: 3rem 2rem; text-align: center;
}
.pp-details > h2 {
  margin: .2rem 0 .5rem; text-transform: uppercase;
  font-size: clamp(2rem, 5vw, 3.4rem);
}
.pp-details .section-lead { margin-left: auto; margin-right: auto; }
.pp-detail-tabs { margin-top: 1.7rem; }
.pp-detail-tablist {
  display: flex; align-items: center; justify-content: center; flex-wrap: wrap;
  gap: .55rem; margin-bottom: 1.8rem;
}
.pp-detail-tab {
  display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
  min-width: 130px; height: 42px; padding: 0 1.15rem;
  border: 1px solid rgba(217,181,62,.26); border-radius: 4px;
  background: rgba(26,20,16,.68); color: var(--muted);
  font-family: inherit; font-size: .72rem; font-weight: 800; letter-spacing: .14em;
  text-transform: uppercase; cursor: pointer;
  transition: color .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease), transform .25s var(--ease);
}
.pp-detail-tab svg {
  width: 15px; height: 15px; fill: none; stroke: currentColor;
  stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round;
}
.pp-detail-tab:hover {
  color: var(--text); border-color: rgba(217,181,62,.48); transform: translateY(-1px);
}
.pp-detail-tab[aria-selected="true"] {
  color: #120d07; background: linear-gradient(180deg, #e0bd37, #c99d15);
  border-color: #f0ca3d; box-shadow: 0 0 0 1px rgba(240,202,61,.24), 0 12px 38px rgba(217,181,62,.24);
}
.pp-detail-stats {
  display: inline-grid; grid-template-columns: repeat(3, minmax(120px, 1fr));
  align-items: center; gap: 0; margin: 0 auto 1.65rem;
}
.pp-detail-stats div {
  padding: 0 1.8rem; border-right: 1px solid rgba(255,255,255,.08);
}
.pp-detail-stats div:last-child { border-right: 0; }
.pp-detail-stats strong {
  display: block; color: var(--accent-hover); font-size: clamp(1.8rem, 4vw, 2.6rem);
  line-height: 1; font-weight: 900; letter-spacing: 0; font-variant-numeric: tabular-nums;
}
.pp-detail-stats span {
  display: block; margin-top: .45rem; color: var(--faint);
  font-size: .66rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase;
}
.pp-detail-pills {
  display: flex; justify-content: center; flex-wrap: wrap; gap: .6rem; margin-bottom: 1.4rem;
}
.pp-detail-pills span {
  display: inline-flex; align-items: center; min-height: 30px; padding: .35rem .8rem;
  border: 1px solid rgba(217,181,62,.13); border-radius: 999px;
  background: rgba(26,20,16,.72); color: var(--muted);
  font-size: .72rem; box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
.pp-detail-panel-wrap {
  position: relative; overflow: hidden; text-align: left;
  border: 1px solid rgba(217,181,62,.16); border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(26,20,16,.9), rgba(15,11,8,.94));
  box-shadow: 0 26px 90px rgba(0,0,0,.46);
}
.pp-detail-panel-wrap::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(circle at 50% 0%, rgba(217,181,62,.1), transparent 42%);
}
.pp-detail-panel {
  position: relative; z-index: 1; padding: clamp(1.35rem, 3vw, 2rem);
  animation: ppPanelIn .34s var(--ease) both;
}
.pp-detail-panel[hidden] { display: none; }
.pp-detail-panel h3 {
  margin: 0 0 1.4rem; color: var(--text); font-size: 1.15rem; text-transform: none;
}
.pp-detail-panel p, .pp-detail-panel li, .pp-detail-panel dt {
  color: var(--muted);
}
.pp-detail-rows {
  display: grid; margin: 0; border-top: 1px solid rgba(255,255,255,.07);
}
.pp-detail-rows div {
  display: grid; grid-template-columns: minmax(110px, .34fr) minmax(0, 1fr);
  gap: 1rem; padding: 1rem 0; border-bottom: 1px solid rgba(255,255,255,.07);
}
.pp-detail-rows dt { font-size: .82rem; }
.pp-detail-rows dd {
  margin: 0; color: var(--text); text-align: right; font-weight: 700;
}
.pp-detail-list {
  margin: 0 0 1.2rem; padding-left: 1.1rem; display: grid; gap: .55rem;
}
.pp-detail-list li::marker { color: var(--accent); }
.file-tree {
  margin: 1.1rem 0 1.2rem; border: 1px solid rgba(217,181,62,.16);
  border-radius: 6px; background: rgba(12,9,6,.48);
  overflow: hidden; box-shadow: inset 0 1px 0 rgba(255,255,255,.025);
}
.file-tree-root {
  display: grid; grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center; gap: .7rem; padding: .78rem .9rem;
  border-bottom: 1px solid rgba(255,255,255,.07);
  background: rgba(255,255,255,.025);
}
.file-tree-root strong, .file-folder-title strong {
  color: var(--text); font-size: .84rem; letter-spacing: .01em;
}
.file-tree-root small, .file-folder-title small {
  color: var(--faint); font-size: .7rem; text-align: right;
}
.file-root-dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--accent-hover);
  box-shadow: 0 0 16px rgba(217,181,62,.34);
}
.file-tree-root-files,
.file-tree-folder ul {
  list-style: none; margin: 0; padding: .28rem 0 .62rem 2.4rem;
}
.file-tree-root-files { border-bottom: 1px solid rgba(255,255,255,.06); }
.file-tree-root-files li,
.file-tree-folder li {
  position: relative; padding: .22rem .95rem .22rem 1rem; color: var(--muted);
}
.file-tree-root-files li::before,
.file-tree-folder li::before {
  content: ""; position: absolute; left: 0; top: .68rem;
  width: 4px; height: 4px; border-radius: 50%; background: rgba(217,181,62,.46);
}
.file-tree code {
  color: var(--muted); font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: .75rem; white-space: normal; word-break: break-word;
}
.file-tree li[data-ext="ffx"] code { color: #d9bd55; }
.file-tree li[data-ext="aep"] code { color: #c9afff; }
.file-tree li[data-ext="mp3"] code,
.file-tree li[data-ext="wav"] code { color: #9fc7e6; }
.file-tree li[data-ext="mp4"] code,
.file-tree li[data-ext="mov"] code { color: #a9d9b2; }
.file-tree li[data-ext="more"] code { color: var(--faint); font-style: italic; }
.file-tree-folder { border-bottom: 1px solid rgba(255,255,255,.06); }
.file-tree-folder:last-child { border-bottom: 0; }
.file-tree-folder summary {
  display: grid; grid-template-columns: 20px minmax(0, 1fr) 18px;
  align-items: center; gap: .72rem; padding: .74rem .9rem;
  cursor: pointer; list-style: none; transition: background .2s var(--ease);
}
.file-tree-folder summary::-webkit-details-marker { display: none; }
.file-tree-folder summary:hover { background: rgba(217,181,62,.035); }
.file-folder-title {
  display: grid; grid-template-columns: minmax(0, 1fr) auto;
  align-items: baseline; gap: .85rem; min-width: 0;
}
.file-folder-title strong {
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.file-folder-icon {
  position: relative; width: 16px; height: 12px; border: 1px solid rgba(217,181,62,.58);
  border-radius: 3px; background: rgba(217,181,62,.055);
}
.file-folder-icon::before {
  content: ""; position: absolute; left: 1px; top: -5px;
  width: 8px; height: 5px; border: 1px solid rgba(217,181,62,.58);
  border-bottom: 0; border-radius: 3px 3px 0 0; background: rgba(217,181,62,.055);
}
.file-tree-chevron {
  justify-self: end; width: 7px; height: 7px;
  border-right: 1px solid var(--faint); border-bottom: 1px solid var(--faint);
  transform: rotate(-45deg); transition: transform .2s var(--ease), border-color .2s var(--ease);
}
.file-tree-folder[open] > summary .file-tree-chevron {
  transform: rotate(45deg); border-color: var(--accent-hover);
}
.pp-detail-action {
  display: grid; grid-template-columns: 28px minmax(0, 1fr) 18px;
  grid-template-areas: "icon title arrow" "icon copy arrow";
  align-items: center; gap: .15rem .8rem; margin-top: 1.2rem; padding: 1rem;
  border: 1px solid rgba(217,181,62,.14); border-radius: var(--radius-sm);
  background: rgba(255,255,255,.025); color: var(--text); text-decoration: none;
  transition: border-color .25s var(--ease), background .25s var(--ease), transform .25s var(--ease);
}
.pp-detail-action::after {
  content: ""; grid-area: arrow; justify-self: end;
  width: 15px; height: 15px; background: var(--muted);
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 17 17 7M9 7h8v8'/%3E%3C/svg%3E") center/contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 17 17 7M9 7h8v8'/%3E%3C/svg%3E") center/contain no-repeat;
  transition: background .25s var(--ease);
}
.pp-detail-action:hover::after { background: var(--accent-hover); }
.pp-detail-action:hover {
  transform: translateY(-1px); border-color: rgba(217,181,62,.34); background: rgba(217,181,62,.05);
}
.pp-detail-action span { grid-area: icon; color: var(--accent); }
.pp-detail-action svg {
  width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 1.8;
}
.pp-detail-action strong { grid-area: title; font-size: .9rem; }
.pp-detail-action small { grid-area: copy; color: var(--faint); font-size: .78rem; }
.pp-detail-action-static::after { content: ""; }
@keyframes ppPanelIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
@media (max-width: 680px) {
  .pp-detail-tab { flex: 1 1 100%; }
  .pp-detail-stats { display: grid; grid-template-columns: 1fr; width: 100%; gap: .8rem; }
  .pp-detail-stats div { border-right: 0; padding: .8rem 0; border-bottom: 1px solid rgba(255,255,255,.07); }
  .pp-detail-stats div:last-child { border-bottom: 0; }
  .pp-detail-rows div { grid-template-columns: 1fr; gap: .35rem; }
  .pp-detail-rows dd { text-align: left; }
  .file-tree-root { grid-template-columns: auto minmax(0, 1fr); }
  .file-tree-root small { grid-column: 2; text-align: left; }
  .file-folder-title { grid-template-columns: 1fr; gap: .12rem; }
  .file-folder-title small { text-align: left; }
}

/* ---- Pricing: compare-at + discount badge ---- */
.pp-compare { color: var(--faint); font-size: 1.15rem; font-weight: 600; margin-right: .35rem; }
.pp-now { color: var(--accent-hover); }
.pp-off {
  display: inline-block; vertical-align: middle; margin-left: .5rem;
  background: linear-gradient(to right, #d4af37, #c9a227); color: #100C08;
  font-size: .7rem; font-weight: 800; letter-spacing: .08em;
  padding: .25rem .55rem; border-radius: var(--radius-sm);
}
/* ---- Plugins chips ---- */
.pp-plugin-warning {
  display: grid; grid-template-columns: auto 1fr; gap: .8rem; align-items: start;
  margin: .9rem 0 1rem; padding: .9rem 1rem;
  border: 1px solid rgba(255,72,72,.38); border-radius: var(--radius-sm);
  background: linear-gradient(180deg, rgba(92,15,15,.34), rgba(36,10,10,.28));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 0 34px rgba(255,55,55,.08);
}
.pp-plugin-warning p { margin: 0; color: var(--text); font-size: .9rem; line-height: 1.55; }
.pp-plugin-warning strong { color: #ff7474; text-transform: uppercase; letter-spacing: .06em; font-size: .76rem; }
.pp-warning-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 50%;
  background: linear-gradient(180deg, #ff5151, #c92323); color: #fff;
  font-weight: 900; line-height: 1; box-shadow: 0 0 0 4px rgba(255,64,64,.1), 0 10px 26px rgba(201,35,35,.22);
}
.pp-requirement-list {
  display: grid; grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .7rem; list-style: none; padding: 0; margin: 0 0 1rem;
}
.pp-requirement-list li {
  display: grid; grid-template-columns: auto 1fr; gap: .7rem; align-items: center;
  padding: .8rem; border: 1px solid rgba(217,181,62,.16);
  border-radius: var(--radius-sm); background: rgba(26,20,16,.58);
}
.pp-req-icon {
  width: 24px; height: 24px; color: var(--accent-hover);
  fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round;
}
.pp-ae-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: 7px;
  border: 1px solid rgba(213,176,255,.74);
  background: linear-gradient(145deg, #1d1144, #2b145f 56%, #3a1b77);
  color: #d7b7ff; font-weight: 900; font-size: .9rem; letter-spacing: -.02em;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.15), 0 0 24px rgba(135,73,255,.22);
}
.pp-requirement-list strong {
  display: block; color: var(--text); font-size: .84rem; text-transform: uppercase; letter-spacing: .04em;
}
.pp-requirement-list small { display: block; margin-top: .12rem; color: var(--faint); font-size: .75rem; line-height: 1.35; }
.pp-plugin-intro { margin-top: 1rem; }
.plugin-chips { display: flex; gap: .5rem; flex-wrap: wrap; margin-top: .7rem; }
.plugin-chip {
  border: 1px solid var(--accent-glow); color: var(--accent-hover);
  font-size: .72rem; font-weight: 600; letter-spacing: .08em;
  padding: .35rem .8rem; border-radius: var(--radius-sm); background: var(--elevated);
}
@media (max-width: 680px) {
  .pp-requirement-list { grid-template-columns: 1fr; }
}

/* ---- How to use ---- */
.howto { max-width: 1140px; margin: 0 auto; }
.howto-grid { display: grid; gap: 1.4rem; grid-template-columns: 1fr; }
@media (min-width: 880px) { .howto-grid { grid-template-columns: repeat(2, 1fr); } }
.howto-step {
  display: grid; grid-template-columns: 1fr; gap: 1rem;
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 1.4rem; transition: border-color .3s var(--ease);
}
@media (min-width: 560px) { .howto-step { grid-template-columns: 1.1fr 1fr; align-items: center; } }
.howto-step:hover { border-color: var(--accent-glow); }
.howto-visual svg { width: 100%; height: auto; display: block; border-radius: var(--radius-sm); }
.howto-num { color: var(--accent); font-weight: 800; font-size: .8rem; letter-spacing: .2em; }
.howto-text h3 { margin: .3rem 0 .4rem; font-size: 1.05rem; text-transform: uppercase; }
.howto-text p { color: var(--muted); margin: 0; font-size: .9rem; }

/* ---- Reviews stars ---- */
.reviews .grid { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
.review-card .stars { color: var(--accent-hover); letter-spacing: .15em; margin: 0 0 .5rem; }
.review-card blockquote { margin: 0 0 .6rem; color: var(--text); font-size: .92rem; }
.review-card figcaption { color: var(--muted); font-size: .8rem; }

/* ---- Reviews page ---- */
.reviews-page { max-width: none; margin: 0; padding: 0 0 5rem; overflow-x: clip; }
.reviews-hero {
  position: relative; overflow: hidden; text-align: center;
  padding: clamp(4.5rem, 9vw, 7rem) 2rem clamp(3.4rem, 7vw, 5.4rem);
  border-bottom: 1px solid var(--border);
  background:
    radial-gradient(ellipse 70% 58% at 50% 36%, rgba(217,181,62,.18), transparent 70%),
    radial-gradient(ellipse 40% 46% at 72% 58%, rgba(217,181,62,.06), transparent 66%),
    #100c08;
}
.reviews-hero::after {
  content: ""; position: absolute; inset: 0; pointer-events: none; opacity: .04;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 128px;
}
.reviews-hero-inner { position: relative; z-index: 1; max-width: 820px; margin: 0 auto; }
.reviews-badge {
  display: inline-flex; align-items: center; justify-content: center;
  margin: 0 0 1.1rem; color: var(--accent-hover);
  font-size: .67rem; font-weight: 800; letter-spacing: .18em;
  text-transform: uppercase;
}
.reviews-hero h1 {
  margin: 0 0 1.2rem; color: var(--text); text-transform: uppercase;
  font-size: clamp(2.45rem, 7vw, 5.3rem); letter-spacing: -.015em;
}
.reviews-hero h1 span,
.reviews-section-head h2 span,
.reviews-modal-box h2 span {
  background: linear-gradient(135deg, #c5a028 0%, #f0d060 60%, #c9a227 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.reviews-hero p {
  color: var(--muted); max-width: 40rem; margin: 0 auto;
  font-size: clamp(1rem, 2vw, 1.14rem);
}
.reviews-hero-stats {
  display: inline-grid; grid-template-columns: 1fr auto 1fr; align-items: stretch;
  gap: 1.4rem; margin-top: 2.2rem; padding: 1.1rem 1.35rem;
  border: 1px solid rgba(217,181,62,.16); border-radius: var(--radius);
  background: rgba(26,20,16,.62); box-shadow: 0 18px 58px rgba(0,0,0,.36);
}
.reviews-hero-stat { min-width: 154px; text-align: center; }
.reviews-hero-stat strong {
  display: flex; align-items: center; justify-content: center; gap: .35rem;
  color: var(--accent-hover); font-size: clamp(1.6rem, 4vw, 2.2rem);
  line-height: 1; letter-spacing: 0; font-variant-numeric: tabular-nums;
}
.reviews-hero-stat span {
  display: block; margin-top: .45rem; color: var(--faint);
  font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; font-weight: 800;
}
.reviews-hero-action {
  display: grid; place-items: center; align-content: center; gap: .65rem;
}
.reviews-hero-write {
  min-height: 46px; padding: 0 1.25rem; border-radius: 999px;
  font-size: .72rem; letter-spacing: .12em; white-space: nowrap;
  box-shadow: 0 12px 34px rgba(217,181,62,.18), 0 0 0 1px rgba(255,255,255,.08) inset;
}
.reviews-hero-write svg {
  width: 17px; height: 17px; margin-right: .48rem;
  fill: none; stroke: currentColor; stroke-width: 2;
  stroke-linecap: round; stroke-linejoin: round;
}
.reviews-stat-star { margin: 0 !important; color: var(--accent-hover) !important; font-size: 1.15rem !important; }
.reviews-stat-divider { width: 1px; background: linear-gradient(to bottom, transparent, rgba(217,181,62,.32), transparent); }
.reviews-all {
  max-width: 1160px; margin: 0 auto; padding: clamp(3rem, 6vw, 4.5rem) 2rem 1rem;
  text-align: center;
}
.reviews-section-head h2 {
  margin: 0 0 .75rem; color: var(--text); text-transform: uppercase;
  font-size: clamp(2rem, 5vw, 3.4rem);
}
.reviews-section-head p { max-width: 44rem; margin: 0 auto 1.3rem; color: var(--muted); }
.reviews-disclosure {
  display: flex; gap: .7rem; max-width: 780px; margin: 0 auto 1.4rem;
  padding: .95rem 1.05rem; text-align: left; color: rgba(245,240,235,.72);
  border: 1px solid rgba(217,181,62,.18); border-radius: var(--radius);
  background: rgba(217,181,62,.05); font-size: .86rem; line-height: 1.6;
}
.reviews-disclosure span { color: var(--accent-hover); font-weight: 900; }
.reviews-write-btn { margin: 0 auto 1.4rem; }
.reviews-write-btn svg {
  width: 18px; height: 18px; fill: none; stroke: currentColor;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
}
.reviews-filters {
  display: flex; align-items: center; justify-content: center; gap: .65rem;
  flex-wrap: wrap; margin: 0 auto 1.6rem;
}
.reviews-filters-label {
  display: inline-flex; color: var(--faint); font-size: .7rem;
  letter-spacing: .14em; text-transform: uppercase; font-weight: 900;
}
.reviews-filter {
  min-height: 36px; padding: 0 .85rem; border-radius: 999px;
  border: 1px solid var(--border); background: rgba(255,255,255,.025);
  color: var(--muted); font: inherit; font-size: .72rem; letter-spacing: .1em;
  text-transform: uppercase; font-weight: 800; cursor: pointer;
  transition: color .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease), transform .25s var(--ease);
}
.reviews-filter:hover,
.reviews-filter.is-active {
  color: var(--accent-hover); border-color: rgba(217,181,62,.36);
  background: rgba(217,181,62,.08); transform: translateY(-1px);
}
.reviews-count {
  color: var(--faint); font-size: .76rem; letter-spacing: .05em;
}
.reviews-submit {
  position: relative; overflow: hidden;
  display: grid; gap: 1.6rem; align-items: stretch;
  grid-template-columns: minmax(0, .78fr) minmax(360px, 1fr);
  margin: 2rem 0 0; padding: 1.65rem;
  border: 1px solid rgba(217,181,62,.16); border-radius: var(--radius);
  background:
    radial-gradient(circle at 14% 16%, rgba(217,181,62,.18), transparent 36%),
    radial-gradient(circle at 86% 82%, rgba(255,255,255,.07), transparent 32%),
    linear-gradient(135deg, rgba(255,255,255,.065), rgba(255,255,255,0) 44%),
    var(--panel);
  box-shadow: 0 20px 70px rgba(0,0,0,.38), 0 0 44px rgba(217,181,62,.08);
}
.reviews-submit::before {
  content: ""; position: absolute; inset: -1px; pointer-events: none;
  background: linear-gradient(115deg, transparent 0%, rgba(217,181,62,.18) 48%, transparent 72%);
  opacity: .62; transform: translateX(-125%);
  animation: reviews-submit-sheen 5.6s var(--ease) infinite;
}
.reviews-submit h2 {
  margin: 0 0 .8rem; text-transform: uppercase;
  font-size: clamp(1.4rem, 3.4vw, 2.2rem);
}
.reviews-submit-copy {
  position: relative; z-index: 1;
  display: flex; flex-direction: column; justify-content: space-between;
  min-height: 100%;
}
.reviews-submit-copy p:not(.eyebrow) {
  color: var(--muted); max-width: 28rem; margin: 0;
}
.reviews-form {
  position: relative; z-index: 1;
  display: grid; gap: .72rem;
  padding: 1.15rem; border: 1px solid var(--border);
  border-radius: var(--radius); background: rgba(12,9,6,.52);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
.reviews-form label,
.reviews-rating legend {
  color: var(--text); font-size: .68rem; letter-spacing: .16em;
  text-transform: uppercase; font-weight: 800;
}
.reviews-form input,
.reviews-form textarea {
  width: 100%; background: rgba(12,9,6,.75); color: var(--text);
  border: 1px solid var(--border-hover); border-radius: var(--radius-sm);
  font: inherit; outline: none;
  transition: border-color .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
}
.reviews-form input {
  min-height: 46px; padding: 0 .95rem;
}
.reviews-form textarea {
  min-height: 132px; resize: vertical; padding: .9rem .95rem;
}
.reviews-form input:focus,
.reviews-form textarea:focus {
  border-color: var(--accent);
  background: #0d0a07;
  box-shadow: 0 0 0 1px var(--accent-glow), 0 0 28px rgba(217,181,62,.08);
}
.reviews-rating {
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  background: linear-gradient(135deg, rgba(217,181,62,.07), rgba(255,255,255,.025));
  margin: .1rem 0 .2rem; padding: .85rem .95rem .75rem;
}
.reviews-rating legend { padding: 0 .4rem; color: var(--muted); }
.reviews-rating-stars {
  display: flex; align-items: center; gap: .38rem;
}
.reviews-rating-star {
  position: relative; display: inline-grid; place-items: center;
  width: 42px; height: 42px; border-radius: 50%;
  cursor: pointer; color: rgba(168,159,149,.35);
  border: 1px solid transparent;
  transition: color .28s var(--ease), transform .28s var(--ease), border-color .28s var(--ease), background .28s var(--ease), box-shadow .28s var(--ease);
}
.reviews-rating-star input {
  position: absolute; inset: 0; opacity: 0; cursor: pointer; min-height: 0;
}
.reviews-rating-star span {
  position: relative; z-index: 1;
  font-size: 1.55rem; line-height: 1;
  transform: translateY(-1px);
  filter: drop-shadow(0 0 0 rgba(217,181,62,0));
  transition: filter .28s var(--ease), transform .28s var(--ease);
}
.reviews-rating-star.is-active {
  color: var(--accent-hover);
  border-color: rgba(217,181,62,.2);
  background: rgba(217,181,62,.06);
  box-shadow: 0 0 24px rgba(217,181,62,.1);
}
.reviews-rating-star.is-active span {
  filter: drop-shadow(0 0 10px rgba(217,181,62,.42));
}
.reviews-rating-star.is-preview {
  transform: translateY(-2px) scale(1.04);
  color: #f2d469;
  box-shadow: 0 0 30px rgba(217,181,62,.18);
}
.reviews-rating-star:focus-within {
  outline: 2px solid rgba(217,181,62,.46);
  outline-offset: 3px;
}
.reviews-rating p {
  margin: .5rem 0 0; color: var(--accent-hover);
  font-size: .82rem; font-weight: 800; letter-spacing: .08em;
  text-transform: uppercase;
}
.reviews-form-status {
  min-height: 1.25rem; margin: 0; color: var(--accent-hover);
  font-size: .8rem; font-weight: 700;
}
.reviews-form .btn {
  width: 100%; min-height: 50px;
}
.reviews-wall {
  display: grid; gap: 1rem; grid-template-columns: repeat(3, minmax(0, 1fr));
  text-align: left;
}
.reviews-wall-card {
  position: relative; overflow: hidden; min-height: 235px;
  display: flex; flex-direction: column; justify-content: space-between;
  border: 1px solid var(--border); border-radius: var(--radius);
  background:
    radial-gradient(circle at 82% 10%, rgba(217,181,62,.12), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,0) 38%),
    var(--panel);
  padding: 1.25rem; opacity: 0; transform: translateY(18px);
  animation: review-card-in .78s var(--ease) forwards;
  animation-delay: calc(var(--review-index, 0) * 18ms);
  transition: border-color .3s var(--ease), box-shadow .3s var(--ease), transform .3s var(--ease);
}
.reviews-wall-card[hidden] { display: none; }
.reviews-wall-card::after {
  content: ""; position: absolute; inset: -1px; pointer-events: none;
  background: linear-gradient(115deg, transparent 0%, rgba(217,181,62,.13) 45%, transparent 72%);
  opacity: 0; transform: translateX(-120%);
}
.reviews-wall-card:hover {
  transform: translateY(-3px); border-color: var(--accent-glow);
  box-shadow: 0 20px 58px rgba(0,0,0,.42), 0 0 30px rgba(217,181,62,.1);
}
.reviews-wall-card:hover::after { opacity: 1; animation: review-sheen 1.1s var(--ease); }
.reviews-card-top {
  display: flex; align-items: center; justify-content: space-between; gap: .8rem;
  color: var(--faint); font-size: .64rem; letter-spacing: .14em;
  text-transform: uppercase; font-weight: 800;
}
.reviews-card-name {
  display: inline-flex; align-items: center; gap: .45rem; flex-wrap: wrap;
  color: var(--text); letter-spacing: .06em;
}
.reviews-verified {
  display: inline-flex; align-items: center; gap: .2rem;
  padding: .15rem .42rem; border: 1px solid rgba(74,222,128,.3);
  border-radius: 999px; background: rgba(74,222,128,.1);
  color: #4ade80; font-size: .56rem; letter-spacing: .06em; white-space: nowrap;
}
.reviews-wall-card .stars {
  color: var(--accent-hover); letter-spacing: .12em; white-space: nowrap;
  text-shadow: 0 0 16px rgba(217,181,62,.22);
}
.reviews-empty {
  position: relative; overflow: hidden; max-width: 780px; margin: .6rem auto 0;
  padding: clamp(1.6rem, 4vw, 2.4rem); text-align: center;
  border: 1px solid rgba(217,181,62,.18); border-radius: var(--radius);
  background:
    radial-gradient(circle at 50% 0%, rgba(217,181,62,.16), transparent 42%),
    linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,0) 42%),
    rgba(18,14,10,.78);
  box-shadow: 0 22px 70px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.035);
}
.reviews-empty::after {
  content: ""; position: absolute; inset: -1px; pointer-events: none;
  background: linear-gradient(115deg, transparent 0%, rgba(217,181,62,.12) 48%, transparent 76%);
  transform: translateX(-120%); animation: reviews-submit-sheen 6.4s var(--ease) infinite;
}
.reviews-empty-mark {
  display: inline-grid; place-items: center; width: 50px; height: 50px;
  margin-bottom: 1rem; border-radius: 50%;
  border: 1px solid rgba(217,181,62,.28);
  color: var(--accent-hover); background: rgba(217,181,62,.08);
  box-shadow: 0 0 32px rgba(217,181,62,.14);
}
.reviews-empty h3 {
  margin: 0 0 .55rem; color: var(--text);
  font-size: clamp(1.25rem, 3vw, 1.75rem); text-transform: uppercase;
}
.reviews-empty p {
  max-width: 34rem; margin: 0 auto 1.2rem; color: var(--muted); line-height: 1.65;
}
.reviews-empty-steps {
  display: flex; justify-content: center; flex-wrap: wrap; gap: .55rem;
}
.reviews-empty-steps span {
  display: inline-flex; align-items: center; min-height: 32px; padding: 0 .8rem;
  border: 1px solid rgba(217,181,62,.14); border-radius: 999px;
  color: var(--accent-hover); background: rgba(217,181,62,.055);
  font-size: .66rem; font-weight: 900; letter-spacing: .12em; text-transform: uppercase;
}
.reviews-wall-card blockquote {
  margin: 1.2rem 0; color: var(--text); font-size: .98rem; line-height: 1.65;
}
.reviews-card-product {
  display: grid; gap: .15rem; color: var(--faint); font-size: .72rem;
}
.reviews-card-product span:last-child {
  color: var(--accent-hover); font-weight: 800; letter-spacing: .04em;
}
.reviews-modal[hidden] { display: none; }
.reviews-modal {
  position: fixed; inset: 0; z-index: 200;
  display: grid; place-items: center; padding: 1.2rem;
}
.reviews-modal-backdrop {
  position: absolute; inset: 0; background: rgba(0,0,0,.72);
  border: 0; cursor: pointer; backdrop-filter: blur(8px);
}
.reviews-modal-box {
  position: relative; z-index: 1; width: min(560px, 100%);
  max-height: min(820px, calc(100vh - 2.4rem)); overflow: auto;
  padding: 1.5rem; border: 1px solid rgba(217,181,62,.2);
  border-radius: var(--radius); background:
    radial-gradient(circle at 88% 10%, rgba(217,181,62,.16), transparent 36%),
    var(--panel);
  box-shadow: 0 34px 120px rgba(0,0,0,.72), 0 0 64px rgba(217,181,62,.12);
  animation: reviews-modal-in .45s var(--ease) both;
}
.reviews-modal-close {
  position: absolute; top: .8rem; right: .9rem;
  width: 34px; height: 34px; border: 1px solid var(--border-hover);
  border-radius: 50%; background: rgba(255,255,255,.03);
  color: var(--muted); font-size: 1.4rem; line-height: 1; cursor: pointer;
}
.reviews-modal-box h2 {
  margin: 0 2.2rem .7rem 0; text-transform: uppercase;
  font-size: clamp(1.55rem, 4vw, 2.2rem);
}
.reviews-modal-intro { color: var(--muted); margin: 0 2rem 1rem 0; }
body.reviews-modal-open { overflow: hidden; }
.reviews-modal .reviews-form {
  background: rgba(12,9,6,.48);
}
.reviews-cta {
  margin-top: 2rem; padding: 1.6rem; border: 1px solid var(--border);
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 88% 15%, rgba(217,181,62,.14), transparent 36%),
    #0d0a07;
}
.reviews-cta h2 { margin: 0 0 .7rem; text-transform: uppercase; }
.reviews-cta p { color: var(--muted); max-width: 44rem; }
.reviews-cta .btn { margin-top: .8rem; }
@keyframes review-card-in { to { opacity: 1; transform: translateY(0); } }
@keyframes review-sheen { to { transform: translateX(120%); } }
@keyframes reviews-submit-sheen {
  0%, 44% { transform: translateX(-125%); opacity: 0; }
  55% { opacity: .68; }
  72%, 100% { transform: translateX(125%); opacity: 0; }
}
@keyframes reviews-modal-in {
  from { opacity: 0; transform: translateY(18px) scale(.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
@media (max-width: 920px) {
  .reviews-summary, .reviews-wall { grid-template-columns: 1fr 1fr; }
  .reviews-hero-stats { grid-template-columns: 1fr; gap: .9rem; width: min(100%, 360px); }
  .reviews-stat-divider { width: 100%; height: 1px; }
}
@media (max-width: 620px) {
  .reviews-all { padding-inline: 1.2rem; }
  .reviews-wall { grid-template-columns: 1fr; }
  .reviews-filters { justify-content: flex-start; }
  .reviews-filter { flex: 1 1 auto; }
  .reviews-wall-card { min-height: auto; }
  .reviews-modal { padding: .8rem; }
  .reviews-modal-box { padding: 1.2rem; }
}
@media (prefers-reduced-motion: reduce) {
  .reviews-wall-card { opacity: 1; transform: none; animation: none; }
  .reviews-wall-card:hover { transform: none; }
  .reviews-wall-card:hover::after { animation: none; opacity: 0; }
  .reviews-submit::before, .reviews-modal-box { animation: none; }
  .reviews-empty::after { animation: none; }
  .reviews-rating-star, .reviews-rating-star span { transition: none; }
}

/* ---- Try it yourself: live text-preset preview ---- */
.try-it { max-width: 1140px; margin: 0 auto; }
.ttx {
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 2rem; box-shadow: 0 18px 60px rgba(0,0,0,.45);
}
.ttx-stage {
  min-height: 150px; display: flex; align-items: center; justify-content: center;
  background: radial-gradient(ellipse at center, #1c1610 0%, #0d0a06 75%);
  border: 1px solid var(--border); border-radius: var(--radius);
  font-size: clamp(2rem, 7vw, 4rem); font-weight: 800; letter-spacing: .04em;
  text-transform: uppercase; overflow: hidden; padding: 1.5rem;
}
.ttx-letter { display: inline-block; will-change: transform, opacity, filter; }
.ttx-controls { display: flex; gap: 1rem; flex-wrap: wrap; align-items: center; margin-top: 1.2rem; }
.ttx-input {
  flex: 1 1 220px; background: var(--elevated); border: 1px solid var(--border-hover);
  color: var(--text); font-family: inherit; font-size: 1rem; font-weight: 600;
  padding: .8rem 1rem; border-radius: var(--radius-sm); letter-spacing: .06em;
  text-transform: uppercase; outline: none; transition: border-color .3s var(--ease);
}
.ttx-input:focus { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent-glow); }
.ttx-chips { display: flex; gap: .5rem; flex-wrap: wrap; }
.ttx-chip {
  background: transparent; border: 1px solid var(--border-hover); color: var(--muted);
  font-family: inherit; font-size: .68rem; letter-spacing: .16em; text-transform: uppercase;
  font-weight: 600; padding: .55rem 1rem; border-radius: var(--radius-sm); cursor: pointer;
  transition: all .3s var(--ease);
}
.ttx-chip:hover { color: var(--text); border-color: var(--accent); }
.ttx-chip[aria-pressed="true"] {
  background: linear-gradient(to right, #d4af37, #c9a227); color: #100C08; border-color: transparent;
  box-shadow: 0 0 0 1px #c9a22759, 0 4px 24px #c9a22733;
}
.ttx-note { color: var(--faint); font-size: .78rem; margin: .9rem 0 0; }

/* Real preset looks: white text, soft glow (matched to the pack renders) */
.ttx-stage { color: #fff; perspective: 600px; }

/* TEXT 1 — glow sweep: letters reveal L->R, newest letter flares */
.ttx-sweep .ttx-letter {
  animation: ttx-sweep .9s cubic-bezier(.16,1,.3,1) both;
  animation-delay: calc(var(--i) * 90ms);
}
@keyframes ttx-sweep {
  0%   { opacity: 0; text-shadow: 0 0 0 transparent; }
  25%  { opacity: 1; text-shadow: 0 0 22px rgba(255,255,255,.95), 0 0 50px rgba(255,255,255,.5); }
  100% { opacity: 1; text-shadow: 0 0 10px rgba(255,255,255,.28); }
}

/* TEXT 2 — soft blur fade with breathing glow */
.ttx-fade .ttx-letter {
  animation: ttx-fade 1.5s cubic-bezier(.16,1,.3,1) both;
  animation-delay: calc(var(--i) * 22ms);
}
@keyframes ttx-fade {
  0%   { opacity: 0; filter: blur(7px); text-shadow: 0 0 0 transparent; }
  55%  { opacity: 1; filter: blur(0); text-shadow: 0 0 18px rgba(255,255,255,.7), 0 0 44px rgba(255,255,255,.3); }
  100% { opacity: 1; filter: blur(0); text-shadow: 0 0 9px rgba(255,255,255,.3); }
}

/* TEXT 3 — typewriter with a glowing cursor */
.ttx-type .ttx-letter {
  animation: ttx-type .01s steps(1) both;
  animation-delay: calc(var(--i) * 110ms);
  text-shadow: 0 0 10px rgba(255,255,255,.35);
}
@keyframes ttx-type { from { opacity: 0; } to { opacity: 1; } }
.ttx-type::after {
  content: ""; display: inline-block; width: .09em; height: .95em;
  margin-left: .12em; background: #fff; vertical-align: -.08em;
  box-shadow: 0 0 14px rgba(255,255,255,.9);
  animation: ttx-blink 1s steps(1) infinite;
}
@keyframes ttx-blink { 0%, 60% { opacity: 1; } 61%, 100% { opacity: 0; } }

/* TEXT 6 — 3D roll-flip through the baseline */
.ttx-flip .ttx-letter {
  transform-origin: 50% 100%;
  animation: ttx-flip .8s cubic-bezier(.16,1,.3,1) both;
  animation-delay: calc(var(--i) * 18ms);
}
@keyframes ttx-flip {
  from { transform: rotateX(95deg); opacity: 0; filter: blur(5px); }
  60%  { text-shadow: 0 0 18px rgba(255,255,255,.7); }
  to   { transform: rotateX(0); opacity: 1; filter: blur(0); text-shadow: 0 0 9px rgba(255,255,255,.3); }
}

/* TEXT 7 — spins in from a tilted angle */
.ttx-spin .ttx-letter {
  animation: ttx-spin .85s cubic-bezier(.16,1,.3,1) both;
  animation-delay: calc(var(--i) * 25ms);
}
@keyframes ttx-spin {
  from { transform: rotate(-24deg) translateY(.7em) scale(1.15); opacity: 0; filter: blur(6px); }
  to   { transform: rotate(0) translateY(0) scale(1); opacity: 1; filter: blur(0); text-shadow: 0 0 9px rgba(255,255,255,.3); }
}

@media (prefers-reduced-motion: reduce) {
  .ttx-stage .ttx-letter { animation: none !important; }
}

/* ---- Hero cover art ---- */
.hero-media { position: relative; isolation: isolate; }
.hero-media::before {
  content: ""; position: absolute; inset: -18% -14%;
  z-index: -2; pointer-events: none; opacity: .68;
  background:
    radial-gradient(circle at 68% 68%, rgba(217,181,62,.24), transparent 36%),
    radial-gradient(circle at 28% 18%, rgba(240,202,61,.16), transparent 32%);
  filter: blur(34px); transform: translate3d(0,0,0);
  animation: heroAmbientGold 9s ease-in-out infinite alternate;
}
.hero-cover {
  position: relative; border-radius: var(--radius);
  padding: 1px; background: rgba(217,181,62,.18);
  box-shadow: 0 34px 90px rgba(0,0,0,.62), 0 0 80px rgba(217,181,62,.14);
}
.hero-cover::before {
  content: ""; position: absolute; inset: -1px; z-index: -1;
  border-radius: inherit; pointer-events: none;
  background: linear-gradient(115deg,
    rgba(217,181,62,.12) 0%,
    rgba(240,202,61,.86) 18%,
    rgba(255,239,164,.28) 34%,
    rgba(217,181,62,.08) 52%,
    rgba(240,202,61,.68) 76%,
    rgba(217,181,62,.12) 100%);
  background-size: 260% 260%;
  filter: blur(.15px);
  animation: heroBorderSweep 6.5s ease-in-out infinite;
}
.hero-cover::after {
  content: ""; position: absolute; inset: 1px; border-radius: calc(var(--radius) - 1px);
  pointer-events: none;
  box-shadow: inset 0 0 0 1px rgba(255,238,162,.16);
}
.hero-cover img {
  width: 100%; height: auto; display: block;
  border-radius: calc(var(--radius) - 1px); border: 0;
  box-shadow: none;
}
@keyframes heroBorderSweep {
  0%, 100% { background-position: 0% 52%; opacity: .72; }
  50% { background-position: 100% 48%; opacity: 1; }
}
@keyframes heroAmbientGold {
  from { opacity: .44; transform: translate3d(-2%, 1%, 0) scale(.98); }
  to { opacity: .78; transform: translate3d(2%, -1%, 0) scale(1.04); }
}
@media (prefers-reduced-motion: reduce) {
  .hero-media::before,
  .hero-cover::before { animation: none; }
}
.looks .ttx { margin-bottom: 2.4rem; }

/* ---- Lottie stage: real AE exports; glow approximates Deep Glow ---- */
.ttx-lottie-stage { padding: 0; }
.ttx-lottie { width: 100%; height: 100%; min-height: 150px;
  filter: drop-shadow(0 0 14px rgba(255,255,255,.55)) drop-shadow(0 0 38px rgba(255,255,255,.22)); }
.ttx-lottie svg { display: block; width: 100% !important; height: 100% !important; }

/* Lottie stage sizing — fill the stage, crop the empty top/bottom of the 1080x1250 frame */
.ttx-lottie-stage { padding: 0; height: 300px; }
.ttx-lottie { height: 100%; }

/* Lottie text exports come through without a fill — force white so it's visible */
.ttx-lottie svg text { fill: #fff; }

/* ---- FAQ & Contact page ---- */
.faq-hero { max-width: 1140px; margin: 0 auto; padding: 4rem 2rem 1rem; text-align: center; }
.faq-hero h1 { font-size: clamp(2rem, 5vw, 3rem); text-transform: uppercase; margin: 0 0 .6rem; }
.faq-hero .section-lead { margin: 0 auto; }
.faq-section { max-width: 820px; margin: 0 auto; padding: 1.5rem 2rem 2rem; }
.faq-section .faq-filter { justify-content: center; }
.faq-item summary { list-style: none; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::before { content: "+"; color: var(--accent); font-weight: 800; margin-right: .6rem; }
.faq-item[open] summary::before { content: "–"; }
.faq-item a { color: var(--accent-hover); }

/* ---- Legal pages ---- */
.legal-page { max-width: 1040px; margin: 0 auto; padding: 4rem 2rem 5rem; }
.legal-hero {
  border-bottom: 1px solid var(--border);
  padding-bottom: 2rem; margin-bottom: 1.2rem;
}
.legal-hero h1 {
  margin: 0 0 1rem; text-transform: uppercase;
  font-size: clamp(2.35rem, 7vw, 4.9rem); letter-spacing: -.01em;
}
.legal-hero p {
  color: var(--muted); max-width: 44rem; margin: 0 0 1.2rem;
  font-size: clamp(1rem, 2vw, 1.15rem);
}
.legal-hero span {
  color: var(--faint); font-size: .76rem; letter-spacing: .14em;
  text-transform: uppercase; font-weight: 700;
}
.legal-toc {
  display: flex; flex-wrap: wrap; gap: .55rem;
  padding: 1.2rem 0 2rem;
}
.legal-toc a {
  color: var(--muted); text-decoration: none; border: 1px solid var(--border);
  background: rgba(255,255,255,.025); border-radius: 999px;
  padding: .5rem .78rem; font-size: .72rem; font-weight: 800;
  letter-spacing: .1em; text-transform: uppercase;
  transition: color .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
}
.legal-toc a:hover {
  color: var(--accent-hover); border-color: var(--accent-glow);
  background: rgba(217,181,62,.07);
}
.legal-stack { display: grid; gap: 1rem; }
.legal-block {
  position: relative; overflow: hidden;
  scroll-margin-top: 86px; padding: 1.45rem 1.55rem;
  background:
    linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,0) 38%),
    var(--panel);
  border: 1px solid var(--border); border-radius: var(--radius);
  opacity: 0; transform: translateY(16px);
  animation: legal-card-in .72s var(--ease) forwards;
  animation-delay: calc(var(--legal-index, 0) * 80ms);
  transition: border-color .3s var(--ease), box-shadow .3s var(--ease), transform .3s var(--ease);
}
.legal-block::after {
  content: ""; position: absolute; inset: -1px; pointer-events: none;
  background: linear-gradient(115deg, transparent 0%, rgba(217,181,62,.13) 45%, transparent 72%);
  opacity: 0; transform: translateX(-120%);
}
.legal-block:hover {
  border-color: var(--accent-glow);
  box-shadow: 0 18px 52px rgba(0,0,0,.36), 0 0 28px rgba(217,181,62,.1);
  transform: translateY(-2px);
}
.legal-block:hover::after { opacity: 1; animation: legal-card-sheen 1.15s var(--ease); }
.legal-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; margin-bottom: 1rem;
  color: var(--accent-hover); border: 1px solid var(--accent-glow);
  border-radius: 50%; background: rgba(217,181,62,.075);
  box-shadow: 0 0 28px rgba(217,181,62,.11);
}
.legal-icon svg { width: 20px; height: 20px; fill: currentColor; }
.legal-block h2 {
  margin: 0 0 .75rem; text-transform: uppercase;
  font-size: clamp(1.2rem, 3vw, 1.65rem);
}
.legal-block p { color: var(--muted); margin: 0 0 1rem; max-width: 44rem; }
.legal-block ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .68rem; }
.legal-block li {
  position: relative; padding-left: 1.25rem; color: var(--text);
  font-size: .94rem; line-height: 1.6;
}
.legal-block li::before {
  content: ""; position: absolute; left: 0; top: .72em;
  width: 6px; height: 6px; border-radius: 50%; background: var(--accent);
  box-shadow: 0 0 16px var(--accent-glow);
}
@keyframes legal-card-in {
  to { opacity: 1; transform: translateY(0); }
}
@keyframes legal-card-sheen {
  to { transform: translateX(120%); }
}
@media (prefers-reduced-motion: reduce) {
  .legal-block { opacity: 1; transform: none; animation: none; }
  .legal-block:hover { transform: none; }
  .legal-block:hover::after { animation: none; opacity: 0; }
}

.contact-section { max-width: 820px; margin: 0 auto; }
.contact-grid { display: grid; gap: 1.2rem; grid-template-columns: 1fr; margin-bottom: 1.6rem; }
@media (min-width: 640px) { .contact-grid { grid-template-columns: 1fr 1fr; } }
.contact-card {
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 1.4rem 1.6rem;
}
.contact-card h3 { margin: 0 0 .3rem; font-size: 1rem; text-transform: uppercase; letter-spacing: .04em; }
.contact-card p { color: var(--muted); margin: 0 0 .8rem; font-size: .9rem; }
.contact-email { color: var(--accent-hover); font-weight: 700; text-decoration: none; }
.contact-socials a {
  display: inline-block; margin-right: .8rem; color: var(--muted); text-decoration: none;
  font-weight: 600; font-size: .85rem; transition: color .3s var(--ease);
}
.contact-socials a:hover { color: var(--accent-hover); }

.contact-form { display: flex; flex-direction: column; gap: .8rem; }
.cf-row { display: grid; gap: .8rem; grid-template-columns: 1fr; }
@media (min-width: 560px) { .cf-row { grid-template-columns: 1fr 1fr; } }
.contact-form input, .contact-form textarea {
  background: var(--elevated); border: 1px solid var(--border-hover); color: var(--text);
  font-family: inherit; font-size: .95rem; padding: .8rem 1rem; border-radius: var(--radius-sm);
  outline: none; transition: border-color .3s var(--ease); width: 100%; resize: vertical;
}
.contact-form input:focus, .contact-form textarea:focus { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent-glow); }
.contact-form .btn { align-self: flex-start; }
.cf-note { color: var(--faint); font-size: .78rem; margin: 0; }

/* Pack cover fix: the img's height="1200" attr was overriding aspect-ratio,
   stretching the cover to ~1200px tall. Let aspect-ratio drive the height,
   and cap it so the square stays contained beside the info column (Alvar-style). */
.pp-cover img { height: auto; }
.pp-cover { max-width: 520px; }
@media (max-width: 939px) { .pp-cover { max-width: 520px; margin-inline: auto; } }

/* ---- Coaching page + homepage path chooser ---- */
.coach-hero {
  max-width: 880px; margin: 0 auto; text-align: center;
  padding: clamp(3.5rem, 8vw, 6rem) 2rem 1.5rem;
}
.coach-hero h1 {
  font-size: clamp(2.2rem, 6vw, 4rem); text-transform: uppercase;
  letter-spacing: -.01em; margin: .2rem 0 1rem;
}
.coach-hero .section-lead { margin: 0 auto 1.8rem; }
.coach-hero .hero-cta { justify-content: center; }

.coach-section { max-width: 1140px; margin: 0 auto; padding: 3rem 2rem; text-align: center; }
.coach-section > h2 { font-size: clamp(1.7rem, 4vw, 2.6rem); text-transform: uppercase; margin: .2rem 0 .6rem; }
.coach-section .section-lead { margin: 0 auto 2rem; }

/* What you'll learn */
.coach-learn-grid {
  display: grid; gap: 1.2rem; grid-template-columns: 1fr; text-align: left; margin-top: 1.6rem;
}
@media (min-width: 720px) { .coach-learn-grid { grid-template-columns: repeat(2, 1fr); } }
.coach-learn-card {
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 1.4rem 1.5rem; transition: border-color .3s var(--ease), transform .3s var(--ease);
}
.coach-learn-card:hover { border-color: var(--accent-glow); transform: translateY(-2px); }
.coach-learn-card h3 { margin: 0 0 .5rem; font-size: 1.05rem; text-transform: uppercase; }
.coach-learn-card p { margin: 0; color: var(--muted); font-size: .92rem; }

/* Pricing tiers */
.coach-tiers {
  display: grid; gap: 1.4rem; grid-template-columns: 1fr; text-align: left;
  margin: 1.8rem 0 1.4rem; align-items: start;
}
@media (min-width: 920px) { .coach-tiers { grid-template-columns: repeat(3, 1fr); } }
.coach-card {
  position: relative; display: flex; flex-direction: column;
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 1.7rem 1.5rem; transition: border-color .3s var(--ease), transform .3s var(--ease), box-shadow .3s var(--ease);
}
.coach-card:hover { border-color: var(--border-hover); transform: translateY(-3px); box-shadow: 0 18px 50px rgba(0,0,0,.5); }
.coach-card.is-popular {
  border-color: var(--accent-glow);
  background: linear-gradient(180deg, var(--elevated), var(--panel));
  box-shadow: 0 24px 70px rgba(0,0,0,.5), 0 0 50px var(--accent-glow);
}
@media (min-width: 920px) { .coach-card.is-popular { transform: translateY(-10px); } }
.coach-badge {
  position: absolute; top: -.7rem; left: 50%; transform: translateX(-50%);
  background: linear-gradient(to right, #d4af37, #c9a227); color: #100C08;
  font-size: .62rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase;
  padding: .32rem .8rem; border-radius: 999px; white-space: nowrap;
  box-shadow: 0 6px 22px #c9a22744;
}
.coach-card h3 { margin: 0 0 .25rem; font-size: 1.25rem; text-transform: uppercase; }
.coach-tagline { margin: 0 0 .9rem; color: var(--muted); font-size: .88rem; }
.coach-price { margin: 0 0 1.1rem; font-weight: 800; }
.coach-was { color: var(--faint); font-size: 1.05rem; font-weight: 600; margin-right: .3rem; }
.coach-now { color: var(--accent-hover); font-size: 1.9rem; }
.coach-off {
  display: inline-block; vertical-align: middle; margin-left: .45rem;
  background: linear-gradient(to right, #d4af37, #c9a227); color: #100C08;
  font-size: .66rem; font-weight: 800; letter-spacing: .06em;
  padding: .22rem .5rem; border-radius: var(--radius-sm);
}
.coach-feats { list-style: none; padding: 0; margin: 0 0 1.4rem; display: grid; gap: .55rem; }
.coach-feats li { position: relative; padding-left: 1.4rem; color: var(--text); font-size: .92rem; }
.coach-feats li::before { content: "✓"; position: absolute; left: 0; color: var(--accent); font-weight: 700; }
.coach-buy { margin-top: auto; }
.coach-buy .btn { width: 100%; }
.coach-scarcity {
  text-align: center; color: var(--accent-hover); font-size: .82rem; font-weight: 600;
  letter-spacing: .04em; margin: .4rem 0 .2rem;
}
.coach-guarantee { text-align: center; color: var(--muted); font-size: .86rem; margin: .3rem 0 0; }

/* How it works */
.coach-steps { display: grid; gap: 1.2rem; grid-template-columns: 1fr; text-align: left; margin-top: 1.6rem; }
@media (min-width: 760px) { .coach-steps { grid-template-columns: repeat(3, 1fr); } }
.coach-step {
  display: flex; gap: 1rem; align-items: flex-start;
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.3rem 1.4rem;
}
.coach-step-num {
  flex: none; display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: 50%;
  border: 1px solid var(--accent-glow); color: var(--accent-hover);
  font-weight: 800; box-shadow: 0 0 22px var(--accent-glow);
}
.coach-step h3 { margin: .25rem 0 .35rem; font-size: 1rem; text-transform: uppercase; }
.coach-step p { margin: 0; color: var(--muted); font-size: .9rem; }

.coach-cta { max-width: 760px; margin: 0 auto; text-align: center; padding: 3rem 2rem 5rem; }
.coach-cta h2 { font-size: clamp(1.7rem, 4vw, 2.4rem); text-transform: uppercase; }
.coach-cta p { color: var(--muted); max-width: 40rem; margin: 0 auto 1.6rem; }
.coach-cta .hero-cta { justify-content: center; }

/* Homepage path chooser */
.choose-section { max-width: 1140px; margin: 0 auto; padding: 3rem 2rem; text-align: center; }
.choose-section > h2 { font-size: clamp(1.7rem, 4vw, 2.6rem); text-transform: uppercase; margin: .2rem 0 .6rem; }
.choose-section .section-lead { margin: 0 auto 2rem; }
.choose-grid { display: grid; gap: 1.4rem; grid-template-columns: 1fr; text-align: left; }
@media (min-width: 760px) { .choose-grid { grid-template-columns: repeat(2, 1fr); } }
.choose-card {
  display: flex; flex-direction: column; align-items: flex-start;
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 1.8rem; transition: border-color .3s var(--ease), transform .3s var(--ease), box-shadow .3s var(--ease);
}
.choose-card:hover { border-color: var(--accent-glow); transform: translateY(-3px); box-shadow: 0 18px 50px rgba(0,0,0,.5); }
.choose-card .eyebrow { margin-bottom: .5rem; }
.choose-card h3 { margin: 0 0 .5rem; font-size: 1.4rem; text-transform: uppercase; }
.choose-card p { color: var(--muted); margin: 0 0 1rem; }
.choose-price { font-weight: 800; margin: 0 0 1.2rem !important; }
.choose-price s { color: var(--faint); font-weight: 600; margin-right: .35rem; }
.choose-price span { color: var(--accent-hover); font-size: 1.5rem; }
.choose-card .btn { margin-top: auto; }

/* Coaching tier cover image */
.coach-media {
  margin: 0 0 1.2rem; border-radius: var(--radius-sm); overflow: hidden;
  border: 1px solid var(--border); aspect-ratio: 1 / 1; background: #000;
}
.coach-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.coach-card.is-popular .coach-media { border-color: var(--accent-glow); }

/* Mobile header: brand on top, nav on ONE compact row (no 2-line wrap) */
@media (max-width: 560px) {
  .site-header { flex-wrap: wrap; justify-content: center; gap: .55rem 0; padding: .85rem 1rem; }
  .site-header .brand { width: 100%; text-align: center; }
  .site-header .nav {
    display: flex; flex-wrap: nowrap; justify-content: center; align-items: center;
    gap: .8rem; width: 100%; max-width: 100%; overflow-x: auto;
    -webkit-overflow-scrolling: touch; scrollbar-width: none;
  }
  .site-header .nav::-webkit-scrollbar { display: none; }
  .site-header .nav a { margin-left: 0; font-size: .68rem; letter-spacing: .05em; white-space: nowrap; }
}
