/* ============================================================
   My Joyful Balance — shared styles
   Warm holistic-coaching aesthetic: terracotta accent,
   dark sage headings, cream grounds, elegant serif type.
   ============================================================ */

:root{
  --bg:#ffffff;
  --cream:#f7f1e7;
  --cream-deep:#efe5d4;
  --ink:#3c4a3b;          /* dark sage — headings */
  --ink-soft:#56624f;
  --body:#4c4a44;         /* warm gray — body copy */
  --muted:#8a857c;
  --line:#e7e0d3;
  --accent:#c2783c;       /* terracotta */
  --accent-deep:#a8632c;
  --accent-soft:#e3b07a;
  --shadow:0 18px 50px -24px rgba(60,50,30,.35);
  --shadow-sm:0 10px 30px -18px rgba(60,50,30,.40);

  --serif:'Lora', Georgia, 'Times New Roman', serif;
  --display:'EB Garamond', Georgia, serif;
  --max:1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--serif);
  color:var(--body);
  background:var(--bg);
  line-height:1.7;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4,h5{color:var(--ink);font-weight:600;line-height:1.18;margin:0;text-wrap:balance;}
p{margin:0 0 1em;text-wrap:pretty;}
em{font-style:italic;color:var(--ink-soft);}

.wrap{max-width:var(--max);margin:0 auto;padding:0 32px;}
.eyebrow{font-family:var(--serif);letter-spacing:.22em;text-transform:uppercase;font-size:12px;font-weight:600;color:var(--accent);}

/* ---------- Frame images ---------- */
.frame-img,.card-img,.band-img{display:block;}

/* ============================================================
   TOP UTILITY BAR  (social + language switcher)
   ============================================================ */
