/* =================================================================
   FINE STITCH DESIGN LLC — Premium Embroidery Theme
   Concept: "Every Stitch Builds Your Identity."
   Palette: Deep Navy / Ivory Cream / Muted Gold / Charcoal
   ================================================================= */

/* ---------- 1. DESIGN TOKENS ---------- */
:root{
  --navy:#14213d;
  --navy-deep:#0d1730;
  --navy-soft:#1d2e52;
  --gold:#c9a24b;
  --gold-soft:#dcc187;
  --gold-deep:#a8842f;
  --cream:#faf7f0;
  --cream-2:#f3eee2;
  --ivory:#fffdf8;
  --charcoal:#2b2b2b;
  --grey:#5d6472;
  --grey-line:#e4ddcd;
  --white:#ffffff;

  --ff-serif:"Cormorant Garamond","Playfair Display",Georgia,serif;
  --ff-sans:"Inter","Poppins",-apple-system,"Segoe UI",Roboto,sans-serif;

  --container:1200px;
  --radius:14px;
  --radius-lg:22px;
  --shadow-sm:0 4px 18px rgba(20,33,61,.07);
  --shadow:0 18px 50px rgba(20,33,61,.12);
  --shadow-gold:0 14px 40px rgba(201,162,75,.28);
  --t:.35s cubic-bezier(.2,.7,.2,1);
}

/* ---------- 2. RESET & BASE ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--ff-sans);
  color:var(--charcoal);
  background:var(--cream);
  line-height:1.7;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--navy);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--gold-deep)}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4{font-family:var(--ff-serif);color:var(--navy);font-weight:700;line-height:1.15;margin:0 0 .5em}
h1{font-size:clamp(2.4rem,5.4vw,4rem);letter-spacing:-.5px}
h2{font-size:clamp(2rem,4vw,3rem);letter-spacing:-.4px}
h3{font-size:clamp(1.4rem,2.4vw,1.9rem)}
h4{font-size:1.2rem}
p{margin:0 0 1.1em}
.container{max-width:var(--container);margin:0 auto;padding:0 22px}
section{position:relative}
::selection{background:var(--gold);color:#fff}

/* Base size for every inline icon. Specific context rules (.btn svg, etc.)
   are more specific and still override this safely. */
.fs-ico{width:20px;height:20px;flex-shrink:0}

/* ---------- 3. UTILITIES ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--ff-sans);font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;font-size:.72rem;color:var(--gold-deep);margin-bottom:1rem;
}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--gold)}
.eyebrow.center{justify-content:center}
.section{padding:clamp(60px,8vw,110px) 0}
.section.cream{background:var(--cream)}
.section.ivory{background:var(--ivory)}
.section.navy{background:var(--navy);color:#e9e6df}
.section.navy h1,.section.navy h2,.section.navy h3{color:#fff}
.section-head{max-width:720px;margin:0 auto 3rem;text-align:center}
.section-head.left{margin-left:0;text-align:left}
.section-head p{color:var(--grey);font-size:1.08rem}
.section.navy .section-head p{color:#c9cde0}
.lead{font-size:1.18rem;color:var(--grey);line-height:1.8}
.gold-text{color:var(--gold-deep)}
.divider-gold{width:70px;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-soft));border-radius:3px;margin:1.2rem auto}
.section-head.left .divider-gold{margin-left:0}
.text-center{text-align:center}
.mt-2{margin-top:2rem}

/* stitch dashed accent line */
.stitch-line{
  height:0;border:none;border-top:2px dashed var(--gold);
  opacity:.5;max-width:120px;margin:1.4rem 0;
}

