:root{
    --ink:#0d1722;          /* near-black slate navy — top bar / footer */
    --teal:#2c4257;         /* primary steel blue-grey */
    --teal-2:#3d5a73;       /* lighter steel blue */
    --teal-deep:#16222e;    /* deep blue-grey — dark sections */
    --teal-soft:#dde6ee;    /* cool blue-grey tint — icon backgrounds */
    --orange:#2563eb;       /* antique gold accent */
    --orange-2:#7cb0f7;     /* light gold — hover / text on dark */
    --orange-ink:#ffffff;   /* near-black text on gold fills — AA */
    --orange-text:#1d4ed8;
    --orange-hover:#1d4ed8;  /* dark amber for accent text on light bg — AA */
    --cream:#e9eef3;        /* light blue-grey section bg */
    --sand:#d6dfe8;
    --paper:#f3f6f9;        /* cool off-white page bg */
    --text:#18242f;         /* dark slate text */
    --muted:#4b5a6b;        /* blue-grey muted text — AA */
    --white:#ffffff;
    --line:rgba(20,35,52,.12);
    --shadow:0 2px 4px rgba(15,30,48,.05),0 20px 48px -22px rgba(15,30,48,.42);
    --shadow-2:0 4px 8px rgba(15,30,48,.06),0 36px 80px -32px rgba(15,30,48,.5);
    --radius:18px;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  /* Metric-matched fallbacks to prevent font-swap layout shift (CLS) */
  @font-face{font-family:'display-fallback';src:local('Impact'),local('Haettenschweiler'),local('Arial Narrow Bold');
    size-adjust:100%;ascent-override:88%;descent-override:18%;line-gap-override:0%}
  @font-face{font-family:'body-fallback';src:local('Arial');size-adjust:107%}
  html{scroll-behavior:smooth;scroll-padding-top:120px}
  body{
    font-family:'Hanken Grotesk','body-fallback',Arial,sans-serif;
    color:var(--text);
    background:var(--paper);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  h1,h2,h3{line-height:1.02;letter-spacing:.5px;text-wrap:balance}
  p{text-wrap:pretty}
  .display{font-family:'Anton','display-fallback',Impact,sans-serif;font-weight:400;text-transform:uppercase;letter-spacing:1px}
  .label{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:2.5px;font-weight:600}
  a{color:inherit;text-decoration:none}
  .wrap{width:min(1180px,92vw);margin-inline:auto}
  section{position:relative}

  /* ---------- Buttons ---------- */
  .btn{
    font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:1.5px;font-weight:700;
    font-size:.98rem;display:inline-flex;align-items:center;gap:.55rem;
    padding:.92rem 1.6rem;border-radius:10px;cursor:pointer;border:2px solid transparent;
    transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
    white-space:nowrap;
  }
  .btn-orange{background:var(--orange);color:var(--orange-ink);box-shadow:0 10px 24px -10px rgba(37,99,235,.7)}
  .btn-orange svg{stroke:var(--orange-ink)}
  .btn-orange:hover{background:var(--orange-hover);transform:translateY(-2px);box-shadow:0 16px 30px -10px rgba(37,99,235,.75)}
  .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
  .btn-ghost:hover{background:#fff;color:var(--teal);border-color:#fff;transform:translateY(-2px)}
  .btn-dark{background:var(--teal);color:#fff}
  .btn-dark:hover{background:var(--teal-2);transform:translateY(-2px)}

  /* ---------- Top utility bar ---------- */
  .topbar{background:var(--ink);color:#cdd9f0;font-size:.85rem}
  .topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.5rem 0;min-height:42px}
  .topbar .tb-left{display:flex;gap:1.6rem;align-items:center;flex-wrap:wrap}
  .topbar a.tb-item,.topbar .tb-item{display:inline-flex;align-items:center;gap:.45rem;color:#cdd9f0}
  .topbar a.tb-item:hover{color:var(--orange-2)}
  .topbar svg{width:15px;height:15px;flex:none}
  .tb-tag{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:1.5px;color:var(--orange-ink);background:var(--orange);padding:.12rem .6rem;border-radius:4px;font-size:.78rem;font-weight:700}
  .socials{display:flex;gap:.5rem}
  .socials a{width:26px;height:26px;border:1px solid rgba(255,255,255,.25);border-radius:50%;display:grid;place-items:center;color:#cdd9f0;transition:.2s}
  .socials a:hover{background:var(--orange);border-color:var(--orange);color:#fff}

  /* ---------- Header ---------- */
  header{position:sticky;top:0;z-index:60;background:rgba(243,246,249,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);transition:box-shadow .25s}
  header.scrolled{box-shadow:0 10px 30px -18px rgba(10,40,38,.4)}
  .nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem 0}
  .brand{display:flex;align-items:center;gap:.7rem}
  .brand .logomark{width:44px;height:44px;flex:none}
  .brand .word{font-family:'Anton',sans-serif;font-size:1.5rem;letter-spacing:1px;color:var(--teal);line-height:.9}
  .brand .sub{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:2.5px;font-size:.6rem;color:var(--muted);font-weight:600}
  .menu{display:flex;align-items:center;gap:2rem}
  .menu nav{display:flex;gap:1.7rem}
  .menu nav a{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:1.2px;font-weight:600;font-size:1rem;color:var(--text);position:relative;padding:.2rem 0}
  .menu nav a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--orange);transition:width .25s}
  .menu nav a:hover::after{width:100%}
  .menu nav a:hover{color:var(--teal)}
  .hamburger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
  .hamburger span{width:26px;height:3px;background:var(--teal);border-radius:3px;transition:.3s}

  /* ---------- Hero ---------- */
  /* Photo-ready: to add a hero photo later, set background-image on .hero with the
     image first in the stack, e.g. url('assets/hero.jpg') then the gradients below. */
  .hero{
    background:
      radial-gradient(1100px 620px at 88% -15%, rgba(37,99,235,.20), transparent 58%),
      radial-gradient(900px 760px at -5% 115%, rgba(61,90,115,.45), transparent 55%),
      linear-gradient(155deg, #0d1822 0%, #1b2a39 46%, #2c4257 100%);
    color:#fff;position:relative;overflow:hidden;
    padding:clamp(3.5rem,8vw,6.5rem) 0 clamp(7rem,12vw,10rem);
    clip-path:polygon(0 0,100% 0,100% 88%,0 100%);
  }
  /* Homepage hero gets a real graded roof photo behind the navy (scoped via the hero+form grid) */
  .hero:has(.hero-grid){
    background:
      radial-gradient(1100px 620px at 88% -15%, rgba(37,99,235,.22), transparent 58%),
      radial-gradient(900px 760px at -5% 115%, rgba(61,90,115,.40), transparent 55%),
      linear-gradient(155deg, rgba(13,24,34,.95) 0%, rgba(27,42,57,.84) 44%, rgba(44,66,87,.62) 100%),
      url('/images/roof-drone.jpg') center 34%/cover no-repeat;
  }
  .hero::before{
    content:"";position:absolute;inset:0;
    background-image:
      linear-gradient(rgba(255,255,255,.07) 1px,transparent 1px),
      linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px),
      linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),
      linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
    background-size:124px 124px,124px 124px,31px 31px,31px 31px;
    -webkit-mask-image:radial-gradient(125% 105% at 18% -5%, #000 26%, transparent 74%);
    mask-image:radial-gradient(125% 105% at 18% -5%, #000 26%, transparent 74%);
  }
  .hero::after{
    content:"";position:absolute;inset:0;pointer-events:none;
    background:
      radial-gradient(135% 95% at 50% -8%, transparent 50%, rgba(4,11,32,.55) 100%),
      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.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.32'/%3E%3C/svg%3E");
    background-size:cover,160px 160px;
  }
  .hero .wrap{position:relative;z-index:2}
  .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,4vw,3.5rem);align-items:center}
  .hero .eyebrow{color:var(--orange-2);margin-bottom:1.1rem;display:inline-flex;align-items:center;gap:.6rem;font-size:.95rem}
  .hero .eyebrow::before{content:"";width:34px;height:2px;background:var(--orange)}
  .hero h1{font-size:clamp(2.5rem,5.2vw,4.6rem);color:#fff;margin-bottom:1.2rem}
  .hero h1 .hl{color:var(--orange-2)}
  .hero p.lead{font-size:clamp(1.05rem,2vw,1.25rem);max-width:620px;color:#d6e2f7;margin-bottom:2rem}
  .hero-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.2rem}
  .hero-trust{display:flex;gap:1.4rem;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.18);padding-top:1.4rem;max-width:620px}

  /* ---------- Hero lead form ---------- */
  .hero-form-card{padding:1.7rem 1.6rem;position:relative;box-shadow:var(--shadow-2);overflow:hidden}
  .hero-form-card::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;
    background:linear-gradient(90deg,var(--orange),var(--orange-2))}
  .hero-form-card h3{font-family:'Anton',sans-serif;font-size:1.55rem;color:var(--teal-deep);text-transform:uppercase;margin:.2rem 0 .3rem}
  .form-card-badge{display:inline-block;font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:1.5px;
    font-size:.72rem;font-weight:700;color:var(--orange-ink);background:var(--orange);padding:.25rem .7rem;border-radius:6px;margin-bottom:.5rem}
  .form-card-sub{font-size:.92rem;color:var(--muted);margin-bottom:1.1rem;line-height:1.45}
  .form-card-fine{font-size:.82rem;color:var(--muted);text-align:center;margin-top:.8rem}
  .form-card-fine a{color:var(--teal);font-weight:700}
  .hero-trust .ht{display:flex;align-items:center;gap:.6rem;font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:1px;font-size:.95rem;color:#e6eefb}
  .hero-trust svg{width:22px;height:22px;color:var(--orange-2);flex:none}

  /* ---------- Hazard tape ---------- */
  .tape{height:16px;background:repeating-linear-gradient(135deg,var(--orange) 0 26px,var(--ink) 26px 52px);position:relative;z-index:5;margin-top:-1px}

  /* ---------- Value / promise bar ---------- */
  .valuebar{background:#fff;border-bottom:1px solid var(--line)}
  .vb-grid{display:flex;justify-content:space-between;align-items:center;gap:1rem 1.6rem;flex-wrap:wrap;padding:1.05rem 0}
  .vb{display:flex;align-items:center;gap:.55rem;font-family:'Saira Condensed',sans-serif;text-transform:uppercase;
    letter-spacing:1px;font-weight:700;font-size:.95rem;color:var(--teal-deep)}
  .vb svg{width:22px;height:22px;color:var(--orange);flex:none}
  @media(max-width:760px){.vb-grid{justify-content:flex-start;gap:.7rem 1.3rem;padding:.9rem 0}.vb{font-size:.86rem}}

  /* ---------- Feature strip ---------- */
  .features{background:var(--cream);padding:clamp(2.5rem,5vw,3.5rem) 0}
  .feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
  .feat-2up{grid-template-columns:repeat(2,minmax(0,1fr))}
  .feat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:1.5rem;display:flex;gap:1rem;align-items:flex-start;transition:.25s;min-width:0}
  .feat:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
  .feat .ic{width:46px;height:46px;border-radius:11px;background:var(--teal-soft);display:grid;place-items:center;flex:none;color:var(--teal)}
  .feat .ic svg{width:24px;height:24px}
  .feat h3{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:.8px;font-size:1.15rem;color:var(--teal-deep);margin-bottom:.2rem}
  .feat p{font-size:.92rem;color:var(--muted);line-height:1.45}

  /* ---------- Stats band ---------- */
  .statsband{background:linear-gradient(150deg,var(--teal-deep),#27384a);color:#fff;
    padding:clamp(2.4rem,5vw,3.4rem) 0;position:relative;overflow:hidden}
  .statsband::before{content:"";position:absolute;inset:0;
    background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
    background-size:64px 64px;-webkit-mask-image:radial-gradient(120% 120% at 50% 0%,#000,transparent 75%);mask-image:radial-gradient(120% 120% at 50% 0%,#000,transparent 75%)}
  .stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;position:relative;z-index:2}
  .stat{text-align:center;position:relative}
  .stat:not(:last-child)::after{content:"";position:absolute;right:-.75rem;top:50%;transform:translateY(-50%);width:1px;height:54px;background:rgba(255,255,255,.14)}
  .snum{font-family:'Anton','display-fallback',Impact,sans-serif;font-size:clamp(2.5rem,5vw,3.6rem);
    color:var(--orange-2);line-height:1;font-variant-numeric:tabular-nums}
  .slabel{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:1.5px;
    font-size:.84rem;color:#cdd9f0;margin-top:.45rem}

  /* ---------- Section heading ---------- */
  .sec{padding:clamp(3.5rem,7vw,6rem) 0}
  .sec-head{max-width:680px;margin-bottom:2.8rem}
  .sec-head.center{margin-inline:auto;text-align:center}
  .sec-head .label{color:var(--orange-text);display:block;margin-bottom:.8rem}
  .sec-head h2{font-size:clamp(2.1rem,4.5vw,3.4rem);color:var(--teal-deep)}
  .sec-head p{color:var(--muted);font-size:1.08rem;margin-top:1rem}

  /* ---------- Services ---------- */
  .services{background:var(--paper)}
  .svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
  .svc{
    background:#fff;border:1px solid var(--line);border-radius:14px;padding:1.5rem 1.4rem;
    position:relative;overflow:hidden;transition:.25s;
  }
  .svc::before{content:"";position:absolute;left:0;top:0;height:100%;width:4px;background:var(--orange);transform:scaleY(0);transform-origin:bottom;transition:transform .3s}
  .svc:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
  .svc:hover::before{transform:scaleY(1)}
  .svc .ic{width:52px;height:52px;border-radius:12px;background:linear-gradient(150deg,var(--teal),var(--teal-2));color:#fff;display:grid;place-items:center;margin-bottom:1rem;transition:.3s}
  .svc:hover .ic{background:linear-gradient(150deg,var(--orange),var(--orange-hover))}
  .svc .ic svg{width:27px;height:27px}
  .svc h3{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:.6px;font-size:1.18rem;color:var(--teal-deep);margin-bottom:.35rem}
  .svc p{font-size:.9rem;color:var(--muted);line-height:1.45}

  /* ---------- About ---------- */
  .about{background:var(--teal-deep);color:#fff;overflow:hidden}
  .about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:3.2rem;align-items:center}
  .about .sec-head h2{color:#fff}
  .about .label{color:var(--orange-2)}
  .about p.body{color:#cdd9f0;font-size:1.06rem;margin-bottom:1.2rem}
  .about-points{list-style:none;display:grid;gap:.9rem;margin-top:1.6rem}
  .about-points li{display:flex;gap:.8rem;align-items:flex-start;font-size:1rem;color:#e6eefb}
  .about-points svg{width:22px;height:22px;color:var(--orange-2);flex:none;margin-top:.15rem}
  .about-art{position:relative;min-height:380px;border-radius:var(--radius);overflow:hidden;
    background:linear-gradient(150deg,#1b2c3d,#33506c);border:1px solid rgba(255,255,255,.12)}
  .about-art::before{content:"";position:absolute;inset:0;
    background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);
    background-size:34px 34px}
  .about-art .roofline{position:absolute;left:0;right:0;bottom:0;height:60%;
    background:repeating-linear-gradient(90deg,rgba(255,255,255,.04) 0 18px,transparent 18px 20px);
    clip-path:polygon(0 45%,50% 0,100% 45%,100% 100%,0 100%);border-top:3px solid var(--orange)}
  .about-art .badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}
  .about-art .badge .num{font-family:'Anton',sans-serif;font-size:5rem;color:#fff;line-height:.9}
  .about-art .badge .txt{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:2px;color:var(--orange-2);font-weight:600}

  /* ---------- Process ---------- */
  .process{background:var(--cream)}
  .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;counter-reset:step}
  .step{background:#fff;border:1px solid var(--line);border-radius:14px;padding:1.8rem 1.5rem;position:relative}
  .step .n{font-family:'Anton',sans-serif;font-size:2.6rem;color:var(--sand);line-height:.8;margin-bottom:.6rem}
  .step:hover .n{color:var(--orange)}
  .step h3{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:.6px;font-size:1.2rem;color:var(--teal-deep);margin-bottom:.35rem}
  .step p{font-size:.92rem;color:var(--muted)}

  /* ---------- Areas ---------- */
  .areas{background:var(--paper)}
  .areas-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center}
  .area-list{columns:2;column-gap:1.5rem}
  .area-list .a{display:flex;align-items:center;gap:.6rem;padding:.5rem 0;font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:.6px;font-size:1.05rem;color:var(--teal-deep);break-inside:avoid}
  .area-list svg{width:16px;height:16px;color:var(--orange);flex:none}
  .map-card{background:linear-gradient(150deg,var(--teal),var(--teal-2));border-radius:var(--radius);min-height:340px;position:relative;overflow:hidden;color:#fff;padding:2rem}
  .map-card::before{content:"";position:absolute;inset:0;
    background-image:linear-gradient(rgba(255,255,255,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px);
    background-size:40px 40px;mask-image:radial-gradient(circle at 60% 55%,#000,transparent 75%)}
  .map-card .pin{position:absolute;top:55%;left:58%;width:24px;height:24px;background:var(--orange);border-radius:50% 50% 50% 0;transform:translate(-50%,-50%) rotate(-45deg);box-shadow:0 0 0 8px rgba(37,99,235,.25)}
  .map-card .pin::after{content:"";position:absolute;inset:7px;background:#fff;border-radius:50%}
  .map-card h3{font-family:'Anton',sans-serif;font-size:1.8rem;position:relative;z-index:2}
  .map-card p{position:relative;z-index:2;color:#d6e2f7;max-width:280px;margin-top:.6rem}

  /* ---------- CTA band ---------- */
  .ctaband{background:linear-gradient(150deg,var(--orange),var(--orange-hover));color:var(--orange-ink);
    padding:clamp(2.6rem,5vw,3.6rem) 0;clip-path:polygon(0 12%,100% 0,100% 100%,0 100%)}
  .ctaband .wrap{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
  .ctaband h2{font-family:'Anton',sans-serif;font-size:clamp(1.8rem,3.5vw,2.8rem);text-transform:uppercase}
  .ctaband .phone{font-family:'Anton',sans-serif;font-size:clamp(1.4rem,3vw,2rem);display:inline-flex;align-items:center;gap:.6rem}
  .ctaband .btn-dark{background:var(--ink)}
  .ctaband .btn-dark:hover{background:#000}

  /* ---------- Contact ---------- */
  .contact{background:var(--teal-deep);color:#fff}
  .contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:3rem}
  .contact .label{color:var(--orange-2)}
  .contact h2{font-size:clamp(2rem,4vw,3rem);color:#fff;margin-bottom:1rem}
  .contact .intro{color:#cdd9f0;margin-bottom:2rem;max-width:380px}
  .cinfo{display:grid;gap:1.3rem}
  .cinfo .row{display:flex;gap:.9rem;align-items:flex-start}
  .cinfo .ic{width:42px;height:42px;border-radius:11px;background:rgba(255,255,255,.08);display:grid;place-items:center;flex:none;color:var(--orange-2)}
  .cinfo .ic svg{width:20px;height:20px}
  .cinfo .k{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:1.5px;font-size:.8rem;color:#9fb3d4}
  .cinfo .v{font-size:1.05rem;color:#fff}
  .form-card{background:#fff;border-radius:var(--radius);padding:2rem;color:var(--text);box-shadow:var(--shadow)}
  .form-card h3{font-family:'Anton',sans-serif;font-size:1.5rem;color:var(--teal-deep);text-transform:uppercase;margin-bottom:1.2rem}
  .field{margin-bottom:1rem}
  .field label{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:1.2px;font-size:.78rem;color:var(--muted);display:block;margin-bottom:.35rem;font-weight:600}
  .field input,.field select,.field textarea{
    width:100%;padding:.8rem .9rem;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:.98rem;color:var(--text);background:var(--paper);transition:.2s}
  .field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--orange);background:#fff;box-shadow:0 0 0 3px rgba(37,99,235,.15)}
  .field textarea{resize:vertical;min-height:96px}
  .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
  .form-card .btn{width:100%;justify-content:center;margin-top:.4rem}
  .form-success{display:none;text-align:center;padding:1.5rem .5rem}
  .form-success.show{display:block}
  .form-success .ic{width:64px;height:64px;border-radius:50%;background:var(--teal-soft);color:var(--teal);display:grid;place-items:center;margin:0 auto 1rem}
  .form-success h3{margin-bottom:.4rem}
  .form-success p{color:var(--muted)}
  .form-error{display:none;margin-top:.9rem;padding:.8rem 1rem;border-radius:10px;
    background:#fdecea;border:1px solid #f3b4ab;color:#9a2b1e;font-size:.92rem;line-height:1.45}
  .form-error.show{display:block}
  .form-error a{color:#9a2b1e;font-weight:700;text-decoration:underline}

  /* ---------- Rating badge (hero) ---------- */
  .hero-trust .ht.rating{color:#fff}
  .stars{display:inline-flex;gap:1px;color:#ffc043}
  .stars svg{width:16px;height:16px;color:#ffc043}
  .rating .rate-num{font-weight:700;color:#fff}

  /* ---------- Reviews ---------- */
  .reviews{background:var(--cream)}
  .gbadge{display:inline-flex;align-items:center;gap:.7rem;background:#fff;border:1px solid var(--line);
    border-radius:50px;padding:.5rem 1.1rem .5rem .6rem;box-shadow:var(--shadow);margin:0 auto 2.4rem;
    font-family:'Saira Condensed',sans-serif;letter-spacing:.5px}
  .gbadge .glogo{width:30px;height:30px;flex:none}
  .gbadge .gnum{font-size:1.25rem;font-weight:700;color:var(--teal-deep)}
  .gbadge .gstars{display:inline-flex;color:#ffc043}
  .gbadge .gstars svg{width:17px;height:17px}
  .gbadge .gcount{color:var(--muted);font-size:.9rem}
  .reviews-wrap{display:flex;flex-direction:column;align-items:center}
  .rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;width:100%}
  .rev{background:#fff;border:1px solid var(--line);border-radius:14px;padding:1.7rem 1.5rem;transition:.25s;display:flex;flex-direction:column}
  .rev:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
  .rev .rev-stars{display:inline-flex;color:#ffc043;margin-bottom:.9rem}
  .rev .rev-stars svg{width:18px;height:18px}
  .rev p.quote{font-size:1rem;color:var(--text);line-height:1.55;margin-bottom:1.2rem;flex:1}
  .rev .who{display:flex;align-items:center;gap:.8rem}
  .rev .ava{width:42px;height:42px;border-radius:50%;flex:none;display:grid;place-items:center;
    background:linear-gradient(150deg,var(--teal),var(--teal-2));color:#fff;font-family:'Anton',sans-serif;font-size:1.1rem}
  .rev .nm{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:.6px;font-weight:700;color:var(--teal-deep);font-size:1rem;line-height:1.1}
  .rev .loc{font-size:.85rem;color:var(--muted)}

  /* ---------- Footer ---------- */
  footer{background:var(--ink);color:#aebdd6;padding:clamp(3rem,5vw,4rem) 0 0}
  .foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:2.5rem;padding-bottom:2.5rem}
  .foot-brand .word{font-family:'Anton',sans-serif;font-size:1.6rem;color:#fff;letter-spacing:1px}
  .foot-brand .sub{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:2.5px;font-size:.62rem;color:#8294b4}
  .foot-brand p{margin:1rem 0;font-size:.95rem;max-width:300px}
  .foot-brand .lic{display:inline-flex;align-items:center;gap:.5rem;font-family:'Saira Condensed',sans-serif;letter-spacing:1.5px;color:#cdd9f0;border:1px dashed rgba(255,255,255,.25);padding:.4rem .8rem;border-radius:8px;font-size:.85rem}
  footer h4{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:1.5px;color:#fff;font-size:1rem;margin-bottom:1.1rem}
  footer ul{list-style:none;display:grid;gap:.55rem}
  footer ul a{font-size:.93rem;color:#aebdd6;transition:.2s}
  footer ul a:hover{color:var(--orange-2);padding-left:4px}
  .foot-contact .row{display:flex;gap:.6rem;align-items:flex-start;margin-bottom:.9rem;font-size:.93rem}
  .foot-contact svg{width:17px;height:17px;color:var(--orange-2);flex:none;margin-top:.2rem}
  .foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.3rem 0;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:#8294b4}
  .foot-bottom .socials a{border-color:rgba(255,255,255,.18)}

  /* ---------- Floating call ---------- */
  .float-call{position:fixed;right:18px;bottom:18px;z-index:70;background:var(--orange);color:var(--orange-ink);border-radius:50px;
    display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.3rem;font-family:'Saira Condensed',sans-serif;
    text-transform:uppercase;letter-spacing:1.5px;font-weight:700;box-shadow:0 14px 30px -10px rgba(37,99,235,.7);transition:.2s}
  .float-call:hover{background:var(--orange-2);transform:translateY(-3px)}
  .float-call svg{width:18px;height:18px}

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

  /* ---------- Accessibility ---------- */
  .skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--orange);color:#fff;padding:.7rem 1.2rem;
    border-radius:0 0 8px 0;font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:1px;font-weight:700}
  .skip-link:focus{left:0}
  .sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
  a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,summary:focus-visible{
    outline:3px solid var(--orange);outline-offset:2px;border-radius:4px}
  @media(prefers-reduced-motion:reduce){
    *{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
    .js .reveal{opacity:1!important;transform:none!important}
  }

  /* ---------- Why Choose Us ---------- */
  .whyus{background:var(--paper)}
  .whyus-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(2rem,4vw,3.2rem);align-items:center}
  .whyus .sec-head{margin-bottom:1.2rem}
  .whyus-intro{color:var(--muted);font-size:1.05rem;margin-bottom:1.4rem}
  .whyus-cta{display:flex;gap:1rem;flex-wrap:wrap}
  .why-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
  .why{display:flex;gap:1rem;background:#fff;border:1px solid var(--line);border-radius:14px;padding:1.3rem;transition:.25s}
  .why:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
  .why .ic{width:46px;height:46px;border-radius:11px;background:var(--teal-soft);color:var(--teal);display:grid;place-items:center;flex:none}
  .why .ic svg{width:24px;height:24px}
  .why h3{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:.6px;font-size:1.08rem;color:var(--teal-deep);margin-bottom:.15rem}
  .why p{font-size:.9rem;color:var(--muted);line-height:1.45}

  /* ---------- Gallery (photo-ready) ---------- */
  .gallery{background:var(--cream)}
  .gal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
  .gal-tile{position:relative;aspect-ratio:4/3;border-radius:14px;overflow:hidden;border:1px solid var(--line);
    background:linear-gradient(150deg,var(--teal-deep),var(--teal-2));display:grid;place-items:center;
    padding:0;width:100%;cursor:zoom-in;font:inherit;color:inherit}
  .gal-tile img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s ease}
  .gal-tile:hover img,.gal-tile:focus-visible img{transform:scale(1.06)}
  .gal-tile:focus-visible{outline:3px solid var(--orange);outline-offset:2px}
  /* lightbox */
  .lb{position:fixed;inset:0;z-index:120;background:rgba(8,14,22,.92);display:none;align-items:center;justify-content:center;padding:4vmin}
  .lb.open{display:flex}
  .lb img{max-width:100%;max-height:100%;border-radius:10px;box-shadow:0 24px 60px -12px rgba(0,0,0,.6)}
  .lb-close{position:absolute;top:16px;right:18px;width:46px;height:46px;border:0;border-radius:50%;cursor:pointer;
    background:rgba(255,255,255,.14);color:#fff;font-size:1.5rem;line-height:1;display:grid;place-items:center}
  .lb-close:hover{background:rgba(255,255,255,.26)}
  /* before / after slider */
  .ba-sec{background:var(--paper)}
  .ba{position:relative;aspect-ratio:3/4;max-width:430px;margin-inline:auto;border-radius:16px;overflow:hidden;
    border:1px solid var(--line);box-shadow:0 18px 40px -18px rgba(15,30,48,.5);user-select:none;touch-action:pan-y}
  .ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
  .ba .ba-b{clip-path:inset(0 calc(100% - var(--pos,50%)) 0 0);z-index:2}
  .ba-range{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize;z-index:5}
  .ba-line{position:absolute;top:0;bottom:0;left:var(--pos,50%);width:3px;background:#fff;transform:translateX(-50%);z-index:3;box-shadow:0 0 0 1px rgba(0,0,0,.18)}
  .ba-knob{position:absolute;top:50%;left:var(--pos,50%);transform:translate(-50%,-50%);z-index:4;width:44px;height:44px;
    border-radius:50%;background:var(--orange);color:#fff;display:grid;place-items:center;box-shadow:0 4px 14px rgba(0,0,0,.32);pointer-events:none;font-size:1.2rem;font-weight:700}
  .ba-tag{position:absolute;bottom:.7rem;z-index:4;font-family:'Saira Condensed',sans-serif;text-transform:uppercase;
    letter-spacing:1px;font-size:.7rem;font-weight:700;padding:.22rem .62rem;border-radius:5px;color:#fff;background:rgba(13,23,34,.74)}
  .ba-tag-b{left:.7rem}.ba-tag-a{right:.7rem}
  /* video feature */
  .video-sec{background:var(--teal-deep);color:#fff}
  .video-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:2.6rem;align-items:center}
  .video-copy .label{color:var(--orange-2)}
  .video-copy h2{color:#fff;margin:.3rem 0 .8rem}
  .video-copy p{color:#c7d3e0;max-width:46ch;margin-bottom:1.4rem}
  .video-frame{max-width:300px;margin-inline:auto;border-radius:26px;overflow:hidden;border:7px solid #0a121b;
    box-shadow:0 26px 55px -18px rgba(0,0,0,.6);background:#0a121b}
  .video-frame video{width:100%;height:auto;display:block;background:#0a121b}
  @media (max-width:760px){.video-grid{grid-template-columns:1fr;gap:1.6rem;text-align:center}.video-copy p{margin-inline:auto}}
  .gal-ph{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;text-align:center}
  .gal-ph svg{width:34px;height:34px;color:#cdd9f0}
  .gal-ph small{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:1.5px;font-size:.78rem;color:#dbe6fb}
  .gal-tile .tag{position:absolute;top:.7rem;left:.7rem;background:var(--orange);color:var(--orange-ink);font-family:'Saira Condensed',sans-serif;
    text-transform:uppercase;letter-spacing:1px;font-size:.68rem;font-weight:700;padding:.2rem .6rem;border-radius:5px;z-index:2}
  .gal-note{text-align:center;color:var(--muted);font-size:.92rem;margin-top:1.8rem}
  .gal-note a{color:var(--teal);font-weight:700}

  /* ---------- FAQ ---------- */
  .faq{background:var(--paper)}
  .faq-wrap{max-width:820px;margin-inline:auto}
  .faq-item{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:.8rem;transition:box-shadow .2s,border-color .2s}
  .faq-item[open]{box-shadow:var(--shadow);border-color:transparent}
  .faq-item summary{list-style:none;cursor:pointer;padding:1.15rem 1.3rem;display:flex;justify-content:space-between;gap:1rem;align-items:center;
    font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:.5px;font-weight:700;font-size:1.06rem;color:var(--teal-deep)}
  .faq-item summary::-webkit-details-marker{display:none}
  .faq-item summary .pl{flex:none;color:var(--orange);transition:transform .25s}
  .faq-item[open] summary .pl{transform:rotate(45deg)}
  .faq-item .ans{padding:0 1.3rem 1.2rem;color:var(--muted);font-size:.98rem;line-height:1.6}

  /* ---------- Mobile action bar ---------- */
  .mobile-cta{display:none}

  /* ---------- Responsive ---------- */
  @media(max-width:980px){
    .feat-grid,.svc-grid,.steps,.rev-grid,.gal-grid{grid-template-columns:repeat(2,1fr)}
    /* a lone last tile (odd-count galleries) spans full width instead of sitting half-empty */
    .gal-grid>.gal-tile:last-child:nth-child(odd){grid-column:1/-1;aspect-ratio:16/9}
    .about-grid,.areas-grid,.contact-grid,.hero-grid,.whyus-grid{grid-template-columns:1fr}
    .hero-trust{max-width:none}
    .about-art{min-height:280px}
    .foot-grid{grid-template-columns:1fr 1fr}
  }
  @media(max-width:760px){
    .topbar .tb-left{gap:1rem;font-size:.78rem}
    .topbar .hide-sm{display:none}
    .menu nav{display:none}
    .hamburger{display:flex}
    .menu.open nav{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--paper);
      padding:1rem 6vw 1.4rem;gap:1rem;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
    .menu .btn{display:none}
    .menu.open .btn{display:inline-flex;width:fit-content}
    .feat-grid,.svc-grid,.steps,.foot-grid,.rev-grid,.why-cards{grid-template-columns:1fr}
    .area-list{columns:1}
    .stats-grid{grid-template-columns:1fr 1fr;gap:2.1rem 1rem}
    .stat:not(:last-child)::after{display:none}
    .form-row{grid-template-columns:1fr}
    .hero{clip-path:polygon(0 0,100% 0,100% 94%,0 100%)}
    .float-call{display:none}
    body{padding-bottom:62px}
    .mobile-cta{display:grid;grid-template-columns:1fr 1fr 1fr;position:fixed;left:0;right:0;bottom:0;z-index:80;
      background:#fff;border-top:1px solid var(--line);box-shadow:0 -10px 30px -12px rgba(15,40,80,.25)}
    .mobile-cta a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.18rem;padding:.55rem .3rem;min-height:62px;
      font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:.8px;font-size:.72rem;font-weight:700;color:var(--teal-deep)}
    .mobile-cta a svg{width:20px;height:20px}
    .mobile-cta a.cta-call,.mobile-cta a.cta-text{color:var(--teal)}
    .mobile-cta a.cta-text{border-left:1px solid var(--line);border-right:1px solid var(--line)}
    .mobile-cta a.cta-est{background:var(--orange);color:var(--orange-ink)}
  }

  /* ---------- Service-page helpers ---------- */
  .svc-points{list-style:none;display:grid;gap:.7rem;margin-top:1.4rem}
  .svc-points li{display:flex;gap:.7rem;align-items:flex-start;color:var(--text);font-size:1rem;line-height:1.5}
  .svc-points svg{width:22px;height:22px;color:var(--teal);flex:none;margin-top:.18rem}
  .ctaband .phone{white-space:nowrap}