.utility{background:var(--ink);color:#e9e4d6;font-size:13px;}
.utility .wrap{display:flex;align-items:center;justify-content:flex-end;gap:22px;height:42px;}
.utility a{display:inline-flex;align-items:center;gap:7px;color:#e2dccb;opacity:.82;transition:opacity .2s,color .2s;}
.utility a:hover{opacity:1;color:#fff;}
.utility .u-social{display:flex;align-items:center;gap:16px;}
.utility .u-social svg{width:16px;height:16px;}
.utility .u-divider{width:1px;height:18px;background:rgba(255,255,255,.18);}

/* language switcher */
.lang-switch{display:flex;align-items:center;gap:2px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:3px;}
.lang-switch button{
  font-family:var(--serif);font-size:12px;font-weight:600;letter-spacing:.08em;
  border:0;background:transparent;color:#d9d3c4;padding:4px 11px;border-radius:999px;
  cursor:pointer;transition:background .2s,color .2s;line-height:1;
}
.lang-switch button:hover{color:#fff;}
.lang-switch button[aria-current="true"]{background:var(--accent);color:#fff;}

/* ============================================================
   HEADER
   ============================================================ */
#site-header{display:contents;}
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.6);-webkit-backdrop-filter:blur(18px) saturate(140%);backdrop-filter:blur(18px) saturate(140%);border-bottom:1px solid rgba(231,224,211,.55);}
.site-header .wrap{display:flex;align-items:center;gap:28px;height:88px;}
.brand{display:flex;align-items:center;gap:14px;}
.brand img{width:66px;height:66px;}
.brand .b-text{display:flex;flex-direction:column;line-height:1.05;gap:4px;}
.brand .b-name{font-family:var(--display);font-size:25px;font-weight:600;color:var(--ink);letter-spacing:.01em;}
.brand .b-tag{font-family:var(--display);font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:600;}

.nav{display:flex;align-items:center;gap:30px;margin-left:auto;}
.nav a{position:relative;font-size:16px;color:var(--ink-soft);padding:6px 0;transition:color .2s;}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--accent);transition:right .25s ease;}
.nav a:hover{color:var(--ink);}
.nav a:hover::after,.nav a[aria-current="page"]::after{right:0;}
.nav a[aria-current="page"]{color:var(--accent);}

.header-actions{display:flex;align-items:center;gap:18px;}
.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;color:var(--ink-soft);background:transparent;border:0;cursor:pointer;transition:background .2s,color .2s;}
.icon-btn:hover{background:var(--cream);color:var(--accent);}
.icon-btn svg{width:19px;height:19px;}
.phone-pill{display:inline-flex;align-items:center;gap:9px;border:1px solid var(--accent);color:var(--accent-deep);border-radius:999px;padding:9px 18px;font-size:14.5px;font-weight:600;transition:background .2s,color .2s;white-space:nowrap;}
.phone-pill:hover{background:var(--accent);color:#fff;}
.phone-pill svg{width:15px;height:15px;}

.burger{display:none;}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--cream);border-top:1px solid var(--line);margin-top:0;}
.footer-main{padding:64px 0 40px;}
.footer-main .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;}
.footer-brand .brand{margin-bottom:18px;}
.footer-brand p{color:var(--ink-soft);max-width:34ch;font-size:15.5px;}
.f-col h4{font-family:var(--display);font-size:20px;margin-bottom:16px;color:var(--ink);}
.f-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px;}
.f-col a{color:var(--ink-soft);font-size:15.5px;transition:color .2s;}
.f-col a:hover{color:var(--accent);}
.f-contact-row{display:flex;gap:10px;align-items:flex-start;color:var(--ink-soft);font-size:15.5px;margin-bottom:11px;}
.f-contact-row svg{width:17px;height:17px;color:var(--accent);flex:0 0 auto;margin-top:3px;}
.footer-social{display:flex;gap:14px;margin-top:18px;}
.footer-social a{display:inline-flex;width:40px;height:40px;border-radius:50%;align-items:center;justify-content:center;background:#fff;color:var(--ink-soft);box-shadow:var(--shadow-sm);transition:color .2s,transform .2s;}
.footer-social a:hover{color:var(--accent);transform:translateY(-2px);}
.footer-social svg{width:17px;height:17px;}
.footer-bottom{border-top:1px solid var(--line);padding:22px 0;}
.footer-bottom .wrap{display:flex;justify-content:space-between;align-items:center;gap:16px;font-size:13.5px;color:var(--muted);}

/* ============================================================
   SHARED SECTION PRIMITIVES
   ============================================================ */
section{position:relative;}
.section-pad{padding:96px 0;}
.center-narrow{max-width:760px;margin:0 auto;text-align:center;}

.btn{display:inline-flex;align-items:center;gap:9px;background:var(--accent);color:#fff;border:0;border-radius:999px;
  padding:14px 30px;font-family:var(--serif);font-size:16px;font-weight:600;cursor:pointer;transition:background .2s,transform .2s,box-shadow .2s;box-shadow:0 12px 26px -14px var(--accent-deep);}
.btn:hover{background:var(--accent-deep);transform:translateY(-2px);}
.btn.ghost{background:transparent;color:var(--accent-deep);border:1px solid var(--accent);box-shadow:none;}
.btn.ghost:hover{background:var(--accent);color:#fff;}

/* fade-up on scroll */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease;}
.reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}

/* ============================================================
   HERO (home)
   ============================================================ */
.hero{padding:72px 0 40px;}
.hero .wrap{display:grid;grid-template-columns:0.74fr 1.26fr;gap:72px;align-items:stretch;}
.hero-figure{position:relative;min-height:520px;}
.hero-figure::before{content:"";position:absolute;inset:20px -20px -20px 20px;background:var(--cream-deep);border-radius:12px;z-index:-1;}
.hero-figure img{width:100%;height:100%;object-fit:cover;border-radius:12px;background:var(--cream);box-shadow:var(--shadow);}
.hero-copy h1{font-family:var(--display);font-size:clamp(40px,4.6vw,64px);font-weight:600;letter-spacing:.005em;margin-bottom:26px;}
.hero-copy p{font-size:16.5px;color:var(--body);}
.hero-copy .lead-final{margin-top:18px;font-style:italic;color:var(--accent-deep);font-size:18px;}

