/* ═══════════════════════════════════════════════════════════
   SHREYA PAINTING WORKS · style.css
   Aesthetic: Warm Editorial — Espresso · Amber · Blush
   Fonts: Fraunces (display) + Outfit (body)
═══════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,600;0,9..144,700;0,9..144,900;1,9..144,400;1,9..144,600&family=Outfit:wght@300;400;500;600;700&display=swap');

:root {
  --espresso:#1C0D03;  --espresso-mid:#2A1507;  --espresso-lt:#3D2010;
  --amber:#C8800A;     --amber-lt:#E8A020;       --amber-pale:#FFF6E8;
  --rose:#D4298C;      --rose-lt:#F050B0;        --rose-pale:#FFF0F8;
  --cream:#FAF5EE;     --cream-dk:#F2EAE0;       --white:#FFFFFF;
  --ink:#1A0A00;       --ink-mid:#3D2A18;        --muted:#7A6858;
  --border:#E8DDD0;    --border-warm:#D8C8B0;
  --sh-xs:0 1px 6px rgba(28,13,3,.08);
  --sh-sm:0 4px 20px rgba(28,13,3,.10);
  --sh-md:0 12px 40px rgba(28,13,3,.14);
  --sh-lg:0 24px 80px rgba(28,13,3,.20);
  --sh-amber:0 8px 32px rgba(200,128,10,.38);
  --sh-rose:0 6px 24px rgba(212,41,140,.30);
  --r:14px; --r-sm:8px; --r-lg:22px; --r-xl:32px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Outfit',system-ui,sans-serif;background:var(--cream);
  color:var(--ink);padding-bottom:80px;-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;display:block;}
a{text-decoration:none;}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}
.d1{transition-delay:.08s;}.d2{transition-delay:.18s;}.d3{transition-delay:.28s;}.d4{transition-delay:.38s;}.d5{transition-delay:.48s;}

/* ══════════════ NAV ══════════════ */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;
  background:var(--espresso);
  border-bottom:2px solid rgba(200,128,10,.25);
  box-shadow:0 2px 32px rgba(28,13,3,.50);}
.nav-inner{position:relative;display:flex;align-items:center;
  justify-content:space-between;padding:10px 18px;flex-wrap:nowrap;}
.nav-brand{display:flex;align-items:center;gap:10px;text-decoration:none;}
.nav-logo{width:42px;height:42px;border-radius:50%;object-fit:cover;
  border:2px solid rgba(200,128,10,.45);flex-shrink:0;}
.nav-name{display:flex;flex-direction:column;line-height:1.18;}
.nav-title{font-family:'Fraunces',serif;font-size:14px;font-weight:700;color:#fff;letter-spacing:.2px;}
.nav-sub{font-size:9px;font-weight:500;color:var(--amber-lt);text-transform:uppercase;letter-spacing:1.4px;}
.hamburger{width:44px;height:44px;border-radius:var(--r-sm);
  background:rgba(200,128,10,.12);border:1.5px solid rgba(200,128,10,.30);
  cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;
  transition:background .2s;}
.hamburger:hover{background:rgba(200,128,10,.25);}
.hamburger span{display:block;width:20px;height:2px;background:var(--amber-lt);border-radius:2px;transition:all .3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.nav-menu{display:none;flex-direction:column;gap:6px;
  position:absolute;top:100%;left:0;right:0;
  background:var(--espresso-mid);border-top:1px solid rgba(255,255,255,.08);
  padding:12px 16px 16px;z-index:999;}
.nav-menu.open{display:flex;}
.nav-item{display:block;padding:12px 18px;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);color:rgba(255,255,255,.80);
  text-decoration:none;border-radius:var(--r-sm);font-weight:500;font-size:14px;
  text-align:center;margin-bottom:7px;transition:background .2s,color .2s;}
.nav-item:last-child{margin-bottom:0;}
.nav-item:hover{background:rgba(200,128,10,.18);color:#fff;}
.nav-item.active{background:var(--amber);color:var(--espresso);font-weight:700;}

/* ══════════════ HERO ══════════════ */
.hero{position:relative;min-height:70vh;display:flex;align-items:flex-end;overflow:hidden;
  padding-top:62px;}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 30%;
  transform:scale(1.04);}
.hero-overlay{position:absolute;inset:0;
  background:linear-gradient(180deg,
    rgba(10,5,2,.75) 0%,
    rgba(10,5,2,.70) 30%,
    rgba(10,5,2,.82) 65%,
    rgba(10,5,2,.96) 100%);}
.hero-overlay-side{position:absolute;inset:0;
  background:radial-gradient(ellipse at 90% 40%,rgba(200,128,10,.12) 0%,transparent 60%);}
.hero-content{position:relative;z-index:2;padding:0 22px 52px;width:100%;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;margin-bottom:16px;
  background:rgba(200,128,10,.15);border:1px solid rgba(200,128,10,.40);
  color:var(--amber-lt);font-size:10px;font-weight:600;letter-spacing:2.5px;
  text-transform:uppercase;padding:5px 14px;border-radius:50px;}
.hero h1{font-family:'Fraunces',serif;font-size:clamp(36px,10vw,64px);font-weight:900;
  color:#fff;line-height:1.06;margin-bottom:16px;letter-spacing:-.5px;}
.hero h1 .line-accent{color:var(--amber-lt);font-style:italic;font-weight:600;}
.hero-sub{font-size:15px;color:rgba(255,255,255,.75);line-height:1.7;
  max-width:380px;margin-bottom:28px;}
.hero-chips{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:28px;}
.hero-chip{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.80);font-size:11px;padding:6px 14px;border-radius:50px;font-weight:500;}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px;}
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:15px 28px;
  background:var(--amber);color:var(--espresso);font-weight:700;font-size:14px;
  border-radius:50px;box-shadow:var(--sh-amber);transition:transform .2s,box-shadow .2s;}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 14px 44px rgba(200,128,10,.55);}
.btn-outline{display:inline-flex;align-items:center;gap:8px;padding:14px 26px;
  background:transparent;border:2px solid rgba(255,255,255,.38);
  color:rgba(255,255,255,.90);font-weight:600;font-size:14px;border-radius:50px;
  transition:border-color .2s,background .2s,transform .2s;}
