/* ============================================================
   PHOENIX AUTO GLASS REPAIRS — Service Pages
   Desert Sky Theme — Navy #0f2744 + Burnt Orange #e05c1a
   ============================================================ */

:root {
  --orange:        #e05c1a;
  --orange-dark:   #c04a10;
  --orange-light:  #f07540;
  --orange-glow:   rgba(224,92,26,0.28);
  --navy:          #0f2744;
  --navy2:         #1a3556;
  --navy3:         #2a4a6e;
  --navy4:         #4a6a8e;
  --light-bg:      #f7f9fc;
  --cream:         #f2f4f8;
  --white:         #ffffff;
  --text-on-dark:  #cfd9e8;
  --text-muted:    #8da4bc;
  --text-body:     #2d3e52;
  --border-dark:   rgba(255,255,255,0.08);
  --border-light:  #dde4ed;
  --radius:        16px;
  --radius-sm:     10px;
  --shadow-sm:     0 1px 4px rgba(0,0,0,0.08);
  --shadow-md:     0 4px 20px rgba(0,0,0,0.14);
  --shadow-lg:     0 8px 40px rgba(0,0,0,0.20);
  --shadow-orange: 0 4px 24px rgba(224,92,26,0.28);
}

*,*::before,*::after{box-sizing:border-box;}
body{font-family:'DM Sans',system-ui,sans-serif;color:var(--text-body);background:#fff;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
h1,h2,h3,h4,h5,h6{font-family:'Barlow Condensed',system-ui,sans-serif;line-height:1.05;letter-spacing:0.01em;font-weight:700;color:var(--navy);}
a{text-decoration:none;color:inherit;}
img{max-width:100%;height:auto;}

/* Scroll Reveal */
.sr{opacity:0;transform:translateY(30px);transition:opacity .75s cubic-bezier(.22,1,.36,1),transform .75s cubic-bezier(.22,1,.36,1);}
.sr.visible{opacity:1;transform:translateY(0);}
.sr-delay-1{transition-delay:.08s;}.sr-delay-2{transition-delay:.16s;}.sr-delay-3{transition-delay:.24s;}
.sr-delay-4{transition-delay:.32s;}.sr-delay-5{transition-delay:.40s;}.sr-delay-6{transition-delay:.48s;}

/* Accent bar */
.nav-accent-bar{height:3px;background:linear-gradient(90deg,var(--navy),var(--orange) 50%,var(--orange-light));position:fixed;top:0;left:0;right:0;z-index:1050;}

/* Top Bar */
.site-topbar{background:var(--navy);color:var(--text-muted);font-size:.80rem;padding:7px 0;position:fixed;top:3px;left:0;right:0;z-index:1040;border-bottom:1px solid var(--border-dark);}
.site-topbar .container{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;max-width:1280px;margin:0 auto;padding:0 24px;}
.topbar-phone{display:inline-flex;align-items:center;gap:7px;color:var(--orange-light);font-weight:700;font-size:.85rem;transition:color .2s;}
.topbar-phone:hover{color:#fff;}
.topbar-hours{color:var(--text-muted);font-size:.78rem;}
.topbar-badge{display:inline-flex;align-items:center;gap:5px;background:rgba(224,92,26,.12);border:1px solid rgba(224,92,26,.25);border-radius:100px;padding:3px 10px;font-size:.72rem;font-weight:600;color:var(--orange-light);}

/* Navbar */
.site-nav{background:rgba(15,39,68,.97);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 2px 20px rgba(0,0,0,.28);position:fixed;top:35px;left:0;right:0;z-index:1030;transition:box-shadow .3s;border-bottom:1px solid var(--border-dark);}
.site-nav.scrolled{box-shadow:0 4px 32px rgba(0,0,0,.38);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:.7rem 1.5rem;max-width:1280px;margin:0 auto;gap:1rem;}
.nav-brand-text{font-family:'Barlow Condensed',system-ui,sans-serif;font-size:1.35rem;font-weight:800;color:#fff;line-height:1.1;letter-spacing:0.04em;text-transform:uppercase;}
.nav-brand-text span{color:var(--orange-light);}
.nav-links{display:flex;align-items:center;gap:.15rem;}
.nav-links>a{color:var(--text-on-dark);font-weight:600;font-size:.90rem;padding:.55rem 1rem;border-radius:8px;transition:color .2s,background .2s;}
.nav-links>a:hover,.nav-links>a.active{color:var(--orange-light);background:rgba(224,92,26,.10);}
.nav-dropdown-wrap{position:relative;}
.nav-dropdown-btn{display:inline-flex;align-items:center;gap:6px;color:var(--text-on-dark);font-weight:600;font-size:.90rem;padding:.55rem 1rem;border-radius:8px;border:none;background:transparent;cursor:pointer;transition:color .2s,background .2s;}
.nav-dropdown-btn:hover,.nav-dropdown-wrap.open .nav-dropdown-btn{color:var(--orange-light);background:rgba(224,92,26,.10);}
.dd-chevron{width:13px;height:13px;transition:transform .25s;color:var(--text-muted);}
.nav-dropdown-wrap.open .dd-chevron{transform:rotate(180deg);}
.nav-services-panel{display:none;position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%);background:var(--navy2);border:1px solid var(--border-dark);border-top:2px solid var(--orange);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:1.25rem;min-width:520px;z-index:200;animation:dropIn .2s cubic-bezier(.22,1,.36,1);}
.nav-dropdown-wrap.open .nav-services-panel{display:block;}
@keyframes dropIn{from{opacity:0;transform:translateX(-50%) translateY(-8px);}to{opacity:1;transform:translateX(-50%) translateY(0);}}
.services-panel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem;}
.service-panel-item{display:flex;align-items:center;gap:10px;padding:.65rem .8rem;border-radius:10px;color:var(--text-on-dark);font-size:.85rem;font-weight:500;transition:background .2s,color .2s;}
.service-panel-item:hover,.service-panel-item.active{background:rgba(224,92,26,.12);color:var(--orange-light);}
.service-panel-icon{width:32px;height:32px;border-radius:8px;background:rgba(224,92,26,.12);border:1px solid rgba(224,92,26,.25);display:flex;align-items:center;justify-content:center;color:var(--orange-light);flex-shrink:0;font-size:.85rem;}
.nav-cta-phone{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--orange),var(--orange-dark));color:#fff!important;font-weight:800;font-size:.87rem;padding:.6rem 1.4rem;border-radius:100px;box-shadow:var(--shadow-orange);margin-left:.5rem;white-space:nowrap;transition:filter .2s,transform .2s,box-shadow .2s;}
.nav-cta-phone:hover{filter:brightness(1.12);transform:translateY(-2px);box-shadow:0 6px 28px rgba(224,92,26,.45);}
.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;border:none;background:transparent;}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--text-on-dark);border-radius:2px;transition:all .3s;}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.nav-mobile-menu{display:none;flex-direction:column;background:var(--navy2);border-top:1px solid var(--border-dark);padding:1rem 1.5rem 1.5rem;gap:.2rem;position:fixed;top:95px;left:0;right:0;max-height:calc(100vh - 95px);overflow-y:auto;z-index:1029;}
.nav-mobile-menu.open{display:flex;}
.nav-mobile-menu a,.nav-mobile-menu button{color:var(--text-on-dark);font-size:.95rem;font-weight:500;padding:.65rem .75rem;border-radius:8px;display:block;border:none;background:transparent;text-align:left;cursor:pointer;transition:background .2s,color .2s;width:100%;}
.nav-mobile-menu a:hover,.nav-mobile-menu button:hover{background:rgba(224,92,26,.10);color:var(--orange-light);}
.nav-mobile-menu .mobile-submenu{display:none;padding-left:1rem;margin-top:.2rem;}
.nav-mobile-menu .mobile-submenu.open{display:block;}
.nav-mobile-cta{margin-top:.75rem;display:block;background:linear-gradient(135deg,var(--orange),var(--orange-dark))!important;color:#fff!important;text-align:center!important;border-radius:100px!important;padding:.8rem 1rem!important;font-weight:800!important;}

/* Sticky Call */
.sticky-call-btn{position:fixed;bottom:28px;left:24px;z-index:999;display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--orange),var(--orange-dark));color:#fff!important;font-weight:800;font-size:.9rem;padding:13px 22px;border-radius:100px;box-shadow:var(--shadow-orange);animation:pulseOrange 2.2s ease-in-out infinite;transition:transform .25s,box-shadow .25s;text-decoration:none;letter-spacing:.01em;}
.sticky-call-btn:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 10px 36px rgba(224,92,26,.50);}
.sticky-call-btn .call-icon{animation:ring 3s ease-in-out infinite;font-size:1rem;}
@keyframes pulseOrange{0%,100%{box-shadow:0 4px 24px rgba(224,92,26,.32);}50%{box-shadow:0 4px 36px rgba(224,92,26,.58);}}
@keyframes ring{0%,80%,100%{transform:rotate(0deg);}85%{transform:rotate(-15deg);}90%{transform:rotate(15deg);}95%{transform:rotate(-10deg);}}

