/* Jen Hargis Mindful Living — site styles */
:root{
  --bg:#f7f2ea;
  --bg-soft:#efe6d7;
  --paper:#fffaf2;
  --ink:#2c2a26;
  --ink-soft:#5a544b;
  --muted:#857c6f;
  --line:#e3d9c7;
  --clay:#9a5b3d;
  --clay-dark:#7a4429;
  --sage:#7b8a6a;
  --accent:#c98a5d;
  --shadow:0 10px 30px -18px rgba(60,40,20,.35);
  --radius:14px;
  --container:1180px;
  --serif:"Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--sans); font-size:16px; line-height:1.65;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{max-width:100%; height:auto; display:block}
a{color:var(--clay-dark); text-decoration:none; transition:color .2s}
a:hover{color:var(--clay)}
h1,h2,h3,h4{font-family:var(--serif); font-weight:500; color:var(--ink); line-height:1.15; letter-spacing:-.01em; margin:0 0 .5em}
h1{font-size:clamp(2.2rem,4.6vw,3.8rem)}
h2{font-size:clamp(1.8rem,3.4vw,2.7rem)}
h3{font-size:1.35rem}
p{margin:0 0 1em; color:var(--ink-soft)}
.container{max-width:var(--container); margin:0 auto; padding:0 24px}
.eyebrow{display:inline-block; font-size:.75rem; letter-spacing:.22em; text-transform:uppercase; color:var(--clay); font-weight:500; margin-bottom:14px}
.lede{font-size:1.15rem; color:var(--ink-soft); max-width:60ch}
.section{padding:96px 0; position:relative}
.section.tight{padding:64px 0}
.section.alt{background:var(--bg-soft)}
.divider{height:1px; background:var(--line); margin:0}

/* Header */
.site-header{
  position:sticky; top:0; z-index:50; backdrop-filter:saturate(140%) blur(10px);
  background:rgba(247,242,234,.85); border-bottom:1px solid var(--line);
}
.nav{display:flex; align-items:center; justify-content:space-between; padding:14px 24px; max-width:var(--container); margin:0 auto}
.brand{display:flex; align-items:center; gap:10px}
.brand img{height:40px; width:auto}
.nav-links{display:flex; gap:28px; align-items:center}
.nav-links a{color:var(--ink); font-size:.95rem; position:relative; padding:6px 0}
.nav-links a::after{content:""; position:absolute; left:0; right:0; bottom:0; height:1px; background:var(--clay); transform:scaleX(0); transform-origin:right; transition:transform .35s ease}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1); transform-origin:left}
.nav-cta{background:var(--ink); color:var(--paper)!important; padding:10px 18px; border-radius:999px; font-size:.9rem}
.nav-cta:hover{background:var(--clay-dark); color:#fff!important}
.nav-toggle{display:none; background:none; border:0; cursor:pointer; padding:8px}
.nav-toggle span{display:block; width:22px; height:2px; background:var(--ink); margin:4px 0; transition:transform .3s, opacity .3s}

/* Hero */
.hero{position:relative; overflow:hidden; min-height:86vh; display:flex; align-items:center; isolation:isolate}
.hero::before{content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(247,242,234,.2) 0%, rgba(247,242,234,.55) 55%, var(--bg) 100%); z-index:-1}
.hero-img{position:absolute; inset:0; z-index:-2}
.hero-img img{width:100%; height:100%; object-fit:cover}
.hero-content{max-width:760px; padding:120px 0 80px}
.hero h1{margin-bottom:.25em}
.hero p.lede{font-size:1.25rem}
.btn-row{display:flex; gap:14px; flex-wrap:wrap; margin-top:28px}
.btn{
  display:inline-flex; align-items:center; gap:8px; padding:14px 26px; border-radius:999px;
  font-weight:500; font-size:.98rem; cursor:pointer; border:1px solid transparent;
  transition:transform .2s ease, background .2s, color .2s, box-shadow .25s;
}
.btn-primary{background:var(--ink); color:var(--paper)}
.btn-primary:hover{background:var(--clay-dark); color:#fff; transform:translateY(-2px); box-shadow:var(--shadow)}
.btn-ghost{background:transparent; color:var(--ink); border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink); color:var(--paper)}

