/* landing.css — editorial marketing landing (faithful rebuild of design handoff landing.html).
   Self-contained: its own :root tokens (warm paper / oxblood / wine). Used only by views/layout.ejs.
   The app shell uses shell.css + findie-brand.css; login/register/legal/tools use theme.css. */
:root{
  --paper:#F4F0E8; --surface:#FFFFFF; --sunken:#F0EBE1; --border:#E8E2D6;
  --ink:#1C1A17; --ink2:#6F6657; --ink3:#9A8F7E;
  --accent:#6A2E26; --accent-2:#8A4636; --accent-soft:#F3E7E3;
  --green:#4F6B50; --brass:#9A7B3F; --red:#B4503A; --c-pine:#2E6B54; --c-indigo:#2C3A72; --c-brass:#A9762B;
  --wine:#2A130F; --wine-2:#180A08; --cream:#F4EFE6;
  --serif:'Instrument Serif',Georgia,serif; --sans:'Hanken Grotesk',system-ui,sans-serif; --mono:'JetBrains Mono',monospace;
  --maxw:1180px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.serif{font-family:var(--serif);font-weight:400;letter-spacing:-0.01em}
.num{font-variant-numeric:tabular-nums}
a{color:inherit;text-decoration:none}
.eyebrow{font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase}
svg.l{width:18px;height:18px;stroke-width:1.7;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round}
.frow li svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round}

