/* ============================================
   MOLDPAPI.COM — Redesigned Stylesheet
   Belfor-Inspired Bold Corporate Theme
   ============================================ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --red:#dc2626;
  --red-dark:#b91c1c;
  --red-darker:#991b1b;
  --red-light:#f87171;
  --red-pale:#fef2f2;
  --dark:#0a0a0a;
  --dark2:#111111;
  --dark3:#1a1a1a;
  --charcoal:#2d2d2d;
  --white:#ffffff;
  --off-white:#f5f5f5;
  --gray-100:#f3f4f6;
  --gray-200:#e5e7eb;
  --gray-300:#d1d5db;
  --gray-400:#9ca3af;
  --gray-500:#6b7280;
  --gray-600:#4b5563;
  --gray-700:#374151;
  --gray-800:#1f2937;
  --gray-900:#111827;
  --font:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --max-w:1320px;
  --shadow-sm:0 1px 2px rgba(0,0,0,0.06);
  --shadow:0 4px 6px -1px rgba(0,0,0,0.1);
  --shadow-lg:0 10px 25px -5px rgba(0,0,0,0.12);
  --shadow-xl:0 25px 50px -12px rgba(0,0,0,0.18);
  --radius:0px;
}
html{scroll-behavior:smooth}
body{font-family:var(--font);font-weight:500;background:var(--white);color:var(--gray-800);line-height:1.4;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

/* === UTILITY === */
.container{max-width:var(--max-w);margin:0 auto;padding:0 2.5rem}
.section-pad{padding:5rem 0}
.bg-off-white{background:var(--off-white)}
.bg-dark{background:var(--dark);color:var(--white)}

/* === TOP UTILITY BAR (Belfor-style) === */
.top-bar{background:var(--gray-200);border-bottom:1px solid var(--gray-300);font-size:0.72rem;padding:0.15rem 0}
.top-bar-inner{display:flex;justify-content:space-between;align-items:center}
.top-bar-left{display:flex;gap:1.5rem;align-items:center;padding-left:300px}
.top-bar-left a{color:var(--gray-600);font-weight:600;letter-spacing:0.5px;text-transform:uppercase;transition:color 0.3s}
.top-bar-left a:hover{color:var(--red)}
.top-bar-right{display:flex;gap:0.5rem;align-items:center}
.top-bar-right span{color:var(--gray-500);font-weight:500}
.top-bar-search{display:flex;align-items:center;gap:0.4rem;color:var(--gray-600);font-weight:600;letter-spacing:0.5px;text-transform:uppercase;cursor:pointer;transition:color 0.3s}
.top-bar-search:hover{color:var(--red)}
.top-bar-search svg{width:16px;height:16px;stroke:currentColor;stroke-width:2;fill:none}
.top-bar-contact{color:var(--gray-600);font-weight:600;letter-spacing:0.3px;transition:color 0.3s;display:inline-flex;align-items:center}
.top-bar-contact:hover{color:var(--red)}
.top-bar-social{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;border:1px solid var(--gray-300);transition:all 0.3s}
.top-bar-social:hover{background:var(--red);border-color:var(--red)}
.top-bar-social svg{width:12px;height:12px;fill:var(--gray-500);stroke:none;transition:fill 0.3s}
.top-bar-social:hover svg{fill:var(--white)}
.top-bar-contact{color:var(--gray-600);font-weight:600;letter-spacing:0.3px;transition:color 0.3s;display:inline-flex;align-items:center}
.top-bar-contact:hover{color:var(--red)}
.top-bar-social{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--gray-300);border:none;transition:all 0.3s}
.top-bar-social:hover{background:var(--red)}
.top-bar-social svg{width:11px;height:11px;fill:var(--gray-600);stroke:none;transition:fill 0.3s}
.top-bar-social:hover svg{fill:var(--white)}

/* === MAIN NAVBAR (Belfor-style) === */
.navbar{background:var(--white);position:sticky;top:0;z-index:1000;border-bottom:1px solid var(--gray-200);transition:box-shadow 0.35s ease,border-color 0.35s ease,background 0.35s ease}
.navbar.scrolled{box-shadow:0 2px 20px rgba(0,0,0,0.08);border-bottom-color:transparent;background:rgba(255,255,255,0.98);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}
.nav-inner{display:flex;align-items:center;height:80px}
.logo{display:flex;align-items:center;margin-right:auto}
.logo img{height:140px;width:auto;margin:-35px 0}
.logo-img{height:44px;width:auto}
.footer-logo-img{height:38px;width:auto;margin-bottom:1rem}
.logo span{color:var(--red)}
.nav-links{display:flex;gap:0;align-items:center;list-style:none;height:100%;margin-left:1rem}
.nav-links li{height:100%;display:flex;align-items:center;position:relative}
.nav-links li + li{border-left:1px solid var(--gray-200)}
.nav-links a{color:var(--gray-700);font-size:0.82rem;font-weight:600;letter-spacing:0;text-transform:uppercase;padding:0 1.5rem;height:100%;display:flex;align-items:center;position:relative;transition:all 0.3s}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform 0.35s var(--ease-out-expo)}
.nav-links a:hover,.nav-links a.active{color:var(--dark)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-links .has-dropdown > a::before{content:'';display:inline-block;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid var(--gray-400);margin-left:0.5rem;transition:transform 0.3s}
.nav-links .has-dropdown:hover > a::before{transform:rotate(180deg)}
/* Dropdown menu */
.nav-dropdown{position:absolute;top:100%;left:0;min-width:260px;background:var(--white);box-shadow:0 12px 40px rgba(0,0,0,0.12);border-radius:0 0 4px 4px;padding:0.5rem 0;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all 0.3s;z-index:1100;border-top:3px solid var(--red)}
.nav-links .has-dropdown:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.has-dropdown.dropdown-open .nav-dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dropdown a{display:flex;align-items:center;padding:0.75rem 1.5rem!important;height:auto!important;font-size:0.8rem!important;letter-spacing:0.3px;color:var(--gray-600)!important;transition:all 0.2s!important;border-bottom:1px solid var(--gray-100);border-left:none!important}
.nav-dropdown a::after{display:none!important}
.nav-dropdown a:hover{background:var(--red-pale)!important;color:var(--red)!important;padding-left:1.75rem!important}
.nav-dropdown a:last-child{border-bottom:none}

/* Red CTA Button (Get In Touch) */
.nav-cta{background:var(--red)!important;color:var(--white)!important;padding:0.7rem 1.5rem!important;height:auto!important;font-size:0.78rem!important;font-weight:800!important;letter-spacing:1px;transition:background 0.3s ease,box-shadow 0.3s ease!important;display:inline-flex;align-items:center;gap:0.5rem;border-left:none!important;position:relative;border-radius:4px;margin-left:0.75rem}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--red-dark)!important;box-shadow:0 4px 20px rgba(220,38,38,0.35)!important}
.nav-cta .cta-arrow{font-size:1.3rem;font-weight:300;margin-left:0.5rem;transition:transform 0.3s var(--ease-spring)}
.nav-cta:hover .cta-arrow{transform:translateX(3px)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:0.5rem}
.hamburger span{display:block;width:24px;height:2px;background:var(--dark);transition:all 0.3s}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile Menu */
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--white);z-index:9999;padding:2rem;flex-direction:column;overflow-y:auto}
.mobile-menu.active{display:flex}
.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2.5rem}
.mobile-close{background:none;border:none;font-size:2rem;cursor:pointer;color:var(--dark);padding:0.5rem}
.mobile-menu nav a{display:block;font-size:1.05rem;font-weight:700;color:var(--gray-700);padding:1rem 0;border-bottom:1px solid var(--gray-200);text-transform:uppercase;letter-spacing:0.5px}
.mobile-menu nav a:hover,.mobile-menu nav a.active{color:var(--red)}
.mobile-menu .mobile-cta{display:block;background:var(--red);color:var(--white);text-align:center;padding:1rem;margin-top:1.5rem;font-weight:800;letter-spacing:1px;text-transform:uppercase;font-size:0.9rem}
.mobile-menu .mobile-cta:hover{background:var(--red-dark)}
/* Mobile section labels */
.mobile-section-label{display:block;font-size:0.68rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--gray-400);padding:1.25rem 0 0.5rem;border-bottom:none}