/* Stats */
.stats{display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:56px; padding-top:32px; border-top:1px solid var(--line)}
.stat strong{display:block; font-family:var(--serif); font-size:2.2rem; color:var(--ink); line-height:1}
.stat span{font-size:.85rem; color:var(--muted); letter-spacing:.05em}

/* Feature grid */
.feature-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:40px}
.feature{background:var(--paper); padding:22px; border-radius:var(--radius); border:1px solid var(--line)}
.feature .icon{width:36px; height:36px; border-radius:50%; background:var(--bg-soft); display:flex; align-items:center; justify-content:center; color:var(--clay); margin-bottom:14px; font-family:var(--serif); font-size:1.1rem}
.feature h4{font-family:var(--sans); font-size:.98rem; margin:0 0 6px; color:var(--ink)}
.feature p{font-size:.9rem; margin:0}

/* Services */
.services-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:48px}
.service-card{background:var(--paper); border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); transition:transform .35s ease, box-shadow .35s}
.service-card:hover{transform:translateY(-6px); box-shadow:var(--shadow)}
.service-card .thumb{aspect-ratio:4/3; overflow:hidden}
.service-card .thumb img{width:100%; height:100%; object-fit:cover; transition:transform .8s ease}
.service-card:hover .thumb img{transform:scale(1.06)}
.service-card .body{padding:26px}
.service-card h3{margin-bottom:10px}
.service-card .tags{display:flex; flex-wrap:wrap; gap:8px; margin-top:14px}
.tag{font-size:.75rem; padding:4px 10px; background:var(--bg-soft); color:var(--ink-soft); border-radius:999px; letter-spacing:.04em}

/* Split */
.split{display:grid; grid-template-columns:1.05fr 1fr; gap:64px; align-items:center}
.split img{border-radius:var(--radius); box-shadow:var(--shadow)}
.split.reverse{grid-template-columns:1fr 1.05fr}
.split.reverse .text{order:2}

/* Testimonials */
.quotes{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:40px}
.quote{background:var(--paper); padding:28px; border-radius:var(--radius); border:1px solid var(--line); position:relative}
.quote::before{content:"”"; font-family:var(--serif); font-size:4rem; color:var(--clay); position:absolute; top:-10px; right:18px; line-height:1; opacity:.5}
.quote p{font-family:var(--serif); font-size:1.15rem; color:var(--ink); font-style:italic; line-height:1.4}
.quote cite{display:block; margin-top:14px; font-style:normal; font-size:.85rem; color:var(--muted); letter-spacing:.04em}