/* Page offset */
.page-body{padding-top:103px;}

/* Buttons */
.btn-primary-orange{display:inline-flex;align-items:center;justify-content:center;gap:9px;background:linear-gradient(135deg,var(--orange),var(--orange-dark));color:#fff;font-size:1rem;font-weight:800;padding:15px 34px;border:none;border-radius:12px;cursor:pointer;position:relative;overflow:hidden;box-shadow:var(--shadow-orange);transition:transform .18s,box-shadow .18s,filter .18s;letter-spacing:.02em;text-decoration:none;}
.btn-primary-orange::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.14) 0%,transparent 60%);pointer-events:none;}
.btn-primary-orange:hover{transform:translateY(-2px);filter:brightness(1.10);box-shadow:0 8px 32px rgba(224,92,26,.48);color:#fff;}
.btn-outline-dark{display:inline-flex;align-items:center;justify-content:center;gap:9px;background:transparent;color:var(--navy);font-size:1rem;font-weight:700;padding:14px 30px;border:2px solid rgba(15,39,68,.25);border-radius:12px;cursor:pointer;transition:border-color .2s,color .2s,background .2s;text-decoration:none;}
.btn-outline-dark:hover{border-color:var(--orange-dark);color:var(--orange-dark);background:rgba(224,92,26,.05);}
.btn-outline-light{display:inline-flex;align-items:center;justify-content:center;gap:9px;background:transparent;color:#fff;font-size:1rem;font-weight:700;padding:14px 30px;border:2px solid rgba(255,255,255,.28);border-radius:12px;cursor:pointer;transition:border-color .2s,background .2s,color .2s;text-decoration:none;}
.btn-outline-light:hover{border-color:var(--orange-light);color:var(--orange-light);background:rgba(224,92,26,.08);}

/* Section utilities */
.container{max-width:1240px;margin:0 auto;padding:0 24px;}
.section-pad{padding:88px 0;}
.section-pad-sm{padding:64px 0;}
.bg-light-section{background:var(--light-bg);}
.bg-cream-section{background:var(--cream);}

.section-badge{display:inline-flex;align-items:center;gap:7px;background:rgba(224,92,26,.10);border:1.5px solid rgba(224,92,26,.28);border-radius:100px;padding:5px 16px;font-size:.76rem;font-weight:700;color:var(--orange-dark);text-transform:uppercase;letter-spacing:.09em;margin-bottom:1rem;}
.section-title{font-family:'Barlow Condensed',system-ui,sans-serif;font-size:clamp(2.2rem,3.4vw,3.2rem);font-weight:800;color:var(--navy);margin-bottom:.5rem;line-height:1.0;letter-spacing:0.01em;}
.section-title-light{color:#fff;}
.section-title-underline{display:block;width:52px;height:4px;background:linear-gradient(90deg,var(--orange),var(--orange-dark));border-radius:2px;margin:.65rem auto 0;}
.section-subtitle{font-size:1.07rem;color:var(--navy4);line-height:1.78;max-width:640px;margin-top:1rem;}
.section-heading-center{text-align:center;margin-bottom:3.5rem;}
.section-heading-center .section-subtitle{margin:1rem auto 0;}

/* ============================================================
   HERO — two-column split (left: white, right: navy CSS atmosphere)
   ============================================================ */
.hero-wrap{display:grid;grid-template-columns:58fr 42fr;min-height:calc(100vh - 103px);border-top:3px solid var(--orange);gap:0;}

/* .hero-inner wraps .hero-left in all service pages */
.hero-inner{background:#fff;padding:72px 60px 72px 68px;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:2;overflow:hidden;}
.hero-inner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 55% 45% at -5% 0%,rgba(224,92,26,.055) 0%,transparent 70%),radial-gradient(ellipse 40% 40% at 105% 100%,rgba(15,39,68,.04) 0%,transparent 70%);pointer-events:none;z-index:0;}
.hero-inner::after{content:'';position:absolute;left:0;top:15%;bottom:15%;width:4px;background:linear-gradient(to bottom,transparent,var(--orange) 30%,var(--orange-dark) 70%,transparent);border-radius:0 2px 2px 0;z-index:1;}

.hero-left{background:#fff;display:flex;flex-direction:column;justify-content:center;gap:22px;position:relative;z-index:2;}
.hero-right{position:relative;background:var(--navy);overflow:hidden;}
/* Layered radial glows */
.hero-right::before{content:'';position:absolute;inset:0;z-index:0;background:radial-gradient(ellipse 70% 55% at 80% 15%,rgba(224,92,26,.18) 0%,transparent 60%),radial-gradient(ellipse 80% 60% at 20% 85%,rgba(26,53,86,.95) 0%,transparent 65%),radial-gradient(ellipse 50% 50% at 50% 50%,rgba(30,60,100,.60) 0%,transparent 100%);}
/* Grid line overlay */
.hero-right::after{content:'';position:absolute;inset:0;z-index:1;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;}
.hero-form-float{position:relative;z-index:3;display:flex;align-items:center;justify-content:center;padding:48px 32px 80px;height:100%;}
.hero-photo-badge{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);z-index:4;display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.07);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);border-radius:100px;padding:8px 20px;color:rgba(255,255,255,.75);font-size:.73rem;font-weight:600;white-space:nowrap;letter-spacing:.02em;}
.hero-photo-badge i{color:var(--orange-light);}

