/* ==========================================================================
   VIN Reports — Premium UI (light, executive)
   ========================================================================== */

/* ───── CSS CUSTOM PROPERTIES ───── */
:root{
  --clr-navy-900:#0b2540;
  --clr-navy-800:#123559;
  --clr-navy-700:#1c4875;

  --clr-yellow-500:#ffd12c;
  --clr-yellow-400:#ffda57;

  --clr-slate-50:#f8fafc;
  --clr-slate-100:#f1f5f9;
  --clr-slate-200:#e2e8f0;
  --clr-slate-300:#cbd5e1;
  --clr-slate-500:#64748b;
  --clr-slate-700:#334155;

  --clr-white:#ffffff;

  --ff-base:'Inter', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  --radius-sm:10px;
  --radius-md:14px;
  --radius-lg:18px;

  --shadow-sm:0 1px 2px rgba(2,6,23,.06);
  --shadow-md:0 12px 30px rgba(2,6,23,.10);
  --shadow-lg:0 18px 55px rgba(2,6,23,.14);

  --transition:all .18s cubic-bezier(.2,0,.2,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--ff-base);
  background:var(--clr-slate-50);
  color:var(--clr-navy-900);
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
button, input, select, textarea { font: inherit; color: inherit; }
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
h1,h2,h3{line-height:1.15;margin:0 0 .6rem 0}
p{margin:0 0 1rem 0}
ul{margin:0;padding-left:1.2rem}
:focus-visible{outline:3px solid var(--clr-yellow-400);outline-offset:3px;border-radius:6px}

/* ───── LAYOUT ───── */
.wrapper{width:min(1120px,92vw);margin:0 auto}
.section{padding:72px 0}
.section--tight{padding:48px 0}
.grid{display:grid;gap:20px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
@media (max-width: 920px){.grid-2,.grid-3{grid-template-columns:1fr}}

/* ───── COMPONENTS ───── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.9rem 1.1rem;border-radius:12px;border:1px solid transparent;
  font-weight:600;cursor:pointer;transition:var(--transition);
  box-shadow:var(--shadow-sm);
  user-select:none;
}
.btn-sm{padding:.62rem .9rem;border-radius:12px;font-size:.95rem}
.btn:disabled{opacity:.55;cursor:not-allowed}
.btn-primary{background:var(--clr-navy-900);color:var(--clr-white)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);background:var(--clr-navy-800)}
.btn-accent{background:var(--clr-yellow-500);color:var(--clr-navy-900)}
.btn-accent:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);background:var(--clr-yellow-400)}
.btn-ghost{background:transparent;border-color:var(--clr-slate-300);color:var(--clr-navy-900);box-shadow:none}
.btn-ghost:hover{background:var(--clr-slate-100)}

.card{
  background:var(--clr-white);
  border:1px solid var(--clr-slate-200);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  padding:22px;
}
.card--elevated{box-shadow:var(--shadow-md)}
.badge{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.28rem .65rem;border-radius:999px;
  font-size:.78rem;font-weight:700;letter-spacing:.02em;
  background:var(--clr-slate-100);
  border:1px solid var(--clr-slate-200);
  color:var(--clr-slate-700);
  max-width:100%;
  white-space:normal;
}
.badge--gold{background:rgba(255,209,44,.22);border-color:rgba(255,209,44,.5);color:var(--clr-navy-900)}

/* Link-styled button (used sparingly for secondary actions in dense areas). */
.btn.btn-link{
  background:transparent;
  border:none;
  box-shadow:none;
  padding:.25rem 0;
  color:var(--clr-slate-700);
  text-decoration:underline;
}
.btn.btn-link:hover{background:transparent;color:var(--clr-navy-900);transform:none;box-shadow:none}

.kpi{
  display:flex;flex-direction:column;gap:.25rem;
}
.kpi__label{color:var(--clr-slate-500);font-weight:600;font-size:.85rem}
.kpi__value{font-size:1.6rem;font-weight:800;color:var(--clr-navy-900)}

.input{
  width:100%;
  padding:.9rem 1rem;
  border-radius:12px;
  border:1px solid var(--clr-slate-300);
  background:var(--clr-white);
  font-size:1rem;
  transition:var(--transition);
}
.input:focus{border-color:rgba(11,37,64,.45);box-shadow:0 0 0 4px rgba(11,37,64,.08);outline:none}
.label{display:block;font-weight:700;margin:.85rem 0 .45rem 0}
.help{color:var(--clr-slate-500);font-size:.9rem}

/* ───── HEADER ───── */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(248,250,252,.86);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--clr-slate-200);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 0;
}
.brand{
  display:flex;align-items:center;gap:.65rem;
  font-weight:900;letter-spacing:.02em;
}
.brand-mark{
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,var(--clr-navy-900),var(--clr-navy-700));
  box-shadow:var(--shadow-sm);
}
.brand-name{font-size:1.05rem}
.nav{
  display:flex;align-items:center;gap:18px;
}
.nav a{color:var(--clr-slate-700);font-weight:700}
.nav a:hover{color:var(--clr-navy-900)}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-toggle{display:none}

