/* =========================================================
   HOME NOTE — shared stylesheet
   Loaded by index.html and every page in /resources/
   Brand tokens follow home_note_brand_tokens.css
   ========================================================= */
:root{
  --hn-navy:#0D1B2A;
  --hn-gold:#B8860B;
  --hn-black:#111111;
  --hn-white:#FFFFFF;
  --hn-warm-grey:#F2F2F2;
  --hn-medium-grey:#9A9A9A;

  --hn-line:#E7E4DE;
  --hn-soft-bg:#FAFAF7;
  --hn-text:#1A1A1A;
  --hn-muted:#5A5A5A;

  --font-sans:"Inter","Helvetica Neue","Neue Haas Grotesk","Avenir Next",Arial,sans-serif;

  --container:1180px;
  --container-narrow:760px;
  --gutter:clamp(20px,4vw,40px);
  --section-pad:clamp(72px,9vw,128px);
  --radius:2px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--hn-white);
  color:var(--hn-text);
  font-family:var(--font-sans);
  font-size:17px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

::selection{background:var(--hn-navy);color:var(--hn-white)}

/* ---------- Typography (architectural, logo-aligned) ---------- */
.eyebrow{
  font-family:var(--font-sans);
  font-size:11px;
  font-weight:600;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--hn-navy);
}
.eyebrow .dot{color:var(--hn-gold);margin:0 .6em;font-weight:400}

h1,h2,h3,h4{
  font-family:var(--font-sans);
  color:var(--hn-black);
  margin:0;
}
h1{font-size:clamp(36px,5.2vw,62px);line-height:1.08;letter-spacing:-0.025em;font-weight:600}
h2{font-size:clamp(28px,3.6vw,42px);line-height:1.12;letter-spacing:-0.02em;font-weight:600}
h3{font-size:clamp(20px,2vw,24px);line-height:1.25;letter-spacing:-0.01em;font-weight:600}
h4{font-size:17px;line-height:1.35;font-weight:600;letter-spacing:-0.005em}

p{margin:0 0 1em 0;color:var(--hn-text)}
.lead{font-size:clamp(17px,1.45vw,20px);line-height:1.55;color:var(--hn-text);font-weight:400;letter-spacing:-0.005em}
.muted{color:var(--hn-muted)}
.small{font-size:13px;color:var(--hn-muted);letter-spacing:0.01em}

.rule{width:48px;height:2px;background:var(--hn-gold);border:0;margin:0 0 28px 0;display:block}
.rule.center{margin-left:auto;margin-right:auto}

.num{font-family:var(--font-sans);font-weight:500;letter-spacing:-0.03em;font-feature-settings:"tnum" 1, "lnum" 1}