.btn-outline:hover{border-color:var(--amber-lt);background:rgba(200,128,10,.14);transform:translateY(-3px);}
/* Diagonal cut at hero bottom */
.hero-cut{position:absolute;bottom:-2px;left:0;right:0;height:60px;
  background:var(--cream);clip-path:polygon(0 100%,100% 0,100% 100%);}

/* ══════════════ STATS ══════════════ */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);
  background:var(--espresso);border-bottom:3px solid var(--amber);}
.stat-cell{text-align:center;padding:20px 8px;border-right:1px solid rgba(255,255,255,.08);}
.stat-cell:last-child{border-right:none;}
.stat-n{font-family:'Fraunces',serif;font-size:clamp(26px,5vw,36px);font-weight:900;
  color:var(--amber-lt);line-height:1;}
.stat-l{font-size:9px;color:rgba(255,255,255,.55);margin-top:5px;
  font-weight:600;text-transform:uppercase;letter-spacing:1px;}

/* ══════════════ SECTION BASE ══════════════ */
.section{padding:50px 20px 10px;}
.eyebrow{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:10px;}
.eyebrow-bar{width:28px;height:2px;background:var(--amber);border-radius:2px;}
.eyebrow-txt{font-size:10px;font-weight:700;letter-spacing:2.5px;color:var(--amber);text-transform:uppercase;}
.section-h{font-family:'Fraunces',serif;font-size:clamp(28px,7vw,40px);font-weight:700;
  color:var(--espresso);text-align:center;line-height:1.18;margin-bottom:8px;}
.section-h em{color:var(--amber);font-style:italic;}
.section-p{text-align:center;font-size:14px;color:var(--muted);line-height:1.75;
  max-width:400px;margin:0 auto 28px;}

/* ══════════════ DIVIDERS ══════════════ */
.divider{height:1px;
  background:linear-gradient(to right,transparent,rgba(200,128,10,.22),transparent);
  margin:36px 20px;}
.divider-dark{height:1px;
  background:linear-gradient(to right,transparent,rgba(255,255,255,.10),transparent);
  margin:24px 16px;}

/* ══════════════ SERVICE CARDS ══════════════ */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:0 16px 8px;}
.svc-card{background:var(--white);border-radius:var(--r);overflow:hidden;
  border:1.5px solid var(--border);box-shadow:var(--sh-xs);
  display:flex;flex-direction:column;position:relative;
  transition:transform .3s,box-shadow .3s,border-color .3s;
  -webkit-mask-image:-webkit-radial-gradient(white,black);}
.svc-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--amber),var(--rose));
  transform:scaleX(0);transform-origin:left;transition:transform .4s;z-index:2;}
.svc-card:hover{transform:translateY(-7px);box-shadow:var(--sh-md);border-color:var(--border-warm);}
.svc-card:hover::after{transform:scaleX(1);}
.svc-thumb{position:relative;height:115px;overflow:hidden;}
.svc-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s;}
.svc-card:hover .svc-thumb img{transform:scale(1.12);}
.svc-badge{position:absolute;top:8px;left:8px;background:var(--espresso);color:white;
  width:30px;height:30px;border-radius:8px;display:flex;align-items:center;
  justify-content:center;font-size:14px;box-shadow:var(--sh-sm);z-index:2;}
.svc-overlay{position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(to top,rgba(28,13,3,.85) 0%,transparent 100%);padding:18px 8px 8px;}
.svc-overlay span{color:#fff;font-size:11px;font-weight:700;display:block;text-align:center;
  text-transform:uppercase;letter-spacing:.8px;}
.svc-link{display:block;width:100%;padding:10px;background:var(--espresso);color:white;
  font-size:10px;font-weight:700;text-align:center;text-transform:uppercase;letter-spacing:1.2px;
  transition:background .2s;}
.svc-link:hover{background:var(--amber);color:var(--espresso);}

/* ══════════════ BENEFIT PANEL ══════════════ */
.benefit-panel{margin:0 16px;background:var(--espresso);border-radius:var(--r-lg);
  position:relative;overflow:hidden;}
.benefit-panel::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--amber),var(--rose),var(--amber),transparent);}
.benefit-inner{padding:30px 20px 28px;}
.benefit-h{font-family:'Fraunces',serif;font-size:clamp(22px,5vw,28px);font-weight:700;
  color:#fff;text-align:center;margin-bottom:6px;}
.benefit-h em{color:var(--amber-lt);font-style:italic;}
.benefit-sub{font-size:13px;color:rgba(255,255,255,.55);text-align:center;margin-bottom:22px;}
.benefit-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.bitem{display:flex;align-items:flex-start;gap:10px;
  background:rgba(255,255,255,.04);border:1px solid rgba(200,128,10,.14);
  border-radius:11px;padding:13px;transition:background .25s;}
.bitem:hover{background:rgba(200,128,10,.09);}
.btick{width:20px;height:20px;border-radius:50%;background:var(--amber);
  color:var(--espresso);display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:900;flex-shrink:0;margin-top:1px;}
.bitem p{font-size:12px;color:rgba(255,255,255,.78);line-height:1.55;}

/* ══════════════ WHY CARDS ══════════════ */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 16px;}
.why-card{background:var(--white);border-radius:var(--r);padding:20px 16px;
  border:1.5px solid var(--border);box-shadow:var(--sh-xs);position:relative;
  overflow:hidden;transition:transform .3s,box-shadow .3s;}
.why-card:hover{transform:translateY(-5px);box-shadow:var(--sh-md);}
.why-num{font-family:'Fraunces',serif;font-size:56px;font-weight:900;
  color:rgba(200,128,10,.07);position:absolute;top:4px;right:10px;line-height:1;}
.why-icon{width:46px;height:46px;border-radius:12px;background:var(--amber-pale);
  border:1.5px solid var(--border-warm);display:flex;align-items:center;
  justify-content:center;font-size:22px;margin-bottom:12px;}
.why-card h4{font-size:14px;font-weight:700;color:var(--espresso);margin-bottom:6px;}
.why-card p{font-size:12px;color:var(--muted);line-height:1.65;}

/* ══════════════ PROJECTS STRIP ══════════════ */
.proj-strip{padding:0 16px;}
.proj-card{background:var(--white);border-radius:var(--r);overflow:hidden;
  border:1.5px solid var(--border);box-shadow:var(--sh-xs);margin-bottom:12px;
  position:relative;transition:transform .3s,box-shadow .3s;
  -webkit-mask-image:-webkit-radial-gradient(white,black);}
