

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}


:root{

  --teal:#1B9E8E;

  --teal2:#13B5A3;

  --teal-dark:#0E7A6D;

  --teal-bg:#E8F7F5;

  --teal-mid:#C5EEE9;

  --orange:#F5820A;

  --orange2:#FF9020;

  --navy:#0D1F3C;

  --white:#fff;

  --light:#F4FAFA;

  --dark:#0D2B2A;

  --mid:#2D5C56;

  --muted:#6B9E99;

  --border:#C5EEE9;

}


html{scroll-behavior:smooth;}

body{font-family:'Inter',sans-serif;background:var(--teal-bg);color:var(--dark);overflow-x:hidden;-webkit-font-smoothing:antialiased;min-height:100vh;}


/* NAV */

nav{background:var(--white);height:68px;padding:0 5%;display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid var(--border);position:sticky;top:0;z-index:100;box-shadow:0 2px 12px rgba(13,43,42,0.06);}

.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;}

.nav-logo img{height:50px;width:auto;object-fit:contain;}

.nav-logo-fallback{display:none;align-items:center;gap:10px;}

.logo-text span{display:block;}

.logo-text span:first-child{font-size:16px;font-weight:900;color:var(--navy);letter-spacing:0.06em;}

.logo-text span:last-child{font-size:8px;color:var(--muted);letter-spacing:0.12em;text-transform:uppercase;}

.nav-phone{display:flex;align-items:center;gap:10px;text-decoration:none;}

.nav-phone-icon{width:42px;height:42px;border-radius:50%;background:var(--orange);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 14px rgba(245,130,10,0.35);animation:phonePulse 2.5s ease infinite;}

@keyframes phonePulse{0%,100%{box-shadow:0 4px 14px rgba(245,130,10,0.35);}50%{box-shadow:0 4px 20px rgba(245,130,10,0.60);}}

.nav-phone-icon svg{width:20px;height:20px;}

.nav-phone-text span:first-child{display:block;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:0.08em;}

.nav-phone-text strong{font-size:20px;font-weight:900;color:var(--navy);letter-spacing:-0.5px;}


/* TOP BRAND BANNER SLIDER */

