:root{
  color-scheme: light dark;
  --navy:#061b3a;--navy-2:#0b2d5c;--blue:#145cff;--blue-2:#4f8cff;
  --bg:#f5f8ff;--bg2:#ffffff;--surface:#ffffff;--surface2:#f7f9fc;
  --text:#0b1220;--muted:#536071;--border:#e4eaf4;
  --green:#16a36a;--amber:#f59e0b;--orange:#f97316;--red:#ef4444;--purple:#7c3aed;--cyan:#0891b2;
  --shadow-sm:0 1px 3px rgba(15,23,42,.08);--shadow-md:0 8px 24px rgba(15,23,42,.10);--shadow-lg:0 20px 60px rgba(15,23,42,.14);
  --r-sm:12px;--r-md:18px;--r-lg:24px;--max:1180px;

  /* GearVerify old variable name aliases */
  --gv-blue: var(--blue);
  --gv-black: var(--text);
  --gv-grey-1: var(--muted);
  --gv-grey-2: var(--muted);
  --gv-grey-3: var(--border);
  --gv-grey-4: var(--surface2);
  --gv-white: var(--bg);
  --gv-red: var(--red);
  --gv-green: var(--green);
  --gv-amber: var(--amber);
  --card-shadow: var(--shadow-sm);
  --card-hover-shadow: var(--shadow-md);
  --card-radius: var(--r-md);
  --radius-lg: var(--r-md);
  --radius-md: var(--r-sm);
  --h1-size: clamp(42px, 6vw, 76px);
  --h2-size: clamp(30px, 4vw, 44px);
  --gv-blue-light: color-mix(in srgb, var(--blue), transparent 88%);
}

html[data-theme="light"]{
  color-scheme: light;
  --bg:#f5f8ff;--bg2:#ffffff;--surface:#ffffff;--surface2:#f7f9fc;--text:#0b1220;--muted:#536071;--border:#e4eaf4;--shadow-sm:0 1px 3px rgba(15,23,42,.08);--shadow-md:0 8px 24px rgba(15,23,42,.10);--shadow-lg:0 20px 60px rgba(15,23,42,.14);
}

html[data-theme="dark"]{
  color-scheme: dark;
  --bg:#071526;--bg2:#0b1c32;--surface:#0f2239;--surface2:#102843;--text:#eef6ff;--muted:#b7c5d6;--border:#1e395a;--shadow-sm:0 1px 3px rgba(0,0,0,.25);--shadow-md:0 10px 28px rgba(0,0,0,.32);--shadow-lg:0 24px 70px rgba(0,0,0,.45);
}

@media (prefers-color-scheme: dark){
  :root:not([data-theme]){
    --bg:#071526;--bg2:#0b1c32;--surface:#0f2239;--surface2:#102843;--text:#eef6ff;--muted:#b7c5d6;--border:#1e395a;--shadow-sm:0 1px 3px rgba(0,0,0,.25);--shadow-md:0 10px 28px rgba(0,0,0,.32);--shadow-lg:0 24px 70px rgba(0,0,0,.45);
  }
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:linear-gradient(180deg,var(--bg2),var(--bg));color:var(--text);line-height:1.5}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
button,input{font:inherit}
.skip-link{position:absolute;left:-999px;top:12px;background:var(--blue);color:white;padding:10px 14px;border-radius:10px;z-index:9999}
.skip-link:focus{left:12px}
.gv-container{max-width:var(--max);margin:0 auto;padding:0 24px}
.gv-header{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--surface) 86%,transparent);backdrop-filter:blur(18px);border-bottom:1px solid var(--border)}
.gv-header__inner{height:72px;display:flex;align-items:center;gap:24px;max-width:1240px;margin:0 auto;padding:0 24px}
.gv-logo{display:inline-flex;align-items:center;gap:10px;font-weight:900;letter-spacing:-.03em}
.gv-logo__mark{width:36px;height:36px;display:grid;place-items:center;border-radius:13px;background:linear-gradient(135deg,var(--blue),#79a7ff);color:white;box-shadow:var(--shadow-sm)}
.gv-logo__mark svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.gv-logo__text{font-size:21px}
/* ── Header & Navigation ────────────────────────────────────────────── */
.gv-nav--desktop{display:flex;align-items:center;gap:6px;margin-left:auto}
.gv-nav__item{border:0;background:transparent;color:var(--muted);font-weight:750;padding:10px 14px;border-radius:12px;cursor:pointer;font-size:15px;position:relative;transition:color .2s ease,background .2s ease}
.gv-nav__item::after{content:'';position:absolute;bottom:4px;left:14px;right:14px;height:2px;background:linear-gradient(90deg,var(--blue),var(--cyan));border-radius:2px;transform:scaleX(0);transition:transform .25s cubic-bezier(.4,0,.2,1)}
.gv-nav__item:hover{background:var(--surface2);color:var(--text)}
.gv-nav__item:hover::after{transform:scaleX(1)}
.gv-theme-toggle{width:44px;height:44px;border:1px solid var(--border);border-radius:14px;background:var(--surface2);color:var(--text);display:inline-grid;place-items:center;cursor:pointer;font-size:18px;box-shadow:var(--shadow-sm);transition:background .2s,border-color .2s,transform .2s}
.gv-theme-toggle:hover{background:var(--surface);border-color:var(--blue);transform:translateY(-1px)}
.gv-theme-toggle:focus-visible{outline:2px solid var(--blue);outline-offset:2px}

/* Tool cards — white bg with roaming neon border on hover */
.gv-tool-card{position:relative;min-height:168px;display:flex;flex-direction:column;gap:10px;padding:20px;border-radius:22px;background:var(--surface);border:1.5px solid var(--border);box-shadow:var(--shadow-sm);transition:transform .25s ease,box-shadow .25s ease}
.gv-tool-card::before{content:'';position:absolute;inset:-1.5px;border-radius:23px;padding:1.5px;background:conic-gradient(from 0deg,var(--blue),var(--purple),var(--cyan),var(--green),var(--amber),var(--blue));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:destination-out;mask-composite:exclude;opacity:0;transition:opacity .3s ease;pointer-events:none}
.gv-tool-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.gv-tool-card:hover::before{opacity:1;animation:spin-border 1.5s linear infinite}
.gv-tool-card:focus-visible{transform:translateY(-3px);box-shadow:var(--shadow-md);outline:2px solid var(--blue);outline-offset:2px}
.gv-tool-card:focus-visible::before{opacity:.6;animation:spin-border 2s linear infinite}
@keyframes spin-border{to{-webkit-mask-conic-angle:0deg}}
.gv-tool-card img{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);flex-shrink:0}
.gv-tool-card strong{font-size:18px;letter-spacing:-.02em}
.gv-tool-card span{font-size:14px;color:var(--muted)}
.gv-tool-card em{position:absolute;right:16px;top:16px;font-style:normal;font-size:11px;font-weight:950;padding:6px 8px;border-radius:999px;background:color-mix(in srgb,var(--amber),transparent 84%);color:var(--amber)}
.gv-tool-card.is-featured{background:linear-gradient(135deg,color-mix(in srgb,var(--blue),transparent 88%),var(--surface))}

/* Problem cards — white bg with roaming neon border on hover */
.gv-problem-card{position:relative;min-height:230px;display:flex;flex-direction:column;gap:12px;padding:22px;border-radius:24px;background:var(--surface);border:1.5px solid var(--border);box-shadow:var(--shadow-sm);transition:transform .25s ease,box-shadow .25s ease}
.gv-problem-card::before{content:'';position:absolute;inset:-1.5px;border-radius:25px;padding:1.5px;background:conic-gradient(from 0deg,var(--blue),var(--purple),var(--cyan),var(--green),var(--amber),var(--blue));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:destination-out;mask-composite:exclude;opacity:0;transition:opacity .3s ease;pointer-events:none}
.gv-problem-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.gv-problem-card:hover::before{opacity:1;animation:spin-border 1.5s linear infinite}
.gv-problem-card:focus-visible{transform:translateY(-3px);box-shadow:var(--shadow-md);outline:2px solid var(--blue);outline-offset:2px}
.gv-problem-card img{width:56px;height:56px;border-radius:18px;box-shadow:var(--shadow-sm);flex-shrink:0;display:flex;align-items:center;justify-content:center}
.gv-problem-card strong{font-size:19px;letter-spacing:-.02em}
.gv-problem-card span{color:var(--muted);font-size:14.5px}
.gv-problem-card b{margin-top:auto;font-size:12px;width:max-content;border-radius:999px;padding:7px 9px;background:color-mix(in srgb,var(--green),transparent 84%);color:var(--green);font-weight:800}
.gv-problem-card.is-soon b{background:color-mix(in srgb,var(--amber),transparent 84%);color:var(--amber)}

/* Icon backgrounds — each card type gets its own color */
.gv-card-blue img{background:color-mix(in srgb,var(--blue) 15%,white 85%)}
.gv-card-purple img{background:color-mix(in srgb,var(--purple) 15%,white 85%)}
.gv-card-cyan img{background:color-mix(in srgb,var(--cyan) 15%,white 85%)}
.gv-card-amber img{background:color-mix(in srgb,var(--amber) 15%,white 85%)}
.gv-card-green img{background:color-mix(in srgb,var(--green) 15%,white 85%)}
@media (prefers-color-scheme: dark){
  .gv-card-blue img{background:color-mix(in srgb,var(--blue) 25%,white 75%)}
  .gv-card-purple img{background:color-mix(in srgb,var(--purple) 25%,white 75%)}
  .gv-card-cyan img{background:color-mix(in srgb,var(--cyan) 25%,white 75%)}
  .gv-card-amber img{background:color-mix(in srgb,var(--amber) 25%,white 75%)}
  .gv-card-green img{background:color-mix(in srgb,var(--green) 25%,white 75%)}
  .gv-problem-card b,.gv-problem-card img{background:rgba(255,255,255,.08)!important}
  .gv-tool-card::before,.gv-problem-card::before{filter:hue-rotate(-20deg) saturate(1.3)}
}

/* Mega panel cards — colorful icon backgrounds */
.gv-mega-card img{width:40px;height:40px;border-radius:14px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);flex-shrink:0}
.gv-mega-card:nth-child(1) img{background:color-mix(in srgb,var(--blue) 15%,white 85%)}
.gv-mega-card:nth-child(2) img{background:color-mix(in srgb,var(--purple) 15%,white 85%)}
.gv-mega-card:nth-child(3) img{background:color-mix(in srgb,var(--cyan) 15%,white 85%)}
.gv-mega-card:nth-child(4) img{background:color-mix(in srgb,var(--amber) 15%,white 85%)}
.gv-mega-card:nth-child(5) img{background:color-mix(in srgb,var(--green) 15%,white 85%)}
@media (prefers-color-scheme: dark){
  .gv-mega-card:nth-child(1) img{background:color-mix(in srgb,var(--blue) 25%,transparent)}
  .gv-mega-card:nth-child(2) img{background:color-mix(in srgb,var(--purple) 25%,transparent)}
  .gv-mega-card:nth-child(3) img{background:color-mix(in srgb,var(--cyan) 25%,transparent)}
  .gv-mega-card:nth-child(4) img{background:color-mix(in srgb,var(--amber) 25%,transparent)}
  .gv-mega-card:nth-child(5) img{background:color-mix(in srgb,var(--green) 25%,transparent)}
}

