/* ============================================================
   Lost Skills of Our Grandparents — Start-Here Guide landing
   Brand: "Almanac Goldenrod & Iron-Gall" (palette A, LOCKED)
   Fonts: Playfair Display (display) + EB Garamond (body) — the book faces
   WCAG rule: text = iron-gall #1F1A17 / madder #8A2B2B / warm brown on cream.
              goldenrod #DAA520 + antique gold #C9A26A = RULES / DECOR ONLY
              (they fail AA as text on cream — never used for text).
   Target reader 55-68, print-first, vision may decline -> generous type,
   high contrast, large tap targets.
   ============================================================ */

/* ---- self-hosted book fonts (latin subset, woff2) — same-origin => fast,
        stable metrics (kills font-swap CLS), no external dependency, EU-privacy ---- */
@font-face{font-family:'EB Garamond';font-style:normal;font-weight:400;font-display:swap;src:url(fonts/ebgaramond-400-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'EB Garamond';font-style:italic;font-weight:400;font-display:swap;src:url(fonts/ebgaramond-400i-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'EB Garamond';font-style:normal;font-weight:500;font-display:swap;src:url(fonts/ebgaramond-500-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'EB Garamond';font-style:italic;font-weight:500;font-display:swap;src:url(fonts/ebgaramond-500i-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'EB Garamond';font-style:normal;font-weight:600;font-display:swap;src:url(fonts/ebgaramond-600-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'EB Garamond';font-style:normal;font-weight:700;font-display:swap;src:url(fonts/ebgaramond-700-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:700;font-display:swap;src:url(fonts/playfairdisplay-700-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:800;font-display:swap;src:url(fonts/playfairdisplay-800-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:900;font-display:swap;src:url(fonts/playfairdisplay-900-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}

:root {
  --cream:     #F3EBD6; /* base page */
  --cream-2:   #EDE2C6; /* deeper alt-section band */
  --paper:     #FBF6E9; /* card / lighter field */
  --ink:       #1F1A17; /* iron-gall — body + headings + strong rules */
  --ink-2:     #2A231D; /* warm near-black for dark bands */
  --ink-soft:  #4A4038; /* muted brown secondary text (>=7:1 on cream) */
  --goldenrod: #DAA520; /* DECOR/RULES ONLY */
  --gold:      #C9A26A; /* antique gold — DECOR/RULES ONLY */
  --madder:    #8A2B2B; /* accent text — passes AA on cream/paper */
  --madder-dk: #701F1F;
  --line:      #D8C9A6; /* hairline rule on cream */
  --line-soft: #E4D9BC;
  --max:       1060px;
  --radius:    4px;      /* almanac = flat square corners, minimal rounding */
  --shadow-sm: 0 2px 10px rgba(31,26,23,.07);
  --shadow-md: 0 10px 30px rgba(31,26,23,.12);
  --shadow-lg: 0 20px 50px rgba(31,26,23,.18);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: "EB Garamond", Georgia, "Times New Roman", serif;
  font-size: 20px;                 /* large by default — over-55 legibility */
  line-height: 1.62;
  color: var(--ink);
  background: var(--cream);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--madder); }

h1, h2, h3, .display {
  font-family: "Playfair Display", Georgia, "Times New Roman", serif;
  font-weight: 800;
  line-height: 1.12;
  color: var(--ink);
  margin: 0 0 .5em;
  letter-spacing: .002em;
}
h1 { font-size: clamp(2.15rem, 5.4vw, 3.4rem); font-weight: 900; }
h2 { font-size: clamp(1.7rem, 4vw, 2.5rem); }
h3 { font-size: clamp(1.3rem, 2.6vw, 1.6rem); }
p  { margin: 0 0 1em; }
strong { font-weight: 700; }

.wrap { width: 100%; max-width: var(--max); margin: 0 auto; padding: 0 24px; }
.section { padding: clamp(52px, 8vw, 92px) 0; }
.center { text-align: center; }

/* eyebrow — small-caps letterspaced, madder (passes AA) */
.eyebrow {
  display: inline-block;
  font-family: "EB Garamond", serif;
  font-size: .82rem; font-weight: 600;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--madder);
  margin-bottom: 14px;
}

/* ---------- Almanac double-rule frame (flat square corners) ---------- */
/* outer iron-gall rule + paper gap + fine goldenrod inner rule = the book frame */
.almanac {
  border: 2px solid var(--ink);
  box-shadow: inset 0 0 0 5px var(--paper), inset 0 0 0 6px var(--goldenrod);
  background: var(--paper);
}

/* ornamental divider: goldenrod rule + centered engraving/fleuron */
.rule-orn {
  display: flex; align-items: center; justify-content: center; gap: 16px;
  margin: 6px auto 30px; max-width: 340px; color: var(--gold);
}
.rule-orn::before, .rule-orn::after {
  content: ""; height: 1px; flex: 1; background: linear-gradient(90deg, transparent, var(--gold), transparent);
}
.rule-orn .di { width: 9px; height: 9px; transform: rotate(45deg); background: var(--goldenrod); flex: 0 0 auto; }

/* manicule pointing-hand ornament (black-on-white art -> multiply hides white) */
.manicule {
  width: 46px; height: 46px; flex: 0 0 auto;
  mix-blend-mode: multiply;
}
.manicule.flip { transform: scaleX(-1); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .55em;
  font-family: "EB Garamond", serif;
  font-weight: 700; font-size: 1.18rem;
  text-decoration: none; cursor: pointer;
  padding: 15px 30px; border-radius: 999px; border: 2px solid transparent;
  transition: transform .12s ease, box-shadow .12s ease, background .12s ease;
  line-height: 1.15;
}
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--ink); color: var(--cream); box-shadow: var(--shadow-md); }
.btn-primary:hover { background: #000; box-shadow: var(--shadow-lg); }
.btn-madder { background: var(--madder); color: #fff; box-shadow: var(--shadow-md); }
.btn-madder:hover { background: var(--madder-dk); }
.btn-outline { background: transparent; color: var(--ink); border-color: var(--ink); }
.btn-outline:hover { background: rgba(31,26,23,.06); }
.btn .ic { width: 21px; height: 21px; flex: 0 0 auto; }
.btn-lg { font-size: 1.28rem; padding: 18px 36px; }
.btn-block { display: flex; width: 100%; }

/* accent underline used under primary CTAs */
.cta-under {
  margin-top: 12px; font-size: .96rem; color: var(--ink-soft);
  display: flex; align-items: center; gap: 9px;
}
.cta-under .ic { width: 18px; height: 18px; color: var(--madder); flex: 0 0 auto; }

/* ---------- HERO ---------- */
.hero {
  background:
    radial-gradient(1100px 480px at 82% -10%, rgba(218,165,32,.14), transparent 62%),
    var(--cream);
  border-bottom: 2px solid var(--ink);
  padding-top: clamp(30px, 5vw, 54px);
  padding-bottom: clamp(44px, 7vw, 74px);
}
.hero-grid {
  display: grid; grid-template-columns: 1.1fr .9fr;
  gap: clamp(30px, 5vw, 60px); align-items: center;
}
.hero h1 { margin-bottom: .3em; }
.hero .lede { font-size: 1.24rem; color: var(--ink-soft); max-width: 38ch; margin-bottom: 20px; }
.hero-promise {
  border-left: 3px solid var(--goldenrod);
  padding: 6px 0 6px 20px; margin: 0 0 26px;
  font-size: 1.16rem; color: var(--ink); max-width: 46ch;
}
.hero-promise strong { color: var(--madder); }

.dl-row { display: flex; flex-wrap: wrap; gap: 14px; }
.hero .dl-row { min-height: 62px; align-items: center; } /* reserve box -> no font-swap CLS */
.hero-optin {
  margin-top: 16px; font-size: .98rem; color: var(--ink-soft);
  padding-top: 14px; border-top: 1px dashed var(--line);
  max-width: 46ch;
}
.hero-optin a { color: var(--madder); font-weight: 700; }

/* hero visual — framed PDF mock + angled second page */
.hero-visual { position: relative; padding: 8px 8px 26px; }
.hero-visual .mock-wrap { position: relative; }
.hero-visual .mock {
  width: 100%; aspect-ratio: 723 / 935; position: relative; z-index: 2;
  box-shadow: var(--shadow-lg);
}
.hero-visual .mock-back {
  position: absolute; z-index: 1; width: 74%; right: -14px; bottom: -18px;
  aspect-ratio: 723 / 935; transform: rotate(4deg);
  box-shadow: var(--shadow-md); border: 1px solid var(--line);
}
.hero-badge {
  position: absolute; z-index: 3; left: -10px; top: -14px;
  background: var(--madder); color: #fff;
  font-family: "Playfair Display", serif; font-weight: 700; font-size: .92rem;
  padding: 9px 15px; border-radius: 999px; box-shadow: var(--shadow-md);
  transform: rotate(-4deg);
}

/* ---------- Trust bar ---------- */
.trustbar { background: var(--ink-2); color: var(--cream); }
.trustbar .wrap { display: flex; flex-wrap: wrap; justify-content: center; gap: 16px 42px; padding: 22px 24px; }
.trustbar .ti { display: flex; align-items: center; gap: 11px; font-size: 1.04rem; }
.trustbar .ti .ic { width: 23px; height: 23px; color: var(--goldenrod); flex: 0 0 auto; }

/* ---------- Section headers ---------- */
.sec-head { max-width: 46ch; margin: 0 auto 8px; text-align: center; }
.sec-head p { color: var(--ink-soft); }

/* ---------- What's inside (D0 items) ---------- */
.items { background: var(--cream); }
.item-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; margin-top: 20px; }
.item-card {
  background: var(--paper); border: 2px solid var(--ink);
  box-shadow: inset 0 0 0 5px var(--paper), inset 0 0 0 6px var(--goldenrod), var(--shadow-sm);
  padding: 30px 26px; border-radius: var(--radius);
  display: flex; flex-direction: column;
}
.item-card .num {
  font-family: "Playfair Display", serif; font-weight: 900; font-size: 1.05rem;
  color: var(--madder); letter-spacing: .04em; margin-bottom: 8px;
}
.item-card h3 { margin-bottom: .35em; }
.item-card p { color: var(--ink-soft); font-size: 1.05rem; margin-bottom: 18px; }
.item-thumb {
  margin-top: auto; border: 1px solid var(--line);
  box-shadow: var(--shadow-sm); aspect-ratio: 723 / 935; background: #fff;
}
.item-card .pass {
  display: flex; align-items: center; gap: 8px; margin: 0 0 14px;
  font-size: .96rem; color: var(--madder); font-style: italic;
}
.item-card .pass .manicule { width: 34px; height: 34px; }
.items-cta { text-align: center; margin-top: 40px; }

/* ---------- Author ---------- */
.author { background: var(--cream-2); border-top: 2px solid var(--ink); border-bottom: 2px solid var(--ink); }
.author-grid { display: grid; grid-template-columns: 320px 1fr; gap: clamp(28px, 5vw, 56px); align-items: center; }
.author-photo {
  border-radius: var(--radius); box-shadow: var(--shadow-md);
  border: 6px solid var(--paper); outline: 2px solid var(--ink);
}
.author h2 { margin-bottom: .2em; }
.author .role { color: var(--madder); font-weight: 600; font-style: italic; margin-bottom: 1em; font-size: 1.1rem; }
.author .ai-note {
  margin-top: 18px; font-size: .92rem; color: var(--ink-soft);
  border-left: 2px solid var(--gold); padding-left: 16px;
}

/* ---------- Optional opt-in ---------- */
.optin {
  background:
    radial-gradient(900px 420px at 18% 118%, rgba(138,43,43,.10), transparent 60%),
    var(--cream);
}
.optin-box {
  max-width: 760px; margin: 0 auto; text-align: center;
  border-radius: var(--radius); padding: clamp(30px, 4vw, 48px);
}
.optin-badge {
  display: inline-block; font-family: "EB Garamond", serif;
  font-size: .82rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  color: var(--cream); background: var(--madder);
  padding: 6px 16px; border-radius: 999px; margin-bottom: 16px;
}
.optin h2 { color: var(--ink); }
.optin .sub { color: var(--ink-soft); font-size: 1.1rem; max-width: 52ch; margin: 0 auto 26px; }

.reward-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin: 0 auto 30px; max-width: 640px; text-align: left; }
.reward {
  display: flex; gap: 16px; align-items: flex-start;
  background: var(--paper); border: 1px solid var(--line);
  border-top: 3px solid var(--goldenrod);
  padding: 18px; border-radius: var(--radius); box-shadow: var(--shadow-sm);
}
.reward img { width: 74px; flex: 0 0 auto; border: 1px solid var(--line); box-shadow: var(--shadow-sm); }
.reward .rk { font-family:"Playfair Display",serif; font-weight:700; font-size:1.06rem; margin:0 0 4px; color: var(--ink); }
.reward .rp { font-size: .96rem; color: var(--ink-soft); margin: 0; line-height: 1.5; }
.reward .rt { font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color: var(--madder); font-weight:700; display:block; margin-bottom:5px; }

.optin-form { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; max-width: 540px; margin: 0 auto; }
.optin-form input[type=email] {
  flex: 1 1 260px; min-width: 0; font: inherit; font-size: 1.1rem;
  padding: 15px 18px; border: 2px solid var(--ink); border-radius: 999px;
  background: #fff; color: var(--ink);
}
.optin-form input[type=email]:focus {
  outline: none; border-color: var(--madder); box-shadow: 0 0 0 3px rgba(138,43,43,.2);
}
.optin .fineprint { font-size: .88rem; color: var(--ink-soft); margin-top: 18px; max-width: 52ch; margin-left:auto; margin-right:auto; }
.optin-msg { margin-top: 18px; font-weight: 700; min-height: 1.3em; font-size: 1.06rem; }
.optin-msg.ok { color: var(--madder); }
.optin-msg.err { color: var(--madder-dk); }

/* ---------- Final CTA ---------- */
.finalcta { background: var(--ink-2); color: var(--cream); text-align: center; }
.finalcta h2 { color: var(--cream); }
.finalcta p { color: #E7DCC4; max-width: 50ch; margin: 0 auto 24px; }
.finalcta .btn-primary { background: var(--cream); color: var(--ink); }
.finalcta .btn-primary:hover { background: #fff; }
.finalcta .cta-under { justify-content: center; color:#D6C9A8; }
.finalcta .cta-under .ic { color: var(--goldenrod); }
.finalcta .eng {
  width: 132px; margin: 0 auto 20px; mix-blend-mode: screen; opacity: .92;
}

/* ---------- Footer ---------- */
footer { background: #1A1613; color: #CFC4AC; font-size: .98rem; }
footer .wrap { padding-top: 48px; padding-bottom: 40px; }
footer .foot-h { font-family:"Playfair Display",serif; color:var(--cream); font-size:1.08rem; margin:0 0 12px; }
.ai-disclosure {
  background: rgba(255,255,255,.05); border: 1px solid rgba(218,165,32,.28);
  border-radius: var(--radius); padding: 18px 22px; margin-bottom: 30px;
  font-size: .92rem; line-height: 1.55; color: #D8CDB5;
}
.ai-disclosure strong { color: var(--cream); }
.foot-cols { display: grid; grid-template-columns: 1.6fr 1fr 1fr; gap: 30px; }
footer a { color: var(--goldenrod); }
.foot-legal {
  margin-top: 32px; padding-top: 20px; border-top: 1px solid rgba(255,255,255,.14);
  display: flex; flex-wrap: wrap; gap: 8px 24px; justify-content: space-between;
  font-size: .86rem; color: #A99C82;
}
.foot-legal a { color: #A99C82; }

/* ---------- Exit-intent popup ---------- */
.pop-overlay {
  position: fixed; inset: 0; background: rgba(26,22,19,.6);
  display: none; align-items: center; justify-content: center; z-index: 999;
  padding: 20px; backdrop-filter: blur(2px);
}
.pop-overlay.show { display: flex; }
.pop {
  background: var(--paper); border: 2px solid var(--ink);
  box-shadow: inset 0 0 0 5px var(--paper), inset 0 0 0 6px var(--goldenrod), var(--shadow-lg);
  border-radius: var(--radius); max-width: 470px; width: 100%;
  padding: 40px 32px 32px; position: relative; text-align: center;
}
.pop h3 { font-size: 1.6rem; }
.pop p { color: var(--ink-soft); }
.pop .btn { margin-top: 6px; }
.pop-optin { margin-top: 16px; font-size: .92rem; color: var(--ink-soft); }
.pop-optin a { color: var(--madder); font-weight: 700; }
.pop-close {
  position: absolute; top: 12px; right: 15px; background: none; border: none;
  font-size: 1.7rem; line-height: 1; cursor: pointer; color: var(--ink-soft);
}

/* ---------- Skip link / a11y ---------- */
.skip { position:absolute; left:-999px; top:0; background:var(--paper); padding:10px 16px; z-index:1000; border-radius:0 0 6px 0; color: var(--ink); }
.skip:focus { left:0; }
:focus-visible { outline: 3px solid var(--madder); outline-offset: 2px; }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-visual { max-width: 400px; margin: 6px auto 0; }
  .hero .lede, .hero-promise, .hero-optin { max-width: none; }
  .item-grid { grid-template-columns: 1fr; gap: 22px; }
  .item-card { max-width: 520px; margin: 0 auto; }
  .author-grid { grid-template-columns: 1fr; text-align: center; }
  .author-photo { max-width: 300px; margin: 0 auto; }
  .author .role, .author .ai-note { text-align: left; }
  .author .ai-note { max-width: 520px; margin-left: auto; margin-right: auto; }
  .reward-row { grid-template-columns: 1fr; max-width: 460px; }
  .foot-cols { grid-template-columns: 1fr; gap: 24px; }
}
@media (max-width: 460px) {
  body { font-size: 19px; }
  .wrap { padding: 0 18px; }
  .btn { width: 100%; }
  .dl-row .btn { width: 100%; }
  .trustbar .wrap { gap: 12px 26px; }
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { transition: none !important; }
}
