/* ============================================================
   Proven Surfaces — Premium Design System v2
   Bold typography · Glass effects · Cinematic animations
   ============================================================ */

:root{
  --navy:     #0f2d4b;
  --navy-d:   #070d1a;
  --navy-l:   #1a4470;
  --cobalt:   #0066FF;
  --cobalt-l: #3d8bff;
  --slate:    #3c4b5a;
  --silver:   #d0d5db;
  --offwhite: #f5f7fa;
  --white:    #ffffff;
  --accent:   #0066FF;
  --text:     #1e293b;
  --muted:    #64748b;

  --layer-metallic: #0066FF;
  --layer-flake:    #2a6cb8;
  --layer-concrete: #8b9baa;

  --radius:    12px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --shadow:    0 2px 8px rgba(0,0,0,.04), 0 8px 24px rgba(0,0,0,.06);
  --shadow-lg: 0 12px 40px rgba(0,0,0,.12);
  --shadow-xl: 0 20px 60px rgba(0,0,0,.15);
  --glass:     rgba(255,255,255,.7);
  --glass-border: rgba(255,255,255,.25);

  --font:  'DM Sans', system-ui, -apple-system, sans-serif;
  --serif: 'DM Serif Display', Georgia, serif;
  --ease:  cubic-bezier(.4,0,.2,1);
  --bounce: cubic-bezier(.34,1.56,.64,1);

  /* Type scale */
  --text-xs:  clamp(.72rem, .7rem + .1vw, .78rem);
  --text-sm:  clamp(.82rem, .8rem + .1vw, .88rem);
  --text-base: clamp(.92rem, .9rem + .1vw, 1rem);
  --text-lg:  clamp(1.05rem, 1rem + .2vw, 1.15rem);
  --text-xl:  clamp(1.3rem, 1.2rem + .4vw, 1.5rem);
  --text-2xl: clamp(1.6rem, 1.4rem + .8vw, 2.2rem);
  --text-3xl: clamp(2rem, 1.6rem + 1.5vw, 3.2rem);
  --text-4xl: clamp(2.4rem, 2rem + 2vw, 3.8rem);
  --text-5xl: clamp(2.8rem, 2.2rem + 2.5vw, 4.2rem);

  /* Spacing */
  --section-py: clamp(4rem, 3rem + 3vw, 7rem);
  --section-py-sm: clamp(3rem, 2.5rem + 2vw, 5rem);
}

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:76px;-webkit-text-size-adjust:100%}

/* Selection & scrollbar */
::selection{background:rgba(0,102,255,.15);color:var(--navy)}
::-webkit-scrollbar{width:8px}
::-webkit-scrollbar-track{background:var(--offwhite)}
::-webkit-scrollbar-thumb{background:rgba(15,45,75,.2);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:rgba(15,45,75,.35)}
body{font-family:var(--font);color:var(--text);background:var(--white);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font:inherit}
input,select,textarea{font:inherit;width:100%;border:1.5px solid #e2e8f0;border-radius:var(--radius);padding:16px 18px;background:var(--white);color:var(--text);transition:border .25s,box-shadow .25s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--cobalt);box-shadow:0 0 0 4px rgba(0,102,255,.1)}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' fill='none' stroke='%2364748b' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}

/* UTILITY */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.label{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--cobalt);margin-bottom:12px;position:relative;padding-left:20px}
.label::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:12px;height:2px;background:var(--cobalt)}
.label--light{color:rgba(255,255,255,.5)}.label--light::before{background:rgba(255,255,255,.3)}
.section-head{margin-bottom:56px}
.section-head h2{font-family:var(--serif);font-size:clamp(2rem,4.5vw,3.2rem);font-weight:400;color:var(--navy);line-height:1.1}
.section-head p{color:var(--muted);font-size:1.05rem;margin-top:14px;max-width:560px;line-height:1.7}
.section-head--center{text-align:center}
.section-head--center p{margin-left:auto;margin-right:auto}
.section-head--center .label{padding-left:0}
.section-head--center .label::before{display:none}

/* ============ TEXTURE EFFECTS ============ */

.texture-grain{position:relative}
.texture-grain::after{
  content:'';position:absolute;top:0;left:0;right:0;bottom:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  background-size:128px 128px;pointer-events:none;z-index:1;opacity:.5
}
.texture-grain>*{position:relative;z-index:2}

.divider-three{display:flex;height:4px;width:100%}
.divider-three span:nth-child(1){flex:1;background:var(--layer-metallic)}
.divider-three span:nth-child(2){flex:1;background:var(--layer-flake)}
.divider-three span:nth-child(3){flex:1;background:var(--layer-concrete)}

.shimmer{
  background:linear-gradient(110deg,transparent 20%,rgba(255,255,255,.12) 40%,rgba(255,255,255,.12) 60%,transparent 80%);
  background-size:200% 100%;animation:shimmer 3s ease-in-out infinite
}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

.texture-flake{
  background-image:
    radial-gradient(circle 1px,rgba(15,45,75,.08) 1px,transparent 1px),
    radial-gradient(circle 1px,rgba(0,86,210,.06) 1px,transparent 1px);
  background-size:20px 20px,33px 33px;
  background-position:0 0,11px 13px
}

.svc-card--metallic{border-top:3px solid var(--layer-metallic)}
.svc-card--flake{border-top:3px solid var(--layer-flake)}
.svc-card--concrete{border-top:3px solid var(--layer-concrete)}
.svc-card--fast{border-top:3px solid #059669}
.svc-card--premium{border-top:3px solid #7c3aed}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:15px 32px;font-size:.92rem;font-weight:600;
  border-radius:50px;background:var(--navy);color:var(--white);
  transition:all .3s var(--ease);white-space:nowrap;
  position:relative;overflow:hidden
}
.btn::before{
  content:'';position:absolute;top:0;left:0;right:0;bottom:0;
  background:linear-gradient(135deg,rgba(255,255,255,.15),transparent);
  opacity:0;transition:opacity .3s
}
.btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(15,45,75,.25)}
.btn:hover::before{opacity:1}
.btn:active{transform:translateY(0)}
.btn--outline{background:transparent;border:2px solid var(--navy);color:var(--navy)}
.btn--outline:hover{background:var(--navy);color:var(--white);box-shadow:0 6px 20px rgba(15,45,75,.2)}
.btn--white{background:var(--white);color:var(--navy)}
.btn--white:hover{background:var(--offwhite);box-shadow:0 6px 20px rgba(0,0,0,.15)}
.btn--cobalt{background:var(--cobalt);color:var(--white)}
.btn--cobalt:hover{background:#0052cc;box-shadow:0 6px 20px rgba(0,102,255,.3)}
.btn--sm{padding:10px 22px;font-size:.85rem}
.btn--full{width:100%}
.btn--lg{font-size:1.1rem;padding:18px 48px}
.btn--ghost{background:rgba(255,255,255,.1);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2)}
.btn--ghost:hover{background:rgba(255,255,255,.2)}

/* ============ NAV ============ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid transparent;transition:all .4s var(--ease)}
.nav--scrolled{border-bottom-color:rgba(0,0,0,.06);box-shadow:0 4px 30px rgba(0,0,0,.06)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:76px}
.nav__logo img{height:auto;max-height:48px;width:auto;max-width:260px}
.nav__links{display:flex;gap:32px;align-items:center}
.nav__links>a,.nav__dropdown-toggle{font-size:.88rem;font-weight:500;color:var(--slate);transition:color .25s;position:relative}
.nav__links>a:hover,.nav__dropdown-toggle:hover{color:var(--navy)}
.nav__links>a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:2px;background:var(--cobalt);transform:scaleX(0);transition:transform .25s var(--ease);border-radius:2px}
.nav__links>a:hover::after{transform:scaleX(1)}
.nav__right{display:flex;align-items:center;gap:16px}
.nav__phone{font-size:.88rem;font-weight:600;color:var(--navy);display:flex;align-items:center;gap:6px}
.nav__burger{display:none;flex-direction:column;gap:5px;width:28px;padding:4px 0}
.nav__burger span{display:block;height:2px;background:var(--navy);border-radius:2px;transition:transform .3s,opacity .3s}

.nav__dropdown{position:relative}
.nav__dropdown-toggle{display:flex;align-items:center;gap:4px}
.nav__dropdown-menu{position:absolute;top:calc(100% + 12px);left:-16px;min-width:240px;padding:12px 0;background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);border:1px solid rgba(0,0,0,.06);opacity:0;visibility:hidden;transform:translateY(12px);transition:all .25s var(--ease);z-index:110}
.nav__dropdown:hover .nav__dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav__dropdown-menu a{display:block;padding:10px 24px;font-size:.88rem;font-weight:500;color:var(--slate);transition:all .2s}
.nav__dropdown-menu a:hover{background:var(--offwhite);color:var(--navy);padding-left:28px}
.nav__dropdown-label{display:block;padding:8px 24px 4px;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);pointer-events:none}
.nav__dropdown-label:first-child{padding-top:4px}
.nav__dropdown-divider{display:block;height:1px;margin:8px 16px;background:rgba(0,0,0,.08)}

/* ============ BREADCRUMB ============ */
.breadcrumb{padding:90px 0 0;background:var(--offwhite)}
.breadcrumb__inner{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--muted);flex-wrap:wrap}
.breadcrumb__inner a{color:var(--accent);transition:color .2s}
.breadcrumb__inner a:hover{color:var(--navy)}
.breadcrumb__sep{color:var(--silver)}

/* ============ HERO ============ */
.hero{
  padding:140px 0 100px;
  background:linear-gradient(160deg,#f0f4f8 0%,#e8edf5 30%,#dde5f0 60%,#f5f7fa 100%);
  position:relative;overflow:hidden
}
.hero::before{
  content:'';position:absolute;top:-50%;right:-20%;width:80%;height:200%;
  background:radial-gradient(ellipse,rgba(0,102,255,.06) 0%,transparent 70%);
  pointer-events:none
}
.hero__inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.hero__badge{display:inline-flex;align-items:center;gap:8px;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--cobalt);margin-bottom:20px;padding:6px 16px;background:rgba(0,102,255,.06);border-radius:50px;border:1px solid rgba(0,102,255,.1)}
.hero h1{font-family:var(--serif);font-size:clamp(2.8rem,5.5vw,4.2rem);font-weight:400;line-height:1.05;color:var(--navy);margin-bottom:24px}
.hero p{font-size:1.15rem;color:var(--muted);max-width:480px;margin-bottom:32px;line-height:1.7}
.hero__ctas{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:32px}
.hero__trust{display:flex;flex-wrap:wrap;gap:20px;font-size:.82rem;font-weight:600;color:var(--slate)}
.hero__trust div{display:flex;align-items:center;gap:6px}
.hero__trust svg{color:var(--cobalt)}
.hero__image{position:relative}
.hero__image img{width:100%;height:560px;object-fit:cover;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl)}
.hero__image::after{
  content:'';position:absolute;inset:-8px;border-radius:calc(var(--radius-xl) + 8px);
  border:1px solid rgba(0,102,255,.12);pointer-events:none
}

/* Hero — Cinematic Full-Viewport */
.hero--cinematic{
  padding:0;min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:var(--navy-d);position:relative;overflow:hidden
}
.hero--cinematic::before{display:none}
.hero__bg{position:absolute;inset:0;z-index:1}
.hero__bg-img{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.5s ease-in-out
}
.hero__bg-img--active{opacity:1}
.hero__overlay{
  position:absolute;inset:0;z-index:2;
  background:rgba(7,13,26,.68)
}
.hero__center{
  position:relative;z-index:3;text-align:center;
  padding:160px 24px 100px;max-width:820px;margin:0 auto
}
.hero--cinematic .hero__badge{
  color:rgba(255,255,255,.7);background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.1)
}
.hero--cinematic h1{color:var(--white);margin-bottom:24px}
.hero--cinematic p{
  color:rgba(255,255,255,.7);max-width:640px;
  margin:0 auto 36px;font-size:1.15rem;line-height:1.7
}
.hero--cinematic .hero__ctas{justify-content:center;margin-bottom:36px}
.hero--cinematic .hero__trust{justify-content:center;color:rgba(255,255,255,.7)}
.hero--cinematic .hero__trust svg{color:var(--cobalt-l)}

/* Hero logo centerpiece */
.hero__logo{
  display:block;margin:0 auto 28px;width:220px;height:220px;
  filter:drop-shadow(0 8px 32px rgba(0,102,255,.3)) drop-shadow(0 2px 8px rgba(0,0,0,.4));
  animation:heroLogoIn 1.2s cubic-bezier(.4,0,.2,1) both
}
@keyframes heroLogoIn{
  from{opacity:0;transform:scale(.85) translateY(20px)}
  to{opacity:1;transform:scale(1) translateY(0)}
}

/* Hero dark variant */
.hero--dark{background:var(--navy);padding:0 0 64px}
.hero--dark .hero__badge{color:rgba(255,255,255,.6)}
.hero--dark h1{color:var(--white)}
.hero--dark p{color:rgba(255,255,255,.7)}
.hero--dark .hero__trust div{color:rgba(255,255,255,.7)}
.hero--dark .hero__trust svg{color:var(--cobalt)}
.hero--compact{padding:100px 0 48px}
.hero--compact h1{font-size:clamp(2rem,4vw,3rem);margin-bottom:14px}

/* Page hero */
.page-hero{
  padding:110px 0 60px;background:var(--navy);
  position:relative;overflow:hidden
}
.page-hero::before{
  content:'';position:absolute;top:0;right:0;width:60%;height:100%;
  background:radial-gradient(ellipse at right,rgba(0,102,255,.12),transparent 70%);
  pointer-events:none
}
.page-hero::after{
  content:'';position:absolute;top:0;left:0;right:0;bottom:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.06'/%3E%3C/svg%3E");
  background-size:128px 128px;pointer-events:none;opacity:.5
}
.page-hero>*{position:relative;z-index:2}
.page-hero h1{font-family:var(--serif);font-size:clamp(2.2rem,5vw,3.4rem);color:var(--white);font-weight:400;line-height:1.1;margin-bottom:18px}
.page-hero p{color:rgba(255,255,255,.65);font-size:1.1rem;max-width:640px;line-height:1.7;margin-bottom:28px}
.page-hero__meta{display:flex;flex-wrap:wrap;gap:24px;font-size:.9rem;color:rgba(255,255,255,.8);margin-bottom:28px}
.page-hero__meta span{display:flex;align-items:center;gap:8px;padding:8px 16px;background:rgba(255,255,255,.08);border-radius:50px;border:1px solid rgba(255,255,255,.1)}
.page-hero__ctas{display:flex;flex-wrap:wrap;gap:12px}