/* ---------- Layout ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.container.narrow{max-width:var(--container-narrow)}
section{padding:var(--section-pad) 0}
.section-divider{border:0;border-top:1px solid var(--hn-line);margin:0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  height:50px;padding:0 26px;border-radius:var(--radius);
  font-family:var(--font-sans);font-size:13px;font-weight:600;
  letter-spacing:0.1em;text-transform:uppercase;
  border:1px solid transparent;cursor:pointer;
  transition:background-color .2s ease,color .2s ease,border-color .2s ease,transform .2s ease;
  white-space:nowrap;
}
.btn-primary{background:var(--hn-gold);color:#fff}
.btn-primary:hover{background:#a3770a}
.btn-ghost{background:transparent;color:var(--hn-black);border-color:var(--hn-black)}
.btn-ghost:hover{background:var(--hn-black);color:#fff}
.btn-on-navy-primary{background:var(--hn-gold);color:#fff}
.btn-on-navy-primary:hover{background:#cf980f}
.btn-on-navy-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn-on-navy-ghost:hover{background:#fff;color:var(--hn-navy);border-color:#fff}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--hn-line);
}
.site-header .row{display:flex;align-items:center;justify-content:space-between;height:72px;gap:24px}
.brand{display:inline-flex;align-items:center;gap:0;line-height:1}
.brand svg{height:28px;width:auto;display:block}
nav.primary{display:flex;align-items:center;gap:28px}
nav.primary a{font-size:13.5px;font-weight:500;color:#222;letter-spacing:0.005em;padding:8px 0;position:relative}
nav.primary a:hover{color:var(--hn-navy)}
nav.primary a:hover::after{content:"";position:absolute;left:0;right:0;bottom:2px;height:1px;background:var(--hn-gold)}
.header-cta{display:flex;align-items:center;gap:12px}
.header-cta .btn{height:42px;padding:0 18px;font-size:11px}
.menu-btn{
  display:none;width:42px;height:42px;border:1px solid var(--hn-line);
  background:#fff;border-radius:var(--radius);cursor:pointer;
  align-items:center;justify-content:center;
}
.menu-btn span{display:block;width:18px;height:1.5px;background:var(--hn-black);position:relative}
.menu-btn span::before,.menu-btn span::after{content:"";position:absolute;left:0;width:18px;height:1.5px;background:var(--hn-black)}
.menu-btn span::before{top:-6px}
.menu-btn span::after{top:6px}

.mobile-nav{display:none;border-top:1px solid var(--hn-line);background:#fff;padding:8px 0 16px}
.mobile-nav a{display:block;padding:12px var(--gutter);font-size:15px;font-weight:500;color:#222;border-bottom:1px solid var(--hn-line);letter-spacing:0.005em}
.mobile-nav a:last-child{border-bottom:0}
.mobile-nav.open{display:block}

/* ---------- Hero (home) ---------- */
.hero{padding:clamp(56px,8vw,104px) 0 clamp(64px,9vw,112px)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}
.hero h1 .accent{border-bottom:2px solid var(--hn-gold);padding-bottom:0.06em;display:inline}
.hero .lead{margin-top:22px;max-width:52ch}
.hero .specifics{
  margin-top:28px;color:var(--hn-text);
  font-size:14px;line-height:1.9;max-width:60ch;
  letter-spacing:0.01em;display:flex;flex-wrap:wrap;gap:6px 0;
}
.hero .specifics .chip{
  display:inline-flex;align-items:center;
  padding:6px 12px;border:1px solid var(--hn-line);
  margin-right:6px;color:var(--hn-black);font-weight:500;background:#fff;
}
.hero .ctas{margin-top:34px;display:flex;flex-wrap:wrap;gap:14px}
.hero .trust{
  margin-top:28px;font-size:12px;color:var(--hn-muted);
  display:flex;flex-wrap:wrap;gap:22px;align-items:center;
  letter-spacing:0.06em;text-transform:uppercase;font-weight:500;
}
.hero .trust .pip{display:inline-flex;align-items:center;gap:10px}
.hero .trust .pip::before{content:"";width:6px;height:1.5px;background:var(--hn-gold)}

.hero-art{position:relative;aspect-ratio: 5 / 6;background:var(--hn-soft-bg);border:1px solid var(--hn-line);overflow:hidden}
.hero-art img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 62%;filter:saturate(0.95) contrast(1.02)}
.hero-art .caption{
  position:absolute;left:18px;bottom:14px;
  font-size:10px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--hn-black);background:rgba(255,255,255,.9);
  padding:8px 12px;font-weight:600;
}
.hero-art .frame-line{position:absolute;left:18px;top:18px;width:34px;height:2px;background:var(--hn-gold);z-index:2}

/* ---------- Two-column editorial ---------- */
.two-col{display:grid;grid-template-columns:5fr 7fr;gap:clamp(28px,5vw,80px);align-items:start}
.two-col .side h2{margin-bottom:18px}

/* ---------- Problem section ---------- */
.problem p{font-size:18px;color:var(--hn-text);max-width:62ch}

