/* =====================================================================
   LIVING WAY × JAR · shared design system
   Blend: JAR institutional restraint + Living Way editorial warmth
   ===================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..700;1,9..144,300..600&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --ink:#17150f;
  --ink-2:#322c22;
  --paper:#f6f1e8;
  --paper-2:#efe6d7;
  --paper-3:#e7dcc9;
  --clay:#b9582f;        /* warm accent */
  --clay-dk:#9a4625;
  --sage:#4f5d49;        /* calm secondary */
  --gold:#c08a3e;
  --muted:#6f6657;
  --line:rgba(23,21,15,.14);
  --line-soft:rgba(23,21,15,.08);
  --white:#fbf8f2;
  --shadow:0 24px 60px -28px rgba(23,21,15,.4);
  --maxw:1240px;
  --display:"Fraunces",Georgia,serif;
  --sans:"Inter",-apple-system,Segoe UI,Roboto,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
section{position:relative}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:400;line-height:1.04;letter-spacing:-.01em}
.eyebrow{
  font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:var(--clay);display:inline-flex;align-items:center;gap:.6rem;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--clay);display:inline-block}
.eyebrow.sage{color:var(--sage)} .eyebrow.sage::before{background:var(--sage)}
.lead{font-size:1.22rem;color:var(--ink-2);max-width:60ch}
.italic{font-style:italic}

/* ---------- header ---------- */
header.site{
  position:sticky;top:0;z-index:50;
  background:rgba(246,241,232,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-soft);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--display);font-size:1.18rem;letter-spacing:.02em}
.brand .lw{font-weight:600;color:var(--ink)}
.brand .x{font-family:var(--sans);font-weight:600;color:var(--clay);font-size:.95rem;transform:translateY(-1px)}
.brand .jar{
  font-family:var(--sans);font-weight:700;letter-spacing:.16em;font-size:.92rem;
  border:1.5px solid var(--ink);padding:.18rem .5rem;border-radius:3px;color:var(--ink)
}
.menu{display:flex;align-items:center;gap:2rem;font-size:.86rem;font-weight:500}
.menu a{color:var(--ink-2);transition:color .2s;position:relative}
.menu a:hover,.menu a.active{color:var(--ink)}
.menu a.active::after{content:"";position:absolute;left:0;right:0;bottom:-26px;height:2px;background:var(--clay)}
.btn{
  display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);font-weight:600;
  font-size:.86rem;padding:.72rem 1.35rem;border-radius:40px;transition:all .22s;cursor:pointer;border:1.5px solid transparent
}
.btn-primary{background:var(--ink);color:var(--white)}
.btn-primary:hover{background:var(--clay);transform:translateY(-1px)}
.btn-ghost{border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--white)}
.btn-light{background:var(--white);color:var(--ink)}
.btn-light:hover{background:var(--clay);color:var(--white)}
.btn .arr{transition:transform .22s}
.btn:hover .arr{transform:translateX(3px)}
.menu-toggle{display:none}

