/* ===== Gilbert Yoga — styles.css ===== */
:root{
  --sage:#8CA789;
  --sage-deep:#5F7A5D;
  --forest:#2C3F2E;
  --sand:#F4EEE2;
  --cream:#FBF8F1;
  --terracotta:#C77B58;
  --rose:#C99A94;
  --ink:#33372F;
  --muted:#6B7168;
  --line:rgba(44,63,46,.12);
  --white:#fff;
  --shadow:0 10px 40px -18px rgba(44,63,46,.35);
  --shadow-sm:0 4px 18px -10px rgba(44,63,46,.4);
  --radius:18px;
  --radius-lg:26px;
  --wrap:1180px;
  --font-head:"Cormorant Garamond",Georgia,serif;
  --font-body:"Inter",system-ui,-apple-system,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 22px}
.section{padding:88px 0}
.eyebrow{
  font-family:var(--font-body);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.74rem;
  font-weight:600;
  color:var(--terracotta);
  margin-bottom:14px;
}
h1,h2,h3{font-family:var(--font-head);font-weight:500;line-height:1.1;color:var(--forest)}
h2{font-size:clamp(2rem,4vw,3rem);letter-spacing:-.01em}
h3{font-size:1.42rem;margin-bottom:8px}
.section-head{max-width:660px;margin:0 auto 52px;text-align:center}
.section-lead{color:var(--muted);font-size:1.06rem;margin-top:14px}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:600;font-size:.98rem;
  padding:14px 26px;border-radius:999px;
  cursor:pointer;border:1.5px solid transparent;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease;
}
.btn-sm{padding:10px 18px;font-size:.9rem}
.btn-primary{background:var(--sage-deep);color:var(--cream);box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--forest);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--forest);border-color:var(--sage)}
.btn-ghost:hover{background:var(--sage);color:var(--cream);border-color:var(--sage);transform:translateY(-2px)}
.btn-on-dark{background:var(--cream);color:var(--forest)}
.btn-on-dark:hover{background:var(--white)}
.btn-ghost-dark{border-color:rgba(251,248,241,.6);color:var(--cream)}
.btn-ghost-dark:hover{background:rgba(251,248,241,.14);color:var(--cream)}
.btn-block{width:100%}