.brand-banner{background:linear-gradient(135deg,#062c2a,#0D1F3C);padding:34px 5% 38px;position:relative;overflow:hidden;}

.brand-banner::before{content:"";position:absolute;right:-90px;top:-40px;width:260px;height:90px;background:var(--orange);border-radius:999px;transform:rotate(-25deg);opacity:.85;}

.brand-banner-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1.15fr;gap:34px;align-items:center;position:relative;z-index:2;}

.banner-copy{color:#fff;}

.banner-eyebrow{font-size:11px;font-weight:900;color:#FFB76E;letter-spacing:.16em;text-transform:uppercase;margin-bottom:10px;}

.banner-copy h1{font-size:clamp(34px,4.2vw,58px);line-height:1.02;font-weight:900;letter-spacing:-1px;}

.banner-copy h1 span{color:var(--orange);}

.banner-copy p{margin-top:14px;color:#DDF4F1;font-size:16px;line-height:1.65;font-weight:600;max-width:560px;}

.banner-areas{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px;}

.banner-areas span{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.14);color:#fff;padding:7px 11px;border-radius:999px;font-size:11px;font-weight:800;}

.banner-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:22px;}

.banner-call,.banner-quote{display:inline-flex;align-items:center;justify-content:center;padding:14px 20px;border-radius:9px;font-size:14px;font-weight:900;text-transform:uppercase;text-decoration:none;transition:.25s;}

.banner-call{background:var(--orange);color:#fff;box-shadow:0 8px 24px rgba(245,130,10,.35);}

.banner-call:hover{background:var(--orange2);transform:translateY(-2px);}

.banner-quote{background:#fff;color:var(--navy);}

.banner-quote:hover{transform:translateY(-2px);}


/* SLIDER */

.media-slider{position:relative;height:410px;border-radius:22px;overflow:hidden;box-shadow:0 24px 70px rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.18);background:#082b29;}

.slide{position:absolute;inset:0;opacity:0;transform:scale(1.04);transition:opacity .7s ease,transform .7s ease;cursor:pointer;}

.slide.active{opacity:1;transform:scale(1);z-index:2;}

.slide img,.slide video{width:100%;height:100%;object-fit:cover;display:block;}

.slide::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 42%,rgba(13,31,60,.78));}

.slide-caption{position:absolute;left:18px;right:18px;bottom:18px;z-index:4;color:#fff;}

.slide-caption small{display:inline-block;background:var(--orange);padding:5px 9px;border-radius:6px;font-size:10px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;}

.slide-caption strong{display:block;font-size:22px;line-height:1.1;font-weight:900;}

.slide-caption span{display:block;color:#DDF4F1;font-size:13px;margin-top:4px;font-weight:600;}

.slider-controls{position:absolute;top:16px;right:16px;display:flex;gap:8px;z-index:10;}

.slider-controls button{width:38px;height:38px;border:none;border-radius:50%;background:rgba(255,255,255,.92);color:var(--navy);font-size:18px;font-weight:900;cursor:pointer;transition:.2s;}

.slider-controls button:hover{background:var(--orange);color:#fff;}

.slider-dots{position:absolute;left:18px;top:18px;z-index:10;display:flex;gap:7px;}

.slider-dots button{width:9px;height:9px;border:none;border-radius:50%;background:rgba(255,255,255,.45);cursor:pointer;}

.slider-dots button.active{background:var(--orange);}


/* MAIN */

.main{display:grid;grid-template-columns:420px 1fr;min-height:calc(100vh - 68px);max-width:1200px;margin:0 auto;padding:48px 5%;gap:60px;align-items:start;}


/* LEFT FORM */

.form-panel{background:var(--white);border-radius:16px;padding:36px 32px 28px;box-shadow:0 8px 40px rgba(13,43,42,0.12);border:1px solid var(--border);position:sticky;top:84px;}

.form-panel-eyebrow{font-size:11px;font-weight:800;color:var(--teal);text-transform:uppercase;letter-spacing:0.14em;margin-bottom:8px;display:flex;align-items:center;gap:8px;}

.form-panel-eyebrow::before{content:'';width:20px;height:2px;background:var(--teal);border-radius:2px;flex-shrink:0;}

.form-panel h2{font-size:24px;font-weight:900;color:var(--teal);line-height:1.20;margin-bottom:6px;text-transform:uppercase;letter-spacing:0.02em;}

.form-panel-sub{font-size:13px;color:var(--muted);margin-bottom:22px;line-height:1.5;}

.fi{margin-bottom:12px;}

.fi input,.fi select{width:100%;padding:14px 16px;background:#F4FAFA;border:1.5px solid var(--border);border-radius:8px;font-size:15px;color:var(--dark);font-family:'Inter',sans-serif;outline:none;transition:border-color 0.2s,background 0.2s;appearance:none;-webkit-appearance:none;}

.fi input:focus,.fi select:focus{border-color:var(--teal);background:var(--white);box-shadow:0 0 0 3px rgba(27,158,142,0.12);}

.fi input::placeholder{color:#9BC4BF;}

.fi select{background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B9E99' stroke-width='1.8' stroke-linecap='round' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-color:#F4FAFA;cursor:pointer;}

.fi select option{background:#fff;color:var(--dark);}

.btn-submit{width:100%;margin-top:4px;margin-bottom:16px;background:var(--orange);color:#fff;padding:16px 20px;border-radius:8px;font-size:16px;font-weight:800;border:none;cursor:pointer;text-transform:uppercase;letter-spacing:0.06em;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 6px 22px rgba(245,130,10,0.40);transition:all 0.25s;position:relative;overflow:hidden;}

.btn-submit::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.15),transparent);transform:translateX(-100%);transition:transform 0.5s;}

.btn-submit:hover{background:var(--orange2);transform:translateY(-2px);box-shadow:0 10px 28px rgba(245,130,10,0.50);}

.btn-submit:hover::after{transform:translateX(100%);}

.btn-submit svg{width:20px;height:20px;flex-shrink:0;}

.form-privacy{font-size:11px;color:#9BC4BF;line-height:1.60;padding-top:12px;border-top:1px solid var(--border);}


/* RIGHT VALUE */

.vs-headline{font-size:clamp(30px,3.8vw,50px);font-weight:900;color:var(--dark);line-height:1.10;letter-spacing:-0.5px;margin-bottom:18px;}

.vs-headline em{color:var(--teal);font-style:normal;text-decoration:underline;text-underline-offset:5px;text-decoration-thickness:3px;}

.vs-sub{font-size:17px;font-weight:600;color:var(--mid);line-height:1.65;margin-bottom:28px;max-width:520px;}

.vs-checks{display:flex;flex-direction:column;gap:14px;margin-bottom:36px;}

.vs-check{display:flex;align-items:flex-start;gap:14px;}

.vs-check-icon{width:28px;height:28px;border-radius:50%;background:var(--teal);flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:1px;box-shadow:0 3px 10px rgba(27,158,142,0.30);}

.vs-check-icon svg{width:14px;height:14px;}

.vs-check-text{font-size:15px;color:var(--mid);line-height:1.55;font-weight:500;}

.vs-check-text strong{color:var(--dark);font-weight:700;}


/* STATS */

.stats-row{display:flex;gap:0;background:var(--white);border-radius:12px;border:1px solid var(--border);overflow:hidden;margin-bottom:36px;box-shadow:0 4px 16px rgba(13,43,42,0.06);}

.stat-item{flex:1;padding:18px 16px;text-align:center;border-right:1px solid var(--border);}

.stat-item:last-child{border-right:none;}

.stat-num{font-size:28px;font-weight:900;color:var(--teal);line-height:1;}

.stat-num span{color:var(--orange);}

.stat-lbl{font-size:11px;color:var(--muted);margin-top:4px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;line-height:1.3;}

.stat-stars{color:#F59E0B;font-size:16px;letter-spacing:2px;}


/* PHOTO GRID */

.vs-photos{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:170px 170px;gap:10px;margin-bottom:28px;}

.vs-photo{border-radius:10px;overflow:hidden;cursor:pointer;position:relative;background:#C5EEE9;}

.vs-photo:first-child{grid-row:span 2;grid-column:span 1;}

.vs-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.4s ease;}

.vs-photo:hover img{transform:scale(1.06);}

.vs-photo-overlay{position:absolute;inset:0;background:rgba(13,43,42,0.45);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity 0.25s;}

.vs-photo:hover .vs-photo-overlay{opacity:1;}

.photo-badge{position:absolute;bottom:12px;left:12px;background:var(--orange);color:#fff;font-size:11px;font-weight:800;padding:4px 10px;border-radius:5px;text-transform:uppercase;letter-spacing:0.08em;z-index:2;}


/* REVIEWS */

.reviews-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:0;}

.rev-card{background:var(--white);border-radius:10px;padding:16px;border:1px solid var(--border);box-shadow:0 2px 8px rgba(13,43,42,0.05);transition:box-shadow 0.25s;}

.rev-card:hover{box-shadow:0 6px 20px rgba(13,43,42,0.10);}

.rev-stars{color:#F59E0B;font-size:12px;letter-spacing:1px;margin-bottom:8px;}

.rev-text{font-size:13px;color:var(--mid);line-height:1.65;margin-bottom:10px;font-style:italic;}

.rev-author{font-size:12px;font-weight:700;color:var(--dark);}


/* ============================================

   5-STEP PROCESS SECTION — ANIMATED

   ============================================ */

.process-section{

  background:linear-gradient(160deg,#062c2a 0%,#0D1F3C 55%,#0a2a27 100%);

  padding:80px 5% 90px;

  position:relative;

  overflow:hidden;

}


.process-section::before{

  content:'';

  position:absolute;

  top:-120px;

  right:-100px;

  width:400px;

  height:400px;

  background:radial-gradient(circle,rgba(27,158,142,0.18) 0%,transparent 70%);

  pointer-events:none;

}


.process-section::after{

  content:'';

  position:absolute;

  bottom:-80px;

  left:-60px;

  width:300px;

  height:300px;

  background:radial-gradient(circle,rgba(245,130,10,0.12) 0%,transparent 70%);

  pointer-events:none;

}


.process-inner{

  max-width:1200px;

  margin:0 auto;

  position:relative;

  z-index:2;

}


.process-head{

  text-align:center;

  margin-bottom:62px;

}


.process-eyebrow{

  font-size:11px;

  font-weight:900;

  color:#FFB76E;

  text-transform:uppercase;

  letter-spacing:.18em;

  margin-bottom:12px;

}


.process-head h2{

  font-size:clamp(30px,3.6vw,52px);

  font-weight:900;

  color:#fff;

  line-height:1.05;

  letter-spacing:-0.8px;

}


.process-head h2 span{

  color:var(--teal2);

}


.process-head p{

  color:#DDF4F1;

  font-size:16px;

  line-height:1.65;

  margin-top:12px;

  font-weight:500;

  max-width:540px;

  margin-left:auto;

  margin-right:auto;

}


/* STEPS TRACK */

.steps-track{

  display:flex;

  align-items:flex-start;

  justify-content:center;

  gap:0;

  position:relative;

}


/* Connecting line between steps */

.steps-track::before{

  content:'';

  position:absolute;

  top:54px;

  left:calc(10% + 54px);

  right:calc(10% + 54px);

  height:3px;

  background:linear-gradient(90deg,rgba(197,238,233,0.15),rgba(27,158,142,0.40),rgba(197,238,233,0.15));

  z-index:0;

}


.step-item{

  flex:1;

  display:flex;

  flex-direction:column;

  align-items:center;

  text-align:center;

  padding:0 10px;

  position:relative;

  z-index:1;

  cursor:default;

  /* Start hidden for entrance animation */

  opacity:0;

  transform:translateY(40px);

  transition:opacity 0.6s ease, transform 0.6s ease;

}


.step-item.visible{

  opacity:1;

  transform:translateY(0);

}


.step-item:nth-child(1){transition-delay:0s;}

.step-item:nth-child(2){transition-delay:0.15s;}

.step-item:nth-child(3){transition-delay:0.30s;}

.step-item:nth-child(4){transition-delay:0.45s;}

.step-item:nth-child(5){transition-delay:0.60s;}


/* Step icon circle */

.step-icon-wrap{

  width:108px;

  height:108px;

  border-radius:50%;

  background:rgba(255,255,255,0.05);

  border:2px solid rgba(197,238,233,0.20);

  display:flex;

  align-items:center;

  justify-content:center;

  margin-bottom:22px;

  position:relative;

  transition:all 0.35s ease;

  cursor:pointer;

  /* Subtle glow ring */

  box-shadow:0 0 0 0 rgba(27,158,142,0);

}


.step-icon-wrap::before{

  content:'';

  position:absolute;

  inset:-6px;

  border-radius:50%;

  border:2px solid transparent;

  transition:border-color 0.35s ease, opacity 0.35s ease;

  opacity:0;

}


.step-item:hover .step-icon-wrap,

.step-item.active-step .step-icon-wrap{

  background:rgba(27,158,142,0.18);

  border-color:var(--teal2);

  box-shadow:0 0 32px rgba(27,158,142,0.35), 0 8px 28px rgba(0,0,0,0.3);

  transform:translateY(-6px) scale(1.06);

}


.step-item:hover .step-icon-wrap::before,

.step-item.active-step .step-icon-wrap::before{

  border-color:rgba(27,158,142,0.30);

  opacity:1;

}


/* The animation.png icon image */

.step-icon-img{

  width:58px;

  height:58px;

  object-fit:contain;

  filter:brightness(0) invert(1) opacity(0.75);

  transition:filter 0.35s ease, transform 0.35s ease;

}


.step-item:hover .step-icon-img,

.step-item.active-step .step-icon-img{

  filter:brightness(0) invert(1) opacity(1) drop-shadow(0 0 8px rgba(19,181,163,0.7));

  transform:scale(1.12) rotate(-4deg);

}


/* Step number badge */

.step-num{

  position:absolute;

  top:-4px;

  right:-4px;

  width:28px;

  height:28px;

  border-radius:50%;

  background:var(--orange);

  color:#fff;

  font-size:12px;

  font-weight:900;

  display:flex;

  align-items:center;

  justify-content:center;

  border:2px solid #0D1F3C;

  box-shadow:0 4px 12px rgba(245,130,10,0.45);

  transition:transform 0.3s ease;

}


.step-item:hover .step-num,

.step-item.active-step .step-num{

  transform:scale(1.2);

}


/* Step label */

.step-label{

  font-size:14px;

  font-weight:900;

  color:#fff;

  text-transform:uppercase;

  letter-spacing:0.08em;

  margin-bottom:8px;

  transition:color 0.25s;

}


.step-item:hover .step-label,

.step-item.active-step .step-label{

  color:var(--teal2);

}


.step-desc{

  font-size:12.5px;

  color:rgba(221,244,241,0.70);

  line-height:1.6;

  font-weight:500;

  max-width:160px;

  transition:color 0.25s;

}


.step-item:hover .step-desc,

.step-item.active-step .step-desc{

  color:#DDF4F1;

}


/* ACTIVE STEP DETAIL CARD */

.step-detail-card{

  background:rgba(255,255,255,0.05);

  border:1px solid rgba(197,238,233,0.18);

  border-radius:16px;

  padding:28px 36px;

  margin-top:48px;

  display:flex;

  align-items:flex-start;

  gap:24px;

  max-width:900px;

  margin-left:auto;

  margin-right:auto;

  backdrop-filter:blur(10px);

  transition:opacity 0.4s ease;

}


.step-detail-icon{

  width:64px;

  height:64px;

  border-radius:50%;

  background:rgba(27,158,142,0.20);

  border:1.5px solid rgba(27,158,142,0.40);

  display:flex;

  align-items:center;

  justify-content:center;

  flex-shrink:0;

}


.step-detail-icon img{

  width:34px;

  height:34px;

  object-fit:contain;

  filter:brightness(0) invert(1);

}


.step-detail-text h3{

  font-size:20px;

  font-weight:900;

  color:#fff;

  margin-bottom:6px;

}


.step-detail-text p{

  font-size:14px;

  color:#DDF4F1;

  line-height:1.7;

  font-weight:500;

}


/* Paint drip animation elements */

.paint-drip-container{

  position:absolute;

  top:0;

  left:0;

  right:0;

  pointer-events:none;

  overflow:hidden;

  height:8px;

}


.paint-drip{

  position:absolute;

  top:0;

  width:3px;

  background:linear-gradient(180deg,var(--teal),transparent);

  border-radius:0 0 3px 3px;

  animation:drip 3s ease-in-out infinite;

  opacity:0.6;

}


.paint-drip:nth-child(1){left:15%;height:24px;animation-delay:0s;animation-duration:2.8s;}

.paint-drip:nth-child(2){left:30%;height:18px;animation-delay:0.6s;animation-duration:3.2s;}

.paint-drip:nth-child(3){left:50%;height:28px;animation-delay:1.1s;animation-duration:2.5s;}

.paint-drip:nth-child(4){left:68%;height:20px;animation-delay:0.3s;animation-duration:3.5s;}

.paint-drip:nth-child(5){left:82%;height:22px;animation-delay:1.7s;animation-duration:2.9s;}


@keyframes drip{

  0%,100%{transform:scaleY(0.4);opacity:0.3;}

  50%{transform:scaleY(1);opacity:0.7;}

}


/* Floating paint blobs background */

.blob{

  position:absolute;

  border-radius:50%;

  pointer-events:none;

  animation:blobFloat 8s ease-in-out infinite;

  opacity:0.06;

}


.blob1{width:180px;height:180px;background:var(--teal);top:10%;left:5%;animation-delay:0s;}

.blob2{width:120px;height:120px;background:var(--orange);top:60%;right:8%;animation-delay:2s;}

.blob3{width:80px;height:80px;background:var(--teal2);bottom:20%;left:40%;animation-delay:4s;}


@keyframes blobFloat{

  0%,100%{transform:translateY(0) scale(1);}

  50%{transform:translateY(-20px) scale(1.08);}

}


/* Animated progress line that fills on scroll */

.progress-line{

  position:absolute;

  top:54px;

  left:calc(10% + 54px);

  height:3px;

  width:0%;

  background:linear-gradient(90deg,var(--teal),var(--orange));

  z-index:1;

  transition:width 1.8s ease;

  border-radius:2px;

}


.progress-line.filled{

  width:calc(80% - 108px);

}


/* VIDEO GALLERY */

.video-section{background:var(--white);padding:56px 5% 64px;border-top:1px solid var(--border);}

.video-inner{max-width:1200px;margin:0 auto;}

.video-head{text-align:center;max-width:760px;margin:0 auto 28px;}

.video-eyebrow{font-size:11px;font-weight:900;color:var(--teal);text-transform:uppercase;letter-spacing:.16em;margin-bottom:8px;}

.video-head h2{font-size:clamp(28px,3.2vw,44px);line-height:1.08;font-weight:900;color:var(--dark);letter-spacing:-.5px;}

.video-head h2 span{color:var(--orange);}

.video-head p{margin-top:10px;color:var(--mid);font-size:15px;line-height:1.6;font-weight:600;}

.video-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}

.video-card{position:relative;height:220px;border-radius:14px;overflow:hidden;background:var(--teal-mid);box-shadow:0 8px 26px rgba(13,43,42,.10);border:1px solid var(--border);cursor:pointer;}

.video-card.big{grid-column:span 2;grid-row:span 2;height:454px;}

.video-card video{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease;}

.video-card:hover video{transform:scale(1.05);}

.video-card::after{content:"▶";position:absolute;left:14px;bottom:14px;width:38px;height:38px;border-radius:50%;background:rgba(13,31,60,.92);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900;box-shadow:0 6px 18px rgba(0,0,0,.25);}

.video-tag{position:absolute;top:12px;left:12px;background:var(--orange);color:#fff;font-size:10px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;padding:5px 9px;border-radius:6px;}


/* FINAL CTA */

.final-cta{background:linear-gradient(135deg,var(--teal-dark),var(--navy));padding:56px 5%;position:relative;overflow:hidden;}

.final-cta::before{content:"";position:absolute;right:-90px;top:-50px;width:260px;height:90px;background:var(--orange);border-radius:999px;transform:rotate(-25deg);opacity:.85;}

.final-cta-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:28px;align-items:center;position:relative;z-index:2;}

.final-cta-kicker{font-size:11px;font-weight:900;color:#FFB76E;text-transform:uppercase;letter-spacing:.16em;margin-bottom:10px;}

.final-cta h2{color:#fff;font-size:clamp(30px,4vw,54px);line-height:1.02;font-weight:900;letter-spacing:-.6px;}

.final-cta p{color:#DDF4F1;margin-top:10px;font-size:16px;line-height:1.6;font-weight:600;max-width:620px;}

.final-cta-actions{display:flex;gap:12px;flex-wrap:wrap;}

.final-cta .cta-call,.final-cta .cta-quote{display:inline-flex;align-items:center;justify-content:center;padding:15px 22px;border-radius:9px;font-size:14px;font-weight:900;text-transform:uppercase;text-decoration:none;white-space:nowrap;transition:.25s;}

.final-cta .cta-call{background:var(--orange);color:#fff;box-shadow:0 8px 24px rgba(245,130,10,.35);}

.final-cta .cta-call:hover{background:var(--orange2);transform:translateY(-2px);}

.final-cta .cta-quote{background:#fff;color:var(--navy);}

.final-cta .cta-quote:hover{transform:translateY(-2px);}


/* FOOTER */

footer{background:var(--white);border-top:1px solid var(--border);padding:14px 5%;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;}

footer p{font-size:12px;color:var(--muted);}

.footer-links{display:flex;gap:20px;}

.footer-links a{font-size:12px;color:var(--muted);text-decoration:none;transition:color 0.2s;}

.footer-links a:hover{color:var(--teal);}


/* FLOATING WHATSAPP */

.float-wa{position:fixed;bottom:22px;right:22px;z-index:500;background:#25D366;color:#fff;padding:11px 18px;border-radius:50px;font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px;text-decoration:none;white-space:nowrap;box-shadow:0 6px 22px rgba(37,211,102,0.45);transition:all 0.2s;}

.float-wa:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(37,211,102,0.60);}

.float-wa svg{width:18px;height:18px;}


/* LIGHTBOX */

#lb{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.92);z-index:9999;align-items:center;justify-content:center;padding:20px;}

#lb.open{display:flex;}

#lb-media img,#lb-media video{max-width:92vw;max-height:90vh;border-radius:12px;object-fit:contain;display:block;}

#lb-x{position:fixed;top:18px;right:22px;background:rgba(255,255,255,0.12);border:none;color:#fff;width:40px;height:40px;border-radius:50%;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background 0.2s;}

#lb-x:hover{background:var(--orange);}


/* SUCCESS */

.success-panel{display:none;text-align:center;padding:20px 0;}

.success-panel .tick{width:64px;height:64px;background:linear-gradient(135deg,var(--teal),var(--teal2));border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;}

.success-panel h3{font-size:22px;font-weight:900;color:var(--teal);margin-bottom:8px;}

.success-panel p{font-size:14px;color:var(--muted);line-height:1.6;margin-bottom:20px;}

.success-panel a{display:inline-flex;align-items:center;gap:8px;background:var(--orange);color:#fff;padding:13px 24px;border-radius:8px;font-weight:800;font-size:14px;text-decoration:none;text-transform:uppercase;}


/* RESPONSIVE */

@media(max-width:960px){

  .brand-banner-inner{grid-template-columns:1fr;}

  .media-slider{height:360px;}

  .main{grid-template-columns:1fr;padding:28px 5%;gap:36px;}

  .form-panel{position:static;}

  .vs-photos{grid-template-rows:140px 140px;}

  .reviews-row{grid-template-columns:1fr;}

  .stats-row{flex-wrap:wrap;}

  .stat-item{flex:0 0 50%;}

  .steps-track{flex-wrap:wrap;gap:24px;}

  .steps-track::before,.progress-line{display:none;}

  .step-item{flex:0 0 calc(33% - 16px);}

  .step-detail-card{flex-direction:column;align-items:center;text-align:center;}

  .video-grid{grid-template-columns:repeat(2,1fr);}

  .video-card.big{grid-column:span 2;height:360px;}

  .final-cta-inner{grid-template-columns:1fr;text-align:center;}

  .final-cta p{margin-left:auto;margin-right:auto;}

  .final-cta-actions{justify-content:center;}

}


@media(max-width:580px){

  .banner-copy h1{font-size:32px;}

  .banner-actions{flex-direction:column;}

  .banner-call,.banner-quote{width:100%;}

  .media-slider{height:300px;}

  .vs-headline{font-size:28px;}

  .vs-photos{grid-template-columns:1fr 1fr;grid-template-rows:auto;}

  .vs-photo:first-child{grid-row:span 1;}

  .nav-phone-text strong{font-size:17px;}

  .step-item{flex:0 0 calc(50% - 12px);}

  .video-grid{grid-template-columns:1fr;}

  .video-card,.video-card.big{grid-column:auto;grid-row:auto;height:260px;}

  .final-cta-actions{flex-direction:column;}

  .final-cta .cta-call,.final-cta .cta-quote{width:100%;}

}




  /* =========================================================
     ANIMATED DARK BUTTONS & TRUST BADGES
     ========================================================= */
  
  /* 1. Trust Badges (Floating Animation & Dark Colors) */
  .banner-trust div {
    transition: all 0.3s ease;
    animation: badgeFloat 4s ease-in-out infinite;
    border: none !important;
    padding: 14px 20px;
    border-radius: 12px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.15);
  }
  
  /* Force text to white for contrast */
  .banner-trust div strong, 
  .banner-trust div span { 
    color: #ffffff !important; 
  }

  /* Distinct solid dark colors for each badge */
  .banner-trust div:nth-child(1) { background-color: #0D1F3C !important; animation-delay: 0s; }
  .banner-trust div:nth-child(2) { background-color: #0E7A6D !important; animation-delay: 0.2s; }
  .banner-trust div:nth-child(3) { background-color: #2D5C56 !important; animation-delay: 0.4s; }

  /* Pause float and slightly enlarge on hover */
  .banner-trust div:hover {
    transform: translateY(-6px) scale(1.05);
    box-shadow: 0 10px 25px rgba(0,0,0,0.3);
    animation-play-state: paused; 
  }

  /* 2. Call Button (Solid Dark Orange + Pulse Animation) */
  .banner-call {
    background-color: #D95D00 !important; 
    color: #ffffff !important;
    border: none !important;
    animation: callPulse 2s infinite;
    transition: all 0.3s ease;
  }
  .banner-call:hover {
    background-color: #FF7300 !important;
    transform: translateY(-4px) scale(1.04);
    animation-play-state: paused;
  }

  /* 3. Quote Button (Solid Dark Blue + Hover Lift) */
  .banner-quote {
    background-color: #0A162B !important; 
    color: #ffffff !important;
    border: none !important;
    transition: all 0.3s ease;
  }
  .banner-quote:hover {
    background-color: #1A365D !important;
    transform: translateY(-4px) scale(1.04);
    box-shadow: 0 8px 22px rgba(10, 22, 43, 0.4);
  }

  /* 4. Keyframes for Animations */
  @keyframes badgeFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-5px); }
  }
  @keyframes callPulse {
    0% { box-shadow: 0 0 0 0 rgba(217, 93, 0, 0.6); }
    70% { box-shadow: 0 0 0 12px rgba(217, 93, 0, 0); }
    100% { box-shadow: 0 0 0 0 rgba(217, 93, 0, 0); }
  }



/* ================================
   PREMIUM ANIMATED BRAND BANNER
================================ */

.brand-banner{
  position:relative;
  overflow:hidden;
  padding:76px 5% 86px;
  background:
    radial-gradient(circle at 12% 15%, rgba(27,158,142,.14), transparent 28%),
    radial-gradient(circle at 86% 12%, rgba(245,130,10,.16), transparent 28%),
    linear-gradient(135deg,#ffffff 0%,#f4faf9 54%,#eefaf8 100%);
  border-bottom:1px solid #DDEDEA;
}

.brand-bg-grid{
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(13,31,60,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(13,31,60,.035) 1px, transparent 1px);
  background-size:44px 44px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.55),transparent 78%);
  pointer-events:none;
}

.brand-shape{
  position:absolute;
  pointer-events:none;
  border-radius:999px;
}

.brand-shape-one{
  right:-110px;
  top:90px;
  width:360px;
  height:110px;
  background:linear-gradient(135deg,#F5820A,#FF9A31);
  opacity:.18;
  transform:rotate(-24deg);
}

.brand-shape-two{
  left:-140px;
  bottom:-160px;
  width:390px;
  height:390px;
  background:radial-gradient(circle, rgba(27,158,142,.18), transparent 66%);
}

.brand-banner-inner{
  max-width:1180px;
  margin:0 auto;
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(420px,560px);
  gap:58px;
  align-items:center;
}

/* COPY */

.banner-copy{
  max-width:640px;
  animation:bannerFadeUp .75s ease both;
}

@keyframes bannerFadeUp{
  from{
    opacity:0;
    transform:translateY(24px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

.banner-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:9px;
  margin-bottom:18px;
  padding:9px 14px;
  border-radius:999px;
  background:#ffffff;
  color:#149B8B;
  border:1px solid #C5EEE9;
  box-shadow:0 8px 22px rgba(13,43,42,.07);
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.banner-eyebrow span{
  color:#F5B301;
  letter-spacing:1px;
}

.banner-copy h1{
  color:#0D1F3C;
  font-size:clamp(44px,5.6vw,74px);
  line-height:.94;
  letter-spacing:-2.5px;
  font-weight:900;
  text-transform:uppercase;
  max-width:690px;
}

.banner-copy h1 span{
  position:relative;
  display:inline-block;
  color:#F5820A;
}

.banner-copy h1 span::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:7px;
  height:14px;
  background:rgba(245,130,10,.16);
  border-radius:999px;
  z-index:-1;
}

.banner-copy p{
  margin-top:20px;
  color:#2D5C56;
  font-size:18px;
  line-height:1.65;
  font-weight:700;
  max-width:590px;
}

/* TRUST */

.banner-trust{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:25px;
}

.banner-trust div{
  background:#fff;
  border:1px solid #DDEDEA;
  border-radius:18px;
  padding:14px 16px;
  min-width:118px;
  box-shadow:0 10px 26px rgba(13,43,42,.07);
  transition:.25s ease;
}

.banner-trust div:hover{
  transform:translateY(-3px);
}

.banner-trust strong{
  display:block;
  color:#0D1F3C;
  font-size:23px;
  line-height:1;
  font-weight:900;
}

.banner-trust span{
  display:block;
  margin-top:5px;
  color:#6B9E99;
  font-size:11px;
  line-height:1.3;
  font-weight:900;
  text-transform:uppercase;
}

/* AREAS */

.banner-areas{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:23px;
}

.banner-areas span{
  background:#ffffff;
  color:#0D1F3C;
  border:1px solid #DDEDEA;
  box-shadow:0 6px 16px rgba(13,43,42,.05);
  padding:8px 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:850;
}

/* CTA */

.banner-actions{
  display:flex;
  flex-wrap:wrap;
  gap:13px;
  margin-top:30px;
}

.banner-call,
.banner-quote{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:56px;
  padding:16px 24px;
  border-radius:14px;
  font-size:14px;
  font-weight:900;
  text-transform:uppercase;
  text-decoration:none;
  transition:.25s ease;
}

.banner-call{
  background:linear-gradient(180deg,#F5820A,#FF9224);
  color:#fff;
  box-shadow:0 16px 34px rgba(245,130,10,.32);
}

.banner-call::before{
  content:"☎";
  margin-right:9px;
}

.banner-quote{
  background:#ffffff;
  color:#0D1F3C;
  border:1.5px solid #DDEDEA;
  box-shadow:0 10px 24px rgba(13,43,42,.08);
}

.banner-quote::after{
  content:"→";
  margin-left:9px;
}

.banner-call:hover,
.banner-quote:hover{
  transform:translateY(-3px);
}

.banner-microcopy{
  margin-top:14px;
  color:#6B9E99;
  font-size:12px;
  font-weight:800;
}

/* RIGHT VISUAL */

.banner-visual{
  position:relative;
  animation:visualEnter .85s ease both .12s;
}

@keyframes visualEnter{
  from{
    opacity:0;
    transform:translateX(28px) scale(.98);
  }
  to{
    opacity:1;
    transform:translateX(0) scale(1);
  }
}

.image-frame{
  position:relative;
  min-height:520px;
  border-radius:34px;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  overflow:visible;
}

.image-glow{
  position:absolute;
  inset:52px 20px 28px;
  border-radius:36px;
  background:
    linear-gradient(135deg,rgba(13,31,60,.96),rgba(17,67,88,.90)),
    radial-gradient(circle at 70% 20%,rgba(245,130,10,.25),transparent 38%);
  box-shadow:
    0 34px 90px rgba(13,31,60,.24),
    inset 0 0 0 1px rgba(255,255,255,.12);
}

.image-frame::before{
  content:"";
  position:absolute;
  right:-18px;
  top:72px;
  width:160px;
  height:54px;
  border-radius:999px;
  background:#F5820A;
  transform:rotate(-24deg);
  z-index:1;
  animation:strokeFloat 4s ease-in-out infinite;
}

@keyframes strokeFloat{
  0%,100%{
    transform:rotate(-24deg) translateY(0);
  }
  50%{
    transform:rotate(-24deg) translateY(-10px);
  }
}

.image-frame img{
  position:relative;
  z-index:3;
  max-height:535px;
  width:auto;
  max-width:100%;
  object-fit:contain;
  filter:drop-shadow(0 28px 36px rgba(13,31,60,.30));
  animation:personFloat 4.2s ease-in-out infinite;
}

@keyframes personFloat{
  0%,100%{
    transform:translateY(0);
  }
  50%{
    transform:translateY(-9px);
  }
}

.paint-stroke{
  position:absolute;
  left:30px;
  bottom:50px;
  width:210px;
  height:62px;
  border-radius:999px;
  background:linear-gradient(135deg,#1B9E8E,#13B5A3);
  transform:rotate(-13deg);
  z-index:2;
  opacity:.95;
}

/* FLOATING CARDS */

.floating-card{
  position:absolute;
  z-index:6;
  background:#fff;
  border:1px solid #DDEDEA;
  border-radius:18px;
  padding:14px 16px;
  box-shadow:0 20px 48px rgba(13,31,60,.18);
  min-width:176px;
  animation:cardFloat 3.8s ease-in-out infinite;
}

@keyframes cardFloat{
  0%,100%{
    transform:translateY(0);
  }
  50%{
    transform:translateY(-8px);
  }
}

.floating-card span{
  display:block;
  color:#1B9E8E;
  font-size:10px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:5px;
}

.floating-card strong{
  display:block;
  color:#0D1F3C;
  font-size:16px;
  line-height:1.2;
  font-weight:900;
}

.card-top{
  left:-10px;
  top:118px;
}

.card-bottom{
  right:-8px;
  bottom:72px;
  animation-delay:.4s;
}

/* RESPONSIVE */

@media(max-width:1050px){
  .brand-banner{
    padding:56px 5% 66px;
  }

  .brand-banner-inner{
    grid-template-columns:1fr;
    gap:38px;
  }

  .banner-copy{
    max-width:790px;
  }

  .image-frame{
    min-height:480px;
  }

  .image-frame img{
    max-height:500px;
  }

  .card-top{
    left:24px;
  }

  .card-bottom{
    right:24px;
  }
}

@media(max-width:620px){
  .brand-banner{
    padding:40px 5% 48px;
  }

  .banner-copy h1{
    font-size:39px;
    letter-spacing:-1.3px;
  }

  .banner-copy p{
    font-size:15px;
  }

  .banner-trust{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:8px;
  }

  .banner-trust div{
    min-width:0;
    padding:12px 8px;
    text-align:center;
  }

  .banner-trust strong{
    font-size:18px;
  }

  .banner-actions{
    flex-direction:column;
  }

  .banner-call,
  .banner-quote{
    width:100%;
  }

  .image-frame{
    min-height:385px;
    margin-top:4px;
  }

  .image-glow{
    inset:52px 0 20px;
    border-radius:28px;
  }

  .image-frame img{
    max-height:405px;
  }

  .floating-card{
    display:none;
  }

  .paint-stroke{
    width:150px;
    height:46px;
    left:14px;
    bottom:38px;
  }
}



/* PREMIUM BRAND BANNER */

.brand-banner{
  position:relative;
  overflow:hidden;
  padding:74px 5% 82px;
  background:
    linear-gradient(90deg, rgba(255,255,255,.96) 0%, rgba(255,255,255,.92) 48%, rgba(255,255,255,.66) 100%),
    url("https://pelicanpainters.ca/wp-content/uploads/2025/08/IMG-20250731-WA0432.webp") center right / cover no-repeat;
  border-bottom:1px solid #DDEDEA;
}

.brand-banner::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 10% 12%, rgba(27,158,142,.12), transparent 28%),
    radial-gradient(circle at 88% 14%, rgba(245,130,10,.16), transparent 26%),
    linear-gradient(180deg, rgba(244,250,249,.80), rgba(255,255,255,.96));
  pointer-events:none;
}

.brand-banner::after{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(13,31,60,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(13,31,60,.035) 1px, transparent 1px);
  background-size:44px 44px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.45),transparent 76%);
  pointer-events:none;
}

.banner-bg-shape{
  position:absolute;
  border-radius:999px;
  pointer-events:none;
  z-index:1;
}

.shape-one{
  right:-95px;
  top:88px;
  width:340px;
  height:105px;
  background:linear-gradient(135deg,#F5820A,#FF9B35);
  opacity:.18;
  transform:rotate(-25deg);
}

.shape-two{
  left:-110px;
  bottom:-130px;
  width:330px;
  height:330px;
  background:radial-gradient(circle, rgba(27,158,142,.18), transparent 66%);
}

.brand-banner-inner{
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(440px,570px);
  gap:58px;
  align-items:center;
  position:relative;
  z-index:3;
}

/* COPY */

.banner-copy{
  max-width:610px;
}

.banner-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:9px;
  margin-bottom:18px;
  padding:9px 14px;
  border-radius:999px;
  background:#ffffff;
  color:#149B8B;
  border:1px solid #C5EEE9;
  box-shadow:0 8px 22px rgba(13,43,42,.07);
  font-size:11px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.banner-eyebrow::before{
  content:"★★★★★";
  color:#F5B301;
  font-size:11px;
  letter-spacing:1px;
}

.banner-copy h1{
  color:#0D1F3C;
  font-size:clamp(44px,5.3vw,72px);
  line-height:.94;
  letter-spacing:-2.4px;
  font-weight:900;
  text-transform:uppercase;
  max-width:650px;
}

.banner-copy h1 span{
  color:#F5820A;
  position:relative;
  display:inline-block;
}

.banner-copy h1 span::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:6px;
  height:14px;
  background:rgba(245,130,10,.16);
  border-radius:999px;
  z-index:-1;
}

.banner-copy p{
  margin-top:19px;
  color:#2D5C56;
  font-size:17px;
  line-height:1.68;
  font-weight:650;
  max-width:570px;
}

/* PROOF */

.banner-proof-row{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:24px;
}

.banner-proof-row div{
  background:#fff;
  border:1px solid #DDEDEA;
  border-radius:16px;
  padding:13px 16px;
  min-width:108px;
  box-shadow:0 8px 22px rgba(13,43,42,.06);
}

.banner-proof-row strong{
  display:block;
  color:#0D1F3C;
  font-size:21px;
  line-height:1;
  font-weight:900;
}

.banner-proof-row span{
  display:block;
  margin-top:4px;
  color:#6B9E99;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
}

/* AREAS */

.banner-areas{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:22px;
}

.banner-areas span{
  background:#ffffff;
  color:#0D1F3C;
  border:1px solid #DDEDEA;
  box-shadow:0 6px 16px rgba(13,43,42,.05);
  padding:8px 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:850;
}

/* CTA */

.banner-actions{
  display:flex;
  flex-wrap:wrap;
  gap:13px;
  margin-top:30px;
}

.banner-call,
.banner-quote{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  padding:15px 23px;
  border-radius:13px;
  font-size:14px;
  font-weight:900;
  text-transform:uppercase;
  text-decoration:none;
  transition:.25s ease;
}

.banner-call{
  background:linear-gradient(180deg,#F5820A,#FF9224);
  color:#fff;
  box-shadow:0 14px 32px rgba(245,130,10,.30);
}

.banner-call::before{
  content:"☎";
  margin-right:9px;
}

.banner-quote{
  background:#ffffff;
  color:#0D1F3C;
  border:1.5px solid #DDEDEA;
  box-shadow:0 10px 24px rgba(13,43,42,.08);
}

.banner-quote::after{
  content:"→";
  margin-left:9px;
}

.banner-call:hover,
.banner-quote:hover{
  transform:translateY(-2px);
}

/* MEDIA */

.banner-media-wrap{
  position:relative;
}

.premium-media-slider{
  position:relative;
  height:485px;
  border-radius:34px;
  overflow:hidden;
  background:#0D1F3C;
  box-shadow:
    0 34px 90px rgba(13,31,60,.24),
    0 0 0 10px rgba(255,255,255,.72);
  border:1px solid rgba(13,31,60,.10);
  isolation:isolate;
}

.premium-media-slider::before{
  content:"";
  position:absolute;
  inset:16px;
  border:1px solid rgba(255,255,255,.23);
  border-radius:27px;
  z-index:8;
  pointer-events:none;
}

.slide{
  position:absolute;
  inset:0;
  opacity:0;
  transform:scale(1.04);
  transition:opacity .75s ease, transform .75s ease;
  cursor:pointer;
}

.slide.active{
  opacity:1;
  transform:scale(1);
  z-index:2;
}

.slide img,
.slide video{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.slide::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(13,31,60,.05) 0%, rgba(13,31,60,.18) 48%, rgba(13,31,60,.88) 100%),
    linear-gradient(90deg, rgba(13,31,60,.20), transparent 50%);
  z-index:2;
}

.slide-caption{
  position:absolute;
  left:30px;
  right:30px;
  bottom:30px;
  z-index:5;
  color:#fff;
}

.slide-caption small{
  display:inline-flex;
  background:#F5820A;
  color:#fff;
  padding:7px 11px;
  border-radius:999px;
  font-size:10px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:11px;
}

.slide-caption strong{
  display:block;
  max-width:430px;
  font-size:31px;
  line-height:1.06;
  font-weight:900;
  letter-spacing:-.7px;
}

.slide-caption span{
  display:block;
  margin-top:8px;
  color:#DFF8F4;
  font-size:13px;
  line-height:1.45;
  font-weight:700;
}

.slider-controls{
  position:absolute;
  top:24px;
  right:24px;
  display:flex;
  gap:9px;
  z-index:12;
}

.slider-controls button{
  width:42px;
  height:42px;
  border:none;
  border-radius:50%;
  background:rgba(255,255,255,.94);
  color:#0D1F3C;
  font-size:22px;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 10px 24px rgba(0,0,0,.16);
  transition:.22s ease;
}

.slider-controls button:hover{
  background:#F5820A;
  color:#fff;
  transform:translateY(-2px);
}

.slider-dots{
  position:absolute;
  left:30px;
  top:30px;
  z-index:12;
  display:flex;
  gap:7px;
}

.slider-dots button{
  width:8px;
  height:8px;
  border:none;
  border-radius:50%;
  background:rgba(255,255,255,.48);
  cursor:pointer;
  transition:.22s ease;
}

.slider-dots button.active{
  width:24px;
  border-radius:999px;
  background:#F5820A;
}

/* FLOATING REVIEW */

.floating-review{
  position:absolute;
  left:-32px;
  bottom:34px;
  z-index:15;
  width:220px;
  background:#fff;
  border:1px solid #DDEDEA;
  border-radius:20px;
  padding:17px;
  box-shadow:0 22px 50px rgba(13,31,60,.18);
  animation:reviewFloat 3.6s ease-in-out infinite;
}

@keyframes reviewFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}

.floating-review .stars{
  color:#F5B301;
  font-size:14px;
  letter-spacing:1px;
  margin-bottom:7px;
}

.floating-review strong{
  display:block;
  color:#0D1F3C;
  font-size:15px;
  line-height:1.25;
  font-weight:900;
}

.floating-review span{
  display:block;
  color:#6B9E99;
  font-size:11px;
  line-height:1.4;
  font-weight:800;
  margin-top:5px;
}

/* RESPONSIVE */

@media(max-width:1050px){
  .brand-banner{
    padding:54px 5% 64px;
  }

  .brand-banner-inner{
    grid-template-columns:1fr;
    gap:38px;
  }

  .banner-copy{
    max-width:780px;
  }

  .premium-media-slider{
    height:430px;
  }

  .floating-review{
    left:22px;
  }
}

@media(max-width:620px){
  .brand-banner{
    padding:38px 5% 46px;
  }

  .banner-copy h1{
    font-size:39px;
    letter-spacing:-1.2px;
  }

  .banner-copy p{
    font-size:15px;
  }

  .banner-proof-row{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:8px;
  }

  .banner-proof-row div{
    min-width:0;
    padding:11px 9px;
    text-align:center;
  }

  .banner-proof-row strong{
    font-size:18px;
  }

  .banner-actions{
    flex-direction:column;
  }

  .banner-call,
  .banner-quote{
    width:100%;
  }

  .premium-media-slider{
    height:330px;
    border-radius:24px;
    box-shadow:
      0 20px 56px rgba(13,31,60,.18),
      0 0 0 6px rgba(255,255,255,.75);
  }

  .slide-caption{
    left:20px;
    right:20px;
    bottom:20px;
  }

  .slide-caption strong{
    font-size:22px;
  }

  .slider-controls{
    top:16px;
    right:16px;
  }

  .slider-controls button{
    width:36px;
    height:36px;
  }

  .slider-dots{
    left:20px;
    top:20px;
  }

  .floating-review{
    display:none;
  }
}



  /* =========================================================
     COMPREHENSIVE MAIN SECTION REDESIGN
     ========================================================= */
  
  /* Layout Grid Container */
  .main {
    display: grid;
    grid-template-columns: 1fr 1.3fr;
    gap: 40px;
    align-items: start;
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  }

  /* LEFT FORM PANEL STYLING */
  .form-panel {
    background: #ffffff;
    border-radius: 16px;
    padding: 32px;
    box-shadow: 0 10px 30px rgba(13, 31, 60, 0.06);
    border: 1px solid rgba(13, 31, 60, 0.05);
    position: relative;
    overflow: hidden;
  }
  .form-panel-eyebrow {
    color: #E06C00;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 8px;
  }
  .form-panel h2 {
    color: #0D1F3C;
    font-size: 28px;
    font-weight: 800;
    line-height: 1.2;
    margin: 0 0 12px 0;
  }
  .form-panel-sub {
    color: #5A6A85;
    font-size: 14px;
    line-height: 1.5;
    margin-bottom: 24px;
  }
  
  /* Input Fields */
  .fi {
    margin-bottom: 16px;
  }
  .fi input, .fi select {
    width: 100%;
    padding: 14px 16px;
    border-radius: 8px;
    border: 1px solid #D1D9E6;
    background-color: #F8FAFC;
    font-size: 14px;
    color: #0D1F3C;
    box-sizing: border-box;
    transition: all 0.3s ease;
  }
  .fi input:focus, .fi select:focus {
    outline: none;
    border-color: #0E7A6D;
    background-color: #ffffff;
    box-shadow: 0 0 0 3px rgba(14, 122, 109, 0.15);
  }

  /* Submit Button */
  .btn-submit {
    width: 100%;
    background-color: #0D1F3C;
    color: #ffffff;
    border: none;
    padding: 16px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.5px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: all 0.3s ease;
    margin-bottom: 16px;
  }
  .btn-submit svg {
    width: 18px;
    height: 18px;
    transition: transform 0.3s ease;
  }
  .btn-submit:hover {
    background-color: #0E7A6D;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(14, 122, 109, 0.3);
  }
  .btn-submit:hover svg {
    transform: translateX(4px);
  }
  .form-privacy {
    font-size: 11px;
    color: #8A99AD;
    line-height: 1.4;
    margin: 0;
  }

  /* Success Panel State styling */
  .success-panel {
    display: none; /* Controlled by your doSubmit JS logic */
    text-align: center;
    padding: 40px 10px;
  }
  .success-panel .tick {
    width: 60px;
    height: 60px;
    background: #0E7A6D;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px;
  }
  .success-panel h3 { color: #0D1F3C; font-size: 22px; margin-bottom: 10px; }
  .success-panel p { color: #5A6A85; font-size: 14px; margin-bottom: 20px; }
  .success-panel a {
    display: inline-block;
    background: #E06C00;
    color: #ffffff;
    padding: 12px 24px;
    border-radius: 6px;
    text-decoration: none;
    font-weight: 700;
    transition: all 0.3s ease;
  }
  .success-panel a:hover { transform: translateY(-2px); background: #FF7300; }

  /* RIGHT VALUE SIDE STYLING */
  .value-side {
    padding-top: 8px;
  }
  .vs-headline {
    color: #0D1F3C;
    font-size: 36px;
    font-weight: 800;
    line-height: 1.2;
    margin: 0 0 12px 0;
  }
  .vs-headline em {
    font-style: normal;
    color: #E06C00;
  }
  .vs-sub {
    color: #5A6A85;
    font-size: 16px;
    line-height: 1.6;
    margin: 0 0 28px 0;
  }

  /* Stats Rows - Dark Solid Accents */
  .stats-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-bottom: 32px;
  }
  .stat-item {
    background: #0D1F3C;
    color: #ffffff;
    padding: 16px;
    border-radius: 12px;
    text-align: center;
  }
  .stat-stars { color: #FFB800; font-size: 12px; margin-bottom: 4px; }
  .stat-num { font-size: 22px; font-weight: 800; }
  .stat-num span { font-size: 14px; opacity: 0.7; }
  .stat-lbl { font-size: 11px; color: rgba(255, 255, 255, 0.7); line-height: 1.3; margin-top: 2px; }

  /* Value Checks */
  .vs-checks {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 32px;
  }
  .vs-check {
    display: flex;
    align-items: flex-start;
    gap: 14px;
  }
  .vs-check-icon {
    background: #0E7A6D;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin-top: 2px;
  }
  .vs-check-icon svg { width: 12px; height: 12px; }
  .vs-check-text { color: #334155; font-size: 14px; line-height: 1.5; }
  .vs-check-text strong { color: #0D1F3C; }

  /* FLUID BENTO IMAGE GALLERY (100% Percentage Scaled) */
  #pelican-bento-gallery {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    width: 100%;
    margin-bottom: 32px;
  }
  #pelican-bento-gallery .vs-photo {
    position: relative;
    border-radius: 12px;
    overflow: hidden;
    cursor: pointer;
    background-color: #F1F5F9;
    box-shadow: 0 4px 15px rgba(13, 31, 60, 0.05);
    transform: translateZ(0); 
  }
  /* Primary Hero Frame (Square) */
  #pelican-bento-gallery .vs-photo:nth-child(1) {
    grid-column: span 2;
    grid-row: span 2;
    aspect-ratio: 1 / 1;
  }
  /* Secondary Supporting Frames (Square) */
  #pelican-bento-gallery .vs-photo:not(:nth-child(1)) {
    grid-column: span 1;
    grid-row: span 1;
    aspect-ratio: 1 / 1;
  }
  #pelican-bento-gallery .vs-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.5s ease;
  }
  /* Authentic Asset Badge */
  #pelican-bento-gallery .photo-badge {
    position: absolute;
    bottom: 12px;
    left: 12px;
    background: #E06C00;
    color: #ffffff;
    padding: 5px 10px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: 6px;
    z-index: 3;
    box-shadow: 0 4px 10px rgba(224, 108, 0, 0.3);
  }
  /* Hover Overlays & SVG Zoom Triggers */
  #pelican-bento-gallery .vs-photo-overlay {
    position: absolute;
    inset: 0;
    background: rgba(13, 31, 60, 0.5);
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  #pelican-bento-gallery .vs-photo-overlay svg {
    width: 28px;
    height: 28px;
    transform: scale(0.7);
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  }
  #pelican-bento-gallery .vs-photo:hover img {
    transform: scale(1.06);
  }
  #pelican-bento-gallery .vs-photo:hover .vs-photo-overlay {
    opacity: 1;
  }
  #pelican-bento-gallery .vs-photo:hover .vs-photo-overlay svg {
    transform: scale(1);
  }

  /* Review Cards */
  .reviews-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
  .rev-card {
    background: #F8FAFC;
    border-radius: 12px;
    padding: 20px;
    border: 1px solid rgba(13, 31, 60, 0.04);
  }
  .rev-stars { color: #FFB800; font-size: 14px; margin-bottom: 8px; }
  .rev-text { color: #475569; font-size: 13px; line-height: 1.5; margin: 0 0 10px 0; font-style: italic; }
  .rev-author { color: #0D1F3C; font-size: 12px; font-weight: 700; }

  /* RESPONSIVE LAYOUT RESPONSES */
  @media (max-width: 900px) {
    .main { grid-template-columns: 1fr; gap: 40px; }
  }
  @media (max-width: 600px) {
    .stats-row { grid-template-columns: repeat(2, 1fr); }
    .reviews-row { grid-template-columns: 1fr; }
    #pelican-bento-gallery { grid-template-columns: repeat(2, 1fr); }
    #pelican-bento-gallery .vs-photo:nth-child(1) { grid-column: span 2; aspect-ratio: 16 / 10; }
  }



/* ================================
   PELICAN LEAD + GALLERY SECTION
   Fully scoped with ppx-
================================ */

.ppx-lead-section{
  position:relative;
  overflow:hidden;
  padding:64px 5%;
  background:
    radial-gradient(circle at 10% 8%, rgba(27,158,142,.13), transparent 28%),
    radial-gradient(circle at 90% 10%, rgba(245,130,10,.15), transparent 28%),
    linear-gradient(135deg,#ffffff 0%,#f4faf9 58%,#eaf8f6 100%);
}

.ppx-lead-section::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(13,31,60,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(13,31,60,.035) 1px, transparent 1px);
  background-size:44px 44px;
  pointer-events:none;
}

.ppx-main{
  position:relative;
  z-index:2;
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns:390px minmax(0,1fr);
  gap:36px;
  align-items:start;
}

/* FORM */

.ppx-form-card{
  position:sticky;
  top:88px;
  background:#ffffff;
  border:1px solid rgba(197,238,233,.95);
  border-radius:28px;
  box-shadow:0 24px 64px rgba(13,43,42,.13);
  overflow:hidden;
}

.ppx-form-card #form-body{
  padding:30px;
}

.ppx-form-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-bottom:13px;
  padding:7px 12px;
  border-radius:999px;
  background:#E8F7F5;
  color:#009E8F;
  border:1px solid #C5EEE9;
  font-size:10px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.ppx-form-card h2{
  color:#071E3A;
  font-size:38px;
  line-height:.98;
  letter-spacing:-1.2px;
  font-weight:900;
  margin:0;
  text-transform:uppercase;
}

.ppx-form-sub{
  margin:12px 0 18px;
  color:#2D5C56;
  font-size:14px;
  line-height:1.55;
  font-weight:700;
}

.ppx-field{
  margin-bottom:11px;
}

.ppx-field input,
.ppx-field select{
  width:100%;
  height:50px;
  border:1px solid #DDEDEA;
  border-radius:14px;
  padding:0 15px;
  background:#F9FEFD;
  color:#0D1F3C;
  font-size:14px;
  font-weight:700;
  outline:none;
  transition:.22s ease;
}

.ppx-field input:focus,
.ppx-field select:focus{
  border-color:#009E8F;
  background:#ffffff;
  box-shadow:0 0 0 4px rgba(0,158,143,.10);
}

.ppx-submit{
  width:100%;
  min-height:54px;
  border:none;
  border-radius:14px;
  margin-top:4px;
  background:linear-gradient(135deg,#ff6b00,#ffb000);
  color:#fff;
  font-size:14px;
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  cursor:pointer;
  box-shadow:0 18px 42px rgba(255,107,0,.36);
  transition:.25s ease;
}

.ppx-submit:hover{
  transform:translateY(-3px);
  box-shadow:0 28px 58px rgba(255,107,0,.48);
}

.ppx-submit svg{
  width:23px;
  height:23px;
}

.ppx-privacy{
  margin:13px 0 0;
  color:#6B9E99;
  font-size:10.5px;
  line-height:1.45;
  font-weight:650;
}

/* RIGHT SIDE */

.ppx-value{
  min-width:0;
}

.ppx-eyebrow{
  display:inline-flex;
  align-items:center;
  margin-bottom:12px;
  padding:8px 13px;
  border-radius:999px;
  background:#ffffff;
  color:#009E8F;
  border:1px solid rgba(197,238,233,.95);
  box-shadow:0 10px 24px rgba(13,43,42,.06);
  font-size:10.5px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.ppx-value h1{
  color:#071E3A;
  font-size:clamp(34px,4.2vw,56px);
  line-height:1.02;
  letter-spacing:-1.4px;
  font-weight:900;
  margin:0;
  text-transform:uppercase;
}

.ppx-value h1 span{
  color:#F5820A;
}

.ppx-sub{
  margin:12px 0 0;
  color:#2D5C56;
  font-size:16px;
  line-height:1.55;
  font-weight:700;
  max-width:720px;
}

/* STATS */

.ppx-stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:11px;
  margin:20px 0 18px;
}

.ppx-stat{
  background:#ffffff;
  border:1px solid rgba(197,238,233,.95);
  border-radius:18px;
  padding:14px 12px;
  box-shadow:0 12px 28px rgba(13,43,42,.07);
  transition:.25s ease;
}

.ppx-stat:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 42px rgba(13,43,42,.12);
}

.ppx-stat strong{
  display:block;
  color:#0D1F3C;
  font-size:24px;
  line-height:1;
  font-weight:900;
}

.ppx-stat span{
  display:block;
  margin-top:5px;
  color:#6B9E99;
  font-size:10.5px;
  line-height:1.25;
  font-weight:900;
  text-transform:uppercase;
}

.ppx-stars{
  color:#F5B301;
  font-size:12px;
  letter-spacing:1px;
  font-weight:900;
  margin-bottom:5px;
}

/* GALLERY */

.ppx-gallery{
  display:grid;
  grid-template-columns:1.22fr .86fr .86fr;
  grid-auto-rows:145px;
  gap:12px;
}

.ppx-photo{
  position:relative;
  overflow:hidden;
  border-radius:22px;
  background:#0D1F3C;
  cursor:pointer;
  box-shadow:0 18px 46px rgba(13,31,60,.14);
  border:1px solid rgba(13,31,60,.08);
  transition:transform .28s ease, box-shadow .28s ease;
}

.ppx-photo:hover{
  transform:translateY(-6px);
  box-shadow:0 28px 64px rgba(13,31,60,.24);
}

.ppx-big{
  grid-row:span 2;
}

.ppx-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:scale(1.02);
  transition:transform .55s ease;
}

.ppx-photo:hover img{
  transform:scale(1.12);
}

.ppx-shade{
  position:absolute;
  inset:0;
  z-index:2;
  background:
    linear-gradient(180deg, rgba(13,31,60,.02) 0%, rgba(13,31,60,.16) 42%, rgba(13,31,60,.86) 100%);
  pointer-events:none;
}

.ppx-badge{
  position:absolute;
  top:14px;
  left:14px;
  z-index:4;
  background:#F5820A;
  color:#fff;
  padding:7px 11px;
  border-radius:999px;
  font-size:10px;
  font-weight:900;
  letter-spacing:.11em;
  text-transform:uppercase;
  box-shadow:0 10px 22px rgba(245,130,10,.30);
}

.ppx-caption{
  position:absolute;
  left:18px;
  right:18px;
  bottom:18px;
  z-index:4;
  color:#fff;
}

.ppx-caption strong{
  display:block;
  max-width:320px;
  font-size:25px;
  line-height:1.04;
  font-weight:900;
  letter-spacing:-.5px;
}

.ppx-caption span{
  display:block;
  margin-top:7px;
  color:#DFF8F4;
  font-size:12px;
  font-weight:800;
}

.ppx-mini{
  position:absolute;
  left:13px;
  right:13px;
  bottom:13px;
  z-index:4;
  color:#fff;
  font-size:14px;
  line-height:1.1;
  font-weight:900;
  text-shadow:0 2px 10px rgba(0,0,0,.36);
}

/* PROOF */

.ppx-proof{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:11px;
  margin-top:18px;
}

.ppx-proof div{
  background:#ffffff;
  border:1px solid rgba(197,238,233,.95);
  border-radius:18px;
  padding:13px 14px;
  box-shadow:0 12px 28px rgba(13,43,42,.07);
  display:grid;
  grid-template-columns:auto 1fr;
  column-gap:10px;
  align-items:center;
}

.ppx-proof span{
  grid-row:span 2;
  width:26px;
  height:26px;
  border-radius:50%;
  background:#009E8F;
  color:#fff;
  display:grid;
  place-items:center;
  font-size:14px;
  font-weight:900;
}

.ppx-proof strong{
  color:#0D1F3C;
  font-size:13px;
  font-weight:900;
  line-height:1.1;
}

.ppx-proof small{
  color:#6B9E99;
  font-size:10.5px;
  font-weight:800;
}

/* REVIEWS */

.ppx-reviews{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:18px;
}

.ppx-reviews > div{
  background:#ffffff;
  border:1px solid rgba(197,238,233,.95);
  border-radius:18px;
  padding:15px;
  box-shadow:0 12px 28px rgba(13,43,42,.07);
}

.ppx-review-stars{
  color:#F5B301;
  font-size:13px;
  letter-spacing:1px;
  font-weight:900;
}

.ppx-reviews p{
  color:#2D5C56;
  font-size:13px;
  line-height:1.45;
  font-weight:700;
  margin:8px 0;
}

.ppx-reviews strong{
  color:#0D1F3C;
  font-size:12px;
  font-weight:900;
}

/* LIGHTBOX */

.media-lb{
  position:fixed;
  inset:0;
  z-index:99999;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(3,12,24,.92);
}

.media-lb.open{
  display:flex;
}

.media-lb-content img,
.media-lb-content video{
  max-width:92vw;
  max-height:88vh;
  border-radius:18px;
  box-shadow:0 30px 80px rgba(0,0,0,.45);
  background:#000;
}

.media-lb-close{
  position:fixed;
  top:18px;
  right:18px;
  width:46px;
  height:46px;
  border:none;
  border-radius:50%;
  background:#F5820A;
  color:#fff;
  font-size:30px;
  line-height:1;
  cursor:pointer;
  box-shadow:0 16px 34px rgba(245,130,10,.34);
}

/* RESPONSIVE */

@media(max-width:1050px){
  .ppx-main{
    grid-template-columns:1fr;
  }

  .ppx-form-card{
    position:relative;
    top:auto;
    max-width:620px;
    width:100%;
    margin:0 auto;
  }
}

@media(max-width:760px){
  .ppx-lead-section{
    padding:42px 5%;
  }

  .ppx-stats{
    grid-template-columns:repeat(2,1fr);
  }

  .ppx-gallery{
    grid-template-columns:1fr 1fr;
    grid-auto-rows:170px;
  }

  .ppx-big{
    grid-column:span 2;
    grid-row:span 1;
  }

  .ppx-proof,
  .ppx-reviews{
    grid-template-columns:1fr;
  }
}

@media(max-width:520px){
  .ppx-form-card #form-body{
    padding:24px 20px;
  }

  .ppx-form-card h2{
    font-size:32px;
  }

  .ppx-value h1{
    font-size:32px;
  }

  .ppx-gallery{
    grid-template-columns:1fr;
    grid-auto-rows:220px;
  }

  .ppx-big{
    grid-column:auto;
    min-height:250px;
  }

  .ppx-caption strong{
    font-size:22px;
  }
}



  .custom-process-section {
    padding: 80px 5%;
    background-color: #ffffff;
    font-family: 'Inter', sans-serif;
    border-top: 1px solid #E2E8F0;
    position: relative;
  }
  .cp-header {
    text-align: center;
    max-width: 800px;
    margin: 0 auto 60px auto;
  }
  .cp-eyebrow {
    color: #F5820A;
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 12px;
    display: inline-block;
  }
  .cp-title {
    color: #0A192F;
    font-family: 'Outfit', sans-serif;
    font-size: 38px;
    font-weight: 900;
    text-transform: uppercase;
    line-height: 1.2;
    margin-bottom: 16px;
  }
  .cp-subtitle {
    color: #64748B;
    font-size: 16px;
    font-weight: 600;
  }
  .cp-grid {
    display: flex;
    justify-content: space-between;
    gap: 24px;
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
    flex-wrap: wrap;
  }
  /* Desktop Connecting Line */
  .cp-line {
    position: absolute;
    top: 50px;
    left: 10%;
    right: 10%;
    height: 2px;
    background-color: #E2E8F0;
    z-index: 1;
  }
  .cp-card {
    background: #ffffff;
    border: 1px solid #E2E8F0;
    border-radius: 20px;
    padding: 32px 24px;
    flex: 1;
    min-width: 240px;
    text-align: center;
    position: relative;
    z-index: 2;
    box-shadow: 0 4px 10px rgba(0,0,0,0.02);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
  }
  .cp-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 40px rgba(0,0,0,0.08);
  }
  .cp-icon-wrap {
    width: 80px;
    height: 80px;
    border-radius: 20px;
    margin: 0 auto 24px auto;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    transition: transform 0.3s ease;
  }
  .cp-card:hover .cp-icon-wrap {
    transform: scale(1.1);
  }
  .cp-icon-wrap svg {
    width: 36px;
    height: 36px;
  }
  .cp-step-num {
    position: absolute;
    top: -10px;
    right: -10px;
    width: 28px;
    height: 28px;
    background: #0A192F;
    color: #ffffff;
    font-size: 13px;
    font-weight: 900;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 3px solid #ffffff;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
  }
  
  /* Icon Color Themes */
  .cp-color-orange { background-color: #FFF0E0; color: #F5820A; }
  .cp-color-blue { background-color: #E0F2FE; color: #3B82F6; }
  .cp-color-purple { background-color: #F3E8FF; color: #A855F7; }
  .cp-color-green { background-color: #DCFCE7; color: #22C55E; }

  .cp-card-title {
    color: #0A192F;
    font-family: 'Outfit', sans-serif;
    font-size: 20px;
    font-weight: 900;
    text-transform: uppercase;
    margin-bottom: 8px;
  }
  .cp-card-desc {
    color: #64748B;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.5;
  }
  .cp-action {
    text-align: center;
    margin-top: 50px;
  }
  .cp-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    background-color: #F5820A;
    color: #ffffff;
    font-family: 'Inter', sans-serif;
    font-size: 16px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 20px 40px;
    border-radius: 8px;
    text-decoration: none;
    box-shadow: 0 10px 25px rgba(245, 130, 10, 0.3);
    transition: all 0.2s ease;
  }
  .cp-btn:hover {
    background-color: #E07305;
    transform: translateY(-2px);
  }
  .cp-btn svg {
    width: 20px;
    height: 20px;
  }
  
  @media (max-width: 992px) {
    .cp-line { display: none; }
  }



.video-section{
  background:
    radial-gradient(circle at 12% 10%, rgba(27,158,142,.10), transparent 28%),
    radial-gradient(circle at 90% 8%, rgba(245,130,10,.12), transparent 28%),
    linear-gradient(180deg,#ffffff 0%,#f4faf9 100%);
  padding:76px 5%;
  border-top:1px solid #e6efee;
  border-bottom:1px solid #e6efee;
}

.video-inner{
  max-width:1180px;
  margin:0 auto;
}

.video-head{
  text-align:center;
  max-width:760px;
  margin:0 auto 36px;
}

.video-eyebrow{
  display:inline-flex;
  padding:8px 13px;
  border-radius:999px;
  background:#fff;
  color:#1B9E8E;
  border:1px solid #C5EEE9;
  box-shadow:0 8px 22px rgba(13,43,42,.06);
  font-size:11px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  margin-bottom:14px;
}

.video-head h2{
  color:#0D1F3C;
  font-size:clamp(34px,4.2vw,56px);
  line-height:1.04;
  font-weight:900;
  letter-spacing:-1.3px;
  text-transform:uppercase;
}

.video-head h2 span{
  color:#F5820A;
}

.video-head p{
  margin:13px auto 0;
  color:#2D5C56;
  font-size:16px;
  line-height:1.65;
  font-weight:650;
}

.video-grid{
  display:grid;
  grid-template-columns:1.35fr 1fr 1fr;
  grid-auto-rows:230px;
  gap:16px;
}

.video-card{
  position:relative;
  overflow:hidden;
  border-radius:22px;
  background:#0D1F3C;
  cursor:pointer;
  box-shadow:0 18px 50px rgba(13,43,42,.13);
  border:1px solid rgba(13,31,60,.08);
  isolation:isolate;
}

.video-card.big{
  grid-row:span 2;
  min-height:476px;
}

.video-card video{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  background:#0D1F3C;
  opacity:1;
  transform:scale(1.01);
  transition:.45s ease;
}

.video-card:hover video{
  transform:scale(1.08);
}

.video-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(13,31,60,.02) 0%, rgba(13,31,60,.16) 42%, rgba(13,31,60,.84) 100%);
  z-index:2;
  pointer-events:none;
}

.video-tag{
  position:absolute;
  top:16px;
  left:16px;
  z-index:5;
  background:#F5820A;
  color:#fff;
  padding:7px 11px;
  border-radius:999px;
  font-size:10px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.video-caption{
  position:absolute;
  left:22px;
  right:22px;
  bottom:82px;
  z-index:5;
  color:#fff;
}

.video-caption h3{
  font-size:28px;
  line-height:1.08;
  font-weight:900;
}

.video-caption p{
  margin-top:7px;
  color:#DFF8F4;
  font-size:14px;
  line-height:1.5;
  font-weight:650;
}

.video-caption.small{
  bottom:76px;
}

.video-caption.small h3{
  font-size:19px;
}

.play-btn{
  position:absolute;
  left:22px;
  bottom:22px;
  z-index:5;
  width:48px;
  height:48px;
  border-radius:50%;
  background:#fff;
  color:#0D1F3C;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  font-weight:900;
  box-shadow:0 12px 28px rgba(0,0,0,.22);
  transition:.25s ease;
}

.video-card:hover .play-btn{
  background:#F5820A;
  color:#fff;
  transform:scale(1.08);
}

@media(max-width:980px){
  .video-grid{
    grid-template-columns:1fr 1fr;
    grid-auto-rows:230px;
  }

  .video-card.big{
    grid-column:span 2;
    grid-row:span 1;
    min-height:330px;
  }
}

@media(max-width:620px){
  .video-section{
    padding:52px 5%;
  }

  .video-head h2{
    font-size:32px;
  }

  .video-grid{
    grid-template-columns:1fr;
    grid-auto-rows:245px;
  }

  .video-card.big{
    grid-column:auto;
    min-height:310px;
  }
}



/* AMAZING VIDEO GALLERY */

.video-section{
  background:
    radial-gradient(circle at 12% 10%, rgba(27,158,142,.10), transparent 28%),
    radial-gradient(circle at 90% 8%, rgba(245,130,10,.12), transparent 28%),
    linear-gradient(180deg,#ffffff 0%,#f4faf9 100%);
  padding:76px 5%;
  position:relative;
  overflow:hidden;
  border-top:1px solid #e6efee;
  border-bottom:1px solid #e6efee;
}

.video-inner{
  max-width:1180px;
  margin:0 auto;
}

.video-head{
  text-align:center;
  max-width:760px;
  margin:0 auto 34px;
}

.video-eyebrow{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 13px;
  border-radius:999px;
  background:#ffffff;
  color:#1B9E8E;
  border:1px solid #C5EEE9;
  box-shadow:0 8px 22px rgba(13,43,42,.06);
  font-size:11px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  margin-bottom:14px;
}

.video-head h2{
  color:#0D1F3C;
  font-size:clamp(34px,4.2vw,56px);
  line-height:1.04;
  font-weight:900;
  letter-spacing:-1.3px;
  text-transform:uppercase;
}

.video-head h2 span{
  color:#F5820A;
}

.video-head p{
  margin:13px auto 0;
  color:#2D5C56;
  font-size:16px;
  line-height:1.65;
  font-weight:650;
}

/* GRID */

.video-gallery{
  display:grid;
  grid-template-columns:1.35fr 1fr 1fr;
  grid-auto-rows:220px;
  gap:16px;
}

.video-card{
  position:relative;
  overflow:hidden;
  border-radius:22px;
  background:#0D1F3C;
  cursor:pointer;
  min-height:220px;
  box-shadow:0 18px 50px rgba(13,43,42,.13);
  border:1px solid rgba(13,31,60,.08);
  isolation:isolate;
}

.video-featured{
  grid-row:span 2;
  min-height:456px;
}

.video-card video{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  opacity:1;
  transform:scale(1.01);
  transition:.45s ease;
  background:#0D1F3C;
}

.video-card:hover video{
  transform:scale(1.08);
}

.video-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(13,31,60,.04) 0%, rgba(13,31,60,.18) 42%, rgba(13,31,60,.86) 100%);
  z-index:2;
  pointer-events:none;
}

.video-play{
  position:absolute;
  left:18px;
  bottom:18px;
  width:46px;
  height:46px;
  border-radius:50%;
  background:#ffffff;
  color:#0D1F3C;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  font-weight:900;
  z-index:4;
  box-shadow:0 12px 28px rgba(0,0,0,.22);
  transition:.25s ease;
}

.video-card:hover .video-play{
  background:#F5820A;
  color:#fff;
  transform:scale(1.08);
}

.video-tag{
  position:absolute;
  top:16px;
  left:16px;
  z-index:5;
  background:#F5820A;
  color:#fff;
  padding:7px 11px;
  border-radius:999px;
  font-size:10px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  box-shadow:0 10px 24px rgba(245,130,10,.26);
}

.video-caption{
  position:absolute;
  left:20px;
  right:20px;
  bottom:82px;
  z-index:5;
  color:#fff;
}

.video-caption h3{
  font-size:28px;
  line-height:1.08;
  font-weight:900;
  letter-spacing:-.5px;
  max-width:420px;
}

.video-caption p{
  margin-top:7px;
  color:#DFF8F4;
  font-size:14px;
  line-height:1.5;
  font-weight:650;
}

.video-caption.small{
  bottom:74px;
}

.video-caption.small h3{
  font-size:18px;
  line-height:1.15;
}

/* CTA */

.video-bottom-cta{
  margin-top:26px;
  background:#0D1F3C;
  color:#fff;
  border-radius:22px;
  padding:22px;
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:center;
  box-shadow:0 18px 50px rgba(13,31,60,.18);
  position:relative;
  overflow:hidden;
}

.video-bottom-cta::after{
  content:"";
  position:absolute;
  right:-70px;
  top:-35px;
  width:220px;
  height:80px;
  border-radius:999px;
  background:#F5820A;
  transform:rotate(-24deg);
  opacity:.86;
}

.video-bottom-cta strong{
  display:block;
  font-size:26px;
  line-height:1.1;
  font-weight:900;
  position:relative;
  z-index:2;
}

.video-bottom-cta span{
  display:block;
  margin-top:5px;
  color:#DFF8F4;
  font-size:14px;
  font-weight:650;
  position:relative;
  z-index:2;
}

.video-cta-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  position:relative;
  z-index:2;
}

.video-cta-actions a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 18px;
  border-radius:12px;
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
  text-decoration:none;
  transition:.25s ease;
}

.video-cta-actions a:first-child{
  background:#F5820A;
  color:#fff;
  box-shadow:0 12px 28px rgba(245,130,10,.28);
}

.video-cta-actions a:last-child{
  background:#fff;
  color:#0D1F3C;
}

.video-cta-actions a:hover{
  transform:translateY(-2px);
}

/* RESPONSIVE */

@media(max-width:980px){
  .video-gallery{
    grid-template-columns:1fr 1fr;
    grid-auto-rows:220px;
  }

  .video-featured{
    grid-column:span 2;
    grid-row:span 1;
    min-height:330px;
  }

  .video-bottom-cta{
    flex-direction:column;
    text-align:center;
  }

  .video-cta-actions{
    justify-content:center;
  }
}

@media(max-width:620px){
  .video-section{
    padding:52px 5%;
  }

  .video-head h2{
    font-size:32px;
  }

  .video-gallery{
    grid-template-columns:1fr;
    grid-auto-rows:240px;
  }

  .video-featured{
    grid-column:auto;
    min-height:300px;
  }

  .video-caption h3{
    font-size:23px;
  }

  .video-cta-actions{
    width:100%;
  }

  .video-cta-actions a{
    width:100%;
  }
}



.float-wa{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:9999;
  display:flex;
  align-items:center;
  gap:12px;
  min-height:64px;
  padding:10px 22px 10px 10px;
  border-radius:999px;
  background:linear-gradient(135deg,#25D366,#0FB955);
  color:#fff;
  text-decoration:none;
  box-shadow:
    0 18px 42px rgba(37,211,102,.42),
    inset 0 0 0 1px rgba(255,255,255,.22);
  overflow:hidden;
  isolation:isolate;
  animation:waFloat 3.2s ease-in-out infinite;
  transition:.25s ease;
}

.float-wa::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.26),transparent);
  transform:translateX(-130%);
  transition:.7s ease;
  z-index:-1;
}

.float-wa:hover{
  transform:translateY(-4px) scale(1.03);
  box-shadow:
    0 24px 54px rgba(37,211,102,.52),
    inset 0 0 0 1px rgba(255,255,255,.28);
}

.float-wa:hover::before{
  transform:translateX(130%);
}

@keyframes waFloat{
  0%,100%{
    transform:translateY(0);
  }
  50%{
    transform:translateY(-6px);
  }
}

.wa-logo{
  width:46px;
  height:46px;
  border-radius:50%;
  background:#fff;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  box-shadow:0 10px 22px rgba(0,0,0,.16);
  position:relative;
  z-index:2;
}

.wa-logo svg{
  width:34px;
  height:34px;
  display:block;
}

.wa-copy{
  display:flex;
  flex-direction:column;
  line-height:1.05;
  position:relative;
  z-index:2;
}

.wa-copy small{
  color:rgba(255,255,255,.86);
  font-size:10px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.wa-copy strong{
  color:#fff;
  font-size:17px;
  font-weight:900;
  letter-spacing:-.2px;
  margin-top:4px;
}

.wa-ripple{
  position:absolute;
  left:32px;
  top:50%;
  width:46px;
  height:46px;
  border-radius:50%;
  background:rgba(255,255,255,.26);
  transform:translate(-50%,-50%);
  animation:waRipple 1.9s ease infinite;
  pointer-events:none;
  z-index:1;
}

@keyframes waRipple{
  0%{
    transform:translate(-50%,-50%) scale(.9);
    opacity:.7;
  }
  75%{
    transform:translate(-50%,-50%) scale(2.05);
    opacity:0;
  }
  100%{
    opacity:0;
  }
}

@media(max-width:640px){
  .float-wa{
    right:14px;
    bottom:84px;
    min-height:58px;
    padding:9px 17px 9px 9px;
  }

  .wa-logo{
    width:42px;
    height:42px;
  }

  .wa-logo svg{
    width:31px;
    height:31px;
  }

  .wa-copy strong{
    font-size:15px;
  }

  .wa-copy small{
    font-size:9px;
  }
}


/* QuoteIQ embedded CRM form — cleaner embedded layout */
html, body { color-scheme: light !important; }

/* Keep the form side clean and avoid the "card inside card" look. */
.ppx-form-card{
  background:#ffffff;
  border:1px solid rgba(197,238,233,.95);
  border-radius:28px;
  box-shadow:0 24px 64px rgba(13,43,42,.13);
}
.ppx-form-card #form-body{
  padding:32px 30px 26px;
}
.ppx-form-eyebrow{
  margin-bottom:12px;
}
.ppx-form-card h2{
  font-size:34px;
  line-height:1.02;
  margin-bottom:12px;
}
.ppx-form-sub{
  margin:0 0 20px;
  max-width:330px;
  color:#214F4A;
  font-size:14.5px;
  line-height:1.55;
  font-weight:750;
}

.qiq-form-wrap{
  width:100%;
  min-height:500px;
  background:transparent !important;
  border:0 !important;
  border-radius:0 !important;
  padding:0 !important;
  overflow:visible;
  box-shadow:none !important;
  color-scheme:light !important;
  position:relative;
}
.qiq-form-wrap::before{display:none !important;}
.qiq-form-wrap iframe{
  width:100% !important;
  max-width:100% !important;
  border:0 !important;
  color-scheme:light !important;
  background:#ffffff !important;
  border-radius:18px !important;
  box-shadow:0 16px 38px rgba(13,31,60,.08) !important;
}

/* These rules catch QuoteIQ when it renders directly inside the page instead of an iframe. */
#qiq-form,
#qiq-form *{
  color-scheme:light !important;
  box-sizing:border-box !important;
}
#qiq-form{
  position:relative;
  z-index:2;
  width:100% !important;
  max-width:100% !important;
  background:transparent !important;
  color:#0D1F3C !important;
}
#qiq-form > *{
  width:100% !important;
  max-width:100% !important;
  margin-left:0 !important;
  margin-right:0 !important;
}
#qiq-form form,
#qiq-form [class*="form"],
#qiq-form [class*="container"],
#qiq-form [class*="card"]{
  width:100% !important;
  max-width:100% !important;
  background:#ffffff !important;
  color:#0D1F3C !important;
  border-radius:18px !important;
  box-shadow:none !important;
}
#qiq-form > div:first-child,
#qiq-form form:first-child{
  border:1.5px solid #DDEDEA !important;
  box-shadow:0 16px 38px rgba(13,31,60,.08) !important;
  padding:24px 22px !important;
}
#qiq-form h1,
#qiq-form h2,
#qiq-form h3,
#qiq-form h4{
  color:#0D1F3C !important;
  font-weight:900 !important;
  letter-spacing:-.4px !important;
  text-align:left !important;
}
#qiq-form h1{font-size:22px !important;line-height:1.15 !important;margin-bottom:6px !important;}
#qiq-form h2,#qiq-form h3{font-size:20px !important;line-height:1.2 !important;margin-bottom:6px !important;}
#qiq-form p,
#qiq-form span,
#qiq-form strong,
#qiq-form div{
  color:#0D1F3C !important;
}
#qiq-form p{font-size:13px !important;color:#5A6A85 !important;}
#qiq-form label{
  color:#0D1F3C !important;
  font-weight:850 !important;
  font-size:13px !important;
  margin-bottom:6px !important;
}
#qiq-form input,
#qiq-form textarea,
#qiq-form select{
  width:100% !important;
  background:#ffffff !important;
  color:#0D1F3C !important;
  border:1.5px solid #D1D9E6 !important;
  border-radius:10px !important;
  min-height:44px !important;
  padding:10px 12px !important;
  box-shadow:none !important;
}
#qiq-form textarea{min-height:92px !important;}
#qiq-form input::placeholder,
#qiq-form textarea::placeholder{
  color:#7A8AA0 !important;
  opacity:1 !important;
}
#qiq-form input:focus,
#qiq-form textarea:focus,
#qiq-form select:focus{
  border-color:#1B9E8E !important;
  outline:none !important;
  box-shadow:0 0 0 4px rgba(27,158,142,.12) !important;
}
#qiq-form button,
#qiq-form input[type="submit"]{
  width:100% !important;
  min-height:48px !important;
  background:linear-gradient(135deg,#F5820A,#FFB000) !important;
  color:#ffffff !important;
  border:0 !important;
  border-radius:12px !important;
  font-weight:900 !important;
  text-transform:uppercase !important;
  box-shadow:0 12px 28px rgba(245,130,10,.28) !important;
}
.ppx-privacy{
  margin-top:14px !important;
  padding:10px 12px;
  border-radius:999px;
  background:#F8FFFE;
  border:1px solid #DDEDEA;
  text-align:center;
  color:#2D5C56 !important;
  font-size:11px !important;
  font-weight:850 !important;
}

@media (prefers-color-scheme: dark){
  html, body, .ppx-lead-section, .ppx-form-card, .qiq-form-wrap, #qiq-form{
    color-scheme:light !important;
    background-color:#ffffff !important;
  }
}

@media(max-width:520px){
  .ppx-form-card #form-body{padding:24px 20px 22px;}
  .ppx-form-card h2{font-size:30px;}
  .qiq-form-wrap{min-height:540px;}
}