/* ===== NAV ===== */
.nav{position:absolute;top:0;left:0;right:0;z-index:20}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:.13em;font-size:26px;color:var(--cream)}
.brand .word{font-family:var(--serif);font-weight:400;font-size:26px;line-height:1;letter-spacing:-0.01em;position:relative;top:.04em}
.nav-links{display:flex;align-items:center;gap:26px}
.nav-links a{font-size:14px;color:rgba(244,239,230,.78);font-weight:500;white-space:nowrap}
.nav-links a:hover{color:var(--cream)}
.nav-links a.nav-cta{display:inline-flex;align-items:center;gap:8px;background:var(--cream);color:var(--wine);padding:9px 16px;border-radius:8px;font-size:13.5px;font-weight:600}
.nav-links a.nav-cta:hover{background:#fff;color:var(--wine)}

/* ===== HERO (split: copy left, product shot right) ===== */
.hero{position:relative;background:radial-gradient(120% 95% at 82% -10%, #43201A 0%, var(--wine) 48%, var(--wine-2) 100%);color:var(--cream);overflow:hidden;padding-top:92px}
.hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(244,239,230,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(244,239,230,.05) 1px,transparent 1px);background-size:62px 62px;mask-image:radial-gradient(95% 75% at 62% 30%,#000,transparent 80%);opacity:.5}
.hero-grid{position:relative;max-width:1340px;margin:0 auto;padding:0 0 22px 40px;display:grid;grid-template-columns:486px minmax(0,1fr);gap:44px;align-items:end}
.hero-copy{display:flex;flex-direction:column;align-items:flex-start;min-width:0}
.hero-eyebrow{color:#E0A892;display:inline-flex;align-items:center;gap:9px;margin-bottom:20px;font-size:11.5px}
.hero-eyebrow .dot{width:5px;height:5px;border-radius:50%;background:#E0A892;flex:0 0 auto}
.hero h1{font-family:var(--serif);font-weight:400;font-size:50px;line-height:1.22;letter-spacing:-0.015em;margin:0 0 4px;text-wrap:balance}
.hero h1 em{font-style:italic;color:#E8B6A4}
.hero-lede{font-size:16.5px;line-height:1.6;color:rgba(244,239,230,.82);margin:24px 0 0}
.hero-lede strong{color:var(--cream);font-weight:600}
.hero-actions{display:flex;gap:13px;align-items:center;margin:28px 0 0;flex-wrap:wrap}
.btn{font-family:var(--sans);display:inline-flex;align-items:center;gap:9px;font-size:15px;font-weight:600;padding:13px 20px;border-radius:10px;cursor:pointer;border:1px solid transparent;transition:transform .15s,background .15s;white-space:nowrap}
.btn-primary{background:var(--cream);color:var(--wine)}
.btn-primary:hover{transform:translateY(-1px);background:#fff}
.btn-ghost{background:rgba(244,239,230,.06);color:var(--cream);border-color:rgba(244,239,230,.22)}
.btn-ghost:hover{background:rgba(244,239,230,.12)}
.hero-trust{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:22px}
.hero-note{font-size:13px;color:rgba(244,239,230,.62);display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.hero-note b{color:#E0A892;font-weight:600}
.hero-divider{width:1px;height:14px;background:rgba(244,239,230,.2)}
/* CRO additions */
.sticky{position:fixed;top:0;left:0;right:0;z-index:60;background:rgba(24,10,8,.93);backdrop-filter:blur(10px);border-bottom:1px solid rgba(244,239,230,.12);transform:translateY(-100%);transition:transform .3s ease}
.sticky.show{transform:translateY(0)}
.sticky .wrap{display:flex;align-items:center;justify-content:space-between;height:58px}
.sticky-right{display:flex;align-items:center;gap:18px}
.sticky-seats{font-size:13px;color:#E0A892;font-weight:600}
.seats{display:inline-flex;align-items:center;gap:9px;font-size:13px;color:rgba(244,239,230,.8);margin-top:18px;white-space:nowrap}
.seats .bulb{width:7px;height:7px;border-radius:50%;background:#7FBF8F;box-shadow:0 0 0 3px rgba(127,191,143,.18)}
.seats b{color:var(--cream)}
.stats{display:flex;justify-content:center;flex-wrap:wrap}
.stat{padding:6px 38px;text-align:center}
.stat+.stat{border-left:1px solid var(--border)}
.stat .v{font-family:var(--serif);font-size:38px;line-height:1;color:var(--ink)}
.stat .l{font-size:13px;color:var(--ink2);margin-top:9px;max-width:160px}
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:46px}
.qcard{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:26px;display:flex;flex-direction:column;gap:14px;min-height:200px}
.qcard p{font-family:var(--serif);font-size:19px;line-height:1.42;color:var(--ink)}
.qcard .who{font-size:13px;color:var(--ink2);margin-top:auto}
.qcard .stars{color:var(--brass);font-size:14px;letter-spacing:2px}
@media(max-width:900px){.quotes{grid-template-columns:1fr}.stat+.stat{border-left:none}.stat{padding:10px 20px}}

/* hero screenshot */
.hero-shot{position:relative;z-index:2}
.hero-shot .browser{width:760px;box-shadow:0 50px 100px -34px rgba(20,8,6,.7),0 0 0 1px rgba(20,8,6,.3)}
.play-badge{position:absolute;top:calc(50% + 19px);left:50%;transform:translate(-50%,-50%);width:72px;height:72px;border-radius:50%;background:rgba(106,46,38,.94);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 14px 44px rgba(20,8,6,.5);transition:transform .15s ease,background .15s;z-index:4}
.play-badge::after{content:"";width:0;height:0;border-style:solid;border-width:10px 0 10px 17px;border-color:transparent transparent transparent var(--cream);margin-left:4px}
.play-badge:hover{transform:translate(-50%,-50%) scale(1.07);background:var(--wine)}
.play-badge .ring{position:absolute;inset:0;border-radius:50%;border:2px solid rgba(244,239,230,.5);animation:pulsering 2.6s ease-out infinite}
@keyframes pulsering{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.4);opacity:0}}
@media(prefers-reduced-motion:reduce){.play-badge .ring{animation:none}}
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(20,8,6,.88);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:48px}
.lightbox.open{display:flex}
.lightbox-inner{position:relative;width:min(1120px,94vw);aspect-ratio:16/9;background:#15100e;border-radius:14px;overflow:hidden;box-shadow:0 50px 120px rgba(0,0,0,.55)}
.lightbox-inner iframe{width:100%;height:100%;border:0;display:block}
.lightbox-close{position:absolute;top:-40px;right:0;background:none;border:none;color:rgba(244,239,230,.85);font-family:var(--sans);font-size:13.5px;font-weight:600;letter-spacing:.04em;cursor:pointer;padding:6px}
.lightbox-close:hover{color:var(--cream)}
.browser{background:var(--surface);border-radius:14px;box-shadow:0 40px 90px -30px rgba(20,8,6,.6),0 0 0 1px rgba(20,8,6,.25);overflow:hidden}
.browser-bar{height:38px;background:var(--sunken);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:7px;padding:0 14px}
.browser-bar i{width:11px;height:11px;border-radius:50%;background:#d8cfc0}
.browser-url{margin-left:14px;font-size:12px;color:var(--ink3);font-family:var(--mono);background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:3px 12px}
.browser img{width:100%;display:block}

/* ===== TRUST STRIP ===== */
.trust{background:var(--paper);padding:52px 0 10px}
.trust .row{display:flex;align-items:center;justify-content:center;gap:38px;flex-wrap:wrap;color:var(--ink2);font-size:13.5px;font-weight:500}
.trust .row .it{display:inline-flex;align-items:center;gap:9px}
.trust .row .it svg{color:var(--accent)}
.trust .sep{width:1px;height:18px;background:var(--border)}

/* ===== SECTIONS ===== */
.section{padding:96px 0}
.sec-head{max-width:680px}
.sec-head .eyebrow{color:var(--accent)}
.sec-head h2{font-family:var(--serif);font-weight:400;font-size:46px;line-height:1.08;letter-spacing:-0.015em;margin:14px 0 0}
.sec-head p{font-size:18px;color:var(--ink2);margin:16px 0 0;line-height:1.6}

/* feature rows */
.frow{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;padding:64px 0;border-top:1px solid var(--border)}
.frow:nth-child(even) .fvisual{order:-1}
.frow h3{font-family:var(--serif);font-weight:400;font-size:34px;line-height:1.1;letter-spacing:-0.01em}
.frow p{font-size:16.5px;color:var(--ink2);margin:14px 0 0}
.frow ul{list-style:none;margin:20px 0 0;display:flex;flex-direction:column;gap:10px}
.frow li{display:flex;gap:10px;align-items:flex-start;font-size:15px;color:var(--ink)}
.frow li svg{color:var(--accent);margin-top:3px;flex:0 0 auto;width:16px;height:16px}
.fvisual{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:26px;box-shadow:0 18px 50px -28px rgba(40,30,20,.3)}

/* mini visuals */
.mini-k{font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--ink2)}
.mini-num{font-family:var(--serif);font-size:38px;line-height:1.05;margin-top:6px}
.mlist{display:flex;flex-direction:column;gap:16px;margin-top:6px}
.mrow{display:flex;align-items:center;gap:14px}
.mrow .nm{width:120px;font-weight:600;font-size:14px}
.mbar{flex:1;height:7px;background:var(--sunken);border-radius:99px;overflow:hidden}
.mbar span{display:block;height:100%;border-radius:99px}
.mrow .pct{width:48px;text-align:right;font-weight:700;font-family:var(--mono);font-size:13px}
.alert{display:flex;gap:12px;padding:13px 0;border-bottom:1px solid var(--border)}
.alert:last-child{border:none}
.alert .d{width:9px;height:9px;border-radius:50%;margin-top:5px;flex:0 0 auto}
.alert .t{font-weight:600;font-size:14.5px}
.alert .s{font-size:13px;color:var(--ink2);margin-top:2px}

/* feature grid */
.fgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:16px;overflow:hidden;margin-top:56px}
.fcell{background:var(--surface);padding:30px 28px}
.fcell .ic{width:38px;height:38px;border-radius:10px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.fcell h4{font-size:16px;font-weight:600}
.fcell p{font-size:14px;color:var(--ink2);margin-top:6px;line-height:1.55}
/* landing multi-accent — marketing only; the app stays single-accent */
.stats .stat:nth-child(1) .v{color:var(--accent)}
.stats .stat:nth-child(2) .v{color:var(--c-indigo)}
.fgrid .fcell:nth-child(1) .ic{color:var(--accent);background:var(--accent-soft)}
.fgrid .fcell:nth-child(2) .ic{color:var(--c-pine);background:rgba(46,107,84,.12)}
.fgrid .fcell:nth-child(3) .ic{color:var(--c-indigo);background:rgba(44,58,114,.10)}
.fgrid .fcell:nth-child(4) .ic{color:var(--c-brass);background:rgba(169,118,43,.14)}
.fgrid .fcell:nth-child(5) .ic{color:var(--accent);background:var(--accent-soft)}
.fgrid .fcell:nth-child(6) .ic{color:var(--c-pine);background:rgba(46,107,84,.12)}
.frow--ox h3,.frow--ox li svg{color:var(--accent)}
.frow--ind h3,.frow--ind li svg{color:var(--c-indigo)}
.frow--pine h3,.frow--pine li svg{color:var(--c-pine)}

/* ===== STORY (pedigree) ===== */
.story{background:var(--ink);color:var(--cream)}
.story .wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:center;padding:90px 32px}
.story .eyebrow{color:#E0A892}
.story h2{font-family:var(--serif);font-weight:400;font-size:44px;line-height:1.1;letter-spacing:-0.015em;margin:14px 0 0}
.story p{color:rgba(244,239,230,.78);font-size:17px;margin:18px 0 0;line-height:1.65}
.story .quote{font-family:var(--serif);font-style:italic;font-size:24px;color:var(--cream);line-height:1.4;border-left:2px solid var(--accent);padding-left:22px}
.story .quote .by{display:block;font-family:var(--sans);font-style:normal;font-size:13px;color:rgba(244,239,230,.6);margin-top:12px;letter-spacing:.04em}

/* ===== PRICING ===== */
.pricing{padding:96px 0;text-align:center}
.pricing .sec-head{margin:0 auto;text-align:center}
.ptiers{display:grid;grid-template-columns:1.1fr 1fr 1fr 1fr;gap:18px;margin-top:54px;text-align:left}
.ptier{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px 24px;display:flex;flex-direction:column}
.ptier.feat{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.ptier .nm{font-family:var(--serif);font-size:24px}
.ptier.feat .tag{display:inline-block;background:var(--accent);color:var(--cream);font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:4px 10px;border-radius:99px;margin-bottom:14px;width:fit-content}
.ptier .price{font-family:var(--serif);font-size:42px;margin:14px 0 2px}
.ptier .price small{font-family:var(--sans);font-size:14px;color:var(--ink2);font-weight:500}
.ptier.feat .price small{color:rgba(244,239,230,.6)}
.ptier .sub{font-size:13.5px;color:var(--ink2)}
.ptier.feat .sub{color:rgba(244,239,230,.7)}
.ptier ul{list-style:none;margin:20px 0 24px;display:flex;flex-direction:column;gap:9px;flex:1}
.ptier li{font-size:13.5px;display:flex;gap:9px}
.ptier li svg{width:15px;height:15px;color:var(--accent);flex:0 0 auto;margin-top:2px}
.ptier.feat li svg{color:#E0A892}
.pbtn{text-align:center;padding:11px;border-radius:9px;font-size:14px;font-weight:600;border:1px solid var(--border);background:var(--surface);color:var(--ink)}
.ptier.feat .pbtn{background:var(--cream);color:var(--wine);border:none}
.ptier .pbtn.solid{background:var(--accent);color:var(--cream);border:none}
.pnote{font-size:13px;color:var(--ink3);margin-top:22px}
/* Partner — full-width band beneath the four tiers */
.ppartner{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:40px;align-items:center;text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:30px 34px;margin-top:18px}
.ppartner-tag{display:inline-block;background:var(--accent-soft);color:var(--accent);font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:4px 10px;border-radius:99px;margin-bottom:12px}
.ppartner .nm{font-family:var(--serif);font-size:24px}
.ppartner-desc{font-size:14.5px;color:var(--ink2);margin:8px 0 16px;max-width:560px;line-height:1.55}
.ppartner-feats{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:9px 22px}
.ppartner-feats li{font-size:13.5px;display:flex;gap:9px;align-items:flex-start}
.ppartner-feats li svg{width:15px;height:15px;color:var(--accent);flex:0 0 auto;margin-top:2px}
.ppartner-buy{display:flex;flex-direction:column;align-items:flex-start;gap:4px;border-left:1px solid var(--border);padding-left:36px}
.ppartner-buy .price{font-family:var(--serif);font-size:42px;margin:0}
.ppartner-buy .price small{font-family:var(--sans);font-size:14px;color:var(--ink2);font-weight:500}
.ppartner-add{font-size:13.5px;color:var(--ink2)}
.ppartner-buy .pbtn{margin-top:14px;width:100%}
@media(max-width:900px){.ppartner{grid-template-columns:1fr;gap:22px}.ppartner-feats{grid-template-columns:1fr}.ppartner-buy{border-left:none;border-top:1px solid var(--border);padding-left:0;padding-top:22px;width:100%}}

/* ===== FINAL CTA ===== */
.final{background:radial-gradient(110% 120% at 50% 0%, #43201A 0%, var(--wine) 50%, var(--wine-2) 100%);color:var(--cream);text-align:center;padding:110px 0}
.final h2{font-family:var(--serif);font-weight:400;font-size:60px;line-height:1.05;letter-spacing:-0.015em}
.final p{color:rgba(244,239,230,.8);font-size:18px;margin:18px auto 0;max-width:520px}
.final .hero-actions{justify-content:center;margin-top:34px}

/* ===== FOOTER ===== */
footer{background:var(--wine-2);color:rgba(244,239,230,.7);padding:46px 0 40px}
footer .wrap{display:flex;justify-content:space-between;align-items:flex-start;gap:30px;flex-wrap:wrap}
footer .brand{font-size:24px}
footer .brand .word{font-family:var(--serif);font-size:24px;color:var(--cream)}
footer .url{font-family:var(--mono);font-size:13px;color:#E0A892;margin-top:8px}
footer .cols{display:flex;gap:60px}
footer .col h5{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(244,239,230,.5);margin-bottom:12px}
footer .col a{display:block;font-size:14px;color:rgba(244,239,230,.78);margin-bottom:8px}
footer .legal{width:100%;border-top:1px solid rgba(244,239,230,.12);margin-top:14px;padding-top:20px;font-size:12.5px;color:rgba(244,239,230,.5);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

@media(max-width:1040px){
  .hero-grid{grid-template-columns:1fr;padding:0 24px 56px;gap:36px;text-align:left}
  .hero-shot .browser{width:100%;max-width:680px}
}
@media(max-width:900px){
  .hero h1{font-size:46px}.hero{padding-top:108px}
  .frow,.story .wrap,.ptiers{grid-template-columns:1fr}
  .frow:nth-child(even) .fvisual{order:0}
  .fgrid{grid-template-columns:1fr 1fr}
  .trust{padding-top:64px}
  .final h2{font-size:40px}.sec-head h2{font-size:34px}
}
.nav-toggle{display:none;background:none;border:1px solid rgba(244,239,230,.22);border-radius:8px;color:var(--cream);cursor:pointer;padding:7px 9px;align-items:center;justify-content:center}
@media(max-width:760px){
  .nav .wrap{height:64px}
  .nav-toggle{display:inline-flex}
  .nav-links{position:absolute;top:60px;right:16px;left:16px;flex-direction:column;align-items:stretch;gap:2px;background:rgba(22,12,9,.97);backdrop-filter:blur(12px);border:1px solid rgba(244,239,230,.12);border-radius:14px;padding:10px;display:none;box-shadow:0 24px 60px rgba(0,0,0,.45)}
  .nav-links.open{display:flex}
  .nav-links a{padding:12px 14px;border-radius:9px;font-size:15px;color:var(--cream)}
  .nav-links a.nav-cta{justify-content:center;margin-top:6px;background:var(--cream);color:var(--wine)}
  .trust .row{gap:14px 22px;font-size:12.5px}
  .story .wrap{padding:64px 24px}
}
@media(max-width:560px){
  .wrap{padding:0 20px}
  .hero{padding-top:84px}
  .hero-grid{padding:0 20px 44px;gap:30px}
  .hero h1{font-size:37px;line-height:1.13}
  .hero-lede{font-size:15.5px;margin-top:20px}
  .hero-actions{flex-direction:column;align-items:stretch;width:100%;gap:10px;margin-top:24px}
  .hero-actions .btn{width:100%;justify-content:center}
  .section{padding:60px 0}
  .sec-head h2{font-size:28px}
  .sec-head p{font-size:16px}
  .frow{padding:38px 0;gap:26px}
  .frow h3{font-size:26px}
  .fvisual{padding:20px}
  .fgrid{grid-template-columns:1fr}
  .quotes{margin-top:30px}
  .ptier{padding:24px 22px}
  .pricing .ptiers{margin-top:32px}
  .final{padding:64px 0}
  .final h2{font-size:33px}
  .final p{font-size:16px}
  .sticky .wrap{height:54px}
  .sticky-seats{display:none}
  footer .wrap{flex-direction:column;gap:26px}
  footer .cols{gap:34px;flex-wrap:wrap}
}
