/* ================================================
   AVG Theme — Main Styles
   Developed by Foresyte IT Solutions
   Client: AdamVincentGilmer.com
   ================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@300;400;500;600&family=Space+Mono:wght@400;700&display=swap');

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --black:      #000000;
  --black-soft: #07070a;
  --gray-dark:  #0e0e12;
  --gray:       #111118;
  --border:     #1a1a26;
  --border-light:#222232;
  --cyan:       #00e5ff;
  --cyan-dim:   rgba(0,229,255,.18);
  --cyan-glow:  rgba(0,229,255,.06);
  --white:      #ffffff;
  --text-main:  #e8e8f0;
  --text-mid:   #8888a8;
  --text-dim:   #444460;
  --gold:       #c9a84c;
  --easing:     cubic-bezier(.22,1,.36,1);
}

html { scroll-behavior: smooth; }

body {
  background: var(--black);
  color: var(--text-main);
  font-family: 'Inter', sans-serif;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

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

/* ── SCROLL ANIMATION BASE STATES ── */
.reveal          { opacity:0; transform:translateY(48px);    transition: opacity .9s var(--easing), transform .9s var(--easing); }
.reveal-left     { opacity:0; transform:translateX(-50px);   transition: opacity .9s var(--easing), transform .9s var(--easing); }
.reveal-right    { opacity:0; transform:translateX(50px);    transition: opacity .9s var(--easing), transform .9s var(--easing); }
.reveal-scale    { opacity:0; transform:scale(.93);           transition: opacity .9s var(--easing), transform .9s var(--easing); }
.reveal-clip     { clip-path:inset(0 100% 0 0);              transition: clip-path 1.1s var(--easing); }
.reveal-fade     { opacity:0;                                 transition: opacity 1s var(--easing); }
.in.reveal, .in.reveal-left, .in.reveal-right, .in.reveal-scale, .in.reveal-fade { opacity:1; transform:none; }
.in.reveal-clip  { clip-path:inset(0 0% 0 0); }

.d1  { transition-delay:.08s; }
.d2  { transition-delay:.16s; }
.d3  { transition-delay:.24s; }
.d4  { transition-delay:.32s; }
.d5  { transition-delay:.40s; }
.d6  { transition-delay:.50s; }
.d7  { transition-delay:.60s; }

/* ── NAVIGATION ── */
.avg-nav {
  position: fixed; top:0; left:0; right:0; z-index:200;
  display: flex; align-items:center; justify-content:space-between;
  padding: 1.1rem 3.5rem;
  background: rgba(0,0,0,.82);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(0,229,255,.08);
  transition: background .4s, border-color .4s;
}
.avg-nav.scrolled { background: rgba(0,0,0,.95); border-color: rgba(0,229,255,.14); }

