/*
Theme Name: Destination Madrid
Theme URI: https://destination-madrid.fr
Author: Mohamed Shaheen
Author URI: mailto:work.mshaheen@gmail.com
Description: Premium WordPress theme for Destination Madrid — a French travel agency specialising in bespoke Madrid experiences. Bilingual (FR/ES), fully customisable via the Customizer. Contact: work.mshaheen@gmail.com
Version: 1.0.0
Requires at least: 5.9
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: destination-madrid
Tags: custom-logo, custom-colors, featured-images, one-column, two-columns, translation-ready, blog
*/

/* ============================================
   DESTINATION MADRID — Premium Redesign
   ============================================ */

:root {
  --gold: #c9a84c;
  --gold-soft: #dfc472;
  --gold-light: #f0e3be;
  --gold-glow: rgba(201,168,76,.10);
  --gold-border: rgba(201,168,76,.18);
  --terra: #9d5133;
  --terra-deep: #7a3d24;
  --sage: #8a9a7b;
  --sage-light: #c5d1bc;
  --sage-bg: #e8ece4;
  --dark: #1e1d1b;
  --dark2: #2c2a28;
  --txt: #4a4845;
  --muted: #9a9793;
  --beige: #ece3d5;
  --warm: #f3ead9;
  --cream: #f9f5ef;
  --off: #fdfbf7;
  --white: #fff;
  --body: 'Poppins', sans-serif;
  --script: 'Satisfy', cursive;
  --serif: 'Abhaya Libre', serif;
  --display: 'Aboreto', serif;
  --ease: cubic-bezier(.25,.46,.45,.94);
  --out: cubic-bezier(.16,1,.3,1);
  --radius: 18px;
  --radius-lg: 28px;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--txt);background:var(--off);line-height:1.75;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:all .4s var(--ease)}
ul{list-style:none}
button{font-family:var(--body);cursor:pointer}

h1,h2,h3,h4{font-family:var(--serif);color:var(--dark);line-height:1.15;font-weight:700}
h1{font-size:clamp(2.6rem,5.5vw,4.8rem);letter-spacing:-.02em}
h2{font-size:clamp(1.9rem,3.8vw,3rem)}
h3{font-size:clamp(1.05rem,1.6vw,1.3rem);font-weight:600}
.sc{font-family:var(--script);color:var(--gold)}
.cp{font-family:var(--display);letter-spacing:.25em;text-transform:uppercase;font-size:.65rem}

.w{max-width:1200px;margin:0 auto;padding:0 clamp(1.2rem,4vw,2.5rem)}