/* ---------- Core product card ---------- */
.product{background:#fff;border:1px solid var(--hn-line);padding:clamp(28px,4vw,56px);display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,4vw,56px);align-items:start}
.product .price-block{border-left:1px solid var(--hn-line);padding-left:clamp(20px,3vw,40px)}
.product .price{
  font-family:var(--font-sans);font-size:clamp(44px,5vw,60px);line-height:1;color:var(--hn-black);
  letter-spacing:-0.035em;font-weight:500;font-feature-settings:"tnum" 1, "lnum" 1;
}
.product .price small{font-size:12px;color:var(--hn-muted);letter-spacing:0.14em;text-transform:uppercase;display:block;margin-top:10px;font-weight:500}
.deliverables{list-style:none;padding:0;margin:24px 0 0 0;display:grid;grid-template-columns:1fr 1fr;gap:10px 28px}
.deliverables li{position:relative;padding-left:22px;font-size:15px;line-height:1.5;color:var(--hn-text)}
.deliverables li::before{content:"";position:absolute;left:0;top:.7em;width:10px;height:1.5px;background:var(--hn-gold)}
.product .cta-row{margin-top:28px;display:flex;gap:12px;flex-wrap:wrap}

/* ---------- Compare ---------- */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:36px}
.compare .card{border:1px solid var(--hn-line);padding:32px;background:#fff}
.compare .card.hn{border-color:var(--hn-black)}
.compare .label{font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--hn-muted);margin-bottom:18px;display:flex;align-items:center;gap:10px;font-weight:600}
.compare .label::before{content:"";width:18px;height:1.5px;background:var(--hn-medium-grey)}
.compare .card.hn .label{color:var(--hn-navy)}
.compare .card.hn .label::before{background:var(--hn-gold);width:26px;height:2px}
.compare h3{font-size:18px;font-weight:600;letter-spacing:-0.01em;margin-bottom:14px}
.compare ul{list-style:none;padding:0;margin:0}
.compare ul li{padding:10px 0;border-bottom:1px solid var(--hn-line);font-size:15px;display:flex;gap:10px;align-items:flex-start}
.compare ul li:last-child{border-bottom:0}
.compare ul li::before{content:"";flex:0 0 auto;width:6px;height:6px;border-radius:50%;background:var(--hn-medium-grey);margin-top:.55em}
.compare .card.hn ul li::before{background:var(--hn-gold)}

/* ---------- Sample report preview ---------- */
.preview-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(24px,4vw,56px);align-items:stretch;margin-top:48px}
.doc{background:#fff;border:1px solid var(--hn-line);box-shadow:0 30px 60px -30px rgba(13,27,42,0.18),0 12px 24px -16px rgba(13,27,42,0.08);padding:0;aspect-ratio: 3 / 4;position:relative;overflow:hidden}
.doc .doc-inner{padding:clamp(22px,3vw,40px);height:100%;display:flex;flex-direction:column}
.doc-cover .header-mark{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--hn-line);padding-bottom:14px}
.doc-cover .mark{font-weight:600;letter-spacing:0.08em;font-size:12px;color:var(--hn-black)}
.doc-cover .mark .n{position:relative;display:inline-block}
.doc-cover .mark .n::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--hn-gold)}
.doc-cover .ref{font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--hn-muted);font-weight:500}
.doc-cover .kicker{margin-top:clamp(18px,3vw,30px);font-size:10px;letter-spacing:0.26em;text-transform:uppercase;color:var(--hn-gold);font-weight:600}
.doc-cover .title{font-size:clamp(20px,2.4vw,28px);line-height:1.1;margin-top:10px;color:var(--hn-black);font-weight:600;letter-spacing:-0.02em}
.doc-cover .meta{margin-top:auto;display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;border-top:1px solid var(--hn-line);padding-top:14px;font-size:11.5px;color:var(--hn-muted)}
.doc-cover .meta b{color:var(--hn-black);font-weight:600;display:block;font-size:10px;letter-spacing:0.18em;text-transform:uppercase}
.doc-cover .photo{flex:1;margin:18px 0;background:var(--hn-soft-bg);position:relative;overflow:hidden;border:1px solid var(--hn-line);min-height:140px}
.doc-cover .photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 55%;filter:saturate(0.95) contrast(1.02)}