.hero-trust-bar{display:flex;align-items:center;flex-wrap:wrap;gap:7px;}
.trust-pill{display:inline-flex;align-items:center;gap:6px;background:var(--light-bg);border:1.5px solid var(--border-light);border-radius:6px;padding:5px 12px;font-size:.70rem;font-weight:700;color:var(--navy3);letter-spacing:.05em;text-transform:uppercase;transition:border-color .2s,background .2s;}
.trust-pill:hover{border-color:rgba(224,92,26,.40);background:#fff5f0;}
.trust-pill i{font-size:.65rem;color:var(--orange);}

.hero-headline{font-family:'Barlow Condensed',system-ui,sans-serif;font-size:clamp(2.6rem,4.2vw,4.6rem);font-weight:900;line-height:1.0;letter-spacing:0.01em;color:var(--navy);margin:0;}
.hero-headline .h1-accent{color:var(--orange-dark);font-style:italic;display:block;}
.hero-desc{font-size:1.02rem;line-height:1.74;color:var(--navy4);max-width:500px;margin:0;}

.hero-checklist{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:9px 20px;border-top:1px solid var(--border-light);padding-top:16px;}
.hero-checklist li{display:flex;align-items:center;gap:9px;font-size:.86rem;font-weight:500;color:var(--text-body);}
.check-icon{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,var(--orange),var(--orange-dark));display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-size:.55rem;font-weight:900;}