/* Reveal animations */
.r{opacity:0;transform:translateY(30px);transition:opacity .8s var(--out),transform .8s var(--out)}
.r.v{opacity:1;transform:none}
.rl{opacity:0;transform:translateX(-40px);transition:opacity .8s var(--out),transform .8s var(--out)}
.rl.v{opacity:1;transform:none}
.rr{opacity:0;transform:translateX(40px);transition:opacity .8s var(--out),transform .8s var(--out)}
.rr.v{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.35s}.d4{transition-delay:.5s}.d5{transition-delay:.65s}
@keyframes up{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
@keyframes zoom{from{transform:scale(1)}to{transform:scale(1.06)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
@keyframes scroll{0%{opacity:1;transform:translateX(-50%) translateY(0)}100%{opacity:0;transform:translateX(-50%) translateY(12px)}}
@keyframes spin-slow{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* Decorative star */
.star{display:inline-block;width:28px;height:28px;position:relative}
.star svg{width:100%;height:100%;fill:none;stroke:var(--gold);stroke-width:1}

/* ============================================
   NAV — Floating Pill
   ============================================ */
.nav{
  position:fixed;top:1rem;left:1.5rem;right:1.5rem;
  max-width:1200px;margin:0 auto;z-index:100;
  padding:.55rem 1.6rem;border-radius:60px;
  background:rgba(253,251,247,.5);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid var(--gold-border);
  transition:all .5s var(--ease);animation:up .7s var(--out) .3s both;
}
.nav.stuck{background:rgba(253,251,247,.95);box-shadow:0 6px 28px rgba(30,29,27,.07);border-color:rgba(201,168,76,.22);top:.7rem}
.nav-in{display:flex;align-items:center;justify-content:space-between}
.nav-logo img{height:62px;transition:height .4s var(--ease)}
.nav.stuck .nav-logo img{height:50px}
.nav-menu{display:flex;align-items:center;gap:2.2rem}
.nav-menu a{font-size:.72rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--dark);position:relative}
.hero-nav .nav-menu a{color:rgba(255,255,255,.85)}
.nav.stuck .nav-menu a{color:var(--dark)}
.nav-menu a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1.5px;background:var(--gold);transition:width .35s var(--ease)}
.nav-menu a:hover::after,.nav-menu a.on::after{width:100%}
.nav-cta{background:var(--terra)!important;color:var(--white)!important;padding:.5rem 1.4rem!important;border-radius:50px;font-weight:600!important;box-shadow:0 3px 12px rgba(157,81,51,.2)}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--terra-deep)!important;box-shadow:0 5px 18px rgba(122,61,36,.25)!important;transform:translateY(-1px)}
/* Language switcher */
.lang-switch{position:relative}
.lang-btn{display:inline-flex;align-items:center;gap:.3rem;font-size:.72rem!important;font-weight:800!important;letter-spacing:.12em!important;padding:.45rem 1rem!important;border-radius:50px;background:var(--gold)!important;color:#fff!important;border:none!important;box-shadow:0 3px 12px rgba(201,168,76,.25);transition:all .35s var(--ease)}
.lang-btn .lang-current{font-weight:800}
.lang-btn svg{opacity:.7;transition:transform .3s ease}
.lang-btn:hover svg{transform:translateY(1px)}
.lang-btn:hover{background:var(--terra)!important;box-shadow:0 5px 18px rgba(157,81,51,.3);transform:translateY(-2px)}
.lang-btn::after{display:none!important}
/* Dropdown menu */
.has-dropdown{position:relative}
.dropdown-toggle{display:inline-flex!important;align-items:center;gap:.3rem}
.dd-chevron{transition:transform .3s ease;flex-shrink:0}
.has-dropdown:hover .dd-chevron,.has-dropdown.open .dd-chevron{transform:rotate(180deg)}
.dropdown-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%);min-width:220px;background:var(--white);border:1px solid var(--gold-border);border-radius:var(--radius);box-shadow:0 12px 35px rgba(30,29,27,.08);padding:.6rem 0;opacity:0;visibility:hidden;transition:all .3s var(--ease);margin-top:.8rem;z-index:200}
.dropdown-menu::before{content:'';position:absolute;top:-6px;left:50%;transform:translateX(-50%) rotate(45deg);width:12px;height:12px;background:var(--white);border-left:1px solid var(--gold-border);border-top:1px solid var(--gold-border)}
.has-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;margin-top:.5rem}
.dropdown-menu li{width:100%}
.dropdown-menu li a{display:block!important;padding:.55rem 1.3rem!important;font-size:.7rem!important;letter-spacing:.08em!important;color:var(--txt)!important;border-bottom:none!important;transition:all .2s ease!important;white-space:nowrap}
.dropdown-menu li a:hover{background:var(--cream)!important;color:var(--terra)!important;padding-left:1.6rem!important}
.dropdown-menu li a::after{display:none!important}
.hero-nav .lang-btn{background:rgba(255,255,255,.15)!important;color:#fff!important;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1.5px solid rgba(255,255,255,.25)!important;box-shadow:none}
.hero-nav .lang-btn:hover{background:var(--gold)!important;border-color:var(--gold)!important;box-shadow:0 5px 18px rgba(201,168,76,.3)}
.nav.stuck .lang-btn{background:var(--gold)!important;color:#fff!important;border:none!important;box-shadow:0 3px 12px rgba(201,168,76,.25)}

.nav-right-mobile{display:none;align-items:center;gap:.7rem}
.lang-btn-mobile{display:inline-flex;align-items:center;justify-content:center;font-size:.65rem!important;font-weight:800!important;letter-spacing:.12em!important;padding:.3rem .7rem!important;border-radius:50px;background:var(--gold)!important;color:#fff!important;border:none!important;text-decoration:none!important;box-shadow:0 2px 8px rgba(201,168,76,.25);transition:all .35s var(--ease);min-width:32px}
.lang-btn-mobile:hover{background:var(--terra)!important}
.hero-nav .lang-btn-mobile{background:rgba(255,255,255,.18)!important;color:#fff!important;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1.5px solid rgba(255,255,255,.25)!important;box-shadow:none}
.nav.stuck .lang-btn-mobile{background:var(--gold)!important;color:#fff!important;border:none!important}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:10;padding:4px}
.burger span{width:22px;height:1.5px;background:var(--dark);transition:all .3s ease;border-radius:2px}
.hero-nav .burger span{background:#fff}
.nav.stuck .burger span{background:var(--dark)}
.burger.on span:nth-child(1){transform:rotate(45deg) translate(4.5px,4.5px)}
.burger.on span:nth-child(2){opacity:0}
.burger.on span:nth-child(3){transform:rotate(-45deg) translate(4.5px,-4.5px)}

/* ============================================
   HERO — Left text + floating circle image
   ============================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:var(--dark)}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.55;animation:zoom 22s ease-in-out infinite alternate}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(30,29,27,.65) 0%,rgba(30,29,27,.2) 50%,rgba(138,154,123,.25) 100%)}
.hero-content{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:2rem;width:100%;max-width:1200px;margin:0 auto;padding:0 clamp(1.2rem,4vw,2.5rem);padding-top:6rem}
.hero-left{color:#fff}
.hero-left .sc{font-size:clamp(1.2rem,2.5vw,1.8rem);display:block;margin-bottom:.4rem;color:var(--gold-soft);animation:up .8s var(--out) .4s both}
.hero-left h1{color:#fff;margin-bottom:1.2rem;animation:up .8s var(--out) .6s both;max-width:520px}
.hero-left .sub{font-size:clamp(.85rem,1.2vw,.98rem);font-weight:300;max-width:440px;opacity:.75;line-height:1.85;margin-bottom:2rem;animation:up .8s var(--out) .8s both}
.hero-btns{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;animation:up .8s var(--out) 1s both}
.btn{display:inline-flex;align-items:center;gap:.45rem;font-size:.76rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:.85rem 2rem;border-radius:50px;border:none;transition:all .4s var(--ease)}
.btn svg{width:14px;height:14px}
.btn-gold{background:var(--terra);color:#fff;box-shadow:0 5px 18px rgba(157,81,51,.25)}
.btn-gold:hover{background:var(--terra-deep);box-shadow:0 7px 24px rgba(122,61,36,.3);transform:translateY(-2px)}
.btn-glass{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(4px)}
.btn-glass:hover{border-color:var(--gold-soft);color:var(--gold-soft)}
.btn-out{display:inline-flex;align-items:center;gap:.45rem;padding:.8rem 1.8rem;border:1.5px solid var(--terra);color:var(--terra);font-size:.74rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border-radius:50px;transition:all .4s var(--ease)}
.btn-out:hover{background:var(--terra);color:#fff;transform:translateY(-2px)}
.btn-out svg{width:14px;height:14px}
.hero-right{display:flex;justify-content:center;align-items:center;position:relative;animation:up 1s var(--out) .5s both}
.hero-circle{width:clamp(260px,22vw,340px);height:clamp(260px,22vw,340px);border-radius:50%;overflow:hidden;border:4px solid rgba(255,255,255,.15);box-shadow:0 20px 60px rgba(0,0,0,.25);position:relative}
.hero-circle img{width:100%;height:100%;object-fit:cover}
.hero-circle-sm{position:absolute;width:80px;height:80px;border-radius:50%;overflow:hidden;border:3px solid rgba(255,255,255,.2);box-shadow:0 8px 24px rgba(0,0,0,.2);bottom:10%;left:-30px}
.hero-circle-sm img{width:100%;height:100%;object-fit:cover}
.hero-deco{position:absolute;width:40px;height:40px;opacity:.4;animation:spin-slow 15s linear infinite}
.hero-deco.d-1{top:15%;right:10%}
.hero-deco.d-2{bottom:25%;left:5%}
.hero-deco svg{width:100%;height:100%;stroke:var(--gold-soft);fill:none;stroke-width:.8}
.hero-bottom{position:absolute;bottom:2.5rem;left:clamp(1.2rem,4vw,2.5rem);z-index:2;color:rgba(255,255,255,.4);font-size:.72rem;font-weight:300;max-width:300px;line-height:1.65;animation:up .8s var(--out) 1.4s both}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);z-index:2;text-align:center;animation:up .8s var(--out) 1.6s both}
.scroll-dot{width:18px;height:30px;border:1.5px solid rgba(255,255,255,.3);border-radius:9px;margin:0 auto .4rem;position:relative}
.scroll-dot::after{content:'';position:absolute;top:5px;left:50%;transform:translateX(-50%);width:2px;height:6px;background:var(--gold-soft);border-radius:2px;animation:scroll 2s ease infinite}
.hero-scroll .cp{color:rgba(255,255,255,.3);font-size:.55rem;letter-spacing:.3em}

/* ============================================
   TRUST PILLARS — 3 columns
   ============================================ */
.s-trust{padding:3.5rem 0;background:var(--cream);border-bottom:1px solid var(--gold-border)}
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.trust-pill{text-align:center;padding:1.5rem 2rem;position:relative}
.trust-pill:not(:last-child)::after{content:'';position:absolute;right:0;top:20%;height:60%;width:1px;background:var(--gold-border)}
.trust-pill .tp-icon{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.7rem}
.trust-pill .tp-icon svg{width:20px;height:20px;stroke:var(--gold);stroke-width:1.5;fill:none}
.trust-pill .tp-title{font-family:var(--serif);font-size:1rem;font-weight:700;color:var(--dark);display:inline}
.trust-pill .tp-desc{font-size:.78rem;font-weight:300;color:var(--muted);line-height:1.65;margin-top:.3rem}

/* ============================================
   ABOUT — Centered heading + dual images
   ============================================ */
.s-about{padding:6rem 0;background:var(--off);position:relative;overflow:hidden}
.about-head{text-align:center;margin-bottom:3.5rem}
.about-head .sc{font-size:1.6rem;display:block;margin-bottom:.3rem}
.about-head .about-deco{display:flex;align-items:center;justify-content:center;gap:.8rem;margin-bottom:1rem}
.about-head .about-deco .line{width:40px;height:1px;background:var(--gold-border)}
.about-head .about-deco svg{width:22px;height:22px;stroke:var(--gold);stroke-width:1;fill:none}
.about-body{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center}
.about-body .ab-img{border-radius:var(--radius-lg);overflow:hidden;height:360px;box-shadow:0 12px 35px rgba(30,29,27,.06)}
.about-body .ab-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.about-body .ab-img:hover img{transform:scale(1.03)}
.about-body .ab-txt{display:flex;flex-direction:column;gap:1rem}
.about-body .ab-txt p{font-size:.92rem;font-weight:300;line-height:1.9;color:var(--txt)}
.about-body .ab-txt .ab-label{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:.3rem}
.about-body .ab-txt .ab-label .dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pulse 2.5s ease infinite}
.about-body .ab-txt .ab-label span{font-size:.68rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--terra)}
.about-star{position:absolute;top:3rem;right:8%;opacity:.12;animation:spin-slow 20s linear infinite}
.about-star svg{width:60px;height:60px;stroke:var(--gold);fill:none;stroke-width:.5}
/* Philosophy statement (about page) */
.s-phil-about{padding:5rem 0;background:var(--cream);text-align:center}
.phil-about-inner{max-width:750px;margin:0 auto}
.phil-about-inner .sc{font-size:1.4rem;display:block;margin-bottom:.5rem}
.phil-about-inner h2{font-size:clamp(1.5rem,2.8vw,2.2rem);font-weight:600;line-height:1.5;color:var(--dark2)}
.phil-about-inner h2 em{font-family:var(--script);font-style:normal;color:var(--gold);font-weight:400;font-size:1.15em}

/* ============================================
   STATS — Strip
   ============================================ */
.s-stats{padding:3.5rem 0;background:var(--warm)}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);text-align:center}
.stat-item .stat-n{font-family:var(--serif);font-size:clamp(2rem,3.5vw,2.8rem);font-weight:800;color:var(--dark);line-height:1}
.stat-item .stat-l{font-size:.72rem;font-weight:400;color:var(--muted);letter-spacing:.06em;margin-top:.3rem}

/* ============================================
   SERVICES — 3x2 Grid with mixed cards
   ============================================ */
.s-services{padding:6rem 0;background:var(--off)}
.srv-head{text-align:center;margin-bottom:3.5rem}
.srv-head .sc{font-size:1.4rem;display:block;margin-bottom:.3rem}
.srv-head p{max-width:500px;margin:.8rem auto 0;font-weight:300;color:var(--muted);font-size:.92rem}
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:auto auto;gap:1.2rem}
.srv-card{border-radius:var(--radius-lg);padding:2rem 1.6rem;position:relative;overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s var(--ease);min-height:220px;display:flex;flex-direction:column;justify-content:flex-end}
.srv-card:hover{transform:translateY(-4px);box-shadow:0 12px 35px rgba(30,29,27,.07)}
.srv-card.srv-img{padding:0;min-height:280px}
.srv-card.srv-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.srv-card.srv-img:hover img{transform:scale(1.04)}
.srv-card.srv-img .srv-img-over{position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(30,29,27,.7) 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:2rem 1.6rem}
.srv-card.srv-img .tag{color:var(--gold-soft)}
.srv-card.srv-img h3{color:#fff}
.srv-card.srv-img p{color:rgba(255,255,255,.65)}
.srv-card.c-sage{background:var(--sage-bg)}
.srv-card.c-cream{background:var(--cream)}
.srv-card.c-warm{background:var(--warm)}
.srv-card.c-beige{background:var(--beige)}
.srv-card.c-white{background:var(--white);border:1px solid var(--gold-border)}
.srv-card .tag{font-size:.58rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--sage);margin-bottom:.5rem}
.srv-card h3{margin-bottom:.4rem}
.srv-card p{font-size:.82rem;font-weight:300;color:var(--muted);line-height:1.65}
.srv-card .srv-arrow{position:absolute;top:1.5rem;right:1.5rem;width:32px;height:32px;border-radius:50%;background:rgba(201,168,76,.1);display:flex;align-items:center;justify-content:center;transition:all .3s ease}
.srv-card:hover .srv-arrow{background:var(--gold)}
.srv-card .srv-arrow svg{width:14px;height:14px;stroke:var(--gold);stroke-width:2;fill:none;transition:stroke .3s ease}
.srv-card:hover .srv-arrow svg{stroke:#fff}

/* ============================================
   EXPLORE — Horizontal scroll cards
   ============================================ */
.s-explore{padding:5rem 0;background:var(--cream)}
.explore-head{margin-bottom:2.5rem}
.explore-head h2{display:inline}
.explore-head .sc{font-size:1.3rem;display:block;margin-bottom:.2rem}
.explore-tags{display:flex;gap:.6rem;margin-top:1.2rem;flex-wrap:wrap}
.explore-tags .etag{padding:.45rem 1.1rem;border-radius:50px;font-size:.7rem;font-weight:500;letter-spacing:.06em;border:1px solid var(--gold-border);color:var(--muted);background:var(--white);transition:all .3s ease;cursor:pointer;font-family:var(--body)}
.explore-tags .etag.active,.explore-tags .etag:hover{background:var(--terra);color:#fff;border-color:var(--terra)}
.explore-track-wrap{overflow:hidden;position:relative}
.explore-track{display:flex;gap:1.2rem;width:max-content;animation:marquee 35s linear infinite}
.explore-track:hover{animation-play-state:paused}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.explore-card{flex:0 0 340px;border-radius:var(--radius-lg);overflow:hidden;position:relative;height:400px;cursor:pointer}
.explore-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.explore-card:hover img{transform:scale(1.05)}
.explore-card .ex-over{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(30,29,27,.75) 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.8rem}
.explore-card .ex-tag{font-size:.58rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:.3rem}
.explore-card h3{color:#fff;font-size:1.2rem}
.explore-card p{color:rgba(255,255,255,.55);font-size:.8rem;font-weight:300;margin-top:.15rem}

/* ============================================
   FULL-WIDTH BAND
   ============================================ */
.band{position:relative;height:65vh;min-height:420px;overflow:hidden;background:var(--dark)}
.band img{position:absolute;inset:0;width:100%;height:130%;object-fit:cover}
.band-over{position:absolute;inset:0;background:linear-gradient(180deg,rgba(30,29,27,.1) 0%,rgba(30,29,27,.35) 100%);display:flex;align-items:center;justify-content:center}
.band-play{width:80px;height:80px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);border:2px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .4s var(--ease)}
.band-play:hover{background:var(--gold);border-color:var(--gold);transform:scale(1.08)}
.band-play svg{width:24px;height:24px;fill:#fff;margin-left:3px}

/* ============================================
   FOUNDERS — Contained editorial card
   ============================================ */
.s-founders-wrap{padding:6rem 0;background:var(--cream)}
.s-founders{display:grid;grid-template-columns:1fr 1fr;min-height:560px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 20px 60px rgba(30,29,27,.06);position:relative}
.s-founders::before{content:'';position:absolute;inset:-2px;border-radius:calc(var(--radius-lg) + 2px);background:linear-gradient(135deg,var(--gold-border),transparent 40%,transparent 60%,var(--terra-deep));opacity:.3;z-index:0;pointer-events:none}
.founders-img{overflow:hidden;position:relative;z-index:1}
.founders-img img{width:100%;height:100%;object-fit:cover;transition:transform 5s ease}
.founders-img:hover img{transform:scale(1.03)}
.founders-body{background:var(--warm);display:flex;flex-direction:column;justify-content:center;padding:clamp(2.5rem,5vw,4rem);position:relative;z-index:1}
.founders-body::after{content:'"';font-family:var(--serif);font-size:12rem;color:var(--gold);opacity:.04;position:absolute;top:-.5rem;right:1rem;line-height:1;pointer-events:none}
.founders-body .sc{font-size:1.4rem;display:block;margin-bottom:.3rem}
.founders-body h2{margin-bottom:1.2rem}
.founders-body p{font-weight:300;font-size:.92rem;margin-bottom:.8rem;line-height:1.85}
.founders-body .founders-closing{font-family:var(--serif);font-size:1.05rem;color:var(--terra);font-weight:600;line-height:1.6;margin-top:.5rem;font-style:italic}
/* About page hero variant — full-width, no card */
.s-founders.about-hero{border-radius:0;box-shadow:none;min-height:100vh}
.s-founders.about-hero::before{display:none}
.s-founders.about-hero .founders-img{min-height:100vh}

/* ============================================
   TESTIMONIALS — Asymmetric cards
   ============================================ */
.s-testi{padding:6rem 0;background:var(--cream)}
.testi-head{text-align:center;margin-bottom:3.5rem}
.testi-head .sc{font-size:1.4rem;display:block;margin-bottom:.3rem}
.testi-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.testi-card{border-radius:var(--radius-lg);padding:2rem;position:relative;display:flex;flex-direction:column}
.testi-card.c-sage{background:var(--sage-bg)}
.testi-card.c-cream{background:var(--off)}
.testi-card.c-warm{background:var(--warm)}
.testi-card.c-white{background:var(--white);border:1px solid var(--gold-border)}
.testi-card .t-quote{font-size:.92rem;font-weight:300;line-height:1.8;color:var(--txt);font-style:italic;margin-bottom:1.2rem;flex:1}
.testi-card .t-quote::before{content:'"';font-family:var(--serif);font-size:2.5rem;color:var(--gold);line-height:0;vertical-align:-.6rem;margin-right:.1rem}
.testi-card .t-author{display:flex;align-items:center;gap:.8rem}
.testi-card .t-avatar{width:42px;height:42px;border-radius:50%;overflow:hidden;border:2px solid var(--gold-border);flex-shrink:0}
.testi-card .t-avatar img{width:100%;height:100%;object-fit:cover}
.testi-card .t-name{font-family:var(--serif);font-weight:600;font-size:.88rem;color:var(--dark)}
.testi-card .t-info{font-size:.68rem;color:var(--muted)}
.testi-card .t-img{border-radius:var(--radius);overflow:hidden;margin-bottom:1.2rem;height:200px}
.testi-card .t-img img{width:100%;height:100%;object-fit:cover}

/* ============================================
   FAQ — Accordion
   ============================================ */
.s-faq{padding:6rem 0;background:var(--off)}
.faq-layout{display:grid;grid-template-columns:.8fr 1.2fr;gap:4rem;align-items:center}
.faq-left{text-align:left}
.faq-left .sc{font-size:1.4rem;display:block;margin-bottom:.3rem}
.faq-left h2{margin-bottom:1rem}
.faq-left p{font-weight:300;color:var(--muted);font-size:.9rem;line-height:1.75}
.faq-list{display:flex;flex-direction:column;gap:.8rem}
.faq-item{border:1px solid var(--gold-border);border-radius:var(--radius);background:var(--white);overflow:hidden;transition:all .3s ease}
.faq-item.open{box-shadow:0 5px 18px rgba(30,29,27,.04)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.5rem;cursor:pointer;gap:1rem}
.faq-q span{font-family:var(--serif);font-size:1rem;font-weight:600;color:var(--dark)}
.faq-q .faq-icon{width:28px;height:28px;border-radius:50%;background:var(--gold-glow);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s ease}
.faq-item.open .faq-icon{background:var(--gold);transform:rotate(45deg)}
.faq-q .faq-icon svg{width:14px;height:14px;stroke:var(--gold);stroke-width:2;fill:none;transition:stroke .3s ease}
.faq-item.open .faq-icon svg{stroke:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.open .faq-a{max-height:300px}
.faq-a-inner{padding:0 1.5rem 1.3rem;font-size:.88rem;font-weight:300;color:var(--muted);line-height:1.8}

/* ============================================
   CTA CONTACT — Form section
   ============================================ */
.s-cta{padding:6rem 0;background:var(--warm);position:relative;overflow:hidden}
.s-cta::before{content:'';position:absolute;top:-1px;left:0;right:0;height:40px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 40'%3E%3Cpath d='M0 40V20C200 0 400 35 600 20S1000 0 1200 20v20z' fill='%23fdfbf7'/%3E%3C/svg%3E");background-size:cover}
.cta-head{text-align:center;margin-bottom:3.5rem}
.cta-head .sc{font-size:1.4rem;display:block;margin-bottom:.3rem}
.cta-head p{max-width:480px;margin:.8rem auto 0;font-weight:300;color:var(--muted);font-size:.92rem}
.cta-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:3rem;align-items:flex-start}
.cta-info{display:flex;flex-direction:column;gap:1.2rem;justify-content:center;align-items:center;text-align:center}
.cta-info-card{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:1.4rem 1.2rem;background:var(--off);border-radius:var(--radius);transition:all .3s ease;width:100%;max-width:320px}
.cta-info-card:hover{background:var(--white);box-shadow:0 5px 18px rgba(30,29,27,.04)}
.cta-info-card .ci-icon{width:44px;height:44px;border-radius:12px;background:var(--gold-glow);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cta-info-card .ci-icon svg{width:18px;height:18px;stroke:var(--gold);stroke-width:1.5;fill:none}
.cta-info-card h4{font-size:.88rem;color:var(--dark);margin-bottom:.15rem}
.cta-info-card p{font-size:.8rem;color:var(--muted);font-weight:300}
.cta-form{background:var(--white);padding:2.5rem;border-radius:var(--radius-lg);box-shadow:0 12px 40px rgba(30,29,27,.05);position:relative;overflow:hidden}
.cta-form::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),var(--terra),var(--gold))}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fg{margin-bottom:1rem}
.fg label{display:block;font-size:.75rem;font-weight:500;color:var(--txt);margin-bottom:.3rem;letter-spacing:.03em}
.fg .req{color:var(--terra)}
.fg input,.fg select,.fg textarea{width:100%;padding:.72rem 1rem;font-family:var(--body);font-size:.88rem;color:var(--txt);background:var(--off);border:1.5px solid var(--gold-border);border-radius:10px;outline:none;transition:all .3s ease}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-glow)}
.fg input::placeholder,.fg textarea::placeholder{color:#c5c0ba;font-weight:300}
.fg textarea{resize:vertical;min-height:100px}
.fg select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath d='M5 7L1 3h8z' fill='%23c9a84c'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.btn-send{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.9rem;background:var(--terra);color:#fff;font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:50px;transition:all .4s var(--ease);box-shadow:0 5px 18px rgba(157,81,51,.22)}
.btn-send:hover{background:var(--terra-deep);box-shadow:0 7px 22px rgba(122,61,36,.28);transform:translateY(-2px)}
.btn-send svg{width:15px;height:15px}
.f-note{text-align:center;margin-top:.7rem;font-size:.68rem;color:#bbb;font-weight:300}

/* ============================================
   FOOTER — Multi-column (like reference)
   ============================================ */
.foot{background:var(--terra);color:rgba(255,255,255,.7);padding:4rem 0 0}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2.5rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.12)}
.foot-brand p{font-size:.82rem;font-weight:300;line-height:1.7;margin-top:1rem;max-width:260px}
.foot-brand img{height:78px;opacity:.9}
.foot-brand .foot-social{display:flex;gap:.5rem;margin-top:1.3rem}
.foot-social a{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.2);transition:all .3s ease;color:rgba(255,255,255,.7)}
.foot-social a:hover{background:var(--white);border-color:var(--white);color:var(--terra);transform:translateY(-2px)}
.foot-col h4{font-family:var(--serif);font-size:.95rem;color:#fff;font-weight:600;margin-bottom:1rem}
.foot-col a{display:block;font-size:.78rem;font-weight:300;margin-bottom:.55rem;transition:all .3s ease}
.foot-col a:hover{color:var(--gold);padding-left:.3rem}
.foot-bar{display:flex;justify-content:space-between;padding:1.5rem 0;font-size:.68rem;color:rgba(255,255,255,.85);flex-wrap:wrap;gap:.5rem}

/* ============================================
   PAGE HERO (subpages)
   ============================================ */
.pg-hero{position:relative;height:50vh;min-height:360px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.pg-hero .hero-bg{position:absolute;inset:0}
.pg-hero .hero-bg img{width:100%;height:100%;object-fit:cover}
.pg-hero .hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(30,29,27,.35) 0%,rgba(30,29,27,.55) 100%)}
.pg-hero-c{position:relative;z-index:2;text-align:center;color:#fff}
.pg-hero-c .sc{font-size:1.3rem;display:block;margin-bottom:.3rem;animation:up .7s var(--out) both}
.pg-hero-c h1{color:#fff;animation:up .7s var(--out) .15s both}
.pg-hero-c .crumb{margin-top:.8rem;font-size:.72rem;letter-spacing:.08em;opacity:.5;animation:up .7s var(--out) .3s both}
.pg-hero-c .crumb a{color:var(--gold-soft)}
.pg-hero-c .crumb a:hover{color:#fff}

/* ============================================
   CONTACT PAGE
   ============================================ */
.s-contact{padding:7rem 0;background:var(--off)}
.contact-hd{text-align:center;max-width:550px;margin:0 auto 4rem}
.contact-hd .sc{font-size:1.3rem;display:block;margin-bottom:.2rem}
.contact-hd p{font-weight:300;color:var(--muted);font-size:.92rem;margin-top:.7rem}
.contact-lay{display:grid;grid-template-columns:1fr 1.5fr;gap:3rem;align-items:flex-start}
.info-stack{display:flex;flex-direction:column;gap:1rem}
.info-c{background:var(--white);border-radius:var(--radius);padding:1.6rem;border:1px solid var(--gold-border);transition:all .4s var(--ease)}
.info-c:hover{box-shadow:0 8px 25px rgba(30,29,27,.04);transform:translateY(-3px)}
.info-c .ic{width:38px;height:38px;border-radius:10px;background:var(--gold-glow);display:flex;align-items:center;justify-content:center;margin-bottom:.7rem}
.info-c .ic svg{width:18px;height:18px;stroke:var(--gold);stroke-width:1.5;fill:none}
.info-c h4{font-size:.95rem;margin-bottom:.25rem;color:var(--dark)}
.info-c p{font-weight:300;font-size:.82rem;color:var(--muted);line-height:1.7}
.trust-bar{background:var(--warm);border-radius:var(--radius);padding:1.2rem}
.trust-row{display:flex;justify-content:center;gap:1.5rem;flex-wrap:wrap}
.trust-it{display:flex;align-items:center;gap:.35rem;font-size:.75rem;font-weight:500;color:var(--terra)}
.trust-it svg{width:14px;height:14px;stroke:var(--gold);stroke-width:1.5;fill:none}
.form-box{background:var(--white);padding:2.5rem;border-radius:var(--radius-lg);border:1px solid var(--gold-border);position:relative;overflow:hidden}
.form-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),var(--terra),var(--gold))}
.form-box h3{text-align:center;margin-bottom:.3rem;font-size:1.3rem}
.form-box .fsub{text-align:center;font-size:.82rem;font-weight:300;color:var(--muted);margin-bottom:2rem}

/* ============================================
   MAP SECTION (Contact page)
   ============================================ */
.s-map{background:var(--off);padding-top:4rem}
.map-head{margin-bottom:2rem}
.map-arrow{margin-top:1rem}
.map-arrow svg{width:24px;height:24px;stroke:var(--gold);animation:float 2s ease infinite}
.map-wrap{position:relative;height:450px;overflow:hidden}
.map-wrap iframe{width:100%;height:100%;filter:saturate(.85) contrast(1.05)}
.map-pin-link{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:2}
.map-pin-badge{display:inline-flex;align-items:center;gap:.5rem;background:var(--white);padding:.7rem 1.4rem;border-radius:50px;box-shadow:0 6px 24px rgba(30,29,27,.12);font-size:.75rem;font-weight:500;color:var(--terra);transition:all .3s ease;border:1px solid var(--gold-border)}
.map-pin-badge:hover{background:var(--terra);color:#fff;transform:translateY(-2px);box-shadow:0 8px 28px rgba(157,81,51,.2)}
.map-pin-badge svg{width:16px;height:16px;stroke:var(--terra);transition:stroke .3s ease}
.map-pin-badge:hover svg{stroke:#fff}

/* Quote section (reusable) */
.s-qt{background:var(--terra);padding:5rem 2rem;text-align:center;position:relative;overflow:hidden}
.s-qt::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(201,168,76,.06) 0%,transparent 50%)}
.s-qt .deco{font-family:var(--serif);font-size:7rem;color:rgba(255,255,255,.04);position:absolute;top:-.3rem;left:50%;transform:translateX(-50%);line-height:1}
.s-qt blockquote{font-family:var(--serif);font-size:clamp(1.2rem,2.8vw,2rem);color:#fff;font-weight:500;font-style:italic;max-width:700px;margin:0 auto;line-height:1.5;position:relative}
.s-qt cite{display:block;margin-top:1.3rem;font-family:var(--display);font-style:normal;font-size:.62rem;color:var(--gold-soft);letter-spacing:.25em;text-transform:uppercase}

/* ============================================
   VIDEO LIGHTBOX MODAL
   ============================================ */
.video-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center}
.video-modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,.85);cursor:pointer}
.video-modal-content{position:relative;width:90%;max-width:960px;aspect-ratio:16/9;z-index:1}
.video-modal-close{position:absolute;top:-2.5rem;right:0;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;opacity:.7;transition:opacity .3s ease;line-height:1}
.video-modal-close:hover{opacity:1}
.video-modal-player{width:100%;height:100%}