.doc-inside .section-h{font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--hn-muted);border-bottom:1px solid var(--hn-line);padding-bottom:8px;margin-bottom:14px;display:flex;justify-content:space-between;font-weight:600}
.doc-inside .rows{display:flex;flex-direction:column;gap:14px}
.doc-inside .row{display:grid;grid-template-columns:1fr auto;gap:8px 12px;padding-bottom:10px;border-bottom:1px dashed var(--hn-line)}
.doc-inside .row:last-child{border-bottom:0}
.doc-inside .row .k{font-size:10px;color:var(--hn-muted);letter-spacing:0.18em;text-transform:uppercase;font-weight:600}
.doc-inside .row .v{font-size:clamp(15px,1.6vw,18px);color:var(--hn-black);font-weight:500;letter-spacing:-0.015em;margin-top:4px;font-feature-settings:"tnum" 1, "lnum" 1}
.doc-inside .row .sample{font-size:9.5px;color:var(--hn-muted);letter-spacing:0.18em;text-transform:uppercase;font-weight:500}
.doc-inside .bar{height:6px;background:var(--hn-warm-grey);border-radius:3px;position:relative;margin-top:8px;overflow:hidden}
.doc-inside .bar i{position:absolute;left:18%;right:32%;top:0;bottom:0;background:var(--hn-gold);border-radius:3px;display:block}
.doc-inside .bar .marker{position:absolute;left:46%;top:-3px;bottom:-3px;width:2px;background:var(--hn-navy)}
.doc-inside .flags{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.doc-inside .flag{font-size:12px;display:flex;gap:8px;align-items:flex-start;color:var(--hn-text)}
.doc-inside .flag::before{content:"";flex:0 0 auto;width:6px;height:6px;background:var(--hn-gold);margin-top:.55em;border-radius:50%}
.doc-inside .next-step{margin-top:14px;background:var(--hn-soft-bg);padding:12px 14px;border-left:2px solid var(--hn-gold);font-size:12.5px;color:var(--hn-black)}
.doc-inside .next-step b{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;display:block;color:var(--hn-navy);margin-bottom:4px;font-weight:600}

.preview-caption{margin-top:20px;font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--hn-muted);text-align:center;font-weight:500}

/* ---------- How it works ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:36px}
.step{border-top:1px solid var(--hn-line);padding-top:24px}
.step .num{font-size:13px;color:var(--hn-gold);letter-spacing:0.22em;font-weight:600}
.step h4{margin-top:14px;font-size:20px;font-weight:600;letter-spacing:-0.015em}
.step p{margin-top:8px;font-size:14.5px;color:var(--hn-muted);line-height:1.6}

/* ---------- Buyer-side stripe ---------- */
.buyer-side{background:var(--hn-soft-bg);border-top:1px solid var(--hn-line);border-bottom:1px solid var(--hn-line)}
.buyer-side .two-col{align-items:center}
.buyer-side .points{list-style:none;padding:0;margin:0}
.buyer-side .points li{padding:14px 0;border-bottom:1px solid var(--hn-line);font-size:16px;display:flex;gap:14px;align-items:flex-start}
.buyer-side .points li:last-child{border-bottom:0}
.buyer-side .points li b{font-weight:600;color:var(--hn-black);display:block;margin-bottom:2px;letter-spacing:-0.005em}
.buyer-side .points li::before{content:"";flex:0 0 auto;width:18px;height:2px;background:var(--hn-gold);margin-top:.7em}

