:root{
  --cream:#F4F0E8;
  --cream-2:#EAE3D6;
  --ink:#1E1F1B;
  --ink-soft:#46463E;
  --forest:#1E1F1B;
  --forest-deep:#15160F;
  --sage:#9B8C76;
  --clay:#A6543A;
  --clay-soft:#C27A5C;
  --line:#DBD3C4;
  --text:#26261F;
  --muted:#6B675C;
  --white:#FFFFFF;
  --shadow:0 26px 64px -32px rgba(30,31,27,.42);
  --radius:8px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:84px}
body{font-family:'Inter',system-ui,sans-serif;color:var(--text);background:var(--cream);line-height:1.7;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Spectral',Georgia,serif;font-weight:500;line-height:1.22;color:var(--ink);letter-spacing:-.005em}
h2{font-size:clamp(1.85rem,3.5vw,2.8rem);font-weight:500}
h3{font-size:1.32rem;font-weight:500}
p{margin-bottom:1rem}
a{color:var(--clay);text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1140px;margin:0 auto;padding:0 26px}
.eyebrow{font-family:'Inter';font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--clay);font-weight:600;margin-bottom:1rem}
.eyebrow::before{content:"";display:inline-block;width:28px;height:1px;background:var(--clay);vertical-align:middle;margin-right:.8rem;transform:translateY(-3px)}
.section-head.center .eyebrow::before{display:none}
.lead{font-size:1.12rem;color:var(--ink-soft)}

.btn{display:inline-flex;align-items:center;gap:.55rem;font-weight:500;font-size:.97rem;letter-spacing:.01em;padding:.95rem 1.8rem;border-radius:3px;cursor:pointer;transition:.25s ease;border:1px solid transparent}
.btn-primary{background:var(--clay);color:#fff;box-shadow:0 12px 26px -16px rgba(166,84,58,.7)}
.btn-primary:hover{background:#8c4630;transform:translateY(-2px)}
.btn-ghost{border-color:var(--ink);color:var(--ink);background:transparent}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}
.btn svg{width:17px;height:17px}

header.nav{position:sticky;top:0;z-index:50;background:rgba(244,240,232,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;flex-direction:column;line-height:1.1}
.brand b{font-family:'Spectral';font-weight:600;font-size:1.18rem;color:var(--ink);letter-spacing:.01em}
.brand span{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--clay)}
.menu{display:flex;gap:2rem;align-items:center}
.menu a{color:var(--ink-soft);font-size:.93rem;font-weight:500;position:relative}
.menu a:hover{color:var(--clay)}
.menu .btn{padding:.6rem 1.2rem}
.burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px}
.burger span{width:26px;height:2px;background:var(--ink);transition:.3s}

.hero{position:relative;overflow:hidden;padding:clamp(3.5rem,8vw,6.5rem) 0 clamp(3rem,6vw,5rem)}
.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 90% 6%,rgba(166,84,58,.08),transparent 55%),radial-gradient(80% 70% at 4% 96%,rgba(30,31,27,.05),transparent 60%);z-index:0}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:3.2rem;align-items:center}
.hero h1{font-size:clamp(2.4rem,5.2vw,4rem);font-weight:400;line-height:1.14;letter-spacing:-.01em;margin-bottom:1.4rem}
.hero h1 em{font-style:italic;color:var(--clay)}
.hero p{font-size:1.13rem;color:var(--ink-soft);max-width:30rem}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:1.9rem}
.hero-meta{margin-top:2.2rem;display:flex;gap:1.8rem;flex-wrap:wrap;font-size:.9rem;color:var(--muted)}
.hero-meta div{display:flex;align-items:center;gap:.5rem}
.hero-meta svg{width:18px;height:18px;color:var(--sage);flex-shrink:0}

