/* ============================================================
   Plaza Sites — Option 4 design system
   Editorial. Cream + ink + terracotta. Fraunces + Inter Tight + JetBrains Mono.
   ============================================================ */

*{box-sizing:border-box;margin:0;padding:0}
:root{
  --paper:#f1ede7;
  --paper-2:#ebe6dd;
  --paper-3:#e3ddd1;
  --ink:#1c1917;
  --ink-2:#3d3a35;
  --mute:#8a8579;
  --line:#d8d1c1;
  --accent:#b8442e;
  --accent-soft:#d76a4d;
  --shadow:0 24px 60px -22px rgba(28,24,23,.22);
}
html,body{background:var(--paper);color:var(--ink);font-family:'Inter Tight',system-ui,sans-serif;font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.55;font-size:16px;letter-spacing:-.005em}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.italic{font-style:italic;font-family:'Fraunces',serif;font-weight:400}
.mono{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:var(--mute)}
.serif{font-family:'Fraunces',serif;font-weight:300;letter-spacing:-.02em}

/* ───────── Nav ───────── */
header.nav{position:fixed;top:0;left:0;right:0;z-index:50;padding:18px 32px;display:flex;align-items:center;justify-content:space-between;color:#fff;transition:all .35s ease;background:linear-gradient(180deg,rgba(28,24,23,.45) 0%,rgba(28,24,23,0) 100%);border-bottom:0px solid transparent}
header.nav.solid{color:var(--ink);background:rgba(241,237,231,.94);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:14px 32px}
/* On non-hero subpages, force solid look at top */
body.subpage:not(.bleed-hero) header.nav{color:var(--ink);background:rgba(241,237,231,.94);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:14px 32px;background-image:none}
body.subpage:not(.bleed-hero) header.nav .cta{background:var(--ink);color:var(--paper);border-color:var(--ink)}
/* Bleed-hero subpages: transparent nav over photo */
body.subpage.bleed-hero header.nav{border-bottom:0px solid transparent}
/* Bleed-hero subpages: solid on scroll */
body.subpage.bleed-hero header.nav.solid{color:var(--ink);background:rgba(241,237,231,.94);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:14px 32px}
body.subpage.bleed-hero header.nav.solid .cta{background:var(--ink);color:var(--paper);border-color:var(--ink)}
body.subpage.bleed-hero header.nav.solid .nav-avatar{background:var(--ink);color:var(--paper);border-color:var(--ink)}
header.nav .brand{display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-weight:400;font-size:22px;letter-spacing:-.02em}
header.nav .brand .dot{width:9px;height:9px;border-radius:50%;background:var(--accent);display:inline-block}
header.nav .links{display:flex;gap:34px;font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em}
header.nav .links a{position:relative;padding:4px 0}
header.nav .links a::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .35s cubic-bezier(.2,.7,.2,1)}
header.nav .links a:hover::after{transform:scaleX(1)}
header.nav .cta-group{display:flex;align-items:center;gap:14px}
header.nav .cta{font-family:'Inter Tight',sans-serif;font-weight:500;font-size:13px;letter-spacing:0;padding:10px 18px;border:1px solid currentColor;border-radius:999px;transition:all .3s ease;background:transparent}
header.nav.solid .cta{background:var(--ink);color:var(--paper);border-color:var(--ink)}
header.nav .cta:hover{background:var(--accent);border-color:var(--accent);color:#fff}
header.nav .log{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;opacity:.85}
header.nav .log:hover{opacity:1;color:var(--accent)}
header.nav .nav-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.18);color:#fff;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.06em;border:1px solid currentColor;text-decoration:none}
header.nav.solid .nav-avatar, body.subpage header.nav .nav-avatar{background:var(--ink);color:var(--paper);border-color:var(--ink)}
header.nav .nav-avatar img{width:100%;height:100%;object-fit:cover}
header.nav .nav-avatar svg{width:100%;height:100%;display:block}