.hero-cta-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}

/* ============================================================
   FEATURE CARDS GRID  (3-col)
   ============================================================ */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;}
.feature-card{background:#fff;border:1px solid var(--border-light);border-radius:18px;padding:2rem 1.5rem;text-align:center;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s,border-color .3s;position:relative;overflow:hidden;}
.feature-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--orange),var(--orange-dark));transform:scaleX(0);transform-origin:left;transition:transform .35s cubic-bezier(.22,1,.36,1);}
.feature-card:hover::after{transform:scaleX(1);}
.feature-card:hover{transform:translateY(-8px);box-shadow:0 16px 40px rgba(0,0,0,.10);border-color:rgba(224,92,26,.25);}
.feature-icon{width:64px;height:64px;border-radius:18px;background:linear-gradient(135deg,rgba(224,92,26,.12),rgba(224,92,26,.04));border:1.5px solid rgba(224,92,26,.22);display:flex;align-items:center;justify-content:center;font-size:1.6rem;color:var(--orange-dark);margin:0 auto 1.25rem;transition:transform .3s,background .3s;}
.feature-card:hover .feature-icon{transform:scale(1.10) rotate(-4deg);background:linear-gradient(135deg,rgba(224,92,26,.20),rgba(224,92,26,.08));}
.feature-card h3,.feature-card h4{font-size:1.05rem;font-weight:800;margin-bottom:.5rem;color:var(--navy);}
.feature-card p{font-size:.86rem;color:var(--navy4);line-height:1.68;margin:0 0 .5rem;}
.feature-card ul{list-style:none;padding:0;margin:.5rem 0 0;display:flex;flex-direction:column;gap:5px;text-align:left;}
.feature-card ul li{font-size:.84rem;color:var(--navy4);line-height:1.5;padding-left:18px;position:relative;}
.feature-card ul li::before{content:'';position:absolute;left:0;top:7px;width:7px;height:7px;border-radius:50%;background:var(--orange);opacity:.75;}

/* ============================================================
   STANDARD CARDS  (left-border, used for H3 blocks)
   ============================================================ */
.standard-card{background:#fff;border-radius:16px;padding:1.6rem 1.5rem;border-left:4px solid var(--orange);border-top:1px solid var(--border-light);border-right:1px solid var(--border-light);border-bottom:1px solid var(--border-light);box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s;}
.standard-card:hover{transform:translateY(-5px);box-shadow:0 12px 32px rgba(0,0,0,.10);}
.standard-card h3,.standard-card h4{font-size:1rem;font-weight:800;margin:0 0 .55rem;color:var(--navy);}
.standard-card p{font-size:.86rem;line-height:1.68;color:var(--navy4);margin:0;}
.standard-card ul{list-style:none;padding:0;margin:.5rem 0 0;display:flex;flex-direction:column;gap:5px;}
.standard-card ul li{font-size:.84rem;color:var(--navy4);line-height:1.5;padding-left:16px;position:relative;}
.standard-card ul li::before{content:'';position:absolute;left:0;top:7px;width:6px;height:6px;border-radius:50%;background:var(--orange);}

/* flex layout for standard cards */
.cards-flex{display:flex;gap:1.5rem;flex-wrap:wrap;}
.cards-flex .standard-card{flex:1;min-width:260px;}

/* ============================================================
   PROCESS STEPS — legacy grid (kept for compat)
   ============================================================ */
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;position:relative;}
.process-grid::before{content:'';position:absolute;top:40px;left:calc(16.67% + 20px);right:calc(16.67% + 20px);height:2px;background:linear-gradient(90deg,var(--orange),var(--orange-dark));opacity:.30;z-index:0;}
.process-step{text-align:center;position:relative;z-index:1;background:#fff;border:1px solid var(--border-light);border-radius:20px;padding:2.25rem 1.75rem 2rem;transition:transform .3s,box-shadow .3s,border-color .3s;}
.process-step:hover{transform:translateY(-8px);box-shadow:0 20px 48px rgba(0,0,0,.10);border-color:var(--orange);}
.process-step-num{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--orange),var(--orange-dark));color:#fff;font-family:'Barlow Condensed',system-ui,sans-serif;font-size:1.8rem;font-weight:900;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;box-shadow:var(--shadow-orange);}
.process-step h4{font-size:1.05rem;font-weight:800;margin:0 0 .6rem;color:var(--navy);}
.process-step p{font-size:.88rem;line-height:1.70;color:var(--navy4);max-width:240px;margin:0 auto;}