/* ---------- 4. BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--ff-sans);font-weight:600;font-size:.98rem;
  padding:15px 30px;border-radius:50px;cursor:pointer;border:2px solid transparent;
  transition:transform var(--t),box-shadow var(--t),background var(--t),color var(--t);
  line-height:1;text-align:center;
}
.btn svg{width:18px;height:18px}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#fff;box-shadow:var(--shadow-gold)}
.btn-gold:hover{color:#fff;transform:translateY(-3px);box-shadow:0 20px 48px rgba(201,162,75,.42)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-deep);color:#fff;transform:translateY(-3px)}
.btn-outline{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}
.btn-ghost{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.4)}
.btn-ghost:hover{background:#fff;color:var(--navy)}
.btn-wa{background:#25d366;color:#fff}
.btn-wa:hover{background:#1ebe5b;color:#fff;transform:translateY(-3px)}
.btn-sm{padding:11px 22px;font-size:.9rem}
.btn-block{width:100%}

/* ---------- 5. TOP BAR ---------- */
.topbar{background:var(--navy-deep);color:#cfd6e6;font-size:.85rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;min-height:42px;gap:1rem;flex-wrap:wrap}
.topbar a{color:#cfd6e6}
.topbar a:hover{color:var(--gold-soft)}
.topbar-info{display:flex;gap:1.5rem;flex-wrap:wrap;align-items:center}
.topbar-info span{display:inline-flex;align-items:center;gap:.45rem}
.topbar-info svg{width:15px;height:15px;color:var(--gold)}
.topbar-social{display:flex;gap:.9rem;align-items:center}
.topbar-social a svg{width:16px;height:16px}

/* ---------- 6. HEADER ---------- */
.site-header{position:sticky;top:0;z-index:900;background:rgba(255,253,248,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--grey-line);transition:box-shadow var(--t),background var(--t)}
.site-header.scrolled{box-shadow:0 8px 30px rgba(20,33,61,.10)}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:78px;gap:1.4rem}
.site-logo img{height:54px;width:auto;transition:height var(--t)}
.site-header.scrolled .site-logo img{height:46px}
.main-nav ul{display:flex;align-items:center;gap:.3rem}
.main-nav a{
  font-family:var(--ff-sans);font-weight:500;font-size:.96rem;color:var(--navy);
  padding:10px 15px;border-radius:8px;position:relative;
}
.main-nav a::after{content:"";position:absolute;left:15px;right:15px;bottom:6px;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform var(--t)}
.main-nav a:hover::after,.main-nav .current-menu-item>a::after{transform:scaleX(1)}
.main-nav .menu-item-has-children>a::before{content:"";display:inline-block;width:6px;height:6px;border-right:2px solid var(--gold-deep);border-bottom:2px solid var(--gold-deep);transform:rotate(45deg);margin-right:7px;vertical-align:1px}
.main-nav li{position:relative}
.main-nav .sub-menu{
  position:absolute;top:100%;left:0;min-width:240px;background:#fff;border:1px solid var(--grey-line);
  border-radius:12px;box-shadow:var(--shadow);padding:8px;display:block;opacity:0;visibility:hidden;
  transform:translateY(10px);transition:all var(--t);z-index:50;
}
.main-nav li:hover>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.main-nav .sub-menu a{display:block;padding:10px 14px;border-radius:8px;font-size:.92rem}
.main-nav .sub-menu a:hover{background:var(--cream);color:var(--gold-deep)}
.main-nav .sub-menu a::after{display:none}
.header-actions{display:flex;align-items:center;gap:.8rem}
.header-phone{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;color:var(--navy)}
.header-phone svg{width:34px;height:34px;padding:8px;background:var(--cream-2);border-radius:50%;color:var(--gold-deep)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.nav-toggle span{width:26px;height:2px;background:var(--navy);border-radius:2px;transition:var(--t)}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile drawer */
.mobile-drawer{position:fixed;inset:0 0 0 auto;width:min(86%,360px);background:var(--navy);color:#fff;z-index:1000;transform:translateX(100%);transition:transform .4s cubic-bezier(.2,.7,.2,1);padding:90px 26px 30px;overflow-y:auto;box-shadow:-20px 0 60px rgba(0,0,0,.3)}
.mobile-drawer.open{transform:translateX(0)}
.mobile-drawer .close-drawer{position:absolute;top:22px;right:22px;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;line-height:1}
.mobile-drawer ul{display:flex;flex-direction:column;gap:.2rem}
.mobile-drawer a{color:#eee;font-size:1.08rem;padding:13px 6px;display:block;border-bottom:1px solid rgba(255,255,255,.08)}
.mobile-drawer a:hover{color:var(--gold-soft)}
.mobile-drawer .sub-menu a{padding-left:20px;font-size:.98rem;color:#c7cde0}
.drawer-cta{margin-top:1.6rem;display:flex;flex-direction:column;gap:.7rem}
.drawer-overlay{position:fixed;inset:0;background:rgba(13,23,48,.55);z-index:990;opacity:0;visibility:hidden;transition:var(--t)}
.drawer-overlay.open{opacity:1;visibility:visible}

/* ---------- 7. HERO ---------- */
.hero{position:relative;background:var(--navy);color:#fff;overflow:hidden;padding:clamp(70px,9vw,120px) 0}
.hero-bg{position:absolute;inset:0;background:
  radial-gradient(circle at 80% 20%,rgba(201,162,75,.20),transparent 45%),
  radial-gradient(circle at 12% 85%,rgba(29,46,82,.9),transparent 50%),
  linear-gradient(135deg,var(--navy-deep),var(--navy) 55%,var(--navy-soft));
}
.hero-threads{position:absolute;inset:0;opacity:.5;background-image:
  repeating-linear-gradient(115deg,transparent 0 38px,rgba(201,162,75,.06) 38px 39px);
  pointer-events:none}
.hero .container{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center}
.hero-tag{display:inline-flex;align-items:center;gap:.6rem;background:rgba(201,162,75,.12);border:1px solid rgba(201,162,75,.35);color:var(--gold-soft);padding:8px 16px;border-radius:50px;font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1.5rem}
.hero-tag svg{width:16px;height:16px}
.hero h1{color:#fff}
.hero h1 .accent{color:var(--gold-soft);font-style:italic}
.hero-sub{font-size:1.15rem;color:#cfd6e6;max-width:560px;margin:1.2rem 0 2rem}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap}
.hero-stats{display:flex;gap:2.2rem;margin-top:2.6rem;flex-wrap:wrap}
.hero-stats .stat{position:relative}
.hero-stats .num{font-family:var(--ff-serif);font-size:2.3rem;color:var(--gold-soft);font-weight:700;line-height:1}
.hero-stats .lbl{font-size:.82rem;color:#aeb6cc;letter-spacing:.04em;margin-top:.25rem}

/* hero visual stack */
.hero-visual{position:relative;min-height:440px}
.hero-card{position:absolute;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.4);border:3px solid rgba(255,255,255,.08)}
.hero-card img{width:100%;height:100%;object-fit:cover}
.hero-card-main{inset:0;z-index:1}
.hero-card-float{width:46%;height:42%;right:-22px;bottom:-26px;z-index:2;border-color:rgba(201,162,75,.5)}
.hero-badge{position:absolute;left:-18px;top:30px;z-index:3;background:#fff;color:var(--navy);border-radius:16px;padding:14px 18px;box-shadow:var(--shadow);display:flex;align-items:center;gap:.7rem;font-weight:700;font-size:.9rem}
.hero-badge .ico{width:40px;height:40px;display:grid;place-items:center;background:var(--cream);border-radius:10px;color:var(--gold-deep)}
.hero-badge .ico svg{width:22px;height:22px}
.hero-badge small{display:block;font-weight:500;color:var(--grey);font-size:.74rem}

/* hero visual fallback (no image) */
.hero-visual.placeholder .hero-card-main{background:
  linear-gradient(135deg,#1d2e52,#0d1730),
  repeating-linear-gradient(45deg,rgba(201,162,75,.08) 0 10px,transparent 10px 20px);
  display:grid;place-items:center}
.hero-visual.placeholder .ph-label{color:var(--gold-soft);font-family:var(--ff-serif);font-size:1.3rem;text-align:center;padding:2rem;opacity:.85}

/* ---------- 8. TRUST STRIP ---------- */
.trust-strip{background:var(--ivory);border-bottom:1px solid var(--grey-line)}
.trust-strip .container{display:flex;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;padding-top:26px;padding-bottom:26px}
.trust-item{display:flex;align-items:center;gap:.8rem;font-weight:600;color:var(--navy);font-size:.95rem}
.trust-item svg{width:30px;height:30px;color:var(--gold-deep);flex-shrink:0}

/* ---------- 9. SERVICE CARDS ---------- */
.grid{display:grid;gap:1.6rem}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.service-card{
  background:#fff;border:1px solid var(--grey-line);border-radius:var(--radius-lg);
  padding:34px 28px;transition:transform var(--t),box-shadow var(--t),border-color var(--t);
  position:relative;overflow:hidden;
}
.service-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--gold),var(--gold-soft));transform:scaleX(0);transform-origin:left;transition:transform var(--t)}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.service-card:hover::before{transform:scaleX(1)}
.service-ico{width:62px;height:62px;border-radius:16px;background:var(--cream);display:grid;place-items:center;color:var(--gold-deep);margin-bottom:1.2rem;transition:var(--t)}
.service-card:hover .service-ico{background:var(--navy);color:var(--gold-soft)}
.service-ico svg{width:30px;height:30px}
.service-card h3{font-size:1.4rem;margin-bottom:.6rem}
.service-card p{color:var(--grey);font-size:.98rem;margin-bottom:1.1rem}
.service-link{font-weight:600;color:var(--gold-deep);display:inline-flex;align-items:center;gap:.4rem;font-size:.92rem}
.service-link svg{width:16px;height:16px;transition:transform var(--t)}
.service-card:hover .service-link svg{transform:translateX(5px)}

/* ---------- 10. ABOUT PREVIEW ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.split.media-right{direction:ltr}
.media-frame{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);min-height:420px;background:linear-gradient(135deg,#1d2e52,#0d1730)}
.media-frame img{width:100%;height:100%;object-fit:cover;min-height:420px}
.media-frame.placeholder{display:grid;place-items:center}
.media-frame .ph-label{color:var(--gold-soft);font-family:var(--ff-serif);text-align:center;padding:2rem;font-size:1.15rem;opacity:.85}
.media-frame .accent-square{position:absolute;width:120px;height:120px;border:3px solid var(--gold);border-radius:14px;right:-18px;bottom:-18px;z-index:-1}
.checklist{display:grid;gap:.9rem;margin:1.5rem 0}
.checklist li{display:flex;align-items:flex-start;gap:.8rem;font-weight:500}
.checklist svg{width:24px;height:24px;color:var(--gold-deep);flex-shrink:0;margin-top:1px}
.stat-row{display:flex;gap:2.5rem;margin:1.8rem 0;flex-wrap:wrap}
.stat-row .num{font-family:var(--ff-serif);font-size:2.6rem;color:var(--navy);font-weight:700;line-height:1}
.stat-row .num small{color:var(--gold-deep)}
.stat-row .lbl{font-size:.85rem;color:var(--grey)}

/* ---------- 11. WHY CHOOSE (feature grid) ---------- */
.feature-card{background:var(--ivory);border:1px solid var(--grey-line);border-radius:var(--radius);padding:28px 24px;transition:var(--t)}
.feature-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-sm);border-color:var(--gold-soft)}
.feature-card .fi{width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,var(--navy),var(--navy-soft));color:var(--gold-soft);display:grid;place-items:center;margin-bottom:1rem}
.feature-card .fi svg{width:26px;height:26px}
.feature-card h4{font-size:1.18rem;margin-bottom:.4rem}
.feature-card p{color:var(--grey);font-size:.94rem;margin:0}
.section.navy .feature-card{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.1)}
.section.navy .feature-card p{color:#c2c8db}

/* ---------- 12. PROCESS TIMELINE ---------- */
.process{display:grid;grid-template-columns:repeat(5,1fr);gap:1.2rem;counter-reset:step;position:relative}
.process::before{content:"";position:absolute;top:38px;left:8%;right:8%;height:2px;background:repeating-linear-gradient(90deg,var(--gold) 0 10px,transparent 10px 20px);z-index:0}
.process-step{position:relative;z-index:1;text-align:center}
.process-step .pnum{width:76px;height:76px;margin:0 auto 1.1rem;border-radius:50%;background:#fff;border:2px solid var(--gold);color:var(--navy);display:grid;place-items:center;font-family:var(--ff-serif);font-size:1.7rem;font-weight:700;box-shadow:var(--shadow-sm);transition:var(--t)}
.section.navy .process-step .pnum{background:var(--navy-deep)}
.process-step:hover .pnum{background:var(--gold);color:#fff;transform:scale(1.06)}
.process-step h4{font-size:1.1rem;margin-bottom:.35rem}
.process-step p{font-size:.88rem;color:var(--grey);margin:0}
.section.navy .process-step p{color:#bcc3d8}

/* ---------- 13. GALLERY ---------- */
.gallery-filters{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-bottom:2.4rem}
.filter-btn{font-family:var(--ff-sans);font-weight:600;font-size:.9rem;padding:10px 22px;border-radius:50px;border:1.5px solid var(--grey-line);background:#fff;color:var(--navy);cursor:pointer;transition:var(--t)}
.filter-btn:hover{border-color:var(--gold)}
.filter-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.gallery-item{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;aspect-ratio:4/3;background:linear-gradient(135deg,#1d2e52,#0d1730);box-shadow:var(--shadow-sm)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gallery-item:hover img{transform:scale(1.08)}
.gallery-item .g-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,23,48,.85),transparent 60%);opacity:0;transition:var(--t);display:flex;flex-direction:column;justify-content:flex-end;padding:20px}
.gallery-item:hover .g-overlay{opacity:1}
.g-overlay .g-cat{color:var(--gold-soft);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600}
.g-overlay .g-title{color:#fff;font-family:var(--ff-serif);font-size:1.2rem}
.gallery-item.ph{display:grid;place-items:center}
.gallery-item.ph .ph-mini{color:var(--gold-soft);font-family:var(--ff-serif);font-size:.95rem;text-align:center;padding:1rem;opacity:.8}
.gallery-item.ph .ph-mini svg{width:34px;height:34px;margin:0 auto .4rem}
.ph-label svg{width:48px;height:48px;margin:0 auto .6rem;display:block}
.gallery-item.hide{display:none}

/* lightbox */
.lightbox{position:fixed;inset:0;background:rgba(13,23,48,.94);z-index:2000;display:none;align-items:center;justify-content:center;padding:30px}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:86vh;border-radius:12px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lightbox .lb-close{position:absolute;top:24px;right:30px;color:#fff;font-size:2.4rem;cursor:pointer;background:none;border:none;line-height:1}
.lightbox .lb-cap{position:absolute;bottom:26px;left:0;right:0;text-align:center;color:#fff;font-family:var(--ff-serif);font-size:1.2rem}

/* ---------- 14. BEFORE / AFTER ---------- */
.ba-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem}
.ba-card{background:#fff;border:1px solid var(--grey-line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.ba-images{display:grid;grid-template-columns:1fr 1fr}
.ba-images>div{aspect-ratio:1/1;position:relative;display:grid;place-items:center;background:linear-gradient(135deg,#1d2e52,#0d1730);color:var(--gold-soft);font-weight:600}
.ba-images .before{background:linear-gradient(135deg,#3a3f4d,#23262f)}
.ba-images span.tag{position:absolute;top:12px;left:12px;background:rgba(0,0,0,.5);color:#fff;font-size:.72rem;padding:4px 10px;border-radius:20px;letter-spacing:.1em;text-transform:uppercase}
.ba-card .ba-foot{padding:18px 22px}
.ba-card .ba-foot h4{margin:0 0 .2rem}
.ba-card .ba-foot p{margin:0;color:var(--grey);font-size:.9rem}

/* ---------- 15. INDUSTRIES ---------- */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.ind-item{background:#fff;border:1px solid var(--grey-line);border-radius:var(--radius);padding:22px 20px;display:flex;align-items:center;gap:1rem;transition:var(--t)}
.ind-item:hover{border-color:var(--gold);transform:translateX(5px);box-shadow:var(--shadow-sm)}
.ind-item .ii{width:48px;height:48px;border-radius:12px;background:var(--cream);color:var(--gold-deep);display:grid;place-items:center;flex-shrink:0}
.ind-item .ii svg{width:24px;height:24px}
.ind-item h4{margin:0;font-size:1.05rem;font-family:var(--ff-sans);font-weight:600;color:var(--navy)}
.ind-item p{margin:0;font-size:.82rem;color:var(--grey)}

/* ---------- 16. CTA BANNER ---------- */
.cta-banner{background:linear-gradient(135deg,var(--navy-deep),var(--navy-soft));border-radius:var(--radius-lg);padding:clamp(40px,6vw,68px);text-align:center;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.cta-banner::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(115deg,transparent 0 40px,rgba(201,162,75,.05) 40px 41px)}
.cta-banner>*{position:relative;z-index:1}
.cta-banner h2{color:#fff;margin-bottom:.6rem}
.cta-banner p{color:#cfd6e6;max-width:620px;margin:0 auto 1.8rem;font-size:1.1rem}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ---------- 17. TESTIMONIALS ---------- */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.testi-card{background:#fff;border:1px solid var(--grey-line);border-radius:var(--radius-lg);padding:32px 28px;position:relative}
.testi-card .quote-mark{font-family:var(--ff-serif);font-size:4rem;color:var(--gold-soft);line-height:.6;opacity:.5;position:absolute;top:22px;right:24px}
.testi-stars{display:flex;gap:3px;color:var(--gold);margin-bottom:1rem}
.testi-stars svg{width:18px;height:18px}
.testi-card p{font-style:italic;color:var(--charcoal);position:relative;z-index:1}
.testi-author{display:flex;align-items:center;gap:.9rem;margin-top:1.2rem}
.testi-author .av{width:48px;height:48px;border-radius:50%;background:var(--navy);color:var(--gold-soft);display:grid;place-items:center;font-family:var(--ff-serif);font-weight:700;font-size:1.2rem}
.testi-author .meta strong{display:block;color:var(--navy);font-family:var(--ff-sans)}
.testi-author .meta span{font-size:.84rem;color:var(--grey)}
.placeholder-note{font-size:.78rem;color:var(--grey);text-align:center;margin-top:1.5rem;font-style:italic}

/* ---------- 18. FAQ ACCORDION ---------- */
.faq-wrap{max-width:820px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--grey-line);border-radius:var(--radius);margin-bottom:.9rem;overflow:hidden;transition:var(--t)}
.faq-item.open{border-color:var(--gold);box-shadow:var(--shadow-sm)}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:22px 24px;font-family:var(--ff-sans);font-weight:600;font-size:1.05rem;color:var(--navy);display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq-q .ic{width:26px;height:26px;flex-shrink:0;border-radius:50%;background:var(--cream);display:grid;place-items:center;transition:var(--t);position:relative}
.faq-q .ic::before,.faq-q .ic::after{content:"";position:absolute;background:var(--gold-deep);border-radius:2px}
.faq-q .ic::before{width:12px;height:2px}
.faq-q .ic::after{width:2px;height:12px;transition:var(--t)}
.faq-item.open .ic{background:var(--gold)}
.faq-item.open .ic::before,.faq-item.open .ic::after{background:#fff}
.faq-item.open .ic::after{transform:rotate(90deg);opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a-inner{padding:0 24px 22px;color:var(--grey)}

/* ---------- 19. FORMS ---------- */
.form-card{background:#fff;border:1px solid var(--grey-line);border-radius:var(--radius-lg);padding:clamp(26px,4vw,42px);box-shadow:var(--shadow)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.1rem}
.field.full{grid-column:1/-1}
.field label{font-weight:600;font-size:.9rem;color:var(--navy)}
.field label .req{color:#c0392b}
.field input,.field select,.field textarea{
  font-family:var(--ff-sans);font-size:1rem;padding:13px 16px;border:1.5px solid var(--grey-line);
  border-radius:10px;background:var(--ivory);color:var(--charcoal);transition:var(--t);width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:#fff;box-shadow:0 0 0 4px rgba(201,162,75,.12)}
.field textarea{resize:vertical;min-height:120px}
.field-file{border:1.5px dashed var(--grey-line);border-radius:10px;padding:18px;text-align:center;background:var(--cream);cursor:pointer;transition:var(--t);position:relative}
.field-file:hover{border-color:var(--gold);background:var(--cream-2)}
.field-file svg{width:30px;height:30px;color:var(--gold-deep);margin:0 auto .5rem}
.field-file span{font-size:.88rem;color:var(--grey);display:block}
.field-file input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.field-file .file-name{font-weight:600;color:var(--navy);margin-top:.4rem}
.form-note{font-size:.82rem;color:var(--grey);margin-top:.4rem}
.form-msg{padding:14px 18px;border-radius:10px;margin-bottom:1.2rem;display:none;font-weight:500}
.form-msg.show{display:block}
.form-msg.success{background:#e6f6ec;color:#1d7a43;border:1px solid #b7e4c7}
.form-msg.error{background:#fdeaea;color:#b03030;border:1px solid #f5c6c6}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* ---------- 20. PAGE HERO (inner) ---------- */
.page-hero{background:var(--navy);color:#fff;padding:clamp(56px,7vw,90px) 0;position:relative;overflow:hidden;text-align:center}
.page-hero .hero-bg{opacity:.9}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{color:#fff;max-width:840px;margin:0 auto .8rem}
.page-hero p{color:#cfd6e6;max-width:640px;margin:0 auto;font-size:1.12rem}
.breadcrumbs{margin-top:1.2rem;font-size:.86rem;color:#aeb6cc}
.breadcrumbs a{color:var(--gold-soft)}
.breadcrumbs span{margin:0 .4rem;color:#6b7596}

/* ---------- 21. CONTENT / RICH TEXT ---------- */
.rich h2{margin-top:2.2rem}
.rich h3{margin-top:1.8rem}
.rich ul.bullets{display:grid;gap:.7rem;margin:1.2rem 0}
.rich ul.bullets li{display:flex;align-items:flex-start;gap:.7rem;color:var(--charcoal)}
.rich ul.bullets svg{width:20px;height:20px;color:var(--gold-deep);flex-shrink:0;margin-top:3px}
.benefit-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;margin:1.5rem 0}
.benefit{display:flex;gap:1rem;background:var(--ivory);border:1px solid var(--grey-line);border-radius:var(--radius);padding:22px}
.benefit .bi{width:46px;height:46px;border-radius:12px;background:var(--cream);color:var(--gold-deep);display:grid;place-items:center;flex-shrink:0}
.benefit .bi svg{width:24px;height:24px}
.benefit h4{margin:0 0 .25rem}
.benefit p{margin:0;font-size:.92rem;color:var(--grey)}
.tag-pills{display:flex;flex-wrap:wrap;gap:.6rem;margin:1.2rem 0}
.tag-pills li{background:#fff;border:1px solid var(--grey-line);border-radius:50px;padding:9px 18px;font-size:.9rem;font-weight:500;color:var(--navy)}

/* ---------- 22. CONTACT INFO CARDS ---------- */
.contact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-bottom:2rem}
.contact-card{background:#fff;border:1px solid var(--grey-line);border-radius:var(--radius);padding:26px;text-align:center;transition:var(--t)}
.contact-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-5px)}
.contact-card .ci{width:56px;height:56px;border-radius:50%;background:var(--cream);color:var(--gold-deep);display:grid;place-items:center;margin:0 auto 1rem}
.contact-card .ci svg{width:26px;height:26px}
.contact-card h4{margin-bottom:.3rem}
.contact-card a,.contact-card p{color:var(--grey);font-size:.96rem;margin:0}
.contact-card a:hover{color:var(--gold-deep)}
.map-frame{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--grey-line);line-height:0}
.map-frame iframe{width:100%;height:380px;border:0}
.hours-list li{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px dashed var(--grey-line)}
.hours-list li span:last-child{font-weight:600;color:var(--navy)}

/* ---------- 23. BLOG ---------- */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem}
.post-card{background:#fff;border:1px solid var(--grey-line);border-radius:var(--radius-lg);overflow:hidden;transition:var(--t);display:flex;flex-direction:column}
.post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.post-thumb{aspect-ratio:16/10;background:linear-gradient(135deg,#1d2e52,#0d1730);position:relative;overflow:hidden}
.post-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.post-card:hover .post-thumb img{transform:scale(1.06)}
.post-cat{position:absolute;top:14px;left:14px;background:var(--gold);color:#fff;font-size:.72rem;font-weight:600;padding:5px 12px;border-radius:20px;letter-spacing:.06em;text-transform:uppercase}
.post-body{padding:24px;display:flex;flex-direction:column;flex:1}
.post-meta{font-size:.82rem;color:var(--grey);margin-bottom:.6rem}
.post-body h3{font-size:1.25rem;margin-bottom:.5rem}
.post-body h3 a{color:var(--navy)}
.post-body h3 a:hover{color:var(--gold-deep)}
.post-body p{color:var(--grey);font-size:.94rem;flex:1}
.post-body .read-more{font-weight:600;color:var(--gold-deep);margin-top:.6rem;font-size:.9rem}
.single-content{max-width:760px;margin:0 auto}
.single-content img{border-radius:var(--radius);margin:1.5rem 0}

/* ---------- 24. FOOTER ---------- */
.site-footer{background:var(--navy-deep);color:#aeb6cc;padding-top:clamp(50px,6vw,80px)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:2.4rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-col h4{color:#fff;font-family:var(--ff-sans);font-size:1.05rem;margin-bottom:1.2rem;position:relative;padding-bottom:.6rem}
.footer-col h4::after{content:"";position:absolute;left:0;bottom:0;width:32px;height:2px;background:var(--gold)}
.footer-brand img{height:54px;margin-bottom:1.2rem;background:#fff;padding:8px 12px;border-radius:10px}
.footer-brand p{font-size:.94rem;line-height:1.8;color:#9aa3bd}
.footer-col ul li{margin-bottom:.7rem}
.footer-col a{color:#aeb6cc;font-size:.94rem}
.footer-col a:hover{color:var(--gold-soft);padding-left:5px}
.footer-contact li{display:flex;gap:.7rem;margin-bottom:1rem;font-size:.94rem;color:#aeb6cc;align-items:flex-start}
.footer-contact svg{width:18px;height:18px;color:var(--gold);flex-shrink:0;margin-top:3px}
.footer-social{display:flex;gap:.7rem;margin-top:1.2rem}
.footer-social a{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.06);display:grid;place-items:center;color:#fff;transition:var(--t)}
.footer-social a:hover{background:var(--gold);transform:translateY(-3px)}
.footer-social svg{width:18px;height:18px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;padding:1.6rem 0;font-size:.86rem;color:#7c87a6}
.footer-bottom a{color:#9aa3bd}
.footer-bottom a:hover{color:var(--gold-soft)}

/* ---------- 25. FLOATING BUTTONS ---------- */
.float-wa{position:fixed;right:22px;bottom:22px;z-index:800;width:60px;height:60px;border-radius:50%;background:#25d366;display:grid;place-items:center;box-shadow:0 12px 30px rgba(37,211,102,.5);transition:var(--t);animation:wa-pulse 2.4s infinite}
.float-wa:hover{transform:scale(1.1)}
.float-wa svg{width:32px;height:32px;color:#fff}
@keyframes wa-pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
.float-call{display:none}

/* ---------- 26. ANIMATIONS ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}*{scroll-behavior:auto}}

/* ---------- 27. 404 ---------- */
.err-404{text-align:center;padding:clamp(70px,10vw,130px) 0}
.err-404 .code{font-family:var(--ff-serif);font-size:clamp(6rem,18vw,12rem);color:var(--navy);line-height:1;position:relative}
.err-404 .code span{color:var(--gold)}
.err-404 p{max-width:480px;margin:1rem auto 2rem;color:var(--grey)}

/* ---------- 28. RESPONSIVE ---------- */
@media (max-width:1024px){
  .hero .container{grid-template-columns:1fr;gap:2.5rem}
  .hero-visual{min-height:380px;max-width:520px}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .process{grid-template-columns:repeat(2,1fr);gap:2rem}
  .process::before{display:none}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .testi-grid,.post-grid,.ind-grid,.contact-cards{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:880px){
  .main-nav,.header-phone{display:none}
  .nav-toggle{display:flex}
  .header-actions .btn:not(.nav-toggle){display:none}
}
@media (max-width:768px){
  body{font-size:16px}
  .grid-2,.grid-3,.grid-4,.gallery-grid,.testi-grid,.post-grid,.ind-grid,.contact-cards,.ba-grid,.benefit-grid,.form-grid,.split{grid-template-columns:1fr}
  .split{gap:2rem}
  .media-frame,.media-frame img{min-height:300px}
  .footer-grid{grid-template-columns:1fr}
  .process{grid-template-columns:1fr}
  .topbar-info{gap:1rem;font-size:.8rem}
  .topbar-info .hide-mobile{display:none}
  .hero-stats{gap:1.6rem}
  .float-call{display:grid;position:fixed;left:22px;bottom:22px;z-index:800;width:56px;height:56px;border-radius:50%;background:var(--navy);place-items:center;box-shadow:var(--shadow)}
  .float-call svg{width:26px;height:26px;color:var(--gold-soft)}
  .float-wa{width:56px;height:56px}
}
@media (max-width:480px){
  .container{padding:0 16px}
  .hero-cta .btn,.cta-actions .btn{width:100%}
  .topbar{display:none}
  .gallery-filters{gap:.4rem}
  .filter-btn{padding:8px 16px;font-size:.82rem}
}
