/* HeadshotMax landing — vanilla CSS, mobile-first, dark default, light via prefers-color-scheme */

*,*::before,*::after{box-sizing:border-box}
:root{
  /* iOS Theme.Palette.accent */
  --accent:#6BA6FF;
  --accent-ink:#0a1830;

  /* Dark (default) */
  --bg:#0a0d12;
  --bg-2:#10141c;
  --bg-3:#171c26;
  --ink:#eef2f7;
  --ink-2:#aab2c0;
  --ink-3:#6b7382;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  --shadow:0 1px 0 rgba(255,255,255,.04), 0 20px 60px -20px rgba(0,0,0,.5);

  --radius:14px;
  --radius-lg:22px;
  --maxw:1120px;
  --pad:clamp(20px, 4vw, 40px);

  --t-fast:.18s ease;

  font-synthesis:none;
  -webkit-text-size-adjust:100%;
  text-rendering:optimizeLegibility;
}

@media (prefers-color-scheme: light){
  :root{
    --bg:#ffffff;
    --bg-2:#f6f8fb;
    --bg-3:#eef2f7;
    --ink:#0a0d12;
    --ink-2:#3a4250;
    --ink-3:#6b7382;
    --line:rgba(0,0,0,.08);
    --line-2:rgba(0,0,0,.14);
    --shadow:0 1px 0 rgba(0,0,0,.02), 0 20px 60px -20px rgba(0,0,0,.12);
    --accent-ink:#ffffff;
  }
}

html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"SF Pro Text","SF Pro Display",system-ui,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","cv11";
  overflow-x:hidden;
}

img,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
a:hover{color:var(--accent)}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

h1,h2,h3{margin:0;letter-spacing:-.02em;line-height:1.1;font-weight:680}
h1{font-size:clamp(34px,5.6vw,60px);font-weight:720}
h2{font-size:clamp(26px,3.6vw,40px)}
h3{font-size:18px}
p{margin:0}

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

.skip{position:absolute;left:-9999px;top:8px;background:var(--accent);color:var(--accent-ink);padding:8px 12px;border-radius:8px}
.skip:focus{left:8px;z-index:100}

/* ---- NAV ---- */
.nav{
  position:sticky;top:0;z-index:10;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:14px var(--pad);
  background:color-mix(in srgb, var(--bg) 80%, transparent);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
}
.brand{display:inline-flex;align-items:center;gap:10px;font-weight:640;letter-spacing:-.01em}
.brand-mark{display:grid;place-items:center}
.brand-word{font-size:17px}
.nav-links{display:flex;align-items:center;gap:22px;font-size:14.5px;color:var(--ink-2)}
.nav-links a{transition:color var(--t-fast)}
.by-hf{color:var(--ink-3)}
@media (max-width: 720px){
  .nav-links a:not(.by-hf){display:none}
}

/* ---- LAYOUT WIDTHS ---- */
section{
  padding:clamp(56px, 9vw, 110px) var(--pad);
  max-width:var(--maxw);
  margin:0 auto;
}
section.hero{padding-top:clamp(40px, 6vw, 70px)}
section h2 + p, .section-lede{color:var(--ink-2);max-width:62ch;margin-top:14px;font-size:17px}

/* ---- HERO ---- */
.hero{
  display:grid;gap:clamp(28px,4vw,56px);
  grid-template-columns:1fr;
  align-items:center;
}
@media (min-width: 920px){
  .hero{grid-template-columns:1.05fr .95fr}
}
.hero h1{letter-spacing:-.025em}
.lede{margin-top:18px;color:var(--ink-2);font-size:clamp(17px,1.6vw,19px);max-width:36ch}

.capture{margin-top:28px}
.capture input[type="email"]{
  flex:1 1 240px;min-width:0;
  background:var(--bg-2);color:var(--ink);
  border:1px solid var(--line-2);
  border-radius:12px;
  padding:14px 16px;
  font-size:16px;
  transition:border-color var(--t-fast), box-shadow var(--t-fast);
}
.capture input[type="email"]:focus{
  outline:0;border-color:var(--accent);
  box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 22%, transparent);
}
.capture button{
  background:var(--accent);color:var(--accent-ink);
  font-weight:620;padding:14px 22px;border-radius:12px;
  transition:transform var(--t-fast), filter var(--t-fast);
}
.capture button:hover{filter:brightness(1.08)}
.capture button:active{transform:translateY(1px)}
.capture form, .capture.mode-prelaunch{
  display:flex;flex-wrap:wrap;gap:10px;align-items:center;
}
.capture .micro{
  width:100%;font-size:13px;color:var(--ink-3);margin-top:6px;
}
.appstore{display:inline-block;border-radius:10px;transition:transform var(--t-fast)}
.appstore:hover{transform:translateY(-1px)}