@media (max-width: 920px){
  .nav{display:none}
  .nav-toggle{display:inline-flex}
}

/* ───── HERO ───── */
.hero{
  background:
    radial-gradient(900px 450px at 20% 10%, rgba(255,209,44,.24), transparent 55%),
    radial-gradient(900px 450px at 90% 20%, rgba(28,72,117,.10), transparent 55%),
    linear-gradient(180deg, var(--clr-white), var(--clr-slate-50));
  padding:72px 0 56px;
}
.hero-grid{
  display:grid;gap:26px;align-items:center;
  grid-template-columns: 1.2fr .8fr;
}
.hero-copy{min-width:0;display:flex;flex-direction:column;align-items:flex-start}
.hero-badge{margin-bottom:10px;justify-content:flex-start;white-space:nowrap;max-width:fit-content}

@media (max-width: 920px){.hero-grid{grid-template-columns:1fr;align-items:start}}

/* Screen-reader only label utility. */
.sr-only{
  position:absolute !important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}

/* Mobile VIN bar (index hero) */
.hero-vinbar{display:none;margin:12px 0 4px 0;width:100%}
.vinbar{display:flex;gap:10px;align-items:stretch;width:100%}
.vinbar__input{flex:1}
.vinbar__btn{white-space:nowrap}
.vinbar__link{margin-top:10px;align-self:flex-start}
.vinbar__link.btn-ghost{box-shadow:none}

.hero h1{font-size:clamp(2.2rem,5vw,3.2rem);letter-spacing:-.02em}
.hero p{font-size:1.05rem;color:var(--clr-slate-700);max-width:60ch}
.hero-list{margin:16px 0 0 0;color:var(--clr-slate-700)}
.hero-list li{margin:.45rem 0}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.hero-card{padding:22px}
.hero-card h3{margin:0 0 .35rem 0}
.trustbar{display:flex;gap:14px;flex-wrap:wrap;margin-top:18px}
.trustitem{display:flex;align-items:center;gap:8px;color:var(--clr-slate-700);font-weight:650;font-size:.92rem}
.icon{
  width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center
}
.icon svg{width:18px;height:18px}

/* ───── PRICING ───── */
.pricing-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:20px}
.pricing-head h2{font-size:2rem}
.pricing-sub{color:var(--clr-slate-700);max-width:60ch}
.pricing-sub--center{margin-left:auto;margin-right:auto;text-align:center}
.pricing-grid{display:grid;gap:18px;grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width: 1100px){.pricing-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 650px){.pricing-grid{grid-template-columns:1fr}}

.plan{
  position:relative;
  padding:22px;
  border-radius:var(--radius-lg);
  background:var(--clr-white);
  border:1px solid var(--clr-slate-200);
  box-shadow:var(--shadow-sm);
  transition:var(--transition);
  overflow:hidden;
}
.plan:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.plan--popular{border-color:rgba(255,209,44,.7);box-shadow:var(--shadow-md)}


