/* ============================================================
   HM Scaffolding — core styles
   Dark, premium, mobile-first. Plain CSS, no build step.
   ============================================================ */
:root{
  --bg:#0B0C10;
  --bg-2:#0F1116;
  --surface:#15181F;
  --surface-2:#1B1F28;
  --line:rgba(255,255,255,.10);
  --line-strong:rgba(255,255,255,.18);
  --text:#F4F6F8;
  --muted:#A2A8B4;
  --muted-2:#7E8696;
  --accent:#F4B740;       /* refined amber, used sparingly */
  --accent-ink:#1A1306;   /* text on accent */
  --maxw:1200px;
  --radius:16px;
  --radius-sm:10px;
  --shadow:0 24px 60px -24px rgba(0,0,0,.7);
  --ease:cubic-bezier(.22,.61,.36,1);
  --font-display:"Sora",system-ui,-apple-system,"Segoe UI",sans-serif;
  --font-body:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  font-size:17px;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.08;letter-spacing:-.02em}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{
  font-family:var(--font-display);font-weight:600;font-size:.8rem;
  letter-spacing:.22em;text-transform:uppercase;color:var(--accent);
  display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent);opacity:.7}
.section{padding:96px 0}
.section--tight{padding:72px 0}
.lead{color:var(--muted);font-size:1.12rem;max-width:60ch}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--font-display);font-weight:600;font-size:1rem;
  padding:15px 26px;border-radius:999px;border:1px solid transparent;
  cursor:pointer;transition:transform .25s var(--ease),background .25s,box-shadow .25s,border-color .25s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--accent);color:var(--accent-ink);box-shadow:0 12px 30px -10px rgba(244,183,64,.55)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px -12px rgba(244,183,64,.7)}
.btn--ghost{background:rgba(255,255,255,.04);border-color:var(--line-strong);color:var(--text)}
.btn--ghost:hover{background:rgba(255,255,255,.09);border-color:var(--text)}
.btn--block{width:100%}
.btn svg{width:18px;height:18px}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  backdrop-filter:saturate(140%) blur(14px);
  background:rgba(11,12,16,.72);
  border-bottom:1px solid transparent;
  transition:background .3s,border-color .3s;
}
.site-header.scrolled{background:rgba(11,12,16,.92);border-bottom-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px;gap:24px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:34px;list-style:none}
.nav-links a{font-size:.97rem;color:var(--muted);font-weight:500;transition:color .2s;position:relative;padding:6px 0}
.nav-links a:hover{color:var(--text)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--accent);transition:width .25s var(--ease)}
.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--text)}
.nav-links a.active::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-phone{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:600;font-size:1rem}
.nav-phone svg{width:17px;height:17px;color:var(--accent)}
.burger{display:none;background:none;border:1px solid var(--line-strong);border-radius:10px;width:46px;height:46px;cursor:pointer;align-items:center;justify-content:center}
.burger span{display:block;width:20px;height:2px;background:var(--text);position:relative;transition:.3s}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--text);transition:.3s}
.burger span::before{top:-6px}.burger span::after{top:6px}
.burger.open span{background:transparent}
.burger.open span::before{top:0;transform:rotate(45deg)}
.burger.open span::after{top:0;transform:rotate(-45deg)}

/* ---------- mobile menu ---------- */
.mobile-menu{
  position:fixed;inset:76px 0 0;z-index:55;background:var(--bg);
  transform:translateY(-12px);opacity:0;pointer-events:none;transition:.3s var(--ease);
  padding:28px 24px 40px;display:flex;flex-direction:column;gap:6px;overflow-y:auto;
}
.mobile-menu.open{transform:none;opacity:1;pointer-events:auto}
.mobile-menu a{padding:16px 4px;font-family:var(--font-display);font-size:1.35rem;font-weight:600;border-bottom:1px solid var(--line)}
.mobile-menu .btn{margin-top:18px}