/* ───────── Subpage hero (smaller than homepage cinematic) ───────── */
.page-hero{padding:160px 0 96px;border-bottom:1px solid var(--line);position:relative}
.page-hero .eye{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--mute);display:flex;align-items:center;gap:14px;margin-bottom:24px}
.page-hero .eye::before{content:"";width:36px;height:1px;background:var(--mute)}
.page-hero .eye .num{color:var(--accent)}
.page-hero h1{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(40px,5.8vw,84px);line-height:1.04;letter-spacing:-.025em;max-width:1100px}
.page-hero h1 em{font-style:italic;color:var(--accent);font-weight:300}
.page-hero .lede{margin-top:32px;display:grid;grid-template-columns:1fr 420px;gap:80px;align-items:end}
.page-hero .lede p{font-size:18px;line-height:1.6;color:var(--ink-2);max-width:620px}
.page-hero .lede .side{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--mute);line-height:1.9;border-left:1px solid var(--line);padding-left:24px}
.page-hero .lede .side b{display:block;color:var(--ink);font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:24px;letter-spacing:-.02em;text-transform:none;line-height:1.2;margin-top:6px}
.page-hero .ctas{margin-top:44px;display:flex;gap:14px;flex-wrap:wrap}
.page-hero .ctas a{font-family:'Inter Tight',sans-serif;font-weight:500;font-size:14px;padding:14px 26px;border-radius:999px;transition:all .3s ease;display:inline-flex;align-items:center;gap:10px}
.page-hero .ctas .p{background:var(--ink);color:var(--paper)}
.page-hero .ctas .p:hover{background:var(--accent)}
.page-hero .ctas .s{border:1px solid var(--ink);color:var(--ink)}
.page-hero .ctas .s:hover{background:var(--ink);color:var(--paper)}
.page-hero .ctas .ghost{color:var(--ink);border-bottom:1px solid var(--ink);padding:4px 0;border-radius:0}
.page-hero .ctas .ghost:hover{color:var(--accent);border-color:var(--accent)}

/* ───────── Section frame ───────── */
.wrap{max-width:1320px;margin:0 auto;padding:0 32px}
.wrap-narrow{max-width:960px;margin:0 auto;padding:0 32px}
section{padding:120px 0;position:relative}
.eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--mute);display:flex;align-items:center;gap:14px;margin-bottom:32px}
.eyebrow::before{content:"";width:36px;height:1px;background:var(--mute)}
.eyebrow .num{color:var(--accent)}
.section-head h2{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(36px,4.8vw,68px);line-height:1.05;letter-spacing:-.025em;max-width:900px}
.section-head h2 em{font-style:italic;color:var(--accent)}
.section-head .sub{margin-top:18px;font-size:17px;color:var(--ink-2);line-height:1.6;max-width:680px}

/* ───────── Editorial table / pricing card row ───────── */
.tiers{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);margin-top:48px}
.tier{padding:36px 28px;border-right:1px solid var(--line);position:relative;transition:background .35s ease;display:flex;flex-direction:column}
.tier:last-child{border-right:none}
.tier:hover{background:var(--paper-2)}
.tier .top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:22px;flex-wrap:wrap;gap:8px}
.tier .top .nm{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--ink)}
.tier .top .nm .badge{display:inline-block;margin-left:8px;padding:3px 8px;background:var(--accent);color:#fff;border-radius:999px;font-size:9px;letter-spacing:.16em}
.tier .top .nm .badge.alt{background:var(--ink)}
.tier .price{font-family:'Fraunces',serif;font-weight:300;font-size:56px;letter-spacing:-.03em;line-height:1}
.tier .price em{font-family:'Fraunces',serif;font-style:italic}
.tier .price .per{font-size:13px;color:var(--mute);font-family:'JetBrains Mono',monospace;letter-spacing:.12em;text-transform:uppercase;margin-left:6px;font-weight:400}
.tier .desc{margin-top:14px;font-size:14px;color:var(--ink-2);line-height:1.55;min-height:64px}
.tier ul{margin-top:22px;list-style:none;border-top:1px dashed var(--line);padding-top:18px;flex:1}
.tier ul li{padding:9px 0;font-size:13px;color:var(--ink-2);display:flex;gap:10px;border-bottom:1px dashed var(--line)}
.tier ul li:last-child{border-bottom:none}
.tier ul li::before{content:"+";color:var(--accent);font-family:'JetBrains Mono',monospace;font-size:11px;flex-shrink:0;padding-top:1px}
.tier .btn{margin-top:26px;display:inline-flex;align-items:center;gap:10px;font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--ink);padding-bottom:6px;border-bottom:1px solid var(--ink);transition:gap .35s ease, color .25s ease;align-self:flex-start}
.tier .btn:hover{gap:18px;color:var(--accent);border-color:var(--accent)}

