:root{
  --cream:#f5f1e8;
  --cream-2:#efeadd;
  --sage:#dde0cd;
  --plum:#5d3a63;
  --plum-dark:#492c4f;
  --plum-deep:#3f2645;
  --green:#74883f;
  --green-dark:#647535;
  --gold:#b8923f;
  --ink:#3a3236;
  --muted:#6f6670;
  --line:#e2dccf;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Montserrat',sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:'Cormorant Garamond',serif;font-weight:500;line-height:1.1;color:var(--plum)}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}

/* ---------- PHOTO SLOTS (replace these with real <img>) ---------- */
.photo{
  position:relative;
  background:linear-gradient(135deg,var(--sage),var(--cream-2));
  display:flex;align-items:center;justify-content:center;
  color:var(--green-dark);
  overflow:hidden;
}
.photo::after{
  content:attr(data-label);
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;opacity:.55;padding:10px;text-align:center;
}
.photo .leaf{position:absolute;font-size:46px;opacity:.18;top:14px;left:16px}

/* ---------- NAV ---------- */
.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(245,241,232,.96);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;gap:22px;height:80px}
.brand{display:flex;flex-direction:column;line-height:1;flex-shrink:0}
.brand .name{font-family:'Great Vibes',cursive;font-size:32px;color:var(--green-dark);white-space:nowrap;display:flex;align-items:baseline;gap:5px}
.brand .name .l{font-size:14px}
.brand .tag{font-size:8px;letter-spacing:.2em;text-transform:uppercase;color:var(--green-dark);margin-top:3px;white-space:nowrap}
.menu{display:flex;align-items:center;gap:17px;list-style:none;margin-left:auto}
.menu a{font-size:11px;letter-spacing:.08em;text-transform:uppercase;font-weight:500;color:var(--plum);transition:color .2s;white-space:nowrap}
.menu a:hover,.menu a.active{color:var(--green-dark)}
.menu a.btn-pill,.menu a.btn-pill:hover{color:#fff}
.btn-pill{
  background:var(--plum);color:#fff;padding:10px 15px;border-radius:30px;
  font-size:10px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;
  transition:background .2s,transform .2s;border:none;cursor:pointer;
  white-space:nowrap;flex-shrink:0;
}
.btn-pill:hover{background:var(--plum-dark);transform:translateY(-1px)}
.hamburger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px}
.hamburger span{width:24px;height:2px;background:var(--plum);transition:.3s}

/* ---------- BUTTONS ---------- */
.btn-green{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--green);color:#fff;padding:13px 26px;
  font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;
  transition:background .2s,transform .2s;border:none;cursor:pointer;
}
.btn-green:hover{background:var(--green-dark);transform:translateY(-1px)}
.btn-plum{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--plum);color:#fff;padding:13px 26px;
  font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;
  transition:background .2s,transform .2s;border:none;cursor:pointer;
}
.btn-plum:hover{background:var(--plum-dark);transform:translateY(-1px)}
.link-arrow{display:inline-flex;align-items:center;gap:7px;color:var(--plum);font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:600}
.link-arrow:hover{color:var(--green-dark)}

