/* ==========================================================================
   StrapFit Studio — compatible watch straps storefront
   Palette: warm cream · navy · steel blue · gold · forest green
   Type:    Fraunces (display) + Inter (UI)
   ========================================================================== */

:root {
  --ink:#14151a; --ink-2:#4c4943; --paper:#fbf8f2; --card:#fff; --muted:#6f6b63;
  --line:#e7dfd2; --line-2:#efe9dd; --navy:#111827; --navy-2:#1b2230;
  --blue:#2f5f8f; --blue-d:#244c73; --sand:#d7b980; --sand-d:#b7945a;
  --green:#1f7a5c; --red:#b54343;
  --shadow-sm:0 6px 18px rgba(16,17,20,.06);
  --shadow:0 14px 40px rgba(16,17,20,.10);
  --shadow-lg:0 26px 70px rgba(16,17,20,.16);
  --radius:18px; --radius-lg:28px; --max:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --font-ui:"Inter",ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif;
  --font-display:"Fraunces","Iowan Old Style",Georgia,serif;
}

* { box-sizing:border-box; }
html { scroll-behavior:smooth; scroll-padding-top:96px; }
body { margin:0; background:var(--paper); color:var(--ink); font-family:var(--font-ui); line-height:1.6; -webkit-font-smoothing:antialiased; }
a { text-decoration:none; color:inherit; }
button,a.btn,input,select { font:inherit; }
img,svg { display:block; max-width:100%; }
h1,h2,h3,h4,p { margin:0; }
h1,h2,h3 { font-family:var(--font-display); font-weight:600; letter-spacing:-.015em; }
h1 { font-size:clamp(34px,5vw,56px); line-height:1.04; }
h2 { font-size:clamp(26px,3.4vw,40px); line-height:1.08; }
h3 { font-size:18px; line-height:1.3; }

.kicker { font-family:var(--font-ui); font-size:12px; font-weight:700; color:var(--blue); text-transform:uppercase; letter-spacing:.15em; }
.kicker.accent-sand { color:var(--sand); }
.muted { color:var(--muted); }

