/* ===== Innova Construction v2 — Styles ===== */
:root{
  --ink:#0E1524;
  --ink-2:#2A3144;
  --muted:#5B6479;
  --line:#E7E5DF;
  --line-2:#F2EFE8;
  --bg:#FFFFFF;
  --bg-warm:#FAF7F1;
  --bg-sand:#F2EDE3;
  --primary:#2AA045;
  --accent:#F5B800;
  --accent-ink:#0E1524;
  --radius: 14px;
  --radius-lg: 22px;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.06), 0 4px 12px rgba(0,0,0,.04);
  --shadow-md: 0 4px 10px rgba(0,0,0,.08), 0 20px 40px -12px rgba(0,0,0,.12);
  --shadow-lg: 0 30px 60px -20px rgba(0,0,0,.25);
  --maxw: 1320px;
  --gutter: clamp(20px, 4vw, 56px);
}

/* ===== Loading Screen ===== */
#loading-screen{
  position:fixed;inset:0;z-index:9999;
  background:var(--primary);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .5s ease, visibility .5s ease;
}
#loading-screen.ls-hidden{opacity:0;visibility:hidden;pointer-events:none}
.ls-inner{position:absolute;inset:0}
.ls-video{width:100%;height:100%;object-fit:cover;display:block}
/* ============================= */

*{box-sizing:border-box}
html,body{margin:0;padding:0;max-width:100%;overflow-x:clip;overscroll-behavior-x:none;overscroll-behavior-y:auto}
html{scroll-behavior:smooth}
body{
  font-family:'Fraunces',Georgia,serif;
  color:var(--ink);background:var(--bg);font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
h1,h2,h3,h4{font-family:'Fraunces',serif;font-weight:400;letter-spacing:-.015em;line-height:1.05;margin:0;text-wrap:balance}
p{margin:0;text-wrap:pretty}
em{font-style:italic;color:var(--accent);font-weight:300}
.container{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Fraunces',serif;font-size:12px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--accent);
}
.eyebrow::before{content:"";width:32px;height:1px;background:var(--accent);display:inline-block}
.section-title{font-size:clamp(34px,4.5vw,64px);letter-spacing:-.02em}
.lead{color:var(--muted);font-size:clamp(16px,1.1vw,18px);max-width:62ch}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 28px;border-radius:999px;font-weight:600;font-size:15px;
  transition:transform .2s, background .25s, color .25s, box-shadow .3s, border-color .25s;
  white-space:nowrap;
}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:#1F7A33;transform:translateY(-1px);box-shadow:0 12px 24px -8px rgba(42,160,69,.45)}
.btn-accent{background:var(--accent);color:var(--accent-ink)}
.btn-accent:hover{background:#D6A000;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.55)}
.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn-light{background:#fff;color:var(--primary)}
.btn-light:hover{background:var(--bg-warm)}
.btn-outline{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff}

/* ===== Header ===== */
.header{
  position:fixed;top:0;left:0;right:0;z-index:60;
  background:rgba(255,255,255,.88);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;transition:all .3s;
}
body.page-home .header,body.page-about .header,body.page-services .header,body.page-gallery .header,body.page-contact .header,body.page-blog .header{background:var(--primary);border-bottom-color:rgba(255,255,255,.12)}
body.page-home .header.scrolled,body.page-about .header.scrolled,body.page-services .header.scrolled,body.page-gallery .header.scrolled,body.page-contact .header.scrolled,body.page-blog .header.scrolled{background:var(--primary)}
body.page-home .header .nav a, body.page-home .header .phone-link,
body.page-about .header .nav a, body.page-about .header .phone-link,
body.page-services .header .nav a, body.page-services .header .phone-link,
body.page-gallery .header .nav a, body.page-gallery .header .phone-link,
body.page-contact .header .nav a, body.page-contact .header .phone-link,
body.page-blog .header .nav a, body.page-blog .header .phone-link{color:#fff}
body.page-home .header .burger,body.page-about .header .burger,body.page-services .header .burger,body.page-gallery .header .burger,body.page-contact .header .burger,body.page-blog .header .burger{border-color:rgba(255,255,255,.3);color:#fff}
.header.scrolled{border-bottom-color:var(--line);background:rgba(255,255,255,.95)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding-block:18px;gap:24px}
.header.scrolled .header-inner{padding-block:14px}
.logo{display:flex;align-items:center;gap:12px}
.logo-img-wrap{gap:0}
.logo-img{height:48px;width:auto;display:block;object-fit:contain}
.logo-img-mobile{height:44px}
.logo-img-footer{height:52px}
.logo-group{display:flex;align-items:center;gap:14px}
.nav-licence{
  display:flex;flex-direction:column;justify-content:center;
  padding-left:14px;
  border-left:1px solid rgba(255,255,255,.5);
  font-family:'Manrope',sans-serif;
  font-size:10px;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;line-height:1.45;color:#fff;
  white-space:nowrap;
}
@media(max-width:768px){
  .logo-img{height:40px}
  .nav-licence{font-size:9px;padding-left:10px;letter-spacing:.1em}
  .logo-group{gap:10px}
}
@media(max-width:420px){
  .nav-licence{font-size:8px;padding-left:8px;letter-spacing:.08em;line-height:1.35}
  .logo-group{gap:8px}
}
.nav{display:flex;align-items:center;gap:32px}
.nav a{
  font-size:14px;font-weight:500;color:var(--ink-2);position:relative;transition:color .2s;
  padding:6px 0;
}
.nav a:hover{color:var(--accent)}
.nav a.active{color:var(--accent)}
.nav a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--accent);
  border-radius:2px;
}
.header-cta{display:flex;align-items:center;gap:14px}
.sv-btn{margin-top:24px;align-self:flex-start}
.phone-group{display:flex;align-items:center;gap:8px}
.phone-icon{width:16px;height:16px;flex-shrink:0;color:var(--accent)}
.phone-nums{display:flex;flex-direction:column;gap:1px}
.phone-link{display:block;font-size:14px;font-weight:600;color:var(--ink);transition:color .2s;line-height:1.3}
.burger{display:none;width:42px;height:42px;border-radius:10px;border:1px solid var(--line);place-items:center}
.burger svg{width:18px;height:18px}
@media (max-width:1024px){
  .nav{display:none}
  .phone-link span{display:none}
  .burger{display:grid}
}
@media (max-width:640px){
  .header-cta .btn{display:none}
  .phone-group{display:none}
}

/* Mobile menu */
.mobile-menu{
  position:fixed;inset:0;background:var(--primary);color:#fff;z-index:100;
  padding:32px;display:none;flex-direction:column;
  opacity:0;transition:opacity .3s;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  overscroll-behavior:none;touch-action:pan-y;
}
.mobile-menu.open{display:flex;opacity:1}
.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:48px}
.mobile-menu-header .logo-img-mobile{filter:brightness(0) invert(1)}
.mobile-menu-close{width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:grid;place-items:center}
.mobile-menu-close svg{width:18px;height:18px}
.mobile-menu nav{display:flex;flex-direction:column;gap:4px}
.mobile-menu nav a{
  font-family:'Fraunces',serif;font-size:36px;font-weight:300;letter-spacing:-.02em;
  padding:14px 0;border-bottom:1px solid rgba(255,255,255,.1);
  display:flex;justify-content:space-between;align-items:center;
}
.mobile-menu nav a small{font-family:'Manrope',sans-serif;font-size:11px;letter-spacing:.2em;color:var(--accent);font-weight:600}
.mobile-menu-foot{margin-top:auto;padding-top:32px;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:14px}
.mobile-menu-foot a{font-size:15px;color:rgba(255,255,255,.8);display:flex;align-items:center;gap:10px}
.mobile-menu-foot svg{width:16px;height:16px;color:var(--accent)}

/* ===== Page routing ===== */
.page{display:none;min-height:100vh;padding-top:84px}
.page.active{display:block}
body.page-home .page.active#page-home,body.page-about .page.active#page-about,body.page-services .page.active#page-services,body.page-gallery .page.active#page-gallery,body.page-contact .page.active#page-contact,body.page-blog .page.active#page-blog{padding-top:0}
section.pad{padding-block:clamp(80px,10vw,140px)}
.section-head{margin-bottom:56px;max-width:820px}
.section-head .eyebrow{margin-bottom:18px}
.section-head .lead{margin-top:20px}
.section-head.row{display:flex;justify-content:space-between;gap:40px;align-items:flex-end;max-width:none;flex-wrap:wrap}
.section-head.row > div:first-child{max-width:700px}

/* ===== HOME / HERO ===== */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:flex-end;
  color:#fff;overflow:hidden;padding-bottom:clamp(80px,10vw,120px);
  padding-top:180px;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
}
.hero-bg img{width:100%;height:100%;object-fit:cover;animation:slowZoom 20s ease-out forwards}
@keyframes slowZoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.55) 0%,rgba(0,0,0,.25) 40%,rgba(0,0,0,.85) 100%);
}
.hero-inner{position:relative;z-index:2;width:100%}
.hero-top{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap;margin-bottom:48px}
.hero .eyebrow{color:var(--accent)}
.hero .eyebrow::before{background:var(--accent)}
.hero h1{
  font-size:clamp(48px,7vw,110px);font-weight:300;letter-spacing:-.03em;line-height:.98;color:#fff;max-width:16ch;
}
.hero h1 em{color:var(--accent);font-weight:400}
.hero p.lead{color:rgba(255,255,255,.8);font-size:clamp(16px,1.2vw,19px);max-width:54ch;margin-top:24px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:36px}
.hero-float-badge{
  background:rgba(255,255,255,.08);backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.18);padding:14px 18px;border-radius:12px;
  display:flex;align-items:center;gap:12px;align-self:flex-start;
}
.hero-float-badge svg{width:20px;height:20px;color:var(--accent)}
.hero-float-badge b{font-family:'Fraunces',serif;font-size:15px;font-weight:500;display:block}
.hero-float-badge span{font-size:12px;color:rgba(255,255,255,.7)}
.hero-bottom{
  margin-top:64px;padding-top:40px;
  border-top:1px solid rgba(255,255,255,.15);
  display:grid;grid-template-columns:repeat(4,1fr);gap:32px;
}
.stat b{font-family:'Fraunces',serif;font-size:clamp(40px,4.5vw,64px);font-weight:300;letter-spacing:-.03em;color:#fff;display:block;line-height:1}
.stat b em{color:var(--accent)}
.stat span{font-size:13px;color:rgba(255,255,255,.65);letter-spacing:.04em;margin-top:6px;display:block}
.scroll-indicator{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.6);
}
.scroll-indicator::after{
  content:"";width:1px;height:44px;background:rgba(255,255,255,.3);
  animation:scrollDown 2s ease-in-out infinite;
}
@keyframes scrollDown{0%,100%{transform:scaleY(.3);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}}
@media (max-width:900px){
  .hero-bottom{grid-template-columns:repeat(2,1fr);gap:24px}
  .hero-float-badge{display:none}
  .scroll-indicator{display:none}
}