/* Step cards */
.gv-step{position:relative;padding:24px;border-radius:24px;background:var(--surface);border:1.5px solid var(--border);box-shadow:var(--shadow-sm);transition:transform .22s ease,box-shadow .22s ease}
.gv-step:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.gv-step::before{content:'';position:absolute;inset:-1.5px;border-radius:25px;padding:1.5px;background:conic-gradient(from 0deg,var(--blue),var(--cyan),var(--green),var(--amber),var(--blue));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:destination-out;mask-composite:exclude;opacity:0;transition:opacity .3s ease;pointer-events:none}
.gv-step:hover::before{opacity:.7;animation:spin-border 2s linear infinite}
.gv-step>span{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,var(--blue),var(--cyan));color:white;font-weight:950;font-size:16px;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.gv-step strong{display:block;font-size:20px;margin-bottom:8px}
.gv-step p{color:var(--muted);margin:0}
@media (prefers-color-scheme: dark){.gv-step>span{background:linear-gradient(135deg,var(--blue),var(--purple))}}

/* Dashboard check rows */
.gv-check-row{display:grid;grid-template-columns:52px 1fr auto;align-items:center;gap:14px;padding:14px;margin:10px 0;border-radius:18px;background:var(--surface2);border:1.5px solid var(--border);transition:.2s ease}
.gv-check-row:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.gv-check-row img{width:40px;height:40px;padding:9px;border-radius:14px;background:color-mix(in srgb,var(--blue),transparent 88%)}
.gv-check-row small{display:block;color:var(--muted);font-weight:650}

/* Status badges */
.gv-status{font-style:normal;font-weight:950;font-size:12px;padding:7px 9px;border-radius:999px}
.gv-status--pass{background:color-mix(in srgb,var(--green),transparent 84%);color:var(--green)}
.gv-status--check{background:color-mix(in srgb,var(--blue),transparent 86%);color:var(--blue)}
.gv-status--warning{background:color-mix(in srgb,var(--amber),transparent 84%);color:var(--amber)}

/* Pills */
.gv-pill{font-style:normal;font-size:11px;font-weight:900;padding:4px 7px;border-radius:999px;background:color-mix(in srgb,var(--amber),transparent 85%);color:var(--amber);width:max-content}
.gv-pill--soon{background:color-mix(in srgb,var(--amber),transparent 84%);color:var(--amber)}
.gv-hero{position:relative;overflow:hidden;padding:82px 0 72px;background:radial-gradient(circle at 76% 28%,rgba(20,92,255,.20),transparent 34%),linear-gradient(180deg,var(--bg2),var(--bg))}
.gv-hero__grid{display:grid;grid-template-columns:minmax(0,1.02fr) minmax(360px,.78fr);gap:54px;align-items:center}
.gv-kicker,.gv-eyebrow{display:inline-flex;color:var(--blue);font-size:12px;font-weight:950;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
.gv-hero h1,.gv-page-hero h1{font-size:clamp(42px,6vw,76px);line-height:.95;letter-spacing:-.075em;margin:0 0 22px;font-weight:950}
.gv-hero h1 span{color:var(--blue)}
.gv-hero p,.gv-page-hero p{font-size:clamp(17px,2vw,21px);color:var(--muted);max-width:680px;margin:0 0 28px}
.gv-hero__actions{display:flex;gap:14px;flex-wrap:wrap}
.gv-trust-chips{display:flex;gap:8px;flex-wrap:wrap}
.gv-trust-chips--hero{margin-top:18px}
.gv-trust-chips span{font-weight:850;font-size:12px;padding:8px 10px;border:1px solid var(--border);border-radius:999px;background:var(--surface)}
.gv-dashboard{background:color-mix(in srgb,var(--surface) 92%,transparent);border:1px solid var(--border);border-radius:28px;padding:18px;box-shadow:var(--shadow-lg);backdrop-filter:blur(16px)}
.gv-dashboard__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.gv-dashboard__top span{font-size:12px;color:var(--muted);font-weight:800}
/* (Old duplicate rules removed — see "Header & Navigation" section above) */

/* Tool grid */
.gv-tool-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}

/* Steps */
.gv-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}

.gv-trust-band{background:linear-gradient(135deg,var(--navy),#0d3870);color:white;padding:46px 0}
.gv-trust-band__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.gv-trust-band__grid>div{padding:18px;border-radius:18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14)}
.gv-trust-band strong{display:block}
.gv-trust-band span{color:#c8d7e9;font-size:14px}

.gv-footer{padding:48px 0 22px;background:var(--surface);border-top:1px solid var(--border)}
.gv-footer__grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:28px}
.gv-footer p,.gv-footer a{color:var(--muted)}
.gv-footer h3{font-size:14px;text-transform:uppercase;letter-spacing:.1em}
.gv-footer a{display:block;margin:8px 0}
.gv-footer__bottom{text-align:center;color:var(--muted);border-top:1px solid var(--border);margin-top:28px;padding-top:18px;font-size:13px}
.gv-simple-header{height:72px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;border-bottom:1px solid var(--border);background:var(--surface)}
.gv-page-hero{padding:78px 0 54px;background:linear-gradient(180deg,var(--bg2),var(--bg))}
.gv-directory{display:grid;gap:34px}
.gv-directory__group h2{font-size:28px;margin:0 0 14px}
.gv-note{padding:16px 18px;border-radius:18px;background:color-mix(in srgb,var(--amber),transparent 88%);border:1px solid color-mix(in srgb,var(--amber),transparent 68%);margin-bottom:20px}
.gv-tool-layout{display:grid;grid-template-columns:.85fr 1.15fr;gap:24px;align-items:start}
.gv-form-card,.gv-result-card{padding:24px;border-radius:24px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.gv-form-card label{display:grid;gap:8px;font-weight:800}
.gv-form-card input{height:50px;border-radius:14px;border:1px solid var(--border);background:var(--surface2);padding:0 14px;color:var(--text)}
.gv-metric-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:18px 0}
.gv-metric-grid div{padding:14px;border-radius:16px;background:var(--surface2);border:1px solid var(--border)}
.gv-metric-grid span{display:block;color:var(--muted);font-size:13px}
.gv-static{padding:60px 24px}
.gv-static h1{font-size:44px}

/* Base: hidden on desktop */
.gv-mobile-toggle{width:44px;height:44px;border:0;background:var(--surface2);border-radius:13px;cursor:pointer;display:none;flex-direction:column;align-items:center;justify-content:center;gap:5px;margin-left:auto}

@media (max-width:1023px){
  .gv-nav--desktop,.gv-header__cta{display:none}
  .gv-theme-toggle{margin-left:auto}
  .gv-mobile-toggle{display:flex;margin-left:0}
  .gv-header__inner{height:64px}
  .gv-hero{padding:54px 0 56px}
  .gv-hero__grid{grid-template-columns:1fr;gap:34px}
  .gv-dashboard{max-width:560px}
  .gv-problem-grid,.gv-tool-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .gv-trust-band__grid,.gv-footer__grid{grid-template-columns:repeat(2,1fr)}
  .gv-tool-layout{grid-template-columns:1fr}
}

/* ── Mobile Accordion (template mobile menu) ─────────────────────────── */
.gv-mobile-menu{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.55);opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease}
.gv-mobile-menu.is-open{opacity:1;visibility:visible}
.gv-mobile-toggle span{display:block;width:22px;height:2px;border-radius:20px;background:var(--text);transition:transform .2s}
.gv-mobile-menu.is-open ~ .gv-mobile-toggle span:nth-child(1),
.gv-mobile-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.gv-mobile-menu.is-open ~ .gv-mobile-toggle span:nth-child(2),
.gv-mobile-toggle.is-open span:nth-child(2){opacity:0}
.gv-mobile-menu.is-open ~ .gv-mobile-toggle span:nth-child(3),
.gv-mobile-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.gv-mobile-menu__panel{position:absolute;right:0;top:0;bottom:0;width:min(380px,92vw);background:var(--surface);border-radius:24px 0 0 24px;display:flex;flex-direction:column;overflow:hidden;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-lg)}
.gv-mobile-menu.is-open .gv-mobile-menu__panel{transform:translateX(0)}
.gv-mobile-menu__top{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}
.gv-mobile-logo{display:flex;align-items:center;gap:10px;font-weight:900;letter-spacing:-.03em;font-size:20px}
.gv-mobile-close{width:36px;height:36px;border:0;background:var(--surface2);border-radius:10px;cursor:pointer;font-size:22px;display:grid;place-items:center;color:var(--text)}
.gv-mobile-accordion{flex:1;overflow-y:auto;padding:12px 16px}
.gv-acc{margin-bottom:8px}
.gv-acc__button{width:100%;display:flex;align-items:center;gap:10px;padding:13px 16px;border:1.5px solid var(--border);border-radius:16px;background:var(--surface2);color:var(--text);font-weight:800;font-size:15px;cursor:pointer;font-family:inherit;transition:background .2s,border-color .2s}
.gv-acc__button img{width:32px;height:32px;border-radius:9px;flex-shrink:0}
.gv-acc__button>span:last-child{margin-left:auto;font-size:18px;transition:transform .2s}
.gv-acc.is-open .gv-acc__button{background:var(--blue);color:white;border-color:var(--blue)}
.gv-acc.is-open .gv-acc__button>span:last-child{transform:rotate(180deg)}
.gv-acc__panel{display:none;padding:8px 10px 4px}
.gv-acc.is-open .gv-acc__panel{display:block}
.gv-acc__panel a{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:12px;color:var(--muted);font-weight:700;font-size:14px;transition:background .15s,color .15s}
.gv-acc__panel a:hover{background:var(--surface2);color:var(--text)}
.gv-acc__panel em{opacity:.55;font-size:12px;font-style:normal}
.gv-mobile-menu__footer{padding:16px 20px;border-top:1px solid var(--border)}
.gv-pill--soon{font-size:11px;font-weight:900;padding:4px 8px;border-radius:999px;background:color-mix(in srgb,var(--amber),transparent 84%);color:var(--amber)}
.gv-btn--full{width:100%;justify-content:center}

/* ── Mega Panel (desktop dropdown) ─────────────────────────────────── */
.gv-mega{position:absolute;top:100%;left:0;right:0;background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 96%,transparent),var(--surface));border-top:1px solid var(--border);border-bottom:1px solid var(--border);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(10px) scale(.985);transition:opacity .22s ease,transform .28s cubic-bezier(.2,.8,.2,1),visibility .22s;z-index:60;overflow:hidden}
.gv-mega.is-open{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.gv-mega__inner{max-width:1120px;margin:0 auto;padding:22px 24px;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;align-items:stretch}
.gv-mega__inner--columns{grid-template-columns:repeat(4,minmax(0,1fr));max-width:1120px}
.gv-mega-list{padding:18px;border:1px solid var(--border);border-radius:20px;background:var(--surface2);min-height:204px;box-shadow:var(--shadow-sm);transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}
.gv-mega-list:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:color-mix(in srgb,var(--blue),var(--border) 55%)}
.gv-mega-list h3{font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin:0 0 12px;font-weight:950}
.gv-mega-list a{display:flex;align-items:center;gap:10px;min-height:36px;padding:9px 10px;border-radius:12px;color:var(--text);font-weight:800;font-size:14px;line-height:1.2;transition:background .16s ease,color .16s ease,transform .16s ease}
.gv-mega-list a:hover{background:var(--surface);color:var(--blue);transform:translateX(3px)}
.gv-mega-list a.is-disabled{opacity:.45;pointer-events:none}
.gv-mega-list a.is-disabled span{margin-left:auto;font-size:12px;font-weight:900;color:var(--amber)}
.gv-mega-card{position:relative;display:grid;grid-template-columns:42px minmax(0,1fr);grid-template-rows:auto auto auto;gap:8px 12px;padding:18px;border-radius:20px;border:1.5px solid var(--border);background:var(--surface2);box-shadow:var(--shadow-sm);min-height:178px;text-decoration:none;color:inherit;overflow:hidden;transition:transform .24s cubic-bezier(.2,.8,.2,1),box-shadow .24s,border-color .24s,background .24s}
.gv-mega-card::before{content:'';position:absolute;inset:-1px;border-radius:21px;padding:1px;background:linear-gradient(135deg,var(--blue),var(--cyan),var(--purple));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:destination-out;mask-composite:exclude;opacity:0;transition:opacity .25s;pointer-events:none}
.gv-mega-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:color-mix(in srgb,var(--blue),var(--border) 45%);background:var(--surface)}
.gv-mega-card:hover::before{opacity:1;animation:mega-glow 1.8s ease-in-out infinite alternate}
.gv-mega-card img{grid-row:1 / span 3;width:42px;height:42px;border-radius:13px;flex-shrink:0;box-shadow:var(--shadow-sm)}
.gv-mega-card strong{display:block;font-size:15px;font-weight:950;line-height:1.25;letter-spacing:-.02em;overflow-wrap:anywhere}
.gv-mega-card span{font-size:13px;color:var(--muted);display:block;line-height:1.35;overflow-wrap:anywhere}
.gv-mega-card em{font-size:11px;font-weight:950;color:var(--amber);font-style:normal;display:inline-flex;width:max-content;max-width:100%;padding:4px 7px;border-radius:999px;background:color-mix(in srgb,var(--amber),transparent 86%)}
.gv-mega-card.is-soon{opacity:.78}
@keyframes mega-glow{from{filter:saturate(1)}to{filter:saturate(1.35) brightness(1.08)}}
@media (max-width:767px){
  body.menu-open{overflow:hidden}
  .gv-container{padding:0 18px}
  .gv-hero h1,.gv-page-hero h1{font-size:42px;letter-spacing:-.06em}
  .gv-hero p,.gv-page-hero p{font-size:16px}
  .gv-hero__actions{display:grid}
  .gv-btn{width:100%}
  .gv-dashboard{border-radius:22px;padding:14px}
  .gv-check-row{grid-template-columns:44px 1fr;gap:10px}
  .gv-check-row .gv-status{grid-column:2;width:max-content}
  .gv-section{padding:52px 0}
  .gv-section__head--row{display:block}
  .gv-problem-grid,.gv-problem-grid--three,.gv-tool-grid,.gv-steps,.gv-trust-band__grid,.gv-footer__grid{grid-template-columns:1fr}
  .gv-problem-card{min-height:auto}
  .gv-footer__grid{gap:10px}
}
@media (max-width:1023px){.gv-mega{display:none}}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{scroll-behavior:auto!important;animation:none!important;transition:none!important}
}