/* ============================================
   SPINNER (contact form)
   ============================================ */
.dm-spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:dm-spin .6s linear infinite}
@keyframes dm-spin{to{transform:rotate(360deg)}}

/* ============================================
   EXPERIENCE PAGES
   ============================================ */
.s-exp-intro{padding:4rem 0 2rem;background:var(--off)}
.exp-intro{max-width:720px;margin:0 auto;text-align:center}
.exp-intro p{font-size:1.05rem;font-weight:300;line-height:1.9;color:var(--txt)}
.s-exp-examples{padding:3rem 0 5rem;background:var(--off)}
.exp-examples-head{text-align:center;margin-bottom:3rem}
.exp-examples-head .sc{font-size:1.3rem;display:block;margin-bottom:.3rem}
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.exp-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--gold-border);transition:all .4s var(--ease)}
.exp-card:hover{transform:translateY(-5px);box-shadow:0 12px 35px rgba(30,29,27,.07)}
.exp-card-img{height:220px;overflow:hidden}
.exp-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.exp-card:hover .exp-card-img img{transform:scale(1.05)}
.exp-card h3{padding:1.2rem 1.4rem .4rem;font-size:1.05rem}
.exp-card p{padding:0 1.4rem 1.4rem;font-size:.82rem;font-weight:300;color:var(--muted);line-height:1.7}

