:root{
  /* -- ACCESSIBILITY-OPTIMIZED COLORS (LIGHT) -- */
  --color-primary: #B83A24;
  --color-primary-hover: #C84428;
  --color-primary-dark: #8F2D1C;
  --color-secondary: #5C6E2A;
  --color-secondary-hover: #7A9038;
  --color-accent: #D4860A;
  --color-background: #FDFBFA; /* Clean off-white */
  --color-surface: #F7F3F0;    /* Neutral light surface */
  --color-surface-2: #F0EAE6;  /* Neutral accent surface */
  --color-text: #1A100A;
  --color-text-muted: #5A4628;
  --color-text-on-accent: #FFFFFF;
  --color-border: #D8CCB4;
  --color-danger: #B83020;
  --color-success: #3A7A48;

  /* Legacy overrides */
  --terra: var(--color-primary); --terrah: var(--color-primary-hover); --terrad: var(--color-primary-dark);
  --olive: var(--color-secondary); --oliveh: var(--color-secondary-hover);
  --mustard: var(--color-accent); --mustardl: #F0A830;
  --ink: var(--color-text); --ink2: #251810; --ink3: #332218;
  --paper: var(--color-background); --paper2: var(--color-surface); --paper3: var(--color-surface-2);
  --worn: var(--color-border); --wornl: #E8E4DE; --wornd: #A89878;
  --cream: #FFFFFF;
  --card: #FFFFFF; /* Pure white for cards */
  --muted: var(--color-text-muted); --mutedl: #8A7858;
  --green: var(--color-success);
  --am: var(--color-accent);
  --on-accent: var(--color-text-on-accent);
  --danger: var(--color-danger);

  --focus:rgba(200,66,42,.28);
  --overlay:rgba(26,16,10,.62);
  --overlay-soft:rgba(26,16,10,.42);
  --product-media:#F5F3EF;
  --accent-shadow:rgba(200,66,42,.24);
  --theme-dur:300ms;
  --theme-ease:ease-in-out;
  --fnd:'Playfair Display',serif;
  --fnb:'DM Sans',sans-serif;
  --fnh:'Caveat',cursive;
  --rad:4px;
  --sh:0 2px 8px rgba(26,16,10,.1),0 1px 0 rgba(26,16,10,.06);
  --sh2:0 8px 32px rgba(26,16,10,.18);
  --border:1px solid rgba(26,16,10,0.08);
  --img-bg:rgba(26,16,10,0.04);
  --skel1:#F0EAE6; --skel2:#F7F3F0;
  --noise-op:0.02;
}

body{
  background:var(--paper);
}
.nav{background:#251810;}
.pcard{background:var(--card);}
.qv-modal, .cm-box, .auth-box{background:var(--card);}
.cm-input, .auth-input{background:var(--paper2);}
.fi{background:var(--paper2);}

/* -- iOS AUTO-ZOOM PREVENTION -- */
@media (max-width: 768px) {
  input, textarea, select {
    font-size: 16px !important;
  }
}
.co-body {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 30px;
  padding: 30px;
}
@media (max-width: 850px) {
  .co-body { grid-template-columns: 1fr; padding: 20px; }
}
.co-form-section {
  background: var(--paper2);
  padding: 24px;
  border-radius: 8px;
  border: 1px solid var(--wornl);
  margin-bottom: 20px;
  transition: all 0.3s ease;
}
.co-form-section.active {
  border-color: var(--terra);
  box-shadow: 0 4px 12px rgba(224,90,58,0.1);
}
.fi.invalid {
  border-color: #B83020 !important;
  background-color: rgba(184,48,32,0.05);
}
.valid-msg {
  color: var(--green);
  font-size: 0.7rem;
  margin-top: 4px;
  display: none;
}
.fi:valid + .valid-msg { display: block; }

/* -- DYNAMIC FILTERS ANIMATIONS -- */
.prod-grid {
  display: grid;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.pcard {
  transition: transform 0.3s ease, opacity 0.3s ease;
}
.pcard.filtering {
  opacity: 0;
  transform: scale(0.95);
}

/* -- CROSS-SELLING -- */
.cross-sell-section {
  margin-top: 30px;
  padding-top: 25px;
  border-top: 2px dashed var(--worn);
}
.cross-sell-title {
  font-family: var(--fnd);
  font-size: 1.2rem;
  color: var(--cream);
  margin-bottom: 15px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.cross-sell-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 16px;
}
.cs-card {
  background: var(--paper3);
  border-radius: 6px;
  padding: 10px;
  cursor: pointer;
  transition: all 0.2s;
  border: 1px solid transparent;
}
.cs-card:hover {
  background: var(--worn);
  border-color: var(--terra);
}
.cs-img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 4px;
  margin-bottom: 8px;
}
.cs-info {
  font-size: 0.75rem;
}
.cs-name {
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 2px;
}
.cs-price {
  color: var(--terra);
  font-weight: 700;
}
.btn-cs-add {
  width: 100%;
  margin-top: 8px;
  padding: 6px;
  font-size: 0.7rem;
  background: var(--terra);
  color: white;
  border: none;
  border-radius: 4px;
  font-weight: 700;
}

/* -- THEME TOGGLE BUTTON -- */
.theme-toggle{
  width:36px;height:36px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:1rem;
  transition:all .2s;flex-shrink:0;
}
.theme-toggle:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.3);}
.btn-add{background:var(--ink);color:var(--cream);border:none;}
.btn-add:hover:not(:disabled){background:var(--terra);}


/* -- Issue 1 Fix: Prevent iOS Auto-Zoom -- */
@media(max-width:768px){
  input, select, textarea { font-size: 16px !important; }
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--fnb);
  background:var(--paper);
  color:var(--ink);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  background-image:
    url("data:image/svg+xml,%3Csvg width='200' height='200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23noise)' opacity='var(--noise-op)'/%3E%3C/svg%3E");
}
img{display:block;max-width:100%}
button{cursor:pointer;font-family:var(--fnb)}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--paper3)}
::-webkit-scrollbar-thumb{background:var(--terra);border-radius:0}

/* -- TAPE STRIP TOP -- */
.tape-top{
  height:8px;
  background:repeating-linear-gradient(
    90deg,
    var(--terra) 0, var(--terra) 40px,
    var(--terrad) 40px, var(--terrad) 80px,
    var(--olive) 80px, var(--olive) 120px,
    var(--mustard) 120px, var(--mustard) 160px
  );
}

/* -- ANNOUNCEMENT BAR -- */
.announcement-bar {
  background: var(--terra);
  color: #fff;
  text-align: center;
  padding: 8px 20px;
  font-size: 0.85rem;
  font-weight: 700;
  position: sticky;
  top: 0;
  z-index: 501; /* Above navbar (400) and cart drawer (500) */
  letter-spacing: 0.5px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.2);
}
.announcement-content {
  max-width: 1200px;
  margin: 0 auto;
}