.plan--hot{
  border: 2px solid #ff6b00;
  box-shadow: 0 0 0 4px rgba(255, 107, 0, 0.15), 0 18px 40px rgba(0,0,0,0.25);
}

.badge--sale{
  background: #ff6b00;
  color: #151515;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
  box-shadow: 0 6px 18px rgba(255, 107, 0, 0.35);
}

.price-old{
  display: inline-block;
  margin-right: 10px;
  font-size: 1.05rem;
  color: var(--clr-slate-500);
  text-decoration: line-through;
  font-weight: 800;
}

.plan-save{
  margin-top: 6px;
  font-size: 0.95rem;
  color: var(--clr-slate-500);
}

.plan--hot .plan-save{
  color: #ff6b00;
  font-weight: 800;
}
.plan--popular::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(255,209,44,.16), transparent 40%);
  pointer-events:none;
}
.plan-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.plan-title{font-weight:900}
.plan-price{font-size:1.95rem;font-weight:950;letter-spacing:-.02em}
.plan-price span{font-size:.95rem;font-weight:800;color:var(--clr-slate-500)}
.plan-metric{color:var(--clr-slate-700);font-weight:700;margin:.45rem 0 .75rem}
.plan-list{color:var(--clr-slate-700);padding-left:1.2rem}
.plan-list li{margin:.35rem 0}
.plan-actions{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}

/* ───── STEPS / FAQ ───── */
.steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
@media (max-width: 920px){.steps{grid-template-columns:1fr}}
.step h3{margin:0 0 .35rem 0}
.step p{color:var(--clr-slate-700)}
.faq{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width: 920px){.faq{grid-template-columns:1fr}}
.faq details{border:1px solid var(--clr-slate-200);border-radius:14px;padding:16px;background:var(--clr-white);box-shadow:var(--shadow-sm)}
.faq summary{cursor:pointer;font-weight:900}
.faq p{color:var(--clr-slate-700);margin-top:.7rem}

/* ───── AUTH / DASHBOARD / CHECKOUT ───── */
.auth-shell{min-height:calc(100vh - 70px);display:grid;place-items:center;padding:40px 0}
.auth-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;align-items:stretch}
@media (max-width: 920px){.auth-grid{grid-template-columns:1fr}}
.side-panel{
  background:linear-gradient(135deg,var(--clr-navy-900),var(--clr-navy-700));
  color:var(--clr-white);
  border-radius:var(--radius-lg);
  padding:22px;
  box-shadow:var(--shadow-md);
}
.side-panel p{color:rgba(255,255,255,.82)}
.side-panel ul{color:rgba(255,255,255,.86)}
.form-actions{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-top:14px}

.table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  overflow:hidden;
  border:1px solid var(--clr-slate-200);
  border-radius:14px;
  background:var(--clr-white);
  box-shadow:var(--shadow-sm);
}
.table th,.table td{padding:12px 12px;border-bottom:1px solid var(--clr-slate-200);text-align:left;font-size:.92rem}
.table th{background:var(--clr-slate-100);font-weight:900;color:var(--clr-slate-700)}
.table tr:last-child td{border-bottom:none}
.mono{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}