/* === SERVICE PAGE HERO === */
.service-page-hero{position:relative;min-height:65vh;display:flex;align-items:center;overflow:hidden;background:var(--dark)}
.service-page-hero .hero-video-wrap{position:absolute;inset:0;z-index:0}
.service-page-hero .hero-video-wrap::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,0.75) 0%,rgba(0,0,0,0.45) 50%,rgba(0,0,0,0.2) 100%);z-index:1}
.service-page-hero .hero-video{position:absolute;top:50%;left:50%;min-width:100%;min-height:100%;width:auto;height:auto;transform:translate(-50%,-50%);object-fit:cover;opacity:1}
.service-page-hero-content{position:relative;z-index:2;color:var(--white);max-width:700px;padding:8rem 0 4rem;padding-left:2rem;border-left:4px solid rgba(255,255,255,0.15)}
.service-page-hero-content .breadcrumb{font-size:0.85rem;color:rgba(255,255,255,0.5);margin-bottom:1rem;display:flex;align-items:center;gap:0.5rem}
.service-page-hero-content .breadcrumb a{color:rgba(255,255,255,0.5);transition:color 0.3s}
.service-page-hero-content .breadcrumb a:hover{color:var(--white)}
.service-page-hero-content h1{font-size:clamp(2.2rem,5vw,3.8rem);font-weight:900;letter-spacing:-0.5px;line-height:1.1;text-transform:uppercase;margin-bottom:1.25rem}
.service-page-hero-content p{font-size:1.05rem;color:rgba(255,255,255,0.65);line-height:1.75;max-width:580px}

/* === HERO (Belfor-style: tag + big title + desc + CTAs) === */
.hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;overflow:hidden;background:var(--dark);padding-bottom:6rem}
.hero-video-wrap{position:absolute;inset:0;z-index:0}
.hero-video-wrap::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,0.88) 0%,rgba(0,0,0,0.72) 35%,rgba(0,0,0,0.4) 65%,rgba(0,0,0,0.18) 100%);z-index:1}
.hero-video-wrap::before{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.45) 0%,transparent 40%);z-index:2;pointer-events:none}
.hero-video{position:absolute;top:50%;left:50%;min-width:100%;min-height:100%;width:auto;height:auto;transform:translate(-50%,-50%);object-fit:cover;opacity:0;transition:opacity 1.2s ease}
.hero-video.active{opacity:1}
.hero .container{position:relative;z-index:2;max-width:none;margin:0;padding:0 2.5rem 0 clamp(2.5rem, 8vw, 10rem)}

/* Hero content block (Belfor-style — left-aligned, bottom-weighted) */
.hero-content{color:var(--white);max-width:620px;margin-right:auto}
.hero-tag{font-size:0.82rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.8);margin-bottom:0.75rem;line-height:1.4;animation:heroStagger 0.7s var(--ease-out-expo) 0.2s both}
.hero-accent-line{width:50px;height:4px;background:var(--red);margin-bottom:1.75rem;animation:heroStagger 0.7s var(--ease-out-expo) 0.3s both}
.hero h1{font-size:clamp(3.5rem,6.5vw,5rem);font-weight:900;line-height:1.05;letter-spacing:-2.5px;text-transform:uppercase;margin-bottom:1.5rem;animation:heroStagger 0.7s var(--ease-out-expo) 0.4s both}
.hero-desc{font-size:1.15rem;font-weight:400;color:rgba(255,255,255,0.7);line-height:1.65;margin-bottom:2.5rem;max-width:560px;animation:heroStagger 0.7s var(--ease-out-expo) 0.55s both}
.hero-desc strong{color:rgba(255,255,255,0.95);font-weight:700}
.hero-actions{display:flex;gap:0;flex-wrap:wrap;margin-top:1.5rem;animation:heroStagger 0.7s var(--ease-out-expo) 0.65s both}
.hero-actions .btn{padding:1.25rem 2.5rem;font-size:0.82rem;font-weight:800;letter-spacing:1.5px;text-transform:uppercase}
@keyframes heroStagger{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* === FLOATING EMERGENCY HOTLINE === */
.emergency-float{position:fixed;bottom:2rem;right:2rem;z-index:999;display:flex;align-items:stretch;gap:0;box-shadow:0 8px 32px rgba(220,38,38,0.25);animation:floatPulse 3s ease-in-out infinite}
@keyframes floatPulse{0%,100%{box-shadow:0 8px 32px rgba(220,38,38,0.25)}50%{box-shadow:0 8px 40px rgba(220,38,38,0.4)}}
.emergency-float-info{background:var(--red);color:var(--white);padding:0.85rem 1.5rem;display:flex;align-items:center;gap:0.75rem}
.emergency-float-label{font-size:0.65rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;opacity:0.85;white-space:nowrap}
.emergency-float-phone{font-size:1.2rem;font-weight:900;letter-spacing:0.5px;white-space:nowrap}
.emergency-float-phone a{color:var(--white)}
.emergency-float-btn{background:var(--red-dark);color:var(--white);width:52px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background 0.3s}
.emergency-float-btn:hover{background:var(--red-darker)}
.emergency-float-btn svg{width:22px;height:22px;fill:var(--white)}

/* === ALWAYS READY SECTION (Belfor-style split) === */
.ready-section{position:relative;overflow:hidden}
.ready-grid{display:grid;grid-template-columns:1fr 1fr;min-height:560px}
.ready-content{background:var(--white);padding:4rem 4rem 4rem 2.5rem;display:flex;flex-direction:column;justify-content:center}
.ready-image{position:relative;overflow:hidden}
.ready-image img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.ready-tag{font-size:0.75rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--red);margin-bottom:0.75rem}
.ready-title{font-size:clamp(2rem,3.5vw,3.2rem);font-weight:800;color:var(--dark);line-height:1.11;letter-spacing:-1.5px;margin-bottom:1.5rem}
.ready-line{width:40px;height:4px;background:var(--red);margin-bottom:1.5rem}
.ready-desc{font-size:0.95rem;color:var(--gray-500);line-height:1.75;margin-bottom:2rem;max-width:500px}

/* Red CTA Banner (full-width) */
.red-cta-banner{background:var(--red);padding:1.5rem 2.5rem;display:flex;align-items:center;gap:0.75rem;color:var(--white);font-size:0.82rem;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:all 0.35s ease;max-width:600px}
.red-cta-banner:hover{background:var(--red-dark);box-shadow:0 6px 24px rgba(220,38,38,0.3)}
.red-cta-banner svg{width:18px;height:18px;fill:none;stroke:var(--white);stroke-width:2.5;transition:transform 0.35s var(--ease-spring)}
.red-cta-banner:hover svg{transform:translateX(4px)}

/* === SERVICE CARDS (homepage — green slide-up hover) === */
.svc-hero{padding:4.5rem 0 2.5rem;background:var(--white)}
.svc-cards-section{padding:3rem 0 4.5rem;background:var(--off-white)}
.svc-cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;max-width:var(--max-w);margin:0 auto;padding:0 2.5rem}

/* Card base — white with green slide-up */
.svc-card{display:block;position:relative;overflow:hidden;background:var(--white);min-height:360px;transition:all 0.5s cubic-bezier(0.4,0,0.2,1);cursor:pointer;border:1px solid var(--gray-200)}
.svc-card::before{content:'';position:absolute;inset:0;background:var(--red);transform:translateY(100%);transition:transform 0.55s cubic-bezier(0.4,0,0.2,1);z-index:0}
.svc-card:hover::before{transform:translateY(0)}
.svc-card:hover{transform:translateY(-8px);box-shadow:0 20px 50px rgba(22,163,74,0.18);border-color:transparent}
.svc-card-inner{position:relative;z-index:1;padding:2.5rem 2rem 2.5rem;height:100%;display:flex;flex-direction:column}