/* ───────── Editorial 3-col / 2-col blocks ───────── */
.block-3{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.block-3 .b{padding:36px 32px 36px 0;border-right:1px solid var(--line);position:relative}
.block-3 .b:last-child{border-right:none;padding-right:0}
.block-3 .b:nth-child(n+2){padding-left:32px}
.block-3 .b .k{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--accent);margin-bottom:18px;display:flex;justify-content:space-between}
.block-3 .b h3{font-family:'Fraunces',serif;font-weight:300;font-size:28px;letter-spacing:-.02em;line-height:1.15;margin-bottom:10px}
.block-3 .b h3 em{font-style:italic;color:var(--accent)}
.block-3 .b p{font-size:14px;color:var(--ink-2);line-height:1.6}

.block-2{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.block-2 .b{padding:48px 48px 48px 0;border-right:1px solid var(--line)}
.block-2 .b:last-child{border-right:none;padding-left:48px;padding-right:0}
.block-2 .b .k{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--accent);margin-bottom:18px}
.block-2 .b h3{font-family:'Fraunces',serif;font-weight:300;font-size:34px;letter-spacing:-.02em;line-height:1.15;margin-bottom:14px}
.block-2 .b h3 em{font-style:italic;color:var(--accent)}
.block-2 .b p{font-size:15px;color:var(--ink-2);line-height:1.65}
.block-2 .b p + p{margin-top:14px}

/* ───────── Editorial proof aside ───────── */
.aside{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;padding:80px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.aside .quote{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(28px,3.6vw,44px);line-height:1.18;letter-spacing:-.02em}
.aside .quote em{font-style:italic;color:var(--accent)}
.aside .who{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--mute);line-height:1.9}
.aside .who b{display:block;color:var(--ink);font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:24px;letter-spacing:-.02em;text-transform:none;line-height:1.2;margin-top:6px}

/* ───────── FAQ accordion ───────── */
.faq{border-top:1px solid var(--line);margin-top:32px}
.faq details{border-bottom:1px solid var(--line);padding:24px 0;cursor:pointer}
.faq summary{font-family:'Fraunces',serif;font-weight:300;font-size:22px;letter-spacing:-.02em;line-height:1.3;display:flex;justify-content:space-between;gap:24px;list-style:none;align-items:flex-start}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--accent);font-family:'JetBrains Mono',monospace;font-size:18px;transition:transform .25s ease;flex-shrink:0}
.faq details[open] summary::after{content:"−"}
.faq .answer{margin-top:14px;font-size:15px;color:var(--ink-2);line-height:1.65;max-width:780px}
.faq .answer p{margin-bottom:10px}
.faq .answer p:last-child{margin-bottom:0}
.faq .answer a{color:var(--accent);border-bottom:1px solid var(--accent)}
.faq .answer ul, .faq .answer ol{margin:8px 0 8px 22px}
.faq .answer li{margin-bottom:6px}

/* ───────── Closer ───────── */
.closer{padding:160px 0 140px;border-top:1px solid var(--line);text-align:center}
.closer h2{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(44px,6vw,92px);line-height:1.02;letter-spacing:-.03em;max-width:1100px;margin:0 auto}
.closer h2 em{font-style:italic;color:var(--accent)}
.closer .tag{margin-top:28px;font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:22px;color:var(--ink-2);letter-spacing:-.01em}
.closer .ctas{margin-top:56px;display:inline-flex;gap:14px;flex-wrap:wrap;justify-content:center}
.closer .ctas a{font-family:'Inter Tight',sans-serif;font-weight:500;font-size:14px;padding:16px 28px;border-radius:999px;transition:all .35s cubic-bezier(.2,.7,.2,1);display:inline-flex;align-items:center;gap:10px}
.closer .ctas .p{background:var(--ink);color:var(--paper)}
.closer .ctas .p:hover{background:var(--accent)}
.closer .ctas .s{border:1px solid var(--ink);color:var(--ink)}
.closer .ctas .s:hover{background:var(--ink);color:var(--paper)}

