/* =====================================================================
   Car Tool India — shared stylesheet (design system)
   Used by every page. Edit here once, changes apply site-wide.
   ===================================================================== */

:root {
  --blue: #3A7AFE;
  --blue-deep: #2C5FD8;
  --blue-sky: #5C9CFF;
  --blue-soft: #EAF1FF;
  --blue-tint: #F5F8FF;
  --charcoal: #1F2937;
  --charcoal-2: #0F172A;
  --gray: #6B7280;
  --gray-line: #E5E7EB;
  --gray-line-soft: #EDEFF3;
  --bg: #F8F9FA;
  --white: #FFFFFF;
  --green: #16A34A;
  --green-wa: #25D366;
  --amber: #F59E0B;

  --radius-sm: 9px;
  --radius: 12px;
  --radius-lg: 18px;
  --radius-xl: 22px;

  --shadow-sm: 0 1px 2px rgba(16,24,40,.05);
  --shadow: 0 8px 24px -12px rgba(16,24,40,.14), 0 2px 6px -2px rgba(16,24,40,.06);
  --shadow-lg: 0 24px 60px -24px rgba(16,24,40,.22);
  --shadow-blue: 0 12px 28px -10px rgba(58,122,254,.45);

  --font-display: "Chakra Petch", ui-sans-serif, system-ui, sans-serif;
  --font-body: "Outfit", ui-sans-serif, system-ui, sans-serif;

  --maxw: 1240px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-body);
  color: var(--charcoal);
  background: var(--bg);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1, h2, h3, h4, h5 {
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--charcoal);
  margin: 0;
  letter-spacing: -.01em;
  text-wrap: balance;
}
p { margin: 0; text-wrap: pretty; }
a { color: var(--blue); text-decoration: none; }
a:hover { color: var(--blue-deep); }
img, svg { display: block; max-width: 100%; }
button { font-family: inherit; cursor: pointer; }
::selection { background: var(--blue); color: #fff; }

.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 26px; }
@media (max-width: 640px) { .container { padding: 0 18px; } }

.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-display); font-weight: 600;
  font-size: 12.5px; letter-spacing: .08em; text-transform: uppercase;
  color: var(--blue-deep); background: var(--blue-soft);
  border: 1px solid rgba(58,122,254,.18);
  padding: 6px 13px; border-radius: 999px;
}
.eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--blue); }

.section { padding: 72px 0; }
.section-tight { padding: 48px 0; }
@media (max-width: 640px) { .section { padding: 52px 0; } }

