/* =========================================================
   Up Top Roofing Ltd — styles.css
   Bold & industrial one-page site. Vanilla CSS, no build.
   ========================================================= */

:root{
  --ink:#14171c;        /* page background (charcoal) */
  --ink-2:#1b1f26;      /* elevated card */
  --ink-3:#232833;      /* steel / hover */
  --line:rgba(255,255,255,.09);
  --line-2:rgba(255,255,255,.16);
  --text:#eef2f7;
  --muted:#9aa6b4;
  --blue:#3a90d4;       /* accent — pulled from the logo */
  --blue-2:#5ba7e6;
  --blue-d:#2b6ea6;
  --amber:#f5a623;      /* primary call-to-action */
  --amber-d:#d98c0a;
  --amber-ink:#3a2a05;  /* text on amber */
  --ok:#37b26b;
  --err:#e2555a;
  --radius:12px;
  --maxw:1160px;
  --header-h:72px;
  --font-display:'Archivo',system-ui,-apple-system,'Segoe UI',sans-serif;
  --font-body:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --shadow:0 18px 40px -18px rgba(0,0,0,.7);
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 8px);}
html,body{overflow-x:clip;}
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--ink);
  color:var(--text);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:800;line-height:1.08;letter-spacing:-.01em;margin:0 0 .4em;}
p{margin:0 0 1rem;}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px;}

/* skip link */
.skip{position:absolute;left:-999px;top:0;background:var(--amber);color:var(--amber-ink);padding:10px 16px;border-radius:0 0 8px 0;z-index:200;font-weight:700;}
.skip:focus{left:0;}

/* focus visibility */
:focus-visible{outline:3px solid var(--blue-2);outline-offset:2px;border-radius:4px;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;position:relative;
  font-family:var(--font-display);font-weight:700;font-size:1rem;
  padding:14px 22px;border-radius:11px;border:1px solid transparent;
  cursor:pointer;line-height:1;white-space:nowrap;overflow:hidden;
  transition:transform .16s cubic-bezier(.2,.7,.2,1),box-shadow .22s ease,filter .2s ease,background .2s ease;
}
.btn svg{width:18px;height:18px;flex:none;position:relative;z-index:1;}
.btn::after{content:"";position:absolute;top:0;left:-130%;width:55%;height:100%;pointer-events:none;z-index:2;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.5),transparent);transform:skewX(-20deg);}
.btn:hover::after{animation:shine .75s ease;}
@keyframes shine{to{left:140%;}}

