/* ============================================================
   WINETOOLS.NL — Design system
   ============================================================ */
:root{
  --black:#000000;
  --white:#FFFFFF;
  --graphite:#1F1F1F;
  --silver:#D9D9D9;
  --gold:#C8A96B;
  --bg:#FAF8F5;
  --surface:#FFFFFF;
  --ink:#1F1F1F;
  --green:#1F1F1F;
  --green-deep:#000000;
  --brass:#C8A96B;
  --gold:#B8962E;
  --muted:#6E6760;
  --line:#E5DFD4;
  --line-soft:#F0EBE3;
  --display:'Montserrat', system-ui, sans-serif;
  --sans:'Inter', system-ui, sans-serif;
  --serif:var(--display);
  --maxw:1280px;
  --pad:clamp(20px, 5vw, 64px);
  --r:4px;
  --shadow-sm:0 2px 10px rgba(31,31,31,.04), 0 1px 2px rgba(31,31,31,.03);
  --shadow-md:0 14px 44px rgba(31,31,31,.08);
  --shadow-lg:0 28px 70px rgba(31,31,31,.14);
  --lux-glow:0 0 0 1px rgba(200,169,107,.12);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:auto}
body{
  margin:0;
  font-family:var(--sans);
  font-weight:400;
  background:var(--bg);
  color:var(--ink);
  font-size:clamp(16px, 1.05vw, 18px);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer}
a{color:inherit;text-decoration:none}
::selection{background:var(--green);color:#fff}

h1,h2,h3,h4{font-family:var(--display);margin:0;line-height:1.08;letter-spacing:-.01em}
h1{font-weight:700;font-size:clamp(48px,5vw,64px)}
h2{font-weight:600;font-size:clamp(32px,3vw,40px)}
h3{font-weight:500;font-size:24px}
h4{font-weight:500;font-size:20px}
.caption,.card-cat,.card-desc,.citem-cat,.pdp-info .cat,.rl-date,.nl-note,.ship-bar .msg{font-size:clamp(12px,.9vw,14px)}
.serif{font-family:var(--display)}

/* ---- utility ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
.eyebrow{
  font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--brass);margin:0 0 18px;
}
.eyebrow.on-dark{color:var(--gold)}
.muted{color:var(--muted)}
.section{padding-block:clamp(56px,8vw,104px)}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:40px}
.section-head h2{font-size:clamp(28px,3.6vw,46px)}
.section-link{
  font-size:14px;font-weight:600;color:var(--green);white-space:nowrap;
  display:inline-flex;align-items:center;gap:7px;padding-bottom:2px;
  border-bottom:1px solid transparent;transition:border-color .25s, gap .25s;
}
.section-link:hover{border-color:var(--green);gap:11px}
.section-link svg{width:15px;height:15px}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--sans);font-size:15px;font-weight:600;letter-spacing:.005em;
  padding:15px 30px;border:1px solid transparent;border-radius:var(--r);
  transition:transform .15s var(--ease), background .25s, color .25s, border-color .25s, box-shadow .25s;
  line-height:1;
}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--green);color:var(--white);letter-spacing:.03em}
.btn-primary:hover{background:var(--green-deep)}
.btn-primary:active{transform:translateY(1px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--bg)}
.btn-light{background:var(--white);color:var(--green);border-color:var(--line)}
.btn-light:hover{background:var(--line-soft)}
.btn-brass{background:var(--brass);color:#fff;border-color:transparent;letter-spacing:.03em}
.btn-brass:hover{filter:brightness(1.1)}
.btn-brass:active{transform:translateY(1px)}
.btn-block{width:100%}
.btn-sm{padding:11px 18px;font-size:13px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* link with arrow on dark */
.txtlink{
  display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:15px;
  color:#fff;border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:3px;
  transition:gap .25s,border-color .25s;
}
.txtlink:hover{gap:13px;border-color:#fff}
.txtlink svg{width:16px;height:16px}

/* ============================================================
   PLACEHOLDER (product / lifestyle imagery)
   ============================================================ */
.ph{
  position:relative;overflow:hidden;background:#fff;
  display:flex;align-items:center;justify-content:center;
}
.ph::before{
  content:"";position:absolute;inset:0;
  background-image:repeating-linear-gradient(135deg, rgba(28,28,28,.022) 0 1px, transparent 1px 11px);
}
.ph.has-img{background:#fff}
.ph.has-img::before{display:none}
.ph.has-img .ph-label,.ph.has-img .ph-mark{display:none}
.ph-img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:14px}
.citem-media .ph-img{padding:10px}
.gallery .main .ph-img{padding:24px}
.gallery .thumb .ph-img{padding:8px}
.ph .ph-label{
  position:relative;z-index:1;font-family:var(--sans);
  font-size:clamp(12px,.85vw,14px);letter-spacing:.08em;text-transform:lowercase;color:var(--muted);
  text-align:center;padding:8px 14px;max-width:80%;
}
.ph .ph-mark{
  position:absolute;font-family:var(--display);font-weight:700;
  color:rgba(31,31,31,.06);font-size:clamp(40px,8vw,96px);z-index:0;user-select:none;
}
.ph.warm{background:var(--line-soft)}
.ph.warm::before{background-image:repeating-linear-gradient(135deg, rgba(31,31,31,.03) 0 1px, transparent 1px 11px)}
.ph.dark{background:var(--graphite)}
.ph.dark::before{background-image:repeating-linear-gradient(135deg, rgba(255,255,255,.04) 0 1px, transparent 1px 13px)}
.ph.dark .ph-label{color:rgba(200,169,107,.75)}
.ph.dark .ph-mark{color:rgba(255,255,255,.05)}

/* ============================================================
   HEADER
   ============================================================ */
.topbar{
  background:var(--graphite);color:var(--silver);font-size:clamp(12px,.9vw,14px);letter-spacing:.02em;
  text-align:center;padding:9px 16px;font-weight:400;
}
.topbar b{color:var(--white);font-weight:600}
header.site{
  position:sticky;top:0;z-index:50;background:rgba(250,248,245,.88);
  backdrop-filter:saturate(160%) blur(16px);border-bottom:1px solid rgba(200,169,107,.14);
}
.nav{display:flex;align-items:center;gap:30px;height:72px}
.brand{display:inline-flex;align-items:center;flex-shrink:0;line-height:0;text-decoration:none}
.brand-logo{display:block;height:44px;width:auto;max-width:min(240px,52vw)}
.brand--sm .brand-logo{height:36px;max-width:200px}
.brand:hover{opacity:.88}
.nav-links{display:flex;gap:30px;margin-left:14px}
.nav-links a{
  font-size:14.5px;font-weight:500;color:var(--ink);position:relative;padding:6px 0;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;background:var(--brass);
  transition:width .28s var(--ease);
}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--ink)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:6px}
.icon-btn{
  width:42px;height:42px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;background:transparent;border:none;color:var(--ink);position:relative;
  transition:background .2s,color .2s;
}
.icon-btn:hover{background:rgba(31,31,31,.08);color:var(--green)}
.icon-btn svg{width:21px;height:21px}
.cart-count{
  position:absolute;top:4px;right:3px;min-width:18px;height:18px;padding:0 5px;
  background:var(--brass);color:#fff;border-radius:9px;font-size:11px;font-weight:700;
  display:flex;align-items:center;justify-content:center;font-family:var(--sans);
  border:2px solid var(--bg);
}
.burger{display:none}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;display:grid;grid-template-columns:1fr 1fr;min-height:calc(100vh - 113px)}
.hero-copy{display:flex;flex-direction:column;justify-content:center;padding:clamp(40px,6vw,90px) var(--pad)}
.hero-copy .inner{max-width:560px}
.hero h1{font-size:clamp(48px,5vw,64px);letter-spacing:-.02em}
.hero h1 em{font-style:normal;color:var(--gold);font-weight:600}
.hero .sub{font-size:clamp(16px,1.05vw,18px);color:var(--muted);margin:26px 0 38px;max-width:440px;line-height:1.5}
.hero-media{position:relative;overflow:hidden;background:var(--line-soft)}
.hero-media .ph{position:absolute;inset:0}
.hero-tag{
  position:absolute;left:28px;bottom:26px;z-index:2;background:rgba(255,255,255,.92);
  backdrop-filter:blur(6px);padding:13px 18px;border-radius:var(--r);max-width:260px;
  box-shadow:var(--shadow-sm);
}
.hero-tag .n{font-family:var(--display);font-weight:600;font-size:16px}
.hero-tag .d{font-size:clamp(12px,.9vw,14px);color:var(--muted);margin-top:2px}