/* ============ TRUST STRIP ============ */
.trust-strip{padding:20px 0;background:var(--white);border-bottom:1px solid #edf0f4}
.trust-strip__inner{display:flex;justify-content:center;flex-wrap:wrap;gap:16px 36px}
.trust-strip__item{display:flex;align-items:center;gap:10px;font-size:.82rem;font-weight:600;color:var(--navy);letter-spacing:.01em}
.trust-strip__item svg{color:var(--cobalt);flex-shrink:0}

/* ============ STATS STRIP ============ */
/* ============ SERVICES ============ */
.services{padding:110px 0;background:var(--white);position:relative;overflow:hidden}
.services__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.svc-card{
  display:flex;flex-direction:column;background:var(--white);border-radius:var(--radius-xl);overflow:hidden;
  border:1px solid #edf0f4;
  transition:all .4s var(--ease);
  position:relative
}
.svc-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,.12)}
.svc-card__img{position:relative;height:240px;overflow:hidden;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
.svc-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.svc-card:hover .svc-card__img img{transform:scale(1.05)}
.svc-card__img::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:60%;
  background:linear-gradient(transparent,rgba(15,45,75,.1));pointer-events:none
}
.svc-card__tag{
  position:absolute;top:14px;left:14px;padding:6px 14px;
  font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  border-radius:50px;background:var(--navy);color:var(--white);
  backdrop-filter:blur(8px);z-index:2
}
.svc-card__tag--prem{background:linear-gradient(135deg,#7c3aed,#a855f7)}
.svc-card__tag--fast{background:linear-gradient(135deg,#059669,#10b981)}
.svc-card__body{padding:24px 28px 28px;flex:1;display:flex;flex-direction:column}
.svc-card__body h3{font-size:1.2rem;font-weight:700;color:var(--navy);margin-bottom:8px}
.svc-card__body h3 a{color:inherit;transition:color .2s}
.svc-card__body h3 a:hover{color:var(--cobalt)}
.svc-card__body p{font-size:.9rem;color:var(--muted);line-height:1.6;margin-bottom:16px}
.svc-card__meta{display:flex;gap:16px;font-size:.82rem;font-weight:600;color:var(--slate)}
.svc-card__meta span{display:flex;align-items:center;gap:4px}
.svc-card__link{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;color:var(--cobalt);margin-top:auto;padding-top:14px;transition:gap .3s var(--ease)}
.svc-card:hover .svc-card__link{gap:10px}

/* ============ COLOR CTA ============ */
.color-cta{padding:48px 0;background:var(--offwhite)}
.color-cta__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.color-cta__text .label{margin-bottom:8px}
.color-cta__text h2{font-family:var(--serif);font-size:clamp(1.4rem,3vw,2rem);color:var(--navy);line-height:1.2;margin-bottom:8px}
.color-cta__text p{color:var(--muted);font-size:.95rem;max-width:480px;line-height:1.6;margin:0}
@media(max-width:640px){.color-cta__inner{flex-direction:column;text-align:center}.color-cta__text p{margin:0 auto}}

/* ============ PROVEN PROCESS ============ */
.proven-process{
  padding:110px 0;background:var(--navy);
  position:relative;overflow:hidden
}
.proven-process::before{
  content:'';position:absolute;top:0;left:0;right:0;bottom:0;
  background:
    radial-gradient(ellipse at 20% 50%,rgba(0,102,255,.08),transparent 50%),
    radial-gradient(ellipse at 80% 50%,rgba(42,108,184,.08),transparent 50%);
  pointer-events:none
}
.proven-process::after{
  content:'';position:absolute;top:0;left:0;right:0;bottom:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.06'/%3E%3C/svg%3E");
  background-size:128px 128px;pointer-events:none;opacity:.4
}
.proven-process>*{position:relative;z-index:2}
.proven-process .section-head h2{color:var(--white)}
.proven-process .section-head p{color:rgba(255,255,255,.55)}
.proven-process .label{color:var(--cobalt-l)}
.proven-process__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.proven-process__card{
  background:rgba(255,255,255,.04);border-radius:var(--radius-xl);padding:40px 24px;
  border:1px solid rgba(255,255,255,.07);text-align:center;
  transition:all .4s var(--ease);backdrop-filter:blur(8px)
}
.proven-process__card:hover{background:rgba(255,255,255,.08);transform:translateY(-4px);border-color:rgba(255,255,255,.12)}
.proven-process__num{
  width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;font-weight:700;margin:0 auto 24px;color:var(--white);
  position:relative;background:linear-gradient(135deg,var(--cobalt),var(--cobalt-l))
}
.proven-process__num::after{
  content:'';position:absolute;inset:-4px;border-radius:50%;
  border:1px solid rgba(255,255,255,.1);pointer-events:none
}
.proven-process__card h3{color:var(--white);font-size:1.15rem;font-weight:600;margin-bottom:12px;text-transform:uppercase;letter-spacing:.04em}
.proven-process__card p{color:rgba(255,255,255,.5);font-size:.9rem;line-height:1.65}

/* ============ SERVICES CATEGORIES ============ */
.services__category{margin-bottom:56px}
.services__category:last-child{margin-bottom:0}
.services__category-header{margin-bottom:32px}
.services__category-header h3{font-family:var(--serif);font-size:clamp(1.4rem,3vw,1.8rem);color:var(--navy);font-weight:400;margin-bottom:8px}
.services__category-header p{color:var(--muted);font-size:1rem;line-height:1.6}
.services__grid--2col{grid-template-columns:repeat(2,1fr)}

/* ============ DIFFERENTIATORS ============ */
/* Gallery page */
.gallery-page{padding:96px 0;background:var(--white)}
.gallery-filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:48px}
.gallery-filters button{padding:10px 24px;border-radius:50px;font-size:.85rem;font-weight:600;color:var(--slate);background:var(--offwhite);border:1px solid #e8ecf0;transition:all .25s var(--ease)}
.gallery-filters button:hover{border-color:var(--navy);color:var(--navy)}
.gallery-filters button.active{background:var(--navy);color:var(--white);border-color:var(--navy)}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.gallery-grid__item{border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;aspect-ratio:4/3;position:relative}
.gallery-grid__item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.gallery-grid__item:hover img{transform:scale(1.06)}
.gallery-grid__item[data-hidden]{display:none}
.gallery-grid__cap{position:absolute;bottom:0;left:0;right:0;padding:14px 18px;background:linear-gradient(transparent,rgba(7,13,26,.85));color:var(--white);font-size:.85rem;font-weight:600;opacity:0;transition:opacity .3s}
.gallery-grid__item:hover .gallery-grid__cap{opacity:1}

/* ============ COMPARE / BEFORE-AFTER ============ */
.compare{padding:110px 0;background:var(--white)}
.compare__grid{display:grid;grid-template-columns:1fr 1fr;gap:36px}
.compare__item{text-align:center}
.compare__slider{position:relative;overflow:hidden;border-radius:var(--radius-xl);cursor:ew-resize;user-select:none;-webkit-user-select:none;aspect-ratio:4/3;box-shadow:var(--shadow)}
.compare__before,.compare__after{position:absolute;top:0;left:0;width:100%;height:100%}
.compare__before img,.compare__after img{width:100%;height:100%;object-fit:cover}
.compare__before{clip-path:inset(0 50% 0 0);z-index:1}
.compare__tag{position:absolute;top:14px;padding:6px 16px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;border-radius:50px;color:var(--white)}
.compare__tag--b{left:14px;background:rgba(0,0,0,.5);backdrop-filter:blur(4px)}
.compare__tag--a{right:14px;background:var(--cobalt)}
.compare__handle{position:absolute;top:0;left:50%;height:100%;display:flex;flex-direction:column;align-items:center;transform:translateX(-50%);z-index:2;pointer-events:none}
.compare__line{flex:1;width:2px;background:var(--white)}
.compare__grip{width:40px;height:40px;border-radius:50%;background:var(--white);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,.25);color:var(--navy)}
.compare__cap{font-size:.9rem;color:var(--muted);margin-top:16px;font-weight:500}

/* ============ ABOUT ============ */
.about{padding:110px 0;background:var(--offwhite)}
.about__inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about__media{position:relative;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-xl)}
.about__media::after{
  content:'';position:absolute;inset:-6px;border-radius:calc(var(--radius-xl) + 6px);
  border:1px solid rgba(0,102,255,.1);pointer-events:none
}
.about__media img{width:100%;height:480px;object-fit:cover}
.about__content h2{font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.6rem);color:var(--navy);margin-bottom:16px;line-height:1.1}
.about__content>p{color:var(--muted);font-size:1.05rem;line-height:1.7;margin-bottom:32px}
.about__points{display:grid;gap:18px}
.about__point{display:flex;align-items:flex-start;gap:16px;padding:16px;border-radius:var(--radius);transition:background .25s}
.about__point:hover{background:var(--white)}
.about__icon{
  width:46px;height:46px;border-radius:var(--radius);
  background:linear-gradient(135deg,var(--navy),var(--navy-l));
  color:var(--white);display:flex;align-items:center;justify-content:center;flex-shrink:0
}
.about__point strong{display:block;font-size:.95rem;color:var(--navy)}
.about__point span{font-size:.82rem;color:var(--muted)}

/* ============ REVIEWS ============ */
.reviews{padding:110px 0;background:var(--white)}
.reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.reviews__card{
  background:var(--offwhite);border-radius:var(--radius-xl);padding:36px;
  transition:all .4s var(--ease);border:1px solid transparent;position:relative
}
.reviews__card:hover{transform:translateY(-4px);background:var(--white);border-color:#edf0f4;box-shadow:var(--shadow-lg)}
.reviews__stars{color:#f59e0b;font-size:1.2rem;margin-bottom:16px;letter-spacing:3px}
.reviews__card blockquote{font-size:1rem;color:var(--text);line-height:1.7;margin-bottom:20px;font-style:italic}
.reviews__card cite{font-style:normal;font-size:.85rem;color:var(--muted);display:flex;align-items:center;gap:8px}
.reviews__card cite strong{color:var(--navy)}
.reviews__card cite::before{content:'';width:20px;height:1px;background:var(--silver)}

/* ============ SERVICE AREAS ============ */
.areas{padding:110px 0;background:var(--offwhite)}
.areas__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.areas__card{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 28px;background:var(--white);border-radius:var(--radius-lg);
  font-weight:600;font-size:.95rem;color:var(--navy);
  border:1px solid #edf0f4;
  transition:all .3s var(--ease)
}
.areas__card:hover{background:var(--navy);color:var(--white);transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.areas__card svg{color:var(--muted);transition:all .3s var(--ease)}
.areas__card:hover svg{color:var(--white);transform:translateX(4px)}

/* Compat for old markup */
.area-card{display:flex;align-items:center;gap:12px;padding:22px 28px;background:var(--white);border-radius:var(--radius-lg);border:1px solid #edf0f4;transition:all .3s var(--ease);font-weight:600;color:var(--navy)}
.area-card:hover{background:var(--navy);color:var(--white);transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.area-card:hover .area-card__arrow{color:var(--white)}
.area-card__name{font-weight:600;font-size:.95rem}
.area-card__arrow{margin-left:auto;color:var(--muted);transition:all .3s}

/* ============ CTA STRIP ============ */
.cta-strip{
  padding:80px 0;background:var(--navy);
  position:relative;overflow:hidden
}
.cta-strip::before{
  content:'';position:absolute;top:-50%;left:50%;transform:translateX(-50%);
  width:120%;height:200%;
  background:radial-gradient(ellipse,rgba(0,102,255,.1),transparent 60%);
  pointer-events:none
}
.cta-strip::after{
  content:'';position:absolute;top:0;left:0;right:0;bottom:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.06'/%3E%3C/svg%3E");
  background-size:128px 128px;pointer-events:none;opacity:.4
}
.cta-strip>*{position:relative;z-index:2}
.cta-strip__inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:28px}
.cta-strip h3{font-family:var(--serif);font-size:clamp(1.5rem,3.5vw,2.2rem);color:var(--white);font-weight:400}
.cta-strip__btns{display:flex;gap:14px;flex-wrap:wrap}

/* ============ CONTACT ============ */
.contact{padding:110px 0;background:var(--offwhite)}
.contact__inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.contact__info h2{font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.6rem);color:var(--navy);margin-bottom:16px;line-height:1.1}
.contact__info>p{color:var(--muted);margin-bottom:28px;font-size:1.05rem;line-height:1.7}
.contact__phone{display:flex;align-items:center;gap:12px;font-size:1.3rem;font-weight:700;color:var(--navy);margin-bottom:10px;transition:color .2s}
.contact__phone:hover{color:var(--cobalt)}
.contact__email{font-size:.95rem;color:var(--accent);margin-bottom:12px;display:inline-block;transition:color .2s}
.contact__email:hover{color:var(--navy)}
.contact__hours{font-size:.85rem;color:var(--muted);margin-bottom:20px}
.contact__social{display:flex;gap:12px;margin-bottom:28px}
.contact__social a{
  width:42px;height:42px;border-radius:50%;
  background:var(--navy);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  transition:all .25s var(--ease)
}
.contact__social a:hover{background:var(--cobalt);transform:translateY(-2px)}
.contact__areas{font-size:.82rem;color:var(--muted);line-height:1.6}
.contact__form{
  display:flex;flex-direction:column;gap:16px;
  background:var(--white);border-radius:var(--radius-xl);
  padding:40px;box-shadow:var(--shadow-lg);
  border:1px solid rgba(0,0,0,.04)
}
.contact__form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact__form .btn{margin-top:8px}

/* Form status */
.form-status{padding:14px 16px;border-radius:var(--radius);font-size:.9rem;font-weight:500;display:none}
.form-status--success{display:block;background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}
.form-status--error{display:block;background:#fef2f2;color:#991b1b;border:1px solid #fecaca}

/* ============ CONTENT SECTIONS ============ */
.content-section{padding:88px 0}
.content-section:nth-child(even){background:var(--offwhite)}
.content-section h2{font-family:var(--serif);font-size:clamp(1.5rem,3vw,2.2rem);color:var(--navy);margin-bottom:20px;line-height:1.2}
.content-section h3{font-size:1.15rem;font-weight:700;color:var(--navy);margin-bottom:10px}
.content-section p{color:var(--muted);font-size:1rem;line-height:1.75;margin-bottom:16px;max-width:720px}
.content-section ul{list-style:none;padding:0;margin-bottom:20px}
.content-section ul li{padding:10px 0 10px 28px;position:relative;color:var(--text);font-size:.95rem;line-height:1.65}
.content-section ul li::before{content:'';position:absolute;left:0;top:18px;width:8px;height:8px;border-radius:50%;background:var(--cobalt)}

/* Benefits grid */
.benefits-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:36px}
.benefit-card{
  display:flex;gap:18px;padding:28px;background:var(--white);
  border-radius:var(--radius-lg);border:1px solid #edf0f4;
  transition:all .3s var(--ease)
}
.benefit-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.benefit-card__icon{
  width:48px;height:48px;border-radius:var(--radius);
  background:linear-gradient(135deg,var(--offwhite),#e8edf5);
  color:var(--cobalt);display:flex;align-items:center;justify-content:center;flex-shrink:0
}
.benefit-card h4{font-size:.95rem;color:var(--navy);margin-bottom:6px}
.benefit-card p{font-size:.85rem;color:var(--muted);line-height:1.6;margin:0}

/* Process steps */
.process{padding:88px 0;background:var(--offwhite)}
.process__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:44px}
.process__step{
  text-align:center;padding:32px 24px;background:var(--white);
  border-radius:var(--radius-xl);border:1px solid #edf0f4;
  transition:all .3s var(--ease);position:relative
}
.process__step:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.process__num{
  width:52px;height:52px;border-radius:50%;
  background:linear-gradient(135deg,var(--navy),var(--navy-l));
  color:var(--white);display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:1.1rem;margin:0 auto 18px
}
.process__step h4{font-size:1rem;color:var(--navy);margin-bottom:10px}
.process__step p{font-size:.85rem;color:var(--muted);line-height:1.6}

/* Best For */
.best-for{padding:88px 0;background:var(--white)}
.best-for__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px}
.best-for__item{
  padding:28px;background:var(--offwhite);border-radius:var(--radius-lg);
  text-align:center;border:1px solid #edf0f4;transition:all .3s var(--ease)
}
.best-for__item:hover{transform:translateY(-2px);background:var(--white);box-shadow:var(--shadow)}
.best-for__item h4{font-size:.95rem;color:var(--navy);margin-bottom:8px}
.best-for__item p{font-size:.85rem;color:var(--muted);line-height:1.55;margin:0}

/* FAQ Accordion */
.faq{padding:88px 0;background:var(--offwhite)}
.faq__list{max-width:800px;margin:0 auto}
.faq__item{border:1px solid #edf0f4;border-radius:var(--radius-lg);margin-bottom:12px;overflow:hidden;background:var(--white);transition:box-shadow .3s}
.faq__item:hover{box-shadow:var(--shadow)}
.faq__q{width:100%;display:flex;align-items:center;justify-content:space-between;padding:22px 28px;font-size:1rem;font-weight:600;color:var(--navy);text-align:left;cursor:pointer;transition:background .2s}
.faq__q:hover{background:var(--offwhite)}
.faq__q::after{content:'+';font-size:1.3rem;font-weight:400;color:var(--muted);transition:transform .3s}
.faq__item.open .faq__q::after{content:'\2212';transform:rotate(180deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq__a p{padding:0 28px 24px;font-size:.95rem;color:var(--muted);line-height:1.75}

/* Related services */
.related{padding:88px 0;background:var(--white)}
.related__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:36px}

/* ============ FOOTER ============ */
.footer{padding:0;background:var(--navy-d);color:rgba(255,255,255,.6)}
.footer__divider{display:flex;height:4px;width:100%}
.footer__divider span:nth-child(1){flex:1;background:var(--layer-metallic)}
.footer__divider span:nth-child(2){flex:1;background:var(--layer-flake)}
.footer__divider span:nth-child(3){flex:1;background:var(--layer-concrete)}
.footer__inner{padding:56px 0 40px}
.footer__grid,.footer__main{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:48px}
.footer__brand img{max-width:200px;height:auto;border-radius:12px;margin-bottom:14px;filter:drop-shadow(0 4px 16px rgba(0,102,255,.2))}
.footer__brand p{font-size:.85rem;line-height:1.65}
.footer__social,.footer__brand-social{display:flex;gap:10px;margin-top:18px}
.footer__social a,.footer__brand-social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);color:rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;transition:all .25s}
.footer__brand-social a:hover,.footer__social a:hover{background:var(--cobalt);color:var(--white);transform:translateY(-2px)}
.footer h4,.footer__col h4{color:var(--white);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px}
.footer a,.footer__col a{display:block;font-size:.88rem;color:rgba(255,255,255,.45);padding:5px 0;transition:all .2s}
.footer a:hover,.footer__col a:hover{color:var(--white);padding-left:4px}
.footer__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;padding:24px 24px;font-size:.78rem;max-width:1200px;margin:0 auto;border-top:1px solid rgba(255,255,255,.08)}
.footer__bottom a{color:rgba(255,255,255,.4);transition:color .2s}
.footer__bottom a:hover{color:var(--white)}

/* ============ MOBILE CTA ============ */
.mcta{position:fixed;bottom:-80px;left:0;right:0;z-index:90;display:flex;background:var(--white);border-top:1px solid #edf0f4;box-shadow:0 -4px 20px rgba(0,0,0,.08);padding:12px 16px;gap:10px;transition:bottom .4s var(--ease)}
.mcta--show{bottom:0}
.mcta__call{flex:0 0 auto;display:flex;align-items:center;gap:6px;padding:13px 18px;border-radius:50px;border:2px solid var(--navy);color:var(--navy);font-size:.85rem;font-weight:600}
.mcta__est{flex:1;display:flex;align-items:center;justify-content:center;padding:13px 18px;border-radius:50px;background:var(--navy);color:var(--white);font-size:.85rem;font-weight:600}

/* ============ LIGHTBOX ============ */
.lightbox{position:fixed;top:0;left:0;right:0;bottom:0;z-index:200;background:rgba(7,13,26,.95);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s}
.lightbox--open{opacity:1;pointer-events:auto}
.lightbox__img{max-width:90vw;max-height:85vh;border-radius:var(--radius);object-fit:contain;transition:opacity .2s}
.lightbox__close{position:absolute;top:20px;right:24px;font-size:2rem;color:var(--white);z-index:5;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.1);transition:background .2s}
.lightbox__close:hover{background:rgba(255,255,255,.2)}
.lightbox__prev,.lightbox__next{position:absolute;top:50%;transform:translateY(-50%);font-size:2rem;color:var(--white);z-index:5;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.1);transition:background .2s}
.lightbox__prev:hover,.lightbox__next:hover{background:rgba(255,255,255,.2)}
.lightbox__prev{left:20px}
.lightbox__next{right:20px}
.lightbox__cap{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.6);font-size:.88rem;text-align:center;font-weight:500}