/* ---------- hero ---------- */
.hero{position:relative;isolation:isolate;overflow:hidden;padding:120px 0 110px}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:url('../assets/img/hero.jpg') center/cover no-repeat;
  transform:scale(1.05);
}
.hero::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg,rgba(11,12,16,.78) 0%,rgba(11,12,16,.62) 40%,rgba(11,12,16,.92) 100%),
    radial-gradient(120% 90% at 15% 10%,rgba(11,12,16,.35),transparent 60%);
}
.hero-inner{max-width:760px}
.hero h1{font-size:clamp(2.5rem,6vw,4.4rem);margin:20px 0 18px}
.hero h1 .accent{color:var(--accent)}
.hero p{font-size:clamp(1.05rem,2.2vw,1.3rem);color:#D7DBE2;max-width:54ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:40px;list-style:none}
.hero-badges li{display:flex;align-items:center;gap:9px;color:#CDD2DA;font-size:.95rem;font-weight:500}
.hero-badges svg{width:18px;height:18px;color:var(--accent);flex:none}

/* ---------- stats strip ---------- */
.stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:42px 0}
.stat{text-align:center}
.stat .num{font-family:var(--font-display);font-weight:700;font-size:2.3rem;letter-spacing:-.02em}
.stat .num .accent{color:var(--accent)}
.stat .label{color:var(--muted);font-size:.9rem;margin-top:4px}

/* ---------- section heading ---------- */
.sec-head{max-width:680px;margin-bottom:54px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(2rem,4.4vw,3rem);margin:16px 0 16px}
.sec-head p{color:var(--muted);font-size:1.08rem}

/* ---------- services ---------- */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.service-card{
  position:relative;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);background:var(--surface);min-height:340px;
  display:flex;flex-direction:column;justify-content:flex-end;
  transition:transform .35s var(--ease),border-color .35s;
}
.service-card:hover{transform:translateY(-6px);border-color:var(--line-strong)}
.service-card .bg{position:absolute;inset:0;z-index:0}
.service-card .bg img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.service-card:hover .bg img{transform:scale(1.06)}
.service-card .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,12,16,.1),rgba(11,12,16,.55) 55%,rgba(11,12,16,.95))}
.service-card .body{position:relative;z-index:1;padding:26px}
.service-card h3{font-size:1.45rem;margin-bottom:8px}
.service-card p{color:#C7CCD5;font-size:.98rem}
.service-card .more{display:inline-flex;align-items:center;gap:7px;margin-top:14px;color:var(--accent);font-weight:600;font-family:var(--font-display);font-size:.95rem}
.service-card .more svg{width:16px;height:16px;transition:transform .25s}
.service-card:hover .more svg{transform:translateX(4px)}

/* specialist chips */
.specialist{margin-top:40px;display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.chip{
  display:inline-flex;align-items:center;gap:9px;padding:11px 18px;border-radius:999px;
  border:1px solid var(--line);background:var(--surface);color:#D6DAE2;font-size:.94rem;font-weight:500;
}
.chip svg{width:16px;height:16px;color:var(--accent)}

/* ---------- feature split (why choose) ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.split-media{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.split-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.why-list{list-style:none;margin-top:26px;display:grid;gap:18px}
.why-list li{display:flex;gap:15px}
.why-ic{flex:none;width:44px;height:44px;border-radius:12px;background:rgba(244,183,64,.12);border:1px solid rgba(244,183,64,.3);display:flex;align-items:center;justify-content:center}
.why-ic svg{width:21px;height:21px;color:var(--accent)}
.why-list h4{font-size:1.08rem;margin-bottom:2px;font-family:var(--font-display)}
.why-list p{color:var(--muted);font-size:.96rem}

/* ---------- areas ---------- */
.areas{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.areas-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;margin-top:14px}
.areas-col h4{font-size:1.15rem;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.areas-col h4 svg{width:18px;height:18px;color:var(--accent)}
.areas-col ul{list-style:none;display:flex;flex-wrap:wrap;gap:8px}
.areas-col li{font-size:.92rem;color:var(--muted);background:var(--surface);border:1px solid var(--line);padding:7px 13px;border-radius:999px}

/* ---------- gallery ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.gallery-grid a{position:relative;overflow:hidden;border-radius:var(--radius-sm);border:1px solid var(--line)}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.gallery-grid a:hover img{transform:scale(1.07)}
.gallery-grid .tall{grid-row:span 2}
.gallery-grid .wide{grid-column:span 2}

/* ---------- CTA / quote ---------- */
.quote{position:relative;overflow:hidden}
.quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}
.quote-info h2{font-size:clamp(2rem,4.4vw,3rem);margin:16px 0 18px}
.quote-info .lead{margin-bottom:30px}
.contact-line{display:flex;align-items:center;gap:16px;padding:18px 0;border-top:1px solid var(--line)}
.contact-line:last-child{border-bottom:1px solid var(--line)}
.contact-line .ic{width:46px;height:46px;border-radius:12px;background:var(--surface);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;flex:none}
.contact-line .ic svg{width:20px;height:20px;color:var(--accent)}
.contact-line .label{font-size:.82rem;color:var(--muted-2);text-transform:uppercase;letter-spacing:.1em}
.contact-line .val{font-family:var(--font-display);font-weight:600;font-size:1.12rem}

.form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}
.form-card h3{font-size:1.4rem;margin-bottom:6px}
.form-card .sub{color:var(--muted);font-size:.95rem;margin-bottom:22px}
.field{margin-bottom:16px}
.field label{display:block;font-size:.86rem;color:var(--muted);margin-bottom:7px;font-weight:500}
.field input,.field select,.field textarea{
  width:100%;background:var(--bg);border:1px solid var(--line-strong);border-radius:10px;
  padding:13px 15px;color:var(--text);font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(244,183,64,.15)}
.field textarea{resize:vertical;min-height:110px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-note{font-size:.82rem;color:var(--muted-2);margin-top:12px;text-align:center}

/* ---------- footer ---------- */
.site-footer{background:var(--bg-2);border-top:1px solid var(--line);padding:64px 0 28px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
.footer-brand img{height:38px;margin-bottom:16px}
.footer-brand p{color:var(--muted);font-size:.95rem;max-width:34ch}
.footer-col h5{font-family:var(--font-display);font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);margin-bottom:16px}
.footer-col ul{list-style:none;display:grid;gap:11px}
.footer-col a{color:var(--muted);font-size:.95rem;transition:color .2s}
.footer-col a:hover{color:var(--text)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-top:48px;padding-top:24px;border-top:1px solid var(--line);color:var(--muted-2);font-size:.85rem}
.socials{display:flex;gap:12px}
.socials a{width:40px;height:40px;border-radius:10px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:.2s}
.socials a:hover{color:var(--text);border-color:var(--line-strong);transform:translateY(-2px)}
.socials svg{width:18px;height:18px}

/* ---------- mobile sticky call bar ---------- */
.mobile-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:50;display:none;
  grid-template-columns:1fr 1fr;gap:10px;padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  background:rgba(11,12,16,.92);backdrop-filter:blur(12px);border-top:1px solid var(--line);
}
.mobile-bar .btn{padding:13px}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:860px){
  .nav-links,.nav-phone{display:none}
  .burger{display:flex}
  .split{grid-template-columns:1fr;gap:36px}
  .quote-grid{grid-template-columns:1fr;gap:36px}
  .areas-cols{grid-template-columns:1fr;gap:28px}
  .section{padding:72px 0}
}
@media (max-width:680px){
  body{font-size:16px}
  .services-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr;gap:30px 16px}
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}
  .gallery-grid .wide{grid-column:span 2}
  .field-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .hero{padding:80px 0 90px}
  .mobile-bar{display:grid}
  body{padding-bottom:78px}
  .nav-cta .btn{display:none}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   ADD-ONS: scrub sequence, subpages, service detail, contact
   ============================================================ */