/* ===== Intro overlay ===== */
.intro{
  position:fixed;inset:0;z-index:1000;
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  background:radial-gradient(circle at 50% 40%,#6E8A6B 0%,#4C6349 55%,#2C3F2E 100%);
  transition:opacity .7s ease,visibility .7s ease;
}
.intro.hide{opacity:0;visibility:hidden;pointer-events:none}
.intro-inner{display:flex;flex-direction:column;align-items:center;text-align:center}
.intro-lotus{width:190px;height:190px}
.intro-lotus .breath{
  fill:none;stroke:rgba(244,238,226,.35);stroke-width:1.5;
  transform-origin:center;animation:breathe 2.6s ease-in-out infinite;
}
.intro-lotus .petal{
  stroke:var(--sand);stroke-width:2.2;
  stroke-dasharray:180;stroke-dashoffset:180;
  animation:draw 1.6s ease forwards;
}
.petals .petal:nth-child(1){animation-delay:.1s}
.petals .petal:nth-child(2){animation-delay:.25s}
.petals .petal:nth-child(3){animation-delay:.25s}
.petals .petal:nth-child(4){animation-delay:.42s}
.petals .petal:nth-child(5){animation-delay:.42s}
.petals .petal:nth-child(6){animation-delay:.6s}
.petals .petal:nth-child(7){animation-delay:.6s}
.intro-word{
  font-family:var(--font-head);font-size:2.4rem;color:var(--cream);
  margin-top:18px;letter-spacing:.02em;
  opacity:0;animation:fadeUp .8s ease 1s forwards;
}
.intro-tag{
  color:rgba(244,238,226,.75);letter-spacing:.32em;text-transform:uppercase;
  font-size:.72rem;margin-top:6px;
  opacity:0;animation:fadeUp .8s ease 1.3s forwards;
}
.intro-skip{
  position:absolute;bottom:26px;right:26px;
  background:rgba(251,248,241,.14);color:var(--cream);
  border:1px solid rgba(251,248,241,.4);border-radius:999px;
  padding:8px 20px;font-size:.85rem;font-weight:500;cursor:pointer;
  transition:background .2s ease;
}
.intro-skip:hover{background:rgba(251,248,241,.28)}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes breathe{0%,100%{transform:scale(.9);opacity:.35}50%{transform:scale(1.08);opacity:.6}}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:500;
  background:rgba(251,248,241,.82);
  backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid transparent;
  transition:box-shadow .3s ease,border-color .3s ease,background .3s ease;
}
.site-header.scrolled{box-shadow:var(--shadow-sm);border-color:var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:10px;color:var(--forest)}
.brand-mark{width:32px;height:32px;color:var(--sage-deep)}
.brand-text{font-family:var(--font-head);font-size:1.5rem;font-weight:600}
.nav{display:flex;align-items:center;gap:26px}
.nav a{font-size:.94rem;font-weight:500;color:var(--ink);transition:color .2s ease}
.nav a:hover{color:var(--sage-deep)}
.nav-portal{color:var(--terracotta)!important;font-weight:600}
.nav-cta{color:var(--cream)!important}
.nav-toggle{
  display:none;flex-direction:column;gap:5px;background:none;border:none;
  cursor:pointer;padding:8px;
}
.nav-toggle span{width:24px;height:2px;background:var(--forest);border-radius:2px;transition:.3s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== Hero ===== */
.hero{position:relative;padding:96px 0 88px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg svg{width:100%;height:100%}
.hero-inner{position:relative;z-index:1;max-width:760px}
.hero-title{font-size:clamp(2.6rem,6vw,4.6rem);margin:8px 0 20px;letter-spacing:-.015em}
.hero-sub{font-size:1.16rem;color:var(--muted);max-width:620px;margin-bottom:30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.trust-line{margin-top:26px;font-size:.9rem;color:var(--sage-deep);font-weight:500}

/* ===== Trust bar ===== */
.trustbar{background:var(--forest);color:var(--cream)}
.trustbar-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:30px 22px;text-align:center}
.trust-item strong{display:block;font-family:var(--font-head);font-size:1.7rem;color:var(--sand)}
.trust-item span{font-size:.82rem;color:rgba(251,248,241,.75);letter-spacing:.03em}

/* ===== Grid / cards ===== */
.grid{display:grid;gap:24px}
.services-grid{grid-template-columns:repeat(3,1fr)}
.card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 26px;box-shadow:var(--shadow-sm);
  transition:transform .25s ease,box-shadow .25s ease;
}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.icon-wrap{
  width:56px;height:56px;border-radius:14px;
  background:var(--sand);color:var(--sage-deep);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;
}
.icon-wrap svg{width:30px;height:30px}
.card p{color:var(--muted);font-size:.98rem}

/* ===== Why ===== */
.why{background:var(--sand)}
.why-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.why-copy p{color:var(--muted);margin-bottom:22px;font-size:1.05rem}
.why-list{list-style:none;margin:0 0 28px}
.why-list li{display:flex;gap:14px;margin-bottom:16px}
.why-list strong{color:var(--forest)}
.why-list div{font-size:.98rem;color:var(--muted)}
.tick{
  flex:none;width:22px;height:22px;border-radius:50%;margin-top:3px;
  background:var(--sage-deep);position:relative;
}
.tick::after{content:"";position:absolute;left:7px;top:4px;width:5px;height:9px;border:solid var(--cream);border-width:0 2px 2px 0;transform:rotate(45deg)}
.why-art svg{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow)}

/* ===== Showcase / schedule ===== */
.showcase{background:var(--cream)}
.schedule{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);
  overflow:hidden;box-shadow:var(--shadow-sm);max-width:960px;margin:0 auto;
}
.sched-row{display:grid;grid-template-columns:.7fr 1.4fr 1.4fr 1.4fr;gap:10px;padding:16px 24px;border-bottom:1px solid var(--line);align-items:center}
.sched-row:last-child{border-bottom:none}
.sched-head{background:var(--forest);color:var(--sand);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:.78rem}
.sched-row span:first-child{font-weight:600;color:var(--sage-deep)}
.sched-row:not(.sched-head) span{font-size:.95rem;color:var(--ink)}
.sched-row:nth-child(even):not(.sched-head){background:rgba(140,167,137,.06)}
.sched-note{text-align:center;margin-top:22px;color:var(--muted)}
.sched-note a{color:var(--terracotta);font-weight:600}

/* ===== Reviews ===== */
.reviews{background:var(--sand)}
.reviews-grid{grid-template-columns:repeat(3,1fr)}
.quote{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 28px;box-shadow:var(--shadow-sm);position:relative;
}
.quote::before{content:"\201C";font-family:var(--font-head);font-size:4rem;color:var(--sage);position:absolute;top:2px;left:18px;line-height:1;opacity:.5}
.quote p{position:relative;color:var(--ink);font-size:1.02rem;margin-bottom:16px;padding-top:14px}
.quote cite{font-style:normal;font-weight:600;color:var(--sage-deep)}

/* ===== FAQ ===== */
.faq-wrap{max-width:820px}
.faq-item{
  background:var(--white);border:1px solid var(--line);border-radius:14px;
  margin-bottom:14px;overflow:hidden;transition:box-shadow .2s ease;
}
.faq-item[open]{box-shadow:var(--shadow-sm)}
.faq-item summary{
  list-style:none;cursor:pointer;padding:20px 24px;
  font-weight:600;color:var(--forest);font-size:1.05rem;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:1.5rem;color:var(--terracotta);transition:transform .25s ease;font-weight:400}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-body{padding:0 24px 22px;color:var(--muted)}