/* ============ THANK YOU ============ */
.thankyou{padding:180px 0 140px;text-align:center;background:var(--offwhite);min-height:70vh;display:flex;align-items:center}
.thankyou__icon{width:88px;height:88px;border-radius:50%;background:#ecfdf5;color:#059669;display:flex;align-items:center;justify-content:center;margin:0 auto 28px}
.thankyou h1{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);color:var(--navy);margin-bottom:16px}
.thankyou p{color:var(--muted);font-size:1.1rem;line-height:1.7;max-width:520px;margin:0 auto 32px}

/* ============ PRIVACY ============ */
.legal{padding:130px 0 90px}
.legal h1{font-family:var(--serif);font-size:clamp(2rem,4vw,2.8rem);color:var(--navy);margin-bottom:36px}
.legal h2{font-size:1.2rem;font-weight:700;color:var(--navy);margin:36px 0 14px}
.legal p,.legal li{color:var(--muted);font-size:.95rem;line-height:1.75;margin-bottom:14px}
.legal ul{padding-left:24px;margin-bottom:18px}

/* ============ ANIMATIONS ============ */
[data-anim]{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-anim].is-visible{opacity:1;transform:none}

/* Hero elements are above-the-fold — animate immediately via CSS, don't wait for JS */
.hero--cinematic [data-anim]{opacity:1;transform:none;animation:heroFadeUp .8s var(--ease) both}
.hero--cinematic [data-anim-delay="1"]{animation-delay:.15s}
.hero--cinematic [data-anim-delay="2"]{animation-delay:.3s}
.hero--cinematic [data-anim-delay="3"]{animation-delay:.45s}
.hero--cinematic [data-anim-delay="4"]{animation-delay:.6s}
@keyframes heroFadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

/* Staggered animation delays */
[data-anim-delay="1"]{transition-delay:.1s}
[data-anim-delay="2"]{transition-delay:.2s}
[data-anim-delay="3"]{transition-delay:.3s}
[data-anim-delay="4"]{transition-delay:.4s}
[data-anim-delay="5"]{transition-delay:.5s}
[data-anim-delay="6"]{transition-delay:.6s}

/* Scale-in animation */
[data-anim="scale"]{transform:scale(.92);opacity:0}
[data-anim="scale"].is-visible{transform:scale(1);opacity:1}

/* Slide-in-left */
[data-anim="left"]{transform:translateX(-40px);opacity:0}
[data-anim="left"].is-visible{transform:none;opacity:1}

/* Slide-in-right */
[data-anim="right"]{transform:translateX(40px);opacity:0}
[data-anim="right"].is-visible{transform:none;opacity:1}

/* ============ RESPONSIVE ============ */
@media(max-width:1024px){
  .hero__inner{grid-template-columns:1fr;gap:48px;text-align:center}
  .hero p{margin-left:auto;margin-right:auto}
  .hero__ctas{justify-content:center}
  .hero__trust{justify-content:center}
  .hero__image img{height:400px}
  .hero__image::after{display:none}
  .hero--cinematic{min-height:90vh}
  .services__grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .compare__grid{grid-template-columns:1fr}
  .about__inner{grid-template-columns:1fr;gap:48px}
  .about__media img{height:360px}
  .about__media::after{display:none}
  .reviews__grid{grid-template-columns:repeat(2,1fr)}
  .contact__inner{grid-template-columns:1fr}
  .cta-strip__inner{flex-direction:column;text-align:center}
  .proven-process__grid{grid-template-columns:repeat(2,1fr);gap:20px}
  .areas__grid{grid-template-columns:repeat(2,1fr)}
  .footer__grid,.footer__main{grid-template-columns:1fr 1fr;gap:36px}
  .process__grid{grid-template-columns:repeat(2,1fr)}
  .benefits-grid{grid-template-columns:1fr}
  .best-for__grid{grid-template-columns:repeat(2,1fr)}
  .related__grid{grid-template-columns:repeat(2,1fr)}
  .page-hero{padding:96px 0 44px}
}

@media(max-width:768px){
  .nav__links,.nav__phone{display:none}
  .nav__burger{display:flex}
  .nav__right .btn{display:none}
  .nav__inner{height:80px}
  .nav__logo img{max-height:72px;max-width:260px}

  .hero{padding:110px 0 70px}
  .hero h1{font-size:2.2rem}
  .hero__image img{height:320px}
  .services__grid{grid-template-columns:1fr;max-width:500px;margin-left:auto;margin-right:auto}
  .gallery-grid{grid-template-columns:1fr}
  .reviews__grid{grid-template-columns:1fr}
  .proven-process__grid{grid-template-columns:1fr}
  .services__grid--2col{grid-template-columns:1fr}
  .areas__grid{grid-template-columns:1fr}
  .footer__grid,.footer__main{grid-template-columns:1fr;gap:28px}
  .footer__bottom{flex-direction:column;align-items:center;text-align:center}
  .process__grid{grid-template-columns:1fr}
  .best-for__grid{grid-template-columns:1fr}
  .related__grid{grid-template-columns:1fr}
  .contact__form .form-row{grid-template-columns:1fr}
  .page-hero{padding:96px 0 44px}
  .page-hero h1{font-size:1.8rem}
  .page-hero__meta{flex-direction:column;gap:8px}
  body{padding-bottom:72px}
}

/* Form consent checkboxes */
.form-consent{display:flex;flex-direction:column;gap:10px;margin:12px 0}
.consent-check{display:flex;align-items:flex-start;gap:8px;font-size:.78rem;color:var(--muted);line-height:1.4;cursor:pointer}
.consent-check input[type="checkbox"]{margin-top:2px;flex-shrink:0;width:16px;height:16px;accent-color:var(--navy)}
.form-legal{font-size:.75rem;color:var(--muted);text-align:center;margin-top:8px}
.form-legal a{color:var(--cobalt);text-decoration:underline}

@media(min-width:769px){
  .mcta{display:none!important}
}

/* ================================================================
   PREMIUM ANIMATIONS — appended, do not modify existing rules above
   ================================================================ */

/* --- Keyframes --- */

@keyframes glow-pulse{
  0%,100%{box-shadow:0 0 5px rgba(0,123,255,.4),0 0 10px rgba(0,123,255,.2)}
  50%{box-shadow:0 0 20px rgba(0,123,255,.6),0 0 40px rgba(0,123,255,.3)}
}

@keyframes float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-4px)}
}

@keyframes text-shimmer{
  0%{background-position:200% center}
  100%{background-position:-200% center}
}

@keyframes border-shimmer{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}

@keyframes icon-bounce{
  0%,100%{transform:translateY(0)}
  40%{transform:translateY(-6px)}
  60%{transform:translateY(-3px)}
}

@keyframes step-pulse{
  0%{transform:scale(1)}
  50%{transform:scale(1.2)}
  100%{transform:scale(1)}
}

@keyframes badge-shimmer{
  0%{opacity:.85;filter:brightness(1)}
  50%{opacity:1;filter:brightness(1.15)}
  100%{opacity:.85;filter:brightness(1)}
}

@keyframes marquee{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

@keyframes spin-slow{
  0%{transform:rotate(0deg)}
  100%{transform:rotate(360deg)}
}

@keyframes urgency-pulse{
  0%,100%{background-color:rgba(220,53,69,.85);box-shadow:0 0 5px rgba(220,53,69,.4)}
  50%{background-color:rgba(253,126,20,.9);box-shadow:0 0 20px rgba(253,126,20,.5)}
}

@keyframes fade-up{
  0%{opacity:0;transform:translateY(30px)}
  100%{opacity:1;transform:translateY(0)}
}

@keyframes scale-in{
  0%{opacity:0;transform:scale(.8)}
  100%{opacity:1;transform:scale(1)}
}

@keyframes slide-in-left{
  0%{opacity:0;transform:translateX(-50px)}
  100%{opacity:1;transform:translateX(0)}
}

@keyframes slide-in-right{
  0%{opacity:0;transform:translateX(50px)}
  100%{opacity:1;transform:translateX(0)}
}

@keyframes ken-burns{
  0%{transform:scale(1)}
  100%{transform:scale(1.1)}
}

/* --- Enhancement styles targeting existing classes --- */

.proven-process__card:hover .proven-process__num{
  animation:step-pulse .6s ease;
}

.trust-strip__item{
  animation:badge-shimmer 3s ease-in-out infinite;
}
.trust-strip__item:nth-child(2){animation-delay:.4s}
.trust-strip__item:nth-child(3){animation-delay:.8s}
.trust-strip__item:nth-child(4){animation-delay:1.2s}
.trust-strip__item:nth-child(5){animation-delay:1.6s}
.trust-strip__item:nth-child(6){animation-delay:2s}



/* --- Parallax-like depth --- */

.section-split{
  background-attachment:fixed;
  background-size:cover;
}

/* --- Accessibility: reduced motion --- */

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
  }
}

/* ===== RESPONSIVE BREAKPOINTS ===== */

/* Ultra-wide desktop */
@media (min-width: 1440px) {
  .container { max-width: 1320px; }
  .hero__content h1 { font-size: clamp(3rem, 4vw, 4.5rem); }
  .svc-grid { grid-template-columns: repeat(3, 1fr); }
}

/* Large desktop */
@media (min-width: 1200px) and (max-width: 1439px) {
  .container { max-width: 1140px; }
}