/* Icon container — larger for detailed icons */
.svc-card-icon{width:80px;height:80px;margin-bottom:1.5rem;transition:all 0.5s}
.svc-card-icon svg{width:100%;height:100%;overflow:visible}

/* Accent line */
.svc-card-line{display:flex;align-items:center;margin-bottom:1.25rem;height:3px}
.svc-card-line .svc-line-color{width:40px;height:3px;background:var(--red);transition:all 0.5s}
.svc-card:hover .svc-card-line .svc-line-color{background:var(--white);width:50px}
.svc-card-line .svc-line-gray{flex:1;height:1px;background:var(--gray-200);transition:all 0.5s}
.svc-card:hover .svc-card-line .svc-line-gray{background:rgba(255,255,255,0.25)}

/* Text — transitions for green overlay */
.svc-card h3{font-size:1.05rem;font-weight:800;text-transform:uppercase;letter-spacing:0.3px;margin-bottom:0.6rem;color:var(--dark);transition:color 0.5s}
.svc-card:hover h3{color:var(--white)}
.svc-card p{font-size:0.85rem;color:var(--gray-500);line-height:1.65;transition:color 0.5s}
.svc-card:hover p{color:rgba(255,255,255,0.85)}

/* Card arrow */
.svc-card .card-arrow{display:inline-flex;align-items:center;gap:0.5rem;font-size:0.7rem;font-weight:800;letter-spacing:2px;text-transform:uppercase;margin-top:auto;padding-top:1.25rem;opacity:0;transform:translateY(8px);transition:all 0.4s ease 0.1s;color:var(--white)}
.svc-card:hover .card-arrow{opacity:1;transform:translateY(0)}
.svc-card .card-arrow svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:2.5}

/* ============================================
   CUSTOM ICON SYSTEM — Detailed per-service
   ============================================ */

/* -- Base icon styles (default = dark gray, hover = white) -- */
.svc-card .ico{transition:all 0.5s}
.svc-card .ico-stroke{fill:none;stroke:var(--gray-700);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;transition:all 0.5s}
.svc-card:hover .ico-stroke{stroke:var(--white)}
.svc-card .ico-fill{fill:var(--red);opacity:0.15;transition:all 0.5s}
.svc-card:hover .ico-fill{fill:var(--white);opacity:0.25}
.svc-card .ico-accent{fill:none;stroke:var(--red);stroke-width:1.4;stroke-linecap:round;transition:all 0.5s}
.svc-card:hover .ico-accent{stroke:rgba(255,255,255,0.9)}
.svc-card .ico-detail{fill:none;stroke:var(--gray-400);stroke-width:1;stroke-linecap:round;transition:all 0.5s}
.svc-card:hover .ico-detail{stroke:rgba(255,255,255,0.5)}
.svc-card .ico-dot{fill:var(--gray-400);transition:all 0.5s}
.svc-card:hover .ico-dot{fill:rgba(255,255,255,0.6)}

/* -- WATER: wave/ripple animation on hover -- */
.svc-card[data-svc="water"] .wave-line{transition:all 0.5s}
.svc-card[data-svc="water"]:hover .wave-1{animation:waterWave 2s ease-in-out infinite}
.svc-card[data-svc="water"]:hover .wave-2{animation:waterWave 2s ease-in-out 0.4s infinite}
.svc-card[data-svc="water"]:hover .wave-3{animation:waterWave 2s ease-in-out 0.8s infinite}
.svc-card[data-svc="water"]:hover .drop-anim{animation:waterDrop 1.5s ease-in infinite}
.svc-card[data-svc="water"]:hover .drop-anim-2{animation:waterDrop 2s ease-in 0.5s infinite}
.svc-card[data-svc="water"]:hover .drop-anim-3{animation:waterDrop 1.8s ease-in 0.8s infinite}
.svc-card[data-svc="water"]:hover .splash-ring{animation:splashGrow 1.6s ease-out infinite}
.svc-card[data-svc="water"]:hover .splash-ring-2{animation:splashGrow 1.6s ease-out 0.5s infinite}
@keyframes waterWave{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
@keyframes waterDrop{0%{transform:translateY(0);opacity:0.7}80%{transform:translateY(10px);opacity:0.2}100%{transform:translateY(0);opacity:0.7}}
@keyframes splashGrow{0%{transform:scale(0.6);opacity:0.8}100%{transform:scale(1.4);opacity:0}}

/* -- FIRE: flicker + rising sparks -- */
.svc-card[data-svc="fire"]:hover .flame-main{animation:flameFlicker 0.7s ease-in-out infinite alternate}
.svc-card[data-svc="fire"]:hover .flame-inner{animation:flameFlicker 0.5s ease-in-out 0.1s infinite alternate}
.svc-card[data-svc="fire"]:hover .flame-core{animation:flameFlicker 0.4s ease-in-out 0.15s infinite alternate}
.svc-card[data-svc="fire"]:hover .spark{animation:sparkRise 1.2s ease-out infinite}
.svc-card[data-svc="fire"]:hover .spark-2{animation:sparkRise 1.5s ease-out 0.3s infinite}
.svc-card[data-svc="fire"]:hover .spark-3{animation:sparkRise 1.8s ease-out 0.6s infinite}
.svc-card[data-svc="fire"]:hover .spark-4{animation:sparkRise 1.4s ease-out 0.9s infinite}
.svc-card[data-svc="fire"]:hover .smoke-wisp{animation:smokeFloat 3s ease-in-out infinite}
.svc-card[data-svc="fire"]:hover .smoke-wisp-2{animation:smokeFloat 3.5s ease-in-out 0.8s infinite}
.svc-card[data-svc="fire"]:hover .ember{animation:emberGlow 1s ease-in-out infinite alternate}
.svc-card[data-svc="fire"]:hover .ember-2{animation:emberGlow 1.2s ease-in-out 0.3s infinite alternate}
@keyframes flameFlicker{0%{transform:scaleX(1) scaleY(1)}100%{transform:scaleX(0.94) scaleY(1.04)}}
@keyframes sparkRise{0%{transform:translate(0,0);opacity:0.8}100%{transform:translate(var(--sx,3px),-18px);opacity:0}}
@keyframes smokeFloat{0%{transform:translateY(0) translateX(0);opacity:0.3}50%{transform:translateY(-8px) translateX(3px);opacity:0.15}100%{transform:translateY(0) translateX(0);opacity:0.3}}
@keyframes emberGlow{0%{opacity:0.3;r:1.5}100%{opacity:0.8;r:2.5}}

/* -- MOLD: pulsing spores + spreading tendrils -- */
.svc-card[data-svc="mold"]:hover .spore-cluster{animation:sporePulse 2s ease-in-out infinite}
.svc-card[data-svc="mold"]:hover .spore-cluster-2{animation:sporePulse 2s ease-in-out 0.4s infinite}
.svc-card[data-svc="mold"]:hover .spore-cluster-3{animation:sporePulse 2s ease-in-out 0.8s infinite}
.svc-card[data-svc="mold"]:hover .spore-float{animation:sporeFloat 2.5s ease-in-out infinite}
.svc-card[data-svc="mold"]:hover .spore-float-2{animation:sporeFloat 3s ease-in-out 0.6s infinite}
.svc-card[data-svc="mold"]:hover .spore-float-3{animation:sporeFloat 2.2s ease-in-out 1s infinite}
.svc-card[data-svc="mold"]:hover .tendril-grow{animation:tendrilExtend 3s ease-in-out infinite}
.svc-card[data-svc="mold"]:hover .tendril-grow-2{animation:tendrilExtend 3.5s ease-in-out 0.5s infinite}
.svc-card[data-svc="mold"]:hover .lens-flare{animation:lensShine 2s ease-in-out infinite}
@keyframes sporePulse{0%,100%{transform:scale(1);opacity:0.6}50%{transform:scale(1.25);opacity:1}}
@keyframes sporeFloat{0%,100%{transform:translate(0,0);opacity:0.4}50%{transform:translate(var(--fx,2px),var(--fy,-4px));opacity:0.8}}
@keyframes tendrilExtend{0%,100%{stroke-dashoffset:30;opacity:0.2}50%{stroke-dashoffset:0;opacity:0.6}}
@keyframes lensShine{0%,100%{opacity:0.15}50%{opacity:0.5}}

/* -- DUCT: fan spin + airflow particles -- */
.svc-card[data-svc="duct"]:hover .fan-blade-group{animation:fanSpin 2.5s linear infinite;transform-origin:40px 40px}
.svc-card[data-svc="duct"]:hover .air-particle{animation:airDrift 2s ease-in-out infinite}
.svc-card[data-svc="duct"]:hover .air-particle-2{animation:airDrift 2.5s ease-in-out 0.4s infinite}
.svc-card[data-svc="duct"]:hover .air-particle-3{animation:airDrift 1.8s ease-in-out 0.8s infinite}
.svc-card[data-svc="duct"]:hover .air-particle-4{animation:airDrift 2.2s ease-in-out 1.2s infinite}
.svc-card[data-svc="duct"]:hover .air-stream{animation:airFlow 1.5s ease-in-out infinite}
.svc-card[data-svc="duct"]:hover .air-stream-2{animation:airFlow 1.5s ease-in-out 0.3s infinite}
.svc-card[data-svc="duct"]:hover .air-stream-3{animation:airFlow 1.5s ease-in-out 0.6s infinite}
.svc-card[data-svc="duct"]:hover .vent-glow{animation:ventPulse 2s ease-in-out infinite}
@keyframes fanSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes airDrift{0%,100%{transform:translate(0,0);opacity:0.3}50%{transform:translate(var(--dx,5px),var(--dy,-3px));opacity:0.7}}
@keyframes airFlow{0%,100%{transform:translateX(0);opacity:0.3}50%{transform:translateX(6px);opacity:0.6}}
@keyframes ventPulse{0%,100%{opacity:0.05}50%{opacity:0.15}}

/* (Legacy icon classes removed — new system uses data-svc selectors above) */

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;gap:0.5rem;padding:1rem 2rem;font-size:0.78rem;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;border:none;cursor:pointer;font-family:var(--font);transition:all 0.35s var(--ease-out-expo);position:relative;overflow:hidden}
.btn:focus-visible{outline:3px solid var(--red);outline-offset:2px}
.btn::after{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,0.1) 50%,transparent 70%);transform:translateX(-100%);transition:transform 0.6s ease}
.btn:hover::after{transform:translateX(100%)}
.btn-primary{background:var(--red);color:var(--white)}
.btn-primary:hover{background:var(--red-dark);transform:translateY(-2px);box-shadow:0 8px 25px rgba(220,38,38,0.3)}
.btn-white{background:var(--white);color:var(--dark)}
.btn-white:hover{background:var(--gray-100);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-outline-white{background:transparent;color:var(--white);border:2px solid rgba(255,255,255,0.5)}
.btn-outline-white:hover{border-color:var(--white);background:rgba(255,255,255,0.1);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--dark);border:2px solid var(--gray-300)}
.btn-outline:hover{border-color:var(--dark);background:var(--dark);color:var(--white)}
.btn-outline-red{background:transparent;color:var(--red);border:2px solid var(--red)}
.btn-outline-red:hover{background:var(--red);color:var(--white)}
.btn-lg{padding:1.1rem 2.5rem;font-size:0.82rem}
.btn svg{width:18px;height:18px}