/* ───── FOOTER ───── */
.footer{
  padding:26px 0;
  color:var(--clr-slate-500);
  border-top:1px solid var(--clr-slate-200);
  background:var(--clr-white);
}
.footer-grid{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.footer a{color:var(--clr-slate-700);font-weight:800}


/* ───── APP SHELL ───── */
.app-shell{
  display:grid;
  grid-template-columns: 280px 1fr;
  gap:18px;
  align-items:start;
}
@media (max-width: 980px){
  .app-shell{grid-template-columns:1fr}
}

.sidebar{
  position:sticky;
  top:86px; /* below header */
  align-self:start;
  background:var(--clr-white);
  border:1px solid var(--clr-slate-200);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
@media (max-width: 980px){
  .sidebar{position:relative;top:auto}
}

.sidebar-head{
  padding:18px 18px 14px;
  border-bottom:1px solid var(--clr-slate-200);
  background:linear-gradient(180deg, var(--clr-white), var(--clr-slate-50));
}
.sidebar-head .who{display:flex;flex-direction:column;gap:2px}
.sidebar-head .who .email{font-weight:900}
.sidebar-head .who .meta{color:var(--clr-slate-500);font-weight:700;font-size:.9rem}

.sidebar-entitlements{
  margin-top:12px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.pill.pill--sidebar{
  width:auto;
  justify-content:flex-start;
  padding:6px 10px;
  font-size:.88rem;
  font-weight:850;
  border-radius:999px;
  background:rgba(255,255,255,.75);
}

.side-nav{display:flex;flex-direction:column;padding:10px}
.side-link{
  display:flex;align-items:center;gap:10px;
  padding:10px 10px;
  border-radius:12px;
  font-weight:850;
  color:var(--clr-slate-700);
  cursor:pointer;
  transition:var(--transition);
}
.side-link:hover{background:var(--clr-slate-100);color:var(--clr-navy-900)}
.side-link[aria-current="page"]{
  background:rgba(255,209,44,.20);
  border:1px solid rgba(255,209,44,.45);
  color:var(--clr-navy-900);
}
.side-link .dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--clr-slate-300);
}
.side-link[aria-current="page"] .dot{background:var(--clr-yellow-500)}
.side-foot{padding:12px 18px;border-top:1px solid var(--clr-slate-200);color:var(--clr-slate-500);font-weight:650;font-size:.92rem}

.page-card{
  background:var(--clr-white);
  border:1px solid var(--clr-slate-200);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  padding:22px;
}

.toast{
  border:1px solid var(--clr-slate-200);
  background:var(--clr-slate-50);
  border-radius:14px;
  padding:12px 14px;
  color:var(--clr-slate-700);
  font-weight:650;
}
.toast--good{
  border-color:rgba(28,72,117,.25);
  background:rgba(28,72,117,.06);
}
.toast--warn{
  border-color:rgba(255,209,44,.6);
  background:rgba(255,209,44,.18);
}

.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid var(--clr-slate-200);
  background:var(--clr-white);
  font-weight:800;
  color:var(--clr-slate-700);
}

.mini-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
@media (max-width: 980px){
  .mini-grid{grid-template-columns:1fr}
}

.inline-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}

.pager{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px}
.pager .pager-text{flex:1;text-align:center}


/* ───── DANGER BUTTON ───── */
.btn-danger{
  background:#b91c1c;
  color:var(--clr-white);
}
.btn-danger:hover{
  transform:translateY(-1px);
  box-shadow:var(--shadow-md);
  background:#991b1b;
}

/* ───── SELECTABLE OPTIONS ───── */
.option-card{
  cursor:pointer;
}
.option-card[aria-disabled="true"]{
  cursor:not-allowed;
  opacity:.55;
}
.option-card[aria-disabled="true"]:hover{
  background:inherit;
  box-shadow:none;
  transform:none;
}
.option-card[aria-disabled="true"]::before{display:none !important;}
.option-card[aria-selected="true"]{
  border-color:rgba(255,209,44,.75);
  box-shadow:var(--shadow-md);
}
.option-card[aria-selected="true"]::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(255,209,44,.16), transparent 45%);
  pointer-events:none;
}
.action-bar{
  position:sticky;
  bottom:0;
  margin-top:16px;
  padding:12px;
  border-radius:16px;
  border:1px solid var(--clr-slate-200);
  background:rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  box-shadow:var(--shadow-md);
  display:grid;
  grid-template-columns: 1fr auto;
  align-items:center;
  gap:12px;
}
.action-bar .help{min-width:0}
.action-bar__actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
}