/* ---------- Founder ---------- */
.founder{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(28px,5vw,72px);align-items:center}
.founder .photo{aspect-ratio: 4 / 5;background:var(--hn-soft-bg);border:1px solid var(--hn-line);position:relative;overflow:hidden}
.founder .photo svg,.founder .photo img{position:absolute;inset:0;width:100%;height:100%}
.founder .photo img{object-fit:cover;object-position:center top}
.founder .photo .badge{position:absolute;left:18px;bottom:18px;background:#fff;padding:9px 12px;font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--hn-black);border:1px solid var(--hn-line);font-weight:600;z-index:2}
.founder blockquote{margin:18px 0 0 0;padding:0 0 0 18px;border:0;border-left:2px solid var(--hn-gold);font-size:clamp(19px,1.7vw,22px);line-height:1.45;color:var(--hn-black);font-weight:500;letter-spacing:-0.015em}
.signature{margin-top:24px}
.signature .name{font-weight:600;color:var(--hn-black);letter-spacing:-0.005em}
.signature .role{color:var(--hn-muted);font-size:14px;margin-top:2px}

/* ---------- Price section ---------- */
.price-section{background:#fff}
.price-card{border:1px solid var(--hn-line);max-width:820px;margin:36px auto 0;padding:clamp(28px,4vw,48px);text-align:left}
.price-card .head{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;border-bottom:1px solid var(--hn-line);padding-bottom:24px;flex-wrap:wrap}
.price-card .head .title{font-size:24px;color:var(--hn-black);font-weight:600;letter-spacing:-0.015em;line-height:1.2}
.price-card .head .amount{font-size:clamp(40px,4.4vw,52px);color:var(--hn-black);font-weight:500;letter-spacing:-0.035em;line-height:1;font-feature-settings:"tnum" 1, "lnum" 1}
.price-card .head .amount small{font-size:11px;color:var(--hn-muted);letter-spacing:0.18em;text-transform:uppercase;display:block;margin-top:8px;font-weight:600}
.price-card ul.deliverables{margin-top:24px}
.price-card .cta-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:28px;border-top:1px solid var(--hn-line);padding-top:24px}
.price-card .cta-row .small{margin-left:auto;max-width:42ch}

/* ---------- Optional support ---------- */
.support-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin-top:40px;background:var(--hn-line);border:1px solid var(--hn-line)}
.support-item{background:#fff;padding:28px 24px;display:flex;flex-direction:column;gap:8px}
.support-item .icon{width:26px;height:26px;color:var(--hn-gold)}
.support-item h4{font-size:15px;font-weight:600;color:var(--hn-black);margin-top:6px;letter-spacing:-0.005em}
.support-item p{font-size:13.5px;color:var(--hn-muted);line-height:1.55;margin:0}

/* ---------- FAQ ---------- */
.faq-grid{max-width:820px;margin:36px auto 0}
details.faq{border-bottom:1px solid var(--hn-line);padding:8px 0}
details.faq[open]{padding-bottom:16px}
details.faq summary{list-style:none;cursor:pointer;padding:20px 40px 20px 0;position:relative;font-size:18px;color:var(--hn-black);font-weight:600;letter-spacing:-0.015em;line-height:1.4}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-weight:300;font-size:22px;color:var(--hn-gold);line-height:1;transition:transform .2s ease}
details.faq[open] summary::after{content:"–"}
details.faq .a{font-size:15.5px;color:var(--hn-text);max-width:68ch;line-height:1.65}

/* ---------- Final CTA (single navy accent section) ---------- */
.final{background:var(--hn-navy);color:#fff;border:0}
.final .container{text-align:center;max-width:880px}
.final .eyebrow{color:rgba(255,255,255,.78)}
.final .eyebrow .dot{color:var(--hn-gold)}
.final .rule{background:var(--hn-gold);margin:0 auto 28px}
.final h2{color:#fff;max-width:18ch;margin:0 auto;letter-spacing:-0.02em}
.final p.lead{color:rgba(255,255,255,.82);margin:22px auto 0;max-width:54ch}
.final .ctas{margin-top:34px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.final .trust{margin-top:24px;font-size:11px;color:rgba(255,255,255,.6);letter-spacing:0.22em;text-transform:uppercase;font-weight:500}

/* ---------- Contact / form ---------- */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(28px,5vw,72px);align-items:start;margin-top:40px}
form.send{display:grid;grid-template-columns:1fr 1fr;gap:18px;background:#fff;border:1px solid var(--hn-line);padding:clamp(24px,3vw,40px)}
form.send .full{grid-column:1 / -1}
form.send label{display:block;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--hn-muted);margin-bottom:8px;font-weight:600}
form.send input,form.send select,form.send textarea{width:100%;border:0;border-bottom:1px solid var(--hn-line);background:transparent;padding:10px 0 12px;font-family:inherit;font-size:15px;color:var(--hn-black);border-radius:0;outline:none;letter-spacing:-0.005em}
form.send textarea{min-height:96px;resize:vertical;line-height:1.5}
form.send input:focus,form.send select:focus,form.send textarea:focus{border-bottom-color:var(--hn-gold)}
form.send select{appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg,transparent 50%,#999 50%),linear-gradient(135deg,#999 50%,transparent 50%);background-position:calc(100% - 14px) 18px,calc(100% - 9px) 18px;background-size:5px 5px,5px 5px;background-repeat:no-repeat}
form.send .submit-row{grid-column:1 / -1;display:flex;align-items:center;gap:16px;flex-wrap:wrap;border-top:1px solid var(--hn-line);padding-top:20px;margin-top:6px}
form.send .submit-row .small{margin-left:auto;max-width:42ch}

.contact-aside .item{padding:18px 0;border-bottom:1px solid var(--hn-line)}
.contact-aside .item:last-child{border-bottom:0}
.contact-aside .k{font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--hn-muted);margin-bottom:6px;font-weight:600}
.contact-aside .v{font-size:15px;color:var(--hn-black);letter-spacing:-0.005em}

/* ---------- Insights / Resources grid (on index) ---------- */
.insights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,32px);margin-top:40px}
.insight-card{background:#fff;border:1px solid var(--hn-line);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s ease, box-shadow .25s ease}
.insight-card:hover{transform:translateY(-2px);box-shadow:0 18px 40px -22px rgba(13,27,42,0.18)}
.insight-card .img{aspect-ratio: 16 / 10;overflow:hidden;background:var(--hn-soft-bg);position:relative}
.insight-card .img img{width:100%;height:100%;object-fit:cover;filter:saturate(0.95) contrast(1.02);transition:transform .6s ease}
.insight-card:hover .img img{transform:scale(1.03)}
.insight-card .body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.insight-card .topic{font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--hn-gold);font-weight:600;margin-bottom:10px}
.insight-card h3{font-size:19px;line-height:1.3;letter-spacing:-0.015em;color:var(--hn-black)}
.insight-card p{font-size:14.5px;color:var(--hn-muted);line-height:1.55;margin:10px 0 16px}
.insight-card .read{margin-top:auto;font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--hn-black);font-weight:600;display:inline-flex;align-items:center;gap:8px}
.insight-card .read::after{content:"→";color:var(--hn-gold);transition:transform .2s ease}
.insight-card:hover .read::after{transform:translateX(3px)}