/* ---------- scroll-scrub sequence ---------- */
.scrub{position:relative;height:300vh;background:#000}        /* tall = scroll distance */
.scrub-sticky{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center}
.scrub canvas{width:100%;height:100%;object-fit:cover;display:block}
.scrub-poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.scrub-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.45),rgba(0,0,0,.15) 35%,rgba(0,0,0,.7));z-index:2;pointer-events:none}
.scrub-caption{position:absolute;z-index:3;left:0;right:0;bottom:9%;text-align:center;padding:0 24px}
.scrub-caption .eyebrow{justify-content:center}
.scrub-caption h2{font-size:clamp(2rem,5vw,3.6rem);margin-top:14px;text-shadow:0 4px 30px rgba(0,0,0,.5)}
.scrub-caption p{color:#dfe3ea;max-width:46ch;margin:14px auto 0;text-shadow:0 2px 16px rgba(0,0,0,.6)}
.scrub-progress{position:absolute;z-index:3;left:50%;bottom:4%;transform:translateX(-50%);width:180px;height:3px;background:rgba(255,255,255,.2);border-radius:2px;overflow:hidden}
.scrub-progress span{position:absolute;left:0;top:0;height:100%;width:0;background:var(--accent)}

/* ---------- subpage hero ---------- */
.page-hero{position:relative;isolation:isolate;overflow:hidden;padding:120px 0 64px}
.page-hero::before{content:"";position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center;transform:scale(1.05)}
.page-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(11,12,16,.72),rgba(11,12,16,.92))}
.page-hero[data-img="services"]::before{background-image:url('../assets/img/commercial-run.jpg')}
.page-hero[data-img="areas"]::before{background-image:url('../assets/img/brick-terrace.jpg')}
.page-hero[data-img="gallery"]::before{background-image:url('../assets/img/flats.jpg')}
.page-hero[data-img="about"]::before{background-image:url('../assets/img/brick-block.jpg')}
.page-hero[data-img="contact"]::before{background-image:url('../assets/img/white-building.jpg')}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.6rem);margin:16px 0 14px}
.page-hero p{color:#D7DBE2;max-width:56ch;font-size:1.1rem}
.crumb{font-size:.85rem;color:var(--muted-2)}
.crumb a:hover{color:var(--text)}

/* ---------- generic prose / content ---------- */
.prose{max-width:72ch}
.prose p{color:var(--muted);margin-bottom:18px}
.prose h3{font-size:1.5rem;margin:34px 0 12px}

/* ---------- service detail rows ---------- */
.detail{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;padding:30px 0}
.detail:nth-child(even) .detail-media{order:2}
.detail-media{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.detail-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.detail h2{font-size:clamp(1.7rem,3.5vw,2.4rem);margin:14px 0 14px}
.detail .lead{margin-bottom:20px}
.ticks{list-style:none;display:grid;gap:11px}
.ticks li{display:flex;gap:12px;color:#D2D7DF;font-size:.98rem}
.ticks svg{width:20px;height:20px;color:var(--accent);flex:none;margin-top:2px}

/* ---------- accreditations ---------- */
.accreds{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:10px}
.accred{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:24px;text-align:center}
.accred .ic{width:52px;height:52px;margin:0 auto 14px;border-radius:13px;background:rgba(244,183,64,.12);border:1px solid rgba(244,183,64,.3);display:flex;align-items:center;justify-content:center}
.accred .ic svg{width:26px;height:26px;color:var(--accent)}
.accred h4{font-size:1.05rem;margin-bottom:6px}
.accred p{color:var(--muted);font-size:.9rem}

/* ---------- full gallery ---------- */
.gallery-full{columns:4;column-gap:14px}
.gallery-full a{display:block;margin:0 0 14px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--line);break-inside:avoid;position:relative}
.gallery-full img{width:100%;display:block;transition:transform .5s var(--ease)}
.gallery-full a:hover img{transform:scale(1.05)}

/* ---------- contact extras ---------- */
.map-embed{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);margin-top:30px;line-height:0}
.map-embed iframe{width:100%;height:340px;border:0;filter:grayscale(.3) contrast(1.05) brightness(.92)}

/* ---------- cta band ---------- */
.cta-band{position:relative;overflow:hidden;text-align:center;padding:84px 0}
.cta-band::before{content:"";position:absolute;inset:0;z-index:-2;background:url('../assets/img/site.jpg') center/cover}
.cta-band::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(11,12,16,.84),rgba(11,12,16,.92))}
.cta-band h2{font-size:clamp(2rem,4.6vw,3rem);margin-bottom:14px}
.cta-band p{color:var(--muted);max-width:48ch;margin:0 auto 28px;font-size:1.1rem}
.cta-band .hero-actions{justify-content:center}