.proj-card:hover{transform:translateY(-5px);box-shadow:var(--sh-md);}
.proj-img{height:180px;overflow:hidden;}
.proj-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s;}
.proj-card:hover .proj-img img{transform:scale(1.08);}
.proj-meta{padding:14px 16px 16px;}
.proj-cat{font-size:10px;font-weight:700;color:var(--amber);text-transform:uppercase;
  letter-spacing:1.5px;margin-bottom:4px;}
.proj-name{font-family:'Fraunces',serif;font-size:17px;font-weight:700;color:var(--espresso);margin-bottom:4px;}
.proj-loc{font-size:12px;color:var(--muted);}
.proj-tag{display:inline-block;background:var(--espresso);color:var(--amber-lt);
  font-size:9px;font-weight:700;padding:3px 10px;border-radius:50px;margin-top:8px;
  text-transform:uppercase;letter-spacing:.8px;}

/* ══════════════ TESTIMONIALS ══════════════ */
.testi-stack{padding:0 16px;display:flex;flex-direction:column;gap:13px;}
.tcard{background:var(--white);border-radius:var(--r);padding:20px;
  border:1.5px solid var(--border);box-shadow:var(--sh-xs);position:relative;overflow:hidden;
  transition:transform .3s,box-shadow .3s;}
.tcard:hover{transform:translateY(-4px);box-shadow:var(--sh-sm);}
.tcard::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--amber),var(--rose));}
.tcard-stars{color:var(--amber);font-size:13px;letter-spacing:2px;margin-bottom:8px;}
.tcard-quote{font-family:'Fraunces',serif;font-size:58px;color:var(--amber);
  line-height:.5;margin-bottom:8px;display:block;opacity:.35;}
.tcard-body{font-family:'Fraunces',serif;font-size:15px;color:var(--ink-mid);
  line-height:1.75;font-style:italic;margin-bottom:14px;}
.tcard-foot{display:flex;align-items:center;gap:10px;}
.tcard-av{width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,var(--espresso),var(--espresso-lt));
  display:flex;align-items:center;justify-content:center;
  color:var(--amber-lt);font-weight:700;font-size:12px;
  font-family:'Fraunces',serif;border:2px solid var(--border-warm);flex-shrink:0;}
.tcard-name{font-size:13px;font-weight:700;color:var(--espresso);}
.tcard-role{font-size:11px;color:var(--muted);margin-top:2px;}

/* ══════════════ FAQ ══════════════ */
.faq-wrap{padding:0 16px;}
.faq-item{background:var(--white);border-radius:var(--r);border:1.5px solid var(--border);
  box-shadow:var(--sh-xs);margin-bottom:9px;overflow:hidden;transition:border-color .25s;}
.faq-item.open{border-color:var(--amber);}
.faq-btn{width:100%;display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:16px 18px;background:none;border:none;cursor:pointer;text-align:left;
  font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;color:var(--espresso);
  line-height:1.45;transition:background .2s;}
.faq-btn:hover,.faq-item.open .faq-btn{background:var(--amber-pale);}
.faq-arrow{font-size:18px;color:var(--amber);flex-shrink:0;transition:transform .3s;}
.faq-item.open .faq-arrow{transform:rotate(180deg);}
.faq-body{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s;padding:0 18px;}
.faq-item.open .faq-body{max-height:300px;padding:4px 18px 18px;}
.faq-body p{font-size:14px;color:var(--muted);line-height:1.80;
  border-top:1px solid var(--border-warm);padding-top:12px;}

/* ══════════════ MAP / ADDRESS ══════════════ */
.addr-card{margin:0 16px;background:var(--white);border-radius:var(--r);padding:20px;
  border:1.5px solid var(--border);box-shadow:var(--sh-xs);display:flex;gap:14px;}
.addr-icon{width:44px;height:44px;border-radius:11px;background:var(--amber-pale);
  border:1.5px solid var(--border-warm);display:flex;align-items:center;
  justify-content:center;font-size:20px;flex-shrink:0;}
.addr-heading{font-family:'Fraunces',serif;font-size:17px;font-weight:700;
  color:var(--espresso);margin-bottom:5px;}
.addr-body{font-size:13px;color:var(--muted);line-height:1.85;}
.map-frame{margin:0 16px;border-radius:var(--r-lg);overflow:hidden;
  border:4px solid var(--espresso);
  box-shadow:0 0 0 3px var(--amber),var(--sh-lg);
  -webkit-mask-image:-webkit-radial-gradient(white,black);
  transform:translateZ(0);position:relative;}
.map-frame iframe{display:block;width:100%;height:280px;border:none;}
.map-caption{position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(to top,rgba(28,13,3,.90),transparent);
  color:white;text-align:center;font-size:12px;font-weight:600;padding:28px 16px 12px;}
.mc{position:absolute;width:14px;height:14px;border-color:var(--amber);border-style:solid;}
.mc-tl{top:6px;left:6px;border-width:2px 0 0 2px;}
.mc-tr{top:6px;right:6px;border-width:2px 2px 0 0;}
.mc-bl{bottom:6px;left:6px;border-width:0 0 2px 2px;}
.mc-br{bottom:6px;right:6px;border-width:0 2px 2px 0;}

/* ══════════════ SEO BLOCK ══════════════ */
.seo-wrap{padding:0 16px 8px;}
.seo-inner{background:var(--white);border-radius:var(--r);padding:22px;
  border:1.5px solid var(--border);box-shadow:var(--sh-xs);}
.seo-inner p{font-size:14px;color:var(--muted);line-height:1.85;margin-bottom:12px;}
.seo-inner p:last-child{margin-bottom:0;}
.seo-inner strong{color:var(--ink);}

/* ══════════════ PAGE INTERIOR ══════════════ */
.page-hero{padding:88px 22px 44px;text-align:center;position:relative;overflow:hidden;
  background:var(--espresso);}
.page-hero::before{content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(6,2,0,.82) 0%,rgba(6,2,0,.88) 55%,rgba(6,2,0,.97) 100%);
  pointer-events:none;}
.page-hero>*{position:relative;z-index:1;}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;
  filter:brightness(0.60);}