/* ───── PLAN FLEX LAYOUT ───── */
.plan{display:flex;flex-direction:column}
.plan-actions{margin-top:auto;padding-top:14px}


/* ───── ORDER REVIEW ───── */
.order-grid{
  display:grid;
  grid-template-columns: 1.25fr .9fr;
  gap:18px;
  align-items:start;
}
@media (max-width: 980px){
  .order-grid{grid-template-columns:1fr}
}
.order-left.card, .order-right.card{padding:22px}
.order-vehicle{
  margin-top:14px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px;
  align-items:start;
}
@media (max-width: 980px){
  .order-vehicle{grid-template-columns:1fr}
}
.order-vehicle__img{
  border:1px solid var(--clr-slate-200);
  border-radius:16px;
  background:var(--clr-slate-50);
  height:220px;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:var(--shadow-sm);
}
.order-vehicle__imgInner{
  color:var(--clr-slate-500);
  font-weight:800;
}
.order-vehicle__title{
  font-weight:950;
  letter-spacing:-.02em;
  font-size:1.15rem;
  margin-bottom:10px;
}
.order-vehicle__rows{
  display:grid;
  gap:8px;
}
.order-vehicle__rows .k{
  display:inline-block;
  width:72px;
  color:var(--clr-slate-500);
  font-weight:800;
}
.order-vehicle__rows .v{
  color:var(--clr-navy-900);
  font-weight:900;
}
.order-lines{
  margin-top:18px;
  border-top:1px solid var(--clr-slate-200);
  padding-top:12px;
}
.order-lines .row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 0;
  border-bottom:1px solid var(--clr-slate-100);
  font-weight:750;
}
.order-lines .row.total{
  border-bottom:none;
  font-weight:950;
  font-size:1.05rem;
}

.plan{display:flex;flex-direction:column}
.plan-actions{margin-top:auto}


/* ───── ADMIN PANEL ───── */
.admin-shell{display:grid;grid-template-columns:280px 1fr;gap:18px;align-items:start}
@media (max-width: 980px){.admin-shell{grid-template-columns:1fr}}
.admin-main{min-width:0}

.table-wrap{overflow:auto;border:1px solid var(--clr-slate-200);border-radius:14px;background:var(--clr-white)}
.table{width:100%;border-collapse:separate;border-spacing:0}
.table th,.table td{padding:10px 12px;border-bottom:1px solid var(--clr-slate-200);text-align:left;vertical-align:top}
.table th{position:sticky;top:0;background:var(--clr-white);z-index:1;font-size:.9rem;color:var(--clr-slate-500);font-weight:900}
.table tr:hover td{background:rgba(255,209,44,.08)}
.table .mono{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}

.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:space-between;margin-bottom:12px}
.toolbar-left{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.toolbar .input{max-width:360px}
.pagination{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.kbd{border:1px solid var(--clr-slate-200);border-radius:8px;padding:4px 8px;background:var(--clr-slate-50);font-weight:850;color:var(--clr-slate-600)}

.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.35);display:none;align-items:center;justify-content:center;padding:18px;z-index:50}
.modal{width:min(920px, 100%);max-height:88vh;overflow:auto;background:var(--clr-white);border-radius:18px;border:1px solid var(--clr-slate-200);box-shadow:var(--shadow-lg)}
.modal-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--clr-slate-200)}
.modal-body{padding:16px 18px}
.modal-foot{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;padding:14px 18px;border-top:1px solid var(--clr-slate-200)}
.tag{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid var(--clr-slate-200);background:var(--clr-slate-50);font-weight:850;color:var(--clr-slate-700)}
.tag--good{border-color:rgba(28,72,117,.25);background:rgba(28,72,117,.06)}
.tag--success{border-color:rgba(22,163,74,.35);background:rgba(22,163,74,.10);color:rgba(21,128,61,1)}
.tag--warn{border-color:rgba(255,209,44,.55);background:rgba(255,209,44,.18)}
.tag--bad{border-color:rgba(185,28,28,.35);background:rgba(185,28,28,.08);color:rgba(185,28,28,1)}
/* ───── AUTH NAV VISIBILITY (prevents flicker) ───── */
[data-auth="in"],
[data-auth="admin"]{
  display:none;
}
html.is-authed [data-auth="in"]{
  display:inline-flex;
}
html.is-admin [data-auth="admin"]{
  display:inline-flex;
}
html.is-authed [data-auth="out"]{
  display:none;
}

