/* ===========================================================
   THE WELLNESS VILLAGES — Shared Stylesheet
   Voice: heartfelt, visionary, elegant, grounded, premium, warm
   =========================================================== */

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

:root{
  --cream:#faf6ee;
  --cream-2:#f2ead9;
  --clay:#9c4a30;
  --clay-deep:#7d3a26;
  --sage:#6b6b2e;
  --sage-deep:#4a4a1f;
  --ink:#2b2620;
  --ink-soft:#5a5348;
  --gold:#c9a24b;
  --line:#e3d9c4;
  --white:#ffffff;
  --shadow: 0 20px 50px rgba(43,38,32,0.08);
  --radius: 18px;
  --max: 1140px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Jost', sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
}

h1,h2,h3,h4{
  font-family:'Fraunces', serif;
  font-weight:500;
  color:var(--ink);
  line-height:1.15;
  margin:0 0 .5em;
  letter-spacing:-0.01em;
}
h1{font-size:clamp(2.4rem,5vw,4rem); font-weight:400;}
h2{font-size:clamp(1.8rem,3.2vw,2.6rem);}
h3{font-size:clamp(1.3rem,2.2vw,1.6rem);}
p{margin:0 0 1.2em; color:var(--ink-soft);}
a{color:var(--clay-deep); text-decoration:none;}
.container{max-width:var(--max); margin:0 auto; padding:0 28px;}

.eyebrow{
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.78rem;
  color:var(--sage-deep);
  font-weight:600;
  margin-bottom:14px;
  display:inline-block;
}