/* === PAGE HERO (inner pages — video background) === */
.page-hero{position:relative;padding:10rem 0 5rem;overflow:hidden;background:var(--dark);min-height:420px;display:flex;align-items:center}
.page-hero-video-wrap{position:absolute;inset:0;z-index:0}
.page-hero-video-wrap::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,0.75) 0%,rgba(0,0,0,0.5) 50%,rgba(0,0,0,0.35) 100%);z-index:1}
.page-hero-video{position:absolute;top:50%;left:50%;min-width:100%;min-height:100%;width:auto;height:auto;transform:translate(-50%,-50%);object-fit:cover}
.page-hero-content{position:relative;z-index:2;color:var(--white)}
.page-hero .breadcrumb{font-size:0.78rem;color:rgba(255,255,255,0.4);margin-bottom:1rem;display:flex;align-items:center;gap:0.5rem;font-weight:600;letter-spacing:0.5px;text-transform:uppercase}
.page-hero .breadcrumb a{color:rgba(255,255,255,0.4);transition:color 0.3s}
.page-hero .breadcrumb a:hover{color:var(--white)}
.page-hero h1{font-size:clamp(2.5rem,5vw,4rem);font-weight:800;letter-spacing:-2px;line-height:1.11}
.page-hero p{font-size:1.05rem;color:rgba(255,255,255,0.55);margin-top:1rem;max-width:600px;line-height:1.7}

/* === VIDEO CONTENT BLOCK (replaces static images) === */
.video-block{position:relative;overflow:hidden;min-height:400px}
.video-block video{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}

/* === SERVICE NAV (services page) === */
.service-nav{background:var(--white);border-bottom:1px solid var(--gray-200);padding:1rem 0;position:sticky;top:80px;z-index:900;box-shadow:var(--shadow-sm)}
.service-nav .container{display:flex;gap:0.5rem;justify-content:center;flex-wrap:wrap}
.service-nav-link{display:inline-flex;align-items:center;padding:0.6rem 1.25rem;font-size:0.75rem;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;color:var(--gray-600);border:1.5px solid var(--gray-200);transition:all 0.3s}
.service-nav-link:hover{color:var(--red);border-color:var(--red);background:var(--red-pale)}
.service-nav-link:active{transform:scale(0.97)}

/* === ANCHOR SCROLL BEHAVIOR (UUPM §5) === */
[id]{scroll-margin-top:80px}

/* === SECTION HEADINGS === */
.section-tag{display:inline-flex;align-items:center;gap:0.5rem;font-size:0.75rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--red);margin-bottom:0.75rem}
.section-tag::before{content:'';width:24px;height:2px;background:var(--red)}
.section-title{font-size:clamp(2rem,3.5vw,3.2rem);font-weight:800;color:var(--dark);letter-spacing:-1.5px;line-height:1.15;margin-bottom:1rem}
.section-desc{font-size:1rem;font-weight:500;color:var(--gray-600);max-width:580px;line-height:1.55}

/* === FEATURES / WHY US === */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.5rem}
.feature-card{background:var(--white);border:1px solid var(--gray-200);padding:2.5rem;transition:all 0.45s var(--ease-out-expo);position:relative;overflow:hidden;contain:layout style}
.feature-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--red),var(--red-light));transform:scaleX(0);transform-origin:left;transition:transform 0.45s var(--ease-out-expo)}
.feature-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,0.1);border-color:transparent}
.feature-card:hover::before{transform:scaleX(1)}

/* Feature icon container — matches svc-card-icon style */
.feat-icon-wrap{width:72px;height:72px;margin-bottom:1.5rem;transition:all 0.5s}
.feat-icon-wrap svg{width:100%;height:100%;overflow:visible}

/* Feature card icon base styles — same system as service cards */
.feature-card .ico-stroke{fill:none;stroke:var(--gray-700);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;transition:all 0.5s}
.feature-card .ico-fill{fill:var(--red);transition:all 0.5s}
.feature-card .ico-accent{fill:none;stroke:var(--red);stroke-width:1.4;stroke-linecap:round;transition:all 0.5s}
.feature-card .ico-detail{fill:none;stroke:var(--gray-400);stroke-width:1;stroke-linecap:round;transition:all 0.5s}
.feature-card .ico-dot{fill:var(--gray-400);transition:all 0.5s}