/* Sign out should NOT be in the top nav; only inside Dashboard > Account tab */
#logoutBtn,
#logoutBtnMobile{
  display:none !important;
}
/* ───── SELECTABLE OPTIONS ───── */
.option-card{
  cursor:pointer;
}
.option-card[aria-disabled="true"]{
  cursor:not-allowed;
  opacity:.55;
}
.option-card[aria-disabled="true"]:hover{
  background:inherit;
  box-shadow:none;
  transform:none;
}
.option-card[aria-disabled="true"]::before{display:none !important;}
.option-card[aria-selected="true"]{
  border-color:#0f172a;
  box-shadow:0 10px 28px rgba(15,23,42,.22);
}
.option-card[aria-selected="true"]::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(255,209,44,.16), transparent 45%);
  pointer-events:none;
}
.option-card[aria-selected="true"]::after{
  content:"Selected";
  position:absolute;
  top:10px;
  right:10px;
  font-size:12px;
  font-weight:800;
  background:#0f172a;
  color:#fff;
  padding:4px 8px;
  border-radius:999px;
  letter-spacing:.01em;
}
.action-bar{
  position:sticky;
  bottom:0;
  margin-top:16px;
  padding:12px;
  border-radius:16px;
  border:1px solid var(--clr-slate-200);
  background:rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  box-shadow:var(--shadow-md);
  display:grid;
  grid-template-columns: 1fr auto;
  align-items:center;
  gap:12px;
}
/* Ensure the 2-column account section stretches both cards equally */
.account-grid{
  align-items: stretch;
}

/* Make cards behave like equal-height columns */
.account-card{
  display:flex;
  flex-direction:column;
  height:100%;
}

/* Form is the vertical layout driver */
.account-form{
  display:flex;
  flex-direction:column;
  gap:12px;
  flex:1;
}

/* Button row pinned to bottom */
.account-form .inline-actions{
  margin-top:auto;
}

/* Reserve equal space for status text so cards stay aligned */
.account-out{
  min-height: 20px;    /* adjust if your help text wraps */
  margin-top:10px;
}
.input:disabled{
  background: var(--clr-slate-100);
  color: var(--clr-slate-500);
  cursor: not-allowed;
}
.account-intro{
  min-height: 40px;     /* ~2 lines; adjust to 44px if your font renders taller */
  margin-bottom: 12px;
}
/* Reload pricing cards: increase breathing room and hierarchy */
.pricing-grid{
  gap: 18px;                 /* more space between cards */
}

.plan.option-card{
  padding: 18px 18px 20px;   /* more internal padding */
  min-height: 220px;         /* consistent height, less cramped */
}

.plan .plan-top{
  margin-bottom: 14px;       /* separate title/badge from price */
}

.plan .plan-title{
  line-height: 1.2;
  font-size: 18px;
}

.plan .badge{
  padding: 7px 12px;
  border-radius: 999px;
}

.plan .plan-price{
  margin-top: 2px;
  margin-bottom: 12px;
  line-height: 1.05;
}

.plan .plan-price span{
  display: inline-block;
  margin-left: 8px;
  font-size: 14px;
  opacity: .75;
}

.plan .plan-metric{
  margin-top: 10px;
  line-height: 1.35;
}

/* Prevent “Selected” pill from crowding the badge area */
.option-card[aria-selected="true"]::after{
  top: 12px;
  right: 12px;
}
#rvVin[readonly]{
  background: var(--clr-slate-100);
  color: var(--clr-slate-700);
  cursor: default;
}
/* =========================
   RunVIN — PayPal post-payment flow
========================= */