/* ---------- Nav ---------- */
header.site-header{
  position:sticky; top:0; z-index:100;
  background:rgba(250,246,238,0.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav-wrap{
  max-width:var(--max); margin:0 auto; padding:18px 28px;
  display:flex; align-items:center; justify-content:space-between;
}
.logo{
  font-family:'Fraunces', serif; font-size:1.25rem; color:var(--ink);
  letter-spacing:.01em;
}
.logo span{color:var(--clay-deep);}
nav.main-nav ul{
  list-style:none; display:flex; gap:30px; margin:0; padding:0;
}
nav.main-nav a{
  color:var(--ink); font-size:.95rem; font-weight:500;
  position:relative; padding:4px 0;
}
nav.main-nav a:hover{color:var(--clay-deep);}
.nav-cta{
  background:var(--clay); color:var(--white) !important; padding:11px 22px;
  border-radius:100px; font-weight:600; font-size:.9rem;
  transition:background .2s ease;
}
.nav-cta:hover{background:var(--clay-deep);}
.mobile-toggle{display:none;}

@media (max-width:860px){
  nav.main-nav ul{display:none;}
  .nav-cta{padding:9px 16px; font-size:.82rem;}
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:15px 32px; border-radius:100px; font-weight:600;
  font-size:.98rem; border:none; cursor:pointer;
  transition:all .2s ease;
}
.btn-primary{background:var(--clay); color:var(--white);}
.btn-primary:hover{background:var(--clay-deep); transform:translateY(-1px);}
.btn-outline{background:transparent; color:var(--ink); border:1.5px solid var(--ink);}
.btn-outline:hover{background:var(--ink); color:var(--white);}
.btn-light{background:var(--white); color:var(--ink);}
.btn-light:hover{background:var(--cream-2);}

/* ---------- Hero ---------- */
.hero{
  padding:100px 0 90px;
  background:linear-gradient(180deg, var(--cream) 0%, var(--cream-2) 100%);
  text-align:center;
}
.hero .container{max-width:840px;}
.hero p.lede{font-size:1.2rem; max-width:620px; margin:0 auto 34px;}
.hero-actions{display:flex; gap:16px; justify-content:center; flex-wrap:wrap;}

.hero-visual{
  margin-top:60px; height:340px; border-radius:24px;
  background:linear-gradient(135deg,var(--sage) 0%, var(--clay) 100%);
  opacity:.88;
  overflow:hidden;
}
.hero-visual img, .visual-photo img{
  width:100%; height:100%; object-fit:cover; display:block;
}
.visual-photo{
  border-radius:24px; overflow:hidden; box-shadow:var(--shadow);
}

/* ---------- Sections ---------- */
section{padding:90px 0;}
.section-alt{background:var(--white);}
.section-dark{background:var(--sage-deep); color:var(--cream);}
.section-dark h2, .section-dark h3{color:var(--cream);}
.section-dark p{color:#d8ddd0;}
.center{text-align:center;}
.narrow{max-width:720px; margin:0 auto;}

/* ---------- Grid / Cards ---------- */
.grid{display:grid; gap:32px;}
.grid-2{grid-template-columns:1fr 1fr;}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}
@media (max-width:860px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}
}

.card{
  background:var(--white); border-radius:var(--radius);
  padding:36px 30px; box-shadow:var(--shadow); border:1px solid var(--line);
}
.card h3{margin-bottom:10px;}
.card .icon{
  width:48px;height:48px;border-radius:50%;
  background:var(--cream-2); display:flex; align-items:center; justify-content:center;
  margin-bottom:18px; font-size:1.3rem;
}

.stat{text-align:center;}
.stat .num{font-family:'Fraunces',serif; font-size:2.6rem; color:var(--clay-deep);}
.stat .label{font-size:.85rem; text-transform:uppercase; letter-spacing:.1em; color:var(--ink-soft);}

/* ---------- Quote ---------- */
blockquote{
  font-family:'Fraunces', serif; font-size:1.5rem; font-style:italic;
  color:var(--ink); border-left:3px solid var(--clay); padding-left:24px; margin:36px 0;
}

/* ---------- Forms ---------- */
.form-card{
  background:var(--white); border-radius:24px; padding:44px; box-shadow:var(--shadow);
  border:1px solid var(--line);
}
label{display:block; font-weight:600; font-size:.88rem; margin-bottom:6px; color:var(--ink);}
input[type=text], input[type=email], input[type=tel], select, textarea{
  width:100%; padding:13px 16px; border-radius:10px; border:1.5px solid var(--line);
  background:var(--cream); font-family:'Jost',sans-serif; font-size:.96rem; margin-bottom:20px;
  color:var(--ink);
}
input:focus, select:focus, textarea:focus{outline:none; border-color:var(--clay);}
.check-grid{display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:20px;}
@media (max-width:600px){.check-grid{grid-template-columns:1fr;}}
.check-item{
  display:flex; align-items:flex-start; gap:10px; background:var(--cream);
  border:1.5px solid var(--line); border-radius:12px; padding:14px 16px; cursor:pointer;
}
.check-item input{width:auto; margin:3px 0 0;}
.check-item span{font-size:.92rem; color:var(--ink); font-weight:500;}
.form-note{
  font-size:.82rem; color:var(--ink-soft); background:var(--cream-2);
  border-radius:10px; padding:14px 18px; margin-top:18px;
}
fieldset{border:none; padding:0; margin:0 0 24px;}
legend{font-family:'Fraunces',serif; font-size:1.1rem; margin-bottom:10px; padding:0;}
.radio-row{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:8px;}
.radio-item{
  display:flex; align-items:center; gap:8px; background:var(--cream);
  border:1.5px solid var(--line); border-radius:100px; padding:9px 18px; cursor:pointer; font-size:.9rem;
}
.radio-item input{width:auto;}

/* ---------- Footer ---------- */
footer.site-footer{
  background:var(--ink); color:#cfc7ba; padding:64px 0 30px;
}
footer.site-footer h4{color:var(--cream); font-family:'Fraunces',serif; font-size:1.3rem;}
footer.site-footer a{color:#cfc7ba;}
footer.site-footer a:hover{color:var(--gold);}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; margin-bottom:50px;}
@media (max-width:860px){.footer-grid{grid-template-columns:1fr 1fr;}}
.footer-grid ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px;}
.footer-bottom{
  border-top:1px solid #46403a; padding-top:24px; font-size:.82rem;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; color:#8b8478;
}

.divider{height:1px; background:var(--line); margin:0;}

.tag-pill{
  display:inline-block; background:var(--cream-2); color:var(--sage-deep);
  padding:6px 16px; border-radius:100px; font-size:.82rem; font-weight:600; margin:4px 6px 4px 0;
}