/* ============================================
   BLOG
   ============================================ */
.pg-hero-sm{height:40vh;min-height:280px}
.pg-hero-post{height:55vh;min-height:380px}
.post-hero-date{display:block;font-size:.75rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:.5rem;animation:up .7s var(--out) both}
.post-read-time{display:inline-block;margin-top:.6rem;font-size:.68rem;color:rgba(255,255,255,.5);letter-spacing:.06em;animation:up .7s var(--out) .4s both}
.s-blog-grid{padding:4rem 0 5rem;background:var(--off)}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.blog-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--gold-border);transition:all .4s var(--ease)}
.blog-card:hover{transform:translateY(-5px);box-shadow:0 12px 35px rgba(30,29,27,.07)}
.blog-card-link{display:block;text-decoration:none;color:inherit}
.blog-card-img{height:200px;overflow:hidden}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.blog-card:hover .blog-card-img img{transform:scale(1.05)}
.blog-card-body{padding:1.3rem 1.4rem 1.4rem}
.blog-date{font-size:.65rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}
.blog-card-body h3{font-size:1.05rem;margin:.4rem 0;line-height:1.35}
.blog-card-body p{font-size:.82rem;font-weight:300;color:var(--muted);line-height:1.7;margin-bottom:.8rem}
.blog-read{font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--terra);display:inline-flex;align-items:center;gap:.3rem;transition:gap .3s ease}
.blog-card:hover .blog-read{gap:.6rem}
.blog-pagination{text-align:center;margin-top:3rem}
.blog-pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;font-size:.78rem;font-weight:500;color:var(--txt);border:1px solid var(--gold-border);margin:0 .2rem;transition:all .3s ease}
.blog-pagination .page-numbers.current,.blog-pagination .page-numbers:hover{background:var(--terra);color:#fff;border-color:var(--terra)}
.blog-empty{text-align:center;padding:4rem 0}
.blog-empty p{font-size:1.1rem;color:var(--muted);font-weight:300}
/* Single post */
.s-post-content{padding:4rem 0 3rem;background:var(--off)}
.post-body{max-width:720px;margin:0 auto;font-size:1rem;font-weight:300;line-height:2;color:var(--txt)}
.post-body h2{font-size:1.5rem;margin:2.5rem 0 1rem;color:var(--dark)}
.post-body h3{font-size:1.2rem;margin:2rem 0 .8rem;color:var(--dark)}
.post-body p{margin-bottom:1.5rem}
.post-body img{border-radius:var(--radius);margin:1.5rem 0;box-shadow:0 8px 24px rgba(30,29,27,.06)}
.post-body blockquote{border-left:3px solid var(--gold);padding:1rem 1.5rem;margin:1.5rem 0;background:var(--cream);border-radius:0 var(--radius) var(--radius) 0;font-style:italic;color:var(--dark2)}
.post-body ul,.post-body ol{padding-left:1.5rem;margin-bottom:1.5rem}
.post-body li{margin-bottom:.5rem}
.post-body a{color:var(--terra);border-bottom:1px solid var(--gold-border);transition:border-color .3s ease}
.post-body a:hover{border-color:var(--terra)}
.s-blog-more{padding:4rem 0 5rem;background:var(--cream)}
.blog-more-head{text-align:center;margin-bottom:2.5rem}
/* Blog homepage section */
.s-blog-home{padding:6rem 0;background:var(--off)}
.blog-home-head{text-align:center;margin-bottom:3rem}
.blog-home-head .sc{font-size:1.4rem;display:block;margin-bottom:.3rem}
.blog-home-btn{text-align:center;margin-top:2.5rem}
/* Linked cards */
a.srv-card{text-decoration:none;color:inherit;display:flex}
a.explore-card{text-decoration:none;color:inherit}

/* ============================================
   TRUSTED BY — Logo grid
   ============================================ */
.s-trusted{padding:5rem 0;background:var(--off)}
.trusted-head{text-align:center;margin-bottom:3rem}
.trusted-head .sc{font-size:1.4rem;display:block;margin-bottom:.3rem}
.trusted-logos{display:flex;align-items:center;justify-content:center;gap:3rem;flex-wrap:wrap}
.trusted-logo{display:flex;align-items:center;justify-content:center;width:120px;height:40px;filter:grayscale(1) opacity(.5);transition:all .5s var(--ease)}
.trusted-logo:hover{filter:none;opacity:1}
.trusted-logo img{max-height:100%;max-width:100%;object-fit:contain}
.trusted-logo svg{max-height:100%;max-width:100%;display:block}

/* Google Reviews enhancements */
.google-rating{display:flex;align-items:center;justify-content:center;gap:.6rem;margin-top:1rem}
.gr-score{font-family:var(--serif);font-size:1.8rem;font-weight:700;color:var(--dark)}
.gr-count{font-size:.78rem;color:var(--muted);font-weight:300}
.t-stars{margin-bottom:.8rem}
.t-stars-row{display:inline-flex;gap:2px}
.t-stars-row svg{width:16px;height:16px}
.star-full{fill:var(--gold)}
.star-half{fill:var(--gold)}
.star-empty{fill:#ddd}
.t-avatar-init{display:flex;align-items:center;justify-content:center;background:var(--gold);color:#fff;font-family:var(--serif);font-weight:700;font-size:1rem}
.google-badge{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:2rem;font-size:.72rem;color:var(--muted)}
.google-badge svg{width:18px;height:18px;flex-shrink:0}

/* Reviews Carousel */
.testi-carousel{position:relative;overflow:hidden;margin:0 -2rem;padding:0 2rem}
.testi-track{display:flex;gap:1.5rem;animation:scrollReviews 30s linear infinite}
.testi-track:hover{animation-play-state:paused}
.testi-carousel .testi-card{min-width:340px;max-width:400px;flex-shrink:0}
@keyframes scrollReviews{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* ============================================
   PHOTO GALLERY — Grid + Lightbox
   ============================================ */
.s-gallery{padding:6rem 0;background:var(--cream)}
.gallery-head{text-align:center;margin-bottom:3rem}
.gallery-head .sc{font-size:1.4rem;display:block;margin-bottom:.3rem}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.gallery-item{border-radius:var(--radius);overflow:hidden;position:relative;cursor:pointer;height:240px}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-over{position:absolute;inset:0;background:rgba(30,29,27,.3);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}
.gallery-item:hover .gallery-over{opacity:1}
.gallery-over svg{width:28px;height:28px;stroke:#fff;stroke-width:2;fill:none}
.gallery-item:nth-child(1){grid-column:span 2;height:300px}
.gallery-item:nth-child(6){grid-column:span 2;height:300px}

/* Gallery Lightbox */
.dm-lightbox{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center}
.lb-overlay{position:absolute;inset:0;background:rgba(0,0,0,.92);cursor:pointer}
.lb-img{position:relative;z-index:1;max-width:90%;max-height:85vh;border-radius:var(--radius);object-fit:contain}
.lb-close{position:absolute;top:1.5rem;right:1.5rem;z-index:2;background:none;border:none;color:#fff;font-size:2.5rem;cursor:pointer;opacity:.7;transition:opacity .3s ease;line-height:1}
.lb-close:hover{opacity:1}
.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);z-index:2;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:#fff}
.lb-prev{left:1.5rem}
.lb-next{right:1.5rem}
.lb-prev:hover,.lb-next:hover{background:var(--gold);border-color:var(--gold)}
.lb-prev svg,.lb-next svg{width:20px;height:20px}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
  .hero-content{grid-template-columns:1fr;text-align:center;padding-top:8rem}
  .hero-left{display:flex;flex-direction:column;align-items:center}
  .hero-left h1{max-width:100%}
  .hero-left .sub{margin-left:auto;margin-right:auto}
  .hero-btns{justify-content:center}
  .hero-right{display:none}
  .hero-bottom{display:none}
  .trust-grid{grid-template-columns:1fr;gap:0}
  .trust-pill:not(:last-child)::after{display:none}
  .trust-pill{border-bottom:1px solid var(--gold-border)}
  .trust-pill:last-child{border-bottom:none}
  .about-body{gap:2rem}
  .about-body .ab-img{height:300px}
  .srv-grid{grid-template-columns:1fr 1fr}
  .s-founders{grid-template-columns:1fr}
  .founders-img{height:400px}
  .s-founders.about-hero .founders-img{min-height:auto;height:60vh}
  .testi-grid{grid-template-columns:1fr}
  .testi-carousel .testi-card{min-width:300px}
  .faq-layout{grid-template-columns:1fr}
  .cta-layout{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr 1fr;gap:2.5rem}
  .contact-lay{grid-template-columns:1fr;gap:2.5rem}
  .stats-row{grid-template-columns:repeat(2,1fr);gap:1.5rem}
  .exp-grid{grid-template-columns:1fr 1fr}
  .blog-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .gallery-item:nth-child(1),.gallery-item:nth-child(6){grid-column:span 1;height:240px}
}
@media(max-width:768px){
  .nav{left:1rem;right:1rem;padding:.45rem 1rem;border-radius:50px;top:.7rem}
  .nav-menu{position:fixed;top:0;right:-100%;width:82%;max-width:320px;height:100vh;height:100dvh;background:var(--cream);flex-direction:column;justify-content:flex-start;padding:5rem 2.5rem 2.5rem;gap:0;transition:right .4s var(--ease);box-shadow:-8px 0 32px rgba(0,0,0,.1);border-radius:0;overflow-y:auto}
  .nav-menu::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--terra),var(--gold))}
  .nav-menu.open{right:0}
  .nav-menu li{width:100%}
  .nav-menu li a{display:block;width:100%;padding:1rem 0;font-size:.82rem!important;letter-spacing:.1em!important;border-bottom:1px solid var(--gold-border);color:var(--dark)!important}
  .nav-menu li a.on{color:var(--terra)!important;font-weight:700!important}
  .nav-menu li a::after{display:none!important}
  .nav-menu li a:hover{color:var(--terra)!important;padding-left:.5rem}
  .nav-menu li.lang-switch{margin-top:1.5rem;padding-top:.5rem;border-top:none}
  .nav-menu li.lang-switch .lang-btn{width:100%;justify-content:center;padding:.7rem 1.2rem!important;font-size:.8rem!important;border-radius:12px;background:var(--gold)!important;color:#fff!important;border:none!important;box-shadow:0 4px 14px rgba(201,168,76,.3)}
  .nav-menu li:last-child{margin-top:.8rem}
  .nav-menu li:last-child .nav-cta{display:block;text-align:center;padding:.85rem 1.2rem!important;border-radius:12px;font-size:.8rem!important;border-bottom:none}
  .has-dropdown .dropdown-menu{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;border:none;border-radius:0;margin:0;padding:0;background:transparent;max-height:0;overflow:hidden;transition:max-height .4s ease}
  .has-dropdown .dropdown-menu::before{display:none}
  .has-dropdown.open .dropdown-menu{max-height:400px}
  .dropdown-menu li a{padding:.7rem 0 .7rem 1.5rem!important;font-size:.78rem!important;border-bottom:1px solid var(--gold-border)!important;color:var(--muted)!important}
  .dropdown-menu li a:hover{padding-left:2rem!important;color:var(--terra)!important;background:transparent!important}
  .dropdown-toggle .dd-chevron{display:inline-block}
  .hero-nav .nav-menu a{color:var(--dark)!important}
  .nav-right-mobile{display:flex}
  .burger{display:flex}
  .burger.on span{background:var(--dark)!important}
  .hero{min-height:85vh}
  .hero-btns{flex-direction:column}
  .about-body{grid-template-columns:1fr}
  .about-body .ab-img{height:280px}
  .about-body:nth-child(3) .ab-txt{order:-1}
  .srv-grid{grid-template-columns:1fr}
  .testi-carousel .testi-card{min-width:280px;max-width:300px}
  .explore-card{flex:0 0 260px;height:300px}
  .founders-body{padding:2.5rem 1.5rem}
  .fr{grid-template-columns:1fr}
  .form-box{padding:1.8rem 1.3rem}
  .cta-form{padding:1.8rem 1.3rem}
  .foot{padding:3rem 0 0}
  .foot-top{grid-template-columns:1fr;text-align:center;gap:2rem;padding-bottom:2rem}
  .foot-brand{padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;align-items:center}
  .foot-brand p{margin-left:auto;margin-right:auto}
  .foot-brand img{height:60px}
  .foot-brand .foot-social{justify-content:center;margin-top:1.2rem}
  .foot-social a{width:38px;height:38px}
  .foot-col h4{margin-bottom:.6rem;font-size:.95rem}
  .foot-col a{font-size:.82rem;margin-bottom:.5rem}
  .foot-bar{flex-direction:column;gap:.4rem;text-align:center;padding:1.2rem 0;font-size:.72rem}
  .trust-row{flex-direction:column;align-items:center;gap:.5rem}
  .stats-row{grid-template-columns:1fr 1fr}
  .exp-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .trusted-logos{gap:2rem}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-item{height:200px}
  .gallery-item:nth-child(1),.gallery-item:nth-child(6){grid-column:span 2;height:220px}
  .pg-hero-sm{height:35vh;min-height:240px}
  .pg-hero-post{height:45vh;min-height:300px}
}
@media(max-width:480px){
  .hero{min-height:100vh}
  .trust-grid{grid-template-columns:1fr}
}
