@charset "utf-8";
/* CSS Document */
@charset "utf-8";
/* CSS Document */

:root{
  --brand:#0D72FF;      
  --brand-600:#1d4ed8;
  --ink:#0f172a;
  --muted:#64748b;
  --line:#e6edf5;
  --card:#ffffff;
  --bg:#ffffff;
  --soft:#f6f8fc;
  --shadow: 0 18px 50px rgba(15,23,42,.08);
  --shadow-sm: 0 10px 26px rgba(15,23,42,.08);
  --radius:16px;
}

body{
  color:var(--ink);
  background:var(--bg);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

/* Top nav */
.nav-wrap{
  border-bottom:1px solid rgba(15,23,42,.06);
  background:#fff;
}
.brand-mark{
  width:22px;height:22px;border-radius:6px;
  background:linear-gradient(180deg, #3b82f6, #1d4ed8);
  display:inline-block;
  box-shadow:0 10px 22px rgba(37,99,235,.25);
}
.nav-link{
  color:#0b1220;
  font-weight:500;
  font-size:.75rem;
}
.navbar-nav .nav-link:hover{
  color:#3F87F5 !important;
}

.btn-brand{
  background:var(--brand);
  border-color:var(--brand);
  font-weight:600;
  padding:.62rem 1rem;
  border-radius:12px;
  box-shadow:0 12px 26px rgba(37,99,235,.18);
}
.btn-brand:hover{
  background:var(--brand-600);
  border-color:var(--brand-600);
}

/* Hero */
.hero{
  position:relative;
  overflow:hidden;
  padding: 72px 0 56px;
}

.hero h1{
  letter-spacing:-.02em;
  line-height:1.05;
  font-size: clamp(2.2rem, 3.2vw, 3.1rem);
  font-weight:800;
  margin-bottom:12px;
}
.hero .price-blue{ color:var(--brand); }
.text-blue{ color:var(--brand); }
.subcopy{
  color:var(--muted);
  font-size:1.02rem;
  line-height:1.55;
  max-width: 34rem;
}
.trust-row{
  margin-top:18px;
  display:flex; flex-wrap:wrap; gap:14px;
  align-items:center;
  color:var(--muted);
  font-size:.9rem;
}
.star{
  color:#f59e0b;
  letter-spacing:.1em;
  font-size:.9rem;
}
.pill{
  border:1px solid rgba(15,23,42,.10);
  background:#fff;
  border-radius:999px;
  padding:.35rem .6rem;
  display:inline-flex; align-items:center; gap:.45rem;
  box-shadow:0 10px 22px rgba(15,23,42,.06);
}
.pill i{ color:var(--brand); }

.hero-form{
  margin-top:18px;
  max-width: 520px;
}
.hero-form .form-control, .hero-form .form-select{
  border-radius: 12px;
  border-color: rgba(15,23,42,.12);
  padding:.75rem .9rem;
}
.hero-form .form-control:focus, .hero-form .form-select:focus{
  border-color: rgba(37,99,235,.55);
  box-shadow: 0 0 0 .2rem rgba(37,99,235,.12);
}

.hero-figure{
  position:relative;
  display:flex;
  justify-content:center;
  align-items:flex-start;
}
.hero-figure .glow{
  position:absolute;
  width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle at 40% 40%, rgba(37,99,235,.18), rgba(37,99,235,0) 60%);
  filter: blur(6px);
  top:-40px; right:-30px;
  pointer-events:none;
}

/* SINGLE fox-img definition (merged) */
.fox-img{
  width: min(510px, 100%);
  height:auto;
  display:block;
  transform: translateY(-4px);
}

/* Section headings */
.section{
  padding: 54px 0;
}
.section-soft{
  background: #fff;
}
.section-title{
  text-align:center;
  margin-bottom: 26px;
}
.section-title h2{
  font-weight:800;
  letter-spacing:-.02em;
  margin-bottom:8px;
}
.section-title p{
  color:var(--muted);
  margin:0 auto;
  max-width: 44rem;
}

/* Pricing cards */
.pricing-toggle{
  display:inline-flex;
  border:1px solid rgba(15,23,42,.10);
  background:#fff;
  border-radius:999px;
  padding:4px;
  gap:4px;
  box-shadow:0 12px 28px rgba(15,23,42,.06);
}
.toggle-btn{
  border:0;
  border-radius:999px;
  padding:.45rem .9rem;
  font-weight:700;
  font-size:.88rem;
  color:var(--muted);
  background:transparent;
}
.toggle-btn.active{
  background:var(--brand);
  color:#fff;
  box-shadow:0 10px 22px rgba(37,99,235,.18);
}

.price-card{
  border:1px solid rgba(15,23,42,.10);
  border-radius:18px;
  box-shadow:0 14px 34px rgba(15,23,42,.06);
  padding: 18px 18px 16px;
  height:100%;
  background:#fff;
}
.price-card .badge-top{
  display:inline-block;
  background:#eef2ff;
  color:#1d4ed8;
  border:1px solid rgba(29,78,216,.15);
  font-weight:800;
  font-size:.74rem;
  padding:.35rem .6rem;
  border-radius:999px;
  margin-bottom:10px;
}
.price-card h3{
  font-weight:800;
  margin: 0 0 4px;
}
.price-card .price{
  font-size: 2.2rem;
  font-weight:900;
  margin: 10px 0 8px;
  letter-spacing:-.02em;
}
.price-card .price small{
  font-size:.92rem;
  font-weight:700;
  color:var(--muted);
}
.price-card ul{
  margin: 0;
  padding-left: 0;
  list-style:none;
  color: #0b1220;
}
.price-card li{
  display:flex;
  gap:.55rem;
  align-items:flex-start;
  padding: 7px 0;
}
.price-card li i{
  color:#10b981;
  margin-top: 2px;
}
.price-card .btn{
  margin-top: 12px;
  border-radius: 12px;
  font-weight:700;
  padding:.72rem 1rem;
}
.price-card.featured{
  border-color: rgba(37,99,235,.28);
  box-shadow: 0 18px 50px rgba(37,99,235,.12);
}
.price-card.featured .btn{
  background:var(--brand);
  border-color:var(--brand);
  color:#fff;
}
.price-card.featured .btn:hover{
  background:var(--brand-600);
  border-color:var(--brand-600);
}

/* FAQ */
.accordion-button{
  font-weight:700;
  border-radius: 14px !important;
}
.accordion-item{
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 14px !important;
  overflow:hidden;
  box-shadow:0 10px 24px rgba(15,23,42,.04);
}
.accordion-button:not(.collapsed){
  background: rgba(37,99,235,.06);
  color: #0b1220;
  box-shadow:none;
}
.accordion-button:focus{
  box-shadow: 0 0 0 .2rem rgba(37,99,235,.12);
  border-color: rgba(37,99,235,.22);
}

/* Footer */
footer{
  padding: 34px 0;
  border-top:1px solid rgba(15,23,42,.08);
  color:var(--muted);
  font-size:.95rem;
}
footer a{
  color:var(--muted);
  text-decoration:none;
  font-size: 14px;
}
footer a:hover{ color:var(--brand); }

/* Responsive polish */
@media (max-width: 991.98px){
  .hero{ padding: 56px 0 44px; }
  .trust-row{ gap:10px; }
  .price-card{ margin-bottom: 14px; }
}

/* Navbar dropdown: desktop boxed */
.fc-dropdown{
  min-width: 260px;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 18px 50px rgba(15,23,42,.10);
  margin-top: 10px;
}
.fc-dd-item{
  border-radius: 12px;
  padding: 10px 12px;
  font-weight: 500;
  color: #0f172a;
}
.fc-dd-item i{
  width: 20px;
  display: inline-grid;
  place-items: center;
  color: #64748b;
  font-size: 1.05rem;
}
.fc-dd-item:hover,
.fc-dd-item:focus{
  background: rgba(37,99,235,.07);
  color: #0f172a;
}
.fc-dd-item:hover i,
.fc-dd-item:focus i{
  color: #2563eb;
}
.fc-navlink.dropdown-toggle::after{
  margin-left: .45rem;
  vertical-align: .15em;
  opacity: .8;
}

/* === Mobile-only: remove dropdown "box" look === */
@media (max-width: 991.98px) {
  .dropdown-menu.fc-dropdown{
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    margin-top: .25rem !important;
    min-width: 0 !important;
    width: 100%;
  }
  .dropdown-menu.fc-dropdown .fc-dd-item{
    padding: 10px 8px;
    border-radius: 10px;
  }
}

/* Scene must be relative so .one/.two/.three can be positioned */
.hero-scene{
  position: relative;
  overflow: visible;
}

/* Position your floating elements (adjust top/left to match design) */
.hero-scene .one,
.hero-scene .two,
.hero-scene .three{
  position:absolute;
  z-index: 5;
  will-change: transform;
  pointer-events:none; /* prevents weird hover/click */
}

/* The actual floating “card” image styling */
.hero-scene .one img,
.hero-scene .two img,
.hero-scene .three img{
  display:block;
  border-radius: 14px; /* optional, looks like screenshot */
  filter: drop-shadow(0 18px 20px rgba(15,23,42,.28));
  /* Or use box-shadow if you prefer: 
     box-shadow: 0 18px 40px rgba(15,23,42,.18); */
}

/* Optional: soft glow behind each floating image */
.hero-scene .one::before,
.hero-scene .two::before,
.hero-scene .three::before{
  content:"";
  position:absolute;
  inset: -14px;
  background: radial-gradient(circle at 40% 40%, rgba(37,99,235,.18), transparent 60%);
  filter: blur(10px);
  z-index: -1;
  opacity: .55;
}

/* Optional: idle “air bob” (independent of scroll) */
@keyframes floatBob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-8px); }
}

