:root{
  --brand-orange:#ff7a00;
  --brand-orange-soft:#ffb347;
  --brand-red:#d32f2f;
  --brand-black:#0b0b0d;
  --brand-dark:#121216;
  --brand-cream:#fff8f1;
  --brand-sand:#f7f1ea;
  --brand-border:rgba(255,122,0,.16);
  --text:#17171b;
  --muted:#5b6470;
  --shadow:0 18px 50px rgba(17,17,17,.12);
  --radius:28px;
}
*{box-sizing:border-box}
html,body{overflow-x:hidden}
body{font-family:Inter,system-ui,sans-serif;color:var(--text);background:linear-gradient(180deg,#fffaf4 0%,#fff 26%,#fff7f2 100%)}
a{text-decoration:none}
img{max-width:100%;display:block}
main{position:relative;z-index:2}
.site-shell{max-width:1440px;margin:0 auto;padding-left:24px;padding-right:24px}
.container,.container-lg,.container-fluid{--bs-gutter-x:1.5rem}
.section-kicker,.overline{display:inline-flex;align-items:center;gap:10px;font-size:.8rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--brand-red)}
.section-kicker:before,.overline:before{content:"";width:34px;height:2px;border-radius:99px;background:linear-gradient(90deg,var(--brand-orange),var(--brand-red))}
.section-title{font-size:clamp(2rem,3vw,3.75rem);line-height:1.03;font-weight:900;letter-spacing:-.04em;color:#0f1013}
.lead{font-size:1.12rem;color:#323845}
.btn-brand{background:linear-gradient(135deg,var(--brand-orange),#ff5b23);border:0;color:#111;font-weight:800;box-shadow:0 14px 30px rgba(255,122,0,.26)}
.btn-brand:hover{background:linear-gradient(135deg,#ff8d24,#ff6633);color:#111;transform:translateY(-2px)}
.btn-outline-brand{border:1px solid rgba(255,122,0,.35);color:#111;background:#fff}
.btn-outline-brand:hover{background:var(--brand-black);color:#fff;border-color:var(--brand-black)}
.btn{transition:all .25s ease}
.fw-black{font-weight:900}

.site-bg-orbs{position:fixed;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.bg-orb{position:absolute;border-radius:50%;filter:blur(8px);opacity:.22;animation:floatOrb 14s ease-in-out infinite}
.orb-a{width:240px;height:240px;background:radial-gradient(circle,var(--brand-orange-soft),transparent 70%);top:4%;left:-2%}
.orb-b{width:320px;height:320px;background:radial-gradient(circle,#ffccb5,transparent 70%);top:30%;right:-8%;animation-delay:-4s}
.orb-c{width:280px;height:280px;background:radial-gradient(circle,#ffd9a7,transparent 70%);bottom:18%;left:8%;animation-delay:-6s}
.orb-d{width:220px;height:220px;background:radial-gradient(circle,#ffc9c9,transparent 70%);bottom:-3%;right:10%;animation-delay:-2s}
@keyframes floatOrb{50%{transform:translateY(-18px) translateX(10px) scale(1.05)}}

.splash-screen{position:fixed;inset:0;display:grid;place-items:center;background:linear-gradient(135deg,#0f1014,#18141a);z-index:3000;transition:opacity .7s ease,visibility .7s ease}
.splash-screen.is-hidden{opacity:0;visibility:hidden}
.splash-window{position:relative;width:min(520px,88vw);height:260px;border-radius:34px;padding:26px;background:linear-gradient(145deg,rgba(255,255,255,.12),rgba(255,255,255,.04));backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.35)}
.splash-logo img{height:76px;width:auto;position:relative;z-index:3}
.splash-copy{position:absolute;left:28px;bottom:24px;font-weight:700;color:#fff;z-index:3}
.splash-glass{position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.16),rgba(255,255,255,.02),rgba(255,255,255,.12));z-index:1}
.splash-cloth{position:absolute;top:18px;left:-180px;width:210px;height:210px;border-radius:48px;background:linear-gradient(135deg,#fff1c7,#ffdcb5);filter:drop-shadow(0 18px 30px rgba(0,0,0,.25));transform:rotate(-12deg);animation:wipeAcross 1.8s ease-in-out infinite;z-index:2}
.splash-cloth:before{content:"";position:absolute;inset:16px;border-radius:36px;background:linear-gradient(135deg,#fff,#ffd493)}
@keyframes wipeAcross{0%{left:-210px;top:40px}50%{left:180px;top:18px}100%{left:530px;top:50px}}

.header-topbar{background:#111;color:#fff;padding:10px 0;font-size:.92rem}
.topbar-note{color:rgba(255,255,255,.72);font-weight:600}
.topbar-actions a{color:#fff;opacity:.88}
.navbar-clean{background:rgba(255,252,248,.95);backdrop-filter:blur(12px);box-shadow:0 10px 30px rgba(17,17,17,.05);padding:16px 0;border-bottom:1px solid rgba(255,122,0,.08)}
.brand-logo{width:62px;height:62px;object-fit:contain;border-radius:20px;background:#fff3e9;padding:10px;box-shadow:0 10px 30px rgba(255,122,0,.12)}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-text strong{font-size:1.24rem;color:#15161a;font-weight:800}
.brand-text small{margin-top:6px;font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--brand-orange);font-weight:900}
.navbar-toggler-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%2817,17,17,0.88%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2.4' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")}
.navbar-clean .nav-link{font-weight:700;color:#191a1f;padding:.95rem 1rem!important;border-radius:999px;transition:all .22s ease}
.navbar-clean .nav-link:hover,.navbar-clean .nav-link.active{background:#fff0e1;color:var(--brand-orange)}
.mega-dropdown,.location-dropdown{min-width:min(960px,90vw);border:1px solid rgba(255,122,0,.14);border-radius:26px;box-shadow:var(--shadow);background:#fff}
.location-dropdown{min-width:min(700px,90vw)}
.dropdown-item{padding:.62rem .8rem;border-radius:16px;font-weight:600;color:#303640;white-space:normal}
.dropdown-item:hover{background:#fff4ea;color:#111}
.mega-title{font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;color:var(--brand-red);font-weight:900;margin-bottom:.6rem}
.header-cta .btn{font-weight:800}
.offcanvas{max-width:360px}
.offcanvas .dropdown-menu{position:static!important;transform:none!important;border:0;box-shadow:none;padding:0!important}

.hero-nextgen{position:relative;overflow:hidden;border-radius:40px;background:linear-gradient(135deg,#111319 0%,#161821 35%,#261313 100%);box-shadow:0 30px 80px rgba(17,17,17,.16)}
.hero-nextgen:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(255,122,0,.35),transparent 30%),radial-gradient(circle at bottom left,rgba(211,47,47,.18),transparent 26%)}
.hero-copy{position:relative;z-index:2;padding:clamp(34px,4vw,72px)}
.eyebrow-pill{display:inline-flex;align-items:center;padding:14px 20px;border-radius:999px;font-weight:800;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:#fff;margin-bottom:22px}
.hero-nextgen h1{font-size:clamp(2.8rem,5.4vw,5.8rem);line-height:.95;letter-spacing:-.06em;color:#fff;font-weight:900;margin:0 0 18px}
.hero-nextgen h2{font-size:clamp(1.25rem,1.7vw,1.7rem);line-height:1.2;color:#fff8ef;font-weight:700;margin:0 0 18px}
.hero-nextgen p{font-size:1.06rem;line-height:1.85;color:rgba(255,255,255,.84);max-width:720px}
.hero-buttons{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px;margin-bottom:22px}
.btn-hero-outline{font-weight:800;border-radius:999px;padding-left:28px;padding-right:28px}
.hero-visual-panel{position:relative;min-height:700px;height:100%;padding:32px}
.hero-art-glow{position:absolute;inset:auto 16% 20% auto;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(255,122,0,.42),transparent 68%);filter:blur(15px)}
.hero-visual-main{position:absolute;inset:0}
.hero-visual-main img{width:100%;height:100%;object-fit:cover;opacity:.45}
.hero-float-card{position:absolute;overflow:hidden;border-radius:28px;border:1px solid rgba(255,255,255,.22);box-shadow:0 18px 50px rgba(0,0,0,.22);animation:heroFloat 7s ease-in-out infinite;background:#fff}
.hero-card-top{top:60px;right:40px;width:280px;height:200px;transform:rotate(7deg)}
.hero-card-bottom{bottom:54px;left:34px;width:240px;height:170px;transform:rotate(-6deg);animation-delay:-2s}
.hero-float-card img{width:100%;height:100%;object-fit:cover}
.hero-badge{position:absolute;display:inline-flex;align-items:center;gap:10px;padding:14px 18px;border-radius:999px;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);color:#fff;font-weight:700}
.hero-badge-top{left:34px;top:44px}
.hero-badge-bottom{right:46px;bottom:32px}
.hero-bubble{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.25),rgba(255,255,255,.02));backdrop-filter:blur(8px);animation:floatOrb 8s ease-in-out infinite}
.bubble-one{width:110px;height:110px;left:52%;top:22%}
.bubble-two{width:76px;height:76px;right:16%;bottom:22%;animation-delay:-2s}
.glass-mini-card{height:100%;padding:20px;border-radius:24px;background:rgba(255,255,255,.07);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.13);color:#fff;box-shadow:0 12px 30px rgba(0,0,0,.12)}
.glass-mini-card strong{display:block;font-size:1.08rem;margin-bottom:10px}
.glass-mini-card span{display:block;color:rgba(255,255,255,.82);line-height:1.65}
@keyframes heroFloat{50%{transform:translateY(-10px) rotate(4deg)}}

.metric-card,.info-card,.mini-card,.quote-panel,.service-card,.location-card,.form-shell,.content-panel,.legal-card{position:relative;background:#fff;border:1px solid rgba(255,122,0,.12);border-radius:28px;box-shadow:var(--shadow);transition:transform .3s ease,box-shadow .3s ease}
.metric-card,.info-card,.mini-card,.quote-panel,.content-panel,.legal-card{padding:30px}
.metric-number{font-size:2rem;line-height:1;font-weight:900;color:#111}
.metric-label{color:var(--muted);line-height:1.7}
.icon-badge{width:62px;height:62px;border-radius:20px;background:linear-gradient(135deg,#fff2df,#ffe2d5);display:grid;place-items:center;font-size:1.3rem;font-weight:900;color:var(--brand-orange)}
.feature-list{padding-left:0;list-style:none;display:grid;gap:14px}
.feature-list li{position:relative;padding-left:28px;color:#343b46;line-height:1.7}
.feature-list li:before{content:"";position:absolute;left:0;top:.68em;width:12px;height:12px;border-radius:50%;background:linear-gradient(135deg,var(--brand-orange),var(--brand-red));box-shadow:0 0 0 5px rgba(255,122,0,.12)}
.page-hero{overflow:hidden;border-radius:34px;background:linear-gradient(135deg,#fff 0%,#fff6ef 100%);border:1px solid rgba(255,122,0,.14);box-shadow:var(--shadow)}
.page-hero .content{padding:42px}
.page-hero-visual{height:100%}
.hero-img{width:100%;height:100%;min-height:430px;object-fit:cover}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:22px}

.service-card img,.location-card img{width:100%;height:240px;object-fit:cover;border-radius:28px 28px 0 0}
.service-card .p-4,.location-card .p-4{padding:28px!important}
.service-card h3,.location-card h3{font-weight:800;color:#15161b}
.service-card p,.location-card p,.info-card p,.quote-panel p,.mini-card p,.content-panel p,.legal-card p{color:var(--muted);line-height:1.78}
.location-grid,.service-grid,.legal-grid{display:grid;gap:24px}
.location-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.location-card{overflow:hidden}
.location-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 18px;padding:0;list-style:none;margin:18px 0 0}
.location-list li{color:#37404c;font-weight:600}
.location-list li:before{content:'•';color:var(--brand-orange);margin-right:8px}
.form-shell{background:linear-gradient(180deg,#fff,#fff7ef)}
.booking-step{display:inline-flex;padding:11px 16px;border-radius:999px;background:#fff1e6;color:#111;font-weight:900;letter-spacing:.02em}
.service-check{padding:18px 18px;border:1px solid rgba(255,122,0,.14);border-radius:20px;background:#fff;transition:all .25s ease;cursor:pointer}
.service-check:hover{transform:translateY(-2px);border-color:rgba(255,122,0,.34);box-shadow:0 12px 28px rgba(0,0,0,.06)}
.project-toggle .btn{min-width:160px}
.status-pill{display:inline-flex;padding:10px 16px;border-radius:999px;font-weight:800}
.status-new{background:#fff1e6;color:var(--brand-orange)}
.status-contact{background:#ffe6e6;color:var(--brand-red)}
.status-booked{background:#eef6ff;color:#245eb8}
.status-completed{background:#e9fbef;color:#14803d}
.footer-cta{display:flex;justify-content:space-between;gap:28px;align-items:center;padding:40px;border-radius:34px;background:linear-gradient(135deg,#111319,#1d1013 45%,#52201b 100%);margin-bottom:34px;box-shadow:0 30px 70px rgba(0,0,0,.18)}
.footer-cta h2{margin:12px 0 14px;color:#fff;font-size:clamp(1.9rem,2.6vw,3rem);line-height:1.03;font-weight:900}
.footer-cta p{margin:0;color:rgba(255,255,255,.76);max-width:760px;line-height:1.8}
.site-footer{position:relative;padding:42px 0 34px;background:#0f1013;color:#fff;overflow:hidden;margin-top:40px}
.site-footer:before{content:"";position:absolute;inset:auto -8% -40px auto;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(255,122,0,.24),transparent 68%)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:24px}
.footer-brand-logo{width:260px;max-width:100%;margin-bottom:16px}
.footer-title{font-size:1rem;font-weight:900;margin-bottom:16px;color:#fff}
.footer-links li{margin-bottom:10px}
.footer-links a,.footer-contact-list a,.footer-contact-list span,.footer-copy{color:rgba(255,255,255,.74);line-height:1.85}
.footer-links a:hover,.footer-contact-list a:hover{color:#fff}
.footer-contact-list{display:grid;gap:6px}
.footer-bottom{display:flex;justify-content:space-between;gap:12px;border-top:1px solid rgba(255,255,255,.1);margin-top:28px;padding-top:18px;color:rgba(255,255,255,.62);font-size:.93rem}
.content-slab{padding:34px;border-radius:28px;background:#fff;border:1px solid rgba(255,122,0,.14);box-shadow:var(--shadow)}
.city-chip-wrap{display:flex;flex-wrap:wrap;gap:12px}
.city-chip{padding:11px 16px;border-radius:999px;background:#fff1e6;color:#111;font-weight:800}
.location-hero-img{height:100%;min-height:560px;object-fit:cover}
.location-section-title{font-size:1.55rem;font-weight:900;color:#111;margin-bottom:14px}

@media (max-width:1199px){
  .mega-dropdown,.location-dropdown{min-width:unset}
  .footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .footer-cta{flex-direction:column;align-items:flex-start}
  .hero-visual-panel{min-height:520px}
}
@media (max-width:991px){
  .topbar-note,.topbar-actions{font-size:.82rem}
  .hero-nextgen{border-radius:28px}
  .hero-copy{padding:28px}
  .hero-visual-panel{min-height:420px;padding:18px}
  .hero-card-top{width:190px;height:140px;right:18px;top:26px}
  .hero-card-bottom{width:160px;height:118px;left:18px;bottom:18px}
  .hero-badge{font-size:.84rem;padding:10px 14px}
  .page-hero .content{padding:28px}
  .hero-img{min-height:280px}
  .location-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:767px){
  .site-shell{padding-left:16px;padding-right:16px}
  .header-topbar{display:none}
  .brand-logo{width:52px;height:52px;border-radius:16px}
  .brand-text strong{font-size:1.05rem}
  .brand-text small{font-size:.7rem}
  .hero-nextgen h1{font-size:2.45rem}
  .hero-nextgen h2{font-size:1.08rem}
  .hero-buttons{flex-direction:column;align-items:stretch}
  .hero-mini-cards .col-md-4{width:100%}
  .location-grid,.footer-grid{grid-template-columns:1fr}
  .location-list{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column}
  .splash-window{height:220px}
  .splash-cloth{width:160px;height:160px}
}