/* ---- HERO 2 · retail-style, categories above the fold ---- */
.hero2{
  position:relative;padding-block:clamp(24px,3.5vw,52px) clamp(32px,4vw,60px);
  background:linear-gradient(180deg, #f8f5f0 0%, var(--bg) 100%);
  border-bottom:1px solid rgba(200,169,107,.12);
}
.hero2-shell{position:relative}
.hero2-banner{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.02fr);
  gap:clamp(28px,4.2vw,68px);align-items:center;
}
.hero2 .copy{position:relative;padding-block:0;max-width:34rem}
.hero2-eyebrow{
  color:var(--brass);font-size:11px;font-weight:600;letter-spacing:.24em;margin-bottom:16px;
}
.hero2 h1{
  font-size:clamp(40px,4.6vw,64px);letter-spacing:-.032em;line-height:1.02;
  font-weight:700;color:var(--ink);
}
.hero2 .sub{
  font-size:16px;color:var(--muted);margin:20px 0 26px;
  max-width:42ch;line-height:1.65;font-weight:400;
}
.hero2-perks{
  list-style:none;margin:0 0 28px;padding:0;display:flex;flex-wrap:wrap;gap:11px 24px;
}
.hero2-perks li{
  display:flex;align-items:center;gap:9px;font-size:13px;font-weight:500;
  color:var(--ink);letter-spacing:.01em;
}
.hero2-perks svg{width:16px;height:16px;color:var(--brass);opacity:1;flex-shrink:0}
.hero2-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero2-cta .btn{padding:14px 28px;font-size:14px}
.hero2-visual{position:relative}
.hero2-media{
  position:relative;aspect-ratio:4/3;max-height:540px;
  border-radius:var(--r);overflow:hidden;
  border:1px solid rgba(31,31,31,.08);background:var(--graphite);
  box-shadow:0 34px 80px -24px rgba(0,0,0,.34);
}
.hero2-media::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:1;
  background:linear-gradient(180deg, transparent 55%, rgba(0,0,0,.5) 100%);
}
.hero2-media .ph{position:absolute;inset:0}
.hero2-media .ph-img{object-fit:cover;object-position:center 42%;padding:0}
.hero2-animate .hero2-media .ph-img{
  animation:hero-img-reveal 1.35s var(--ease) .22s both;
}

.hero-spotlight{
  position:absolute;left:16px;right:16px;bottom:16px;z-index:2;
  display:grid;grid-template-columns:54px 1fr auto;align-items:center;gap:14px;
  padding:13px 16px;text-align:left;cursor:pointer;
  background:rgba(24,24,24,.78);backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.12);border-radius:calc(var(--r) - 3px);
  box-shadow:0 12px 32px rgba(0,0,0,.32);
  transition:background .25s,border-color .25s,transform .25s var(--ease),box-shadow .25s;
}
.hero2-animate .hero-spotlight{animation:hero-spotlight-in .75s var(--ease) .62s both}
.hero-spotlight:hover{
  background:rgba(24,24,24,.9);border-color:rgba(200,169,107,.45);transform:translateY(-2px);
  box-shadow:0 16px 38px rgba(0,0,0,.38);
}
.hero-spotlight:focus-visible{outline:1px solid rgba(200,169,107,.6);outline-offset:2px}
.hero-spotlight-thumb{
  width:54px;height:54px;border-radius:calc(var(--r) - 4px);overflow:hidden;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);
}
.hero-spotlight-thumb img{width:100%;height:100%;object-fit:contain;padding:5px}
.hero-spotlight-copy{display:flex;flex-direction:column;gap:3px;min-width:0}
.hero-spotlight-label{
  font-size:9.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--brass);
}
.hero-spotlight-name{
  font-family:var(--display);font-weight:500;font-size:14px;line-height:1.25;color:#fff;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.01em;
}
.hero-spotlight-meta{font-size:12px;color:rgba(255,255,255,.62);letter-spacing:.02em}
.hero-spotlight-arrow{width:15px;height:15px;color:rgba(255,255,255,.6);flex-shrink:0}

/* ---- hero trust bar ---- */
.hero-trust{display:flex;align-items:center;gap:14px;margin-top:22px;flex-wrap:wrap}
.hero-trust .stars{margin-bottom:0;gap:2px}
.hero-trust .stars i{width:11px;height:11px}
.hero-trust-score{font-family:var(--display);font-weight:700;font-size:14px;color:var(--ink)}
.hero-trust-count{font-size:13px;color:var(--muted)}
.hero-trust-sep{color:var(--line);font-size:16px;line-height:1}
.hero-trust-badge{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);font-weight:500}
.hero-trust-badge svg{width:13px;height:13px;color:var(--brass);flex-shrink:0}

.hero-pop{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:20px}
.hero-pop-backdrop{position:absolute;inset:0;border:none;background:rgba(28,28,28,.52);cursor:pointer}
.hero-pop.is-open .hero-pop-backdrop{animation:anim-fade-in .35s var(--ease) both}
.hero-pop-panel{
  position:relative;z-index:1;width:min(520px,calc(100vw - 40px));max-height:calc(100vh - 40px);overflow:auto;
  background:#fff;border-radius:calc(var(--r)*2);box-shadow:var(--shadow-lg);border:1px solid var(--line);
}
.hero-pop.is-open .hero-pop-panel{animation:anim-pop-panel .48s var(--ease) both}
.hero-pop-close{
  position:absolute;top:12px;right:12px;z-index:2;width:40px;height:40px;border:none;border-radius:50%;
  background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink);
  cursor:pointer;transition:background .2s;
}
.hero-pop-close:hover{background:var(--line-soft)}
.hero-pop-close svg{width:18px;height:18px}
.hero-pop-media{position:relative;aspect-ratio:4/3;background:var(--line-soft);border-bottom:1px solid var(--line)}
.hero-pop-media .ph{position:absolute;inset:0}
.hero-pop-media .ph-img{object-fit:contain;padding:20px}
.hero-pop-body{padding:22px 24px 26px}
.hero-pop-badge{
  display:inline-block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--graphite);background:var(--line-soft);padding:5px 10px;border-radius:999px;margin-bottom:10px;
}
.hero-pop-cat{font-size:13px;color:var(--muted);margin:0 0 6px}
.hero-pop-body h3{font-size:clamp(22px,2.4vw,28px);margin:0 0 10px}
.hero-pop-desc{font-size:15px;color:var(--muted);line-height:1.55;margin:0 0 14px}
.hero-pop-price{font-family:var(--display);font-weight:700;font-size:24px;margin-bottom:18px}
.hero-pop-actions{display:flex;gap:10px;flex-wrap:wrap}
.hero-pop-actions .btn{flex:1;min-width:140px}
.hero2-cats{margin-top:clamp(24px,3vw,36px)}
.hero2-cats-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:22px}
.hero2-cats-head h2{font-size:clamp(22px,2.4vw,31px)}

/* ============================================================
   CATEGORY TILES
   ============================================================ */