/* ── Old Class Name Compatibility ─────────────────────────────────── */
/* Maps the old premium-light class names to the new template system */

.gv-header-inner { height: 72px; display: flex; align-items: center; gap: 24px; max-width: 1240px; margin: 0 auto; padding: 0 24px; }
.gv-logo-icon, .gv-logo__mark { width: 36px; height: 36px; display: grid; place-items: center; border-radius: 13px; background: linear-gradient(135deg, var(--blue), #79a7ff); color: white; box-shadow: var(--shadow-sm); }
.gv-logo__mark svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 2.2; stroke-linecap: round; stroke-linejoin: round; }
.gv-logo-icon img, img.gv-logo-icon { display: none; }
.gv-logo__mark { display: grid; }
.gv-logo-icon + span, img.gv-logo-icon + span { font-size: 21px; font-weight: 900; letter-spacing: -.03em; }
.gv-logo-text { font-size: 21px; font-weight: 900; letter-spacing: -.03em; }
.gv-nav-trigger { border: 0; background: transparent; color: var(--muted); font-weight: 750; padding: 10px 12px; border-radius: 12px; cursor: pointer; }
.gv-nav-trigger:hover { background: var(--surface2); color: var(--text); outline: none; }
.gv-nav-item { border: 0; background: transparent; color: var(--muted); font-weight: 750; padding: 10px 12px; border-radius: 12px; cursor: pointer; font-family: inherit; font-size: inherit; }
.gv-nav-item:hover { background: var(--surface2); color: var(--text); }
.gv-header-cta { display: inline-flex; align-items: center; justify-content: center; gap: 8px; border-radius: 14px; font-weight: 850; padding: 12px 18px; background: linear-gradient(135deg, var(--blue), #79a7ff); color: white; box-shadow: 0 12px 28px rgba(20,92,255,.24); }
a.gv-header-cta:hover { transform: translateY(-2px); }
.gv-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; border-radius: 14px; font-weight: 850; padding: 12px 20px; text-decoration: none; cursor: pointer; font-family: inherit; border: 0; transition: transform .18s ease, box-shadow .18s ease; }
.gv-btn--primary { background: linear-gradient(135deg, var(--blue), color-mix(in srgb, var(--blue) 70%, black)); color: white; box-shadow: 0 8px 22px rgba(20,92,255,.28); }
.gv-btn--primary:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(20,92,255,.36); }
.gv-btn--secondary { background: var(--surface2); color: var(--text); border: 1.5px solid var(--border); }
.gv-btn--secondary:hover { background: var(--surface); border-color: var(--blue); color: var(--blue); }
.gv-hamburger { display: none; width: 44px; height: 44px; border: 0; background: var(--surface2); border-radius: 13px; align-items: center; justify-content: center; flex-direction: column; gap: 5px; cursor: pointer; }
.gv-hamburger span { width: 22px; height: 2px; border-radius: 20px; background: var(--text); }
.gv-nav-search { display: flex; align-items: center; gap: 0.5rem; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-radius: 50px; padding: 0.5rem 1rem; margin-left: auto; max-width: 260px; }
.gv-nav-search input { background: transparent; border: none; color: var(--text); font-size: 14px; width: 100%; }
.gv-nav-search input::placeholder { color: var(--muted); }
.gv-nav-search input:focus { outline: none; }

/* Hero */
.gv-hero-inner { max-width: 1240px; margin: 0 auto; padding: 0 24px; }
.gv-hero-content { max-width: 680px; }
.gv-hero-title { font-size: clamp(2.5rem, 6vw, 4rem); font-weight: 900; letter-spacing: -.05em; line-height: 1.05; margin: 0 0 1rem; }
.gv-hero-subtitle { font-size: 1.2rem; color: var(--muted); margin: 0 0 1.5rem; line-height: 1.6; }
.gv-hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 1.5rem; }
.gv-hero-tool-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