/* ---------- HERO (full-bleed image, text LOCKED LEFT of viewport) ---------- */
.hero{position:relative;min-height:90vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 16%}
.hero-scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(95deg,rgba(245,241,232,.82) 0%,rgba(245,241,232,.5) 24%,rgba(245,241,232,.14) 40%,rgba(245,241,232,0) 54%);}
/* content pinned to the LEFT of the viewport — never centered, never over Michelle */
.hero-content{position:relative;z-index:2;width:100%;padding:0 clamp(28px,5vw,90px)}
.hero-text{max-width:560px}
.hero-content h1{font-size:clamp(38px,4.4vw,56px);line-height:1.05;margin-bottom:20px;text-shadow:0 1px 2px rgba(245,241,232,.9)}
.hero-content h1 .accent{display:block;font-style:italic;color:var(--green-dark)}
.hero-divider{display:flex;align-items:center;gap:10px;max-width:300px;margin:0 0 22px}
.hero-divider .ln{flex:1;height:1px;background:var(--gold)}
.hero-divider .lf{color:var(--gold);font-size:15px}
.hero-content p{color:var(--ink);max-width:440px;margin-bottom:28px;font-size:15px;font-weight:500;text-shadow:0 1px 2px rgba(245,241,232,.9)}
.hero-cta{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.btn-outline-hero{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:40px;
  border:1.5px solid var(--plum);color:var(--plum);background:rgba(255,255,255,.55);
  font-family:'Montserrat',sans-serif;font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
  transition:all .25s;white-space:nowrap}
.btn-outline-hero:hover{background:var(--plum);color:#fff}
/* circular badge, right side, hidden on small screens */
.hero-badge{position:absolute;z-index:2;top:50%;right:clamp(20px,4vw,72px);transform:translateY(-50%);
  width:152px;height:152px;border-radius:50%;background:var(--green);color:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:18px;
  box-shadow:0 12px 32px rgba(0,0,0,.2)}
.hero-badge .blf{font-size:18px;color:#e9e4ce;margin-bottom:5px}
.hero-badge .bt{font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;font-weight:600;line-height:1.35}
.hero-badge .bs{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:17px;margin-top:7px;color:#f1edda}
@media(max-width:1180px){.hero-badge{display:none}}

/* category strip */
.strip{background:var(--plum);}
.strip-inner{display:flex;justify-content:space-between;flex-wrap:wrap}
.strip-item{
  flex:1;min-width:200px;text-align:center;color:#fff;
  padding:16px 10px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  border-right:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;gap:9px;
}
.strip-item:last-child{border-right:none}
.strip-item .lf{color:var(--gold)}

/* ---------- MEET ---------- */
.section{padding:80px 0}
.meet-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center}
.meet-photo{width:330px;height:330px;border-radius:50%;margin:0 auto;border:2px solid var(--green);position:relative;overflow:hidden;background-size:cover;background-position:center 20%}
.eyebrow{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--green-dark);font-weight:600;margin-bottom:14px}
.meet h2{font-size:44px;margin-bottom:22px}
.meet p{color:var(--muted);margin-bottom:16px;font-size:15px}

/* ---------- KITCHEN ---------- */
.kitchen{background:var(--sage)}
.kitchen-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:55px;align-items:center}
.kitchen h2{font-size:42px;margin-bottom:20px;line-height:1.05}
.kitchen p{color:#5c5746;margin-bottom:26px;font-size:15px}
.kitchen-photo{height:360px;border-radius:6px}

/* ---------- SPEAKING ---------- */
.speaking-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:0;align-items:stretch}
.speaking-photo{min-height:360px}
.speaking-text{background:var(--cream);display:flex;flex-direction:column;justify-content:center;padding:60px 50px}
.speaking-text h2{font-size:40px;margin-bottom:20px;line-height:1.05}
.speaking-text p{color:var(--muted);margin-bottom:26px;font-size:15px}

/* ---------- RECIPES ---------- */
.recipes{background:var(--cream-2);text-align:center}
.recipes .eyebrow{margin-bottom:38px}
.recipe-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 6px 22px rgba(70,45,75,.07);transition:transform .25s,box-shadow .25s;text-align:left}
.card:hover{transform:translateY(-6px);box-shadow:0 14px 32px rgba(70,45,75,.13)}
.card .photo{height:175px}
.card-body{padding:18px 18px 22px}
.card-body h3{font-size:21px;line-height:1.15;margin-bottom:12px;color:var(--ink)}
.browse{margin-top:42px}
.btn-outline{
  display:inline-flex;align-items:center;gap:8px;background:transparent;border:1px solid var(--green);
  color:var(--green-dark);padding:13px 28px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;
  transition:.2s;cursor:pointer;border-radius:2px;
}
.btn-outline:hover{background:var(--green);color:#fff}

/* ---------- FOOTER BANDS ---------- */
.cta-band{background:var(--plum);color:#fff;position:relative;overflow:hidden}
.cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;padding:60px 0}
.cta-band h3{color:#fff;font-size:30px;margin-bottom:14px}
.cta-band p{font-size:14px;opacity:.9;margin-bottom:22px;max-width:340px}
.sub-form{display:flex;max-width:380px}
.sub-form input{flex:1;border:none;padding:13px 16px;font-family:inherit;font-size:13px;border-radius:3px 0 0 3px}
.sub-form input:focus{outline:2px solid var(--gold);outline-offset:-2px}
.sub-form button{border-radius:0 3px 3px 0;border:none}
.cta-band .leaf-bg{position:absolute;font-size:150px;opacity:.07;color:#fff}
.lb1{left:-20px;bottom:-30px}.lb2{right:-20px;top:-30px}

footer.site-foot{background:var(--cream);padding:36px 0;border-top:1px solid var(--line)}
.foot-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px}
.foot-brand .name{font-family:'Great Vibes',cursive;font-size:30px;color:var(--green-dark)}
.foot-brand .tag{font-size:8px;letter-spacing:.2em;text-transform:uppercase;color:var(--green-dark)}
.socials{display:flex;gap:18px}
.socials a{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--plum);transition:.2s}
.socials a:hover{color:var(--green-dark);transform:translateY(-2px)}
.socials svg{width:18px;height:18px;fill:currentColor}
.foot-links{display:flex;gap:26px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:500}
.foot-links a:hover{color:var(--green-dark)}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .menu{
    position:fixed;top:80px;right:0;width:260px;height:calc(100vh - 80px);
    background:var(--cream);flex-direction:column;align-items:flex-start;gap:0;
    padding:24px;box-shadow:-6px 0 24px rgba(0,0,0,.08);
    transform:translateX(100%);transition:transform .3s;z-index:60;
  }
  .menu.open{transform:translateX(0)}
  .menu li{width:100%;padding:12px 0;border-bottom:1px solid var(--line)}
  .hamburger{display:flex}
  .hero{min-height:76vh}
  .hero-scrim{background:linear-gradient(120deg,rgba(245,241,232,.85) 28%,rgba(245,241,232,.5) 62%,rgba(245,241,232,.14) 100%)}
  .meet-grid,.kitchen-grid,.speaking-grid,.cta-grid{grid-template-columns:1fr;gap:36px}
  .speaking-photo{min-height:300px}
  .recipe-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .wrap{padding:0 18px}
  .hero-content h1{font-size:30px}
  .hero{min-height:80vh}
  .meet h2,.kitchen h2,.speaking-text h2{font-size:32px}
  .recipe-grid{grid-template-columns:1fr}
  .strip-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.18)}
  .foot-inner{flex-direction:column;text-align:center}
  .sub-form{flex-direction:column;gap:10px}
  .sub-form input,.sub-form button{border-radius:3px;width:100%}
}

