/* ============================================================
   Garage Mono — per-category product page theme.
   Loaded ONLY on "/fleet/<slug>/" routes (see layout.mjs regex), AFTER main.css,
   and every rule is scoped under .page-product so it never touches other pages.
   Ported from the approved product sample 3 ("Booking First").
   ============================================================ */

body.page-product{
  --bg:#0a0a0a; --panel:#141414; --panel-2:#1c1c1c; --line:#2a2a2a; --ink:#f5f5f5; --muted:#a0a0a0;
  --red:#ff2e3c; --red-d:#e01421;
  --light:#f5f5f5; --on-light:#0a0a0a; --on-light-muted:#5a5a5a;
  --maxw:1200px; --font:"Inter",system-ui,sans-serif;
  background:var(--bg); color:var(--ink); font-family:var(--font);
  font-size:17px; line-height:1.65; -webkit-font-smoothing:antialiased;
}
.page-product h1,.page-product h2,.page-product h3{margin:0;line-height:1.05;letter-spacing:-.02em;font-weight:900}
.page-product p{margin:0 0 1rem}
.page-product a{color:inherit}
.page-product img,.page-product svg{max-width:100%;display:block}
.page-product .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.page-product .display{text-transform:uppercase;letter-spacing:-.01em;color:#b8b8b8}
.page-product .accent{color:#fff}
.page-product .eyebrow{font-size:.72rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:#c9c9c9;margin:0 0 .8rem}

.page-product .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:800;font-size:.92rem;padding:14px 26px;border-radius:6px;text-decoration:none;border:2px solid transparent;transition:transform .15s ease,background .15s ease;text-transform:uppercase;letter-spacing:.03em;cursor:pointer}
.page-product .btn.primary{background:var(--red);color:#fff;box-shadow:0 10px 30px rgba(255,46,60,.28)}
.page-product .btn.primary:hover{transform:translateY(-2px);background:var(--red-d)}
.page-product .btn.ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.page-product .btn.ghost:hover{border-color:#5a5a5a;color:#fff}
.page-product .btn-row{display:flex;flex-wrap:wrap;gap:12px}
.page-product a:focus-visible,.page-product button:focus-visible{outline:3px solid var(--red);outline-offset:2px;border-radius:6px}

/* ---- Shared chrome (layout header/footer) re-themed dark, product pages only ---- */
.page-product .container{max-width:var(--maxw)}
.page-product .skip-link{background:var(--red);color:#fff}
.page-product .site-header{background:rgba(10,10,10,.86);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:80}
.page-product .site-header .brand strong{color:var(--ink)}
.page-product .site-header .brand small{color:var(--muted)}
.page-product .brand-mark{background:var(--red);color:#fff;border-color:var(--red)}
.page-product .site-nav a{color:#cfcfcf}
.page-product .site-nav a:hover{color:#fff}
.page-product .nav-cta{background:var(--red);color:#fff;border:2px solid transparent;font-weight:800;text-transform:uppercase;letter-spacing:.03em}
.page-product .nav-cta:hover{background:var(--red-d)}
.page-product .site-footer{background:#050505;color:var(--muted);border-top:1px solid var(--line)}
.page-product .site-footer h2,.page-product .site-footer h3{color:var(--ink)}
.page-product .site-footer p{color:var(--muted)}
.page-product .site-footer a{color:#fff}

/* ---- BREADCRUMB ---- */
.page-product .crumbs-row{padding:1.3rem 0 .2rem}
.page-product .crumbs{font-size:.82rem;color:var(--muted);font-weight:600}
.page-product .crumbs a{text-decoration:none;color:var(--muted)}
.page-product .crumbs a:hover{color:#fff}
.page-product .crumbs b{color:var(--ink)}
.page-product .crumbs .sep{margin:0 .5rem;color:#555}

/* ---- LEAD ---- */
.page-product .lead{padding:.4rem 0 1.8rem}
.page-product .lead h1{font-size:clamp(2rem,5vw,3.4rem)}
.page-product .lead .model{font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:#fff;margin:.8rem 0 0;font-size:1rem}
.page-product .lead .model small{color:var(--muted);font-weight:600;text-transform:none;letter-spacing:0;margin-left:.4rem}

/* ---- TWO-COLUMN LAYOUT ---- */
.page-product .block{padding:0 0 3.6rem}
.page-product .layout{display:grid;grid-template-columns:1.55fr .95fr;gap:2.4rem;align-items:start}

/* ---- LEFT: HERO ART ---- */
.page-product .art{position:relative;background:linear-gradient(145deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:18px;padding:2.4rem;display:flex;align-items:center;justify-content:center;min-height:280px;box-shadow:0 24px 50px rgba(0,0,0,.5);margin-bottom:1.6rem}
.page-product .art svg{width:100%;max-width:480px;fill:#cfcfcf}
.page-product .art .photo-note{position:absolute;right:18px;top:16px;font-size:.62rem;color:#6a6a6a;letter-spacing:.08em;text-transform:uppercase;font-weight:700}
.page-product .art.has-image{padding:0;overflow:hidden}
.page-product .art.has-image img{width:100%;height:100%;object-fit:cover;border-radius:18px}

/* ---- SPEC CHIPS ---- */
.page-product .specs{display:flex;flex-wrap:wrap;gap:.6rem;margin:0 0 1.6rem}
.page-product .spec{display:inline-flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:9px 14px;font-size:.82rem;font-weight:700;color:var(--ink)}

.page-product .intro{color:var(--muted);max-width:54ch;margin-bottom:2rem}

/* ---- SUB-HEADINGS ---- */
.page-product .sub{font-size:1.15rem;text-transform:uppercase;letter-spacing:.02em;margin:0 0 1rem;color:var(--ink)}

/* ---- FEATURE LIST (two-column) ---- */
.page-product .feature-cols{columns:2;column-gap:2rem;padding:0;margin:0 0 2rem;list-style:none}
.page-product .feature-cols li{display:flex;gap:.6rem;align-items:flex-start;margin-bottom:.7rem;break-inside:avoid;font-weight:500;font-size:.95rem}
.page-product .feature-cols .tick{flex:0 0 auto;width:20px;height:20px;border-radius:50%;background:#f5f5f5;color:#0a0a0a;display:inline-flex;align-items:center;justify-content:center;font-size:.66rem;font-weight:900;margin-top:2px}

/* ---- DELIVERY CHIPS ---- */
.page-product .chips{display:flex;flex-wrap:wrap;gap:.5rem;margin:0 0 2rem}
.page-product .chip{background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:7px 14px;font-size:.8rem;font-weight:700;color:var(--ink)}

/* ---- WHAT'S INCLUDED ---- */
.page-product .incl{list-style:none;padding:0;margin:0 0 .4rem}
.page-product .incl li{display:flex;gap:.7rem;align-items:flex-start;margin-bottom:.7rem;color:var(--muted);font-size:.95rem}
.page-product .incl .tick{color:var(--red);font-weight:900;margin-top:1px}
.page-product .incl b{color:#fff}

/* ---- RIGHT: BOOKING CARD (sticky) ---- */
.page-product .booking{position:sticky;top:90px;background:linear-gradient(160deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:18px;padding:1.7rem;box-shadow:0 24px 50px rgba(0,0,0,.55)}
.page-product .booking .tier-name{font-size:.78rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.page-product .booking .price{font-size:2.6rem;font-weight:900;color:#fff;line-height:1;margin:.4rem 0 .1rem;font-family:inherit}
.page-product .booking .price small{font-size:1rem;color:var(--muted);font-weight:700}
.page-product .booking .booking-note{color:var(--muted);font-size:.85rem;margin:0 0 1.2rem}
.page-product .booking .btn{width:100%;margin-bottom:.7rem;padding:13px 22px}
.page-product .booking .stars{color:#f5f5f5;letter-spacing:.1em;text-align:center;margin-top:1rem;font-size:.95rem}
.page-product .booking .ministats{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem;margin-top:1.3rem;padding-top:1.3rem;border-top:1px solid var(--line);text-align:center}
.page-product .booking .ministats b{display:block;font-size:1.15rem;font-weight:900;color:#fff}
.page-product .booking .ministats span{font-size:.64rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:700;display:block;margin-top:.2rem}

/* ---- CLOSING ---- */
.page-product .closing{text-align:center;position:relative;overflow:hidden;border-top:1px solid var(--line);padding:3.6rem 0}
.page-product .closing::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 360px at 50% -20%, rgba(255,255,255,.06), transparent 60%);pointer-events:none}
.page-product .closing h2{position:relative;font-size:clamp(1.7rem,4vw,2.6rem);max-width:20ch;margin:0 auto 1rem;text-transform:uppercase}
.page-product .closing p{position:relative;color:var(--muted);max-width:48ch;margin:0 auto 1.8rem}
.page-product .closing .btn-row{position:relative;justify-content:center}

/* ---- RESPONSIVE ---- */
@media(max-width:880px){
  .page-product .layout{grid-template-columns:1fr}
  .page-product .booking{position:static;order:-1;margin-bottom:1.6rem}
  .page-product .feature-cols{columns:1}
}
@media(max-width:560px){
  .page-product .art{padding:1.6rem;min-height:200px}
  .page-product .lead h1{font-size:1.9rem}
}
@media(prefers-reduced-motion:reduce){.page-product *{scroll-behavior:auto;transition:none!important}}

/* ---- QUOTE FORM in the booking aside (exotic product pages) ---- */
.page-product .booking{scroll-margin-top:90px}
.page-product .booking .qform{display:flex;flex-direction:column;gap:.7rem;margin:0 0 .4rem}
.page-product .qf-row{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.page-product .qf-field{display:flex;flex-direction:column;gap:.35rem;min-width:0}
.page-product .qf-label{font-size:.66rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.page-product .qf-label small{text-transform:none;letter-spacing:0;font-weight:600}
.page-product .qform input,.page-product .qform select{
  background:#0e0e0e;border:1px solid var(--line);border-radius:10px;
  color:#fff;font:600 .95rem/1.2 Inter,system-ui,sans-serif;padding:.7rem .9rem;
  color-scheme:dark;width:100%}
.page-product .qform input:focus,.page-product .qform select:focus{
  outline:0;border-color:var(--red);box-shadow:0 0 0 3px rgba(255,46,60,.16)}
.page-product .booking .qform .btn{margin-bottom:0}
.page-product .qf-foot{color:var(--muted);font-size:.78rem;text-align:center;margin:.5rem 0 0}
@media(max-width:560px){.page-product .qf-row{grid-template-columns:1fr}}

/* ---- BOOKING WIDGET in the aside (fleet product pages only) ---- */
.page-product .booking .booking-widget{margin:0 0 .7rem}
/* Reserve the widget's settled stacked height to limit CLS while it loads */
.page-product .booking .booking-widget .rentid-embed{min-height:340px}
.page-product .booking .booking-widget iframe{border-radius:10px}