/* Feature card hover — icon color shifts */
.feature-card:hover .ico-stroke{stroke:var(--dark)}
.feature-card:hover .ico-accent{stroke:var(--red-dark)}
.feature-card:hover .ico-detail{stroke:var(--gray-500)}
.feature-card:hover .ico-dot{fill:var(--gray-600)}

/* -- CLOCK: pulse + hand tick -- */
.feature-card[data-feat="clock"]:hover .clock-minute{animation:minuteTick 3s ease-in-out infinite;transform-origin:40px 40px}
.feature-card[data-feat="clock"]:hover .alert-ring{animation:alertSpin 4s linear infinite;transform-origin:40px 40px;opacity:0.4}
.feature-card[data-feat="clock"]:hover .pulse-ring{animation:clockPulse 2s ease-out infinite;transform-origin:40px 40px}
.feature-card[data-feat="clock"]:hover .pulse-ring-2{animation:clockPulse 2s ease-out 1s infinite;transform-origin:40px 40px}
@keyframes minuteTick{0%,100%{transform:rotate(0deg)}50%{transform:rotate(30deg)}}
@keyframes alertSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes clockPulse{0%{transform:scale(1);opacity:0.5}100%{transform:scale(1.3);opacity:0}}

/* -- CERT: sparkle + ribbon wave -- */
.feature-card[data-feat="cert"]:hover .cert-sparkle{animation:certSparkle 1.5s ease-in-out infinite}
.feature-card[data-feat="cert"]:hover .cert-sparkle-2{animation:certSparkle 1.5s ease-in-out 0.4s infinite}
.feature-card[data-feat="cert"]:hover .cert-sparkle-3{animation:certSparkle 1.5s ease-in-out 0.8s infinite}
.feature-card[data-feat="cert"]:hover .ribbon-l{animation:ribbonWave 2s ease-in-out infinite}
.feature-card[data-feat="cert"]:hover .ribbon-r{animation:ribbonWave 2s ease-in-out 0.3s infinite}
@keyframes certSparkle{0%,100%{opacity:0;transform:scale(0.5)}50%{opacity:0.8;transform:scale(1.5)}}
@keyframes ribbonWave{0%,100%{transform:translateX(0)}50%{transform:translateX(2px)}}

/* -- SHIELD: glow + lock reveal -- */
.feature-card[data-feat="shield"]:hover .shield-glow{animation:shieldGlow 2s ease-in-out infinite}
.feature-card[data-feat="shield"]:hover .shield-lock{opacity:0.5;transition:opacity 0.5s}
.feature-card[data-feat="shield"]:hover .shield-lock-arc{opacity:0.4;transition:opacity 0.5s}
@keyframes shieldGlow{0%,100%{opacity:0.15}50%{opacity:0.45}}

/* -- DOC: pen + signature -- */
.feature-card[data-feat="doc"]:hover .doc-pen{animation:penWrite 2s ease-in-out infinite;opacity:0.5}
.feature-card[data-feat="doc"]:hover .doc-pen-tip{opacity:0.4}
.feature-card[data-feat="doc"]:hover .doc-sig{animation:sigDraw 2.5s ease-in-out infinite}
@keyframes penWrite{0%,100%{transform:translate(0,0)}50%{transform:translate(-4px,4px)}}
@keyframes sigDraw{0%{stroke-dasharray:20;stroke-dashoffset:20;opacity:0}50%{stroke-dashoffset:0;opacity:0.7}100%{stroke-dashoffset:0;opacity:0}}

.feature-card h3{font-size:1rem;font-weight:800;color:var(--dark);margin-bottom:0.75rem;text-transform:uppercase;letter-spacing:0}
.feature-card p{font-size:0.88rem;color:var(--gray-500);line-height:1.7}

/* === ABOUT === */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.about-img{position:relative;overflow:hidden;box-shadow:var(--shadow-xl)}
.about-img img{width:100%;height:100%;object-fit:cover;min-height:400px}
.about-img-badge{position:absolute;bottom:0;left:0;background:var(--red);color:var(--white);padding:1.25rem 1.75rem}
.about-img-badge h3{font-size:2rem;font-weight:900;line-height:1}
.about-img-badge p{font-size:0.68rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;opacity:0.8}
.about-features{display:flex;flex-direction:column;gap:1.25rem;margin-top:2rem}
.about-feat{display:flex;gap:1rem;align-items:flex-start}
.about-feat-icon{width:36px;height:36px;min-width:36px;background:var(--red-pale);border:1px solid rgba(220,38,38,0.15);display:flex;align-items:center;justify-content:center}
.about-feat-icon svg{width:18px;height:18px;stroke:var(--red);stroke-width:2;fill:none}
.about-feat h4{font-size:0.88rem;font-weight:800;color:var(--dark);margin-bottom:0.15rem}
.about-feat p{font-size:0.83rem;color:var(--gray-500);line-height:1.6}

/* === CTA BANNER === */
.cta-banner{position:relative;padding:5rem 0;overflow:hidden;background:var(--dark)}
.cta-banner-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.cta-banner-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,10,10,0.94),rgba(10,10,10,0.88))}
.cta-banner-content{position:relative;z-index:2;text-align:center;color:var(--white);max-width:700px;margin:0 auto}
.cta-banner-content h2{font-size:clamp(2rem,3.5vw,3.2rem);font-weight:800;margin-bottom:1rem;letter-spacing:-1.5px}
.cta-banner-content p{font-size:1rem;color:rgba(255,255,255,0.55);margin-bottom:2rem;line-height:1.7}
.cta-banner-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* === RESOURCES / LIBRARY SECTION === */
.resources-section{padding:5rem 0;background:var(--white)}
.resources-title{font-size:clamp(2rem,3.5vw,3.2rem);font-weight:800;color:var(--dark);letter-spacing:-1.5px;line-height:1.11;margin-bottom:0.75rem}
.resources-desc{font-size:0.95rem;color:var(--gray-500);margin-bottom:2rem;line-height:1.7}
.resources-tabs{display:flex;gap:0.75rem;margin-bottom:2.5rem}
.resource-tab{padding:0.6rem 1.5rem;font-size:0.75rem;font-weight:800;letter-spacing:0.5px;text-transform:uppercase;border:none;cursor:pointer;font-family:var(--font);transition:all 0.3s}
.resource-tab.active{background:var(--red);color:var(--white)}
.resource-tab:not(.active){background:var(--white);color:var(--gray-600);border:1.5px solid var(--gray-300)}
.resource-tab:not(.active):hover{color:var(--dark);border-color:var(--dark)}
.resources-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.resource-card{background:var(--off-white);overflow:hidden;transition:all 0.3s}
.resource-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.resource-card-img{height:200px;background:var(--gray-200);overflow:hidden}
.resource-card-img img{width:100%;height:100%;object-fit:cover}
.resource-card-body{padding:1.5rem}
.resource-card-tag{font-size:0.68rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--red);margin-bottom:0.5rem}
.resource-card-body h3{font-size:1.1rem;font-weight:900;color:var(--dark);line-height:1.3}

/* === STATS BAR === */
.stats-bar{background:var(--dark);padding:3.5rem 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center;color:var(--white)}
.stat-item h3{font-size:2.5rem;font-weight:900;line-height:1;color:var(--red-light)}
.stat-item p{font-size:0.72rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-top:0.35rem}

/* === CONTACT === */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem}
.contact-form{display:flex;flex-direction:column;gap:1.15rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.15rem}
.form-group{display:flex;flex-direction:column;gap:0.4rem}
.form-group label{font-size:0.75rem;font-weight:700;color:var(--gray-600);letter-spacing:0.5px;text-transform:uppercase}
.form-group input,.form-group select,.form-group textarea{background:var(--white);border:1.5px solid var(--gray-300);color:var(--gray-800);padding:0.9rem 1rem;font-size:0.88rem;font-family:var(--font);transition:border-color 0.3s,box-shadow 0.3s;outline:none;min-height:44px}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(220,38,38,0.08)}
.form-group textarea{min-height:120px;resize:vertical}

