/* ==========================================================================
   Promotions Page 2.0  (promotions_info.php / promo_page)
   --------------------------------------------------------------------------
   Mockup: promotions-final-2.0.html. All rules are scoped under `.promo2`
   (a wrapper inside `.lp-content`) so they never leak into the rest of the LP
   framework. Colors map to the existing `--lp-*` tokens (see :scope block);
   blue/gold are page-local secondary accents per the design spec.
   Sections: deal bar, hero, value strip, spotlight (split hero + supporting),
   category tiles, product grid + facet rail, advantage, reviews, showroom,
   finale. (Personalized band + low-stock are deferred — not styled here.)
   ========================================================================== */

.promo2 {
  /* Map the mockup palette onto house tokens */
  --red:      var(--lp-brand, #CF1C3C);
  --red-dk:   var(--lp-brand-dark, #A01730);
  --black:    var(--lp-black, #080808);
  --offblack: #191A1C;
  --offblack-2: #222428;
  --white:    #FFFFFF;
  --grey:     var(--lp-grey-light, #F0F1F3);
  --offwhite: #F5F6FA;
  --blue:     #3968BA;   /* page-local secondary accent */
  --gold:     #FCB002;   /* page-local secondary accent */
  /* Savings/discount markers — the single green used by EVERY discount
     indicator on the page (hero sticker, hero-split SAVE pill, deal-card chip). */
  --lp-savings:     #a4d007;
  --lp-savings-ink: #1c2b00;
  --p-text:   #1F2937;
  --p-text-dk:#111827;
  --p-muted:  var(--lp-muted, #6B7280);
  --line:     var(--lp-border, #E5E7EB);
  --line-2:   #d8dbe0;
  --p-max:    1280px;
  --p-shadow: 0 1px 3px rgba(8,8,8,.05), 0 8px 24px rgba(8,8,8,.06);

  color: var(--p-text);
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  background: var(--white);
}
.promo2 *{ box-sizing: border-box; }
.promo2 img{ max-width: 100%; display: block; }
.promo2 button{ font: inherit; cursor: pointer; }
.promo2 a{ color: inherit; }
.promo2 .wrap{ max-width: var(--p-max); margin: 0 auto; padding: 0 24px; }
.promo2 section{ padding: 42px 0; }
/* Today's top deals sits on a light-grey band so the dark spotlight cards read
   with a touch of contrast against the page. */
.promo2 #top{ background: var(--grey); }

/* shared section heading */
.promo2 .shead{ display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:22px; }
.promo2 .shead h2{ font-size:26px !important; font-weight:800 !important; margin:0 !important; letter-spacing:-.015em; color:var(--p-text-dk) !important; }
.promo2 .shead .sub{ color:var(--p-muted); font-size:14.5px; margin:6px 0 0; }
.promo2 .shead a{ font-size:14px; font-weight:700; color:var(--red); text-decoration:none; white-space:nowrap; }
.promo2 .shead a:hover{ text-decoration:underline; }

/* shared buttons */
.promo2 .btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; border:0; border-radius:8px; padding:13px 22px; font-weight:700; font-size:15px; text-decoration:none; transition:filter .15s, transform .1s, background .15s, color .15s, border-color .15s; }
.promo2 .btn:active{ transform:translateY(1px); }
.promo2 .btn-deal{ background:var(--red); color:#fff !important; }
.promo2 .btn-deal:hover{ background:var(--red-dk); }
.promo2 .btn-out{ background:transparent; color:#fff !important; border:1.5px solid rgba(255,255,255,.45); }
.promo2 .btn-out:hover{ border-color:#fff; }

/* ============ deal bar (top banner) ============ */
/* Scrolls away with the page; its details are summarized into .promo-stickybar
   which docks under the site nav on scroll (see .promo-stickybar below). */
.promo2 .dealbar{ background:var(--red); color:#fff; position:relative; z-index:40; }
.promo2 .dealbar .wrap{ display:flex; align-items:center; justify-content:space-between; gap:16px; min-height:44px; font-size:14px; font-weight:600; padding-top:6px; padding-bottom:6px; }
.promo2 .dealbar .left{ display:flex; align-items:center; gap:10px; }
.promo2 .dealbar .badge{ background:#fff; color:var(--red); font-weight:800; font-size:12px; padding:3px 8px; border-radius:4px; }
.promo2 .dealbar .timer{ display:flex; align-items:center; gap:6px; font-variant-numeric:tabular-nums; white-space:nowrap; }
.promo2 .dealbar .timer b{ background:rgba(0,0,0,.22); padding:3px 7px; border-radius:4px; font-weight:800; }

/* ============ minimized sticky promo summary ============ */
/* Fixed, docked just under the (shrinking) site nav. promo_page.js sets `top`
   to the live header height and toggles .is-visible once the deal bar scrolls
   out of view. Sits below the nav (z-index < .wr-header's 1000). */
.promo2 .promo-stickybar{
  position:fixed; left:0; right:0; top:0; z-index:900;
  background:var(--red); color:#fff; box-shadow:0 6px 16px rgba(8,8,8,.18);
  transform:translateY(-12px); opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .25s ease, transform .25s ease, visibility .25s ease;
}
.promo2 .promo-stickybar.is-visible{ transform:translateY(0); opacity:1; visibility:visible; pointer-events:auto; }
.promo2 .promo-stickybar .wrap{ display:flex; align-items:center; gap:14px; min-height:46px; padding-top:7px; padding-bottom:7px; }
.promo2 .promo-stickybar .sb-badge{ background:#fff; color:var(--red); font-weight:800; font-size:11.5px; letter-spacing:.04em; padding:3px 8px; border-radius:4px; flex-shrink:0; }
.promo2 .promo-stickybar .sb-title{ font-weight:700; font-size:14px; flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.promo2 .promo-stickybar .sb-timer{ display:flex; align-items:center; gap:6px; font-variant-numeric:tabular-nums; font-size:13px; font-weight:600; white-space:nowrap; flex-shrink:0; }
.promo2 .promo-stickybar .sb-timer b{ background:rgba(0,0,0,.22); padding:3px 7px; border-radius:4px; font-weight:800; }
.promo2 .promo-stickybar .sb-code{ font-weight:700; font-size:12.5px; background:rgba(255,255,255,.16); border:1px dashed rgba(255,255,255,.55); padding:3px 9px; border-radius:5px; white-space:nowrap; flex-shrink:0; }
.promo2 .promo-stickybar .sb-cta{ background:#fff; color:var(--red); font-weight:800; font-size:13px; padding:8px 16px; border-radius:7px; text-decoration:none; white-space:nowrap; flex-shrink:0; transition:background .15s, color .15s; }
.promo2 .promo-stickybar .sb-cta:hover{ background:var(--lp-savings); color:var(--lp-savings-ink); }
@media (max-width:700px){
  .promo2 .promo-stickybar .sb-code{ display:none; }
  .promo2 .promo-stickybar .sb-title{ font-size:13px; }
  .promo2 .promo-stickybar .sb-timer b:nth-child(n+4){ display:none; } /* drop seconds */
  .promo2 .promo-stickybar .sb-cta{ padding:7px 12px; }
}

/* ============ hero ============ */
/* padding:0 explicitly overrides .lp-content .hero (hero.css) which would
   otherwise apply its own vertical padding when our declaration is removed. */
.promo2 .hero{ background:var(--black); color:#fff; position:relative; overflow:hidden; border-bottom:3px solid var(--blue); padding:0; }
.promo2 .hero::after{ content:""; position:absolute; inset:0; background:radial-gradient(900px 380px at 82% -10%, rgba(252,176,2,.10), transparent 60%), radial-gradient(700px 460px at 0% 120%, rgba(207,28,60,.22), transparent 55%); pointer-events:none; }
.promo2 .hero .wrap{ position:relative; z-index:1; display:grid; grid-template-columns:1.5fr 1fr; gap:0; align-items:stretch; min-height:300px; }
.promo2 .hero .copy{ padding:48px 44px; display:flex; flex-direction:column; justify-content:center; }
.promo2 .hero .kicker{ display:inline-flex; align-items:center; gap:9px; font-size:12.5px !important; font-weight:700 !important; letter-spacing:.13em; text-transform:uppercase; color:var(--gold) !important; margin-bottom:12px !important; }
.promo2 .hero .kicker .dot{ width:8px; height:8px; border-radius:50%; background:var(--red); box-shadow:0 0 0 0 rgba(207,28,60,.7); animation:promo-pulse 2s infinite; }
@keyframes promo-pulse{ 0%{ box-shadow:0 0 0 0 rgba(207,28,60,.6);} 70%{ box-shadow:0 0 0 10px rgba(207,28,60,0);} 100%{ box-shadow:0 0 0 0 rgba(207,28,60,0);} }
.promo2 .hero h1{ font-size:clamp(34px,4.6vw,54px) !important; line-height:1.02 !important; margin:0 0 12px !important; font-weight:800 !important; letter-spacing:-.02em; color:#fff !important; text-shadow:none !important; text-align:left !important; }
.promo2 .hero h1 em{ font-style:normal; color:var(--red); }
.promo2 .hero p{ font-size:16.5px !important; color:#c4c7cf !important; margin:0 0 24px !important; max-width:44ch; line-height:1.45 !important; text-shadow:none !important; }
.promo2 .hero .ctas{ display:flex; gap:12px; flex-wrap:wrap; }
.promo2 .hero .visual{ position:relative; display:flex; align-items:center; justify-content:center; padding:24px; background:rgba(255,255,255,.03); border-left:1px solid rgba(255,255,255,.06); }
.promo2 .hero .visual .big{ font-size:120px; filter:drop-shadow(0 12px 30px rgba(0,0,0,.5)); }
.promo2 .hero .visual img{ max-height:240px; object-fit:contain; mix-blend-mode:normal; filter:drop-shadow(0 12px 30px rgba(0,0,0,.5)); }
.promo2 .hero .pct{ position:absolute; top:26px; right:26px; background:var(--lp-savings); color:var(--lp-savings-ink); width:94px; height:94px; border-radius:50%; display:flex; flex-direction:column; align-items:center; justify-content:center; font-weight:800; line-height:1; box-shadow:0 8px 22px rgba(0,0,0,.4); transform:rotate(8deg); z-index:2; }
.promo2 .hero .pct .u{ font-size:30px !important; color:var(--lp-savings-ink) !important; }
.promo2 .hero .pct .l{ font-size:11px !important; margin-top:3px; letter-spacing:.05em; color:var(--lp-savings-ink) !important; }
.promo2 .hero .pct .l-top{ margin-top:0; margin-bottom:1px; }

/* Map-doodle texture (inline SVG) behind the hero — no raster asset, scales to
   any width. Used as the hero background when the promo has NO coupon badge. */
.promo2 .hero .tex{ position:absolute; inset:0; z-index:0; opacity:.10; background-size:220px 220px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220' viewBox='0 0 220 220'><g fill='none' stroke='%23ffffff' stroke-width='2'><circle cx='40' cy='40' r='16'/><path d='M30 40h20M40 30v20'/><rect x='150' y='28' width='30' height='24' rx='3'/><path d='M150 36h30'/><path d='M70 150l18-10 18 10-18 10z'/><path d='M120 120l14 0 0 14-14 0z'/><circle cx='175' cy='160' r='12'/><path d='M120 60q20 20 0 40'/><path d='M20 120h26M33 110v20'/><path d='M180 100l8 14h-16z'/></g></svg>"); }

/* No-badge hero: copy spans the full width (no right-hand visual panel). */
.promo2 .hero.no-badge .wrap{ grid-template-columns:1fr; }
.promo2 .hero.no-badge .copy{ position:relative; z-index:1; }

/* Coupon-badge hero: right-hand framed panel with the stored badge + code. */
.promo2 .hero .badge-panel{ position:relative; z-index:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; padding:24px; background:rgba(255,255,255,.04); border-left:1px solid rgba(255,255,255,.06); }
.promo2 .hero .badge-panel .frame{ background:#fff; border-radius:14px; padding:14px; box-shadow:0 12px 30px rgba(0,0,0,.45); }
.promo2 .hero .badge-panel .frame img{ max-width:200px; max-height:200px; object-fit:contain; display:block; }
.promo2 .hero .badge-panel .code{ text-align:center; }
.promo2 .hero .badge-panel .code .lbl{ font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); margin-bottom:4px; }
.promo2 .hero .badge-panel .code .val{ font-size:22px; font-weight:800; letter-spacing:.05em; color:#fff; background:rgba(255,255,255,.08); border:1px dashed rgba(255,255,255,.35); border-radius:8px; padding:6px 14px; display:inline-block; }

/* ============ value strip ============ */
.promo2 .vstrip{ background:var(--offblack); color:#e3e5ea; }
.promo2 .vstrip .wrap{ display:flex; justify-content:space-between; gap:8px; flex-wrap:wrap; padding:13px 24px; }
.promo2 .vstrip .v{ display:flex; align-items:center; gap:9px; font-size:13.5px; }
.promo2 .vstrip .v b{ color:#fff; font-weight:700; }
.promo2 .vstrip .ic{ font-size:18px; }

/* ============ spotlight: split hero + supporting ============ */
.promo2 .spotlight{ display:grid; grid-template-columns:1.55fr 1fr; gap:16px; }
.promo2 .hsplit{ display:grid; grid-template-columns:1fr 1fr; border-radius:16px; overflow:hidden; background:var(--offblack); box-shadow:var(--p-shadow); text-decoration:none; color:#fff; min-height:380px; }
.promo2 .hsplit .imgcol{ position:relative; display:flex; align-items:center; justify-content:center; padding:26px; }
.promo2 .hsplit .imgcol img{ max-width:100%; max-height:300px; object-fit:contain; mix-blend-mode:multiply; }
.promo2 .hsplit .pct{ position:absolute; top:16px; left:16px; background:var(--lp-savings); color:var(--lp-savings-ink); font-size:14px; font-weight:800; padding:6px 12px; border-radius:8px; z-index:2; }
.promo2 .hsplit .copycol{ background:var(--offblack); padding:30px 32px; display:flex; flex-direction:column; justify-content:center; }
.promo2 .hsplit .eyebrow{ font-size:11.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); margin-bottom:10px; }
.promo2 .hsplit h3{ font-size:26px !important; font-weight:800 !important; margin:0 0 12px !important; line-height:1.08 !important; color:#fff !important; }
.promo2 .hsplit .pr{ display:flex; align-items:baseline; gap:10px; margin-bottom:8px; }
.promo2 .hsplit .pr .now{ font-size:29px; font-weight:800; }
.promo2 .hsplit .pr .was{ font-size:16px; color:#b6b9c0; text-decoration:line-through; }
.promo2 .hsplit .sub{ font-size:13.5px; color:#cdd0d7; line-height:1.5; }
.promo2 .hsplit .go{ display:inline-flex; align-self:flex-start; margin-top:16px; background:#fff; color:var(--p-text-dk); font-weight:700; font-size:14px; padding:11px 19px; border-radius:8px; transition:background .15s; }
.promo2 .hsplit .go:hover{ background:var(--grey); }
.promo2 .hsplit.panel-grad .imgcol{ background:linear-gradient(90deg,#fff 60%,#eef0f3 100%); }
.promo2 .hsplit.panel-white .imgcol{ background:#fff; }
.promo2 .hsplit.panel-grey  .imgcol{ background:var(--grey); }

.promo2 .spot-support{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
/* Steam-style supporting deal card: image fills the frame (zoom/crop "V1"
   treatment kept), price block sits on a solid bottom bar. Discount shows ONCE
   here, in the green chip — no top-left pill. */
.promo2 .sd{ position:relative; border-radius:14px; overflow:hidden; min-height:200px; background:var(--offblack); color:#fff; display:block; text-decoration:none; transition:transform .12s, box-shadow .15s; }
.promo2 .sd:hover{ transform:translateY(-2px); box-shadow:0 12px 30px rgba(8,8,8,.18); }
.promo2 .sd .img{ position:absolute; left:0; right:0; top:0; bottom:62px; overflow:hidden; background:#fff; }
.promo2 .sd .img img{ width:100%; height:100%; object-fit:cover; transform:scale(var(--zoom,1.4)); transform-origin:var(--ox,54%) var(--oy,44%); }
.promo2 .sd .bar{ position:absolute; left:0; right:0; bottom:0; height:62px; background:var(--offblack); padding:9px 12px; display:flex; flex-direction:column; justify-content:center; gap:5px; border-top:1px solid rgba(255,255,255,.06); }
.promo2 .sd .nm{ font-size:12px; font-weight:600; line-height:1.2; color:#e8eaee; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.promo2 .sd .prow{ display:flex; align-items:center; gap:8px; }
.promo2 .sd .chip{ background:var(--lp-savings); color:var(--lp-savings-ink); font-size:12px; font-weight:800; padding:2px 7px; border-radius:4px; }
.promo2 .sd .was{ font-size:11.5px; color:#8b909a; text-decoration:line-through; }
.promo2 .sd .now{ font-size:14.5px; font-weight:800; color:#fff; margin-left:auto; }

/* ============ category tiles (treatment C) ============ */
.promo2 .cat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.promo2 .tC{ position:relative; border-radius:14px; overflow:hidden; aspect-ratio:1.1/1; background:var(--offblack); display:block; text-decoration:none; }
.promo2 .tC .imgwrap{ position:absolute; inset:0; overflow:hidden; }
.promo2 .tC .imgwrap img{ width:100%; height:100%; object-fit:cover; transform:scale(var(--zoom,1.45)); transform-origin:var(--ox,54%) var(--oy,46%); }
.promo2 .tC .bar{ position:absolute; left:0; right:0; bottom:0; padding:34px 18px 16px; z-index:2; background:linear-gradient(0deg, rgba(8,8,8,.96) 0%, rgba(8,8,8,.82) 42%, rgba(8,8,8,0) 100%); color:#fff; }
.promo2 .tC .nm{ font-size:17px; font-weight:800; line-height:1.1; }
.promo2 .tC .ct{ font-size:12px; font-weight:700; color:var(--gold); margin-top:3px; }
.promo2 .tC .arrow{ position:absolute; top:14px; right:14px; width:32px; height:32px; border-radius:50%; background:rgba(255,255,255,.16); backdrop-filter:blur(4px); color:#fff; display:flex; align-items:center; justify-content:center; font-size:14px; z-index:3; transition:background .15s; }
.promo2 .tC:hover .arrow{ background:var(--red); }
.promo2 .tC.shopall{ background:var(--offblack-2); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; }
.promo2 .tC.shopall .ic{ font-size:26px; }
.promo2 .tC.shopall .lbl{ font-size:18px; font-weight:800; color:#fff; }

/* ============ product grid + facet rail ============ */
.promo2 .shop{ display:grid; grid-template-columns:248px 1fr; gap:26px; align-items:start; }
.lp-content .filters{ gap:0; }
.promo2 .filters{ background:#fff; border:1px solid var(--line); border-radius:14px; position:sticky; top:162px; overflow:hidden; box-shadow:var(--p-shadow); }
.promo2 .filters .fh{ width:100%; padding:14px 16px; border-bottom:1px solid var(--line); display:flex; justify-content:space-between; align-items:center; }
.promo2 .filters .fh b{ font-size:14px; color:var(--p-text-dk); }
.promo2 .filters .fh button{ background:none; border:0; color:var(--red); font-size:12.5px; font-weight:700; }

/* Theme the shared facet-rail module (csr-includes/facets/facet-rail.css) with
   the promo page's palette. The rail markup/logic lives in the reusable module;
   only colors are mapped here. */
.promo2 .wrf-rail{
  width:100%;
  --wrf-accent:  var(--red);
  --wrf-text:    var(--p-text);
  --wrf-text-dk: var(--p-text-dk);
  --wrf-muted:   var(--p-muted);
  --wrf-line:    var(--line);
  --wrf-line-2:  var(--line-2);
  --wrf-grey:    var(--grey);
  --wrf-bg:      #fff;
  --wrf-radius:  8px;
}
.promo2 .fgroup{ border-bottom:1px solid var(--line); }
.promo2 .fgroup summary{ list-style:none; cursor:pointer; padding:13px 16px; font-weight:700; font-size:13px; display:flex; justify-content:space-between; align-items:center; color:var(--p-text-dk); }
.promo2 .fgroup summary::-webkit-details-marker{ display:none; }
.promo2 .fgroup summary .cv{ color:var(--p-muted); transition:transform .2s; }
.promo2 .fgroup[open] summary .cv{ transform:rotate(180deg); }
.promo2 .fgroup .ns{ font-size:10px; text-transform:uppercase; letter-spacing:.07em; color:var(--p-muted); padding:0 16px 4px; }
.promo2 .fgroup .body{ padding:2px 16px 14px; max-height:230px; overflow-y:auto; }
.promo2 .fo{ display:flex; align-items:center; gap:9px; padding:5px 0; font-size:13px; color:var(--p-text); cursor:pointer; }
.promo2 .fo input{ width:15px; height:15px; accent-color:var(--red); }
.promo2 .fo .n{ margin-left:auto; font-size:11.5px; color:var(--p-muted); }
.promo2 .fo.is-zero{ opacity:.4; }
.promo2 .results-top{ display:flex; align-items:center; justify-content:space-between; gap:12px; background:var(--grey); border-radius:12px; padding:11px 16px; margin-bottom:16px; flex-wrap:wrap; }
.promo2 .results-top .rt{ display:flex; align-items:center; gap:10px; }
.promo2 .results-top .count{ font-size:13px; color:var(--p-muted); font-weight:600; }
.promo2 .results-top select{ font:inherit; font-size:13px; padding:8px 11px; border:1px solid var(--line-2); border-radius:8px; background:#fff; }
.promo2 .viewtoggle{ display:inline-flex; border:1px solid var(--line-2); border-radius:8px; overflow:hidden; background:#fff; }
.promo2 .viewtoggle button{ border:0; background:#fff; padding:7px 11px; font-size:15px; line-height:1; color:var(--p-muted); }
.promo2 .viewtoggle button + button{ border-left:1px solid var(--line-2); }
.promo2 .viewtoggle button.is-active{ background:var(--red); color:#fff; }
.promo2 .chips{ display:flex; gap:8px; flex-wrap:wrap; }
.promo2 .chip{ display:inline-flex; align-items:center; gap:7px; font-size:12.5px; font-weight:600; background:#fff; border:1px solid var(--line-2); border-radius:20px; padding:6px 10px 6px 12px; }
.promo2 .chip button{ border:0; background:none; font-size:14px; color:var(--p-muted); line-height:1; }
.promo2 .pgrid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.promo2 .p{ background:var(--grey); border-radius:14px; overflow:hidden; display:flex; flex-direction:column; position:relative; transition:box-shadow .15s, transform .12s; text-decoration:none; color:inherit; }
.promo2 .p:hover{ box-shadow:var(--p-shadow); transform:translateY(-2px); }
.promo2 .p .pimg{ height:200px; display:flex; align-items:center; justify-content:center; position:relative; background:#fff; padding:14px; }
.promo2 .p .pimg img{ max-width:100%; max-height:100%; object-fit:contain; mix-blend-mode:multiply; }
.promo2 .p .save{ position:absolute; top:14px; left:14px; background:var(--lp-savings); color:var(--lp-savings-ink); font-size:12.5px; font-weight:700; padding:5px 11px; border-radius:6px; z-index:2; }
.promo2 .p .flag{ position:absolute; top:14px; right:14px; background:var(--gold); color:#3a2a07; font-size:10.5px; font-weight:800; padding:4px 8px; border-radius:6px; z-index:2; }
/* Unavailable item (sold out / package with dead components). Still listed, but
   visibly flagged and de-emphasized; it has already been sunk to the grid bottom. */
.promo2 .p .oos{ position:absolute; top:14px; right:14px; background:#374151; color:#fff; font-size:10.5px; font-weight:800; letter-spacing:.03em; text-transform:uppercase; padding:4px 8px; border-radius:6px; z-index:2; }
.promo2 .p.unavail .pimg img{ filter:grayscale(1); opacity:.5; }
.promo2 .p.unavail .save{ display:none; }
.promo2 .p .stockline{ font-size:11.5px; font-weight:700; color:#9ca3af; margin-top:6px; }
.promo2 .p .body{ padding:14px 16px 16px; display:flex; flex-direction:column; flex:1; }
.promo2 .p .model{ font-size:10.5px; text-transform:uppercase; letter-spacing:.04em; color:var(--p-muted); margin-bottom:3px; }
.promo2 .p h3{ font-size:14px !important; line-height:1.32 !important; font-weight:700 !important; color:var(--p-text-dk) !important; margin:0 0 7px !important; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; min-height:37px; }
.promo2 .p .rev{ font-size:12px; color:var(--gold); margin-bottom:8px; }
.promo2 .p .rev span{ color:var(--p-muted); }
.promo2 .p .pr{ display:flex; align-items:baseline; gap:7px; }
.promo2 .p .pr .now{ font-size:20px; font-weight:800; color:var(--red); }
.promo2 .p .pr .was{ font-size:12.5px; color:var(--p-muted); text-decoration:line-through; }
.promo2 .p .yousave{ font-size:11.5px; color:#15803d; font-weight:700; margin-top:2px; }
.promo2 .p .buy{ margin-top:12px; background:var(--black); color:#fff; border:0; border-radius:8px; padding:11px; font-weight:700; font-size:13.5px; transition:background .15s; text-align:center; text-decoration:none; }
.promo2 .p .buy:hover{ background:var(--offblack); }
.promo2 .pgrid-empty{ grid-column:1/-1; text-align:center; color:var(--p-muted); padding:40px 0; font-size:15px; }
.promo2 .loadmore{ display:block; margin:28px auto 0; background:#fff; border:1.5px solid var(--red); color:var(--red); font-weight:700; font-size:14px; padding:12px 32px; border-radius:8px; transition:background .15s, color .15s; }
.promo2 .loadmore:hover{ background:var(--red); color:#fff; }
.promo2 .loadmore[hidden]{ display:none; }
.promo2 .mfilter{ display:none; width:100%; justify-content:center; gap:8px; background:#fff; border:1px solid var(--line-2); border-radius:8px; padding:11px; font-weight:700; font-size:14px; margin-bottom:14px; }

/* list view (toggle) */
.promo2 .pgrid.list{ display:flex; flex-direction:column; gap:12px; }
.promo2 .pgrid.list .p{ flex-direction:row; align-items:stretch; }
.promo2 .pgrid.list .p .pimg{ width:200px; height:200px; flex-shrink:0; }
.promo2 .pgrid.list .p .body{ flex:1; }
.promo2 .pgrid.list .p h3{ min-height:0; }
.promo2 .pgrid.list .p .buy{ align-self:flex-start; padding-left:28px; padding-right:28px; }
@media (max-width:560px){
  .promo2 .pgrid.list .p{ flex-direction:column; }
  .promo2 .pgrid.list .p .pimg{ width:100%; }
}

/* ============ advantage ============ */
.promo2 .adv{ background:var(--offwhite); }
.promo2 .adv .top{ display:grid; grid-template-columns:1.4fr 1fr; gap:32px; align-items:start; margin-bottom:24px; }
.promo2 .adv .feature{ background:#fff; border:1px solid var(--line); border-radius:16px; padding:24px; box-shadow:var(--p-shadow); }
.promo2 .adv .feature .ph-img{ width:100%; border-radius:12px; aspect-ratio:16/10; background:var(--offblack); display:flex; align-items:center; justify-content:center; font-size:60px; color:#4b5563; margin-bottom:18px; overflow:hidden; }
.promo2 .adv .feature .ph-img img{ width:100%; height:100%; object-fit:cover; }
.promo2 .adv .feature h3{ font-size:21px !important; font-weight:800 !important; margin:0 0 10px !important; color:var(--p-text-dk) !important; }
.promo2 .adv .feature p{ font-size:14.5px !important; line-height:1.6 !important; color:var(--p-text) !important; margin:0 0 18px !important; }
.promo2 .adv .points{ display:flex; flex-direction:column; gap:20px; padding-top:6px; }
.promo2 .adv .pt{ display:flex; gap:14px; }
.promo2 .adv .pt .ic{ font-size:22px; flex-shrink:0; }
.promo2 .adv .pt h4{ margin:0 0 3px !important; font-size:15.5px !important; font-weight:700 !important; color:var(--p-text-dk) !important; }
.promo2 .adv .pt p{ margin:0 !important; font-size:13.5px !important; color:var(--p-muted) !important; line-height:1.5 !important; }
.promo2 .adv .grid4{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.promo2 .adv .mini{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:22px 18px; text-align:center; }
.promo2 .adv .mini .ic{ font-size:30px; margin-bottom:10px; }
.promo2 .adv .mini h4{ margin:0 0 7px !important; font-size:15px !important; font-weight:700 !important; color:var(--p-text-dk) !important; }
.promo2 .adv .mini p{ margin:0 !important; font-size:13px !important; color:var(--p-muted) !important; line-height:1.5 !important; }

/* ============ reviews ============ */
.promo2 .proof{ background:var(--black); color:#fff; }
.promo2 .proof .wrap{ padding:48px 24px; }
.promo2 .proof .head{ text-align:center; margin-bottom:28px; }
.promo2 .proof .head h2{ font-size:26px !important; font-weight:800 !important; margin:0 0 8px !important; color:#fff !important; }
.promo2 .proof .head .agg{ font-size:14px; color:#aeb3bd; }
.promo2 .proof .head .agg b{ color:var(--gold); }
.promo2 .qs{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.promo2 .quote{ background:var(--offblack); border:1px solid #2a2c31; border-radius:14px; padding:22px; }
.promo2 .quote .stars{ color:var(--gold); margin-bottom:10px; font-size:15px; }
.promo2 .quote p{ font-size:14.5px !important; line-height:1.55 !important; color:#dde0e6 !important; margin:0 0 14px !important; }
.promo2 .quote .who{ font-size:13px; color:#9aa0ac; font-weight:600; }

/* ============ showroom ============ */
.promo2 .showroom{ background:var(--offwhite); }
.promo2 .showroom .card{ background:#fff; border:1px solid var(--line); border-radius:16px; box-shadow:var(--p-shadow); display:grid; grid-template-columns:380px 1fr; gap:0; overflow:hidden; }
.promo2 .showroom .ph{ background:var(--offblack); display:flex; align-items:center; justify-content:center; font-size:72px; color:#4b5563; min-height:300px; overflow:hidden; }
.promo2 .showroom .ph img{ width:100%; height:100%; object-fit:cover; }
.promo2 .showroom .body{ padding:36px 40px; display:flex; flex-direction:column; justify-content:center; }
.promo2 .showroom .body h2{ font-size:26px !important; font-weight:800 !important; margin:0 0 12px !important; color:var(--p-text-dk) !important; }
.promo2 .showroom .body p{ font-size:15px !important; line-height:1.6 !important; color:var(--p-text) !important; margin:0 0 22px !important; max-width:54ch; }

/* ============ finale ============ */
.promo2 .finale{ background:var(--black); color:#fff; text-align:center; border-top:3px solid var(--red); }
.promo2 .finale .wrap{ padding:54px 24px; }
.promo2 .finale h2{ font-size:28px !important; font-weight:800 !important; margin:0 0 10px !important; color:#fff !important; }
.promo2 .finale p{ color:#aeb3bd !important; margin:0 0 22px !important; font-size:16px !important; }

/* ============ responsive ============ */
@media (max-width:1000px){
  .promo2 .spotlight{ grid-template-columns:1fr; }
  .promo2 .cat-grid{ grid-template-columns:repeat(2,1fr); }
  .promo2 .pgrid{ grid-template-columns:repeat(3,1fr); }
  .promo2 .adv .grid4{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:860px){
  .promo2 .hero .wrap{ grid-template-columns:1fr; }
  .promo2 .hero .visual{ min-height:170px; border-left:0; border-top:1px solid rgba(255,255,255,.06); }
  .promo2 .hero .copy{ padding:36px 24px; }
  .promo2 .shop{ grid-template-columns:1fr; }
  .promo2 .filters{ position:static; }
  .promo2 .mfilter{ display:flex; }
  .promo2 .pgrid{ grid-template-columns:repeat(2,1fr); }
  .promo2 .adv .top{ grid-template-columns:1fr; }
  .promo2 .qs{ grid-template-columns:1fr; }
  .promo2 .showroom .card{ grid-template-columns:1fr; }
  .promo2 .showroom .ph{ min-height:200px; }
  .promo2 .showroom .body{ padding:28px 24px; }
}
@media (max-width:760px){
  .promo2 .hsplit{ grid-template-columns:1fr; }
  .promo2 .hsplit .imgcol{ min-height:220px; }
  .promo2 .hsplit .copycol{ padding:26px; }
  .promo2 .hsplit h3{ font-size:22px !important; }
  .promo2 .hsplit .pr .now{ font-size:25px; }
}
@media (max-width:560px){
  .promo2 .spot-support{ grid-template-columns:1fr 1fr; }
  .promo2 .cat-grid{ grid-template-columns:1fr 1fr; }
  .promo2 .pgrid{ grid-template-columns:repeat(2,1fr); }
  .promo2 .adv .grid4{ grid-template-columns:1fr; }
  .promo2 .dealbar .timer b:nth-child(n+3){ display:none; }
  .promo2 section{ padding:32px 0; }
}
@media (max-width:400px){
  .promo2 .pgrid{ grid-template-columns:1fr; }
  .promo2 .cat-grid{ grid-template-columns:1fr; }
}
