/* Warm theme + gallery + FAQ + cert side */
:root{--teal:#55968e; --goldBrand:#e9be62; --orangeBrand:#ED5A27; --logo-grad:linear-gradient(90deg, rgba(85,150,142,0.4) 0%, rgba(233,190,98,0.4) 48%, rgba(237,90,39,0.4) 100%); --text:#3d2e2a; --muted:#7b6154; --gold:#f2c066; --sunset:#e8632b; --shadow:0 14px 34px rgba(0,0,0,.10); --radius:22px --certViolet:#6F42C1;}
*{box-sizing:border-box} html,body{margin:0;padding:0}
body{font-family:'Quicksand',system-ui,-apple-system,Arial,sans-serif;color:var(--text);
background: url('paper.png'),  var(--logo-grad), linear-gradient(180deg,#fff7f0 0%,#ffecd9 45%,#ffdcb8 100%);line-height:1.65}
img{max-width:100%;display:block}
.container{width:min(1120px,92vw);margin-inline:auto}.container.narrow{width:min(800px,92vw)}
.site-header{position:sticky;top:0;z-index:50;background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(255,236,224,.9));backdrop-filter:blur(10px);border-bottom:1px solid rgba(240,122,75,.22);box-shadow:0 6px 18px rgba(240,122,75,.10)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:10px 0}.brand .logo{width:150px}@media(max-width:900px){.brand .logo{width:120px}}
.nav-toggle{display:none}.nav-list{display:flex;gap:22px;list-style:none;padding:0;margin:0}.nav-list a{color:var(--text);text-decoration:none;font-weight:700}.nav-list a:hover{color:var(--sunset)}
.hero{padding:clamp(80px,14vh,160px) 0;text-align:center;position:relative;overflow:hidden}
.hero.warm{background:radial-gradient(1200px 560px at 12% -10%,rgba(240,122,75,.50),transparent 60%),radial-gradient(1200px 620px at 88% -8%,rgba(240,191,102,.46),transparent 60%),radial-gradient(1300px 760px at 50% 100%,rgba(29,183,176,.26),transparent 70%)}
.hero h1{font-size:clamp(38px,6.2vw,68px);margin:0 0 10px}.hero .sub{font-size:clamp(16px,2.6vw,22px);color:var(--muted);margin:0 0 24px;max-width:720px;margin-inline:auto}
.cta{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.button{display:inline-block;padding:12px 20px;border-radius:999px;text-decoration:none;font-weight:800;letter-spacing:.2px;border:2px solid transparent;transition:.2s transform ease,.2s box-shadow ease,.2s background ease;cursor:pointer}
.button:hover{transform:translateY(-2px);box-shadow:0 18px 38px rgba(240,122,75,.28)}
.button.primary{background:linear-gradient(90deg,var(--sunset),var(--gold));color:#fff;border:0;box-shadow:0 14px 36px rgba(240,122,75,.28)}
.button.ghost{border-color:var(--sunset);color:var(--sunset);background:#fff9ef}.button.outline{border-color:var(--gold);color:#7a5a20;background:#fff9ef}.button.small{padding:10px 14px;font-size:14px}
.section{padding:80px 0}.section.sand{background: url('paper.png'),  var(--logo-grad), linear-gradient(180deg,#ffe7d0,#fdddbb)}.section.gradient{background: url('paper.png'),  var(--logo-grad), linear-gradient(180deg,rgba(29,183,176,.12),rgba(240,122,75,.22))}
.grid.two{display:grid;grid-template-columns:1.05fr 1.2fr;gap:28px;align-items:start}@media(max-width:900px){.grid.two{grid-template-columns:1fr}}
.about-grid{grid-template-columns:1.05fr 1.2fr}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}@media(max-width:900px){.cards{grid-template-columns:1fr}}
.card{background:linear-gradient(180deg,#fff,#fff0e6);border-radius:var(--radius);padding:22px;box-shadow:0 20px 50px rgba(240,122,75,.16),var(--shadow);border:1px solid rgba(240,122,75,.18)
  border:1px solid transparent;
  border-image: linear-gradient(90deg,var(--teal),var(--goldBrand),var(--orangeBrand)) 1;
}.card h3{margin-top:0}
.mini-gallery{display:grid;grid-template-columns:1fr;gap:18px;margin-top:8px;position:relative}
.mini-gallery::before{content:"";position:absolute;inset:-18px -12px -12px;background:radial-gradient(600px 220px at 20% -10%,rgba(240,122,75,.20),transparent 70%),radial-gradient(520px 220px at 80% -8%,rgba(247,199,110,.18),transparent 75%);pointer-events:none;filter:blur(14px)}
.mini-gallery .thumb{position:relative;border:none;padding:0;background:transparent}
.mini-gallery img{width:100%;height:auto;aspect-ratio:3/2;object-fit:cover;border-radius:20px;box-shadow:0 32px 84px rgba(240,122,75,.32),var(--shadow);border:1px solid rgba(240,122,75,.20)}
.mini-gallery .featured img{aspect-ratio:4/5}
.cert-side{margin-top:10px;display:grid;place-items:center;gap:6px}
.cert-side .cert-badge-img{width:140px;height:auto;filter:drop-shadow(0 6px 18px rgba(240,122,75,.22))}
.session-figure img{border-radius:20px;box-shadow:0 26px 70px rgba(240,122,75,.30),var(--shadow);border:1px solid rgba(240,122,75,.28);width:min(720px,100%);margin-inline:auto;display:block}
.testi{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}@media(max-width:900px){.testi{grid-template-columns:1fr}}.testi blockquote{background:#fff;border-left:6px solid var(--sunset);padding:18px 18px 10px;border-radius:var(--radius);box-shadow:var(--shadow);margin:0}.testi cite{display:block;color:var(--muted);margin-top:8px}
.calendly-embed{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:8px}
.newsletter-form{background:#fff;padding:20px;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid rgba(0,0,0,.05)}
.newsletter-form label{display:block;font-weight:700;margin:10px 0 6px}.newsletter-form input{width:100%;padding:12px 14px;border-radius:14px;border:1px solid #d9e3e6;outline:none}.newsletter-form button{margin-top:10px}
.muted{color:var(--muted);font-size:13px}
/* FAQ accordions */
.faq{max-width:900px;margin:18px auto 0;display:grid;gap:12px}
.faq details{background:#fff;border:1px solid rgba(240,122,75,.18);border-radius:16px;box-shadow:0 16px 38px rgba(240,122,75,.12),var(--shadow);padding:10px 14px}
.faq summary{cursor:pointer;font-weight:800;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq details[open]{background:linear-gradient(180deg,#fff,#fff5ee)}
.faq p{margin:10px 0 6px}
h3.mini{margin:0 0 8px;font-size:18px}
/* Social logo buttons */
.social-logos{list-style:none;padding:0;margin:16px 0 0;display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.social-logos li a{display:inline-flex;align-items:center;justify-content:center;width:76px;height:76px;border-radius:22px;background:#fff;box-shadow:0 16px 40px rgba(240,122,75,.18),var(--shadow);border:1px solid rgba(240,122,75,.14);transition:transform .18s ease,box-shadow .18s ease}
.social-logos li a:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 22px 54px rgba(240,122,75,.26)}
.social-logos img{width:42px;height:auto;display:block}
@media (max-width: 520px){ .social-logos li a{ width:64px; height:64px } .social-logos img{ width:38px } }
.site-footer{border-top:1px solid rgba(0,0,0,.06);padding:20px 0;background:#fff}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-nav a{color:var(--muted);text-decoration:none;margin-left:12px}.footer-nav a:hover{color:var(--sunset)}
.section h2{text-align:center;position:relative;margin-bottom:12px}
.section h2::after{content:"";display:block;width:180px;height:6px;margin:12px auto 0;background:linear-gradient(90deg,var(--sunset),var(--gold));border-radius:999px;box-shadow:0 6px 16px rgba(240,122,75,.25)}
.cert-row{margin-top:18px;display:grid;place-items:center;gap:8px}.cert-badge-img{width:160px;height:auto;filter:drop-shadow(0 6px 18px rgba(240,122,75,.22))}
.list{margin:0;padding-left:18px}.list li{margin:8px 0}.lead{max-width:900px;margin:8px auto 24px;font-size:clamp(16px,2.2vw,20px)}

/* Certification under about-text */
.cert-inline{margin-top:26px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;width:100%;text-align:center}
.cert-inline img{width:140px;height:auto;filter:drop-shadow(0 6px 18px rgba(240,122,75,.22))}

@media (min-width: 900px){
  /* Push the cert to align visually with the middle photo */
  .cert-inline{ margin-top: clamp(120px, 18vh, 260px); }
}

/* Warmer headings */
h1,h2,h3{font-family:'Fraunces',serif;color:#3a2b25;letter-spacing:.2px}

/* Extra warm glows on sections */
.section{position:relative;isolation:isolate}
.section::before{
  content:"";position:absolute;inset:-40px -4vw -20px -4vw;z-index:-1;pointer-events:none;
  background:
    radial-gradient(900px 420px at 12% -6%, rgba(232,99,43,.14), transparent 60%),
    radial-gradient(860px 460px at 88% -10%, rgba(242,192,102,.16), transparent 65%);
  filter:blur(10px);
}

/* Hero even warmer */
.hero.warm{
  background:
    radial-gradient(1200px 560px at 12% -10%, rgba(232,99,43,.40), transparent 60%),
    radial-gradient(1200px 620px at 88% -8%, rgba(242,192,102,.38), transparent 60%),
    radial-gradient(1300px 760px at 50% 100%, rgba(245,180,90,.22), transparent 70%);
}

/* Cards: softer, creamier */
.card{
  background:linear-gradient(180deg,#fffdf9,#fff3e8);
  border-radius:28px;
  border:1px solid rgba(232,99,43,.16);
  box-shadow:0 26px 68px rgba(232,99,43,.16), 0 10px 26px rgba(0,0,0,.05);

  border:1px solid transparent;
  border-image: linear-gradient(90deg,var(--teal),var(--goldBrand),var(--orangeBrand)) 1;
}

/* Buttons: deeper warmth */
.button.primary{
  background:linear-gradient(90deg,#e8632b,#f2c066);
  box-shadow:0 18px 42px rgba(232,99,43,.28);
}
.button.ghost{border-color:#e8632b;color:#e8632b;background:#fff7ef}
.button.outline{border-color:#f2c066;color:#7a5a20;background:#fff7ef}

/* Photos: warm halo around images */
.mini-gallery img{
  border-radius:22px;
  box-shadow:
    0 36px 88px rgba(232,99,43,.26),
    0 10px 24px rgba(0,0,0,.08);
  outline:1px solid rgba(232,99,43,.20);
  outline-offset:-6px;
  background:
    radial-gradient(160% 140% at 50% 0%, rgba(242,192,102,.22), transparent 60%);
}

/* Section headings underline warmer */
.section h2::after{
  background:linear-gradient(90deg,#e8632b,#f2c066);
  box-shadow:0 8px 18px rgba(232,99,43,.28);
}

/* FAQ and forms warmer */
.faq details{
  background:linear-gradient(180deg,#fff,#fff7ef);
  border:1px solid rgba(232,99,43,.16);
  box-shadow:0 20px 46px rgba(232,99,43,.12);
}
.newsletter-form{
  background:linear-gradient(180deg,#fff,#fff7ef);
  border:1px solid rgba(232,99,43,.10);
  box-shadow:0 22px 52px rgba(232,99,43,.12);
}
.newsletter-form input{background:#fffdfb}

/* Cert badge: subtle warm frame */
.cert-inline img{
  border-radius:20px;
  background:linear-gradient(180deg,#fff,#fff4e6);
  padding:8px;
  outline:1px solid rgba(232,99,43,.16);
  outline-offset:-4px;
  box-shadow:0 18px 42px rgba(232,99,43,.18);
}

/* CTA hover a bit stronger */
.button:hover{box-shadow:0 24px 54px rgba(232,99,43,.34);}

/* Divider glow under About */
.about-grid{row-gap:12px}

/* Wavy separators between sections */
.section{position:relative}
.section::after{
  content:"";
  position:absolute; left:8vw; right:8vw; top:0; height:3px;
  background: linear-gradient(90deg,var(--teal),var(--goldBrand),var(--orangeBrand));
  opacity:.22;
  border-radius:999px;
  box-shadow: 0 1px 10px rgba(237,90,39,.08);
  pointer-events:none;
}
/* Do not show on first section after hero boundary adjustments */
.section:first-of-type::after{ display:none }

/* Gradient bullets for method lists */
.method-grid .list li{ position:relative; padding-left:28px }
.method-grid .list li::before{
  content:""; width:14px; height:14px; border-radius:50%;
  background: linear-gradient(90deg,var(--teal),var(--goldBrand),var(--orangeBrand));
  position:absolute; left:0; top:.5em;
  box-shadow:0 6px 14px rgba(237,90,39,.22);
}

/* Micro-animations on scroll */
.reveal{ opacity:0; transform:translateY(10px); transition:opacity .5s ease, transform .5s ease }
.reveal.in{ opacity:1; transform:none }
.button:hover{ transform:translateY(-3px) scale(1.02) }

/* Remove default bullets where gradient mini-icons are used */
.method-grid .list{ list-style:none; padding-left:0 }

/* Hero bottom wave separator */
.hero{position:relative}
.hero::after{ display:none }

/* Remove borders around white cards */
.card{ border:0 !important; border-image:none !important; }

/* Testimonials */
.quote{font-style:italic; line-height:1.6}
.author{margin-top:8px; color:var(--muted); font-weight:600}


/* === Mobile overflow & background fix (iOS) === */
html, body { max-width: 100%; overflow-x: hidden; }

/* Improve background rendering on mobile to avoid side scroll */
body{
  background-repeat: no-repeat;
  background-position: center top, center top, center top;
  background-size: auto 100%, cover, cover;
}

/* iOS doesn't like background-attachment: fixed */
@media (max-width: 768px){
  body{
    background-attachment: scroll;
    background-size: auto 100%, 100% 100%, 100% 100%;
  }
}

/* Certification violet */
.cert-inline .muted{ color: var(--certViolet) !important; font-weight:700; }
.cert-inline .cert-text{ color: var(--certViolet); font-weight:800; letter-spacing:.8px; text-transform: uppercase; }

/* Footer logo backup size */
.site-footer .logo.small{ width:300px; height:auto; }



/* === v32: Mobile top menu wrap (<=640px) — design intact === */
@media (max-width: 640px){
  .header-inner{ flex-wrap: wrap; gap: 8px; }
  .brand h1{ font-size: 20px; }
  .logo{ width: 40px; }
  .nav{
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    row-gap: 6px;
    justify-content: space-between;
  }
  .nav a{
    white-space: nowrap;
    font-size: 14px;
    padding: 8px 10px;
  }
}