/* Tablet landscape */
@media (max-width: 1024px) {
  .svc-grid { grid-template-columns: repeat(2, 1fr); }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .process-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Tablet portrait */
@media (max-width: 768px) {
  .hero__content h1 { font-size: 2rem; }
  .svc-grid { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .comparison-grid { grid-template-columns: 1fr; }
  section { padding: 3rem 0; }
}

/* Small tablet / large phone */
@media (max-width: 640px) {
  .container { padding: 0 1rem; }
  .hero__content { padding: 0 1rem; }
  .trust-strip { flex-wrap: wrap; gap: 0.5rem; }
  .trust-strip__item { font-size: 0.75rem; }
  .nav__inner { padding: 0 1rem; }
}

/* Small phone */
@media (max-width: 480px) {
  body { font-size: 14px; }
  .hero__content h1 { font-size: 1.6rem; }
  .hero__content p { font-size: 0.9rem; }
  .btn { padding: 0.75rem 1.5rem; font-size: 0.85rem; width: 100%; text-align: center; }
  .svc-card__body { padding: 1rem; }
  .section-head h2 { font-size: 1.5rem; }
}

/* ===== ACCESSIBILITY ===== */

/* Focus visible for keyboard users */
*:focus-visible {
  outline: 3px solid var(--accent, #0066FF);
  outline-offset: 3px;
}

/* Remove outline for mouse users */
*:focus:not(:focus-visible) {
  outline: none;
}

/* Touch targets minimum 44px */
button, a, input[type="submit"], .btn {
  min-height: 44px;
  min-width: 44px;
}

/* Skip to content link */
.skip-link {
  position: absolute;
  top: -100%;
  left: 0;
  background: var(--primary, #0066FF);
  color: #fff;
  padding: 0.75rem 1.5rem;
  z-index: 10000;
  font-weight: 700;
}
.skip-link:focus {
  top: 0;
}

/* High contrast mode support */
@media (forced-colors: active) {
  .btn { border: 2px solid ButtonText; }
  .svc-card { border: 1px solid CanvasText; }
}

/* Tap highlight for mobile */
a, button {
  -webkit-tap-highlight-color: rgba(0, 102, 255, 0.2);
}

/* Screen-reader only utility */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}


/* ===== INLINE STYLES MOVED FROM HTML ===== */
/* Scroll Progress Bar */
.scroll-progress{position:fixed;top:0;left:0;width:0;height:3px;background:linear-gradient(90deg,#0066FF,#00d4ff);z-index:10001;transition:width .1s linear;pointer-events:none}
/* Social Proof Toast */
.sp-toast{position:fixed;bottom:24px;left:24px;background:rgba(15,45,75,.95);backdrop-filter:blur(12px);color:#fff;padding:14px 20px;border-radius:12px;font-size:.85rem;z-index:9998;transform:translateX(-120%);transition:transform .5s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 32px rgba(0,0,0,.3);max-width:320px;border:1px solid rgba(255,255,255,.08)}
.sp-toast.show{transform:translateX(0)}
.sp-toast__city{color:#06b6d4;font-weight:600}
.sp-toast__time{color:rgba(255,255,255,.5);font-size:.75rem;margin-top:4px}
/* Exit Intent Popup */
.exit-popup{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(6px);z-index:10002;display:none;align-items:center;justify-content:center}
.exit-popup.active{display:flex}
.exit-popup__card{background:linear-gradient(135deg,#0f2d4b,#1a3f5c);padding:40px;border-radius:20px;max-width:440px;width:90%;text-align:center;color:#fff;position:relative;box-shadow:0 25px 60px rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.1)}
.exit-popup__card h3{font-family:'DM Serif Display',serif;font-size:1.6rem;margin-bottom:8px}
.exit-popup__card p{color:rgba(255,255,255,.7);margin-bottom:20px;font-size:.95rem}
.exit-popup__card input{width:100%;padding:12px 16px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.08);color:#fff;font-size:.95rem;margin-bottom:10px;box-sizing:border-box}
.exit-popup__card input::placeholder{color:rgba(255,255,255,.4)}
.exit-popup__card button[type="submit"]{width:100%;padding:12px;border:none;border-radius:8px;background:linear-gradient(135deg,#2563eb,#06b6d4);color:#fff;font-weight:600;font-size:1rem;cursor:pointer;margin-bottom:8px}
.exit-popup__close{position:absolute;top:12px;right:16px;background:none;border:none;color:rgba(255,255,255,.5);font-size:1.5rem;cursor:pointer}
.exit-popup__note{font-size:.75rem;color:rgba(255,255,255,.4);margin-top:8px}
/* Confetti */
@keyframes confetti-fall{0%{transform:translateY(-100vh) rotate(0deg);opacity:1}100%{transform:translateY(100vh) rotate(720deg);opacity:0}}
.confetti-piece{position:fixed;width:10px;height:10px;top:-10px;z-index:10003;animation:confetti-fall 3s ease-in forwards;pointer-events:none}
/* Nav glassmorphism when scrolled */
.nav--scrolled{backdrop-filter:blur(16px) saturate(1.4)!important;background:rgba(15,45,75,.92)!important}
.nav--scrolled .nav__links>a,.nav--scrolled .nav__dropdown-toggle{color:rgba(255,255,255,.85)}
.nav--scrolled .nav__links>a:hover,.nav--scrolled .nav__dropdown-toggle:hover{color:#fff}
.nav--scrolled .nav__links>a::after{background:#fff}
.nav--scrolled .nav__phone{color:rgba(255,255,255,.9)}
.nav--scrolled .nav__burger span{background:#fff}
.nav--scrolled .nav__dropdown-menu{background:rgba(15,45,75,.98);border-color:rgba(255,255,255,.1)}
.nav--scrolled .nav__dropdown-menu a{color:rgba(255,255,255,.7)}
.nav--scrolled .nav__dropdown-menu a:hover{color:#fff;background:rgba(255,255,255,.08)}
.nav--scrolled .nav__dropdown-label{color:rgba(255,255,255,.4)}
.nav--scrolled .nav__dropdown-divider{background:rgba(255,255,255,.12)}
/* Mobile CTA Bar override */
.mcta{position:fixed;bottom:0;left:0;right:0;display:none;z-index:9999;background:rgba(15,45,75,.97);backdrop-filter:blur(12px);padding:10px 16px;gap:10px;border-top:1px solid rgba(255,255,255,.1);transition:transform .3s ease}
.mcta--hide{transform:translateY(100%)}
@media(max-width:768px){.mcta.mcta--show{display:flex}}
/* Gradient orbs for hero */
.hero--cinematic::before{content:'';position:absolute;top:-20%;left:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(37,99,235,.15),transparent 70%);border-radius:50%;z-index:0;animation:orb-float 8s ease-in-out infinite alternate;pointer-events:none}
.hero--cinematic::after{content:'';position:absolute;bottom:-10%;right:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(6,182,212,.1),transparent 70%);border-radius:50%;z-index:0;animation:orb-float 10s ease-in-out infinite alternate-reverse;pointer-events:none}
@keyframes orb-float{0%{transform:translate(0,0) scale(1)}100%{transform:translate(30px,-40px) scale(1.1)}}
/* Calculator Section */
.calc-section{padding:5rem 0;background:linear-gradient(135deg,#0a1225 0%,#142340 100%)}
.calc-card{max-width:600px;margin:2rem auto 0;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:16px;padding:2.5rem;backdrop-filter:blur(10px)}
.calc-form{display:flex;flex-direction:column;gap:1.5rem}
.calc-field label{display:block;font-size:0.85rem;font-weight:600;color:rgba(255,255,255,0.7);margin-bottom:0.5rem;text-transform:uppercase;letter-spacing:0.05em}
.calc-field select,.calc-field input{width:100%;padding:0.9rem 1rem;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);border-radius:8px;color:#fff;font-size:1rem;font-family:inherit;transition:border-color 0.3s}
.calc-field select:focus,.calc-field input:focus{border-color:var(--accent,#0066FF);outline:none}
.calc-field select option{background:#1a2a4a;color:#fff}
.calc-btn{width:100%;font-size:1.05rem;padding:1rem;cursor:pointer}
.calc-result{margin-top:2rem;text-align:center;padding:2rem;background:rgba(0,102,255,0.1);border-radius:12px;border:1px solid rgba(0,102,255,0.3);animation:scale-in 0.4s ease}
.calc-result__label{display:block;font-size:0.8rem;text-transform:uppercase;letter-spacing:0.1em;color:rgba(255,255,255,0.6);margin-bottom:0.5rem}
.calc-result__price{display:block;font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,#0066FF,#00d4ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.calc-result__note{font-size:0.8rem;color:rgba(255,255,255,0.5);margin-top:1rem}
.calc-result__note a{color:var(--accent,#0066FF)}

/* ===== UTILITY CLASSES ===== */
.is-hidden{display:none}
.gallery-cta{text-align:center;margin-top:40px}

/* ===== SECTION HEADER ===== */
/* ===== PRELOADER ===== */
.preloader{position:fixed;inset:0;background:#0a1225;z-index:99999;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1.5rem;transition:opacity 0.6s,visibility 0.6s}
.preloader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.preloader__logo{height:120px;width:auto;border-radius:16px;filter:drop-shadow(0 0 20px rgba(0,102,255,0.4)) drop-shadow(0 4px 12px rgba(0,0,0,0.4));animation:preloader-bounce 1s ease-in-out infinite alternate}
.preloader__bar{width:200px;height:4px;border-radius:2px;background:rgba(255,255,255,0.1);overflow:hidden}
.preloader__fill{height:100%;width:0;background:linear-gradient(90deg,#0066FF,#4d94ff);border-radius:2px;animation:preloader-fill 1.8s ease-in-out infinite}
@keyframes preloader-bounce{0%{transform:translateY(0) scale(1)}100%{transform:translateY(-12px) scale(1.05)}}
@keyframes preloader-fill{0%{width:0}50%{width:100%}100%{width:0}}

/* ===== HERO SLIDESHOW KEN BURNS ===== */
.hero__bg-img{animation:ken-burns 20s ease-in-out infinite alternate}
.hero__bg-img:nth-child(2){animation-delay:-7s}
.hero__bg-img:nth-child(3){animation-delay:-14s}

/* ===== CASE STUDIES ===== */
.cases{padding:6rem 0;background:var(--offwhite,#f5f7fa)}
.cases .section-head h2{color:var(--navy)}
.cases-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-top:3rem}
.case-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,0.08);transition:all 0.4s cubic-bezier(0.175,0.885,0.32,1.275)}
.case-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px rgba(0,0,0,0.12)}
.case-card__img{position:relative;overflow:hidden;height:280px}
.case-card__img img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease}
.case-card:hover .case-card__img img{transform:scale(1.05)}
.case-card__badge{position:absolute;top:1rem;left:1rem;background:rgba(0,102,255,0.9);color:#fff;padding:0.35rem 0.9rem;border-radius:50px;font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;backdrop-filter:blur(4px)}
.case-card__body{padding:1.5rem 2rem 2rem}
.case-card__body h3{font-family:'DM Serif Display',serif;font-size:1.35rem;color:var(--navy,#0f2d4b);margin-bottom:1rem}
.case-card__stats{display:flex;gap:1.5rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(0,0,0,0.08)}
.case-stat{text-align:center}
.case-stat__num{display:block;font-size:1.4rem;font-weight:800;color:var(--cobalt,#0066FF)}
.case-stat__label{font-size:0.7rem;text-transform:uppercase;letter-spacing:0.1em;color:rgba(0,0,0,0.5)}
.case-card__body p{font-size:0.9rem;line-height:1.6;color:rgba(0,0,0,0.6)}

@media(max-width:768px){
  .cases-grid{grid-template-columns:1fr}
  .case-card__img{height:220px}
}

/* ===== COOKIE BANNER ===== */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:rgba(10,18,37,0.97);color:#fff;padding:1rem 2rem;z-index:9999;backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,0.1)}
.cookie-banner__inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.cookie-banner__text{margin:0;font-size:0.85rem;color:rgba(255,255,255,0.8)}
.cookie-banner__link{color:#0066FF}
.cookie-banner__actions{display:flex;gap:0.75rem}
.cookie-banner__accept{background:#0066FF;color:#fff;border:none;padding:0.5rem 1.5rem;border-radius:6px;cursor:pointer;font-weight:600;font-size:0.85rem}
.cookie-banner__decline{background:transparent;color:rgba(255,255,255,0.6);border:1px solid rgba(255,255,255,0.2);padding:0.5rem 1rem;border-radius:6px;cursor:pointer;font-size:0.85rem}

/* ===== ROUND 2 ENHANCEMENTS ===== */

/* Animated gradient border */
.gradient-border {
  position: relative;
  overflow: hidden;
}
.gradient-border::before {
  content: '';
  position: absolute;
  inset: -2px;
  background: linear-gradient(45deg, #0066FF, #00d4ff, #0066FF, #00d4ff);
  background-size: 300% 300%;
  animation: border-shimmer 4s ease-in-out infinite;
  border-radius: inherit;
  z-index: -1;
}
.gradient-border::after {
  content: '';
  position: absolute;
  inset: 2px;
  background: inherit;
  border-radius: inherit;
  z-index: -1;
}

/* Typed text cursor */
.hero__badge::after {
  content: '|';
  animation: blink 0.8s infinite;
  margin-left: 2px;
  font-weight: 300;
}
@keyframes blink { 0%, 50% { opacity: 1; } 51%, 100% { opacity: 0; } }

/* Floating orbs */
.orb {
  position: absolute;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0,102,255,0.15), transparent);
  pointer-events: none;
  z-index: 0;
}
.orb--1 { width: 400px; height: 400px; top: -200px; right: -100px; animation: float 8s ease-in-out infinite; }
.orb--2 { width: 300px; height: 300px; bottom: -150px; left: -50px; animation: float 10s ease-in-out infinite reverse; }

/* ================================================================
   ROUND 3 — RICH COMPONENT STYLING
   Appended — do not modify existing rules above
   ================================================================ */

/* ---------- 1. RICH HERO SECTION ---------- */

/* Hero overlay gradient */
.hero__overlay {
  background: linear-gradient(
    180deg,
    rgba(10,18,37,0.3) 0%,
    rgba(10,18,37,0.6) 40%,
    rgba(10,18,37,0.85) 100%
  );
}

/* Hero logo glow */
.hero__logo {
  filter: drop-shadow(0 0 40px rgba(0,102,255,0.3)) drop-shadow(0 0 80px rgba(0,102,255,0.15));
  transition: filter 0.5s ease;
}
.hero__logo:hover {
  filter: drop-shadow(0 0 60px rgba(0,102,255,0.5)) drop-shadow(0 0 100px rgba(0,102,255,0.25));
}

/* Hero trust badges */
.hero__trust div {
  padding: 0.5rem 1rem;
  background: rgba(255,255,255,0.05);
  border-radius: 50px;
  border: 1px solid rgba(255,255,255,0.1);
  backdrop-filter: blur(4px);
  transition: all 0.3s ease;
}
.hero__trust div:hover {
  background: rgba(0,102,255,0.15);
  border-color: rgba(0,102,255,0.3);
}

/* ---------- 2. PREMIUM SERVICE CARDS ---------- */

/* Service card premium effects */
.svc-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.05), transparent);
  transition: left 0.5s ease;
}
.svc-card:hover::before {
  left: 100%;
}

/* Service card image */
.svc-card__img {
  border-radius: 12px 12px 0 0;
}

/* Service tag pill */
.svc-card__tag {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

/* Price styling */
.svc-card__price {
  font-size: 1.1rem;
  font-weight: 800;
  background: linear-gradient(135deg, #0066FF, #00d4ff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ---------- 3. PROCESS SECTION ENHANCEMENT ---------- */

/* Process connecting lines */
.proven-process__card:not(:last-child)::after {
  content: '';
  position: absolute;
  right: -1rem;
  top: 50%;
  width: 2rem;
  height: 2px;
  background: linear-gradient(90deg, rgba(0,102,255,0.5), transparent);
}
@media(max-width:1024px){.proven-process__card:not(:last-child)::after{display:none}}

/* Process number glow */
.proven-process__num {
  box-shadow: 0 0 20px rgba(0,102,255,0.3), 0 0 40px rgba(0,102,255,0.1);
}
.proven-process__card:hover .proven-process__num {
  box-shadow: 0 0 30px rgba(0,102,255,0.5), 0 0 60px rgba(0,102,255,0.2);
  transform: scale(1.1);
  transition: all 0.3s ease;
}

/* ---------- 4. COMPARISON SLIDER ENHANCEMENT ---------- */

/* Comparison slider */
.compare__slider {
  border-radius: 16px;
  box-shadow: 0 10px 40px rgba(0,0,0,0.2);
  border: 1px solid rgba(255,255,255,0.1);
}

/* Comparison handle */
.compare__grip {
  width: 44px;
  height: 44px;
  background: #0066FF;
  box-shadow: 0 0 20px rgba(0,102,255,0.5);
  border: 3px solid #fff;
  cursor: ew-resize;
  transition: box-shadow 0.3s ease;
}
.compare__grip:hover {
  box-shadow: 0 0 30px rgba(0,102,255,0.7), 0 0 60px rgba(0,102,255,0.3);
}

/* ---------- 5. REVIEW/TESTIMONIAL CARD ENHANCEMENT ---------- */

/* Testimonial card */
.review-card, [class*="testimonial"] {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  padding: 2rem;
  position: relative;
  overflow: hidden;
  transition: all 0.4s ease;
}
.review-card:hover, [class*="testimonial"]:hover {
  border-color: rgba(0,102,255,0.3);
  background: rgba(0,102,255,0.05);
  transform: translateY(-4px);
}
.review-card::before, [class*="testimonial"]::before {
  content: '\201C';
  position: absolute;
  top: -10px;
  left: 15px;
  font-size: 6rem;
  font-family: 'DM Serif Display', serif;
  color: rgba(0,102,255,0.1);
  line-height: 1;
}

/* ---------- 6. STATS SECTION GLASSMORPHISM ---------- */

/* Stats glass effect */
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 30% 50%, rgba(0,102,255,0.1) 0%, transparent 50%),
              radial-gradient(circle at 70% 50%, rgba(0,212,255,0.08) 0%, transparent 50%);
  pointer-events: none;
}
  text-align: center;
  border-radius: 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  backdrop-filter: blur(4px);
  transition: all 0.3s ease;
}
  background: rgba(255,255,255,0.06);
  transform: translateY(-4px);
  border-color: rgba(0,102,255,0.2);
}

/* ---------- 7. GALLERY MASONRY-LIKE EFFECT ---------- */

/* Gallery grid masonry */
.gallery-grid {
  grid-template-columns: repeat(4, 1fr);
}
.gallery-grid__item {
  position: relative;
}
.gallery-grid__item::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(10,18,37,0.7), transparent 50%);
  opacity: 0;
  transition: opacity 0.3s ease;
}
.gallery-grid__item:hover::after { opacity: 1; }

/* Make some items span 2 rows for masonry effect */
.gallery-grid__item:nth-child(1),
.gallery-grid__item:nth-child(5) {
  grid-row: span 2;
}

@media (max-width: 768px) {
  .gallery-grid { grid-template-columns: repeat(2, 1fr); }
  .gallery-grid__item:nth-child(1),
  .gallery-grid__item:nth-child(5) { grid-row: span 1; }
}

/* ---------- 8. CONTACT FORM PREMIUM STYLING ---------- */

/* Contact form inputs (dark variant) */
.contact input,
.contact select,
.contact textarea {
  transition: all 0.3s ease;
}
.contact input:focus,
.contact select:focus,
.contact textarea:focus {
  border-color: #0066FF;
  box-shadow: 0 0 0 3px rgba(0,102,255,0.15);
  outline: none;
}

/* Contact info cards */
.contact__info-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.5rem;
  background: rgba(255,255,255,0.04);
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.08);
  transition: all 0.3s ease;
}
.contact__info-item:hover {
  background: rgba(0,102,255,0.1);
  border-color: rgba(0,102,255,0.2);
}

/* ---------- 9. FOOTER PREMIUM STYLING ---------- */

/* Footer gradient top border */
.footer::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, #0066FF, #00d4ff, #0066FF, transparent);
}

/* Footer links */
.footer a {
  position: relative;
  transition: color 0.3s ease;
}
.footer a:hover {
  color: #0066FF;
}
.footer a::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 1px;
  background: #0066FF;
  transition: width 0.3s ease;
}
.footer a:hover::after {
  width: 100%;
}

/* ---------- 10. BUTTON ENHANCEMENTS ---------- */

/* Primary button hover glow */
.btn--cobalt::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(45deg, transparent 30%, rgba(255,255,255,0.15) 50%, transparent 70%);
  transform: translateX(-100%);
  transition: transform 0.5s ease;
}
.btn--cobalt:hover::before {
  transform: translateX(100%);
}
.btn--cobalt:hover {
  box-shadow: 0 8px 25px rgba(0,102,255,0.4), 0 0 60px rgba(0,102,255,0.15);
}

/* Ghost button */
.btn--ghost {
  border: 1px solid rgba(255,255,255,0.3);
  backdrop-filter: blur(4px);
}
.btn--ghost:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.5);
  box-shadow: 0 4px 15px rgba(255,255,255,0.1);
}

/* ---------- 11. CTA SECTION ---------- */

/* CTA section premium */
.cta-strip h2 {
  text-shadow: 0 0 40px rgba(0,102,255,0.3);
}

/* ---------- 12. SECTION DIVIDERS ---------- */

/* Section dividers */
section + section {
  position: relative;
}

/* ===== SUBPAGE STYLES ===== */

/* Subpage hero banner */
.subpage-hero {
  min-height: 50vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: relative;
  background: linear-gradient(180deg, rgba(10,18,37,0.7), rgba(10,18,37,0.9)), url('https://pub-1387b782cd0043d186c1d8d7d33c4985.r2.dev/proven-surfaces/gulf-winds/web/unclassified/gulfwinds-IMG_2279.jpg') center/cover;
  background-size: cover;
  background-position: center;
}
.subpage-hero h1 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(2.5rem, 5vw, 4rem);
  color: #fff;
  margin-bottom: 1rem;
}
.subpage-hero p {
  color: rgba(255,255,255,0.7);
  max-width: 600px;
  margin: 0 auto;
}

/* Stats strip */
.stats-strip {
  display: flex;
  justify-content: center;
  gap: 3rem;
  padding: 3rem 0;
  background: var(--navy, #0f2d4b);
}
.stats-strip__item {
  text-align: center;
  color: #fff;
}
.stats-strip__num {
  display: block;
  font-size: 2.5rem;
  font-weight: 800;
  background: linear-gradient(135deg, #0066FF, #00d4ff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.stats-strip__label {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.6);
}
.stats-strip__unit{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#0066FF,#00d4ff);-webkit-background-clip:text;background-clip:text;font-size:1rem;font-weight:400}

@media (max-width: 768px) {
  .stats-strip { flex-wrap: wrap; gap: 1.5rem; }
  .stats-strip__item { flex: 0 0 45%; }
}

/* Gallery filters (subpage) */
.gallery-filter-btn {
  padding: 0.5rem 1.25rem;
  border: 1px solid rgba(0,102,255,0.3);
  border-radius: 50px;
  background: transparent;
  color: rgba(255,255,255,0.7);
  cursor: pointer;
  transition: all 0.3s ease;
  font-size: 0.85rem;
}
.gallery-filter-btn.active,
.gallery-filter-btn:hover {
  background: #0066FF;
  color: #fff;
  border-color: #0066FF;
}

/* Gallery overlay on hover */
.gallery-grid__overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 1.25rem;
  background: linear-gradient(transparent, rgba(7,13,26,0.9));
  opacity: 0;
  transition: opacity 0.3s ease;
  z-index: 3;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.gallery-grid__item:hover .gallery-grid__overlay { opacity: 1; }
.gallery-grid__overlay strong {
  color: #fff;
  font-size: 0.95rem;
  margin-bottom: 0.25rem;
}
.gallery-grid__overlay span {
  color: rgba(255,255,255,0.6);
  font-size: 0.8rem;
}

/* Gallery responsive: 4 cols desktop, 3 tablet, 2 mobile, 1 small */
@media (max-width: 1024px) {
  .gallery-grid { grid-template-columns: repeat(3, 1fr) !important; }
}
@media (max-width: 768px) {
  .gallery-grid { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 480px) {
  .gallery-grid { grid-template-columns: 1fr !important; }
}

/* Contact methods */
.contact-methods {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-bottom: 3rem;
}
.contact-method {
  text-align: center;
  padding: 2rem;
  background: var(--white);
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  transition: all 0.3s ease;
  box-shadow: var(--shadow);
}
.contact-method:hover {
  background: rgba(0,102,255,0.04);
  border-color: rgba(0,102,255,0.3);
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}
.contact-method__icon {
  font-size: 2rem;
  margin-bottom: 1rem;
}
.contact-method h3 {
  color: var(--navy);
  margin-bottom: 0.5rem;
  font-family: var(--serif);
}
.contact-method a {
  color: #0066FF;
  font-weight: 600;
}

@media (max-width: 768px) {
  .contact-methods { grid-template-columns: 1fr; }
}

/* Why-us cards responsive */
@media (max-width: 1024px) {
  .why-us__grid { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 480px) {
  .why-us__grid { grid-template-columns: 1fr !important; }
}

/* Why-us card hover */
.why-us__card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

/* ================================================================
   MOBILE-FIRST ENHANCEMENTS
   Target: 8.5+ mobile/responsive score
   Appended — do not modify existing rules above
   ================================================================ */

/* ---- 1. GLOBAL TOUCH TARGETS (44px min) ---- */

a,
button,
input[type="submit"],
input[type="button"],
input[type="reset"],
select,
.btn,
.nav__links > a,
.nav__dropdown-toggle,
.nav__dropdown-menu a,
.nav__burger,
.footer a,
.footer__col a,
.footer__social a,
.footer__brand-social a,
.contact__social a,
.gallery-filters button,
.gallery-filter-btn,
.faq__q,
.areas__card,
.area-card,
.breadcrumb__inner a,
.consent-check,
.cookie-banner__accept,
.cookie-banner__decline,
.lightbox__close,
.lightbox__prev,
.lightbox__next,
.mcta__call,
.mcta__est {
  min-height: 44px;
  min-width: 44px;
}

/* Inline links inside paragraphs should not force block height */
p a, li a, span a, cite a, blockquote a,
.form-legal a, .cookie-banner__link {
  min-height: auto;
  min-width: auto;
}

/* ---- 2. TYPOGRAPHY — clamp() for all headings, 16px body min ---- */

body {
  font-size: clamp(1rem, 1vw + 0.875rem, 1.125rem);
}

h1, .hero h1, .hero--compact h1, .page-hero h1, .subpage-hero h1,
.thankyou h1, .legal h1 {
  font-size: clamp(1.75rem, 5vw, 4.2rem);
}

h2, .section-head h2, .content-section h2,
.about__content h2, .contact__info h2, .cta-strip h3 {
  font-size: clamp(1.5rem, 4vw, 3.2rem);
}

h3, .svc-card__body h3, .proven-process__card h3,
.case-card__body h3, .contact-method h3 {
  font-size: clamp(1.05rem, 2.5vw, 1.35rem);
}

h4, .benefit-card h4, .process__step h4, .best-for__item h4,
.footer h4, .footer__col h4 {
  font-size: clamp(0.85rem, 1.5vw, 1rem);
}

/* ---- 3. FORM INPUTS — min 48px height on mobile ---- */

input,
select,
textarea {
  min-height: 48px;
  font-size: 16px; /* prevents iOS zoom */
}

.calc-field select,
.calc-field input {
  min-height: 48px;
  font-size: 16px;
}

.exit-popup__card input {
  min-height: 48px;
  font-size: 16px;
}

.contact__form label,
.calc-field label {
  margin-bottom: 6px;
  display: block;
}

/* ---- 4. IMAGES — safety net ---- */

img,
video,
iframe,
svg {
  max-width: 100%;
  height: auto;
}

/* ---- 5. 320px SAFETY — prevent horizontal overflow everywhere ---- */

html {
  overflow-x: hidden;
}

.container {
  max-width: 100%;
  overflow-wrap: break-word;
  word-wrap: break-word;
}

/* ---- 6. MOBILE-FIRST BREAKPOINTS (min-width progressive) ---- */

/* === Extra-small: 320px base (default styles apply) === */

@media (min-width: 480px) {
  .container { padding: 0 20px; }
  .gallery { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 640px) {
  .container { padding: 0 24px; }
  .services__grid { grid-template-columns: repeat(2, 1fr); }
  .benefits-grid { grid-template-columns: repeat(2, 1fr); }
  .best-for__grid { grid-template-columns: repeat(2, 1fr); }
  .cases-grid { grid-template-columns: repeat(2, 1fr); }
  .reviews__grid { grid-template-columns: repeat(2, 1fr); }
  .areas__grid { grid-template-columns: repeat(2, 1fr); }
  .proven-process__grid { grid-template-columns: repeat(2, 1fr); }
  .process__grid { grid-template-columns: repeat(2, 1fr); }
  .contact-methods { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 768px) {
  .gallery { grid-template-columns: repeat(3, 1fr); }
  .footer__grid, .footer__main { grid-template-columns: 1fr 1fr; }
  .contact__inner { grid-template-columns: 1fr 1fr; }
  .about__inner { grid-template-columns: 1fr 1fr; }
  .compare__grid { grid-template-columns: 1fr 1fr; }
  .contact__form .form-row { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 1024px) {
  .services__grid { grid-template-columns: repeat(3, 1fr); }
  .gallery { grid-template-columns: repeat(4, 1fr); }
  .reviews__grid { grid-template-columns: repeat(3, 1fr); }
  .proven-process__grid { grid-template-columns: repeat(4, 1fr); }
  .areas__grid { grid-template-columns: repeat(4, 1fr); }
  .process__grid { grid-template-columns: repeat(4, 1fr); }
  .best-for__grid { grid-template-columns: repeat(3, 1fr); }
  .related__grid { grid-template-columns: repeat(3, 1fr); }
  .footer__grid, .footer__main { grid-template-columns: 1.5fr 1fr 1fr; }
  .contact-methods { grid-template-columns: repeat(3, 1fr); }
  .hero__inner { grid-template-columns: 1fr 1fr; }
}

/* ---- 7. HAMBURGER MENU — full-screen overlay ---- */

@media (max-width: 768px) {
  .nav__links.nav__links--open {
    display: flex;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 0;
    background: rgba(7, 13, 26, 0.97);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    z-index: 200;
    padding: 80px 24px 40px;
    animation: mobileMenuIn 0.3s ease forwards;
    overflow-y: auto;
  }

  @keyframes mobileMenuIn {
    from { opacity: 0; transform: translateY(-20px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  .nav__links--open > a,
  .nav__links--open .nav__dropdown-toggle {
    font-size: 1.25rem;
    color: #fff;
    padding: 16px 0;
    min-height: 52px;
    display: flex;
    align-items: center;
    width: 100%;
    justify-content: center;
    border-bottom: 1px solid rgba(255,255,255,0.06);
  }

  .nav__links--open .nav__dropdown-menu {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    border: none;
    background: transparent;
    min-width: 0;
    padding: 0;
    text-align: center;
  }

  .nav__links--open .nav__dropdown-menu a {
    font-size: 1rem;
    color: rgba(255,255,255,0.6);
    padding: 14px 0;
    min-height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .nav__links--open .nav__dropdown-menu a:hover {
    color: #fff;
    background: rgba(0,102,255,0.1);
    padding-left: 0;
  }

  /* Keep burger above overlay */
  .nav__burger {
    position: relative;
    z-index: 210;
    min-height: 44px;
    min-width: 44px;
    padding: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}

/* ---- 8. MOBILE CTA BAR — larger tap targets ---- */

@media (max-width: 768px) {
  .mcta {
    padding: 14px 16px;
    gap: 10px;
    z-index: 9999;
  }

  .mcta__call,
  .mcta__est {
    min-height: 50px;
    padding: 14px 20px;
    font-size: 0.9rem;
    font-weight: 700;
    border-radius: 50px;
  }

  /* Prevent CTA bar from overlapping page content */
  body {
    padding-bottom: 80px;
  }
}

/* ---- 9. GALLERY — single column at 480px ---- */

@media (max-width: 480px) {
  .gallery {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 0 12px;
  }

  .gallery-grid {
    grid-template-columns: 1fr !important;
    gap: 16px;
  }

  .gallery-grid__item:nth-child(1),
  .gallery-grid__item:nth-child(5) {
    grid-row: span 1;
  }
}

/* ---- 10. 320px NARROW SCREEN FIXES ---- */

@media (max-width: 359px) {
  .container { padding: 0 12px; }

  body { font-size: 15px; }

  .hero { padding: 100px 0 48px; }
  .hero h1 { font-size: 1.6rem; }
  .hero p { font-size: 0.95rem; }
  .hero__ctas { flex-direction: column; gap: 10px; }
  .hero__ctas .btn { width: 100%; }

  .hero--cinematic .hero__center { padding: 100px 16px 60px; }
  .hero__logo { width: 140px; height: 140px; }

  .page-hero { padding: 88px 0 36px; }
  .page-hero h1 { font-size: 1.5rem; }

  .btn { padding: 12px 20px; font-size: 0.85rem; }
  .btn--sm { padding: 10px 16px; font-size: 0.8rem; }

  .svc-card__body { padding: 16px; }
  .svc-card__img { height: 180px; }

  .proven-process { padding: 64px 0; }
  .proven-process__card { padding: 24px 16px; }

  .reviews__card { padding: 24px; }

  .contact__form { padding: 24px 16px; }
  .contact { padding: 64px 0; }

  .faq__q { padding: 16px; font-size: 0.9rem; }
  .faq__a p { padding: 0 16px 16px; }

  .footer__inner { padding: 36px 0 24px; }
  .footer__brand img { max-width: 140px; height: auto; }
  .footer__bottom { padding: 16px 12px; font-size: 0.72rem; }

  .legal { padding: 100px 0 60px; }

  .cta-strip { padding: 48px 0; }
  .cta-strip__btns { flex-direction: column; width: 100%; }
  .cta-strip__btns .btn { width: 100%; }

  .services { padding: 64px 0; }
  .work { padding: 64px 0; }
  .about { padding: 64px 0; }
  .reviews { padding: 64px 0; }
  .areas { padding: 64px 0; }

  .trust-strip__inner { gap: 8px 16px; }
  .trust-strip__item { font-size: 0.72rem; }
  .trust-strip__item svg { width: 14px; height: 14px; }

  .cookie-banner { padding: 0.5rem 1rem; }
  .cookie-banner__inner { flex-direction: row; flex-wrap: nowrap; text-align: left; align-items: center; gap: 0.75rem; }
  .cookie-banner__text { font-size: 0.75rem; flex: 1; min-width: 0; }
  .cookie-banner__actions { width: auto; flex-shrink: 0; }
  .cookie-banner__accept { padding: 0.4rem 1rem; font-size: 0.78rem; }
  .cookie-banner__decline { padding: 0.4rem 0.75rem; font-size: 0.78rem; }

  .exit-popup__card { padding: 28px 20px; }
  .exit-popup__card h3 { font-size: 1.3rem; }

  .breadcrumb__inner { font-size: 0.78rem; }

  .case-card__body { padding: 1rem 1.25rem 1.25rem; }
  .case-card__img { height: 180px; }
  .case-card__stats { gap: 1rem; flex-wrap: wrap; }

  .calc-card { padding: 1.5rem; }

  .compare__slider { aspect-ratio: 3/2; }

  .sp-toast { max-width: 260px; left: 12px; bottom: 90px; font-size: 0.78rem; padding: 10px 14px; }

  .contact-methods { grid-template-columns: 1fr; }
  .contact-method { padding: 1.25rem; }
}

/* Also ensure 320-479 range is safe */
@media (max-width: 479px) {
  .hero__trust { gap: 8px; flex-direction: column; align-items: center; }
  .page-hero__meta { gap: 6px; }
  .page-hero__ctas { flex-direction: column; }
  .page-hero__ctas .btn { width: 100%; text-align: center; }

  .services__grid--2col { grid-template-columns: 1fr; }
  .nav__inner { height: 70px; }
  .nav__logo img { max-height: 64px; max-width: 220px; }
  .scroll-progress { height: 2px; }

  .about__media img { height: 240px; }
  .hero__image img { height: 240px; }

  .gallery-filters { gap: 6px; }
  .gallery-filters button { padding: 10px 16px; font-size: 0.8rem; }

  .benefits-grid { gap: 12px; }
  .benefit-card { padding: 20px; gap: 12px; }

  .footer__social a, .footer__brand-social a { width: 44px; height: 44px; }
  .contact__social a { width: 46px; height: 46px; }

  .stats-strip { flex-direction: column; gap: 1rem; padding: 2rem 0; }
  .stats-strip__item { flex: none; }
  .stats-strip__num { font-size: 2rem; }

  .content-section { padding: 56px 0; }
}

/* ---- 11. FORM LABEL SPACING ---- */

@media (max-width: 768px) {
  .contact__form label {
    margin-bottom: 6px;
    font-size: 0.85rem;
  }

  .contact__form input,
  .contact__form select,
  .contact__form textarea {
    min-height: 48px;
    padding: 14px 16px;
    font-size: 16px;
  }

  .contact__form textarea {
    min-height: 120px;
  }

  .contact__form .form-row {
    gap: 14px;
  }

  .consent-check {
    padding: 8px 0;
    min-height: 44px;
    align-items: center;
  }

  .consent-check input[type="checkbox"] {
    width: 20px;
    height: 20px;
    min-height: 20px;
  }
}

/* ---- 12. NAV LINK ADEQUATE SPACING ON MOBILE ---- */

@media (max-width: 768px) {
  .footer a, .footer__col a {
    padding: 8px 0;
    min-height: 44px;
    display: flex;
    align-items: center;
  }

  .breadcrumb__inner a {
    padding: 6px 4px;
  }

  /* FAQ touch targets */
  .faq__q {
    min-height: 52px;
    padding: 18px 20px;
  }

  /* Area cards */
  .areas__card, .area-card {
    min-height: 52px;
    padding: 16px 20px;
  }
}

/* ---- 13. PREVENT WIDE ELEMENTS FROM OVERFLOWING ---- */

.hero__inner,
.about__inner,
.contact__inner,
.cta-strip__inner,
.footer__grid,
.footer__main,
.proven-process__grid,
.services__grid,
.reviews__grid,
.gallery,
.gallery-grid,
.cases-grid,
.compare__grid,
.areas__grid,
.process__grid,
.benefits-grid,
.best-for__grid,
.related__grid,
.contact-methods {
  max-width: 100%;
}

table {
  display: block;
  overflow-x: auto;
  max-width: 100%;
}

pre, code {
  overflow-x: auto;
  max-width: 100%;
  word-break: break-word;
}

/* ═══════════════════════════════════════════
   COMPETITIVE EDGE FEATURES
   ═══════════════════════════════════════════ */

/* ── Color Picker ── */


/* ── Chat Widget ── */
.chat-widget{position:fixed;bottom:100px;right:20px;z-index:95;font-family:var(--font)}
.chat-widget__btn{width:56px;height:56px;border-radius:50%;background:var(--cobalt);color:var(--white);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,102,255,.35);transition:transform .3s var(--ease),box-shadow .3s var(--ease);position:relative;z-index:2}
.chat-widget__btn:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(0,102,255,.45)}
.chat-widget__close{display:none}
.chat-widget.open .chat-widget__icon{display:none}
.chat-widget.open .chat-widget__close{display:block}
.chat-widget__panel{position:absolute;bottom:70px;right:0;width:320px;background:rgba(255,255,255,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:0 16px 48px rgba(0,0,0,.12);opacity:0;transform:translateY(16px) scale(.95);pointer-events:none;transition:all .3s var(--ease);overflow:hidden}
.chat-widget.open .chat-widget__panel{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.chat-widget__header{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--navy);color:var(--white)}
.chat-widget__avatar{width:36px;height:36px;border-radius:50%;background:var(--cobalt);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem}
.chat-widget__status{font-size:.75rem;color:rgba(255,255,255,.7);display:block}
.chat-widget__body{padding:20px}
.chat-widget__msg{background:var(--offwhite);border-radius:var(--radius) var(--radius) var(--radius) 4px;padding:12px 16px;margin-bottom:10px;font-size:.9rem;color:var(--text);line-height:1.5}
.chat-widget__msg a{color:var(--cobalt);text-decoration:none}
.chat-widget__msg a:hover{text-decoration:underline}
.chat-widget__footer{padding:12px 20px;border-top:1px solid rgba(0,0,0,.06)}
.chat-widget__cta{width:100%;text-align:center;display:block}

/* ── Timeline Estimator ── */
.calc-timeline{margin-top:24px;padding-top:24px;border-top:1px solid rgba(0,0,0,.08);animation:scale-in .4s ease}
.calc-timeline__header{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--navy);margin-bottom:16px;font-size:.95rem}
.calc-timeline__header svg{color:var(--cobalt)}
.calc-timeline__steps{display:flex;flex-direction:column;gap:0;position:relative;padding-left:16px}
.calc-timeline__step{display:flex;align-items:flex-start;gap:16px;padding:10px 0;position:relative}
.calc-timeline__step::before{content:'';position:absolute;left:-12px;top:0;bottom:0;width:2px;background:var(--silver)}
.calc-timeline__step:first-child::before{top:50%}
.calc-timeline__step:last-child::before{bottom:50%}
.calc-timeline__dot{width:12px;height:12px;border-radius:50%;background:var(--silver);border:2px solid var(--white);box-shadow:0 0 0 2px var(--silver);flex-shrink:0;margin-top:4px;position:relative;z-index:1}
.calc-timeline__dot--active{background:var(--cobalt);box-shadow:0 0 0 2px var(--cobalt)}
.calc-timeline__dot--done{background:#22c55e;box-shadow:0 0 0 2px #22c55e}
.calc-timeline__content{display:flex;flex-direction:column;gap:2px}
.calc-timeline__content strong{font-size:.875rem;color:var(--text)}
.calc-timeline__content span{font-size:.8rem;color:var(--muted)}

/* ── Service Area Coverage ── */
.coverage{padding:80px 0;background:var(--navy);color:var(--white);position:relative;overflow:hidden}
.coverage .section-head h2{color:var(--white)}
.coverage .section-head p{color:rgba(255,255,255,.7)}
.coverage .label{color:var(--cobalt-l)}
.coverage__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:32px}
.coverage__region{text-align:center;padding:32px 20px;border-radius:var(--radius-lg);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);transition:all .3s var(--ease)}
.coverage__region:hover{background:rgba(255,255,255,.1);transform:translateY(-4px)}
.coverage__count{font-size:3rem;font-weight:800;color:var(--cobalt-l);line-height:1}
.coverage__state{font-size:1.1rem;font-weight:600;margin:8px 0 4px;color:var(--white)}
.coverage__detail{font-size:.85rem;color:rgba(255,255,255,.5)}
.coverage__note{text-align:center;color:rgba(255,255,255,.6);font-size:.9rem}
.coverage__note a{color:var(--cobalt-l);text-decoration:none}
.coverage__note a:hover{text-decoration:underline}

/* ── Responsive: Color Picker, Chat, Coverage ── */
@media(max-width:768px){
  .coverage__grid{grid-template-columns:repeat(2,1fr)}
  .chat-widget{bottom:90px;right:12px}
  .chat-widget__panel{width:calc(100vw - 32px);right:-8px}
}
@media(max-width:479px){
  .coverage__grid{grid-template-columns:1fr 1fr;gap:12px}
  .coverage__count{font-size:2.2rem}
}

/* ── Blog Content Enhancements ── */
.blog-figure{max-width:100%;margin:2rem 0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.blog-figure img{width:100%;height:auto;display:block}
.blog-figure figcaption{padding:.75rem 1rem;font-size:.85rem;color:var(--muted);background:var(--white);text-align:center;font-style:italic}
.pull-quote{border-left:4px solid var(--accent);padding:1.5rem 2rem;margin:2rem 0;font-size:1.15rem;font-style:italic;color:var(--navy);line-height:1.6;background:rgba(15,45,75,.03);border-radius:0 var(--radius-lg) var(--radius-lg) 0}
.pull-quote strong{font-style:normal}
.blog-table{width:100%;border-collapse:collapse;margin:1.5rem 0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.blog-table th{background:var(--navy);color:#fff;font-weight:600;padding:.75rem 1rem;text-align:left;font-size:.9rem}
.blog-table td{padding:.75rem 1rem;color:var(--muted);font-size:.9rem;border-bottom:1px solid #e2e8f0}
.blog-table tbody tr:nth-child(even){background:rgba(15,45,75,.02)}
.blog-table tbody tr:hover{background:rgba(15,45,75,.05)}
@media(max-width:768px){
  .blog-table{font-size:.8rem}
  .blog-table th,.blog-table td{padding:.5rem .65rem}
  .pull-quote{padding:1rem 1.25rem;font-size:1.05rem}
}

/* ── Service Page Gallery ── */
.svc-gallery{padding:80px 0;background:var(--offwhite)}
.svc-gallery__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:40px}
.svc-gallery__item{margin:0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);background:var(--white);transition:transform .3s,box-shadow .3s}
.svc-gallery__item:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.12)}
.svc-gallery__item img{width:100%;height:220px;object-fit:cover;display:block}
.svc-gallery__item figcaption{padding:12px 16px;font-size:.85rem;color:var(--muted);text-align:center;line-height:1.4}
@media(max-width:768px){.svc-gallery__grid{grid-template-columns:repeat(2,1fr);gap:12px}.svc-gallery__item img{height:160px}}
@media(max-width:479px){.svc-gallery__grid{grid-template-columns:1fr}}

/* ── Why Choose Section ── */
.why-choose{padding:80px 0;background:var(--white)}
.why-choose__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:40px}
.why-choose__card{background:var(--offwhite);border-radius:var(--radius-lg);padding:40px 32px;text-align:center;border:1px solid rgba(15,45,75,.06);transition:transform .3s,box-shadow .3s}
.why-choose__card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(15,45,75,.1)}
.why-choose__icon{width:56px;height:56px;border-radius:50%;background:var(--navy);color:#fff;display:inline-flex;align-items:center;justify-content:center;margin-bottom:20px}
.why-choose__card h4{font-size:1.15rem;margin-bottom:12px;color:var(--navy)}
.why-choose__card p{font-size:.95rem;color:var(--muted);line-height:1.6}
@media(max-width:768px){.why-choose__grid{grid-template-columns:1fr;gap:20px}.why-choose__card{padding:28px 24px}}

/* ── Related Services ── */
.related-services{padding:80px 0;background:var(--offwhite)}
.related-services__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.related-services__card{display:block;background:var(--white);border-radius:var(--radius-lg);padding:32px 28px;text-decoration:none;border:1px solid rgba(15,45,75,.06);transition:transform .3s,box-shadow .3s,border-color .3s}
.related-services__card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(15,45,75,.1);border-color:var(--accent)}
.related-services__card h4{font-size:1.15rem;color:var(--navy);margin-bottom:8px}
.related-services__card p{font-size:.9rem;color:var(--muted);line-height:1.5;margin-bottom:12px}
.related-services__price{display:inline-block;font-size:.85rem;font-weight:600;color:var(--accent);background:rgba(15,45,75,.04);padding:4px 12px;border-radius:20px;margin-bottom:12px}
.related-services__card .svc-card__link{display:block;font-size:.9rem}
@media(max-width:768px){.related-services__grid{grid-template-columns:1fr}}

/* ── Page Hero Background ── */
.page-hero{position:relative;overflow:hidden}
.page-hero__bg{position:absolute;top:0;right:0;width:40%;height:100%;background-size:cover;background-position:center;opacity:.15;pointer-events:none}
@media(max-width:768px){.page-hero__bg{width:100%;opacity:.08}}

/* ============================================================
   Gallery v2 — Project-based layout with B/A sliders
   ============================================================ */

/* Project Card */
.project-card{background:var(--white);border:1px solid rgba(15,45,75,.08);border-radius:var(--radius-xl);padding:0;margin-bottom:48px;overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.project-card:hover{box-shadow:var(--shadow-lg)}
.project-card[data-hidden]{display:none}

.project-card__header{display:flex;justify-content:space-between;align-items:flex-start;padding:40px 40px 24px;gap:32px;flex-wrap:wrap}
.project-card__info{flex:1;min-width:240px}
.project-card__title{font-family:var(--serif);font-size:clamp(1.5rem,3vw,2.2rem);color:var(--navy);line-height:1.15;margin-top:4px}
.project-card__location{color:var(--muted);font-size:.92rem;margin-top:6px;display:flex;align-items:center;gap:6px}
.project-card__location::before{content:'';display:inline-block;width:14px;height:14px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0118 0z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E") no-repeat center/contain}

.project-card__stats{display:flex;gap:24px;flex-shrink:0}
.project-card__stat{text-align:center;padding:12px 16px;background:var(--offwhite);border-radius:var(--radius);min-width:100px}
.project-card__stat-value{display:block;font-size:1rem;font-weight:700;color:var(--navy)}
.project-card__stat-label{display:block;font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}

/* Before/After Slider */
.ba-slider{padding:0 40px 32px}
.ba-slider__container{position:relative;overflow:hidden;border-radius:var(--radius-lg);aspect-ratio:16/9;cursor:ew-resize;user-select:none;-webkit-user-select:none}
.ba-slider__container img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}
.ba-slider__before{position:absolute;top:0;left:0;width:50%;height:100%;overflow:hidden;z-index:2}
.ba-slider__before img{width:auto;min-width:100%;height:100%;position:absolute;top:0;right:0}
.ba-slider__handle{position:absolute;top:0;left:50%;height:100%;z-index:3;display:flex;flex-direction:column;align-items:center;justify-content:center;transform:translateX(-50%);pointer-events:none}
.ba-slider__handle-line{width:3px;flex:1;background:var(--white);border-radius:3px;box-shadow:0 0 6px rgba(0,0,0,.3)}
.ba-slider__handle-circle{width:44px;height:44px;border-radius:50%;background:var(--cobalt);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px rgba(0,0,0,.3);flex-shrink:0;margin:4px 0}
.ba-slider__label{position:absolute;bottom:16px;z-index:4;background:rgba(7,13,26,.7);color:var(--white);padding:6px 16px;border-radius:50px;font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;backdrop-filter:blur(4px)}
.ba-slider__label--before{left:16px}
.ba-slider__label--after{right:16px}
.ba-slider__caption{text-align:center;color:var(--muted);font-size:.92rem;margin-top:16px;font-style:italic}

/* Phase sections */
.project-card__phases{padding:0 40px 40px}
.project-card__phase{margin-bottom:32px}
.project-card__phase:last-child{margin-bottom:0}
.project-card__phase-title{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:16px;display:flex;align-items:center;gap:10px}

.phase-dot{width:10px;height:10px;border-radius:50%;display:inline-block}
.phase-dot--before{background:#ef4444}
.phase-dot--during{background:#f59e0b}
.phase-dot--after{background:#22c55e}

.project-card__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.project-card__grid .gallery-grid__item{aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;cursor:pointer;position:relative}
.project-card__grid .gallery-grid__item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.project-card__grid .gallery-grid__item:hover img{transform:scale(1.08)}

/* ---- Project Showcase Cards ---- */
.project-showcase{background:var(--white);border:1px solid rgba(15,45,75,.08);border-radius:var(--radius-xl);margin-bottom:48px;overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.project-showcase:hover{box-shadow:var(--shadow-lg)}
.project-showcase[data-hidden]{display:none}

.project-showcase__hero{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;cursor:pointer}
.project-showcase__hero img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.project-showcase:hover .project-showcase__hero img{transform:scale(1.03)}
.project-showcase__hero-overlay{position:absolute;bottom:0;left:0;right:0;padding:32px 40px;background:linear-gradient(0deg,rgba(10,18,37,.85) 0%,rgba(10,18,37,0) 100%)}
.project-showcase__hero-overlay h2{font-family:var(--serif);font-size:clamp(1.4rem,3vw,2rem);color:#fff;line-height:1.2;margin:0}
.project-showcase__hero-overlay p{color:rgba(255,255,255,.7);font-size:.9rem;margin:6px 0 0}

.project-showcase__comparison{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:24px 40px}
.project-showcase__comparison-item{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;aspect-ratio:4/3}
.project-showcase__comparison-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.project-showcase__comparison-item:hover img{transform:scale(1.05)}
.project-showcase__comparison-label{position:absolute;top:12px;left:12px;background:#0a1225;color:#fff;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:5px 14px;border-radius:50px;z-index:2}

.project-showcase__strip{display:flex;gap:12px;padding:0 40px 32px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(30,58,95,.3) transparent}
.project-showcase__strip::-webkit-scrollbar{height:6px}
.project-showcase__strip::-webkit-scrollbar-track{background:transparent}
.project-showcase__strip::-webkit-scrollbar-thumb{background:rgba(30,58,95,.3);border-radius:3px}
.project-showcase__strip img{flex:0 0 auto;width:180px;height:130px;object-fit:cover;border-radius:var(--radius);cursor:pointer;scroll-snap-align:start;transition:transform .3s var(--ease),opacity .3s var(--ease)}
.project-showcase__strip img:hover{transform:scale(1.06);opacity:.9}

@media(max-width:1024px){
  .project-showcase__hero-overlay{padding:24px 28px}
  .project-showcase__comparison{padding:20px 28px}
  .project-showcase__strip{padding:0 28px 28px}
}
@media(max-width:768px){
  .project-showcase__hero{aspect-ratio:4/3}
  .project-showcase__hero-overlay{padding:20px}
  .project-showcase__comparison{padding:16px 20px;gap:12px}
  .project-showcase__comparison-item{aspect-ratio:3/2}
  .project-showcase__strip{padding:0 20px 24px;gap:10px}
  .project-showcase__strip img{width:150px;height:110px}
}
@media(max-width:479px){
  .project-showcase__hero-overlay h2{font-size:1.2rem}
  .project-showcase__strip img{width:130px;height:95px}
}

/* Responsive: project cards */
@media(max-width:1024px){
  .project-card__header{padding:28px 28px 20px}
  .project-card__stats{gap:16px}
  .ba-slider{padding:0 28px 24px}
  .project-card__phases{padding:0 28px 28px}
  .project-card__grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
  .project-card__header{flex-direction:column;padding:24px 20px 16px}
  .project-card__stats{width:100%;justify-content:space-between}
  .project-card__stat{flex:1;min-width:0;padding:10px 8px}
  .ba-slider{padding:0 20px 20px}
  .ba-slider__container{aspect-ratio:4/3}
  .project-card__phases{padding:0 20px 24px}
  .project-card__grid{grid-template-columns:repeat(2,1fr);gap:8px}
}
@media(max-width:479px){
  .project-card__grid{grid-template-columns:repeat(2,1fr)}
  .project-card__stat-value{font-size:.88rem}
  .ba-slider__handle-circle{width:36px;height:36px}
}

/* ---- MOBILE FIX: orb overflow at 320px ---- */
body { overflow-x: hidden; }
@media (max-width: 480px) {
  .orb { display: none; }
}

/* ---- MOBILE FIX: touch targets ---- */
@media (max-width: 768px) {
  .exit-popup__close,
    min-width: 48px;
    min-height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .footer__bottom a {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
  }

  .contact__phone {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
  }

  .consent-check input[type="checkbox"] {
    width: 24px;
    height: 24px;
    min-width: 44px;
    min-height: 44px;
    margin: -10px;
    padding: 10px;
  }
}

/* ---- MOBILE FIX: hero badge text ---- */
@media (max-width: 480px) {
  .hero__badge {
    font-size: 0.6rem;
    letter-spacing: 0.04em;
    padding: 5px 12px;
    white-space: normal;
    text-align: center;
    max-width: 90vw;
    word-break: break-word;
  }
}

/* ── Torginol Color Swatches ── */
.color-options { padding: 80px 0; }
.color-options .label { display: block; text-align: center; margin-bottom: 8px; }
.color-options h2 { text-align: center; margin-bottom: 8px; }
.color-options__sub { text-align: center; color: var(--muted); font-size: .95rem; margin-bottom: 40px; }
.color-options__sub a { color: var(--accent); text-decoration: underline; }
.color-swatches { display: flex; flex-wrap: wrap; justify-content: center; gap: 24px; max-width: 800px; margin: 0 auto 32px; }
.color-swatch { display: flex; flex-direction: column; align-items: center; gap: 8px; width: 100px; }
.color-swatch__img { width: 80px; height: 80px; border-radius: 50%; overflow: hidden; box-shadow: 0 2px 8px rgba(0,0,0,.12); border: 3px solid #fff; }
.color-swatch__img img { width: 100%; height: 100%; object-fit: cover; }
.color-swatch__name { font-size: .75rem; font-weight: 600; text-align: center; color: var(--dark); line-height: 1.2; }
.color-swatch__code { font-size: .65rem; color: var(--muted); }
.color-options__note { text-align: center; font-size: .85rem; color: var(--muted); margin-top: 16px; }
.color-options__scene { max-width: 900px; margin: 32px auto 0; border-radius: 12px; overflow: hidden; box-shadow: 0 4px 20px rgba(0,0,0,.1); }
.color-options__scene img { width: 100%; height: auto; display: block; }
@media (max-width: 600px) {
  .color-swatches { gap: 16px; }
  .color-swatch { width: 72px; }
  .color-swatch__img { width: 60px; height: 60px; }
}

/* Colors Catalog Page */
.colors-tabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:var(--sp-8)}
.colors-tab{padding:10px 24px;border-radius:var(--radius-full);border:1px solid rgba(255,255,255,.15);background:transparent;color:rgba(255,255,255,.7);font-size:.88rem;font-weight:600;cursor:pointer;transition:all .25s}
.colors-tab:hover{border-color:var(--accent);color:var(--accent)}
.colors-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}
.colors-panel{display:none}
.colors-panel.active{display:block}
.colors-panel__header{text-align:center;margin-bottom:var(--sp-6)}
.colors-panel__header h2{font-family:var(--font-serif);font-size:1.8rem;margin-bottom:8px}
.colors-panel__header p{color:var(--muted);max-width:640px;margin:0 auto}
.colors-panel__header a{color:var(--accent);text-decoration:underline}
.colors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:20px}
.colors-card{display:block;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);overflow:hidden;transition:all .25s;text-decoration:none}
.colors-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.colors-card__img{aspect-ratio:1;overflow:hidden;background:var(--navy)}
.colors-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.colors-card:hover .colors-card__img img{transform:scale(1.08)}
.colors-card__info{padding:10px 12px;text-align:center}
.colors-card__name{display:block;font-size:.85rem;font-weight:600;color:var(--offwhite)}
.colors-card__code{display:block;font-size:.7rem;color:var(--muted);margin-top:2px;letter-spacing:.03em}
.colors-panel__more{text-align:center;color:var(--muted);font-size:.88rem;margin-top:var(--sp-6)}
.colors-panel__more a{color:var(--accent);text-decoration:underline}
.colors-attribution{text-align:center;color:var(--muted);font-size:.82rem;margin-top:var(--sp-8);padding-top:var(--sp-6);border-top:1px solid rgba(255,255,255,.08)}
.colors-attribution a{color:var(--accent);text-decoration:underline}
@media (max-width:768px){.colors-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:12px}.colors-tab{padding:8px 16px;font-size:.8rem}}
@media (max-width:480px){.colors-grid{grid-template-columns:repeat(3,1fr);gap:10px}.colors-card__info{padding:6px 8px}.colors-card__name{font-size:.78rem}}

/* ================================================================
   DESIGN POLISH — v3 Overhaul
   Section transitions · Hover states · Card consistency · Hero polish
   ================================================================ */

/* ---- Section Transitions ---- */
.section-sep{height:1px;background:linear-gradient(90deg,transparent,rgba(0,102,255,.15) 30%,rgba(0,102,255,.15) 70%,transparent);margin:0}
.section-sep--dark{background:linear-gradient(90deg,transparent,rgba(255,255,255,.06) 30%,rgba(255,255,255,.06) 70%,transparent)}

/* Subtle gradient overlays on alternating sections */
section.bg-subtle{background:linear-gradient(180deg,var(--offwhite) 0%,var(--white) 100%)}
section.bg-accent{background:linear-gradient(180deg,rgba(0,102,255,.02) 0%,var(--white) 100%)}
section.bg-dark{background:var(--navy-d);color:var(--offwhite)}
section.bg-dark .section-head h2{color:var(--white)}
section.bg-dark .section-head p{color:rgba(255,255,255,.6)}

/* ---- Hero Polish ---- */
/* Unified hero padding rhythm */
.subpage-hero{padding:clamp(100px,14vh,160px) 0 clamp(50px,7vh,80px)}
.page-hero{padding:clamp(96px,13vh,140px) 0 clamp(44px,6vh,70px)}

/* Subpage hero animated gradient accent */
.subpage-hero::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:40%;
  background:linear-gradient(0deg,rgba(0,102,255,.08) 0%,transparent 100%);
  pointer-events:none;z-index:1
}

/* Page hero consistent gradient */
.page-hero::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:120px;
  background:linear-gradient(0deg,var(--white),transparent);
  pointer-events:none;z-index:1
}

/* ---- Card Consistency ---- */
/* Unified hover behavior for ALL card types */
.svc-card,.case-card,.factor-card,.diff__item,.review-card,[class*="testimonial"]{
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease)
}
.svc-card:hover,.case-card:hover{
  transform:translateY(-6px);
  box-shadow:0 16px 48px rgba(0,0,0,.12)
}
/* Unified image scale on hover */
.svc-card:hover img,.case-card:hover img,.gallery-grid__item:hover img{
  transform:scale(1.05)
}

/* Card glass border on dark bgs */
.review-card,.factor-card{border:1px solid rgba(255,255,255,.06)}

/* ---- Hover States ---- */
/* Nav dropdown left-accent on hover */
.nav__dropdown-menu a{position:relative;border-left:3px solid transparent}
.nav__dropdown-menu a:hover{border-left-color:var(--cobalt);padding-left:25px}

/* Breadcrumb hover */
.breadcrumb__inner a{position:relative}
.breadcrumb__inner a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--cobalt);transition:width .25s var(--ease)}
.breadcrumb__inner a:hover::after{width:100%}

/* Form input hover (before focus) */
input:hover,select:hover,textarea:hover{border-color:var(--silver)}

/* Color swatch hover ring */
  box-shadow:0 0 0 3px rgba(0,102,255,.3),0 8px 24px rgba(0,0,0,.15);
  transform:translateY(-4px)
}

/* Gallery item hover overlay with zoom icon */
.gallery-grid__item{position:relative;overflow:hidden;border-radius:var(--radius)}
.gallery-grid__item::before{
  content:'⤢';position:absolute;top:50%;left:50%;z-index:3;
  transform:translate(-50%,-50%) scale(0);
  font-size:1.5rem;color:var(--white);
  width:44px;height:44px;display:flex;align-items:center;justify-content:center;
  background:rgba(0,102,255,.8);border-radius:50%;
  transition:transform .3s var(--bounce);pointer-events:none
}
.gallery-grid__item:hover::before{transform:translate(-50%,-50%) scale(1)}

/* ---- Differentiator Cards Polish ---- */
.diff__item{border-radius:var(--radius-lg);overflow:hidden}
.diff__item:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,.1)}

/* ---- Review Stars ---- */
.review-card .stars,.reviews__card .stars{color:#f59e0b;letter-spacing:2px}

/* ---- Section Header Consolidation ---- */
/* Section head system */
.section-head{text-align:center;margin-bottom:clamp(2rem,2rem + 2vw,3.5rem)}
.section-head h2{font-family:var(--serif);font-size:var(--text-3xl);font-weight:400;color:var(--navy);line-height:1.1}
.section-head p{color:var(--muted);font-size:var(--text-lg);margin-top:14px;max-width:560px;line-height:1.7}
.section-head--center{text-align:center}
.section-head--center p{margin-left:auto;margin-right:auto}

/* ---- Dark/Light Rhythm ---- */
/* Subtle radial accent on dark sections */
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 20% 50%,rgba(0,102,255,.08) 0%,transparent 60%),
              radial-gradient(ellipse at 80% 80%,rgba(0,212,255,.05) 0%,transparent 50%);
  pointer-events:none
}

/* Light sections subtle texture */
.services,.about{
  background:linear-gradient(180deg,var(--offwhite) 0%,var(--white) 100%);
  position:relative
}

/* Grain overlay for texture depth */
.proven-process,.stats,.cta-strip{position:relative}

/* ---- Nav Polish ---- */
/* Scrolled nav: slightly smaller, tighter */
.nav--scrolled .nav__inner{height:64px;transition:height .3s var(--ease)}
.nav--scrolled .nav__logo img{max-height:40px;transition:max-height .3s var(--ease)}

/* Dropdown menu: add subtle top arrow */
.nav__dropdown-menu::before{
  content:'';position:absolute;top:-6px;left:32px;
  width:12px;height:12px;background:var(--white);
  transform:rotate(45deg);border-top:1px solid rgba(0,0,0,.06);border-left:1px solid rgba(0,0,0,.06)
}

/* ---- Service Area Map Section ---- */
.coverage{position:relative}
.coverage::before{
  content:'';position:absolute;top:0;left:0;right:0;height:120px;
  background:linear-gradient(180deg,var(--offwhite),transparent);
  pointer-events:none
}

/* ---- Responsive Polish: 1024px tablet ---- */
@media(max-width:1024px){
  .coverage__grid{grid-template-columns:repeat(3,1fr)}
}

/* ---- Responsive Polish: 640px landscape phone ---- */
@media(max-width:640px){
  .services__grid{grid-template-columns:1fr;max-width:440px;margin:0 auto}
  .cases-grid{grid-template-columns:1fr}
  .cta-strip__btns{flex-direction:column;width:100%}
  .cta-strip__btns .btn{width:100%;text-align:center}
  .footer__grid{grid-template-columns:1fr;gap:28px}
}

/* ---- Color Picker Focus States ---- */

/* ---- Gallery Overlay Polish ---- */
.gallery-grid__item{position:relative;overflow:hidden;border-radius:var(--radius-lg)}
.gallery-grid__cap{z-index:2}

/* ---- Trust Strip Hover ---- */
.trust-strip__item{transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.trust-strip__item:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.06)}

/* ---- Stats Number Counter ---- */
/* ---- Compare Slider Polish ---- */
@media(max-width:640px){
  .compare__tag{top:8px;left:8px;font-size:.65rem;padding:4px 10px}
}

/* ---- Calculator Input Focus ---- */
.calc-field input:hover,.calc-field select:hover{background:rgba(255,255,255,.12);border-color:rgba(0,102,255,.3)}
.calc-field input:invalid{border-color:rgba(255,60,60,.4)}

/* ---- CTA Strip Flow ---- */
.cta-strip{border-top:1px solid rgba(255,255,255,.06)}

/* ================================================================
   PRICING PAGE — Complete Styles
   ================================================================ */

/* Dark page wrapper */
.pricing-page{background:var(--navy-d);color:var(--offwhite)}
.pricing-page .section-head h2{color:var(--white)}
.pricing-page .section-head p{color:rgba(255,255,255,.6)}
.pricing-page .label{color:var(--cobalt-l)}
.pricing-page .label::before{background:var(--cobalt-l)}
.pricing-page .breadcrumb{background:transparent}

/* Philosophy */
.pricing-philosophy{padding:4rem 0 2rem}
.pricing-philosophy p{font-size:1.1rem;color:rgba(255,255,255,.65);line-height:1.8;max-width:780px;margin:0 auto;text-align:center}

/* Tiers section */
.pricing-tiers{padding:4rem 0 6rem}

/* Pricing grid */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;align-items:start}

/* Pricing card */
.pricing-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-lg);
  padding:24px;
  position:relative;
  transition:all .4s var(--ease);
  overflow:hidden
}
.pricing-card:hover{
  transform:translateY(-6px);
  border-color:rgba(0,102,255,.2);
  box-shadow:0 20px 60px rgba(0,0,0,.3),0 0 40px rgba(0,102,255,.06)
}
.pricing-card h3{font-family:var(--serif);font-size:1.4rem;color:var(--white);margin-bottom:8px}
.pricing-card__img{border-radius:var(--radius) var(--radius) 0 0;overflow:hidden;height:200px;margin:-24px -24px 24px}
.pricing-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.pricing-card:hover .pricing-card__img img{transform:scale(1.05)}
.pricing-card__price{
  display:block;font-size:2rem;font-weight:800;
  background:linear-gradient(135deg,#0066FF,#00d4ff);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  line-height:1.2
}
.pricing-card__unit{display:block;font-size:.82rem;color:rgba(255,255,255,.45);margin-bottom:16px;text-transform:uppercase;letter-spacing:.05em}
.pricing-card__desc{font-size:.92rem;color:rgba(255,255,255,.6);line-height:1.6;margin-bottom:20px}
.pricing-card ul{list-style:none;padding:0;margin:0 0 24px}
.pricing-card ul li{
  position:relative;padding:8px 0 8px 28px;
  font-size:.88rem;color:rgba(255,255,255,.7);
  border-bottom:1px solid rgba(255,255,255,.04)
}
.pricing-card ul li:last-child{border-bottom:none}
.pricing-card ul li::before{
  content:'✓';position:absolute;left:0;top:8px;
  color:var(--cobalt-l);font-weight:700;font-size:.85rem
}
.pricing-card__systems{margin:0 0 20px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08);font-size:.82rem}
.pricing-card__systems span{color:rgba(255,255,255,.4);margin-right:8px}
.pricing-card__systems a{color:var(--cobalt-l);text-decoration:none;margin-right:10px;transition:color .2s}
.pricing-card__systems a:hover{color:var(--white);text-decoration:underline}

/* Featured card */
.pricing-card--featured{
  background:rgba(0,102,255,.08);
  border-color:rgba(0,102,255,.25);
  padding:28px;
  transform:scale(1.03)
}
.pricing-card--featured:hover{transform:scale(1.03) translateY(-6px)}
.pricing-card--featured .pricing-card__img{margin:-28px -28px 24px}
.pricing-card--featured::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,#0066FF,#00d4ff)
}
.pricing-badge{
  display:inline-block;
  background:linear-gradient(135deg,#0066FF,#00d4ff);
  color:var(--white);font-size:.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;
  padding:6px 18px;border-radius:50px;margin-bottom:12px
}

/* Comparison table */
.comparison-section{padding:0 0 6rem}
.comparison-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.02)}
.comparison-table{width:100%;border-collapse:collapse;font-size:.88rem}
.comparison-table th,.comparison-table td{padding:14px 20px;text-align:center;border-bottom:1px solid rgba(255,255,255,.06)}
.comparison-table th{font-weight:700;color:var(--white);background:rgba(255,255,255,.05);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em}
.comparison-table td{color:rgba(255,255,255,.6)}
.comparison-table td:first-child{text-align:left;font-weight:500;color:var(--offwhite)}
.comparison-table tbody tr{transition:background .2s}
.comparison-table tbody tr:hover{background:rgba(255,255,255,.04)}
.comparison-table__featured{background:rgba(0,102,255,.08)!important}
.comparison-table thead .comparison-table__featured{color:var(--cobalt-l)}
.comparison-table tbody tr:last-child td{border-bottom:none}

/* Factor cards & grid */
.factors-section{padding:0 0 6rem}
.factors-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.factor-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius-lg);
  padding:28px 24px;
  transition:all .3s var(--ease)
}
.factor-card:hover{
  border-color:rgba(0,102,255,.2);
  background:rgba(0,102,255,.06);
  transform:translateY(-4px)
}
.factor-card h3{font-family:var(--serif);font-size:1.1rem;color:var(--white);margin-bottom:10px}
.factor-card p{font-size:.88rem;color:rgba(255,255,255,.55);line-height:1.6;margin:0}
.factor-card p strong{color:rgba(255,255,255,.85)}
.factor-card__size{color:var(--cobalt-l);font-size:.82rem;font-weight:600;margin-bottom:10px}

/* Pricing factors section */
.pricing-factors{padding:4rem 0 6rem;border-top:1px solid rgba(255,255,255,.06)}

/* CTA on pricing page */
.pricing-page .cta-strip{background:linear-gradient(180deg,rgba(0,102,255,.12) 0%,transparent 100%);border-top:1px solid rgba(0,102,255,.15)}
.pricing-cta__inner{text-align:center;padding:5rem 0}
.pricing-cta__inner .btn{margin-top:2rem}

/* Responsive */
@media(max-width:1024px){
  .pricing-grid{grid-template-columns:1fr 1fr;gap:20px}
  .pricing-card--featured{transform:none;grid-column:1/-1;max-width:500px;margin:0 auto}
  .pricing-card--featured:hover{transform:translateY(-6px)}
  .factors-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .pricing-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto}
  .pricing-card--featured{max-width:none;padding:24px}
  .pricing-card--featured .pricing-card__img{margin:-24px -24px 24px}
  .pricing-card__img{height:160px}
  .comparison-table{font-size:.8rem}
  .comparison-table th,.comparison-table td{padding:10px 12px}
  .factors-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .factors-grid{grid-template-columns:1fr}
  .comparison-table{font-size:.75rem}
  .comparison-table th,.comparison-table td{padding:8px 10px}
}

/* ---- About Page Components ---- */
.why-us{padding:var(--section-py) 0;background:var(--offwhite)}
.why-us__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:3rem}
.why-us__card{
  text-align:center;padding:2rem 1.5rem;
  background:var(--white);border-radius:var(--radius-lg);
  box-shadow:var(--shadow);transition:all .35s var(--ease)
}
.why-us__card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.why-us__card .icon{font-size:2.5rem;margin-bottom:1rem}
.why-us__card h3{font-family:var(--serif);font-size:1.15rem;color:var(--navy);margin-bottom:.5rem}
.why-us__card p{color:var(--muted);font-size:.9rem;line-height:1.6}
@media(max-width:768px){.why-us__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.why-us__grid{grid-template-columns:1fr}}

/* ---- Contact Page Components ---- */
.contact-info{padding:var(--section-py-sm) 0;background:var(--offwhite)}
.contact-info__methods p{color:var(--muted);font-size:.9rem;margin-bottom:.75rem}
.contact-info__grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:2rem}
.contact-info__card{padding:2rem;background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);transition:all .3s var(--ease)}
.contact-info__card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.contact-info__card h3{font-family:var(--serif);color:var(--navy);margin-bottom:1rem;font-size:1.15rem}
.hours-grid{display:grid;gap:.5rem;font-size:.9rem;color:var(--muted)}
.hours-grid__row{display:flex;justify-content:space-between}
.hours-grid__row strong{color:var(--navy)}
.hours-grid__row strong.closed{color:var(--muted)}
.service-area{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}
.service-area .flag{font-size:2rem}
.service-area strong{color:var(--navy);font-size:1.1rem;display:block}
.service-area p{color:var(--muted);font-size:.85rem;margin:0}
.urgent-banner{margin-top:2rem;padding:1.5rem 2rem;background:linear-gradient(135deg,var(--navy),var(--navy-l));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.urgent-banner strong{color:var(--white);font-size:1.05rem}
.urgent-banner p{color:rgba(255,255,255,.7);font-size:.9rem;margin:0}
.urgent-banner__desc{color:rgba(255,255,255,.7);font-size:.9rem;margin:.25rem 0 0}
.btn--nowrap{white-space:nowrap}
.btn-group{display:flex;flex-wrap:wrap;gap:12px}
.btn-group--center{justify-content:center}
.contact__detail{margin-bottom:20px}
.contact__detail-label{font-size:.9rem;color:var(--navy);display:block;margin-bottom:6px}
.contact__detail-value{font-size:.9rem;color:var(--muted)}
@media(max-width:768px){.contact-info__grid{grid-template-columns:1fr}}

/* ---- Color Picker Utilities ---- */

/* ---- Service Page Utilities ---- */
.content-section--alt{background:var(--offwhite)}
.content-section--dark{background:var(--navy-d);color:var(--offwhite)}
.content-section--dark h2{color:var(--white)}
.content-section--dark p{color:rgba(255,255,255,.65)}
.warranty-section{text-align:center;max-width:720px;margin:0 auto}
.warranty-section h2{margin-bottom:24px}
.warranty-section p{margin:0 auto 32px;max-width:560px}
.color-options--alt{background:var(--offwhite)}
.colors-catalog{padding:3rem 0 6rem}
