/* ============================================================
   SOPHIA — Brand stylesheet
   Palette: cream #FCF0E1 · peach #FFE5C4 · sage #BFCFBB
            forest #344C3D · taupe #6A5A4E
   Type: Fraunces (display) + Inter (text)
   ============================================================ */

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

:root{
  --cream:#FCF0E1;
  --peach:#FFE5C4;
  --sage:#BFCFBB;
  --forest:#344C3D;
  --forest-deep:#26392E;
  --taupe:#6A5A4E;
  --ink:#2C2620;
  --line:rgba(52,76,61,.16);
  --shadow:0 18px 50px -24px rgba(44,38,32,.45);
  --maxw:1240px;
  --serif:'Fraunces',Georgia,serif;
  --sans:'Inter',system-ui,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.04;margin:0;color:var(--forest);letter-spacing:-.02em}
h1{font-size:clamp(2.8rem,7vw,6rem);font-weight:900}
h2{font-size:clamp(2rem,4.4vw,3.6rem)}
h3{font-size:clamp(1.4rem,2.4vw,2rem)}
p{margin:0 0 1.1em}

.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:clamp(64px,9vw,128px) 0}
.eyebrow{font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.22em;font-size:.74rem;color:var(--taupe);margin:0 0 18px}
.lead{font-size:clamp(1.05rem,1.6vw,1.28rem);color:#4a443c;max-width:60ch}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--sans);font-weight:600;font-size:.96rem;
  letter-spacing:.02em;
  padding:15px 30px;border-radius:999px;
  border:1.5px solid var(--forest);
  background:var(--forest);color:var(--cream);
  cursor:pointer;transition:.25s ease;
}
.btn:hover{background:var(--forest-deep);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--forest)}
.btn--ghost:hover{background:var(--forest);color:var(--cream)}
.btn--peach{background:var(--peach);border-color:var(--peach);color:var(--forest)}
.btn--peach:hover{background:#ffd9a8;border-color:#ffd9a8}
.btn .arrow{transition:transform .25s}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- Top utility + nav ---------- */
.topbar{background:var(--forest-deep);color:var(--cream)}
.topbar .container{display:flex;justify-content:flex-end;align-items:center;gap:18px;height:38px;font-size:.8rem}
.socials{display:flex;gap:16px;align-items:center}
.socials a{opacity:.8;transition:opacity .2s;display:inline-flex}
.socials a:hover{opacity:1}
.socials svg{width:17px;height:17px;fill:currentColor}

.nav{position:sticky;top:0;z-index:50;background:rgba(252,240,225,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav .container{display:flex;align-items:center;justify-content:space-between;height:84px;gap:24px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:54px;width:auto}
.nav-links{display:flex;align-items:center;gap:30px;font-family:var(--sans);font-weight:500;font-size:.95rem}
.nav-links a{color:var(--forest);position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--taupe);transition:width .25s}
.nav-links a:hover::after{width:100%}
.nav-cta{border:1.6px solid var(--forest);border-radius:999px;padding:10px 22px;font-weight:600;color:var(--forest);transition:.2s}
.nav-cta:hover{background:var(--forest);color:var(--cream)}
.nav-cta::after{display:none!important}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{display:block;width:26px;height:2px;background:var(--forest);margin:5px 0;transition:.3s}

/* ---------- Hero ---------- */
.hero{background:var(--cream)}
.hero .grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,72px);align-items:center;min-height:78vh;padding:clamp(40px,6vw,80px) 0}
.hero-copy h1{margin-bottom:.18em}
.hero-copy .sub{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(1.3rem,2.4vw,1.9rem);color:var(--taupe);margin-bottom:1.4em;display:block}
.hero-media{position:relative;border-radius:24px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/5;background:var(--sage)}
.hero-media video,.hero-media img{width:100%;height:100%;object-fit:cover}

/* ---------- Split block ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center}
.split.reverse .media{order:2}
.split .media{border-radius:22px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:5/4}
.split .media img{width:100%;height:100%;object-fit:cover}

/* ---------- Slideshow ---------- */
.slideshow{position:relative;border-radius:22px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:5/4;background:var(--sage)}
.slideshow .slide{position:absolute;inset:0;opacity:0;transition:opacity 1s ease;}
.slideshow .slide.active{opacity:1}
.slideshow .slide img{width:100%;height:100%;object-fit:cover}
.dots{position:absolute;bottom:16px;left:0;right:0;display:flex;gap:8px;justify-content:center;z-index:2}
.dots button{width:9px;height:9px;border-radius:50%;border:0;background:rgba(252,240,225,.55);cursor:pointer;padding:0;transition:.2s}
.dots button.active{background:var(--cream);width:24px;border-radius:999px}