/* Home feature strip */
.home-feature{background:var(--bg-warm);padding-block:clamp(80px,10vw,140px)}
.home-feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,96px);align-items:center}
.hf-media{aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden;position:relative;box-shadow:var(--shadow-lg)}
.hf-media img{width:100%;height:100%;object-fit:cover}
.hf-media-quote{
  position:absolute;left:24px;bottom:24px;right:24px;
  background:rgba(255,255,255,.96);padding:20px 22px;border-radius:14px;
  font-family:'Fraunces',serif;font-size:18px;font-weight:400;color:var(--ink);
  box-shadow:var(--shadow-md);
}
.hf-media-quote small{display:block;font-family:'Manrope',sans-serif;font-size:11px;letter-spacing:.14em;color:var(--accent);font-weight:600;margin-top:10px}
.hf-copy h2{margin-bottom:24px}
.hf-list{margin-top:32px;display:grid;gap:2px}
.hf-list div{padding:18px 0;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px}
.hf-list div:first-child{border-top:1px solid var(--line)}
.hf-list svg{width:18px;height:18px;color:var(--accent);flex-shrink:0}
.hf-list b{font-family:'Fraunces',serif;font-size:18px;font-weight:500;flex:1}
.hf-list span{font-size:13px;color:var(--muted)}
@media (max-width:900px){.home-feature-grid{grid-template-columns:1fr;gap:40px}}

/* Home services preview */
.home-services{background:#fff;padding-block:clamp(80px,10vw,140px)}
.home-services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px;
}
.hs-card{
  position:relative;aspect-ratio:3/4;border-radius:var(--radius-lg);overflow:hidden;
  background:#000;cursor:pointer;transition:transform .5s;
}
.hs-card:hover{transform:translateY(-6px)}
.hs-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.8,.2,1);opacity:.75}
.hs-card:hover img{transform:scale(1.06);opacity:.55}
.hs-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 40%,rgba(0,0,0,.85) 100%)}
.hs-body{position:absolute;left:0;right:0;bottom:0;padding:28px;color:#fff;z-index:2}
.hs-body small{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-weight:600;display:block;margin-bottom:10px}
.hs-body h3{font-size:clamp(22px,2vw,30px);color:#fff}
.hs-arrow{
  position:absolute;top:24px;right:24px;width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.14);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.28);
  display:grid;place-items:center;color:#fff;z-index:2;transition:all .3s;
}
.hs-card:hover .hs-arrow{background:var(--accent);border-color:var(--accent);transform:rotate(-45deg)}
.hs-arrow svg{width:16px;height:16px}
@media (max-width:900px){.home-services-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.home-services-grid{grid-template-columns:1fr}}

/* Home cta banner */
.cta-banner{
  background:var(--primary);color:#fff;padding-block:clamp(60px,7vw,100px);
  position:relative;overflow:hidden;
}
.cta-banner::before{
  content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,184,0,.25),transparent 70%);
}
.cta-banner-inner{display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap;position:relative;z-index:1}
.cta-banner h3{font-size:clamp(28px,3.5vw,44px);font-weight:300;letter-spacing:-.02em;max-width:20ch}
.cta-banner h3 em{color:var(--accent)}

/* ===== ABOUT PAGE ===== */
.page-title-block{padding:clamp(60px,8vw,120px) 0 clamp(40px,5vw,72px);background:var(--bg-warm)}
.page-title-block .eyebrow{margin-bottom:18px}
.page-title-block h1{font-size:clamp(48px,6.5vw,96px);font-weight:300;letter-spacing:-.03em;max-width:18ch}
.page-title-block .lead{margin-top:24px;font-size:clamp(17px,1.3vw,20px);max-width:58ch}