@media (max-width:1024px){
  .gallery-full{columns:3}
  .accreds{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .detail{grid-template-columns:1fr;gap:26px}
  .detail:nth-child(even) .detail-media{order:0}
  .scrub{height:240vh}
}
@media (max-width:680px){
  .gallery-full{columns:2}
}

/* ============================================================
   PREMIUM PASS — typography, depth, texture, micro-detail
   ============================================================ */
:root{
  --bg:#0A0B0E;
  --bg-2:#0E1014;
  --surface:#14161D;
  --surface-2:#1A1D26;
  --accent:#E7B45A;          /* softer, more luxe gold */
  --accent-2:#F2C879;
  --accent-ink:#1A1306;
  --font-serif:"Fraunces",Georgia,"Times New Roman",serif;
  --shadow:0 30px 70px -28px rgba(0,0,0,.78);
  --shadow-sm:0 12px 30px -16px rgba(0,0,0,.6);
}

/* subtle film grain over everything (very low opacity) */
body::after{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* roomier, more editorial rhythm */
.section{padding:120px 0}
.section--tight{padding:88px 0}
.eyebrow{font-size:.78rem;letter-spacing:.26em;color:var(--accent)}
.sec-head{margin-bottom:64px}
.sec-head h2{font-size:clamp(2.1rem,4.8vw,3.3rem);letter-spacing:-.025em}

/* ---- hero: bigger, layered, with glow ---- */
.hero{padding:150px 0 130px}
.hero::after{
  background:
    radial-gradient(80% 60% at 78% 18%,rgba(231,180,90,.16),transparent 60%),
    linear-gradient(180deg,rgba(10,11,14,.74) 0%,rgba(10,11,14,.58) 38%,rgba(10,11,14,.95) 100%);
}
.hero-inner{max-width:840px}
.hero h1{font-size:clamp(2.8rem,7vw,5.4rem);letter-spacing:-.035em;line-height:1.02;margin:22px 0 22px}
.hero h1 .accent{
  color:transparent;background:linear-gradient(96deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;
  font-family:var(--font-serif);font-style:italic;font-weight:500;
}
.hero p{font-size:clamp(1.1rem,2.2vw,1.32rem);color:#DDE1E8}
.hero-badges{margin-top:46px;gap:12px 30px}
.hero-badges li{font-size:.96rem}

/* ---- buttons: gradient + sheen ---- */
.btn--primary{
  background:linear-gradient(96deg,var(--accent),var(--accent-2));
  color:var(--accent-ink);position:relative;overflow:hidden;
  box-shadow:0 14px 34px -12px rgba(231,180,90,.6);
}
.btn--primary::after{
  content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.45),transparent);
  transform:skewX(-18deg);transition:left .6s var(--ease);
}
.btn--primary:hover::after{left:140%}
.btn{padding:16px 30px}

/* ---- trust marquee ---- */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2);overflow:hidden;padding:20px 0}
.trust-track{display:inline-flex;align-items:center;gap:0;white-space:nowrap;animation:marquee 38s linear infinite;will-change:transform}
.trust-track span{font-family:var(--font-display);font-weight:600;font-size:.92rem;letter-spacing:.16em;text-transform:uppercase;color:#C9CED8;padding:0 26px}
.trust-track .dot{color:var(--accent);padding:0}
.trust:hover .trust-track{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---- stats: serif numbers + dividers ---- */
.stats-grid{padding:54px 0}
.stat{position:relative}
.stat + .stat::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);height:54px;width:1px;background:var(--line)}
.stat .num{font-family:var(--font-serif);font-weight:500;font-size:3rem;letter-spacing:-.02em}