/* === FORM ENHANCEMENTS (UUPM §8) === */
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(220,38,38,0.1);outline:none}
.contact-form input::placeholder,
.contact-form textarea::placeholder{color:var(--gray-400);transition:opacity 0.2s}
.contact-form input:focus::placeholder,
.contact-form textarea:focus::placeholder{opacity:0.5}
.contact-form input:invalid:not(:placeholder-shown),
.contact-form select:invalid:not(:placeholder-shown),
.contact-form textarea:invalid:not(:placeholder-shown){border-color:#dc2626;background:rgba(220,38,38,0.02)}
.contact-form input:valid:not(:placeholder-shown),
.contact-form textarea:valid:not(:placeholder-shown){border-color:#15803d}
.form-group select{cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}
.contact-info-cards{display:flex;flex-direction:column;gap:1.25rem}
.contact-info-card{display:flex;gap:1rem;align-items:flex-start;padding:1.25rem;background:var(--off-white);border:1px solid var(--gray-200);transition:all 0.3s}
.contact-info-card:hover{border-color:var(--red);box-shadow:var(--shadow)}
.contact-info-icon{width:44px;height:44px;min-width:44px;background:var(--white);border:1px solid var(--gray-200);display:flex;align-items:center;justify-content:center}
.contact-info-icon svg{width:20px;height:20px;stroke:var(--red);stroke-width:2;fill:none}
.contact-info-card h4{font-size:0.72rem;font-weight:700;color:var(--gray-400);letter-spacing:1px;text-transform:uppercase;margin-bottom:0.2rem}
.contact-info-card p,.contact-info-card a{font-size:0.92rem;color:var(--gray-800);font-weight:500}
.contact-info-card a:hover{color:var(--red)}
.contact-emergency{background:var(--dark);padding:1.75rem;display:flex;align-items:center;gap:1.25rem;color:var(--white);margin-top:1rem}
.contact-emergency svg{width:36px;height:36px;fill:var(--red);flex-shrink:0}
.contact-emergency .ce-label{font-size:0.65rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.4)}
.contact-emergency .ce-phone{font-size:1.3rem;font-weight:900}
.contact-emergency a{color:var(--white)}

/* === TESTIMONIAL === */
.testimonial-section{background:var(--dark);padding:6rem 0;position:relative;overflow:hidden}
.testimonial-section::before{content:'';position:absolute;top:0;right:0;width:50%;height:100%;background:linear-gradient(135deg,transparent 0%,rgba(220,38,38,0.05) 100%)}
.testimonial-card{max-width:800px;margin:2rem auto 0;text-align:center;position:relative;padding:3rem}
.testimonial-card blockquote{font-size:1.25rem;line-height:1.8;color:rgba(255,255,255,0.7);font-style:italic;margin-bottom:1.5rem}
.testimonial-card cite{font-size:0.82rem;font-weight:800;color:var(--white);font-style:normal;letter-spacing:1px;text-transform:uppercase}
.testimonial-quote-mark{font-size:8rem;line-height:1;font-family:Georgia,serif;color:transparent;-webkit-text-stroke:2px var(--red);opacity:0.3;position:absolute;top:-1rem;left:50%;transform:translateX(-50%)}

/* === LOCATIONS === */
.locations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:0.6rem;margin-top:2rem}
.location-item{display:flex;align-items:center;gap:0.5rem;padding:0.75rem 1rem;background:var(--white);border:1px solid var(--gray-200);font-size:0.88rem;font-weight:600;color:var(--gray-600);transition:all 0.3s var(--ease-out-expo)}
.location-item:hover{border-color:var(--red);color:var(--dark);transform:translateY(-2px);box-shadow:0 4px 16px rgba(220,38,38,0.1)}
.location-item svg{width:14px;height:14px;stroke:var(--red);stroke-width:2;fill:none;flex-shrink:0;transition:transform 0.3s var(--ease-spring)}
.location-item:hover svg{transform:scale(1.15)}

/* === PROCESS === */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;margin-top:3rem}
.process-step{text-align:center;position:relative}
.process-step::after{content:'';position:absolute;top:32px;left:60%;width:80%;height:2px;background:var(--gray-200)}
.process-step:last-child::after{display:none}
.process-num{width:64px;height:64px;background:var(--dark);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:900;margin:0 auto 1.25rem;position:relative;z-index:2}
.process-step h3{font-size:0.88rem;font-weight:900;color:var(--dark);margin-bottom:0.4rem;text-transform:uppercase;letter-spacing:0.3px}
.process-step p{font-size:0.83rem;color:var(--gray-500);line-height:1.6}

/* === CERTIFICATIONS === */
.cert-card{text-align:center;padding:2.5rem;background:var(--white);border:1px solid var(--gray-200);transition:all 0.3s}
.cert-card:hover{box-shadow:var(--shadow-lg);border-color:transparent;transform:translateY(-4px)}
.cert-card h2{font-size:2.2rem;font-weight:900;color:var(--dark);margin-bottom:0.5rem}
.cert-card h3{font-size:0.85rem;font-weight:700;color:var(--gray-700);margin-bottom:0.5rem}
.cert-card p{font-size:0.82rem;color:var(--gray-500);line-height:1.6}

/* === FOOTER (Belfor-style) === */
.footer{background:var(--gray-100);color:var(--dark);padding:0;border-top:1px solid var(--gray-200)}
.footer-main{padding:4rem 0 3rem;border-bottom:1px solid var(--gray-200)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:3rem}
.footer-tagline{font-size:0.72rem;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:var(--red);margin-bottom:0.5rem}
.footer-headline{font-size:clamp(1.8rem,3vw,2.5rem);font-weight:800;color:var(--dark);letter-spacing:-1px;line-height:1.11;margin-bottom:1.5rem}
.footer-social{display:flex;gap:0.6rem;margin-top:1rem}
.footer-social a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1.5px solid var(--gray-300);transition:all 0.3s var(--ease-out-expo)}
.footer-social a:hover{background:var(--red);border-color:var(--red);transform:translateY(-2px)}
.footer-social svg{width:16px;height:16px;fill:var(--gray-600)}
.footer-social a:hover svg{fill:var(--white)}
.footer h4{font-size:0.72rem;font-weight:800;letter-spacing:2px;text-transform:uppercase;margin-bottom:1.25rem;color:var(--gray-400)}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:0.65rem}
.footer ul a{color:var(--gray-600);font-size:0.88rem;font-weight:500;transition:color 0.3s}
.footer ul a:hover{color:var(--red)}
.footer-contact-item{display:flex;align-items:flex-start;gap:0.65rem;margin-bottom:0.85rem}
.footer-contact-item svg{width:14px;height:14px;stroke:var(--red);stroke-width:2;fill:none;margin-top:3px;flex-shrink:0}
.footer-contact-item span{color:var(--gray-600);font-size:0.88rem;line-height:1.5}
.footer-contact-item a{color:var(--gray-600);transition:color 0.3s}
.footer-contact-item a:hover{color:var(--red)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 0;font-size:0.78rem;color:var(--gray-400)}
.footer-bottom a{color:var(--gray-400);transition:color 0.3s}
.footer-bottom a:hover{color:var(--red)}

/* === SKIP NAVIGATION === */
.skip-nav{position:absolute;top:-9999px;left:-9999px;z-index:9999;padding:0.75rem 1rem;background:var(--red);color:var(--white);text-decoration:none;border-radius:0 0 4px 0;font-weight:600;font-size:0.88rem}
.skip-nav:focus{top:0;left:0}

/* === SCROLL REVEAL === */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.7s var(--ease-out-expo),transform 0.7s var(--ease-out-expo)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:0.12s}
.reveal-delay-2{transition-delay:0.24s}
.reveal-delay-3{transition-delay:0.36s}

/* === RESPONSIVE === */