/* ============================================================
   WAVE BAND
   ============================================================ */
.wave-band{position:relative;color:#fff;isolation:isolate;margin:40px 0;}
.wave-band .band-inner{position:relative;min-height:440px;display:flex;align-items:center;
  -webkit-mask:url("wave-mask.svg") top center/100% 100% no-repeat;
          mask:url("wave-mask.svg") top center/100% 100% no-repeat;}
.wave-band img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:0;box-shadow:none;z-index:-2;}
.wave-band .band-tint{position:absolute;inset:0;background:linear-gradient(90deg,rgba(34,40,32,.78),rgba(34,40,32,.62) 55%,rgba(34,40,32,.5));z-index:-1;}
.wave-band .wrap{display:grid;grid-template-columns:1.3fr .9fr;gap:40px;align-items:center;width:100%;padding-top:70px;padding-bottom:70px;}
.wave-band .band-copy p{color:#f3eee2;font-size:17px;text-shadow:0 1px 14px rgba(0,0,0,.35);}
.wave-band .band-copy .b-final{font-style:italic;color:#fff;}
.wave-band .band-title{font-family:var(--display);font-size:clamp(38px,4.4vw,58px);color:var(--accent-soft);font-weight:600;text-align:right;line-height:1.05;text-shadow:0 2px 18px rgba(0,0,0,.4);}

/* ============================================================
   INTRO STATEMENT
   ============================================================ */
.statement{text-align:center;}
.statement h2{font-family:var(--display);font-size:clamp(28px,3vw,40px);font-weight:600;color:var(--ink);max-width:900px;margin:0 auto 22px;}
.statement .s-sub{font-family:var(--display);font-size:clamp(22px,2.3vw,30px);color:var(--accent-deep);font-style:italic;}

/* ============================================================
   HOME CARDS (staggered)
   ============================================================ */
.cards-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px 64px;align-items:start;}
.cards-grid .col{display:flex;flex-direction:column;gap:80px;}
.cards-grid .col.offset{margin-top:90px;}
.offer-card img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:8px;margin-bottom:0;background:var(--cream);}
.offer-card .card-body{margin-top:16px;padding:18px 16px 0;border-top:1px solid var(--line);}
.offer-card h3{font-family:var(--display);font-size:27px;font-weight:600;margin-bottom:14px;}
.offer-card .q{font-style:italic;color:var(--accent-deep);margin-bottom:14px;display:block;}
.offer-card p{font-size:15.5px;}

/* ============================================================
   AANBOD (offerings) page
   ============================================================ */
.page-hero{padding:80px 0 30px;text-align:center;}
.page-hero h1{font-family:var(--display);font-size:clamp(34px,4vw,56px);font-weight:600;max-width:26ch;margin:0 auto;}
.page-hero .sub{font-family:var(--display);font-size:clamp(24px,2.5vw,34px);color:var(--accent-deep);font-style:italic;margin-top:14px;}

.questions-block{background:var(--cream);}
.questions-block .wrap{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.questions-block h2{font-family:var(--display);font-size:clamp(26px,2.6vw,36px);margin-bottom:24px;}
.q-list{list-style:none;margin:0 0 0;padding:0;display:grid;gap:14px;}
.q-list li{display:flex;gap:14px;align-items:flex-start;font-size:16.5px;color:var(--ink-soft);}
.q-list li::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--accent-soft);flex:0 0 auto;margin-top:9px;}
.questions-block .intake-note{font-size:16px;color:var(--body);}