.breadcrumb{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:14px;flex-wrap:wrap;}
.breadcrumb a{color:rgba(255,255,255,.50);font-size:11px;transition:color .2s;}
.breadcrumb a:hover{color:var(--amber-lt);}
.breadcrumb span{color:rgba(255,255,255,.25);font-size:11px;}
.breadcrumb strong{color:var(--amber-lt);font-size:11px;}
.page-hero h1{font-family:'Fraunces',serif;font-size:clamp(28px,8vw,44px);
  font-weight:700;color:#fff;line-height:1.15;margin-bottom:12px;}
.page-hero h1 em{color:var(--amber-lt);font-style:italic;}
.page-hero p{color:rgba(255,255,255,.70);font-size:14px;max-width:400px;margin:0 auto 22px;line-height:1.7;}

.page-wrap{padding:0 16px 24px;max-width:820px;margin:0 auto;}
.acard{background:var(--white);border-radius:var(--r);padding:22px 18px;margin-bottom:13px;
  border:1.5px solid var(--border);box-shadow:var(--sh-xs);transition:transform .28s,box-shadow .28s;}
.acard:hover{transform:translateY(-3px);box-shadow:var(--sh-sm);}
.acard h3{font-family:'Fraunces',serif;font-size:20px;font-weight:700;
  color:var(--espresso);margin-bottom:10px;}
.acard p{font-size:14px;color:var(--muted);line-height:1.80;}
.acard ul{list-style:none;padding:0;margin-top:12px;}
.acard ul li{background:var(--amber-pale);border-left:3px solid var(--amber);
  border-radius:7px;padding:9px 13px;margin-bottom:6px;font-size:14px;color:var(--ink);}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-top:14px;}
.val-box{background:var(--cream-dk);border:1.5px solid var(--border-warm);
  border-radius:var(--r-sm);padding:15px 12px;text-align:center;
  transition:border-color .2s,transform .2s;}
.val-box:hover{border-color:var(--amber);transform:scale(1.03);}
.val-icon{font-size:28px;margin-bottom:7px;}
.val-box h4{font-size:13px;color:var(--espresso);font-weight:700;margin-bottom:4px;}
.val-box p{font-size:12px;color:var(--muted);line-height:1.5;}

.track-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:14px;}
.track-box{background:var(--amber-pale);border:1.5px solid var(--border-warm);
  border-radius:var(--r-sm);padding:16px;text-align:center;}
.track-n{font-family:'Fraunces',serif;font-size:32px;font-weight:900;color:var(--espresso);line-height:1;}
.track-l{font-size:11px;color:var(--muted);margin-top:5px;font-weight:600;
  text-transform:uppercase;letter-spacing:.7px;}

.btn-dark{display:inline-flex;align-items:center;gap:7px;margin-top:13px;padding:11px 22px;
  background:var(--espresso);color:#fff;border-radius:50px;font-size:13px;font-weight:600;
  transition:background .2s,transform .2s;}
.btn-dark:hover{background:var(--amber);color:var(--espresso);transform:translateY(-2px);}

.cta-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px;}
.cta-box{display:block;text-align:center;padding:14px 8px;border-radius:11px;
  font-weight:700;font-size:13px;line-height:1.5;transition:opacity .2s,transform .2s;}
.cta-box:hover{opacity:.88;transform:translateY(-2px);}
.cta-call{background:var(--espresso);color:#fff;}
.cta-wa{background:#25D366;color:#fff;}

.cmap{border-radius:var(--r);overflow:hidden;border:3px solid var(--espresso);
  box-shadow:0 0 0 2px var(--amber),var(--sh-md);
  -webkit-mask-image:-webkit-radial-gradient(white,black);
  transform:translateZ(0);position:relative;padding-bottom:56%;height:0;}
.cmap iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none;display:block;}

/* ══════════════ SERVICE DETAIL PAGES ══════════════ */
.svc-body{padding:0 16px;max-width:620px;margin:0 auto;}
.svc-section{background:var(--white);border-radius:var(--r);padding:22px;margin:14px 0;
  border:1.5px solid var(--border);box-shadow:var(--sh-xs);}
.svc-section h2{font-family:'Fraunces',serif;font-size:19px;color:var(--espresso);
  margin-bottom:10px;padding-bottom:8px;border-bottom:2px solid var(--border);}
.svc-section h2 span{color:var(--amber);}
.svc-section p{font-size:14px;color:var(--muted);line-height:1.80;margin-bottom:10px;}
.svc-section p:last-child{margin-bottom:0;}
.svc-list{list-style:none;padding:0;margin-top:10px;}
.svc-list li{display:flex;align-items:flex-start;gap:9px;padding:9px 12px;
  background:var(--amber-pale);border-radius:8px;margin-bottom:6px;
  font-size:13.5px;color:var(--ink);border-left:3px solid var(--amber);}
.svc-list li::before{content:'✓';color:var(--amber);font-weight:900;flex-shrink:0;}
.svc-tip{background:linear-gradient(135deg,rgba(200,128,10,.08),rgba(232,160,32,.05));
  border:1.5px solid rgba(200,128,10,.22);border-radius:10px;
  padding:13px 15px;margin:11px 0;font-size:13px;color:var(--ink);line-height:1.65;}
.svc-tip strong{color:var(--amber);}
.svc-cta-box{background:linear-gradient(135deg,var(--espresso),var(--espresso-mid));
  border-radius:var(--r);padding:22px 18px;text-align:center;margin:14px 0;}
.svc-cta-box h3{font-family:'Fraunces',serif;color:var(--amber-lt);font-size:17px;margin-bottom:7px;}
.svc-cta-box p{color:rgba(255,255,255,.68);font-size:13px;margin-bottom:15px;}
.svc-cta-btns{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.btn-amber{display:block;text-align:center;background:var(--amber);color:var(--espresso);
  padding:13px;border-radius:10px;font-weight:700;font-size:14px;}
.btn-green{display:block;text-align:center;background:#25D366;color:#fff;
  padding:13px;border-radius:10px;font-weight:700;font-size:14px;}

.related-h{font-family:'Fraunces',serif;font-size:17px;color:var(--espresso);
  text-align:center;margin:16px 0 12px;}
.related-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:0 16px 16px;}
.related-card{background:var(--white);border-radius:var(--r);overflow:hidden;
  border:1.5px solid var(--border);box-shadow:var(--sh-xs);display:block;
  transition:transform .2s,box-shadow .2s;}
.related-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md);}
.rc-img{height:78px;overflow:hidden;}
.rc-img img{width:100%;height:100%;object-fit:cover;}
.rc-body{padding:11px;}
.rc-body h4{font-size:12px;color:var(--espresso);font-weight:700;margin-bottom:2px;}
.rc-body p{font-size:11px;color:var(--muted);}