#heroPhoto{background-image:url('images/michelle-hero.jpg');background-position:62% 14%}
#speakingPhoto{background-image:url('images/michelle-speaking.jpg');background-size:cover;background-position:center 30%}
#meetPhoto{background-image:url('images/michelle-headshot.jpg');background-size:cover;background-position:center 18%}
#kitchenPhoto{background-image:url('images/featured-buddha-bowl.jpg');background-size:cover;background-position:center}
#recipe1{background-image:url('images/recipe-chickpea-bowls.jpg');background-size:cover;background-position:center}
#recipe2{background-image:url('images/recipe-blueberry-pancakes.jpg');background-size:cover;background-position:center}
#recipe3{background-image:url('images/recipe-mushroom-pasta.jpg');background-size:cover;background-position:center}
#recipe4{background-image:url('images/recipe-avocado-mousse.jpg');background-size:cover;background-position:center}
/* ---------- INTRO ---------- */
.intro{background:var(--cream);padding:64px 0 56px;text-align:center}
.intro-inner{max-width:760px;margin:0 auto;padding:0 24px}
.intro-name{font-family:'Great Vibes',cursive;font-size:clamp(46px,6vw,72px);color:var(--plum);line-height:1.05;margin:6px 0 18px}
.intro-lead{font-size:clamp(16px,2vw,19px);line-height:1.7;color:var(--ink);max-width:640px;margin:0 auto}
.intro-div{margin:26px auto 0;justify-content:center}
.intro .eyebrow{justify-content:center}

