:root{
  --white:#FFFFFF;--bg:#FAF9F7;--bg2:#F4F2EE;--bg3:#EDEAE4;--bg4:#E5E1DA;
  --ink:#1C1916;--ink2:#3A3530;--muted:#6B6560;--faint:#A8A39D;
  --gold:#B8922A;--gold-lt:#D4AE5A;--gold-dark:#8A6B1A;--gold-bg:#FBF5E8;--gold-line:rgba(184,146,42,0.22);
  --green:#1DAF5C;--green-bg:#E8F7EE;--red:#E53E3E;
  --glass:rgba(255,255,255,.72);--glass-border:rgba(255,255,255,.35);--glass-blur:24px;
  --shadow-xs:0 1px 2px rgba(28,25,22,.04);
  --shadow-sm:0 2px 8px rgba(28,25,22,.06),0 1px 2px rgba(28,25,22,.04);
  --shadow-md:0 8px 30px rgba(28,25,22,.08),0 2px 8px rgba(28,25,22,.04);
  --shadow-lg:0 20px 60px rgba(28,25,22,.1),0 4px 16px rgba(28,25,22,.06);
  --shadow-xl:0 32px 80px rgba(28,25,22,.14);
  --r-xs:8px;--r-sm:10px;--r-md:14px;--r-lg:20px;--r-xl:28px;--nav-h:72px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'DM Sans',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--ink);overflow-x:hidden;-webkit-font-smoothing:antialiased;line-height:1.6}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button,input,select{font-family:inherit}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gold);border-radius:3px}
::selection{background:rgba(184,146,42,.2)}

/* ── SCROLL REVEAL ── */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{transform:translateX(-40px)}.reveal-left.visible{transform:translateX(0)}
.reveal-right{transform:translateX(40px)}.reveal-right.visible{transform:translateX(0)}
.reveal-scale{transform:scale(.92)}.reveal-scale.visible{transform:scale(1)}
.reveal-delay-1{transition-delay:.12s}.reveal-delay-2{transition-delay:.24s}.reveal-delay-3{transition-delay:.36s}.reveal-delay-4{transition-delay:.48s}
@media(prefers-reduced-motion:reduce){.reveal,.reveal-left,.reveal-right,.reveal-scale{opacity:1;transform:none;transition:none}}

