/* ===================================================================
   AutoClass demo — warm light theme (sand / paper / graphite / crimson).
   RTL-first, logical properties only. AA contrast. Reduced-motion aware.
   =================================================================== */

:root {
  --stone-50:  #f4f0e8;
  --stone-100: #e6ded2;
  --stone-200: #cfc2b4;
  --stone-500: #807365;

  --graphite:      #111318;
  --graphite-soft: #2e3439;
  --ink:    #171717;
  --muted:  #665f56;
  --muted-2:#807365;

  --line:        rgba(23,23,23,.14);
  --line-strong: rgba(23,23,23,.24);
  --paper:  rgba(255,255,255,.78);
  --card:   #ffffff;

  --red:      #bf1f2d;
  --red-deep: #8f1722;
  --red-tint: rgba(191,31,45,.10);
  --red-line: rgba(191,31,45,.30);

  --yellow:    #f6c700;
  --plate-ink: #0e0e0e;
  --il-blue:   #0038b8;

  --shadow-sm: 0 1px 2px rgba(46,43,41,.06), 0 2px 6px rgba(46,43,41,.05);
  --shadow-md: 0 2px 6px rgba(46,43,41,.06), 0 16px 30px -16px rgba(46,43,41,.22);
  --shadow-lg: 0 8px 24px -8px rgba(46,43,41,.18), 0 40px 70px -30px rgba(46,43,41,.30);

  --radius:    8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --maxw:      1180px;
  --ease:      cubic-bezier(.2,.7,.2,1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; font-size: 100%; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  margin: 0;
  background:
    linear-gradient(180deg, rgba(255,255,255,.82), rgba(230,222,210,.64) 44%, #f7f4ee 100%),
    var(--stone-50);
  background-attachment: fixed;
  color: var(--ink);
  font-family: "Assistant", "Noto Sans Hebrew", system-ui, sans-serif;
  font-size: 1.0625rem;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

h1, h2, h3 { font-family: "Rubik", "Assistant", system-ui, sans-serif; line-height: 1.12; margin: 0; color: var(--graphite); letter-spacing: -.01em; }
p { margin: 0; }

a { color: var(--red-deep); text-decoration-thickness: 2px; text-underline-offset: 3px; }
a:hover { color: var(--ink); }

.muted { color: var(--muted); }
.small { font-size: .9rem; }

a:focus-visible, button:focus-visible, input:focus-visible {
  outline: 3px solid var(--red); outline-offset: 3px; border-radius: 8px;
}

.skip {
  position: absolute; inset-inline-start: 16px; top: -120px;
  background: var(--red-deep); color: #fff;
  padding: 12px 18px; border-radius: 10px; font-weight: 800; z-index: 200;
  transition: top .2s var(--ease); text-decoration: none;
}
.skip:focus { top: 16px; }

.wrap { max-width: var(--maxw); margin-inline: auto; padding-inline: 22px; }
.visually-hidden { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; }

/* ---------- Header ---------- */
header.site {
  position: sticky; top: 0; z-index: 60;
  background: rgba(244,240,232,.82);
  backdrop-filter: blur(12px) saturate(1.1);
  border-block-end: 1px solid var(--line);
}
.bar { display: flex; align-items: center; gap: 16px; height: 72px; }
.brand { display: flex; align-items: center; text-decoration: none; }
.logo-badge { display:inline-flex; align-items:center; background:#fff; padding:7px 12px; border-radius:12px; box-shadow: var(--shadow-sm); }
.logo-badge img { display:block; height:40px; width:auto; }
nav.primary { margin-inline-start: auto; display: flex; gap: 2px; }
nav.primary a {
  color: var(--muted); text-decoration: none; font-weight: 600; font-size: .98rem;
  padding: 9px 13px; border-radius: 9px;
}
nav.primary a:hover { color: var(--ink); background: rgba(23,23,23,.05); }
.bar-actions { display: flex; align-items: center; gap: 10px; }
.call-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: #fff; color: var(--ink); border: 1px solid var(--line-strong);
  font-weight: 700; text-decoration: none; padding: 10px 15px; border-radius: 11px; white-space: nowrap;
  box-shadow: var(--shadow-sm);
}
.call-btn:hover { border-color: var(--red); color: var(--red-deep); }
.cart-btn {
  position: relative; display: grid; place-items: center;
  width: 46px; height: 46px; border-radius: 11px;
  background: #fff; border: 1px solid var(--line-strong); color: var(--ink); cursor: pointer; box-shadow: var(--shadow-sm);
}
.cart-btn:hover { border-color: var(--red); color: var(--red-deep); }
.cart-count {
  position: absolute; inset-block-start: -6px; inset-inline-start: -6px;
  min-width: 21px; height: 21px; padding: 0 5px; border-radius: 999px;
  background: var(--red-deep); color: #fff; font-size: .76rem; font-weight: 800;
  display: grid; place-items: center; border: 2px solid var(--stone-50);
}
.cart-count.is-zero { display: none; }

@media (max-width: 880px) {
  nav.primary { display: none; }
  .bar-actions { margin-inline-start: auto; }
  .call-btn__txt { display: none; }
  .call-btn { padding: 11px; }
}

/* ---------- Hero ---------- */
.hero { position: relative; padding: 78px 0 64px; overflow: hidden; }
.hero::before {
  content:""; position:absolute; z-index:-1; inset-block-start:-40%; inset-inline-end:-10%;
  width:760px; height:760px; border-radius:50%;
  background: radial-gradient(closest-side, var(--red-tint), transparent 70%);
  pointer-events:none;
}
.hero-grid { display:grid; grid-template-columns: 1.12fr .88fr; gap: 50px; align-items: center; }
.hero-copy { min-width: 0; }
.eyebrow {
  display:inline-flex; align-items:center; gap:9px;
  color: var(--red-deep); font-weight:700; font-size:.84rem; letter-spacing:.4px;
  background: var(--red-tint); border: 1px solid var(--red-line);
  padding: 7px 14px; border-radius: 999px; margin-bottom: 20px;
}
.hero h1 { font-size: clamp(2.3rem, 5.6vw, 4rem); font-weight: 800; max-width: 17ch; }
.hero h1 .hl { color: var(--red-deep); }
.hero .lead { color: var(--muted); font-size: clamp(1.05rem, 2vw, 1.26rem); max-width: 50ch; margin-top: 20px; }

/* Plate form */
.plate-form { margin-top: 32px; }
.plate-label { display:block; font-weight:700; margin-bottom: 10px; color: var(--ink); }
.plate-row { display:flex; flex-wrap: wrap; gap: 12px; align-items: stretch; }
.il-plate {
  direction: ltr; display:flex; align-items:center; overflow:hidden;
  background: var(--yellow); border-radius: 12px; border: 3px solid #0c0c0c;
  box-shadow: var(--shadow-md); min-width: 230px; flex: 1 1 230px;
}
.il-plate__flag { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px; align-self: stretch; padding: 0 7px; background:#0a0a0a; }
.il-plate__flag svg { display:block; border-radius:2px; }
.il-plate__il { color:#fff; font-size:.62rem; font-weight:800; letter-spacing:1px; font-family:"Rubik"; }
.plate-input {
  flex:1; border:0; background:transparent; outline-offset:-3px;
  color: var(--plate-ink); font-family:"Rubik", monospace; font-weight:800;
  font-size: clamp(1.6rem, 5vw, 2.2rem); letter-spacing: 3px; text-align:center; padding: 12px 10px; min-width: 0;
}
.plate-input::placeholder { color: rgba(0,0,0,.3); }
.plate-go { flex: 0 0 auto; }
@media (max-width: 520px){ .plate-go { width: 100%; justify-content:center; } }

.plate-hint { margin: 16px 0 8px; color: var(--muted-2); font-size: .92rem; }
.plate-chips { display:flex; flex-wrap:wrap; gap: 8px; }
.chip {
  display:inline-flex; align-items:center; gap:8px; cursor:pointer;
  background: #fff; border:1px solid var(--line-strong); color: var(--ink);
  padding: 8px 14px; border-radius: 999px; font: inherit; font-weight: 600; font-size:.92rem; box-shadow: var(--shadow-sm);
}
.chip:hover { border-color: var(--red); transform: translateY(-1px); }
.chip__plate {
  direction:ltr; background: var(--yellow); color: var(--plate-ink);
  font-family:"Rubik"; font-weight:800; font-size:.78rem; letter-spacing:1px;
  padding: 2px 7px; border-radius: 5px; border:1px solid #0c0c0c;
}
.plate-msg {
  margin-top: 14px; padding: 13px 16px; border-radius: 12px;
  background: rgba(0,56,184,.07);
  border: 1px solid rgba(0,56,184,.28); color: var(--ink); font-size: .96rem;
}

/* Hero media */
.hero-media { min-width:0; }
.hero-card { position: relative; border-radius: var(--radius-lg); overflow: hidden; border:1px solid var(--line); box-shadow: var(--shadow-lg); }
.hero-card img { width:100%; height: 330px; object-fit: cover; display:block; }
.hero-badge {
  position:absolute; inset-block-end: 14px; inset-inline-start: 14px;
  background: rgba(255,255,255,.92); backdrop-filter: blur(6px);
  border:1px solid var(--line); border-radius: 14px; padding: 10px 16px;
  display:flex; flex-direction:column; line-height:1; box-shadow: var(--shadow-sm);
}
.hero-badge strong { font-family:"Rubik"; font-size:1.7rem; color: var(--red-deep); }
.hero-badge span { color: var(--muted); font-size:.82rem; margin-top:4px; }
.hero-ticks { list-style:none; margin: 18px 0 0; padding:0; display:grid; gap:10px; }
.hero-ticks li { position:relative; padding-inline-start: 26px; color: var(--ink); font-weight:600; }
.hero-ticks li::before {
  content:""; position:absolute; inset-inline-start:0; inset-block-start:.55em;
  width: 11px; height: 11px; border-radius:3px; background: var(--red);
}
@media (max-width: 920px){
  .hero-grid { grid-template-columns: 1fr; gap: 30px; }
  .hero-media { order: 2; }
}

/* ---------- Reveal ---------- */
.reveal { opacity:0; transform: translateY(14px); animation: rise .7s var(--ease) forwards; }
.d1{animation-delay:.05s} .d2{animation-delay:.15s} .d3{animation-delay:.25s} .d4{animation-delay:.35s}
@keyframes rise { to { opacity:1; transform:none; } }
@media (prefers-reduced-motion: reduce){ .reveal{ animation:none; opacity:1; transform:none; } }

/* ---------- Section heads ---------- */
section { padding: 70px 0; }
.sec-head { margin-bottom: 34px; }
.sec-head.center { text-align:center; }
.kicker { color: var(--red-deep); font-weight:800; letter-spacing:2px; font-size:.76rem; text-transform:uppercase; }
.sec-head h2 { font-size: clamp(1.7rem, 4vw, 2.5rem); margin-top: 8px; font-weight:800; }
.sec-head .muted { margin-top: 12px; max-width: 60ch; }
.sec-head.center .muted { margin-inline: auto; }

/* ---------- Fitment ---------- */
.fitment { background: linear-gradient(180deg, #fff, #fbf9f4); border-block: 1px solid var(--line); scroll-margin-top: 86px; }
.fitment-head { display:flex; flex-wrap:wrap; align-items:center; gap: 20px; margin-bottom: 26px; }
.fitment-title { flex: 1 1 260px; }
.fitment-title h2 { font-size: clamp(1.5rem, 3.4vw, 2.1rem); margin-top:6px; font-weight:800; }
.car-card { display:flex; align-items:center; gap:14px; background:#fff; border:1px solid var(--line-strong); border-radius:14px; padding: 14px 18px; box-shadow: var(--shadow-sm); }
.car-card .plate-mini {
  direction:ltr; background:var(--yellow); color:var(--plate-ink); border:2px solid #0c0c0c;
  border-radius:7px; padding:5px 9px; font-family:"Rubik"; font-weight:800; letter-spacing:2px; font-size:1.05rem;
}
.car-info b { font-family:"Rubik"; font-size:1.15rem; display:block; color: var(--graphite); }
.car-info span { color: var(--muted); font-size:.9rem; }
.change-car { margin-inline-start: auto; }

.filter-bar { display:flex; flex-wrap:wrap; gap:8px; margin-bottom: 26px; }
.fpill { cursor:pointer; background:#fff; border:1px solid var(--line-strong); color: var(--muted); padding: 8px 15px; border-radius: 999px; font: inherit; font-weight:600; font-size:.92rem; }
.fpill:hover { color: var(--ink); border-color: var(--ink); }
.fpill[aria-pressed="true"] { background: var(--red-deep); border-color: var(--red-deep); color:#fff; }

.product-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(248px, 1fr)); gap: 18px; }
.pcard { display:flex; flex-direction:column; background:#fff; border:1px solid var(--line); border-radius: var(--radius-lg); overflow:hidden; box-shadow: var(--shadow-sm); transition: transform .22s var(--ease), box-shadow .22s var(--ease), border-color .22s var(--ease); }
.pcard:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--red-line); }
.pcard__media { position:relative; aspect-ratio: 16/10; overflow:hidden; background: var(--stone-100); }
.pcard__media img { width:100%; height:100%; object-fit:cover; display:block; }
.ptile { width:100%; height:100%; display:grid; place-items:center; background: linear-gradient(150deg, var(--stone-100), #fff); }
.ptile svg { width: 56px; height: 56px; color: var(--graphite-soft); opacity:.9; }
.pcard__cat { position:absolute; inset-block-start:10px; inset-inline-start:10px; background: rgba(255,255,255,.92); color: var(--ink); font-size:.72rem; font-weight:700; padding:4px 10px; border-radius:999px; border:1px solid var(--line); }
.pcard__body { padding: 16px 16px 18px; display:flex; flex-direction:column; flex:1; }
.pcard__name { font-family:"Rubik"; font-weight:700; font-size:1.02rem; line-height:1.25; }
.pcard__desc { color: var(--muted); font-size:.9rem; margin-top:8px; flex:1; }
.variants { display:flex; gap:6px; margin-top:14px; }
.variants button { flex:1; cursor:pointer; font: inherit; font-weight:700; font-size:.82rem; padding: 8px 6px; border-radius:9px; border:1px solid var(--line-strong); background:#fff; color: var(--muted); }
.variants button[aria-pressed="true"] { background: var(--red-tint); border-color: var(--red); color: var(--red-deep); }
.pcard__foot { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-top:14px; }
.price { font-family:"Rubik"; font-weight:800; font-size:1.3rem; color: var(--graphite); }
.add-btn { display:inline-flex; align-items:center; gap:7px; cursor:pointer; white-space:nowrap; background: var(--red-deep); color:#fff; border:0; font:inherit; font-weight:700; font-size:.92rem; padding: 10px 15px; border-radius: 10px; }
.add-btn:hover { background: var(--red); }
.add-btn svg { width:17px; height:17px; }

.general-block { margin-top: 48px; }
.general-h { font-family:"Rubik"; font-size:1.3rem; margin-bottom: 18px; padding-block-start: 28px; border-block-start:1px solid var(--line); }

/* ---------- How it works ---------- */
.how { background: var(--stone-50); border-block: 1px solid var(--line); }
.steps { list-style:none; margin:0; padding:0; display:grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
@media (max-width: 800px){ .steps { grid-template-columns: 1fr; } }
.step { position:relative; background:#fff; border:1px solid var(--line); border-radius: var(--radius-lg); padding: 28px 24px 26px; box-shadow: var(--shadow-sm); }
.step-num { display:grid; place-items:center; width:46px; height:46px; border-radius:12px; background: var(--red-deep); color:#fff; font-family:"Rubik"; font-weight:800; font-size:1.3rem; margin-bottom:16px; }
.step h3 { font-size:1.2rem; }
.step p { color: var(--muted); margin-top:8px; }

/* ---------- Services ---------- */
.grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap:16px; }
.card { background:#fff; border:1px solid var(--line); border-radius: var(--radius-lg); padding: 24px; box-shadow: var(--shadow-sm); transition: transform .22s var(--ease), box-shadow .22s var(--ease); }
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.card .ico { width:46px; height:46px; border-radius:12px; display:grid; place-items:center; margin-bottom:15px; background: var(--red-tint); border:1px solid var(--red-line); }
.card .ico svg { width:24px; height:24px; color: var(--red-deep); }
.card h3 { font-size:1.16rem; }
.card p { color: var(--muted); margin-top:8px; font-size:.96rem; }

/* Photo service cards */
.scard { display:flex; flex-direction:column; background:#fff; border:1px solid var(--line); border-radius: var(--radius-lg); overflow:hidden; box-shadow: var(--shadow-sm); transition: transform .22s var(--ease), box-shadow .22s var(--ease); }
.scard:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.scard__media { aspect-ratio: 16/10; overflow:hidden; background: var(--stone-100); }
.scard__media img { width:100%; height:100%; object-fit:cover; display:block; transition: transform .45s var(--ease); }
.scard:hover .scard__media img { transform: scale(1.05); }
.scard__body { padding: 18px 20px 20px; }
.scard__body h3 { font-size:1.18rem; }
.scard__body p { color: var(--muted); margin-top:8px; font-size:.95rem; }

/* ---------- About ---------- */
.about-grid { display:grid; grid-template-columns: 1.3fr .9fr; gap: 42px; align-items:center; }
@media (max-width: 820px){ .about-grid { grid-template-columns: 1fr; } }
.about p { color: var(--muted); font-size:1.08rem; margin-top: 14px; }
.about p:first-of-type { margin-top: 0; }
.trust { list-style:none; margin:0; padding:0; display:grid; grid-template-columns: 1fr 1fr; gap:14px; }
.trust li { background:#fff; border:1px solid var(--line); border-radius: var(--radius-md); padding: 18px; box-shadow: var(--shadow-sm); }
.trust strong { font-family:"Rubik"; font-size:1.45rem; color: var(--red-deep); display:block; line-height:1; }
.trust span { color: var(--muted); font-size:.88rem; display:block; margin-top:6px; }

/* ---------- Contact ---------- */
.contact-grid { display:grid; grid-template-columns: 1fr 1fr; gap:18px; }
@media (max-width: 760px){ .contact-grid { grid-template-columns: 1fr; } }
.panel { background:#fff; border:1px solid var(--line); border-radius: var(--radius-lg); padding: 28px; box-shadow: var(--shadow-sm); }
.panel h3 { font-size:1.25rem; margin-bottom:16px; }
.contact-list { list-style:none; margin:0; padding:0; display:grid; gap:14px; }
.contact-list li { display:flex; align-items:center; gap:14px; }
.contact-list .ci { width:40px; height:40px; flex:none; border-radius:11px; display:grid; place-items:center; background: var(--stone-100); border:1px solid var(--line); }
.contact-list .ci svg { width:20px; height:20px; color: var(--red-deep); }
.contact-list a, .contact-list span { color: var(--ink); text-decoration:none; font-weight:600; }
.contact-list a:hover { color: var(--red-deep); }
.contact-list small { display:block; color: var(--muted); font-weight:400; font-size:.82rem; }
.contact-list address { font-style:normal; font-weight:600; }

table.hours { width:100%; border-collapse:collapse; }
table.hours caption { text-align:start; color: var(--muted); margin-bottom:10px; }
table.hours th, table.hours td { text-align:start; padding:11px 4px; border-block-end:1px solid var(--line); }
table.hours th { font-weight:600; color: var(--muted); }
table.hours td { font-weight:700; }
.closed { color: var(--red-deep); }
.full { width:100%; justify-content:center; margin-top:18px; }

/* ---------- Buttons ---------- */
.btn { display:inline-flex; align-items:center; gap:9px; padding:13px 20px; border-radius:11px; font-weight:700; font-size:1rem; text-decoration:none; border:1px solid transparent; cursor:pointer; font-family:inherit; }
.btn svg { width:19px; height:19px; }
.btn-primary { background: var(--red-deep); color:#fff; box-shadow: var(--shadow-sm); }
.btn-primary:hover { background: var(--red); color:#fff; }
.btn-ghost { background:#fff; color: var(--ink); border-color: var(--line-strong); }
.btn-ghost:hover { border-color: var(--ink); color: var(--ink); }

/* ---------- Footer (dark graphite) ---------- */
.site-foot { background: var(--graphite); color: #d9d6d0; padding: 56px 0 28px; }
.site-foot h3 { font-size:1.1rem; margin-bottom:12px; color:#fff; }
.foot-grid { display:grid; grid-template-columns: 1.4fr 1fr; gap:36px; }
@media (max-width: 760px){ .foot-grid { grid-template-columns: 1fr; } }
.site-foot p, .site-foot li { color: #b7b3ac; }
.site-foot a { color: #e7e4df; }
.site-foot a:hover { color:#fff; }
.a11y-foot ul { padding-inline-start: 18px; margin:8px 0; }
.a11y-foot strong { color:#fff; }
.foot-logo { margin-bottom: 16px; }
.foot-bottom { margin-top:40px; padding-top:22px; border-top:1px solid rgba(255,255,255,.12); display:flex; flex-wrap:wrap; gap:12px; justify-content:space-between; color:#9a968f; font-size:.9rem; }
.demo-stamp { color:#f1b3b6; font-weight:600; }

/* ---------- Cart drawer ---------- */
.drawer-backdrop, .modal-backdrop { position: fixed; inset:0; z-index:120; background: rgba(23,20,18,.42); backdrop-filter: blur(2px); animation: fade .2s var(--ease); }
@keyframes fade { from { opacity:0; } to { opacity:1; } }
.cart-drawer { position: fixed; inset-block:0; inset-inline-start: 0; z-index:130; width: min(420px, 92vw); background: #fbf9f4; border-inline-end: 1px solid var(--line); display:flex; flex-direction:column; box-shadow: var(--shadow-lg); animation: slideIn .28s var(--ease); }
.cart-drawer[hidden], .checkout[hidden] { display: none; }
@keyframes slideIn { from { transform: translateX(-100%); } to { transform: none; } }
.cart-drawer__head { display:flex; align-items:center; justify-content:space-between; padding: 22px 22px 16px; border-block-end:1px solid var(--line); }
.cart-drawer__head h2 { font-size:1.3rem; }
.cart-drawer__close, .checkout__close { background:none; border:0; color: var(--muted); font-size:1.4rem; cursor:pointer; line-height:1; padding:6px; border-radius:8px; }
.cart-drawer__close:hover, .checkout__close:hover { color: var(--ink); }
.cart-body { flex:1; overflow-y:auto; padding: 16px 22px; }
.cart-empty { text-align:center; color: var(--muted); padding: 48px 10px; }
.cart-item { display:flex; gap:12px; padding: 14px 0; border-block-end:1px solid var(--line); }
.cart-item__media { width:62px; height:62px; flex:none; border-radius:11px; overflow:hidden; background: var(--stone-100); display:grid; place-items:center; }
.cart-item__media img { width:100%; height:100%; object-fit:cover; }
.cart-item__media .ptile svg { width:26px; height:26px; }
.cart-item__info { flex:1; min-width:0; }
.cart-item__name { font-weight:700; font-size:.95rem; line-height:1.25; }
.cart-item__var { color: var(--muted); font-size:.8rem; margin-top:2px; }
.cart-item__row { display:flex; align-items:center; justify-content:space-between; margin-top:8px; }
.qty { display:inline-flex; align-items:center; gap:0; border:1px solid var(--line-strong); border-radius:9px; overflow:hidden; }
.qty button { width:30px; height:30px; background:#fff; border:0; color: var(--ink); font:inherit; font-weight:700; cursor:pointer; }
.qty button:hover { background: var(--stone-100); }
.qty span { min-width:30px; text-align:center; font-weight:700; }
.cart-item__price { font-family:"Rubik"; font-weight:700; color: var(--graphite); }
.cart-item__remove { background:none; border:0; color: var(--muted); cursor:pointer; font-size:.82rem; text-decoration:underline; padding:0; }
.cart-item__remove:hover { color: var(--red-deep); }
.cart-foot { padding: 18px 22px 22px; border-block-start:1px solid var(--line); background:#fff; }
.cart-total { display:flex; align-items:center; justify-content:space-between; font-size:1.05rem; }
.cart-total strong { font-family:"Rubik"; font-size:1.5rem; color: var(--graphite); }
.cart-note { color: var(--muted); font-size:.84rem; margin: 8px 0 14px; }

/* ---------- Checkout modal ---------- */
.checkout {
  position: fixed; z-index:130; inset-block-start: 50%; inset-inline-start: 50%;
  transform: translate(50%, -50%);
  width: min(520px, 94vw); max-height: 92vh; overflow-y:auto;
  background: #fff; border:1px solid var(--line); border-radius: var(--radius-lg); padding: 30px;
  box-shadow: var(--shadow-lg); animation: pop .26s var(--ease);
}
@keyframes pop { from { opacity:0; transform: translate(50%, -46%) scale(.97); } to { opacity:1; } }
.checkout__close { position:absolute; inset-block-start:16px; inset-inline-end:16px; }
.checkout h2 { font-size:1.5rem; }
.checkout form { margin-top: 18px; }
.field { margin-bottom: 14px; }
.field label { display:block; font-weight:600; font-size:.9rem; margin-bottom:6px; }
.field input { width:100%; padding: 12px 14px; border-radius: 10px; border:1px solid var(--line-strong); background:#fff; color: var(--ink); font: inherit; }
.field input::placeholder { color: var(--muted-2); }
.field input:focus { border-color: var(--red); }
.pay { border:1px solid var(--line); border-radius:14px; padding: 16px; margin: 18px 0; background: #fbf9f4; }
.pay legend { padding: 0 8px; font-weight:700; color: var(--muted); font-size:.85rem; }
.pay-row { display:grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.checkout-total { display:flex; align-items:center; justify-content:space-between; margin: 6px 0 16px; font-size:1.1rem; }
.checkout-total strong { font-family:"Rubik"; font-size:1.5rem; color: var(--graphite); }
#checkout-step-done { text-align:center; padding: 10px 0 6px; }
.done-mark { width:72px; height:72px; margin:0 auto 18px; border-radius:50%; display:grid; place-items:center; background: var(--red-tint); border:2px solid var(--red); }
.done-mark svg { width:38px; height:38px; color: var(--red-deep); }
#checkout-step-done h2 { margin-bottom: 10px; }
#checkout-step-done .btn { margin-top: 20px; }

/* ---------- Toast ---------- */
.toast { position: fixed; inset-block-end: 24px; inset-inline-end: 24px; z-index:140; background:#fff; border:1px solid var(--red-line); color: var(--ink); padding: 13px 18px; border-radius: 12px; font-weight:700; box-shadow: var(--shadow-md); display:flex; align-items:center; gap:10px; animation: toastIn .25s var(--ease); }
.toast::before { content:""; width:9px; height:9px; border-radius:50%; background: var(--red); }
@keyframes toastIn { from { opacity:0; transform: translateY(10px); } to { opacity:1; } }

/* ===================================================================
   Accessibility widget (light themed)
   =================================================================== */
.a11y-toggle { position: fixed; inset-inline-end: 20px; inset-block-end: 20px; z-index: 100; width:56px; height:56px; border-radius:50%; border:2px solid #fff; background: var(--red-deep); color:#fff; cursor:pointer; display:grid; place-items:center; box-shadow: var(--shadow-md); }
.a11y-toggle svg { width:28px; height:28px; }
.a11y-toggle:hover { background: var(--red); transform: scale(1.05); }
.a11y-panel { position: fixed; inset-inline-end: 20px; inset-block-end: 86px; z-index: 101; width: 300px; max-width: calc(100vw - 40px); background:#fff; color: var(--ink); border:1px solid var(--line-strong); border-radius:16px; padding:16px; box-shadow: var(--shadow-lg); }
.a11y-panel[hidden] { display:none; }
.a11y-panel__head { display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.a11y-panel__title { font-family:"Rubik"; font-weight:700; font-size:1.1rem; }
.a11y-panel__close { background:none; border:none; color: var(--muted); font-size:1.25rem; cursor:pointer; line-height:1; padding:4px 6px; }
.a11y-panel__close:hover { color: var(--ink); }
.a11y-row--font { display:flex; align-items:center; justify-content:space-between; padding:10px 0; border-block-end:1px solid var(--line); }
.a11y-row__label { font-weight:600; }
.a11y-fs-controls { display:inline-flex; align-items:center; gap:8px; }
.a11y-fs-controls button { width:34px; height:34px; border-radius:9px; border:1px solid var(--line-strong); background:#fff; color: var(--ink); font:inherit; font-weight:700; cursor:pointer; }
.a11y-fs-controls button:hover { border-color: var(--red); }
.a11y-fs-label { min-width:40px; text-align:center; color: var(--muted); font-size:.9rem; }
.a11y-opt { display:block; width:100%; text-align:start; margin-top:8px; padding:11px 13px; border-radius:11px; border:1px solid var(--line-strong); background:#fff; color: var(--ink); font:inherit; font-weight:600; cursor:pointer; }
.a11y-opt:hover { border-color: var(--red); }
.a11y-opt[aria-pressed="true"] { background: var(--red-tint); border-color: var(--red); color: var(--red-deep); }
.a11y-opt[aria-pressed="true"]::after { content:" ✓"; color: var(--red-deep); }
.a11y-reset { display:block; width:100%; margin-top:12px; padding:10px; border-radius:11px; border:1px solid var(--red); background:transparent; color: var(--red-deep); font:inherit; font-weight:700; cursor:pointer; }
.a11y-reset:hover { background: var(--red-deep); color:#fff; border-color: var(--red-deep); }
.a11y-statement-link { display:block; text-align:center; margin-top:12px; font-size:.92rem; }

/* a11y state classes on <html> */
html.a11y-fs-1 { font-size: 112.5%; }
html.a11y-fs-2 { font-size: 125%; }
html.a11y-fs-3 { font-size: 140%; }
html.a11y-links a { text-decoration: underline !important; text-decoration-thickness:2px; font-weight:700; }
html.a11y-readable, html.a11y-readable body, html.a11y-readable * { font-family: Arial, "Assistant", sans-serif !important; letter-spacing:.03em; word-spacing:.12em; line-height:1.9 !important; }
html.a11y-bigcursor, html.a11y-bigcursor * { cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='48' height='48' viewBox='0 0 48 48'%3E%3Cpath d='M10 4l26 15-11 3-3 11z' fill='%23000000' stroke='%23ffffff' stroke-width='2.5' stroke-linejoin='round'/%3E%3C/svg%3E") 8 4, auto !important; }
html.a11y-noanim *, html.a11y-noanim *::before, html.a11y-noanim *::after { animation:none !important; transition:none !important; scroll-behavior:auto !important; }
html.a11y-noanim .reveal { opacity:1 !important; transform:none !important; }

/* High-contrast mode (black on white, maximal separation) */
html.a11y-contrast body { background:#fff !important; color:#000 !important; }
html.a11y-contrast h1, html.a11y-contrast h2, html.a11y-contrast h3,
html.a11y-contrast p, html.a11y-contrast li, html.a11y-contrast span, html.a11y-contrast small,
html.a11y-contrast td, html.a11y-contrast th, html.a11y-contrast address, html.a11y-contrast .muted,
html.a11y-contrast .pcard__desc, html.a11y-contrast .step p, html.a11y-contrast caption,
html.a11y-contrast .car-info span, html.a11y-contrast label { color:#000 !important; }
html.a11y-contrast header.site, html.a11y-contrast .site-foot, html.a11y-contrast .pcard,
html.a11y-contrast .card, html.a11y-contrast .panel, html.a11y-contrast .step, html.a11y-contrast .trust li,
html.a11y-contrast .fitment, html.a11y-contrast .how, html.a11y-contrast .car-card,
html.a11y-contrast .cart-drawer, html.a11y-contrast .checkout, html.a11y-contrast .a11y-panel,
html.a11y-contrast .cart-foot, html.a11y-contrast .pay { background:#fff !important; border-color:#000 !important; }
html.a11y-contrast .site-foot, html.a11y-contrast .site-foot h3, html.a11y-contrast .site-foot p, html.a11y-contrast .site-foot li, html.a11y-contrast .site-foot a { color:#000 !important; }
html.a11y-contrast a, html.a11y-contrast .kicker, html.a11y-contrast .hero h1 .hl,
html.a11y-contrast .trust strong, html.a11y-contrast .hero-badge strong, html.a11y-contrast .closed,
html.a11y-contrast .price, html.a11y-contrast .cart-total strong { color:#000 !important; }
html.a11y-contrast .btn-primary, html.a11y-contrast .add-btn, html.a11y-contrast .step-num,
html.a11y-contrast .fpill[aria-pressed="true"], html.a11y-contrast .a11y-toggle,
html.a11y-contrast .cart-count, html.a11y-contrast .skip { background:#000 !important; color:#fff !important; border-color:#000 !important; }
html.a11y-contrast .hero::before { display:none !important; }