/* ══════════════ FORM ══════════════ */
.form-card{background:var(--white);border-radius:var(--r);padding:22px 18px;
  border:1.5px solid var(--border);box-shadow:var(--sh-sm);}
.form-card h3{font-family:'Fraunces',serif;font-size:21px;font-weight:700;
  color:var(--espresso);margin-bottom:16px;}
.fg{margin-bottom:13px;}
.fg label{display:block;font-size:12px;font-weight:600;color:var(--ink-mid);
  margin-bottom:5px;text-transform:uppercase;letter-spacing:.6px;}
.fg input,.fg textarea,.fg select{
  width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:10px;
  font-family:'Outfit',sans-serif;font-size:14px;color:var(--ink);
  background:var(--cream);transition:border-color .2s,box-shadow .2s;outline:none;}
.fg input:focus,.fg textarea:focus,.fg select:focus{
  border-color:var(--amber);box-shadow:0 0 0 3px rgba(200,128,10,.12);}
.fg textarea{height:110px;resize:vertical;}
.submit-btn{width:100%;padding:14px;background:var(--espresso);color:#fff;
  border:none;border-radius:50px;font-family:'Outfit',sans-serif;
  font-size:15px;font-weight:700;cursor:pointer;
  transition:background .2s,transform .2s,box-shadow .2s;}
.submit-btn:hover{background:var(--amber);color:var(--espresso);
  transform:translateY(-2px);box-shadow:var(--sh-amber);}

/* ══════════════ PROJECTS GALLERY PAGE ══════════════ */
.gallery-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px;padding:0 16px 8px;}
.gcard{background:var(--white);border-radius:var(--r);overflow:hidden;
  border:1.5px solid var(--border);box-shadow:var(--sh-xs);position:relative;
  transition:transform .3s,box-shadow .3s;-webkit-mask-image:-webkit-radial-gradient(white,black);}
.gcard:hover{transform:translateY(-5px);box-shadow:var(--sh-md);}
.gcard-img{height:120px;overflow:hidden;}
.gcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s;}
.gcard:hover .gcard-img img{transform:scale(1.12);}
.gcard-info{padding:10px 11px 12px;}
.gcard-cat{font-size:9px;font-weight:700;color:var(--amber);
  text-transform:uppercase;letter-spacing:1.2px;margin-bottom:3px;}
.gcard-name{font-family:'Fraunces',serif;font-size:13px;font-weight:700;
  color:var(--espresso);line-height:1.3;margin-bottom:2px;}
.gcard-loc{font-size:11px;color:var(--muted);}

/* ══════════════ FLOAT WA ══════════════ */
.float-wa{position:fixed;bottom:96px;right:14px;z-index:999;
  display:flex;flex-direction:column;align-items:center;gap:6px;}
.float-wa-label{background:var(--espresso);color:#fff;font-size:10px;font-weight:700;
  padding:4px 10px;border-radius:20px;box-shadow:var(--sh-sm);white-space:nowrap;
  border:1px solid rgba(200,128,10,.28);}
.float-wa-btn{width:52px;height:52px;border-radius:50%;background:#25D366;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 22px rgba(37,211,102,.50);position:relative;transition:transform .2s;}
.float-wa-btn:hover{transform:scale(1.10);}
.float-wa-btn img{width:28px;height:28px;}
.float-wa-btn::before{content:'';position:absolute;inset:-5px;border-radius:50%;
  border:2.5px solid rgba(37,211,102,.32);animation:wapulse 2.2s ease-out infinite;}
@keyframes wapulse{0%{transform:scale(1);opacity:1;}80%{transform:scale(1.55);opacity:0;}100%{transform:scale(1.55);opacity:0;}}

/* ══════════════ FIXED FOOTER BAR ══════════════ */
.foot-bar{position:fixed;bottom:0;left:0;width:100%;background:var(--white);
  border-top:2.5px solid var(--amber);padding:10px 0;
  display:flex;justify-content:center;gap:36px;z-index:1000;
  box-shadow:0 -4px 20px rgba(28,13,3,.10);}
.foot-bar a img,.foot-bar a svg{width:34px;height:34px;transition:transform .2s;}
.foot-bar a:hover img{transform:scale(1.20);}
.copyright{background:var(--espresso);color:rgba(255,255,255,.45);font-size:11px;
  text-align:center;padding:12px 16px;margin-bottom:72px;
  display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;}
.clink{color:var(--amber-lt);font-weight:700;}
.clink:hover{color:#fff;}

/* ══════════════ FOUNDER SECTION ══════════════ */
.founder-card{margin:0 16px;background:var(--espresso);border-radius:var(--r-lg);
  overflow:hidden;position:relative;}
.founder-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--rose),var(--amber),var(--rose),transparent);}
.founder-img-wrap{height:220px;overflow:hidden;position:relative;}
.founder-img-wrap img{width:100%;height:100%;object-fit:cover;object-position:center top;}
.founder-img-wrap::after{content:'';position:absolute;bottom:0;left:0;right:0;height:80px;
  background:linear-gradient(to top,var(--espresso),transparent);}
.founder-body{padding:20px 20px 24px;}
.founder-tag{display:inline-flex;align-items:center;gap:6px;
  background:rgba(200,128,10,.15);border:1px solid rgba(200,128,10,.35);
  color:var(--amber-lt);font-size:10px;font-weight:700;padding:4px 12px;
  border-radius:50px;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:12px;}