.input[readonly]{
  background: var(--clr-slate-100);
  border-color: var(--clr-slate-300);
  color: var(--clr-slate-700);
}


.rv-pay-state{
  padding:14px 0 0;
  text-align:center;
}

.rv-pay-icon{
  width:44px;
  height:44px;
  margin:0 auto 10px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(28, 72, 117, .10);
  color: var(--clr-navy-900);
}

.rv-pay-icon--fail{
  background: rgba(255, 209, 44, .22);
}

.rv-pay-icon svg{
  width:22px;
  height:22px;
}

.rv-pay-title{
  font-weight:900;
  font-size:1.05rem;
}

.rv-receipt{
  border:1px solid var(--clr-slate-200);
  background: var(--clr-slate-50);
  border-radius: 14px;
  padding:10px 12px;
  text-align:left;
}

.rv-receipt-row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:6px 0;
  border-bottom:1px solid var(--clr-slate-200);
}

.rv-receipt-row:last-child{
  border-bottom:none;
}

.rv-prep{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}

.rv-spinner{
  width:16px;
  height:16px;
  border-radius:999px;
  border:2px solid var(--clr-slate-300);
  border-top-color: var(--clr-navy-900);
  animation: rvspin 0.8s linear infinite;
}

@keyframes rvspin{
  to { transform: rotate(360deg); }
}

/* =========================
   RunVIN accordion + unified result
========================= */

#rvVin[readonly]{
  background: var(--clr-slate-100);
  border-color: var(--clr-slate-300);
  color: var(--clr-slate-700);
  cursor: default;
}

.rv-acc{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:10px;
}

.rv-acc__item{
  border:1px solid var(--clr-slate-200);
  border-radius:16px;
  background: var(--clr-white);
  overflow:hidden;
}

.rv-acc__head{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 14px;
  background: var(--clr-white);
  border:none;
  cursor:pointer;
  text-align:left;
}

.rv-acc__title{
  font-weight:900;
}

.rv-acc__chev{
  transition: transform 0.18s ease;
  opacity:.8;
}

.rv-acc__item.is-open .rv-acc__chev{
  transform: rotate(180deg);
}

.rv-acc__panel{
  padding: 0 14px 14px;
}


/* Unified result visuals (reuse your existing checkout-like feel) */
.rv-pay-state{
  padding: 4px 0 0;
  text-align:center;
}

.rv-pay-icon{
  width:44px;
  height:44px;
  margin:0 auto 10px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(28, 72, 117, .10);
  color: var(--clr-navy-900);
}

.rv-pay-icon--fail{
  background: rgba(255, 209, 44, .22);
}

.rv-pay-icon svg{
  width:22px;
  height:22px;
}

.rv-pay-title{
  font-weight:900;
  font-size:1.05rem;
}

.rv-receipt{
  border:1px solid var(--clr-slate-200);
  background: var(--clr-slate-50);
  border-radius: 14px;
  padding:10px 12px;
  text-align:left;
}

.rv-receipt-row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:6px 0;
  border-bottom:1px solid var(--clr-slate-200);
}

.rv-receipt-row:last-child{
  border-bottom:none;
}

.rv-prep{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}

.rv-spinner{
  width:16px;
  height:16px;
  border-radius:999px;
  border:2px solid var(--clr-slate-300);
  border-top-color: var(--clr-navy-900);
  animation: rvspin 0.8s linear infinite;
}

@keyframes rvspin{
  to { transform: rotate(360deg); }
}