.cat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.cat-tile{display:block;group:cat;transition:transform .35s var(--ease)}
.cat-tile:hover{transform:translateY(-3px)}
.cat-tile .cat-img{aspect-ratio:1;border-radius:var(--r);overflow:hidden;background:#fff;border:1px solid var(--line)}
.cat-tile .cat-img .ph{position:absolute;inset:0}
.cat-tile .cat-imgwrap{
  position:relative;aspect-ratio:1;border-radius:var(--r);overflow:hidden;
  border:1px solid var(--line);background:#fff;
  transition:border-color .35s var(--ease),box-shadow .35s var(--ease);
}
.cat-tile:hover .cat-imgwrap{border-color:var(--brass);box-shadow:0 8px 28px rgba(0,0,0,.1)}
.cat-tile .ph-inner{position:absolute;inset:0;transition:transform .5s var(--ease)}
.cat-tile .ph-inner .ph{position:absolute;inset:0;width:100%;height:100%}
.cat-tile .ph-inner .ph-img{object-fit:cover;padding:0}
.cat-tile:hover .ph-inner{transform:scale(1.06)}
.cat-tile .cat-name{
  margin-top:14px;font-family:var(--display);font-weight:600;font-size:18px;
  display:flex;align-items:center;justify-content:space-between;
  transition:color .25s var(--ease);
}
.cat-tile:hover .cat-name{color:var(--brass)}
.cat-tile .cat-name svg{width:16px;height:16px;color:var(--brass);opacity:0;transform:translateX(-6px);transition:.3s var(--ease)}
.cat-tile:hover .cat-name svg{opacity:1;transform:translateX(0)}

/* ============================================================
   PRODUCT CARD
   ============================================================ */
.prod-grid{display:grid;gap:22px}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.card{
  background:transparent;border:none;border-radius:0;
  overflow:visible;display:flex;flex-direction:column;position:relative;
  cursor:pointer;
}
.card:hover{box-shadow:none}
.card-media{
  position:relative;aspect-ratio:1;background:transparent;overflow:hidden;border-radius:var(--r);
  transition:box-shadow .4s var(--ease);
}
.card:hover .card-media{box-shadow:0 16px 40px rgba(0,0,0,.1)}
.card-media .ph,
.card-media .ph.has-img,
.card-media .ph.warm{background:transparent}
.card-media .ph{position:absolute;inset:0;transition:opacity .45s var(--ease)}
.card-media .ph.alt{opacity:0}
.card:hover .card-media .ph.alt{opacity:1}
.card-media .ph-img{padding:0;transition:transform .55s var(--ease)}
.card:hover .card-media .ph-img{transform:scale(1.045)}
.card:focus-visible{outline:2px solid var(--brass);outline-offset:4px;border-radius:var(--r)}
.card-stretch{
  position:absolute;inset:0;z-index:1;border-radius:var(--r);
  text-indent:-9999px;overflow:hidden;
}
.card-name a{color:inherit;text-decoration:none}
.card-name a:hover{color:inherit}
.card .wish,.card .add-btn{z-index:2}
.card-badge{
  position:absolute;top:12px;left:12px;z-index:3;background:var(--green);color:#fff;
  font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  padding:5px 10px;border-radius:2px;line-height:1.25;
}
.card-badge.brass{background:var(--brass)}
.wish{
  position:absolute;top:11px;right:11px;z-index:3;width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.9);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;
  color:var(--ink);opacity:0;transform:translateY(-4px);transition:.25s var(--ease);
}
.card:hover .wish{opacity:1;transform:translateY(0)}
.wish:hover{color:var(--brass);border-color:var(--brass)}
.wish.active{color:#fff;background:var(--brass);border-color:var(--brass);opacity:1;transform:none}
.wish svg{width:18px;height:18px}
.card-body{padding:16px 2px 0;display:flex;flex-direction:column;flex:1}
.card-cat{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.card-name{font-family:var(--display);font-weight:600;font-size:19px;line-height:1.2;margin-bottom:5px;transition:color .25s var(--ease)}
.card:hover .card-name{color:var(--ink)}
.card-rating{display:flex;align-items:center;gap:7px;margin-bottom:9px}
.card-rating .stars{margin-bottom:0;gap:2px}
.card-rating .stars i{width:12px;height:12px}
.card-rating-n{font-size:12px;color:var(--muted);font-weight:500}
.card-desc{color:var(--muted);margin-bottom:16px;flex:1;transition:color .25s var(--ease)}
.card:hover .card-desc{color:var(--ink)}
.card-body::after{
  content:"Bekijk product";display:block;font-size:12px;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;color:var(--brass);margin-top:12px;opacity:0;transform:translateY(4px);
  transition:opacity .25s var(--ease),transform .25s var(--ease);
}
.card:hover .card-body::after{opacity:1;transform:none}
.card-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:auto}
.price{font-family:var(--display);font-weight:700;font-size:21px}
.price .old{font-family:var(--sans);font-size:13px;color:var(--muted);text-decoration:line-through;margin-right:7px;font-weight:500}
.add-btn{
  display:inline-flex;align-items:center;gap:7px;background:var(--green);color:#fff;
  border:none;border-radius:var(--r);padding:10px 16px;font-size:13px;font-weight:600;
  transition:background .2s,transform .15s,box-shadow .2s;white-space:nowrap;
}
.add-btn:hover{background:var(--green-deep)}
.add-btn:active{transform:scale(.96)}
.add-btn svg{width:15px;height:15px}
.add-btn.added{background:var(--brass)}

/* reveal-on-hover add (featured) */
.card.reveal .card-foot .add-btn{opacity:0;transform:translateY(6px);transition:.28s var(--ease)}
.card.reveal:hover .card-foot .add-btn{opacity:1;transform:none}

/* ============================================================
   FEATURED
   ============================================================ */
.featured-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.feat{display:flex;flex-direction:column}
.feat-media{
  position:relative;aspect-ratio:4/5;background:transparent;border:none;
  border-radius:calc(var(--r)*1.5);overflow:hidden;cursor:pointer;
  transition:box-shadow .4s var(--ease);
}
.feat:hover .feat-media{box-shadow:0 20px 50px rgba(0,0,0,.12)}
.feat-media .ph{position:absolute;inset:0}
.feat-media .ph,
.feat-media .ph.has-img{background:transparent}
.feat-media .ph-img{padding:0;transition:transform .6s var(--ease)}
.feat:hover .feat-media .ph-img{transform:scale(1.04)}
.feat-name{transition:color .25s var(--ease)}
.feat:hover .feat-name{color:var(--brass)}
.feat-foot{padding-top:18px}
.feat-name{font-family:var(--display);font-weight:600;font-size:23px;margin-bottom:6px}
.feat-desc{color:var(--muted);margin-bottom:12px}
.feat-row{display:flex;align-items:center;justify-content:space-between;gap:14px}
.feat .add-btn{opacity:0;transform:translateY(6px);transition:.3s var(--ease)}
.feat:hover .add-btn{opacity:1;transform:none}

/* ============================================================
   BRAND MOMENT
   ============================================================ */
.brandmoment{background:var(--graphite);color:var(--silver);overflow:hidden}
.brandmoment .inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:center;
  padding-block:clamp(56px,8vw,110px)}
.brandmoment h2{color:var(--white);font-size:clamp(32px,3vw,44px);max-width:13ch;line-height:1.05}
.brandmoment h2 em{font-style:normal;color:var(--brass)}
.brandmoment p{font-size:clamp(16px,1.05vw,18px);line-height:1.65;color:rgba(255,255,255,.7);margin:24px 0;max-width:46ch}
.brandmoment-media{position:relative}
.brandmoment-media .ph{aspect-ratio:1;border-radius:var(--r);transform:scale(1.08);transform-origin:center}
.brandmoment-media .float{
  position:absolute;left:-22px;bottom:30px;background:var(--white);color:var(--ink);
  padding:16px 20px;border-radius:var(--r);box-shadow:var(--shadow-lg);max-width:210px;
}
.brandmoment-media .float .q{font-family:var(--display);font-size:17px;line-height:1.3;font-weight:600}
.brandmoment-media .float .a{color:var(--muted);margin-top:6px}