.founder-name{font-family:'Fraunces',serif;font-size:22px;font-weight:700;color:#fff;margin-bottom:4px;}
.founder-role{font-size:12px;color:rgba(255,255,255,.55);margin-bottom:14px;}
.founder-bio{font-size:14px;color:rgba(255,255,255,.72);line-height:1.80;}

/* ══════════════ BEFORE/AFTER ══════════════ */
.ba-card{margin:0 16px;border-radius:var(--r);overflow:hidden;
  border:2px solid var(--espresso);box-shadow:var(--sh-md);
  -webkit-mask-image:-webkit-radial-gradient(white,black);}
.ba-card img{width:100%;display:block;}
.ba-caption{background:var(--espresso);padding:12px 16px;text-align:center;}
.ba-caption p{font-size:12px;color:rgba(255,255,255,.65);}
.ba-caption strong{color:var(--amber-lt);font-size:13px;}

/* ══════════════ CLIENT LOGOS STRIP ══════════════ */
.clients-wrap{padding:0 16px;overflow:hidden;}
.clients-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;
  letter-spacing:2px;text-align:center;margin-bottom:14px;}
.clients-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.client-chip{background:var(--white);border:1.5px solid var(--border);border-radius:10px;
  padding:10px 8px;text-align:center;font-size:11px;font-weight:600;color:var(--espresso);
  line-height:1.4;box-shadow:var(--sh-xs);transition:border-color .2s,transform .2s;}
.client-chip:hover{border-color:var(--amber);transform:scale(1.04);}

@media(max-width:360px){
  .svc-grid{grid-template-columns:1fr 1fr;}
  .stats-row{grid-template-columns:repeat(2,1fr);}
  .why-grid{grid-template-columns:1fr;}
  .benefit-grid{grid-template-columns:1fr;}
}

/* ══════════════ DIRECTIONS BUTTON ══════════════ */
.map-wrapper{border-radius:var(--r-lg) var(--r-lg) 0 0;overflow:hidden;
  border:4px solid var(--espresso);border-bottom:none;
  box-shadow:var(--sh-md);
  -webkit-mask-image:-webkit-radial-gradient(white,black);}
.directions-btn{display:flex;align-items:center;gap:12px;
  background:linear-gradient(135deg,var(--espresso),var(--espresso-mid));
  border:4px solid var(--espresso);border-top:none;
  border-radius:0 0 var(--r-lg) var(--r-lg);
  padding:14px 20px;text-decoration:none;
  box-shadow:0 0 0 3px var(--amber),var(--sh-md);
  transition:background .25s,transform .25s;position:relative;z-index:1;}