/* ---------- hero ---------- */
.hero{padding:104px 0 96px;position:relative;overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(120% 90% at 88% -10%, rgba(185,88,47,.16), transparent 55%),
    radial-gradient(90% 80% at 0% 110%, rgba(79,93,73,.16), transparent 55%);
}
.hero .wrap{position:relative;z-index:1}
.hero h1{font-size:clamp(2.7rem,6vw,5rem);max-width:16ch;margin:.5rem 0 1.4rem}
.hero .lead{font-size:1.3rem;max-width:54ch}
.hero-cta{display:flex;gap:1rem;margin-top:2.4rem;flex-wrap:wrap}
.hero-figure{
  margin-top:64px;height:360px;border-radius:0;position:relative;overflow:hidden;
  background:linear-gradient(120deg,#23201a,#3a342a);box-shadow:var(--shadow)
}

/* duotone building motif used across the site */
.cityscape{position:absolute;inset:0;opacity:.9}
.grain{display:none}
.figure-tag{
  position:absolute;left:24px;bottom:22px;z-index:3;color:var(--white);
  font-family:var(--display);font-style:italic;font-size:1.15rem;letter-spacing:.01em
}
.figure-badge{
  position:absolute;right:22px;top:22px;z-index:3;background:rgba(251,248,242,.92);
  color:var(--ink);font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  padding:.45rem .8rem;border-radius:30px
}

/* ---------- generic blocks ---------- */
.band{padding:96px 0}
.band.tight{padding:72px 0}
.band.ink{background:var(--ink);color:var(--paper)}
.band.ink h2,.band.ink h3{color:var(--white)}
.band.ink .lead{color:rgba(246,241,232,.78)}
.band.sage{background:var(--sage);color:var(--paper)}
.band.sage h2{color:var(--white)} .band.sage .lead{color:rgba(246,241,232,.85)}
.band.paper2{background:var(--paper-2)}
.section-head{max-width:62ch;margin-bottom:54px}
.section-head h2{font-size:clamp(2rem,4vw,3.1rem);margin:1rem 0 1.1rem}
.center{text-align:center;margin-left:auto;margin-right:auto}

/* stat strip */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stat{padding:34px 26px;border-right:1px solid var(--line-soft)}
.stat:last-child{border-right:none}
.stat .num{font-family:var(--display);font-size:2.8rem;line-height:1;color:var(--ink)}
.stat .num .u{font-size:1.4rem;color:var(--clay)}
.stat .lab{font-size:.82rem;color:var(--muted);margin-top:.6rem;letter-spacing:.02em}
.band.ink .stat .num{color:var(--white)} .band.ink .stat{border-color:rgba(255,255,255,.12)}
.band.ink .stat .lab{color:rgba(246,241,232,.6)}

/* two-brand split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.split>div{padding:48px 44px}
.split .lw-col{background:var(--paper)}
.split .jar-col{background:var(--ink);color:var(--paper);border-left:1px solid var(--line)}
.split h3{font-size:1.7rem;margin-bottom:.4rem}
.split .jar-col h3{color:var(--white)}
.split .role{font-size:.74rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--clay)}
.split .jar-col .role{color:var(--gold)}
.split ul{list-style:none;margin-top:1.3rem;display:flex;flex-direction:column;gap:.85rem}
.split li{display:flex;gap:.7rem;font-size:.96rem;align-items:flex-start}
.split li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--clay);margin-top:.55rem;flex:none}
.split .jar-col li::before{background:var(--gold)}
.split .jar-col li{color:rgba(246,241,232,.86)}
.together{text-align:center;padding:26px;font-family:var(--display);font-style:italic;font-size:1.3rem;
  background:var(--paper-2);border:1px solid var(--line);border-top:none;border-radius:0 0 14px 14px}

/* card grid */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.card{
  background:var(--white);border:1px solid var(--line);border-radius:13px;padding:34px 30px;
  transition:transform .25s,box-shadow .25s;position:relative;overflow:hidden
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .ico{width:46px;height:46px;border-radius:11px;background:var(--paper-2);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.card .ico svg{width:24px;height:24px;stroke:var(--clay);fill:none;stroke-width:1.6}
.card h3{font-size:1.32rem;margin-bottom:.55rem}
.card h4{font-size:1.08rem;margin-bottom:.4rem}
.card p{font-size:.93rem;color:var(--muted)}
.card .tag{font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--sage);margin-bottom:.7rem;display:block}
.card.dark{background:var(--ink-2);border-color:rgba(255,255,255,.12);color:var(--paper)}
.card.dark h3{color:#fff} .card.dark p{color:rgba(246,241,232,.7)} .card.dark .ico{background:rgba(255,255,255,.08)}

/* numbered steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:s}
.step{padding-top:30px;border-top:2px solid var(--ink);position:relative}
.step .n{font-family:var(--display);font-size:.95rem;color:var(--clay);font-weight:600;letter-spacing:.1em}
.step h4{font-size:1.2rem;margin:.5rem 0 .5rem}
.step p{font-size:.9rem;color:var(--muted)}
.band.ink .step{border-color:var(--gold)}
.band.ink .step p{color:rgba(246,241,232,.7)}

/* feature row (image + text) */
.feature{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.feature.rev{direction:rtl}.feature.rev>*{direction:ltr}
.feature .panel{height:440px;border-radius:0;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.feature h2{font-size:clamp(1.8rem,3.4vw,2.7rem);margin:1rem 0 1.1rem}
.feature p+p{margin-top:1rem}
.tick{list-style:none;margin-top:1.5rem;display:flex;flex-direction:column;gap:.9rem}
.tick li{display:flex;gap:.8rem;font-size:.98rem;align-items:flex-start}
.tick li svg{width:20px;height:20px;stroke:var(--clay);fill:none;stroke-width:2;flex:none;margin-top:.2rem}

/* compare table */
.compare{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:13px;overflow:hidden}
.compare>div{padding:34px 28px;border-right:1px solid var(--line-soft)}
.compare>div:last-child{border-right:none}
.compare .who{font-family:var(--display);font-size:1.3rem;margin-bottom:.3rem}
.compare .sub{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:1.1rem}
.compare .verdict{font-size:.92rem;color:var(--muted)}
.compare .win{background:var(--ink);color:var(--paper)}
.compare .win .who{color:#fff} .compare .win .sub{color:var(--gold)} .compare .win .verdict{color:rgba(246,241,232,.8)}

/* trust / logos */
.trust{display:flex;align-items:center;justify-content:center;gap:46px;flex-wrap:wrap;opacity:.8}
.trust span{font-family:var(--display);font-size:1.15rem;color:var(--muted);letter-spacing:.02em}

/* quote */
.quote{font-family:var(--display);font-size:clamp(1.8rem,3.6vw,2.8rem);line-height:1.18;max-width:20ch}
.quote .hl{color:var(--clay)}

/* CTA band */
.cta{padding:92px 0;background:var(--ink);color:var(--paper);text-align:center;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;
  background:radial-gradient(80% 120% at 50% -20%,rgba(185,88,47,.28),transparent 60%)}
.cta .wrap{position:relative;z-index:1}
.cta h2{font-size:clamp(2.2rem,4.5vw,3.4rem);color:#fff;max-width:18ch;margin:0 auto 1.2rem}
.cta p{color:rgba(246,241,232,.75);max-width:48ch;margin:0 auto 2rem;font-size:1.1rem}

/* footer */
footer.site{background:#100e0a;color:rgba(246,241,232,.72);padding:72px 0 36px;font-size:.88rem}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
footer.site .brand{color:#fff;margin-bottom:1rem}
footer.site .brand .lw{color:#fff}
footer.site .brand .jar{border-color:rgba(255,255,255,.6);color:#fff}
footer.site h5{font-family:var(--sans);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(246,241,232,.5);margin-bottom:1.1rem}
footer.site ul{list-style:none;display:flex;flex-direction:column;gap:.7rem}
footer.site a:hover{color:#fff}
.accred{display:flex;gap:14px;flex-wrap:wrap;margin-top:1.3rem}
.accred .b{font-size:.62rem;font-weight:600;letter-spacing:.1em;border:1px solid rgba(255,255,255,.22);
  padding:.4rem .6rem;border-radius:4px;color:rgba(246,241,232,.7)}
.foot-bottom{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;padding-top:28px;font-size:.78rem;color:rgba(246,241,232,.5)}

/* forms */
.form{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form .full{grid-column:1/-1}
.form label{display:block;font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}
.form input,.form select,.form textarea{
  width:100%;padding:.85rem 1rem;border:1px solid var(--line);border-radius:9px;background:var(--white);
  font-family:var(--sans);font-size:.95rem;color:var(--ink)
}
.form textarea{min-height:130px;resize:vertical}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--clay)}

/* misc */
.pill{display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  background:var(--paper-2);color:var(--sage);padding:.4rem .85rem;border-radius:30px;border:1px solid var(--line-soft)}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* audience nav chips */
.nav-aud{display:flex;gap:10px;flex-wrap:wrap;margin-top:1.6rem}
.nav-aud a{font-size:.82rem;font-weight:600;padding:.55rem 1.1rem;border-radius:30px;border:1px solid var(--line);color:var(--ink-2);transition:all .2s}
.nav-aud a:hover,.nav-aud a.on{background:var(--ink);color:var(--white);border-color:var(--ink)}

/* app / phone showcase */
.app-showcase{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.phone{width:300px;max-width:100%;aspect-ratio:300/600;background:#0f0d09;border-radius:42px;padding:11px;
  box-shadow:var(--shadow);margin:0 auto;position:relative}
.phone.tall{width:352px;aspect-ratio:320/688;border-radius: