/* ============================================================
   Deep Root Strategies — shared styles
   Editorial / refined direction (forest green + cream)
   ============================================================ */
:root{
  --forest:#1f3d2b;
  --forest-2:#2c5338;
  --moss:#5a7d52;
  --sage:#8aa177;
  --cream:#f6f3ea;
  --cream-2:#efeadd;
  --ink:#1a2620;
  --paper:#fbfaf5;
  --gold:#b8915a;
  --muted:#525e54;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Spline Sans',sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
.serif{font-family:'Fraunces',serif}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1180px;margin:0 auto;padding:0 40px}

/* ---------- NAV ---------- */
nav{
  position:sticky;top:0;z-index:50;
  background:rgba(251,250,245,.88);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(31,61,43,.12);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:80px}
.brand{display:flex;align-items:center;gap:12px}
.brand .logo{height:46px;width:auto;flex-shrink:0}
.brand .name{font-family:'Fraunces',serif;font-weight:600;font-size:19px;letter-spacing:.2px;color:var(--forest);line-height:1.05}
.brand .name span{display:block;font-family:'Spline Sans',sans-serif;font-weight:500;font-size:10px;letter-spacing:2.6px;text-transform:uppercase;color:var(--moss);margin-top:2px}
.nav-links{display:flex;gap:38px;align-items:center}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--forest-2);position:relative;padding:4px 0}
.nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--gold);transition:width .3s}
.nav-links a:not(.nav-cta):hover::after{width:100%}
.nav-links a.active:not(.nav-cta){color:var(--forest)}
.nav-links a.active:not(.nav-cta)::after{width:100%}
.nav-cta{background:var(--forest);color:var(--cream)!important;padding:11px 26px;border-radius:30px;font-size:13.5px;letter-spacing:.3px;transition:background .25s;white-space:nowrap}
.nav-cta:hover{background:var(--forest-2)}

/* mobile nav toggle */
.nav-toggle{display:none;background:none;border:none;cursor:pointer;width:42px;height:42px;align-items:center;justify-content:center}
.nav-toggle svg{width:26px;height:26px;stroke:var(--forest);stroke-width:1.8;fill:none}

/* ---------- BUTTONS ---------- */
.btn-primary{background:var(--forest);color:var(--cream);padding:15px 30px;border-radius:32px;font-weight:500;font-size:15px;transition:transform .2s,background .25s;display:inline-block}
.btn-primary:hover{transform:translateY(-2px);background:var(--forest-2)}
.btn-ghost{color:var(--forest);font-weight:500;font-size:15px;padding:15px 6px;border-bottom:1.5px solid transparent;transition:border-color .25s;display:inline-block}
.btn-ghost:hover{border-color:var(--gold)}

/* ---------- SHARED EYEBROW + SECTION HEAD ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--moss);font-weight:600;margin-bottom:26px}
.eyebrow::before{content:"";width:30px;height:1.5px;background:var(--gold)}
section.block{padding:96px 0}
.sec-head{max-width:620px;margin-bottom:54px}
.sec-head .eyebrow{margin-bottom:18px}
.sec-head h2{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(30px,3.6vw,44px);line-height:1.1;letter-spacing:-.5px;color:var(--forest)}
.sec-head p{margin-top:18px;font-size:17px;color:#46544a}

/* ---------- PAGE HERO (inner pages) ---------- */
.page-hero{padding:80px 0 30px;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;top:-180px;right:-120px;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,var(--cream-2),transparent 64%);opacity:.6;z-index:0}
.page-hero .inner{position:relative;z-index:1;max-width:760px}
.page-hero h1{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(38px,5vw,62px);line-height:1.04;letter-spacing:-1px;color:var(--forest);margin-bottom:22px}
.page-hero h1 em{font-style:italic;color:var(--gold)}
.page-hero p.lede{font-size:19px;color:#3c4a40;max-width:620px}

/* ---------- HOME HERO ---------- */
.hero{padding:96px 0 80px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;top:-160px;left:50%;transform:translateX(-50%);width:760px;height:760px;border-radius:50%;background:radial-gradient(circle,var(--cream-2),transparent 62%);opacity:.7;z-index:0}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;position:relative;z-index:1}
.hero h1{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(40px,5.4vw,68px);line-height:1.04;letter-spacing:-1px;color:var(--forest);margin-bottom:26px}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero p.lede{font-size:18.5px;color:#3c4a40;max-width:480px;margin-bottom:36px}
.hero-actions{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.hero-visual{position:relative;display:flex;justify-content:center;align-items:center}
.logo-stage{position:relative;width:100%;max-width:440px;aspect-ratio:1/1;display:grid;place-items:center}
.logo-stage .ring{position:absolute;inset:0;border-radius:50%;background:var(--forest);box-shadow:0 30px 70px -28px rgba(31,61,43,.55)}
.logo-stage .ring2{position:absolute;inset:-18px;border-radius:50%;border:1px solid rgba(31,61,43,.18)}
.logo-stage .ring3{position:absolute;inset:-40px;border-radius:50%;border:1px solid rgba(31,61,43,.1)}
.logo-stage .hero-logo{position:relative;z-index:2;width:72%;height:auto;color:var(--cream);filter:drop-shadow(0 8px 18px rgba(0,0,0,.25))}
.hero-badge{position:absolute;right:-10px;bottom:26px;background:var(--cream);border:1px solid var(--cream-2);border-radius:16px;padding:16px 20px;box-shadow:0 18px 40px -18px rgba(31,61,43,.4);max-width:200px;z-index:3}
.hero-badge .big{font-family:'Fraunces',serif;font-size:28px;font-weight:600;color:var(--forest);line-height:1}
.hero-badge .small{font-size:12px;color:var(--moss);margin-top:6px;letter-spacing:.3px}

/* ---------- STRIP ---------- */
.strip{background:var(--forest);color:var(--cream);padding:22px 0}
.strip-inner{display:flex;justify-content:center;gap:50px;flex-wrap:wrap;font-family:'Fraunces',serif;font-style:italic;font-size:18px;color:var(--cream)}
.strip-inner .dot{color:var(--sage)}

/* ---------- SERVICE CARDS ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:var(--paper);border:1px solid rgba(31,61,43,.13);border-radius:18px;padding:34px 30px;transition:transform .3s,box-shadow .3s,border-color .3s;position:relative;overflow:hidden}
.card::before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:var(--sage);transform:scaleX(0);transform-origin:left;transition:transform .35s}
.card:hover{transform:translateY(-6px);box-shadow:0 24px 50px -28px rgba(31,61,43,.4);border-color:transparent}
.card:hover::before{transform:scaleX(1)}
.card .ic{width:48px;height:48px;border-radius:13px;background:var(--cream-2);display:grid;place-items:center;margin-bottom:20px}
.card .ic svg{width:25px;height:25px;stroke:var(--forest);fill:none;stroke-width:1.6}
.card h3{font-family:'Fraunces',serif;font-weight:600;font-size:22px;color:var(--forest);margin-bottom:10px}
.card p{font-size:14.5px;color:var(--muted);line-height:1.6}
.card .tag{display:inline-block;margin-top:16px;font-size:11.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);font-weight:600}

/* ---------- AI BAND ---------- */
.ai-band{background:var(--forest);color:var(--cream);border-radius:26px;padding:60px 56px;display:grid;grid-template-columns:1.3fr 1fr;gap:50px;align-items:center;position:relative;overflow:hidden}
.ai-band::after{content:"";position:absolute;right:-80px;top:-80px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(138,161,119,.25),transparent 70%)}
.ai-band h2{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(28px,3.3vw,40px);line-height:1.12;margin-bottom:18px}
.ai-band h2 em{font-style:italic;color:var(--sage)}
.ai-band p{font-size:16px;color:rgba(246,243,234,.82);line-height:1.65}
.ai-points{display:flex;flex-direction:column;gap:18px;position:relative;z-index:2}
.ai-point{display:flex;gap:15px;align-items:flex-start}
.ai-point .n{font-family:'Fraunces',serif;font-style:italic;font-size:20px;color:var(--sage);flex-shrink:0;width:26px}
.ai-point .t{font-size:14.5px;color:rgba(246,243,234,.9)}
.ai-point .t b{color:var(--cream);font-weight:600;display:block;font-size:15px;margin-bottom:2px}

/* ---------- ABOUT ---------- */
.about{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:center}
.about-img{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:4/5;box-shadow:0 22px 50px -28px rgba(31,61,43,.4)}
.about-img img{width:100%;height:100%;object-fit:cover;object-position:center top}
.about-img .leaf{position:absolute;left:16px;bottom:16px;width:54px;height:54px;background:var(--forest);border-radius:50%;display:grid;place-items:center;box-shadow:0 6px 16px -6px rgba(0,0,0,.5)}
.about-img .leaf svg{width:34px;height:auto;color:var(--cream)}
.about h2{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(28px,3.4vw,42px);color:var(--forest);line-height:1.1;margin-bottom:22px}
.about p{font-size:16.5px;color:#46544a;margin-bottom:18px}
.about .sig{font-family:'Fraunces',serif;font-style:italic;font-size:21px;color:var(--gold);margin-top:8px}
.about .role{font-size:13px;letter-spacing:1.5px;text-transform:uppercase;color:var(--moss);font-weight:600}

/* ---------- ABOUT PAGE EXTRAS ---------- */
.bio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:10px}
.bio-card{background:var(--paper);border:1px solid rgba(31,61,43,.13);border-radius:18px;padding:30px 28px}
.bio-card h3{font-family:'Fraunces',serif;font-weight:600;font-size:18px;color:var(--forest);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.bio-card h3 svg{width:22px;height:22px;stroke:var(--gold);fill:none;stroke-width:1.7}
.bio-card ul{list-style:none}
.bio-card li{font-size:15px;color:var(--muted);padding:6px 0 6px 18px;position:relative}
.bio-card li::before{content:"";position:absolute;left:0;top:14px;width:6px;height:6px;border-radius:50%;background:var(--sage)}

.exp{display:flex;flex-direction:column;gap:0}
.exp-item{display:grid;grid-template-columns:200px 1fr;gap:34px;padding:30px 0;border-top:1px solid rgba(31,61,43,.14)}
.exp-item:last-child{border-bottom:1px solid rgba(31,61,43,.14)}
.exp-item .role-t{font-family:'Fraunces',serif;font-weight:600;font-size:19px;color:var(--forest)}
.exp-item p{font-size:15.5px;color:var(--muted)}

/* ---------- SERVICES PAGE ---------- */
.svc-detail{display:grid;grid-template-columns:1fr;gap:0}
.svc-block{display:grid;grid-template-columns:.9fr 1.1fr;gap:36px;align-items:center;padding:32px 0;border-top:1px solid rgba(31,61,43,.14)}
.svc-block:first-child{border-top:none}
.svc-block.flip .svc-visual{order:2}
.svc-visual{background:var(--forest);border-radius:22px;height:260px;display:grid;place-items:center;position:relative;overflow:hidden;box-shadow:0 24px 50px -30px rgba(31,61,43,.5)}
.svc-visual::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 20%,rgba(138,161,119,.25),transparent 60%)}
.svc-visual .big-ic{position:relative;z-index:2;width:76px;height:76px}
.svc-visual .big-ic svg{width:100%;height:100%;stroke:var(--cream);fill:none;stroke-width:1.2}
.svc-visual .lbl{font-family:'Fraunces',serif;font-style:italic;color:var(--cream);font-size:clamp(26px,3.2vw,40px);text-align:center;padding:0 28px;line-height:1.2;z-index:2}
.svc-text .num{font-family:'Fraunces',serif;font-style:italic;color:var(--gold);font-size:17px;margin-bottom:8px}
.svc-text h2{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(26px,3.2vw,38px);color:var(--forest);line-height:1.1;margin-bottom:16px}
.svc-text p.d{font-size:17.5px;color:#46544a;margin-bottom:20px}
.svc-text .areas{display:grid;gap:10px}
.svc-text .areas .a{display:flex;gap:12px;align-items:flex-start;font-size:16px;color:var(--muted)}
.svc-text .areas .a svg{width:20px;height:20px;stroke:var(--moss);fill:none;stroke-width:2;flex-shrink:0;margin-top:2px}

/* ---------- FOOTER ---------- */
footer{background:var(--forest);color:var(--cream);padding:80px 0 38px;margin-top:30px}
.foot-cta{text-align:center;max-width:680px;margin:0 auto 60px}
.foot-cta .foot-logo{width:64px;height:auto;margin:0 auto 24px;color:var(--cream)}
.foot-cta h2{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(30px,4vw,52px);line-height:1.08;margin-bottom:22px}
.foot-cta h2 em{font-style:italic;color:var(--sage)}
.foot-cta p{font-size:17px;color:rgba(246,243,234,.8);margin-bottom:34px}
.foot-btn{background:var(--cream);color:var(--forest);padding:17px 40px;border-radius:34px;font-weight:600;font-size:16px;display:inline-block;transition:transform .2s}
.foot-btn:hover{transform:translateY(-2px)}
.foot-bottom{border-top:1px solid rgba(246,243,234,.18);padding-top:30px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
.foot-brand{display:flex;align-items:center;gap:12px}
.foot-brand .logo{height:36px;width:auto;color:var(--cream)}
.foot-brand .name{font-family:'Fraunces',serif;font-weight:600;font-size:17px}
.foot-links{display:flex;gap:26px;font-size:14px;color:rgba(246,243,234,.75)}
.foot-links a:hover{color:var(--cream)}
.foot-meta{font-size:13px;color:rgba(246,243,234,.55);width:100%;text-align:center;margin-top:8px}

/* ---------- RESPONSIVE ---------- */
@media(max-width:880px){
  .hero-grid,.ai-band,.about,.svc-block,.svc-block.flip{grid-template-columns:1fr;gap:40px}
  .svc-block.flip .svc-visual{order:0}
  .cards,.bio-grid{grid-template-columns:1fr}
  .exp-item{grid-template-columns:1fr;gap:8px}
  .nav-links{
    display:none;position:absolute;top:80px;left:0;right:0;
    flex-direction:column;gap:0;background:var(--paper);
    border-bottom:1px solid rgba(31,61,43,.12);padding:10px 0;
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:14px 40px;width:100%}
  .nav-links a.nav-cta{margin:10px 40px;text-align:center;width:auto}
  .nav-toggle{display:flex}
  .wrap{padding:0 24px}
  .hero-visual{max-width:360px;margin:0 auto}
  .ai-band{padding:44px 30px}
  .logo-stage{max-width:320px}
  section.block{padding:64px 0}
  .svc-visual .lbl{font-size:32px}
}