/* ───────── Footer ───────── */
.foot{padding:64px 0 40px;border-top:1px solid var(--line);font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--mute)}
.foot .row{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap}
.foot .brand{font-family:'Fraunces',serif;font-weight:400;font-size:22px;letter-spacing:-.02em;text-transform:none;color:var(--ink)}
.foot .brand em{font-style:italic;color:var(--accent)}
.foot .col h4{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--ink);margin-bottom:14px;font-weight:500}
.foot .col a{display:block;color:var(--mute);text-transform:none;letter-spacing:0;font-family:'Inter Tight',sans-serif;font-size:14px;padding:4px 0;transition:color .2s ease}
.foot .col a:hover{color:var(--accent)}
.foot .micro-tag{margin-top:8px;font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:16px;color:var(--ink-2);text-transform:none;letter-spacing:-.01em;max-width:280px;line-height:1.45}
.foot .copy{margin-top:48px;border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;color:var(--mute);gap:24px;flex-wrap:wrap}

/* ───────── Mobile burger (works with /assets/mobile-nav.js) ───────── */
.nav-burger{display:none;background:transparent;border:none;width:36px;height:36px;cursor:pointer;position:relative;color:inherit;align-items:center;justify-content:center}
.nav-burger span,.nav-burger span::before,.nav-burger span::after{display:block;position:absolute;width:20px;height:1.5px;background:currentColor;border-radius:1px;transition:all .3s ease}
.nav-burger span{top:50%;left:50%;transform:translate(-50%,-50%)}
.nav-burger span::before{content:"";top:-6px;left:0}
.nav-burger span::after{content:"";top:6px;left:0}
.nav-burger[aria-expanded="true"] span{background:transparent}
.nav-burger[aria-expanded="true"] span::before{top:0;transform:rotate(45deg)}
.nav-burger[aria-expanded="true"] span::after{top:0;transform:rotate(-45deg)}
.mobile-menu-overlay{position:fixed;inset:0;background:rgba(28,24,23,.5);opacity:0;pointer-events:none;transition:opacity .35s ease;z-index:60}
.mobile-menu-overlay.open{opacity:1;pointer-events:auto}
.mobile-menu{position:fixed;top:0;right:0;width:min(360px,84vw);height:100vh;background:var(--paper);padding:80px 32px 32px;z-index:65;transform:translateX(100%);transition:transform .4s cubic-bezier(.2,.7,.2,1);display:flex;flex-direction:column;gap:6px;border-left:1px solid var(--line)}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu a{padding:14px 0;font-family:'Fraunces',serif;font-weight:300;font-size:24px;letter-spacing:-.02em;color:var(--ink);border-bottom:1px solid var(--line)}
.mobile-menu a:hover{color:var(--accent)}

