
:root{
  --blue:#2f6eb2;
  --orange:#e47828;
  --white:#ffffff;
  --ink:#18324b;
  --text:#3b4754;
  --muted:#6a7683;
  --bg:#f5f8fc;
  --card:#ffffff;
  --shadow:0 18px 40px rgba(24,50,75,.12);
  --radius:22px;
  --radius-sm:14px;
  --max:1180px;
  --header-h:108px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,Arial,sans-serif;color:var(--text);background:#fff;line-height:1.6}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{width:min(calc(100% - 40px),var(--max));margin:0 auto}
.section{padding:88px 0}
.section-alt{background:linear-gradient(180deg,#f7fbff, #eef5fc)}
.center{text-align:center;max-width:820px;margin:0 auto 34px}
.section-tag,.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;background:rgba(47,110,178,.1);color:var(--blue);font-weight:700;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase}
.section-tag.light{background:rgba(255,255,255,.15);color:#fff}
h1,h2,h3{color:var(--ink);margin:0 0 16px;line-height:1.12}
h1{font-size:clamp(2.5rem,5vw,4.5rem);color:#fff;max-width:12ch}
h2{font-size:clamp(2rem,3vw,3rem)}
h3{font-size:1.2rem}
p{margin:0 0 16px}
ul{padding:0;margin:0;list-style:none}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;border-radius:999px;font-weight:700;transition:.28s ease;cursor:pointer;border:none}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 14px 24px rgba(228,120,40,.28)}
.btn-primary:hover{transform:translateY(-2px) scale(1.01);box-shadow:0 18px 28px rgba(228,120,40,.35)}
.btn-secondary{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.5);backdrop-filter:blur(8px)}
.btn-secondary:hover{background:#fff;color:var(--blue)}
.btn-block{width:100%}
.btn-glow{animation:pulseGlow 2.2s infinite}
@keyframes pulseGlow{0%,100%{box-shadow:0 14px 24px rgba(228,120,40,.28)}50%{box-shadow:0 18px 34px rgba(228,120,40,.5)}}
.topbar{background:var(--blue);color:#fff;font-weight:700;font-size:.95rem}
.topbar-inner{display:flex;justify-content:space-between;gap:20px;padding:10px 0}
.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);box-shadow:0 8px 26px rgba(24,50,75,.08);transition:.28s ease}
.site-header.shrink{--header-h:84px}
.nav-wrap{height:var(--header-h);display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:28px;transition:.28s ease}
.brand img{height:112px;transition:.28s ease;filter:drop-shadow(0 6px 18px rgba(47,110,178,.18))}
.site-header.shrink .brand img{height:84px}
.site-nav{display:flex;justify-content:center;gap:28px;font-weight:700;color:var(--blue)}
.site-nav a{position:relative}
.site-nav a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:3px;border-radius:3px;background:var(--orange);transition:.25s ease}
.site-nav a:hover::after,.site-nav a:focus-visible::after{width:100%}
.header-actions{display:flex;align-items:center;gap:14px}
.phone-link{color:var(--blue);font-weight:700}
.menu-toggle{display:none;background:none;border:none;font-size:2rem;color:var(--blue)}
.hero{position:relative;min-height:calc(100vh - var(--header-h) - 42px);display:grid;place-items:center;overflow:hidden}
.hero-bg-slides,.hero-slide,.hero-overlay{position:absolute;inset:0}
.hero-slide{background-size:cover;background-position:center;opacity:0;transform:scale(1.05);transition:opacity 1s ease, transform 6s ease}
.hero-slide.is-active{opacity:1;transform:scale(1)}
.hero-overlay{background:linear-gradient(90deg,rgba(11,25,38,.84),rgba(15,37,57,.56) 45%,rgba(15,37,57,.35))}
.hero-content{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .7fr;gap:42px;align-items:center;padding:80px 0}
.hero-copy p{max-width:60ch;color:rgba(255,255,255,.9);font-size:1.06rem}
.eyebrow.text-white{color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.25)}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin:28px 0}
.hero-points{display:flex;flex-wrap:wrap;gap:12px}
.hero-points li a{display:inline-flex;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.24);color:#fff;font-weight:700;backdrop-filter:blur(8px);transition:.25s ease}
.hero-points li a:hover{background:#fff;color:var(--blue);transform:translateY(-2px)}
.hero-card{background:rgba(255,255,255,.95);backdrop-filter:blur(8px);padding:28px;border-radius:var(--radius);box-shadow:var(--shadow)}
.floating-card{animation:floaty 4.5s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero-card h2{font-size:1.75rem}
.mini-steps{display:grid;gap:16px;margin:18px 0 24px}
.mini-steps div{display:grid;grid-template-columns:52px 1fr;gap:14px;align-items:center;padding:14px;border-radius:18px;background:#f7fbff}
.mini-steps strong{display:grid;place-items:center;width:52px;height:52px;background:var(--blue);color:#fff;border-radius:50%;font-size:1.2rem}
.trust-strip{position:relative;z-index:3;margin-top:-44px}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.trust-grid a{background:#fff;border-radius:20px;padding:22px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:6px;transition:.25s ease}
.trust-grid a:hover{transform:translateY(-6px)}
.trust-grid strong{color:var(--blue);font-size:1.02rem}
.trust-grid span{color:var(--muted);font-size:.95rem}
.split-layout{display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:center}
.intro-feature-card,.why-media,.map-card{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.intro-feature-card img,.why-media img{width:100%;height:100%;object-fit:cover;min-height:420px}
.feature-badge{position:absolute;left:22px;bottom:22px;background:#fff;color:var(--ink);padding:12px 16px;border-radius:999px;font-weight:700;box-shadow:var(--shadow)}
.text-link{font-weight:800;color:var(--blue)}
.service-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
.service-card{background:#fff;padding:28px 24px;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid rgba(47,110,178,.08)}
.service-card.featured{background:linear-gradient(180deg,rgba(47,110,178,.06), #fff)}
.service-icon{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;background:rgba(228,120,40,.12);color:var(--orange);font-size:1.4rem;margin-bottom:16px}
.check-list{display:grid;gap:12px;margin:0 0 18px}
.check-list li{position:relative;padding-left:34px}
.check-list li::before{content:"✓";position:absolute;left:0;top:0;width:24px;height:24px;display:grid;place-items:center;background:rgba(47,110,178,.1);border-radius:50%;color:var(--blue);font-weight:800}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:18px}
.gallery-item{border-radius:22px;overflow:hidden;box-shadow:var(--shadow)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.gallery-item.tall{grid-row:span 2}
.gallery-item.wide{grid-column:span 2}
.hover-zoom:hover img{transform:scale(1.06)}
.reviews .review-slider{position:relative;max-width:860px;margin:0 auto;min-height:300px}
.review-card{position:absolute;inset:0;opacity:0;transform:translateX(30px);transition:.35s ease;background:#fff;border-radius:26px;padding:38px;box-shadow:var(--shadow);text-align:center}
.review-card.is-active{opacity:1;transform:translateX(0);position:relative}
.stars{color:var(--orange);font-size:1.25rem;letter-spacing:.18em;margin-bottom:12px}
.slider-controls{display:flex;justify-content:center;gap:12px;margin-top:18px}
.slider-btn{width:48px;height:48px;border-radius:50%;border:none;background:var(--blue);color:#fff;font-size:1.7rem;cursor:pointer;transition:.2s ease}
.slider-btn:hover{background:var(--orange);transform:translateY(-2px)}
.area-list-wrap{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:24px}
.area-list{display:grid;gap:10px}
.area-list li{padding:12px 14px;border-radius:16px;background:#f5f8fc;font-weight:600}
#serviceMap{height:440px;width:100%}
.map-note{padding:14px 18px;background:#fff;color:var(--muted);font-size:.95rem}
.seo-block p{max-width:900px;margin:0 auto;text-align:center;font-size:1.05rem}
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.process-card{background:#fff;border-radius:24px;padding:28px;box-shadow:var(--shadow)}
.process-card span{display:inline-grid;place-items:center;width:58px;height:58px;border-radius:18px;background:var(--orange);color:#fff;font-size:1.1rem;font-weight:800;margin-bottom:14px}
.quote{background:linear-gradient(135deg,var(--blue),#204f85);color:#fff}
.quote h2,.quote p{color:#fff}
.quote-wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:36px;align-items:start}
.quote-form{background:rgba(255,255,255,.08);padding:24px;border-radius:var(--radius);backdrop-filter:blur(8px)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.quote-form input,.quote-form select,.quote-form textarea{width:100%;padding:15px 16px;border:none;border-radius:16px;font:inherit;margin-bottom:14px}
.form-note{font-size:.9rem;color:rgba(255,255,255,.85)}
.site-footer{padding:54px 0;background:#0f2031;color:rgba(255,255,255,.82)}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:26px}
.footer-grid h3{color:#fff;font-size:1rem}
.footer-grid li{margin-bottom:8px}
.footer-grid a:hover{color:#fff}
.footer-logo{height:72px;margin-bottom:14px;filter:brightness(0) invert(1)}
.floating-cta{position:fixed;right:20px;bottom:20px;z-index:1200}
.reveal,.reveal-stagger>*{opacity:0;transform:translateY(28px);transition:.7s ease}
.reveal.visible,.reveal-stagger>*.visible{opacity:1;transform:none}
.reveal-stagger>*:nth-child(2){transition-delay:.08s}.reveal-stagger>*:nth-child(3){transition-delay:.16s}.reveal-stagger>*:nth-child(4){transition-delay:.24s}.reveal-stagger>*:nth-child(5){transition-delay:.32s}
.hover-lift{transition:.28s ease}.hover-lift:hover{transform:translateY(-8px)}
@media (max-width: 1080px){
  .site-nav{gap:18px;font-size:.95rem}
  .service-grid{grid-template-columns:repeat(3,1fr)}
  .hero-content,.quote-wrap,.split-layout{grid-template-columns:1fr}
  .hero-copy h1{max-width:unset}
}
@media (max-width: 820px){
  .topbar-inner{flex-direction:column;align-items:center;text-align:center;padding:8px 0;gap:4px}
  .menu-toggle{display:block;justify-self:end}
  .site-nav{position:absolute;left:20px;right:20px;top:100%;background:#fff;border-radius:20px;box-shadow:var(--shadow);padding:18px;display:none;flex-direction:column;align-items:flex-start}
  .site-nav.open{display:flex}
  .header-actions{display:none}
  .nav-wrap{grid-template-columns:auto auto;justify-content:space-between;height:auto;padding:12px 0}
  .brand img{height:92px}
  .site-header.shrink .brand img{height:74px}
  .trust-grid,.process-grid,.service-grid,.gallery-grid,.footer-grid,.area-list-wrap,.form-row{grid-template-columns:1fr}
  .gallery-item.tall,.gallery-item.wide{grid-column:auto;grid-row:auto}
  .gallery-grid{grid-auto-rows:230px}
  .review-card{padding:28px}
  .floating-cta{left:16px;right:16px;bottom:16px}
}

/* Services Page V2 */
.services-page-title{color:var(--ink);max-width:none}
.services-page-intro{max-width:740px;margin:0 auto 22px}
.services-hero{padding-bottom:48px}
.services-banner{margin-top:38px}
.services-banner-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:18px}
.services-banner-photo,.service-detail-media,.project-strip-item{border-radius:24px;overflow:hidden;box-shadow:var(--shadow);background:#fff}
.services-banner-photo img,.service-detail-media img,.project-strip-item img{width:100%;height:100%;object-fit:cover}
.services-banner-photo{min-height:220px}
.services-banner-photo.wide{min-height:460px}
.services-quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.quick-service-card{background:#fff;padding:28px 24px;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid rgba(47,110,178,.08)}
.service-detail-stack{display:grid;gap:34px}
.service-detail{padding:26px 0}
.service-detail.reverse .service-detail-copy{order:2}
.service-detail.reverse .service-detail-media{order:1}
.service-detail-copy p{max-width:60ch}
.service-detail-media{min-height:420px}
.service-detail-media.collage-two{display:grid;grid-template-columns:1fr;grid-template-rows:1fr 1fr;gap:10px;padding:10px;background:#fff}
.service-detail-media.collage-two img{border-radius:18px}
.project-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.project-strip-item{min-height:220px}
.quote-checks li::before{background:rgba(255,255,255,.2);color:#fff}
@media (max-width:1080px){
  .services-banner-grid{grid-template-columns:1fr 1fr}
  .services-banner-photo.wide{grid-column:1 / -1;min-height:320px}
  .services-quick-grid,.project-strip{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:820px){
  .services-banner-grid,.services-quick-grid,.project-strip{grid-template-columns:1fr}
  .services-banner-photo,.services-banner-photo.wide,.service-detail-media{min-height:240px}
  .service-detail.reverse .service-detail-copy,.service-detail.reverse .service-detail-media{order:initial}
}

/* Services Page V3 */
.section-compact{padding:56px 0}
.compact-intro{max-width:860px;margin:0 auto 28px}
.compact-intro.narrow{max-width:720px}
.boxed-panel{background:#fff;border:1px solid rgba(47,110,178,.08);border-radius:28px;box-shadow:var(--shadow);padding:28px}
.services-hero-v3{padding-bottom:22px}
.compact-banner{display:grid;grid-template-columns:1fr 1.2fr;gap:22px;align-items:stretch;margin-top:28px}
.compact-banner-copy h2{font-size:2rem;margin-bottom:10px}
.compact-banner-photo{border-radius:28px;overflow:hidden;box-shadow:var(--shadow);min-height:320px;background:#fff}
.compact-banner-photo img{width:100%;height:100%;object-fit:cover}
.mini-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.mini-tags span{display:inline-flex;padding:10px 14px;border-radius:999px;background:#f5f8fc;color:var(--blue);font-weight:700}
.compact-service-grid{gap:18px}
.service-card-grid-v3{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.service-box{background:#fff;border:1px solid rgba(47,110,178,.08);border-radius:30px;overflow:hidden;box-shadow:var(--shadow)}
.service-box-photo{height:240px;background:#f4f7fb}
.service-box-photo img{width:100%;height:100%;object-fit:cover}
.service-box-body{padding:24px}
.service-box-body h3{font-size:1.5rem;margin-bottom:10px}
.compact-checks{gap:10px;margin:0 0 20px}
.compact-checks li{font-size:.96rem}
.compact-project-strip{grid-template-columns:repeat(4,1fr);gap:16px}
.compact-project-strip .project-strip-item{min-height:190px;border-radius:22px}
.compact-why{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:center}
.compact-why-photo img{min-height:320px}
.compact-process-grid .process-card{padding:24px}
@media (max-width:1080px){.compact-banner,.service-card-grid-v3,.compact-why{grid-template-columns:1fr}.compact-project-strip{grid-template-columns:repeat(2,1fr)}}
@media (max-width:820px){.section-compact{padding:44px 0}.compact-banner-photo{min-height:240px}.service-box-photo{height:210px}.compact-project-strip{grid-template-columns:1fr}}



/* Services Page V4 */
.compact-banner-copy.boxed-panel{padding:24px 28px 24px}
.compact-banner-copy p{margin-bottom:16px;max-width:58ch}
.mini-tags-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px}
.mini-tags-grid a{display:flex;align-items:center;justify-content:center;min-height:68px;padding:16px 18px;border-radius:22px;background:linear-gradient(180deg,#f6f8fc,#eef3fa);border:1px solid rgba(47,110,178,.12);color:var(--blue);font-weight:800;font-size:1.08rem;box-shadow:0 10px 22px rgba(15,32,49,.06);transition:.22s ease;text-align:center}
.mini-tags-grid a:hover{background:var(--blue);color:#fff;transform:translateY(-4px);box-shadow:0 16px 30px rgba(47,110,178,.22)}
.mini-tags-grid a:focus-visible{outline:3px solid rgba(228,120,40,.35);outline-offset:2px}
@media (max-width:820px){.mini-tags-grid{grid-template-columns:1fr}.compact-banner-copy.boxed-panel{padding:22px}}


/* About Page V1 */

.about-hero{padding-top:64px;padding-bottom:54px}
.about-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:24px;align-items:stretch}
.about-hero-copy{display:flex;flex-direction:column;justify-content:center}
.about-hero-copy h1{font-size:clamp(2.3rem,4.2vw,3.8rem);color:var(--ink);max-width:none}
.about-hero-copy .lead{font-size:1.08rem;color:var(--ink)}
.about-hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin:8px 0 16px}
.about-secondary-btn{background:#eef4fb;color:var(--blue);border:1px solid rgba(47,110,178,.15)}
.about-secondary-btn:hover{background:var(--blue);color:#fff}
.about-mini-points{display:grid;gap:10px;margin-top:6px}
.about-mini-points li{padding:12px 14px;border-radius:16px;background:#f5f8fc;font-weight:700;color:var(--ink)}
.about-hero-media img{min-height:100%;object-fit:cover}
.about-value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.about-value-card{background:#fff;padding:28px;border-radius:26px;box-shadow:var(--shadow);border:1px solid rgba(47,110,178,.08)}
.about-story-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:24px;align-items:stretch}
.about-story-stack{display:grid;gap:18px}
.about-story-photo{min-height:220px}
.about-story-copy{height:100%}
.about-areas-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.about-area-list{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:16px}
.about-area-list li{padding:12px 14px;border-radius:16px;background:#f5f8fc;font-weight:700;color:var(--ink)}
.area-highlight-copy{display:flex;flex-direction:column;justify-content:center}
@media (max-width:1080px){.about-hero-grid,.about-story-grid,.about-areas-grid{grid-template-columns:1fr}.about-value-grid{grid-template-columns:1fr}.about-area-list{grid-template-columns:repeat(2,1fr)}}
@media (max-width:820px){.about-hero{padding-top:42px}.about-area-list{grid-template-columns:1fr}}


/* About Page V2 */
.about-story-copy-v2{padding:22px 26px;align-self:start}
.about-story-copy-v2 p:last-child{margin-bottom:0}
.about-gallery-strip{grid-template-columns:repeat(4,1fr);gap:14px}
.about-gallery-card{min-height:150px;border-radius:18px}
.about-gallery-card img{height:150px;object-fit:cover}
@media (max-width:1080px){.about-gallery-strip{grid-template-columns:repeat(2,1fr)}}
@media (max-width:820px){.about-gallery-strip{grid-template-columns:1fr}.about-gallery-card,.about-gallery-card img{height:200px;min-height:200px}}


/* About Page V3 */
.about-story-grid-single{grid-template-columns:1fr;max-width:860px;margin:0 auto}
.about-story-grid-single .about-story-copy-v2{padding:22px 26px 18px}
.about-story-grid-single .about-story-copy-v2 p:last-child{margin-bottom:0}


/* Contact Page V2 */

.contact-page-title{color:var(--ink);max-width:none}
.contact-hero{padding-top:60px;padding-bottom:54px}
.contact-hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:24px;align-items:stretch}
.contact-hero-copy{display:flex;flex-direction:column;justify-content:center}
.contact-hero-copy .lead{font-size:1.08rem;color:var(--ink);max-width:60ch}
.contact-hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin:12px 0 18px}
.contact-mini-points{display:grid;gap:10px;margin-top:6px}
.contact-mini-points li{padding:12px 14px;border-radius:16px;background:#f5f8fc;font-weight:700;color:var(--ink)}
.contact-hero-media img{min-height:100%;object-fit:cover}
.contact-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.contact-info-card{background:#fff;padding:28px;border-radius:26px;box-shadow:var(--shadow);border:1px solid rgba(47,110,178,.08)}
.contact-form-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:26px;align-items:start}
.contact-side-stack{display:grid;gap:18px}
.contact-support-card{padding:28px}
.contact-check-list{margin:0}
.contact-photo-strip{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.contact-photo-strip .project-strip-item{min-height:180px;border-radius:22px}
.contact-form-card{background:linear-gradient(135deg,var(--blue),#204f85);box-shadow:var(--shadow);border-radius:28px;padding:28px}
.contact-form-card h2{color:#fff;margin-bottom:8px}
.form-intro{margin-bottom:18px;color:rgba(255,255,255,.92)}
.contact-map-frame{overflow:hidden}
#serviceMap{width:100%;height:420px}
@media (max-width:1080px){
  .contact-hero-grid,.contact-form-grid{grid-template-columns:1fr}
  .contact-card-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:820px){
  .contact-hero{padding-top:42px}
  .contact-card-grid,.contact-photo-strip{grid-template-columns:1fr}
}