/* ---- service cards: taller, numbered, deeper ---- */
.service-card{min-height:420px;border-radius:20px;box-shadow:var(--shadow-sm)}
.service-card .bg::after{background:linear-gradient(180deg,rgba(10,11,14,0) 30%,rgba(10,11,14,.6) 62%,rgba(10,11,14,.97))}
.service-card:hover{box-shadow:var(--shadow)}
.service-card .snum{
  position:absolute;z-index:2;top:22px;right:24px;font-family:var(--font-serif);font-style:italic;
  font-size:1.4rem;color:var(--accent);opacity:.9;
}
.service-card h3{font-size:1.7rem;letter-spacing:-.02em}
.service-card .body{padding:30px}

.chip{padding:12px 20px;box-shadow:var(--shadow-sm)}
.chip:hover{border-color:var(--line-strong)}

/* ---- testimonials ---- */
.testimonials{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tcard{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:34px 30px 30px;box-shadow:var(--shadow-sm)}
.tcard .quote-mark{position:absolute;top:8px;right:24px;font-family:var(--font-serif);font-size:5rem;line-height:1;color:var(--accent);opacity:.16}
.stars{display:flex;gap:3px;color:var(--accent);margin-bottom:16px}
.stars svg{width:17px;height:17px}
.tcard blockquote{font-family:var(--font-serif);font-weight:400;font-size:1.18rem;line-height:1.5;color:#EDEFF3;letter-spacing:-.01em}
.tcard figcaption{margin-top:20px;padding-top:18px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:2px}
.tname{font-family:var(--font-display);font-weight:600;font-size:.98rem}
.tloc{color:var(--muted-2);font-size:.86rem}

/* ---- split media: richer frame ---- */
.split-media,.detail-media{box-shadow:var(--shadow)}
.split-media::after{content:"";position:absolute;inset:0;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);pointer-events:none}

/* ---- header polish ---- */
.site-header.scrolled{background:rgba(10,11,14,.9)}
.brand img{height:36px}

@media (max-width:980px){ .tgrid{grid-template-columns:1fr} }
@media (max-width:860px){
  .section{padding:84px 0}
  .hero{padding:96px 0 92px}
  .stat + .stat::before{display:none}
}
@media (prefers-reduced-motion:reduce){
  .trust-track{animation:none}
}

/* ---- hero underline draw on "properly" ---- */
.uline{position:relative;display:inline-block}
.uline-svg{position:absolute;left:-1%;bottom:-.16em;width:102%;height:.42em;overflow:visible;pointer-events:none}
.uline-svg path{fill:none;stroke:var(--accent-2);stroke-width:6;stroke-linecap:round;
  stroke-dasharray:1;stroke-dashoffset:1;animation:uline-draw 1s var(--ease) .6s forwards}
@keyframes uline-draw{to{stroke-dashoffset:0}}
@media (prefers-reduced-motion:reduce){ .uline-svg path{stroke-dashoffset:0;animation:none} }

/* ---- video feature ---- */
.video-frame{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow);aspect-ratio:16/9;background:#000}
.video-frame video{width:100%;height:100%;object-fit:cover;display:block}
.vf-poster{position:absolute;inset:0;width:100%;height:100%;border:0;padding:0;cursor:pointer;background:none}
.vf-poster img{width:100%;height:100%;object-fit:cover}
.vf-poster::after{content:"";position:absolute;inset:0;background:rgba(10,11,14,.32);transition:background .3s}
.vf-poster:hover::after{background:rgba(10,11,14,.18)}
.vf-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;
  width:84px;height:84px;border-radius:50%;background:linear-gradient(96deg,var(--accent),var(--accent-2));
  display:flex;align-items:center;justify-content:center;box-shadow:0 18px 44px -12px rgba(231,180,90,.7);transition:transform .3s var(--ease)}