.service{padding:72px 0;border-bottom:1px solid var(--line);}
.service .wrap{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.service.flip .s-media{order:2;}
.service .s-media img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:6px;background:var(--cream);}
.service h2{font-family:var(--display);font-size:clamp(30px,3.2vw,44px);font-weight:600;margin-bottom:6px;}
.price-row{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0 28px;}
.price-tag{background:transparent;border:1px solid var(--line);color:var(--ink-soft);border-radius:6px;padding:5px 12px;font-size:14px;font-weight:500;letter-spacing:.01em;}
.price-tag.lead{background:transparent;color:var(--accent-deep);border-color:var(--accent-soft);font-weight:600;}
.feature{margin-bottom:18px;}
.feature h4{font-size:18px;color:var(--ink);margin-bottom:4px;font-weight:600;}
.feature p{font-size:15.5px;margin:0;}
.service .btn{margin-top:10px;}

/* ============================================================
   JOYCE (about) page
   ============================================================ */
.about-hero{padding:80px 0;}
.about-hero .wrap{display:grid;grid-template-columns:1fr 1.02fr;gap:64px;align-items:start;}
.about-hero h1{font-family:var(--display);font-size:clamp(30px,3.2vw,44px);font-weight:600;margin-bottom:24px;}
.about-hero p{font-size:16.5px;}
.about-portrait img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:26px;position:sticky;top:110px;box-shadow:var(--shadow);background:var(--cream);}
.credentials{background:var(--cream);}
.credentials .wrap{display:grid;grid-template-columns:.8fr 1.2fr;gap:56px;}
.credentials h2{font-family:var(--display);font-size:clamp(28px,3vw,40px);font-weight:600;}
.cred-group{margin-bottom:26px;}
.cred-group h4{font-size:17px;color:var(--accent-deep);letter-spacing:.04em;margin-bottom:6px;}
.cred-group .school{font-style:italic;color:var(--muted);}
.cred-list{list-style:none;margin:8px 0 0;padding:0;display:grid;gap:8px;}
.cred-list li{display:flex;gap:11px;align-items:center;color:var(--ink-soft);}
.cred-list li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent);flex:0 0 auto;}
.testi{text-align:center;}
.testi h2{font-family:var(--display);font-size:clamp(28px,3vw,42px);font-style:italic;color:var(--ink);margin-bottom:46px;}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.testi-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:34px 30px;text-align:left;box-shadow:var(--shadow-sm);}
.testi-card .quote-mark{font-family:var(--display);font-size:54px;line-height:.6;color:var(--accent-soft);}
.testi-card p{font-style:italic;color:var(--body);margin:10px 0 18px;}
.testi-card .who{font-weight:600;color:var(--ink);font-style:normal;}
.testi-card.placeholder{border-style:dashed;border-color:var(--accent-soft);}
.testi-card .ph-note{font-style:normal;color:var(--muted);}
.testi-card .stars{color:var(--accent);letter-spacing:3px;font-size:15px;margin-bottom:8px;}
.testi-card .who .src{display:block;font-weight:400;font-style:normal;color:var(--muted);font-size:13.5px;margin-top:3px;}
.sk-reviews{margin-top:36px;min-height:280px;}
.sk-reviews .sk-ww-google-reviews{width:100%;border:none !important;border-radius:0 !important;background:transparent !important;}

/* ============================================================
   CONTACT page
   ============================================================ */