/* ---------- Footer ---------- */
footer.site-footer{background:#fff;border-top:1px solid var(--hn-line);padding:56px 0 32px}
.footer-grid{display:grid;grid-template-columns:1.4fr .8fr .8fr 1fr;gap:32px}
.footer-grid h5{font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--hn-muted);margin:0 0 14px;font-weight:600}
.footer-grid a{display:block;font-size:14px;color:var(--hn-text);padding:5px 0}
.footer-grid a:hover{color:var(--hn-gold)}
.footer-brand .tagline{font-size:10px;letter-spacing:0.26em;text-transform:uppercase;color:var(--hn-muted);margin-top:14px;font-weight:600}
.footer-brand p{font-size:14px;color:var(--hn-muted);margin-top:14px;max-width:36ch}
.footer-bottom{border-top:1px solid var(--hn-line);margin-top:40px;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--hn-muted);letter-spacing:0.04em}

/* ---------- Animations ---------- */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* =========================================================
   ARTICLE PAGES (/resources/*.html)
   ========================================================= */
.article-hero{padding:clamp(48px,7vw,88px) 0 clamp(36px,5vw,64px);border-bottom:1px solid var(--hn-line)}
.article-hero .crumbs{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--hn-muted);font-weight:600;margin-bottom:24px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.article-hero .crumbs a{color:var(--hn-muted)}
.article-hero .crumbs a:hover{color:var(--hn-gold)}
.article-hero .crumbs .sep{color:var(--hn-line)}
.article-hero h1{max-width:22ch;letter-spacing:-0.028em}
.article-hero .lead{margin-top:22px;max-width:62ch;color:var(--hn-text)}
.article-hero .meta-row{margin-top:28px;display:flex;flex-wrap:wrap;gap:22px;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--hn-muted);font-weight:600;border-top:1px solid var(--hn-line);padding-top:18px}
.article-hero .meta-row .gold{color:var(--hn-gold)}

.article-figure{margin-top:clamp(28px,4vw,48px);position:relative}
.article-figure .frame{position:relative;border:1px solid var(--hn-line);overflow:hidden;aspect-ratio: 16 / 9;background:var(--hn-soft-bg)}
.article-figure img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(0.95) contrast(1.02)}
.article-figure figcaption{margin-top:12px;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--hn-muted);font-weight:600}