.about-story{padding-block:clamp(80px,10vw,140px)}
.about-story-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,96px);align-items:flex-start}
.about-story .media{aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);position:sticky;top:100px}
.about-story .media img{width:100%;height:100%;object-fit:cover}
.about-story .copy h2{margin-bottom:24px}
.about-story .copy p{color:var(--muted);font-size:17px;margin-bottom:20px}
.about-story .copy p strong{color:var(--ink);font-weight:600}
.about-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;margin-top:40px;background:var(--line);border:1px solid var(--line)}
.about-stats > div{background:#fff;padding:28px;display:flex;flex-direction:column;gap:8px}
.about-stats b{font-family:'Fraunces',serif;font-size:42px;font-weight:300;color:var(--accent);letter-spacing:-.02em;line-height:1}
.about-stats span{font-size:13px;color:var(--muted)}
@media (max-width:900px){
  .about-story-grid{grid-template-columns:1fr;gap:40px}
  .about-story .media{position:static}
}

.about-values{background:var(--primary);color:#fff;padding-block:clamp(80px,10vw,140px)}
.about-values .eyebrow{color:var(--accent)}
.about-values .eyebrow::before{background:var(--accent)}
.about-values .section-title{color:#fff}
.about-values .lead{color:rgba(255,255,255,.72)}
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:56px;border-top:1px solid rgba(255,255,255,.15);border-left:1px solid rgba(255,255,255,.15)}
.value{padding:36px 28px;border-right:1px solid rgba(255,255,255,.15);border-bottom:1px solid rgba(255,255,255,.15);display:flex;flex-direction:column;gap:16px;min-height:320px;transition:background .3s}
.value:hover{background:rgba(255,255,255,.04)}
.value-num{font-family:'Fraunces',serif;font-size:13px;color:var(--accent);letter-spacing:.18em}
.value-icon{width:52px;height:52px;border-radius:12px;background:rgba(245,184,0,.15);display:grid;place-items:center;color:var(--accent)}
.value-icon svg{width:24px;height:24px}
.value h3{font-size:24px;font-weight:400;margin-top:auto;color:#fff}
.value p{color:rgba(255,255,255,.68);font-size:14.5px}
@media (max-width:900px){.values-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.values-grid{grid-template-columns:1fr}}

/* ===== SERVICES PAGE ===== */
.services-list{padding-block:clamp(60px,8vw,100px)}
.services-list-inner{display:grid;gap:2px;border-top:1px solid var(--line)}
.svc-row{
  padding:32px 0;border-bottom:1px solid var(--line);
  display:grid;grid-template-columns:80px 1.4fr 2fr 180px;gap:32px;align-items:center;
  cursor:pointer;transition:background .3s, padding .3s;
  position:relative;
}
.svc-row:hover{padding-left:16px;background:linear-gradient(90deg,var(--bg-warm),transparent 50%)}
.svc-num{font-family:'Fraunces',serif;font-size:14px;color:var(--accent);letter-spacing:.18em}
.svc-name{font-family:'Fraunces',serif;font-size:clamp(28px,3vw,44px);font-weight:300;letter-spacing:-.02em;line-height:1.05}
.svc-name em{color:var(--accent);font-weight:400}
.svc-desc{color:var(--muted);font-size:15px;max-width:50ch}
.svc-cta{display:flex;align-items:center;justify-content:flex-end;gap:12px;font-size:13px;font-weight:600;color:var(--primary);letter-spacing:.04em}
.svc-cta-arrow{width:44px;height:44px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;transition:all .3s}
.svc-row:hover .svc-cta-arrow{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(-45deg)}
.svc-cta-arrow svg{width:16px;height:16px}
@media (max-width:900px){
  .svc-row{grid-template-columns:60px 1fr;gap:12px;padding:24px 0}
  .svc-desc{grid-column:2;max-width:none;margin-top:8px}
  .svc-cta{grid-column:2;justify-content:flex-start;margin-top:14px}
}

/* Service drawer */
.drawer-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(6px);
  z-index:150;opacity:0;visibility:hidden;transition:opacity .3s, visibility .3s;
}
.drawer-backdrop.open{opacity:1;visibility:visible}
.drawer{
  position:fixed;top:0;right:0;bottom:0;width:min(640px,100%);background:#fff;z-index:160;
  transform:translateX(100%);transition:transform .45s cubic-bezier(.2,.8,.2,1);
  overflow-y:auto;
}
.drawer.open{transform:translateX(0)}
.drawer-close{
  position:sticky;top:18px;margin-left:auto;margin-right:18px;
  width:44px;height:44px;border-radius:50%;background:#fff;border:1px solid var(--line);
  display:grid;place-items:center;z-index:10;
}
.drawer-hero{aspect-ratio:16/10;overflow:hidden;margin-top:-62px}
.drawer-hero img{width:100%;height:100%;object-fit:cover}
.drawer-body{padding:36px clamp(24px,4vw,48px) 56px}
.drawer-body .eyebrow{margin-bottom:14px}
.drawer-body h2{font-size:clamp(32px,4vw,48px);letter-spacing:-.02em;margin-bottom:18px}
.drawer-body h2 em{color:var(--accent);font-weight:300}
.drawer-body > p{color:var(--muted);font-size:16px;margin-bottom:32px}
.drawer-meta{display:grid;grid-template-columns:1fr 1fr;gap:1px;margin-bottom:32px;background:var(--line);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.drawer-meta > div{background:#fff;padding:20px}
.drawer-meta small{font-size:11px;letter-spacing:.14em;color:var(--muted);font-weight:600;text-transform:uppercase}
.drawer-meta b{font-family:'Fraunces',serif;font-size:22px;font-weight:400;display:block;margin-top:6px}
.drawer-includes{margin-bottom:32px}
.drawer-includes h4{font-size:14px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px;color:var(--ink)}
.drawer-includes ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.drawer-includes li{display:flex;gap:12px;align-items:center;font-size:15px}
.drawer-includes svg{width:18px;height:18px;color:var(--accent);flex-shrink:0}
.drawer-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:32px}
.drawer-gallery img{aspect-ratio:1;object-fit:cover;border-radius:8px}
.drawer-cta{display:flex;gap:12px;flex-wrap:wrap}

/* ===== GALLERY PAGE ===== */
.gallery-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:40px;padding-block:20px}
.gf-btn{
  padding:10px 20px;border-radius:999px;font-size:13px;font-weight:600;letter-spacing:.04em;
  border:1px solid var(--line);background:#fff;transition:all .25s;color:var(--ink-2);
}
.gf-btn:hover{border-color:var(--accent);color:var(--accent)}
.gf-btn.on{background:var(--primary);color:#fff;border-color:var(--primary)}
.gallery-grid{
  columns:3;column-gap:16px;
}
@media (max-width:900px){.gallery-grid{columns:2}}
@media (max-width:560px){.gallery-grid{columns:1}}
.gallery-item{
  break-inside:avoid;margin-bottom:16px;border-radius:var(--radius);overflow:hidden;
  position:relative;cursor:pointer;background:#eee;
  opacity:0;transform:translateY(20px);animation:gfade .5s forwards;
}
@keyframes gfade{to{opacity:1;transform:none}}
.gallery-item img{width:100%;height:auto;display:block;transition:transform .8s cubic-bezier(.2,.8,.2,1)}
.gallery-item:hover img{transform:scale(1.04)}
.gallery-item::after{
  content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.7) 100%);
  opacity:0;transition:opacity .3s;
}
.gallery-item:hover::after{opacity:1}
.gallery-caption{
  position:absolute;left:20px;right:20px;bottom:20px;color:#fff;z-index:2;
  opacity:0;transform:translateY(10px);transition:all .3s;
}
.gallery-item:hover .gallery-caption{opacity:1;transform:none}
.gallery-caption b{font-family:'Fraunces',serif;font-size:18px;font-weight:500;display:block}
.gallery-caption small{font-size:12px;color:rgba(255,255,255,.7);letter-spacing:.08em}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:200;
  display:none;align-items:center;justify-content:center;padding:40px;
}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:10px}
.lightbox-close{position:absolute;top:24px;right:24px;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;display:grid;place-items:center;backdrop-filter:blur(8px)}
.lightbox-close svg{width:20px;height:20px}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;display:grid;place-items:center;backdrop-filter:blur(8px)}
.lightbox-nav:hover{background:var(--accent)}
.lightbox-nav.prev{left:24px}
.lightbox-nav.next{right:24px}
.lightbox-nav svg{width:22px;height:22px}
.lightbox-caption{position:absolute;left:0;right:0;bottom:24px;text-align:center;color:rgba(255,255,255,.9);font-size:14px}
.lightbox-caption b{font-family:'Fraunces',serif;font-size:18px;font-weight:500;display:block;color:#fff}

/* ===== PROCESS PAGE ===== */
.process-timeline{padding-block:clamp(60px,8vw,100px)}
.timeline{position:relative;padding-left:clamp(60px,6vw,100px)}
.timeline::before{content:"";position:absolute;left:20px;top:20px;bottom:40px;width:1px;background:var(--line)}
.timeline-step{position:relative;padding-bottom:64px;display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:flex-start}
.timeline-step:last-child{padding-bottom:0}
.timeline-step::before{
  content:"";position:absolute;left:-64px;top:10px;width:42px;height:42px;border-radius:50%;
  background:#fff;border:2px solid var(--line);
}
.timeline-step::after{
  content:"";position:absolute;left:-52px;top:22px;width:18px;height:18px;border-radius:50%;
  background:var(--accent);
}
.timeline-step .step-num{
  font-family:'Fraunces',serif;font-size:14px;color:var(--accent);letter-spacing:.18em;margin-bottom:8px;
}
.timeline-step h3{font-size:clamp(26px,2.8vw,40px);font-weight:300;letter-spacing:-.02em;margin-bottom:16px}
.timeline-step h3 em{color:var(--accent)}
.timeline-step p{color:var(--muted);font-size:16px;margin-bottom:20px}
.timeline-step ul{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.timeline-step li{font-size:14px;color:var(--ink-2);display:flex;gap:10px;align-items:center}
.timeline-step li::before{content:"";width:4px;height:4px;border-radius:50%;background:var(--accent);flex-shrink:0}
.timeline-step .media{aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md)}
.timeline-step .media img{width:100%;height:100%;object-fit:cover}
@media (max-width:900px){
  .timeline-step{grid-template-columns:1fr;gap:20px}
  .timeline{padding-left:48px}
  .timeline-step::before{left:-48px}
  .timeline-step::after{left:-36px}
}

/* ===== TESTIMONIALS PAGE ===== */
.tsm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tsm-card{
  background:#fff;border-radius:var(--radius-lg);padding:32px;
  border:1px solid var(--line-2);display:flex;flex-direction:column;gap:18px;
  transition:transform .3s, box-shadow .3s;
}
.tsm-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.tsm-stars{display:flex;gap:2px;color:#E8A23F}
.tsm-stars svg{width:18px;height:18px;fill:currentColor}
.tsm-quote{
  font-family:'Fraunces',serif;font-size:20px;line-height:1.4;font-weight:300;
  letter-spacing:-.01em;flex:1;
}
.tsm-meta{display:flex;align-items:center;gap:14px;padding-top:18px;border-top:1px solid var(--line-2)}
.tsm-avatar{width:44px;height:44px;border-radius:50%;background:var(--bg-sand);color:var(--primary);display:grid;place-items:center;font-family:'Fraunces',serif;font-size:15px;font-weight:500}
.tsm-who b{display:block;font-size:14px}
.tsm-who span{font-size:12px;color:var(--muted)}
@media (max-width:900px){.tsm-grid{grid-template-columns:1fr}}

/* ===== AREAS PAGE ===== */
.areas-grid{display:grid;grid-template-columns:1.1fr 1.4fr;gap:clamp(40px,6vw,96px);align-items:flex-start}
.areas-map{
  aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;position:relative;
  background:var(--bg-sand);border:1px solid var(--line);
}
.areas-map img{width:100%;height:100%;object-fit:cover}
.areas-map::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(42,160,69,.15),rgba(245,184,0,.1))}
.areas-map-pin{
  position:absolute;z-index:2;transform:translate(-50%,-100%);
}
.pin-dot{width:14px;height:14px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(245,184,0,.3);position:relative}
.pin-dot::after{content:"";position:absolute;inset:-8px;border-radius:50%;border:2px solid var(--accent);animation:pinPulse 2s ease-out infinite}
@keyframes pinPulse{0%{transform:scale(.8);opacity:1}100%{transform:scale(2);opacity:0}}
.pin-label{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--primary);background:#fff;padding:4px 8px;border-radius:4px;margin-bottom:6px;display:inline-block;white-space:nowrap;box-shadow:var(--shadow-sm)}