.contact-hero{padding:80px 0 20px;text-align:center;}
.contact-hero h1{font-family:var(--display);font-size:clamp(34px,4vw,54px);font-weight:600;}
.contact-hero p{max-width:62ch;margin:18px auto 0;font-size:17px;color:var(--ink-soft);}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:start;}
.contact-info{display:grid;gap:30px;}
.info-block{display:flex;gap:18px;align-items:flex-start;}
.info-block .ic{flex:0 0 auto;width:46px;height:46px;border-radius:50%;background:var(--cream);display:flex;align-items:center;justify-content:center;color:var(--accent);}
.info-block .ic svg{width:20px;height:20px;}
.info-block h4{font-size:18px;margin-bottom:4px;}
.info-block p,.info-block a{font-size:15.5px;color:var(--ink-soft);margin:0;}
/* WhatsApp call-to-action — read clearly as a tappable link */
.info-block a.wa-cta{display:inline-flex;align-items:center;gap:9px;margin-top:2px;padding:9px 16px 9px 12px;border-radius:999px;background:var(--cream);border:1px solid var(--line);color:var(--accent-deep);font-weight:600;font-size:15px;line-height:1;text-decoration:none;transition:background .2s,border-color .2s,color .2s,transform .2s;}
.info-block a.wa-cta:hover{background:#fff;border-color:var(--accent-soft);color:var(--accent-deep);transform:translateY(-1px);box-shadow:var(--shadow-sm);}
.wa-cta .wa-cta-ic{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;flex:0 0 auto;}
.wa-cta .wa-cta-ic svg{width:13px;height:13px;}
.hours-grid{display:grid;grid-template-columns:auto auto;gap:4px 22px;font-size:15.5px;color:var(--ink-soft);}
.contact-form{background:var(--cream);border-radius:12px;padding:40px;box-shadow:var(--shadow-sm);}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.field{margin-bottom:18px;display:flex;flex-direction:column;gap:7px;}
.field label{font-size:13.5px;font-weight:600;color:var(--ink);letter-spacing:.03em;}
.field input,.field textarea{font-family:var(--serif);font-size:15.5px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:8px;padding:12px 14px;transition:border-color .2s,box-shadow .2s;}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--accent-soft);box-shadow:0 0 0 3px rgba(194,120,60,.14);}
.field textarea{resize:vertical;min-height:230px;line-height:1.55;}
.form-note{font-size:13px;color:var(--muted);margin-top:6px;}
.form-ok{display:none;background:#eef3ea;border:1px solid #cde0c4;color:#46603a;border-radius:8px;padding:14px 16px;margin-bottom:18px;font-size:15px;}
.form-ok.show{display:block;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:900px){
  .hero .wrap,.wave-band .wrap,.statement,.questions-block .wrap,.service .wrap,
  .about-hero .wrap,.credentials .wrap,.contact-grid,.cards-grid,
  .testi-grid,.footer-main .wrap{grid-template-columns:1fr;}
  .cards-grid .col.offset{margin-top:0;}
  .cards-grid .col{gap:48px;}
  .service.flip .s-media{order:0;}
  .wave-band .band-title{text-align:left;}
  .wave-band .wrap{padding-top:96px;padding-bottom:96px;row-gap:24px;}
  .testi-grid{gap:18px;}
  .contact-form .row{grid-template-columns:1fr;}
  .footer-main .wrap{gap:36px;}

  .header-actions .phone-pill,.header-actions .icon-btn:not(.burger){display:none;}
  .header-actions{margin-left:auto;}
  .header-actions .burger{display:inline-flex;transition:transform .3s ease,color .25s ease;}
  .site-header.open .burger{color:var(--accent);transform:rotate(90deg);}

  .nav{
    position:absolute;top:88px;left:0;right:0;
    flex-direction:column;align-items:flex-start;
    margin-left:0;gap:14px;
    background:#fff;border-bottom:1px solid var(--line);
    padding:18px 32px;box-shadow:var(--shadow);
    opacity:0;visibility:hidden;transform:translateY(-10px);
    transition:opacity .28s ease,transform .28s ease,visibility .28s;
  }
  .site-header.open .nav{opacity:1;visibility:visible;transform:translateY(0);}
  .nav a{opacity:0;transform:translateY(6px);transition:opacity .3s ease,transform .3s ease;}
  .site-header.open .nav a{opacity:1;transform:translateY(0);}
  .site-header.open .nav a:nth-child(1){transition-delay:.06s;}
  .site-header.open .nav a:nth-child(2){transition-delay:.12s;}
  .site-header.open .nav a:nth-child(3){transition-delay:.18s;}
  .site-header.open .nav a:nth-child(4){transition-delay:.24s;}
  .section-pad{padding:64px 0;}
}
@media (max-width:560px){
  .wrap{padding:0 22px;}
  .utility .wrap{gap:14px;justify-content:space-between;}
  .brand .b-name{font-size:21px;}
}