/* ───────── Forms ───────── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:32px}
.form-grid .full{grid-column:1/-1}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--ink)}
.field label .opt{color:var(--mute);text-transform:none;letter-spacing:0;font-family:'Inter Tight',sans-serif;margin-left:6px}
.field input, .field select, .field textarea{font-family:'Inter Tight',sans-serif;font-size:15px;padding:14px 16px;border:1px solid var(--line);background:var(--paper);color:var(--ink);border-radius:0;transition:border-color .2s ease;-webkit-appearance:none}
.field input:focus, .field select:focus, .field textarea:focus{outline:none;border-color:var(--accent)}
.field textarea{min-height:120px;resize:vertical}
.field .hint{font-family:'Inter Tight',sans-serif;font-size:13px;color:var(--mute);text-transform:none;letter-spacing:0}
.btn-primary{display:inline-flex;align-items:center;gap:10px;font-family:'Inter Tight',sans-serif;font-weight:500;font-size:14px;padding:16px 28px;border-radius:999px;background:var(--ink);color:var(--paper);transition:all .3s ease;border:none;cursor:pointer}
.btn-primary:hover{background:var(--accent)}
.btn-secondary{display:inline-flex;align-items:center;gap:10px;font-family:'Inter Tight',sans-serif;font-weight:500;font-size:14px;padding:16px 28px;border-radius:999px;background:transparent;color:var(--ink);border:1px solid var(--ink);transition:all .3s ease;cursor:pointer}
.btn-secondary:hover{background:var(--ink);color:var(--paper)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--ink);padding-bottom:6px;border-bottom:1px solid var(--ink);transition:gap .35s ease, color .25s ease;background:transparent;border-top:none;border-left:none;border-right:none;cursor:pointer}
.btn-ghost:hover{gap:18px;color:var(--accent);border-color:var(--accent)}

/* ───────── Misc utilities ───────── */
.note-band{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:24px 0}
.note-band .row{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--mute)}
.note-band b{color:var(--ink);font-weight:500}
.pillrow{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.pillrow .pill{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:var(--ink);border:1px solid var(--line);background:var(--paper);padding:6px 12px;border-radius:999px}
.pillrow .pill.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ───────── Responsive ───────── */
@media (max-width:980px){
  header.nav .links{display:none}
  header.nav .log{display:none}
  .nav-burger{display:inline-flex}
  .page-hero{padding:120px 0 64px}
  .page-hero .lede{grid-template-columns:1fr;gap:32px}
  .tiers{grid-template-columns:1fr;border-bottom:none}
  .tier{border-right:none;border-bottom:1px solid var(--line)}
  .tier:last-child{border-bottom:none}
  .block-3{grid-template-columns:1fr;border-bottom:none}
  .block-3 .b{border-right:none;border-bottom:1px solid var(--line);padding-left:0!important;padding-right:0}
  .block-2{grid-template-columns:1fr;border-bottom:none}
  .block-2 .b{border-right:none;border-bottom:1px solid var(--line);padding:32px 0!important}
  .aside{grid-template-columns:1fr;gap:24px;padding:48px 0}
  .form-grid{grid-template-columns:1fr}
  section{padding:80px 0}
  .foot .row{flex-direction:column;gap:32px}
}

/* ───────── Reveal ───────── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   Subpage richness — Photo blocks, gallery strips, feature splits
   ============================================================ */

/* Hero-with-photo: split the page hero with a cinematic image right */
.page-hero.with-photo .wrap{display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center}
.page-hero.with-photo .copy .lede{grid-template-columns:1fr;gap:24px;max-width:none}
.page-hero.with-photo .copy .lede .side{padding-top:24px;border-top:1px solid var(--line);border-left:none;padding-left:0}
.page-hero.with-photo .copy .lede p{max-width:none}
.page-hero.with-photo .copy{position:relative;z-index:2}
.page-hero.with-photo .photo{position:relative;aspect-ratio:4/5;background:var(--paper-2);overflow:hidden;border:1px solid var(--line);border-radius:2px;box-shadow:0 30px 80px -40px rgba(28,25,23,.45)}
.page-hero.with-photo .photo img{width:100%;height:100%;object-fit:cover;transition:transform 1.6s cubic-bezier(.2,.7,.2,1)}
.page-hero.with-photo:hover .photo img{transform:scale(1.04)}
.page-hero.with-photo .photo .tag{position:absolute;left:20px;bottom:20px;background:rgba(28,25,23,.85);color:var(--paper);padding:8px 14px;font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.16em;backdrop-filter:blur(6px)}
@media (max-width:860px){
  .page-hero.with-photo .wrap{grid-template-columns:1fr;gap:40px}
  .page-hero.with-photo .photo{aspect-ratio:5/4;max-width:480px}
}

/* Feature split — cinematic photo on one side, manifesto text on other */
.feature-split{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);background:var(--paper);overflow:hidden}
.feature-split .photo{position:relative;aspect-ratio:5/6;min-height:420px;background:var(--paper-2);overflow:hidden}
.feature-split .photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.6s cubic-bezier(.2,.7,.2,1)}
.feature-split:hover .photo img{transform:scale(1.04)}
.feature-split .photo .frame{position:absolute;inset:24px;border:1px solid rgba(241,237,231,.5);pointer-events:none}
.feature-split .text{padding:80px 60px;display:flex;flex-direction:column;justify-content:center;gap:24px;background:var(--paper-2)}
.feature-split.dark .text{background:var(--ink);color:var(--paper)}
.feature-split.dark .text .eye{color:var(--paper);opacity:.65}
.feature-split.dark .text em{color:var(--accent-soft)}
.feature-split.dark .text p{color:rgba(241,237,231,.78)}
.feature-split .text .eye{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.22em;color:var(--mute)}
.feature-split .text .eye .num{color:var(--accent)}
.feature-split .text h2{font-family:'Fraunces',serif;font-weight:300;font-size:42px;line-height:1.05;letter-spacing:-.025em;margin:0}
.feature-split .text h2 em{font-style:italic;color:var(--accent);font-weight:300}
.feature-split .text p{font-size:16px;line-height:1.65;color:var(--ink-2);max-width:520px}
.feature-split .text .signoff{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--mute);padding-top:20px;border-top:1px solid var(--line)}
.feature-split.reverse{direction:rtl}
.feature-split.reverse > *{direction:ltr}
@media (max-width:860px){
  .feature-split{grid-template-columns:1fr}
  .feature-split .photo{aspect-ratio:4/3;min-height:280px}
  .feature-split .text{padding:48px 24px}
  .feature-split .text h2{font-size:32px}
}