.directions-btn:hover{background:linear-gradient(135deg,var(--amber),var(--amber-lt));transform:translateY(-2px);}
.dir-icon{font-size:26px;flex-shrink:0;}
.dir-text{flex:1;display:flex;flex-direction:column;gap:1px;}
.dir-text strong{color:#fff;font-size:14px;font-weight:700;}
.directions-btn:hover .dir-text strong{color:var(--espresso);}
.dir-text small{color:rgba(255,255,255,.55);font-size:11px;}
.directions-btn:hover .dir-text small{color:rgba(28,13,3,.65);}
.dir-arrow{color:var(--amber-lt);font-size:22px;font-weight:700;flex-shrink:0;
  transition:transform .25s;}
.directions-btn:hover .dir-arrow{transform:translateX(5px);color:var(--espresso);}

/* contact page map-wrapper standalone */
.cmap .map-wrapper,
div > .map-wrapper{border-radius:var(--r-lg);border:4px solid var(--espresso);
  box-shadow:0 0 0 3px var(--amber),var(--sh-md);border-bottom:4px solid var(--espresso);}
div > .map-wrapper + .directions-btn{border-radius:0 0 var(--r-lg) var(--r-lg);}

/* ══════════════ PREMIUM LOCATION CARD ══════════════ */
.location-card{margin:0 16px;border-radius:var(--r-lg);overflow:hidden;
  border:2px solid var(--border-warm);
  box-shadow:0 2px 8px rgba(28,13,3,.06), 0 16px 48px rgba(28,13,3,.12);
  -webkit-mask-image:-webkit-radial-gradient(white,black);}

/* Info strip — espresso dark band */
.loc-info-strip{background:var(--espresso);padding:0;
  display:flex;flex-direction:column;}
.loc-info-item{display:flex;align-items:flex-start;gap:13px;
  padding:16px 20px;}
.loc-info-divider{height:1px;background:rgba(255,255,255,.07);margin:0 20px;}
.loc-info-icon{font-size:20px;flex-shrink:0;margin-top:1px;
  width:36px;height:36px;border-radius:9px;
  background:rgba(200,128,10,.15);border:1px solid rgba(200,128,10,.30);
  display:flex;align-items:center;justify-content:center;}
.loc-info-body{display:flex;flex-direction:column;gap:3px;}
.loc-info-label{font-size:9px;font-weight:700;color:var(--amber);
  text-transform:uppercase;letter-spacing:1.8px;}
.loc-info-val{font-size:13px;color:rgba(255,255,255,.82);line-height:1.55;font-weight:500;}
.loc-phone{color:var(--amber-lt) !important;font-weight:700;text-decoration:none;}
.loc-phone:hover{color:#fff !important;}

/* Map */
.loc-map-wrap{position:relative;line-height:0;border-top:2px solid rgba(200,128,10,.25);
  overflow:hidden;}
/* Iframe is 145% wide, offset left so info card slides off-screen;
   container overflow:hidden clips it cleanly — no dark mask needed   */
.loc-map-wrap iframe{display:block;width:145%;height:280px;border:0;
  margin-left:-45%;}

/* Action buttons row */
.loc-actions{display:grid;grid-template-columns:1fr 1fr;border-top:2px solid rgba(200,128,10,.20);}
.loc-btn{display:flex;align-items:center;justify-content:center;gap:8px;
  padding:15px 10px;font-size:13px;font-weight:700;text-decoration:none;
  transition:background .22s,transform .2s;}
.loc-btn svg{flex-shrink:0;transition:transform .22s;}
.loc-btn-dir{background:var(--amber);color:var(--espresso);
  border-right:1.5px solid rgba(28,13,3,.15);}
.loc-btn-dir:hover{background:var(--amber-lt);}
.loc-btn-dir:hover svg{transform:translateX(3px) translateY(-2px);}
.loc-btn-view{background:var(--espresso);color:rgba(255,255,255,.88);}
.loc-btn-view:hover{background:var(--espresso-lt);color:#fff;}
.loc-btn-view:hover svg{transform:scale(1.15);}

/* ══════════════ MAP OVERLAY PILLS ══════════════ */
.map-overlay-btns{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);
  display:flex;gap:8px;z-index:10;white-space:nowrap;}
.map-pill{display:inline-flex;align-items:center;gap:6px;
  padding:9px 16px;border-radius:50px;font-size:12px;font-weight:700;
  text-decoration:none;letter-spacing:.2px;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  box-shadow:0 4px 20px rgba(0,0,0,.35),0 1px 4px rgba(0,0,0,.25);
  transition:transform .2s,box-shadow .2s;}
.map-pill:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,.40);}
.map-pill-dir{background:rgba(200,128,10,.96);color:#1C0D03;border:1.5px solid rgba(255,255,255,.25);}
.map-pill-dir svg{flex-shrink:0;}
.map-pill-dir:hover{background:rgba(232,160,32,.99);}
.map-pill-view{background:rgba(255,255,255,.92);color:#1C0D03;border:1.5px solid rgba(200,128,10,.30);}
.map-pill-view:hover{background:#fff;}

/* ── Hide Google Maps built-in UI bars (top + bottom) ── */
/* The info panel is suppressed by using a wider-than-container iframe
   that crops the left side via overflow:hidden on loc-map-wrap          */
.map-bottom-mask{
  position:absolute;
  bottom:0;left:0;right:0;
  height:54px;
  background:var(--espresso);
  z-index:5;
  pointer-events:none;
}
.map-top-mask{
  position:absolute;
  top:0;left:0;right:0;
  height:46px;
  background:var(--espresso);
  z-index:5;
  pointer-events:none;
}
/* Left mask: narrow strip just wide enough to hide Google's info chip
   (the small "Parth Row House" label that appears bottom-left)          */
.map-left-mask{display:none;}
/* Pills float above the bottom mask */
.map-overlay-btns{bottom:64px;}

/* ═══════════════════════════════════════════════════════════════
   DESKTOP RESPONSIVE  —  careshmajadhav.in style patterns
   768px · 1024px · 1200px
═══════════════════════════════════════════════════════════════ */

@media(min-width:768px){
  /* ── Body ── */
  body{padding-bottom:0;}

  /* ── Nav: brand LEFT, pills RIGHT — exact careshma pattern ── */
  .nav-inner{display:flex;align-items:center;justify-content:space-between;
    padding:0 32px;flex-wrap:nowrap;}
  .nav-logo{width:46px;height:46px;}
  .nav-title{font-size:16px;}
  .nav-sub{font-size:10px;}
  .hamburger{display:none !important;}
  .nav-menu{display:flex !important;flex-direction:row !important;
    position:static !important;
    align-items:center;gap:6px;flex:0 0 auto;
    background:transparent !important;border:none !important;
    padding:0 !important;}
  .nav-item{display:inline-flex !important;align-items:center;
    padding:9px 18px !important;margin:0 !important;
    border-radius:50px !important;font-size:13px !important;
    white-space:nowrap;
    background:rgba(255,255,255,.06) !important;
    border:1px solid rgba(255,255,255,.10) !important;}
  .nav-item.active{background:var(--amber) !important;
    color:var(--espresso) !important;
    border-color:var(--amber) !important;font-weight:700 !important;}
  .nav-item:hover:not(.active){background:rgba(200,128,10,.18) !important;
    color:#fff !important;}

  /* ── Hero ── */
  .hero{min-height:86vh;}
  .hero-content{padding:0 48px 72px;max-width:640px;}
  .hero h1{font-size:clamp(46px,6vw,68px);}
  .hero-sub{font-size:16px;max-width:460px;}
  .hero-ctas{gap:14px;}

  /* ── Stats ── */
  .stats-row{grid-template-columns:repeat(4,1fr);max-width:1200px;margin:0 auto;}
  .stat-n{font-size:36px;}

  /* ── All sections: centred, max 1200px ── */
  .section{padding:56px 40px 12px;max-width:1200px;
    margin-left:auto;margin-right:auto;}
  .section-h{font-size:clamp(30px,4vw,42px);}
  .section-p{font-size:15px;max-width:520px;}
  .divider{margin:40px auto;max-width:1200px;padding:0 40px;
    box-sizing:border-box;}

  /* ── Service grid: 3 columns ── */
  .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);
    padding:0 40px 12px;gap:16px;
    max-width:1200px;margin:0 auto;}
  .svc-thumb{height:140px;}

  /* ── Benefit panel ── */
  .benefit-panel{margin:0 auto;max-width:1200px;padding:0 40px;}
  .benefit-inner{padding:36px 44px;}
  .benefit-grid{grid-template-columns:repeat(3,1fr);gap:14px;align-items:stretch;}
  .bitem{padding:16px 14px;}
  .bitem p{font-size:13px;}

  /* ── Why/trust grid: 4 cols ── */
  .why-grid{grid-template-columns:repeat(4,1fr);
    padding:0 40px;gap:16px;
    max-width:1200px;margin:0 auto;}

  /* ── Projects: 3-col grid ── */
  .proj-strip{padding:0 40px;display:grid;
    grid-template-columns:repeat(3,1fr);gap:16px;
    max-width:1200px;margin:0 auto;}
  .proj-strip .proj-card{margin-bottom:0;}
  .proj-img{height:190px;}

  /* ── Founder: side-by-side ── */
  .founder-card{margin:0 auto;max-width:1200px;padding:0 40px;
    display:flex;flex-direction:row;border-radius:0;
    background:transparent;box-shadow:none;border:none;}
  .founder-card-inner{display:flex;flex-direction:row;width:100%;
    background:var(--espresso);border-radius:var(--r-lg);overflow:hidden;
    border:1.5px solid var(--border-warm);box-shadow:var(--sh-lg);}
  .founder-img-wrap{width:42%;flex-shrink:0;height:auto;}
  .founder-img-wrap img{height:100%;width:100%;
    object-fit:cover;object-position:center top;}
  .founder-img-wrap::after{display:none;}
  .founder-body{padding:36px 40px;display:flex;
    flex-direction:column;justify-content:center;}
  .founder-name{font-size:26px;}
  .founder-bio{font-size:14px;}

  /* ── Before/After ── */
  .ba-card{margin:0 auto;max-width:1200px;padding:0 40px;
    background:transparent;border:none;box-shadow:none;}
  .ba-card-inner{background:var(--espresso);border-radius:var(--r-lg);
    overflow:hidden;border:1.5px solid var(--border-warm);box-shadow:var(--sh-lg);}

  /* ── Clients: 4 cols ── */
  .clients-wrap{padding:0 40px;max-width:1200px;margin:0 auto;}
  .clients-grid{grid-template-columns:repeat(4,1fr);gap:12px;}
  .client-chip{font-size:12px;padding:12px 10px;}

  /* ── Testimonials: 3-col ── */
  .testi-stack{padding:0 40px;flex-direction:row;align-items:stretch;gap:16px;
    max-width:1200px;margin:0 auto;}
  .tcard{flex:1;}

  /* ── FAQ ── */
  .faq-wrap{padding:0 40px;max-width:900px;margin-left:auto;margin-right:auto;}
  .faq-btn{font-size:14px;}

  /* ── SEO block ── */
  .seo-wrap{padding:0 40px 12px;max-width:900px;
    margin-left:auto;margin-right:auto;}

  /* ── Location card ── */
  .location-card{
    width:calc(100% - 80px);
    margin-left:auto;margin-right:auto;
    max-width:900px;}
  .loc-info-strip{flex-direction:row;}
  .loc-info-divider{width:1px;height:auto;margin:14px 0;}
  .loc-info-item{flex:1;padding:20px 22px;}
  .loc-info-val{font-size:13px;}
  .loc-map-wrap iframe{height:340px;width:145%;margin-left:-45%;}

  /* ── Float WA ── */
  .float-wa{right:24px;bottom:100px;}
  .float-wa-btn{width:56px;height:56px;}

  /* ── Footer bar: pill-shaped, centred like careshma ── */
  .foot-bar{left:50%;transform:translateX(-50%);
    border-radius:60px;bottom:14px;width:auto;
    padding:10px 40px;gap:36px;
    border-top:2px solid var(--amber);
    box-shadow:0 -2px 24px rgba(28,13,3,.14);}
  .foot-bar a img,.foot-bar a svg{width:34px;height:34px;}
  .copyright{margin-bottom:0;font-size:11px;padding:14px 24px;}

  /* ── Map overlay pills ── */
  .map-pill{font-size:13px;padding:10px 20px;}

  /* ── Inner page wrap ── */
  .page-wrap{padding:32px 40px 32px;max-width:900px;margin:0 auto;}
  .page-hero{padding:82px 48px 36px;}
  .page-hero h1{font-size:clamp(32px,5vw,50px);}
  .page-hero p{font-size:15px;max-width:540px;}

  /* ── Gallery ── */
  .gallery-grid{grid-template-columns:repeat(2,minmax(0,520px));padding:0 40px;
    max-width:1120px;margin:0 auto;justify-content:center;}
  .gcard-img{height:200px;}

  /* ── Service detail pages ── */
  .svc-body{padding:0 40px;max-width:820px;margin:0 auto;}
  .svc-cta-btns{grid-template-columns:1fr 1fr;max-width:360px;margin:0 auto;}
  .related-grid{padding:0 40px 20px;grid-template-columns:repeat(4,1fr);
    max-width:1200px;margin-left:auto;margin-right:auto;}

  /* ── Contact form ── */
  .form-card{padding:28px 32px;}
  .cmap{padding-bottom:42%;height:0;position:relative;}
  .cmap iframe{position:absolute;top:0;left:0;width:100%;height:100%;}
  .addr-card{padding:22px 28px;}

  /* ── Address on index ── */
  .addr-card{max-width:1200px;margin-left:auto;margin-right:auto;}

  /* ── Map frame on index ── */
  .map-frame{max-width:900px;margin-left:auto;margin-right:auto;}
}

@media(min-width:1024px){
  /* ── Nav ── */
  .nav-inner{padding:0 56px;}
  .nav-logo{width:50px;height:50px;}

  /* ── Hero ── */
  .hero{min-height:88vh;}
  .hero-content{padding:0 64px 80px;max-width:700px;}
  .hero h1{font-size:clamp(52px,6vw,72px);}

  /* ── Sections ── */
  .section{padding:60px 56px 14px;}
  .svc-grid{padding:0 56px 14px;}
  .why-grid{padding:0 56px;}
  .benefit-panel{padding:0 56px;}
  .proj-strip{padding:0 56px;}
  .testi-stack{padding:0 56px;}
  .faq-wrap{padding:0 56px;}
  .seo-wrap{padding:0 56px 14px;}
  .clients-wrap{padding:0 56px;}
  .gallery-grid{padding:0 56px;max-width:1200px;}
  /* centre a lone last card when count is odd */
  .gallery-grid .gcard:last-child:nth-child(odd){grid-column:1 / -1;max-width:520px;margin:0 auto;width:100%;}
  .svc-body{padding:0 56px;}
  .related-grid{padding:0 56px 24px;}

  /* ── Founder image taller ── */
  .founder-img-wrap img{min-height:380px;}
  .founder-body{padding:40px 48px;}

  /* ── Service image taller ── */
  .svc-thumb{height:160px;}
  .proj-img{height:210px;}

  /* ── Page hero ── */
  .page-hero{padding:86px 64px 40px;}
  .page-hero h1{font-size:clamp(36px,5vw,54px);}
  .page-wrap{padding:32px 56px 36px;}

  /* ── Footer pill wider ── */
  .foot-bar{gap:48px;padding:12px 56px;}
}

@media(min-width:1200px){
  /* All sections strictly contained */
  body{box-shadow:0 0 80px rgba(28,13,3,.06);}
  .nav-inner{padding:0 64px;}
  .hero-content{padding:0 72px 88px;}
  .section{padding:64px 64px 16px;}
  .benefit-panel{padding:0 64px;}
  .svc-grid,.why-grid,.proj-strip,.testi-stack{padding-left:64px;padding-right:64px;}
  .faq-wrap,.seo-wrap,.clients-wrap,.gallery-grid{padding-left:64px;padding-right:64px;}
  .svc-body,.related-grid{padding-left:64px;padding-right:64px;}
  .map-frame{max-width:1040px;}
  .page-wrap{padding:32px 64px 40px;}
  .foot-bar{padding:12px 64px;gap:56px;}
  .location-card{width:calc(100% - 128px);max-width:900px;}
}