.areas-list-wrap h3{font-size:clamp(24px,2.5vw,32px);margin-bottom:24px}
.areas-list{columns:2;column-gap:32px}
.areas-list a{
  display:flex;justify-content:space-between;align-items:center;padding:14px 0;
  border-bottom:1px solid var(--line);font-size:15px;font-weight:500;color:var(--ink-2);
  break-inside:avoid;transition:color .2s, padding-left .2s;
}
.areas-list a:hover{color:var(--accent);padding-left:6px}
.areas-list a svg{width:14px;height:14px;opacity:0;transition:opacity .2s;color:var(--accent)}
.areas-list a:hover svg{opacity:1}
@media (max-width:900px){
  .areas-grid{grid-template-columns:1fr}
  .areas-list{columns:2}
}
@media (max-width:500px){.areas-list{columns:1}}

/* ===== CONTACT PAGE ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,5vw,72px);align-items:flex-start}
.contact-aside h2{font-size:clamp(32px,4vw,52px);margin-bottom:20px}
.contact-aside h2 em{color:var(--accent);font-weight:300}
.contact-info{margin-top:32px;display:flex;flex-direction:column;gap:2px}
.contact-item{display:flex;gap:16px;padding:22px 0;border-top:1px solid var(--line);align-items:center}
.contact-item:last-child{border-bottom:1px solid var(--line)}
.ci-icon{width:42px;height:42px;border-radius:10px;background:var(--bg-sand);display:grid;place-items:center;flex-shrink:0;color:var(--primary)}
.ci-icon svg{width:18px;height:18px}
.ci-body{flex:1;min-width:0}
.ci-body small{font-size:11px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;font-weight:600}
.ci-body b{font-family:'Fraunces',serif;font-size:19px;font-weight:400;display:block;margin-top:4px;letter-spacing:-.01em;color:var(--ink);overflow-wrap:anywhere;word-break:break-word}
.ci-body span{font-size:13px;color:var(--muted);display:block;margin-top:2px}
.contact-direct{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}
.contact-direct .btn-wa{background:var(--primary);color:#fff}
.contact-direct .btn-wa:hover{background:#0e1524}

.form-card{
  background:var(--bg-warm);border-radius:var(--radius-lg);padding:clamp(28px,3vw,44px);
  border:1px solid var(--line-2);
}
.form-card h3{font-size:28px;margin-bottom:6px}
.form-card > p{color:var(--muted);font-size:14.5px;margin-bottom:28px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-field{margin-bottom:16px}
.form-field label{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:8px}
.form-field label span{color:var(--accent)}
.form-field input,.form-field select,.form-field textarea{
  width:100%;padding:14px 16px;border:1px solid var(--line);background:#fff;border-radius:10px;
  font:inherit;font-size:15px;color:var(--ink);transition:all .2s;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(245,184,0,.1);
}
.form-field input.err,.form-field select.err,.form-field textarea.err{border-color:#D94545}
.form-field .err-msg{font-size:12px;color:#D94545;margin-top:6px;display:none}
.form-field.err .err-msg{display:block}
.form-field textarea{resize:vertical;min-height:110px}
.form-field select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%235B6479' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:right 18px center;padding-right:40px}
.form-submit{margin-top:8px;width:100%}
.form-note{font-size:12px;color:var(--muted);margin-top:14px;line-height:1.5}
.form-success{display:none;padding:22px;background:linear-gradient(135deg,#EAF4EE,#D4EADC);border-radius:12px;color:#1E5A34;font-size:14.5px;align-items:center;gap:14px;margin-top:20px}
.form-success.show{display:flex}
.form-success svg{width:28px;height:28px;flex-shrink:0;color:#2A8451}
.form-error{display:none;padding:16px 20px;background:#fee2e2;border-radius:12px;color:#991b1b;font-size:14px;margin-top:16px;line-height:1.5}
.form-error.show{display:block}

.contact-map{
  margin-top:80px;border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:21/9;border:1px solid var(--line);
}
.contact-map iframe{width:100%;height:100%;border:0}

@media (max-width:900px){
  .contact-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .contact-map{aspect-ratio:4/3}
}

/* ===== FOOTER ===== */
.footer{background:var(--accent);color:var(--ink);padding-block:72px 28px}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(0,0,0,.18)}
.footer-brand p{color:rgba(14,21,36,.82);font-size:14.5px;margin-top:18px;max-width:34ch}
.footer-social{display:flex;gap:10px;margin-top:22px}
.footer-social a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(14,21,36,.35);display:grid;place-items:center;color:var(--ink);transition:all .2s}
.footer-social a:hover{background:var(--ink);border-color:var(--ink);color:var(--accent)}
.footer-social svg{width:16px;height:16px}
.footer-col h5{font-family:'Manrope',sans-serif;font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:rgba(14,21,36,.7);margin-bottom:20px}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.footer-col a,.footer-col li{font-size:14px;color:var(--ink);transition:color .2s}
.footer-col a:hover{color:rgba(14,21,36,.65)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;flex-wrap:wrap;gap:16px;font-size:13px;color:rgba(14,21,36,.6)}
.footer-bottom a:hover{color:var(--ink)}
@media (max-width:900px){.footer-top{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:560px){
  .footer-top{grid-template-columns:1fr 1fr;gap:24px 16px}
  .footer-brand{grid-column:1/-1}
  .footer-col:last-child{grid-column:1/-1}
}

/* ===== Floating actions ===== */
.floating{position:fixed;right:22px;bottom:22px;z-index:40;display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.floating.hide{display:none}
.fab{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;background:var(--primary);color:#fff;box-shadow:var(--shadow-md);transition:transform .2s}
.fab:hover{transform:translateY(-3px) scale(1.05)}
.fab.wa{background:var(--primary)}
.fab svg{width:24px;height:24px}
.fab.phone{position:relative;background:var(--accent)}
.fab.contact-fab{
  background:var(--primary);border:2px solid var(--accent);
  width:auto;height:48px;border-radius:24px;
  padding:0 18px;gap:9px;display:flex;align-items:center;
  font-size:13px;font-weight:600;letter-spacing:.02em;white-space:nowrap;
}
.fab.contact-fab svg{width:18px;height:18px;flex-shrink:0}
.fab.phone::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--accent);opacity:0;animation:ring 2s ease-out infinite}
@keyframes ring{0%{transform:scale(.8);opacity:.6}100%{transform:scale(1.4);opacity:0}}

.back-to-top{
  position:fixed;left:22px;bottom:22px;z-index:40;
  width:44px;height:44px;border-radius:50%;background:#fff;color:var(--primary);
  display:none;place-items:center;box-shadow:var(--shadow-md);border:1px solid var(--line);
}
.back-to-top.show{display:grid}
.back-to-top svg{width:18px;height:18px}

/* ===== Reveal animations ===== */
.reveal{opacity:0;transform:translateY(32px);transition:opacity 1.1s ease,transform 1.1s cubic-bezier(.22,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity 1.1s ease,transform 1.1s cubic-bezier(.22,.8,.2,1)}
.reveal-left.in{opacity:1;transform:none}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity 1.1s ease,transform 1.1s cubic-bezier(.22,.8,.2,1)}
.reveal-right.in{opacity:1;transform:none}
.reveal-scale{opacity:0;transform:scale(.95);transition:opacity 1.1s ease,transform 1.1s cubic-bezier(.22,.8,.2,1)}
.reveal-scale.in{opacity:1;transform:scale(1)}
/* stagger helpers */
.reveal-d1{transition-delay:.15s}
.reveal-d2{transition-delay:.32s}
.reveal-d3{transition-delay:.5s}

/* ===== Tweaks ===== */
#tweaks-panel{
  position:fixed;right:22px;top:90px;z-index:200;
  width:320px;background:#fff;border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow-lg);padding:20px;display:none;max-height:80vh;overflow:auto;
}
#tweaks-panel.show{display:block}
#tweaks-panel h4{font-family:'Fraunces',serif;font-size:20px;margin-bottom:4px;display:flex;justify-content:space-between;align-items:center}
#tweaks-panel h4 button{color:var(--muted);font-size:20px;line-height:1}
#tweaks-panel > p{font-size:12px;color:var(--muted);margin-bottom:16px}
.tweak{margin-bottom:14px}
.tweak label{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:6px}
.tweak textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:8px;font:inherit;font-size:13px;resize:vertical;min-height:60px}
.color-swatches{display:flex;gap:6px;flex-wrap:wrap}
.swatch{width:28px;height:28px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px var(--line);cursor:pointer;transition:transform .15s}
.swatch.on{box-shadow:0 0 0 2px var(--primary)}
.swatch:hover{transform:scale(1.1)}
.seg{display:flex;background:var(--bg-warm);border-radius:8px;padding:3px}
.seg button{flex:1;padding:8px 10px;font-size:12px;font-weight:600;border-radius:6px;color:var(--muted)}
.seg button.on{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}
.tweak-switch{display:flex;justify-content:space-between;align-items:center}
.switch{width:40px;height:22px;border-radius:999px;background:var(--line);position:relative;cursor:pointer;transition:background .2s}
.switch::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:transform .2s}
.switch.on{background:var(--primary)}
.switch.on::after{transform:translateX(18px)}