.skip-link { position:absolute; left:12px; top:-60px; background:var(--navy); color:#fff; padding:10px 16px; border-radius:10px; z-index:100; transition:top .2s var(--ease); }
.skip-link:focus { top:12px; }

/* Icons */
.icon { width:22px; height:22px; flex:none; }
.stars { display:inline-flex; gap:1px; }
.star-fill { color:var(--sand); fill:var(--sand); width:16px; height:16px; }
.star-empty { color:var(--line); width:16px; height:16px; }

/* Buttons */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; border:0; border-radius:999px; padding:13px 22px; background:var(--blue); color:#fff; font-weight:700; cursor:pointer; box-shadow:0 8px 20px rgba(47,95,143,.24); transition:transform .18s var(--ease),box-shadow .18s var(--ease),background .18s var(--ease); }
.btn .icon { width:18px; height:18px; }
.btn:hover { background:var(--blue-d); transform:translateY(-2px); }
.btn:active { transform:translateY(0); }
.btn[disabled] { opacity:.5; cursor:not-allowed; transform:none; box-shadow:none; }
.btn.alt { background:#fff; color:var(--ink); border:1px solid var(--line); box-shadow:var(--shadow-sm); }
.btn.alt:hover { background:#fff; border-color:var(--sand); }
.btn.btn-light { background:var(--sand); color:var(--navy); box-shadow:0 8px 20px rgba(215,185,128,.35); }
.btn.btn-light:hover { background:#e6ca95; }
.btn.btn-block { width:100%; }
.btn.btn-sm { padding:9px 15px; font-size:14px; box-shadow:none; }
.btn.added { background:var(--green); }

:where(a,button,select,input,summary,.tab):focus-visible { outline:3px solid rgba(47,95,143,.45); outline-offset:2px; border-radius:8px; }

.link-arrow { display:inline-flex; align-items:center; gap:6px; font-weight:700; font-size:14px; color:var(--blue); }
.link-arrow .icon { width:16px; height:16px; }
.link-arrow:hover { gap:9px; }

/* Header */
.top { background:var(--navy); color:#f4ead2; text-align:center; padding:9px 16px; font-size:13.5px; }
.header { position:sticky; top:0; z-index:40; background:rgba(251,248,242,.85); backdrop-filter:saturate(140%) blur(14px); border-bottom:1px solid var(--line); }
.nav { max-width:var(--max); margin:auto; padding:13px 22px; display:flex; gap:22px; align-items:center; }
.logo { display:inline-flex; align-items:center; gap:11px; }
.logo-mark .lug { fill:var(--navy); } .logo-mark .bar { fill:var(--blue); } .logo-mark .pin { fill:var(--sand); }
.logo-word { font-family:var(--font-display); font-weight:700; font-size:23px; letter-spacing:-.02em; display:inline-flex; align-items:baseline; gap:6px; }
.logo-dot { color:var(--blue); }
.logo-tag { font-family:var(--font-ui); font-weight:700; font-size:10.5px; text-transform:uppercase; letter-spacing:.22em; color:var(--sand-d); }
.links { display:flex; gap:20px; flex:1; justify-content:center; font-size:14.5px; font-weight:500; color:#38352f; }
.links a { padding:6px 2px; position:relative; }
.links a::after { content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0; background:var(--blue); transition:width .22s var(--ease); }
.links a:hover::after { width:100%; }
.tools { display:flex; gap:8px; align-items:center; }
.icon-btn { position:relative; width:42px; height:42px; border-radius:999px; display:inline-flex; align-items:center; justify-content:center; border:1px solid var(--line); background:#fff; transition:border-color .18s var(--ease),transform .18s var(--ease); }
.icon-btn:hover { border-color:var(--sand); transform:translateY(-1px); }
.cart-count { position:absolute; top:-4px; right:-4px; min-width:18px; height:18px; padding:0 4px; background:var(--blue); color:#fff; font-size:11px; font-weight:700; border-radius:999px; display:grid; place-items:center; }
.nav-toggle { display:none; width:42px; height:42px; border-radius:12px; border:1px solid var(--line); background:#fff; align-items:center; justify-content:center; cursor:pointer; }

/* Layout */
.section { max-width:var(--max); margin:auto; padding:60px 22px; }
.section-tight { padding:24px 22px; }
.section-title { display:flex; justify-content:space-between; gap:24px; align-items:end; margin-bottom:30px; flex-wrap:wrap; }
.section-title h2 { margin-top:8px; }
.sub { color:var(--muted); line-height:1.6; max-width:580px; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.grid-cards { display:grid; grid-template-columns:repeat(auto-fill,minmax(230px,1fr)); gap:18px; }

/* Hero */
.hero { max-width:var(--max); margin:auto; padding:56px 22px 30px; display:grid; grid-template-columns:1.05fr .95fr; gap:44px; align-items:center; }
.hero-copy h1 { margin:16px 0 18px; }
.lead { font-size:18px; line-height:1.6; color:var(--ink-2); max-width:560px; }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; margin-top:26px; }
.hero-proof { list-style:none; margin:24px 0 0; padding:0; display:flex; flex-wrap:wrap; gap:10px 22px; font-size:14px; color:var(--ink-2); }
.hero-proof li { display:inline-flex; align-items:center; gap:7px; }
.hero-proof .icon { width:17px; height:17px; color:var(--green); }

/* Hero finder card */
.device { background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); padding:18px; }
.finder-card { background:linear-gradient(155deg,#14233a,#284e72); border-radius:22px; padding:24px; color:#fff; position:relative; overflow:hidden; }
.finder-card::after { content:""; position:absolute; right:-70px; top:-70px; width:220px; height:220px; background:rgba(255,255,255,.1); border-radius:50%; }
.finder-title { font-size:28px; color:#fff; margin:4px 0 16px; }
.finder-field { position:relative; z-index:1; margin-bottom:12px; }
.finder-field label { color:#dfe6ef; font-size:12.5px; font-weight:700; display:block; margin-bottom:6px; }
.finder-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.finder-card select { background:rgba(255,255,255,.96); border:1px solid rgba(255,255,255,.3); }
.finder-card .btn { margin-top:6px; }
.finder-help { display:block; margin-top:12px; color:var(--sand); font-size:13px; font-weight:600; position:relative; z-index:1; }
.finder-help:hover { text-decoration:underline; }

/* form controls */
.field { display:flex; flex-direction:column; }
label { font-size:13px; font-weight:700; color:#46423c; margin-bottom:7px; }
select,input[type=number],input[type=text] { width:100%; padding:12px 14px; border:1px solid var(--line); border-radius:12px; background:#fff; font-size:15px; color:var(--ink); appearance:none; transition:border-color .16s var(--ease),box-shadow .16s var(--ease); }
select { background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%236f6b63' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='m4 6 4 4 4-4'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:38px; }
select:focus,input:focus { border-color:var(--blue); box-shadow:0 0 0 3px rgba(47,95,143,.14); outline:none; }

/* Trust strip */
.trust-strip { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:22px; box-shadow:var(--shadow-sm); }
.trust { display:flex; gap:12px; align-items:flex-start; }
.trust+.trust { border-left:1px solid var(--line-2); padding-left:14px; }
.trust-ico { flex:none; width:40px; height:40px; border-radius:12px; background:#f3eee2; color:var(--blue); display:grid; place-items:center; }
.trust b { display:block; font-size:15px; }
.trust p { color:var(--muted); font-size:13.5px; line-height:1.45; }

/* Shop by model tiles */
.model-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.model-tile { position:relative; border-radius:var(--radius-lg); overflow:hidden; min-height:230px; display:flex; align-items:flex-end; color:#fff; box-shadow:var(--shadow); transition:transform .2s var(--ease); border:1px solid var(--line); }
.model-tile:hover { transform:translateY(-4px); }
.model-tile::before { content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(17,24,39,.15),rgba(17,24,39,.85)); z-index:1; }
.model-apple { background:linear-gradient(150deg,#3a3f4a,#14151a); }
.model-tissot-prx { background:linear-gradient(150deg,#34526f,#1b2230); }
.model-swatch-omega { background:linear-gradient(150deg,#7a4a25,#2a1a0f); }
.model-blancpain-swatch { background:linear-gradient(150deg,#1f4f6b,#0e2330); }
.model-tile-body { position:relative; z-index:2; padding:22px; }
.model-tile h3 { color:#fff; font-size:22px; margin:6px 0 4px; }
.model-tile p { color:rgba(255,255,255,.82); font-size:13.5px; }
.model-count { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--sand); }
.model-cta { display:inline-flex; align-items:center; gap:6px; margin-top:12px; font-weight:700; font-size:14px; }
.model-cta .icon { width:16px; height:16px; }

/* Material tiles */
.material { background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:24px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; transition:transform .2s var(--ease),box-shadow .2s var(--ease); }
.material:hover { transform:translateY(-4px); box-shadow:var(--shadow); }
.material-ico { width:48px; height:48px; border-radius:14px; display:grid; place-items:center; background:linear-gradient(150deg,#14233a,#284e72); color:#fff; margin-bottom:14px; }
.material h3 { font-family:var(--font-ui); font-weight:700; font-size:18px; }
.material p { color:var(--muted); font-size:14px; line-height:1.55; margin:8px 0 14px; flex:1; }
.material .model-cta { color:var(--blue); }

/* Product card */
.product-card { background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease); }
.product-card:hover { transform:translateY(-4px); box-shadow:var(--shadow); border-color:#ddd2bd; }
.product-media { position:relative; aspect-ratio:1/1; overflow:hidden; background:#f1ece1; display:block; }
.product-media img { width:100%; height:100%; object-fit:cover; transition:transform .4s var(--ease); }
.product-card:hover .product-media img { transform:scale(1.05); }
.badge { position:absolute; top:10px; left:10px; background:rgba(255,255,255,.95); border-radius:999px; padding:5px 10px; font-size:11.5px; font-weight:700; color:var(--navy); box-shadow:var(--shadow-sm); z-index:2; }
.badge-out { background:var(--red); color:#fff; left:auto; right:10px; }
.quickview-btn { position:absolute; left:50%; bottom:12px; transform:translateX(-50%) translateY(8px); background:rgba(20,21,26,.9); color:#fff; border:0; border-radius:999px; padding:9px 16px; font-size:13px; font-weight:600; cursor:pointer; opacity:0; transition:opacity .2s var(--ease),transform .2s var(--ease); z-index:2; }
.product-media:hover .quickview-btn { opacity:1; transform:translateX(-50%) translateY(0); }
.info { padding:16px; display:flex; flex-direction:column; gap:9px; flex:1; }
.product-title { font-size:15px; font-family:var(--font-ui); font-weight:700; line-height:1.35; letter-spacing:0; }
.product-compat { display:flex; align-items:center; gap:6px; font-size:12.5px; color:var(--green); font-weight:600; }
.product-compat .icon { width:15px; height:15px; }
.compat-row { display:flex; flex-wrap:wrap; gap:6px; }
.chip { font-size:11.5px; padding:5px 9px; background:#f3efe7; border-radius:999px; color:var(--ink-2); font-weight:600; }
.buy { display:flex; justify-content:space-between; align-items:center; margin-top:auto; padding-top:6px; gap:10px; }
.price-wrap { display:flex; align-items:baseline; gap:7px; flex-wrap:wrap; }
.price { font-size:19px; font-family:var(--font-display); font-weight:600; }
.price-was { font-size:13px; color:var(--muted); text-decoration:line-through; }

/* Breadcrumb */
.breadcrumb { font-size:13px; color:var(--muted); margin-bottom:18px; display:flex; gap:8px; flex-wrap:wrap; }
.breadcrumb a:hover { color:var(--blue); }
.breadcrumb span[aria-current] { color:var(--ink); font-weight:600; }

/* Collection */
.collection-head h1 { margin-bottom:8px; }
.subcats { display:flex; gap:10px; flex-wrap:wrap; margin:18px 0 0; }
.subcat-pill { border:1px solid var(--line); background:#fff; border-radius:999px; padding:9px 16px; font-size:14px; font-weight:600; }
.subcat-pill:hover { border-color:var(--sand); }
.collection-layout { display:grid; grid-template-columns:260px 1fr; gap:30px; margin-top:28px; align-items:start; }

.filters { position:sticky; top:96px; }
.filters-head { display:flex; justify-content:space-between; align-items:center; margin-bottom:10px; }
.filters-head h2 { font-family:var(--font-ui); font-size:16px; font-weight:800; }
.filters-clear { font-size:13px; color:var(--blue); font-weight:600; }
.filter-group { border-top:1px solid var(--line); padding:14px 0; }
.filter-group summary { cursor:pointer; font-weight:700; font-size:14px; list-style:none; display:flex; justify-content:space-between; align-items:center; }
.filter-group summary::-webkit-details-marker { display:none; }
.filter-group summary::after { content:"–"; color:var(--muted); }
.filter-group:not([open]) summary::after { content:"+"; }
.filter-opts { display:flex; flex-direction:column; gap:7px; margin-top:12px; max-height:230px; overflow:auto; padding-right:4px; }
.filter-opt { display:flex; align-items:center; gap:9px; font-size:13.5px; color:var(--ink-2); cursor:pointer; }
.filter-opt input { width:auto; accent-color:var(--blue); }
.filter-opt span { display:flex; gap:6px; align-items:center; }
.filter-opt i { color:var(--muted); font-style:normal; font-size:12px; }
.filter-apply { margin-top:18px; }

.results-bar { display:flex; align-items:center; gap:14px; margin-bottom:16px; flex-wrap:wrap; }
.results-count { color:var(--muted); font-size:14px; }
.results-count strong { color:var(--ink); }
.sort { margin-left:auto; display:flex; align-items:center; gap:8px; font-size:13px; color:var(--muted); }
.sort select { width:auto; padding:9px 34px 9px 12px; font-size:14px; }
.filters-toggle { display:none; }
.active-chips { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:14px; }
.active-chip { display:inline-flex; align-items:center; gap:6px; background:#f3efe7; border-radius:999px; padding:6px 8px 6px 12px; font-size:13px; font-weight:600; }
.active-chip .icon { width:14px; height:14px; }
.active-chip:hover { background:#ece3d2; }
.empty { text-align:center; padding:60px 20px; color:var(--muted); }
.empty h3 { font-family:var(--font-ui); margin-bottom:8px; color:var(--ink); }

/* Disclaimer */
.disclaimer { display:flex; gap:12px; align-items:flex-start; border-radius:14px; }
.disclaimer .icon { flex:none; color:var(--blue); width:22px; height:22px; margin-top:1px; }
.disclaimer p { font-size:13px; line-height:1.55; color:var(--ink-2); }
.disclaimer-inline { background:#f6f1e6; border:1px solid var(--line); padding:14px 16px; margin:8px 0 22px; }
.disclaimer-block { background:transparent; }
.footer-disclaimer { background:#f1ebdf; border-top:1px solid var(--line); }
.footer-disclaimer-inner { max-width:var(--max); margin:auto; padding:26px 22px; }
.footer-disclaimer .disclaimer p { font-size:12.5px; color:#6c665b; }

/* PDP */
.pdp { display:grid; grid-template-columns:1fr 1fr; gap:36px; align-items:start; }
.pdp-gallery { position:sticky; top:96px; }
.pdp-main { position:relative; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; background:#f1ece1; box-shadow:var(--shadow); aspect-ratio:1/1; }
.pdp-main img { width:100%; height:100%; object-fit:cover; }
.pdp-thumbs { display:flex; gap:10px; margin-top:12px; flex-wrap:wrap; }
.pdp-thumb { width:64px; height:64px; border-radius:12px; overflow:hidden; border:2px solid transparent; padding:0; cursor:pointer; background:#f1ece1; }
.pdp-thumb img { width:100%; height:100%; object-fit:cover; }
.pdp-thumb.active { border-color:var(--blue); }
.pdp-info h1 { margin:6px 0 12px; font-size:clamp(26px,3vw,38px); }
.pdp-rating { display:flex; align-items:center; gap:10px; margin-bottom:14px; font-size:13.5px; }
.pdp-price-row { display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-bottom:18px; }
.pdp-price { font-family:var(--font-display); font-size:30px; font-weight:600; }
.save-badge { background:#fde7e0; color:#7a3322; font-size:12px; font-weight:700; padding:4px 10px; border-radius:999px; }
.stock { font-size:13px; font-weight:700; padding:4px 12px; border-radius:999px; }
.stock.in { background:#e6f5ee; color:var(--green); }
.stock.out { background:#fde7e0; color:var(--red); }
.fitbox { border:1px solid #bee3d1; background:#effaf4; border-radius:14px; padding:14px 16px; margin:0 0 18px; }
.fitbox b { display:flex; align-items:center; gap:8px; color:#14533d; }
.fitbox b .icon { width:18px; height:18px; }
.fitbox span { display:block; color:#2f6b54; font-size:14px; margin-top:4px; }
.pdp-form { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:22px; }
.pdp-form .field { grid-column:span 1; }
.qty-field { max-width:120px; }
.pdp-add { grid-column:1/-1; padding:16px; font-size:16px; }
.pdp-specs { border-top:1px solid var(--line); margin:0 0 18px; padding-top:10px; }
.pdp-specs div { display:flex; justify-content:space-between; gap:20px; padding:10px 0; border-bottom:1px solid var(--line-2); font-size:14px; }
.pdp-specs dt { color:var(--muted); } .pdp-specs dd { margin:0; font-weight:600; text-align:right; }
.pdp-assurances { display:grid; gap:10px; margin:0 0 18px; }
.pdp-assurances div { display:flex; gap:10px; align-items:flex-start; font-size:14px; color:var(--ink-2); }
.pdp-assurances .icon { color:var(--blue); width:20px; height:20px; flex:none; }
.warning { border:1px solid #f2d0c7; background:#fff4f1; color:#7a3322; border-radius:14px; padding:14px 16px; margin:0 0 16px; font-size:14px; line-height:1.5; }

/* Sticky mobile add-to-cart */
.sticky-cart { position:fixed; left:0; right:0; bottom:0; z-index:50; background:#fff; border-top:1px solid var(--line); box-shadow:0 -10px 30px rgba(16,17,20,.12); padding:12px 18px; display:none; align-items:center; justify-content:space-between; gap:14px; }
.sticky-cart-info { display:flex; flex-direction:column; }
.sticky-cart-info b { font-family:var(--font-display); font-size:18px; }
.sticky-cart-info span { font-size:12px; color:var(--muted); }
.sticky-cart .btn { flex:1; max-width:220px; }

/* Finder page */
.finder-page-head { margin-bottom:22px; }
.finder-page-head h1 { margin:8px 0 8px; }
.finder-bar { display:grid; grid-template-columns:repeat(4,1fr) auto; gap:14px; align-items:end; background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:20px; box-shadow:var(--shadow-sm); margin-bottom:8px; }
.finder-bar .btn { height:46px; }

/* Size guide */
.size-guide { display:grid; grid-template-columns:.9fr 1.1fr; gap:32px; align-items:center; background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:34px; box-shadow:var(--shadow-sm); }
.size-guide-copy h2 { margin:8px 0 12px; }
.size-guide-copy .btn { margin-top:16px; }
.size-table { border:1px solid var(--line); border-radius:16px; overflow:hidden; }
.size-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; padding:14px 18px; border-bottom:1px solid var(--line-2); font-size:14px; }
.size-row:last-child { border-bottom:0; }
.size-head { background:#f6f1e6; font-weight:700; font-family:var(--font-ui); }
.size-row b { color:var(--blue); }

/* FAQ */
.faq-grid { display:grid; gap:12px; max-width:820px; }
.faq { background:#fff; border:1px solid var(--line); border-radius:14px; padding:4px 20px; box-shadow:var(--shadow-sm); }
.faq summary { cursor:pointer; list-style:none; font-weight:700; font-size:16px; padding:16px 0; display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq summary::-webkit-details-marker { display:none; }
.faq-plus { position:relative; width:16px; height:16px; flex:none; }
.faq-plus::before,.faq-plus::after { content:""; position:absolute; background:var(--blue); border-radius:2px; }
.faq-plus::before { left:0; top:7px; width:16px; height:2px; }
.faq-plus::after { left:7px; top:0; width:2px; height:16px; transition:transform .2s var(--ease); }
.faq[open] .faq-plus::after { transform:rotate(90deg); opacity:0; }
.faq p { color:var(--muted); line-height:1.6; padding:0 0 18px; }

/* Footer */
.site-footer { background:#f1ebdf; }
.footer-inner { max-width:var(--max); margin:auto; padding:46px 22px 30px; display:grid; grid-template-columns:1.4fr 2fr; gap:40px; }
.footer-brand .logo { margin-bottom:14px; }
.footer-blurb { color:var(--muted); max-width:320px; line-height:1.6; }
.footer-cols { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.footer-col h4 { font-family:var(--font-ui); font-size:13px; text-transform:uppercase; letter-spacing:.1em; margin-bottom:14px; }
.footer-col ul { list-style:none; margin:0; padding:0; display:grid; gap:10px; }
.footer-col a { color:var(--ink-2); font-size:14px; }
.footer-col a:hover { color:var(--blue); }
.footer-legal { border-top:1px solid var(--line); }
.footer-legal-inner { max-width:var(--max); margin:auto; padding:18px 22px 28px; }
.footer-copy { font-size:12.5px; color:#7c766b; }

/* Quick view modal */
.quickview { position:fixed; inset:0; z-index:60; display:flex; align-items:center; justify-content:center; padding:20px; }
.quickview[hidden] { display:none; }
.quickview-backdrop { position:absolute; inset:0; background:rgba(16,17,20,.55); backdrop-filter:blur(3px); }
.quickview-dialog { position:relative; background:#fff; border-radius:var(--radius-lg); max-width:760px; width:100%; max-height:88vh; overflow:auto; box-shadow:var(--shadow-lg); }
.quickview-x { position:absolute; top:14px; right:14px; width:40px; height:40px; border-radius:999px; border:1px solid var(--line); background:#fff; cursor:pointer; display:grid; place-items:center; z-index:2; }
.quickview-body { display:grid; grid-template-columns:1fr 1fr; gap:0; }
.qv-media { background:#f1ece1; aspect-ratio:1/1; }
.qv-media img { width:100%; height:100%; object-fit:cover; }
.qv-info { padding:30px; }
.qv-info h3 { font-family:var(--font-display); font-size:24px; margin-bottom:10px; }
.qv-info .product-compat { margin-bottom:12px; }
.qv-price { font-family:var(--font-display); font-size:26px; margin:6px 0 16px; }
.qv-meta { display:flex; flex-direction:column; gap:8px; font-size:14px; color:var(--ink-2); margin-bottom:20px; }
.qv-actions { display:flex; gap:10px; flex-wrap:wrap; }

/* Toast */
.toast { position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(20px); background:var(--navy); color:#fff; padding:13px 20px; border-radius:999px; font-size:14px; font-weight:600; box-shadow:var(--shadow-lg); opacity:0; pointer-events:none; transition:opacity .25s var(--ease),transform .25s var(--ease); z-index:80; }
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* Responsive */
@media (max-width:980px) {
  .hero,.size-guide { grid-template-columns:1fr; }
  .collection-layout { grid-template-columns:1fr; }
  .filters { position:static; display:none; border:1px solid var(--line); border-radius:var(--radius); padding:18px; background:#fff; margin-bottom:18px; }
  .filters.open { display:block; }
  .filters-toggle { display:inline-flex; }
  .pdp { grid-template-columns:1fr; gap:24px; }
  .pdp-gallery { position:static; }
  .grid-4,.model-grid,.trust-strip { grid-template-columns:repeat(2,1fr); }
  .trust+.trust:nth-child(odd) { border-left:0; padding-left:0; }
  .footer-inner { grid-template-columns:1fr; gap:28px; }
  .finder-bar { grid-template-columns:1fr 1fr; }
  .nav-toggle { display:inline-flex; order:3; margin-left:auto; }
  .tools { order:2; }
  .links { order:4; flex-basis:100%; flex-direction:column; gap:2px; margin-top:8px; display:none; }
  .links.open { display:flex; }
  .links a { padding:12px 4px; border-bottom:1px solid var(--line-2); width:100%; font-size:16px; }
  .links a::after { display:none; }
  .quickview-body { grid-template-columns:1fr; }
  .qv-media { aspect-ratio:16/10; }
  .sticky-cart { display:flex; }
}
@media (max-width:600px) {
  .section { padding:44px 16px; }
  .trust-strip,.finder-bar { grid-template-columns:1fr; }
  .trust+.trust { border-left:0; padding-left:0; border-top:1px solid var(--line-2); padding-top:14px; }
  .grid-4,.model-grid { grid-template-columns:1fr; }
  .grid-cards { grid-template-columns:repeat(2,1fr); gap:12px; }
  .footer-cols { grid-template-columns:1fr 1fr; }
  .pdp-form { grid-template-columns:1fr; }
}
@media (prefers-reduced-motion:reduce) { * { scroll-behavior:auto!important; transition:none!important; animation:none!important; } }