/* LAYOUT */
.container{max-width:1280px;margin:0 auto;padding:0 48px}
section{padding:100px 0}
.sec-label{display:inline-flex;align-items:center;gap:12px;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.sec-label::before{content:'';width:32px;height:2px;background:linear-gradient(90deg,var(--gold),transparent);border-radius:1px}
.sec-label.center{justify-content:center}
.sec-label.center::before{display:none}
.sec-label.center::after{content:'';width:32px;height:2px;background:linear-gradient(90deg,transparent,var(--gold));border-radius:1px}
h2.h{font-family:'DM Serif Display',serif;font-size:clamp(30px,4vw,52px);font-weight:400;line-height:1.12;color:var(--ink);letter-spacing:-.01em}
h2.h em{font-style:italic;color:var(--gold)}
.sub{font-size:15px;color:var(--muted);line-height:1.85;margin-top:16px;max-width:600px}
hr.div{border:none;height:1px;background:linear-gradient(90deg,transparent,var(--bg4),transparent)}

/* NAV — Glassmorphism 2026 */
/* Prevent anchor links from hiding behind fixed nav */
[id]{scroll-margin-top:calc(var(--nav-h) + 16px)}
.nav{position:fixed;top:0;left:0;right:0;z-index:900;height:var(--nav-h);background:transparent;display:flex;align-items:center;transition:all .4s cubic-bezier(.22,1,.36,1);animation:navSlideDown .6s cubic-bezier(.22,1,.36,1) both}
@keyframes navSlideDown{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
.nav.scrolled{background:rgba(255,255,255,.95);box-shadow:0 2px 40px rgba(0,0,0,.08);backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4)}
.nav-inner{width:100%;max-width:1240px;margin:0 auto;padding:0 40px;display:flex;align-items:center;justify-content:space-between;gap:32px}
.nav-logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-logo img{height:44px;width:auto}
.nav-logo-text{display:flex;flex-direction:column}
.nav-logo-name{font-family:'DM Serif Display',serif;font-size:16px;color:#fff;line-height:1.1;letter-spacing:.3px;transition:color .4s}
.nav-logo-tag{font-size:9px;letter-spacing:2px;text-transform:capitalize;color:var(--gold-lt,#f0d060);font-weight:600;transition:color .4s}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none;flex:1;justify-content:center;min-width:0}
.nav-links a{font-size:13px;font-weight:500;color:rgba(255,255,255,.7);padding:8px 16px;border-radius:var(--r-sm);transition:all .25s cubic-bezier(.22,1,.36,1);white-space:nowrap;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:6px;left:50%;transform:translateX(-50%) scaleX(0);width:18px;height:2px;background:var(--gold);border-radius:2px;transition:transform .3s cubic-bezier(.22,1,.36,1)}
.nav-links a:hover,.nav-links a.active{color:#fff;background:rgba(255,255,255,.1)}
.nav-links a:hover::after,.nav-links a.active::after{transform:translateX(-50%) scaleX(1)}
/* CTA link in nav */
.nav-cta-link a{color:var(--gold-lt,#f0d060);font-weight:600}
.nav-cta-link a:hover{background:rgba(255,215,0,.15)}
.nav-sep{width:1px;height:20px;background:var(--bg3);margin:0 4px;flex-shrink:0}
/* Dropdown */
.nav-item{position:relative;list-style:none}
.nav-item .nav-dd-trigger{cursor:pointer;display:flex;align-items:center;gap:5px}
.nav-item .nav-dd-trigger .dd-arrow{font-size:9px;transition:transform .25s ease;display:inline-block;line-height:1}
.nav-item:hover .dd-arrow,.nav-item:focus-within .dd-arrow,.nav-dd-trigger[aria-expanded="true"] .dd-arrow{transform:rotate(180deg)}
.nav-dropdown{position:absolute;top:calc(100% + 6px);left:50%;transform:translateX(-50%) translateY(6px);background:#fff;border:1px solid var(--bg3);border-radius:var(--r-md);padding:6px;min-width:220px;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s,transform .2s;z-index:100;list-style:none}
.nav-item:hover .nav-dropdown,.nav-item:focus-within .nav-dropdown,.nav-item .nav-dd-trigger[aria-expanded="true"]+.nav-dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-dropdown li a{padding:10px 14px;border-radius:var(--r-sm);font-size:13px;font-weight:500;color:var(--muted);transition:all .15s;display:flex;align-items:center;gap:10px}
.nav-dropdown li a:hover,.nav-dropdown li a:focus{color:var(--ink);background:var(--bg2);padding-left:18px;outline:none}
.nav.scrolled .nav-logo-name{color:var(--ink)}
.nav.scrolled .nav-logo-tag{color:var(--gold)}
.nav.scrolled .nav-links a{color:var(--muted)}
.nav.scrolled .nav-links a:hover,.nav.scrolled .nav-links a.active{color:var(--ink);background:rgba(184,146,42,.06)}
.nav.scrolled .nav-links a::after{background:var(--gold)}
.nav.scrolled .nav-phone{color:var(--ink);border-color:var(--bg3)}
.nav.scrolled .nav-phone:hover{border-color:var(--gold-line);color:var(--gold)}
.nav.scrolled .nav-cta{background:linear-gradient(135deg,var(--ink),#2d2822);color:#fff;border-color:var(--ink)}
.nav.scrolled .nav-cta:hover{box-shadow:0 4px 20px rgba(28,25,22,.25)}
.nav.scrolled .hamburger span{background:var(--ink)}
.nav.scrolled .nav-cta-link a{color:var(--gold)}
.nav-dropdown li a .dd-icon{font-size:18px;flex-shrink:0;width:24px;text-align:center}
.nav-dropdown li a .dd-label{display:flex;flex-direction:column;gap:1px}
.nav-dropdown li a .dd-label span{font-size:11px;color:var(--faint);font-weight:400}
@media(prefers-reduced-motion:reduce){.nav-dropdown,.dd-arrow{transition:none}.ticker-inner,.rev-track{animation:none!important}.float-wa,.chat-fab{animation:none!important}}
.nav-actions{display:flex;align-items:center;gap:12px;flex-shrink:0;margin-left:auto}
.nav-phone{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:rgba(255,255,255,.85);padding:7px 14px;border:1.5px solid rgba(255,255,255,.2);border-radius:var(--r-sm);transition:all .3s cubic-bezier(.22,1,.36,1);white-space:nowrap;flex-shrink:0}
.nav-phone:hover{border-color:var(--gold-lt);color:var(--gold-lt);background:rgba(255,215,0,.08)}
.btn-wa{display:inline-flex;align-items:center;gap:6px;background:var(--green);color:#fff;padding:8px 16px;border-radius:var(--r-sm);font-size:12px;font-weight:600;transition:all .25s;border:none;white-space:nowrap;flex-shrink:0}
.btn-wa:hover{background:#17a050;transform:translateY(-1px);box-shadow:0 6px 20px rgba(29,175,92,.3)}
/* Primary CTA in nav */
.nav-cta{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,rgba(255,255,255,.15),rgba(255,255,255,.05));backdrop-filter:blur(8px);color:#fff;padding:9px 20px;border-radius:var(--r-sm);font-size:12px;font-weight:700;letter-spacing:.4px;transition:all .35s cubic-bezier(.22,1,.36,1);border:1px solid rgba(255,255,255,.2);white-space:nowrap;flex-shrink:0;position:relative;overflow:hidden}
.nav-cta::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,215,0,.2),rgba(184,146,42,.1));opacity:0;transition:opacity .35s}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(255,215,0,.2)}
.nav-cta:hover::before{opacity:1}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;border:none;background:none;position:relative;width:34px;height:34px;justify-content:center;align-items:center}
.hamburger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:all .3s ease;position:absolute}
.hamburger span:nth-child(1){top:10px}
.hamburger span:nth-child(2){top:16px}
.hamburger span:nth-child(3){top:22px}
.hamburger.open span:nth-child(1){top:16px;transform:rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){top:16px;transform:rotate(-45deg)}
.mob-menu{position:fixed;top:var(--nav-h);left:0;right:0;z-index:899;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--bg3);padding:16px 20px 24px;flex-direction:column;gap:2px;box-shadow:0 16px 48px rgba(0,0,0,.1);transform:translateY(-12px);opacity:0;visibility:hidden;transition:transform .35s cubic-bezier(.22,1,.36,1),opacity .3s ease,visibility .3s ease;pointer-events:none;max-height:calc(100vh - var(--nav-h));overflow-y:auto}
.mob-menu.open{transform:translateY(0);opacity:1;visibility:visible;pointer-events:all}
.mob-menu a{padding:12px 14px;border-radius:var(--r-sm);font-size:15px;font-weight:500;color:var(--ink);transition:background .15s}
.mob-menu a:hover{background:var(--bg2)}
.mob-menu .mob-sub{padding-left:28px;font-size:14px;color:var(--faint)}
.mob-menu .mob-parent{font-weight:600}
.mob-menu .mob-phone{color:var(--muted);font-size:14px}
.mob-menu .mob-cta-quote{background:var(--ink);color:#fff;text-align:center;font-weight:700;margin-top:4px}
.mob-div{height:1px;background:var(--bg3);margin:8px 0}
.mob-cta{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--green);color:#fff;padding:14px;border-radius:var(--r-sm);font-weight:600;font-size:15px;margin-top:8px}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:var(--ink)}
.hero::before{content:"";position:absolute;inset:0;background:url("images/img_002.webp") center/cover no-repeat;opacity:.5;filter:brightness(.8) contrast(1.1) saturate(1.1)}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(170deg,rgba(28,25,22,.8) 0%,rgba(28,25,22,.5) 50%,rgba(28,25,22,.2) 100%)}
.hero-left{position:relative;z-index:1;display:flex;align-items:center;padding:80px 64px 80px 40px;width:100%}
.hero-left-inner{max-width:640px;margin:0 auto}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,215,0,.12);border:1px solid rgba(255,215,0,.3);padding:8px 18px;border-radius:50px;margin-bottom:28px;backdrop-filter:blur(8px)}
.badge-dot{width:8px;height:8px;border-radius:50%;background:#22C55E;box-shadow:0 0 0 4px rgba(34,197,94,.15);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgba(34,197,94,.15)}50%{box-shadow:0 0 0 8px rgba(34,197,94,.06)}}
.hero-badge span{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold-lt,#f0d060)}
.hero-h1{font-family:'DM Serif Display',serif;font-size:clamp(38px,4.5vw,64px);line-height:1.05;color:#fff;margin-bottom:22px;font-weight:400;letter-spacing:-.02em;text-shadow:0 2px 20px rgba(0,0,0,.3)}
.hero-h1 em{font-style:italic;color:var(--gold-lt,#f0d060);display:inline;text-shadow:0 0 40px rgba(240,208,96,.3)}
.hero-sub{font-size:16px;color:rgba(255,255,255,.8);line-height:1.85;margin-bottom:36px;max-width:520px;text-shadow:0 1px 8px rgba(0,0,0,.2)}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:52px}
.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--gold);color:#fff;padding:14px 30px;border-radius:var(--r-md);font-size:14px;font-weight:600;border:none;transition:all .3s cubic-bezier(.22,1,.36,1);letter-spacing:.3px;cursor:pointer;position:relative;overflow:hidden}
.btn-primary::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(184,146,42,.2),transparent);opacity:0;transition:opacity .3s}
.btn-primary:hover{background:#9a7a22;transform:translateY(-2px);box-shadow:0 10px 30px rgba(184,146,42,.4)}
.btn-primary:hover::after{opacity:1}
.btn-outline{display:inline-flex;align-items:center;gap:8px;background:transparent;color:#fff;padding:13px 26px;border-radius:var(--r-md);font-size:14px;font-weight:500;border:1.5px solid rgba(255,255,255,.3);transition:all .3s cubic-bezier(.22,1,.36,1);cursor:pointer}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-bg);transform:translateY(-1px)}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid rgba(255,255,255,.15);border-radius:var(--r-md);overflow:hidden;background:rgba(0,0,0,.2);backdrop-filter:blur(8px)}
.hstat{padding:16px 12px;text-align:center;border-right:1px solid rgba(255,255,255,.12)}
.hstat:last-child{border-right:none}
.hstat-n{font-family:'DM Serif Display',serif;font-size:26px;color:#fff;line-height:1}
.hstat-l{font-size:10px;color:rgba(255,255,255,.6);margin-top:4px}
.hero-right{display:none}
.hero-right-img{width:100%;height:100%;object-fit:cover;display:block}
.hero-right-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(250,249,247,.15),transparent 40%)}
.hero-float{position:absolute;top:28px;right:28px;background:rgba(255,255,255,.12);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.25);border-radius:50px;padding:10px 18px;display:flex;align-items:center;gap:8px}
.hero-float span{font-size:13px;font-weight:700;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.4)}

/* TICKER */
.ticker{background:var(--ink);padding:13px 0;overflow:hidden;white-space:nowrap;border-top:1px solid rgba(255,255,255,.06)}
.ticker-inner{display:inline-flex;animation:ticker 32s linear infinite}
.ticker-item{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:capitalize;color:rgba(255,255,255,.55);padding:0 28px;display:inline-flex;align-items:center;gap:16px}
.ticker-dot{font-size:5px;color:var(--gold)}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* TRUST */
.trust{background:var(--bg2);padding:13px 0;border-bottom:1px solid var(--bg3);text-align:center}
.trust-inner{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:capitalize;color:var(--muted)}
.trust-inner span{color:var(--gold)}

/* RIBBON — Auto-scroll portfolio strip */
.ribbon-strip{overflow:hidden;background:var(--ink);padding:0;position:relative}
.ribbon-strip::before,.ribbon-strip::after{content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.ribbon-strip::before{left:0;background:linear-gradient(to right,var(--ink),transparent)}
.ribbon-strip::after{right:0;background:linear-gradient(to left,var(--ink),transparent)}
.ribbon-track{display:flex;gap:6px;animation:ribbonScroll 45s linear infinite;width:max-content}
.ribbon-track:hover{animation-play-state:paused}
.ribbon-img{flex-shrink:0;width:280px;height:180px;border-radius:8px;overflow:hidden;position:relative}
.ribbon-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.35),transparent 60%);transition:opacity .3s}
.ribbon-img:hover::after{opacity:0}
.ribbon-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.22,1,.36,1);animation:kenBurnsRibbon 20s ease-in-out infinite alternate}
.ribbon-img:hover img{transform:scale(1.08);animation:none}
@keyframes kenBurnsRibbon{0%{transform:scale(1)}100%{transform:scale(1.06)}}
@keyframes ribbonScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* MOTTO */
.motto{background:var(--ink);padding:88px 0;text-align:center;position:relative;overflow:hidden}
.motto-temple{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;opacity:.28;filter:brightness(.7) saturate(1.2);transform:scale(1.05);transition:transform .1s linear}
@media(prefers-reduced-motion:reduce){.motto-temple{transition:none}}
.motto-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(28,25,22,.55) 0%,rgba(28,25,22,.3) 40%,rgba(28,25,22,.7) 100%);z-index:1}
.motto-gold-line{position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,rgba(184,146,42,.4),transparent);z-index:2}
.motto::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(184,146,42,.05) 1px,transparent 1px);background-size:28px 28px}
.motto-content{position:relative;z-index:3;max-width:760px;margin:0 auto}
.motto-q{font-family:'DM Serif Display',serif;font-size:100px;line-height:.55;color:rgba(184,146,42,.1);user-select:none;margin-bottom:18px}
.motto h2{font-family:'DM Serif Display',serif;font-size:clamp(20px,3vw,34px);font-weight:400;color:#fff;line-height:1.5;margin-bottom:28px}
.motto h2 em{font-style:italic;color:var(--gold-lt)}
.motto-sub{font-size:15px;color:rgba(255,255,255,.4);line-height:1.9;max-width:580px;margin:0 auto 44px}
.motto-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(184,146,42,.12);border-radius:var(--r-md);overflow:hidden;max-width:800px;margin:0 auto}
.mpillar{padding:28px 24px;background:rgba(255,255,255,.02)}
.mpillar:nth-child(2){background:rgba(184,146,42,.04);border-left:1px solid rgba(184,146,42,.12);border-right:1px solid rgba(184,146,42,.12)}
.mpillar-icon{font-size:28px;margin-bottom:12px}
.mpillar h4{font-size:14px;font-weight:700;color:#fff;margin-bottom:8px}
.mpillar p{font-size:12px;color:rgba(255,255,255,.35);line-height:1.8}

/* SERVICES — Modern Horizontal Cards */
.services{background:#faf9f6;padding-bottom:60px}
.svc-head{text-align:center;margin-bottom:48px}
/* SERVICE TABS — pill style */
.svc-tabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:44px}
.svc-tab{padding:10px 22px;border-radius:50px;font-size:12px;font-weight:600;letter-spacing:.5px;border:1.5px solid var(--bg4);background:#fff;color:var(--muted);transition:all .25s cubic-bezier(.22,1,.36,1);cursor:pointer}
.svc-tab:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-1px)}
.svc-tab.active{background:linear-gradient(135deg,var(--gold),var(--gold-lt));color:#fff;border-color:transparent;box-shadow:0 4px 16px rgba(184,146,42,.3)}

/* 3×3 GRID */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

/* SERVICE CARDS — 2026 Vertical with depth */
.svc-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;border-radius:var(--r-lg);background:#fff;padding:28px 18px 24px;transition:all .4s cubic-bezier(.22,1,.36,1);border:1px solid rgba(0,0,0,.04);position:relative;overflow:hidden;box-shadow:var(--shadow-xs)}
.svc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-lt));opacity:0;transition:opacity .3s}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.svc-card:hover::before{opacity:1}
.svc-card.hidden{display:none}