/* ================================================================
   HERO SLIDER
   ================================================================ */
.hs{position:relative;height:100vh;min-height:580px;overflow:hidden}
.hs-slide{
  position:absolute;inset:0;display:flex;align-items:center;
  opacity:0;transition:opacity .9s ease;pointer-events:none;
}
.hs-slide.active{opacity:1;pointer-events:auto;z-index:2}
.hs-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.06);transition:transform 8s ease;
}
.hs-slide.active .hs-bg{transform:scale(1)}

.hs-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to right,rgba(0,0,0,.88) 0%,rgba(0,0,0,.70) 55%,rgba(0,0,0,.48) 100%);
}
/* Hero text entrance animation */
@keyframes hs-text-enter{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
.hs-content > *{opacity:0}
.hs-slide.active .hs-content > *{opacity:1}
.hs-slide.active.hs-entering .hs-content > *:nth-child(1){animation:hs-text-enter .85s cubic-bezier(.22,.8,.2,1) .12s both}
.hs-slide.active.hs-entering .hs-content > *:nth-child(2){animation:hs-text-enter .85s cubic-bezier(.22,.8,.2,1) .26s both}
.hs-slide.active.hs-entering .hs-content > *:nth-child(3){animation:hs-text-enter .85s cubic-bezier(.22,.8,.2,1) .42s both}
.hs-slide.active.hs-entering .hs-content > *:nth-child(4){animation:hs-text-enter .85s cubic-bezier(.22,.8,.2,1) .58s both}
.hs-content h1,.hs-content h2{text-shadow:0 2px 24px rgba(0,0,0,.6)}
.hs-eye{color:rgba(255,255,255,.75)}
.hs-content{
  position:relative;z-index:3;
  padding-top:110px;padding-bottom:170px;
}
.hs-content h1{
  color:#fff;font-size:clamp(38px,6vw,82px);margin-top:20px;
}

/* Arrows */
.hs-arr{
  position:absolute;top:50%;transform:translateY(-50%);z-index:10;
  width:50px;height:50px;border-radius:50%;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);
  color:#fff;display:grid;place-items:center;cursor:pointer;
  transition:background .2s;
}
.hs-arr:hover{background:rgba(255,255,255,.22)}
.hs-arr svg{width:22px;height:22px}
.hs-prev{left:24px}
.hs-next{right:24px}
/* Dots */
.hs-dots{
  position:absolute;bottom:88px;left:50%;transform:translateX(-50%);
  display:flex;gap:10px;z-index:10;
}
.hs-dot{
  width:8px;height:8px;border-radius:4px;
  background:rgba(255,255,255,.35);cursor:pointer;padding:0;
  transition:background .3s,width .3s;
}
.hs-dot.on{width:26px;background:#fff}
/* Stats bar */
.hs-stats{
  position:absolute;bottom:0;left:0;right:0;
  background:rgba(18,27,54,.9);backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);z-index:10;padding:18px 0;
}
.hss-inner{
  display:flex;align-items:center;justify-content:space-around;
  flex-wrap:wrap;
}
.hss-item{text-align:center;padding:8px 16px}
.hss-div{width:1px;height:38px;background:rgba(255,255,255,.14);flex-shrink:0}
.hss-item b{
  display:block;font-family:'Fraunces',serif;
  font-size:clamp(24px,2.8vw,40px);color:#fff;font-weight:400;line-height:1.1;
}
.hss-item b em{color:var(--accent);font-style:normal}
.hss-item span{
  display:block;font-size:11px;text-transform:uppercase;
  letter-spacing:.1em;color:rgba(255,255,255,.52);margin-top:4px;
}

/* ================================================================
   MINI ABOUT
   ================================================================ */
.mini-about{padding:clamp(60px,8vw,100px) 0}
.ma-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,80px);align-items:center;
}
.ma-img{display:flex;justify-content:center;align-items:center}
.ma-about-logo{width:100%;max-width:420px;height:auto;display:block;border-radius:var(--radius-lg)}

/* ================================================================
   JEFF BROWN SECTION
   ================================================================ */
.jeff-section{padding:clamp(60px,8vw,100px) 0;background:var(--bg-warm)}
.jb-grid{
  display:grid;grid-template-columns:3fr 2fr;
  gap:clamp(32px,4vw,56px);align-items:center;
  padding-left:0;
}
.jb-video-row{display:flex;align-items:center;gap:14px}
.jb-slider{position:relative;flex:1;min-width:0}
.jb-slide{display:none}
@keyframes jb-slide-in{from{opacity:0}to{opacity:1}}
.jb-slide.active{display:block;animation:jb-slide-in .7s ease}
.jb-frame{position:relative;width:100%;aspect-ratio:16/9}
.jb-frame iframe{
  position:absolute;inset:0;width:100%;height:100%;
  border:none;border-radius:var(--radius);
}
.jb-arr{
  flex-shrink:0;
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.9);border:1px solid rgba(0,0,0,.1);
  box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.jb-arr:hover{background:#fff}
.jb-arr svg{width:18px;height:18px;color:var(--primary)}
.jb-vdots{display:flex;gap:8px;justify-content:center;margin-top:14px}
.jb-vdot{
  width:8px;height:8px;border-radius:50%;
  background:var(--line);border:none;transition:background .3s;
}
.jb-vdot.on{background:var(--accent)}
.jb-title{
  font-family:'Fraunces',serif;font-weight:600;
  font-size:clamp(20px,2.5vw,34px);letter-spacing:.06em;
  text-transform:uppercase;color:var(--primary);line-height:1.2;
}
.jb-rule{width:36px;height:3px;background:var(--accent);margin:20px 0}
.jb-copy p{color:var(--muted);line-height:1.75}

/* ================================================================
   WHY CHOOSE US
   ================================================================ */
.why-us{
  position:relative;padding:clamp(60px,8vw,100px) 0;
  background:#0e0e0e;overflow:hidden;
}
.wu-video-bg{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;opacity:.55;pointer-events:none;z-index:0;
}
.wu-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(135deg,rgba(0,0,0,.7) 0%,rgba(0,0,0,.55) 100%);
}
.wu-inner{position:relative;z-index:2}
.wu-heading{
  text-align:center;font-family:'Fraunces',serif;font-weight:600;
  font-size:clamp(17px,1.8vw,26px);letter-spacing:.2em;text-transform:uppercase;
  color:#fff;display:flex;align-items:center;justify-content:center;gap:18px;
  margin-bottom:clamp(36px,5vw,60px);
}
.wu-heading .wu-line{
  display:inline-block;width:36px;height:1px;
  background:rgba(255,255,255,.32);flex-shrink:0;
}
.wu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.wu-card{
  background:#fff;border:1px solid rgba(0,0,0,.06);
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:0 10px 30px -12px rgba(0,0,0,.25);
}
/* Hover only fires after .in (the animation) so transition is safe here */
.wu-card:hover{transform:translateY(-5px);box-shadow:0 20px 40px -14px rgba(0,0,0,.35);transition:transform .3s,box-shadow .3s}

/* Card reveal — use higher specificity to override .wu-card base */
@keyframes wu-rise{from{opacity:0;transform:translateY(52px) scale(.93)}to{opacity:1;transform:none}}
.wu-card.reveal-scale{opacity:0;transform:translateY(52px) scale(.93)}
.wu-card.reveal-scale.in{animation:wu-rise 1.1s cubic-bezier(.22,.8,.2,1) forwards}
.wu-card.reveal-scale.reveal-d1.in{animation-delay:.18s}
.wu-card.reveal-scale.reveal-d2.in{animation-delay:.36s}
.wu-img{height:210px;overflow:hidden}
.wu-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.wu-card:hover .wu-img img{transform:scale(1.06)}
.wu-body{padding:22px 24px 26px}
.wu-body h3{
  color:var(--ink);font-family:'Fraunces',serif;font-weight:600;
  font-size:18px;margin-bottom:10px;text-align:center;
}
.wu-body p{color:var(--ink-2);font-size:14px;line-height:1.75;text-align:left}

/* ================================================================
   SERVICES — ALTERNATING LAYOUT
   ================================================================ */
.sv-section{background:#fff;padding-bottom:clamp(60px,8vw,100px)}

.sv-main-title{
  font-size:clamp(38px,5vw,72px);
  color:var(--primary);
  text-align:center;
  padding:clamp(60px,7vw,96px) 0 clamp(40px,5vw,64px);
  margin:0;
}
.sv-main-title em{color:var(--accent);font-style:italic}

.sv-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  height:clamp(380px,42vw,480px);
  margin-bottom:16px;
}

/* flip: text left, image right */
.sv-row--flip .sv-text{order:1}
.sv-row--flip .sv-img{order:2}

.sv-img{overflow:hidden;height:100%}
.sv-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .7s ease;
}
.sv-row:hover .sv-img img{transform:scale(1.04)}