/* ===== CTA band ===== */
.cta-band{
  background:linear-gradient(135deg,var(--sage-deep),var(--forest));
  color:var(--cream);padding:78px 0;text-align:center;
}
.cta-inner{max-width:640px;margin:0 auto}
.cta-band h2{color:var(--sand)}
.cta-band p{color:rgba(251,248,241,.85);margin:14px 0 28px;font-size:1.08rem}
.cta-band .hero-cta{justify-content:center}

/* ===== Contact ===== */
.contact{background:var(--cream)}
.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:start}
.contact-copy p{color:var(--muted);margin-bottom:26px;font-size:1.05rem}
.contact-list{list-style:none}
.contact-list li{display:flex;gap:14px;margin-bottom:20px;align-items:center}
.ci{flex:none;width:44px;height:44px;border-radius:12px;background:var(--sand);color:var(--sage-deep);display:flex;align-items:center;justify-content:center}
.ci svg{width:22px;height:22px}
.contact-list strong{display:block;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}
.contact-list a,.contact-list div span{font-size:1.08rem;color:var(--forest);font-weight:500}
.contact-list a:hover{color:var(--terracotta)}
.contact-form{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-sm)}
.contact-form label{display:block;font-size:.86rem;font-weight:600;color:var(--forest);margin-bottom:16px}
.contact-form input,.contact-form select,.contact-form textarea{
  width:100%;margin-top:7px;padding:12px 14px;border:1px solid var(--line);
  border-radius:10px;font-family:inherit;font-size:.96rem;color:var(--ink);background:var(--cream);
  transition:border-color .2s ease,box-shadow .2s ease;
}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{
  outline:none;border-color:var(--sage-deep);box-shadow:0 0 0 3px rgba(140,167,137,.25)
}
.contact-form textarea{resize:vertical}
.form-note{font-size:.8rem;color:var(--muted);margin-top:12px;text-align:center}

/* ===== Footer ===== */
.site-footer{background:var(--forest);color:rgba(251,248,241,.8);padding:56px 0 26px}
.footer-inner{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:36px;padding-bottom:34px;border-bottom:1px solid rgba(251,248,241,.15)}
.footer-brand .brand{color:var(--cream);margin-bottom:14px}
.footer-brand .brand-mark{color:var(--sand)}
.footer-brand p{font-size:.94rem;max-width:320px}
.footer-nav{display:flex;flex-direction:column;gap:10px}
.footer-nav a:hover,.footer-contact a:hover{color:var(--sand)}
.footer-contact{display:flex;flex-direction:column;gap:10px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;padding-top:22px;font-size:.86rem}
.credit a{color:var(--sand);font-weight:600}
.credit a:hover{text-decoration:underline}

/* ===== Mobile sticky bar ===== */
.mobilebar{
  position:fixed;bottom:0;left:0;right:0;z-index:400;display:none;
  gap:10px;padding:10px 14px;background:rgba(251,248,241,.95);
  backdrop-filter:blur(10px);border-top:1px solid var(--line);
  box-shadow:0 -6px 24px -14px rgba(44,63,46,.5);
}
.mb-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;border-radius:12px;font-weight:600;font-size:.95rem}
.mb-btn svg{width:20px;height:20px}
.mb-call{background:var(--sand);color:var(--forest)}
.mb-book{background:var(--sage-deep);color:var(--cream)}

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

/* ===== Responsive ===== */
@media(max-width:920px){
  .services-grid,.reviews-grid{grid-template-columns:1fr 1fr}
  .why-inner{grid-template-columns:1fr;gap:36px}
  .contact-inner{grid-template-columns:1fr;gap:36px}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .nav{
    position:fixed;top:72px;right:0;left:0;flex-direction:column;align-items:stretch;
    background:var(--cream);padding:18px 22px 26px;gap:6px;
    border-bottom:1px solid var(--line);box-shadow:var(--shadow);
    transform:translateY(-140%);transition:transform .35s ease;
  }
  .nav.open{transform:translateY(0)}
  .nav a{padding:12px 6px;border-bottom:1px solid var(--line)}
  .nav .nav-cta{margin-top:10px;border-bottom:none}
  .nav-toggle{display:flex}
  .section{padding:64px 0}
  .trustbar-inner{grid-template-columns:1fr 1fr;gap:24px 12px}
  .services-grid,.reviews-grid{grid-template-columns:1fr}
  .mobilebar{display:flex}
  body{padding-bottom:66px}
  .footer-inner{grid-template-columns:1fr;gap:26px}
  .sched-row{grid-template-columns:1fr;gap:6px;padding:16px 20px}
  .sched-head{display:none}
  .sched-row:not(.sched-head) span{display:flex;justify-content:space-between}
  .sched-row:not(.sched-head) span::before{content:attr(data-lbl);font-weight:600;color:var(--sage-deep);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}
  .sched-row span:first-child::before{display:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;animation-iteration-count:1!important;transition-duration:.001s!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