/* ---------- SUBPAGE HEADER / ARTICLE ---------- */
.page-head{background:linear-gradient(135deg,var(--sage),var(--cream));padding:96px 0 64px;text-align:center}
.page-head .eyebrow{display:block;margin-bottom:10px}
.page-head h1{font-size:clamp(38px,5vw,58px);color:var(--plum);margin-bottom:16px}
.page-head p{max-width:620px;margin:0 auto;color:var(--ink);font-size:17px;line-height:1.6}
.page-wrap{max-width:1080px;margin:0 auto;padding:64px 24px}

/* recipe article */
.recipe{padding:48px 0;border-bottom:1px solid #e7e1d3;scroll-margin-top:100px}
.recipe:last-child{border-bottom:none}
.recipe-main{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start}
.recipe .rphoto{width:100%;height:340px;border-radius:8px;background-size:cover;background-position:center;box-shadow:0 10px 30px rgba(70,45,75,.1)}
.recipe h2{font-size:34px;color:var(--plum);margin-bottom:8px}
.recipe .meta{display:flex;gap:22px;flex-wrap:wrap;margin:14px 0 18px;font-size:13px;letter-spacing:.04em;color:var(--green-dark);font-weight:600;text-transform:uppercase}
.recipe .meta span{display:flex;flex-direction:column;line-height:1.3}
.recipe .meta span b{font-size:16px;color:var(--ink);text-transform:none;letter-spacing:0}
.recipe .desc{color:var(--ink);margin-bottom:22px;font-size:15px;line-height:1.7}
.recipe h4{font-family:'Montserrat',sans-serif;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--green-dark);margin:18px 0 10px;font-weight:700}
.recipe ul,.recipe ol{margin:0 0 6px 18px;color:var(--ink);font-size:15px;line-height:1.7}
.recipe ul li,.recipe ol li{margin-bottom:7px}
@media(max-width:820px){.recipe-main{grid-template-columns:1fr;gap:24px}.recipe .rphoto{height:260px}}

/* Michelle's Tip card */
.tip-card{margin-top:30px;background:var(--sage);border-left:4px solid var(--plum);border-radius:12px;padding:26px 30px}
.tip-h{font-family:'Montserrat',sans-serif;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--plum);font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.tip-card p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:20px;line-height:1.6;color:var(--ink);margin:0}
.tip-card .sig{display:block;margin-top:14px;font-family:'Great Vibes',cursive;font-size:26px;color:var(--plum);font-style:normal}

/* Closing note from Michelle */
.note-card{margin:60px auto 0;max-width:780px;background:linear-gradient(135deg,var(--sage),var(--cream));border-radius:16px;padding:46px 44px;text-align:center;border-top:3px solid var(--plum);box-shadow:0 10px 34px rgba(70,45,75,.08)}
.note-card .tip-h{justify-content:center}
.note-card p{font-family:'Cormorant Garamond',serif;font-size:20px;line-height:1.7;color:var(--ink);margin-bottom:16px}
.note-card p:last-of-type{margin-bottom:0}
.note-card .sig{display:block;font-family:'Great Vibes',cursive;font-size:34px;color:var(--plum);margin-top:18px}