.sv-text{
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(48px,6vw,88px) clamp(40px,5vw,80px);
  background:#fff;
}
.sv-text h3{
  font-family:'Fraunces',serif;
  font-size:clamp(26px,2.8vw,40px);
  color:var(--primary);margin-bottom:18px;
}
.sv-text p{
  color:var(--muted);font-size:16px;line-height:1.75;
  max-width:44ch;
}
.sv-cta{text-align:center;padding:clamp(40px,5vw,64px) 20px 0}

/* ================================================================
   GALLERY PREVIEW
   ================================================================ */
.gallery-preview{padding:clamp(60px,8vw,100px) 0;background:var(--bg-warm)}
.gp-top{margin-bottom:20px}
.gp-sub{
  font-family:'Fraunces',serif;font-weight:600;
  font-size:clamp(13px,1.1vw,17px);letter-spacing:.14em;text-transform:uppercase;
  color:var(--primary);margin-top:10px;
}
.gp-desc{color:var(--muted);max-width:72ch;margin-bottom:36px;text-align:justify}
.gp-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:240px 240px;
  gap:10px;
}
.gp-cell{border-radius:var(--radius);overflow:hidden}
.gp-cell img{width:100%;height:100%;object-fit:cover;transition:transform .5s;display:block}
.gp-cell:hover img{transform:scale(1.05)}
.gp-tall{grid-row:1/3}
.gp-cta{text-align:center;margin-top:36px}

/* ================================================================
   CLIENT REVIEW
   ================================================================ */