/* ---- TABLET (1024px and below) ---- */
@media(max-width:1024px){
  /* Nav collapses to hamburger at tablet like Belfor */
  .nav-links{display:none}
  .nav-cta{display:none!important}
  .hamburger{display:flex}
  .nav-inner{justify-content:space-between;height:68px}
  .logo img{height:90px;margin:-20px 0;max-width:220px}
  .logo-img{height:38px}

  /* Top bar simplified */
  .top-bar{font-size:0.72rem;padding:0.4rem 0}
  .top-bar-left{gap:1rem}

  /* Container */
  .container{padding:0 2rem}

  /* Hero */
  .hero{min-height:80vh;padding-bottom:5rem}
  .hero .container{padding:0 2rem 0 clamp(2rem, 6vw, 6rem)}
  .hero h1{font-size:clamp(2.8rem,5.5vw,3.8rem);letter-spacing:-2px}
  .hero-desc{font-size:1.05rem;max-width:520px}
  .hero-content{max-width:560px}
  .hero-actions .btn{padding:1.1rem 2rem;font-size:0.78rem}

  /* Page hero (subpages) */
  .page-hero{padding:8rem 0 4rem;min-height:340px}
  .page-hero h1{font-size:clamp(2.2rem,4.5vw,3.2rem)}

  /* Service cards 2-col */
  .svc-cards-grid{grid-template-columns:repeat(2,1fr);padding:0 2rem}
  .svc-card{min-height:320px}

  /* Ready section stack */
  .ready-grid{grid-template-columns:1fr}
  .ready-content{padding:3rem 2rem}
  .ready-image{min-height:350px;position:relative}

  /* About / Contact grids */
  .about-grid{grid-template-columns:1fr;gap:2.5rem}
  .about-grid > div[style*="order:2"]{order:unset}
  .contact-grid{grid-template-columns:1fr;gap:2.5rem}

  /* Process 2-col */
  .process-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}
  .process-step::after{display:none}

  /* Stats 2x2 */
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}

  /* Resources 2-col */
  .resources-grid{grid-template-columns:repeat(2,1fr)}

  /* Footer 2-col */
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .footer-headline{font-size:clamp(1.5rem,3vw,2rem)}

  /* Section spacing */
  .section-pad{padding:4rem 0}
  .svc-hero{padding:3.5rem 0 2rem}

  /* Locations */
  .locations-grid{grid-template-columns:repeat(3,1fr)}

  /* Service nav scrollable */
  .service-nav{top:68px}
  .service-nav .container{justify-content:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:0.4rem;padding-bottom:0.5rem}
  .service-nav .container::-webkit-scrollbar{display:none}
  .service-nav-link{white-space:nowrap;flex-shrink:0}

  /* Emergency widget */
  .emergency-float{bottom:1.5rem;right:1.5rem}

  /* Form */
  .form-row{grid-template-columns:1fr 1fr}

  /* Testimonial */
  .testimonial-card{padding:2rem 1rem}
  .testimonial-card blockquote{font-size:1.1rem}

  /* CTA Banner */
  .cta-banner{padding:4rem 0}
  .cta-banner-content h2{font-size:clamp(1.8rem,3.5vw,2.8rem)}
}

/* ---- MOBILE (768px and below) ---- */
@media(max-width:768px){
  /* Top bar hidden */
  .top-bar{display:none}

  /* Navbar */
  .nav-inner{height:auto;position:relative;justify-content:center;flex-direction:column;padding:1rem 0}
  .nav-inner .logo{position:static;margin-right:0;justify-content:center;width:100%}
  .nav-inner .hamburger{position:absolute;right:0;top:50%;transform:translateY(-50%)}
  .logo img{height:auto;width:80%;max-width:320px;margin:0 auto;display:block}
  .logo-img{height:34px}

  /* Container tighter */
  .container{padding:0 1.5rem}

  /* Hero */
  .hero{min-height:70vh;align-items:flex-end;padding-bottom:3.5rem}
  .hero .container{padding:0 1.5rem}
  .hero h1{font-size:clamp(2.2rem,7vw,3rem);letter-spacing:-1.5px}
  .hero-tag{font-size:0.75rem;letter-spacing:2px}
  .hero-desc{font-size:0.95rem;max-width:100%;margin-bottom:1.5rem}
  .hero-content{max-width:100%}
  .hero-accent-line{width:40px;height:3px;margin-bottom:1.25rem}
  .hero-actions{gap:0.75rem}
  .hero-actions .btn{padding:0.95rem 1.5rem;font-size:0.75rem;letter-spacing:0.8px}

  /* Page hero (subpages) */
  .page-hero{padding:6rem 0 3rem;min-height:280px}
  .page-hero h1{font-size:clamp(1.8rem,5vw,2.5rem);letter-spacing:-1px}
  .page-hero p{font-size:0.92rem;margin-top:0.75rem}
  .page-hero .breadcrumb{font-size:0.72rem;margin-bottom:0.75rem}

  /* Section spacing */
  .section-pad{padding:3rem 0}
  .svc-hero{padding:3rem 0 1.5rem}
  .svc-cards-section{padding:2rem 0 3rem}

  /* Service cards 2-col still */
  .svc-cards-grid{grid-template-columns:repeat(2,1fr);gap:1rem;padding:0 1.5rem}
  .svc-card{min-height:280px}
  .svc-card-inner{padding:1.75rem 1.25rem 1.75rem}
  .svc-card-icon{width:60px;height:60px;margin-bottom:1rem}
  .svc-card h3{font-size:0.92rem}
  .svc-card p{font-size:0.8rem;line-height:1.55}

  /* Ready section */
  .ready-content{padding:2.5rem 1.5rem}
  .ready-title{font-size:clamp(1.8rem,5vw,2.5rem)}
  .ready-desc{font-size:0.9rem}
  .ready-image{min-height:280px}
  .red-cta-banner{padding:1.15rem 1.75rem;font-size:0.75rem;letter-spacing:1px;max-width:100%}

  /* Feature cards */
  .feature-card{padding:2rem 1.5rem}
  .feat-icon-wrap{width:60px;height:60px;margin-bottom:1.25rem}
  .feature-card h3{font-size:0.92rem}
  .feature-card p{font-size:0.83rem}

  /* Stats */
  .stats-bar{padding:2.5rem 0}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}
  .stat-item h3{font-size:2rem}
  .stat-item p{font-size:0.68rem;letter-spacing:1.5px}

  /* Resources */
  .resources-grid{grid-template-columns:1fr}
  .resources-title{font-size:clamp(1.6rem,4vw,2.2rem)}
  .resources-tabs{gap:0.5rem;flex-wrap:wrap}
  .resource-tab{padding:0.5rem 1rem;font-size:0.7rem}

  /* Section titles */
  .section-title{font-size:clamp(1.6rem,4.5vw,2.2rem);letter-spacing:-1px}
  .section-tag{font-size:0.7rem;letter-spacing:2.5px}
  .section-desc{font-size:0.9rem}

  /* Form */
  .form-row{grid-template-columns:1fr}
  .form-group input,.form-group select,.form-group textarea{padding:0.85rem 0.9rem;font-size:0.85rem}

  /* Locations 2-col */
  .locations-grid{grid-template-columns:repeat(2,1fr);gap:0.5rem}
  .location-item{padding:0.65rem 0.75rem;font-size:0.82rem}

  /* Process */
  .process-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}
  .process-num{width:52px;height:52px;font-size:1.1rem}
  .process-step h3{font-size:0.82rem}
  .process-step p{font-size:0.78rem}

  /* Footer */
  .footer-main{padding:3rem 0 2rem}
  .footer-grid{grid-template-columns:1fr;gap:2rem;text-align:center}
  .footer-headline{font-size:clamp(1.4rem,4vw,1.8rem)}
  .footer-bottom{flex-direction:column;gap:0.75rem;text-align:center}
  .footer h4{margin-bottom:0.75rem}
  .footer-social{justify-content:center}
  .footer-contact-item{justify-content:center}
  .footer ul{align-items:center}

  /* CTA Banner */
  .cta-banner{padding:3rem 0}
  .cta-banner-content h2{font-size:clamp(1.6rem,4.5vw,2.2rem)}
  .cta-banner-content p{font-size:0.9rem}
  .cta-banner-actions{flex-direction:column;align-items:stretch}
  .cta-banner-actions .btn{justify-content:center}

  /* Contact emergency */
  .contact-emergency{padding:1.25rem;gap:1rem}
  .contact-emergency .ce-phone{font-size:1.1rem}

  /* Testimonial */
  .testimonial-section{padding:4rem 0}
  .testimonial-card{padding:1.5rem 0.5rem}
  .testimonial-card blockquote{font-size:1rem;line-height:1.7}
  .testimonial-quote-mark{font-size:5rem}

  /* Emergency floating widget — compact */
  .emergency-float{bottom:1rem;right:1rem}
  .emergency-float-info{padding:0.65rem 1rem}
  .emergency-float-phone{font-size:0.95rem}
  .emergency-float-btn{width:46px}
  .emergency-float-btn svg{width:20px;height:20px}

  /* Cert cards */
  .cert-card{padding:1.75rem}
  .cert-card h2{font-size:1.8rem}

  /* Mobile menu enhancements */
  .mobile-menu{padding:1.5rem}
  .mobile-menu nav a{font-size:1.1rem;padding:1.1rem 0}
  .mobile-menu .mobile-cta{padding:1.1rem;font-size:0.88rem}

  /* About section */
  .about-img{min-height:300px}
  .about-img img{min-height:300px}
  .about-img-badge{padding:1rem 1.25rem}
  .about-img-badge h3{font-size:1.6rem}

  /* Service nav */
  .service-nav{top:60px;padding:0.75rem 0}
}