/* ============================================================
   TIMELINE PROCESS — premium vertical layout
   ============================================================ */
.timeline-process{display:flex;flex-direction:column;gap:0;max-width:820px;margin:0 auto;position:relative;}
.timeline-process::before{content:'';position:absolute;left:27px;top:54px;bottom:54px;width:2px;background:linear-gradient(to bottom,var(--orange),var(--orange-dark) 60%,rgba(224,92,26,.15));z-index:0;}
.tl-step{display:grid;grid-template-columns:56px 1fr;gap:0 28px;position:relative;z-index:1;padding:0 0 40px;}
.tl-step:last-child{padding-bottom:0;}
.tl-num{width:56px;height:56px;border-radius:14px;background:var(--navy);border:2px solid var(--orange);color:var(--orange-light);font-family:'Barlow Condensed',system-ui,sans-serif;font-size:1.2rem;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:0.02em;box-shadow:0 4px 16px rgba(15,39,68,.18);position:relative;z-index:2;transition:background .25s,border-color .25s,box-shadow .25s;}
.tl-step:hover .tl-num{background:var(--orange);border-color:var(--orange-dark);color:#fff;box-shadow:0 6px 20px rgba(224,92,26,.38);}
.tl-body{padding:10px 0 0;}
.tl-body b{display:block;font-size:1rem;font-weight:600;color:var(--navy);margin:0 0 .45rem;line-height:1.3;}
.tl-body p{font-size:.90rem;line-height:1.75;color:var(--navy4);margin:0;}
.tl-body ul{list-style:none;padding:0;margin:.65rem 0 0;display:flex;flex-direction:column;gap:5px;}
.tl-body ul li{font-size:.85rem;color:var(--navy4);line-height:1.5;padding-left:18px;position:relative;}
.tl-body ul li::before{content:'';position:absolute;left:0;top:7px;width:7px;height:7px;border-radius:50%;background:var(--orange);opacity:.7;}

/* timeline on dark bg */
.bg-dark-process .timeline-process::before{background:linear-gradient(to bottom,rgba(224,92,26,.8),rgba(224,92,26,.3));}
.bg-dark-process .tl-num{background:rgba(255,255,255,.06);border-color:rgba(224,92,26,.55);color:var(--orange-light);}
.bg-dark-process .tl-body h4{color:#fff;}
.bg-dark-process .tl-body p{color:var(--text-on-dark);}

@media(max-width:540px){
  .timeline-process::before{left:23px;}
  .tl-step{grid-template-columns:46px 1fr;gap:0 18px;}
  .tl-num{width:46px;height:46px;border-radius:10px;font-size:1rem;}
  .tl-body{padding-top:8px;}
  .tl-body h4{font-size:1rem;}
}

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:.65rem;}
.faq-item{border:1px solid rgba(0,0,0,.07);border-radius:12px;background:#fff;box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow .2s;}
.faq-item.open{border-color:rgba(224,92,26,.28);box-shadow:0 4px 20px rgba(224,92,26,.08);}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.15rem 1.35rem;font-size:.97rem;font-weight:700;color:var(--navy);background:transparent;border:none;cursor:pointer;text-align:left;transition:background .2s,color .2s;}
.faq-question:hover{background:var(--light-bg);}
.faq-item.open .faq-question{color:var(--orange-dark);}
.faq-chevron{width:22px;height:22px;border-radius:50%;background:var(--light-bg);border:1px solid var(--border-light);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.65rem;color:var(--navy4);transition:transform .25s,background .2s,color .2s;}
.faq-item.open .faq-chevron{transform:rotate(180deg);background:rgba(224,92,26,.10);border-color:rgba(224,92,26,.28);color:var(--orange-dark);}
.faq-answer{display:none;padding:.9rem 1.35rem 1.2rem;font-size:.92rem;color:var(--navy4);line-height:1.78;border-top:1px solid rgba(0,0,0,.05);}
.faq-item.open .faq-answer{display:block;}

/* ============================================================
   CTA BANNER
   ============================================================ */
.cta-banner{background:linear-gradient(135deg,var(--navy) 0%,var(--navy2) 100%);color:#fff;text-align:center;padding:88px 24px;position:relative;overflow:hidden;}
.cta-banner::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(224,92,26,.07) 1px,transparent 1px);background-size:24px 24px;pointer-events:none;}
.cta-banner h2{font-size:clamp(2.4rem,4vw,3.8rem);font-weight:900;color:#fff;margin-bottom:1rem;letter-spacing:0.01em;position:relative;}
.cta-banner p{font-size:1.1rem;color:rgba(255,255,255,.68);margin:0 auto 2.25rem;max-width:560px;position:relative;line-height:1.75;}
.cta-banner-btns{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;position:relative;}

/* ============================================================
   QUOTE FORM
   ============================================================ */
.qform-outer{width:100%;max-width:460px;}
.qform-wrap{background:#fff;border-radius:20px;padding:32px 32px 26px;box-shadow:0 24px 64px rgba(0,0,0,.22),0 0 0 1px rgba(0,0,0,.05);border-top:4px solid var(--orange);}
.qform-header{margin-bottom:24px;display:flex;align-items:center;gap:14px;padding-bottom:20px;border-bottom:2px solid #f1f5f9;}
.qform-icon{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,var(--orange),var(--orange-dark));display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.15rem;flex-shrink:0;box-shadow:0 6px 18px rgba(224,92,26,.35);}
.qform-title{font-family:'Barlow Condensed',system-ui,sans-serif;font-size:1.45rem;font-weight:800;color:var(--navy);display:block;line-height:1.1;}
.qform-subtitle{font-size:.78rem;color:var(--navy4);display:block;margin-top:3px;}
.qform-field{margin-bottom:14px;}
.qform-label{display:block;font-size:.68rem;font-weight:700;color:var(--navy4);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;}
.qform-input-wrap{position:relative;}
.qform-input-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:#cbd5e1;font-size:.82rem;pointer-events:none;z-index:1;}
.qform-textarea-icon{top:13px;transform:none;}
.qform-input{width:100%;padding:11px 13px 11px 38px;font-size:.90rem;color:var(--navy);background:#f7f9fc;border:1.5px solid #dde4ed;border-radius:10px;outline:none;font-family:'DM Sans',system-ui,sans-serif;transition:border-color .18s,box-shadow .18s,background .18s;}
.qform-input::placeholder{color:#c0ccd8;}
.qform-input:focus{border-color:var(--orange);background:#fff;box-shadow:0 0 0 3px rgba(224,92,26,.12);}
.qform-textarea{resize:none;min-height:76px;padding-top:11px;}
.qform-math-row{display:flex;align-items:center;gap:8px;}
.qform-math-img{border-radius:7px;border:1.5px solid var(--border-light);height:40px;flex-shrink:0;background:var(--light-bg);}
.qform-math-refresh{width:36px;height:36px;border-radius:8px;border:1.5px solid var(--border-light);background:var(--light-bg);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--navy4);flex-shrink:0;transition:background .2s,border-color .2s;}
.qform-math-refresh:hover{background:#fff5f0;border-color:var(--orange);color:var(--orange-dark);}
.qform-math-row .qform-input-wrap{flex:1;min-width:0;}
.qform-submit{margin-top:10px;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:13px 20px;font-size:.93rem;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--orange-light),var(--orange),var(--orange-dark));border:none;border-radius:10px;cursor:pointer;box-shadow:0 4px 18px rgba(224,92,26,.38);transition:transform .18s,filter .18s;font-family:'DM Sans',system-ui,sans-serif;letter-spacing:.03em;text-transform:uppercase;}
.qform-submit:hover:not(:disabled){transform:translateY(-2px);filter:brightness(1.08);box-shadow:0 8px 28px rgba(224,92,26,.50);}
.qform-submit:disabled{opacity:.7;cursor:not-allowed;}
.qform-disclaimer{text-align:center;font-size:.70rem;color:#aaa;margin:8px 0 0;display:flex;align-items:center;justify-content:center;gap:5px;}
.qform-success{text-align:center;padding:1.5rem 0;}
.qform-success-icon{width:56px;height:56px;border-radius:50%;background:#fff5f0;border:2px solid var(--orange);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin:0 auto 1rem;color:var(--orange-dark);}
.qform-success-title{font-weight:800;font-size:1.05rem;color:var(--navy);margin-bottom:.5rem;}
.qform-success-sub{font-size:.84rem;color:var(--navy4);line-height:1.65;}
.qform-success-sub a{color:var(--orange-dark);}
.qform-error-banner{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.84rem;padding:9px 14px;margin-bottom:10px;}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:#070e1a;color:#94a3b8;position:relative;}
.footer-top-line{height:4px;background:linear-gradient(90deg,var(--navy2),var(--orange) 50%,var(--orange-light));}
.footer-inner{max-width:1260px;margin:0 auto;padding:72px 40px 56px;display:grid;grid-template-columns:1.7fr 1fr 2fr 1.4fr;gap:52px;}
.footer-brand-name{font-family:'Barlow Condensed',system-ui,sans-serif;font-size:1.2rem;font-weight:800;color:#fff;line-height:1.2;margin-bottom:1rem;}
.footer-brand-name span{color:var(--orange-light);}
.footer-stars{display:flex;align-items:center;gap:3px;margin-bottom:1rem;}
.footer-stars i{color:var(--orange);font-size:.78rem;}
.footer-stars span{font-size:.78rem;color:#94a3b8;margin-left:5px;}
.footer-desc{font-size:.875rem;color:#64748b;line-height:1.8;margin-bottom:1.5rem;}
.footer-phone-link{display:inline-flex;align-items:center;gap:8px;background:rgba(224,92,26,.12);border:1px solid rgba(224,92,26,.30);color:var(--orange-light);font-weight:700;font-size:.97rem;padding:9px 16px;border-radius:8px;transition:background .2s;}
.footer-phone-link:hover{background:rgba(224,92,26,.20);}
.footer-col h4{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:#fff;margin:0 0 1.25rem;padding-bottom:.65rem;border-bottom:2px solid rgba(224,92,26,.45);display:block;}
.footer-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem;}
.footer-links a{font-size:.855rem;color:#64748b;transition:color .18s,padding-left .18s;display:inline-flex;align-items:center;gap:6px;}
.footer-links a:hover{color:var(--orange-light);padding-left:4px;}
.footer-contact-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:1.1rem;}
.footer-contact-icon{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:var(--orange-light);flex-shrink:0;font-size:.9rem;transition:background .2s;}
.footer-contact-item:hover .footer-contact-icon{background:rgba(224,92,26,.12);border-color:rgba(224,92,26,.30);}
.footer-contact-text{font-size:.855rem;color:#64748b;line-height:1.55;}
.footer-contact-text strong{display:block;color:#cbd5e1;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px;}
.footer-contact-text a{color:var(--orange-light);transition:color .2s;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding:20px 40px;background:rgba(0,0,0,.22);}
.footer-bottom-inner{max-width:1260px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;font-size:.775rem;color:#475569;flex-wrap:wrap;gap:10px;}
.footer-bottom-links{display:flex;align-items:center;gap:6px;}
.footer-bottom-links a{color:#475569;transition:color .2s;font-size:.775rem;padding:2px 6px;}
.footer-bottom-links a:hover{color:var(--orange-light);}
.footer-bottom-links .sep{color:#1e293b;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .hero-wrap{grid-template-columns:1fr;min-height:auto;}
  .hero-inner{padding:52px 32px 48px;}
  .hero-inner::after{display:none;}
  .hero-right{min-height:auto;}
  .hero-form-float{padding:36px 24px 72px;align-items:flex-start;}
  .features-grid{grid-template-columns:repeat(2,1fr);}
  .process-grid{grid-template-columns:repeat(2,1fr);}
  .process-grid::before{display:none;}
  .footer-inner{grid-template-columns:1fr 1fr;gap:32px;padding:56px 28px 44px;}
}
@media(max-width:768px){
  .nav-links,.nav-cta-phone{display:none;}
  .nav-toggle{display:flex;}
  .page-body{padding-top:95px;}
  .hero-inner{padding:40px 20px;}
  .hero-checklist{grid-template-columns:1fr 1fr;}
  .features-grid{grid-template-columns:1fr 1fr;}
  .process-grid{grid-template-columns:1fr;}
  .cards-flex{flex-direction:column;}
  .section-pad{padding:64px 0;}
  .cta-banner{padding:64px 20px;}
  .footer-inner{grid-template-columns:1fr 1fr;gap:24px;padding:40px 20px 32px;}
  .footer-bottom{padding:16px 20px;}
}
@media(max-width:540px){
  .features-grid{grid-template-columns:1fr;}
  .hero-checklist{grid-template-columns:1fr;}
  .footer-inner{grid-template-columns:1fr;padding:36px 16px 28px;}
  .sticky-call-btn{bottom:16px;left:14px;padding:11px 18px;font-size:.85rem;}
  .qform-wrap{padding:24px 18px;}
  .qform-outer{max-width:100%;}
}

/* ============================================================
   PREMIUM DESIGN ENHANCEMENTS
   ============================================================ */

/* --- Feature cards: staggered alternate rows + top-line reveal --- */
.features-grid .feature-card:nth-child(even) { margin-top: 20px; }

.feature-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--orange), var(--orange-light), transparent);
  transform: scaleX(0); transform-origin: left;
  transition: transform 0.45s cubic-bezier(0.22,1,0.36,1);
}
.feature-card:hover::before { transform: scaleX(1); }

/* --- Standard cards: stronger left border + hover glow --- */
.standard-card {
  border-left-width: 4px;
  transition: transform 0.3s, box-shadow 0.3s, border-left-color 0.3s;
}
.standard-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 40px rgba(15,39,68,0.10);
  border-left-color: var(--orange-dark);
}

/* --- Section headings: watermark-style section label --- */
.section-heading-center { position: relative; }

/* --- Timeline enhancements: body content pull-quote style --- */
.tl-body {
  background: #fff;
  border: 1px solid var(--border-light);
  border-radius: 16px;
  padding: 20px 24px;
  box-shadow: var(--shadow-sm);
  transition: box-shadow 0.3s, transform 0.3s;
}
.tl-step:hover .tl-body {
  box-shadow: 0 8px 28px rgba(15,39,68,0.10);
  transform: translateX(4px);
}
.tl-body b  { display: block; font-size: 1rem; font-weight: 600; color: var(--navy); margin: 0 0 .45rem; line-height: 1.3; }
.tl-body p  { font-size: 0.91rem; font-weight: 400; color: var(--text-muted); margin: 0; line-height: 1.75; }

/* Adjust timeline line to account for new body padding */
.timeline-process::before { left: 27px; top: 60px; bottom: 60px; }

/* --- FAQ: open answer tint --- */
.faq-item { border-left: 3px solid transparent; }
.faq-item.open { border-left-color: var(--orange); }
.faq-item.open .faq-answer { background: rgba(224,92,26,0.04); border-radius: 0 0 10px 10px; }

/* --- CTA Banner: diagonal stripe bg + urgency glow on button --- */
.cta-banner::before {
  background-image:
    repeating-linear-gradient(
      -45deg,
      transparent, transparent 14px,
      rgba(255,255,255,0.015) 14px, rgba(255,255,255,0.015) 15px
    );
  background-size: auto;
}
@keyframes ctaBtnGlow { 0%,100% { box-shadow: 0 4px 24px rgba(224,92,26,0.32); } 50% { box-shadow: 0 8px 36px rgba(224,92,26,0.56); } }
.cta-banner .btn-primary-orange { animation: ctaBtnGlow 2.4s ease-in-out infinite; }
.cta-banner .btn-primary-orange .fa-arrow-right { transition: transform 0.2s; }
.cta-banner .btn-primary-orange:hover .fa-arrow-right { transform: translateX(5px); }

/* --- Section-title underline: centered default --- */
.section-title-underline { margin: 0.65rem 0 0; }
.section-heading-center .section-title-underline { margin: 0.65rem auto 0; }

/* --- Page section alternation visual interest: subtle left accent line on light sections --- */
.bg-light-section { position: relative; }

/* --- Responsive fixes for enhancements --- */
@media(max-width:1024px){
  .features-grid .feature-card:nth-child(even) { margin-top: 0; }
}
@media(max-width:768px){
  .tl-body { padding: 16px 18px; }
}

/* --- Service section intro: 2-col card (text left, image right) --- */
.svc-section-intro {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 0;
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 4px 32px rgba(15,39,68,.10);
  border: 1px solid var(--border-light);
  margin-bottom: 2.5rem;
}
.svc-section-intro__body {
  padding: 2.5rem 3rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.svc-section-intro__body .section-badge { display: inline-flex; margin-bottom: 1rem; }
.svc-section-intro__body .section-title { text-align: left; font-size: clamp(1.5rem, 2.2vw, 2.2rem); margin-bottom: .4rem; }
.svc-section-intro__body .section-title-underline { display:block; width:48px; height:4px; background:linear-gradient(90deg,var(--orange),var(--orange-dark)); border-radius:2px; margin:0.6rem 0 1rem; }
.svc-section-intro__body .svc-intro-subtitle { font-size:.97rem; color:var(--text-muted); line-height:1.8; margin:0; }
.svc-section-intro__pic { position: relative; overflow: hidden; min-height: 320px; }
.svc-section-intro__pic img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center 15%; display: block; }

/* icon list (used inside svc-section-intro__body) */
.svc-icon-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .75rem; }
.svc-icon-list__item { display: flex; align-items: flex-start; gap: 12px; }
.svc-icon-list__icon { width: 36px; height: 36px; min-width: 36px; border-radius: 10px; background: rgba(224,92,26,.10); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.svc-icon-list__icon i { color: var(--orange); font-size: .9rem; }
.svc-icon-list__label { display: block; color: var(--navy); font-size: .93rem; font-weight: 600; margin-bottom: 2px; }
.svc-icon-list__desc { font-size: .88rem; color: var(--text-muted); margin: 0; line-height: 1.65; }

@media(max-width:1024px) { .svc-section-intro { grid-template-columns: 1fr 300px; } }
@media(max-width:768px) {
  .svc-section-intro { grid-template-columns: 1fr; }
  .svc-section-intro__body { padding: 1.5rem 1.25rem; order: 1; }
  .svc-section-intro__pic { min-height: 220px; order: 2; }
}