/* CTA strip */
.cta-strip{background:linear-gradient(135deg,#2c2a26,#4a3a2c); color:var(--paper); padding:72px 0; text-align:center; border-radius:var(--radius); margin:0 24px}
.cta-strip h2{color:#fff8ec}
.cta-strip p{color:#d8cdb8; max-width:55ch; margin:0 auto 26px}
.cta-strip .btn-primary{background:var(--paper); color:var(--ink)}
.cta-strip .btn-primary:hover{background:var(--clay); color:#fff}

/* Footer */
footer{background:#1f1d1a; color:#cfc6b7; padding:72px 0 32px; margin-top:0}
footer h4{color:#fff8ec; font-family:var(--sans); font-size:.85rem; letter-spacing:.18em; text-transform:uppercase; margin-bottom:18px}
footer a{color:#cfc6b7}
footer a:hover{color:#fff}
.foot-grid{display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:48px}
.foot-grid p{color:#9b8f7c; font-size:.92rem}
.foot-grid ul{list-style:none; padding:0; margin:0}
.foot-grid li{margin-bottom:10px; font-size:.92rem}
.foot-bottom{margin-top:48px; padding-top:24px; border-top:1px solid #2f2c27; display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; font-size:.82rem; color:#7d7363}

/* Forms */
.form{display:grid; gap:16px; max-width:560px}
.form label{display:block; font-size:.85rem; color:var(--ink-soft); margin-bottom:6px; letter-spacing:.03em}
.form input,.form textarea,.form select{
  width:100%; padding:13px 16px; border:1px solid var(--line); background:var(--paper);
  border-radius:10px; font:inherit; color:var(--ink); transition:border-color .2s, box-shadow .2s;
}
.form input:focus,.form textarea:focus,.form select:focus{outline:none; border-color:var(--clay); box-shadow:0 0 0 3px rgba(154,91,61,.15)}
.form textarea{min-height:140px; resize:vertical}
.row2{display:grid; grid-template-columns:1fr 1fr; gap:16px}

/* Info card */
.info-card{background:var(--paper); padding:32px; border-radius:var(--radius); border:1px solid var(--line)}
.info-card h3{margin-top:0}
.info-list{list-style:none; padding:0; margin:0}
.info-list li{padding:14px 0; border-bottom:1px solid var(--line); display:flex; gap:14px; align-items:flex-start}
.info-list li:last-child{border-bottom:0}
.info-list strong{display:block; font-size:.78rem; color:var(--muted); letter-spacing:.12em; text-transform:uppercase; margin-bottom:2px}
.info-list span{color:var(--ink)}

/* Prose pages (policies) */
.prose{max-width:760px; margin:0 auto}
.prose h2{margin-top:2em}
.prose h3{margin-top:1.6em; font-family:var(--sans); font-size:1.05rem; font-weight:600; color:var(--ink)}
.prose ul{padding-left:1.2em}
.prose li{margin-bottom:.4em; color:var(--ink-soft)}

/* Cookie banner */
.cookie{
  position:fixed; left:24px; right:24px; bottom:24px; z-index:80;
  background:#1f1d1a; color:#f4ecd9; border-radius:14px; padding:18px 22px;
  display:flex; gap:18px; align-items:center; justify-content:space-between;
  box-shadow:0 20px 50px -20px rgba(0,0,0,.45); max-width:780px; margin:0 auto;
  transform:translateY(150%); transition:transform .5s cubic-bezier(.2,.7,.2,1);
}
.cookie.show{transform:translateY(0)}
.cookie p{margin:0; color:#d8cdb8; font-size:.9rem; flex:1}
.cookie .actions{display:flex; gap:10px; flex-shrink:0}
.cookie button{
  background:var(--paper); color:var(--ink); border:0; padding:10px 18px; border-radius:999px;
  font:inherit; font-size:.88rem; cursor:pointer; transition:background .2s;
}
.cookie button.ghost{background:transparent; color:#d8cdb8; border:1px solid #4a443c}
.cookie button:hover{background:var(--clay); color:#fff}

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

/* Page header */
.page-head{padding:120px 0 60px; background:linear-gradient(180deg, var(--bg-soft), var(--bg))}
.page-head h1{max-width:18ch}
.page-head .lede{margin-top:14px}

/* Crumbs */
.crumbs{font-size:.82rem; color:var(--muted); margin-bottom:18px; letter-spacing:.04em}
.crumbs a{color:var(--muted)}

/* Responsive */
@media (max-width: 900px){
  .nav-links{position:fixed; top:64px; left:0; right:0; background:var(--paper); flex-direction:column; gap:0; padding:0; max-height:0; overflow:hidden; transition:max-height .4s ease; border-bottom:1px solid var(--line)}
  .nav-links.open{max-height:480px}
  .nav-links a{width:100%; padding:18px 24px; border-bottom:1px solid var(--line)}
  .nav-cta{margin:14px 24px; text-align:center}
  .nav-toggle{display:block}
  .stats{grid-template-columns:repeat(2,1fr)}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .services-grid{grid-template-columns:1fr}
  .split,.split.reverse{grid-template-columns:1fr; gap:32px}
  .split.reverse .text{order:0}
  .quotes{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr; gap:32px}
  .row2{grid-template-columns:1fr}
  .section{padding:72px 0}
  .cookie{flex-direction:column; align-items:flex-start; left:12px; right:12px; bottom:12px}
}
@media (max-width:520px){
  .feature-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr; gap:14px}
  .hero{min-height:auto}
  .hero-content{padding:80px 0 60px}
}

@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1; transform:none; transition:none}
  *{animation:none!important; transition:none!important}
}
