/* ═══════════════════════════════════════════════════════
   CASKWORTH — Premium Whisky Shop
   Light Theme Design System
   ═══════════════════════════════════════════════════════ */
:root {
  --bg:      #ffffff;
  --bg2:     #faf8f5;
  --bg3:     #f4f0ea;
  --card:    #ffffff;
  --gold:    #c9941a;
  --gold2:   #e8a820;
  --goldbg:  #fdf6e8;
  --dark:    #1c1c1e;
  --text:    #2d2d2d;
  --muted:   #6b6b6b;
  --muted2:  #9b9b9b;
  --border:  #e8e0d4;
  --border2: rgba(201,148,26,.18);
  --green:   #16a34a;
  --r:       8px;
  --rl:      14px;
  --rxl:     20px;
  --shadow:  0 2px 16px rgba(0,0,0,.07);
  --shadow2: 0 8px 40px rgba(0,0,0,.10);
  --tr:      all .2s ease;
  --font-d:  'Playfair Display', Georgia, serif;
  --font-b:  'Inter', system-ui, sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;overflow-x:hidden;}
body{background:var(--bg);color:var(--text);font-family:var(--font-b);font-size:14px;line-height:1.65;overflow-x:hidden;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:var(--font-b);cursor:pointer;}
input,textarea,select{font-family:var(--font-b);}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:#f4f0ea;}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:3px;}

/* ── CONTAINER ── */
.container{max-width:1280px;margin:0 auto;padding:0 24px;}
.container-sm{max-width:800px;margin:0 auto;padding:0 24px;}
.container-lg{max-width:1440px;margin:0 auto;padding:0 24px;}

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4,h5{font-family:var(--font-d);font-weight:600;line-height:1.2;color:var(--dark);}
.label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600;}
.section-title{font-size:clamp(26px,4vw,42px);font-weight:600;}
em{font-style:italic;color:var(--gold);}
p{color:var(--muted);line-height:1.75;}

/* ── SECTIONS ── */
.section{padding:80px 0;}
.section-sm{padding:48px 0;}
.section-lg{padding:100px 0;}
.section-header{margin-bottom:40px;}
.section-header.center{text-align:center;}