/* -- NAVBAR -- */
.nav{
  position:sticky;top:0; /* announcement bar manages this via JS */
  z-index:400;
  background:var(--ink2);
  border-bottom:3px solid var(--terra);
  height:68px;display:flex;align-items:center;
  padding:0 36px;gap:16px;
  transition:top .25s ease;
}
.nav-logo{flex-shrink:0}
.nav-logo img{height:44px;object-fit:contain}
.nav-divider{width:1px;height:28px;background:rgba(255,255,255,.1);flex-shrink:0}
.nav-cats{
  display:flex;gap:0;list-style:none;flex:1;
  overflow-x:auto;scrollbar-width:none;
}
.nav-cats::-webkit-scrollbar{display:none}
.nav-cats a{
  display:block;padding:6px 14px;white-space:nowrap;
  color:var(--wornd);
  font-family:var(--fnb);font-size:.8rem;font-weight:600;letter-spacing:.3px;
  text-decoration:none;transition:all .18s;
  border-bottom:2px solid transparent;
}
.nav-cats a:hover{color:var(--wornl)}
.nav-cats a.active{color:var(--mustardl);border-bottom-color:var(--mustard)}
.nav-r{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-socs{display:flex;gap:6px}
.nsoc{
  width:32px;height:32px;
  border:var(--border);
  border-radius:2px;
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;transition:all .18s;
}
.nsoc:hover{background:var(--terra);border-color:var(--terra)}
.nsoc svg{width:14px;height:14px;fill:#fff}
.srch{position:relative}
.srch input{
  background:rgba(255,255,255,.07);
  border:var(--border);
  color:var(--cream);padding:7px 14px 7px 32px;
  font-size:.8rem;width:160px;outline:none;transition:all .22s;
  font-family:var(--fnb);border-radius:2px;
}
.srch input::placeholder{color:rgba(200,184,152,.35)}
.srch input:focus{width:200px;border-color:var(--mustard);background:rgba(255,255,255,.1)}
.srch-ic{position:absolute;left:10px;top:50%;transform:translateY(-50%);opacity:.35;pointer-events:none}
.srch-ic svg{width:13px;height:13px;fill:var(--worn)}
.cart-btn{
  display:flex;align-items:center;gap:7px;
  background:var(--terra);color:#fff;border:none;
  padding:8px 18px;
  font-weight:700;font-size:.82rem;transition:all .18s;letter-spacing:.3px;
  border-radius:2px;position:relative;
  font-family:var(--fnb);
}
.cart-btn:hover{background:var(--terrah);transform:translateY(-1px);box-shadow:0 4px 16px rgba(200,66,42,.4)}
.cart-n{
  background:var(--cream);color:var(--terra);
  width:18px;height:18px;border-radius:50%;
  font-size:.68rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;
}

/* -- TICKER -- */
.ticker{
  background:var(--mustard);overflow:hidden;
  padding:8px 0;border-bottom:1px solid var(--terrad);
}
.ticker-inner{
  display:flex;gap:0;width:max-content;
  animation:ticker 22s linear infinite;
}
.ticker-item{
  display:flex;align-items:center;gap:8px;
  padding:0 28px;color:var(--ink2);
  font-size:.78rem;font-weight:600;white-space:nowrap;letter-spacing:.3px;
}
.ticker-sep{color:rgba(26,16,10,.4);font-size:.6rem}

@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* -- SLOGAN -- */
.hero-slogan{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:14px;margin-bottom:4px;
  font-family:var(--fnh);font-size:1.45rem;font-weight:600;
  color:var(--mustardl);
  letter-spacing:.3px;
}
.hero-slogan::before,.hero-slogan::after{
  content:'';display:block;
  width:28px;height:1.5px;
  background:var(--mustard);opacity:.6;
}


/* -- HERO -- */
.hero{
  background:var(--ink2);
  min-height:520px;
  display:grid;grid-template-columns:1fr 380px;
  align-items:center;padding:72px 80px;gap:60px;
  position:relative;overflow:hidden;
}
/* Worn paper texture overlay */
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 600px 500px at 5% 60%,rgba(200,66,42,.14) 0%,transparent 55%),
    radial-gradient(ellipse 400px 400px at 95% 20%,rgba(212,134,10,.08) 0%,transparent 55%);
}
/* Diagonal stripe */
.hero::after{
  content:'';position:absolute;
  right:-100px;top:-80px;
  width:380px;height:800px;
  background:rgba(255,255,255,.02);
  transform:rotate(-14deg);
}
.hero-l{position:relative;z-index:2}
.hero-stamp{
  display:inline-block;
  border:2px solid var(--terra);
  padding:4px 12px;
  font-family:var(--fnb);font-size:.68rem;font-weight:700;
  letter-spacing:2.5px;text-transform:uppercase;color:var(--terra);
  margin-bottom:20px;
  position:relative;
}
.hero-stamp::before{content:'★';position:absolute;left:-8px;top:50%;transform:translateY(-50%);font-size:.6rem;color:var(--terra)}
.hero-stamp::after{content:'★';position:absolute;right:-8px;top:50%;transform:translateY(-50%);font-size:.6rem;color:var(--terra)}
.hero-h1{
  font-family:var(--fnd);
  font-size:5.2rem;font-weight:900;line-height:.95;
  color:var(--cream);margin-bottom:16px;letter-spacing:-1px;
}
.hero-h1 em{font-style:italic;color:var(--mustardl)}
.hero-h1 .line2{
  font-family:var(--fnh);
  font-size:3.8rem;font-weight:600;
  color:var(--terra);display:block;
  margin-top:4px;letter-spacing:0;
}
.hero-sub{
  color:var(--wornd);font-size:.96rem;line-height:1.8;
  max-width:440px;margin-bottom:32px;font-weight:300;
}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-hero{
  padding:13px 32px;border:none;
  font-weight:700;font-size:.9rem;letter-spacing:.4px;
  transition:all .22s;font-family:var(--fnb);border-radius:2px;
}
.btn-hero-p{background:var(--terra);color:#fff}
.btn-hero-p:hover{background:var(--terrah);transform:translateY(-2px);box-shadow:0 8px 24px rgba(200,66,42,.45)}
.btn-hero-s{background:transparent;color:var(--worn);border:1.5px solid rgba(200,184,152,.3)}
.btn-hero-s:hover{border-color:var(--worn);color:var(--cream)}
/* Hero right - hang tag */
.hero-r{
  position:relative;z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:16px;
}
.hang-tag{
  background:var(--paper2);
  border:1px solid var(--worn);
  border-radius:4px 4px 4px 4px;
  padding:24px 22px;
  width:220px;
  position:relative;
  box-shadow:4px 4px 0 rgba(26,16,10,.25);
  animation:sway 4s ease-in-out infinite;
  transform-origin:top center;
}
.hang-tag::before{
  content:'';position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  width:18px;height:18px;border-radius:50%;
  border:2px solid var(--wornd);background:var(--paper3);
  box-shadow:0 0 0 1px rgba(26,16,10,.1);
}
.hang-tag::after{
  content:'';position:absolute;top:-28px;left:50%;
  width:1px;height:16px;background:var(--wornd);
}
.ht-logo{display:flex;justify-content:center;margin-bottom:14px;padding-bottom:12px;border-bottom:1px dashed var(--worn)}
.ht-logo img{width:100px;height:100px;object-fit:contain}
.ht-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.78rem}
.ht-key{color:var(--muted);font-weight:500}
.ht-val{font-weight:700;color:var(--ink)}
.ht-val.big{font-family:var(--fnd);font-size:1.5rem;color:var(--terra);font-weight:900}
.ht-barcode{
  margin-top:14px;padding-top:12px;border-top:1px dashed var(--worn);
  display:flex;justify-content:center;
}
.ht-barcode svg{width:120px;height:28px}
.ht-stamp{
  position:absolute;bottom:14px;right:10px;
  font-family:var(--fnh);font-size:1.4rem;color:var(--terra);
  transform:rotate(-12deg);opacity:.7;font-weight:700;
}
@keyframes sway{0%,100%{transform:rotate(-1.5deg)}50%{transform:rotate(1.5deg)}}
.hero-pills{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.hpill{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  color:var(--wornd);padding:5px 13px;
  font-size:.73rem;font-weight:600;border-radius:2px;
}
.scroll-hint{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:6px;z-index:2;
  color:var(--wornd);font-size:.65rem;letter-spacing:2px;text-transform:uppercase;opacity:.5;
}
.scroll-dot{width:4px;height:4px;border-radius:50%;background:var(--terra);animation:bounce 1.6s ease-in-out infinite}
.scroll-dot:nth-child(3){animation-delay:.2s}
.scroll-dot:nth-child(4){animation-delay:.4s}
@keyframes bounce{0%,100%{transform:translateY(0);opacity:.4}50%{transform:translateY(4px);opacity:1}}

/* -- SECTION DIVIDER -- */
.sec-divider{
  background:var(--paper3);
  padding:14px 40px;
  display:flex;align-items:center;gap:16px;
  border-top:1px solid var(--worn);border-bottom:1px solid var(--worn);
}
.sec-divider-line{flex:1;height:1px;background:var(--worn);opacity:.5}
.sec-divider-text{
  font-family:var(--fnd);font-size:1.1rem;font-style:italic;
  color:var(--muted);white-space:nowrap;
}

/* -- SHOP SECTION -- */
.shop-wrap{
  padding:44px 60px 60px;
  background:var(--paper);
  background-image:url("data:image/svg+xml,%3Csvg width='40' height='40' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='20' cy='20' r='.5' fill='rgba(26,16,10,.04)'/%3E%3C/svg%3E");
}
.shop-hdr{margin-bottom:28px}
.shop-title-row{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:18px;flex-wrap:wrap;gap:12px;
}
.shop-title-group{}
.shop-title{
  font-family:var(--fnd);font-size:2.6rem;font-weight:900;
  color:var(--ink);line-height:1;
}
.shop-title-hand{
  font-family:var(--fnh);font-size:1.4rem;
  color:var(--terra);display:block;margin-top:2px;
  font-weight:600;
}
.shop-count{font-size:.82rem;color:var(--muted);font-weight:500;margin-top:4px}

/* FILTER ROW */
.filter-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  padding-bottom:18px;
  border-bottom:2px solid var(--paper3);
  align-items:center;
  row-gap:12px;
  /* Horizontal scroll fallback on very small screens */
  overflow-x:auto;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
}
.filter-row::-webkit-scrollbar{display:none;}
.filter-group{
  display:flex;
  align-items:center;
  gap:8px;
  background:var(--paper2);
  padding:4px 10px;
  border-radius:6px;
  border:1px solid var(--wornl);
}
.filter-label{
  font-size:.65rem;
  font-weight:700;
  text-transform:uppercase;
  color:var(--muted);
  letter-spacing:.5px;
}
.fselect-mini{
  background:transparent;
  border:none;
  font-size:.78rem;
  font-weight:600;
  color:var(--ink);
  font-family:var(--fnb);
  outline:none;
  cursor:pointer;
  padding:2px 4px;
}
.fchip{
  padding:6px 14px;
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.3px;
  background:transparent;
  color:var(--muted);
  border:1.5px solid var(--paper3);
  border-radius:4px;
  transition:all .18s cubic-bezier(0.4, 0, 0.2, 1);
  cursor:pointer;
  font-family:var(--fnb);
  box-sizing:border-box;
}
.fchip:hover{background:var(--paper2);border-color:var(--worn);color:var(--ink);transform:translateY(-1px)}
.fchip.active{background:var(--ink2);color:var(--cream);border-color:var(--ink2);transform:scale(1.02)}

/* Cross-selling Section */
.cross-sell{
  margin-top:20px;
  padding-top:20px;
  border-top:2px solid var(--paper3);
  animation:fadeIn .4s ease;
}
.cross-sell-t{
  font-family:var(--fnd);
  font-size:.95rem;
  font-weight:800;
  color:var(--ink);
  margin-bottom:12px;
  display:flex;
  align-items:center;
  gap:8px;
}
.cross-sell-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(140px, 1fr));
  gap:16px;
}
.cs-card{
  background:var(--img-bg);
  border:var(--border);
  padding:8px;
  transition:all .2s;
  cursor:pointer;
  position:relative;
}
.cs-card:hover{border-color:var(--terra);transform:translateY(-2px);box-shadow:var(--sh)}
.cs-img{
  height:100px;
  background:var(--img-bg);
  margin-bottom:6px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:2rem;
}
.cs-img img{width:100%;height:100%;object-fit:cover;mix-blend-mode:multiply;}
.cs-name{font-size:.72rem;font-weight:700;color:var(--ink);margin-bottom:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.cs-price{font-family:var(--fnd);font-size:.8rem;font-weight:800;color:var(--terra);}
.cs-btn{
  width:100%;
  margin-top:6px;
  background:var(--ink2);
  color:var(--cream);
  border:none;
  font-size:.65rem;
  font-weight:700;
  padding:5px;
  cursor:pointer;
  text-transform:uppercase;
}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* PRODUCT GRID */
.pgrid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:16px;
}

/* PRODUCT CARD */
.pcard{
  background:#F5F3EF;color:var(--ink);
  border:var(--border);
  border-radius:0;
  overflow:visible;
  position:relative;
  transition:all .24s cubic-bezier(.34,1.1,.64,1);
  box-shadow:var(--sh);
}
.pcard:hover{
  transform:translateY(-6px) rotate(.3deg);
  box-shadow:var(--sh2);
  z-index:10;
  border-color:var(--terra);
}
/* Tape corner */
.pcard::before{
  content:'';position:absolute;top:-6px;left:50%;transform:translateX(-50%);
  width:40px;height:12px;background:rgba(212,134,10,.35);
  border-radius:1px;z-index:5;
}
.pcard-img{
  aspect-ratio:1/1;width:100%;background:var(--img-bg);
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  font-size:3.5rem;
  border-bottom:var(--border);
}
.pcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;mix-blend-mode:multiply;}
.pcard:hover .pcard-img img{transform:scale(1.04)}
.pcard-img-ph{opacity:.25;transition:transform .3s}
.pcard:hover .pcard-img-ph{transform:scale(1.08)}

/* Price sticker */
.price-line{
  display:flex;align-items:baseline;gap:7px;
  margin-bottom:12px;
}
.price-amount{
  font-family:var(--fnd);font-size:1.25rem;font-weight:900;
  color:var(--ink);letter-spacing:-.3px;line-height:1;
}
.price-dt{
  font-size:.7rem;font-weight:700;color:var(--muted);
  text-transform:uppercase;letter-spacing:.5px;
}
.price-orig{
  font-size:.82rem;font-weight:600;
  color:var(--muted);text-decoration:line-through;
  margin-left:2px;
}
.price-sale-tag{
  font-size:.58rem;font-weight:800;letter-spacing:.5px;
  text-transform:uppercase;
  background:var(--terra);color:#fff;
  padding:2px 6px;margin-left:2px;
  vertical-align:middle;
}

/* Sold sticker */
.sold-sticker{
  position:absolute;top:14px;left:14px;
  background:rgba(255,255,255,.92);
  color:var(--ink);
  padding:8px 12px;font-size:.72rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  border-radius:999px;z-index:3;
  display:inline-flex;align-items:center;gap:6px;
  box-shadow:0 14px 30px rgba(0,0,0,.12);
  border:1px solid rgba(26,16,10,.08);
}
.sold-sticker span{display:inline-flex;align-items:center;gap:6px;}
.new-sticker{
  position:absolute;top:10px;left:10px;
  background:var(--olive);color:#fff;
  padding:5px 11px;font-size:.68rem;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;
  border-radius:2px;z-index:3;
  transform:rotate(-2deg);
  box-shadow:2px 2px 0 rgba(26,16,10,.3);
}
.pcard.sold{
  opacity:0.98;
  filter:grayscale(15%);
  border-color:rgba(98,88,78,.12);
  background:rgba(255,255,255,.95);
}
.pcard.sold .pcard-img::after{
  content:'Vendu';
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(255,255,255,0) 35%,rgba(23,19,16,.22) 100%);
  color:#fff;
  font-size:.85rem;
  font-weight:700;
  letter-spacing:.08em;
  display:flex;align-items:flex-end;justify-content:flex-end;
  padding:14px;
  pointer-events:none;
}
.pcard.sold .pcard-name,
.pcard.sold .pcard-desc,
.pcard.sold .pcard-cat,
.pcard.sold .ptag{color:var(--muted);}
.pcard.sold .btn-add{
  background:transparent;
  color:var(--muted);
  border:1px solid rgba(26,16,10,.12);
  box-shadow:none;
}
.pcard.sold .btn-add:disabled{
  opacity:1;
  color:var(--muted);
  cursor:not-allowed;
}
.pcard.sold .wish-btn{opacity:0!important;pointer-events:none;}
.wish-btn{
  position:absolute;top:10px;right:10px;
  width:34px;height:34px;border-radius:50%;
  background:var(--paper2);border:1px solid var(--worn);
  display:flex;align-items:center;justify-content:center;
  font-size:.95rem;cursor:pointer;transition:all .2s;z-index:3;
  opacity:0;transform:scale(.8);
}
.pcard:hover .wish-btn{opacity:1;transform:scale(1)}
.wish-btn.liked{opacity:1 !important;background:var(--terra);border-color:var(--terra);transform:scale(1) !important;}