/* amber — primary 3D pop */
.btn-primary{
  background:linear-gradient(180deg,#ffca66 0%,var(--amber) 46%,var(--amber-d) 100%);
  color:var(--amber-ink);
  box-shadow:0 4px 10px rgba(0,0,0,.3);
}
.btn-primary:hover{transform:translateY(-3px);filter:brightness(1.04);
  box-shadow:0 14px 26px -10px rgba(245,166,35,.55),0 5px 10px rgba(0,0,0,.35);}
.btn-primary:active{transform:translateY(-1px);
  box-shadow:0 4px 10px -6px rgba(245,166,35,.5);}

/* blue — call 3D pop */
.btn-call{
  background:linear-gradient(180deg,#3f8ccc 0%,#2b6ea6 100%);color:#fff;
  box-shadow:0 4px 10px rgba(0,0,0,.3);
}
.btn-call:hover{transform:translateY(-3px);filter:brightness(1.06);
  box-shadow:0 14px 26px -10px rgba(58,144,212,.55),0 5px 10px rgba(0,0,0,.35);}
.btn-call:active{transform:translateY(-1px);
  box-shadow:0 4px 10px -6px rgba(58,144,212,.5);}

/* glass ghost */

.btn-lg{padding:17px 28px;font-size:1.06rem;}
.btn-block{width:100%;justify-content:center;}

/* ---------- Header ---------- */
.header{
  position:fixed;top:0;left:0;right:0;z-index:100;height:var(--header-h);
  display:flex;align-items:center;
  background:rgba(20,23,28,0);border-bottom:1px solid transparent;
  transition:background .25s ease,border-color .25s ease,box-shadow .25s ease;
}
.header.scrolled{background:rgba(17,20,25,.94);border-bottom-color:var(--line);backdrop-filter:blur(10px);box-shadow:0 6px 24px -14px rgba(0,0,0,.9);}
.header .container{display:flex;align-items:center;justify-content:space-between;gap:14px;}
.brand{display:flex;align-items:center;gap:12px;}
.logo-utr{height:46px;width:auto;display:block;opacity:0;filter:drop-shadow(0 2px 6px rgba(0,0,0,.65)) drop-shadow(0 0 10px rgba(170,200,230,.4));transition:filter .25s ease,opacity .35s ease;}
.header.scrolled .logo-utr{opacity:1;}
html:not(.js) .logo-utr{opacity:1;}
.brand:hover .logo-utr{filter:drop-shadow(0 2px 6px rgba(0,0,0,.6)) drop-shadow(0 0 13px rgba(160,190,220,.6));}

.nav{display:flex;align-items:center;gap:6px;}
.nav a.navlink{
  font-family:var(--font-display);font-weight:600;font-size:.96rem;color:var(--muted);
  padding:9px 13px;border-radius:8px;transition:color .15s,background .15s;
}
.nav a.navlink:hover{color:var(--text);background:var(--ink-3);}
.nav .nav-call{display:none;}
.header-cta{display:flex;align-items:center;gap:10px;margin-left:6px;}
.header-cta .btn-primary{display:none;} /* shown only on mobile — nav has its own on desktop */
.header-phone{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:700;color:var(--text);padding:8px 6px;}
.header-phone svg{width:17px;height:17px;color:var(--blue-2);}

.menu-btn{display:none;background:transparent;border:1px solid var(--line-2);color:var(--text);width:46px;height:44px;border-radius:9px;cursor:pointer;align-items:center;justify-content:center;}
.menu-btn svg{width:24px;height:24px;}

/* ---------- Hero ---------- */
.hero{
  position:relative;overflow:hidden;min-height:100vh;min-height:100svh;display:flex;align-items:center;
  padding:calc(var(--header-h) + 40px) 0 60px;background:var(--ink);
}
.hero-bg{
  position:absolute;left:0;top:0;width:100%;height:142%;z-index:0;
  background:url('images/coast.svg') center/cover no-repeat;
  transform:translate3d(0,0,0);will-change:transform;
}
/* To use a real photo: drop images/hero.jpg in, then add class "has-photo" to <section class="hero"> */
.hero.has-photo .hero-bg{background-image:url('images/hero.jpg');}
@media (max-width:700px){.hero.has-photo .hero-bg{background-image:url('images/hero-mobile.jpg');}}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(120% 70% at 50% 40%, rgba(11,16,22,.12) 0%, rgba(11,16,22,.42) 60%, rgba(11,16,22,.62) 100%),
    linear-gradient(180deg, rgba(11,16,22,.74) 0%, rgba(11,16,22,.34) 38%, rgba(11,16,22,.5) 66%, rgba(11,16,22,.93) 100%);
}
.hero .hero-inner{position:relative;z-index:2;}

/* hero entrance (plays once on load) */
@keyframes heroPop{from{opacity:0;transform:translateY(24px) scale(.95)}to{opacity:1;transform:none}}
@keyframes heroUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
@keyframes glowPulse{
  0%,100%{filter:drop-shadow(0 12px 30px rgba(0,0,0,.6)) drop-shadow(0 0 22px rgba(150,185,220,.22));}
  50%{filter:drop-shadow(0 12px 30px rgba(0,0,0,.6)) drop-shadow(0 0 42px rgba(185,208,235,.5));}
}
.hero-logo{animation:heroPop .9s cubic-bezier(.16,.8,.24,1) both;}

/* bouncing scroll cue */
.scroll-cue{position:absolute;left:50%;bottom:24px;z-index:3;color:var(--blue-2);
  width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(91,167,230,.4);background:rgba(11,16,22,.35);backdrop-filter:blur(4px);
  animation:bob 1.9s ease-in-out infinite;transition:color .2s,border-color .2s,background .2s;}
.scroll-cue svg{width:22px;height:22px;}
.scroll-cue:hover{color:#fff;border-color:var(--blue-2);background:rgba(58,144,212,.25);}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}
.hero-centered .eyebrow{animation:heroUp .8s .14s cubic-bezier(.16,.8,.24,1) both;}
.hero h1{animation:heroUp .8s .24s cubic-bezier(.16,.8,.24,1) both;}
.hero .hero-sub{animation:heroUp .8s .36s cubic-bezier(.16,.8,.24,1) both;}
.hero .hero-cta{animation:heroUp .8s .48s cubic-bezier(.16,.8,.24,1) both;}
.hero .trust-list{animation:heroUp .8s .60s cubic-bezier(.16,.8,.24,1) both;}
.hero-inner{max-width:760px;}
.hero-centered{max-width:860px;margin-left:auto;margin-right:auto;display:flex;flex-direction:column;align-items:center;text-align:center;}
.hero-logo{margin-bottom:22px;}
.hero-logo{position:relative;}
.hero-logo img{width:480px;max-width:88vw;height:auto;display:block;
  filter:drop-shadow(0 12px 30px rgba(0,0,0,.6)) drop-shadow(0 0 26px rgba(150,185,220,.28));
  animation:glowPulse 4s ease-in-out 1.4s infinite;}
/* metallic glint that sweeps across the logo (masked to its shape) */
@supports ((-webkit-mask:url("x")) or (mask:url("x"))){
  .hero-logo::after{
    content:"";position:absolute;inset:0;pointer-events:none;z-index:2;
    -webkit-mask:url('images/logo-mask.png') center/contain no-repeat;
            mask:url('images/logo-mask.png') center/contain no-repeat;
    background:linear-gradient(105deg, transparent 43%, rgba(255,255,255,.85) 50%, transparent 57%);
    background-size:240% 100%;background-position:170% 0;
    animation:logoGlint 6.5s ease-in-out 2.2s 3;
  }
}
@keyframes logoGlint{0%{background-position:170% 0}24%{background-position:-170% 0}100%{background-position:-170% 0}}
.hero-centered .hero-cta{justify-content:center;}
.hero-centered .trust-list{justify-content:center;}
.hero-centered .hero-sub{margin-left:auto;margin-right:auto;}
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-display);font-weight:700;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--blue-2);background:rgba(58,144,212,.12);border:1px solid rgba(58,144,212,.3);
  padding:7px 14px;border-radius:999px;margin-bottom:22px;
}
.hero h1{font-size:clamp(2.3rem,6vw,4.1rem);font-weight:900;margin-bottom:.35em;}
.hero h1 .accent{color:var(--blue-2);}
.hero-sub{font-size:clamp(1.05rem,2.2vw,1.28rem);color:#d5dbe3;max-width:600px;margin-bottom:30px;}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:34px;}

/* trust strip */
/* .trust = each badge item; the container border/padding lives on .trust-list only */
.trust{display:flex;align-items:center;gap:9px;list-style:none;font-weight:600;font-size:.95rem;color:#cdd4dd;}
.trust svg{width:20px;height:20px;color:var(--blue-2);flex:none;}
.trust .lbp-sm{width:26px;height:auto;flex:none;display:block;}
.trust-list{display:flex;flex-wrap:wrap;gap:14px 26px;margin:0;padding:26px 0 0;border-top:1px solid var(--line);}
@media (max-width:560px){
  .trust-list{display:grid;grid-template-columns:1fr 1fr;gap:12px 14px;}
}

/* ---------- Sections ---------- */
.section{padding:88px 0;}
.section.alt{background:var(--ink-2);}
.section-head{max-width:680px;margin:0 0 48px;}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.kicker{font-family:var(--font-display);font-weight:700;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--blue-2);margin-bottom:12px;}
.section-head h2{font-size:clamp(1.8rem,4vw,2.7rem);text-wrap:balance;}
/* metallic sheen travelling across section headings */
@supports ((-webkit-background-clip:text) or (background-clip:text)){
  .section-head h2{
    background-image:linear-gradient(105deg, var(--text) 0 42%, #ffffff 50%, var(--text) 58% 100%);
    background-size:220% 100%;background-position:120% 0;
    -webkit-background-clip:text;background-clip:text;
    -webkit-text-fill-color:transparent;color:transparent;
    animation:headSheen 7.5s ease-in-out 1s 2;
  }
}
@keyframes headSheen{0%{background-position:120% 0}22%{background-position:-40% 0}100%{background-position:-40% 0}}
.section-head p{color:var(--muted);font-size:1.08rem;margin-bottom:0;}

/* ---------- Services ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;}
.card{
  background:var(--ink);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;
  transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;
}
.section.alt .card{background:var(--ink);}
.card:hover{transform:translateY(-5px);border-color:var(--blue);box-shadow:var(--shadow);}
.card-ico{width:54px;height:54px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(58,144,212,.12);border:1px solid rgba(58,144,212,.28);margin-bottom:18px;}
.card-ico svg{width:28px;height:28px;color:var(--blue-2);}
.card h3{font-size:1.28rem;margin-bottom:.5em;}
.card p{color:var(--muted);margin:0;font-size:.98rem;}
.card .tag{display:inline-block;margin-top:16px;font-family:var(--font-display);font-weight:700;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--blue-2);}

/* ---------- Why / About ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;}
.about-copy p{color:#cbd2db;font-size:1.06rem;}
.about-copy .lead{font-size:1.2rem;color:var(--text);}
.feature-list{list-style:none;margin:24px 0 0;padding:0;display:grid;gap:16px;}
.feature-list li{display:flex;gap:14px;align-items:flex-start;}
.feature-list .fi{flex:none;width:38px;height:38px;border-radius:10px;background:rgba(58,144,212,.12);border:1px solid rgba(58,144,212,.28);display:flex;align-items:center;justify-content:center;}
.feature-list .fi.fi-logo{background:none;border:none;width:44px;height:44px;}
.fi-logo img{width:42px;height:auto;display:block;}
.feature-list .fi svg{width:20px;height:20px;color:var(--blue-2);}
.feature-list h3{font-size:1.05rem;margin:0 0 2px;}
.feature-list p{margin:0;color:var(--muted);font-size:.96rem;}
.lbp-no{color:var(--blue-2);text-decoration:underline;text-underline-offset:3px;}
.lbp-no:hover{color:#fff;}

.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}
.stat{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;text-align:center;}
.section.alt .stat{background:var(--ink);}
.stat .num{font-family:var(--font-display);font-weight:900;font-size:2.4rem;color:var(--blue-2);line-height:1;}
.stat .lbl{color:var(--muted);font-weight:600;font-size:.95rem;margin-top:8px;}

/* ---------- Gallery ---------- */
.gallery{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.shot{
  position:relative;aspect-ratio:16/10;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);background:var(--ink-2);cursor:pointer;
  display:block;width:100%;padding:0;appearance:none;-webkit-appearance:none;font:inherit;color:var(--text);text-align:left;
  transition:transform .25s cubic-bezier(.2,.7,.2,1),border-color .25s ease,box-shadow .25s ease;
}
.shot:hover{transform:translateY(-4px);border-color:var(--blue);box-shadow:var(--shadow);}
.shot.feature{grid-column:1/-1;aspect-ratio:2/1;}
.shot img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease;}
.shot:hover img{transform:scale(1.05);}
.shot .cap{position:absolute;left:0;right:0;bottom:0;padding:26px 16px 13px;font-weight:600;font-size:.95rem;
  font-family:var(--font-display);letter-spacing:.01em;color:#fff;
  background:linear-gradient(to top,rgba(10,12,16,.92),rgba(10,12,16,.45) 60%,transparent);}
@media (max-width:640px){
  .gallery{grid-template-columns:1fr;}
  .shot,.shot.feature{aspect-ratio:16/10;}
}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:300;background:rgba(8,10,13,.92);display:none;align-items:center;justify-content:center;padding:24px;}
.lightbox.open{display:flex;}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:8px;box-shadow:0 30px 80px -20px #000;}
.lightbox .lb-close{position:absolute;top:18px;right:20px;width:48px;height:48px;border-radius:10px;background:rgba(255,255,255,.1);border:1px solid var(--line-2);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.lightbox .lb-close svg{width:26px;height:26px;}

/* ---------- Colours (Colorsteel / Colorcote) ----------
   Light "brochure page" band — swatches read true, like the printed colour chart. */
.colours-band{background:linear-gradient(180deg,#f7f6f1 0%,#eceae2 100%);position:relative;overflow:hidden;}
.colours-band .kicker{color:var(--blue-d);}
.colours-band .section-head h2{animation:none;background:none;-webkit-background-clip:initial;background-clip:initial;-webkit-text-fill-color:#20242a;color:#20242a;}
.colours-band .section-head p{color:#4a5260;}
.colours-band .sw-name{color:#5a6270;}
.colours-band .swatch-fig:hover .sw-name{color:#20242a;}
.colours-band .colours-sub{color:#20242a;}
.colours-band .colours-note{color:#20242a;}
.colours-band .colours-fine,.colours-band .swipe-hint{color:#5f6673;}
.swatch-carousel{position:relative;margin-top:6px;}
.swatch-track{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:6px 4px 14px;cursor:grab;}
.swatch-track::-webkit-scrollbar{display:none;}
.swatch-track.grabbing{cursor:grabbing;scroll-behavior:auto;}
.swatch-fig{flex:0 0 clamp(124px,40vw,158px);scroll-snap-align:center;margin:0;text-align:center;display:block;appearance:none;-webkit-appearance:none;border:0;background:none;padding:0;font:inherit;color:inherit;cursor:pointer;transition:transform .2s cubic-bezier(.2,.7,.2,1);}
.swatch-fig:hover{transform:translateY(-7px) scale(1.03);}
.swatch-fig:active .swatch{transform:scale(.965);}
/* flat, true-colour chip — no texture/shading so the colour reads exactly */
.swatch{
  display:block;width:100%;position:relative;aspect-ratio:3/2;border-radius:11px;overflow:hidden;background-color:var(--c);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.22), 0 8px 18px -10px rgba(0,0,0,.35);
  transition:box-shadow .22s ease;
}
.swatch-track.play .swatch{animation:chipFlip .8s cubic-bezier(.2,.8,.3,1) both;animation-delay:calc(var(--i,0)*.055s);}
.swatch-fig:hover .swatch{box-shadow:inset 0 0 0 1px rgba(0,0,0,.2),0 16px 28px -12px rgba(0,0,0,.4),0 0 22px -6px rgba(58,144,212,.4);}
.sw-name{display:block;margin-top:10px;font-family:var(--font-display);font-weight:600;font-size:.9rem;color:var(--muted);letter-spacing:.02em;transition:color .2s;}
.swatch-fig:hover .sw-name{color:var(--text);}
html.js .swatch{opacity:0;}
html.js .profile-card{opacity:0;}
@keyframes chipFlip{0%{opacity:0;transform:perspective(700px) rotateY(0deg) scale(.82);}12%{opacity:1;}82%{transform:perspective(700px) rotateY(368deg) scale(1);}100%{opacity:1;transform:perspective(700px) rotateY(360deg) scale(1);}}
.colours-note{text-align:center;margin:32px 0 0;color:#cbd2db;font-weight:600;}
.colours-fine{text-align:center;margin:10px 0 0;color:var(--muted);font-size:.8rem;}
.swipe-hint{text-align:center;margin:2px 0 0;color:var(--muted);font-size:.82rem;letter-spacing:.02em;}
.car-btn{position:absolute;top:calc(50% - 18px);transform:translateY(-50%);z-index:6;width:44px;height:44px;border-radius:50%;border:1px solid var(--line-2);background:rgba(15,19,25,.82);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(6px);box-shadow:0 6px 16px -8px rgba(0,0,0,.8);transition:background .2s,border-color .2s,transform .15s;}
.car-btn:hover{background:var(--ink-3);border-color:var(--blue);}
.car-btn:active{transform:translateY(-50%) scale(.94);}
.car-btn svg{width:22px;height:22px;}
.car-prev{left:-8px;}
.car-next{right:-8px;}
@media (max-width:600px){.car-btn{display:none;}}

/* iron profiles */
.colours-sub{text-align:center;font-family:var(--font-display);font-weight:800;font-size:clamp(1.3rem,2.6vw,1.7rem);margin:48px 0 4px;}
.profiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(168px,1fr));gap:16px;margin-top:22px;}
.profile-card{position:relative;overflow:hidden;background:#1b1f26;border:1px solid rgba(0,0,0,.25);border-radius:12px;padding:22px 18px;text-align:center;transition:border-color .2s,box-shadow .2s;appearance:none;-webkit-appearance:none;font:inherit;color:var(--text);cursor:pointer;width:100%;display:block;box-shadow:0 10px 22px -14px rgba(0,0,0,.5);}
.profile-card:hover{border-color:var(--blue);box-shadow:var(--shadow);}
.profiles.play .profile-card{animation:cardFlip .78s cubic-bezier(.2,.8,.3,1) both;animation-delay:calc(var(--i,0)*.09s);}
@keyframes cardFlip{0%{opacity:0;transform:perspective(820px) rotateY(0deg) scale(.85);}12%{opacity:1;}82%{transform:perspective(820px) rotateY(368deg) scale(1);}100%{opacity:1;transform:perspective(820px) rotateY(360deg) scale(1);}}
.profile-art{margin-bottom:14px;display:flex;align-items:center;justify-content:center;height:56px;}
.profile-art svg{width:100%;height:56px;display:block;filter:drop-shadow(0 2px 3px rgba(0,0,0,.55));}
.pf-name{display:block;font-family:var(--font-display);font-weight:700;font-size:1.02rem;color:var(--text);}
.pf-desc{display:block;color:var(--muted);font-size:.82rem;margin-top:3px;}
/* colour popup */
.cmodal{position:fixed;inset:0;z-index:320;display:none;align-items:center;justify-content:center;padding:24px;background:rgba(8,10,13,.82);backdrop-filter:blur(4px);}
.cmodal.open{display:flex;}
.cmodal-card{position:relative;width:min(420px,92vw);background:#f8f7f2;border:1px solid rgba(0,0,0,.12);border-radius:16px;padding:26px;box-shadow:var(--shadow);text-align:center;animation:cmPop .28s cubic-bezier(.2,.8,.3,1);}
@keyframes cmPop{from{opacity:0;transform:translateY(14px) scale(.94)}to{opacity:1;transform:none}}
.cmodal-swatch{height:150px;border-radius:12px;background-color:var(--c,#333);box-shadow:inset 0 0 0 1px rgba(0,0,0,.14);margin-bottom:18px;}
.cmodal-profile{height:150px;border-radius:12px;background:var(--ink);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;padding:26px;margin-bottom:18px;}
.cmodal-profile svg{width:100%;height:auto;max-height:92px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.6));}
.cmodal-photos{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:0 0 14px;}
.cmodal-photos img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:10px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.12),0 6px 14px -8px rgba(0,0,0,.35);}
.cmodal-name{font-size:1.5rem;margin:0 0 8px;color:#20242a;}
.cmodal-desc{color:#343b47;margin:0 0 12px;font-size:1.02rem;}
.cmodal-fine{color:#5f6673;font-size:.8rem;margin:0;}
#cmQuote{margin:2px 0 14px;}
.cmodal-close{position:absolute;top:12px;right:12px;width:44px;height:44px;border-radius:9px;background:rgba(0,0,0,.05);border:1px solid rgba(0,0,0,.15);color:#20242a;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.cmodal-close:hover{background:rgba(0,0,0,.1);border-color:var(--blue);}
.cmodal-close svg{width:22px;height:22px;}

/* ---------- Service area ---------- */
.area-band{padding-bottom:72px;}
.area-pills{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:820px;margin-inline:auto;}
.area-pills li{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-weight:600;font-size:.98rem;color:#cdd4dd;
  background:var(--ink-2);border:1px solid var(--line-2);border-radius:999px;padding:10px 20px;
  transition:transform .18s ease,border-color .18s ease,color .18s ease;
}
.area-pills li::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--blue-2);flex:none;}
.area-pills li:hover{border-color:var(--blue);color:#fff;}
.area-note{text-align:center;color:var(--muted);margin:26px 0 0;font-size:1rem;}
.area-note a{color:var(--blue-2);font-weight:700;}
.area-note a:hover{text-decoration:underline;}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto;display:grid;gap:12px;}
.faq-item{background:var(--ink);border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:border-color .2s ease;}
.faq-item[open]{border-color:var(--blue);}
.faq-item summary{
  list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:14px;
  font-family:var(--font-display);font-weight:700;font-size:1.05rem;color:var(--text);
  padding:18px 22px;user-select:none;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{
  content:"";flex:none;width:12px;height:12px;
  border-right:2.5px solid var(--blue-2);border-bottom:2.5px solid var(--blue-2);
  transform:rotate(45deg);transition:transform .25s ease;margin-right:4px;
}
.faq-item[open] summary::after{transform:rotate(225deg);}
.faq-item summary:hover{color:var(--blue-2);}
.faq-a{padding:0 22px 20px;}
.faq-a p{color:var(--muted);margin:0;font-size:1rem;line-height:1.7;}

/* ---------- Sticky call bar (mobile) ---------- */
.callbar{
  position:fixed;left:0;right:0;bottom:0;z-index:95;
  display:none;gap:10px;padding:10px 14px calc(10px + env(safe-area-inset-bottom,0px));
  background:rgba(15,18,23,.92);backdrop-filter:blur(10px);border-top:1px solid var(--line-2);
  transform:translateY(110%);transition:transform .35s cubic-bezier(.2,.7,.2,1);
}
.callbar.show{transform:translateY(0);}
.callbar .btn{flex:1;justify-content:center;padding:13px 10px;font-size:.98rem;}
@media (max-width:700px){
  .callbar{display:flex;}
  body{padding-bottom:74px;}
}

/* ---------- Job-photo film strip (auto-scrolling reel) ---------- */
.reel-kicker{text-align:center;color:var(--muted);font-size:.85rem;margin:34px 0 0;letter-spacing:.02em;}
.reel-band{width:100vw;margin:18px 0 0 calc(50% - 50vw);}
.reel{overflow:hidden;position:relative;padding:10px 0 14px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);}
.reel-track{display:flex;gap:14px;width:max-content;animation:reelScroll 95s linear infinite;will-change:transform;}
.reel:hover .reel-track{animation-play-state:paused;}
@keyframes reelScroll{to{transform:translateX(calc(-50% - 7px));}}
.reel-item{
  appearance:none;-webkit-appearance:none;border:1px solid var(--line);padding:0;background:var(--ink-2);
  height:240px;border-radius:12px;overflow:hidden;cursor:pointer;flex:none;display:block;
  transition:transform .25s cubic-bezier(.2,.7,.2,1),border-color .25s ease,box-shadow .25s ease;
}
.reel-item:hover{transform:translateY(-5px) scale(1.02);border-color:var(--blue);box-shadow:var(--shadow);z-index:2;}
.reel-item img{height:100%;width:auto;display:block;}
@media (max-width:640px){
  .reel-item{height:168px;}
  .reel-track{animation-duration:72s;}
}


/* ---------- Leak line (hero) ---------- */
.leak-line{margin:14px 0 0;color:#e8edf3;font-weight:600;font-size:.98rem;}
.leak-line a{color:var(--amber);font-weight:700;text-decoration:underline;text-underline-offset:3px;}
.leak-line a:hover{color:#ffca66;}

/* ---------- Inline quote strips ---------- */
.quote-strip{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;margin:44px 0 0;padding:20px 24px;border:1px solid var(--line);border-radius:14px;background:var(--ink-2);}
.section.alt .quote-strip{background:var(--ink);}
.quote-strip p{margin:0;font-family:var(--font-display);font-weight:700;font-size:1.08rem;}

/* ---------- Reel pause control ---------- */
.reel-pause{position:absolute;right:18px;top:-6px;z-index:5;appearance:none;-webkit-appearance:none;
  font:600 .8rem var(--font-display);color:#cdd4dd;background:rgba(15,19,25,.85);border:1px solid var(--line-2);
  border-radius:999px;padding:7px 14px;cursor:pointer;transition:color .2s,border-color .2s;}
.reel-pause:hover{color:#fff;border-color:var(--blue);}
.reel-band{position:relative;}
.reel.paused .reel-track,.reel:focus-within .reel-track{animation-play-state:paused;}

/* ---------- Lightbox figure / nav ---------- */
.lb-fig{margin:0;display:flex;flex-direction:column;align-items:center;gap:0;max-width:92vw;}
.lb-fig img{max-width:92vw;max-height:82vh;border-radius:8px 8px 0 0;box-shadow:0 30px 80px -20px #000;}
.lb-fig figcaption{width:100%;background:rgba(12,15,20,.95);color:#dbe1e9;font-weight:600;font-size:.95rem;
  padding:12px 16px;border-radius:0 0 8px 8px;text-align:center;}
.lb-fig figcaption:empty{display:none;}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;
  background:rgba(255,255,255,.1);border:1px solid var(--line-2);color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;z-index:2;transition:background .2s,border-color .2s;}
.lb-nav:hover{background:rgba(58,144,212,.35);border-color:var(--blue);}
.lb-nav svg{width:26px;height:26px;}
.lb-prev{left:16px;}
.lb-next{right:16px;}
@media (max-width:640px){.lb-nav{width:44px;height:44px;}.lb-prev{left:6px;}.lb-next{right:6px;}}

/* ---------- Form validation ---------- */
.field input.invalid,.field textarea.invalid{border-color:var(--err);box-shadow:0 0 0 3px rgba(226,85,90,.22);}
.field .field-err{display:none;color:#f3a2a5;font-size:.85rem;margin-top:6px;font-weight:600;}
.field input.invalid ~ .field-err,.field textarea.invalid ~ .field-err{display:block;}
.form-status a{color:var(--blue-2);font-weight:700;text-decoration:underline;text-underline-offset:2px;}
.sms{text-decoration:underline;text-underline-offset:2px;color:var(--blue-2);}

/* ---------- Reviews ---------- */
.reviews{display:flex;flex-wrap:wrap;justify-content:center;gap:20px;}
.review{flex:1 1 300px;max-width:calc(33.33% - 14px);}
@media (max-width:960px){.review{max-width:calc(50% - 10px);}}
@media (max-width:640px){.review{max-width:100%;}}
.review{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;display:flex;flex-direction:column;}
.section.alt .review{background:var(--ink);}
.stars{display:flex;gap:3px;margin-bottom:14px;color:var(--amber);}
.stars svg{width:19px;height:19px;}
.review blockquote{margin:0 0 18px;font-size:1.04rem;color:#dbe1e9;font-style:normal;line-height:1.6;}
.review .who{display:flex;align-items:center;gap:12px;margin-top:auto;}
.review .avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--blue-2),var(--blue-d));color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:1rem;}
.review .who .nm{font-weight:700;font-size:.98rem;}
.review .who .rl{color:var(--muted);font-size:.85rem;}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start;}
.contact-details{display:grid;gap:14px;margin:0;}
.cd{display:flex;gap:15px;align-items:flex-start;background:var(--ink);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;}
.section.alt .cd{background:var(--ink-2);}
.cd .ci{flex:none;width:44px;height:44px;border-radius:11px;background:rgba(58,144,212,.12);border:1px solid rgba(58,144,212,.28);display:flex;align-items:center;justify-content:center;}
.cd .ci svg{width:22px;height:22px;color:var(--blue-2);}
.cd .lbl{color:var(--muted);font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;}
.cd .val{font-family:var(--font-display);font-weight:700;font-size:1.12rem;color:var(--text);}
.cd a.val:hover{color:var(--blue-2);}
.cd .sub{color:var(--muted);font-size:.9rem;}

/* form */
.form-card{background:var(--ink);border:1px solid var(--line);border-radius:16px;padding:30px 28px;box-shadow:var(--shadow);}
.section.alt .form-card{background:var(--ink-2);}
.form-card h3{font-size:1.4rem;margin-bottom:6px;}
.form-card .fine{color:var(--muted);font-size:.92rem;margin-bottom:20px;}
.field{margin-bottom:16px;}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:7px;color:#d5dbe3;}
.field label .req{color:var(--amber);}
.field input,.field textarea{
  width:100%;background:var(--ink-2);border:1px solid var(--line-2);border-radius:10px;
  color:var(--text);font-family:inherit;font-size:1rem;padding:13px 15px;transition:border-color .15s,box-shadow .15s;
}
.section.alt .field input,.section.alt .field textarea{background:var(--ink);}
.field input::placeholder,.field textarea::placeholder{color:#697585;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(58,144,212,.25);}
.field textarea{resize:vertical;min-height:112px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-status{margin-top:14px;padding:14px 16px;border-radius:10px;font-weight:600;display:none;}
.form-status.show{display:block;}
.form-status.ok{background:rgba(55,178,107,.13);border:1px solid rgba(55,178,107,.4);color:#8be3b0;}
.form-status.err{background:rgba(226,85,90,.13);border:1px solid rgba(226,85,90,.4);color:#f3a2a5;}

/* ---------- Footer ---------- */
.footer{background:#0f1217;border-top:1px solid var(--line);padding:56px 0 30px;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:40px;}
.logo-utr-footer{height:58px;width:auto;display:block;margin-bottom:16px;filter:drop-shadow(0 3px 10px rgba(0,0,0,.5));}
.footer p{color:var(--muted);font-size:.96rem;max-width:340px;}
.footer h4{font-family:var(--font-display);font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;color:#c6cdd6;margin-bottom:16px;}
.footer ul{list-style:none;margin:0;padding:0;display:grid;gap:10px;}
.footer ul a,.footer ul li{color:var(--muted);font-size:.96rem;}
.footer ul a:hover{color:var(--blue-2);}
.footer-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px;}
.badge{display:inline-flex;align-items:center;gap:7px;font-size:.8rem;font-weight:600;color:#cdd4dd;background:var(--ink-2);border:1px solid var(--line);padding:7px 12px;border-radius:999px;}
.badge svg{width:15px;height:15px;color:var(--blue-2);}
.badge .lbp-xs{width:20px;height:auto;display:block;}
.footer-bottom{border-top:1px solid var(--line);padding-top:24px;display:flex;flex-wrap:wrap;gap:8px 20px;justify-content:space-between;color:var(--muted);font-size:.88rem;}


/* ---------- Reveal animation (scroll-triggered; html.js gate = static page if JS fails) ---------- */
html.js .reveal{
  opacity:0;transform:translateY(32px) scale(.985);
  transition:opacity .75s cubic-bezier(.16,.8,.24,1),transform .75s cubic-bezier(.16,.8,.24,1);
  transition-delay:var(--rd,0ms);will-change:opacity,transform;
}
html.js .reveal.in{opacity:1;transform:none;}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .split,.contact-grid{grid-template-columns:1fr;gap:38px;}
  .footer-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width:820px){
  .header-phone .lbl{display:none;}
  .menu-btn{display:inline-flex;}
  .header-cta .btn-primary{display:inline-flex;}
  .header-phone{padding:12px 10px;min-width:44px;min-height:44px;justify-content:center;}
  .header-phone svg{width:20px;height:20px;}
  .nav{
    position:fixed;top:var(--header-h);left:0;right:0;flex-direction:column;align-items:stretch;gap:2px;
    background:rgba(17,20,25,.98);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
    padding:14px 22px 22px;transform:translateY(-130%);transition:transform .3s ease,visibility .3s;
    visibility:hidden;z-index:99;
  }
  .nav.open{visibility:visible;transform:translateY(0);}
  .nav a.navlink{font-size:1.05rem;padding:13px 10px;border-bottom:1px solid var(--line);border-radius:0;}
  .nav .nav-call{display:flex;align-items:center;gap:10px;color:var(--blue-2);font-weight:700;}
  .nav .nav-call svg{width:18px;height:18px;}
  .nav .btn{margin-top:12px;}
  .section{padding:64px 0;}
}
@media (max-width:560px){
  .form-row{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .stats{grid-template-columns:1fr 1fr;}
  .hero-cta .btn{flex:1 1 100%;justify-content:center;}
  .header-cta .btn-primary{padding:11px 15px;}
  .hero-logo{margin-bottom:14px;}
  .hero-logo img{width:230px;}
  .hero{padding-top:calc(var(--header-h) + 22px);}
  .eyebrow{font-size:.68rem;letter-spacing:.06em;padding:6px 12px;}
}
@media (max-width:379px){
  .callbar .btn{font-size:.85rem;padding:12px 6px;gap:6px;}
}
/* clear custom focus for dialog close/nav buttons */
.cmodal-close:focus-visible,.lb-close:focus-visible,.lb-nav:focus-visible,.reel-pause:focus-visible{outline:3px solid var(--blue-2);outline-offset:2px;}

@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto !important;}
  .reveal,html.js .reveal{opacity:1;transform:none;transition:none;}
  .card:hover{transform:none;}
  .shot:hover{transform:none;}
  .shot:hover img{transform:none;}
  .hero-logo,.hero-logo img,.hero-centered .eyebrow,.hero h1,.hero .hero-sub,.hero .hero-cta,.hero .trust-list,.scroll-cue{animation:none;}
  .hero-bg{transform:none !important;}
  .btn:hover,.btn-primary:hover,.btn-call:hover,.btn-ghost:hover{transform:none;}
  .btn:hover::after{animation:none;}
  .swatch,.profile-card{opacity:1 !important;animation:none !important;}
  .swatch-fig:hover,.profile-card:hover{transform:none;}
  .callbar{transition:none;}
  .area-pills li:hover{transform:none;}
  .reel-track{animation:none;}
  .quote-strip,.leak-line{transition:none;}
  .reel{overflow-x:auto;-webkit-mask-image:none;mask-image:none;}
  .reel-item:hover{transform:none;}
  .hero-logo::after{animation:none;opacity:0;}
  .section-head h2{animation:none;background:none;-webkit-text-fill-color:var(--text);color:var(--text);}
  .cmodal-card{animation:none;}
}