/* ---------- Cards (events) ---------- */
.cards{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.card{background:var(--cream);border:1px solid var(--line);border-radius:22px;padding:40px;display:flex;flex-direction:column;transition:.25s;box-shadow:0 1px 0 rgba(0,0,0,.02)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card h3{margin-bottom:.5em}
.card p{color:#4a443c;flex:1}

/* ---------- Testimonials ---------- */
.testimonials{background:var(--forest);color:var(--cream);text-align:center}
.testimonials h2,.testimonials .eyebrow{color:var(--cream)}
.testimonials .eyebrow{color:var(--sage)}
.quote-wrap{position:relative;max-width:880px;margin:30px auto 0;min-height:230px}
.quote{position:absolute;inset:0;opacity:0;transition:opacity .8s;display:flex;flex-direction:column;justify-content:center}
.quote.active{opacity:1}
.quote p{font-family:var(--serif);font-weight:400;font-size:clamp(1.4rem,2.8vw,2.1rem);line-height:1.3;color:var(--cream);font-style:italic}
.quote .who{font-family:var(--sans);font-style:normal;font-size:.95rem;letter-spacing:.06em;text-transform:uppercase;color:var(--sage);margin-top:18px}
.q-nav{display:flex;gap:10px;justify-content:center;margin-top:34px}
.q-nav button{width:9px;height:9px;border-radius:50%;border:0;background:rgba(252,240,225,.35);cursor:pointer;transition:.2s}
.q-nav button.active{background:var(--sage);width:26px;border-radius:999px}

/* ---------- Location ---------- */
.location{background:var(--peach)}
.location .split .media{aspect-ratio:auto;box-shadow:var(--shadow)}
.map-frame{border-radius:22px;overflow:hidden;box-shadow:var(--shadow);min-height:380px}
.map-frame iframe{width:100%;height:100%;min-height:380px;border:0;display:block}
.hours-row{display:flex;justify-content:space-between;max-width:340px;padding:10px 0;border-bottom:1px solid var(--line)}
.hours-row strong{color:var(--forest)}
.addr{font-style:normal;font-size:1.15rem;line-height:1.7;margin:14px 0 26px}

/* ---------- Footer ---------- */
.footer{background:var(--forest-deep);color:var(--cream);padding:72px 0 40px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1.3fr;gap:48px}
.footer h4{color:var(--cream);font-family:var(--serif);font-size:1.4rem;margin-bottom:18px}
.footer .wordmark{height:64px;filter:brightness(0) invert(1);opacity:.92;margin-bottom:18px}
.footer a{color:rgba(252,240,225,.82);transition:color .2s}
.footer a:hover{color:var(--cream)}
.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px;font-size:.98rem}
.foot-socials{display:flex;gap:16px;margin-top:8px}
.foot-socials svg{width:20px;height:20px;fill:currentColor;opacity:.85}
.foot-socials a:hover svg{opacity:1}
.signup form{display:flex;gap:10px;margin-top:8px;flex-wrap:wrap}
.signup input{flex:1;min-width:170px;padding:13px 16px;border-radius:999px;border:1px solid rgba(252,240,225,.3);background:rgba(252,240,225,.08);color:var(--cream);font-family:var(--sans)}
.signup input::placeholder{color:rgba(252,240,225,.55)}
.footer-bottom{margin-top:54px;padding-top:24px;border-top:1px solid rgba(252,240,225,.16);display:flex;justify-content:space-between;gap:16px;font-size:.84rem;color:rgba(252,240,225,.6);flex-wrap:wrap}

/* ---------- Page hero (subpages) ---------- */
.page-hero{background:var(--forest);color:var(--cream);text-align:center;padding:clamp(70px,10vw,130px) 0 clamp(56px,8vw,104px)}
.page-hero h1{color:var(--cream)}
.page-hero .eyebrow{color:var(--sage)}
.media-hero{position:relative;min-height:60vh;display:flex;align-items:flex-end;color:var(--cream);overflow:hidden}
.media-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.media-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(38,57,46,.15),rgba(38,57,46,.78));z-index:1}
.media-hero .container{position:relative;z-index:2;padding-bottom:56px}
.media-hero h1{color:var(--cream)}

/* overlay badge for menu */
.overlay-wrap{position:relative;border-radius:22px;overflow:hidden;box-shadow:var(--shadow)}
.overlay-wrap img{width:100%;display:block}
.overlay-wrap .overlay-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;background:rgba(38,57,46,.5);color:var(--cream);padding:20px}
.overlay-text h2{color:var(--cream);font-size:clamp(2rem,5vw,4rem)}

.checklist{list-style:none;padding:0;margin:18px 0 30px;display:grid;gap:12px}
.checklist li{display:flex;gap:12px;align-items:flex-start;color:#4a443c}
.checklist li::before{content:"✦";color:var(--taupe);font-size:1.1rem;line-height:1.4}

.tag{display:inline-block;background:var(--sage);color:var(--forest-deep);font-weight:600;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;padding:7px 14px;border-radius:999px;margin-bottom:18px}

.photo-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:48px}
.photo-strip img{border-radius:14px;aspect-ratio:1;object-fit:cover;box-shadow:var(--shadow)}

.bg-sage{background:var(--sage)}
.bg-peach{background:var(--peach)}
.center{text-align:center}
.mx-auto{margin-left:auto;margin-right:auto}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  body{font-size:17px}
  .hero .grid,.split,.cards,.footer-grid{grid-template-columns:1fr}
  .hero .grid{min-height:auto;gap:36px}
  .hero-media{aspect-ratio:4/3;order:-1}
  .split.reverse .media{order:0}
  .photo-strip{grid-template-columns:repeat(2,1fr)}
  .nav-links{position:fixed;inset:84px 0 auto 0;background:var(--cream);flex-direction:column;align-items:flex-start;padding:24px 28px;gap:20px;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .35s;box-shadow:var(--shadow)}
  .nav-links.open{transform:translateY(0)}
  .nav-toggle{display:block}
  .footer-bottom{justify-content:flex-start}
}