.article-body{padding:clamp(48px,7vw,88px) 0}
.article-body .prose{max-width:680px;margin:0 auto}
.article-body .prose p{font-size:17.5px;line-height:1.75;color:var(--hn-text);margin:0 0 1.1em}
.article-body .prose h2{font-size:clamp(24px,2.6vw,30px);line-height:1.2;letter-spacing:-0.02em;margin:48px 0 18px;padding-top:18px;border-top:1px solid var(--hn-line)}
.article-body .prose h2:first-child{border-top:0;padding-top:0;margin-top:0}
.article-body .prose h3{font-size:19px;font-weight:600;letter-spacing:-0.01em;margin:28px 0 10px}
.article-body .prose ul,.article-body .prose ol{margin:0 0 1.2em;padding-left:0;list-style:none}
.article-body .prose ul li,.article-body .prose ol li{position:relative;padding:6px 0 6px 26px;font-size:16.5px;line-height:1.6;color:var(--hn-text);border-bottom:1px solid var(--hn-line)}
.article-body .prose ul li:last-child,.article-body .prose ol li:last-child{border-bottom:0}
.article-body .prose ul li::before{content:"";position:absolute;left:0;top:1.05em;width:12px;height:1.5px;background:var(--hn-gold)}
.article-body .prose ol{counter-reset:hn-list}
.article-body .prose ol li::before{
  counter-increment:hn-list;content:counter(hn-list,decimal-leading-zero);
  position:absolute;left:0;top:.5em;font-size:11px;letter-spacing:0.12em;font-weight:600;color:var(--hn-gold);
}
.article-body .prose blockquote{
  margin:32px 0;padding:6px 0 6px 22px;border-left:2px solid var(--hn-gold);
  font-size:21px;line-height:1.45;color:var(--hn-black);font-weight:500;letter-spacing:-0.015em;
}
.article-body .prose strong{font-weight:600;color:var(--hn-black)}
.article-body .prose .callout{
  margin:32px 0;padding:22px 24px;background:var(--hn-soft-bg);border:1px solid var(--hn-line);
  border-left:2px solid var(--hn-gold);
}
.article-body .prose .callout .k{font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--hn-navy);font-weight:600;margin-bottom:8px}
.article-body .prose .callout p{margin:0;font-size:16px}
.article-body .prose .signoff{
  margin-top:48px;padding-top:24px;border-top:1px solid var(--hn-line);
  display:flex;gap:14px;align-items:center;flex-wrap:wrap;
  font-size:13px;letter-spacing:0.06em;color:var(--hn-muted);
}
.article-body .prose .signoff .name{font-weight:600;color:var(--hn-black);letter-spacing:-0.005em}

/* Inline CTA inside articles */
.article-cta{background:var(--hn-soft-bg);border-top:1px solid var(--hn-line);border-bottom:1px solid var(--hn-line);padding:clamp(40px,6vw,72px) 0}
.article-cta .container{max-width:760px;text-align:left;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center}
.article-cta h3{font-size:clamp(20px,2.2vw,26px);letter-spacing:-0.02em;line-height:1.25;color:var(--hn-black)}
.article-cta p{margin:8px 0 0;color:var(--hn-muted);font-size:15px;max-width:48ch}
.article-cta .row{display:flex;gap:12px;flex-wrap:wrap}

/* Related articles */
.related{padding:clamp(56px,8vw,96px) 0;border-top:1px solid var(--hn-line)}
.related .head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:32px}
.related .head h2{font-size:clamp(22px,2.4vw,28px);letter-spacing:-0.02em}
.related .head a{font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--hn-black);font-weight:600;border-bottom:1px solid var(--hn-gold);padding-bottom:2px}

/* ---------- Responsive ---------- */
@media (max-width: 1024px){
  .product{grid-template-columns:1fr}
  .product .price-block{border-left:0;border-top:1px solid var(--hn-line);padding:24px 0 0;padding-left:0;margin-top:8px}
  .deliverables{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:repeat(2,1fr)}
  .support-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .insights-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 880px){
  nav.primary,.header-cta .btn{display:none}
  .menu-btn{display:inline-flex}
  .hero-grid,.two-col,.preview-grid,.founder,.contact-grid{grid-template-columns:1fr}
  .compare{grid-template-columns:1fr}
  .hero-art{aspect-ratio: 4 / 3}
  form.send{grid-template-columns:1fr}
  .deliverables{grid-template-columns:1fr}
  .price-card .head{flex-direction:column}
  .article-cta .container{grid-template-columns:1fr}
}
@media (max-width: 560px){
  .steps{grid-template-columns:1fr}
  .support-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .insights-grid{grid-template-columns:1fr}
  .hero .ctas .btn{flex:1 1 100%}
}

@media print{
  .site-header,.final,form.send,.menu-btn,.article-cta,.related{display:none}
  body{font-size:12pt}
  .article-body .prose{max-width:none}
}