/* ============================================================
   REVIEWS
   ============================================================ */
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.review{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:30px 28px 28px;display:flex;flex-direction:column;position:relative;overflow:hidden;
  transition:border-color .3s,box-shadow .3s;
}
.review:hover{border-color:var(--brass);box-shadow:0 8px 28px rgba(0,0,0,.07)}
.review::before{
  content:'\201C';position:absolute;top:-8px;right:18px;
  font-family:Georgia,'Times New Roman',serif;font-size:96px;line-height:1;
  color:var(--line);pointer-events:none;user-select:none;
}
.stars{display:flex;gap:3px;margin-bottom:18px}
.stars i{
  width:14px;height:14px;border-radius:0;background:var(--brass);display:block;
  clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%);
}
.stars i.off{background:var(--line)}
.stars-empty i.off{background:rgba(200,169,107,.28)}
.pdp-rating .n.muted{color:#8A7A50;font-style:italic}
.review-empty{padding:28px 0;color:var(--muted);font-size:15px}
.review-source-note{margin:0 0 20px;font-size:13px;color:var(--muted);line-height:1.5}
.review-q{font-family:var(--display);font-size:19px;line-height:1.5;font-weight:500;margin-bottom:20px;flex:1}
.review-who{font-size:13.5px;font-weight:600}
.review-who span{color:var(--muted);font-weight:500}

/* ============================================================
   USP BAR
   ============================================================ */
.usp{background:var(--surface);border-block:1px solid var(--line)}
.usp .inner{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding-block:38px}
.usp-item{display:flex;align-items:center;gap:16px}
.usp-item .ic{
  width:46px;height:46px;flex-shrink:0;border:1px solid var(--line);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--brass);
  background:var(--line-soft);transition:background .25s,border-color .25s;
}
.usp-item:hover .ic{background:var(--brass);border-color:var(--brass);color:#fff}
.usp-item .ic svg{width:21px;height:21px;transition:color .25s}
.usp-item .t{font-size:14.5px;font-weight:700;line-height:1.3;color:var(--ink)}
.usp-item .s{font-size:12.5px;color:var(--muted);margin-top:2px}

/* ============================================================
   PERSONALISATION SHOWCASE
   ============================================================ */
.engrave-show{background:linear-gradient(180deg,#f6f1e9 0%,var(--bg) 100%);border-block:1px solid var(--line)}
.engrave-show .inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center;
  padding-block:clamp(56px,8vw,104px)}
.engrave-copy h2{font-size:clamp(28px,3vw,42px);max-width:14ch;line-height:1.06;margin-bottom:18px}
.engrave-copy>p{color:var(--muted);font-size:clamp(16px,1.05vw,18px);line-height:1.65;max-width:46ch;margin:0 0 28px}
.engrave-steps{list-style:none;margin:0 0 30px;padding:0;display:flex;flex-direction:column;gap:16px}
.engrave-steps li{display:flex;align-items:flex-start;gap:14px}
.engrave-steps .num{flex-shrink:0;width:27px;height:27px;border-radius:50%;background:var(--ink);color:#fff;
  font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:var(--display)}
.engrave-steps .st-t{display:block;font-weight:600;font-size:15.5px;color:var(--ink)}
.engrave-steps .st-s{display:block;color:var(--muted);font-size:13.5px;margin-top:1px}
.engrave-card{background:var(--surface);border:1px solid var(--line);border-radius:calc(var(--r)*2);
  padding:clamp(22px,2.4vw,30px);box-shadow:var(--shadow-md)}
.engrave-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.engrave-card-kicker{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.engrave-card-chip{font-size:11.5px;font-weight:700;color:var(--brass);border:1px solid rgba(200,169,107,.45);
  border-radius:100px;padding:4px 11px}
.engrave-live{background:linear-gradient(135deg,#f1e9db 0%,#fbf8f3 100%);border:1px solid var(--line);
  border-radius:calc(var(--r)*1.5);min-height:104px;display:flex;align-items:center;justify-content:center;
  padding:18px 22px;margin-bottom:16px;text-align:center;overflow:hidden}
.engrave-live-text{font-size:clamp(30px,3.4vw,44px);line-height:1.12;color:var(--ink);word-break:break-word;
  max-width:100%;transition:opacity .2s}
.engrave-live-text.is-placeholder{color:var(--muted);opacity:.45}
.engrave-input-row{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.engrave-input-row input{flex:1;min-width:0;font-family:inherit;font-size:15px;padding:12px 14px;
  border:1px solid var(--line);border-radius:var(--r);background:var(--surface);color:var(--ink);outline:none;
  transition:border-color .2s,box-shadow .2s}
.engrave-input-row input:focus{border-color:var(--brass);box-shadow:0 0 0 3px rgba(200,169,107,.18)}
.engrave-input-count{font-size:12px;color:var(--muted);flex-shrink:0;font-variant-numeric:tabular-nums}
.engrave-pick{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.engrave-pick-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;
  padding:13px 6px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);
  transition:border-color .2s,background .2s,box-shadow .2s;cursor:pointer;min-height:74px}
.engrave-pick-btn:hover{border-color:var(--brass)}
.engrave-pick-btn.active{border-color:var(--brass);box-shadow:0 0 0 1px var(--brass);background:var(--line-soft)}
.engrave-pick-sample{font-size:24px;line-height:1;color:var(--ink)}
.engrave-pick-name{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.engrave-pick-btn.active .engrave-pick-name{color:var(--ink)}
.engrave-pick-hint{font-size:13px;color:var(--muted);margin:0 0 18px;min-height:18px;text-align:center;line-height:1.45}
.engrave-card-foot{display:flex;align-items:center;gap:9px;margin-top:18px;padding-top:16px;
  border-top:1px solid var(--line-soft);font-size:12.5px;color:var(--muted)}
.engrave-card-foot svg{width:16px;height:16px;color:var(--brass);flex-shrink:0}

/* ============================================================
   GIFT BAND
   ============================================================ */
.giftband{background:var(--graphite);color:var(--silver);overflow:hidden}
.giftband .inner{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,72px);align-items:center;
  padding-block:clamp(52px,7vw,96px)}
.giftband h2{color:#fff;font-size:clamp(28px,2.8vw,40px);max-width:15ch;line-height:1.08;margin-bottom:16px}
.giftband-copy>p{color:rgba(255,255,255,.66);line-height:1.6;max-width:44ch;margin:0 0 26px}
.giftband-cta{display:flex;flex-wrap:wrap;gap:12px}
.giftband-points{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.giftband-points li{display:flex;align-items:center;gap:16px;padding:18px 4px;border-top:1px solid rgba(255,255,255,.1)}
.giftband-points li:first-child{border-top:none}
.giftband-ic{flex-shrink:0;width:44px;height:44px;border-radius:50%;border:1px solid rgba(200,169,107,.4);
  display:flex;align-items:center;justify-content:center;color:var(--brass)}
.giftband-ic svg{width:20px;height:20px}
.giftband-pt-t{display:block;font-weight:700;font-size:15px;color:#fff}
.giftband-pt-s{display:block;font-size:13px;color:rgba(255,255,255,.6);margin-top:2px}

/* ============================================================
   FAQ
   ============================================================ */
.faq-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(28px,5vw,72px);align-items:start}
.faq-intro h2{font-size:clamp(28px,3.2vw,42px);line-height:1.06;margin-bottom:16px}
.faq-intro-sub{color:var(--muted);line-height:1.6;max-width:34ch}
.faq-link{color:var(--ink);font-weight:600;border-bottom:1px solid var(--brass)}
.faq-link:hover{color:var(--brass)}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item:first-child{border-top:1px solid var(--line)}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:22px 2px;
  cursor:pointer;list-style:none;font-family:var(--display);font-weight:600;font-size:clamp(16px,1.4vw,19px);
  color:var(--ink);transition:color .2s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--brass)}
.faq-ic{width:20px;height:20px;flex-shrink:0;color:var(--brass);transition:transform .3s var(--ease)}
.faq-item[open] .faq-ic{transform:rotate(45deg)}
.faq-a{color:var(--muted);line-height:1.65;padding:0 40px 24px 2px;max-width:60ch;font-size:15.5px}

/* ============================================================
   NEWSLETTER
   ============================================================ */
.newsletter{background:var(--graphite);padding-block:clamp(56px,8vw,90px)}
.newsletter .inner{display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center;
  padding:clamp(36px,5vw,56px);border:1px solid rgba(255,255,255,.09);border-radius:calc(var(--r) + 2px);
  background:rgba(255,255,255,.04);box-shadow:none}
.newsletter h2{font-size:clamp(28px,3.4vw,42px);max-width:14ch;color:#fff}
.newsletter p{color:rgba(255,255,255,.62);margin-top:14px;max-width:42ch}
.newsletter .eyebrow{color:var(--brass)}
.nl-form{display:flex;gap:10px;max-width:480px;margin-left:auto;width:100%;min-width:0}
.nl-form input{
  flex:1;min-width:0;font-family:inherit;font-size:15px;padding:15px 18px;border:1px solid rgba(255,255,255,.18);
  border-radius:var(--r);background:rgba(255,255,255,.09);color:#fff;outline:none;
  transition:border-color .2s,box-shadow .2s,background .2s;
}
.nl-form input::placeholder{color:rgba(255,255,255,.4)}
.nl-form input:focus{border-color:var(--brass);background:rgba(255,255,255,.13);box-shadow:0 0 0 3px rgba(200,169,107,.22)}
.nl-form.err input{border-color:#EF9A9A;box-shadow:0 0 0 3px rgba(239,154,154,.15)}
.nl-note{font-size:13px;margin-top:12px;height:18px;color:rgba(255,255,255,.5)}
.nl-note.ok{color:#81C784}
.nl-note.bad{color:#EF9A9A}

/* ============================================================
   FOOTER
   ============================================================ */
footer.site{background:var(--black);color:var(--silver)}
footer.site .inner{display:grid;grid-template-columns:1.4fr 1fr 1.2fr;gap:48px;padding-block:64px}
footer.site .brand{display:inline-flex}
.foot-tag{line-height:1.6;color:var(--silver);margin:16px 0 24px;max-width:34ch}
.socials{display:flex;gap:10px}
.socials a{width:40px;height:40px;border:1px solid #333;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--silver);transition:.2s}
.socials a:hover{background:var(--brass);border-color:var(--brass);color:#fff}
.socials svg{width:18px;height:18px}
.foot-h{font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#fff;margin-bottom:20px}
.foot-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.foot-col a{color:var(--silver);transition:color .2s}
.foot-col a:hover{color:var(--white)}
.foot-contact p{color:var(--silver);margin:0 0 12px;line-height:1.5}
.foot-sub{margin-top:4px}
.foot-meta{font-size:13px;color:#9a9a9a;line-height:1.55}
.pay{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap;align-items:center}
.pay-badge{display:block;line-height:0;border-radius:4px;overflow:hidden;box-shadow:0 0 0 1px rgba(255,255,255,.08)}
.pay-badge img{display:block;width:48px;height:32px;object-fit:contain}

/* ============================================================
   CART DRAWER
   ============================================================ */
.overlay{
  position:fixed;inset:0;z-index:80;background:rgba(28,28,28,.42);
  opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s;
}
.overlay.open{opacity:1;visibility:visible}

.mobile-menu{display:none}
@media(max-width:900px){
  .mobile-menu{display:block;position:fixed;top:0;left:0;height:100%;width:min(340px,90vw);background:var(--bg);z-index:95;
    padding:24px;overflow-y:auto;transform:translateX(-100%);transition:transform .35s var(--ease);box-shadow:var(--shadow-lg)}
  .mobile-menu.open{transform:none}
}

.drawer{
  position:fixed;top:0;right:0;height:100%;width:min(440px,100vw);z-index:90;
  background:var(--bg);box-shadow:var(--shadow-lg);transform:translateX(100%);
  transition:transform .42s var(--ease);display:flex;flex-direction:column;
}
.drawer.open{transform:translateX(0)}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:22px 24px;border-bottom:1px solid var(--line)}
.drawer-head h3{font-size:22px}
.drawer-head .count{font-size:13px;color:var(--muted);font-family:var(--sans);font-weight:500}
.drawer-close{width:38px;height:38px;border:none;background:transparent;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s}
.drawer-close:hover{background:rgba(28,28,28,.07)}
.drawer-close svg{width:20px;height:20px}
.ship-bar{padding:16px 24px;background:#fff;border-bottom:1px solid var(--line)}
.ship-bar .msg{font-size:13px;margin-bottom:9px;display:flex;align-items:center;gap:7px}
.ship-bar .msg b{color:var(--green)}
.ship-bar .msg svg{width:15px;height:15px;color:var(--green)}
.ship-track{height:6px;background:var(--line);border-radius:3px;overflow:hidden}
.ship-fill{height:100%;background:var(--green);border-radius:3px;transition:width .5s var(--ease)}
.drawer-items{flex:1;overflow-y:auto;padding:8px 24px}
.citem{display:grid;grid-template-columns:74px 1fr;gap:16px;padding:20px 0;border-bottom:1px solid var(--line)}
.citem-media{aspect-ratio:1;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);background:#fff;position:relative}
.citem-media .ph{position:absolute;inset:0}
.citem-name{font-family:var(--display);font-weight:600;font-size:16px;line-height:1.2;padding-right:18px}
.citem-cat{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:3px}
.citem-row{display:flex;align-items:center;justify-content:space-between;margin-top:14px}
.citem-price{font-family:var(--display);font-weight:600;font-size:16px}
.qty{display:flex;align-items:center;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff}
.qty button{width:30px;height:32px;border:none;background:transparent;font-size:16px;color:var(--ink);display:flex;align-items:center;justify-content:center;transition:background .15s}
.qty button:hover{background:rgba(31,31,31,.08);color:var(--green)}
.qty span{min-width:30px;text-align:center;font-size:14px;font-weight:600}
.citem-remove{position:absolute;top:20px;right:0;border:none;background:transparent;color:var(--muted);width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:.2s}
.citem-remove:hover{color:#B4452E;background:rgba(180,69,46,.08)}
.citem-remove svg{width:15px;height:15px}
.citem{position:relative}
.drawer-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px;gap:18px}
.drawer-empty .e-ic{width:64px;height:64px;border-radius:50%;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted)}
.drawer-empty .e-ic svg{width:28px;height:28px}
.drawer-empty p{color:var(--muted);max-width:24ch}
.drawer-foot{border-top:1px solid var(--line);padding:22px 24px;background:#fff}
.subtotal{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.subtotal .l{font-size:14px;color:var(--muted)}
.subtotal .v{font-family:var(--display);font-weight:700;font-size:24px}
.drawer-foot .vat{font-size:12px;color:var(--muted);margin-bottom:18px}
.drawer-foot .btn{margin-top:4px}
.drawer-foot .cont{display:block;text-align:center;margin-top:14px;font-size:13.5px;color:var(--muted);font-weight:500}
.drawer-foot .cont:hover{color:var(--green)}
.drawer-pay{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.drawer-pay-label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);font-weight:500}
.drawer-pay-label svg{width:14px;height:14px;color:var(--green)}
.drawer-pay-icons{display:flex;gap:6px;align-items:center}
.drawer-pay-icons img{width:34px;height:22px;object-fit:contain;border-radius:3px;box-shadow:0 0 0 1px var(--line)}

/* --- Engrave upsell in cart --- */
.engrave-upsell{border-top:1px solid var(--line);padding:16px 24px;background:var(--line-soft)}
.engrave-upsell-head{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--graphite);margin-bottom:12px}
.engrave-upsell-icon{font-size:14px}
.engrave-upsell-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#fff;border-radius:var(--r);border:1px solid var(--line);margin-bottom:8px}
.engrave-upsell-item:last-child{margin-bottom:0}
.engrave-upsell-thumb{width:46px;height:46px;flex-shrink:0;border-radius:var(--r);overflow:hidden}
.engrave-upsell-thumb img{width:100%;height:100%;object-fit:contain}
.engrave-upsell-info{flex:1;min-width:0}
.engrave-upsell-name{font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
.engrave-upsell-sub{font-size:11px;color:var(--muted)}
.engrave-upsell-btn{flex-shrink:0;font-size:12px;font-weight:600;padding:7px 13px;border-radius:var(--r);border:1.5px solid var(--brass);background:transparent;color:var(--brass);cursor:pointer;letter-spacing:.02em;transition:background .15s,color .15s}
.engrave-upsell-btn:hover{background:var(--brass);color:#fff}

/* ============================================================
   CATALOG PAGE
   ============================================================ */
.pagehead{background:var(--surface);border-bottom:1px solid var(--line)}
.pagehead .inner{padding-block:clamp(36px,5vw,64px)}
.crumbs{font-size:13px;color:var(--muted);margin-bottom:16px;display:flex;gap:8px;align-items:center}
.crumbs a:hover{color:var(--green)}
.crumbs svg{width:12px;height:12px;opacity:.5}
.pagehead h1{font-size:clamp(48px,5vw,64px)}
.pagehead .lead{color:var(--muted);margin-top:14px;max-width:50ch;font-size:16px}
.catalog-layout{display:grid;grid-template-columns:248px 1fr;gap:44px;padding-block:48px;align-items:start}
.filters{position:sticky;top:96px}
.filters-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.filters-title{font-family:var(--display);font-size:22px;font-weight:700}
.filter-group{padding-bottom:26px;margin-bottom:26px;border-bottom:1px solid var(--line)}
.filter-group:last-of-type{border-bottom:none}
.filter-h{font-size:13px;font-weight:700;letter-spacing:.04em;margin-bottom:16px;text-transform:uppercase}
.fopt{display:flex;align-items:center;gap:11px;padding:7px 0;cursor:pointer;font-size:14.5px;color:var(--ink);transition:color .15s}
.fopt:hover{color:var(--green)}
.fopt input{appearance:none;width:18px;height:18px;border:1.5px solid var(--line);border-radius:3px;display:grid;place-content:center;transition:.15s;flex-shrink:0;background:#fff}
.fopt input:checked{background:var(--green);border-color:var(--green)}
.fopt input:checked::after{content:"";width:10px;height:10px;
  background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E")}
.fopt .n{flex:1}
.fopt .c{font-size:12px;color:var(--muted)}
.fopt input[type="radio"]{border-radius:50%}
.fopt input[type="radio"]:checked::after{border-radius:50%;width:8px;height:8px;background:var(--white);background-image:none}
.fopt-stars{color:var(--brass);letter-spacing:.02em;font-size:13px}
.range-labels{display:flex;justify-content:space-between;margin-top:8px;font-size:13.5px;color:var(--muted)}
.range-labels .range-val{font-weight:600;color:var(--ink)}
.range-wrap{margin-top:4px}
input[type=range]{width:100%;accent-color:var(--green)}
.filters-apply{margin-top:18px}
.clear-filters{font-size:13px;color:var(--green);font-weight:600;background:none;border:none;padding:0;margin-top:4px}
.clear-filters:hover{text-decoration:underline}

.catalog-main .toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:26px;flex-wrap:wrap}
.toolbar-left{display:flex;align-items:center;gap:14px;flex-wrap:wrap;flex:1;min-width:0}
.catalog-main .toolbar .res{font-size:14px;color:var(--muted);white-space:nowrap}
.catalog-main .toolbar .res b{color:var(--ink);font-weight:600}
.filter-chips{display:flex;flex-wrap:wrap;gap:8px;max-width:100%}
.filter-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border:1px solid var(--line);border-radius:999px;
  background:#fff;font-size:12.5px;font-weight:600;color:var(--ink);transition:.2s;max-width:100%;line-height:1.25}
.filter-chip:hover{border-color:var(--green);color:var(--green)}
.filter-chip svg{width:12px;height:12px;opacity:.55}
.empty-title{font-family:var(--display);font-size:22px;margin-bottom:8px;color:var(--ink)}
.sort-wrap{display:flex;align-items:center;gap:10px}
.sort-wrap label{font-size:13.5px;color:var(--muted)}
.select{position:relative}
.select select{appearance:none;font-family:inherit;font-size:14px;font-weight:500;padding:11px 38px 11px 15px;
  border:1px solid var(--line);border-radius:var(--r);background:#fff;color:var(--ink);cursor:pointer;outline:none;transition:border-color .2s}
.select select:focus{border-color:var(--green)}
.select svg{position:absolute;right:13px;top:50%;transform:translateY(-50%);width:15px;height:15px;pointer-events:none;color:var(--muted)}
.mobile-filter-btn{display:none}
.filters-apply{display:none}
.empty-grid{text-align:center;padding:80px 20px;color:var(--muted)}

/* ============================================================
   LEGAL PAGES
   ============================================================ */
.legal-page{background:var(--line-soft)}
.legal-head{background:#fff;border-bottom:1px solid var(--line)}
.legal-head .inner{padding-block:clamp(36px,5vw,56px)}
.legal-head .eyebrow{margin-bottom:12px}
.legal-head h1{max-width:16ch}
.legal-head .lead{max-width:52ch}
.legal-content{padding-block:clamp(40px,5vw,64px) clamp(48px,6vw,80px)}

.legal-body{display:flex;flex-direction:column;gap:18px;max-width:860px}
.legal-card{
  background:#fff;border:1px solid var(--line);border-radius:calc(var(--r)*2);
  padding:clamp(22px,3vw,32px);box-shadow:var(--shadow-sm);
}
.legal-card h2{
  font-size:clamp(17px,1.6vw,20px);font-weight:700;margin:0 0 16px;
  padding-bottom:14px;border-bottom:1px solid var(--line-soft);
}
.legal-card ol{margin:0;padding-left:22px;color:var(--ink)}
.legal-card li{margin-bottom:12px;line-height:1.7;font-size:15px}
.legal-card li:last-child{margin-bottom:0}
.legal-aside{margin:28px 0 0;font-size:14px;color:var(--muted)}
.legal-aside a{color:var(--green);font-weight:600;text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s}
.legal-aside a:hover{border-color:var(--green)}

.contact-layout{
  display:grid;grid-template-columns:repeat(2,1fr);gap:18px;max-width:960px;
}
.contact-card{
  background:#fff;border:1px solid var(--line);border-radius:calc(var(--r)*2);
  padding:clamp(22px,3vw,28px);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;
}
.contact-card--primary{
  background:var(--graphite);border-color:var(--graphite);color:#fff;
}
.contact-card--primary .contact-card-title{color:var(--gold)}
.contact-card--primary .contact-note{color:rgba(255,255,255,.65)}
.contact-card--wide{grid-column:1/-1}
.contact-card-title{
  font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted);margin:0 0 16px;
}
.contact-card-body{display:flex;flex-direction:column;gap:10px;flex:1}
.contact-card-body p,.contact-card-body address{margin:0;line-height:1.65;font-size:15px}
.contact-email{
  display:inline-block;font-family:var(--display);font-weight:700;font-size:clamp(20px,2.2vw,26px);
  color:#fff;text-decoration:none;transition:opacity .2s;
}
.contact-email:hover{opacity:.85}
.contact-phone{
  display:inline-block;font-family:var(--display);font-weight:600;font-size:18px;
  color:#fff;text-decoration:none;transition:opacity .2s;
}
.contact-phone:hover{opacity:.85}
.contact-hours{font-size:15px;color:rgba(255,255,255,.88)}
.contact-lead{font-family:var(--display);font-weight:600;font-size:17px}
.contact-address{font-style:normal}
.contact-note{font-size:14px;color:var(--muted)}
.contact-foot-link{color:var(--gold);font-weight:600;text-decoration:none}
.contact-foot-link:hover{text-decoration:underline}
.contact-dl{display:grid;grid-template-columns:repeat(2,1fr);gap:16px 32px;margin:0}
.contact-dl div{display:grid;grid-template-columns:140px 1fr;gap:10px;align-items:baseline}
.contact-dl dt{font-size:13px;color:var(--muted);margin:0;font-weight:500}
.contact-dl dd{margin:0;font-size:15px;color:var(--ink)}
@media(max-width:820px){
  .contact-layout{grid-template-columns:1fr}
  .contact-dl{grid-template-columns:1fr}
}
@media(max-width:680px){
  .contact-dl div{grid-template-columns:1fr;gap:4px}
  .legal-head h1{max-width:none}
}

/* ============================================================
   PRODUCT DETAIL
   ============================================================ */
.pdp{padding-block:clamp(48px,6vw,72px)}
.pdp-top{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(40px,5vw,80px);align-items:start}
.gallery-main{
  position:relative;aspect-ratio:1;overflow:hidden;
  background:transparent;
}
.gallery-main .card-badge{z-index:4}
.gallery-slides{position:absolute;inset:0}
.gallery-slide{
  position:absolute;inset:0;opacity:0;transition:opacity .85s var(--ease);
  pointer-events:none;
}
.gallery-slide.is-active{opacity:1;pointer-events:auto}
.gallery-slide-img{width:100%;height:100%;object-fit:contain;padding:0}
.gallery-dots{
  position:absolute;left:50%;bottom:14px;transform:translateX(-50%);z-index:3;
  display:flex;gap:7px;
}
.gallery-dot{
  width:6px;height:6px;border-radius:50%;border:none;padding:0;cursor:pointer;
  background:rgba(31,31,31,.2);transition:transform .25s var(--ease),background .25s;
}
.gallery-dot.active{background:var(--ink);transform:scale(1.2)}
.gallery-dot:hover{background:rgba(31,31,31,.45)}
.gallery-nav{
  position:absolute;top:50%;z-index:4;width:42px;height:42px;margin-top:-21px;
  border-radius:50%;border:1px solid rgba(31,31,31,.1);background:rgba(250,248,245,.9);
  display:flex;align-items:center;justify-content:center;color:var(--ink);cursor:pointer;
  transition:background .2s,opacity .25s,border-color .2s;opacity:.85;
}
.gallery-main:hover .gallery-nav{opacity:1}
.gallery-nav:hover{background:#fff;border-color:rgba(31,31,31,.18)}
.gallery-nav svg{width:17px;height:17px}
.gallery-nav-prev{left:8px}
.gallery-nav-next{right:8px}
.gallery-thumbs{
  display:flex;gap:10px;margin-top:14px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding-bottom:4px;scrollbar-width:thin;
}
.gallery-thumbs .thumb{
  flex:0 0 calc(20% - 8px);min-width:68px;aspect-ratio:1;scroll-snap-align:start;
  background:transparent;border:none;border-radius:0;
  overflow:hidden;position:relative;cursor:pointer;opacity:.55;
  transition:opacity .25s var(--ease);
}
.gallery-thumbs .thumb.active{opacity:1}
.gallery-thumbs .thumb:hover{opacity:.85}
.gallery-thumb-img{width:100%;height:100%;object-fit:contain;padding:0;background:transparent}
.pdp-info .cat{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);margin-bottom:14px}
.pdp-info h1{font-size:clamp(32px,3vw,42px);line-height:1.04;font-weight:600;letter-spacing:-.025em}
.pdp-rating{display:flex;align-items:center;gap:10px;margin-top:16px}
.pdp-rating .stars{margin-bottom:0}
.pdp-rating .stars i{width:12px;height:12px}
.pdp-rating .n{font-size:13.5px;color:var(--muted)}
.pdp-rating-link{background:none;border:none;padding:0;cursor:pointer;text-decoration:underline;text-underline-offset:2px;font:inherit}
.pdp-price{font-family:var(--display);font-weight:700;font-size:clamp(30px,2.8vw,36px);margin:22px 0 20px;letter-spacing:-.02em}
.pdp-price .old{font-size:18px;color:var(--muted);text-decoration:line-through;margin-right:10px;font-weight:500}
.pdp-desc-wrap{margin-bottom:26px;max-width:48ch}
.pdp-desc{line-height:1.65;color:var(--ink);margin:0;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;overflow:hidden}
.pdp-desc-expanded{-webkit-line-clamp:unset;display:block;overflow:visible}
.pdp-desc-part{margin-bottom:1em}
.pdp-read-more{margin-top:10px;padding:0;border:0;background:none;font:inherit;font-size:13.5px;font-weight:600;color:var(--brass);cursor:pointer;text-decoration:underline;text-underline-offset:3px}
.pdp-read-more:hover{color:var(--ink)}
.pdp-long-copy{max-width:62ch}
.pdp-long-copy p{line-height:1.7;color:var(--ink);margin:0 0 1.1em}
.pdp-long-copy p:last-child{margin-bottom:0}
.spec-table{width:100%;border-collapse:collapse;margin-bottom:30px}
.spec-table tr{border-bottom:1px solid var(--line)}
.spec-table td{padding:12px 0;font-size:14.5px;vertical-align:top}
.spec-table td:first-child{color:var(--muted);width:40%}
.spec-table td:last-child{font-weight:500}
.pdp-stock{display:flex;align-items:center;gap:9px;margin-bottom:16px;font-size:14px;color:var(--ink);font-weight:600}
.pdp-stock-dot{width:9px;height:9px;border-radius:50%;background:#3FA34D;flex-shrink:0;box-shadow:0 0 0 3px rgba(63,163,77,.18)}
.pdp-stock-sep{color:var(--line)}
.pdp-stock-ship{color:var(--muted);font-weight:400}
.buy-row{display:flex;gap:12px;align-items:stretch;margin-bottom:18px}
.buy-row .qty{height:54px}
.buy-row .qty button{width:46px;height:100%;font-size:18px}
.buy-row .qty span{min-width:40px;font-size:16px}
.buy-row .btn{flex:1;height:54px}
.pdp-price-note{font-size:15px;font-weight:500;color:var(--muted);margin-left:10px}
.engrave-panel{margin:0 0 26px;padding:22px;border:1px solid var(--line);border-radius:var(--r);background:linear-gradient(180deg,#fafafa 0%,#fff 100%)}
.engrave-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}
.engrave-head h3{font-family:var(--display);font-size:18px;margin:0 0 6px}
.engrave-head p{margin:0;font-size:13.5px;color:var(--muted);line-height:1.5;max-width:36ch}
.engrave-toggle{display:inline-flex;align-items:center;gap:10px;font-size:13px;font-weight:600;cursor:pointer;flex-shrink:0}
.engrave-toggle input{position:absolute;opacity:0;width:0;height:0}
.engrave-switch{width:44px;height:26px;border-radius:999px;background:var(--silver);position:relative;transition:.2s}
.engrave-switch::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:.2s}
.engrave-toggle input:checked+.engrave-switch{background:var(--green)}
.engrave-toggle input:checked+.engrave-switch::after{transform:translateX(18px)}
.engrave-meta{font-size:12.5px;color:var(--ink);margin-bottom:10px;line-height:1.5}
.engrave-note{font-size:12.5px;color:var(--muted);margin:0 0 14px;line-height:1.55}
.engrave-field{margin-bottom:12px}
.engrave-field label{display:block;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.engrave-field input{width:100%;height:48px;border:1px solid var(--line);border-radius:6px;padding:0 14px;font:inherit;font-size:15px;background:#fff}
.engrave-field input.engrave-preview{font-size:clamp(18px,2.2vw,24px);letter-spacing:.02em}
.engrave-field input:focus{outline:2px solid rgba(200,169,107,.35);border-color:var(--brass)}
.engrave-counter{text-align:right;font-size:12px;color:var(--muted);margin-top:6px}
.engrave-err{color:#B4452E;font-size:13px;margin:0 0 12px}
.engrave-fonts{border:none;margin:0;padding:0}
.engrave-fonts legend{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.engrave-font-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.engrave-font{display:flex;flex-direction:column;gap:4px;padding:12px;border:1px solid var(--line);border-radius:6px;background:#fff;cursor:pointer;transition:.2s;position:relative;min-height:96px}
.engrave-font input{position:absolute;opacity:0}
.engrave-font.active{border-color:var(--brass);box-shadow:0 0 0 1px var(--brass)}
.engrave-font-sample{font-size:clamp(22px,2.4vw,28px);line-height:1.15;color:var(--ink);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.engrave-font-name{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.engrave-font-hint{font-size:11px;color:var(--muted);line-height:1.35}
.engrave-fine{font-size:12px;color:var(--muted);margin:14px 0 0;line-height:1.5}
.engrave-materials{border:none;margin:0 0 16px;padding:0}
.engrave-materials legend{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.engrave-material-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:4px}
.engrave-material{display:flex;flex-direction:column;gap:4px;padding:12px;border:1px solid var(--line);border-radius:6px;background:#fff;cursor:pointer;transition:.2s}
.engrave-material input{position:absolute;opacity:0}
.engrave-material.active{border-color:var(--brass);box-shadow:0 0 0 1px var(--brass)}
.engrave-material-name{font-family:var(--display);font-weight:600;font-size:15px}
.engrave-material-hint{font-size:11px;color:var(--brass);font-weight:600}
.engrave-material-place{font-size:11px;color:var(--muted);line-height:1.35}
.card-badge.engrave-badge{
  left:auto;right:10px;top:auto;bottom:10px;background:var(--graphite);
  max-width:calc(100% - 20px);text-align:center;
}
.citem-engrave{font-size:12px;color:var(--ink);margin-top:8px;line-height:1.45;padding:8px 10px;background:#f7f7f7;border-radius:4px}
.citem-engrave-fee{color:var(--brass);font-weight:600}
.pdp-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.wish-btn{display:inline-flex;align-items:center;gap:9px;font-size:14px;font-weight:600;color:var(--ink);
  background:none;border:none;padding:8px 0;transition:color .2s}
.wish-btn:hover{color:var(--brass)}
.wish-btn.active{color:var(--brass)}
.wish-btn svg{width:19px;height:19px}
.pdp-assure{display:flex;flex-direction:column;gap:11px;margin-top:26px;padding-top:24px;border-top:1px solid var(--line)}
.pdp-sticky-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:120;background:rgba(250,248,245,.96);backdrop-filter:blur(12px);border-top:1px solid var(--line);padding:12px 20px calc(12px + env(safe-area-inset-bottom,0px));align-items:center;gap:14px;box-shadow:0 -4px 20px rgba(31,31,31,.08)}
.pdp-sticky-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.pdp-sticky-name{font-size:13px;font-weight:500;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pdp-sticky-price{font-size:17px;font-weight:700;color:var(--ink);font-family:var(--display)}
.pdp-sticky-btn{padding:13px 20px;font-size:14px;white-space:nowrap;flex-shrink:0}
@media(max-width:768px){.pdp-sticky-bar{display:flex}}
.pdp-assure .row{display:flex;align-items:center;gap:11px;font-size:clamp(12px,.9vw,14px);color:var(--ink)}
.pdp-assure .row svg{width:18px;height:18px;color:var(--green);flex-shrink:0}
.pdp-pay{margin-top:18px;padding-top:18px;border-top:1px solid var(--line-soft);display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.pdp-pay-label{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.pdp-pay-icons{display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.pdp-pay-icons img{height:26px;width:auto;border:1px solid var(--line);border-radius:5px;background:#fff;padding:3px 5px}
@media(max-width:768px){.pdp-main{padding-bottom:88px}}

/* tabs */
.pdp-tabs{margin-top:clamp(56px,7vw,90px)}
.tabbar{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:32px}
.tabbar button{font-family:inherit;font-size:15px;font-weight:600;color:var(--muted);background:none;border:none;
  padding:16px 22px;position:relative;transition:color .2s}
.tabbar button:hover{color:var(--ink)}
.tabbar button.active{color:var(--ink)}
.tabbar button.active::after{content:"";position:absolute;left:22px;right:22px;bottom:-1px;height:1.5px;background:var(--brass)}
.tabpane{max-width:760px;animation:fade .35s var(--ease)}
.tabpane p{line-height:1.7;color:var(--ink);margin:0 0 18px}
.tabpane h4{font-family:var(--display);font-size:20px;margin:28px 0 12px}
.tabpane ul{padding-left:20px;color:var(--ink);line-height:1.8}
@keyframes fade{from{opacity:0}to{opacity:1}}
main{animation:fade .4s var(--ease) both}
.review-list{display:grid;gap:18px;max-width:760px}
.rl-item{border:1px solid rgba(200,169,107,.14);background:var(--surface);border-radius:var(--r);padding:26px;box-shadow:var(--shadow-sm)}
.rl-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.rl-who{font-weight:600;font-size:14.5px}
.rl-who span{color:var(--muted);font-weight:500}
.rl-date{font-size:12.5px;color:var(--muted)}

/* ============================================================
   ANIMATIONS / REVEAL
   ============================================================ */
@keyframes anim-rise{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:none}
}
@keyframes anim-fade-in{
  from{opacity:0}
  to{opacity:1}
}
@keyframes hero-img-reveal{
  from{opacity:0;transform:scale(1.045)}
  to{opacity:1;transform:scale(1)}
}
@keyframes hero-spotlight-in{
  from{opacity:0;transform:translateY(14px)}
  to{opacity:1;transform:none}
}
@keyframes anim-pop-panel{
  from{opacity:0;transform:scale(.97) translateY(16px)}
  to{opacity:1;transform:none}
}

.hero2-animate .hero2-copy > *{
  opacity:0;animation:anim-rise .75s var(--ease) both;
}
.hero2-animate .hero2-copy .hero2-eyebrow{animation-delay:.06s}
.hero2-animate .hero2-copy h1{animation-delay:.14s}
.hero2-animate .hero2-copy .sub{animation-delay:.22s}
.hero2-animate .hero2-copy .hero2-perks{animation-delay:.3s}
.hero2-animate .hero2-copy .hero2-cta{animation-delay:.4s}
.hero2-animate .hero2-perks li{
  opacity:0;animation:anim-rise .55s var(--ease) both;
}
.hero2-animate .hero2-perks li:nth-child(1){animation-delay:.36s}
.hero2-animate .hero2-perks li:nth-child(2){animation-delay:.43s}
.hero2-animate .hero2-perks li:nth-child(3){animation-delay:.5s}
.hero2-visual-animate{opacity:0;animation:anim-rise .9s var(--ease) .1s both}

.reveal-up{opacity:0;transform:translateY(22px)}
.reveal-up.in{opacity:1;transform:none;transition:opacity .75s var(--ease),transform .75s var(--ease)}

.reveal-stagger > *{opacity:0;transform:translateY(20px)}
.reveal-stagger.in > *{
  opacity:1;transform:none;
  transition:opacity .65s var(--ease),transform .65s var(--ease);
}
.reveal-stagger.in > *:nth-child(1){transition-delay:0ms}
.reveal-stagger.in > *:nth-child(2){transition-delay:70ms}
.reveal-stagger.in > *:nth-child(3){transition-delay:140ms}
.reveal-stagger.in > *:nth-child(4){transition-delay:210ms}
.reveal-stagger.in > *:nth-child(5){transition-delay:280ms}
.reveal-stagger.in > *:nth-child(6){transition-delay:350ms}

/* ============================================================
   HELP POPUP
   ============================================================ */
.help-wrap{position:fixed;bottom:24px;right:24px;z-index:300;display:flex;flex-direction:column;align-items:flex-end;gap:12px;transition:bottom .25s var(--ease)}
@media(max-width:768px){body.has-sticky-cta .help-wrap{bottom:calc(84px + env(safe-area-inset-bottom,0px))}}

.help-trigger{width:58px;height:58px;border-radius:50%;border:none;padding:0;cursor:pointer;position:relative;box-shadow:0 4px 20px rgba(0,0,0,.18);transition:transform .2s var(--ease)}
.help-trigger:hover{transform:scale(1.07)}
.help-trigger.open{transform:scale(1.07)}
.help-trigger-img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}
.help-online-dot{position:absolute;bottom:2px;right:2px;width:14px;height:14px;border-radius:50%;background:#25D366;border:2.5px solid var(--white)}

.help-bubble{display:flex;align-items:center;gap:6px;background:var(--white);border-radius:20px 20px 4px 20px;box-shadow:var(--shadow-md);animation:help-pop .3s var(--ease) both;overflow:hidden}
.help-bubble-text{background:none;border:none;padding:12px 8px 12px 16px;font-size:14px;color:var(--ink);cursor:pointer;text-align:left;line-height:1.4;flex:1}
.help-bubble-text:hover{color:var(--brass)}
.help-bubble-close{background:none;border:none;padding:10px 12px 10px 4px;cursor:pointer;color:var(--muted);display:grid;place-content:center;flex-shrink:0;transition:color .15s}
.help-bubble-close:hover{color:var(--ink)}

.help-card{background:var(--white);border-radius:16px;box-shadow:var(--shadow-lg);width:300px;overflow:hidden;animation:help-pop .3s var(--ease) both}
.help-card-close{background:none;border:none;cursor:pointer;color:rgba(255,255,255,.8);width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:20px;line-height:1;flex-shrink:0;margin-left:auto;transition:color .15s,background .15s}
.help-card-close:hover{color:#fff;background:rgba(255,255,255,.15)}
.help-card-head{display:flex;align-items:center;gap:12px;padding:20px 20px 16px;background:var(--graphite);position:relative}
.help-card-avatar{width:46px;height:46px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid rgba(255,255,255,.2)}
.help-card-name{font-size:14px;font-weight:600;color:var(--white)}
.help-card-status{display:flex;align-items:center;gap:6px;font-size:12px;color:rgba(255,255,255,.65);margin-top:3px}
.help-dot{width:8px;height:8px;border-radius:50%;background:#25D366;flex-shrink:0}
.help-card-msg{margin:0;padding:18px 20px;font-size:14px;line-height:1.6;color:var(--ink);border-bottom:1px solid var(--line)}
.help-wa-btn{display:flex;align-items:center;gap:10px;margin:14px 16px 16px;padding:13px 18px;background:#25D366;color:#fff;border-radius:10px;font-size:14px;font-weight:600;text-decoration:none;transition:background .15s;justify-content:center}
.help-wa-btn:hover{background:#1ebe5d}

@keyframes help-pop{from{opacity:0;transform:translateY(10px) scale(.95)}to{opacity:1;transform:none}}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.01ms!important}
  .reveal-up,.reveal-stagger > *,.hero2-animate .hero2-copy > *,.hero2-animate .hero2-perks li,.hero2-visual-animate{
    opacity:1!important;transform:none!important;
  }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1080px){
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .cat-grid .cat-tile:nth-child(4),.cat-grid .cat-tile:nth-child(5){grid-column:span 1}
  .cols-4{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  .nav-links{display:none}
  .burger{display:flex}
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-media{min-height:46vh;order:-1}
  .hero-copy{padding-block:54px}
  .hero2-banner{grid-template-columns:1fr;gap:24px}
  .hero2-visual{order:-1}
  .hero2-media{max-height:340px}
  .hero2-perks{gap:9px 16px}
  .brandmoment .inner{grid-template-columns:1fr;gap:40px}
  .brandmoment-media{order:-1}
  .engrave-show .inner{grid-template-columns:1fr;gap:36px}
  .giftband .inner{grid-template-columns:1fr;gap:36px}
  .faq-grid{grid-template-columns:1fr;gap:22px}
  .newsletter .inner{grid-template-columns:1fr;gap:28px;border:none;background:none}
  .nl-form{margin-left:0}
  .review-grid{grid-template-columns:1fr}
  .featured-grid{grid-template-columns:1fr;gap:36px}
  .usp .inner{grid-template-columns:repeat(2,1fr);gap:26px}
  footer.site .inner{grid-template-columns:1fr;gap:40px}
  .catalog-layout{grid-template-columns:1fr;gap:0}
  .filters{position:fixed;top:0;left:0;height:100%;width:min(340px,90vw);background:var(--bg);z-index:85;
    padding:24px;overflow-y:auto;transform:translateX(-100%);transition:transform .35s var(--ease);box-shadow:var(--shadow-lg)}
  .filters.open{transform:none}
  .filters .mobile-filter-btn{display:flex}
  .filters-apply{display:inline-flex}
  .mobile-filter-btn{display:inline-flex}
  .pdp-top{grid-template-columns:1fr;gap:32px}
  .catalog-layout{padding-block:24px}
  .crumbs{font-size:12px}
}
@media(max-width:680px){
  .nav{gap:10px}
  .brand-logo{height:36px;max-width:min(150px,42vw)}
  .nav-right{gap:0}
  .icon-btn{width:40px;height:40px}
  .icon-btn svg{width:20px;height:20px}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .section-head{flex-direction:column;align-items:flex-start;gap:12px}
  .usp .inner{grid-template-columns:1fr}
  .hero h1{font-size:clamp(40px,11vw,60px)}
  .drawer{width:100vw}
  .engrave-head{flex-direction:column}
  .engrave-font-grid,.engrave-material-grid{grid-template-columns:1fr}

  /* ---- Catalog pagehead compact ---- */
  .pagehead .inner{padding-block:clamp(18px,4vw,28px)}
  .pagehead h1{font-size:clamp(22px,6vw,30px)}
  .pagehead .lead{display:none}
  .crumbs{display:none}

  /* ---- Toolbar sticky op mobiel ---- */
  .catalog-main .toolbar{
    position:sticky;top:72px;z-index:40;
    background:rgba(250,248,245,.97);backdrop-filter:blur(10px);
    margin:0 calc(-1 * var(--pad));padding:10px var(--pad);
    border-bottom:1px solid var(--line);margin-bottom:16px;
    gap:10px;flex-wrap:nowrap;align-items:center;
  }
  .toolbar-left{gap:8px;flex-wrap:nowrap;flex:1}
  .catalog-main .toolbar .res{display:none}
  .sort-wrap label{display:none}
  .sort-wrap .select select{font-size:13px;padding:8px 28px 8px 10px}

  /* ---- 1-kolom grid op kleine schermen ---- */
  .cols-3,.cols-4{grid-template-columns:1fr}
  .prod-grid{gap:0}

  /* ---- Product card: horizontale layout (afbeelding links, info rechts) ---- */
  .card{flex-direction:row;align-items:stretch;border-bottom:1px solid var(--line);padding:14px 0;gap:14px}
  .card-media{width:100px;flex-shrink:0;aspect-ratio:1;align-self:flex-start;border-radius:var(--r)}
  .card-body{padding:0;flex:1;display:flex;flex-direction:column;justify-content:space-between;min-width:0}
  .card:hover .card-media{box-shadow:none}
  .card-cat{display:none}
  .card-desc{display:none}
  .card-body::after{display:none}
  .card-name{font-size:15px;margin-bottom:4px;font-weight:600;line-height:1.25}
  .card-rating{margin-bottom:4px}
  .card-rating .stars i{width:10px;height:10px}
  .card-rating-n{font-size:11px}
  .card-foot{margin-top:auto;padding-top:10px;gap:8px;justify-content:space-between}
  .price{font-size:18px}
  .price .old{font-size:11px}
  .add-btn{padding:9px 14px;font-size:13px;gap:6px}
  .add-btn svg{width:14px;height:14px}
  .wish{opacity:1;transform:none;width:32px;height:32px;top:6px;right:0}
  .wish svg{width:15px;height:15px}
  .card-badge{top:6px;left:6px;font-size:10px;padding:3px 7px}
}