/* Apply bob to the IMG so parallax can still transform the container div */
.hero-scene .one img{ animation: floatBob 4.6s ease-in-out infinite; }
.hero-scene .two img{ animation: floatBob 5.2s ease-in-out infinite; }
.hero-scene .three img{ animation: floatBob 6.0s ease-in-out infinite; }
.hero-scene .one{ top: 200px; left: -10px; }
.hero-scene .two{ top: 310px; left: -10px; }
.hero-scene .three{ bottom: 10px; right: -50px; z-index: 4; }

/* Side-by-side container */
.nav-auth{ white-space: nowrap; }

/* Shared base */
.btn-auth-outline,
.btn-auth-solid{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  padding: 14px 30px;
  border-radius: 4px;     /* same rounded feel */
  font-weight: 700;
  font-size: .95rem;
  line-height: 1;
  box-shadow: none !important;   /* no shadow */
}

/* Login (white) */
.btn-auth-outline{
  background:#ffffff;
  color:#0f172a;
  border: 1px solid #e5e7eb;     /* light border like screenshot */
}
.btn-auth-outline:hover,
.btn-auth-outline:focus{
  background:#ffffff;
  border-color:#293865;
  color:#0f172a;
}

/* Create Free Account (blue) */
.btn-auth-solid{
  background:#0D72FF;           /* screenshot-style blue */
  border: 1px solid #0D72FF;
  color:#ffffff;
}
.btn-auth-solid:hover,
.btn-auth-solid:focus{
  background:#0D72FF;           /* slightly darker hover */
  border-color:#0D72FF;
  color:#ffffff;
}

/* Icons */
.btn-auth-outline i,
.btn-auth-solid i{
  font-size: 1.05rem;
  line-height: 1;
}

/* NAV AUTH BUTTONS (hard override so they don't look like plain links) */
.nav-wrap .nav-auth a.btn-auth{
  display:inline-flex !important;
  align-items:center !important;
  gap:.55rem !important;
  padding: 12px 30px !important;
  border-radius: 4px !important;
  font-weight: 700 !important;
  font-size: .95rem !important;
  line-height: 1 !important;
  box-shadow:none !important;
  text-decoration:none !important;
}

.nav-wrap .nav-auth a.btn-auth-outline{
  background:#fff !important;
  color:#0f172a !important;
  border:1px solid #e5e7eb !important;
}
.nav-wrap .nav-auth a.btn-auth-outline:hover{
  border-color:#293865 !important;
}

.nav-wrap .nav-auth a.btn-auth-solid{
  background:#0D72FF !important;
  border:1px solid #0D72FF !important;
  color:#fff !important;
}
.nav-wrap .nav-auth a.btn-auth-solid:hover{
  background:#0D72FF !important;
  border-color:#0D72FF !important;
}

/* Keeps icons aligned */
.nav-wrap .nav-auth a.btn-auth i{
  font-size:1.05rem !important;
  line-height:1 !important;
}


/* FLOAT BOB ANIMATION (UPDATED TO A UNIQUE KEYFRAMES NAME) */
.floatBob{
  animation: floatBobRecreation 3.2s ease-in-out infinite;
}
@keyframes floatBobRecreation{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-10px); }
}

/* (everything after remains the same) */

/* Apply bob to the IMG so parallax can still transform the container div */
.hero-scene .one img{ animation: floatBob 4.6s ease-in-out infinite; }
.hero-scene .two img{ animation: floatBob 5.2s ease-in-out infinite; }
.hero-scene .three img{ animation: floatBob 6.0s ease-in-out infinite; }
.hero-scene .one{ top: 200px; left: -10px; }
.hero-scene .two{ top: 310px; left: -10px; }
.hero-scene .three{ bottom: 10px; right: -50px; z-index: 4; }



/* Side-by-side container */
.nav-auth{ white-space: nowrap; }

/* Shared base */
.btn-auth-outline,
.btn-auth-solid{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  padding: 14px 30px;
  border-radius: 4px;     /* same rounded feel */
  font-weight: 700;
  font-size: .95rem;
  line-height: 1;
  box-shadow: none !important;   /* no shadow */
}

/* Login (white) */
.btn-auth-outline{
  background:#ffffff;
  color:#0f172a;
  border: 1px solid #e5e7eb;     /* light border like screenshot */
}
.btn-auth-outline:hover,
.btn-auth-outline:focus{
  background:#ffffff;
  border-color:#293865;
  color:#0f172a;
}

/* Create Free Account (blue) */
.btn-auth-solid{
  background:#0D72FF;           /* screenshot-style blue */
  border: 1px solid #0D72FF;
  color:#ffffff;
}
.btn-auth-solid:hover,
.btn-auth-solid:focus{
  background:#0D72FF;           /* slightly darker hover */
  border-color:#0D72FF;
  color:#ffffff;
}

/* Icons */
.btn-auth-outline i,
.btn-auth-solid i{
  font-size: 1.05rem;
  line-height: 1;
}

/* NAV AUTH BUTTONS (hard override so they don't look like plain links) */
.nav-wrap .nav-auth a.btn-auth{
  display:inline-flex !important;
  align-items:center !important;
  gap:.55rem !important;
  padding: 12px 30px !important;
  border-radius: 4px !important;
  font-weight: 700 !important;
  font-size: .95rem !important;
  line-height: 1 !important;
  text-decoration: none !important;
  box-shadow: none !important;

  /* beat "nav-link" / theme rules */
  background-clip: padding-box !important;
}

/* Outline (Login) */
.nav-wrap .nav-auth a.btn-auth-outline{
  background:#ffffff !important;
  color:#304469 !important;
  border: 1px solid #e5e7eb !important;
}
.nav-wrap .nav-auth a.btn-auth-outline:hover{
  background:#293865 !important;
  border-color:#293865 !important;
  color:#ffffff !important;
}

/* Solid (Create account) */
.nav-wrap .nav-auth a.btn-auth-solid{
  background:#0D72FF !important;
  border: 1px solid #0D72FF !important;
  color:#ffffff !important;
}
.nav-wrap .nav-auth a.btn-auth-solid:hover{
  background:#3e5ce7 !important;
  border-color:#3e5ce7 !important;
  color:#ffffff !important;
}

/* Icons */
.nav-wrap .nav-auth a.btn-auth i{
  font-size: 1.05rem !important;
  line-height: 1 !important;
}

/* Custom button (no underline) */
.btn-start-track{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 14px 30px;
  border-radius: 4px;
  background:#3f87f5;          /* screenshot blue */
  color:#fff;
  font-weight:800;
  font-size:.95rem;
  line-height:1;
  text-decoration:none;        /* removes underline */
  border: 0;
}

.btn-start-track:hover,
.btn-start-track:focus{
  background:#2f76e3;
  color:#fff;
  text-decoration:none;
}

/* Left icon square */
.btn-start-ico{
  width:22px;
  height:22px;
  border-radius: 6px;
  background: rgba(255,255,255,.18);
  display:inline-grid;
  place-items:center;
}

.btn-start-ico i{
  font-size: 1rem;
  line-height:1;
}