/* Gallery strip — sample photos as proof, hover zoom */
.gallery-strip{padding-top:0}
.gallery-strip .head{display:flex;align-items:end;justify-content:space-between;gap:24px;padding-bottom:28px;border-bottom:1px solid var(--ink);margin-bottom:0}
.gallery-strip .head h3{font-family:'Fraunces',serif;font-weight:300;font-size:32px;line-height:1.05;letter-spacing:-.02em;margin:0;max-width:560px}
.gallery-strip .head h3 em{font-style:italic;color:var(--accent);font-weight:300}
.gallery-strip .head .lk{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--ink);white-space:nowrap;padding-bottom:6px;border-bottom:1px solid currentColor}
.gallery-strip .head .lk:hover{color:var(--accent)}
.gallery-strip .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-bottom:1px solid var(--ink)}
.gallery-strip .card{position:relative;aspect-ratio:1/1;overflow:hidden;border-right:1px solid var(--line);background:var(--paper-2)}
.gallery-strip .card:last-child{border-right:none}
.gallery-strip .card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.4s cubic-bezier(.2,.7,.2,1),filter .5s ease;filter:saturate(.92)}
.gallery-strip .card:hover img{transform:scale(1.07);filter:saturate(1)}
.gallery-strip .card .meta{position:absolute;left:14px;bottom:12px;right:14px;display:flex;justify-content:space-between;color:var(--paper);font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.18em;z-index:2;mix-blend-mode:normal;text-shadow:0 1px 2px rgba(0,0,0,.5)}
.gallery-strip .card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,25,23,0) 50%,rgba(28,25,23,.55) 100%);pointer-events:none;z-index:1}
.gallery-strip .note{padding:18px 0 0;display:flex;justify-content:space-between;gap:24px;font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.16em;color:var(--mute);flex-wrap:wrap}
.gallery-strip .note em{font-style:italic;color:var(--ink-2)}
@media (max-width:860px){
  .gallery-strip .grid{grid-template-columns:repeat(2,1fr)}
  .gallery-strip .card:nth-child(2n){border-right:none}
  .gallery-strip .head{flex-direction:column;align-items:flex-start}
  .gallery-strip .head h3{font-size:24px}
}