/* ICON — larger with gradient bg */
.svc-icon-box{width:64px;height:64px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;transition:transform .3s cubic-bezier(.22,1,.36,1)}
.svc-card:hover .svc-icon-box{transform:scale(1.08)}
.svc-icon-box svg{width:28px;height:28px}

/* NUMBER — tiny badge inside icon */
.svc-num{position:absolute;top:-4px;left:-4px;font-size:8px;font-weight:800;color:#fff;background:var(--gold);width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;line-height:1;z-index:2;box-shadow:0 2px 4px rgba(0,0,0,.15)}

/* CONTENT — stacked text */
.svc-info{flex:1;min-width:0;text-align:center}
.svc-name{font-family:'DM Serif Display',serif;font-size:15px;color:var(--ink);margin-bottom:5px;line-height:1.35}
.svc-desc{font-size:11.5px;color:#9a9488;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* PRICE ROW */
.svc-price-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.svc-price{font-size:13px;color:var(--ink);font-weight:800;letter-spacing:-.3px}
.svc-price sup{font-size:8px;color:#8a8278;font-weight:500}
.svc-price-unit{font-size:9px;color:#aaa49a;font-weight:500}

/* CTA — small pill */
.svc-enq{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border-radius:8px;font-size:10px;font-weight:700;transition:all .2s;white-space:nowrap;text-decoration:none;background:var(--gold);color:#fff;border:none;cursor:pointer}
.svc-enq:hover{background:#c9a530;transform:translateY(-1px);box-shadow:0 3px 10px rgba(184,146,42,.3)}

/* OVERLAY — unused */
.svc-card .svc-overlay{display:none}

/* VIEW ALL */
.svc-view-toggle{text-align:center;margin-top:28px}
.svc-view-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 28px;border-radius:50px;font-size:13px;font-weight:700;letter-spacing:.3px;border:2px solid var(--gold);background:transparent;color:var(--gold);cursor:pointer;transition:all .25s}
.svc-view-btn:hover{background:var(--gold);color:#fff}
.svc-view-btn .arrow{transition:transform .3s;font-size:14px}
.svc-view-btn.expanded .arrow{transform:rotate(180deg)}

/* CTA ROW */
.svc-cta-row{margin-top:44px;padding:36px 40px;background:var(--ink);border-radius:16px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.svc-cta-row h3{font-family:'DM Serif Display',serif;font-size:22px;color:#fff;margin-bottom:6px}
.svc-cta-row h3 em{color:var(--gold-lt)}
.svc-cta-row p{font-size:13px;color:rgba(255,255,255,.45);line-height:1.75;max-width:500px}

/* ABOUT */
.about{background:var(--bg)}
.about-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-visual{position:relative}
.about-card{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/5;background:linear-gradient(160deg,#2C1A0A,#5A3820,#8A6040,#BF9A70);box-shadow:var(--shadow-lg)}
.about-card-img{width:100%;height:100%;object-fit:cover}
.about-float{position:absolute;bottom:-24px;right:-24px;background:var(--gold);border-radius:var(--r-md);padding:24px 28px;text-align:center;box-shadow:0 16px 48px rgba(184,146,42,.4)}
.about-float-n{font-family:'DM Serif Display',serif;font-size:40px;color:#fff;line-height:1}
.about-float-l{font-size:11px;font-weight:700;letter-spacing:.5px;color:rgba(255,255,255,.85);text-transform:capitalize;margin-top:4px}
.about-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.atag{padding:6px 14px;border-radius:50px;background:#fff;border:1px solid var(--bg3);font-size:11px;font-weight:600;color:var(--muted);transition:all .2s}
.atag:hover{border-color:var(--gold-line);color:var(--gold)}
.about-feats{margin-top:32px;display:flex;flex-direction:column;gap:14px}
.afeat{display:flex;align-items:flex-start;gap:16px;padding:18px 20px;background:#fff;border:1px solid var(--bg3);border-radius:var(--r-md);transition:all .25s;border-left:3px solid var(--gold)}
.afeat:hover{transform:translateX(4px);box-shadow:var(--shadow-md)}
.afeat-icon{font-size:20px;flex-shrink:0;margin-top:1px}
.afeat h4{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:3px}
.afeat p{font-size:12px;color:var(--muted);line-height:1.7}

/* WHY */
.why{background:var(--white);text-align:center}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:52px;text-align:left}
.why-card{background:var(--bg);border:1px solid var(--bg3);border-radius:var(--r-md);padding:22px 18px;transition:all .3s}
.why-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--gold-line)}
.why-icon{width:44px;height:44px;border-radius:var(--r-sm);background:var(--gold-bg);border:1px solid var(--gold-line);display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:14px}
.why-card h4{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:6px}
.why-card p{font-size:11px;color:var(--muted);line-height:1.75}

/* CALCULATOR */
.calculator{background:var(--bg2)}
.calc-layout{display:grid;grid-template-columns:1fr 360px;gap:28px;align-items:start;margin-top:52px}
.calc-panel{background:#fff;border:1px solid var(--bg3);border-radius:var(--r-lg);overflow:hidden}
.calc-panel-head{padding:20px 24px;background:var(--bg);border-bottom:1px solid var(--bg3);display:flex;flex-wrap:wrap;gap:6px}
.cc-btn{padding:6px 14px;border-radius:50px;font-size:11px;font-weight:600;border:1.5px solid var(--bg3);background:#fff;color:var(--muted);cursor:pointer;transition:all .2s}
.cc-btn:hover{border-color:var(--gold-line);color:var(--gold)}
.cc-btn.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.calc-rows{padding:12px;display:flex;flex-direction:column;gap:6px}
.calc-row{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--r-sm);border:1.5px solid transparent;background:var(--bg);transition:all .2s}
.calc-row:hover{border-color:var(--gold-line);background:var(--gold-bg)}
.calc-row.active{border-color:var(--gold);background:var(--gold-bg)}
.cr-info{flex:1;min-width:0}
.cr-name{font-size:13px;font-weight:600;color:var(--ink)}
.cr-desc{font-size:11px;color:var(--faint);margin-top:2px}
.cr-price{font-size:11px;color:var(--gold);font-weight:600;margin-top:3px}
.cr-controls{display:flex;align-items:center;gap:8px;flex-shrink:0}
.cr-qty{width:80px;padding:7px 10px;font-size:13px;border:1.5px solid var(--bg3);border-radius:var(--r-sm);background:#fff;color:var(--ink);text-align:center;transition:border-color .2s}
.cr-qty:focus{outline:none;border-color:var(--gold)}
.cr-unit{font-size:10px;color:var(--faint)}
.cr-btn{width:32px;height:32px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;border:none;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;flex-shrink:0}
.cr-btn.add{background:var(--ink);color:#fff}
.cr-btn.add:hover{background:var(--ink2);transform:scale(1.08)}
.cr-btn.rem{background:#fee2e2;color:var(--red)}
.cr-btn.rem:hover{background:var(--red);color:#fff}
.est-panel{position:sticky;top:calc(var(--nav-h) + 16px);background:#fff;border:1px solid var(--bg3);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md)}
.est-top{background:var(--ink);padding:24px 22px}
.est-lbl{font-size:10px;letter-spacing:2px;text-transform:capitalize;color:rgba(255,255,255,.45);margin-bottom:8px}
.est-num{font-family:'DM Serif Display',serif;font-size:42px;color:#fff;line-height:1}
.est-sub{font-size:11px;color:rgba(255,255,255,.35);margin-top:6px}
.est-body{padding:20px}
.est-list{max-height:220px;overflow-y:auto;margin-bottom:14px}
.est-item{display:flex;justify-content:space-between;align-items:flex-start;padding:8px 0;border-bottom:1px solid var(--bg3)}
.est-item:last-child{border-bottom:none}
.ei-name{font-size:12px;color:var(--ink)}
.ei-qty{font-size:10px;color:var(--faint);margin-top:2px}
.ei-amt{font-size:12px;color:var(--gold);font-weight:700;margin-left:8px;white-space:nowrap}
.est-empty{text-align:center;padding:28px 16px;font-size:13px;color:var(--faint);font-style:italic}
.est-sep{border:none;border-top:1px solid var(--bg3);margin:12px 0}
.est-total{display:flex;justify-content:space-between;font-size:15px;font-weight:700;margin-bottom:4px}
.est-total span:last-child{color:var(--gold)}
.est-note{font-size:10px;color:var(--faint);margin-bottom:18px}
.btn-generate{width:100%;padding:13px;margin-bottom:8px;background:var(--gold);color:#fff;border:none;border-radius:var(--r-sm);font-size:13px;font-weight:700;cursor:pointer;letter-spacing:.5px;transition:all .25s}
.btn-generate:hover{background:var(--gold-lt);transform:translateY(-1px);box-shadow:0 6px 20px rgba(184,146,42,.3)}
.btn-clear{width:100%;padding:10px;background:transparent;border:1.5px solid var(--bg3);border-radius:var(--r-sm);font-size:12px;color:var(--muted);cursor:pointer;transition:all .2s}
.btn-clear:hover{border-color:#fca5a5;color:var(--red)}

/* PROCESS */
.process{background:var(--white)}
.process-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:60px;position:relative}
.process-steps::before{content:'';position:absolute;top:36px;left:10%;right:10%;height:1px;background:var(--bg3)}
.pstep{padding:0 16px;text-align:center}
.pstep-num{width:72px;height:72px;border-radius:50%;background:#fff;border:2px solid var(--bg3);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:20px;position:relative;z-index:1;transition:all .3s}
.pstep:hover .pstep-num{border-color:var(--gold);background:var(--gold-bg);box-shadow:0 0 0 6px rgba(184,146,42,.1)}
.pstep h4{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:6px}
.pstep p{font-size:12px;color:var(--muted);line-height:1.7}

/* PORTFOLIO */
.portfolio{background:var(--bg)}
.pf-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:40px;gap:20px;flex-wrap:wrap}
.pf-filters{display:flex;gap:8px;flex-wrap:wrap}
.pf-btn{padding:7px 18px;border-radius:50px;font-size:12px;font-weight:600;border:1.5px solid var(--bg3);background:#fff;color:var(--muted);cursor:pointer;transition:all .2s}
.pf-btn:hover{border-color:var(--gold-line);color:var(--gold)}
.pf-btn.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.pf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pf-item{border-radius:var(--r-md);overflow:hidden;position:relative;cursor:pointer;transition:transform .3s}
.pf-item:hover{transform:scale(1.02)}
.pf-item.tall{grid-row:span 2}
.pf-thumb{position:relative;overflow:hidden}
.pf-thumb-inner{width:100%;height:240px;transition:transform .5s}
.pf-item.tall .pf-thumb-inner{height:100%;min-height:496px}
.pf-item:hover .pf-thumb-inner{transform:scale(1.06)}
.pf-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(28,25,22,.8),transparent 50%)}
.pf-info{position:absolute;bottom:0;left:0;right:0;padding:20px;z-index:2}
.pf-cat{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:capitalize;color:var(--gold-lt);margin-bottom:5px}
.pf-title{font-family:'DM Serif Display',serif;font-size:17px;color:#fff;line-height:1.25}
.pf-loc{font-size:11px;color:rgba(255,255,255,.45);margin-top:4px}
.pf-bg-1{background:linear-gradient(145deg,#3D1F08,#7A4020,#B47040)}
.pf-bg-2{background:linear-gradient(145deg,#12152A,#1E2B5C,#304080)}
.pf-bg-3{background:linear-gradient(145deg,#0D1B2A,#1B3A5C,#2E6090)}
.pf-bg-4{background:linear-gradient(145deg,#1A0E0A,#3C2215,#6A4028)}
.pf-bg-5{background:linear-gradient(145deg,#0A100A,#1A2E1A,#2E4A2E)}
.pf-bg-img{background-size:cover;background-position:center;background-repeat:no-repeat}

/* UPLOAD */
.upload{background:var(--ink);padding:96px 0}
.upload-head{text-align:center;margin-bottom:48px}
.upload-head .sec-label{color:var(--gold-lt)}
.upload-head .h{color:#fff}
.upload-head .sub{color:rgba(255,255,255,.4);max-width:520px;margin-left:auto;margin-right:auto}
.drop-zone{border:2px dashed rgba(184,146,42,.35);border-radius:var(--r-lg);padding:52px 32px;text-align:center;cursor:pointer;transition:all .3s;background:rgba(184,146,42,.04);position:relative;max-width:580px;margin:0 auto 52px}
.drop-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.drop-zone:hover,.drop-zone.dragging{border-color:var(--gold);background:rgba(184,146,42,.09)}
.drop-icon{width:68px;height:68px;border-radius:50%;background:rgba(184,146,42,.1);border:1px solid rgba(184,146,42,.2);display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 20px}
.drop-zone h4{font-family:'DM Serif Display',serif;font-size:21px;color:#fff;margin-bottom:8px}
.drop-zone p{font-size:13px;color:rgba(255,255,255,.35);line-height:1.75}
.upload-bar{display:none;margin-top:20px}
.upload-bar.show{display:block}
.prog-track{height:2px;background:rgba(255,255,255,.1);border-radius:1px}
.prog-fill{height:100%;background:var(--gold);border-radius:1px;width:0;transition:width .35s}
.prog-label{font-size:11px;color:rgba(184,146,42,.7);letter-spacing:.5px;margin-top:10px;text-align:center}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.gal-item{aspect-ratio:1;border-radius:var(--r-md);overflow:hidden;position:relative;cursor:pointer;border:1px solid rgba(255,255,255,.06);transition:all .3s;background:rgba(255,255,255,.04)}
.gal-item:hover{transform:scale(1.04);border-color:rgba(184,146,42,.4);box-shadow:0 8px 32px rgba(0,0,0,.4)}
.gal-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.gal-item:hover img{transform:scale(1.08)}
.gal-del{position:absolute;top:8px;right:8px;z-index:2;width:26px;height:26px;border-radius:50%;background:rgba(229,62,62,.9);border:none;color:#fff;font-size:11px;cursor:pointer;opacity:0;display:flex;align-items:center;justify-content:center;transition:opacity .2s;backdrop-filter:blur(4px)}
.gal-item:hover .gal-del{opacity:1}
.gal-add{aspect-ratio:1;border-radius:var(--r-md);border:2px dashed rgba(184,146,42,.2);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;background:rgba(184,146,42,.02);position:relative}
.gal-add:hover{border-color:var(--gold);background:rgba(184,146,42,.06)}
.gal-add input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.gal-add-icon{font-size:26px;color:rgba(184,146,42,.4);line-height:1;margin-bottom:8px}
.gal-add-txt{font-size:10px;letter-spacing:1px;color:rgba(255,255,255,.2);text-transform:capitalize}
.gal-empty{grid-column:1/-1;text-align:center;padding:48px 20px}
.gal-empty p{font-family:'DM Serif Display',serif;font-size:18px;color:rgba(255,255,255,.15);font-style:italic}

/* REVIEWS */
.reviews{background:linear-gradient(180deg,var(--white) 0%,#fdfcfa 100%);position:relative}
.reviews{overflow:hidden}
.reviews>.container{max-width:1440px;padding:0 32px;position:relative}
/* ═══ Review Carousel ═══ */
.rev-carousel-wrap{margin-top:52px;position:relative}
.rev-carousel{overflow:hidden;position:relative}
.rev-page{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;opacity:0;transform:translateX(60px);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1);position:absolute;top:0;left:0;right:0;pointer-events:none}
.rev-page.active{opacity:1;transform:translateX(0);position:relative;pointer-events:auto}
.rev-page.exit-left{opacity:0;transform:translateX(-60px)}
@media(max-width:1024px){.rev-page{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.rev-page{grid-template-columns:1fr;gap:16px}}

/* Carousel Nav */
.rev-nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:36px}
.rev-nav-btn{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--gold-line);background:var(--white);color:var(--gold);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.22,1,.36,1)}
.rev-nav-btn:hover{background:var(--gold);color:#fff;border-color:var(--gold);transform:scale(1.08);box-shadow:0 4px 20px rgba(184,153,54,.25)}
.rev-dots{display:flex;gap:8px;align-items:center}
.rev-dot{width:10px;height:10px;border-radius:50%;background:var(--gold-line);cursor:pointer;transition:all .4s cubic-bezier(.22,1,.36,1)}
.rev-dot.active{background:var(--gold);width:28px;border-radius:5px;box-shadow:0 2px 8px rgba(184,153,54,.3)}

/* View All Button */
.rev-all-btn-wrap{text-align:center;margin-top:28px}
.rev-all-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 32px;border:1.5px solid var(--gold-line);background:transparent;color:var(--gold);font-size:14px;font-weight:600;border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.22,1,.36,1);letter-spacing:.3px}
.rev-all-btn:hover{background:var(--gold);color:#fff;border-color:var(--gold);transform:translateY(-2px);box-shadow:0 8px 24px rgba(184,153,54,.2)}
.rev-all-btn svg{transition:transform .3s}
.rev-all-btn.expanded svg{transform:rotate(45deg)}

/* All Reviews Grid */
.rev-all-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px;animation:fadeUp .5s ease both}
@media(max-width:1024px){.rev-all-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.rev-all-grid{grid-template-columns:1fr}}
.rev-card{background:var(--white);border:1px solid rgba(0,0,0,.05);border-radius:var(--r-md);padding:28px 26px 22px;transition:all .4s cubic-bezier(.22,1,.36,1);position:relative;overflow:hidden}
.rev-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-lt),var(--gold));opacity:0;transition:opacity .4s}
.rev-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px rgba(0,0,0,.08);border-color:var(--gold-line)}
.rev-card:hover::before{opacity:1}

/* Reveal animation for carousel cards */
.reveal-card{opacity:0;transform:translateY(30px);animation:cardRevealIn .7s cubic-bezier(.22,1,.36,1) both;animation-delay:calc(var(--d,0) * .12s)}
@keyframes cardRevealIn{from{opacity:0;transform:translateY(30px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}

/* Star fill animation */
.star-fill{background:linear-gradient(90deg,var(--gold) var(--star-pct,0%),#e0d5c0 var(--star-pct,0%));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:transparent;animation:starFill 1s cubic-bezier(.22,1,.36,1) .4s both}
@keyframes starFill{from{--star-pct:0%}to{--star-pct:100%}}
/* Fallback for browsers without @property */
.star-fill{animation:starFadeIn .8s ease .3s both}
@keyframes starFadeIn{from{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}
@keyframes revReveal{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
/* scrollReviews removed — reviews now use CSS grid */
.rev-q{font-family:'DM Serif Display',serif;font-size:48px;color:var(--gold);opacity:.3;line-height:.6;margin-bottom:14px;transition:opacity .3s}
.rev-card:hover .rev-q{opacity:.5}
.rev-text{font-size:14.5px;color:rgba(28,25,22,.68);line-height:1.8;margin-bottom:18px;font-style:italic}
.rev-stars{color:#F59E0B;font-size:13px;letter-spacing:3px;margin-bottom:14px}
.rev-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:0}
.rev-author{display:flex;align-items:center;gap:12px}
.rev-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;color:#16a34a;background:rgba(22,163,74,.08);padding:3px 8px;border-radius:20px;letter-spacing:.3px;text-transform:uppercase}
.rev-badge svg{width:12px;height:12px;flex-shrink:0}
.rev-date{font-size:11px;color:var(--faint);white-space:nowrap}
/* Stagger delays for review cards */
.rev-card:nth-child(3n+1).visible{animation-delay:0s}
.rev-card:nth-child(3n+2).visible{animation-delay:.1s}
.rev-card:nth-child(3n+3).visible{animation-delay:.2s}
/* Google trust bar */
.rev-trust-bar{display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap;margin:28px auto 0;max-width:600px;padding:16px 24px;background:linear-gradient(135deg,rgba(248,249,250,.95),rgba(255,255,255,.95));border:1px solid rgba(0,0,0,.06);border-radius:var(--r-md)}
.rev-trust-bar .trust-google{display:flex;align-items:center;gap:8px}
.rev-trust-bar .trust-google svg{width:20px;height:20px}
.rev-trust-bar .trust-rating{display:flex;align-items:center;gap:6px}
.rev-trust-bar .trust-rating .stars{color:#F59E0B;font-size:14px;letter-spacing:2px}
.rev-trust-bar .trust-rating .score{font-size:15px;font-weight:700;color:var(--ink)}
.rev-trust-bar .trust-rating .count{font-size:12px;color:var(--muted)}
.rev-trust-bar .trust-divider{width:1px;height:28px;background:var(--bg3)}
.rev-trust-bar .trust-stat{text-align:center}
.rev-trust-bar .trust-stat .num{font-size:15px;font-weight:700;color:var(--ink)}
.rev-trust-bar .trust-stat .label{font-size:11px;color:var(--muted);display:block}

.rev-img-wrap{width:100%;margin-bottom:14px;border-radius:8px;overflow:hidden;max-height:180px}
.rev-img-wrap img{width:100%;height:180px;object-fit:cover;display:block}

.rev-av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-lt));display:flex;align-items:center;justify-content:center;font-family:'DM Serif Display',serif;font-size:18px;color:#fff;flex-shrink:0}
.rev-name{font-size:14px;font-weight:600;color:var(--ink)}
.rev-loc{font-size:11px;color:var(--faint);margin-top:2px}

/* REVIEW SCROLL - handled by rev-track animation */

/* FAQ */
.faq{background:var(--bg2)}
.faq-list{max-width:820px;margin:52px auto 0;display:flex;flex-direction:column;gap:10px}
.faq-item{background:#fff;border:1px solid var(--bg3);border-radius:var(--r-md);overflow:hidden;transition:border-color .2s}
.faq-item.open{border-color:var(--gold-line)}
.faq-q{padding:18px 22px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;gap:16px;user-select:none}
.faq-q-text{font-size:15px;font-weight:600;color:var(--ink);flex:1;line-height:1.4}
.faq-icon{width:28px;height:28px;border-radius:50%;flex-shrink:0;background:var(--bg2);border:1px solid var(--bg3);display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:16px;font-weight:700;transition:all .3s}
.faq-item.open .faq-icon{background:var(--gold);color:#fff;border-color:var(--gold);transform:rotate(45deg)}
.faq-ans{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-item.open .faq-ans{max-height:250px}
.faq-ans p{padding:0 22px 20px;font-size:14px;color:var(--muted);line-height:1.85}

/* CTA */
.cta-band{background:var(--ink);padding:88px 0;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(184,146,42,.06) 1px,transparent 1px);background-size:32px 32px}
.cta-band-inner{position:relative;z-index:1}
.cta-band h2{font-family:'DM Serif Display',serif;font-size:clamp(26px,4vw,50px);font-weight:400;color:#fff;margin-bottom:16px}
.cta-band h2 em{font-style:italic;color:var(--gold-lt)}
.cta-band p{font-size:16px;color:rgba(255,255,255,.4);line-height:1.85;max-width:540px;margin:0 auto 40px}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-cta-wa{display:inline-flex;align-items:center;gap:10px;padding:15px 36px;background:var(--green);color:#fff;border-radius:var(--r-sm);border:none;font-size:14px;font-weight:700;cursor:pointer;transition:all .3s}
.btn-cta-wa:hover{background:#17a050;transform:translateY(-2px);box-shadow:0 12px 36px rgba(29,175,92,.3)}
.btn-cta-call{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;border:1.5px solid rgba(255,255,255,.2);color:rgba(255,255,255,.8);border-radius:var(--r-sm);font-size:14px;font-weight:500;cursor:pointer;transition:all .3s;background:transparent}
.btn-cta-call:hover{border-color:rgba(184,146,42,.5);color:var(--gold-lt)}

/* MAP & AREAS */
.map-sec{padding:0}
.map-sec iframe{width:100%;height:380px;border:none;display:block;filter:saturate(.7) brightness(.95)}
.areas{background:var(--bg2);padding:56px 0;text-align:center}
.areas h3{font-family:'DM Serif Display',serif;font-size:26px;color:var(--ink);margin-bottom:6px}
.areas h3 em{font-style:italic;color:var(--gold)}
.areas p{font-size:13px;color:var(--muted);margin-bottom:28px}
.area-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;max-width:900px;margin:0 auto}
.area-tag{padding:6px 16px;border-radius:50px;background:#fff;border:1px solid var(--bg3);font-size:12px;color:var(--muted);transition:all .2s}
.area-tag:hover{border-color:var(--gold-line);color:var(--gold)}

/* FOOTER */
footer{background:var(--ink);padding:64px 0 32px;border-top:1px solid rgba(255,255,255,.06)}
.f-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:52px;margin-bottom:52px}
.f-logo{height:44px;width:auto;margin-bottom:14px}
.f-tag{font-size:11px;letter-spacing:1.5px;text-transform:capitalize;color:rgba(184,146,42,.55);margin-bottom:14px}
.f-about{font-size:13px;color:rgba(255,255,255,.3);line-height:1.85;max-width:280px;margin-bottom:22px}
.f-contacts{display:flex;flex-direction:column;gap:10px}
.f-contact{display:flex;align-items:center;gap:9px;font-size:13px;color:rgba(255,255,255,.4);transition:color .2s}
.f-contact:hover{color:var(--gold-lt)}
.f-cicon{color:var(--gold);font-size:15px}
.f-wa{display:inline-flex;align-items:center;gap:7px;background:var(--green);color:#fff;padding:9px 16px;border-radius:var(--r-sm);font-size:12px;font-weight:700;margin-top:14px;transition:background .2s}
.f-wa:hover{background:#17a050}
.f-col h5{font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:capitalize;color:rgba(184,146,42,.5);margin-bottom:20px}
.f-links{list-style:none;display:flex;flex-direction:column;gap:12px}
.f-links a{font-size:13px;color:rgba(255,255,255,.3);display:flex;align-items:center;gap:7px;transition:color .2s}
.f-links a::before{content:'›';color:var(--gold)}
.f-links a:hover{color:rgba(255,255,255,.7)}
.f-bot{border-top:1px solid rgba(255,255,255,.06);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.f-bot p,.f-credit{font-size:12px;color:rgba(255,255,255,.2)}
.f-credit a{color:var(--gold-lt);font-weight:600}

/* FLOATS — 2026 pill buttons */
.float-wa{position:fixed;bottom:32px;right:32px;z-index:800;width:58px;height:58px;border-radius:var(--r-lg);background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px rgba(29,175,92,.45);animation:waPulse 3s infinite;transition:all .3s cubic-bezier(.22,1,.36,1)}
.float-wa:hover{transform:scale(1.1) translateY(-2px);box-shadow:0 12px 40px rgba(29,175,92,.55)}
@keyframes waPulse{0%,100%{box-shadow:0 8px 32px rgba(29,175,92,.45)}50%{box-shadow:0 8px 48px rgba(29,175,92,.65),0 0 0 12px rgba(29,175,92,.06)}}
.float-call{position:fixed;bottom:100px;right:32px;z-index:800;width:50px;height:50px;border-radius:var(--r-lg);background:var(--gold);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(184,146,42,.4);transition:all .3s cubic-bezier(.22,1,.36,1)}
.float-call:hover{transform:scale(1.1) translateY(-2px);box-shadow:0 10px 32px rgba(184,146,42,.5)}

/* CHAT FAB — 2026 */
.chat-fab{position:fixed;bottom:32px;left:32px;z-index:800;width:58px;height:58px;border-radius:var(--r-lg);background:var(--gold);color:#fff;border:none;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px rgba(184,146,42,.45);cursor:pointer;font-size:22px;animation:goldPulse 3s infinite;transition:all .3s cubic-bezier(.22,1,.36,1)}
.chat-fab:hover{transform:scale(1.1) translateY(-2px)}
@keyframes goldPulse{0%,100%{box-shadow:0 8px 32px rgba(184,146,42,.45)}50%{box-shadow:0 8px 48px rgba(184,146,42,.6),0 0 0 12px rgba(184,146,42,.06)}}
.chat-box{position:fixed;bottom:100px;left:28px;z-index:801;width:320px;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid rgba(184,146,42,.15);transform:translateY(16px) scale(.97);opacity:0;pointer-events:none;transition:all .3s}
.chat-box.open{transform:translateY(0) scale(1);opacity:1;pointer-events:all}
.chat-head{background:var(--gold);padding:16px 18px;display:flex;align-items:center;gap:12px;position:relative}
.chat-av{width:40px;height:40px;border-radius:50%;background:rgba(0,0,0,.2);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.chat-head h4{font-size:15px;font-weight:700;color:#fff}
.chat-online{display:flex;align-items:center;gap:5px;font-size:10px;color:rgba(255,255,255,.7);margin-top:2px}
.chat-online::before{content:'';width:7px;height:7px;border-radius:50%;background:#fff;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.chat-close-btn{position:absolute;top:12px;right:12px;width:28px;height:28px;border-radius:50%;background:rgba(0,0,0,.2);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px}
.chat-body{background:#fff;padding:18px}
.chat-bubble{background:var(--bg2);border-radius:10px 10px 10px 4px;padding:12px 14px;margin-bottom:14px;font-size:13px;color:var(--ink);line-height:1.7}
.chat-quick{display:flex;flex-direction:column;gap:8px}
.chat-q{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border:1px solid var(--bg3);border-radius:var(--r-sm);font-size:13px;color:var(--ink);cursor:pointer;transition:all .2s;background:var(--bg)}
.chat-q:hover{border-color:var(--gold-line);color:var(--gold);background:var(--gold-bg)}
.chat-q-arr{color:var(--gold)}
.chat-foot{background:#fff;padding:8px 18px 14px;border-top:1px solid var(--bg3);font-size:10px;color:var(--faint);text-align:center}

/* MODAL */
.modal-bg{display:none;position:fixed;inset:0;z-index:1000;background:rgba(28,25,22,.86);backdrop-filter:blur(8px);align-items:center;justify-content:center;padding:16px}
.modal-bg.open{display:flex}
.modal{background:#fff;border-radius:var(--r-lg);width:100%;max-width:700px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
.modal-head{padding:22px 28px;border-bottom:1px solid var(--bg3);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:#fff;z-index:1}
.modal-head h3{font-family:'DM Serif Display',serif;font-size:22px;color:var(--ink)}
.modal-close{width:34px;height:34px;border-radius:50%;background:var(--bg2);border:1px solid var(--bg3);color:var(--muted);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.modal-close:hover{background:#fee2e2;border-color:#fca5a5;color:var(--red)}
.modal-body{padding:28px}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.f-group{margin-bottom:14px}
.f-group label{display:block;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:capitalize;color:var(--gold);margin-bottom:7px}
.f-group input,.f-group select{width:100%;padding:11px 14px;border:1.5px solid var(--bg3);border-radius:var(--r-sm);font-size:14px;color:var(--ink);background:#fff;transition:border-color .2s}
.f-group input:focus,.f-group select:focus{outline:none;border-color:var(--gold)}
.btn-gen{width:100%;padding:14px;background:var(--gold);color:#fff;border:none;border-radius:var(--r-sm);font-size:14px;font-weight:700;cursor:pointer;margin-top:6px;transition:all .25s;letter-spacing:.3px}
.btn-gen:hover{background:var(--gold-lt);transform:translateY(-1px)}
.q-preview{display:none;margin-top:20px}
.q-preview.show{display:block}
.qp-watermark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-35deg);font-size:48px;font-weight:900;letter-spacing:8px;color:rgba(184,146,42,.06);text-transform:capitalize;white-space:nowrap;pointer-events:none;z-index:0;user-select:none}
.qp-paper{position:relative}
.qp-paper > *{position:relative;z-index:1}
.qp-cta-box{background:linear-gradient(135deg,#FBF5E8,#F4F2EE);border:2px solid var(--gold-line);border-radius:var(--r-md);padding:20px 24px;margin-top:20px;text-align:center}
.qp-cta-box h4{font-family:'DM Serif Display',serif;font-size:18px;color:var(--ink);margin-bottom:6px}
.qp-cta-box p{font-size:13px;color:var(--muted);margin-bottom:16px;line-height:1.7}
.qp-cta-btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.qp-cta-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:var(--r-sm);font-size:13px;font-weight:700;cursor:pointer;transition:all .25s;border:none}
.qp-cta-btn.primary{background:var(--gold);color:#fff}
.qp-cta-btn.primary:hover{background:var(--gold-lt);transform:translateY(-1px)}
.qp-cta-btn.secondary{background:#fff;color:var(--green);border:1.5px solid var(--green)}
.qp-cta-btn.secondary:hover{background:var(--green);color:#fff}
.q-paper{background:#fff;padding:40px;border:1px solid var(--bg3);border-radius:var(--r-md)}
.qp-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px;padding-bottom:22px;border-bottom:2px solid var(--gold)}
.qp-brand-tag{font-size:9px;letter-spacing:2px;text-transform:capitalize;color:var(--faint)}
.qp-brand-contact{font-size:12px;color:var(--muted);margin-top:6px}
.qp-badge{background:var(--ink);color:#fff;padding:7px 16px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:1px;display:inline-block}
.qp-date{font-size:11px;color:var(--muted);margin-top:8px}
.qp-num-box{text-align:right;flex-shrink:0}
.qp-meta{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px}
.qp-mi label{font-size:9px;color:var(--faint);text-transform:capitalize;letter-spacing:.5px;display:block;margin-bottom:3px}
.qp-mi span{font-size:13px;font-weight:600;color:var(--ink)}
.qp-table{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:18px}
.qp-table th{background:var(--ink);color:var(--gold-lt);padding:9px 12px;text-align:left;font-size:9px;letter-spacing:.5px}
.qp-table td{padding:9px 12px;color:var(--ink2);border-bottom:1px solid var(--bg3)}
.qp-table tr:nth-child(even) td{background:var(--bg)}
.qp-total{background:var(--ink);color:#fff;border-radius:var(--r-sm);padding:16px 20px;display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.qp-total-lbl{font-size:10px;color:rgba(255,255,255,.45);text-transform:capitalize;letter-spacing:1px}
.qp-total-amt{font-family:'DM Serif Display',serif;font-size:28px;color:var(--gold-lt)}
.qp-terms{background:var(--bg2);border-left:3px solid var(--gold);padding:12px 16px;border-radius:0 var(--r-sm) var(--r-sm) 0;margin-bottom:22px}
.qp-terms h5{font-size:9px;text-transform:capitalize;letter-spacing:1px;color:var(--faint);margin-bottom:8px}
.qp-terms li{font-size:11px;color:var(--muted);padding:2px 0;list-style:none}
.qp-terms li::before{content:"• ";color:var(--gold)}
.qp-foot{display:flex;justify-content:space-between;align-items:flex-end;padding-top:16px;border-top:1px solid var(--bg3)}
.qp-sign-line{border-top:1px solid var(--bg3);width:130px;margin:28px 0 4px auto}
.qp-sign-txt{font-size:10px;color:var(--faint);text-align:right}
.q-acts{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}
.q-act{flex:1;padding:11px;border-radius:var(--r-sm);font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s;min-width:110px}
.q-act-print{background:var(--bg2);border:1px solid var(--bg3);color:var(--ink)}
.q-act-print:hover{border-color:var(--gold-line);color:var(--gold)}
.q-act-wa{background:var(--green);border:none;color:#fff}
.q-act-wa:hover{background:#17a050}
.q-act-edit{background:transparent;border:1.5px solid var(--bg3);color:var(--muted)}
.q-act-edit:hover{color:var(--ink);border-color:var(--ink2)}

/* LIGHTBOX */
#lightbox{display:none;position:fixed;inset:0;z-index:1100;background:rgba(10,8,6,.96);align-items:center;justify-content:center}
#lightbox.open{display:flex}
#lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:var(--r-sm);box-shadow:0 32px 80px rgba(0,0,0,.8)}
.lb-close{position:absolute;top:20px;right:24px;background:none;border:none;color:rgba(255,255,255,.5);font-size:36px;cursor:pointer;transition:color .2s;line-height:1}
.lb-close:hover{color:#fff}

/* PRINT */
@media print{
  .nav,.ticker,.trust,.motto,.services,.about,.why,.calculator,.process,.portfolio,.upload,.reviews,.faq,.cta-band,.map-sec,.areas,footer,.float-wa,.float-call,.chat-fab,.chat-box,#lightbox,.sticky-wa,.qp-cta-box,.q-acts{display:none!important}
  .modal-bg{display:block!important;position:static!important;background:none!important;padding:0}
  .modal{max-height:none!important;border:none!important;box-shadow:none!important}
  .q-preview{display:block!important}
  .q-paper{padding:16px}
  body{background:#fff!important}
  @page{margin:8mm}
}

/* RESPONSIVE */
@media(max-width:900px){
  .hero{grid-template-columns:1fr}
  .hero-right{display:none}
  .hero-left{padding:80px 40px;justify-content:flex-start}
  .hero-left-inner{max-width:100%;margin-left:0}
  .svc-grid{grid-template-columns:repeat(3,1fr);gap:10px}
  .svc-card{padding:14px;gap:12px}
  .svc-icon-box{width:48px;height:48px;border-radius:10px}
  .svc-icon-box svg{width:24px;height:24px}
  .svc-name{font-size:13px}
  .svc-desc{font-size:10px}
  .svc-price{font-size:12px}
  .about-inner{grid-template-columns:1fr;gap:48px}
  .about-float{right:0}
  .why-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .calc-layout{grid-template-columns:1fr}
  .est-panel{position:static}
  .process-steps{grid-template-columns:repeat(3,1fr);gap:28px}
  .process-steps::before{display:none}
  .pf-grid{grid-template-columns:repeat(2,1fr)}
  .pf-item.tall{grid-row:auto}
  .pf-item.tall .pf-thumb-inner{min-height:240px}
  .f-grid{grid-template-columns:1fr 1fr;gap:36px}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:900px){
  .nav-phone{display:none}
  .btn-wa{display:none}
  .nav-links a{padding:7px 10px;font-size:12px}
  .nav-links{gap:4px}
  .nav-sep{display:none}
}
@media(max-width:768px){
  .nav-inner{padding:0 20px}
  .nav-links,.nav-phone,.nav-cta,.btn-wa{display:none}
  .hamburger{display:flex}
  .nav-dropdown{display:none}
  section{padding:64px 0}
  .container{padding:0 20px}
  .svc-grid{grid-template-columns:repeat(3,1fr);gap:6px}
  .svc-card{padding:12px;gap:10px}
  .svc-icon-box{width:42px;height:42px;border-radius:8px}
  .svc-icon-box svg{width:22px;height:22px}
  .svc-name{font-size:12px}
  .svc-desc{font-size:9.5px}
  .svc-price{font-size:11px}
  .svc-enq{font-size:9px;padding:4px 10px}
  .why-grid{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr 1fr}
  .pf-grid{grid-template-columns:1fr}
  .f-grid{grid-template-columns:1fr;gap:28px}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .f-row{grid-template-columns:1fr}
  .motto-pillars{grid-template-columns:1fr}
  .mpillar:nth-child(2){border:none;border-top:1px solid rgba(184,146,42,.12);border-bottom:1px solid rgba(184,146,42,.12)}
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .hstat:nth-child(2){border-right:none}
  .cta-btns{flex-direction:column;align-items:center}
  .f-bot{flex-direction:column;text-align:center}
  .chat-box{width:calc(100vw - 48px);left:24px}
}
@media(max-width:480px){
  .svc-grid{grid-template-columns:repeat(2,1fr);gap:6px}
  .svc-card{padding:10px;gap:8px;flex-direction:column;text-align:center}
  .svc-icon-box{width:48px;height:48px}
  .svc-name{font-size:12px;white-space:normal}
  .svc-desc{-webkit-line-clamp:1;font-size:9.5px}
  .svc-price-row{flex-direction:column;gap:4px}
  .svc-price{font-size:11px}
  .svc-enq{font-size:9px;padding:4px 10px;width:100%;justify-content:center}
  .process-steps{grid-template-columns:1fr}
  .hero-btns{flex-direction:column}
  .btn-primary,.btn-outline{width:100%;justify-content:center}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
}


/* STICKY WA BAR */
.sticky-wa{position:fixed;bottom:0;left:0;right:0;z-index:850;background:linear-gradient(90deg,#128C7E,#25D366);padding:12px 20px;display:flex;align-items:center;justify-content:center;gap:14px;transform:translateY(100%);transition:transform .4s ease;box-shadow:0 -4px 20px rgba(0,0,0,.2)}
.sticky-wa.show{transform:translateY(0)}
.sticky-wa-text{color:#fff;font-weight:700;font-size:14px;letter-spacing:.3px}
.sticky-wa-btn{background:#fff;color:#128C7E;padding:8px 22px;border-radius:50px;font-size:13px;font-weight:700;white-space:nowrap;transition:all .2s}
.sticky-wa-btn:hover{background:#f0fff4;transform:scale(1.04)}
.sticky-wa-close{color:rgba(255,255,255,.7);font-size:18px;cursor:pointer;margin-left:8px;line-height:1;padding:4px}
@media(max-width:480px){.sticky-wa-text{font-size:12px}.sticky-wa-btn{padding:7px 16px;font-size:12px}}
/* Push float buttons up when sticky shown */
.float-wa{bottom:84px}.float-call{bottom:24px}

.skip-link{position:absolute;top:-60px;left:16px;background:var(--gold);color:#fff;padding:10px 18px;border-radius:6px;font-weight:600;font-size:14px;z-index:9999;transition:top .2s;text-decoration:none}
.skip-link:focus{top:8px}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:3px}
@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}
@media print{.nav,.ticker,.trust,.float-wa,.float-call,.chat-fab,.chat-box,.sticky-wa{display:none!important}body{color:#000;font-size:12pt}}
img[loading="lazy"]{opacity:0;transition:opacity .4s}
img[loading="lazy"].loaded{opacity:1}
[id]{scroll-margin-top:80px}
a[target="_blank" rel="noopener noreferrer"]:not(.btn-wa):not(.sticky-wa-btn)::after{content:" ↗";font-size:.75em;opacity:.6}

/* GALLERY SECTIONS */
.gal-sec{padding:72px 0}
.gal-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:36px}
.gs{background:#fff;border:1px solid var(--bg3);border-radius:var(--r-md);padding:18px;text-align:center;box-shadow:var(--shadow-sm)}
.gs-n{font-family:'DM Serif Display',serif;font-size:24px;color:var(--gold);line-height:1}
.gs-l{font-size:11px;color:var(--muted);margin-top:5px}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:36px}
.gal-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.gv-card,.gp-card{border-radius:var(--r-lg);overflow:hidden;background:#fff;box-shadow:var(--shadow-sm);transition:all .4s cubic-bezier(.22,1,.36,1);border:1px solid rgba(0,0,0,.04)}
.gv-card:hover,.gp-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:var(--gold-line)}
.gv-img-wrap,.gp-img-wrap{position:relative;aspect-ratio:4/3;overflow:hidden}
.gv-img,.gp-img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.22,1,.36,1),opacity .5s;opacity:0;animation:kenBurns 18s ease-in-out infinite alternate}
.gv-img.loaded,.gp-img.loaded{opacity:1}
.gv-card:hover .gv-img,.gp-card:hover .gp-img{transform:scale(1.1);animation:none}
@keyframes kenBurns{0%{transform:scale(1) translate(0,0)}100%{transform:scale(1.08) translate(-1%,1%)}}
.gv-overlay,.gp-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(28,25,22,.75) 0%,rgba(28,25,22,.2) 50%,transparent 100%);display:flex;align-items:flex-end;padding:16px;opacity:0;transition:opacity .35s}
.gv-card:hover .gv-overlay,.gp-card:hover .gp-overlay{opacity:1}
.gv-enq,.gp-enq{background:var(--gold);color:#fff;padding:7px 16px;border-radius:var(--r-sm);font-size:11px;font-weight:700;cursor:pointer;border:none;transition:all .2s}
.gv-enq:hover,.gp-enq:hover{background:var(--gold-lt);transform:translateY(-1px)}
.gv-info,.gp-info{padding:14px 16px 16px;border-top:2px solid transparent;transition:border-color .3s}
.gv-card:hover .gv-info,.gp-card:hover .gp-info{border-top-color:var(--gold)}
.gv-title,.gp-title{font-weight:600;font-size:13px;color:var(--ink);margin-bottom:3px;letter-spacing:.2px}
.gv-sub,.gp-sub{font-size:11px;color:var(--muted);line-height:1.4}
.type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;background:#fff;border-radius:var(--r-lg);padding:26px;border:1px solid var(--bg3);margin-bottom:0}
.type-card{text-align:center;padding:12px 8px}
.type-icon{font-size:24px;margin-bottom:8px}
.type-card b{display:block;font-size:13px;color:var(--ink);margin-bottom:5px}
.type-card p{font-size:11px;color:var(--muted);line-height:1.6;margin:0}
@media(max-width:900px){.gal-stats{grid-template-columns:repeat(2,1fr)}.type-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.type-grid{grid-template-columns:1fr}.gal-stats{grid-template-columns:1fr 1fr}.container{padding:0 16px}section{padding:56px 0}.svc-cta-row{flex-direction:column;text-align:center;gap:14px}}


/* Mission/Vision/Values Grid */
.mvv-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 900px) { .mvv-grid { grid-template-columns: 1fr; } }
@media (max-width: 480px) { .mvv-grid { gap: 14px; } }
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