/* ---- SMALL MOBILE (480px and below) ---- */
@media(max-width:480px){
  /* Tightest container */
  .container{padding:0 1rem}

  /* Navbar */
  .nav-inner{height:auto}
  .logo img{width:75%;max-width:260px}
  .logo-img{height:30px}

  /* Hero fullscreen feel */
  .hero{min-height:65vh;padding-bottom:2.5rem}
  .hero h1{font-size:clamp(1.9rem,8vw,2.6rem);letter-spacing:-1px;margin-bottom:1rem}
  .hero-tag{font-size:0.7rem;letter-spacing:2px}
  .hero-desc{font-size:0.88rem;line-height:1.5;margin-bottom:1.5rem}
  .hero-accent-line{margin-bottom:1rem}

  /* Hero CTAs stack full-width */
  .hero-actions{flex-direction:column;gap:0.6rem}
  .hero-actions .btn{width:100%;justify-content:center;padding:0.9rem 1.25rem;font-size:0.72rem}

  /* Page hero */
  .page-hero{padding:5rem 0 2.5rem;min-height:220px}
  .page-hero h1{font-size:clamp(1.6rem,6vw,2.2rem)}
  .page-hero p{font-size:0.85rem}

  /* Service cards 1-col on small phones */
  .svc-cards-grid{grid-template-columns:1fr;padding:0 1rem;gap:0.75rem}
  .svc-card{min-height:250px}
  .svc-card-inner{padding:1.5rem 1.25rem}
  .svc-card-icon{width:56px;height:56px;margin-bottom:0.85rem}
  .svc-card h3{font-size:0.88rem}

  /* Ready section */
  .ready-content{padding:2rem 1rem}
  .ready-title{font-size:clamp(1.5rem,5vw,2rem);letter-spacing:-0.8px}
  .ready-image{min-height:220px}
  .red-cta-banner{padding:1rem 1.25rem;font-size:0.7rem}

  /* Section titles */
  .section-title{font-size:clamp(1.4rem,5vw,1.9rem)}
  .section-pad{padding:2.5rem 0}

  /* Feature cards tighter */
  .feature-card{padding:1.5rem 1.25rem}
  .feat-icon-wrap{width:52px;height:52px;margin-bottom:1rem}
  .feat-icon-wrap{width:52px;height:52px;margin-bottom:1rem}

  /* Stats */
  .stats-bar{padding:2rem 0}
  .stat-item h3{font-size:1.7rem}
  .stat-item p{font-size:0.62rem}

  /* Resources */
  .resources-title{font-size:clamp(1.4rem,4.5vw,1.8rem)}
  .resource-card-body{padding:1.15rem}
  .resource-card-body h3{font-size:0.95rem}
  .resource-card-img{height:160px}

  /* Locations 1-col */
  .locations-grid{grid-template-columns:1fr;gap:0.4rem}

  /* Process 1-col */
  .process-grid{grid-template-columns:1fr;gap:1rem}
  .process-num{width:48px;height:48px;font-size:1rem;margin-bottom:1rem}

  /* Footer */
  .footer-main{padding:2.5rem 0 1.5rem}
  .footer-headline{font-size:1.3rem}
  .footer-tagline{font-size:0.65rem}

  /* Form */
  .form-group input,.form-group select,.form-group textarea{padding:0.8rem;font-size:0.82rem}

  /* CTA Banner */
  .cta-banner{padding:2.5rem 0}
  .cta-banner-content h2{font-size:clamp(1.4rem,5vw,1.8rem)}
  .cta-banner-actions .btn{width:100%;font-size:0.72rem}

  /* Emergency widget — phone icon only on very small screens */
  .emergency-float-info{display:none}
  .emergency-float{box-shadow:none;background:none;animation:none}
  .emergency-float-btn{width:48px;height:48px;border-radius:50%;background:none;box-shadow:none}
  .emergency-float-btn:hover{background:none}
  .emergency-float-btn svg{width:28px;height:28px;fill:var(--red)}

  /* Contact info cards */
  .contact-info-card{padding:1rem}
  .contact-info-icon{width:38px;height:38px;min-width:38px}
  .contact-emergency{flex-direction:column;text-align:center;gap:0.75rem;padding:1.25rem}

  /* About */
  .about-img{min-height:240px}
  .about-img img{min-height:240px}

  /* Testimonial */
  .testimonial-section{padding:3rem 0}
  .testimonial-card blockquote{font-size:0.92rem}
  .testimonial-quote-mark{font-size:4rem}

  /* Cert */
  .cert-card{padding:1.5rem}
  .cert-card h2{font-size:1.5rem}

  /* Mobile menu */
  .mobile-menu{padding:1.25rem}
  .mobile-menu nav a{font-size:1rem;padding:0.95rem 0}

  /* Buttons — minimum touch target 44px */
  .btn{min-height:44px}
  .service-nav-link{min-height:44px;padding:0.5rem 1rem}
}

/* ---- REDUCED MOTION ---- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important}
  .hero-tag,.hero-accent-line,.hero h1,.hero-desc,.hero-actions{animation:none!important;opacity:1!important;transform:none!important}
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
  body{animation:none!important}
}

/* ---- TOUCH DEVICE OPTIMIZATIONS ---- */
@media(hover:none){
  /* Disable hover-dependent animations on touch — show cards in default state */
  .svc-card:active::before{transform:translateY(0)}
  .svc-card:active{transform:translateY(-4px)}
  .svc-card:active h3{color:var(--white)}
  .svc-card:active p{color:rgba(255,255,255,0.85)}
  .svc-card:active .card-arrow{opacity:1;transform:translateY(0)}
  .svc-card:active .svc-card-line .svc-line-color{background:var(--white);width:50px}
  .svc-card:active .svc-card-line .svc-line-gray{background:rgba(255,255,255,0.25)}
  .svc-card:active .ico-stroke{stroke:var(--white)}
  .svc-card:active .ico-fill{fill:var(--white);opacity:0.25}
  .svc-card:active .ico-accent{stroke:rgba(255,255,255,0.9)}
  .svc-card:active .ico-detail{stroke:rgba(255,255,255,0.5)}
  .svc-card:active .ico-dot{fill:rgba(255,255,255,0.6)}

  /* Feature cards */
  .feature-card:active{transform:translateY(-4px);box-shadow:var(--shadow-xl)}
  .feature-card:active::before{transform:scaleX(1)}

  /* Reduce motion for performance */
  .reveal{transition-duration:0.4s}
}