/* ── DIVIDER ── */
.divider{width:48px;height:3px;background:var(--gold);border-radius:2px;margin:12px 0 20px;}
.divider.center{margin:12px auto 20px;}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:13px 28px;border-radius:var(--r);border:none;cursor:pointer;transition:var(--tr);white-space:nowrap;text-decoration:none;min-height:46px;}
.btn-gold{background:var(--gold);color:#fff;}
.btn-gold:hover{background:var(--gold2);transform:translateY(-1px);box-shadow:0 4px 16px rgba(201,148,26,.35);}
.btn-outline{background:transparent;color:var(--gold);border:2px solid var(--gold);}
.btn-outline:hover{background:var(--gold);color:#fff;}
.btn-dark{background:var(--dark);color:#fff;}
.btn-dark:hover{background:#333;transform:translateY(-1px);}
.btn-white{background:#fff;color:var(--dark);border:1px solid var(--border);}
.btn-white:hover{border-color:var(--gold);color:var(--gold);}
.btn-sm{padding:8px 18px;font-size:11px;min-height:36px;}
.btn-lg{padding:16px 36px;font-size:13px;min-height:54px;}
.btn-full{width:100%;}

/* ── ANNOUNCE BAR ── */
#announce-bar{background:var(--dark);color:#fff;height:36px;display:flex;align-items:center;overflow:hidden;font-size:11px;font-weight:500;letter-spacing:.06em;}
.announce-track{display:flex;white-space:nowrap;animation:scrollx 30s linear infinite;gap:48px;align-items:center;height:100%;}
.announce-item{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.ann-dot{width:5px;height:5px;border-radius:50%;background:var(--gold);flex-shrink:0;}
@keyframes scrollx{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* ── HEADER ── */
#site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);transition:box-shadow .2s;}
#site-header.scrolled{box-shadow:var(--shadow);}
.header-inner{max-width:1280px;margin:0 auto;padding:0 24px;height:70px;display:flex;align-items:center;gap:16px;}
/* LOGO */
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0;}
.logo-icon{width:44px;height:44px;background:linear-gradient(150deg,#2a1a06,#0d0a04);border:1.5px solid #c9941a;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 0 14px rgba(201,148,26,.3);}
.logo-icon svg{width:28px;height:28px;}
.logo-icon svg{width:22px;height:22px;}
.logo-text b{display:block;font-family:var(--font-d);font-size:19px;font-weight:700;color:var(--dark);line-height:1;}
.logo-text small{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:#c9941a;font-weight:600;}
/* NAV */
.site-nav{display:flex;align-items:center;gap:2px;flex:1;justify-content:center;}
.nav-link{font-size:12px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;padding:8px 14px;color:var(--muted);border-radius:6px;transition:color .18s,background .18s;text-decoration:none;border:none;background:none;cursor:pointer;white-space:nowrap;}
.nav-link:hover,.nav-link.active{color:var(--gold);background:var(--goldbg);}
/* ACTIONS */
.h-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.h-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;background:none;border:1px solid transparent;color:var(--dark);cursor:pointer;transition:var(--tr);position:relative;}
.h-btn:hover{background:var(--bg3);border-color:var(--border);}
.cart-count{position:absolute;top:-2px;right:-2px;width:17px;height:17px;border-radius:50%;background:var(--gold);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;align-items:center;justify-content:center;min-width:44px;min-height:44px;}
.hamburger span{display:block;width:22px;height:2px;background:var(--dark);border-radius:2px;transition:.2s;}

/* ── AGE GATE ── */
#age-gate{position:fixed;inset:0;z-index:9999;background:rgba(28,28,30,.95);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;padding:20px;}
.ag-box{background:#fff;border-radius:var(--rxl);padding:48px 40px;max-width:440px;width:100%;text-align:center;box-shadow:var(--shadow2);}
.ag-logo{width:64px;height:64px;background:linear-gradient(135deg,var(--gold),#7b3f1a);border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;}
.ag-title{font-family:var(--font-d);font-size:26px;font-weight:600;margin-bottom:10px;color:var(--dark);}
.ag-sub{font-size:13px;color:var(--muted);margin-bottom:28px;line-height:1.7;}
.ag-btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;}
.ag-legal{font-size:10px;color:var(--muted2);margin-top:18px;line-height:1.6;}

/* ── MOBILE NAV ── */
#mob-nav{position:fixed;inset:0;background:#fff;z-index:5000;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;}
#mob-nav.open{transform:translateX(0);}
.mob-inner{padding:80px 28px 60px;display:flex;flex-direction:column;min-height:100%;}
.mob-link{display:block;font-family:var(--font-d);font-size:28px;font-weight:500;color:var(--dark);padding:14px 0;border-bottom:1px solid var(--border);text-decoration:none;transition:color .18s;}
.mob-link:active{color:var(--gold);}
.mob-close{position:absolute;top:18px;right:18px;background:var(--bg3);border:1px solid var(--border);color:var(--dark);font-size:20px;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;}

/* ── CART DRAWER ── */
#cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:600;opacity:0;pointer-events:none;transition:opacity .3s;}
#cart-overlay.open{opacity:1;pointer-events:all;}
#cart-drawer{position:fixed;top:0;right:0;bottom:0;width:400px;max-width:100vw;background:#fff;border-left:1px solid var(--border);z-index:700;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;}
#cart-drawer.open{transform:translateX(0);}
.cart-hd{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);}
.cart-hd h3{font-family:var(--font-d);font-size:20px;}
.cart-x{background:none;border:none;font-size:22px;cursor:pointer;color:var(--muted);width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:6px;}
.cart-x:hover{background:var(--bg3);}
.cart-body{flex:1;overflow-y:auto;padding:16px 24px;}
.cart-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--border);}
.ci-img{width:64px;height:80px;border-radius:8px;object-fit:cover;flex-shrink:0;background:var(--bg3);}
.ci-info{flex:1;}
.ci-name{font-size:13px;font-weight:500;color:var(--dark);margin-bottom:4px;}
.ci-price{font-size:14px;font-weight:700;color:var(--gold);}
.ci-qty{display:flex;align-items:center;gap:8px;margin-top:8px;}
.ci-qty button{width:28px;height:28px;border-radius:6px;background:var(--bg3);border:1px solid var(--border);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;font-weight:600;}
.ci-qty span{font-size:13px;font-weight:600;min-width:22px;text-align:center;}
.ci-rm{background:none;border:none;color:var(--muted2);cursor:pointer;font-size:18px;margin-left:auto;}
.cart-ft{padding:20px 24px;border-top:1px solid var(--border);}
.cart-row{display:flex;justify-content:space-between;font-size:13px;padding:5px 0;color:var(--muted);}
.cart-total-row{display:flex;justify-content:space-between;padding:14px 0 0;border-top:1px solid var(--border);margin-top:8px;}
.cart-total-row span{font-size:14px;font-weight:600;color:var(--dark);}
.min-warn{background:#fff7ed;border:1px solid #fed7aa;border-radius:var(--r);padding:10px 14px;font-size:11px;color:#c2410c;margin-bottom:12px;text-align:center;}
.cart-empty{text-align:center;padding:48px 20px;color:var(--muted);}
.cart-empty .icon{font-size:40px;margin-bottom:16px;}

/* ── QUICK VIEW ── */
#qv-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:800;opacity:0;pointer-events:none;transition:opacity .3s;display:flex;align-items:center;justify-content:center;padding:16px;}
#qv-overlay.open{opacity:1;pointer-events:all;}
.qv-box{background:#fff;border-radius:var(--rxl);max-width:700px;width:100%;display:grid;grid-template-columns:1fr 1fr;overflow:hidden;box-shadow:var(--shadow2);max-height:90vh;}
.qv-img-wrap{background:var(--bg3);display:flex;align-items:center;justify-content:center;position:relative;}
.qv-img-wrap img{width:100%;height:100%;object-fit:contain;padding:24px;}
.qv-content{padding:32px;overflow-y:auto;}
.qv-x{position:absolute;top:12px;right:12px;background:#fff;border:1px solid var(--border);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;color:var(--muted);}
.qv-cat{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:8px;display:block;}
.qv-name{font-family:var(--font-d);font-size:22px;font-weight:600;color:var(--dark);margin-bottom:6px;line-height:1.3;}
.qv-price{font-size:26px;font-weight:700;color:var(--gold);margin:12px 0;}
.qv-desc{font-size:13px;color:var(--muted);line-height:1.75;margin-bottom:16px;}
.qv-notes{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px;}
.qv-chip{background:var(--goldbg);border:1px solid var(--border2);border-radius:100px;padding:4px 12px;font-size:11px;color:var(--gold);font-weight:500;}
.qv-qty-row{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.qty-box{display:flex;align-items:center;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;}
.qty-box button{width:38px;height:38px;background:var(--bg3);border:none;cursor:pointer;font-size:18px;font-weight:600;color:var(--dark);}
.qty-box span{width:44px;text-align:center;font-size:15px;font-weight:600;}

/* ── STICKY ADD TO CART ── */
.sticky-atc{position:sticky;bottom:0;left:0;right:0;z-index:100;background:#fff;border-top:1px solid var(--border);padding:12px 16px;display:none;gap:10px;align-items:center;box-shadow:0 -4px 20px rgba(0,0,0,.08);}
.sticky-atc.visible{display:flex;}

/* ── TOAST ── */
#toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(60px);background:var(--dark);color:#fff;border-radius:100px;padding:12px 24px;font-size:12px;z-index:9000;transition:transform .3s;white-space:nowrap;box-shadow:var(--shadow2);pointer-events:none;}
#toast.show{transform:translateX(-50%) translateY(0);}

/* ── HERO ── */
#hero{background:var(--bg2);min-height:88vh;display:flex;align-items:center;overflow:hidden;position:relative;}
.hero-bg-accent{position:absolute;top:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(201,148,26,.1),transparent 70%);pointer-events:none;}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;width:100%;padding:80px 0;}
.hero-text .label{display:block;margin-bottom:16px;}
.hero-h1{font-size:clamp(36px,6vw,68px);font-weight:700;line-height:1.05;margin-bottom:20px;color:var(--dark);}
.hero-h1 em{color:var(--gold);font-style:italic;}
.hero-sub{font-size:15px;color:var(--muted);line-height:1.8;margin-bottom:32px;max-width:460px;}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:40px;}
.hero-badges{display:flex;gap:20px;flex-wrap:wrap;}
.hbadge{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--muted);}
.hbadge svg{color:var(--green);}
.hero-img{position:relative;display:flex;align-items:center;justify-content:center;}
.hero-img-wrap{position:relative;z-index:1;}
.hero-img-wrap img{max-height:580px;width:auto;filter:drop-shadow(0 20px 60px rgba(0,0,0,.15));animation:float 4s ease-in-out infinite;}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}
.hero-img-circle{position:absolute;width:400px;height:400px;background:radial-gradient(circle,var(--goldbg),transparent 70%);border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);z-index:0;}
.hero-tag{position:absolute;background:#fff;border:1px solid var(--border);border-radius:12px;padding:12px 16px;box-shadow:var(--shadow);z-index:2;}
.hero-tag-top{top:8%;right:0;}
.hero-tag-bot{bottom:12%;left:0;}
.hero-tag .ht-val{font-family:var(--font-d);font-size:18px;font-weight:700;color:var(--gold);}
.hero-tag .ht-label{font-size:10px;color:var(--muted);letter-spacing:.06em;}

/* ── TRUST BAR ── */
.trust-bar{background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:18px 0;}
.trust-inner{display:flex;align-items:center;justify-content:space-around;flex-wrap:wrap;gap:12px;}
.trust-item{display:flex;align-items:center;gap:10px;}
.trust-icon{width:36px;height:36px;background:var(--goldbg);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0;}
.trust-text strong{display:block;font-size:13px;font-weight:600;color:var(--dark);}
.trust-text span{font-size:11px;color:var(--muted);}

/* ── CATEGORY CARDS ── */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.cat-card{background:#fff;border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;cursor:pointer;text-decoration:none;display:block;transition:var(--tr);}
.cat-card:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:var(--shadow2);}
.cat-img-wrap{height:160px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.cat-label-wrap{padding:14px 16px;}
.cat-name{font-family:var(--font-d);font-size:16px;font-weight:600;color:var(--dark);margin-bottom:3px;}
.cat-desc{font-size:11px;color:var(--muted);}
.cat-arr{color:var(--gold);font-size:14px;float:right;margin-top:-20px;}

/* ── PRODUCTS GRID ── */
.products-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px;}
.pc{background:#fff;border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;transition:var(--tr);display:flex;flex-direction:column;position:relative;}
.pc:hover{border-color:var(--gold);box-shadow:var(--shadow2);transform:translateY(-2px);}
.pc-img-wrap{height:220px;background:var(--bg3);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.pc-img-wrap img{height:190px;width:auto;object-fit:contain;transition:transform .35s;}
.pc:hover .pc-img-wrap img{transform:scale(1.05);}
.pc-badge{position:absolute;top:10px;left:10px;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 10px;border-radius:100px;}
.badge-hot{background:#fef08a;color:#78350f;}
.badge-new{background:#dcfce7;color:#14532d;}
.badge-rare{background:#fee2e2;color:#991b1b;}
.badge-sale{background:#dbeafe;color:#1e40af;}
.pc-info{padding:14px;flex:1;display:flex;flex-direction:column;}
.pc-cat{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:5px;}
.pc-name{font-family:var(--font-d);font-size:14px;font-weight:600;color:var(--dark);line-height:1.35;margin-bottom:3px;min-height:38px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.pc-dist{font-size:10px;color:var(--muted2);margin-bottom:8px;}
.pc-price{font-size:18px;font-weight:700;color:var(--gold);margin-top:auto;}
.pc-atc{width:100%;background:var(--dark);color:#fff;border:none;border-radius:var(--r);padding:10px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:background .18s;margin-top:10px;min-height:40px;}
.pc-atc:hover{background:var(--gold);}

/* ── FILTER TABS ── */
.filter-wrap{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:28px;}
.ftab{font-size:11px;font-weight:500;padding:8px 18px;border-radius:100px;border:1px solid var(--border);background:#fff;color:var(--muted);cursor:pointer;transition:var(--tr);white-space:nowrap;}
.ftab:hover{border-color:var(--gold);color:var(--gold);}
.ftab.active{background:var(--gold);border-color:var(--gold);color:#fff;font-weight:700;}

/* ── PAGE HERO ── */
.page-hero{background:var(--bg2);padding:70px 0 50px;border-bottom:1px solid var(--border);}
.page-hero .label{display:block;margin-bottom:12px;}
.page-hero h1{font-size:clamp(28px,5vw,52px);margin-bottom:14px;}
.page-hero p{font-size:14px;max-width:540px;}
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted2);margin-bottom:20px;}
.breadcrumb a{color:var(--muted2);transition:color .18s;}
.breadcrumb a:hover{color:var(--gold);}

/* ── BLOG ── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.bc{background:#fff;border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;text-decoration:none;display:block;transition:var(--tr);}
.bc:hover{border-color:var(--gold);box-shadow:var(--shadow2);transform:translateY(-3px);}
.bc-img{height:220px;background:#ffffff;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:12px;}
.bc-img img{max-height:196px;max-width:100%;width:auto;height:auto;object-fit:contain;transition:transform .35s;filter:drop-shadow(0 4px 12px rgba(0,0,0,.12));}
.bc:hover .bc-img img{transform:scale(1.06);}
.bc-body{padding:20px;}
.bc-cat{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:8px;display:block;}
.bc-title{font-family:var(--font-d);font-size:17px;font-weight:600;color:var(--dark);line-height:1.3;margin-bottom:8px;}
.bc-excerpt{font-size:12px;color:var(--muted);line-height:1.7;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.bc-meta{display:flex;align-items:center;gap:10px;margin-top:12px;font-size:11px;color:var(--muted2);}
.bc-meta span:first-child::after{content:'·';margin-left:10px;}

/* ── FAQ ── */
.faq-item{border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:10px;background:#fff;}
.faq-q{width:100%;background:none;border:none;padding:18px 20px;display:flex;align-items:center;justify-content:space-between;font-size:14px;font-weight:600;color:var(--dark);cursor:pointer;text-align:left;gap:12px;}
.faq-q:hover{background:var(--bg3);}
.faq-icon{width:24px;height:24px;border-radius:50%;background:var(--goldbg);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:14px;flex-shrink:0;transition:transform .2s;}
.faq-item.open .faq-icon{transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;font-size:13px;color:var(--muted);line-height:1.75;}
.faq-a-inner{padding:0 20px 18px;}
.faq-item.open .faq-a{max-height:200px;}

/* ── NEWSLETTER ── */
.nl-section{background:var(--dark);padding:64px 0;text-align:center;}
.nl-section h2{color:#fff;font-size:clamp(24px,4vw,38px);margin-bottom:10px;}
.nl-section p{color:rgba(255,255,255,.6);margin-bottom:28px;}
.nl-form{display:flex;max-width:420px;margin:0 auto;}
.nl-input{flex:1;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-right:none;border-radius:var(--r) 0 0 var(--r);padding:13px 16px;color:#fff;font-size:13px;outline:none;}
.nl-input::placeholder{color:rgba(255,255,255,.4);}
.nl-input:focus{border-color:var(--gold);}
.nl-btn{background:var(--gold);color:#fff;border:none;border-radius:0 var(--r) var(--r) 0;padding:13px 20px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:background .18s;white-space:nowrap;}
.nl-btn:hover{background:var(--gold2);}

/* ── FORMS ── */
.form-group{margin-bottom:16px;}
.form-label{display:block;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;font-weight:600;}
.form-input{width:100%;background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;color:var(--dark);font-size:13px;transition:border-color .18s;outline:none;}
.form-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,148,26,.1);}
.form-input::placeholder{color:var(--muted2);}
textarea.form-input{resize:vertical;min-height:100px;}
select.form-input{cursor:pointer;}

/* ── CHECKOUT ── */
.co-layout{display:grid;grid-template-columns:1fr 380px;gap:32px;align-items:start;}
.co-section{background:#fff;border:1px solid var(--border);border-radius:var(--rl);padding:28px;margin-bottom:20px;}
.co-title{font-family:var(--font-d);font-size:18px;font-weight:600;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--border);}
.order-box{background:#fff;border:1px solid var(--border);border-radius:var(--rl);padding:24px;position:sticky;top:90px;}
.ob-title{font-family:var(--font-d);font-size:18px;font-weight:600;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border);}
.ob-item{display:flex;justify-content:space-between;font-size:12px;padding:6px 0;color:var(--muted);}
.ob-total{display:flex;justify-content:space-between;padding:14px 0 0;border-top:1px solid var(--border);margin-top:8px;}
.ob-total span{font-weight:700;color:var(--dark);font-size:15px;}
/* Payment methods */
.pay-methods{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px;}
.pay-method{border:2px solid var(--border);border-radius:var(--r);padding:12px;cursor:pointer;text-align:center;transition:var(--tr);background:#fff;}
.pay-method:hover,.pay-method.selected{border-color:var(--gold);background:var(--goldbg);}
.pay-method .pm-label{font-size:11px;font-weight:600;color:var(--dark);margin-top:4px;}
.pay-method .pm-icon{font-size:22px;}
/* Crypto */
.crypto-panel{display:none;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:20px;margin-top:12px;}
.crypto-panel.active{display:block;}
.crypto-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px;}
.ctab{font-size:10px;font-weight:600;padding:5px 12px;border-radius:100px;border:1px solid var(--border);background:#fff;cursor:pointer;transition:var(--tr);}
.ctab.active{background:var(--gold);border-color:var(--gold);color:#fff;}
.crypto-addr-wrap{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:14px;font-size:11px;word-break:break-all;color:var(--dark);margin-bottom:12px;font-family:monospace;}
.qr-wrap{text-align:center;margin-bottom:10px;}
.qr-wrap canvas{border-radius:8px;border:4px solid #fff;box-shadow:var(--shadow);}

/* ── FOOTER ── */
#site-footer{background:var(--dark);padding:64px 0 32px;color:rgba(255,255,255,.7);}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px;}
.fc h4{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:16px;}
.fc p{font-size:12px;line-height:1.75;}
.fc ul{list-style:none;display:flex;flex-direction:column;gap:8px;}
.fc li a{font-size:12px;color:rgba(255,255,255,.6);transition:color .18s;}
.fc li a:hover{color:var(--gold);}
.footer-logo b{font-family:var(--font-d);font-size:20px;color:#fff;display:block;margin-bottom:4px;}
.footer-logo small{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);}
.footer-social{display:flex;gap:8px;margin-top:16px;}
.fsoc{width:36px;height:36px;border-radius:8px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);transition:var(--tr);text-decoration:none;}
.fsoc:hover{background:var(--gold);color:#fff;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;}
.footer-copy{font-size:11px;color:rgba(255,255,255,.4);}
.footer-links{display:flex;gap:16px;}
.footer-links a{font-size:11px;color:rgba(255,255,255,.4);transition:color .18s;}
.footer-links a:hover{color:var(--gold);}
.f21{font-size:11px;color:var(--gold);font-weight:600;}

/* ── WHATSAPP FLOAT ── */
#wa-float{position:fixed;bottom:24px;left:20px;width:54px;height:54px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;z-index:500;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:transform .2s;}
#wa-float:hover{transform:scale(1.08);}
.wa-label{position:absolute;left:64px;background:var(--dark);color:#fff;font-size:11px;font-weight:600;padding:6px 12px;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;}
#wa-float:hover .wa-label{opacity:1;}

/* ── INFO CARDS ── */
.info-card{background:#fff;border:1px solid var(--border);border-radius:var(--rl);padding:28px;}
.info-card h3{font-family:var(--font-d);font-size:22px;margin-bottom:12px;}
.info-card p{font-size:13px;}

/* ── STEPS ── */
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative;}
.step-card{text-align:center;padding:28px 16px;background:#fff;border:1px solid var(--border);border-radius:var(--rl);}
.step-num{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--gold),#7b3f1a);color:#fff;font-family:var(--font-d);font-size:22px;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;}
.step-title{font-family:var(--font-d);font-size:17px;font-weight:600;margin-bottom:8px;}
.step-desc{font-size:12px;color:var(--muted);}

/* ── POLICY PAGES ── */
.policy-content h2{font-family:var(--font-d);font-size:22px;font-weight:600;margin:28px 0 12px;color:var(--dark);}
.policy-content p{font-size:13px;color:var(--muted);line-height:1.8;margin-bottom:14px;}
.policy-content ul{margin-left:20px;margin-bottom:14px;}
.policy-content li{font-size:13px;color:var(--muted);line-height:1.8;margin-bottom:6px;}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;}
.contact-item{display:flex;align-items:flex-start;gap:14px;padding:20px;background:#fff;border:1px solid var(--border);border-radius:var(--rl);}
.contact-icon{width:44px;height:44px;background:var(--goldbg);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0;}

/* ── WHOLESALE ── */
.ws-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.ws-tier{background:#fff;border:1px solid var(--border);border-radius:var(--rl);padding:28px;}
.ws-tier.featured{border-color:var(--gold);position:relative;}
.ws-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--gold);color:#fff;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:4px 14px;border-radius:100px;}
.ws-tier-name{font-family:var(--font-d);font-size:22px;font-weight:600;margin-bottom:8px;}
.ws-tier-price{font-size:32px;font-weight:700;color:var(--gold);margin:12px 0 16px;}
.ws-tier ul{list-style:none;font-size:12px;color:var(--muted);display:flex;flex-direction:column;gap:8px;margin-bottom:20px;}
.ws-tier li::before{content:'✓  ';color:var(--green);}

/* ── REVEAL ANIMATION ── */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .5s,transform .5s;}
.reveal.visible{opacity:1;transform:translateY(0);}

/* ── MISC ── */
.text-center{text-align:center;}
.text-gold{color:var(--gold);}
.mt-8{margin-top:8px;}.mt-16{margin-top:16px;}.mt-24{margin-top:24px;}.mt-32{margin-top:32px;}.mt-48{margin-top:48px;}
.mb-8{margin-bottom:8px;}.mb-16{margin-bottom:16px;}.mb-24{margin-bottom:24px;}.mb-32{margin-bottom:32px;}
.states-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px;}
.state-tag{background:var(--goldbg);border:1px solid var(--border2);border-radius:4px;padding:4px 8px;font-size:10px;color:var(--gold);font-weight:500;}

/* ══════════════════ RESPONSIVE ══════════════════ */
@media(max-width:1100px){.products-grid{grid-template-columns:repeat(3,1fr);}.cat-grid{grid-template-columns:repeat(3,1fr);}.footer-grid{grid-template-columns:1fr 1fr 1fr;}}
@media(max-width:900px){.site-nav{display:none!important;}.hamburger{display:flex!important;}.hero-inner{grid-template-columns:1fr;gap:32px;}.hero-text{order:1;}.hero-img{order:2;}.hero-h1{font-size:clamp(32px,7vw,52px);}.products-grid{grid-template-columns:repeat(2,1fr);}.cat-grid{grid-template-columns:repeat(2,1fr);}.steps-grid{grid-template-columns:repeat(2,1fr);}.qv-box{grid-template-columns:1fr;}.qv-img-wrap{height:220px;}.co-layout{grid-template-columns:1fr;}.ws-tiers{grid-template-columns:1fr;}.contact-grid{grid-template-columns:1fr;}.blog-grid{grid-template-columns:repeat(2,1fr);}.footer-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:640px){.blog-grid{grid-template-columns:1fr;}.products-grid{grid-template-columns:repeat(2,1fr);gap:12px;}.cat-grid{grid-template-columns:repeat(2,1fr);gap:12px;}.hero-img{display:none;}.steps-grid{grid-template-columns:1fr;}}
@media(max-width:480px){.container{padding:0 16px;}.header-inner{padding:0 16px;}.products-grid{grid-template-columns:repeat(2,1fr);gap:10px;}.pc-img-wrap{height:170px;}.footer-grid{grid-template-columns:1fr;}.pay-methods{grid-template-columns:1fr;}}
@media(hover:none) and (pointer:coarse){.pc:hover,.bc:hover,.cat-card:hover{transform:none;}.pc:active,.bc:active,.cat-card:active{opacity:.85;}}
@supports(padding:env(safe-area-inset-bottom)){#wa-float{bottom:calc(20px + env(safe-area-inset-bottom));}}
html,body{overflow-x:hidden;}


/* ─── SHOP MEGA DROPDOWN ────────────────────────────────── */
.has-mega { position:relative; }

/* Arrow indicator only on Shop */
.has-mega > .nav-link { display:flex; align-items:center; gap:4px; cursor:pointer; }
.has-mega > .nav-link::after {
  content:"▾"; font-size:10px; opacity:.65;
  transition:transform .22s ease;
}
.has-mega.mega-open > .nav-link::after,
.has-mega:hover > .nav-link::after { transform:rotate(-180deg); opacity:1; }

/* Dropdown panel */
.mega-menu {
  position:absolute; top:calc(100% + 10px);
  left:50%; transform:translateX(-50%) translateY(6px);
  background:#fff; border:1px solid var(--border);
  border-radius:14px;
  box-shadow:0 20px 56px rgba(0,0,0,.14);
  padding:28px 24px 22px;
  display:grid; grid-template-columns:repeat(4,1fr); gap:0 26px;
  min-width:800px;
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .22s ease, transform .22s ease, visibility .22s;
  z-index:9999;
}
/* Open on hover (desktop) */
.has-mega:hover .mega-menu {
  opacity:1; visibility:visible; pointer-events:all;
  transform:translateX(-50%) translateY(0);
}
/* Open on click (pinned state) */
.has-mega.mega-open .mega-menu {
  opacity:1; visibility:visible; pointer-events:all;
  transform:translateX(-50%) translateY(0);
}

/* Columns */
.mega-col { min-width:0; }
.mega-col + .mega-col { border-left:1px solid var(--border); padding-left:22px; }
.mega-col-title {
  font-size:9px; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; color:var(--gold);
  margin-bottom:12px; padding-bottom:7px;
  border-bottom:1px solid var(--border);
}
.mega-col a {
  display:block; font-size:12px; color:var(--muted);
  padding:4px 0; text-decoration:none;
  transition:color .15s, padding-left .15s;
}
.mega-col a:hover { color:var(--gold); padding-left:5px; }
.mega-col a strong { display:block; font-size:11.5px; font-weight:600; color:var(--dark); }
.mega-col a span   { font-size:10px; color:var(--muted2); display:block; }
.mega-col .sub-label {
  font-size:9px; font-weight:700; letter-spacing:.12em;
  text-transform:uppercase; color:var(--muted2);
  margin:10px 0 3px;
}
.mega-featured {
  background:var(--goldbg); border-radius:10px;
  padding:14px 14px 16px; margin-left:2px;
}
.mega-featured .mega-col-title { border-color:rgba(201,148,26,.25); }
.mega-featured a { color:var(--dark); }
.mega-featured a:hover { color:var(--gold); }
.mega-browse-btn {
  display:inline-block; margin-top:12px;
  padding:7px 16px; background:var(--gold);
  color:#fff !important; border-radius:20px;
  font-size:11px; font-weight:700;
  text-align:center;
}
.mega-browse-btn:hover { background:var(--gold-dk,#a07010) !important; padding-left:16px !important; }

/* ── MOBILE SHOP COLLAPSIBLE ─────────────────────────────── */
.mob-shop-toggle {
  display:flex; align-items:center; justify-content:space-between;
  width:100%; padding:14px 0;
  font-size:15px; font-weight:600; color:var(--dark);
  background:none; border:none; border-bottom:1px solid var(--border);
  cursor:pointer; text-align:left;
}
.mob-shop-toggle .mob-arrow {
  font-size:11px; opacity:.6;
  transition:transform .22s ease;
}
.mob-shop-toggle.open .mob-arrow { transform:rotate(-180deg); }
.mob-shop-cats {
  display:none; padding:8px 0 4px;
  border-bottom:1px solid var(--border);
}
.mob-shop-cats.open { display:block; }
.mob-cat-section { padding:6px 0; }
.mob-cat-section-title {
  font-size:9px; font-weight:700; letter-spacing:.12em;
  text-transform:uppercase; color:var(--gold);
  padding:6px 12px 3px;
}
.mob-cat-link {
  display:block; padding:7px 12px;
  font-size:13px; color:var(--muted);
  text-decoration:none;
  border-radius:6px; transition:background .15s, color .15s;
}
.mob-cat-link:hover,
.mob-cat-link:active { background:var(--goldbg); color:var(--gold); }
.mob-cat-link span {
  display:block; font-size:10px;
  color:var(--muted2);
}
/* Hide mega menu entirely on mobile */
@media(max-width:900px) {
  .mega-menu { display:none !important; }
  .has-mega > .nav-link::after { display:none; }
}

/* Mobile: hide mega, show simple links */
@media(max-width:900px){
  .mega-menu{display:none!important;}
  .has-mega>.nav-link::after{display:none;}
}

/* ── Product card links ── */
.pc-img-link{display:block;text-decoration:none;color:inherit;}
.pc-img-link:hover .pc-img-wrap{box-shadow:0 4px 20px rgba(201,148,26,.15);}
.pc-name-link{text-decoration:none;color:inherit;}
.pc-name-link:hover .pc-name{color:var(--gold);}
.pc-btns{display:flex;gap:6px;align-items:center;margin-top:8px;}
.pc-btns .pc-atc{flex:1;}
.pc-view-btn{display:inline-flex;align-items:center;padding:7px 10px;
  font-size:11px;font-weight:600;color:var(--gold);
  border:1px solid var(--border2);border-radius:var(--r);
  text-decoration:none;white-space:nowrap;
  transition:background .15s,color .15s;}
.pc-view-btn:hover{background:var(--goldbg);color:var(--gold-dk,#a07010);}

/* ── Product image fallback when images not available ── */
.pc-img-wrap img, .pdp-img-wrap img {
  background: linear-gradient(160deg,#2a1a06,#0d0a04);
}

/* Blog post tags */
.blog-tags{display:flex;flex-wrap:wrap;gap:6px;}
.blog-tag{font-size:10px;color:#888;background:#faf8f5;
  border:1px solid #ede4d8;border-radius:4px;padding:3px 10px;
  text-decoration:none;transition:all .15s;}
.blog-tag:hover{background:#c9941a;color:#fff;border-color:#c9941a;}

/* ── Responsive additions for GT Metrix / PageSpeed ── */
@media(min-width:1200px){
  .container{max-width:1320px;}
  .products-grid{grid-template-columns:repeat(5,1fr);}
}
@media(max-width:768px){
  .products-grid{grid-template-columns:repeat(2,1fr);gap:12px;}
  .pc-img-wrap{height:180px;}
  .pc-name{font-size:13px;}
  .pc-price{font-size:15px;}
  h1{font-size:clamp(22px,5vw,38px);}
  h2{font-size:clamp(18px,4vw,28px);}
}
@media(max-width:360px){
  .products-grid{grid-template-columns:1fr;}
  .header-inner{padding:0 12px;}
}

/* ── Accessibility & Performance additions ── */
@font-face {
  font-family: 'Inter';
  font-display: swap;
}
@font-face {
  font-family: 'Playfair Display';
  font-display: swap;
}

/* Skip navigation link */
.skip-link {
  position: absolute;
  top: -100px;
  left: 16px;
  z-index: 9999;
  padding: 10px 18px;
  background: #c9941a;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  border-radius: 0 0 8px 8px;
  text-decoration: none;
  transition: top .2s;
}
.skip-link:focus {
  top: 0;
  outline: 3px solid #1c1c1e;
  outline-offset: 2px;
}

/* Visible focus for all interactive elements */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible {
  outline: 3px solid #c9941a !important;
  outline-offset: 2px;
  border-radius: 3px;
}

/* Responsive images — prevent layout shift */
img {
  max-width: 100%;
  height: auto;
}

/* Ensure tap targets are large enough on mobile */
@media(max-width:640px) {
  a, button, [role="button"] {
    min-height: 44px;
    min-width: 44px;
  }
  .pc-atc, .pdp-copy-btn, .pdp-copybtn {
    min-height: 44px;
  }
}

/* ── Accessibility contrast patch (WCAG AA) ─────────────────
   #c9941a on white = 2.7:1 (fails 4.5:1 normal text threshold)
   --gold-dark = #7a5800 → 6.1:1 ✅ for small text
   --muted2 fixed: #767676 → 4.54:1 ✅ (was #9b9b9b = 2.75:1)
   ──────────────────────────────────────────────────────────── */
/* a11y-contrast-patch */
:root {
  --gold-dark: #7a5800;
  --muted2:    #767676;
}
/* Small text that uses gold — switch to dark variant */
.logo-text small,
.pdp-label, .pdp-cat-label, .pdp-cat,
.pdp-section-label, .pdp-tnlbl, .pdp-desclbl,
.pdp-copy-lbl, .pdp-link-label,
.pdp-tags-lbl, .blog-tags-lbl,
.spec-key, .pdp-spec-label,
.pdp-tn-lbl, .pdp-tags-lbl,
.pdp-share-lbl, .pdp-copy-lbl,
.pdp-copylbl, .pdp-link-lbl,
.pc-cat, .pdp-dist, .pdp-region,
.pdp-crypto { color: var(--gold-dark); }

/* Prices and large gold text keep original (large text = 3:1 threshold, #c9941a passes) */
.pdp-price, .pc-price,
.pdp-copybtn:hover, .pdp-copy-btn:hover { color: var(--gold); }

/* Focus visible — enhanced for accessibility */
:focus-visible {
  outline: 3px solid var(--gold-dark) !important;
  outline-offset: 2px !important;
}
*:focus:not(:focus-visible) { outline: none; }

/* Mobile tap targets — minimum 48x48px */
.btn, .nav-link, .pc-atc, .pc-view-btn,
.pdp-copybtn, .pdp-copy-btn,
.pdp-copybtn, button.pdp-copy-btn {
  min-height: 44px;
}
.nav-link { min-height: 44px; display: inline-flex; align-items: center; }

/* ── Accessibility: reduced motion + touch-action ─── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
}
.btn,.pc-atc,.nav-link,.pdp-copy-btn,.pdp-copybtn{touch-action:manipulation}