/* mode toggle */
.mode-live{display:none}
body.live .mode-prelaunch{display:none}
body.live .mode-live{display:block}

/* HERO VISUAL — CSS-only before/after slider */
.hero-visual{position:relative}
.ba{
  position:relative;aspect-ratio:1/1;
  border-radius:var(--radius-lg);overflow:hidden;
  background:var(--bg-2);
  box-shadow:var(--shadow);
  isolation:isolate;
}
.ba-before,.ba-after{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  background:linear-gradient(135deg,#2a3140,#1b2230);
}
.ba-after{
  background:linear-gradient(135deg,#3a4a66,#6BA6FF);
  clip-path: inset(0 calc(100% - var(--p,50%)) 0 0);
  will-change: clip-path;
  transition:clip-path .12s linear;
}
.ba-range{
  position:absolute;inset:0;width:100%;height:100%;margin:0;
  background:transparent;opacity:0;cursor:ew-resize;
}
.ba::before{
  /* divider line + handle */
  content:"";
  position:absolute;top:0;bottom:0;left:var(--p,50%);
  width:2px;background:rgba(255,255,255,.9);
  transform:translateX(-1px);pointer-events:none;
}
.ba::after{
  content:"";
  position:absolute;top:50%;left:var(--p,50%);
  width:36px;height:36px;border-radius:50%;
  background:#fff;color:#0a0d12;
  transform:translate(-50%,-50%);
  box-shadow:0 4px 14px rgba(0,0,0,.35);
  pointer-events:none;
  background-image:
    linear-gradient(45deg,transparent 47%,#0a0d12 47%,#0a0d12 53%,transparent 53%),
    linear-gradient(-45deg,transparent 47%,#0a0d12 47%,#0a0d12 53%,transparent 53%);
}
.ba-tag{
  position:absolute;bottom:12px;
  font-size:12px;letter-spacing:.06em;text-transform:uppercase;
  padding:6px 10px;border-radius:999px;
  background:rgba(0,0,0,.55);color:#fff;backdrop-filter:blur(6px);
  pointer-events:none;
}
.ba-tag-before{left:12px}
.ba-tag-after{right:12px}

/* JS-less fallback: use :hover to nudge the slider so mouse users see motion */
@media (hover:hover){
  .ba:hover{--p:30%}
}

/* ---- SPEED ---- */
.speed{text-align:left}
.speed h2{max-width:18ch}
.speed-meta{
  list-style:none;padding:0;margin:36px 0 0;
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
}
@media (min-width: 720px){.speed-meta{grid-template-columns:repeat(4,1fr)}}
.speed-meta li{
  background:var(--bg-2);border:1px solid var(--line);
  border-radius:var(--radius);padding:18px;
}
.speed-meta strong{display:block;font-size:30px;font-weight:680;letter-spacing:-.02em}
.speed-meta span{display:block;color:var(--ink-3);font-size:13.5px;margin-top:4px}

/* ---- STYLE GRID ---- */
.style-grid{
  margin-top:36px;
  display:grid;gap:14px;
  grid-template-columns:repeat(2,1fr);
}
@media (min-width: 720px){.style-grid{grid-template-columns:repeat(3,1fr)}}
.tile{
  margin:0;position:relative;
  border-radius:var(--radius);overflow:hidden;
  background:var(--bg-2);
  aspect-ratio:1/1;
  border:1px solid var(--line);
}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.tile figcaption{
  position:absolute;left:0;right:0;bottom:0;
  padding:10px 12px;
  background:linear-gradient(to top, rgba(0,0,0,.7), transparent);
  color:#fff;font-size:13.5px;font-weight:560;
  display:flex;align-items:center;justify-content:space-between;gap:6px;
}
.badge{
  font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;
  padding:3px 8px;border-radius:999px;
  background:var(--accent);color:var(--accent-ink);font-weight:620;
}

/* ---- HOW ---- */
.steps{
  list-style:none;padding:0;margin:36px 0 0;
  display:grid;gap:16px;grid-template-columns:1fr;
}
@media (min-width: 800px){.steps{grid-template-columns:repeat(3,1fr)}}
.steps li{
  background:var(--bg-2);border:1px solid var(--line);
  border-radius:var(--radius);padding:24px;
}
.step-n{
  display:inline-grid;place-items:center;
  width:30px;height:30px;border-radius:8px;
  background:var(--accent);color:var(--accent-ink);
  font-weight:680;font-size:14px;margin-bottom:14px;
}
.steps h3{margin-bottom:6px}
.steps p{color:var(--ink-2);font-size:15.5px}

.ios-badges{
  list-style:none;padding:0;margin:28px 0 0;
  display:flex;flex-wrap:wrap;gap:10px;color:var(--ink-2);
}
.ios-badges li{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border:1px solid var(--line-2);border-radius:999px;
  font-size:13.5px;
}

/* ---- PRICING ---- */
.price-card{
  margin-top:30px;
  background:linear-gradient(180deg, var(--bg-2), var(--bg-3));
  border:1px solid var(--line-2);border-radius:var(--radius-lg);
  padding:clamp(24px,3vw,40px);
  max-width:520px;
  box-shadow:var(--shadow);
}
.price-main{display:flex;align-items:baseline;gap:10px}
.price-num{font-size:48px;font-weight:720;letter-spacing:-.025em}
.price-unit{color:var(--ink-3);font-size:15px}
.price-list{list-style:none;padding:0;margin:18px 0 0;display:grid;gap:10px}
.price-list li{position:relative;padding-left:22px;color:var(--ink-2)}
.price-list li::before{
  content:"";position:absolute;left:0;top:.6em;width:12px;height:6px;
  border-left:2px solid var(--accent);border-bottom:2px solid var(--accent);
  transform:rotate(-45deg);
}
.price-fine{margin-top:20px;font-size:13px;color:var(--ink-3);border-top:1px solid var(--line);padding-top:14px}

/* ---- FAQ ---- */
.faq{max-width:780px}
.faq details{
  border-bottom:1px solid var(--line);
  padding:18px 0;
}
.faq summary{
  list-style:none;cursor:pointer;
  font-size:17px;font-weight:580;letter-spacing:-.005em;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-size:22px;color:var(--ink-3);
  font-weight:400;transition:transform var(--t-fast);
  line-height:1;
}
.faq details[open] summary::after{transform:rotate(45deg);color:var(--accent)}
.faq p{margin-top:10px;color:var(--ink-2);font-size:15.5px;max-width:64ch}

/* ---- LEGAL ---- */
.legal{max-width:780px}
.legal h2{font-size:22px;margin-top:32px}
.legal h2:first-child{margin-top:0}
.legal p{color:var(--ink-2);margin-top:10px;font-size:14.5px}

/* ---- FOOTER ---- */
.foot{
  border-top:1px solid var(--line);
  padding:48px var(--pad) 36px;
  background:var(--bg-2);
}
.foot-grid{
  max-width:var(--maxw);margin:0 auto;
  display:grid;gap:28px;grid-template-columns:1fr;
}
@media (min-width: 720px){.foot-grid{grid-template-columns:2fr 1fr 1fr}}
.foot-brand{font-weight:640;letter-spacing:-.01em}
.foot-tag{color:var(--ink-3);font-size:14px;margin-top:4px}
.foot-links{list-style:none;padding:0;margin:0;display:grid;gap:8px;font-size:14px;color:var(--ink-2)}
.foot-copy{
  max-width:var(--maxw);margin:30px auto 0;
  color:var(--ink-3);font-size:12.5px;border-top:1px solid var(--line);padding-top:18px;
}

/* ---- REDUCED MOTION ---- */
@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .ba-after{transition:none}
}

/* ---- PRINT (basic) ---- */
@media print{
  .nav,.hero-visual,.capture,.ios-badges,.foot,.cf-beacon{display:none}
  body{color:#000;background:#fff}
}

/* ---- ARTICLE / LANDING PAGES (added 2026-06-04 for SEO + GEO pages) ---- */
.article{max-width:760px;margin:0 auto;padding:0 20px}
.article-body{padding:24px 0 64px}
.article-body h1{font-size:36px;line-height:1.15;letter-spacing:-.02em;margin:8px 0 18px}
.article-body h2{font-size:24px;margin-top:36px;margin-bottom:12px;letter-spacing:-.01em}
.article-body h3{font-size:18px;margin-top:24px;margin-bottom:8px}
.article-body p{font-size:17px;line-height:1.62;margin:0 0 14px;color:var(--ink-2)}
.article-body ul,.article-body ol{padding-left:22px;margin:0 0 18px}
.article-body li{margin:0 0 8px;font-size:17px;line-height:1.6;color:var(--ink-2)}
.article-body a{color:#6BA6FF;text-decoration:underline;text-underline-offset:2px}
.article-body strong{color:var(--ink-1)}
.article-body table{width:100%;border-collapse:collapse;margin:14px 0 22px;font-size:15px}
.article-body th,.article-body td{padding:10px 12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.article-body th{font-weight:600;color:var(--ink-1);background:rgba(255,255,255,.02)}
.article-body details{padding:12px 0;border-bottom:1px solid var(--line)}
.article-body details summary{cursor:pointer;font-weight:600;color:var(--ink-1);padding:4px 0}
.article-body details[open] summary{margin-bottom:6px}
.article-body details p{margin:4px 0 0}

.hero-narrow{padding:32px 0 24px;text-align:left;border-bottom:1px solid var(--line);margin-bottom:24px}
.eyebrow{font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:#6BA6FF;font-weight:600;margin:0 0 8px}

.cta-primary{
  display:inline-block;padding:12px 18px;border-radius:10px;
  background:#6BA6FF;color:#0a0d12;font-weight:600;text-decoration:none;
  font-size:15.5px;letter-spacing:-.005em;
}
.cta-primary:hover{filter:brightness(1.05)}
.cta-end{margin:40px 0 0;padding:24px;border:1px solid var(--line);border-radius:14px;background:rgba(107,166,255,.04);text-align:center}
.cta-end h2{margin-top:0}
.cta-end p{margin-bottom:14px}

.reasons{list-style:none;padding-left:0}
.reasons li{padding-left:0;margin-bottom:14px}

.link-list{list-style:disc}

.steps-compact{list-style:decimal}

/* ---- AFFILIATES PAGE (added 2026-06-04) ---- */
.cta-secondary{
  display:inline-block;margin-left:10px;padding:12px 16px;border-radius:10px;
  background:transparent;color:var(--ink-2);font-weight:520;text-decoration:none;
  font-size:15px;border:1px solid var(--line-2);
}
.cta-secondary:hover{color:var(--ink);border-color:var(--line-2)}

.earn-card{
  background:linear-gradient(180deg,var(--bg-2),var(--bg-3));
  border:1px solid var(--line-2);border-radius:var(--radius-lg);
  padding:clamp(22px,3vw,32px);box-shadow:var(--shadow);
}
.earn-eyebrow{font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);font-weight:600;margin:0 0 14px}
.earn-grid{display:grid;gap:18px;grid-template-columns:1fr}
@media (min-width:520px){.earn-grid{grid-template-columns:1fr 1fr}}
.earn-grid > div{display:flex;flex-direction:column;gap:4px}
.earn-num{font-size:38px;font-weight:720;letter-spacing:-.025em}
.earn-unit{color:var(--ink-3);font-size:14px}
.earn-fine{color:var(--ink-3);font-size:13.5px;margin-top:16px}
.earn-fine a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}

.terms-grid{
  margin-top:36px;display:grid;gap:14px;
  grid-template-columns:1fr;
}
@media (min-width:640px){.terms-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:980px){.terms-grid{grid-template-columns:repeat(4,1fr)}}
.term{
  background:var(--bg-2);border:1px solid var(--line);
  border-radius:var(--radius);padding:20px;
}
.term-key{font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);font-weight:600;margin:0 0 8px}
.term-val{font-size:22px;font-weight:680;letter-spacing:-.015em;margin:0 0 8px;color:var(--ink)}
.term-fine{font-size:13.5px;color:var(--ink-2);margin:0;line-height:1.5}

.earn-table-wrap{margin-top:30px;overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-2)}
.earn-table{width:100%;border-collapse:collapse;font-size:15px}
.earn-table th,.earn-table td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line)}
.earn-table th{font-weight:620;color:var(--ink);background:var(--bg-3);font-size:13px;letter-spacing:.04em;text-transform:uppercase}
.earn-table tbody tr:last-child td{border-bottom:0}
.earn-table td{color:var(--ink-2)}
.earn-table td:first-child{color:var(--ink);font-weight:600}
.earn-row-hi{background:color-mix(in srgb,var(--accent) 7%,transparent)}
.earn-row-hi td:nth-child(2),.earn-row-hi td:nth-child(3){color:var(--ink);font-weight:600}

.who-grid{margin-top:30px;display:grid;gap:16px;grid-template-columns:1fr}
@media (min-width:720px){.who-grid{grid-template-columns:1fr 1fr}}
.who{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.who h3{margin:0 0 12px;font-size:16px;letter-spacing:.04em;text-transform:uppercase}
.who-yes h3{color:#7ed598}
.who-no h3{color:#ff9a8a}
.who ul{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.who li{position:relative;padding-left:22px;color:var(--ink-2);font-size:15px}
.who-yes li::before{
  content:"";position:absolute;left:0;top:.55em;width:11px;height:6px;
  border-left:2px solid #7ed598;border-bottom:2px solid #7ed598;transform:rotate(-45deg);
}
.who-no li::before{
  content:"×";position:absolute;left:2px;top:-.1em;font-weight:700;color:#ff9a8a;font-size:18px;line-height:1;
}

/* Blog (added 2026-06-05) — pull quote, proof grid, share footer, blog index. */
.article-body figure{margin:22px 0;border-radius:var(--radius);overflow:hidden;background:var(--bg-2);border:1px solid var(--line)}
.article-body figure img{display:block;width:100%;height:auto}
.article-body figcaption{padding:10px 14px;font-size:13.5px;color:var(--ink-3);border-top:1px solid var(--line);background:var(--bg-3)}
.pull{margin:28px 0;padding:18px 22px;border-left:3px solid var(--accent);background:rgba(107,166,255,.06);font-size:19px;line-height:1.4;color:var(--ink);font-weight:560;letter-spacing:-.005em}
.pull cite{display:block;margin-top:8px;font-style:normal;font-size:13px;color:var(--ink-3);font-weight:400}
.proof-grid{display:grid;gap:8px;grid-template-columns:repeat(2,1fr);margin:22px 0}
@media (min-width:640px){.proof-grid{grid-template-columns:repeat(4,1fr)}}
.proof-grid figure{margin:0;border-radius:10px}
.proof-grid figcaption{font-size:12px;padding:6px 8px}
.proof-cap{font-size:13.5px;color:var(--ink-3);margin:-12px 0 22px;text-align:center;font-style:italic}
.share-foot{margin:36px 0 0;padding:16px 18px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);font-size:14.5px;color:var(--ink-2);display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between}
.share-foot a{color:var(--accent);font-weight:600}
.byline{font-size:13.5px;color:var(--ink-3);margin:0 0 24px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.byline-dot{color:var(--ink-3)}
.blog-index{max-width:980px;margin:0 auto;padding:32px 20px 80px}
.blog-index h1{font-size:38px;letter-spacing:-.02em;margin:8px 0 8px}
.blog-index .lede{font-size:18px;color:var(--ink-2);max-width:640px;margin:0 0 28px}
.post-list{display:grid;gap:18px;grid-template-columns:1fr}
@media (min-width:760px){.post-list{grid-template-columns:1fr 1fr}}
.post-card{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:22px;display:flex;flex-direction:column;gap:10px;transition:border-color var(--t-fast)}
.post-card:hover{border-color:var(--line-2)}
.post-card a.post-link{color:var(--ink);text-decoration:none}
.post-card .post-eyebrow{font-size:12.5px;color:var(--accent);font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.post-card h2{font-size:20px;margin:0;letter-spacing:-.01em}
.post-card p{margin:0;font-size:15px;color:var(--ink-2);line-height:1.5}
.post-card .post-meta{font-size:13px;color:var(--ink-3);margin-top:auto;padding-top:8px}