/* Featured tier — recommended pricing card with a warm tinted backdrop */
.tier.featured{position:relative;background:linear-gradient(180deg,rgba(184,68,46,.06) 0%,rgba(184,68,46,.02) 60%,transparent 100%);border-left:1px solid var(--accent);border-right:1px solid var(--accent)}
.tier.featured::before{content:"Most picked";position:absolute;top:-12px;left:24px;background:var(--accent);color:#fff;font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.18em;padding:6px 12px;border-radius:2px}
.tier.featured .price em{color:var(--accent)}
.tier.featured .btn{background:var(--accent);color:#fff;border-color:var(--accent)}
.tier.featured .btn:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* Quote band — editorial pull quote */
.pullquote{border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);padding:80px 0;background:var(--paper-2);text-align:center}
.pullquote blockquote{max-width:880px;margin:0 auto;padding:0 24px;font-family:'Fraunces',serif;font-weight:300;font-size:38px;line-height:1.18;letter-spacing:-.02em;color:var(--ink)}
.pullquote blockquote em{font-style:italic;color:var(--accent);font-weight:300}
.pullquote cite{display:block;margin-top:24px;font-style:normal;font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:var(--mute)}
@media (max-width:860px){.pullquote blockquote{font-size:26px} .pullquote{padding:60px 0}}

/* Accent ribbon — slim terracotta divider between sections */
.ribbon{height:6px;background:var(--accent);position:relative}
.ribbon::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,rgba(0,0,0,0) 0 10px,rgba(0,0,0,.07) 10px 11px)}

/* Stats triplet — large editorial numbers */
.stat-trio{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink)}
.stat-trio .s{padding:48px 32px;border-right:1px solid var(--line);position:relative}
.stat-trio .s:last-child{border-right:none}
.stat-trio .s .num{font-family:'Fraunces',serif;font-weight:300;font-size:68px;line-height:1;letter-spacing:-.03em;color:var(--ink)}
.stat-trio .s .num em{font-style:italic;color:var(--accent);font-weight:300}
.stat-trio .s .lbl{margin-top:12px;font-family:'JetBrains Mono',monospace;font-size:16px;text-transform:uppercase;letter-spacing:.18em;color:var(--mute)}
.stat-trio .s .det{margin-top:14px;font-size:14px;color:var(--ink-2);line-height:1.5;max-width:280px}
@media (max-width:860px){
  .stat-trio{grid-template-columns:1fr}
  .stat-trio .s{border-right:none;border-bottom:1px solid var(--line);padding:36px 0}
  .stat-trio .s:last-child{border-bottom:none}
  .stat-trio .s .num{font-size:54px}
}

/* Photo row — three photos in a tight band (smaller, more editorial than gallery) */
.photo-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--ink);border-top:1px solid var(--ink);border-bottom:1px solid var(--ink)}
.photo-row .p{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--paper-2)}
.photo-row .p img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.6s cubic-bezier(.2,.7,.2,1)}
.photo-row .p:hover img{transform:scale(1.05)}
.photo-row .p .cap{position:absolute;left:16px;bottom:14px;color:var(--paper);font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.2em;z-index:2;text-shadow:0 1px 2px rgba(0,0,0,.5)}
.photo-row .p::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,25,23,0) 55%,rgba(28,25,23,.5));z-index:1}
@media (max-width:860px){
  .photo-row{grid-template-columns:1fr;gap:1px}
}

/* Color-block intro: terracotta band w/ headline + photo on right */
.color-band{background:var(--ink);color:var(--paper);padding:0;overflow:hidden;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink)}
.color-band .grid{display:grid;grid-template-columns:1.1fr 1fr;gap:0;align-items:stretch;min-height:480px}
.color-band .copy{padding:80px 60px;display:flex;flex-direction:column;justify-content:center;gap:24px}
.color-band .eye{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.22em;color:rgba(241,237,231,.6)}
.color-band .eye .num{color:var(--accent-soft)}
.color-band h2{font-family:'Fraunces',serif;font-weight:300;font-size:54px;line-height:1.02;letter-spacing:-.03em;margin:0}
.color-band h2 em{font-style:italic;color:var(--accent-soft);font-weight:300}
.color-band p{font-size:17px;line-height:1.6;color:rgba(241,237,231,.78);max-width:520px}
.color-band .photo{position:relative;overflow:hidden;background:var(--ink-2)}
.color-band .photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.color-band .photo::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--ink) 0%,rgba(28,25,23,.3) 30%,rgba(28,25,23,0) 100%);z-index:1}
.color-band .stamp{position:absolute;right:24px;bottom:24px;font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.22em;color:rgba(241,237,231,.6);z-index:2}
@media (max-width:860px){
  .color-band .grid{grid-template-columns:1fr;min-height:auto}
  .color-band .copy{padding:48px 24px}
  .color-band h2{font-size:36px}
  .color-band .photo{aspect-ratio:5/4}
}

