/* ===== page-level CSS: home, listing, product, cart, checkout, account ===== */

/* ---------- HERO ---------- */
.hero{position:relative;border-radius:var(--r-xl);overflow:hidden;height:clamp(380px,46vw,540px);margin-top:24px;background:var(--ink)}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity .7s var(--ease)}
.hero-slide.on{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover}
.hero-slide::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(17,17,17,.72) 0%,rgba(17,17,17,.35) 45%,transparent 75%)}
.hero-content{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;padding:0 clamp(28px,6vw,76px);max-width:640px;z-index:2}
.hero-content .eyebrow{color:#fff;opacity:.9}
.hero-content h1{color:#fff;font-size:clamp(32px,4.6vw,58px);line-height:1.03;margin:14px 0 16px;white-space:pre-line}
.hero-content p{color:rgba(255,255,255,.88);font-size:clamp(15px,1.5vw,19px);max-width:440px;margin-bottom:28px}
.hero-dots{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:3}
.hero-dots button{width:30px;height:5px;border-radius:3px;background:rgba(255,255,255,.4);transition:.2s}
.hero-dots button.on{background:#fff;width:46px}
.hero-arrows{position:absolute;right:22px;bottom:22px;display:flex;gap:8px;z-index:3}
.hero-arrows button{width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.16);backdrop-filter:blur(6px);color:#fff;display:grid;place-items:center;transition:.16s}
.hero-arrows button:hover{background:#fff;color:var(--ink)}
@media(max-width:680px){.hero-content p{display:none}.hero-arrows{display:none}}

.section{padding-top:54px;padding-bottom:54px}
.section-tight{padding-top:30px;padding-bottom:30px}

/* ---------- category tiles ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cat-tile{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:1/1;display:block;background:var(--bg-2)}
.cat-tile:first-child{grid-row:span 2;aspect-ratio:auto}
.cat-tile img{width:100%;height:100%;object-fit:cover;transition:.5s var(--ease)}
.cat-tile:hover img{transform:scale(1.06)}
.cat-tile::after{content:'';position:absolute;inset:0;background:linear-gradient(transparent 40%,rgba(17,17,17,.72))}
.cat-tile-body{position:absolute;left:20px;bottom:18px;right:20px;z-index:2;color:#fff}
.cat-tile-body b{font-size:19px;font-weight:800;display:block}
.cat-tile-body span{font-size:13px;opacity:.85;display:inline-flex;align-items:center;gap:5px;margin-top:3px}
@media(max-width:860px){.cat-grid{grid-template-columns:repeat(2,1fr)}.cat-tile:first-child{grid-row:auto;aspect-ratio:1/1}}

/* ---------- tabs ---------- */
.tabs{display:flex;gap:6px;border-bottom:1px solid var(--line);margin-bottom:26px;flex-wrap:wrap}
.tab{padding:12px 0;margin-right:24px;font-weight:700;font-size:16px;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:.16s}
.tab.on{color:var(--ink);border-color:var(--red)}
.tab:hover{color:var(--ink)}

/* ---------- promo split ---------- */
.promo-split{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.promo-card{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:240px;display:flex;align-items:center;padding:38px}
.promo-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.promo-card::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(17,17,17,.6),transparent)}
.promo-card .pc-in{position:relative;z-index:2;color:#fff}
@media(max-width:680px){.promo-split{grid-template-columns:1fr}}

/* ---------- big banner ---------- */
.bigbanner{border-radius:var(--r-xl);background:linear-gradient(120deg,var(--red-darker),var(--red));color:#fff;padding:clamp(36px,5vw,64px);display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;overflow:hidden;position:relative}
.bigbanner::before{content:'';position:absolute;right:-60px;top:-60px;width:320px;height:320px;border-radius:50%;background:rgba(255,255,255,.08)}
.bigbanner h2{font-size:clamp(24px,3vw,34px);max-width:520px;line-height:1.08}

/* horizontal carousel */
.hscroll{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:8px}
.hscroll>*{scroll-snap-align:start;flex:0 0 clamp(220px,24vw,280px)}

/* brand strip */
.brandstrip{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.brand-chip{padding:14px 28px;border:1px solid var(--line);border-radius:var(--r-md);font-weight:800;font-size:16px;letter-spacing:.02em;color:var(--ink-2);background:#fff}

/* ---------- listing / category ---------- */
.list-layout{display:grid;grid-template-columns:264px 1fr;gap:34px;align-items:start}
.filters{position:sticky;top:120px}
.filter-block{border-bottom:1px solid var(--line);padding:20px 0}
.filter-block:first-child{padding-top:0}
.filter-block h4{font-size:14px;font-weight:800;margin-bottom:14px;display:flex;justify-content:space-between;align-items:center}
.fcheck{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:14px;color:var(--ink-2);cursor:pointer}
.fcheck input{width:18px;height:18px;accent-color:var(--red);cursor:pointer}
.fcheck:hover{color:var(--red)}
.fcheck .ct{margin-left:auto;font-size:12px;color:var(--muted-2)}
.swatch-row{display:flex;flex-wrap:wrap;gap:9px}
.swatch{width:30px;height:30px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1.5px var(--line);cursor:pointer}
.swatch.on{box-shadow:0 0 0 2px var(--red)}
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--bg-2);border-radius:var(--r-md);padding:12px 16px;margin-bottom:22px;flex-wrap:wrap}
.toolbar-views{display:flex;gap:4px}
.view-btn{width:38px;height:38px;border-radius:var(--r-sm);display:grid;place-items:center;color:var(--muted)}
.view-btn.on{background:#fff;color:var(--ink);box-shadow:var(--sh-1)}
.cmp-btn{display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:13.5px;color:var(--ink-2);padding:9px 14px;border-radius:var(--r-md);border:1.5px solid var(--line);background:#fff;transition:.14s}
.cmp-btn:hover{border-color:var(--ink)}
.cmp-btn.on{border-color:var(--red);color:var(--red);background:var(--red-tint)}
.cmp-btn b{color:var(--red)}
.chiprow{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.chip{display:inline-flex;align-items:center;gap:7px;background:var(--red-tint);color:var(--red);border-radius:var(--r-full);padding:7px 13px;font-size:13px;font-weight:600}
.chip button{display:grid;place-items:center;color:var(--red)}
.pager{display:flex;gap:6px;justify-content:center;margin-top:40px}
.pager button{min-width:42px;height:42px;border-radius:var(--r-md);border:1.5px solid var(--line);font-weight:700;display:grid;place-items:center;background:#fff}
.pager button.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.pager button:hover:not(.on){border-color:var(--ink)}
.cat-hero{border-radius:var(--r-lg);overflow:hidden;position:relative;height:200px;margin-bottom:8px;display:flex;align-items:center;padding:0 40px}
.cat-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cat-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(17,17,17,.65),transparent)}
.cat-hero .ch-in{position:relative;z-index:2;color:#fff}
.filter-toggle{display:none}

/* ---------- PDP ---------- */
.pdp{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:start}
.pdp-gallery{display:grid;grid-template-columns:78px 1fr;gap:14px;position:sticky;top:120px}
.pdp-thumbs{display:flex;flex-direction:column;gap:10px}
.pdp-thumb{border-radius:var(--r-md);overflow:hidden;aspect-ratio:1/1;border:2px solid var(--line);background:var(--bg-2)}
.pdp-thumb.on{border-color:var(--red)}
.pdp-thumb img{width:100%;height:100%;object-fit:cover}
.pdp-main{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:1/1;background:var(--bg-2)}
.pdp-main img{width:100%;height:100%;object-fit:cover}
.pdp-badges{position:absolute;top:16px;left:16px;display:flex;flex-direction:column;gap:6px}
.pdp-opt{padding:16px 0;border-top:1px solid var(--line-2)}
.pdp-colorbtn{padding:10px 16px;border:1.5px solid var(--line);border-radius:var(--r-md);font-weight:600;font-size:14px;background:#fff;transition:.14s}
.pdp-colorbtn.on{border-color:var(--red);background:var(--red-tint);color:var(--red)}
.pdp-colorbtn:hover{border-color:var(--ink)}
.pdp-stock{padding:16px 0;border-top:1px solid var(--line-2);font-size:15px}
.pdp-buy{display:flex;gap:12px;align-items:stretch;min-width:0;flex-wrap:wrap}
.pdp-buy .btn{height:auto;flex:1 1 170px;min-width:0;white-space:normal}
.link-act{display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:14px;color:var(--ink-2)}
.link-act:hover{color:var(--red)}
.pdp-perks{margin-top:24px;border-top:1px solid var(--line);padding-top:22px;display:grid;gap:16px}
.perk{display:flex;align-items:center;gap:13px}
.perk b{display:block;font-size:14px}
.perk span{font-size:13px;color:var(--muted)}
.pdp-tabbody{padding-top:8px}
/* impressive red rounded tabs */
.pdp-tabs{display:flex;gap:6px;position:relative;z-index:2}
.pdp-tab{padding:14px 26px;font-weight:700;font-size:15px;color:var(--ink-2);background:var(--bg-2);border-radius:var(--r-md) var(--r-md) 0 0;transition:.16s var(--ease);position:relative;top:1px}
.pdp-tab:hover{color:var(--ink);background:var(--bg-3)}
.pdp-tab.on{background:var(--red);color:#fff}
.pdp-tabpanel{background:var(--bg-2);border-radius:0 var(--r-lg) var(--r-lg) var(--r-lg);padding:34px}
@media(max-width:600px){.pdp-tabs{flex-wrap:nowrap;overflow-x:auto;gap:6px;scrollbar-width:none;-webkit-overflow-scrolling:touch}.pdp-tabs::-webkit-scrollbar{display:none}.pdp-tab{flex:0 0 auto;padding:11px 18px;font-size:13.5px;border-radius:var(--r-md) var(--r-md) 0 0}.pdp-tabpanel{border-radius:0 var(--r-lg) var(--r-lg) var(--r-lg);padding:22px}}
/* layout safety: prevent grid/flex children from forcing horizontal overflow */
.pdp,.list-layout,.cart-layout,.contact-grid,.acc-layout{min-width:0}
.pdp>*,.list-layout>*,.cart-layout>*,.acc-layout>*{min-width:0}
.pdp-info,.pdp-gallery{min-width:0}
/* sale urgency strip */
.pdp-urgency{display:flex;align-items:center;justify-content:space-between;gap:14px;background:var(--red-tint);border:1px solid var(--red-tint-2);border-radius:var(--r-md);padding:12px 16px;margin-bottom:14px;flex-wrap:wrap}
.pdp-urgency-l{font-size:13.5px;font-weight:700;color:var(--red);display:inline-flex;align-items:center;gap:7px}
.spec-table{width:100%;max-width:620px;border-collapse:collapse}
.spec-table tr{border-bottom:1px solid var(--line-2)}
.spec-table th{text-align:left;padding:14px 0;font-weight:600;color:var(--muted);width:40%;font-size:14.5px}
.spec-table td{padding:14px 0;font-weight:600;font-size:14.5px}
.reviews{max-width:780px}
.rev-summary{display:flex;gap:32px;align-items:center;background:var(--bg-2);border-radius:var(--r-lg);padding:24px;flex-wrap:wrap}
.rev-score{text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px}
.rev-score b{font-size:46px;font-weight:900;line-height:1}
.rev-item{display:flex;gap:14px;padding:22px 0;border-bottom:1px solid var(--line-2)}
.rev-av{width:46px;height:46px;border-radius:50%;background:var(--red-tint);color:var(--red);display:grid;place-items:center;font-weight:800;font-size:18px;flex-shrink:0}
@media(max-width:860px){
  .pdp{grid-template-columns:1fr;gap:28px}
  .pdp-gallery{position:static}
  .rev-summary{gap:20px}
}
@media(max-width:520px){
  .pdp-gallery{grid-template-columns:1fr}
  .pdp-thumbs{flex-direction:row;order:2}
  .pdp-thumb{width:64px;flex-shrink:0}
}
@media(max-width:900px){
  .list-layout{grid-template-columns:1fr}
  .filters{position:fixed;top:0;left:0;bottom:0;width:min(86vw,340px);background:#fff;z-index:100;padding:20px;overflow-y:auto;transform:translateX(-100%);transition:.25s var(--ease);box-shadow:var(--sh-3)}
  .filters.open{transform:none}
  .filter-toggle{display:inline-flex}
}