.nav-logo { display:flex; align-items:center; gap:.85rem; text-decoration:none; color:inherit; cursor:pointer; }
.nav-slash { display:block; width:3px; height:38px; background:var(--cyan); }
.nav-text  { display:flex; flex-direction:column; }
.nav-name  { font-family:'Bebas Neue',sans-serif; font-size:1.1rem; letter-spacing:.14em; color:#fff; line-height:1; }
.nav-sub   { font-size:.56rem; letter-spacing:.18em; color:#8888aa; text-transform:uppercase; margin-top:.15rem; }

.nav-links { display:flex; align-items:center; gap:2.2rem; }
.nav-links a { color:var(--text-mid); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; transition:color .25s; }
.nav-links a:hover { color:#fff; }
.nav-cta {
  border:1px solid var(--cyan); color:var(--cyan);
  padding:.48rem 1.4rem; font-size:.68rem; letter-spacing:.16em; text-transform:uppercase;
  transition: background .25s, color .25s;
}
.nav-cta:hover { background:var(--cyan); color:#000; }

/* ── HERO ── */
.avg-hero {
  position: relative; min-height:100vh;
  display:flex; align-items:center; overflow:hidden;
  background: #000;
}

/* Creative gradient background — replaces hero_bg photo */
.hero-gradient-bg {
  position: absolute; inset: 0; z-index: 0;
  background:
    /* Deep space base */
    radial-gradient(ellipse 120% 80% at 15% 50%,  #040d1a 0%, transparent 60%),
    radial-gradient(ellipse 80%  90% at 85% 20%,  #060818 0%, transparent 55%),
    /* Cyan precision glow — upper left, near text */
    radial-gradient(ellipse 55% 45% at 5%  20%,   rgba(0,180,255,.13) 0%, transparent 65%),
    /* Electric-teal pulse behind filmstrip — right side */
    radial-gradient(ellipse 50% 70% at 92% 45%,   rgba(0,229,255,.09) 0%, transparent 60%),
    /* Deep violet depth — centre-bottom */
    radial-gradient(ellipse 100% 60% at 50% 100%,  rgba(40,0,80,.55)  0%, transparent 65%),
    /* Subtle warm accent upper-right */
    radial-gradient(ellipse 35% 35% at 78% 8%,    rgba(80,20,180,.18) 0%, transparent 55%),
    /* Base */
    linear-gradient(160deg, #03080f 0%, #000510 40%, #050008 100%);
  animation: hero-bg-pulse 12s ease-in-out infinite alternate;
}
@keyframes hero-bg-pulse {
  0%   { opacity: 1; }
  50%  { opacity: .88; }
  100% { opacity: 1; }
}
.hero-grid-lines {
  position:absolute; inset:0; z-index:2;
  background-image:
    linear-gradient(rgba(0,229,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,229,255,.035) 1px, transparent 1px);
  background-size:70px 70px;
  mask-image: radial-gradient(ellipse 85% 85% at 40% 50%, #000 40%, transparent 100%);
}
.hero-content {
  position:relative; z-index:3;
  max-width:1280px; margin:0 auto;
  padding:0 3.5rem; padding-top:4.5rem;
  width:100%;
}
.hero-eyebrow {
  display:flex; align-items:center; gap:1rem;
  font-family:'Space Mono',monospace; font-size:.65rem;
  color:var(--cyan); letter-spacing:.28em; text-transform:uppercase;
  margin-bottom:1.6rem;
  opacity:0; animation: fadeUp .8s var(--easing) .3s forwards;
}
.hero-eyebrow::before { content:''; display:block; width:36px; height:1px; background:var(--cyan); }

.hero-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2.4rem,5vw,6rem);
  line-height:.92; letter-spacing:.015em;
  max-width:800px; margin-bottom:1.8rem;
}
.hero-title .word {
  display:inline-block; overflow:hidden;
  clip-path:inset(0 100% 0 0);
}
.hero-title .word span { display:inline-block; }

.hero-subhead {
  max-width:620px; font-size:.98rem; font-weight:300;
  line-height:1.8; color:var(--text-mid); margin-bottom:1rem;
  opacity:0; animation: fadeUp .9s var(--easing) 1.1s forwards;
}
.hero-subhead strong { color:#c8c8e0; font-weight:500; }

.hero-tagline {
  font-family:'Space Mono',monospace; font-size:.9rem;
  color:var(--cyan); letter-spacing:.06em;
  margin-bottom:2.8rem;
  opacity:0; animation: fadeUp .8s var(--easing) 1.4s forwards;
}
.hero-tagline::before { content:'"'; } .hero-tagline::after { content:'"'; }

.hero-btns {
  display:flex; gap:1rem; flex-wrap:wrap;
  opacity:0; animation: fadeUp .8s var(--easing) 1.6s forwards;
}
.btn-primary {
  background:var(--cyan); color:#000;
  padding:.88rem 2.2rem; font-size:.75rem; font-weight:700;
  letter-spacing:.15em; text-transform:uppercase;
  transition:background .25s, transform .25s, box-shadow .25s;
  box-shadow:0 0 0 rgba(0,229,255,0);
}
.btn-primary:hover { background:#fff; transform:translateY(-2px); box-shadow:0 8px 30px rgba(0,229,255,.25); }
.btn-secondary {
  border:1px solid #2a2a3a; color:var(--text-mid);
  padding:.88rem 2.2rem; font-size:.75rem;
  letter-spacing:.15em; text-transform:uppercase;
  transition:border-color .25s, color .25s, transform .25s;
}
.btn-secondary:hover { border-color:var(--cyan); color:var(--cyan); transform:translateY(-2px); }

/* Hero stats bar */
.hero-stats {
  display:flex; gap:3rem; flex-wrap:nowrap;
  margin-top:2.5rem; padding-top:2rem; padding-bottom:2.5rem;
  border-top:1px solid var(--border-light);
  opacity:0; animation: fadeUp .8s var(--easing) 1.9s forwards;
}
.stat { }
.stat-num {
  font-family:'Bebas Neue',sans-serif; font-size:2.8rem;
  color:var(--cyan); line-height:1;
  text-shadow:0 0 30px rgba(0,229,255,.3);
}
.stat-num[data-infinity="true"] {
  display:flex;
  align-items:center;
  line-height:1;
}
.stat-label { font-size:.6rem; letter-spacing:.18em; text-transform:uppercase; color:#9090b8; margin-top:.3rem; }

.hero-bottom-line {
  position:absolute; bottom:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
  animation:lineReveal 1.5s var(--easing) 2s forwards;
  clip-path:inset(0 100% 0 0);
}

/* ── SECTION COMMON ── */
.section-wrap { padding:7rem 3.5rem; max-width:1280px; margin:0 auto; }
.section-label {
  display:flex; align-items:center; gap:.8rem;
  font-family:'Space Mono',monospace; font-size:.62rem;
  color:var(--cyan); letter-spacing:.28em; text-transform:uppercase;
  margin-bottom:1rem;
}
.section-label::before { content:''; width:28px; height:1px; background:var(--cyan); flex-shrink:0; }
.section-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2.2rem,4.5vw,5rem);
  line-height:.95; letter-spacing:.03em;
  margin-bottom:1.5rem;
}
.cyan { color:var(--cyan); }

/* ── ABOUT SECTION ── */
.about-section { background:var(--black-soft); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.about-section .section-wrap { padding-top:3.5rem; }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }

.about-img-wrap {
  position:relative; isolation:isolate;
}
/* Radial cyan glow behind the figure */
.about-img-wrap::before {
  content:'';
  position:absolute; inset:-40px -20px;
  background:
    radial-gradient(ellipse 90% 50% at 50% 108%, rgba(0,229,255,.22) 0%, rgba(0,180,255,.08) 35%, transparent 65%),
    radial-gradient(ellipse 55% 75% at 12% 55%, rgba(0,100,220,.10) 0%, transparent 60%);
  z-index:-1; pointer-events:none;
}
/* Horizontal glow line below the image */
.about-img-wrap::after {
  content:'';
  position:absolute; bottom:-1.8rem; left:5%; right:5%; height:1px;
  background:linear-gradient(90deg, transparent, rgba(0,229,255,.45) 25%, rgba(0,229,255,.45) 75%, transparent);
  pointer-events:none;
}
.about-img-wrap img {
  width:100%; max-height:580px; object-fit:contain; object-position:top;
  position:relative; z-index:1;
  filter:contrast(1.06) drop-shadow(0 40px 60px rgba(0,0,0,.6));
}
/* Corner bracket accents — removed */
.about-glow {
  position:absolute; inset:0; pointer-events:none; z-index:2;
}
.about-glow::before,
.about-glow::after {
  content:none;
}

.about-text .section-title { margin-bottom:.8rem; }
.about-lead { font-size:1.05rem; font-weight:300; line-height:1.75; color:var(--text-mid); margin-bottom:1.2rem; }
.about-lead strong { color:#cccce0; font-weight:500; }
.about-body { font-size:.88rem; line-height:1.85; color:var(--text-mid); margin-bottom:1rem; }
.about-body strong { color:#cccce0; }

.about-divider { width:60px; height:1px; background:var(--cyan); opacity:.4; margin:1.8rem 0; }

.exp-list { list-style:none; display:flex; flex-direction:column; gap:.1rem; margin-bottom:1.8rem; }
.exp-list li {
  font-size:.78rem; color:#c0c0d8; padding:.45rem 0;
  border-bottom:1px solid var(--border); display:flex; align-items:center; gap:.8rem;
  letter-spacing:.03em;
}
.exp-list li::before { content:'→'; color:var(--cyan); font-size:.65rem; flex-shrink:0; }

.signature-wrap { margin-top:1.5rem; }
.signature-wrap img { height:48px; width:auto; opacity:.75; filter:drop-shadow(0 2px 8px rgba(0,229,255,.1)); }

/* ── ABOUT — magazine feature under headshot ── */
.about-mag-feature {
  margin-top:1.8rem; display:flex; align-items:center; gap:1rem;
}
.about-mag-feature .badge-featured {
  font-family:'Space Mono',monospace; font-size:.58rem;
  color:var(--cyan); letter-spacing:.22em; text-transform:uppercase;
  display:block; margin-bottom:.35rem;
}
.about-mag-feature .badge-mag-thumb {
  height:68px; width:auto; object-fit:cover;
  flex-shrink:0;
}
.about-mag-feature .badge-pub-name {
  font-family:'Space Mono',monospace; font-size:.6rem;
  color:var(--text-mid); letter-spacing:.1em; line-height:1.5;
}

/* ── FRAMEWORK (80/20/365) ── */
.framework-section { background:var(--black); }
.framework-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:start; }
.framework-logo { margin-bottom:1.5rem; }
.framework-logo img { height:50px; width:auto; }
.framework-intro { font-size:.9rem; line-height:1.8; color:var(--text-mid); margin-bottom:2rem; }

.pillars-grid { display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--border); }
.pillar {
  background:var(--gray-dark); padding:1.6rem;
  transition:background .3s;
  position:relative; overflow:hidden;
}
.pillar::before {
  content:''; position:absolute; top:0; left:0; width:2px; height:0;
  background:var(--cyan); transition:height .4s var(--easing);
}
.pillar:hover { background:var(--gray); }
.pillar:hover::before { height:100%; }
.pillar-num { font-family:'Bebas Neue',sans-serif; font-size:2.2rem; color:#4a4a6a; line-height:1; margin-bottom:.4rem; }
.pillar-name { font-size:.82rem; font-weight:500; color:#cccce0; letter-spacing:.04em; margin-bottom:.3rem; }
.pillar-desc { font-size:.72rem; color:#a0a0c0; line-height:1.55; }

/* ── COMPANIES ── */
.companies-section { background:var(--gray-dark); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.co-grid { display:grid; grid-template-columns:1fr 1fr; gap:2rem; margin-top:3rem; }
.co-card {
  background:var(--gray); border:1px solid var(--border);
  padding:2.8rem; position:relative; overflow:hidden;
  transition:border-color .35s, transform .35s;
}
.co-card::after {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
  transform:scaleX(0); transition:transform .5s var(--easing);
}
.co-card:hover { border-color:rgba(0,229,255,.25); transform:translateY(-4px); }
.co-card:hover::after { transform:scaleX(1); }
.co-logo { margin-bottom:1.5rem; height:44px; display:flex; align-items:center; }
.co-logo img { height:100%; width:auto; max-width:100%; object-fit:contain; object-position:left center; }
.co-tag { font-family:'Space Mono',monospace; font-size:.58rem; color:var(--cyan); letter-spacing:.2em; text-transform:uppercase; margin-bottom:.6rem; opacity:.7; }
.co-name { font-family:'Bebas Neue',sans-serif; font-size:1.8rem; letter-spacing:.05em; margin-bottom:.8rem; }
.co-desc { font-size:.82rem; color:#aaaacc; line-height:1.75; margin-bottom:1.5rem; }
.co-items { list-style:none; }
.co-items li {
  font-size:.72rem; color:#8888aa; padding:.32rem 0;
  border-bottom:1px solid var(--border); display:flex; align-items:center; gap:.6rem;
}
.co-items li::before { content:'→'; color:var(--cyan); font-size:.6rem; }

/* ── SPEAKING ── */
.speaking-section { background:var(--black-soft); }
.speaking-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.speaking-img {
  position:relative; overflow:hidden;
  border-top: 2px solid rgba(0,229,255,.85);
  border-left: 2px solid rgba(0,229,255,.85);
  box-shadow: -8px -8px 40px rgba(0,229,255,.35), -3px -3px 14px rgba(0,229,255,.25);
}
.speaking-img img { width:100%; height:440px; object-fit:cover; filter:contrast(1.1) grayscale(15%); transition:transform 8s ease; }
.speaking-img:hover img { transform:scale(1.04); }
.speaking-img-overlay { display:none; }

.topics-wrap { display:flex; flex-wrap:wrap; gap:.5rem; margin:1.5rem 0; }
.topic {
  font-size:.66rem; border:1px solid #2e2e48; color:#8888aa;
  padding:.32rem .85rem; letter-spacing:.05em;
  transition:border-color .25s, color .25s, background .25s;
}
.topic:hover { border-color:rgba(0,229,255,.4); color:var(--cyan); background:rgba(0,229,255,.04); }

.book-btn {
  display:inline-block; margin-top:2rem;
  border:1px solid var(--cyan); color:var(--cyan);
  padding:.88rem 2.2rem; font-size:.72rem; letter-spacing:.15em; text-transform:uppercase;
  transition:background .25s, color .25s, transform .25s;
}
.book-btn:hover { background:var(--cyan); color:#000; transform:translateY(-2px); }

/* ── QUOTE ── */
.quote-section {
  background:var(--black); padding:8rem 3.5rem;
  text-align:center; position:relative; overflow:hidden;
}
.quote-section::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 60% 70% at 50% 50%, rgba(0,229,255,.04), transparent 70%);
}
.big-quote {
  position:relative; z-index:1;
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(1.8rem,3.5vw,3.5rem);
  line-height:1.2; letter-spacing:.05em;
  max-width:900px; margin:0 auto 1.5rem;
  color:var(--text-mid);
}
.big-quote .highlight { color:#fff; }
.big-quote em { color:var(--cyan); font-style:normal; }
.quote-attr {
  font-family:'Space Mono',monospace; font-size:.65rem;
  color:#8888aa; letter-spacing:.22em; text-transform:uppercase;
}
.quote-attr::before { content:'— '; color:var(--cyan); }

/* ── SOCIAL ── */
.social-section { padding:4rem 3.5rem; border-top:1px solid var(--border); border-bottom:1px solid var(--border); background:var(--gray-dark); }
.social-inner { max-width:1280px; margin:0 auto; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:2rem; }
.social-label { font-family:'Space Mono',monospace; font-size:.65rem; color:#9090b8; letter-spacing:.22em; text-transform:uppercase; }
.social-links { display:flex; gap:1rem; }
.soc-link {
  width:44px; height:44px; border:1px solid #2e2e48;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:.62rem; letter-spacing:.05em;
  transition:border-color .25s, color .25s, background .25s;
  text-decoration:none;
}
.soc-link svg { width:20px; height:20px; fill:#fff; transition:fill .25s; }
.soc-link:hover { border-color:var(--cyan); background:rgba(0,229,255,.05); }
.soc-link:hover svg { fill:var(--cyan); }

/* ── FOOTER ── */
.avg-footer {
  background:var(--gray-dark); border-top:1px solid var(--border);
  padding:4rem 3.5rem;
}
.footer-inner { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr 1fr; gap:3rem; }
.foot-logo { display:flex; align-items:center; gap:.6rem; margin-bottom:1.2rem; }
.foot-slash { width:2px; height:30px; background:var(--cyan); }
.foot-name { font-family:'Bebas Neue',sans-serif; font-size:1rem; letter-spacing:.12em; }
.foot-info { font-size:.78rem; color:#aaaacc; line-height:2.3; }
.foot-info a { color:#aaaacc; transition:color .2s; }
.foot-info a:hover { color:var(--cyan); }
.foot-mono { font-family:'Space Mono',monospace; font-size:.65rem; color:var(--cyan); margin-top:1.2rem; opacity:.85; }
.foot-addr { font-size:.78rem; color:#aaaacc; line-height:2.3; }
.foot-copy { font-size:.62rem; color:#666688; letter-spacing:.1em; text-transform:uppercase; margin-top:.8rem; }

/* ── KEYFRAMES ── */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(32px); }
  to   { opacity:1; transform:none; }
}
@keyframes lineReveal {
  to { clip-path:inset(0 0% 0 0); }
}
@keyframes countUp { from { opacity:0; } to { opacity:1; } }

/* ── PARALLAX SUPPORT ── */
.parallax-bg { will-change:transform; }

/* ── NAV GL LOGO ── */
.nav-gl-logo { height:22px; width:auto; opacity:.85; transition:opacity .2s; vertical-align:middle; }
.nav-gl-logo:hover { opacity:1; }

/* ── MOST INFLUENTIAL LEADERS BADGE SECTION ── */
.badge-section {
  background:#050508; padding:3rem;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.badge-inner {
  max-width:1280px; margin:0 auto;
  display:flex; flex-direction:column; align-items:center; gap:2rem;
}
.badge-img {
  max-width:420px; width:100%;
  filter:drop-shadow(0 0 20px rgba(0,229,255,.15));
}
.badge-caption { display:flex; flex-direction:column; align-items:center; gap:1rem; }
.badge-featured {
  font-family:'Space Mono',monospace; font-size:.62rem;
  color:var(--cyan); letter-spacing:.28em; text-transform:uppercase;
  font-variant:small-caps;
}
.badge-pub-row {
  display:flex; align-items:center; gap:1rem;
}
.badge-mag-thumb {
  height:80px; width:auto; object-fit:cover;
  border:1px solid var(--border-light);
}
.badge-pub-name {
  font-family:'Space Mono',monospace; font-size:.65rem;
  color:var(--text-mid); letter-spacing:.12em;
}

/* ── PUBLICATIONS — fan pages ── */
.avg-pub-page {
  position:relative; width:210px; cursor:pointer; flex-shrink:0;
  transition:transform .4s cubic-bezier(.22,1,.36,1);
}
.avg-pub-page img { border:1px solid var(--border-light); filter:drop-shadow(0 20px 40px rgba(0,0,0,.8)); }
.avg-pub-fan-1 { transform:rotate(-4deg) translateX(60px); z-index:1; }
.avg-pub-fan-2 { transform:rotate(0deg); z-index:2; }
.avg-pub-fan-3 { transform:rotate(4deg) translateX(-60px); z-index:1; }
.avg-pub-page:hover { z-index:10; }
.avg-pub-fan-1:hover { transform:rotate(0deg) translateX(-20px) scale(1.04); }
.avg-pub-fan-2:hover { transform:rotate(0deg) scale(1.06); }
.avg-pub-fan-3:hover { transform:rotate(0deg) translateX(20px) scale(1.04); }

/* ── PUBLICATIONS PAGE ── */
.pub-hero {
  background:var(--black); padding:8rem 3.5rem 5rem;
  border-bottom:1px solid var(--border);
  text-align:center;
}
.pub-hero h1 {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2rem,4vw,4rem);
  letter-spacing:.04em; line-height:1;
  margin-bottom:1.2rem;
}
.pub-hero p {
  font-size:.9rem; color:var(--text-mid);
  max-width:680px; margin:0 auto; line-height:1.8;
}
.pub-feature {
  background:var(--black-soft); padding:6rem 3.5rem;
  border-bottom:1px solid var(--border);
}
.pub-feature-inner {
  max-width:1280px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1.4fr; gap:5rem; align-items:center;
}
.pub-cover {
  width:100%; max-width:400px;
  border:1px solid var(--border-light);
  filter:drop-shadow(0 20px 40px rgba(0,229,255,.1));
}
.pub-feature-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(1.8rem,3vw,3rem);
  line-height:1; letter-spacing:.04em; margin-bottom:.5rem;
}
.pub-feature-sub {
  font-family:'Space Mono',monospace; font-size:.7rem;
  color:var(--cyan); letter-spacing:.18em; margin-bottom:1.5rem;
}
.pub-feature-excerpt {
  font-size:.88rem; color:var(--text-mid);
  line-height:1.85; margin-bottom:2rem;
}
.pub-fan-section {
  background:var(--black); padding:6rem 3.5rem;
  border-bottom:1px solid var(--border);
}
.pub-fan-section h2 {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2rem,4vw,4rem);
  letter-spacing:.04em; text-align:center; margin-bottom:3rem;
}
.pub-fan-cards {
  display:flex; justify-content:center; align-items:center;
  gap:0; position:relative;
}
.pub-fan-card {
  position:relative; width:220px; cursor:pointer;
  transition:transform .4s cubic-bezier(.22,1,.36,1), z-index 0s;
  flex-shrink:0;
}
.pub-fan-card:nth-child(2) { transform:rotate(-5deg) translateX(44px); z-index:1; }
.pub-fan-card:nth-child(3) { transform:rotate(0deg); z-index:2; }
.pub-fan-card:nth-child(4) { transform:rotate(5deg) translateX(-44px); z-index:1; }
.pub-fan-card:hover { z-index:10; }
.pub-fan-card:nth-child(2):hover { transform:rotate(0deg) translateX(-16px) scale(1.04); }
.pub-fan-card:nth-child(3):hover { transform:rotate(0deg) scale(1.06); }
.pub-fan-card:nth-child(4):hover { transform:rotate(0deg) translateX(16px) scale(1.04); }
.pub-fan-card img {
  width:100%; border:1px solid var(--border-light);
  filter:drop-shadow(0 20px 40px rgba(0,0,0,.8));
}

/* ── PODCAST PAGE ── */
.pod-hero {
  background:var(--black); padding:8rem 3.5rem 5rem;
  border-bottom:1px solid var(--border);
  text-align:center;
}
.pod-hero h1 {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2rem,4vw,4rem);
  letter-spacing:.04em; line-height:1;
  margin-bottom:1.2rem;
}
.pod-hero p {
  font-size:.9rem; color:var(--text-mid);
  max-width:640px; margin:0 auto; line-height:1.8;
}
.podcast-grid {
  max-width:1280px; margin:0 auto;
  display:grid; grid-template-columns:repeat(3,1fr); gap:2rem;
  padding:5rem 3.5rem;
}
.podcast-card {
  background:var(--gray-dark); border:1px solid var(--border);
  position:relative; overflow:hidden;
  transition:border-color .35s, transform .35s;
}
.podcast-card::after {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
  transform:scaleX(0); transition:transform .5s var(--easing);
}
.podcast-card:hover { border-color:rgba(0,229,255,.25); transform:translateY(-4px); }
.podcast-card:hover::after { transform:scaleX(1); }
.podcast-card-thumb { position:relative; overflow:hidden; }
.podcast-card-thumb img { width:100%; height:200px; object-fit:cover; transition:transform .6s ease; }
.podcast-card:hover .podcast-card-thumb img { transform:scale(1.04); }
.pod-ep-badge {
  position:absolute; top:1rem; left:1rem;
  background:var(--cyan); color:#000;
  font-family:'Space Mono',monospace; font-size:.58rem;
  letter-spacing:.15em; padding:.28rem .7rem;
}
.podcast-card-body { padding:1.8rem; }
.podcast-card-body h3 {
  font-family:'Bebas Neue',sans-serif; font-size:1.6rem;
  letter-spacing:.04em; margin-bottom:.6rem; line-height:1;
}
.podcast-card-body p { font-size:.8rem; color:var(--text-mid); line-height:1.75; margin-bottom:1.5rem; }
.pod-btns { display:flex; flex-direction:column; gap:.6rem; }
.pod-btn-apple, .pod-btn-spotify {
  display:flex; align-items:center; justify-content:center; gap:.5rem;
  padding:.6rem 1rem; font-size:.65rem; letter-spacing:.1em; text-transform:uppercase;
  transition:background .25s, color .25s, border-color .25s;
  font-family:'Space Mono',monospace;
}
.pod-btn-apple { background:var(--gray); border:1px solid var(--border-light); color:var(--text-mid); }
.pod-btn-apple:hover { border-color:var(--cyan); color:var(--cyan); }
.pod-btn-spotify { background:var(--gray); border:1px solid var(--border-light); color:var(--text-mid); }
.pod-btn-spotify:hover { border-color:#1db954; color:#1db954; }

/* ── CONTACT PAGE ── */
.contact-hero {
  background:var(--black); padding:8rem 3.5rem 5rem;
  border-bottom:1px solid var(--border);
  text-align:center;
}
.contact-hero h1 {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2rem,4vw,4rem);
  letter-spacing:.04em; line-height:1;
}
.contact-body {
  max-width:1280px; margin:0 auto; padding:5rem 3.5rem;
  display:grid; grid-template-columns:1fr 1.5fr; gap:5rem;
}
.contact-info-label {
  font-family:'Space Mono',monospace; font-size:.62rem;
  color:var(--cyan); letter-spacing:.28em; text-transform:uppercase;
  display:flex; align-items:center; gap:.8rem; margin-bottom:2rem;
}
.contact-info-label::before { content:''; width:28px; height:1px; background:var(--cyan); }
.contact-info-item { margin-bottom:1.5rem; }
.contact-info-item strong {
  display:block; font-size:.7rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--text-dim); margin-bottom:.3rem;
}
.contact-info-item a, .contact-info-item span {
  font-size:.88rem; color:var(--text-mid); transition:color .2s;
}
.contact-info-item a:hover { color:var(--cyan); }
.contact-form { display:flex; flex-direction:column; gap:1.2rem; }
.contact-form input,
.contact-form textarea,
.contact-form select {
  background:var(--gray-dark); border:1px solid var(--border-light);
  color:var(--text-main); padding:.9rem 1.2rem;
  font-family:'Inter',sans-serif; font-size:.85rem;
  width:100%; outline:none;
  transition:border-color .25s, box-shadow .25s;
  -webkit-appearance:none; appearance:none;
}
.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus {
  border-color:rgba(0,229,255,.4);
  box-shadow:0 0 0 2px rgba(0,229,255,.06);
}
.contact-form textarea { min-height:160px; resize:vertical; }
.contact-form select { background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238888a8' stroke-width='1.5' fill='none'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 1rem center; }
.contact-submit {
  background:var(--cyan); color:#000;
  border:none; padding:.95rem 2.4rem;
  font-size:.75rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  cursor:pointer; transition:background .25s, transform .25s, box-shadow .25s;
  font-family:'Inter',sans-serif; align-self:flex-start;
}
.contact-submit:hover { background:#fff; transform:translateY(-2px); box-shadow:0 8px 30px rgba(0,229,255,.2); }
.contact-form-label {
  font-size:.72rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--text-dim); margin-bottom:.3rem; display:block;
}
.contact-field { display:flex; flex-direction:column; }
.booking-section {
  background:var(--gray-dark); border-top:1px solid var(--border);
  padding:5rem 3.5rem;
}
.booking-section-inner { max-width:1280px; margin:0 auto; }
.booking-tags { display:flex; flex-wrap:wrap; gap:.8rem; margin-top:2rem; }
.booking-tag {
  font-family:'Space Mono',monospace; font-size:.65rem;
  border:1px solid rgba(255,255,255,.35); color:#b0b0cc;
  padding:.42rem 1.1rem; letter-spacing:.08em;
  transition:border-color .25s, color .25s, background .25s;
}
.booking-tag:hover { border-color:rgba(0,229,255,.4); color:var(--cyan); background:rgba(0,229,255,.04); }

/* ═══════════════════════════════════════════════════════
   MOBILE HAMBURGER — hidden on desktop
   ═══════════════════════════════════════════════════════ */
.avg-burger { display:none; }

/* ═══════════════════════════════════════════════════════
   RESPONSIVE — ≤768px
   ═══════════════════════════════════════════════════════ */
@media (max-width:768px) {

  /* ── NAVIGATION ── */
  .avg-nav { padding:.85rem 1.2rem; position:relative; flex-wrap:nowrap; }
  .avg-burger {
    display:flex; flex-direction:column; justify-content:space-between;
    width:26px; height:18px; cursor:pointer;
    background:none; border:none; padding:0; flex-shrink:0; margin-left:auto;
  }
  .avg-burger span { display:block; height:2px; background:#fff; transition:transform .3s, opacity .3s; }
  .avg-nav.nav-open .avg-burger span:nth-child(1) { transform:translateY(8px) rotate(45deg); }
  .avg-nav.nav-open .avg-burger span:nth-child(2) { opacity:0; }
  .avg-nav.nav-open .avg-burger span:nth-child(3) { transform:translateY(-8px) rotate(-45deg); }
  .nav-links {
    display:none; position:absolute; top:100%; left:0; right:0; z-index:300;
    background:rgba(0,0,0,.97); border-bottom:1px solid rgba(0,229,255,.15);
    flex-direction:column; gap:0; padding:.5rem 0;
  }
  .avg-nav.nav-open .nav-links { display:flex; }
  .nav-links a { padding:.9rem 1.5rem; font-size:.8rem; border-bottom:1px solid rgba(255,255,255,.05); width:100%; }
  .nav-links .nav-cta { margin:.8rem 1.5rem; width:calc(100% - 3rem); text-align:center; display:block; }

  /* ── HERO ── */
  .hero-content { padding:0 1.2rem; padding-top:5.5rem; }
  .hero-title { font-size:clamp(2rem,11vw,3.5rem); }
  .hero-subhead { font-size:.88rem; }
  .hero-btns { flex-direction:column; }
  .btn-primary, .btn-secondary { text-align:center; width:100%; }
  .hero-stats { gap:1.5rem; }
  .stat-num { font-size:2.2rem; }

  /* ── SECTION COMMON ── */
  .section-wrap { padding:3.5rem 1.2rem; }
  .about-section .section-wrap { padding-top:2.5rem; }

  /* ── ABOUT ── */
  .about-grid { grid-template-columns:1fr; gap:2rem; }
  .about-img-wrap img { max-height:460px; display:block; }
  .about-mag-feature { margin-top:0; transform:translateY(-60px); }
  .about-mag-feature .badge-mag-thumb { height:68px; }
  .about-text .section-title { font-size:clamp(2rem,10vw,3rem); }
  .about-lead { font-size:.88rem; }
  .about-body { font-size:.82rem; }

  /* ── FRAMEWORK / 80·20·365 ── */
  .framework-grid { grid-template-columns:1fr; gap:2.5rem; }
  .pillars-grid { grid-template-columns:1fr; }

  /* ── BIOHACKING VISION (inline grid) ── */
  section[aria-label="Adam's Vision on Biohacking"] { padding:4rem 1.2rem !important; }
  section[aria-label="Adam's Vision on Biohacking"] > div { grid-template-columns:1fr !important; gap:2rem !important; }

  /* ── COMPANIES ── */
  .co-grid { grid-template-columns:1fr; }
  .co-card { padding:1.8rem; }
  .co-logo { margin-bottom:1.2rem; height:auto; }
  .co-logo img { height:auto !important; object-fit:contain; object-position:left center; }
  /* Genetic LifeSpan: 10:1 ratio — needs full width to be legible */
  .co-grid .co-card:first-child .co-logo img { width:100%; max-width:100%; }
  /* THRiV: 2.8:1 ratio — cap so it doesn't dominate */
  .co-grid .co-card:last-child .co-logo img { width:auto; max-width:160px; height:56px !important; }
  .co-name { font-size:1.5rem; }
  .co-desc { font-size:.8rem; }
  .co-items li { font-size:.72rem; }

  /* ── SPEAKING ── */
  .speaking-grid { grid-template-columns:1fr; gap:2rem; }
  .speaking-img img { height:220px; }

  /* ── MISSION (inline) ── */
  section[aria-label="Mission Statement"] { padding:4rem 1.2rem !important; }

  /* ── QUOTE ── */
  .quote-section { padding:4.5rem 1.2rem; }

  /* ── SOCIAL ── */
  .social-section { padding:2.5rem 1.2rem; }
  .social-inner { flex-direction:column; align-items:flex-start; gap:1.5rem; }

  /* ── FOOTER ── */
  .avg-footer { padding:3rem 1.2rem; }
  .footer-inner { grid-template-columns:1fr; gap:2rem; }

  /* ── PUBLICATIONS hero & feature ── */
  .pub-hero { padding:6rem 1.2rem 3rem; }
  .pub-feature { padding:3.5rem 1.2rem; }
  .pub-feature-inner { grid-template-columns:1fr; gap:2rem; }

  /* Publications story — stack badge above fan cards on mobile */
  section[aria-label="Magazine Story Pages"] > div > div[style*="display:flex"] {
    flex-direction:column !important;
    align-items:center !important;
    gap:2rem !important;
  }

  /* ── PODCAST ── */
  .pod-hero { padding:6rem 1.2rem 3rem; }
  .podcast-grid { grid-template-columns:1fr; padding:3rem 1.2rem; }

  /* ── CONTACT ── */
  .contact-hero { padding:6rem 1.2rem 3rem; }
  .contact-body { grid-template-columns:1fr; gap:2.5rem; padding:3rem 1.2rem; }
  .booking-section { padding:3rem 1.2rem; }
}

/* ── HERO FILMSTRIP COLLAGE ── */
.hero-inner {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 3rem;
  align-items: center;
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 3.5rem;
  padding-top: 7rem;
}

/* Remove padding from hero-content since hero-inner handles it now */
.hero-content {
  padding: 0 !important;
  max-width: 100%;
}

.hero-filmstrip {
  position: relative;
  display: flex;
  gap: 5px;
  height: 80vh;
  max-height: 680px;
  min-height: 480px;
  flex-shrink: 0;
  opacity: 0;
  animation: fadeIn 1.2s var(--easing) .5s forwards;
}

/* Vertical scan line that travels down the full strip */
.hf-scan {
  position: absolute;
  left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(0,229,255,.45), transparent);
  z-index: 30;
  pointer-events: none;
  animation: hf-scan 5s linear infinite;
}
@keyframes hf-scan {
  0%   { top: -2px; opacity: 0; }
  5%   { opacity: 1; }
  95%  { opacity: .5; }
  100% { top: 100%; opacity: 0; }
}

/* Individual strip — vertical filmstrip column */
.hf-strip {
  flex: 1;
  display: flex;
  flex-direction: column;
  position: relative;
  border: 1px solid rgba(0,229,255,.1);
}

/* Perforation holes top and bottom */
.hf-holes {
  flex-shrink: 0;
  height: 22px;
  background: repeating-linear-gradient(
    90deg,
    transparent 0, transparent 3px,
    rgba(0,229,255,.1) 3px, rgba(0,229,255,.1) 10px,
    transparent 10px, transparent 13px
  );
  border-top: 1px solid rgba(0,229,255,.08);
  border-bottom: 1px solid rgba(0,229,255,.08);
}

/* Image area */
.hf-img {
  flex: 1;
  position: relative;
  overflow: hidden;
}
.hf-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  filter: brightness(.75) saturate(.85) contrast(1.05);
  transition: filter .5s ease, transform 10s ease;
}
.hf-strip:hover .hf-img img {
  filter: brightness(.95) saturate(1) contrast(1.05);
  transform: scale(1.05);
}

/* Dark gradient fade at bottom of each image */
.hf-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.1) 0%, rgba(0,0,8,.5) 100%);
  z-index: 1;
}

/* Cyan top edge accent on hover */
.hf-strip::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--cyan), transparent);
  opacity: 0;
  transition: opacity .4s;
  z-index: 5;
}
.hf-strip:hover::before { opacity: 1; }

/* Frame number label */
.hf-frame {
  position: absolute;
  bottom: 6px;
  left: 50%;
  transform: translateX(-50%);
  font-family: 'Space Mono', monospace;
  font-size: .38rem;
  color: rgba(0,229,255,.4);
  letter-spacing: .1em;
  z-index: 5;
  white-space: nowrap;
}

/* ── TABLET — shrink filmstrip column + tighten about section ── */
@media (max-width: 1200px) and (min-width: 769px) {
  .hero-inner {
    grid-template-columns: 1fr 300px;
    gap: 2rem;
  }
  .about-mag-feature { margin-top:0; transform:translateY(-70px); }
}

/* ── MOBILE — hide filmstrip, restore single column ── */
@media (max-width: 768px) {
  .hero-inner {
    grid-template-columns: 1fr;
    padding-top: 5rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
  .hero-filmstrip { display: none; }
  .hero-stats { gap: 1.5rem; flex-wrap:nowrap; }
  .stat-label { font-size: .55rem; }
}

@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ── FOOTER SOCIAL COLUMN ── */
.foot-social-col { display:flex; flex-direction:column; }
.foot-social-col .social-links { flex-wrap:wrap; }

@media (max-width:768px) {
  .foot-social-col { margin-top:1rem; }
  .foot-social-col .social-links { gap:.5rem; }
  /* Tighten the Adam + THRiV flex row on small screens */
  .foot-social-col > div[style*="display:flex"] { gap:1.5rem !important; }
  /* Reduce soc-link icon box size slightly */
  .soc-link { width:32px; height:32px; }
}

/* ── CO-CARD SCROLL-TRIGGERED ACTIVE STATE ── */
.co-card.co-scroll-active::after { transform:scaleX(1); }
