/* Aureum Roofing — shared styles (extracted from single-page build) */
:root{
  --ink:#0d0f12; --char:#16191e; --slate:#5b636d; --soft:#8a929c;
  --mist:#f2f5f8; --line:#e3e8ed; --white:#ffffff;
  --sky:#8fd0ef; --sky-2:#b9e4f6; --sky-deep:#1f7aa3; --sky-ink:#0a3548;
  --r:16px; --max:1200px; --shadow:0 24px 60px -28px rgba(13,15,18,.35);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Hanken Grotesk',sans-serif;color:var(--ink);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.dsp{font-family:'Archivo',sans-serif;line-height:1.02;letter-spacing:-.02em}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.eyebrow{font-family:'Archivo';font-weight:700;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sky-deep)}
.eyebrow.light{color:var(--sky)}
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:'Archivo';font-weight:700;font-size:.95rem;padding:.95rem 1.5rem;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:transform .25s,box-shadow .25s,background .25s,color .25s}
.btn-sky{background:var(--sky);color:var(--ink)}
.btn-sky:hover{transform:translateY(-3px);box-shadow:0 16px 30px -12px rgba(143,208,239,.8)}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{transform:translateY(-3px);box-shadow:0 18px 34px -14px rgba(13,15,18,.6)}
.btn-ghost{background:transparent;border-color:rgba(255,255,255,.4);color:#fff}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.topbar{background:var(--ink);color:#cdd4dc;font-size:.83rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.55rem 24px;flex-wrap:wrap}
.topbar a{color:#fff;font-weight:600}.topbar .dot{color:var(--sky)}
header.nav{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);transition:box-shadow .3s}
header.nav.scrolled{box-shadow:0 10px 30px -22px rgba(13,15,18,.5)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:.7rem}.brand img{height:46px}
.navlinks{display:flex;gap:1.8rem;align-items:center}
.navlinks a{font-weight:600;font-size:.95rem;color:var(--char);position:relative}
.navlinks a::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--sky);transition:width .3s}
.navlinks a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:1rem}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:26px;height:2.5px;background:var(--ink);border-radius:2px}
.hero{position:relative;min-height:90vh;display:flex;align-items:flex-end;overflow:hidden;background:#0d0f12}
.hero-bg{position:absolute;inset:0;background-image:url('../images/hero-roof.jpg');background-size:cover;background-position:center;transform:scale(1.08);animation:kenburns 26s ease-in-out infinite alternate;will-change:transform}
@keyframes kenburns{from{transform:scale(1.08) translate3d(0,0,0)}to{transform:scale(1.15) translate3d(-1.6%,-1.2%,0)}}
.hero-shade{position:absolute;inset:0;background:
  linear-gradient(100deg,rgba(8,11,15,.94) 0%,rgba(8,11,15,.82) 28%,rgba(8,11,15,.5) 52%,rgba(8,11,15,.2) 76%,rgba(8,11,15,.34) 100%),
  linear-gradient(0deg,rgba(8,11,15,.92) 0%,rgba(8,11,15,.32) 30%,transparent 60%)}
.hero .wrap{position:relative;z-index:2;padding-top:7rem;padding-bottom:4.8rem;width:100%}
.hero-inner{position:relative;display:inline-block;max-width:790px}
.hero-glass{position:absolute;inset:-1.7rem -2.6rem;z-index:0;border-radius:30px;background:linear-gradient(105deg,rgba(7,10,14,.52),rgba(7,10,14,.12));backdrop-filter:blur(7px) saturate(115%);-webkit-backdrop-filter:blur(7px) saturate(115%);border:1px solid rgba(255,255,255,.05);-webkit-mask:radial-gradient(128% 116% at 24% 44%,#000 50%,transparent 100%);mask:radial-gradient(128% 116% at 24% 44%,#000 50%,transparent 100%)}
.hero-inner>p,.hero-inner>h1,.hero-inner>div:not(.hero-glass){position:relative;z-index:1}
.hero h1.hero-h1{color:#fff;font-weight:900;font-size:clamp(2.7rem,6.8vw,5.5rem);line-height:.98;max-width:14ch;margin:.25rem 0 0}
.hero-h1 .ln{display:block;overflow:hidden;padding:0 .06em .08em 0}
.hero-h1 .ln-i{display:inline-block;transform:translateY(118%);animation:lineUp .95s cubic-bezier(.22,.8,.16,1) forwards;text-shadow:0 4px 30px rgba(0,0,0,.45)}
.hero-h1 .ln:nth-child(1) .ln-i{animation-delay:.14s}
.hero-h1 .ln:nth-child(2) .ln-i{animation-delay:.28s}
@keyframes lineUp{to{transform:none}}
.hero .hero-h1 .ln-i.acc{background:linear-gradient(100deg,var(--sky) 0%,var(--sky) 36%,#eef9ff 50%,var(--sky) 64%,var(--sky) 100%);background-size:230% 100%;background-position:128% 0;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;filter:drop-shadow(0 4px 20px rgba(0,0,0,.4));animation:lineUp .95s cubic-bezier(.22,.8,.16,1) .42s forwards,shimmer 1.3s ease-out 1.5s forwards}
@keyframes shimmer{from{background-position:128% 0}to{background-position:-28% 0}}
.hero p.sub{color:#eef3f7;font-size:clamp(1.05rem,1.7vw,1.35rem);max-width:46ch;margin:1.5rem 0 2rem;font-weight:500;text-shadow:0 2px 18px rgba(0,0,0,.5)}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}
.hero-trust{display:flex;gap:1.6rem;flex-wrap:wrap;margin-top:2.6rem;color:#e3e9ef;font-weight:600;font-size:.95rem;text-shadow:0 2px 14px rgba(0,0,0,.5)}
.hero-trust span{display:flex;align-items:center;gap:.5rem}.hero-trust svg{width:18px;height:18px;color:var(--sky)}
.reveal{opacity:0;transform:translateY(22px);animation:rise .8s cubic-bezier(.2,.7,.2,1) forwards}
.d1{animation-delay:.05s}.dsub{animation-delay:.66s}.dcta{animation-delay:.82s}.dtrust{animation-delay:.96s}
@keyframes rise{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){
  .hero-bg{animation:none;transform:scale(1.04)}
  .hero-h1 .ln-i,.hero .hero-h1 .ln-i.acc{transform:none;animation:none}
  .hero .hero-h1 .ln-i.acc{background-position:0 0}
  .reveal{opacity:1;transform:none;animation:none}
}
.strip{background:var(--char);color:#fff}
.strip .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;padding:0}
.strip .cell{padding:2.1rem 1.5rem;text-align:center;border-right:1px solid rgba(255,255,255,.08)}
.strip .cell:last-child{border-right:0}
.strip .n{font-family:'Archivo';font-weight:800;font-size:1.7rem;color:var(--sky)}
.strip .l{font-size:.9rem;color:#c4ccd5;margin-top:.2rem}
section.pad{padding:clamp(4rem,8vw,7rem) 0}
.shead{max-width:62ch}
.shead h2{font-weight:800;font-size:clamp(2rem,4.2vw,3.2rem);margin:.7rem 0 .8rem}
.shead p{color:var(--slate);font-size:1.08rem;max-width:56ch}
.bg-mist{background:var(--mist)}.bg-ink{background:var(--ink)}

/* ===== TRANSFORMATION ===== */
.tf{background:radial-gradient(1200px 600px at 70% -10%,rgba(143,208,239,.16),transparent 60%),var(--ink);color:#fff}
.tf .shead h2{color:#fff}.tf .shead p{color:#c4ccd5}
.xwrap{margin-top:2.6rem;position:relative;border-radius:20px;overflow:hidden;box-shadow:0 40px 90px -40px rgba(0,0,0,.8);border:1px solid rgba(255,255,255,.08)}
.xfade{position:relative;aspect-ratio:16/9;background:#000}
.xfade .layer{position:absolute;inset:0;opacity:0;transition:opacity 1.1s ease}
.xfade .layer img{width:100%;height:100%;object-fit:cover;transform:scale(1.0);transition:transform 4s ease}
.xfade .layer.on{opacity:1;z-index:1}
.xfade .layer.on img{transform:scale(1.07)}
.xfade::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(180deg,rgba(0,0,0,.35),transparent 30%,transparent 60%,rgba(0,0,0,.55))}
.xcap{position:absolute;left:0;right:0;bottom:0;z-index:3;padding:1.6rem 1.8rem;display:flex;justify-content:space-between;align-items:flex-end;gap:1rem}
.xcap .stage{font-family:'Archivo';font-weight:900;font-size:clamp(1.4rem,3vw,2.2rem)}
.xcap .desc{color:#dbe2e9;font-size:.98rem;max-width:42ch}
.xcap .time{font-family:'Archivo';font-weight:700;color:var(--sky);font-size:.85rem;letter-spacing:.12em}
.xbar{position:absolute;top:0;left:0;right:0;z-index:3;height:4px;background:rgba(255,255,255,.18)}
.xbar i{display:block;height:100%;width:0;background:var(--sky)}
.xbar i.run{animation-name:fill;animation-timing-function:linear;animation-fill-mode:forwards}
@keyframes fill{from{width:0}to{width:100%}}
.xctrl{display:flex;align-items:center;gap:.6rem;margin-top:1.2rem;flex-wrap:wrap}
.chip{font-family:'Archivo';font-weight:700;font-size:.9rem;color:#cdd4dc;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);padding:.6rem 1.1rem;border-radius:999px;cursor:pointer;transition:.25s}
.chip:hover{border-color:var(--sky)}
.chip.active{background:var(--sky);color:var(--ink);border-color:var(--sky)}
.playbtn{margin-left:auto;display:inline-flex;align-items:center;gap:.5rem;font-family:'Archivo';font-weight:700;font-size:.9rem;color:#fff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);padding:.6rem 1rem;border-radius:999px;cursor:pointer}
.playbtn svg{width:16px;height:16px}

/* before/after slider */
.ba-row{display:grid;grid-template-columns:1.15fr .85fr;gap:2.6rem;align-items:center;margin-top:3.4rem}
.ba{position:relative;aspect-ratio:16/9;border-radius:18px;overflow:hidden;user-select:none;touch-action:none;cursor:ew-resize;box-shadow:0 30px 70px -34px rgba(0,0,0,.8);border:1px solid rgba(255,255,255,.08)}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba .after{z-index:2;clip-path:inset(0 50% 0 0)}
.ba .lab{position:absolute;bottom:14px;z-index:4;font-family:'Archivo';font-weight:700;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:rgba(13,15,18,.6);padding:.34rem .7rem;border-radius:999px;backdrop-filter:blur(4px)}
.ba .lab.l{left:14px}.ba .lab.r{right:14px}
.ba .handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;z-index:5;transform:translateX(-50%)}
.ba .handle::before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:#fff;box-shadow:0 6px 20px rgba(0,0,0,.4)}
.ba .handle::after{content:"\2194";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.2rem;color:var(--ink);z-index:1}
.ba-copy h3{font-size:clamp(1.6rem,3.4vw,2.2rem);font-weight:800;margin-bottom:.8rem}
.ba-copy p{color:#c4ccd5;font-size:1.05rem}
.ba-copy .mini{display:flex;gap:1.4rem;margin-top:1.6rem;flex-wrap:wrap}
.ba-copy .mini div b{font-family:'Archivo';font-weight:900;color:var(--sky);font-size:1.5rem;display:block}
.ba-copy .mini div span{font-size:.85rem;color:#aab2bc}

/* services */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:3rem}
.svc{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2rem 1.8rem;transition:transform .3s,box-shadow .3s,border-color .3s}
.svc:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.svc .ic{width:54px;height:54px;border-radius:13px;display:grid;place-items:center;background:linear-gradient(145deg,var(--sky-2),var(--sky));margin-bottom:1.1rem}
.svc .ic svg{width:28px;height:28px;color:var(--ink)}
.svc h3{font-size:1.3rem;font-weight:700;margin-bottom:.5rem}.svc p{color:var(--slate);font-size:.98rem}
/* gallery */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px;margin-top:3rem}
.gal figure{position:relative;overflow:hidden;border-radius:14px;cursor:pointer;background:#0d0f12}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.gal figure:hover img{transform:scale(1.07)}
.gal figcaption{position:absolute;left:0;right:0;bottom:0;padding:1rem;color:#fff;font-family:'Archivo';font-weight:700;font-size:.95rem;background:linear-gradient(0deg,rgba(13,15,18,.82),transparent);opacity:0;transform:translateY(8px);transition:.35s}
.gal figure:hover figcaption{opacity:1;transform:none}
.gal .tag{position:absolute;top:.8rem;left:.8rem;background:var(--sky);color:var(--ink);font-family:'Archivo';font-weight:700;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;padding:.3rem .65rem;border-radius:999px}
.g-wide{grid-column:span 2}.g-tall{grid-row:span 2}
/* process */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;margin-top:3rem}
.step{position:relative;padding:1.6rem 0 0}
.step .num{font-family:'Archivo';font-weight:900;font-size:3rem;color:var(--line);line-height:1}
.step h3{font-size:1.18rem;font-weight:700;margin:.5rem 0 .4rem}.step p{color:var(--slate);font-size:.96rem}
.step::before{content:"";position:absolute;top:1.6rem;left:0;width:46px;height:4px;background:var(--sky);border-radius:3px}
/* why */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:3.4rem;align-items:center}
.split-img{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);position:relative}
.split-img img{width:100%;height:100%;object-fit:cover;min-height:420px}
.badge{position:absolute;bottom:18px;left:18px;background:#fff;border-radius:14px;padding:.9rem 1.2rem;box-shadow:0 16px 30px -14px rgba(0,0,0,.4)}
.badge .b1{font-family:'Archivo';font-weight:900;font-size:1.7rem}.badge .b2{font-size:.82rem;color:var(--slate)}
.checks{list-style:none;margin-top:1.6rem;display:grid;gap:1rem}
.checks li{display:flex;gap:.85rem;align-items:flex-start}
.checks .ck{flex:0 0 auto;width:26px;height:26px;border-radius:50%;background:var(--sky);display:grid;place-items:center;margin-top:2px}
.checks .ck svg{width:15px;height:15px;color:var(--ink)}
.checks b{font-family:'Archivo';font-weight:700;display:block;font-size:1.05rem}.checks span{color:var(--slate);font-size:.96rem}
/* area */
.area{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.area-list{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.6rem}
.area-list span{background:#fff;border:1px solid var(--line);border-radius:999px;padding:.5rem 1.1rem;font-weight:600;font-size:.95rem}
.cta{background:linear-gradient(120deg,var(--ink),var(--char));color:#fff;border-radius:24px;padding:clamp(2.5rem,5vw,4rem);text-align:center;position:relative;overflow:hidden}
.cta::after{content:"";position:absolute;width:340px;height:340px;background:radial-gradient(circle,var(--sky) 0%,transparent 70%);opacity:.22;top:-120px;right:-80px}
.cta h2{font-weight:900;font-size:clamp(2rem,4.6vw,3.3rem);position:relative}
.cta p{color:#d7dee5;max-width:48ch;margin:1rem auto 2rem;position:relative;font-size:1.1rem}
.cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative}
.contact{display:grid;grid-template-columns:1fr 1fr;gap:3.4rem}
.cline{display:flex;gap:1rem;align-items:flex-start;padding:1.1rem 0;border-bottom:1px solid var(--line)}
.cline .ci{flex:0 0 auto;width:46px;height:46px;border-radius:12px;background:var(--mist);display:grid;place-items:center}
.cline .ci svg{width:22px;height:22px;color:var(--sky-deep)}
.cline .lbl{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--soft);font-weight:700;font-family:'Archivo'}
.cline .val{font-size:1.15rem;font-weight:700;font-family:'Archivo'}
.cline .val.tbd{color:var(--soft);font-weight:600;font-style:italic;font-family:'Hanken Grotesk'}
form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
form label{font-size:.82rem;font-weight:700;font-family:'Archivo';display:block;margin:1rem 0 .4rem}
form input,form textarea{width:100%;padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:11px;font-family:inherit;font-size:1rem;background:#fff;transition:border-color .2s}
form input:focus,form textarea:focus{outline:none;border-color:var(--sky-deep)}
form textarea{min-height:120px;resize:vertical}
.formcard{background:var(--mist);border-radius:var(--r);padding:2rem}
.formnote{font-size:.82rem;color:var(--soft);margin-top:1rem}
footer{background:var(--ink);color:#aab2bc;padding:3.5rem 0 2rem;font-size:.95rem}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.1)}
footer img.flogo{height:64px;margin-bottom:1rem}
footer h4{font-family:'Archivo';color:#fff;font-size:1rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:1rem}
footer a{display:block;padding:.3rem 0;color:#aab2bc;transition:color .2s}footer a:hover{color:var(--sky)}
.fbar{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-top:1.6rem;font-size:.85rem;color:#7b838d}
.lb{position:fixed;inset:0;background:rgba(8,9,11,.92);display:none;align-items:center;justify-content:center;z-index:200;padding:24px;cursor:zoom-out}
.lb.open{display:flex}.lb img{max-width:92vw;max-height:88vh;border-radius:10px}
.lb .x{position:absolute;top:22px;right:26px;color:#fff;font-size:2.4rem;font-family:'Archivo';cursor:pointer}
[data-rev]{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
[data-rev].in{opacity:1;transform:none}
@media(max-width:980px){
  .svc-grid,.steps{grid-template-columns:repeat(2,1fr)}
  .split,.area,.contact,.ba-row{grid-template-columns:1fr;gap:2.2rem}
  .strip .wrap{grid-template-columns:repeat(2,1fr)}.strip .cell:nth-child(2){border-right:0}
  .gal{grid-template-columns:repeat(2,1fr)}.fgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
  .navlinks{position:fixed;inset:78px 0 auto 0;background:#fff;flex-direction:column;gap:0;padding:1rem 24px 2rem;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .35s;box-shadow:var(--shadow)}
  .navlinks.show{transform:none}
  .navlinks a{padding:.9rem 0;width:100%;border-bottom:1px solid var(--line)}
  .burger{display:flex}.nav-cta .btn{display:none}.topbar .area-note{display:none}
  .svc-grid,.steps,.gal,.fgrid{grid-template-columns:1fr}.g-wide,.g-tall{grid-column:auto;grid-row:auto}
  form .row{grid-template-columns:1fr}.xcap{flex-direction:column;align-items:flex-start;gap:.4rem;padding:1rem}
}

/* ===== Transformation showpiece (scoped, replaces prior version) ===== */
#transform{
  --tf-ink:#0b0d10; --tf-char:#14171c; --tf-panel:#1b1f25; --tf-line:rgba(255,255,255,.1);
  --tf-slate:#9aa3ad; --tf-sky:#8fd0ef; --tf-sky2:#bfe6f7;
  padding:clamp(3.5rem,7vw,6.5rem) 0; color:#fff;
  background:radial-gradient(1200px 600px at 80% -10%, rgba(143,208,239,.12), transparent 60%), linear-gradient(180deg,#0b0d10,#0e1115);
}
#transform .tf-in{max-width:1120px;margin:0 auto;padding:0 24px}
#transform .tf-eyebrow{font-family:'Archivo',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;color:var(--tf-sky)}
#transform .tf-head{max-width:42ch;margin:.7rem 0 .5rem}
#transform .tf-head h2{font-family:'Archivo',sans-serif;font-weight:900;font-size:clamp(2rem,4.6vw,3.4rem);color:#fff;letter-spacing:-.02em;line-height:1.02}
#transform .tf-head h2 .a{color:var(--tf-sky)}
#transform .tf-sub{color:var(--tf-slate);font-size:1.05rem;max-width:52ch}
#transform .modes{display:inline-flex;background:var(--tf-panel);border:1px solid var(--tf-line);border-radius:999px;padding:5px;margin:1.8rem 0 1.2rem;gap:4px}
#transform .modes button{font-family:'Archivo',sans-serif;font-weight:700;font-size:.85rem;letter-spacing:.02em;color:var(--tf-slate);background:none;border:0;padding:.6rem 1.3rem;border-radius:999px;cursor:pointer;transition:.25s;display:flex;align-items:center;gap:.5rem}
#transform .modes button.on{background:var(--tf-sky);color:#0b0d10}
#transform .modes svg{width:16px;height:16px}
#transform .stage{position:relative;aspect-ratio:16/9;border-radius:18px;overflow:hidden;background:#000;box-shadow:0 40px 90px -40px rgba(0,0,0,.9);border:1px solid var(--tf-line)}
#transform .layer{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease}
#transform .layer img{width:100%;height:100%;object-fit:cover;transform:scale(1);transition:transform 4s ease}
#transform .layer.show{opacity:1}
#transform .layer.show img{transform:scale(1.08)}
#transform .vignette{position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,rgba(0,0,0,.28),transparent 28%,transparent 62%,rgba(0,0,0,.62))}
#transform .slabel{position:absolute;left:22px;bottom:74px;z-index:5;pointer-events:none}
#transform .slabel .step{font-family:'Archivo',sans-serif;font-weight:900;font-size:.8rem;letter-spacing:.2em;color:var(--tf-sky);text-transform:uppercase}
#transform .slabel .ttl{font-family:'Archivo',sans-serif;font-weight:900;font-size:clamp(1.5rem,3.4vw,2.4rem);text-shadow:0 3px 18px rgba(0,0,0,.6);line-height:1.05}
#transform .slabel .cap{font-size:.95rem;color:#e7edf3;max-width:42ch;text-shadow:0 2px 10px rgba(0,0,0,.6)}
#transform .fade-up{animation:tfFadeUp .7s cubic-bezier(.2,.7,.2,1)}
@keyframes tfFadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
#transform .controls{position:absolute;left:0;right:0;bottom:0;z-index:6;display:flex;align-items:center;gap:14px;padding:16px 18px;background:linear-gradient(0deg,rgba(8,10,13,.78),transparent)}
#transform .play{flex:0 0 auto;width:42px;height:42px;border-radius:50%;border:0;background:var(--tf-sky);color:#0b0d10;cursor:pointer;display:grid;place-items:center;transition:transform .2s}
#transform .play:hover{transform:scale(1.08)}
#transform .play svg{width:18px;height:18px}
#transform .track{flex:1;display:flex;gap:8px}
#transform .seg{flex:1;cursor:pointer;padding:8px 0}
#transform .seg .bar{height:4px;border-radius:3px;background:rgba(255,255,255,.22);overflow:hidden;position:relative}
#transform .seg .fill{position:absolute;inset:0;width:0;background:var(--tf-sky);border-radius:3px}
#transform .seg.done .fill{width:100%}
#transform .seg .nm{font-family:'Archivo',sans-serif;font-weight:700;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--tf-slate);margin-top:7px;transition:color .25s}
#transform .seg.active .nm{color:#fff}
#transform .compare{position:absolute;inset:0;display:none}
#transform .compare.on{display:block}
#transform .compare .base{position:absolute;inset:0}
#transform .compare .base img{width:100%;height:100%;object-fit:cover}
#transform .compare .ctop{position:absolute;inset:0;width:50%;overflow:hidden;border-right:3px solid var(--tf-sky)}
#transform .compare .ctop img{width:100vw;max-width:none;height:100%;object-fit:cover}
#transform .cmp-wide{position:absolute;inset:0}
#transform .handle{position:absolute;top:0;bottom:0;left:50%;width:44px;transform:translateX(-50%);cursor:ew-resize;z-index:7;display:grid;place-items:center}
#transform .handle .knob{width:44px;height:44px;border-radius:50%;background:var(--tf-sky);color:#0b0d10;display:grid;place-items:center;box-shadow:0 6px 20px rgba(0,0,0,.5)}
#transform .handle .knob svg{width:22px;height:22px}
#transform .tagba{position:absolute;top:14px;z-index:7;font-family:'Archivo',sans-serif;font-weight:800;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;padding:.4rem .8rem;border-radius:999px;background:rgba(11,13,16,.7);backdrop-filter:blur(6px);border:1px solid var(--tf-line)}
#transform .tagba.l{left:14px;color:#fff}
#transform .tagba.r{right:14px;color:var(--tf-sky)}
#transform .hint{position:absolute;left:50%;bottom:16px;transform:translateX(-50%);z-index:7;font-size:.82rem;color:#cfd7df;background:rgba(11,13,16,.6);padding:.4rem .9rem;border-radius:999px;pointer-events:none;transition:opacity .4s}
#transform .meta{display:flex;flex-wrap:wrap;gap:1.5rem;margin-top:1.4rem;color:var(--tf-slate);font-size:.92rem}
#transform .meta b{font-family:'Archivo',sans-serif;color:#fff;display:block;font-size:1.25rem}
#transform .meta .it{display:flex;flex-direction:column}
#transform .tf-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:2rem}
#transform .tf-strip figure{position:relative;aspect-ratio:16/10;border-radius:12px;overflow:hidden;cursor:pointer;border:1px solid var(--tf-line)}
#transform .tf-strip img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
#transform .tf-strip figure:hover img{transform:scale(1.08)}
#transform .tf-strip figcaption{position:absolute;left:0;right:0;bottom:0;padding:.7rem;font-family:'Archivo',sans-serif;font-weight:700;font-size:.78rem;background:linear-gradient(0deg,rgba(8,10,13,.85),transparent)}
.xlb{position:fixed;inset:0;background:rgba(6,7,9,.94);display:none;align-items:center;justify-content:center;z-index:300;padding:24px;cursor:zoom-out}
.xlb.open{display:flex}
.xlb img{max-width:94vw;max-height:90vh;border-radius:10px}
.xlb .xx{position:absolute;top:20px;right:26px;font-size:2.3rem;font-family:'Archivo',sans-serif;color:#fff;cursor:pointer}
@media(max-width:760px){
  #transform .slabel{bottom:84px}
  #transform .tf-strip{grid-template-columns:repeat(2,1fr)}
  #transform .seg .nm{display:none}
}

/* ===== multi-page additions (Step 1) ===== */
.navlinks a.current{color:var(--sky-deep)}
.navlinks a.current::after{width:100%}
.skel{padding:clamp(4rem,9vw,8rem) 0;background:linear-gradient(180deg,var(--mist),#fff)}
.skel .wrap{max-width:760px;text-align:center}
.skel .tagk{display:inline-block;font-family:'Archivo';font-weight:700;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sky-deep);background:#fff;border:1px solid var(--line);padding:.45rem 1rem;border-radius:999px;margin-bottom:1.4rem}
.skel h1{font-weight:900;font-size:clamp(2.2rem,5vw,3.4rem);margin-bottom:1rem}
.skel p{color:var(--slate);font-size:1.1rem;max-width:52ch;margin:0 auto 2rem}
.skel .next{display:inline-flex;flex-direction:column;gap:.5rem;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.4rem 1.8rem;text-align:left;box-shadow:var(--shadow)}
.skel .next b{font-family:'Archivo';font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--soft)}
.skel .next span{font-weight:600;color:var(--char)}

/* ===== credentials icons (Step 2 home) ===== */
.cred-ic{width:56px;height:56px;border-radius:14px;margin:0 auto 1.1rem;display:grid;place-items:center;background:linear-gradient(145deg,var(--sky-2),var(--sky))}
.cred-ic svg{width:28px;height:28px;color:var(--ink)}
.cred-t{font-family:'Archivo';font-weight:800;font-size:1.08rem;color:var(--char)}
.cred-n{font-family:'Archivo';font-weight:900;font-size:1.6rem;color:var(--sky-deep);margin:.3rem 0 .5rem}
.cred-d{font-size:.92rem;color:var(--slate);line-height:1.5}

/* ===== badge credential cards (Step 2 update) ===== */
.cred-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;margin-top:3rem;max-width:980px;margin-left:auto;margin-right:auto}
.cred-card{text-align:center;padding:1.8rem 1.6rem 2rem;border:1px solid var(--line);border-radius:var(--r);background:#fff;display:flex;flex-direction:column;align-items:center;transition:transform .3s,box-shadow .3s}
.cred-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.cred-badge{width:148px;height:148px;object-fit:contain;margin-bottom:.6rem}
.cred-card .cred-d{font-size:.96rem;color:var(--slate);line-height:1.5;max-width:30ch}
@media(max-width:760px){.cred-grid{grid-template-columns:1fr;max-width:380px}}

/* ===== services page (Step 3) ===== */
.svc-grid.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:980px){.svc-grid.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.svc-grid.cols-4{grid-template-columns:1fr}}
.svc .tagline{display:inline-block;margin-top:.9rem;font-family:'Archivo';font-weight:700;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--sky-deep)}
.callout{display:flex;gap:1.9rem;align-items:flex-start;background:linear-gradient(120deg,var(--sky-ink),#0c4a66);color:#fff;border-radius:22px;padding:clamp(1.9rem,4vw,3rem);box-shadow:var(--shadow);position:relative;overflow:hidden}
.callout::after{content:"";position:absolute;width:360px;height:360px;background:radial-gradient(circle,var(--sky) 0%,transparent 70%);opacity:.18;top:-130px;right:-90px;pointer-events:none}
.callout-ic{flex:0 0 auto;width:66px;height:66px;border-radius:16px;background:var(--sky);display:grid;place-items:center;position:relative;z-index:1}
.callout-ic svg{width:34px;height:34px;color:var(--sky-ink)}
.callout .ctext{position:relative;z-index:1}
.callout .eyebrow{color:var(--sky)}
.callout h3{font-family:'Archivo';font-size:clamp(1.5rem,3.2vw,2.2rem);font-weight:800;margin:.4rem 0 .7rem;letter-spacing:-.02em}
.callout p{color:#d7e8f1;font-size:1.06rem;max-width:66ch;margin:0}
@media(max-width:640px){.callout{flex-direction:column;gap:1.2rem}}

/* ===== service area page (Step 5) ===== */
.area-list span.hq{background:var(--sky);border-color:var(--sky);color:var(--ink)}
.mapwrap{margin-top:2.8rem;border-radius:20px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.mapwrap iframe{display:block;width:100%;height:540px;border:0}
@media(max-width:720px){.mapwrap iframe{height:420px}}
.map-note{margin-top:1rem;font-size:.88rem;color:var(--soft)}

/* ===== OUR WORK — transformation engine (Step 4) ===== */
.work-intro .shead h2 .a{color:var(--sky-deep)}

/* multi-roof switcher tabs */
.roof-tabs{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.8rem}
.roof-tab{font-family:'Archivo';font-weight:700;font-size:.92rem;color:var(--slate);background:#fff;border:1.5px solid var(--line);padding:.6rem 1.2rem;border-radius:999px;cursor:pointer;transition:.22s;display:inline-flex;align-items:center;gap:.5rem}
.roof-tab:hover{border-color:var(--sky-deep);color:var(--char)}
.roof-tab.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.roof-tab .pin{width:7px;height:7px;border-radius:50%;background:var(--sky)}
.roof-soon{font-family:'Archivo';font-weight:700;font-size:.82rem;color:var(--soft);align-self:center;margin-left:.3rem}

/* scroll-driven rebuild (centerpiece) */
.rebuild{position:relative;height:340vh;background:var(--ink)}
.rebuild-sticky{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;padding:0 24px}
.rebuild-ey{font-family:'Archivo';font-weight:700;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sky);margin-bottom:1rem;text-align:center}
.rebuild-frame{position:relative;width:100%;max-width:1140px;aspect-ratio:16/9;border-radius:18px;overflow:hidden;box-shadow:0 50px 110px -40px rgba(0,0,0,.85);border:1px solid rgba(255,255,255,.08);background:#000}
.rlayer{position:absolute;inset:0;opacity:0;will-change:opacity}
.rlayer img{width:100%;height:100%;object-fit:cover;will-change:transform}
.rebuild-vig{position:absolute;inset:0;z-index:4;pointer-events:none;background:linear-gradient(180deg,rgba(0,0,0,.25),transparent 26%,transparent 58%,rgba(0,0,0,.7))}
.rebuild-cap{position:absolute;left:0;right:0;bottom:0;z-index:5;padding:1.6rem 1.8rem;color:#fff}
.rebuild-cap .stp{font-family:'Archivo';font-weight:900;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sky)}
.rebuild-cap .ttl{font-family:'Archivo';font-weight:900;font-size:clamp(1.5rem,3.4vw,2.4rem);line-height:1.05;text-shadow:0 3px 18px rgba(0,0,0,.6)}
.rebuild-cap .desc{font-size:.98rem;color:#e7edf3;max-width:46ch;text-shadow:0 2px 10px rgba(0,0,0,.6);margin-top:.25rem}
.rebuild-rail{position:relative;width:100%;max-width:1140px;height:4px;border-radius:3px;background:rgba(255,255,255,.16);margin-top:1.3rem}
.rebuild-rail i{position:absolute;left:0;top:0;bottom:0;width:0;background:var(--sky);border-radius:3px}
.rebuild-rail .tick{position:absolute;top:50%;transform:translate(-50%,-50%);width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.3);border:2px solid var(--ink)}
.rebuild-rail .tick.on{background:var(--sky)}
.rebuild-hint{margin-top:1rem;font-family:'Archivo';font-weight:700;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:#9aa3ad;display:flex;align-items:center;gap:.5rem}
.rebuild-hint svg{width:16px;height:16px;animation:hintbob 1.8s ease-in-out infinite}
@keyframes hintbob{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}

/* hands-on scrubber */
.scrub-frame{position:relative;width:100%;aspect-ratio:16/9;border-radius:18px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);background:#000;margin-top:2.4rem}
.slayer{position:absolute;inset:0;opacity:0}
.slayer img{width:100%;height:100%;object-fit:cover}
.scrub-badge{position:absolute;top:14px;left:14px;z-index:6;font-family:'Archivo';font-weight:800;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:rgba(13,15,18,.62);backdrop-filter:blur(6px);padding:.4rem .8rem;border-radius:999px;border:1px solid rgba(255,255,255,.16)}
.scrub-track{position:relative;height:46px;margin:1.4rem auto 0;display:flex;align-items:center}
.scrub-line{position:absolute;left:0;right:0;height:5px;border-radius:3px;background:var(--line)}
.scrub-line i{position:absolute;left:0;top:0;bottom:0;width:0;background:var(--sky);border-radius:3px}
.scrub-thumb{position:absolute;top:50%;left:0;transform:translate(-50%,-50%);width:34px;height:34px;border-radius:50%;background:var(--sky);border:3px solid #fff;box-shadow:0 6px 18px rgba(0,0,0,.35);cursor:grab;touch-action:none;z-index:3}
.scrub-thumb:active{cursor:grabbing}
.scrub-stops{display:flex;justify-content:space-between;margin-top:.7rem}
.scrub-stops span{font-family:'Archivo';font-weight:700;font-size:.8rem;letter-spacing:.04em;color:var(--soft);cursor:pointer;transition:color .2s}
.scrub-stops span.on{color:var(--sky-deep)}

/* gallery */
.wgal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px;margin-top:2.6rem}
.wgal figure{position:relative;overflow:hidden;border-radius:14px;cursor:pointer;background:#0d0f12;margin:0}
.wgal img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.wgal figure:hover img{transform:scale(1.07)}
.wgal figcaption{position:absolute;left:0;right:0;bottom:0;padding:1rem;color:#fff;font-family:'Archivo';font-weight:700;font-size:.92rem;background:linear-gradient(0deg,rgba(13,15,18,.82),transparent);opacity:0;transform:translateY(8px);transition:.35s}
.wgal figure:hover figcaption{opacity:1;transform:none}
.wgal .g-wide{grid-column:span 2}.wgal .g-tall{grid-row:span 2}
.wlb{position:fixed;inset:0;background:rgba(8,9,11,.93);display:none;align-items:center;justify-content:center;z-index:200;padding:24px;cursor:zoom-out}
.wlb.open{display:flex}.wlb img{max-width:92vw;max-height:88vh;border-radius:10px}
@media(max-width:980px){.wgal{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){
  .rebuild{height:300vh}
  .wgal{grid-template-columns:1fr;grid-auto-rows:220px}.wgal .g-wide{grid-column:auto}
}
@media(prefers-reduced-motion:reduce){.rlayer img{transform:none!important}.rebuild-hint svg{animation:none}}

/* paired project gallery (Our Work — More shots) */
.wgal.paired{grid-template-columns:repeat(2,1fr);grid-auto-rows:auto;gap:16px}
.wgal.paired figure{aspect-ratio:16/10}
@media(max-width:760px){.wgal.paired{grid-template-columns:1fr}}

/* ===== custom North Mississippi map (Step 5 update) ===== */
.msmap{margin-top:2.8rem;background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);padding:clamp(1.2rem,3vw,2.2rem)}
.msmap-svg{width:100%;max-width:560px;height:auto;display:block;margin:0 auto}
.msmap-svg .nbr{font-family:'Archivo';font-weight:700;font-size:12px;fill:#aab2bb;letter-spacing:.18em}
.msmap-svg .stlabel{font-family:'Archivo';font-weight:700;font-size:12px;fill:#c2cad2;letter-spacing:.14em;text-anchor:middle}
.msmap-svg .northlbl{font-family:'Archivo';font-weight:900;font-size:17px;fill:var(--sky-deep);letter-spacing:.04em;text-anchor:middle}
.msmap-svg .tn{font-family:'Hanken Grotesk';font-weight:600;font-size:12.5px;fill:var(--char);paint-order:stroke;stroke:#fff;stroke-width:3.4px;stroke-linejoin:round}
.msmap-svg .tn.hq{font-family:'Archivo';font-weight:800;font-size:14px;fill:var(--ink);stroke-width:4.2px}
.msmap-legend{display:flex;gap:1.6rem;flex-wrap:wrap;justify-content:center;margin-top:1.4rem;padding-top:1.3rem;border-top:1px solid var(--line)}
.msmap-legend span{display:inline-flex;align-items:center;gap:.55rem;font-size:.9rem;color:var(--slate)}
.msmap-legend i{flex:0 0 auto}
.msmap-legend .sw{width:16px;height:16px;border-radius:4px;background:rgba(74,158,217,.22);border:2px solid var(--sky-deep)}
.msmap-legend .hqdot{width:13px;height:13px;border-radius:50%;background:#fff;border:2.5px solid var(--ink)}
.msmap-legend .tdot{width:11px;height:11px;border-radius:50%;background:var(--sky-deep);border:1.5px solid #fff;box-shadow:0 0 0 1px var(--line)}