.vf-poster:hover .vf-play{transform:translate(-50%,-50%) scale(1.08)}
.vf-play svg{width:30px;height:30px;color:var(--accent-ink);margin-left:4px}
.video-frame.playing .vf-poster{display:none}

/* ---- certificate feature (about) ---- */
.cert-row{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:center}
.cert-img{border-radius:16px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;display:block}
.cert-img img{width:100%;display:block}
.cert-badge{display:inline-flex;align-items:center;gap:10px;background:rgba(231,180,90,.1);
  border:1px solid rgba(231,180,90,.32);color:var(--accent-2);border-radius:999px;padding:8px 16px;
  font-family:var(--font-display);font-weight:600;font-size:.82rem;letter-spacing:.04em}
.cert-meta{margin-top:18px;display:grid;gap:8px;color:var(--muted);font-size:.95rem}
.cert-meta b{color:var(--text);font-weight:600}
@media (max-width:860px){ .cert-row{grid-template-columns:1fr;gap:28px} }

/* ---- WhatsApp floating button ---- */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:60;width:60px;height:60px;border-radius:50%;
  background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 34px -8px rgba(37,211,102,.6);transition:transform .25s var(--ease)}
.wa-float:hover{transform:translateY(-3px) scale(1.05)}
.wa-float svg{width:34px;height:34px}
@media (max-width:680px){ .wa-float{bottom:84px;right:16px;width:54px;height:54px} .wa-float svg{width:30px;height:30px} }

/* ---- FAQ accordion ---- */
.faq-list{max-width:840px;margin:0 auto;display:grid;gap:12px}
.faq-item{background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:border-color .25s}
.faq-item[open]{border-color:var(--line-strong)}
.faq-item summary{cursor:pointer;list-style:none;padding:22px 26px;font-family:var(--font-display);font-weight:600;
  font-size:1.08rem;display:flex;justify-content:space-between;align-items:center;gap:18px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--accent);font-size:1.6rem;line-height:1;transition:transform .3s var(--ease);flex:none}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item .faq-a{padding:0 26px 24px;color:var(--muted);max-width:72ch;font-size:1rem}

/* ---- founders' note ---- */
.founders-note{max-width:820px;margin:0 auto;text-align:center}
.founders-note blockquote{font-family:var(--font-serif);font-weight:400;font-size:clamp(1.3rem,2.6vw,1.85rem);
  line-height:1.45;letter-spacing:-.01em;color:#EDEFF3;margin:22px 0 0}
.founders-sign{margin-top:24px;font-family:var(--font-display);font-weight:600;color:var(--accent);letter-spacing:.02em}
.founders-edit{margin-top:10px;color:var(--muted-2);font-size:.82rem}