/* blog */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.post{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 6px 22px rgba(70,45,75,.07);display:flex;flex-direction:column}
.post .pphoto{height:190px;background-size:cover;background-position:center}
.post-body{padding:22px;flex:1;display:flex;flex-direction:column}
.post .cat{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--green-dark);font-weight:700;margin-bottom:8px}
.post h3{font-size:21px;color:var(--ink);line-height:1.25;margin-bottom:10px}
.post p{font-size:14px;color:var(--muted);line-height:1.6;flex:1}
.post .link-arrow{margin-top:14px}
@media(max-width:820px){.blog-grid{grid-template-columns:1fr}}

/* booking */
.book-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start}
.book-info h2{font-size:30px;color:var(--plum);margin-bottom:14px}
.book-info p{color:var(--ink);line-height:1.7;font-size:15px;margin-bottom:18px}
.book-info .svc{display:flex;gap:12px;align-items:flex-start;margin-bottom:16px}
.book-info .svc .lf{color:var(--green);font-size:18px;margin-top:2px}
.book-info .svc b{display:block;color:var(--ink);font-size:16px;margin-bottom:2px}
.book-info .svc span{color:var(--muted);font-size:14px;line-height:1.5}
.book-form{background:#fff;border-radius:10px;padding:32px;box-shadow:0 10px 34px rgba(70,45,75,.1)}
.book-form label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin:14px 0 6px;letter-spacing:.02em}
.book-form input,.book-form select,.book-form textarea{width:100%;padding:12px 14px;border:1px solid #d9d2c4;border-radius:7px;font-family:'Montserrat',sans-serif;font-size:14px;color:var(--ink);background:var(--cream)}
.book-form textarea{min-height:96px;resize:vertical}
.book-form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.book-form button{margin-top:22px;width:100%}
.book-note{font-size:12px;color:var(--muted);margin-top:14px;text-align:center}
.cal-embed{margin-top:24px;border-radius:10px;overflow:hidden;min-height:0}
@media(max-width:820px){.book-grid{grid-template-columns:1fr;gap:32px}.book-form .row{grid-template-columns:1fr}}

/* ---------- INTERACTIVE INTRO ---------- */
.enter{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;overflow:hidden;opacity:1;transition:opacity .7s ease}
.enter.hide{opacity:0;pointer-events:none}
.enter-bg{position:absolute;inset:0;background:url('images/michelle-hero.jpg') center 14%/cover;transform:scale(1.04);animation:mb-zoom 8s ease-out both}
.enter-scrim{position:absolute;inset:0;background:linear-gradient(160deg,rgba(73,44,79,.6),rgba(73,44,79,.74))}
.enter-content{position:relative;z-index:2;text-align:center;color:#f5f1e8;padding:28px;max-width:680px;animation:mb-rise .9s .1s ease both}
.enter-eyebrow{font-family:'Montserrat',sans-serif;font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:#e7d9b0;margin-bottom:8px}
.enter-name{font-family:'Great Vibes',cursive;font-weight:400;font-size:clamp(58px,12vw,104px);line-height:1.02;color:#fff;margin-bottom:4px}
.enter .sdiv{display:flex;align-items:center;justify-content:center;gap:10px;margin:14px auto}
.enter .sdiv .ln{width:54px;height:1px;background:var(--gold)}
.enter .sdiv .lf{color:var(--gold);font-size:15px}
.enter-lead{font-size:clamp(15px,2vw,18px);line-height:1.6;color:#f0ead8;margin:14px auto 28px;max-width:470px}
.enter-btn{font-size:13px;padding:16px 44px;letter-spacing:.14em}
.enter-links{margin-top:22px;font-size:13px;letter-spacing:.03em}
.enter-links a{color:#f0ead8;text-decoration:underline;margin:0 8px}
.enter-links a:hover{color:#fff}
.enter-links span{color:#c8a6c7}
@keyframes mb-rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes mb-zoom{from{transform:scale(1.12)}to{transform:scale(1.04)}}