.h-section { font-size: clamp(26px, 4vw, 40px); line-height: 1.12; }
.lead { font-size: clamp(16px, 1.4vw, 19px); color: var(--gray); line-height: 1.6; }
.muted { color: var(--gray); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px 22px; border-radius: 999px;
  font-family: var(--font-display); font-weight: 700; font-size: 14.5px;
  border: 1px solid transparent; line-height: 1; white-space: nowrap;
  transition: transform .15s ease, background .15s ease, box-shadow .15s ease, border-color .15s ease, color .15s ease;
}
.btn svg { width: 17px; height: 17px; }
.btn-primary { background: var(--blue); color: #fff; box-shadow: var(--shadow-blue); }
.btn-primary:hover { background: var(--blue-deep); color: #fff; transform: translateY(-1px); }
.btn-ghost { background: #fff; color: var(--charcoal); border-color: var(--gray-line); }
.btn-ghost:hover { background: var(--bg); color: var(--charcoal); }
.btn-wa { background: var(--green-wa); color: #fff; }
.btn-wa:hover { background: #1EBE5A; color: #fff; transform: translateY(-1px); }
.btn-lg { padding: 15px 28px; font-size: 16px; }
.btn-block { width: 100%; }

/* ---------- Pills / badges ---------- */
.pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 11px; border-radius: 999px; font-size: 12px; font-weight: 600;
  background: var(--bg); color: var(--charcoal); border: 1px solid var(--gray-line);
}
.pill-best { background: #FFF4E5; color: #B45309; border-color: #FCE3BF; }
.pill-choice { background: var(--blue-soft); color: var(--blue-deep); border-color: rgba(58,122,254,.2); }
.pill-green { background: #ECFDF3; color: #15803D; border-color: #BBF7D0; }

/* ---------- Cards ---------- */
.card { background: #fff; border: 1px solid var(--gray-line-soft); border-radius: var(--radius-lg); }
.card-pad { padding: 24px; }
.card-hover { transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.card-hover:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: var(--gray-line); }

.grid { display: grid; gap: 22px; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 980px) { .grid-4 { grid-template-columns: repeat(2, 1fr); } .grid-3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .grid-2, .grid-3 { grid-template-columns: 1fr; } .grid-4 { grid-template-columns: repeat(2, 1fr); gap: 12px; } }

.check { color: var(--green); flex: none; }

/* ---------- Announcement bar ---------- */
.announce {
  background: linear-gradient(90deg, var(--blue-deep), var(--blue));
  color: #fff; font-size: 13px; font-weight: 500;
  text-align: center; padding: 9px 16px;
}
.announce a { color: #fff; text-decoration: underline; }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.9);
  backdrop-filter: saturate(180%) blur(10px);
  -webkit-backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid var(--gray-line-soft);
  transition: transform .32s cubic-bezier(.4,0,.2,1), box-shadow .25s ease;
  will-change: transform;
}
.site-header.hdr-hidden { transform: translateY(-100%); }
.site-header.hdr-stuck { box-shadow: 0 6px 22px rgba(15,23,42,.08); }
.site-header .bar { display: flex; align-items: center; gap: 18px; height: 72px; }
.brand { display: flex; align-items: center; gap: 11px; flex: none; }
.brand img { width: 40px; height: 40px; object-fit: contain; }
.brand .wm { font-family: var(--font-display); font-weight: 700; font-size: 20px; letter-spacing: -.3px; white-space: nowrap; }
.brand .wm .b { color: var(--blue); }
.nav { display: flex; align-items: center; gap: 26px; margin: 0 auto; }
.nav a { font-size: 14.5px; font-weight: 500; color: #374151; }
.nav a:hover, .nav a.active { color: var(--blue); font-weight: 600; }
.header-actions { display: flex; align-items: center; gap: 10px; flex: none; }

/* mobile menu */
.menu-btn { display: none; width: 44px; height: 44px; border-radius: 12px; border: 1px solid var(--gray-line); background: #fff; align-items: center; justify-content: center; }
.mobile-nav { display: none; }
.mobile-nav.open {
  display: flex; flex-direction: column;
  position: fixed; inset: 0; z-index: 200; background: #fff;
  overflow-y: auto; animation: mnavFade .2s ease;
}
@keyframes mnavFade { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: none; } }
.mnav-top { display: flex; align-items: center; justify-content: space-between; height: 72px; flex: none; padding: 0 18px; border-bottom: 1px solid var(--gray-line-soft); }
.mnav-top .brand .wm { font-size: 19px; }
.mnav-close { width: 44px; height: 44px; border-radius: 12px; border: 1px solid var(--gray-line); background: #fff; display: flex; align-items: center; justify-content: center; flex: none; }
.mobile-nav > a { padding: 17px 22px; font-family: var(--font-display); font-weight: 600; font-size: 18px; color: var(--charcoal); border-bottom: 1px solid var(--gray-line-soft); }
.mnav-cta { margin-top: auto; padding: 18px 18px calc(18px + env(safe-area-inset-bottom)); display: flex; flex-direction: column; gap: 10px; border-top: 1px solid var(--gray-line-soft); }
.mnav-cta .btn { width: 100%; justify-content: center; }
@media (max-width: 900px) {
  .nav { display: none; }
  .header-actions .hide-sm { display: none; }
  .menu-btn { display: flex; }
  .header-actions { margin-left: auto; gap: 10px; }
  .site-header .bar { gap: 12px; }
}

/* ---------- Hero ---------- */
.hero { position: relative; overflow: hidden;
  background:
    radial-gradient(60% 50% at 12% 8%, rgba(58,122,254,.10), transparent 60%),
    radial-gradient(50% 42% at 90% 0%, rgba(44,95,216,.10), transparent 60%),
    linear-gradient(180deg, #FFFFFF 0%, var(--bg) 100%);
}
.hero-grid {
  position: absolute; inset: 0; opacity: .5; pointer-events: none;
  background-image:
    linear-gradient(to right, rgba(58,122,254,.07) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(58,122,254,.07) 1px, transparent 1px);
  background-size: 34px 34px;
  -webkit-mask-image: radial-gradient(70% 60% at 30% 30%, #000, transparent 75%);
          mask-image: radial-gradient(70% 60% at 30% 30%, #000, transparent 75%);
}
.hero .container { position: relative; display: grid; grid-template-columns: 1.05fr .95fr; grid-template-areas: "intro media" "actions media"; column-gap: 46px; row-gap: 22px; align-items: center; padding-top: 56px; padding-bottom: 64px; }
.hero-intro { grid-area: intro; }
.hero-media { grid-area: media; }
.hero-actions { grid-area: actions; }
.hero h1 { font-size: clamp(36px, 5.6vw, 56px); line-height: 1.04; }
.hero h1 .b { color: var(--blue); }
@media (max-width: 900px) { .hero .container { grid-template-columns: 1fr; grid-template-areas: "intro" "media" "actions"; column-gap: 0; row-gap: 24px; padding-top: 28px; padding-bottom: 38px; } .hero-actions .trust-row { margin-top: 6px !important; } }

/* ---------- Shop by category compact row ---------- */
.cat-row { display: flex; gap: 12px; overflow-x: auto; scrollbar-width: none; padding-bottom: 4px; }
.cat-row::-webkit-scrollbar { display: none; }
.cat-row > a { flex: 1 0 0; min-width: 124px; }
@media (max-width: 640px) { .cat-row { gap: 10px; margin: 0 -18px; padding: 2px 18px 6px; } .cat-row > a { min-width: 112px; } }

/* ---------- Brand strip ---------- */
.brand-strip { background: #fff; border-top: 1px solid var(--gray-line-soft); border-bottom: 1px solid var(--gray-line-soft); }
.brand-strip .row { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 14px 34px; padding: 22px 0; }
.brand-chip { font-family: var(--font-display); font-weight: 700; font-size: 17px; color: #9AA3B2; letter-spacing: .3px; }

/* ---------- Product card ---------- */
.product-card { display: flex; flex-direction: column; overflow: hidden; }
.product-card .thumb { aspect-ratio: 4/3; background: var(--blue-tint); display: flex; align-items: center; justify-content: center; position: relative; }
.product-card .thumb .ph { font-family: var(--font-display); font-weight: 700; font-size: 40px; color: #C3D2EE; }
.product-card .body { padding: 16px 18px 18px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.product-card .pname { font-size: 15px; font-weight: 700; color: var(--charcoal); font-family: var(--font-display); line-height: 1.3; }
.product-card .pbrand { font-size: 12px; color: var(--gray); }
.product-card .price { display: flex; align-items: baseline; gap: 8px; margin-top: 2px; }
.product-card .price .now { font-size: 18px; font-weight: 700; font-family: var(--font-display); color: var(--charcoal); }
.product-card .price .was { font-size: 13px; color: var(--gray); text-decoration: line-through; }
.product-card .badges { position: absolute; top: 10px; left: 10px; display: flex; gap: 6px; flex-wrap: wrap; }

/* ---------- Trust / stat ---------- */
.trust-row { display: flex; flex-wrap: wrap; gap: 12px; }
.trust-item { display: flex; align-items: center; gap: 9px; background: #fff; border: 1px solid var(--gray-line-soft); border-radius: 999px; padding: 9px 16px; font-size: 13.5px; font-weight: 600; }

/* ---------- FAQ ---------- */
.faq-item { background: #fff; border: 1px solid var(--gray-line-soft); border-radius: var(--radius); margin-bottom: 12px; overflow: hidden; }
.faq-item summary { list-style: none; cursor: pointer; padding: 18px 22px; display: flex; align-items: center; justify-content: space-between; gap: 16px; font-weight: 600; font-size: 15.5px; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary .ic { font-family: var(--font-display); font-size: 22px; color: var(--blue); flex: none; }
.faq-item[open] summary .ic { color: var(--gray); }
.faq-item .ans { padding: 0 22px 20px; color: var(--gray); font-size: 14.5px; line-height: 1.65; }

/* ---------- Footer ---------- */
.footer { background: var(--charcoal); color: #C7CDD9; margin-top: 0; }
.footer .top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr 1.1fr; gap: 28px; padding: 54px 0 36px; }
@media (max-width: 1024px) { .footer .top { grid-template-columns: 1.3fr 1fr 1fr; gap: 28px; } }
@media (max-width: 900px) { .footer .top { grid-template-columns: 1fr 1fr; gap: 28px; } }
@media (max-width: 560px) { .footer .top { grid-template-columns: 1fr; } }
.footer h4 { color: #fff; font-size: 14px; margin-bottom: 14px; }
.footer a { color: #A6AEBD; font-size: 13.5px; display: block; margin-bottom: 10px; }
.footer a:hover { color: #fff; }
.footer .bottom { border-top: 1px solid #2C3645; padding: 18px 0; display: flex; flex-wrap: wrap; gap: 10px 24px; align-items: center; justify-content: space-between; font-size: 12.5px; color: #8A94A6; }

/* ---------- WhatsApp float ---------- */
.wa-float {
  position: fixed; right: 20px; bottom: 22px; z-index: 60;
  width: 56px; height: 56px; border-radius: 50%; background: var(--green-wa);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 10px 26px rgba(37,211,102,.5);
  animation: waPulse 2.4s infinite;
}
@keyframes waPulse { 0%,100% { box-shadow: 0 10px 26px rgba(37,211,102,.45); } 50% { box-shadow: 0 10px 26px rgba(37,211,102,.2), 0 0 0 12px rgba(37,211,102,0); } }

/* ---------- Breadcrumb ---------- */
.crumb { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--gray); padding: 16px 0 0; }
.crumb a { color: var(--gray); }
.crumb a:hover { color: var(--blue); }

/* ---------- Forms ---------- */
.field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.field label { font-size: 13px; font-weight: 600; color: var(--charcoal); }
.field input, .field textarea, .field select {
  font-family: var(--font-body); font-size: 14.5px; color: var(--charcoal);
  padding: 12px 14px; border: 1px solid var(--gray-line); border-radius: var(--radius-sm); background: #fff; width: 100%;
}
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--blue); box-shadow: 0 0 0 3px rgba(58,122,254,.15); }
.field .req { color: #DC2626; }
.hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.form-note { font-size: 12.5px; color: var(--gray); margin-top: 6px; }
.form-status { font-size: 14px; font-weight: 600; margin-top: 12px; }
.form-status.ok { color: var(--green); }
.form-status.err { color: #DC2626; }

/* ---------- Section heading helper ---------- */
.sec-head { text-align: center; max-width: 680px; margin: 0 auto 40px; }
.sec-head .lead { margin-top: 12px; }

.reveal { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .wa-float { animation: none; } html { scroll-behavior: auto; } }

/* ---------- Reviews marquee ---------- */
.cti-marquee { animation: ctiMarquee 55s linear infinite; }
.cti-marquee:hover { animation-play-state: paused; }
@keyframes ctiMarquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .cti-marquee { animation: none !important; } }

/* ---------- Mobile bottom navigation ---------- */
.btm-nav { display: none; }
@media (max-width: 900px) {
  .btm-nav {
    display: flex; position: fixed; left: 0; right: 0; bottom: 0; z-index: 70;
    background: rgba(255,255,255,.97);
    backdrop-filter: saturate(180%) blur(12px); -webkit-backdrop-filter: saturate(180%) blur(12px);
    border-top: 1px solid var(--gray-line); box-shadow: 0 -4px 20px rgba(16,24,40,.09);
    padding-bottom: env(safe-area-inset-bottom);
  }
  .btm-nav a {
    flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px;
    min-height: 58px; padding: 8px 2px 9px;
    font-family: var(--font-display); font-weight: 600; font-size: 10.5px; color: var(--gray);
  }
  .btm-nav a svg { width: 22px; height: 22px; }
  .btm-nav a.active { color: var(--blue); }
  .btm-nav a.cta-call { color: var(--blue); }
  .btm-nav a.cta-wa { color: var(--green-wa); }
  .wa-float { bottom: calc(76px + env(safe-area-inset-bottom)); right: 16px; width: 50px; height: 50px; }
  .footer { padding-bottom: 84px; }
}

/* ---------- Smartphone layout optimization ---------- */
@media (max-width: 768px) {
  /* collapse inline 2-column grids (product gallery+summary, description, spec card) */
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: 1fr 1fr"],
  [style*="grid-template-columns:1.4fr 1fr"],
  [style*="grid-template-columns: 1.4fr 1fr"] { grid-template-columns: 1fr !important; }
  /* gallery thumbnail row wraps instead of overflowing */
  [style*="display:flex;gap:10px;margin-top:12px"] { flex-wrap: wrap !important; }
  /* related products -> horizontal swipe row, smaller cards */
  .related-row {
    display: flex !important; grid-template-columns: none !important;
    overflow-x: auto; gap: 12px; scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch; scrollbar-width: none;
    margin: 0 -18px; padding: 2px 18px 8px;
  }
  .related-row::-webkit-scrollbar { display: none; }
  .related-row .product-card { flex: 0 0 60%; max-width: 210px; scroll-snap-align: start; }
  .related-row .product-card .body { padding: 12px 13px 14px; gap: 6px; }
  .related-row .product-card .pname { font-size: 13.5px; }
}


/* ===== Inquiry / lead modal (shared) ===== */
.cti-modal{position:fixed;inset:0;z-index:2000;display:none}
.cti-modal.open{display:block}
.cti-modal__backdrop{position:absolute;inset:0;background:rgba(15,23,42,.55);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.cti-modal__card{position:relative;max-width:440px;margin:7vh auto 0;background:#fff;border-radius:16px;box-shadow:0 24px 60px rgba(15,23,42,.32);padding:26px 24px 22px;animation:ctiPop .22s ease}
@media(max-width:520px){.cti-modal__card{margin:0;position:absolute;left:0;right:0;bottom:0;border-radius:16px 16px 0 0}}
@keyframes ctiPop{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.cti-modal__x{position:absolute;top:10px;right:13px;border:0;background:transparent;font-size:27px;line-height:1;color:#94A3B8;cursor:pointer}
.cti-modal__title{font-family:var(--font-display);font-size:21px;margin:0 0 2px;color:var(--charcoal)}
.cti-modal__sub{color:var(--gray);font-size:13px;margin:0 0 16px;min-height:1px}
.cti-modal__form .cti-f{display:block;margin-bottom:13px}
.cti-modal__form .cti-f>span{display:block;font-size:12.5px;font-weight:600;color:var(--charcoal);margin-bottom:5px}
.cti-modal__form .cti-f>span i{color:#DC2626;font-style:normal}
.cti-modal__form input{width:100%;padding:11px 13px;border:1px solid var(--gray-line);border-radius:10px;font-size:14.5px;font-family:inherit;background:#fff;box-sizing:border-box}
.cti-modal__form input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(58,122,254,.15)}
.cti-modal__form .cti-hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.cti-modal__form button[type=submit]{margin-top:6px}
.cti-modal__status{font-size:13px;margin-top:10px;text-align:center}
.cti-modal__status.ok{color:#16A34A}
.cti-modal__status.err{color:#DC2626}
.cti-modal__note{font-size:12.5px;color:var(--gray);text-align:center;margin:12px 0 0}
/* 16px inputs prevent iOS auto-zoom on focus */
.cti-modal__form input{font-size:16px}
.cti-modal__thanks{text-align:center;padding:18px 6px 8px}
.cti-modal__check{width:62px;height:62px;border-radius:50%;background:#ECFDF3;color:#16A34A;font-size:32px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.cti-modal__thanks h3{font-family:var(--font-display);font-size:21px;margin:0 0 6px;color:var(--charcoal)}
.cti-modal__thanks p{color:var(--gray);font-size:14px;margin:0;line-height:1.5}
@media(max-width:520px){.cti-modal__card{max-height:92vh;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:max(22px,env(safe-area-inset-bottom))}}

/* ---------- Auto-scroll marquee (right -> left) ---------- */
.marquee{overflow:hidden;width:100%;-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 7%,#000 93%,transparent 100%);mask-image:linear-gradient(90deg,transparent 0,#000 7%,#000 93%,transparent 100%)}
.marquee-track{display:flex;gap:16px;width:max-content;align-items:stretch;animation:marquee-rtl var(--marquee-dur,45s) linear infinite;will-change:transform}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes marquee-rtl{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){.marquee-track{animation:none;flex-wrap:wrap;justify-content:center}}

/* ---------- Why Car Tool India ---------- */
.why-cti{position:relative;background:var(--blue-soft);overflow:hidden}
.why-cti__text{max-width:520px;padding:74px 0}
.why-cti__img{position:absolute;right:0;bottom:0;height:100%;width:auto;max-width:54%;object-fit:contain;object-position:right bottom}
@media (max-width:900px){
  .why-cti__img{position:static;max-width:560px;width:100%;height:auto;margin:6px auto 0}
  .why-cti__text{padding:46px 0 4px}
  .why-cti{padding-bottom:0}
}

/* ---------- Diagnostic Solutions cards (animated) ---------- */
.dsol-card{position:relative;background:#fff;border-radius:6px;padding:34px 26px 30px;box-shadow:0 6px 20px rgba(15,23,42,.07);border-bottom:3px solid var(--blue);animation:dsol-float 5s ease-in-out infinite;animation-delay:var(--d,0s);transition:box-shadow .25s ease}
.dsol-card:hover{box-shadow:0 18px 36px rgba(58,122,254,.22)}
.dsol-accent{position:absolute;top:0;right:0;width:42px;height:42px;background:var(--blue);border-bottom-left-radius:12px}
.dsol-card h3{font-family:var(--font-display);font-weight:700;font-size:18px;line-height:1.25;color:var(--charcoal);margin:0 0 12px;max-width:175px}
.dsol-card p{font-size:13px;color:var(--gray);line-height:1.55;margin:0}
@keyframes dsol-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@media (prefers-reduced-motion:reduce){.dsol-card{animation:none}}

/* ---------- Support-First section ---------- */
.support-first{position:relative;background:#fff;overflow:hidden}
.support-first__text{max-width:500px;margin-left:auto;padding:70px 0}
.support-first__img{position:absolute;left:0;bottom:0;height:100%;width:auto;max-width:44%;object-fit:contain;object-position:left bottom}
@media (max-width:1024px){
  .support-first__img{position:static;max-width:380px;width:100%;height:auto;margin:0 auto}
  .support-first__text{max-width:none;padding:10px 0 50px}
}

/* ---------- Trust stats banner ---------- */
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.trust-grid>div{text-align:center;padding:8px 12px;border-right:1px solid rgba(255,255,255,.18)}
.trust-grid>div:last-child{border-right:0}
.trust-grid .num{color:#fff;font-family:var(--font-display);font-weight:700;font-size:clamp(24px,3vw,31px);line-height:1}
.trust-grid .lbl{color:#C3D0F0;font-size:13.5px;font-weight:600;margin-top:6px}
@media (max-width:600px){
  .trust-grid{grid-template-columns:1fr 1fr;gap:22px 0}
  .trust-grid>div:nth-child(2){border-right:0}
}

/* ---------- Fixomotive Repair grid ---------- */
.fixrepair-grid{display:grid;grid-template-columns:1.02fr 1fr;gap:48px;align-items:center}
@media (max-width:900px){.fixrepair-grid{grid-template-columns:1fr;gap:30px}}



/* ---------- Timed lead-capture popup ---------- */
.cti-pop { position: fixed; inset: 0; z-index: 1200; display: none; align-items: center; justify-content: center; padding: 20px; }
.cti-pop.open { display: flex; }
.cti-pop__bd { position: absolute; inset: 0; background: rgba(15,23,42,.55); -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px); }
.cti-pop__card { position: relative; width: 100%; max-width: 400px; background: #fff; border-radius: 18px; overflow: hidden; box-shadow: 0 30px 70px rgba(15,23,42,.35); animation: ctiPopIn .3s cubic-bezier(.2,.8,.2,1); }
@keyframes ctiPopIn { from { opacity: 0; transform: translateY(16px) scale(.97); } to { opacity: 1; transform: none; } }
.cti-pop__head { background: linear-gradient(135deg,#2C5FD8,#3A7AFE); color: #fff; padding: 22px 24px 20px; position: relative; }
.cti-pop__x { position: absolute; top: 12px; right: 12px; width: 32px; height: 32px; border: none; border-radius: 50%; background: rgba(255,255,255,.18); color: #fff; font-size: 20px; line-height: 1; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.cti-pop__x:hover { background: rgba(255,255,255,.3); }
.cti-pop__badge { display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; background: rgba(255,255,255,.2); padding: 5px 11px; border-radius: 999px; margin-bottom: 12px; font-family: var(--font-display); }
.cti-pop__title { font-family: var(--font-display); font-weight: 700; font-size: 21px; line-height: 1.2; margin: 0; color: #fff; }
.cti-pop__sub { font-size: 13.5px; color: #E4ECFF; margin: 8px 0 0; line-height: 1.5; }
.cti-pop__body { padding: 20px 24px 24px; }
.cti-pop__row { display: flex; align-items: stretch; border: 1.5px solid var(--gray-line); border-radius: 12px; overflow: hidden; margin-bottom: 12px; transition: border-color .15s ease; }
.cti-pop__row:focus-within { border-color: var(--blue); }
.cti-pop__cc { display: flex; align-items: center; padding: 0 13px; background: var(--blue-soft); font-family: var(--font-display); font-weight: 700; font-size: 14px; color: var(--charcoal); border-right: 1.5px solid var(--gray-line); }
.cti-pop__row input { flex: 1; min-width: 0; border: none; outline: none; padding: 13px 14px; font-size: 16px; font-family: inherit; color: var(--charcoal); }
.cti-pop__btn { width: 100%; justify-content: center; }
.cti-pop__note { text-align: center; font-size: 12.5px; color: var(--gray); margin: 12px 0 0; }
.cti-pop__note a { color: var(--blue); font-weight: 600; }
.cti-pop__status { font-size: 13px; margin-top: 10px; text-align: center; }
.cti-pop__status.ok { color: #16A34A; font-weight: 600; }
.cti-pop__status.err { color: #DC2626; font-weight: 600; }
.cti-pop__thanks { padding: 38px 24px; text-align: center; }
.cti-pop__check { width: 64px; height: 64px; border-radius: 50%; background: #ECFDF3; color: #16A34A; font-size: 34px; display: flex; align-items: center; justify-content: center; margin: 0 auto 16px; }
.cti-pop__thanks h3 { font-family: var(--font-display); font-size: 22px; margin: 0 0 6px; color: var(--charcoal); }
.cti-pop__thanks p { color: var(--gray); font-size: 14px; margin: 0; line-height: 1.5; }
@media (max-width: 420px) {
  .cti-pop { padding: 12px; }
  .cti-pop__card { max-height: 94vh; overflow-y: auto; -webkit-overflow-scrolling: touch; }
  .cti-pop__head { padding: 18px 20px 16px; }
  .cti-pop__title { font-size: 19px; }
  .cti-pop__body { padding: 18px 20px 22px; }
}
.cti-pop__hp { position: absolute; left: -9999px; width: 1px; height: 1px; }
@media (max-width: 480px) { .cti-pop { align-items: flex-end; padding: 0; } .cti-pop__card { max-width: none; border-radius: 18px 18px 0 0; } }


/* ---------- Sticky sub-bars follow header hide/show ---------- */
:root { --sticky-top: 72px; }
.ptabs-bar { top: var(--sticky-top, 72px) !important; transition: top .32s cubic-bezier(.4,0,.2,1); }
#filters { top: var(--sticky-top, 72px) !important; transition: top .32s cubic-bezier(.4,0,.2,1); }