.portrait{position:relative}
.portrait-frame{aspect-ratio:4/4.7;border-radius:5px;overflow:hidden;background:linear-gradient(150deg,#cfc6b6,#a89d88 60%,#9B8C76);box-shadow:var(--shadow);position:relative}
.portrait-frame img{width:100%;height:100%;object-fit:cover}
.badge{position:absolute;bottom:18px;left:-14px;background:#fff;border-radius:3px;padding:.75rem 1.1rem;box-shadow:var(--shadow);display:flex;align-items:center;gap:.6rem;font-size:.84rem;font-weight:500;color:var(--ink)}
.badge svg{width:22px;height:22px;color:var(--clay)}

section{padding:clamp(3.5rem,7vw,6rem) 0}
.section-head{max-width:48rem;margin-bottom:3rem}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.alt{background:var(--cream-2)}
.ink-bg{background:var(--forest-deep);color:#E7E1D4}
.ink-bg h2,.ink-bg h3{color:#fff}
.ink-bg .eyebrow{color:var(--clay-soft)}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2rem 1.7rem;transition:.3s}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.card .ic{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--cream-2);margin-bottom:1.2rem}
.card .ic svg{width:26px;height:26px;color:var(--ink)}
.card h3{margin-bottom:.6rem}
.card p{font-size:.96rem;color:var(--muted);margin:0}

.motifs{display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem 2.2rem;margin-top:1.5rem}
.motifs li{list-style:none;display:flex;align-items:flex-start;gap:.7rem;padding:.5rem 0;border-bottom:1px solid var(--line);color:var(--ink-soft)}
.motifs li svg{width:18px;height:18px;color:var(--sage);flex-shrink:0;margin-top:5px}

.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;margin-top:1rem}
.step{position:relative;padding-top:1rem}
.step .n{font-family:'Spectral';font-size:2.4rem;color:var(--clay-soft);line-height:1;margin-bottom:.6rem;display:block}
.step h3{margin-bottom:.5rem}
.step p{font-size:.96rem;color:var(--muted);margin:0}
.ink-bg .step p{color:#c7c0b2}

.split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.feature-list{margin-top:1.2rem}
.feature-list div{display:flex;gap:.9rem;padding:1rem 0;border-top:1px solid var(--line)}
.feature-list div:first-child{border-top:none}
.feature-list .fi{width:40px;height:40px;border-radius:11px;background:var(--cream);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ink-bg .feature-list .fi{background:rgba(255,255,255,.07)}
.feature-list svg{width:20px;height:20px;color:var(--clay)}
.feature-list h4{font-family:'Inter';font-weight:600;font-size:1rem;color:var(--ink);margin-bottom:.2rem}
.ink-bg .feature-list h4{color:#fff}
.feature-list p{font-size:.93rem;color:var(--muted);margin:0}
.ink-bg .feature-list p{color:#c7c0b2}

.callout{background:var(--cream-2);border-left:3px solid var(--clay);border-radius:0 14px 14px 0;padding:1.5rem 1.7rem;margin-top:2rem}
.callout h3{font-size:1.2rem;margin-bottom:.5rem}
.callout p{margin:0;color:var(--ink-soft)}

.faq{max-width:50rem;margin:0 auto}
.faq details{background:#fff;border:1px solid var(--line);border-radius:14px;margin-bottom:.8rem;overflow:hidden;transition:.2s}
.faq details[open]{box-shadow:var(--shadow);border-color:transparent}
.faq summary{cursor:pointer;padding:1.25rem 1.5rem;font-weight:500;font-size:1.04rem;color:var(--ink);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{flex-shrink:0;width:24px;height:24px;border-radius:50%;border:1.5px solid var(--sage);position:relative;transition:.3s}
.faq summary .pm:before,.faq summary .pm:after{content:"";position:absolute;background:var(--ink);top:50%;left:50%;transform:translate(-50%,-50%)}
.faq summary .pm:before{width:11px;height:1.5px}
.faq summary .pm:after{width:1.5px;height:11px;transition:.3s}
.faq details[open] summary .pm:after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.faq details[open] summary .pm{background:var(--cream-2)}
.faq .ans{padding:0 1.5rem 1.4rem;color:var(--ink-soft);font-size:.97rem}
.faq .ans p{margin-bottom:.7rem}

.cabinet{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;max-width:560px}
.cabinet .top{padding:1.7rem 1.7rem 1.3rem;border-bottom:1px solid var(--line)}
.cabinet .tag{display:inline-block;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--clay);font-weight:600;margin-bottom:.5rem}
.cabinet h3{margin-bottom:.4rem}
.cabinet address{font-style:normal;color:var(--ink-soft);font-size:.97rem}
.cabinet .access{padding:1.3rem 1.7rem;font-size:.9rem;color:var(--muted)}
.cabinet .access div{display:flex;align-items:flex-start;gap:.6rem;margin-bottom:.55rem}
.cabinet .access svg{width:17px;height:17px;color:var(--sage);flex-shrink:0;margin-top:3px}

.cta-final{background:var(--forest-deep);border-radius:26px;padding:clamp(2.5rem,5vw,4rem);text-align:center;color:#fff;position:relative;overflow:hidden}
.cta-final:before{content:"";position:absolute;inset:0;background:radial-gradient(60% 100% at 50% 0,rgba(166,84,58,.28),transparent 70%)}
.cta-final>*{position:relative;z-index:1}
.cta-final h2{color:#fff;margin-bottom:1rem}
.cta-final p{color:#cfc7b8;max-width:34rem;margin:0 auto 2rem}
.cta-final .hero-cta{justify-content:center}
.cta-final .btn-primary{background:var(--cream);color:var(--ink)}
.cta-final .btn-primary:hover{background:#fff}
.cta-final .btn-ghost{border-color:rgba(255,255,255,.5);color:#fff}
.cta-final .btn-ghost:hover{background:#fff;color:var(--forest-deep)}

footer{background:var(--ink);color:#b6b2a6;padding:3.5rem 0 2rem;font-size:.9rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;margin-bottom:2.5rem}
footer h4{font-family:'Spectral';color:#fff;font-size:1.05rem;margin-bottom:1rem;font-weight:500}
footer a{color:#b6b2a6;display:block;margin-bottom:.5rem}
footer a:hover{color:#fff}
.foot-brand b{font-family:'Spectral';color:#fff;font-size:1.3rem;display:block;margin-bottom:.6rem}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:1.5rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.82rem;color:#8b877b}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* Landing pages */
.lp-hero{padding:clamp(3rem,7vw,5.5rem) 0 clamp(2rem,4vw,3rem);position:relative;overflow:hidden}
.lp-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 90% 6%,rgba(166,84,58,.08),transparent 55%);z-index:0}
.lp-hero .wrap{position:relative;z-index:1;max-width:840px}
.lp-hero h1{font-size:clamp(2.1rem,4.5vw,3.3rem);font-weight:500;line-height:1.18;letter-spacing:-.01em;margin:0 0 1.2rem}
.crumbs{font-size:.82rem;color:var(--muted);margin-bottom:1.4rem;letter-spacing:.02em}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--clay)}
.prose{max-width:760px}
.prose h2{margin:2.6rem 0 1rem}
.prose h3{margin:1.9rem 0 .6rem;font-size:1.2rem}
.prose p{color:var(--ink-soft);margin-bottom:1.1rem}
.prose strong{color:var(--ink)}
.prose ul{margin:0 0 1.2rem;padding:0;list-style:none}
.prose ul li{position:relative;padding-left:1.6rem;margin-bottom:.55rem;color:var(--ink-soft)}
.prose ul li:before{content:"";position:absolute;left:0;top:.62em;width:7px;height:7px;border-radius:50%;background:var(--clay)}
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.5rem}
.related a{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem 1.3rem;color:var(--ink);font-weight:500;transition:.25s}
.related a:hover{box-shadow:var(--shadow);border-color:transparent;transform:translateY(-3px);color:var(--clay)}
.related a span{display:block;font-size:.82rem;color:var(--muted);font-weight:400;margin-top:.2rem}

@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:2.5rem}
  .portrait{max-width:380px;margin:0 auto}
  .cards,.steps,.pricing,.approaches,.lineage{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr}
  .motifs{grid-template-columns:1fr}
}
@media(max-width:680px){
  .menu{position:fixed;inset:74px 0 auto 0;background:var(--cream);flex-direction:column;align-items:stretch;padding:1.2rem 26px 1.8rem;gap:.2rem;border-bottom:1px solid var(--line);box-shadow:var(--shadow);transform:translateY(-130%);transition:.35s;z-index:40}
  .menu.open{transform:translateY(0)}
  .menu a{padding:.85rem 0;border-bottom:1px solid var(--line)}
  .menu .btn{margin-top:.8rem;justify-content:center}
  .burger{display:flex}
  .cards,.steps,.foot-grid,.related{grid-template-columns:1fr}
  .hero-meta{gap:1rem}
}
