/*
Theme Name: Mana Mind and Meaning
Theme URI: https://manamindandmeaning.com
Author: Mana Mind and Meaning
Description: Custom theme for Mana Mind and Meaning Counselling Centre — Dr. Vandana Supriya Kasaravalli.
Version: 1.1
Requires PHP: 7.4
Text Domain: mana-mind-meaning
*/

<style>

  /* ============================================================
     TOKENS
     Stage  — the cinematic, dark performance world of the hero
     Sanctuary — the warm parchment world of the practice itself
  ============================================================ */
  /* colors are hardcoded directly below (no CSS variables) */
  *{box-sizing:border-box; margin:0; padding:0;}
  html{scroll-behavior:smooth;}
  body{font-family:'Outfit', sans-serif; color:#1E1B16; background:#FBF7EF; font-weight:300; line-height:1.7; overflow-x:hidden;}
  h1,h2,h3,h4{font-family:'Fraunces', serif; font-weight:500; letter-spacing:-0.01em; color:#1E1B16;}
  a{color:inherit; text-decoration:none;}
  img{max-width:100%; display:block;}
  button{font-family:inherit;}
  .wrap{max-width:1240px; margin:0 auto; padding:0 40px;}
  @media(max-width:640px){.wrap{padding:0 22px;}}
  @media (prefers-reduced-motion: reduce){*{animation:none !important; transition:none !important;}}
  ::selection{background:#9C2C63; color:#fff;}

  .eyebrow{
    display:flex; align-items:center; gap:12px; font-size:11.5px; letter-spacing:0.22em; text-transform:uppercase;
    color:#445939; font-weight:500; margin-bottom:18px;
  }
  .eyebrow::before{content:''; width:30px; height:1px; background:#445939;}
  .eyebrow.on-dark{color:rgba(255,255,255,0.7);}
  .eyebrow.on-dark::before{background:#C3AEE6;}

  /* ---------- NAV ---------- */
  header{position:fixed; top:0; left:0; right:0; z-index:200; background:rgba(251,247,239,0.86); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-bottom:1px solid rgba(30,27,22,0.08);}
  nav{display:flex; align-items:center; justify-content:space-between; padding:18px 40px; max-width:1240px; margin:0 auto;}
  .brand{display:flex; align-items:center; gap:11px;}
  .brand-mark{width:30px; height:30px; flex-shrink:0;}
  .brand-mark svg{width:100%; height:100%; display:block;}
  .brand-name{font-family:'Fraunces', serif; font-size:16.5px; font-weight:500;}
  .brand-name span{display:block; font-family:'Outfit',sans-serif; font-size:9.5px; letter-spacing:0.16em; text-transform:uppercase; color:#6C6354; font-weight:400; margin-top:2px;}
  .nav-links{display:flex; gap:36px; font-size:13.5px;}
  .nav-links a{position:relative; padding-bottom:5px; color:#6C6354; transition:color .25s; letter-spacing:0.02em;}
  .nav-links a::after{content:''; position:absolute; left:0; bottom:0; width:0; height:1px; background:#9C2C63; transition:width .25s;}
  .nav-links a:hover{color:#1E1B16;}
  .nav-links a:hover::after{width:100%;}
  .nav-cta{font-size:13px; display:flex; align-items:center; gap:8px; color:#fff; background:#9C2C63; padding:11px 22px; border-radius:30px; transition:all .3s cubic-bezier(.22,.68,0,1);}
  .nav-cta:hover{background:#6E1D46; gap:12px; transform:translateY(-1px);}
  .nav-toggle{display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; z-index:201;}
  .nav-toggle span{width:22px; height:1.5px; background:#1E1B16;}
  @media(max-width:900px){.nav-links{display:none;} .nav-cta{display:none;} .nav-toggle{display:flex;}}

  .mobile-menu{display:none; position:fixed; inset:0; background:#FBF7EF; z-index:199; flex-direction:column; align-items:center; justify-content:center; gap:28px;}
  .mobile-menu.open{display:flex;}
  .mobile-menu a{font-family:'Fraunces',serif; font-size:25px; color:#1E1B16; font-style:italic;}
  .mobile-menu a.nav-cta{font-style:normal; background:#9C2C63; color:#fff; padding:13px 30px;}

  /* ============================================================
     HERO — THE SANCTUARY
     Warm, calm, and clear: a counselling psychologist first.
  ============================================================ */
  .hero{
    position:relative; min-height:96vh; background:
      radial-gradient(120% 90% at 80% 20%, #F6F0E3 0%, #FBF7EF 55%),
      #FBF7EF;
    overflow:hidden; display:flex; align-items:center; padding:150px 0 60px;
  }
  .hero-canvas{position:absolute; inset:0; z-index:1; opacity:0; transition:opacity 1.6s ease; pointer-events:none;
    -webkit-mask-image:linear-gradient(100deg, transparent 0%, transparent 34%, rgba(0,0,0,0.5) 50%, #000 64%, #000 100%);
    mask-image:linear-gradient(100deg, transparent 0%, transparent 34%, rgba(0,0,0,0.5) 50%, #000 64%, #000 100%);
  }
  .hero-canvas.ready{opacity:1;}
  .hero-glow{position:absolute; inset:0; z-index:1; pointer-events:none; background:radial-gradient(55% 50% at 80% 55%, rgba(124,148,112,0.14), transparent 70%);}
  .hero-vignette{position:absolute; inset:0; z-index:2; pointer-events:none; background:linear-gradient(180deg, rgba(251,247,239,0.0) 0%, rgba(251,247,239,0) 80%, #FBF7EF 100%);}

  .hero .wrap{position:relative; z-index:3; width:100%;}
  .hero-main{display:grid; grid-template-columns:0.95fr 1.05fr; gap:34px; align-items:center;}
  .hero-headline{padding-right:30px;}
  .hero-headline h1{font-size:clamp(36px, 5vw, 64px); line-height:1.08; font-weight:400; letter-spacing:-0.02em; color:#1E1B16;}
  .hero-headline h1 em{font-style:italic; color:#9C2C63; font-weight:500;}
  .hero-cred{font-size:15.5px; color:#6C6354; margin:26px 0 12px; max-width:460px; line-height:1.85;}
  .hero-creds-line{font-size:13px; color:#6C6354; opacity:0.75; letter-spacing:0.03em; margin-bottom:36px;}
  .hero-actions{display:flex; gap:16px; flex-wrap:wrap;}
  .btn{display:inline-flex; align-items:center; gap:9px; padding:16px 30px; font-size:14px; letter-spacing:0.02em; transition:all .3s cubic-bezier(.22,.68,0,1); border:1px solid transparent; border-radius:32px; cursor:pointer;}
  .btn-primary{background:#9C2C63; color:#fff;}
  .btn-primary:hover{background:#6E1D46; transform:translateY(-2px); box-shadow:0 14px 28px -10px rgba(156,44,99,0.35);}
  .btn-ghost{border-color:#1E1B16; color:#1E1B16;}
  .btn-ghost:hover{border-color:#9C2C63; color:#9C2C63; gap:13px;}

  .hero-photo-block{position:relative; justify-self:end; width:100%; max-width:520px;}
  .hero-photo{position:relative; aspect-ratio:11/6.2; overflow:visible; perspective:1200px;}
  .hero-photo-shadow{position:absolute; inset:14px -14px -14px 14px; border-radius:16px; background:repeating-linear-gradient(135deg, #F6F0E3, #F6F0E3 2px, #F1E8D6 2px, #F1E8D6 4px); z-index:-1;}
  .hero-photo-inner{width:100%; height:100%; border-radius:16px; transform-style:preserve-3d; transition:transform .25s cubic-bezier(.22,.68,0,1); overflow:hidden; box-shadow:0 26px 54px -22px rgba(30,27,22,0.28);}
  .hero-photo img{width:100%; height:100%; object-fit:cover; object-position:50% 50%;}
  .hero-photo-tag{position:absolute; bottom:-6px; left:24px; z-index:2; font-size:11px; letter-spacing:0.1em; text-transform:uppercase; color:#1E1B16; background:#FFFFFF; white-space:nowrap; padding:9px 18px; border:1px solid #E2D6B8; border-radius:30px; box-shadow:0 10px 24px -12px rgba(30,27,22,0.25);}

  @media(max-width:980px){
    .hero-main{grid-template-columns:1fr; text-align:left;}
    .hero-headline{padding-right:0; margin-bottom:26px;}
    .hero-photo-block{justify-self:start; max-width:420px; margin:0 auto 10px;}
    .hero-canvas{
      -webkit-mask-image:linear-gradient(180deg, transparent 0%, transparent 28%, rgba(0,0,0,0.5) 42%, #000 56%, #000 100%);
      mask-image:linear-gradient(180deg, transparent 0%, transparent 28%, rgba(0,0,0,0.5) 42%, #000 56%, #000 100%);
    }
  }

  .hero-marquee{
    margin-top:60px; border-top:1px solid #E2D6B8; border-bottom:1px solid #E2D6B8;
    padding:18px 0; overflow:hidden; white-space:nowrap; position:relative; z-index:3;
  }
  .hero-marquee-track{display:inline-flex; gap:0; animation:scroll 40s linear infinite;}
  .hero-marquee span{font-size:12.5px; letter-spacing:0.1em; text-transform:uppercase; color:#6C6354; padding:0 26px; display:inline-flex; align-items:center; gap:26px;}
  .hero-marquee span::after{content:'·'; color:#9C2C63; font-size:16px;}
  @keyframes scroll{from{transform:translateX(0);} to{transform:translateX(-50%);}}

  .scroll-cue{position:absolute; bottom:24px; left:50%; transform:translateX(-50%); z-index:3; display:flex; flex-direction:column; align-items:center; gap:10px; color:#6C6354; font-size:10.5px; letter-spacing:0.18em; text-transform:uppercase;}
  .scroll-cue .line{width:1px; height:34px; background:linear-gradient(180deg, #6C6354, transparent); position:relative; overflow:hidden;}
  .scroll-cue .line::after{content:''; position:absolute; top:-100%; left:0; width:100%; height:100%; background:#9C2C63; animation:cueDrip 2.2s ease-in-out infinite;}
  @keyframes cueDrip{0%{top:-100%;} 60%{top:100%;} 100%{top:100%;}}
  @media(max-width:980px){.scroll-cue{display:none;}}

  /* section helpers */
  section{padding:120px 0;}
  .section-head{max-width:600px; margin-bottom:60px;}
  .section-head h2{font-size:clamp(28px,3.6vw,44px); font-weight:400; letter-spacing:-0.01em;}
  .section-head p{color:#6C6354; font-size:16px; margin-top:16px; max-width:460px;}

  /* thread motif used as connective signature across sections */
  .thread{position:absolute; pointer-events:none; z-index:0;}

  /* ---------- ABOUT ---------- */
  .about{background:#FFFFFF; position:relative; overflow:hidden;}
  .about-grid{display:grid; grid-template-columns:0.6fr 1.4fr; gap:80px; align-items:start;}
  .about-photo-col{position:sticky; top:120px;}
  .about-img{aspect-ratio:4/5; position:relative; overflow:hidden; border-radius:6px; perspective:1000px;}
  .about-img-inner{width:100%; height:100%; transform-style:preserve-3d; transition:transform .2s cubic-bezier(.22,.68,0,1); border-radius:6px; overflow:hidden;}
  .about-img img{width:100%; height:100%; object-fit:cover; object-position:50% 8%;}
  .about-img-shadow{position:absolute; inset:14px -14px -14px 14px; border-radius:6px; background:repeating-linear-gradient(135deg, #F6F0E3, #F6F0E3 2px, #F1E8D6 2px, #F1E8D6 4px); z-index:-1;}
  .about-caption{margin-top:18px; font-size:12.5px; letter-spacing:0.06em; text-transform:uppercase; color:#6C6354; display:flex; justify-content:space-between; border-top:1px solid #E2D6B8; padding-top:14px;}

  .about-text .quote-intro{
    font-family:'Fraunces',serif; font-style:italic; font-size:clamp(22px,2.4vw,30px);
    line-height:1.45; color:#1E1B16; margin-bottom:36px; font-weight:400;
  }
  .about-text .quote-intro em{color:#9C2C63; font-style:italic;}
  .about-text p{margin-bottom:18px; color:#6C6354; font-size:16px; max-width:620px;}
  .about-text strong{color:#1E1B16; font-weight:500;}

  .credentials-strip{display:flex; flex-wrap:wrap; gap:12px; margin:34px 0 38px;}
  .cred-pill{display:flex; align-items:center; gap:8px; font-size:13px; color:#445939; background:#F6F0E3; border:1px solid #E2D6B8; padding:9px 16px 9px 12px; border-radius:30px;}
  .cred-pill .dot{width:6px; height:6px; border-radius:50%; background:#9C2C63; flex-shrink:0;}

  .credentials-list{margin-top:10px; border-top:1px solid #E2D6B8;}
  .credentials-list li{list-style:none; display:flex; justify-content:space-between; align-items:center; font-size:14.5px; color:#1E1B16; padding:16px 0; border-bottom:1px solid #E2D6B8;}
  .credentials-list li span:last-child{color:#6C6354; font-size:13px;}

  .emblem{width:84px; height:84px; margin:46px 0 6px; perspective:600px;}
  .emblem-spin{width:100%; height:100%; transform-style:preserve-3d; animation:emblemSpin 14s linear infinite;}
  .emblem-spin svg{width:100%; height:100%;}
  @keyframes emblemSpin{from{transform:rotateY(0deg);} to{transform:rotateY(360deg);}}

  @media(max-width:940px){.about-grid{grid-template-columns:1fr; gap:46px;} .about-photo-col{position:static; max-width:300px;}}

  /* ---------- APPROACH ---------- */
  .approach{
    background:
      linear-gradient(100deg, rgba(10,11,16,0.95) 0%, rgba(10,11,16,0.88) 36%, rgba(10,11,16,0.62) 64%, rgba(10,11,16,0.32) 100%),
      url('assets/images/about-dance.png') center 14% / cover no-repeat,
      #0A0B10;
    color:#F3ECDD; position:relative; overflow:hidden;
  }
  .approach .section-head h2{color:#F3ECDD;}
  .approach .section-head p{color:rgba(243,236,221,0.62);}
  .approach-particles{position:absolute; inset:0; z-index:0; opacity:0.5;}
  .approach-row{display:grid; grid-template-columns:repeat(4,1fr); gap:36px; position:relative; padding-top:14px; z-index:1;}
  .approach-row::before{content:''; position:absolute; top:18px; left:0; right:0; height:1px; background:rgba(255,255,255,0.14);}
  .approach-item{position:relative; padding-top:46px;}
  .approach-item::before{content:''; position:absolute; top:14px; left:0; width:9px; height:9px; border-radius:50%; background:#C7A24E; box-shadow:0 0 12px 2px rgba(199,162,78,0.5);}
  .approach-item h4{font-size:18px; margin-bottom:12px; font-weight:500; color:#F3ECDD;}
  .approach-item p{font-size:14px; color:rgba(243,236,221,0.62); line-height:1.7;}
  @media(max-width:880px){.approach-row{grid-template-columns:1fr 1fr; row-gap:50px;} .approach-row::before{display:none;}}
  @media(max-width:560px){.approach-row{grid-template-columns:1fr;}}

  /* ---------- SERVICES ---------- */
  .services{background:#FBF7EF;}
  .services-list{display:grid; grid-template-columns:1fr 1fr; gap:0 64px;}
  .service-row{display:flex; justify-content:space-between; align-items:center; gap:20px; padding:21px 16px; border-bottom:1px solid #E2D6B8; transition:padding-left .3s cubic-bezier(.22,.68,0,1), background .3s; border-radius:8px; position:relative;}
  .service-row:hover{padding-left:22px; border-bottom-color:transparent; background:#FFFFFF;}
  .s-head{display:flex; align-items:center; gap:16px; flex-shrink:0;}
  .service-row .s-name{font-family:'Fraunces',serif; font-size:18px; font-weight:500;}
  .service-row .s-desc{font-size:13.5px; color:#6C6354; text-align:right; max-width:210px;}

  .s-icon{width:32px; height:38px; flex-shrink:0; display:inline-flex; align-items:center; justify-content:center;
    transform:rotate(var(--icon-rot,0deg)); animation:iconBreathe 5s ease-in-out infinite; animation-delay:var(--icon-delay,0s);}
  .s-icon svg{width:100%; height:100%; overflow:visible;}
  .s-icon path{fill:none; stroke:var(--icon-color, #445939); stroke-width:1.6; stroke-linecap:round;
    stroke-dasharray:170; stroke-dashoffset:170; transition:stroke-dashoffset 1.1s ease-out, stroke .3s ease;}
  .s-icon circle{fill:var(--icon-color, #445939); opacity:0; transition:opacity .5s ease .7s;}
  .reveal.in .s-icon path{stroke-dashoffset:0;}
  .reveal.in .s-icon circle{opacity:1;}
  .service-row:hover .s-icon path{stroke:#9C2C63;}
  .service-row:hover .s-icon circle{fill:#9C2C63;}
  .service-row:hover .s-icon{animation-play-state:paused; transform:rotate(0deg) scale(1.12);}
  @keyframes iconBreathe{0%,100%{transform:rotate(var(--icon-rot,0deg)) scale(1);} 50%{transform:rotate(var(--icon-rot,0deg)) scale(1.07);}}

  @media(max-width:760px){.services-list{grid-template-columns:1fr;} .service-row{flex-direction:column; align-items:flex-start; gap:6px;} .service-row .s-desc{text-align:left; max-width:none; padding-left:48px;}}

  .formats-row{display:flex; gap:50px; margin-top:54px; flex-wrap:wrap; padding-top:40px; border-top:1px solid #E2D6B8;}
  .formats-row .fmt{display:flex; align-items:center; gap:16px; font-size:14.5px; color:#6C6354;}
  .formats-row .fmt b{color:#1E1B16; font-weight:500; font-family:'Fraunces',serif; font-size:16px; display:block;}
  .formats-row .fmt-mark{width:34px; height:34px; border-radius:50%; background:#F6F0E3; border:1px solid #E2D6B8; display:flex; align-items:center; justify-content:center; flex-shrink:0;}
  .formats-row .fmt-mark span{width:8px; height:8px; border-radius:50%; background:#9C2C63;}
  .enquiry-note{margin-top:16px; font-size:13.5px; color:#6C6354; font-style:italic; font-family:'Fraunces',serif;}

  /* ---------- WORKSHOPS ---------- */
  .workshops{background:linear-gradient(165deg, #445939, #34452C); color:#fff; position:relative; overflow:hidden;}
  .workshops .section-head h2, .workshops .section-head p{color:#fff;}
  .workshops .section-head p{color:rgba(255,255,255,0.78);}
  .workshop-illustration{width:100%; height:120px; margin-bottom:6px; display:block; position:relative; z-index:1;}
  .workshops-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; position:relative; z-index:1; perspective:1200px;}
  .workshop-card{background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.14); padding:34px 28px; border-radius:10px; transform-style:preserve-3d; transition:transform .15s cubic-bezier(.22,.68,0,1), background .3s, border-color .3s;}
  .workshop-card:hover{background:rgba(255,255,255,0.12); border-color:rgba(255,255,255,0.3);}
  .workshop-card .tag{display:block; font-size:11.5px; letter-spacing:0.12em; text-transform:uppercase; color:#C3AEE6; margin-bottom:16px;}
  .workshop-card h4{color:#fff; font-size:19px; margin-bottom:12px; font-weight:500;}
  .workshop-card p{color:rgba(255,255,255,0.78); font-size:14.5px;}
  .workshops-note{margin-top:40px; font-size:14.5px; color:rgba(255,255,255,0.85); position:relative; z-index:1;}
  .workshops-note a{text-decoration:underline; color:#fff;}
  @media(max-width:880px){.workshops-grid{grid-template-columns:1fr;}}

  /* ---------- TESTIMONIALS ---------- */
  .testimonials{background:#FFFFFF; position:relative; overflow:hidden;}
  .testi-feature{position:relative; max-width:840px; padding-left:40px; border-left:2px solid #9C2C63; min-height:170px;}
  .testi-feature .mark{position:absolute; left:-18px; top:-46px; font-family:'Fraunces',serif; font-size:140px; color:#F6F0E3; z-index:0; line-height:1;}
  .testi-feature p{position:relative; z-index:1; font-family:'Fraunces',serif; font-style:italic; font-size:clamp(21px,2.4vw,28px); line-height:1.5; color:#1E1B16; margin-bottom:26px; transition:opacity .35s ease;}
  .testi-feature .testi-meta{display:flex; gap:14px; align-items:center; font-size:14px;}
  .testi-feature .testi-name{font-weight:500; color:#1E1B16;}
  .testi-feature .testi-role{color:#6C6354;}
  .testi-dots{display:flex; gap:10px; margin-top:44px;}
  .testi-dots button{width:8px; height:8px; border-radius:50%; border:none; background:#E2D6B8; cursor:pointer; transition:background .2s, transform .2s;}
  .testi-dots button.active{background:#9C2C63; transform:scale(1.3);}
  .testi-note{margin-top:30px; font-size:12.5px; color:#6C6354;}

  /* ---------- BLOG ---------- */
  .blog{background:#F6F0E3; position:relative; overflow:hidden;}
  .blog-tags{display:flex; gap:12px; flex-wrap:wrap; margin-top:8px;}
  .blog-tag{font-size:13px; padding:10px 20px; background:#FFFFFF; border:1px solid #E2D6B8; color:#6C6354; transition:all .25s cubic-bezier(.22,.68,0,1); border-radius:30px;}
  .blog-tag:hover{border-color:#9C2C63; color:#9C2C63; transform:translateY(-2px);}
  .blog-note{margin-top:40px; padding:28px 30px; background:#FFFFFF; border-left:2px solid #9C2C63; font-size:14.5px; color:#6C6354; max-width:560px; border-radius:0 8px 8px 0;}

  /* ---------- APPOINTMENT ---------- */
  .appointment{background:#FFFFFF;}
  .appt-grid{display:grid; grid-template-columns:0.8fr 1.2fr; gap:80px;}
  .appt-info h2{font-size:clamp(28px,3.4vw,40px); font-weight:400; margin-bottom:20px;}
  .appt-info p{color:#6C6354; margin-bottom:36px; font-size:15.5px;}
  .contact-block{display:flex; flex-direction:column; border-top:1px solid #E2D6B8;}
  .contact-line{display:flex; justify-content:space-between; gap:14px; padding:18px 0; border-bottom:1px solid #E2D6B8; font-size:14.5px;}
  .contact-line b{font-weight:500; color:#1E1B16;}
  .contact-line span{color:#6C6354; text-align:right;}
  .contact-line a:hover{color:#9C2C63;}

  form{display:grid; grid-template-columns:1fr 1fr; gap:28px 28px;}
  .field{display:flex; flex-direction:column; gap:9px;}
  .field.full{grid-column:1/-1;}
  label{font-size:12px; letter-spacing:0.08em; text-transform:uppercase; color:#6C6354;}
  input, select, textarea{
    border:none; border-bottom:1px solid #E2D6B8; background:transparent; padding:10px 2px;
    font-family:'Outfit',sans-serif; font-size:15px; color:#1E1B16; outline:none; transition:border-color .2s;
  }
  input:focus, select:focus, textarea:focus{border-color:#9C2C63;}
  textarea{resize:vertical; min-height:70px;}
  .radio-group{display:flex; gap:24px; padding-top:4px;}
  .radio-opt{display:flex; align-items:center; gap:8px; font-size:14.5px; color:#6C6354;}
  .radio-opt input{width:auto; padding:0;}
  .submit-btn{
    grid-column:1/-1; justify-self:start; margin-top:6px;
    background:#1E1B16; color:#fff; padding:16px 38px; border:none; font-size:14px; letter-spacing:0.02em;
    cursor:pointer; transition:all .3s cubic-bezier(.22,.68,0,1); font-family:'Outfit',sans-serif; border-radius:32px;
    display:inline-flex; align-items:center; gap:9px;
  }
  .submit-btn:hover{background:#9C2C63; transform:translateY(-2px); box-shadow:0 14px 28px -10px rgba(156,44,99,0.45);}
  @media(max-width:940px){.appt-grid{grid-template-columns:1fr;} form{grid-template-columns:1fr;}}

  /* ---------- FOOTER ---------- */
  footer{background:#0A0B10; color:rgba(243,236,221,0.78); padding:80px 0 28px; position:relative; overflow:hidden;}
  .footer-grid{display:grid; grid-template-columns:1.3fr 1fr 1fr 1fr; gap:40px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,0.12); position:relative; z-index:1;}
  .footer-brand{display:flex; align-items:center; gap:10px; margin-bottom:18px;}
  .footer-brand .brand-mark{width:26px; height:26px;}
  footer h5{color:#fff; font-size:12px; letter-spacing:0.1em; text-transform:uppercase; margin-bottom:20px; font-weight:500;}
  footer ul{list-style:none; display:flex; flex-direction:column; gap:12px; font-size:14px;}
  footer ul a{color:rgba(243,236,221,0.62); transition:color .2s;}
  footer ul a:hover{color:#C7A24E;}
  .footer-desc{font-size:14px; color:rgba(243,236,221,0.5); max-width:280px; line-height:1.8;}
  .footer-bottom{display:flex; justify-content:space-between; align-items:center; padding-top:26px; font-size:12.5px; color:rgba(243,236,221,0.4); flex-wrap:wrap; gap:10px; position:relative; z-index:1;}
  @media(max-width:880px){.footer-grid{grid-template-columns:1fr 1fr;}}
  @media(max-width:520px){.footer-grid{grid-template-columns:1fr;}}

  .wa-float{
    position:fixed; bottom:28px; right:28px; z-index:90; width:56px; height:56px; border-radius:50%;
    background:#9C2C63; display:flex; align-items:center; justify-content:center; color:#fff;
    box-shadow:0 10px 28px rgba(156,44,99,0.4); transition:transform .25s cubic-bezier(.22,.68,0,1);
  }
  .wa-float:hover{transform:scale(1.08);}
  .wa-float svg{width:26px; height:26px;}

  .reveal{opacity:0; transform:translateY(18px); transition:opacity .8s cubic-bezier(.22,.68,0,1), transform .8s cubic-bezier(.22,.68,0,1);}
  .reveal.in{opacity:1; transform:translateY(0);}
  .reveal-stagger.in .stagger-item{opacity:1; transform:translateY(0);}
  .stagger-item{opacity:0; transform:translateY(14px); transition:opacity .6s cubic-bezier(.22,.68,0,1), transform .6s cubic-bezier(.22,.68,0,1);}


/* ---------- BLOG TEASER (front page) ---------- */
.blog-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:34px;}
.blog-card{background:#FFFFFF; border:1px solid #E2D6B8; border-radius:10px; padding:26px; display:flex; flex-direction:column; gap:10px; transition:transform .25s cubic-bezier(.22,.68,0,1), box-shadow .25s cubic-bezier(.22,.68,0,1);}
.blog-card:hover{transform:translateY(-4px); box-shadow:0 20px 40px -24px rgba(30,27,22,0.25);}
.blog-card .blog-card-date{font-size:11.5px; letter-spacing:0.08em; text-transform:uppercase; color:#445939;}
.blog-card h4{font-size:18px; font-weight:500; line-height:1.35;}
.blog-card p{font-size:14px; color:#6C6354; line-height:1.65;}
.blog-card a.read-more{font-size:13px; color:#9C2C63; margin-top:auto;}
.blog-viewall{margin-top:34px; display:inline-flex;}
@media(max-width:880px){.blog-grid{grid-template-columns:1fr;}}

/* ---------- BLOG ARCHIVE (home.php) ---------- */
.journal-hero{padding:170px 0 60px; background:#FBF7EF;}
.journal-hero h1{font-size:clamp(32px,4vw,52px); font-weight:400;}
.journal-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:26px;}
@media(max-width:880px){.journal-grid{grid-template-columns:1fr;}}
.journal-card{background:#FFFFFF; border:1px solid #E2D6B8; border-radius:10px; overflow:hidden; display:flex; flex-direction:column; transition:transform .25s cubic-bezier(.22,.68,0,1), box-shadow .25s cubic-bezier(.22,.68,0,1);}
.journal-card:hover{transform:translateY(-4px); box-shadow:0 20px 40px -24px rgba(30,27,22,0.25);}
.journal-card img{width:100%; aspect-ratio:16/10; object-fit:cover;}
.journal-card-body{padding:24px; display:flex; flex-direction:column; gap:10px; flex:1;}
.journal-card .cat{font-size:11px; letter-spacing:0.1em; text-transform:uppercase; color:#445939;}
.journal-card h3{font-size:19px; font-weight:500; line-height:1.35;}
.journal-card .excerpt{font-size:14px; color:#6C6354; line-height:1.65; flex:1;}
.journal-card .read-more{font-size:13px; color:#9C2C63; margin-top:4px;}
.journal-empty{padding:60px 0; text-align:center; color:#6C6354;}
.journal-pagination{display:flex; gap:12px; justify-content:center; margin-top:56px;}
.journal-pagination a, .journal-pagination span{padding:10px 18px; border:1px solid #E2D6B8; border-radius:30px; font-size:13.5px; color:#1E1B16;}
.journal-pagination .current{background:#1E1B16; color:#fff; border-color:#1E1B16;}

/* ---------- SINGLE POST ---------- */
.post-hero{padding:170px 0 40px; background:#FBF7EF;}
.post-hero .cat{font-size:11.5px; letter-spacing:0.1em; text-transform:uppercase; color:#445939; margin-bottom:14px; display:block;}
.post-hero h1{font-size:clamp(30px,4vw,50px); font-weight:400; line-height:1.15;}
.post-hero .meta{margin-top:18px; font-size:13.5px; color:#6C6354;}
.post-featured-img{margin:0 0 50px;}
.post-featured-img img{width:100%; border-radius:10px; max-height:520px; object-fit:cover;}
.post-content{max-width:740px; margin:0 auto; font-size:17px; color:#1E1B16; line-height:1.85;}
.post-content p{margin-bottom:22px;}
.post-content h2{font-size:28px; margin:44px 0 18px;}
.post-content h3{font-size:22px; margin:36px 0 14px;}
.post-content img{border-radius:10px; margin:30px 0;}
.post-content a{color:#9C2C63; text-decoration:underline;}
.post-content blockquote{border-left:2px solid #9C2C63; padding-left:24px; font-family:'Fraunces',serif; font-style:italic; font-size:20px; margin:30px 0; color:#1E1B16;}
.post-tags{max-width:740px; margin:50px auto 0; display:flex; gap:10px; flex-wrap:wrap;}
.post-tags a{font-size:12.5px; padding:8px 16px; background:#F6F0E3; border:1px solid #E2D6B8; border-radius:30px; color:#6C6354;}
.post-back{max-width:740px; margin:60px auto 0; padding-top:30px; border-top:1px solid #E2D6B8;}
.post-back a{font-size:14px; color:#6C6354;}
.post-back a:hover{color:#9C2C63;}

/* ---------- generic page ---------- */
.generic-page{padding:170px 0 100px; max-width:740px; margin:0 auto;}
.generic-page h1{font-size:clamp(30px,4vw,46px); font-weight:400; margin-bottom:24px;}
.generic-page .entry-content p{margin-bottom:20px; color:#6C6354; font-size:16px; line-height:1.85;}

/* ---------- enquiry success banner ---------- */
.enquiry-success{grid-column:1/-1; background:#F6F0E3; border:1px solid #E2D6B8; border-left:3px solid #445939; padding:18px 22px; border-radius:8px; font-size:14.5px; color:#1E1B16; margin-bottom:6px;}