.pcard-body{padding:14px 14px 16px;}
.pcard-cat{
  font-size:.65rem;font-weight:700;letter-spacing:1.2px;
  text-transform:uppercase;color:var(--olive);margin-bottom:5px;
}
.pcard-name{
  font-family:var(--fnd);font-size:1rem;font-weight:700;
  color:var(--ink);margin-bottom:8px;line-height:1.25;
}
.pcard-tags{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:8px}
.ptag{
  background:var(--paper2);border:1px solid var(--wornl);
  color:var(--muted);padding:2px 8px;
  font-size:.68rem;font-weight:600;border-radius:1px;
}
.pcard-desc{
  font-size:.77rem;color:var(--muted);line-height:1.55;margin-bottom:14px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  font-weight:400;
}
.btn-add{
  width:100%;background:var(--ink2);color:var(--cream);border:1px solid var(--worn);
  padding:10px;border-radius:2px;font-weight:700;font-size:.8rem;
  letter-spacing:.4px;transition:all .2s;text-transform:uppercase;
  font-family:var(--fnb);position:relative;overflow:hidden;
}
.btn-add::after{
  content:'';position:absolute;inset:0;
  background:var(--terra);transform:scaleX(0);transform-origin:left;
  transition:transform .22s ease;
}
.btn-add span{position:relative;z-index:1}
.btn-add:hover::after{transform:scaleX(1)}
.btn-add:hover{transform:none}
.btn-add:disabled{background:rgba(26,16,10,.04);color:var(--mutedl);cursor:not-allowed;border-color:rgba(26,16,10,.12);}
.btn-add:disabled::after{display:none}
.btn-add.incart{background:var(--green);color:#fff}
.btn-add.incart::after{display:none}

/* -- EMPTY / LOADING -- */
.empty-st{grid-column:1/-1;text-align:center;padding:80px 20px;color:var(--muted)}
.empty-st .ei{font-size:3rem;margin-bottom:14px;opacity:.3}
.empty-st p{font-family:var(--fnd);font-size:1.1rem;font-style:italic}
.grid-ld{grid-column:1/-1;display:flex;align-items:center;justify-content:center;padding:80px;gap:12px;color:var(--muted)}
.spin{width:22px;height:22px;border:2px solid var(--worn);border-top-color:var(--terra);border-radius:50%;animation:sp .7s linear infinite;flex-shrink:0}
@keyframes sp{to{transform:rotate(360deg)}}

/* -- FEATURE STRIP -- */
.feat-strip{
  background:var(--ink2);
  padding:48px 80px;
  display:flex;align-items:center;gap:60px;
  position:relative;overflow:hidden;
  border-top:3px solid var(--terra);
}
.feat-strip::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(45deg,transparent,transparent 20px,rgba(255,255,255,.01) 20px,rgba(255,255,255,.01) 21px);
}
.feat-text{flex:1;position:relative;z-index:1}
.feat-eyebrow{font-family:var(--fnd);font-size:.75rem;font-style:italic;color:var(--terra);margin-bottom:10px;letter-spacing:.5px}
.feat-title{font-family:var(--fnd);font-size:2.4rem;font-weight:900;color:var(--cream);line-height:1.05;margin-bottom:12px}
.feat-title em{font-style:italic;color:var(--mustardl)}
.feat-body{color:var(--wornd);font-size:.9rem;line-height:1.75;font-weight:300;max-width:440px;margin-bottom:22px}
.feat-logo{position:relative;z-index:1;flex-shrink:0}
.feat-logo img{width:160px;height:160px;object-fit:contain;animation:float 5s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-10px) rotate(2deg)}}

/* -- CART DRAWER -- */
.cart-bd{
  position:fixed;inset:0;z-index:500;
  background:rgba(26,16,10,.55);
  opacity:0;pointer-events:none;transition:opacity .22s;
  display:flex;justify-content:flex-end;
}
.cart-bd.open{opacity:1;pointer-events:all}
.cart-dr{
  width:100%;max-width:390px;background:var(--card);
  display:flex;flex-direction:column;
  transform:translateX(110%);transition:transform .28s cubic-bezier(.4,0,.2,1);
  box-shadow:-6px 0 40px rgba(26,16,10,.2);
  border-left:3px solid var(--terra);
}
.cart-bd.open .cart-dr{transform:translateX(0)}
.cart-hd{
  padding:18px 20px;display:flex;align-items:center;justify-content:space-between;
  border-bottom:2px solid var(--paper3);
  background:var(--paper2);
}
.cart-hd-t{
  font-family:var(--fnd);font-size:1.2rem;font-weight:700;
  display:flex;align-items:center;gap:8px;
}
.cart-x{
  background:none;border:1px solid var(--worn);width:30px;height:30px;
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);font-size:.85rem;transition:all .15s;border-radius:1px;
}
.cart-x:hover{background:var(--terra);border-color:var(--terra);color:#fff}
.cart-body{flex:1;overflow-y:auto;padding:14px}
.cart-empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  height:220px;color:var(--muted);gap:10px;text-align:center;
}
.cart-empty span{font-size:2.5rem;opacity:.3}
.cart-empty p{font-family:var(--fnd);font-size:.9rem;font-style:italic}
.cline{display:flex;gap:12px;align-items:flex-start;padding:13px 0;border-bottom:1px dashed var(--worn)}
.cline:last-child{border:none}
.cline-img{
  width:56px;height:56px;background:var(--img-bg);
  border:var(--border);overflow:hidden;
  display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;
}
.cline-img img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply;}
.cline-info{flex:1}
.cline-name{font-weight:700;font-size:.87rem;margin-bottom:2px;color:var(--ink)}
.cline-meta{font-size:.74rem;color:var(--muted)}
.cline-price{font-family:var(--fnd);font-weight:700;font-size:.9rem;margin-top:3px;color:var(--terra)}
.cline-rm{background:none;border:none;color:var(--muted);cursor:pointer;font-size:.82rem;transition:color .15s;padding:3px}
.cline-rm:hover{color:var(--terra)}
.cart-ft{border-top:2px solid var(--paper3);padding:16px 20px;display:none;background:var(--paper)}
.cart-row{display:flex;justify-content:space-between;font-size:.83rem;color:var(--muted);margin-bottom:6px}
.cart-row.tot{
  font-family:var(--fnd);font-size:1.1rem;color:var(--ink);
  margin-top:10px;padding-top:10px;border-top:1px dashed var(--worn);
}
.bundle-tag{
  background:rgba(200,66,42,.08);border:1px solid rgba(200,66,42,.2);
  padding:8px 12px;margin-bottom:12px;border-radius:4px;
  display:flex;align-items:center;gap:10px;
}
.bundle-tag-ic{font-size:1.1rem}
.bundle-tag-tx{font-size:.72rem;color:var(--terra);line-height:1.3;font-weight:600}
.btn-co{
  width:100%;background:var(--terra);color:#fff;border:none;
  padding:13px;font-weight:700;font-size:.88rem;
  margin-top:12px;transition:all .18s;letter-spacing:.4px;
  text-transform:uppercase;font-family:var(--fnb);border-radius:2px;
}
.btn-co:hover{background:var(--terrah);transform:translateY(-1px)}