/* HR color utility classes */
.hr-lightgray { border:0; border-top:1px solid #efefef; opacity:1; }
.hr-gray      { border:0; border-top:1px solid #cbd5e1; opacity:1; }
.hr-darkgray  { border:0; border-top:1px solid #94a3b8; opacity:1; }

.hr-blue      { border:0; border-top:1px solid #3f87f5; opacity:1; }
.hr-brand     { border:0; border-top:1px solid var(--brand); opacity:1; }

.hr-green     { border:0; border-top:1px solid #22c55e; opacity:1; }
.hr-orange    { border:0; border-top:1px solid #f59e0b; opacity:1; }
.hr-red       { border:0; border-top:1px solid #ef4444; opacity:1; }

/* Optional thickness helpers */
.hr-2 { border-top-width:2px; }
.hr-3 { border-top-width:3px; }

/* Optional dashed/dotted */
.hr-dashed { border-top-style:dashed; }
.hr-dotted { border-top-style:dotted; }







/* === Get Started Section (uses your existing :root vars + font stack) === */
.gs-wrap{ padding: 64px 0; }

.gs-kicker{
  color: var(--brand);
  font-weight: 800;
  font-size: .92rem;
  letter-spacing: .02em;
  margin-bottom: 12px;
}

.gs-title{
  font-weight: 900;
  letter-spacing: -0.02em;
  font-size: clamp(2.1rem, 3.2vw, 3rem);
  line-height: 1.08;
  margin: 0 0 14px;
  color: var(--ink);
}

.gs-underline{
  text-decoration: underline;
  text-decoration-thickness: 4px;
  text-underline-offset: 8px;
  text-decoration-color: rgba(37,99,235,.35);
}

.gs-copy{
  color: var(--muted);
  font-size: 1.05rem;
  line-height: 1.6;
  max-width: 36rem;
  margin: 0 0 20px;
}

.gs-steps{ display:grid; gap: 12px; margin: 10px 0 26px; }

.gs-step{
  display:flex;
  align-items:flex-start;
  gap: 14px;
}

.gs-check{
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: #f1f5f9;
  border: 1px solid rgba(15,23,42,.10);
  display:inline-grid;
  place-items:center;
  flex: 0 0 auto;
}

.gs-check i{
  color: var(--ink);
  font-size: 1.05rem;
}

.gs-step-text{
  color: var(--ink);
  font-weight: 700;
  line-height: 1.45;
  margin-top: 2px;
}

.gs-step-text strong{ font-weight: 900; }

.gs-link{
  color: var(--brand);
  font-weight: 900;
  text-decoration: none;
}
.gs-link:hover{ text-decoration: underline; }

.gs-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 14px 22px;
  border-radius: 8px;
  background: #3f87f5;          /* matches your screenshot blue */
  color: #fff;
  font-weight: 900;
  text-decoration: none;
  border: 1px solid #3f87f5;
}
.gs-btn:hover{
  background: #2f76e3;
  border-color:#2f76e3;
  color:#fff;
}

/* Right photo frame (navy dotted card) */
.gs-photo-frame{
  width: min(520px, 100%);
  border-radius: 22px;
  padding: 26px;
  background-color: #2f4368; /* navy base */
  /* dotted pattern */
  background-image:
    radial-gradient(rgba(255,255,255,.20) 1.2px, transparent 1.2px);
  background-size: 18px 18px;
  box-shadow: 0 28px 70px rgba(15,23,42,.12);
}

.gs-photo-inner{
  border-radius: 18px;
  overflow:hidden;
  background:#fff;
}

.gs-photo{
  width: 100%;
  height: 420px;              /* adjust to match your image */
  object-fit: cover;
  display:block;
}

/* responsive tweaks */
@media (max-width: 991.98px){
  .gs-photo{ height: 360px; }
  .gs-photo-frame{ margin-top: 10px; }
}




/* ALL SIDES */
.p-5{padding:5px!important;}
.p-10{padding:10px!important;}
.p-15{padding:15px!important;}
.p-20{padding:20px!important;}
.p-25{padding:25px!important;}
.p-30{padding:30px!important;}
.p-35{padding:35px!important;}
.p-40{padding:40px!important;}
.p-45{padding:45px!important;}
.p-50{padding:50px!important;}
.p-55{padding:55px!important;}
.p-60{padding:60px!important;}
.p-65{padding:65px!important;}
.p-70{padding:70px!important;}
.p-75{padding:75px!important;}
.p-80{padding:80px!important;}
.p-85{padding:85px!important;}
.p-90{padding:90px!important;}
.p-95{padding:95px!important;}
.p-100{padding:100px!important;}
.p-105{padding:105px!important;}
.p-110{padding:110px!important;}
.p-115{padding:115px!important;}
.p-120{padding:120px!important;}
.p-125{padding:125px!important;}
.p-130{padding:130px!important;}
.p-135{padding:135px!important;}
.p-140{padding:140px!important;}
.p-145{padding:145px!important;}
.p-150{padding:150px!important;}

/* TOP */
.pt-5{padding-top:5px!important;}
.pt-10{padding-top:10px!important;}
.pt-15{padding-top:15px!important;}
.pt-20{padding-top:20px!important;}
.pt-25{padding-top:25px!important;}
.pt-30{padding-top:30px!important;}
.pt-35{padding-top:35px!important;}
.pt-40{padding-top:40px!important;}
.pt-45{padding-top:45px!important;}
.pt-50{padding-top:50px!important;}
.pt-55{padding-top:55px!important;}
.pt-60{padding-top:60px!important;}
.pt-65{padding-top:65px!important;}
.pt-70{padding-top:70px!important;}
.pt-75{padding-top:75px!important;}
.pt-80{padding-top:80px!important;}
.pt-85{padding-top:85px!important;}
.pt-90{padding-top:90px!important;}
.pt-95{padding-top:95px!important;}
.pt-100{padding-top:100px!important;}
.pt-105{padding-top:105px!important;}
.pt-110{padding-top:110px!important;}
.pt-115{padding-top:115px!important;}
.pt-120{padding-top:120px!important;}
.pt-125{padding-top:125px!important;}
.pt-130{padding-top:130px!important;}
.pt-135{padding-top:135px!important;}
.pt-140{padding-top:140px!important;}
.pt-145{padding-top:145px!important;}
.pt-150{padding-top:150px!important;}

/* BOTTOM */
.pb-5{padding-bottom:5px!important;}
.pb-10{padding-bottom:10px!important;}
.pb-15{padding-bottom:15px!important;}
.pb-20{padding-bottom:20px!important;}
.pb-25{padding-bottom:25px!important;}
.pb-30{padding-bottom:30px!important;}
.pb-35{padding-bottom:35px!important;}
.pb-40{padding-bottom:40px!important;}
.pb-45{padding-bottom:45px!important;}
.pb-50{padding-bottom:50px!important;}
.pb-55{padding-bottom:55px!important;}
.pb-60{padding-bottom:60px!important;}
.pb-65{padding-bottom:65px!important;}
.pb-70{padding-bottom:70px!important;}
.pb-75{padding-bottom:75px!important;}
.pb-80{padding-bottom:80px!important;}
.pb-85{padding-bottom:85px!important;}
.pb-90{padding-bottom:90px!important;}
.pb-95{padding-bottom:95px!important;}
.pb-100{padding-bottom:100px!important;}
.pb-105{padding-bottom:105px!important;}
.pb-110{padding-bottom:110px!important;}
.pb-115{padding-bottom:115px!important;}
.pb-120{padding-bottom:120px!important;}
.pb-125{padding-bottom:125px!important;}
.pb-130{padding-bottom:130px!important;}
.pb-135{padding-bottom:135px!important;}
.pb-140{padding-bottom:140px!important;}
.pb-145{padding-bottom:145px!important;}
.pb-150{padding-bottom:150px!important;}

/* LEFT */
.pl-5{padding-left:5px!important;}
.pl-10{padding-left:10px!important;}
.pl-15{padding-left:15px!important;}
.pl-20{padding-left:20px!important;}
.pl-25{padding-left:25px!important;}
.pl-30{padding-left:30px!important;}
.pl-35{padding-left:35px!important;}
.pl-40{padding-left:40px!important;}
.pl-45{padding-left:45px!important;}
.pl-50{padding-left:50px!important;}
.pl-55{padding-left:55px!important;}
.pl-60{padding-left:60px!important;}
.pl-65{padding-left:65px!important;}
.pl-70{padding-left:70px!important;}
.pl-75{padding-left:75px!important;}
.pl-80{padding-left:80px!important;}
.pl-85{padding-left:85px!important;}
.pl-90{padding-left:90px!important;}
.pl-95{padding-left:95px!important;}
.pl-100{padding-left:100px!important;}
.pl-105{padding-left:105px!important;}
.pl-110{padding-left:110px!important;}
.pl-115{padding-left:115px!important;}
.pl-120{padding-left:120px!important;}
.pl-125{padding-left:125px!important;}
.pl-130{padding-left:130px!important;}
.pl-135{padding-left:135px!important;}
.pl-140{padding-left:140px!important;}
.pl-145{padding-left:145px!important;}
.pl-150{padding-left:150px!important;}

/* RIGHT */
.pr-5{padding-right:5px!important;}
.pr-10{padding-right:10px!important;}
.pr-15{padding-right:15px!important;}
.pr-20{padding-right:20px!important;}
.pr-25{padding-right:25px!important;}
.pr-30{padding-right:30px!important;}
.pr-35{padding-right:35px!important;}
.pr-40{padding-right:40px!important;}
.pr-45{padding-right:45px!important;}
.pr-50{padding-right:50px!important;}
.pr-55{padding-right:55px!important;}
.pr-60{padding-right:60px!important;}
.pr-65{padding-right:65px!important;}
.pr-70{padding-right:70px!important;}
.pr-75{padding-right:75px!important;}
.pr-80{padding-right:80px!important;}
.pr-85{padding-right:85px!important;}
.pr-90{padding-right:90px!important;}
.pr-95{padding-right:95px!important;}
.pr-100{padding-right:100px!important;}
.pr-105{padding-right:105px!important;}
.pr-110{padding-right:110px!important;}
.pr-115{padding-right:115px!important;}
.pr-120{padding-right:120px!important;}
.pr-125{padding-right:125px!important;}
.pr-130{padding-right:130px!important;}
.pr-135{padding-right:135px!important;}
.pr-140{padding-right:140px!important;}
.pr-145{padding-right:145px!important;}
.pr-150{padding-right:150px!important;}



/* Arrow Button Section Below */
.arrow-btn{
  display:inline-flex;
  align-items:center;
  gap:2px;
  padding:12px 30px;
  border-radius:4px;
  background:#0D72FF;      /* normal */
  color:#fff;
  text-decoration:none;
  font-weight:700;
  transition: background-color .18s ease, transform .18s ease;
}

/* Arrow starts as ↗ (up-right) */
.arrow-btn__icon{
  display:inline-flex;
  transform: rotate(-45deg);
  transition: transform .18s ease;
  transform-origin: 50% 50%;
}

/* Hover: arrow becomes → and button darkens */
.arrow-btn:hover{
  background:#3E5CE7;
}

.arrow-btn:hover .arrow-btn__icon{
  transform: rotate(0deg);
}

.arrow-btn:active{
  transform: translateY(1px);
}

@media (prefers-reduced-motion: reduce){
  .arrow-btn,
  .arrow-btn__icon{
    transition:none;
  }
}

.tiny{
  color:var(--muted);
  font-size:.86rem;
}
.cta{
  background: #304469;
  color:#fff;
  padding: 64px 0;
}

.f-sm{
  color:#737373;
  font-size:12px;
}




/* SECTION LAYOUT */
.recreation-section{
  padding: 120px 0;
  background:#fff;
}

.recreation-wrap{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 24px;
  display:grid;
  grid-template-columns: 520px 1fr;
  gap: 64px;
  align-items:center;
}

/* LEFT STACK */
.recreation-media{ position:relative; }

.media-stack{
  position:relative;
  width: 520px;
  max-width: 100%;
  aspect-ratio: 1.15 / 1;
}

/* Purple back plate */
.media-back{
  position:absolute;
  right: 6%;
  top: 2%;
  width: 78%;
  height: 78%;
  background:#2F4368;
  border-radius: 56px;
  z-index:0;
}

/* Main photo */
.media-photo{
  position:absolute;
  left: 0;
  top: 10%;
  width: 82%;
  height: 90%;
  border-radius: 56px;
  overflow:hidden;
  z-index:1;
}

.media-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* Floating card placement */
.media-floater{
  position:absolute;
  left: 56%;
  bottom: -12%;
  z-index:2;
}

/* FLOAT BOB ANIMATION */
.floatBob{
  animation: floatBob 3.2s ease-in-out infinite;
}
@keyframes floatBob{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-10px); }
}

/* CARD */
.speed-card img{
  width: 240px;
  border-radius: 22px;
  box-shadow: 0 18px 50px rgba(15, 23, 42, .14);
}

.speed-arc{
  width: 150px;
  height: 80px;
  margin: 0 auto 10px;
  border-top-left-radius: 999px;
  border-top-right-radius: 999px;
  border: 10px solid #eef2f7;        /* light arc base */
  border-bottom: 0;
  position:relative;
  overflow:hidden;
}
.speed-arc::after{
  content:"";
  position:absolute;
  inset:-10px -10px 0 -10px;
  border-top-left-radius: 999px;
  border-top-right-radius: 999px;
  border: 10px solid #684DFF;        /* purple arc */
  border-bottom:0;
  clip-path: polygon(0 0, 82% 0, 82% 100%, 0 100%); /* arc fill amount */
}

/* RIGHT CONTENT */
.recreation-content h2{
  font-size: 48px;
  line-height: 1.1;
  margin: 0 0 16px;
  color:#212529;
  font-weight:800;
}

.recreation-content p{
  margin: 0 0 26px;
  color:#51607a;
  line-height:1.7;
  max-width: 540px;
}

/* Checks */
.check-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px 34px;
  margin: 10px 0 28px;
}

.check-item{
  display:flex;
  align-items:center;
  gap: 12px;
  color:#64748b;
  font-weight:700;
}

.check-icon{
  width: 28px;
  height: 28px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius: 999px;
  background: rgba(62, 92, 231, .12);
  color:#3E5CE7;
  font-weight: bolder;
  flex: 0 0 28px;
}


/* RESPONSIVE */
@media (max-width: 992px){
  .recreation-wrap{
    grid-template-columns: 1fr;
    gap: 36px;
  }
  .media-stack{
    width: 100%;
    max-width: 560px;
    margin: 0 auto;
  }
  .recreation-content h2{
    font-size: 40px;
  }
}
@media (max-width: 520px){
  .check-grid{
    grid-template-columns: 1fr;
  }
  .recreation-content h2{
    font-size: 34px;
  }
  .speed-card{
    width: 220px;
  }
}



/* HOW IT WORKS - SECTION */
.howitworks{
  background:#F2F9FF;
  padding: 90px 0 110px;
}

.howitworks__wrap{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 24px;
}

.howitworks__head{
  text-align:center;
  margin-bottom: 54px;
}

.howitworks__kicker{
  font-weight:800;
  font-size: 13px;
  letter-spacing: .16em;
  color:#3F87F5;              /* green kicker */
  margin-bottom: 14px;
}

.howitworks__title{
  margin: 0 0 18px;
  font-size: clamp(2.2rem, 3.2vw, 3.1rem);
  line-height: 1.08;
  font-weight: 900;
  color:#0f172a;
}

.howitworks__sub{
  margin: 0 auto;
  max-width: 720px;
  color:#6b7280;
  line-height: 1.8;
  font-size: 16px;
}

/* STEPS GRID */
.howitworks__steps{
  --step-gap: 44px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--step-gap);
}

/* dotted connectors (between 1-2 and 2-3) */
.step-card{
  position:relative;
  background:#fff;
  border-radius: 6px;
  padding: 56px 34px 40px;
  text-align:center;
  box-shadow: 0 18px 40px rgba(15, 23, 42, .06);
  min-height: 220px;
}

/* draw a dotted line from card to the next card */
.step-card:not(:last-child)::after{
  content:"";
  position:absolute;
  top: 58%;
  left: 100%;
  width: var(--step-gap);           /* exactly the gap */
  border-top: 2px dashed #7b8798;
  opacity:.75;
}

/* Number bubble */
.step-card__num{
  width: 78px;
  height: 78px;
  border-radius: 999px;
  background: rgba(63, 135, 245, .12);
  color:#3f87f5;
  font-weight: 900;
  font-size: 34px;
  display:flex;
  align-items:center;
  justify-content:center;

  /* float above the card */
  position:absolute;
  left: 50%;
  top: -34px;
  transform: translateX(-50%);
  box-shadow: 0 14px 30px rgba(15, 23, 42, .06);
}

.step-card__title{
  margin: 18px 0 10px;
  font-size: 22px;
  font-weight: 900;
  color:#0f172a;
}

.step-card__text{
  margin: 0 auto;
  max-width: 260px;
  color:#6b7280;
  line-height: 1.75;
}

/* RESPONSIVE */
@media (max-width: 992px){
  .howitworks__title{ font-size: 44px; }
  .howitworks__steps{
    grid-template-columns: 1fr;
    gap: 26px;
  }
  .step-card:not(:last-child)::after{ display:none; }
  .step-card{ padding: 56px 26px 34px; }
}

@media (max-width: 520px){
  .howitworks{ padding: 70px 0 90px; }
  .howitworks__title{ font-size: 36px; }
}

/* Hide on mobile (Bootstrap-like breakpoint: < 768px) */
@media (max-width: 767.98px){
  .hide-mobile{ display:none !important; }
}


/* LEGAL - TERMS - PRIVACY CONTENT */
.head-blue {background: #F2F9FF;}
.legal {color:var(--muted); padding: 125px 75px}
.legal h5 {color: #313744; font-weight: 900; font-size: 18px;}




/* =========================
   LOGIN PAGE
   ========================= */

/* Background like screenshot (soft green tint) */
.auth-page{
  min-height: 100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 56px 18px 60px;
  background: #F2F9FF; /* screenshot-like */
}

/* Overall center container */
.auth-shell{
  width: min(760px, 100%);
  text-align:center;
}

/* Logo row */
.auth-brand{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: 18px;
  color: var(--ink);
  margin-bottom: 18px;
}

.auth-mark{
  width: 30px;
  height: 30px;
  display:inline-grid;
  place-items:center;
}
.auth-mark svg{
  width: 30px;
  height: 30px;
}

/* Big title */
.auth-title{
  margin: 4px 0 8px;
  font-weight: 900;
  letter-spacing: -0.02em;
  line-height: 1.05;
  font-size: clamp(40px, 6vw, 64px);
  color: #0b0f0e;
}

/* Card */
.auth-card{
  width: min(520px, 100%);
  margin: 0 auto;
  background: #fff;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 6px; /* screenshot looks slightly squared */
  box-shadow: var(--shadow);
  padding: 30px 36px 22px;
  text-align:left;
}

/* Labels like screenshot */
.auth-label{
  display:block;
  font-size: 15px;
  color: #1a2320;
  margin: 14px 0 8px;
  font-weight: bold;
}

/* Inputs: square-ish */
.auth-input{
  width: 100%;
  height: 46px;
  border-radius: 0;
  border: 1px solid rgba(15,23,42,.16);
  padding: 10px 12px;
  font-size: 15px;
  background:#fff;
  outline:none;
}
.auth-input:focus{
  border-color: rgba(13,114,255,.55);
  box-shadow: 0 0 0 4px rgba(13,114,255,.12);
}

/* Login button: full-width solid brand */
.auth-btn{
  width: 100%;
  height: 56px;
  margin-top: 18px;  
  border-radius: 4px;
  border: 1px solid var(--brand);
  background: var(--brand);
  color:#fff;
  font-weight: 800;
  font-size: 16px;
  cursor:pointer;
  transition: background-color .15s ease, transform .06s ease;
}
.auth-btn:hover{
  background: var(--brand-600);
  border-color: var(--brand-600);
}
.auth-btn:active{
  transform: translateY(1px);
}

/* Only the right-side link row */
.auth-row{
  display:flex;
  justify-content:flex-end;
  margin-top: 14px;
  font-size: 14px;
}
.auth-row a{
  color: #0b0f0e;
  text-decoration:none;
  font-weight: 500;
}
.auth-row a:hover{ text-decoration: underline; }

/* Bottom text */
.auth-foot{
  margin-top: 34px;
  font-size: 14px;
  font-weight: 500;
  color: #0b0f0e;
}
.auth-foot strong{ font-weight: 900; }

/* Mobile polish */
@media (max-width: 520px){
  .auth-card{ padding: 24px 18px 18px; }
}


/* =========================
   REGISTER PAGE 
   ========================= */

.reg-page{
  min-height: 100vh;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding: 56px 18px 64px;
  background: #F2F9FF; /* matches screenshot #1 background */
}

.reg-shell{
  width: min(900px, 100%);
  text-align:center;
}

/* Big headline */
.reg-title{
  margin: 8px 0 26px;
  font-weight: 900;
  letter-spacing: -0.02em;
  line-height: 1.05;
  font-size: clamp(38px, 6vw, 60px);
  color: #0b0f0e;
}

/* Card */
.reg-card{
  width: min(520px, 100%);
  margin: 0 auto;
  background: #fff;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 6px;
  box-shadow: var(--shadow);
  padding: 28px 36px 24px;
  text-align:left;
}

/* Header like screenshot #2 (icon + title + blurb) */
.reg-head{
  display:flex;
  gap: 12px;
  align-items:flex-start;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(15,23,42,.08);
  margin-bottom: 18px;
}

.reg-ico{
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: rgba(13,114,255,.12);
  display:inline-grid;
  place-items:center;
  flex: 0 0 34px;
}
.reg-ico svg{
  width: 18px;
  height: 18px;
  fill: none;
  stroke: var(--brand);
  stroke-width: 2;
}

.reg-head h2{
  margin: 0;
  font-size: 22px;
  font-weight: 900;
  color: var(--ink);
  line-height: 1.15;
}
.reg-head p{
  margin: 6px 0 0;
  color: var(--muted);
  line-height: 1.55;
  font-size: 14px;
}

/* Form label */
.reg-label{
  display:block;
  font-weight: bold;
  font-size: 15px;
  color: #1a2320;
  margin: 16px 0 8px;
}

/* Input group with icon (like screenshot #2) */
.reg-field{
  position:relative;
}

.reg-input{
  width: 100%;
  height: 46px;
  border-radius: 4px;
  border: 1px solid rgba(15,23,42,.12);
  padding: 10px 12px 10px 40px; /* room for icon */
  font-size: 15px;
  background:#fff;
  outline:none;
}
.reg-input:focus{
  border-color: rgba(13,114,255,.55);
  box-shadow: 0 0 0 4px rgba(13,114,255,.12);
}

/* little icon inside input */
.reg-input-ico{
  position:absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  color: rgba(15,23,42,.55);
  display:inline-grid;
  place-items:center;
  pointer-events:none;
}
.reg-input-ico svg{
  width: 18px;
  height: 18px;
  fill: none;
  stroke: rgba(15,23,42,.55);
  stroke-width: 2;
}

/* helper text under username */
.reg-help{
  margin-top: 8px;
  color: #94a3b8;
  font-size: 13px;
}

/* Bottom row: left login link, right button */
.reg-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  margin-top: 22px;
}

.reg-actions a{
  color: var(--brand);
  text-decoration:none;
  font-weight: 800;
}
.reg-actions a:hover{ text-decoration: underline; }

.reg-muted{
  color: #94a3b8;
  font-size: 14px;
}

/* big submit button like screenshot #1 */
.reg-btn{
  width: 100%;
  border: 1px solid var(--brand);
  background: var(--brand);
  color:#fff;
  font-weight: 900;
  border-radius: 4px;
  padding: 12px 18px;
  min-width: 190px;
  cursor:pointer;
  transition: background-color .15s ease, transform .06s ease;
}
.reg-btn:hover{
  background: var(--brand-600);
  border-color: var(--brand-600);
}
.reg-btn:active{ transform: translateY(1px); }

/* Footer line centered like screenshot #1 */
.reg-foot{
  margin-top: 30px;
  text-align:center;
  font-weight: 600;
  color: #0b0f0e;
  font-size: 14px;
}

/* Mobile */
@media (max-width: 720px){
  .reg-card{ padding: 22px 18px 18px; }
  .reg-actions{
    flex-direction: column;
    align-items: stretch;
  }
  .reg-btn{ width:100%; }
  .reg-foot{ margin-top: 22px; }
}


/* =========================
   404 PAGE
   Uses your existing :root vars
   ========================= */

.err404{
  background: #fff;
  padding: 84px 0 90px;
}

.err404__wrap{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 24px;
  display:grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 56px;
  align-items:center;
}

/* Left */
.err404__kicker{
  color: var(--brand);
  font-weight: 900;
  font-size: clamp(2.1rem, 4.4vw, 3.2rem);
  letter-spacing: -0.02em;
  margin: 0 0 10px;
}

.err404__title{
  margin: 0 0 12px;
  font-weight: 700;
  font-size: clamp(1.35rem, 2.2vw, 1.7rem);
  color: #0b1220;
}

.err404__sub{
  margin: 0 0 22px;
  color: #7c8aa5;
  font-size: 1.02rem;
  line-height: 1.65;
  max-width: 32rem;
}

/* Button like screenshot (soft pill) */
.err404__btn{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  font-size: 14px;
  font-weight: bold;
  padding: 12px 18px;
  border-radius: 4px;
  background: rgba(13,114,255,.08);
  border: 1px solid rgba(13,114,255,.18);
  color: var(--brand);
  text-decoration:none;
  transition: background-color .15s ease, border-color .15s ease, transform .06s ease;
}
.err404__btn:hover{
  background: rgba(13,114,255,.12);
  border-color: rgba(13,114,255,.25);
}
.err404__btn:active{ transform: translateY(1px); }

/* Right */
.err404__art{
  display:flex;
  justify-content:flex-end;
}

.err404__img{
  width: min(720px, 100%);
  height: auto;
  display:block;
}

/* Responsive */
@media (max-width: 991.98px){
  .err404{ padding: 64px 0 70px; }
  .err404__wrap{
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .err404__art{ justify-content:center; }
}




/* Recall Checker */
.recall-page{
  max-width: 980px;
  margin: 0 auto;
}

.recall-hero{
  padding-top: 10px;
}

.recall-pill{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.5rem 1rem;
  border-radius: 999px;
  background: rgba(255, 59, 59, .08);
  color:#d11a2a;
  font-weight:600;
  font-size:.9rem;
}

.recall-title{
  font-weight:800;
  letter-spacing:-.02em;
  font-size: clamp(2rem, 3.5vw, 3.1rem);
  color:#0f172a;
}

.recall-subtitle{
  color:#64748b;
  font-size:1.05rem;
  max-width: 720px;
  margin: 0 auto;
}

.recall-tabs{
  background:#f3f6fb;
  border:1px solid rgba(15,23,42,.08);
  border-radius: 14px;
  padding: .35rem;
}

.recall-tab{
  border:0;
  background:transparent;
  padding:.65rem 1.05rem;
  border-radius: 12px;
  font-weight:700;
  color:#334155;
  transition: all .15s ease;
}

.recall-tab.is-active{
  background:#0D72FF;
  color:#fff;
  box-shadow: 0 10px 24px rgba(13,114,255,.22);
}

.recall-panels{
  max-width: 760px;
}

.recall-panel{
  display:none;
}

.recall-panel.is-active{
  display:block;
}

.recall-form-row{
  display:flex;
  gap: 14px;
  align-items:center;
  justify-content:center;
  flex-wrap: wrap;
}

.recall-input-wrap{
  position:relative;
  flex: 1 1 440px;
  max-width: 520px;
}

.recall-input{
  width:100%;
  height: 50px;
  border-radius: 4px;
  border:1px solid rgba(15,23,42,.12);
  background:#fff;
  padding: 0 56px 0 16px;
  font-size: 1rem;
  outline:none;
  transition: box-shadow .15s ease, border-color .15s ease;
}

.recall-input:focus{
  border-color: rgba(13,114,255,.55);
  box-shadow: 0 0 0 .25rem rgba(13,114,255,.14);
}

.recall-counter{
  position:absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  color:#94a3b8;
  font-weight:700;
  font-size:.9rem;
}

.recall-btn{	
  background:#0D72FF;
  text-align: center;
  color:#ffffff;
  gap:.55rem;
  padding: 18px 30px;
  border-radius: 4px;     /* same rounded feel */
  font-weight: 700;
  font-size: .95rem;
  border: 0px;
  line-height: 1;
  box-shadow: none !important;   /* no shadow */
}

.recall-btn:hover,
.recall-btn:focus{
  background:#3E5CE7;    
  color:#ffffff;
}

.recall-hint{
  color:#94a3b8;
  font-size:.95rem;
}

.recall-vehicle-grid{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 14px;
  text-align:left;
}

.recall-vehicle-action{
  grid-column: 1 / -1;
}

.recall-label{
  display:block;
  font-weight:700;
  color:#334155;
  margin-bottom: 6px;
  font-size:.95rem;
}

@media (max-width: 768px){
  .recall-vehicle-grid{ grid-template-columns: 1fr; }
  .recall-btn{ width:100%; }
  .recall-input-wrap{ flex-basis: 100%; }
}

.recall-h2{
  font-weight:800;
  color:#0f172a;
}

.recall-stat-card{
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  border-radius: 16px;
  padding: 22px 18px;
  box-shadow: 0 18px 50px rgba(15,23,42,.06);
  height: 100%;
}

.recall-stat-value{
  font-weight:900;
  font-size: 2.3rem;
  letter-spacing:-.02em;
  margin-bottom: 6px;
}

.recall-stat-sub{
  color:#64748b;
  font-weight:600;
}

.recall-faq{
  background:#f6f8fc;
  border:1px solid rgba(15,23,42,.08);
  border-radius: 18px;
  padding: 26px 26px;
}

.recall-faq-title{
  font-weight:900;
  color:#0f172a;
  margin-bottom: 12px;
}

.recall-faq-item{
  padding: 16px 0;
  border-bottom: 1px solid rgba(15,23,42,.08);
}

.recall-faq-q{
  font-weight:900;
  color:#0f172a;
  margin-bottom: 8px;
}

.recall-faq-a{
  color:#475569;
  font-weight:600;
  line-height:1.55;
}

.recall-alert{
  max-width: 760px;
  margin: 0 auto;
  padding: 12px 14px;
  border-radius: 12px;
  border:1px solid rgba(15,23,42,.10);
  background:#fff;
  text-align:left;
  font-weight:700;
}

.recall-alert.is-error{
  border-color: rgba(220, 38, 38, .25);
  background: rgba(220, 38, 38, .06);
  color:#b91c1c;
}

.recall-alert.is-ok{
  border-color: rgba(22, 163, 74, .25);
  background: rgba(22, 163, 74, .06);
  color:#166534;
}

.recall-results{
  max-width: 760px;
  margin: 0 auto;
  text-align:left;
}

.recall-results-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.recall-results-kicker{
  font-weight:900;
  font-size:.85rem;
  color:#64748b;
  text-transform: uppercase;
  letter-spacing:.08em;
}

.recall-results-title{
  font-weight:900;
  color:#0f172a;
}

.recall-results-meta{
  color:#64748b;
  font-weight:700;
  font-size:.95rem;
}

.recall-card{
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  border-radius: 16px;
  padding: 16px 16px;
  box-shadow: 0 18px 50px rgba(15,23,42,.06);
  margin-bottom: 14px;
}

.recall-card-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 14px;
  margin-bottom: 10px;
}

.recall-card-title{
  font-weight:900;
  color:#0f172a;
  margin:0;
  font-size:1.05rem;
}

.recall-badge{
  display:inline-flex;
  align-items:center;
  padding:.35rem .6rem;
  border-radius: 999px;
  font-weight:900;
  font-size:.8rem;
  background: rgba(13,114,255,.10);
  color:#0D72FF;
  white-space: nowrap;
}

.recall-card-body{
  color:#475569;
  font-weight:600;
  line-height:1.55;
}

.recall-kv{
  margin-top: 10px;
  display:grid;
  grid-template-columns: 140px 1fr;
  gap: 6px 12px;
  font-size: .95rem;
}

.recall-k{
  color:#64748b;
  font-weight:800;
}

.recall-v{
  color:#0f172a;
  font-weight:700;
}




/* Two-column FAQ layout */
.fc-faq2{
  padding: 40px 0;
}

.fc-faq2-grid{
  display:grid;
  grid-template-columns: 1.1fr 1.4fr;
  gap: 42px;
  align-items:start;
}

@media (max-width: 992px){
  .fc-faq2-grid{ grid-template-columns: 1fr; }
}


.fc-faq2-title{
  font-size: clamp(2.2rem, 3.2vw, 3.4rem);
  line-height:1.02;
  font-weight: 300; /* thin look like screenshot */
  margin: 0 0 18px 0;
  color:#0f172a;
}

.fc-faq2-sub{
  color:var(--muted);
  line-height:1.7;
  max-width: 420px;
}

/* Right accordion */
.fc-faq2-right{
  border-top: 1px solid rgba(15,23,42,.18);
}

.fc-faq2-item{
  border-bottom: 1px solid rgba(15,23,42,.18);
}

.fc-faq2-q{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 16px;
  padding: 18px 6px;
  background: transparent;
  border: 0;
  text-align:left;
  cursor:pointer;
  font-weight: 800;
  font-size: 1.05rem;
  color:#0f172a;
}

/* IMPORTANT: remove the default blue glow */
.fc-faq2-q:focus,
.fc-faq2-q:focus-visible{
  outline: none;
  box-shadow: none;
}

/* If you still want a minimal focus indicator for accessibility, use a thin underline */
.fc-faq2-q:focus-visible{
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 6px;
  text-decoration-color: rgba(13,114,255,.45);
}

/* Chevron icon color + "bold-ish" look */
.fc-faq2-icon{
  color: rgba(13,114,255,.65);
  font-size: 1.25rem;
  line-height: 1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

/* Fake-bold for Bootstrap Icons (tiny stroke effect) */
.fc-faq2-icon i{
  text-shadow:
    .5px 0 currentColor,
    -.5px 0 currentColor,
    0 .5px currentColor,
    0 -.5px currentColor;
}

.fc-faq2-a{
  display:none;
  padding: 14px 6px 22px 6px;
  color:#64748b;
  font-weight:normal;
  line-height:1.75;
}

/* OPEN state = show answer and add subtle blue top/bottom lines (like your 3rd image) */
.fc-faq2-item.is-open{
  border-top: 2px solid #efefef thin;
  border-bottom: 2px solid #efefef thin;
}

.fc-faq2-item.is-open .fc-faq2-a{
  display:block;
}

.fc-faq2-item.is-open .fc-faq2-icon{
  color: rgba(13,114,255,.95);
}







/* VIN Decoder Hero */
.vin-decoder-hero{
  padding: 48px 0 40px;
  max-width: 980px;
  margin: 0 auto;
}

.vin-title{
  font-weight: 800;
  letter-spacing: -0.02em;
  font-size: clamp(2.2rem, 4vw, 3.1rem);
  line-height: 1.05;
  margin: 0 0 10px;
  color: #0f172a;
}

.vin-subtitle{
  margin: 0 auto 28px;
  color: #475569;
  font-size: 1.05rem;
  line-height: 1.55;
}

.vin-subtitle-2{
  display: inline-block;
  margin-top: 4px;
}

.vin-form{
  margin-top: 12px;
}

.vin-form-row{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.vin-input-wrap{
  position: relative;
  width: min(560px, 92vw);
}

.vin-input{
  width: 100%;
  height: 56px;
  border-radius: 4px;
  border: 1px solid rgba(15,23,42,.14);
  background: #fff;
  padding: 0 84px 0 18px;  /* right padding for the counter */
  font-size: 1.02rem;
  color: #0f172a;
  outline: none;
  box-shadow: 0 8px 18px rgba(15,23,42,.06);
  transition: border-color .15s ease, box-shadow .15s ease;
}

.vin-input:focus{
  border-color: rgba(13,114,255,.55);
  box-shadow: 0 0 0 4px rgba(13,114,255,.14), 0 10px 22px rgba(15,23,42,.08);
}

.vin-input.is-invalid{
  border-color: rgba(239,68,68,.75);
  box-shadow: 0 0 0 4px rgba(239,68,68,.12), 0 10px 22px rgba(15,23,42,.08);
}

.vin-counter{
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  font-size: .86rem;
  color: #94a3b8;
  user-select: none;
}


.vin-btn{	
  background:#0D72FF;
  text-align: center;
  color:#ffffff;
  gap:.55rem;
  padding: 18px 30px;
  border-radius: 4px;     /* same rounded feel */
  font-weight: 700;
  font-size: .95rem;
  border: 0px;
  line-height: 1;
  box-shadow: none !important;   /* no shadow */
}

.vin-btn:hover,
.vin-btn:focus{
  background:#3E5CE7;    
  color:#ffffff;
}

.vin-btn:disabled{
  opacity: .55;
  cursor: not-allowed;
  box-shadow: none;
}

.vin-help{
  margin-top: 10px;
  font-size: .95rem;
  color: #64748b;
  min-height: 22px;
}

/* Mobile: stack input and button like screenshot spacing */
@media (max-width: 575.98px){
  .vin-btn{ width: min(560px, 92vw); }
}





/* Car Payment Calculator */
.pc-wrap{
  --pc-brand:#2563eb;
  --pc-ink:#0f172a;
  --pc-muted:#64748b;
  --pc-line:#e6edf5;
  --pc-soft:#f6f8fc;
  --pc-shadow: 0 18px 50px rgba(15,23,42,.08);
}

.pc-title{
  font-weight: 800;
  letter-spacing: -0.02em;
  font-size: clamp(2.2rem, 4vw, 3.1rem);
  line-height: 1.05;
  margin: 0 0 10px;
  color: #0f172a;
}

.pc-subtitle{
  color: var(--pc-muted);
  max-width: 720px;
  margin: 0 auto;
}

.pc-card{
  background:#fff;
  border:1px solid var(--pc-line);
  border-radius:18px;
  box-shadow: var(--pc-shadow);
  overflow:hidden;
}

.pc-card-head{
  padding: 22px 22px 0 22px;
}

.pc-h2{
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--pc-ink);
}

.pc-body{
  padding: 18px 22px 22px 22px;
}

.pc-field{
  padding: 14px 0;
}
.pc-field:last-child{ border-bottom:0; padding-bottom:0; }

.pc-label{
  font-size: 18px;
  font-weight: bold;
  color: var(--pc-ink);
  margin-bottom: .55rem;
}

.pc-inputgroup .input-group-text{
  background:#fff;
  border-color: var(--pc-line);
  color: var(--pc-muted);
  font-weight: 700;
}
.pc-inputgroup .form-control{
  border-color: var(--pc-line);
  height: 44px;
  font-weight: 700;
  color: var(--pc-ink);
}
.pc-inputgroup .form-control:focus{
  box-shadow: 0 0 0 .2rem rgba(37,99,235,.12);
  border-color: rgba(37,99,235,.55);
}

.pc-range{ margin-top: .75rem; }
.pc-range-meta{
  display:flex;
  justify-content:space-between;
  font-size:.78rem;
  color: var(--pc-muted);
  margin-top: .2rem;
}

.pc-terms{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top: .35rem;
}
.pc-term-btn{
  border:1px solid var(--pc-line);
  background: #f3f4f6;
  color: #334155;
  padding: 10px 14px;
  border-radius:10px;
  font-weight:800;
  font-size:.85rem;
  min-width: 78px;
}
.pc-term-btn.is-active{
  background: var(--pc-brand);
  border-color: var(--pc-brand);
  color:#fff;
}

.pc-check{
  display:flex;
  align-items:center;
  gap:8px;
  color: var(--pc-muted);
  font-weight: 700;
  font-size: .9rem;
}
.pc-check input{ transform: translateY(1px); }

.pc-summary{
  border-radius:18px;
  background: var(--pc-brand);
  box-shadow: var(--pc-shadow);
  color:#fff;
  padding: 22px;
  max-height: 400px;   /* pick what you want */
  overflow: auto;
}

.pc-summary-kicker{
  opacity:.9;
  font-weight: 700;
  font-size: .85rem;
}

.pc-summary-price{
  font-weight: 900;
  font-size: 3rem;
  letter-spacing: -0.03em;
  margin: 6px 0 2px 0;
}

.pc-summary-sub{
  opacity:.9;
  font-weight: 700;
  font-size: .95rem;
}

.pc-summary-divider{
  border-color: rgba(255,255,255,.18);
  margin: 18px 0;
}

.pc-summary-rows{ display:grid; gap: 14px; }
.pc-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-weight: 800;
}
.pc-row-label{ opacity:.95; }
.pc-row-value{ opacity:1; }

.pc-row-total{
  margin-top: 6px;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,.18);
}

.pc-details{
  border-radius:18px;
  background: #ffffff;
  border:1px solid var(--pc-line);
  color:#666;
  padding: 22px;
  max-height: 760px;   /* pick what you want */
  overflow: auto;
}

.pc-details p{
	font-size: 14px;
}

.pc-details h5{
	font-size: 22px;
	font-weight: bold;
	padding-bottom: 5px;
	border-bottom: thin solid #efefef;
}


/* ===== Contact Hero  ===== */
.cu-hero{
  position: relative;
  min-height: 300px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-attachment: fixed; /* image stays put while page scrolls */
}

/* Mobile/iOS safety */
@media (max-width: 991.98px){
  .cu-hero{ background-attachment: scroll; }
}

.cu-hero__overlay{
  min-height: 300px;
  display: grid;
  place-items: center;
  background: rgba(62, 92, 255, 0.72); /* blue overlay */
}

.cu-hero__inner{
  text-align: center;
  padding: 28px 16px;
}

.cu-hero__kicker{
  color: rgba(255,255,255,.9);
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  margin-bottom: 10px;
}

.cu-hero__title{
  color: #ffffff;
  font-weight: 800;
  font-size: clamp(36px, 4vw, 56px);
  line-height: 1.05;
  margin: 0;
}



/* ===== Section spacing ===== */
.cu-section{
  background: #ffffff;
  padding: 90px 0;
}

/* LEFT SIDE */
.cu-mini{
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: #6b7280;
  margin-bottom: 14px;
}

.cu-h2{
  font-size: clamp(34px, 3.2vw, 48px);
  line-height: 1.08;
  font-weight: 800;
  color: #0f172a;
  margin: 0 0 18px 0;
}

.cu-p{
  color: #6b7280;
  font-size: 16px;
  line-height: 1.8;
  max-width: 520px;
  margin: 0 0 46px 0;
}

.cu-meta{
  margin-top: 12px;
  margin-bottom: 58px;
}

.cu-meta__label{
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: #6b7280;
  margin-bottom: 12px;
}

.cu-meta__text{
  color: #0f172a;
  font-size: 16px;
  line-height: 1.85;
}

/* Social */
.cu-social{
  display: flex;
  gap: 16px;
  margin-top: 14px;
}

.cu-social__btn{
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  color: #0f172a;
  text-decoration: none;
  border: 1px solid rgba(15, 23, 42, 0.10);
  background: #ffffff;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}

.cu-social__btn:hover{
  transform: translateY(-1px);
  background: rgba(59, 130, 246, 0.08);
  border-color: rgba(59, 130, 246, 0.25);
}

/* RIGHT SIDE FORM */
.cu-form{
  max-width: 640px;
  margin-left: auto;
}

.cu-label{
  display: block;
  font-weight: 600;
  font-size: 14px;
  color: #0f172a;
  margin-bottom: 10px;
}

.cu-star{
  color: #ef4444;
  font-weight: 800;
}

.cu-input{
  width: 100%;
  border: 1px solid rgba(15, 23, 42, 0.16);
  background: #ffffff;
  border-radius: 6px;
  padding: 14px 14px;
  font-size: 15px;
  outline: none;
  transition: box-shadow .12s ease, border-color .12s ease;
}

.cu-input::placeholder{
  color: #9ca3af;
}

.cu-input:focus{
  border-color: rgba(59, 130, 246, 0.55);
  box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.14);
}

.cu-textarea{
  min-height: 160px;
  resize: vertical;
}

.cu-err{
  display: none;
  margin-top: 8px;
  color: #b91c1c;
  font-size: 13px;
}

.cu-input.is-invalid{
  border-color: rgba(185, 28, 28, 0.55);
}

.cu-input.is-invalid:focus{
  box-shadow: 0 0 0 4px rgba(185, 28, 28, 0.12);
}

/* Button */
.cu-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 8px;
  padding: 14px 22px;
  background: #3b5bff; /* screenshot-like blue */
  color: #ffffff;
  font-weight: 800;
  min-width: 190px;
  box-shadow: 0 18px 40px rgba(59, 91, 255, 0.22);
  transition: transform .12s ease, filter .12s ease;
}

.cu-btn:hover{
  transform: translateY(-1px);
  filter: brightness(0.98);
}

.cu-btn:active{
  transform: translateY(0);
}

.cu-success{
  display: none;
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: 10px;
  background: rgba(16, 185, 129, 0.10);
  border: 1px solid rgba(16, 185, 129, 0.20);
  color: #065f46;
  font-weight: 700;
  font-size: 14px;
}

/* Mobile spacing */
@media (max-width: 991.98px){
  .cu-section{ padding: 60px 0; }
  .cu-form{ margin-left: 0; }
}

.cu-hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }

.cu-errbox{
  margin-bottom: 18px;
  padding: 12px 14px;
  border-radius: 10px;
  background: rgba(239, 68, 68, 0.10);
  border: 1px solid rgba(239, 68, 68, 0.22);
  color: #7f1d1d;
  font-weight: 700;
}

/* VIN Decoder Results (tight values, left aligned) */
.vin-results{
  max-width: 680px;
  margin: 22px auto 0;
  text-align: left;
}

.vin-results-head{ margin-bottom: 12px; }

.vin-results-kicker{
  font-weight: 800;
  letter-spacing: .08em;
  font-size: .78rem;
  color: #64748b;
  text-transform: uppercase;
  margin-bottom: 6px;
}

.vin-results-title{
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 10px;
  font-size: 1.6rem;
  line-height: 1.15;
  color: #0f172a;
}

.vin-results-title-strong{ font-weight: 900; }
.vin-results-title-vin{ font-weight: 500; color: #334155; }

.vin-card{
  background: #fff;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 14px;
  padding: 16px;
  box-shadow: 0 18px 50px rgba(15,23,42,.10);
}

/* Layout inside the card */
.vin-grid{
  display: grid;
  grid-template-columns: 1fr 1fr; /* two blocks per row on desktop */
  gap: 0;
}

/* Each "cell" is its own little 2-col grid: label + value (tight) */
.vin-cell{
  display: grid;
  grid-template-columns: 125px auto; /* KEY: auto keeps values close */
  gap: 8px 12px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(15,23,42,.14);
  align-items: start;
}

.vin-cell.full{
  grid-column: 1 / -1;
}

.vin-k{
  font-weight: 900;
  color: #0f172a;
  font-size: 14px;
  line-height: 1.1;
  white-space: nowrap;
}

.vin-v{
  font-weight: 500;
  color: #334155;
  font-size: 14px;
  line-height: 1.25;
  text-align: left;
  justify-self: start;  /* KEY: prevents drifting to the far right */
}

/* Last row border cleanup */
.vin-grid .vin-cell.last{
  border-bottom: 0;
}

/* Mobile: stack everything */
@media (max-width: 767.98px){
  .vin-grid{
    grid-template-columns: 1fr;
  }

  .vin-cell{
    grid-template-columns: 1fr; /* label on top, value below */
    padding: 12px 0;
  }

  .vin-k{
    font-size: 14px;
    white-space: normal;
  }

  .vin-v{
    font-size: 14px;
  }
}




/* =========================
  FAQs Page Section
========================= */
.fc-help-wrap{
  max-width: 920px;
  margin: 0 auto;
  padding: 70px 0 40px;
}

.fc-help-head{
  max-width: 760px;
  margin: 0 auto 34px;
}

.fc-help-kicker{
  display: inline-block;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #0D72FF;
  margin-bottom: 10px;
}

.fc-help-title{
  font-size: clamp(2rem, 4vw, 2.7rem);
  line-height: 1.1;
  font-weight: 800;
  color: #0f172a;
  margin: 0 0 12px;
}

.fc-help-text{
  font-size: 1.02rem;
  line-height: 1.75;
  color: #64748b;
  margin: 0;
}

.fc-help-list{
  margin-top: 26px;
}

.fc-help-accordion{
  --bs-accordion-border-width: 0;
  --bs-accordion-border-color: transparent;
  --bs-accordion-btn-focus-box-shadow: none;
  --bs-accordion-active-bg: #ffffff;
  --bs-accordion-btn-bg: #ffffff;
  --bs-accordion-bg: #ffffff;
}

.fc-help-accordion .accordion-item.fc-help-item{
  border: 1px solid rgba(15,23,42,.08) !important;
  border-radius: 18px !important;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 12px 35px rgba(15,23,42,.06);
  margin-bottom: 16px;
}

.fc-help-accordion .accordion-button.fc-help-btn{
  padding: 20px 56px 20px 22px !important;
  font-size: 1.04rem;
  font-weight: 700;
  line-height: 1.45;
  color: #0f172a !important;
  background: #fff !important;
}

.fc-help-accordion .accordion-button:not(.collapsed).fc-help-btn{
  color: #0D72FF !important;
  box-shadow: none !important;
}

.fc-help-accordion .accordion-button:focus.fc-help-btn{
  box-shadow: none !important;
}

.fc-help-accordion .accordion-button.fc-help-btn::after{
  flex-shrink: 0;
  width: 1.15rem;
  height: 1.15rem;
  background-size: 1.15rem;
  filter: invert(38%) sepia(99%) saturate(2893%) hue-rotate(205deg) brightness(101%) contrast(101%);
}

.fc-help-body{
  padding: 0 22px 22px 22px !important;
  font-size: .98rem;
  line-height: 1.8;
  color: #475569;
  border-top: 1px solid rgba(15,23,42,.06);
  background: #fff;
}

@media (max-width: 767.98px){
  .fc-help-wrap{
    padding: 50px 0 20px;
  }

  .fc-help-title{
    font-size: 1.8rem;
  }

  .fc-help-text{
    font-size: .97rem;
    line-height: 1.7;
  }

  .fc-help-accordion .accordion-button.fc-help-btn{
    padding: 18px 48px 18px 18px !important;
    font-size: .98rem;
  }

  .fc-help-body{
    padding: 0 18px 18px 18px !important;
    font-size: .95rem;
  }
}