/* Sticker — small printed-feel terracotta circle that floats on cards/photos */
.sticker{position:absolute;width:88px;height:88px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;text-align:center;font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.16em;line-height:1.25;transform:rotate(-8deg);box-shadow:0 8px 24px -10px rgba(184,68,46,.5);z-index:3;padding:8px}
.sticker.tr{top:18px;right:18px}
.sticker.bl{bottom:18px;left:18px}

/* ── Subpage first-section must clear fixed nav (desktop + mobile) ── */
/* Override the inline critical-css that zeroes padding-top on first section */
body.subpage > main > section:first-of-type:not(.hero):not(.page-hero),
body.subpage > section:first-of-type:not(.hero):not(.page-hero){padding-top:140px !important}
body.subpage .page-hero{padding-top:160px !important}
@media (max-width:860px){
  body.subpage > main > section:first-of-type:not(.hero):not(.page-hero),
  body.subpage > section:first-of-type:not(.hero):not(.page-hero){padding-top:96px !important}
  body.subpage .page-hero{padding-top:120px !important}
}

/* ── Full-bleed photo hero for subpages (matches home page hero look) ── */
.page-hero.full-bleed-hero{position:relative;height:100vh;min-height:680px;width:100%;padding:0 !important;border-bottom:none;overflow:hidden;background-color:var(--ink);background-size:cover;background-position:center;background-repeat:no-repeat;color:#fff}
body.subpage .page-hero.full-bleed-hero{padding-top:0 !important}
.page-hero.full-bleed-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,24,23,.55) 0%,rgba(28,24,23,.20) 28%,rgba(28,24,23,.35) 58%,rgba(28,24,23,.85) 100%);pointer-events:none;z-index:1}
.page-hero.full-bleed-hero > .wrap{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:96px;max-width:1320px;margin:0 auto;padding-left:48px;padding-right:48px}
.page-hero.full-bleed-hero .eye{color:rgba(255,255,255,.78);margin-bottom:20px}
.page-hero.full-bleed-hero .eye::before{background:rgba(255,255,255,.55)}
.page-hero.full-bleed-hero .eye .num{color:var(--accent)}
.page-hero.full-bleed-hero h1{color:#fff;max-width:1100px}
.page-hero.full-bleed-hero h1 em{color:#fff;font-style:italic}
.page-hero.full-bleed-hero .lede{margin-top:28px;grid-template-columns:1fr 380px;gap:64px}
.page-hero.full-bleed-hero .lede p{color:rgba(255,255,255,.92);max-width:620px}
.page-hero.full-bleed-hero .lede .side{color:rgba(255,255,255,.78);border-left-color:rgba(255,255,255,.28)}
.page-hero.full-bleed-hero .lede .side b{color:#fff}
.page-hero.full-bleed-hero .lede .side span{color:rgba(255,255,255,.65) !important}
.page-hero.full-bleed-hero .ctas{margin-top:36px}
.page-hero.full-bleed-hero .ctas .p{background:#fff;color:var(--ink)}
.page-hero.full-bleed-hero .ctas .p:hover{background:var(--accent);color:#fff}
.page-hero.full-bleed-hero .ctas .s{border-color:rgba(255,255,255,.6);color:#fff}
.page-hero.full-bleed-hero .ctas .s:hover{background:#fff;color:var(--ink);border-color:#fff}
.page-hero.full-bleed-hero .ctas .ghost{color:#fff;border-bottom-color:rgba(255,255,255,.6)}
.page-hero.full-bleed-hero .ctas .ghost:hover{color:var(--accent);border-bottom-color:var(--accent)}
@media (max-width:860px){
  .page-hero.full-bleed-hero{min-height:600px;height:90vh}
  body.subpage .page-hero.full-bleed-hero{padding-top:0 !important}
  .page-hero.full-bleed-hero > .wrap{padding:0 24px 64px;justify-content:flex-end}
  .page-hero.full-bleed-hero .lede{grid-template-columns:1fr;gap:24px}
  .page-hero.full-bleed-hero .lede .side{border-left:none;border-top:1px solid rgba(255,255,255,.25);padding:20px 0 0;margin-top:8px}
}