/* -- CHECKOUT MODAL -- */
.co-ov{
  position:fixed;inset:0;z-index:600;
  background:rgba(26,16,10,.65);
  display:flex;
  padding:16px;opacity:0;pointer-events:none;transition:opacity .22s;
  overflow-y:auto;
}
.co-ov.open{opacity:1;pointer-events:all}
.co-modal{
  background:var(--card);
  border:2px solid var(--worn);
  border-top:4px solid var(--terra);
  width:100%;max-width:760px;
  margin:auto;
  display:flex;flex-direction:column;
  box-shadow:8px 8px 0 rgba(26,16,10,.25);
  transform:translateY(14px) scale(.98);transition:all .22s cubic-bezier(.34,1.1,.64,1);
}
.co-ov.open .co-modal{transform:none}
.co-hd{
  padding:12px 22px;border-bottom:1px solid var(--wornl);
  display:flex;align-items:center;justify-content:space-between;flex-shrink:0;
  background:var(--paper2);
}
.co-hd-t{font-family:var(--fnd);font-size:1.1rem;font-weight:700}
.co-x{
  background:none;border:1px solid var(--worn);width:30px;height:30px;
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;cursor:pointer;transition:all .15s;color:var(--muted);
}
.co-x:hover{background:var(--terra);color:#fff;border-color:var(--terra)}
.co-body{overflow-y:auto;flex:1;display:flex}
.co-form{flex:1;padding:14px 22px;border-right:1px solid var(--wornl)}
.co-sum{width:215px;padding:16px;flex-shrink:0;background:var(--paper2)}
.co-sec{
  font-family:var(--fnd);font-size:.75rem;font-style:italic;
  color:var(--muted);margin:8px 0 6px;
  display:flex;align-items:center;gap:8px;
}
.co-sec:first-child{margin-top:0}
.co-sec::after{content:'';flex:1;height:1px;background:var(--wornl)}
.fg2{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}
.fg1{display:flex;flex-direction:column;gap:3px;margin-bottom:8px}
.fl{font-size:.68rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--muted)}
.fi{
  padding:7px 10px;border:1.5px solid var(--wornl);
  font-size:.87rem;outline:none;transition:all .18s;
  background:var(--cream);font-family:var(--fnb);color:var(--ink);
  border-radius:1px;
}
.fi:focus{border-color:var(--terra);box-shadow:0 0 0 3px rgba(200,66,42,.1)}
.fi::placeholder{color:rgba(138,118,88,.4)}
.fsel{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238A7658' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}
.form-field,.fg1,.auth-field,.cm-field,.qv-review-field{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.form-grid,.fg2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:10px}
.form-grid--1{grid-template-columns:1fr}
.form-row,.promo-row,.qv-review-rating{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.form-label,.fl,.auth-label,.cm-label,.qv-review-label{display:block;font-size:.67rem;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:var(--muted)}
.form-control,.fi,.auth-input,.cm-input,.qv-review-input,#offerPriceInput,#promoInput{width:100%;padding:10px 12px;border:1.5px solid var(--wornl);background:var(--paper2);color:var(--ink);font-size:.86rem;font-family:var(--fnb);outline:none;transition:all .18s;border-radius:2px}
.form-control:focus,.fi:focus,.auth-input:focus,.cm-input:focus,.qv-review-input:focus,#offerPriceInput:focus,#promoInput:focus{border-color:var(--terra);box-shadow:0 0 0 3px rgba(200,66,42,.08)}
textarea.form-control,textarea.fi,textarea.cm-input,textarea.qv-review-input{resize:vertical;min-height:100px;line-height:1.6}
.form-control::placeholder,.fi::placeholder,.auth-input::placeholder,.cm-input::placeholder,.qv-review-input::placeholder,#offerPriceInput::placeholder,#promoInput::placeholder{color:rgba(138,118,88,.4)}
.form-message,#coValidationMsg,.auth-err,#qvReviewLoginMsg,#qvReviewAlreadyMsg,#offerResult{font-size:.76rem;line-height:1.5;padding:10px 12px;border-radius:8px}
#coValidationMsg,.auth-err,#offerResult{border:1px solid rgba(184,48,32,.25);background:rgba(184,48,32,.12);color:#B83020}
#qvReviewLoginMsg{border:1px dashed var(--worn);background:var(--paper2);color:var(--muted)}
#qvReviewAlreadyMsg{border:1px solid var(--green);background:rgba(74,154,88,.1);color:var(--green)}
.auth-box,.cm-box,.ret-box,.qv-review-form{border-radius:16px;box-shadow:0 24px 70px rgba(0,0,0,.35)}
.ret-sub{font-size:.82rem;color:var(--muted);line-height:1.6;margin-bottom:14px}
.form-summary,.co-sum{border-radius:14px}
.form-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.form-compact{max-width:420px}
.osl{display:flex;justify-content:space-between;font-size:.81rem;padding:6px 0;border-bottom:1px dashed var(--worn);color:var(--muted)}
.osl:last-child{border:none}
.osl span:last-child{font-weight:600;color:var(--ink)}
.os-tot{
  display:flex;justify-content:space-between;
  font-family:var(--fnd);font-size:1rem;font-weight:700;
  padding-top:8px;margin-top:6px;border-top:2px solid var(--worn);
}
.info-box{
  margin-top:10px;background:var(--paper3);
  border:1px solid var(--worn);padding:10px;
  font-size:.74rem;color:var(--muted);line-height:1.6;
}
.btn-place{
  width:100%;background:var(--terra);color:#fff;border:none;
  padding:11px;font-weight:700;font-size:.88rem;
  margin-top:12px;transition:all .2s;letter-spacing:.4px;text-transform:uppercase;
  font-family:var(--fnb);border-radius:2px;
}
.btn-place:hover{background:var(--terrah);transform:translateY(-1px);box-shadow:0 6px 20px rgba(200,66,42,.4)}
.btn-place:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}

/* -- SUCCESS -- */
.succ{
  display:none;flex-direction:column;align-items:center;
  justify-content:center;padding:48px 28px;text-align:center;flex:1;
  background:var(--cream);
}
.succ-stamp{
  width:90px;height:90px;border-radius:50%;
  border:3px solid var(--green);
  display:flex;align-items:center;justify-content:center;
  font-size:2.2rem;margin-bottom:18px;color:var(--green);
  animation:stampIn .5s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes stampIn{from{transform:scale(0) rotate(-20deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}
.succ-t{
  font-family:var(--fnd);font-size:1.7rem;font-weight:900;margin-bottom:6px;
}
.succ-hand{font-family:var(--fnh);font-size:1.3rem;color:var(--terra);margin-bottom:12px}
.succ-s{color:var(--muted);font-size:.87rem;line-height:1.7;max-width:300px;margin-bottom:18px}
.succ-id{
  background:var(--paper2);border:1.5px dashed var(--worn);
  padding:10px 22px;font-family:var(--fnd);font-size:1.1rem;font-weight:900;
  letter-spacing:1px;margin-bottom:18px;color:var(--terra);
}
.succ-soc{display:flex;gap:8px;justify-content:center}
.succ-soc a{
  display:flex;align-items:center;gap:5px;
  padding:8px 14px;
  background:var(--paper2);border:1px solid var(--worn);
  color:var(--muted);font-size:.78rem;font-weight:600;text-decoration:none;
  transition:all .18s;
}
.succ-soc a:hover{background:var(--terra);color:#fff;border-color:var(--terra)}
.succ-soc svg{width:13px;height:13px;fill:currentColor}

/* -- TOAST -- */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(100px);
  z-index:1200; /* above FAB (450) and all modals */
  background:var(--ink2);color:var(--cream);
  padding:12px 20px;font-size:.83rem;font-weight:600;
  box-shadow:4px 4px 0 rgba(26,16,10,.3);
  border-left:3px solid var(--terra);
  border-radius:4px;
  opacity:0;transition:all .32s cubic-bezier(.34,1.4,.64,1);
  display:flex;align-items:center;gap:8px;max-width:340px;width:calc(100% - 32px);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.err{border-left-color:var(--terra);background:var(--terra)}
.tdot{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0}
.toast.err .tdot{background:rgba(255,255,255,.6)}

/* -- FOOTER -- */
footer{
  background:var(--ink2);color:var(--wornd);
  padding:52px 80px 28px;
  border-top:3px solid var(--terra);
}
.foot-top{
  display:grid;grid-template-columns:1fr 1fr 1fr;
  gap:48px;margin-bottom:36px;padding-bottom:36px;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.foot-logo{margin-bottom:14px}
.foot-logo img{height:56px;object-fit:contain}
.foot-tagline{font-family:var(--fnh);font-size:1.1rem;color:rgba(200,184,152,.5);margin-top:8px}
.foot-col-t{
  font-family:var(--fnd);font-size:.85rem;font-weight:700;font-style:italic;
  color:rgba(200,184,152,.7);margin-bottom:14px;
  padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.08);
}
.foot-links{display:flex;flex-direction:column;gap:8px}
.foot-links a{color:rgba(200,184,152,.38);font-size:.82rem;text-decoration:none;transition:color .18s;display:flex;align-items:center;gap:7px}
.foot-links a:hover{color:var(--terra)}
.foot-socs{display:flex;gap:8px;margin-top:4px}
.fsoc{
  width:38px;height:38px;border:1px solid rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;transition:all .18s;border-radius:1px;
}
.fsoc:hover{background:var(--terra);border-color:var(--terra);transform:translateY(-2px)}
.fsoc svg{width:15px;height:15px;fill:rgba(255,255,255,.7)}
.fsoc:hover svg{fill:#fff}
.foot-bottom{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:10px;
}
.foot-copy{font-size:.74rem;opacity:.28}
.foot-hand{font-family:var(--fnh);font-size:1rem;color:rgba(200,184,152,.35)}

/* -- RESPONSIVE -- */






/* -- ACCOUNT BTN -- */

/* -- WISHLIST NAV BTN -- */
.wish-nav-btn{
  display:flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.06);color:var(--cream);
  border:1px solid rgba(255,255,255,.2);
  padding:7px 14px;font-weight:700;font-size:.82rem;
  transition:all .18s;border-radius:2px;
  font-family:var(--fnb);white-space:nowrap;cursor:pointer;
}
.wish-nav-btn:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.4);}
.wish-nav-btn.has-items{color:#fff;background:var(--terra);border-color:var(--terra);}
#wishNavCount:not(:empty)::before{content:'('}
#wishNavCount:not(:empty)::after{content:')'}

/* -- WISHLIST DRAWER -- */
.wish-bd{
  position:fixed;inset:0;z-index:600;
  display:flex;align-items:stretch;justify-content:flex-end;
  opacity:0;visibility:hidden;
  transition:opacity .28s,visibility .28s;
}
.wish-bd.open{opacity:1;visibility:visible;}
.wish-bd-bg{position:absolute;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(3px);}
.wish-panel{
  position:relative;z-index:1;
  width:min(400px,100vw);
  background:var(--card);
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform .32s cubic-bezier(.4,0,.2,1);
  border-left:1px solid var(--worn);
}
.wish-bd.open .wish-panel{transform:translateX(0);}
.wish-ph{
  padding:18px 20px;border-bottom:1px solid var(--worn);
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;
}
.wish-ph-title{font-family:var(--fnd);font-size:1.1rem;font-weight:700;color:var(--cream);}
.wish-ph-sub{font-size:.72rem;color:var(--muted);margin-top:2px;}
.wish-close{background:none;border:none;color:var(--muted);font-size:1.2rem;cursor:pointer;padding:4px;transition:color .15s;}
.wish-close:hover{color:var(--terra);}
.wish-body{flex:1;overflow-y:auto;padding:16px;}
.wish-empty{
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:12px;height:200px;
  color:var(--muted);text-align:center;
}
.wish-empty-ic{font-size:2.5rem;}
.wish-empty-t{font-size:.88rem;font-weight:600;color:var(--cream);}
.wish-empty-s{font-size:.76rem;}
.wish-item{
  display:flex;gap:12px;align-items:flex-start;
  padding:12px 0;border-bottom:1px solid var(--worn);
}
.wish-item:last-child{border-bottom:none;}
.wish-item-img{
  width:64px;height:64px;flex-shrink:0;
  background:var(--img-bg);overflow:hidden;border:var(--border);
}
.wish-item-img img{width:100%;height:100%;object-fit:contain;display:block;mix-blend-mode:multiply;}
.wish-item-img .wish-item-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;}
.wish-item-info{flex:1;min-width:0;}
.wish-item-cat{font-size:.6rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--terra);margin-bottom:2px;}
.wish-item-name{font-weight:700;font-size:.88rem;color:var(--cream);line-height:1.3;margin-bottom:4px;}
.wish-item-price{font-family:var(--fnd);font-size:1rem;font-weight:700;color:var(--cream);}
.wish-item-price span{font-size:.65rem;font-weight:500;color:var(--muted);}
.wish-item-orig{font-size:.72rem;text-decoration:line-through;color:var(--muted);margin-left:5px;}
.wish-item-actions{display:flex;gap:6px;margin-top:8px;}
.wish-add-btn{
  flex:1;background:var(--terra);color:#fff;border:none;
  padding:7px 10px;font-size:.72rem;font-weight:700;
  cursor:pointer;font-family:var(--fnb);transition:all .15s;
}
.wish-add-btn:hover:not(:disabled){background:var(--terrad);}
.wish-add-btn:disabled{opacity:.5;cursor:not-allowed;}
.wish-rm-btn{
  background:var(--paper2);color:var(--muted);border:1px solid var(--worn);
  padding:7px 10px;font-size:.72rem;cursor:pointer;font-family:var(--fnb);transition:all .15s;
}
.wish-rm-btn:hover{color:var(--terra);border-color:var(--terra);}
.wish-ft{padding:14px 20px;border-top:1px solid var(--worn);flex-shrink:0;}
.wish-clear-btn{
  width:100%;background:none;border:1px solid var(--worn);
  color:var(--muted);padding:9px;font-size:.76rem;font-weight:600;
  cursor:pointer;font-family:var(--fnb);transition:all .15s;
}
.wish-clear-btn:hover{border-color:var(--terra);color:var(--terra);}

.acct-btn{
  display:flex;align-items:center;gap:5px;
  background:transparent;color:rgba(200,184,152,.7);border:1px solid rgba(255,255,255,.15);
  padding:7px 13px;font-weight:600;font-size:.78rem;
  transition:all .18s;border-radius:2px;
  font-family:var(--fnb);white-space:nowrap;
}
.acct-btn:hover{color:var(--cream);border-color:rgba(255,255,255,.35);}
.acct-btn.logged-in{color:var(--mustardl);border-color:rgba(212,134,10,.4);}

/* -- AUTH MODAL -- */
.auth-overlay{
  position:fixed;inset:0;z-index:960;
  background:rgba(15,8,3,.85);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;
  transition:opacity .3s,visibility .3s;padding:20px;
}
.auth-overlay.open{opacity:1;visibility:visible;}
.auth-box{
  background:var(--card);max-width:400px;width:100%;
  border-top:4px solid var(--terra);padding:36px 32px;
  position:relative;
  transform:translateY(30px) scale(.96);
  transition:transform .35s cubic-bezier(.34,1.2,.64,1);
  box-shadow:0 40px 100px rgba(0,0,0,.5);
}
.auth-overlay.open .auth-box{transform:translateY(0) scale(1);}
.auth-title{font-family:var(--fnd);font-size:1.4rem;font-weight:900;margin-bottom:4px;}
.auth-sub{font-size:.78rem;color:var(--muted);margin-bottom:22px;}
.auth-tabs{display:flex;gap:0;margin-bottom:22px;border-bottom:2px solid var(--paper3);}
.auth-tab{flex:1;padding:9px;font-size:.8rem;font-weight:700;background:none;border:none;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .18s;font-family:var(--fnb);}
.auth-tab.active{color:var(--terra);border-bottom-color:var(--terra);}
.auth-field{margin-bottom:14px;}
.auth-label{display:block;font-size:.65rem;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:var(--muted);margin-bottom:5px;}
.auth-input{width:100%;padding:10px 12px;border:1.5px solid var(--worn);background:var(--paper2);color:var(--ink);font-size:.86rem;font-family:var(--fnb);outline:none;transition:border .18s;}
.auth-input:focus{border-color:var(--terra);}
.auth-btn{width:100%;background:var(--terra);color:#fff;border:none;padding:13px;font-weight:800;font-size:.9rem;cursor:pointer;font-family:var(--fnb);transition:all .18s;margin-top:4px;}
.auth-btn:hover{background:var(--terrad);transform:translateY(-1px);}
.auth-btn:disabled{opacity:.5;cursor:not-allowed;}
.auth-google-btn{display:flex;align-items:center;justify-content:center;gap:10px;background:#fff;color:var(--ink);border:1.5px solid var(--worn);margin-top:10px;}
.auth-google-btn:hover{background:#fff;border-color:var(--terra);color:var(--terra);}
.auth-google-ic{width:18px;height:18px;flex:0 0 18px;display:block;}
.auth-divider{display:flex;align-items:center;gap:10px;margin:14px 0 8px;color:var(--muted);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--worn);}
.auth-err{font-size:.75rem;color:#B83020;margin-top:8px;padding:7px 10px;background:rgba(184,48,32,.12);border:1px solid rgba(184,48,32,.25);display:none;}
.auth-close{position:absolute;top:12px;right:12px;width:32px;height:32px;background:var(--paper2);color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:50%;font-size:1rem;transition:all .15s;border:1px solid var(--worn);}
.auth-close:hover{background:var(--terra);color:#fff;transform:rotate(90deg);}
.auth-profile{text-align:center;padding:8px 0;}
.auth-profile-av{width:56px;height:56px;border-radius:50%;background:var(--terra);color:#fff;font-size:1.4rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;}
.auth-profile-name{font-family:var(--fnd);font-size:1.1rem;font-weight:900;margin-bottom:4px;}
.auth-profile-email{font-size:.78rem;color:var(--muted);margin-bottom:18px;}
.auth-signout{background:var(--paper2);color:var(--ink);border:1.5px solid var(--worn);width:100%;padding:10px;font-weight:700;font-size:.82rem;cursor:pointer;font-family:var(--fnb);transition:all .18s;}
.auth-signout:hover{border-color:var(--terra);color:var(--terra);}


/* -- SALE PRICE -- */

.sale-badge{position:absolute;top:10px;left:10px;background:var(--terra);color:#fff;font-size:.6rem;font-weight:800;padding:3px 7px;letter-spacing:.5px;z-index:4}

/* -- SCROLL REVEALS -- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-l{opacity:0;transform:translateX(-32px);transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1)}
.reveal-l.visible{opacity:1;transform:translateX(0)}
.reveal-r{opacity:0;transform:translateX(32px);transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1)}
.reveal-r.visible{opacity:1;transform:translateX(0)}

/* -- CARD SHINE -- */
.pcard{overflow:hidden;}
.pcard-shine{position:absolute;inset:0;background:linear-gradient(105deg,transparent 35%,rgba(255,255,255,.16) 50%,transparent 65%);transform:translateX(-100%) skewX(-15deg);transition:transform .55s ease;pointer-events:none;z-index:15;}
.pcard:hover .pcard-shine{transform:translateX(200%) skewX(-15deg);}
.pcard-img::after{content:'Quick View';position:absolute;inset:0;background:rgba(26,16,10,.5);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:#fff;opacity:0;transition:opacity .22s;pointer-events:none;}
.pcard:hover .pcard-img::after{opacity:1;}

/* -- QV IMAGE GALLERY - FADE -- */
/*
  Quick View Style Guide
  ----------------------
  Variables:
    --terra, --terrad, --paper, --paper2, --ink, --muted,
    --worn, --paper3, --green, --am

  Components:
    .qv-overlay  -> fullscreen modal layer
    .qv-modal    -> responsive card container
    .qv-img-wrap -> image hero with optional sold-out overlay
    .qv-actions  -> primary CTA region
    .qv-sold-actions -> sold-out fallback action bar

  Integration:
    - Call updateQVSchema(product) when opening a product.
    - Use trackEvent('quickview_open', { productId, productName, sold })
      to capture Quick View performance.
    - lazyLoadImages() must be run after image markup injection.
*/
.qv-img-wrap{position:relative;background:#F5F3EF;overflow:hidden;height:100%;}
.qv-img-frame{position:relative;width:100%;height:100%;min-height:400px;}
.qv-img-frame img,.qv-img-frame .qv-img-ph{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:contain;
  mix-blend-mode:multiply;
  opacity:0;
  transition:opacity .42s ease;
  pointer-events:none;
}
.qv-img-frame img.qv-active{opacity:1;pointer-events:auto;cursor:zoom-in;background:#F5F3EF;}
.qv-img-frame img.qv-active:hover{transform:none;}
.qv-img-frame .qv-img-ph{display:flex;align-items:center;justify-content:center;font-size:5rem;background:#F5F3EF;}
.qv-img-frame .qv-img-ph.qv-active{opacity:1;}
/* Thumbnails strip */
.qv-thumbs{
  position:absolute;bottom:0;left:0;right:0;
  display:flex;gap:24px;padding:16px;
  background:linear-gradient(to top, rgba(15,8,3,.3) 0%, transparent 100%);
  z-index:10;overflow-x:auto;scrollbar-width:none;
}
.qv-thumbs::-webkit-scrollbar{display:none;}
.qv-thumb{
  width:42px;height:42px;flex-shrink:0;
  border:2px solid transparent;
  overflow:hidden;cursor:pointer;
  transition:border-color .15s, transform .15s;
  opacity:.65;
  transition:opacity .15s, border-color .15s, transform .15s;
}
.qv-thumb:hover{opacity:1;transform:translateY(-2px);}
.qv-thumb.qv-thumb-active{border-color:var(--terra);opacity:1;}
.qv-thumb img{width:100%;height:100%;object-fit:contain;display:block;background:#F5F3EF;mix-blend-mode:multiply;}
/* Arrow buttons */
.qv-gal-prev,.qv-gal-next{
  position:absolute;top:45%;transform:translateY(-50%);
  background:rgba(26,16,10,.5);color:#fff;border:none;
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:1rem;z-index:11;
  transition:background .15s, transform .2s;
  backdrop-filter:blur(4px);
}
.qv-gal-prev{left:8px;}.qv-gal-next{right:8px;}
.qv-gal-prev:hover{background:var(--terra);transform:translateY(-50%) translateX(-2px);}
.qv-gal-next:hover{background:var(--terra);transform:translateY(-50%) translateX(2px);}

/* -- QUICKVIEW OVERLAY -- */
.qv-overlay{position:fixed;inset:0;z-index:900;background:rgba(15,8,3,.8);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;padding:20px;}
.qv-overlay.open{opacity:1;visibility:visible;}
.qv-modal{background:var(--card);max-width:820px;width:100%;display:grid;grid-template-columns:1.05fr 1fr;position:relative;transform:translateY(40px) scale(.95);transition:transform .38s cubic-bezier(.34,1.2,.64,1);max-height:92vh;overflow:hidden;border-top:4px solid var(--terra);box-shadow:0 40px 100px rgba(0,0,0,.6);}
.qv-overlay.open .qv-modal{transform:translateY(0) scale(1);}
.qv-sold-banner{position:absolute;top:20px;right:20px;left:auto;bottom:auto;background:rgba(15,15,15,.78);display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border-radius:999px;font-family:var(--fnd);font-size:.9rem;font-weight:800;color:#fff;letter-spacing:.12em;z-index:10;pointer-events:none;backdrop-filter:blur(8px);box-shadow:0 16px 40px rgba(0,0,0,.15);}

.qv-body{padding:26px 24px;display:flex;flex-direction:column;gap:12px;overflow-y:auto;max-height:92vh;}
.qv-tag{font-size:.62rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--terra);margin-bottom:2px;}
.qv-name{font-family:var(--fnd);font-size:1.5rem;font-weight:900;line-height:1.15;color:var(--ink);margin-bottom:4px;}
.qv-price{display:flex;align-items:baseline;gap:5px;font-family:var(--fnd);font-size:2.2rem;font-weight:900;color:var(--ink);margin-bottom:2px;}
.qv-price-dt{font-size:.95rem;font-weight:600;color:var(--muted);}
.qv-orig-price{font-size:1rem;font-weight:500;text-decoration:line-through;color:var(--muted);margin-left:8px;}
.qv-chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:4px;}
.qv-chip{padding:4px 11px;border:1.5px solid var(--worn);font-size:.73rem;font-weight:600;color:var(--ink);background:var(--paper2);}
.qv-desc{font-size:.83rem;line-height:1.75;color:var(--muted);border-top:1px solid var(--paper3);padding-top:12px;margin-top:2px;}
.qv-size-section{display:flex;align-items:center;justify-content:space-between;min-height:28px;margin-bottom:4px;}
.qv-size-label{font-size:.82rem;color:var(--muted);}
.sz-guide-btn{background:none;border:none;color:var(--terra);font-size:.73rem;font-weight:600;cursor:pointer;text-decoration:underline;padding:0;font-family:var(--fnb);}
[data-theme="dark"] .sz-guide-btn{color:var(--terrah);}
.sz-guide-btn:hover{color:var(--terrad);}

/* VISITOR COUNTER */
.qv-visitors{
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:rgba(224,150,10,0.08);
  color:var(--am);
  padding:5px 12px;
  border-radius:20px;
  font-size:.72rem;
  font-weight:700;
  margin-top:10px;
  border:1px solid rgba(224,150,10,0.15);
  opacity:0;
  transform:translateY(8px);
  transition:all .4s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.qv-visitors.visible{opacity:1;transform:none;}
.qv-visitors-pulse{
  width:6px;height:6px;
  background:var(--am);
  border-radius:50%;
  position:relative;
}
.qv-visitors-pulse::after{
  content:'';
  position:absolute;inset:-2px;
  border:1.5px solid var(--am);
  border-radius:50%;
  animation:v-pulse 2s infinite;
}
@keyframes v-pulse{
  0%{transform:scale(1);opacity:1}
  100%{transform:scale(2.5);opacity:0}
}
.qv-delivery{display:flex;gap:10px;align-items:flex-start;background:var(--paper);border:var(--border);padding:11px 13px;font-size:.75rem;color:var(--muted);line-height:1.6;border-radius:2px;}
.qv-delivery strong{color:var(--ink);font-weight:700;}
.qv-actions{margin-top:auto;padding-top:8px;}
.qv-add{width:100%;background:var(--terra);color:#fff;border:none;padding:14px;font-weight:800;font-size:.9rem;letter-spacing:.5px;transition:all .18s;cursor:pointer;font-family:var(--fnb);border-radius:2px;}
.qv-add:hover:not(:disabled){background:var(--terrad);transform:translateY(-2px);box-shadow:0 8px 24px rgba(200,66,42,.4);}
.qv-add:disabled{opacity:.5;cursor:not-allowed;}
.qv-add.in-cart{background:var(--green);}
.qv-close{position:absolute;top:14px;right:14px;z-index:20;width:36px;height:36px;background:rgba(26,16,10,.7);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.15);color:#fff;font-size:1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:50%;transition:all .2s;}
.qv-close:hover{background:var(--terra);transform:rotate(90deg) scale(1.1);border-color:var(--terra);}
.analytics-overlay{position:fixed;inset:0;z-index:1000;background:rgba(15,8,3,.6);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:16px;}
.analytics-overlay.open{display:flex;}
.analytics-panel{background:var(--card);width:min(980px,100%);max-height:95vh;overflow-y:auto;border-radius:18px;border:1px solid rgba(255,255,255,.1);box-shadow:0 38px 120px rgba(0,0,0,.35);padding:26px;position:relative;}
.analytics-close{position:absolute;top:16px;right:16px;width:38px;height:38px;background:var(--paper2);border:none;border-radius:50%;color:var(--ink);font-size:1.05rem;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.analytics-head{margin-bottom:18px;}
.analytics-head h2{font-size:1.6rem;font-weight:900;margin-bottom:6px;}
.analytics-sub{font-size:.92rem;color:var(--muted);}
.analytics-grid{display:grid;grid-template-columns:repeat(3,minmax(160px,1fr));gap:12px;margin-bottom:16px;}
.qv-metric-card{padding:18px 14px;background:var(--paper2);border:1px solid var(--worn);border-radius:14px;display:flex;flex-direction:column;gap:8px;}
.qv-metric-card span{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;}
.qv-metric-card strong{font-size:1.6rem;color:var(--ink);}
.analytics-chart{padding:18px 0 10px;display:grid;gap:12px;border-top:1px solid var(--paper3);border-bottom:1px solid var(--paper3);margin-bottom:16px;}
.qv-chart-row{display:grid;grid-template-columns:1fr 1fr auto;gap:14px;align-items:center;}
.qv-chart-bar-wrapper{background:var(--paper);border:1px solid var(--worn);border-radius:999px;overflow:hidden;height:14px;}
.qv-chart-bar{height:100%;background:linear-gradient(90deg,var(--terra),var(--terrad));border-radius:999px;}
.analytics-log{max-height:220px;overflow-y:auto;padding:14px 12px;border-radius:12px;background:rgba(15,8,3,.04);border:1px solid var(--paper3);font-size:.85rem;color:var(--muted);}
.analytics-event{padding:10px 8px;border-bottom:1px solid rgba(0,0,0,.04);}
.analytics-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;margin-top:16px;}
.analytics-actions .btn-hero-s{padding:10px 14px;}
.analytics-alert{padding:10px 12px;border-left:4px solid var(--terra);background:rgba(255,235,230,.96);margin-bottom:10px;border-radius:10px;color:var(--ink);}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}

/* -- CONTACT MODAL -- */
.cm-overlay{position:fixed;inset:0;z-index:950;background:rgba(15,8,3,.82);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;padding:20px;}
.cm-overlay.open{opacity:1;visibility:visible;}
.cm-box{background:var(--card);max-width:480px;width:100%;border-top:4px solid var(--terra);padding:36px 32px;position:relative;transform:translateY(30px) scale(.96);transition:transform .35s cubic-bezier(.34,1.2,.64,1);box-shadow:0 40px 100px rgba(0,0,0,.5);}
.cm-overlay.open .cm-box{transform:translateY(0) scale(1);}
.cm-title{font-family:var(--fnd);font-size:1.5rem;font-weight:900;margin-bottom:4px;}
.cm-sub{font-size:.8rem;color:var(--muted);margin-bottom:22px;}
.cm-field{margin-bottom:14px;}
.cm-label{display:block;font-size:.65rem;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:var(--muted);margin-bottom:5px;}
.cm-input{width:100%;padding:10px 12px;border:1.5px solid var(--worn);background:var(--paper2);color:var(--ink);font-size:.86rem;font-family:var(--fnb);outline:none;transition:border .18s;}
.cm-input:focus{border-color:var(--terra);}
textarea.cm-input{resize:vertical;min-height:100px;line-height:1.6;}
.cm-send{width:100%;background:var(--terra);color:#fff;border:none;padding:13px;font-weight:800;font-size:.9rem;letter-spacing:.4px;cursor:pointer;font-family:var(--fnb);transition:all .18s;margin-top:4px;}
.cm-send:hover{background:var(--terrad);transform:translateY(-1px);box-shadow:0 8px 24px rgba(200,66,42,.4);}
.cm-send:disabled{opacity:.5;cursor:not-allowed;}
.cm-close{position:absolute;top:12px;right:12px;width:32px;height:32px;background:var(--paper2);color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:50%;font-size:1rem;transition:all .15s;border:1px solid var(--worn);}
.cm-close:hover{background:var(--terra);color:#fff;transform:rotate(90deg);}
.cm-success{text-align:center;padding:20px 0;display:none;}
.cm-success-ic{font-size:2.8rem;margin-bottom:10px;}
.cm-success-t{font-family:var(--fnd);font-size:1.2rem;font-weight:900;margin-bottom:6px;}
.cm-success-s{font-size:.82rem;color:var(--muted);}
.cm-direct{margin-top:16px;padding-top:16px;border-top:1px solid var(--paper3);text-align:center;font-size:.78rem;color:var(--muted);}
.cm-direct a{color:var(--terra);font-weight:700;text-decoration:none;}
.cm-direct a:hover{text-decoration:underline;}


/* ------------------------------------------
   RESPONSIVE - TABLET (=1024px)
------------------------------------------ */
@media(max-width:1024px){
  .hero{grid-template-columns:1fr;padding:64px 32px 44px;gap:28px;min-height:auto}
  .hero-r{display:none}
  .hero-h1{font-size:3.6rem}
  .hero-slogan{font-size:1.2rem}
  .shop-wrap{padding:32px 22px 48px}
  .feat-strip{padding:36px 24px;gap:24px;flex-direction:column}
  footer{padding:36px 24px 20px}
  .foot-top{grid-template-columns:1fr 1fr;gap:24px}
  .pgrid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px}
}

/* ------------------------------------------
   RESPONSIVE - MOBILE (=768px)
------------------------------------------ */
@media(max-width:768px){
  /* Navbar */
  .nav{padding:0 12px;height:56px;gap:8px}
  .nav-logo img{height:36px}
  .nav-socs{display:none}
  .srch input{width:110px;font-size:.75rem;padding:6px 10px 6px 28px}
  .srch input:focus{width:140px}
  .cart-btn{padding:7px 10px;font-size:.76rem;gap:5px}
  .wish-nav-btn{padding:6px 4px;font-size:.76rem}
  .acct-btn{padding:6px 8px;font-size:.76rem}
  .acct-btn span#acctLabel{display:none}

  /* Hero */
  .hero{padding:56px 16px 36px}
  .hero-h1{font-size:2.6rem;line-height:1.1}
  .hero-sub{font-size:.82rem}
  .hero-btns{flex-direction:column;gap:10px}
  .btn-hero{width:100%;text-align:center}

  /* Shop grid */
  .pgrid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:12px}
  .pcard-img{height:170px}
  .shop-wrap{padding:22px 12px 40px}
  .filter-bar{gap:6px}
  .fchip{padding:5px 10px;font-size:.7rem}

  /* Checkout */
  .co-body{flex-direction:column}
  .co-form{border-right:none;padding:16px}
  .co-sum{width:100%;border-top:1px solid var(--worn);padding:14px 16px}
  .fg2{grid-template-columns:1fr}
  .co-hd{padding:12px 16px}
  .co-modal{max-height:97vh;border-radius:0;margin:0;border-left:none;border-right:none}

  /* Modals */
  .qv-modal{grid-template-columns:1fr;max-height:96vh}
  .qv-img-wrap{min-height:280px}
  .qv-body{padding:18px 16px}
  .qv-name{font-size:1.3rem}
  .qv-price{font-size:1.9rem}
  .qv-tag{font-size:.6rem;}
  .qv-close{top:12px;right:12px;}

  /* Footer */
  footer{padding:28px 16px 16px}
  .foot-top{grid-template-columns:1fr;gap:18px}

  /* Cart drawer */
  .cart-panel{width:100vw}
}

/* ------------------------------------------
   RESPONSIVE - SMALL PHONE (=480px)
------------------------------------------ */
@media(max-width:480px){
  /* Navbar - tighten further */
  .nav{padding:0 10px;gap:6px;height:52px}
  .nav-logo img{height:30px}
  .srch{display:none}
  .cart-btn{padding:6px 9px;font-size:.72rem}
  .cart-btn svg{display:none}
  .wish-nav-btn .wish-nav-label{display:none}
  .wish-count-badge{top:-3px;right:-4px}

  /* Hero */
  .hero{padding:52px 14px 32px}
  .hero-h1{font-size:2rem}
  .hero-stamp{font-size:.62rem;padding:3px 9px}
  .hero-slogan{font-size:1.05rem}
  .hero-sub{font-size:.78rem}

  /* Grid - 2 columns always */
  .pgrid{grid-template-columns:1fr 1fr;gap:8px}
  .pcard-img{height:150px}
  .pcard-body{padding:10px 10px 12px}
  .pcard-name{font-size:.88rem}
  .price-amount{font-size:1.05rem}
  .shop-wrap{padding:18px 10px 36px}
  .shop-hd{margin-bottom:12px}
  .shop-title{font-size:1.4rem}

  /* Filter chips - scrollable row */
  .filter-bar{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
  .filter-bar::-webkit-scrollbar{display:none}
  .fchip{flex-shrink:0;padding:5px 10px;font-size:.68rem}

  /* Checkout */
  .co-ov{padding:0}
  .co-modal{max-height:100dvh;border:none}
  .co-form{padding:10px}
  .co-sum{padding:10px}
  .co-sec{margin:8px 0 6px}
  .fg2,.fg3{grid-template-columns:1fr}
  .fi{padding:7px 10px;font-size:.82rem}
  .btn-place{padding:11px;font-size:.85rem}

  /* Quickview */
  .qv-modal{border-radius:0;max-height:97vh;}
  .qv-body{padding:16px 14px;gap:10px;}
  .qv-img-wrap{min-height:240px;}
  .qv-name{font-size:1.25rem;}
  .qv-price{font-size:1.7rem;}
  .qv-tag{font-size:.58rem;}
  .qv-desc{font-size:.8rem;}
  .qv-close{top:12px;right:12px;width:32px;height:32px;font-size:.9rem;}

  /* Wishlist / Cart */
  .wish-empty-t{font-size:1rem}
  .cline{gap:8px}
  .cline-img{width:52px;height:52px}

  /* Footer */
  footer{padding:24px 12px 14px}
  .foot-bottom{font-size:.67rem;flex-direction:column;gap:6px;text-align:center}

  /* Ticker */
  .ticker-item{font-size:.7rem}

  /* Toasts */
  .toast{left:12px;right:12px;bottom:16px;width:auto}
}

/* ------------------------------------------
   QUICKVIEW always stacked on narrow
------------------------------------------ */
@media(max-width:640px){
  .qv-modal{grid-template-columns:1fr;max-height:98dvh;}
  .qv-img-wrap{min-height:220px;}
  .qv-body{padding:14px 12px;}
}

/* Touch targets - min 44px for accessibility */
@media(max-width:768px){
  button,a,.fchip,.sg-btn{min-height:36px}
  .wish-btn{width:36px;height:36px}
}

/* -- WHATSAPP FLOATING BUTTON -- */
.wa-fab{
  position:fixed;bottom:24px;right:20px;z-index:9999;
  display:flex;align-items:center;gap:10px;
  background:#25D366;color:#fff;
  border-radius:50px;padding:13px 20px 13px 16px;
  box-shadow:0 4px 20px rgba(37,211,102,.45),0 2px 8px rgba(0,0,0,.25);
  text-decoration:none;font-family:var(--fnb);font-size:.82rem;font-weight:700;
  letter-spacing:.02em;
  transition:transform .2s,box-shadow .2s;
  animation:wa-pulse 3s ease-in-out infinite;
}
.wa-fab:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 8px 28px rgba(37,211,102,.55),0 4px 12px rgba(0,0,0,.3);}
.wa-fab svg{width:22px;height:22px;flex-shrink:0;fill:#fff}
.wa-fab-label{white-space:nowrap}
@keyframes wa-pulse{
  0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.45),0 2px 8px rgba(0,0,0,.25);}
  50%{box-shadow:0 4px 28px rgba(37,211,102,.7),0 2px 8px rgba(0,0,0,.25);}
}
@media(max-width:480px){
  .wa-fab{padding:11px 14px 11px 12px;font-size:.76rem;right:14px;bottom:18px}
  .wa-fab-label{display:none}
  .wa-fab{border-radius:50%;padding:13px}
}

/* -- RETURN POLICY MODAL -- */
.ret-overlay{
  position:fixed;inset:0;z-index:10500;
  background:rgba(0,0,0,.72);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .25s;
  padding:16px;
}
.ret-overlay.open{opacity:1;pointer-events:all;}
.ret-box{
  background:var(--paper);border:1.5px solid var(--worn);border-radius:14px;
  max-width:560px;width:100%;max-height:88vh;overflow-y:auto;
  padding:32px 28px;position:relative;
  box-shadow:0 20px 60px rgba(0,0,0,.5);
}
.ret-close{
  position:absolute;top:14px;right:16px;
  background:none;border:none;color:var(--muted);font-size:1.3rem;cursor:pointer;
  width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;transition:background .15s;
}
.ret-close:hover{background:var(--paper2);}
.ret-title{font-family:var(--fnd);font-size:1.6rem;font-weight:800;color:var(--ink);margin-bottom:6px;}
.ret-badge{display:inline-block;background:var(--terra);color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.05em;padding:3px 10px;border-radius:20px;margin-bottom:18px;}
.ret-section{margin-bottom:18px;}
.ret-section h3{font-family:var(--fnb);font-size:.9rem;font-weight:700;color:var(--terra);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;}
.ret-section p,.ret-section li{font-size:.88rem;color:var(--muted);line-height:1.65;}
.ret-section ul{padding-left:18px;margin:0;}
.ret-section li{margin-bottom:5px;}
.ret-divider{border:none;border-top:1px solid var(--worn);margin:16px 0;}
.ret-wa-cta{
  display:flex;align-items:center;gap:12px;
  background:#f0fdf4;border:1.5px solid #86efac;border-radius:10px;
  padding:14px 16px;margin-top:18px;text-decoration:none;
  transition:background .15s;
}
[data-theme="dark"] .ret-wa-cta{background:rgba(37,211,102,.08);border-color:rgba(37,211,102,.3);}
.ret-wa-cta:hover{background:#dcfce7;}
.ret-wa-cta svg{width:26px;height:26px;fill:#25D366;flex-shrink:0;}
.ret-wa-cta span{font-family:var(--fnb);font-size:.85rem;color:#166534;font-weight:700;}

.review-card{background:var(--card);border:1px solid var(--wornl);border-radius:10px;padding:20px 18px}
.review-stars{color:var(--mustard);font-size:1rem;margin-bottom:10px;letter-spacing:2px}
.review-text{font-size:.87rem;color:var(--muted);line-height:1.8;margin-bottom:12px;font-style:italic}
.review-author{font-size:.8rem;color:var(--terra);font-weight:600}

/* -- GUIDE DES TAILLES -- */
.sz-guide-btn{background:none;border:1px solid var(--terra);color:var(--terra);font-size:.72rem;cursor:pointer;padding:3px 8px;border-radius:4px;margin-left:auto;white-space:nowrap;transition:all .2s}.sz-guide-btn:hover{background:var(--terra);color:#fff}
.sz-guide-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:9999;align-items:center;justify-content:center}
.sz-guide-overlay.open{display:flex}
.sz-guide-box{background:var(--paper);max-width:520px;width:90%;max-height:80vh;overflow-y:auto;border-radius:10px;padding:24px;position:relative}
.sz-guide-title{font-family:var(--fnd);font-size:1.1rem;color:var(--cream);margin-bottom:16px}
.sz-guide-close{position:absolute;top:14px;right:16px;background:none;border:none;color:var(--muted);font-size:1.2rem;cursor:pointer}
.sz-table{width:100%;border-collapse:collapse;font-size:.78rem}
.sz-table th{background:var(--paper2);color:var(--terra);padding:7px 10px;text-align:left;border-bottom:1px solid var(--paper3)}
.sz-table td{padding:7px 10px;border-bottom:.5px solid var(--paper3);color:var(--muted)}
.sz-table tr:hover td{background:var(--paper2)}
.sz-tab-btns{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.sz-tab-btn{background:var(--paper2);border:1px solid var(--paper3);color:var(--muted);border-radius:4px;padding:4px 12px;font-size:.75rem;cursor:pointer}
.sz-tab-btn.active{background:var(--terra);color:#fff;border-color:var(--terra)}
.sz-note{font-size:.72rem;color:var(--muted);margin-top:12px;line-height:1.6}

/* -- RÉCEMMENT VUS -- */
.recently-sec{padding:46px 24px;background:var(--paper);border-top:1px solid var(--worn);border-bottom:1px solid var(--worn)}
.recently-sec h3{font-family:var(--fnd);font-size:1.35rem;color:var(--ink);margin-bottom:18px}
.recently-grid{display:flex;gap:14px;overflow-x:auto;padding:2px 2px 12px;scrollbar-width:thin}
.recently-card{flex-shrink:0;width:150px;cursor:pointer;border-radius:8px;overflow:hidden;background:var(--card);border:1px solid var(--worn);box-shadow:var(--sh);transition:transform .18s,border-color .18s,box-shadow .18s}
.recently-card:hover{transform:translateY(-3px);border-color:var(--terra);box-shadow:var(--sh2)}
.recently-card img,.recently-card .rc-ph{width:150px;height:150px;object-fit:contain;display:block;background:var(--img-bg);display:flex;align-items:center;justify-content:center;font-size:2rem;}
.rc-info{padding:10px 10px 11px}
.rc-name{font-size:.78rem;color:var(--ink);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rc-price{font-size:.86rem;font-weight:800;color:var(--terra);margin-top:4px}

/* -- À PROPOS / NOTRE HISTOIRE -- */
#aboutSec{color:var(--ink)}
#aboutSec h2{color:var(--ink)!important}
#aboutSec h2 em{color:var(--mustardl)}
#aboutSec p{color:var(--muted)!important}
#aboutSec [style*="background:var(--paper2)"]{background:var(--card)!important;border-color:var(--worn)!important;box-shadow:var(--sh)}
#aboutSec [style*="font-family:var(--fnd)"]{color:var(--ink)!important}

/* -- CODES PROMO -- */
.promo-row{display:flex;gap:8px;margin:10px 0 4px}
.promo-row input{flex:1}
.promo-tag{display:inline-flex;align-items:center;gap:6px;background:var(--olive);color:#fff;font-size:.75rem;padding:3px 10px;border-radius:20px;margin-bottom:6px}
.promo-tag button{background:none;border:none;color:#fff;cursor:pointer;font-size:.85rem;padding:0;line-height:1}

/* -- REVIEWS FORM & LIST -- */
.qv-reviews{margin-top:24px;border-top:1px solid var(--worn);padding-top:20px}
.qv-reviews-title{font-family:var(--fnd);font-size:1.1rem;font-weight:700;margin-bottom:16px;color:var(--cream)}
.qv-review-list{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}
.qv-review-item{background:var(--paper2);padding:14px;border:1px solid var(--wornl);border-radius:4px}
.qv-review-stars{color:var(--mustard);font-size:.85rem;margin-bottom:5px}
.qv-review-author{font-size:.75rem;color:var(--terra);font-weight:700;margin-bottom:4px}
.qv-review-text{font-size:.82rem;color:var(--muted);line-height:1.5;font-style:italic}
.qv-review-form{background:var(--paper2);padding:18px;border:1.5px solid var(--terra);border-radius:6px;margin-top:20px}
.qv-review-form h4{font-family:var(--fnd);font-size:.95rem;margin-bottom:12px;color:var(--cream)}
.qv-review-field{margin-bottom:12px}
.qv-review-label{display:block;font-size:.65rem;font-weight:700;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.qv-review-input{width:100%;padding:8px 10px;background:var(--paper);border:1px solid var(--worn);color:var(--ink);font-size:.85rem;font-family:var(--fnb);outline:none}
.qv-review-input:focus{border-color:var(--terra)}
.qv-review-rating{display:flex;gap:4px;margin-bottom:12px}
.star-btn{background:none;border:none;color:var(--worn);font-size:1.4rem;cursor:pointer;padding:0;transition:color .15s}
.star-btn.active{color:var(--mustard)}
.qv-review-btn{width:100%;background:var(--terra);color:#fff;border:none;padding:10px;font-weight:700;font-size:.85rem;cursor:pointer;transition:all .18s}
.qv-review-btn:hover{background:var(--terrad)}
.qv-review-btn:disabled{opacity:.5;cursor:not-allowed}

/* -- THEME PARITY LAYER -- */
html,
body,
.nav,
.shop-wrap,
.pcard,
.pcard-img,
.btn-add,
.fchip,
.filter-group,
.fi,
.fselect-mini,
.cart-dr,
.cart-hd,
.cart-ft,
.co-modal,
.co-hd,
.co-form-section,
.co-sum,
.wish-panel,
.auth-box,
.cm-box,
.qv-modal,
.qv-body,
.ret-box,
.recently-sec,
.recently-card,
.review-card,
.qv-review-item,
.qv-review-form,
.theme-toggle,
.acct-btn,
.wish-nav-btn,
.cart-btn,
.btn-hero,
.btn-co,
.btn-place,
.qv-add,
.cm-send,
.auth-btn,
.succ-soc a,
.foot-links a,
.fsoc,
.nsoc {
  transition:
    color var(--theme-dur) var(--theme-ease),
    background-color var(--theme-dur) var(--theme-ease),
    border-color var(--theme-dur) var(--theme-ease),
    box-shadow var(--theme-dur) var(--theme-ease),
    opacity var(--theme-dur) var(--theme-ease),
    transform var(--theme-dur) var(--theme-ease);
}

.pcard,
.recently-card,
.review-card,
.qv-review-item,
.qv-review-form,
.auth-box,
.cm-box,
.qv-modal,
.ret-box,
.wish-panel,
.cart-dr,
.co-modal {
  background:var(--card);
  color:var(--ink);
  border-color:var(--worn);
}

.pcard-img,
.qv-img-wrap,
.qv-img-frame img.qv-active,
.qv-img-frame .qv-img-ph,
.qv-thumb img,
.cline-img,
.wish-item-img,
.recently-card img,
.recently-card .rc-ph,
.cs-img {
  background:var(--product-media);
}

.hero,
.feat-strip,
footer,
.nav {
  background:var(--ink2);
  color:var(--cream);
}

.feat-title,
.qv-reviews-title,
.qv-review-form h4,
.wish-ph-title,
.wish-empty-t,
.wish-item-name,
.wish-item-price,
.cross-sell-title,
.sz-guide-title {
  color:var(--ink);
}

.hero .feat-title,
.feat-strip .feat-title,
footer .foot-col-t,
footer .foot-tagline {
  color:var(--cream);
}

.btn-hero-p,
.btn-co,
.btn-place,
.btn-add,
.qv-add,
.cm-send,
.auth-btn,
.cart-btn,
.wish-add-btn,
.promo-tag,
.sale-badge,
.new-sticker,
.ret-badge {
  background:var(--terra);
  color:var(--on-accent);
  border-color:var(--terra);
}

.btn-hero-p:hover,
.btn-co:hover,
.btn-place:hover,
.btn-add:hover:not(:disabled),
.qv-add:hover:not(:disabled),
.cm-send:hover,
.auth-btn:hover,
.cart-btn:hover,
.wish-add-btn:hover:not(:disabled) {
  background:var(--terrah);
  border-color:var(--terrah);
  box-shadow:0 8px 24px var(--accent-shadow);
}

.btn-hero-s,
.auth-signout,
.wish-clear-btn,
.wish-rm-btn,
.cart-x,
.co-x,
.cm-close,
.auth-close,
.ret-close,
.analytics-close {
  background:var(--paper2);
  color:var(--ink);
  border-color:var(--worn);
}

.btn-hero-s:hover,
.auth-signout:hover,
.wish-clear-btn:hover,
.wish-rm-btn:hover,
.cart-x:hover,
.co-x:hover,
.cm-close:hover,
.auth-close:hover,
.ret-close:hover,
.analytics-close:hover {
  background:var(--terra);
  color:var(--on-accent);
  border-color:var(--terra);
}

.fi,
.auth-input,
.cm-input,
.qv-review-input,
.fselect-mini,
select.fchip {
  background:var(--paper2)!important;
  color:var(--ink)!important;
  border-color:var(--wornl)!important;
}

.fi:focus,
.auth-input:focus,
.cm-input:focus,
.qv-review-input:focus,
.fchip:focus-visible,
.btn-hero:focus-visible,
.btn-co:focus-visible,
.btn-place:focus-visible,
.btn-add:focus-visible,
.qv-add:focus-visible,
.theme-toggle:focus-visible,
.cart-btn:focus-visible,
.wish-nav-btn:focus-visible,
.acct-btn:focus-visible,
.nsoc:focus-visible,
.fsoc:focus-visible {
  outline:2px solid var(--terra);
  outline-offset:2px;
  box-shadow:0 0 0 4px var(--focus);
}

.cart-bd,
.co-ov,
.auth-overlay,
.cm-overlay,
.qv-overlay,
.ret-overlay,
.analytics-overlay,
.wish-bd-bg {
  background:var(--overlay);
}

.toast,
.announcement-bar {
  background:var(--terra);
  color:var(--on-accent);
}

.auth-err,
.fi.invalid {
  border-color:var(--danger)!important;
}

#aboutSec [style*="background:var(--paper2)"],
#reviewsSec [style*="grid-column"],
#qvReviewLoginMsg,
#qvReviewAlreadyMsg {
  background:var(--card)!important;
  color:var(--ink)!important;
  border-color:var(--worn)!important;
}

#aboutSec h2,
#aboutSec .font-fnd,
#aboutSec [style*="font-family:var(--fnd)"] {
  color:var(--ink)!important;
}

#aboutSec {
  background: var(--paper);
}

#aboutSec [style*="border:1px solid var(--wornl)"] {
  border: 1px solid rgba(0,0,0,0.05) !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.03);
}
#aboutSec em {
  color: var(--terra);
  font-style: italic;
}

.hero,
.feat-strip,
footer,
.nav {
  background:#251810;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration:0.01ms!important;
    animation-iteration-count:1!important;
    scroll-behavior:auto!important;
    transition-duration:0.01ms!important;
  }
}

/* ══════════════════════════════════════════
   SKELETON LOADING — Premium ghost cards
   Matches exactly the real .pcard layout
══════════════════════════════════════════ */
@keyframes skShimmer {
  0%   { background-position: -600px 0 }
  100% { background-position:  600px 0 }
}
.skel-card {
  background: var(--card);
  border: var(--border);
  overflow: hidden;
  position: relative;
  box-shadow: var(--sh);
}
/* Tape corner — same as real pcard */
.skel-card::before {
  content: '';
  position: absolute;
  top: -6px;
  left: 50%;
  transform: translateX(-50%);
  width: 40px;
  height: 12px;
  background: rgba(212,134,10,.18);
  border-radius: 1px;
  z-index: 5;
}
.skel-img {
  aspect-ratio: 1 / 1;
  width: 100%;
  background: linear-gradient(
    90deg,
    var(--skel1) 25%,
    var(--skel2) 50%,
    var(--skel1) 75%
  );
  background-size: 1200px 100%;
  animation: skShimmer 1.6s ease-in-out infinite;
  border-bottom: var(--border);
}
.skel-body {
  padding: 14px 14px 16px;
}
.skel-line {
  height: 10px;
  border-radius: 3px;
  margin-bottom: 8px;
  background: linear-gradient(
    90deg,
    var(--skel1) 25%,
    var(--skel2) 50%,
    var(--skel1) 75%
  );
  background-size: 1200px 100%;
  animation: skShimmer 1.6s ease-in-out infinite;
}
.skel-line.sk-cat  { width: 38%; height: 8px; margin-bottom: 6px; }
.skel-line.sk-name { width: 88%; height: 14px; margin-bottom: 10px; }
.skel-line.sk-tag1 { width: 28%; height: 8px; display: inline-block; margin-right: 6px; margin-bottom: 10px; }
.skel-line.sk-tag2 { width: 22%; height: 8px; display: inline-block; margin-bottom: 10px; }
.skel-line.sk-desc { width: 100%; height: 8px; margin-bottom: 4px; }
.skel-line.sk-desc2{ width: 70%; height: 8px; margin-bottom: 14px; }
.skel-line.sk-price{ width: 40%; height: 18px; margin-bottom: 12px; }
.skel-line.sk-btn  {
  width: 100%;
  height: 38px;
  border-radius: 2px;
  margin-bottom: 0;
}
/* Stagger shimmer delays per card */
.skel-card:nth-child(2) .skel-img,
.skel-card:nth-child(2) .skel-line { animation-delay: 0.1s; }
.skel-card:nth-child(3) .skel-img,
.skel-card:nth-child(3) .skel-line { animation-delay: 0.2s; }
.skel-card:nth-child(4) .skel-img,
.skel-card:nth-child(4) .skel-line { animation-delay: 0.3s; }
.skel-card:nth-child(5) .skel-img,
.skel-card:nth-child(5) .skel-line { animation-delay: 0.15s; }
.skel-card:nth-child(6) .skel-img,
.skel-card:nth-child(6) .skel-line { animation-delay: 0.25s; }
.skel-card:nth-child(7) .skel-img,
.skel-card:nth-child(7) .skel-line { animation-delay: 0.05s; }
.skel-card:nth-child(8) .skel-img,
.skel-card:nth-child(8) .skel-line { animation-delay: 0.35s; }

/* ══════════════════════════════════════════
   FLOATING CART BUTTON (FAB) — Mobile only
   Appears when scrolled past navbar,
   shows cart count badge
══════════════════════════════════════════ */
.cart-fab {
  position: fixed;
  bottom: 24px;
  right: 20px;
  z-index: 450;
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: var(--terra);
  color: #fff;
  border: none;
  display: none;           /* hidden by default, JS shows on scroll */
  align-items: center;
  justify-content: center;
  box-shadow: 0 6px 24px rgba(200,66,42,.55), 0 2px 8px rgba(0,0,0,.25);
  cursor: pointer;
  transition: transform .22s cubic-bezier(.34,1.4,.64,1),
              box-shadow .22s ease,
              background .15s ease,
              opacity .3s ease;
  transform: scale(0) translateY(20px);
  opacity: 0;
}
.cart-fab.fab-visible {
  display: flex;
  transform: scale(1) translateY(0);
  opacity: 1;
}
.cart-fab:hover {
  background: var(--terrah);
  transform: scale(1.1) translateY(-2px);
  box-shadow: 0 10px 32px rgba(200,66,42,.65), 0 4px 12px rgba(0,0,0,.3);
}
.cart-fab:active {
  transform: scale(.96);
}
.cart-fab svg {
  width: 22px;
  height: 22px;
  stroke: #fff;
  fill: none;
  stroke-width: 2.2;
  flex-shrink: 0;
}
.cart-fab-badge {
  position: absolute;
  top: -2px;
  right: -2px;
  min-width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--mustardl);
  color: var(--ink2);
  font-size: .62rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  border: 2px solid var(--paper);
  font-family: var(--fnb);
  line-height: 1;
  transition: transform .2s cubic-bezier(.34,1.6,.64,1);
}
.cart-fab-badge.bump {
  transform: scale(1.4);
}
/* Only show FAB on mobile screens */
@media (min-width: 769px) {
  .cart-fab { display: none !important; }
}

/* -- SPLASH SCREEN -- */
.splash-screen {
  position: fixed;
  inset: 0;
  z-index: 100000;
  background: #251810; /* match .nav / hero dark bg */
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 20px;
  transition: transform 0.6s cubic-bezier(0.76, 0, 0.24, 1);
}
.splash-logo {
  animation: splashPulse 1s ease-in-out infinite alternate;
}
.splash-bar {
  width: 80px;
  height: 3px;
  background: rgba(255,255,255,.1);
  border-radius: 2px;
  overflow: hidden;
  position: relative;
}
.splash-bar::after {
  content: '';
  position: absolute;
  left: -40%;
  top: 0;
  width: 40%;
  height: 100%;
  background: var(--terra);
  border-radius: 2px;
  animation: splashBar 1.2s ease-in-out infinite;
}
@keyframes splashBar {
  0%   { left: -40%; }
  100% { left: 100%; }
}
@keyframes splashPulse {
  0% { transform: scale(1); opacity: 0.6; }
  100% { transform: scale(1.08); opacity: 1; }
}
.splash-screen.hidden {
  transform: translateY(-100%);
  pointer-events: none;
}

/* -- ABOUT SECTION text fixes -- */
#aboutSec [style*="color:var(--cream)"],
#aboutSec [style*="color: var(--cream)"] {
  color: var(--ink) !important;
}

/* -- ORDER HISTORY modal background fix -- */
#orderHistorySec .co-body {
  background: var(--paper) !important;
  color: var(--ink) !important;
}

/* -- PROMO label hint -- */
.promo-hint {
  font-size: .65rem;
  color: var(--muted);
  margin-top: 3px;
  display: block;
  letter-spacing: .3px;
}

/* -- Skip-to-main link for keyboard navigation -- */
.skip-link {
  position: absolute;
  top: -60px;
  left: 16px;
  background: var(--terra);
  color: #fff;
  padding: 8px 16px;
  z-index: 99999;
  border-radius: 0 0 4px 4px;
  font-weight: 700;
  font-size: .85rem;
  text-decoration: none;
  transition: top .2s;
}
.skip-link:focus {
  top: 0;
}

/* -- Smooth scroll on anchor clicks -- */
html { scroll-padding-top: 80px; }

/* -- Improved touch targets on interactive elements -- */
@media (max-width: 768px) {
  .fchip, .sz-tab-btn, .filter-group select {
    min-height: 40px;
    display: inline-flex;
    align-items: center;
  }
  .filter-row {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 12px;
    -webkit-overflow-scrolling: touch;
  }
  /* Ensure toast is above FAB on mobile */
  .toast {
    bottom: 88px; /* above the 58px FAB + spacing */
  }
}

/* -- Improve announcement bar + nav stacking -- */
.announcement-bar + .tape-top + .nav,
.announcement-bar + .nav {
  /* JS will set top dynamically */
}

/* -- Card hover state visibility on touch devices -- */
@media (hover: none) {
  .pcard:hover {
    transform: none;
    box-shadow: var(--sh);
  }
  .wish-btn {
    opacity: 1;
    transform: scale(1);
  }
  .pcard-img::after {
    display: none;
  }
}

/* -- Checkout form improvements -- */
.co-form-section + .co-form-section {
  margin-top: 4px;
}
.os-tot {
  flex-wrap: wrap;
  align-items: center;
  gap: 4px;
}

/* -- Scrollbar style for modals -- */
.qv-body::-webkit-scrollbar,
.cart-body::-webkit-scrollbar,
.co-body::-webkit-scrollbar {
  width: 4px;
}
.qv-body::-webkit-scrollbar-thumb,
.cart-body::-webkit-scrollbar-thumb,
.co-body::-webkit-scrollbar-thumb {
  background: var(--terra);
  border-radius: 2px;
}
.qv-body::-webkit-scrollbar-track,
.cart-body::-webkit-scrollbar-track,
.co-body::-webkit-scrollbar-track {
  background: transparent;
}