/* ───── MOBILE REFINEMENTS ───── */
@media (max-width: 520px){
  .wrapper{width:min(1120px,94vw)}
  .header-inner{padding:12px 0}

  .section{padding:46px 0}
  .hero{padding:44px 0 34px}

  /* Index hero: keep the VIN CTA above the fold. */
  .hero-vinbar{display:block}
  .hero-quick{display:none}
  .vinbar{flex-direction:column}
  .vinbar__btn{width:100%}
  /* Sample report: underlined link on mobile. */
  .vinbar__link{
    width:100%;
    justify-content:center;
    margin-top:10px;
    padding:0;
    background:transparent;
    border:none;
    box-shadow:none;
    color:var(--clr-slate-700);
    text-decoration:underline;
  }
  .vinbar__link:hover{background:transparent;color:var(--clr-navy-900);transform:none;box-shadow:none}
  .hero h1{font-size:clamp(1.9rem,6.2vw,2.35rem)}
  .hero p{font-size:1rem}
  .trustbar{display:none}

  /* Keep the top badge visually anchored and avoid odd wrapping that makes it look "floating". */
  .hero-badge{align-self:flex-start;white-space:nowrap;justify-content:flex-start;max-width:fit-content}

  .hero-note{display:none}

  .card{padding:16px}
  .page-card{padding:16px}
  .order-left.card, .order-right.card{padding:16px}
  .order-grid{gap:14px}
  .order-vehicle__img{height:190px}

  /* Secondary CTAs (Pricing / How it works): keep them as real buttons, centered, and pushed down a bit on mobile. */
  .hero-actions{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:10px;
    margin-top:20px;
    width:100%;
    max-width:420px;
    margin-left:auto;
    margin-right:auto;
  }
  .hero-actions .btn{
    width:100%;
    justify-content:center;
    padding:.78rem .95rem;
    border-radius:12px;
  }
  .inline-actions, .form-actions{flex-direction:column;align-items:stretch}
  .inline-actions .btn, .inline-actions a.btn, .form-actions .btn{width:100%}

  .action-bar{position:static}

  .table th,.table td{padding:10px 10px}
  .footer{padding:22px 0}
}

@media (max-width: 360px){
  /* Ultra-small screens: avoid a cramped 2-up CTA row in the hero. */
  .hero-actions{grid-template-columns:1fr}
}

/* ───── DASHBOARD RESPONSIVE: ACCOUNT + HISTORY TABLES ───── */
@media (max-width: 720px){
  /* Account tab */
  .account-top{grid-template-columns:1fr !important}
  .account-grid{grid-template-columns:1fr !important;gap:14px !important}
  .account-card{padding:16px}
  /* Prevent iOS zoom on focus */
  .account-form .input{font-size:16px}

  /* Reload action bar: keep primary action obvious on mobile */
  .action-bar{grid-template-columns:1fr}
  .action-bar__actions{width:100%;flex-direction:column;align-items:stretch;justify-content:flex-start}
  .action-bar__actions .btn, .action-bar__actions a.btn{width:100%}
  .action-bar__actions .btn-link{width:auto;align-self:flex-start}

  /* Stack tables into card rows */
  .table-wrap{overflow:visible;border:none;background:transparent}
  .table.table--stack{border-collapse:separate;border-spacing:0 10px;border:none;box-shadow:none;background:transparent;overflow:visible}
  .table--stack thead{display:none}
  .table--stack tbody{display:block}
  .table--stack tr{display:block;border:1px solid var(--clr-slate-200);border-radius:14px;background:var(--clr-white);padding:12px 12px;margin-bottom:12px}
  .table--stack td{display:block;border:none;padding:6px 0}
  .table--stack td::before{content:attr(data-label);display:block;font-size:.72rem;font-weight:900;color:var(--clr-slate-500);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}
  .table--stack tr:hover td{background:transparent}

  /* Pager (Activity & receipts) */
  .pager{flex-wrap:wrap;justify-content:stretch}
  .pager .pager-text{flex:1 1 100%;order:3;text-align:left}
  .pager .btn{flex:1 1 calc(50% - 10px)}

  /* Defensive wrapping for long IDs/strings in stacked tables */
  .table--stack td{overflow-wrap:anywhere}
}