/* Stats / Trust bar */
.gv-stats-bar { background: linear-gradient(135deg, var(--navy), #0d3870); padding: 46px 0; color: white; }
.gv-stats-inner { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; max-width: 1240px; margin: 0 auto; padding: 0 24px; }
.gv-stat-item { padding: 18px; border-radius: 18px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14); text-align: center; }
.gv-stat-number { font-size: 1.8rem; font-weight: 900; color: white; }
.gv-stat-label { color: #c8d7e9; font-size: 0.875rem; margin-top: 4px; }

/* Section */
.gv-section-inner { max-width: 1240px; margin: 0 auto; padding: 0 24px; }
.gv-section-title { font-size: clamp(1.75rem, 4vw, 2.5rem); font-weight: 900; letter-spacing: -.04em; line-height: 1.1; margin: 0 0 0.75rem; }
.gv-section-subtitle { font-size: 1.1rem; color: var(--muted); margin: 0 0 2rem; }

/* Category pills */
.gv-category-pills { display: flex; gap: 8px; flex-wrap: wrap; margin: 1.5rem 0; }
.gv-category-pill { display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px; border: 1px solid var(--border); border-radius: 999px; background: var(--surface); color: var(--text); font-size: 0.875rem; font-weight: 700; cursor: pointer; transition: all 0.2s; }
.gv-category-pill:hover { background: var(--surface2); border-color: var(--blue); color: var(--blue); }
.gv-category-pill.active { background: var(--blue); border-color: var(--blue); color: white; }

/* Featured / tool grid */
.gv-featured-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }

/* Tool card */
.gv-tool-card-icon { margin-bottom: 12px; }
.gv-tool-card-icon svg { width: 40px; height: 40px; padding: 8px; border-radius: 12px; background: color-mix(in srgb, var(--blue), transparent 90%); }
.gv-tool-card-title { font-size: 1.1rem; font-weight: 800; margin-bottom: 6px; }
.gv-tool-card-desc { font-size: 0.875rem; color: var(--muted); line-height: 1.5; margin-bottom: 12px; }
.gv-tool-card-footer { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: 12px; border-top: 1px solid var(--border); }
.gv-tool-card-cta { color: var(--blue); font-weight: 700; font-size: 0.875rem; }

/* Problem card */
.gv-problem-card-icon { margin-bottom: 12px; }
.gv-problem-card-icon svg { width: 44px; height: 44px; padding: 10px; border-radius: 14px; }
.gv-problem-card-title { font-size: 1.1rem; font-weight: 800; letter-spacing: -.02em; margin-bottom: 6px; }
.gv-problem-card-desc { font-size: 0.875rem; color: var(--muted); line-height: 1.5; margin-bottom: 12px; }
.gv-problem-card-footer { display: flex; align-items: center; justify-content: space-between; margin-top: auto; }
.gv-problem-card-cta { display: inline-flex; align-items: center; gap: 4px; color: var(--blue); font-weight: 700; font-size: 0.875rem; }
.gv-problem-card-cta svg { width: 16px; height: 16px; }

/* Benefit */
.gv-benefit-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.gv-benefit-icon { font-size: 2rem; margin-bottom: 12px; }
.gv-benefit-title { font-size: 1rem; font-weight: 800; margin-bottom: 8px; }
.gv-benefit-desc { font-size: 0.9rem; color: var(--muted); line-height: 1.6; }

/* Steps */
.gv-step { padding: 24px; border-radius: 24px; background: var(--surface); border: 1px solid var(--border); box-shadow: var(--shadow-sm); }
.gv-step-number { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: 14px; background: var(--navy); color: white; font-weight: 950; font-size: 1rem; margin-bottom: 16px; }
.gv-step-title { display: block; font-size: 1.1rem; font-weight: 800; margin-bottom: 8px; }
.gv-step-desc { color: var(--muted); font-size: 0.9rem; line-height: 1.6; }

/* Status */
.gv-status-pass { background: color-mix(in srgb, var(--green), transparent 84%); color: var(--green); }
.gv-status-warn, .gv-status-warning { background: color-mix(in srgb, var(--amber), transparent 84%); color: var(--amber); }
.gv-status-fail { background: color-mix(in srgb, var(--red), transparent 84%); color: var(--red); }
.gv-badge-active { background: color-mix(in srgb, var(--green), transparent 84%); color: var(--green); padding: 4px 10px; border-radius: 999px; font-size: 0.75rem; font-weight: 900; }
.gv-badge-soon { background: color-mix(in srgb, var(--amber), transparent 84%); color: var(--amber); padding: 4px 10px; border-radius: 999px; font-size: 0.75rem; font-weight: 900; }

/* Footer */
.gv-footer-inner { max-width: 1240px; margin: 0 auto; padding: 0 24px; }
.gv-footer-grid { display: grid; grid-template-columns: 1.4fr repeat(3, 1fr); gap: 28px; }
.gv-footer-brand p { color: var(--muted); font-size: 0.9rem; line-height: 1.6; margin-top: 12px; }
.gv-footer-col-title { font-size: 0.8rem; text-transform: uppercase; letter-spacing: .1em; font-weight: 900; margin-bottom: 12px; }
.gv-footer-links { list-style: none; padding: 0; margin: 0; }
.gv-footer-links li { margin: 8px 0; }
.gv-footer-links a { color: var(--muted); font-size: 0.875rem; }
.gv-footer-links a:hover { color: var(--text); }
.gv-footer-bottom { text-align: center; color: var(--muted); border-top: 1px solid var(--border); margin-top: 28px; padding-top: 18px; font-size: 0.8rem; line-height: 1.6; }
.gv-footer-bottom-links { display: flex; justify-content: center; gap: 16px; margin-top: 12px; }
.gv-footer-bottom-links a { color: var(--muted); font-size: 0.8rem; }

/* Mobile */
.gv-mobile-overlay { display: none; }
.gv-mobile-cta-bar { display: none; }
.gv-mobile-menu { position: fixed; inset: 0; z-index: 100; background: rgba(0,0,0,.52); opacity: 0; visibility: hidden; transition: .22s ease; }
.gv-mobile-menu.is-open { opacity: 1; visibility: visible; }
.gv-mobile-header { display: flex; align-items: center; justify-content: space-between; padding: 18px; }
.gv-mobile-body { padding: 0 16px 20px; overflow: auto; }
.gv-mobile-section { margin-bottom: 8px; }
.gv-mobile-section-header { width: 100%; display: flex; align-items: center; gap: 12px; background: rgba(255,255,255,.06); color: white; border: 1px solid rgba(255,255,255,.12); border-radius: 18px; padding: 14px; font-weight: 850; cursor: pointer; font-family: inherit; font-size: 1rem; }
.gv-mobile-section-items { padding: 0 14px; display: none; }
.gv-mobile-section-items.is-open { display: grid; gap: 8px; padding-top: 8px; }
.gv-mobile-link { display: flex; align-items: center; gap: 12px; padding: 12px; border-radius: 12px; background: rgba(255,255,255,.07); color: white; font-weight: 700; font-size: 0.9rem; }
.gv-mobile-link:hover { background: rgba(255,255,255,.12); }
.gv-mobile-footer { padding: 18px; border-top: 1px solid rgba(255,255,255,.12); display: flex; flex-direction: column; gap: 10px; }

/* Main content */
.main-content { max-width: 1200px; margin: 0 auto; padding: 3rem 1.5rem 5rem; scroll-margin-top: 80px; }
#main { scroll-margin-top: 80px; }
.content-wrapper { max-width: 800px; margin: 0 auto; }

/* Source strip */
.gv-source-strip { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; margin: 1.5rem 0; }
.gv-source-badge { padding: 8px 14px; border: 1px solid var(--border); border-radius: 999px; background: var(--surface); color: var(--text); font-size: 0.8rem; font-weight: 700; }

/* CTA section */
.gv-cta-section, .cta-section { padding: 2rem; background: color-mix(in srgb, var(--blue), transparent 90%); border-radius: 20px; text-align: center; margin: 2rem 0; border: 1px solid color-mix(in srgb, var(--blue), transparent 80%); }
.gv-cta-section h2, .cta-section h2 { font-size: 1.25rem; font-weight: 900; margin-bottom: 0.75rem; }

/* Sidebar link */
.sidebar-link { display: flex; align-items: center; gap: 12px; padding: 12px 16px; border-radius: 12px; color: var(--text); font-weight: 600; transition: all 0.2s; }
.sidebar-link:hover { background: var(--surface2); }

/* Related tools */
.related-tools { margin-top: 2.5rem; padding-top: 2rem; border-top: 1px solid var(--border); }
.related-tool-card { display: flex; flex-direction: column; gap: 4px; padding: 14px; border: 1px solid var(--border); border-radius: 14px; background: var(--surface); color: var(--text); font-weight: 700; font-size: 0.9rem; }
.related-tool-card:hover { border-color: var(--blue); box-shadow: var(--shadow-md); }
.related-tool-card small { font-size: 0.8rem; color: var(--muted); font-weight: 400; }

/* Form styles */
.form-group { margin-bottom: 1.25rem; }
.form-group label { display: block; font-weight: 700; margin-bottom: 0.5rem; color: var(--text); font-size: 0.9rem; }
.form-group input, .form-group select, .form-group textarea { width: 100%; padding: 0.75rem 1rem; border: 1px solid var(--border); border-radius: 12px; font-size: 1rem; font-family: inherit; background: var(--surface2); color: var(--text); transition: border-color 0.2s, box-shadow 0.2s; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { outline: none; border-color: var(--blue); box-shadow: 0 0 0 3px rgba(20,92,255,.1); }
.form-hint { color: var(--muted); font-size: 0.8rem; margin-top: 0.25rem; display: block; }

/* Result styles */
.result-header h3 { font-size: 1.2rem; font-weight: 800; margin-bottom: 0.5rem; }
.result-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 12px; margin-top: 1rem; }
.result-item { background: var(--surface2); border-radius: 14px; padding: 14px; border: 1px solid var(--border); }
.result-label { display: block; font-size: 0.78rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 4px; font-weight: 700; }
.result-value { display: block; font-size: 1.1rem; font-weight: 800; color: var(--text); }
.result-actions { margin-top: 1.25rem; text-align: center; }
.result-link { color: var(--blue); font-weight: 700; text-decoration: none; }
.result-link:hover { text-decoration: underline; }
.recall-header-label { display: flex; flex-direction: column; align-items: center; padding: 1.5rem; background: color-mix(in srgb, var(--amber), transparent 90%); border-radius: 20px 20px 0 0; text-align: center; }
.recall-count-badge { background: var(--amber); color: white; padding: 0.3rem 1rem; border-radius: 50px; font-weight: 700; font-size: 0.875rem; margin-bottom: 0.5rem; }
.recall-vin-note { font-size: 0.8rem; color: color-mix(in srgb, var(--amber) 70%, black); }

/* Responsive overrides for old classes */
@media (max-width: 1023px) {
  .gv-header-inner { height: 64px; }
  .gv-stats-inner { grid-template-columns: repeat(2, 1fr); }
  .gv-featured-grid { grid-template-columns: repeat(2, 1fr); }
  .gv-benefit-grid { grid-template-columns: repeat(2, 1fr); }
  .gv-footer-grid { grid-template-columns: repeat(2, 1fr); }
  .gv-hero-tool-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 767px) {
  .gv-stats-inner { grid-template-columns: 1fr 1fr; }
  .gv-featured-grid { grid-template-columns: 1fr; }
  .gv-benefit-grid { grid-template-columns: 1fr; }
  .gv-footer-grid { grid-template-columns: 1fr; }
  .gv-hero-tool-grid { grid-template-columns: 1fr; }
  .gv-nav-search { display: none; }
  .gv-header-cta { display: none; }
  .gv-nav-item { display: none; }
}
.content-wrapper { max-width: 800px; margin: 0 auto; }
.tool-form { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: 24px; }
.submit-btn { width: 100%; background: linear-gradient(135deg, var(--blue), color-mix(in srgb, var(--blue) 80%, black)); color: white; border: none; border-radius: var(--r-sm); padding: 14px; font-weight: 850; cursor: pointer; font-family: inherit; font-size: 1rem; }
.submit-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(20,92,255,.3); }
.result-box { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 0; overflow: hidden; box-shadow: var(--shadow-md); }
.comparison-result{background:var(--surface);border-radius:var(--r-lg);overflow:hidden}
.towing-labels{display:grid;grid-template-columns:1fr;background:linear-gradient(135deg,color-mix(in srgb,var(--blue),transparent 88%),var(--surface2));padding:18px;border-bottom:1px solid var(--border)}
.towing-label-block{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 18px;border-radius:18px;border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-sm)}
.towing-label-text{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:8px 14px;border-radius:999px;font-size:15px;font-weight:950;letter-spacing:.02em;text-transform:uppercase;white-space:nowrap}
.towing-label-name{font-size:18px;font-weight:950;color:var(--text);letter-spacing:-.03em;text-align:right}
.towing-pass .towing-label-text{background:color-mix(in srgb,var(--green),transparent 84%);color:var(--green)}
.towing-check .towing-label-text{background:color-mix(in srgb,var(--amber),transparent 84%);color:var(--amber)}
.towing-high .towing-label-text{background:color-mix(in srgb,var(--red),transparent 86%);color:var(--red)}
.comparison-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:1px;background:var(--border);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.comp-item{background:var(--surface);padding:18px 16px;min-height:92px;display:flex;flex-direction:column;justify-content:center;gap:6px;line-height:1.55}
.comp-label{display:block;color:var(--muted);font-size:11px;font-weight:950;letter-spacing:.12em;text-transform:uppercase;line-height:1.3}
.comp-label::after{content:' ';white-space:pre}
.comp-value{display:block;color:var(--text);font-size:22px;font-weight:950;line-height:1.15;letter-spacing:-.03em;overflow-wrap:anywhere}
.result-source-note{margin:18px;padding:16px 18px;border-radius:16px;background:var(--surface2);border:1px solid var(--border);color:var(--text);font-size:15px;line-height:1.63}
.result-warning-box{margin:0 18px 18px;padding:16px 18px;border-radius:16px;background:color-mix(in srgb,var(--amber),transparent 90%);border:1px solid color-mix(in srgb,var(--amber),transparent 55%);color:var(--text);font-size:14px;line-height:1.58}
.result-warning-box p{margin:.25rem 0}
.result-warning-box ul{margin:0;padding-left:1.15rem}
.result-warning-box li+li{margin-top:9px}
@media (max-width:600px){.towing-label-block{align-items:flex-start;flex-direction:column}.towing-label-name{text-align:left}.comparison-grid{grid-template-columns:1fr}.comp-value{font-size:20px}}
/* ── USB-C Visual Flow Result ───────────────────────────────────────────── */
.gv-flow-result{background:var(--surface);border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-md)}
.gv-flow-hero{position:relative;padding:24px 22px 20px;text-align:center;background:linear-gradient(160deg,var(--surface2) 0%,var(--surface) 60%);border-bottom:1px solid var(--border);overflow:hidden}
.gv-flow-badge{display:inline-flex;align-items:center;gap:8px;padding:7px 18px;border-radius:999px;font-size:12px;font-weight:950;letter-spacing:.06em;text-transform:uppercase}
.gv-flow-badge--pass{background:color-mix(in srgb,var(--green),transparent 88%);color:var(--green);border:1.5px solid var(--green)}
.gv-flow-badge--warn{background:color-mix(in srgb,var(--amber),transparent 88%);color:var(--amber);border:1.5px solid var(--amber)}
.gv-flow-badge--fail{background:color-mix(in srgb,var(--red),transparent 90%);color:var(--red);border:1.5px solid var(--red)}
.gv-flow-badge--ok svg{color:var(--green)}
.gv-flow-badge--warn svg{color:var(--amber)}
.gv-flow-badge--fail svg{color:var(--red)}
.gv-flow-eyebrow{font-size:10px;font-weight:950;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:8px}
.gv-flow-title{font-size:22px;font-weight:950;letter-spacing:-.03em;color:var(--text);margin-top:2px}
.gv-flow-usable{font-size:42px;font-weight:950;letter-spacing:-.04em;margin-top:10px;color:var(--text)}
.gv-flow-usable small{display:block;font-size:.3em;color:var(--muted);font-weight:750;letter-spacing:.05em;margin-top:4px}
.gv-flow-diagram{padding:28px 20px 24px;background:linear-gradient(180deg,var(--surface) 0%,var(--surface2) 100%);border-bottom:1px solid var(--border)}
.gv-chain{display:flex;align-items:center;justify-content:center;gap:0}
.gv-chain-node{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;min-width:90px;flex:0 0 auto}
.gv-chain-icon{width:72px;height:72px;border-radius:18px;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;background:var(--surface);transition:border-color .3s;position:relative}
.gv-chain-icon svg{width:40px;height:40px}
.gv-chain-icon--pass{border-color:var(--green);box-shadow:0 0 0 3px color-mix(in srgb,var(--green) 20%,transparent)}
.gv-chain-icon--warn{border-color:var(--amber);box-shadow:0 0 0 3px color-mix(in srgb,var(--amber) 20%,transparent)}
.gv-chain-icon--fail{border-color:var(--red);box-shadow:0 0 0 3px color-mix(in srgb,var(--red) 20%,transparent)}
.gv-chain-icon--ref{border-color:var(--blue);box-shadow:0 0 0 3px color-mix(in srgb,var(--blue) 20%,transparent)}
.gv-chain-watt{font-size:18px;font-weight:950;color:var(--text);letter-spacing:-.03em}
.gv-chain-watt small{font-size:.55em;color:var(--muted);font-weight:750}
.gv-chain-label{font-size:10px;font-weight:950;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.gv-chain-sub{font-size:10px;color:var(--muted);margin-top:-4px;text-align:center}
/* Flow connector between nodes */
.gv-flow-conn{position:relative;flex:1;min-width:28px;max-width:64px;height:56px;display:flex;align-items:center;justify-content:center;overflow:visible}
.gv-flow-line{width:100%;height:3px;background:var(--border);position:relative;border-radius:3px;overflow:visible}
.gv-flow-line-inner{position:absolute;inset:0;border-radius:3px;overflow:hidden}
.gv-flow-line-fill{position:absolute;top:0;left:0;height:100%;border-radius:3px;width:0;animation:none}
/* The animated energy pulse */
.gv-flow-pulse{position:absolute;top:-4px;left:0;width:28px;height:11px;background:linear-gradient(90deg,transparent,var(--blue),var(--cyan),var(--blue),transparent);border-radius:6px;box-shadow:0 0 8px var(--cyan);opacity:0;pointer-events:none}
.gv-flow-pulse--pass{background:linear-gradient(90deg,transparent,var(--green),#22c55e,var(--green),transparent);box-shadow:0 0 8px var(--green)}
.gv-flow-pulse--warn{background:linear-gradient(90deg,transparent,var(--amber),#f59e0b,var(--amber),transparent);box-shadow:0 0 8px var(--amber)}
.gv-flow-pulse--fail{background:linear-gradient(90deg,transparent,var(--red),#ef4444,var(--red),transparent);box-shadow:0 0 8px var(--red)}
.gv-flow-pulse--bottleneck{background:linear-gradient(90deg,transparent,var(--red),#ef4444,var(--red),transparent);box-shadow:0 0 10px var(--red)}
/* Flow line label */
.gv-flow-conn-label{position:absolute;bottom:-22px;left:0;right:0;text-align:center;font-size:10px;font-weight:750;color:var(--muted);letter-spacing:.04em}
/* Bottleneck indicator */
.gv-chain-node--bottleneck .gv-chain-icon{animation:gv-bottleneck-pulse 1.5s ease-in-out infinite;border-color:var(--red);box-shadow:0 0 0 4px color-mix(in srgb,var(--red) 25%,transparent)}
.gv-chain-node--bottleneck .gv-chain-watt{color:var(--red)}
.gv-chain-warn-tag{display:none;align-items:center;gap:4px;padding:3px 8px;border-radius:999px;background:color-mix(in srgb,var(--red),transparent 88%);color:var(--red);font-size:10px;font-weight:950;letter-spacing:.06em;text-transform:uppercase;margin-top:2px}
.gv-chain-node--bottleneck .gv-chain-warn-tag{display:inline-flex}
/* Simple bar meter per node */
.gv-chain-bar{width:72px;height:6px;background:var(--border);border-radius:6px;overflow:hidden;margin-top:2px}
.gv-chain-bar-fill{height:100%;border-radius:6px;width:0;transition:width 1s cubic-bezier(.22,1,.36,1)}
.gv-chain-bar-fill--green{background:linear-gradient(90deg,var(--green),#22c55e)}
.gv-chain-bar-fill--amber{background:linear-gradient(90deg,var(--amber),#f59e0b)}
.gv-chain-bar-fill--red{background:linear-gradient(90deg,var(--red),#ef4444)}
.gv-chain-bar-fill--blue{background:linear-gradient(90deg,var(--blue),var(--blue-2))}
/* ── Keyframes for flow animation ── */
@keyframes gv-flow-animate{
  0%{transform:translateX(0);opacity:0}
  10%{opacity:1}
  100%{transform:translateX(60px);opacity:0}
}
@keyframes gv-chain-in{
  0%{opacity:0;transform:translateY(8px)}
  100%{opacity:1;transform:translateY(0)}
}
@keyframes gv-bottleneck-pulse{
  0%,100%{box-shadow:0 0 0 4px color-mix(in srgb,var(--red) 25%,transparent)}
  50%{box-shadow:0 0 0 8px color-mix(in srgb,var(--red) 10%,transparent)}
}
@keyframes gv-bar-fill{to{width:var(--bar-width)}}
@keyframes gv-flow-slide{
  0%{left:0;opacity:1}
  80%{opacity:1}
  100%{left:100%;opacity:0}
}
/* ── Measurement table ── */
.gv-flow-section{border-bottom:1px solid var(--border)}
.gv-flow-section-title{padding:12px 22px 10px;font-size:11px;font-weight:950;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);border-bottom:1px dashed var(--border)}
.gv-flow-table{width:100%;border-collapse:collapse}
.gv-flow-table th,.gv-flow-table td{padding:12px 18px;text-align:left;border-bottom:1px solid var(--border);font-size:13px}
.gv-flow-table th{font-size:10px;font-weight:950;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:var(--surface2);width:42%}
.gv-flow-table td{font-weight:750;color:var(--text)}
.gv-flow-table tr:last-child td,.gv-flow-table tr:last-child th{border-bottom:none}
.gv-flow-table .gv-row-pass td{color:var(--green)}
.gv-flow-table .gv-row-warn td{color:var(--amber)}
.gv-flow-table .gv-row-fail td{color:var(--red)}
/* ── Chain summary grid ── */
.gv-flow-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border)}
.gv-flow-info-cell{background:var(--surface);padding:14px 18px;display:flex;flex-direction:column;gap:3px}
.gv-flow-info-label{font-size:10px;font-weight:950;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.gv-flow-info-value{font-size:20px;font-weight:950;color:var(--text);letter-spacing:-.02em}
.gv-flow-info-sub{font-size:11px;color:var(--muted)}
/* ── Analysis note ── */
.gv-flow-analysis{padding:16px 22px;border-top:1px solid var(--border)}
/* ── MOBILE ── */
@media (max-width:600px){
  .gv-chain{flex-direction:column;gap:0;position:relative}
  .gv-chain-node{margin-bottom:0}
  .gv-chain-node::after{display:none}
  .gv-flow-conn{width:56px;height:48px;min-width:56px;transform:rotate(90deg)}
  .gv-chain-icon{width:64px;height:64px}
  .gv-chain-icon svg{width:34px;height:34px}
  .gv-chain-watt{font-size:16px}
  .gv-chain-bar{width:64px}
  .gv-chain-in-1{animation:gv-chain-in .5s ease-out .1s both}
  .gv-chain-in-2{animation:gv-chain-in .5s ease-out .4s both}
  .gv-chain-in-3{animation:gv-chain-in .5s ease-out .7s both}
  .gv-flow-usable{font-size:36px}
  .gv-flow-info-grid{grid-template-columns:1fr}
}
.gv-visual-result{background:var(--surface);border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-md)}
.gv-result-hero{display:flex;align-items:center;gap:14px;padding:22px 22px 18px;border-bottom:1px solid var(--border)}
.gv-result-hero-status{font-size:11px;font-weight:950;letter-spacing:.12em;text-transform:uppercase;padding:5px 12px;border-radius:999px;white-space:nowrap}
.gv-result-hero-label{font-size:15px;font-weight:750;color:var(--text)}
.gv-result-summary{padding:20px 22px;display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:1px;background:var(--border);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.gv-result-metric{background:var(--surface);padding:18px 16px;min-height:96px;display:flex;flex-direction:column;justify-content:center;gap:8px}
.gv-result-metric .gv-rm-label{display:block;color:var(--muted);font-size:11px;font-weight:950;letter-spacing:.12em;text-transform:uppercase;line-height:1.3}
.gv-result-metric .gv-rm-value{display:block;color:var(--text);font-size:22px;font-weight:950;line-height:1.15;letter-spacing:-.03em}
.gv-result-metric .gv-rm-note{display:block;color:var(--muted);font-size:12px;line-height:1.4}
.gv-result-note{margin:18px 22px;padding:16px 18px;border-radius:16px;background:var(--surface2);border:1px solid var(--border);color:var(--text);font-size:15px;line-height:1.6}
.gv-result-note--warn{margin:0 22px 18px;padding:16px 18px;border-radius:16px;background:color-mix(in srgb,var(--amber),transparent 90%);border:1px solid color-mix(in srgb,var(--amber),transparent 55%);font-size:14px;line-height:1.55}
.gv-result-note--warn ul{margin:0;padding-left:1.15rem}
.gv-result-note--warn li+li{margin-top:8px}
/* Power chain flow diagram */
.gv-power-chain{margin:18px 22px;padding:18px 20px;background:var(--surface2);border-radius:18px;border:1px solid var(--border)}
.gv-power-chain-title{font-size:11px;font-weight:950;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.gv-chain-row{display:flex;align-items:center;gap:0}
.gv-chain-node{flex:0 0 auto;min-width:80px;text-align:center}
.gv-chain-node-icon{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 6px;border:1.5px solid var(--border)}
.gv-chain-node-label{font-size:11px;font-weight:750;color:var(--text);letter-spacing:.04em}
.gv-chain-node-watts{font-size:13px;font-weight:950;color:var(--text)}
.gv-chain-arrow{flex:1;display:flex;align-items:center;justify-content:center;min-width:28px;max-width:40px}
.gv-chain-bar-wrap{flex:1;display:flex;flex-direction:column;justify-content:center;gap:3px;padding:0 4px}
.gv-chain-bar-bg{height:8px;border-radius:8px;background:var(--border);overflow:hidden}
.gv-chain-bar-fill{height:100%;border-radius:8px;transition:width .4s ease}
.gv-chain-bar-fill--green{background:linear-gradient(90deg,var(--green),#22c55e)}
.gv-chain-bar-fill--amber{background:linear-gradient(90deg,var(--amber),#f59e0b)}
.gv-chain-bar-fill--red{background:linear-gradient(90deg,var(--red),#ef4444)}
.gv-chain-bar-fill--blue{background:linear-gradient(90deg,var(--blue),var(--blue-2))}
.gv-chain-limit-label{font-size:10px;color:var(--muted);text-align:center}
/* Bar meter (standalone) */
.gv-bar-meter{margin:14px 0}
.gv-bar-meter-label{font-size:12px;font-weight:750;color:var(--text);margin-bottom:6px;display:flex;justify-content:space-between}
.gv-bar-meter-track{height:10px;border-radius:10px;background:var(--border);overflow:hidden}
.gv-bar-meter-fill{height:100%;border-radius:10px}
/* ── Tire Comparison Visual ─────────────────────────────────────────────────── */
.gv-tire-compare{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;padding:20px 22px;border-bottom:1px solid var(--border)}
.gv-tire-side{text-align:center}
.gv-tire-svg-wrap{display:flex;justify-content:center;margin-bottom:10px}
.gv-tire-label{font-size:12px;font-weight:950;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.gv-tire-size{font-size:20px;font-weight:950;letter-spacing:-.02em;color:var(--text)}
.gv-tire-diam{font-size:13px;color:var(--muted);margin-top:4px}
.gv-tire-vs{font-size:28px;font-weight:950;color:var(--border);letter-spacing:-.04em}
.gv-tire-diagram svg{overflow:visible}
/* Speedometer dial */
.gv-speed-dial{display:flex;justify-content:center;padding:20px 22px;border-bottom:1px solid var(--border)}
.gv-speed-dial svg{max-width:280px;width:100%}
/* Wheel offset side view */
.gv-wheel-diagram{padding:20px 22px;border-bottom:1px solid var(--border)}
/* Towing bar meters */
.gv-towing-meter-wrap{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:20px 22px;border-bottom:1px solid var(--border)}
.gv-towing-meter{min-width:0}
.gv-towing-meter-labels{font-size:11px;font-weight:950;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;display:flex;justify-content:space-between}
/* Mobile visual adjustments */
@media (max-width:600px){
  .gv-result-summary{grid-template-columns:1fr}
  .gv-tire-compare{grid-template-columns:1fr;gap:10px}
  .gv-tire-vs{display:none}
  .gv-towing-meter-wrap{grid-template-columns:1fr}
}
.footer-disclaimer { background: color-mix(in srgb, var(--amber), transparent 90%); border-left: 4px solid var(--amber); padding: 16px 20px; border-radius: 0 var(--r-sm) var(--r-sm) 0; margin-top: 24px; font-size: 0.875rem; }
.error-box { background: color-mix(in srgb, var(--red), transparent 90%); border: 1px solid var(--red); border-radius: var(--r-sm); padding: 16px; color: var(--red); }
.loading-box { background: var(--surface2); border-radius: var(--r-sm); padding: 32px; text-align: center; color: var(--muted); font-style: italic; margin: 24px 0; border: 1px solid var(--border); }
.no-recalls-box { background: color-mix(in srgb, var(--green), transparent 90%); border: 1px solid var(--green); border-radius: var(--r-sm); padding: 32px; text-align: center; margin: 24px 0; }
.no-recalls-label { font-weight: 700; color: var(--green); }
.result-label { display: block; font-size: 0.8rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 4px; }
.result-value { display: block; font-size: 1.25rem; font-weight: 900; color: var(--text); }
.recall-card { border: 1px solid var(--border); border-radius: var(--r-sm); padding: 16px; margin-bottom: 12px; background: var(--surface); }

/* ── USB-C Power Flow v2: clean desktop/mobile layout ───────────────────── */
.usb-flow-result{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);overflow:hidden}
.usb-flow-hero{padding:24px 22px 22px;text-align:center;background:linear-gradient(160deg,var(--surface2),var(--surface));border-bottom:1px solid var(--border)}
.usb-flow-badge{display:inline-flex;align-items:center;gap:8px;padding:7px 18px;border-radius:999px;font-size:12px;font-weight:950;letter-spacing:.06em;text-transform:uppercase;border:1.5px solid currentColor}
.usb-flow-badge--pass{background:color-mix(in srgb,var(--green),transparent 88%);color:var(--green)}
.usb-flow-badge--warn{background:color-mix(in srgb,var(--amber),transparent 88%);color:var(--amber)}
.usb-flow-badge--fail{background:color-mix(in srgb,var(--red),transparent 90%);color:var(--red)}
.usb-flow-eyebrow{margin-top:10px;font-size:10px;font-weight:950;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.usb-flow-title{margin-top:3px;font-size:22px;font-weight:950;letter-spacing:-.03em;color:var(--text)}
.usb-flow-usable{margin-top:12px;font-size:44px;font-weight:950;line-height:1;letter-spacing:-.045em;color:var(--text)}
.usb-flow-usable small{display:block;margin-top:7px;font-size:13px;line-height:1.45;font-weight:750;letter-spacing:.02em;color:var(--muted)}
.usb-flow-diagram{padding:30px 24px 28px;background:linear-gradient(180deg,var(--surface),var(--surface2));border-bottom:1px solid var(--border)}
.usb-flow-chain{display:grid;grid-template-columns:minmax(130px,1fr) minmax(90px,.75fr) minmax(130px,1fr) minmax(90px,.75fr) minmax(130px,1fr);align-items:center;gap:0;max-width:900px;margin:0 auto}
.usb-flow-node{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;gap:7px;min-width:0;animation:usb-flow-node-in .45s ease-out both}
.usb-flow-node:nth-child(3){animation-delay:.12s}.usb-flow-node:nth-child(5){animation-delay:.24s}
.usb-flow-icon{width:76px;height:76px;border-radius:20px;border:2px solid var(--border);background:var(--surface);display:grid;place-items:center;box-shadow:var(--shadow-sm)}
.usb-flow-icon svg{width:44px;height:44px;color:var(--text)}
.usb-flow-icon--pass{border-color:var(--green);box-shadow:0 0 0 4px color-mix(in srgb,var(--green) 18%,transparent)}
.usb-flow-icon--warn{border-color:var(--amber);box-shadow:0 0 0 4px color-mix(in srgb,var(--amber) 18%,transparent)}
.usb-flow-icon--fail{border-color:var(--red);box-shadow:0 0 0 4px color-mix(in srgb,var(--red) 18%,transparent)}
.usb-flow-icon--target{border-color:var(--blue);box-shadow:0 0 0 4px color-mix(in srgb,var(--blue) 18%,transparent)}
.usb-flow-node.is-bottleneck .usb-flow-icon{animation:usb-flow-bottleneck 1.5s ease-in-out infinite;border-color:var(--red)}
.usb-flow-kicker{font-size:10px;font-weight:950;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.usb-flow-value{font-size:22px;font-weight:950;letter-spacing:-.035em;color:var(--text);line-height:1}
.usb-flow-value small{font-size:.55em;color:var(--muted);font-weight:750}
.usb-flow-status{font-size:12px;font-weight:850;line-height:1.35;color:var(--text)}
.usb-flow-sub{font-size:11px;line-height:1.4;color:var(--muted);max-width:150px}
.usb-flow-node.is-bottleneck .usb-flow-value,.usb-flow-node.is-bottleneck .usb-flow-status{color:var(--red)}
.usb-flow-tag{display:none;margin-top:1px;padding:4px 8px;border-radius:999px;background:color-mix(in srgb,var(--red),transparent 88%);color:var(--red);font-size:10px;font-weight:950;letter-spacing:.06em;text-transform:uppercase}
.usb-flow-node.is-bottleneck .usb-flow-tag{display:inline-flex}
.usb-flow-bar{width:76px;height:6px;background:var(--border);border-radius:999px;overflow:hidden;margin-top:2px}
.usb-flow-bar span{display:block;height:100%;border-radius:999px;animation:usb-flow-bar .75s cubic-bezier(.22,1,.36,1) both}
.usb-flow-bar--green{background:linear-gradient(90deg,var(--green),#22c55e)}
.usb-flow-bar--amber{background:linear-gradient(90deg,var(--amber),#f59e0b)}
.usb-flow-bar--red{background:linear-gradient(90deg,var(--red),#ef4444)}
.usb-flow-bar--blue{background:linear-gradient(90deg,var(--blue),var(--blue-2))}
.usb-flow-link{position:relative;height:76px;display:flex;align-items:center;justify-content:center;min-width:0}
.usb-flow-line{position:relative;width:100%;height:6px;border-radius:999px;background:var(--border);overflow:hidden}
.usb-flow-line::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--blue) 50%,transparent),transparent);opacity:.55}
.usb-flow-link::after{content:'›';position:absolute;right:-2px;top:50%;transform:translateY(-52%);font-size:30px;font-weight:950;color:var(--blue);line-height:1}
.usb-flow-link.is-limited::after{color:var(--red)}
.usb-flow-pulse{position:absolute;left:0;top:50%;width:34px;height:12px;transform:translateY(-50%);border-radius:999px;background:linear-gradient(90deg,transparent,var(--green),#22c55e,var(--green),transparent);box-shadow:0 0 12px color-mix(in srgb,var(--green) 75%,transparent);animation:usb-flow-left-right 1.8s ease-in-out infinite;pointer-events:none}
.usb-flow-link.is-warning .usb-flow-pulse{background:linear-gradient(90deg,transparent,var(--amber),#f59e0b,var(--amber),transparent);box-shadow:0 0 12px color-mix(in srgb,var(--amber) 75%,transparent)}
.usb-flow-link.is-limited .usb-flow-pulse{background:linear-gradient(90deg,transparent,var(--red),#ef4444,var(--red),transparent);box-shadow:0 0 12px color-mix(in srgb,var(--red) 75%,transparent)}
.usb-flow-link-label{position:absolute;left:50%;top:calc(50% + 14px);transform:translateX(-50%);white-space:nowrap;font-size:10px;font-weight:850;letter-spacing:.04em;color:var(--muted)}
.usb-flow-section{border-bottom:1px solid var(--border)}
.usb-flow-section-title{padding:14px 22px 10px;border-bottom:1px dashed var(--border);font-size:11px;font-weight:950;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.usb-flow-table{width:100%;border-collapse:collapse}.usb-flow-table th,.usb-flow-table td{padding:13px 18px;text-align:left;border-bottom:1px solid var(--border);font-size:13px;line-height:1.45}.usb-flow-table th{background:var(--surface2);font-size:10px;font-weight:950;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);width:42%}.usb-flow-table td{font-weight:750;color:var(--text)}.usb-flow-table tr:last-child th,.usb-flow-table tr:last-child td{border-bottom:0}.usb-row-pass td{color:var(--green)}.usb-row-warn td{color:var(--amber)}.usb-row-fail td{color:var(--red)}
.usb-flow-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border)}
.usb-flow-info-cell{background:var(--surface);padding:15px 18px;display:flex;flex-direction:column;gap:4px}.usb-flow-info-label{font-size:10px;font-weight:950;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.usb-flow-info-value{font-size:21px;font-weight:950;letter-spacing:-.025em;color:var(--text)}.usb-flow-info-sub{font-size:12px;line-height:1.45;color:var(--muted)}
.usb-flow-analysis{padding:17px 22px;border-top:1px solid var(--border)}
@keyframes usb-flow-node-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes usb-flow-left-right{0%{left:-28px;opacity:0}12%{opacity:1}85%{opacity:1}100%{left:100%;opacity:0}}
@keyframes usb-flow-top-bottom{0%{top:-24px;opacity:0}12%{opacity:1}85%{opacity:1}100%{top:100%;opacity:0}}
@keyframes usb-flow-bottleneck{0%,100%{box-shadow:0 0 0 4px color-mix(in srgb,var(--red) 22%,transparent)}50%{box-shadow:0 0 0 9px color-mix(in srgb,var(--red) 10%,transparent)}}
@keyframes usb-flow-bar{from{width:0}to{width:var(--w)}}
@media (max-width:700px){
  .usb-flow-hero{padding:22px 18px 21px}.usb-flow-title{font-size:20px}.usb-flow-usable{font-size:38px}
  .usb-flow-diagram{padding:22px 18px 24px}
  .usb-flow-chain{display:grid;grid-template-columns:74px 1fr;max-width:360px;margin:0 auto;column-gap:16px;row-gap:0;align-items:center;position:relative}
  .usb-flow-node{display:contents;animation:none;text-align:left}.usb-flow-node-media{grid-column:1;display:flex;justify-content:center}.usb-flow-node-copy{grid-column:2;display:flex;flex-direction:column;align-items:flex-start;text-align:left;gap:5px;padding:18px 0;min-height:104px;justify-content:center}
  .usb-flow-icon{width:62px;height:62px;border-radius:17px;position:relative;z-index:2}.usb-flow-icon svg{width:36px;height:36px}.usb-flow-kicker{font-size:10px}.usb-flow-value{font-size:19px}.usb-flow-status{font-size:13px;line-height:1.45}.usb-flow-sub{max-width:none;font-size:12px;line-height:1.5}.usb-flow-bar{width:92px}
  .usb-flow-link{grid-column:1;grid-row:auto;height:54px;width:62px;justify-self:center;display:block;min-width:0;max-width:none;transform:none}.usb-flow-link-copy{display:none}.usb-flow-line{position:absolute;left:50%;top:-4px;bottom:-4px;width:6px;height:auto;transform:translateX(-50%)}.usb-flow-line::before{background:linear-gradient(180deg,transparent,color-mix(in srgb,var(--blue) 50%,transparent),transparent)}.usb-flow-link::after{content:'⌄';right:auto;left:50%;top:50%;transform:translate(-50%,-45%);font-size:24px}.usb-flow-pulse{left:50%;top:-24px;width:12px;height:30px;transform:translateX(-50%);background:linear-gradient(180deg,transparent,var(--green),#22c55e,var(--green),transparent);animation:usb-flow-top-bottom 1.8s ease-in-out infinite}.usb-flow-link.is-warning .usb-flow-pulse{background:linear-gradient(180deg,transparent,var(--amber),#f59e0b,var(--amber),transparent)}.usb-flow-link.is-limited .usb-flow-pulse{background:linear-gradient(180deg,transparent,var(--red),#ef4444,var(--red),transparent)}.usb-flow-link-label{display:none}
  .usb-flow-table,.usb-flow-table thead,.usb-flow-table tbody,.usb-flow-table tr,.usb-flow-table th,.usb-flow-table td{display:block;width:100%}.usb-flow-table thead{display:none}.usb-flow-table tr{padding:14px 18px;border-bottom:1px solid var(--border);background:var(--surface)}.usb-flow-table tr:last-child{border-bottom:0}.usb-flow-table th,.usb-flow-table td{border:0;padding:0}.usb-flow-table td:first-child{font-size:10px;font-weight:950;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:5px}.usb-flow-table td:nth-child(2){font-size:20px;font-weight:950;color:var(--text);margin-bottom:4px}.usb-flow-table td:nth-child(3){font-size:13px;line-height:1.55}.usb-row-pass td:nth-child(3){color:var(--green)}.usb-row-warn td:nth-child(3){color:var(--amber)}.usb-row-fail td:nth-child(3){color:var(--red)}
  .usb-flow-info-grid{grid-template-columns:1fr}.usb-flow-info-cell{padding:16px 18px}.usb-flow-analysis{padding:17px 18px}
}

/* ⛓ Charger Compatibility Flow — .charger-flow-* ⛓ */
.charger-flow-result{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);overflow:hidden}
.charger-flow-hero{padding:24px 22px 22px;text-align:center;background:linear-gradient(160deg,var(--surface2),var(--surface));border-bottom:1px solid var(--border)}
.charger-flow-badge{display:inline-flex;align-items:center;gap:8px;padding:7px 18px;border-radius:999px;font-size:12px;font-weight:950;letter-spacing:.06em;text-transform:uppercase;border:1.5px solid currentColor}
.charger-flow-badge--pass{background:color-mix(in srgb,var(--green),transparent 88%);color:var(--green)}
.charger-flow-badge--warn{background:color-mix(in srgb,var(--amber),transparent 88%);color:var(--amber)}
.charger-flow-badge--fail{background:color-mix(in srgb,var(--red),transparent 90%);color:var(--red)}
.charger-flow-eyebrow{margin-top:10px;font-size:10px;font-weight:950;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.charger-flow-title{margin-top:3px;font-size:22px;font-weight:950;letter-spacing:-.03em;color:var(--text)}
.charger-flow-summary{margin-top:14px;display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.charger-flow-chip{padding:5px 12px;border-radius:999px;font-size:11px;font-weight:850;background:var(--surface2);border:1px solid var(--border);color:var(--text);display:inline-flex;align-items:center;gap:4px}
.charger-flow-chip strong{font-weight:950}
.charger-flow-diagram{padding:30px 24px 28px;background:linear-gradient(180deg,var(--surface),var(--surface2));border-bottom:1px solid var(--border)}
.charger-flow-chain{display:grid;grid-template-columns:minmax(120px,1fr) minmax(90px,.75fr) minmax(120px,1fr) minmax(90px,.75fr) minmax(120px,1fr);align-items:center;gap:0;max-width:860px;margin:0 auto}
.charger-flow-node{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;gap:7px;min-width:0;animation:charger-flow-node-in .45s ease-out both}
.charger-flow-node:nth-child(3){animation-delay:.12s}.charger-flow-node:nth-child(5){animation-delay:.24s}
.charger-flow-icon{width:72px;height:72px;border-radius:19px;border:2px solid var(--border);background:var(--surface);display:grid;place-items:center;box-shadow:var(--shadow-sm)}
.charger-flow-icon svg{width:40px;height:40px;color:var(--text)}
.charger-flow-icon--pass{border-color:var(--green);box-shadow:0 0 0 4px color-mix(in srgb,var(--green) 18%,transparent)}
.charger-flow-icon--warn{border-color:var(--amber);box-shadow:0 0 0 4px color-mix(in srgb,var(--amber) 18%,transparent)}
.charger-flow-icon--fail{border-color:var(--red);box-shadow:0 0 0 4px color-mix(in srgb,var(--red) 18%,transparent)}
.charger-flow-icon--target{border-color:var(--blue);box-shadow:0 0 0 4px color-mix(in srgb,var(--blue) 18%,transparent)}
.charger-flow-icon--ref{border-color:var(--muted);box-shadow:none}
.charger-flow-kicker{font-size:10px;font-weight:950;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.charger-flow-value{font-size:21px;font-weight:950;letter-spacing:-.035em;color:var(--text);line-height:1}
.charger-flow-value small{font-size:.55em;color:var(--muted);font-weight:750}
.charger-flow-status{font-size:12px;font-weight:850;line-height:1.35;color:var(--text)}
.charger-flow-sub{font-size:11px;line-height:1.4;color:var(--muted);max-width:140px}
.charger-flow-tag{display:none;margin-top:1px;padding:3px 7px;border-radius:999px;background:color-mix(in srgb,var(--red),transparent 88%);color:var(--red);font-size:10px;font-weight:950;letter-spacing:.06em;text-transform:uppercase}
.charger-flow-node.is-bottleneck .charger-flow-tag{display:inline-flex}
.charger-flow-node.is-bottleneck .charger-flow-icon{animation:charger-flow-bottleneck 1.5s ease-in-out infinite;border-color:var(--red)}
.charger-flow-node.is-bottleneck .charger-flow-value,.charger-flow-node.is-bottleneck .charger-flow-status{color:var(--red)}
.charger-flow-bar{width:72px;height:6px;background:var(--border);border-radius:999px;overflow:hidden;margin-top:2px}
.charger-flow-bar span{display:block;height:100%;border-radius:999px;animation:charger-flow-bar .75s cubic-bezier(.22,1,.36,1) both}
.charger-flow-bar--green{background:linear-gradient(90deg,var(--green),#22c55e)}
.charger-flow-bar--amber{background:linear-gradient(90deg,var(--amber),#f59e0b)}
.charger-flow-bar--red{background:linear-gradient(90deg,var(--red),#ef4444)}
.charger-flow-bar--blue{background:linear-gradient(90deg,var(--blue),var(--blue-2))}
.charger-flow-bar--muted{background:var(--muted)}
.charger-flow-link{position:relative;height:72px;display:flex;align-items:center;justify-content:center;min-width:0}
.charger-flow-line{position:relative;width:100%;height:6px;border-radius:999px;background:var(--border);overflow:hidden}
.charger-flow-line::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--blue) 50%,transparent),transparent);opacity:.55}
.charger-flow-link::after{content:'→';position:absolute;right:-2px;top:50%;transform:translateY(-52%);font-size:28px;font-weight:950;color:var(--blue);line-height:1}
.charger-flow-link.is-limited::after{color:var(--red)}
.charger-flow-pulse{position:absolute;left:0;top:50%;width:30px;height:12px;transform:translateY(-50%);border-radius:999px;background:linear-gradient(90deg,transparent,var(--green),#22c55e,var(--green),transparent);box-shadow:0 0 12px color-mix(in srgb,var(--green) 75%,transparent);animation:charger-flow-left-right 1.8s ease-in-out infinite;pointer-events:none}
.charger-flow-link.is-warning .charger-flow-pulse{background:linear-gradient(90deg,transparent,var(--amber),#f59e0b,var(--amber),transparent);box-shadow:0 0 12px color-mix(in srgb,var(--amber) 75%,transparent)}
.charger-flow-link.is-limited .charger-flow-pulse{background:linear-gradient(90deg,transparent,var(--red),#ef4444,var(--red),transparent);box-shadow:0 0 12px color-mix(in srgb,var(--red) 75%,transparent)}
.charger-flow-link-label{position:absolute;left:50%;top:calc(50% + 14px);transform:translateX(-50%);white-space:nowrap;font-size:10px;font-weight:850;letter-spacing:.04em;color:var(--muted)}
.charger-flow-notes{padding:18px 22px;border-top:1px solid var(--border)}
.charger-flow-notes-title{padding:12px 22px 10px;border-bottom:1px dashed var(--border);font-size:11px;font-weight:950;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.charger-flow-notes ul{margin:0;padding:14px 18px 0;list-style:none}
.charger-flow-notes li{position:relative;padding-left:18px;font-size:13px;line-height:1.65;color:var(--text);margin-bottom:7px}
.charger-flow-notes li::before{content:'•';position:absolute;left:0;color:var(--muted);font-weight:900}
.charger-flow-notes li:last-child{margin-bottom:0}
.charger-flow-analysis{padding:17px 22px;border-top:1px solid var(--border);font-size:13px;line-height:1.6;color:var(--text);background:var(--surface2)}
@keyframes charger-flow-node-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes charger-flow-left-right{0%{left:-24px;opacity:0}12%{opacity:1}85%{opacity:1}100%{left:100%;opacity:0}}
@keyframes charger-flow-top-bottom{0%{top:-24px;opacity:0}12%{opacity:1}85%{opacity:1}100%{top:100%;opacity:0}}
@keyframes charger-flow-bottleneck{0%,100%{box-shadow:0 0 0 4px color-mix(in srgb,var(--red) 22%,transparent)}50%{box-shadow:0 0 0 9px color-mix(in srgb,var(--red) 10%,transparent)}}
@keyframes charger-flow-bar{from{width:0}to{width:var(--w)}}
@media (max-width:700px){
  .charger-flow-hero{padding:22px 18px 21px}.charger-flow-title{font-size:20px}
  .charger-flow-summary{flex-direction:column;align-items:center;gap:6px}
  .charger-flow-diagram{padding:22px 18px 24px}
  .charger-flow-chain{display:grid;grid-template-columns:72px 1fr;max-width:340px;margin:0 auto;column-gap:14px;row-gap:0;align-items:center;position:relative}
  .charger-flow-node{display:contents;animation:none;text-align:left}.charger-flow-node-media{grid-column:1;display:flex;justify-content:center}.charger-flow-node-copy{grid-column:2;display:flex;flex-direction:column;align-items:flex-start;text-align:left;gap:5px;padding:18px 0;min-height:100px;justify-content:center}
  .charger-flow-icon{width:60px;height:60px;border-radius:16px;position:relative;z-index:2}.charger-flow-icon svg{width:34px;height:34px}.charger-flow-kicker{font-size:10px}.charger-flow-value{font-size:19px}.charger-flow-status{font-size:13px;line-height:1.45}.charger-flow-sub{max-width:none;font-size:12px;line-height:1.5}.charger-flow-bar{width:88px}
  .charger-flow-link{grid-column:1;grid-row:auto;height:52px;width:60px;justify-self:center;display:block;min-width:0;max-width:none;transform:none}.charger-flow-line{position:absolute;left:50%;top:-4px;bottom:-4px;width:6px;height:auto;transform:translateX(-50%)}.charger-flow-line::before{background:linear-gradient(180deg,transparent,color-mix(in srgb,var(--blue) 50%,transparent),transparent)}.charger-flow-link::after{content:'↓';right:auto;left:50%;top:50%;transform:translate(-50%,-45%);font-size:22px}.charger-flow-pulse{left:50%;top:-24px;width:12px;height:28px;transform:translateX(-50%);background:linear-gradient(180deg,transparent,var(--green),#22c55e,var(--green),transparent);animation:charger-flow-top-bottom 1.8s ease-in-out infinite}.charger-flow-link.is-warning .charger-flow-pulse{background:linear-gradient(180deg,transparent,var(--amber),#f59e0b,var(--amber),transparent)}.charger-flow-link.is-limited .charger-flow-pulse{background:linear-gradient(180deg,transparent,var(--red),#ef4444,var(--red),transparent)}.charger-flow-link-label{display:none}
  .charger-flow-notes{padding:16px 18px}.charger-flow-notes ul{padding:12px 14px 0}.charger-flow-notes li{font-size:12px}.charger-flow-analysis{padding:16px 18px}
}

/* 🚗 Tire Size Calculator — .tire-visual-* 🚗 */
.tire-visual-result{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);overflow:hidden}
.tire-visual-hero{padding:26px 22px 22px;text-align:center;background:linear-gradient(160deg,var(--surface2),var(--surface));border-bottom:1px solid var(--border)}
.tire-visual-eyebrow{margin-bottom:6px;font-size:10px;font-weight:950;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.tire-visual-size{margin-top:4px;font-size:30px;font-weight:950;letter-spacing:-.03em;color:var(--text)}
.tire-visual-diam{margin-top:10px;font-size:44px;font-weight:950;letter-spacing:-.045em;color:var(--text);line-height:1}
.tire-visual-diam small{display:block;margin-top:6px;font-size:13px;font-weight:750;letter-spacing:.02em;color:var(--muted)}
.tire-visual-diagram{padding:28px 22px 24px;background:linear-gradient(180deg,var(--surface),var(--surface2));border-bottom:1px solid var(--border)}
.tire-visual-svg-wrap{display:flex;justify-content:center;align-items:center}
.tire-visual-svg-wrap svg{overflow:visible;max-width:100%}
.tire-visual-measurements{padding:0 22px 20px;background:var(--surface2);border-bottom:1px solid var(--border)}
.tire-visual-meas-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border)}
.tire-visual-meas-cell{background:var(--surface);padding:16px 18px;display:flex;flex-direction:column;gap:4px}
.tire-visual-meas-label{font-size:10px;font-weight:950;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.tire-visual-meas-value{font-size:22px;font-weight:950;letter-spacing:-.025em;color:var(--text);line-height:1}
.tire-visual-meas-value small{font-size:.55em;color:var(--muted);font-weight:750}
.tire-visual-meas-sub{font-size:11px;color:var(--muted);line-height:1.4}
.tire-visual-section{padding:18px 22px;border-bottom:1px solid var(--border)}
.tire-visual-section:last-child{border-bottom:0}
.tire-visual-section-title{padding-bottom:10px;font-size:11px;font-weight:950;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);border-bottom:1px dashed var(--border);margin-bottom:14px}
.tire-visual-proportions{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.tire-visual-prop-item{text-align:center;padding:14px 8px;border-radius:14px;background:var(--surface2);border:1px solid var(--border)}
.tire-visual-prop-value{font-size:20px;font-weight:950;color:var(--text);letter-spacing:-.02em}
.tire-visual-prop-label{font-size:10px;font-weight:750;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-top:4px}
.tire-visual-actions{margin-top:18px;display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.tire-visual-actions a,.tire-visual-actions button{padding:10px 20px;border-radius:999px;font-size:13px;font-weight:850;border:none;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:6px}
.tire-visual-compare-btn{background:linear-gradient(135deg,var(--blue),color-mix(in srgb,var(--blue) 80%,black));color:#fff}
.tire-visual-print-btn{background:var(--surface2);border:1px solid var(--border) !important;color:var(--text)}
@keyframes tire-visual-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@media (max-width:700px){
  .tire-visual-hero{padding:22px 18px 20px}.tire-visual-size{font-size:24px}.tire-visual-diam{font-size:36px}
  .tire-visual-diagram{padding:22px 16px 20px}
  .tire-visual-meas-grid{grid-template-columns:1fr}
  .tire-visual-proportions{grid-template-columns:repeat(2,1fr)}
  .tire-visual-section{padding:16px 18px}
}

/* 🚗 OBD-II Diagnostic Dashboard — .obd-visual-* 🚗 */
.obd-visual-result{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);overflow:hidden}
.obd-visual-hero{padding:24px 22px 20px;background:linear-gradient(160deg,var(--surface2),var(--surface));border-bottom:1px solid var(--border);text-align:center}
.obd-visual-code{margin-bottom:4px;font-size:11px;font-weight:950;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.obd-visual-name{margin-top:2px;font-size:20px;font-weight:950;letter-spacing:-.02em;color:var(--text)}
.obd-visual-severity{margin-top:12px;display:inline-flex;align-items:center;gap:8px;padding:6px 16px;border-radius:999px;font-size:12px;font-weight:950;letter-spacing:.05em;text-transform:uppercase;border:1.5px solid currentColor}
.obd-visual-cat{margin-top:10px;font-size:11px;font-weight:750;color:var(--muted);letter-spacing:.04em}
.obd-visual-section{padding:18px 22px;border-bottom:1px solid var(--border)}
.obd-visual-section:last-child{border-bottom:0}
.obd-visual-section-title{padding-bottom:8px;font-size:11px;font-weight:950;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);border-bottom:1px dashed var(--border);margin-bottom:12px}
.obd-visual-drive-badge{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:999px;font-size:13px;font-weight:850;border:1.5px solid currentColor;margin-bottom:10px}
.obd-visual-cause-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
.obd-visual-cause-item{padding:14px 16px;background:var(--surface2);border-radius:14px;border:1px solid var(--border);font-size:13px;line-height:1.6;color:var(--text)}
.obd-visual-tip-card{padding:14px 18px;background:color-mix(in srgb,var(--blue),transparent 92%);border-radius:14px;border:1px solid color-mix(in srgb,var(--blue),transparent 70%);border-left:3px solid var(--blue);margin-bottom:10px}
.obd-visual-tip-card:last-child{margin-bottom:0}
.obd-visual-tip-label{font-size:10px;font-weight:950;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);margin-bottom:6px}
.obd-visual-tip-text{font-size:13px;line-height:1.6;color:var(--text)}
.obd-visual-rel-codes{display:flex;flex-wrap:wrap;gap:8px}
.obd-visual-rel-code{padding:6px 14px;border-radius:999px;background:linear-gradient(135deg,var(--blue),color-mix(in srgb,var(--blue) 80%,black));color:#fff;font-size:13px;font-weight:850;text-decoration:none;transition:transform .15s}
.obd-visual-rel-code:hover{transform:translateY(-1px)}
@keyframes obd-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@media (max-width:700px){
  .obd-visual-hero{padding:22px 18px 20px}.obd-visual-name{font-size:18px}.obd-visual-section{padding:16px 18px}.obd-visual-cause-grid{grid-template-columns:1fr}
}

/* 🚨 Product Recall Cards — .recall-visual-* 🚨 */
.recall-visual-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);overflow:hidden;margin-bottom:20px}
.recall-visual-badge{margin:18px 22px 0;display:inline-flex;align-items:center;gap:8px;padding:6px 16px;border-radius:999px;background:color-mix(in srgb,var(--red),transparent 88%);color:var(--red);font-size:11px;font-weight:950;letter-spacing:.12em;text-transform:uppercase;border:1.5px solid var(--red)}
.recall-visual-hero{padding:14px 22px 20px;background:linear-gradient(160deg,var(--surface2),var(--surface));border-bottom:1px solid var(--border);text-align:center}
.recall-visual-eyebrow{margin-bottom:6px;font-size:10px;font-weight:950;letter-spacing:.18em;text-transform:uppercase;color:var(--red)}
.recall-visual-name{margin-top:4px;font-size:20px;font-weight:950;letter-spacing:-.02em;color:var(--text);line-height:1.3}
.recall-visual-brand-badge{margin-top:12px;display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:999px;background:color-mix(in srgb,var(--amber),transparent 85%);color:var(--amber);font-size:12px;font-weight:850;border:1.5px solid var(--amber)}
.recall-visual-date{margin-top:10px;font-size:11px;font-weight:750;color:var(--muted);letter-spacing:.04em}
.recall-visual-section{padding:18px 22px;border-bottom:1px solid var(--border)}
.recall-visual-section:last-of-type{border-bottom:0}
.recall-visual-section-title{padding-bottom:8px;font-size:11px;font-weight:950;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);border-bottom:1px dashed var(--border);margin-bottom:12px}
.recall-visual-hazard-card{padding:14px 18px;background:color-mix(in srgb,var(--red),transparent 91%);border-radius:14px;border:1px solid color-mix(in srgb,var(--red),transparent 70%);border-left:3px solid var(--red);font-size:13px;line-height:1.6;color:var(--text)}
.recall-visual-remedy-card{padding:14px 18px;background:color-mix(in srgb,var(--green),transparent 93%);border-radius:14px;border:1px solid color-mix(in srgb,var(--green),transparent 70%);border-left:3px solid var(--green);font-size:13px;line-height:1.6;color:var(--text)}
.recall-visual-units{margin-top:8px;font-size:22px;font-weight:950;color:var(--text);letter-spacing:-.02em}
.recall-visual-cta-wrap{padding:18px 22px 22px}
.recall-visual-cta{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;border-radius:999px;background:linear-gradient(135deg,var(--blue),color-mix(in srgb,var(--blue) 80%,black));color:#fff;font-size:13px;font-weight:850;text-decoration:none;transition:transform .15s}
.recall-visual-cta:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
@keyframes recall-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@media (max-width:700px){
  .recall-visual-hero{padding:22px 18px 20px}.recall-visual-name{font-size:18px}.recall-visual-section{padding:16px 18px}.recall-visual-cta-wrap{padding:16px 18px 20px}
}

/* 🚗 VIN Decoder — .vin-visual-* 🚗 */
.vin-visual-result{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);overflow:hidden}
.vin-visual-hero{padding:24px 22px 20px;background:linear-gradient(160deg,var(--surface2),var(--surface));border-bottom:1px solid var(--border);text-align:center}
.vin-visual-eyebrow{margin-bottom:4px;font-size:10px;font-weight:950;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.vin-visual-code{margin-top:6px;font-size:20px;font-weight:950;letter-spacing:-.02em;color:var(--text)}
.vin-visual-vin{margin-top:8px;font-size:15px;font-weight:850;letter-spacing:.12em;font-family:monospace;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 16px;display:inline-block;color:var(--text)}
.vin-visual-identity{margin-top:12px;font-size:16px;font-weight:850;color:var(--blue);letter-spacing:-.01em}
.vin-visual-section{padding:18px 22px;border-bottom:1px solid var(--border)}
.vin-visual-section:last-of-type{border-bottom:0}
.vin-visual-section-title{padding-bottom:8px;font-size:11px;font-weight:950;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);border-bottom:1px dashed var(--border);margin-bottom:12px}
.vin-visual-spec-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border)}
.vin-visual-spec-item{background:var(--surface);padding:12px 16px;display:flex;flex-direction:column;gap:3px}
.vin-visual-spec-label{font-size:10px;font-weight:950;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.vin-visual-spec-value{font-size:14px;font-weight:800;color:var(--text)}
.vin-visual-actions{display:flex;flex-wrap:wrap;gap:10px}
.vin-visual-cta{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:999px;background:var(--surface2);border:1.5px solid var(--border);color:var(--text);font-size:13px;font-weight:850;text-decoration:none;cursor:pointer;transition:transform .15s}
.vin-visual-cta-primary{background:linear-gradient(135deg,var(--blue),color-mix(in srgb,var(--blue) 80%,black));color:#fff;border-color:transparent}
.vin-visual-cta:hover{transform:translateY(-1px)}
.vin-visual-disclaimer{margin:18px 22px 22px;padding:12px 16px;background:color-mix(in srgb,var(--amber),transparent 88%);border:1px solid color-mix(in srgb,var(--amber),transparent 60%);border-radius:12px;font-size:13px;color:var(--text);line-height:1.5}
.vin-visual-disclaimer strong{color:var(--amber)}
@keyframes vin-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@media (max-width:700px){
  .vin-visual-hero{padding:22px 18px 20px}.vin-visual-vin{font-size:13px;letter-spacing:.08em}.vin-visual-section{padding:16px 18px}.vin-visual-spec-grid{grid-template-columns:1fr}.vin-visual-actions{flex-direction:column}
}