.cr-section{
  position:relative;height:520px;
  background:url('https://images.unsplash.com/photo-1600210492486-724fe5c67fb0?w=1920&q=50&auto=format&fit=crop') center/cover no-repeat;
  display:flex;align-items:center;overflow:hidden;
}
.cr-overlay{position:absolute;inset:0;background:rgba(5,9,20,.84)}
.cr-inner{
  position:relative;z-index:2;width:100%;
  height:100%;
  padding:clamp(40px,5vw,70px) 0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
}
.cr-track{width:100%;max-width:720px;text-align:center;padding:0 20px}
.cr-slide{display:none}
.cr-slide.on{display:block}
/* review card entrance animation */
@keyframes cr-card-in{from{opacity:0;transform:translateY(32px) scale(.97)}to{opacity:1;transform:none}}
@keyframes cr-fade-up{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.cr-section.cr-seen .cr-slide.on .cr-card{animation:cr-card-in .7s cubic-bezier(.22,.8,.2,1) both}
.cr-section.cr-seen .cr-slide.on .cr-card > *:nth-child(1){animation:cr-fade-up .8s ease .10s both}
.cr-section.cr-seen .cr-slide.on .cr-card > *:nth-child(2){animation:cr-fade-up .8s ease .24s both}
.cr-section.cr-seen .cr-slide.on .cr-card > *:nth-child(3){animation:cr-fade-up .8s ease .38s both}
.cr-section.cr-seen .cr-slide.on .cr-card > *:nth-child(4){animation:cr-fade-up .8s ease .54s both}
.cr-card{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius-lg);padding:clamp(24px,3vw,40px) clamp(24px,4vw,52px);
  backdrop-filter:blur(6px);
}
.cr-label{
  font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.45);margin-bottom:16px;
}
.cr-rule{width:36px;height:1px;background:rgba(255,255,255,.3);margin:0 auto 26px}
.cr-track blockquote{
  font-family:'Fraunces',serif;font-size:clamp(17px,1.6vw,22px);
  color:#fff;line-height:1.65;font-style:italic;margin:0 0 18px;
}
.cr-track cite{font-style:normal;font-size:13px;color:rgba(255,255,255,.5)}
.cr-arr{
  position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  color:#fff;display:grid;place-items:center;cursor:pointer;
  transition:background .2s;
}
.cr-arr:hover{background:rgba(255,255,255,.18)}
.cr-arr svg{width:18px;height:18px}
.cr-prev{left:clamp(12px,4vw,60px)}
.cr-next{right:clamp(12px,4vw,60px)}
.cr-dots{display:flex;gap:8px;margin-top:24px}
.crd{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,.25);cursor:pointer;padding:0;
  transition:background .3s;
}
.crd.on{background:#fff}

/* ================================================================
   RESPONSIVE — TABLET + MOBILE
   ================================================================ */
@media(max-width:960px){
  .hs-content-jeff{flex-direction:column;text-align:center}
  .hs-jeff-video{flex:none;width:100%;max-width:500px;margin:0 auto}
  .ma-grid{grid-template-columns:1fr;gap:40px}
  .ma-img{order:-1}
  .ma-about-logo{max-width:100%}
  .jb-grid{grid-template-columns:1fr}
  .wu-grid{grid-template-columns:1fr 1fr}
  /* Services: auto height when stacked */
  .sv-row,.sv-row--flip{grid-template-columns:1fr;height:auto}
  .sv-row--flip .sv-text{order:2}
  .sv-row--flip .sv-img{order:1}
  .sv-img{height:280px;min-height:unset}
  .sv-text{padding:clamp(28px,4vw,48px) clamp(24px,4vw,48px)}
  .sv-text p{max-width:100%}
  .gp-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .gp-tall{grid-row:auto}
  .gp-cell{height:200px}
}
@media(max-width:600px){
  .hs{min-height:500px}
  .hs-content{padding-top:90px;padding-bottom:150px}
  .hs-arr{width:38px;height:38px}
  .hs-arr svg{width:18px;height:18px}
  .hs-prev{left:10px}
  .hs-next{right:10px}
  .wu-grid{grid-template-columns:1fr}
  /* Gallery: true 2-col instagram-style grid, no wide cells */
  .gp-grid{grid-template-columns:1fr 1fr;gap:6px}
  .gp-tall,.gp-wide{grid-row:auto;grid-column:auto}
  .gp-cell{height:150px}
  .cr-arr{display:none}
  .hs-arr{display:none}
  .jb-arr{display:none}
  /* Services mobile */
  .sv-row,.sv-row--flip{grid-template-columns:1fr;height:auto}
  .sv-row--flip .sv-text{order:2}
  .sv-row--flip .sv-img{order:1}
  .sv-img{height:240px}
  /* Jeff Brown: tighter arrows on small screens */
  .jb-video-row{gap:8px}
  .jb-arr{width:32px;height:32px}
  .jb-arr svg{width:14px;height:14px}
  /* Floating CTA: sticky center-bottom on mobile */
  .fab.contact-fab{
    position:fixed;bottom:16px;left:50%;transform:translateX(-50%);
    right:auto;z-index:50;
    box-shadow:0 4px 20px rgba(0,0,0,.35);
  }
  .fab.contact-fab:hover{transform:translateX(-50%) translateY(-3px)}
  .floating{bottom:90px}
  /* Reveal animations: smaller distance on mobile to avoid overflow */
  .reveal-left{transform:translateX(-20px)}
  .reveal-right{transform:translateX(20px)}
  .reveal{transform:translateY(20px)}
}

/* ===== About Us Page ===== */
.ab-banner{position:relative;min-height:clamp(420px,52vh,580px);display:flex;align-items:flex-end;overflow:hidden;padding-bottom:clamp(48px,5vw,80px);padding-top:120px}
.ab-banner-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.ab-banner-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.88) 0%,rgba(0,0,0,.65) 100%)}
.ab-banner-content{position:relative;z-index:2;color:#fff}
.ab-banner-content .eyebrow{color:var(--accent)}
.ab-banner-content .eyebrow::before{background:var(--accent)}
.ab-banner-title{font-size:clamp(40px,6vw,88px);font-weight:300;letter-spacing:-.02em;margin:14px 0 0;color:#fff;line-height:1.05}
@keyframes ab-enter{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
.ab-banner.ab-entering .ab-banner-content .eyebrow{animation:ab-enter .7s ease .10s both}
.ab-banner.ab-entering .ab-banner-content .ab-banner-title{animation:ab-enter .9s cubic-bezier(.22,.8,.2,1) .24s both}
.ab-banner.ab-entering .ab-banner-content .lead{animation:ab-enter .8s ease .42s both}
.ab-banner-content .lead{color:rgba(255,255,255,.75);margin-top:14px;font-size:clamp(15px,1.2vw,18px);max-width:52ch}

.ab-section{background:var(--bg-warm)}
.ab-row{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,72px);align-items:center;
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(56px,7vw,96px) clamp(24px,5vw,80px);
}
.ab-row-flip .ab-img{order:2}
.ab-row-flip .ab-text{order:1}
.ab-img{
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-lg);
  aspect-ratio:4/3;
}
.ab-img img{width:100%;height:100%;object-fit:cover;display:block}
.ab-text{display:flex;flex-direction:column;justify-content:center}
.ab-text .eyebrow{margin-bottom:14px}
.ab-text h2{font-size:clamp(26px,2.8vw,42px);font-weight:300;letter-spacing:-.02em;margin-bottom:20px}
.ab-text p{color:var(--muted);font-size:17px;line-height:1.7;margin-bottom:16px;max-width:48ch}

@media(max-width:768px){
  .ab-row,.ab-row-flip{grid-template-columns:1fr;padding:40px 24px;gap:24px}
  .ab-row-flip .ab-img,.ab-row-flip .ab-text{order:unset}
}

/* ===== Services Page ===== */
.svc-banner{position:relative;min-height:clamp(420px,52vh,580px);display:flex;align-items:flex-end;overflow:hidden;padding-bottom:clamp(48px,5vw,80px);padding-top:120px}
.svc-banner-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.svc-banner-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.88) 0%,rgba(0,0,0,.65) 100%)}
.svc-banner-content{position:relative;z-index:2;color:#fff}
.svc-banner-content .eyebrow{color:var(--accent)}
.svc-banner-content .eyebrow::before{background:var(--accent)}
.svc-banner-title{font-size:clamp(40px,6vw,88px);font-weight:300;letter-spacing:-.02em;margin:14px 0 0;color:#fff;line-height:1.05}
.svc-banner-content .lead{color:rgba(255,255,255,.75);margin-top:14px;font-size:clamp(15px,1.2vw,18px);max-width:52ch}
@keyframes svc-enter{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
.svc-banner.svc-entering .svc-banner-content .eyebrow{animation:svc-enter .7s ease .10s both}
.svc-banner.svc-entering .svc-banner-content .svc-banner-title{animation:svc-enter .9s cubic-bezier(.22,.8,.2,1) .24s both}
.svc-banner.svc-entering .svc-banner-content .lead{animation:svc-enter .8s ease .42s both}

#page-services .svc-row{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(40px,6vw,80px);border-bottom:1px solid var(--line);max-width:var(--maxw);margin:0 auto;padding:clamp(56px,7vw,96px) clamp(24px,5vw,80px)}
#page-services .svc-row-flip .svc-img{order:2}
#page-services .svc-row-flip .svc-body{order:1}
#page-services .svc-img{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/3}
#page-services .svc-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 6s ease}
#page-services .svc-img:hover img{transform:scale(1.04)}
#page-services .svc-body{display:flex;flex-direction:column;justify-content:flex-start}
.svc-num{font-family:'Manrope',sans-serif;font-size:11px;font-weight:700;letter-spacing:.22em;color:var(--accent);margin-bottom:10px;display:block}
#page-services .svc-body .eyebrow{margin-bottom:10px}
#page-services .svc-body h2{font-size:clamp(24px,2.6vw,40px);font-weight:300;letter-spacing:-.02em;margin-bottom:20px}
#page-services .svc-body p{color:var(--muted);font-size:16px;line-height:1.75;margin-bottom:14px;max-width:50ch}
.svc-list{list-style:none;padding:0;margin:16px 0 28px;display:grid;grid-template-columns:1fr 1fr;gap:8px 16px}
.svc-list li{font-size:14px;color:var(--ink-2);padding-left:18px;position:relative;line-height:1.5}
.svc-list li::before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:var(--accent)}
.svc-cta-btn{align-self:flex-start;margin-top:4px}

.svc-final-cta{background:var(--primary);color:#fff;text-align:center;padding:clamp(64px,8vw,112px) clamp(24px,5vw,80px)}
.svc-final-cta .eyebrow::before{background:var(--accent)}
.svc-final-cta h2{font-size:clamp(30px,4vw,56px);font-weight:300;letter-spacing:-.02em;color:#fff;margin:16px 0 20px}
.svc-final-cta h2 em{color:var(--accent)}
.svc-final-cta p{color:rgba(255,255,255,.7);font-size:clamp(16px,1.2vw,19px);max-width:52ch;margin:0 auto 36px}

@media(max-width:768px){
  #page-services .svc-row{grid-template-columns:1fr;gap:24px;padding:40px 24px}
  #page-services .svc-row-flip .svc-img,#page-services .svc-row-flip .svc-body{order:unset}
  #page-services .svc-img{aspect-ratio:4/3}
  #page-services .svc-body{padding:0}
  .svc-list{grid-template-columns:1fr}
}

/* ===== GALLERY PAGE ===== */
.gal-banner{position:relative;min-height:clamp(400px,50vh,560px);display:flex;align-items:flex-end;overflow:hidden;padding-bottom:clamp(48px,5vw,80px);padding-top:120px}
.gal-banner-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.gal-banner-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.88),rgba(0,0,0,.55))}
.gal-banner-content{position:relative;z-index:1}
.gal-banner-title{font-size:clamp(36px,5vw,72px);font-weight:300;letter-spacing:-.03em;color:#fff;margin:14px 0 20px;line-height:1.1}
.gal-banner-title em{font-style:italic;color:var(--accent)}
.gal-banner .eyebrow{color:rgba(255,255,255,.7)}
.gal-banner .eyebrow::before{background:var(--accent)}
.gal-banner .lead{color:rgba(255,255,255,.75);max-width:52ch;font-size:clamp(15px,1.1vw,18px)}

@keyframes gal-enter{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
.gal-banner-content .eyebrow,
.gal-banner-content .gal-banner-title,
.gal-banner-content .lead{opacity:0}
.gal-banner.gal-entering .gal-banner-content .eyebrow{animation:gal-enter .7s ease .10s both}
.gal-banner.gal-entering .gal-banner-content .gal-banner-title{animation:gal-enter .9s cubic-bezier(.22,.8,.2,1) .24s both}
.gal-banner.gal-entering .gal-banner-content .lead{animation:gal-enter .8s ease .42s both}

.gal-item{opacity:0;transform:translateY(18px);transition:opacity .55s ease var(--d,0s),transform .55s ease var(--d,0s)}
.gal-item.in{opacity:1;transform:none}

.gal-intro{padding:clamp(48px,6vw,80px) clamp(24px,5vw,80px);border-bottom:1px solid var(--line)}
.gal-intro .container{max-width:780px}
.gal-intro-lead{font-size:clamp(18px,1.5vw,22px);font-weight:300;color:var(--ink);line-height:1.65;margin-bottom:20px;letter-spacing:-.01em}
.gal-intro p{color:var(--muted);font-size:clamp(15px,1.1vw,17px);line-height:1.8;margin:0}

.gal-grid{display:flex;flex-wrap:wrap;gap:4px;align-items:stretch}
.gal-item{height:clamp(160px,18vw,260px);overflow:hidden;cursor:pointer;flex-grow:1;min-width:120px}
.gal-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.gal-item:hover img{transform:scale(1.05)}

.gal-cta{background:var(--bg-warm);text-align:center;padding:clamp(64px,8vw,112px) clamp(24px,5vw,80px);border-top:1px solid var(--line)}
.gal-cta h2{font-size:clamp(28px,3.5vw,52px);font-weight:300;letter-spacing:-.02em;margin-bottom:16px}
.gal-cta h2 em{color:var(--accent)}
.gal-cta p{color:var(--muted);font-size:clamp(15px,1.1vw,18px);max-width:48ch;margin:0 auto 36px}

@media(max-width:600px){
  .gal-item{height:140px;min-width:90px}
}

/* ===== CONTACT PAGE BANNER ===== */
@keyframes ct-enter{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
.ct-banner{position:relative;min-height:clamp(420px,55vh,600px);display:flex;align-items:flex-end;overflow:hidden;padding-bottom:clamp(56px,6vw,96px);padding-top:120px}
.ct-banner-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.ct-banner-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.82) 40%,rgba(0,0,0,.55))}
.ct-banner-content{position:relative;z-index:1;max-width:720px}
.ct-banner-title{font-size:clamp(38px,6vw,82px);font-weight:300;letter-spacing:-.03em;color:#fff;margin:14px 0 22px;line-height:1.05}
.ct-banner-title em{font-style:italic;color:var(--accent)}
.ct-banner .eyebrow{color:rgba(255,255,255,.7)}
.ct-banner .eyebrow::before{background:var(--accent)}
.ct-banner .lead{color:rgba(255,255,255,.75);max-width:54ch;font-size:clamp(15px,1.1vw,18px);margin-bottom:28px}
.ct-banner-actions{display:flex;gap:12px;flex-wrap:wrap}
.ct-banner-content .eyebrow,
.ct-banner-content .ct-banner-title,
.ct-banner-content .lead,
.ct-banner-content .ct-banner-actions{opacity:0}
.ct-banner.ct-entering .ct-banner-content .eyebrow{animation:ct-enter .7s ease .10s both}
.ct-banner.ct-entering .ct-banner-content .ct-banner-title{animation:ct-enter .9s cubic-bezier(.22,.8,.2,1) .24s both}
.ct-banner.ct-entering .ct-banner-content .lead{animation:ct-enter .8s ease .40s both}
.ct-banner.ct-entering .ct-banner-content .ct-banner-actions{animation:ct-enter .7s ease .56s both}

/* ===== BLOG PAGE ===== */
@keyframes blog-enter{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
.blog-banner{position:relative;min-height:clamp(400px,52vh,560px);display:flex;align-items:flex-end;overflow:hidden;padding-bottom:clamp(48px,5vw,80px);padding-top:120px}
.blog-banner-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.blog-banner-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.9),rgba(0,0,0,.55))}
.blog-banner-content{position:relative;z-index:1}
.blog-banner-title{font-size:clamp(36px,5vw,72px);font-weight:300;letter-spacing:-.03em;color:#fff;margin:14px 0 20px;line-height:1.1}
.blog-banner-title em{font-style:italic;color:var(--accent)}
.blog-banner .eyebrow{color:rgba(255,255,255,.7)}
.blog-banner .eyebrow::before{background:var(--accent)}
.blog-banner .lead{color:rgba(255,255,255,.75);max-width:54ch;font-size:clamp(15px,1.1vw,18px)}
.blog-banner-content .eyebrow,
.blog-banner-content .blog-banner-title,
.blog-banner-content .lead{opacity:0}
.blog-banner.blog-entering .blog-banner-content .eyebrow{animation:blog-enter .7s ease .10s both}
.blog-banner.blog-entering .blog-banner-content .blog-banner-title{animation:blog-enter .9s cubic-bezier(.22,.8,.2,1) .24s both}
.blog-banner.blog-entering .blog-banner-content .lead{animation:blog-enter .8s ease .42s both}

.blog-section{padding:clamp(56px,7vw,96px) 0}

/* ── Blog grid — library style ── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.blog-card{border-radius:12px;overflow:hidden;background:#fff;border:1px solid var(--line);display:flex;flex-direction:column;opacity:0;transform:translateY(16px);transition:opacity .5s ease var(--d,0s),transform .5s ease var(--d,0s),border-color .2s,box-shadow .2s}
.blog-card.in{opacity:1;transform:none}
.blog-card:hover{border-color:var(--accent);box-shadow:0 4px 20px rgba(245,184,0,.15)}

/* Thumbnail — compact */
.blog-thumb{height:160px;overflow:hidden;background:var(--bg-warm);flex-shrink:0}
.blog-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.blog-card:hover .blog-thumb img{transform:scale(1.05)}

/* Color block when no image */
.blog-thumb-color{height:80px;background:linear-gradient(135deg,var(--primary) 0%,#2d3f6e 100%);display:flex;align-items:center;padding:0 18px}
.blog-thumb-cat{font-family:'Manrope',sans-serif;font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.6)}

/* Card body */
.blog-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.blog-meta{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.blog-tag{font-family:'Manrope',sans-serif;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:rgba(245,184,0,.1);padding:3px 9px;border-radius:20px}
.blog-date{font-family:'Manrope',sans-serif;font-size:11px;font-weight:500;color:var(--muted)}
.blog-card h3{font-size:16px;font-weight:600;letter-spacing:-.01em;line-height:1.4;margin-bottom:8px;color:var(--ink)}
.blog-card h3 a{color:inherit;text-decoration:none}
.blog-card h3 a:hover{color:var(--accent)}
.blog-excerpt{font-size:13px;color:var(--muted);line-height:1.65;flex:1;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.blog-read-more{align-self:flex-start;font-family:'Manrope',sans-serif;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--primary);text-decoration:none;display:flex;align-items:center;gap:5px;transition:gap .2s,color .2s}
.blog-read-more:hover{color:var(--accent);gap:9px}
.blog-read-more svg{width:12px;height:12px;flex-shrink:0}

.blog-loading{grid-column:1/-1;display:flex;flex-direction:column;align-items:center;gap:16px;padding:80px 0;color:var(--muted)}
.blog-spinner{width:36px;height:36px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.blog-error{text-align:center;padding:60px 0;color:var(--muted)}
.blog-error a{color:var(--accent)}

@media(max-width:900px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.blog-grid{grid-template-columns:1fr}}

/* ===== Blog post view ===== */
.blog-post-view{padding:clamp(48px,6vw,80px) 0 clamp(64px,8vw,96px)}
.bpv-back{background:none;border:none;cursor:pointer;font-family:'Manrope',sans-serif;font-size:14px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--primary);display:inline-flex;align-items:center;gap:8px;padding:0;margin-bottom:clamp(40px,5vw,64px);transition:gap .2s,color .2s}
.bpv-back:hover{color:var(--accent);gap:14px}
.bpv-back svg{width:18px;height:18px;flex-shrink:0}
.bpv-article{max-width:760px;margin:0 auto}
.bpv-header{margin-bottom:clamp(28px,3vw,44px)}
.bpv-header .blog-meta{margin-bottom:16px}
.bpv-header h1{font-size:clamp(28px,4vw,54px);font-weight:300;letter-spacing:-.03em;line-height:1.15;margin:0;color:var(--ink)}
.bpv-hero-img{width:100%;border-radius:var(--radius-lg);margin-bottom:clamp(32px,4vw,52px);object-fit:cover;max-height:500px;display:block}
.bpv-body{font-size:clamp(16px,1.1vw,18px);line-height:1.8;color:var(--ink-2)}
.bpv-body h2{font-family:'Fraunces',Georgia,serif;font-size:clamp(20px,2vw,30px);font-weight:400;letter-spacing:-.02em;color:var(--ink);margin:clamp(36px,4vw,52px) 0 16px;padding-top:clamp(36px,4vw,52px);border-top:1px solid var(--line)}
.bpv-body h3{font-family:'Fraunces',Georgia,serif;font-size:clamp(18px,1.6vw,24px);font-weight:400;color:var(--ink);margin:28px 0 12px}
.bpv-body p{margin:0 0 24px}
.bpv-body ul,.bpv-body ol{margin:0 0 24px 24px;line-height:1.8}
.bpv-body li{margin-bottom:8px}
.bpv-body strong{font-weight:700;color:var(--ink)}
.bpv-body em{font-style:italic}
.bpv-body a{color:var(--accent);text-decoration:underline}
.bpv-body blockquote{border-left:3px solid var(--accent);padding:12px 20px;margin:0 0 24px;background:var(--bg-warm);border-radius:0 8px 8px 0;font-style:italic;color:var(--muted)}

/* ── Likes ── */
.bpv-reactions{padding:clamp(28px,3vw,44px) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-top:clamp(32px,4vw,52px)}
.bpv-like-btn{display:inline-flex;align-items:center;gap:10px;background:none;border:2px solid var(--line);border-radius:100px;padding:12px 24px;font-family:'Manrope',sans-serif;font-size:15px;font-weight:700;color:var(--muted);cursor:pointer;transition:all .2s}
.bpv-like-btn svg{width:20px;height:20px;flex-shrink:0;transition:all .2s}
.bpv-like-btn:hover{border-color:#e8a0b0;color:#c0394d}
.bpv-like-btn:hover svg{stroke:#c0394d}
.bpv-like-btn.liked{border-color:#e8a0b0;color:#c0394d;background:#fff0f3}
.bpv-like-btn.liked svg{fill:#c0394d;stroke:#c0394d}

/* ── Comments ── */
.bpv-comments{padding:clamp(36px,4vw,56px) 0 0}
.bpv-comments-title{font-size:clamp(18px,1.8vw,24px);font-weight:400;letter-spacing:-.02em;margin-bottom:clamp(24px,3vw,36px);color:var(--ink)}
.bpv-comment{padding:clamp(18px,2.5vw,28px);background:var(--bg-warm);border-radius:var(--radius);margin-bottom:16px}
.bpv-comment-head{display:flex;align-items:center;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.bpv-comment-name{font-family:'Manrope',sans-serif;font-weight:700;font-size:14px;color:var(--ink)}
.bpv-comment-date{font-family:'Manrope',sans-serif;font-size:12px;color:var(--muted)}
.bpv-comment-body{font-size:15px;color:var(--ink-2);line-height:1.7}
.bpv-no-comments{color:var(--muted);font-size:14px;margin-bottom:32px}
.bpv-comment-form-wrap{margin-top:clamp(32px,4vw,48px);padding:clamp(24px,3vw,40px);background:var(--bg-warm);border-radius:var(--radius-lg)}
.bpv-comment-form-wrap h4{font-size:clamp(16px,1.4vw,20px);font-weight:400;letter-spacing:-.01em;margin-bottom:24px;color:var(--ink)}
.bpv-cf-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.bpv-cf-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.bpv-cf-field label{font-family:'Manrope',sans-serif;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.bpv-cf-field input,.bpv-cf-field textarea{width:100%;padding:11px 14px;border:1.5px solid var(--line);border-radius:10px;font-family:'Manrope',sans-serif;font-size:14px;color:var(--ink);outline:none;background:#fff;transition:border .2s;resize:vertical}
.bpv-cf-field input:focus,.bpv-cf-field textarea:focus{border-color:var(--primary)}
@media(max-width:600px){.bpv-cf-row{grid-template-columns:1fr}}

.blog-cta{position:relative;background:var(--primary) center/cover no-repeat;text-align:center;padding:clamp(64px,8vw,96px) clamp(24px,5vw,80px);overflow:hidden}
.blog-cta-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.75) 0%,rgba(0,0,0,.55) 100%);z-index:0}
.blog-cta .container{position:relative;z-index:1}
.blog-cta .eyebrow{color:var(--accent)}
.blog-cta .eyebrow::before{background:var(--accent)}
.blog-cta h2{font-size:clamp(28px,3.5vw,52px);font-weight:300;color:#fff;letter-spacing:-.02em;margin:16px 0 32px}
.blog-cta h2 em{color:var(--accent)}

@media(max-width:900px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
