/* =================================================================
   Bevspir Group — Design System
   Bevspir Fine Spirits & Beverages Group — vibrant, energetic, premium
   ================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800;900&family=Inter:wght@400;500;600;700&display=swap');

:root{
  /* Brand gradient stops */
  --violet:#8B2FE6;
  --magenta:#FF2D86;
  --coral:#FF6B35;
  --teal:#00E0D0;
  --cyan:#00B4D8;

  /* Core palette */
  --ink:#140821;          /* deep near-black violet */
  --ink-2:#1d0f2e;
  --ink-3:#2a1840;
  --paper:#ffffff;
  --mist:#f6f3fb;
  --mist-2:#efe9f7;
  --line:#e7e0f0;
  --muted:#6b6280;
  --text:#241b35;

  --grad-brand:linear-gradient(120deg,#8B2FE6 0%,#FF2D86 52%,#FF6B35 100%);
  --grad-brand-soft:linear-gradient(120deg,#9b46ec 0%,#ff4d97 55%,#ff7d4d 100%);
  --grad-cool:linear-gradient(120deg,#00E0D0 0%,#00B4D8 100%);
  --grad-night:linear-gradient(160deg,#1a0a2e 0%,#2a0f45 55%,#3d1259 100%);

  --shadow-sm:0 2px 8px rgba(40,12,70,.08);
  --shadow:0 12px 34px rgba(40,12,70,.12);
  --shadow-lg:0 26px 70px rgba(40,12,70,.22);
  --glow:0 14px 40px rgba(255,45,134,.35);

  --radius:18px;
  --radius-sm:12px;
  --radius-lg:28px;
  --maxw:1240px;
  --header-h:118px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;
  color:var(--text);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4,.brandfont{font-family:'Poppins',sans-serif;line-height:1.1;color:var(--ink)}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.gradient-text{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-weight:700;font-family:'Poppins',sans-serif;font-size:15px;
  padding:13px 26px;border-radius:999px;transition:.25s ease;white-space:nowrap;border:2px solid transparent}
.btn-primary{background:var(--grad-brand);color:#fff;box-shadow:var(--glow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 50px rgba(255,45,134,.5)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.35);backdrop-filter:blur(6px)}
.btn-ghost:hover{background:rgba(255,255,255,.18);transform:translateY(-2px)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--ink-3);transform:translateY(-2px)}
.btn-outline{border-color:var(--line);background:#fff;color:var(--ink)}
.btn-outline:hover{border-color:var(--magenta);color:var(--magenta)}
.btn-sm{padding:9px 18px;font-size:13.5px}
.btn-block{width:100%}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.86);
  backdrop-filter:blur(16px);border-bottom:1px solid var(--line);transition:.3s}
.topbar{background:var(--ink);color:#fff;font-size:12.5px;letter-spacing:.3px}
.topbar .container{display:flex;align-items:center;justify-content:space-between;height:34px}
.topbar a{opacity:.85;transition:.2s}.topbar a:hover{opacity:1}
.topbar .ticker{display:flex;gap:26px;overflow:hidden;white-space:nowrap}
.topbar .ticker span{display:inline-flex;align-items:center;gap:7px}
.topbar .dot{color:var(--teal)}

.header-main{display:flex;align-items:center;gap:22px;padding:14px 0}
.logo{color:var(--ink);flex-shrink:0}
.logo svg{height:52px;width:auto}
.search{flex:1;display:flex;align-items:center;background:var(--mist);border:2px solid transparent;
  border-radius:999px;padding:4px 4px 4px 20px;transition:.2s;max-width:560px}
.search:focus-within{border-color:var(--magenta);background:#fff;box-shadow:0 6px 22px rgba(255,45,134,.16)}
.search svg{flex-shrink:0;color:var(--muted)}
.search input{flex:1;border:none;background:none;outline:none;font-size:15px;padding:10px 12px;color:var(--ink)}
.search button{background:var(--grad-brand);color:#fff;border-radius:999px;padding:11px 22px;font-weight:700;font-size:14px;font-family:'Poppins'}
.header-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.iconbtn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 12px;border-radius:14px;
  font-size:11.5px;font-weight:600;color:var(--ink);transition:.2s;position:relative}
.iconbtn:hover{background:var(--mist);color:var(--magenta)}
.iconbtn svg{width:22px;height:22px}
.cart-count{position:absolute;top:2px;right:6px;background:var(--coral);color:#fff;
  font-size:10.5px;font-weight:800;min-width:18px;height:18px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 2px 6px rgba(255,107,53,.5)}
.cart-count:empty{display:none}

/* ---------- Nav ---------- */
.mainnav{border-top:1px solid var(--line)}
.mainnav .container{display:flex;align-items:center;gap:4px;height:50px}
.mainnav a{font-family:'Poppins';font-weight:600;font-size:14.5px;color:var(--ink);
  padding:8px 16px;border-radius:10px;transition:.2s;position:relative}
.mainnav a:hover{color:var(--magenta);background:var(--mist)}
.mainnav a.active{color:var(--magenta)}
.mainnav a.active::after{content:"";position:absolute;left:16px;right:16px;bottom:2px;height:3px;
  background:var(--grad-brand);border-radius:3px}
.nav-deal{margin-left:auto;color:var(--coral)!important;display:inline-flex;align-items:center;gap:6px}

.menu-toggle{display:none}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#cfc4e0;margin-top:90px;position:relative;overflow:hidden}
.site-footer::before{content:"";position:absolute;inset:0;background:
  radial-gradient(700px 300px at 12% 0%,rgba(139,47,230,.35),transparent 60%),
  radial-gradient(700px 300px at 85% 20%,rgba(255,45,134,.25),transparent 60%);pointer-events:none}
.footer-top{position:relative;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding:64px 24px 44px}
.footer-brand .logo{color:#fff;margin-bottom:18px}
.footer-brand p{font-size:14px;max-width:320px;color:#b6a9cc}
.footer-social{display:flex;gap:12px;margin-top:22px}
.footer-social a{width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;transition:.25s;color:#fff}
.footer-social a:hover{background:var(--grad-brand);transform:translateY(-3px)}
.footer-col h4{color:#fff;font-size:14px;letter-spacing:.5px;text-transform:uppercase;margin-bottom:18px}
.footer-col a{display:block;font-size:14px;padding:6px 0;color:#b6a9cc;transition:.2s}
.footer-col a:hover{color:var(--teal);transform:translateX(4px)}
.footer-bottom{position:relative;border-top:1px solid rgba(255,255,255,.1);padding:22px 24px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:13px;color:#9d8fb6}
.footer-bottom .links{display:flex;gap:22px;flex-wrap:wrap}
.footer-bottom a:hover{color:#fff}

/* ---------- Product card ---------- */
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:22px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  transition:.3s cubic-bezier(.2,.7,.2,1);display:flex;flex-direction:column;position:relative}
.card:hover{transform:translateY(-7px);box-shadow:var(--shadow-lg);border-color:transparent}
.card-media{position:relative;aspect-ratio:1/1.02;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 30%,var(--mist),#fff);overflow:hidden}
.card-media svg.bottle{height:80%;width:auto;filter:drop-shadow(0 14px 22px rgba(40,12,70,.22));transition:.35s}
.card:hover .card-media svg.bottle{transform:translateY(-4px) scale(1.05) rotate(-2deg)}
.media-frame{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}
.media-frame img.pimg{width:100%;height:100%;object-fit:cover;transition:.45s cubic-bezier(.2,.7,.2,1);background:var(--mist)}
.card:hover .media-frame img.pimg{transform:scale(1.07)}
.badge{position:absolute;top:12px;left:12px;font-family:'Poppins';font-weight:700;font-size:11px;
  letter-spacing:.4px;text-transform:uppercase;color:#fff;padding:5px 11px;border-radius:999px;
  background:var(--grad-brand);box-shadow:0 6px 16px rgba(255,45,134,.4);z-index:2}
.badge.cool{background:var(--grad-cool);box-shadow:0 6px 16px rgba(0,180,216,.4)}
.badge.dark{background:var(--ink)}
.wishbtn{position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.85);display:flex;align-items:center;justify-content:center;z-index:2;
  color:var(--muted);transition:.2s;box-shadow:var(--shadow-sm)}
.wishbtn:hover{color:var(--magenta);transform:scale(1.12)}
.wishbtn.active{color:var(--magenta)}
.card-body{padding:16px 16px 18px;display:flex;flex-direction:column;flex:1}
.card-cat{font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--violet);margin-bottom:5px}
.card-name{font-family:'Poppins';font-weight:600;font-size:15px;color:var(--ink);line-height:1.25;
  margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:38px}
.card-meta{font-size:12.5px;color:var(--muted);margin-bottom:8px}
.stars{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;color:var(--muted);margin-bottom:12px}
.stars b{color:#ff9500;letter-spacing:1px}
.card-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px}
.price{font-family:'Poppins';font-weight:800;font-size:20px;color:var(--ink)}
.price .list{font-size:13px;font-weight:500;color:var(--muted);text-decoration:line-through;margin-left:6px}
.addbtn{background:var(--grad-brand);color:#fff;width:42px;height:42px;border-radius:13px;
  display:flex;align-items:center;justify-content:center;transition:.25s;box-shadow:0 6px 16px rgba(255,45,134,.35)}
.addbtn:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 10px 24px rgba(255,45,134,.5)}
.addbtn.added{background:var(--grad-cool)}

/* ---------- Section headers ---------- */
.section{padding:64px 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:34px;flex-wrap:wrap}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:'Poppins';font-weight:700;font-size:13px;
  letter-spacing:1px;text-transform:uppercase;color:var(--magenta);margin-bottom:12px}
.eyebrow::before{content:"";width:26px;height:3px;border-radius:3px;background:var(--grad-brand)}
.section-head h2{font-size:clamp(28px,4vw,42px);font-weight:800}
.section-head p{color:var(--muted);max-width:520px;margin-top:8px}

/* ---------- Pills / filters ---------- */
.pillrow{display:flex;gap:10px;flex-wrap:wrap}
.pill{font-family:'Poppins';font-weight:600;font-size:13.5px;padding:9px 18px;border-radius:999px;
  background:#fff;border:1.5px solid var(--line);color:var(--ink);transition:.2s;cursor:pointer}
.pill:hover{border-color:var(--magenta);color:var(--magenta)}
.pill.active{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(120px);
  background:var(--ink);color:#fff;padding:14px 22px;border-radius:14px;display:flex;align-items:center;gap:12px;
  box-shadow:var(--shadow-lg);z-index:300;opacity:0;transition:.4s cubic-bezier(.2,.8,.2,1);font-weight:600;font-size:14px}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.toast .ic{width:28px;height:28px;border-radius:50%;background:var(--grad-cool);display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* ---------- Misc reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

@media (max-width:1024px){
  .mainnav a{padding:8px 11px;font-size:13.5px}
}
@media (max-width:880px){
  :root{--header-h:74px}
  .topbar{display:none}
  .search{order:3;flex-basis:100%;max-width:none;margin-top:10px}
  .header-main{flex-wrap:wrap}
  .mainnav{display:none}
  .menu-toggle{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:var(--mist);color:var(--ink)}
  .mobile-nav.open{display:flex}
  .footer-top{grid-template-columns:1fr 1fr;gap:30px}
}
@media (max-width:560px){
  .footer-top{grid-template-columns:1fr 1fr;gap:24px 18px;padding:40px 22px 30px}
  .footer-brand{grid-column:1 / -1;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:22px;margin-bottom:2px}
  .footer-brand p{max-width:none}
  .footer-col h4{margin-bottom:12px}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:12px;text-align:left;padding:22px}
  .product-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}
  .header-actions .label-hide{display:none}
}

/* ---------- Category / catalog page ---------- */
.cat-hero{position:relative;overflow:hidden;background:var(--grad-night);color:#fff;padding:54px 0 60px}
.cat-hero .blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5}
.cat-hero .blob.x1{width:360px;height:360px;background:#8B2FE6;top:-120px;left:-60px}
.cat-hero .blob.x2{width:320px;height:320px;background:#FF2D86;bottom:-160px;right:8%}
.cat-hero .container{position:relative;z-index:2}
.crumbs{font-size:13px;color:#c4b6dd;margin-bottom:14px}
.crumbs a:hover{color:#fff}
.cat-hero h1{font-size:clamp(34px,5vw,56px);font-weight:900;color:#fff;letter-spacing:-1px}
.cat-hero p{color:#d6c9ec;max-width:560px;margin-top:12px;font-size:16px}
.cat-hero .tag{display:inline-block;margin-top:18px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  padding:7px 16px;border-radius:999px;font-size:13px;font-weight:600}

.toolbar{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  padding:18px 0;border-bottom:1px solid var(--line);margin-bottom:26px}
.toolbar .count{font-size:14px;color:var(--muted)}
.toolbar .count b{color:var(--ink)}
.sortwrap{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--muted)}
.sortwrap select{font-family:'Poppins';font-weight:600;font-size:14px;color:var(--ink);border:1.5px solid var(--line);
  border-radius:999px;padding:9px 16px;background:#fff;cursor:pointer;outline:none}
.sortwrap select:focus{border-color:var(--magenta)}
.catalog-layout{display:grid;grid-template-columns:228px 1fr;gap:34px;align-items:start}
.filters{position:sticky;top:calc(var(--header-h) + 20px)}
.filters h4{font-size:13px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin:0 0 14px}
.filter-group{border-bottom:1px solid var(--line);padding-bottom:20px;margin-bottom:20px}
.filter-opt{display:flex;align-items:center;gap:10px;padding:7px 0;cursor:pointer;font-size:14.5px;color:var(--text)}
.filter-opt input{width:17px;height:17px;accent-color:var(--magenta);cursor:pointer}
.filter-opt:hover{color:var(--magenta)}
.filter-opt .n{margin-left:auto;font-size:12.5px;color:var(--muted)}
.empty{text-align:center;padding:80px 20px;color:var(--muted)}
.empty h3{color:var(--ink);margin-bottom:8px}
@media (max-width:880px){
  .catalog-layout{grid-template-columns:1fr}
  .filters{position:static;display:none}
  .filters.mobile-open{display:block;margin-bottom:24px}
  .toolbar{position:static;box-shadow:none;margin-bottom:18px}
}

/* ---------- Product detail ---------- */
.pd-wrap{display:grid;grid-template-columns:1fr 1fr;gap:50px;padding:40px 0 10px;align-items:start}
.pd-media{position:sticky;top:calc(var(--header-h) + 20px);background:radial-gradient(circle at 50% 30%,var(--mist),#fff);
  border:1px solid var(--line);border-radius:var(--radius-lg);min-height:520px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.pd-media .badge{font-size:12px}
.pd-media svg.bottle{height:430px;filter:drop-shadow(0 30px 50px rgba(40,12,70,.28));animation:pdfloat 6s ease-in-out infinite}
@keyframes pdfloat{50%{transform:translateY(-16px)}}
.pd-media .media-frame{width:100%;height:100%;min-height:520px;border-radius:var(--radius-lg)}
.pd-media .media-frame img.pimg{width:100%;height:100%;min-height:520px;object-fit:cover}
.pd-media .ring{position:absolute;width:340px;height:340px;border-radius:50%;border:1px dashed var(--line);animation:spin 50s linear infinite;z-index:0;pointer-events:none}
.pd-info .crumbs{color:var(--muted);margin-bottom:16px;font-size:13px}
.pd-info .crumbs a:hover{color:var(--magenta)}
.pd-brand{font-family:'Poppins';font-weight:700;letter-spacing:.5px;text-transform:uppercase;font-size:13px;color:var(--violet);margin-bottom:8px}
.pd-info h1{font-size:clamp(28px,3.6vw,40px);font-weight:800;line-height:1.1}
.pd-rating{display:flex;align-items:center;gap:14px;margin:14px 0 18px}
.pd-rating .stars{font-size:15px;margin:0}
.pd-rating a{font-size:13.5px;color:var(--muted);text-decoration:underline}
.pd-award{display:inline-flex;align-items:center;gap:8px;margin:6px 0 2px;font-size:13.5px;font-weight:600;
  color:#7a4b00;background:linear-gradient(120deg,#fff4d6,#ffe9c2);border:1px solid #ffd98a;
  padding:7px 14px;border-radius:999px}
.pd-award svg{color:#d9920a}
.detail-panels{display:flex;flex-direction:column;gap:2px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin-bottom:26px}
.dpanel{display:flex;gap:14px;align-items:flex-start;padding:16px 18px;background:#fff;border-bottom:1px solid var(--line)}
.dpanel:last-child{border-bottom:none}
.dpanel .dp-ic{font-size:22px;line-height:1;flex-shrink:0;width:34px;text-align:center}
.dpanel h4{font-size:14px;margin-bottom:3px;color:var(--ink)}
.dpanel p{font-size:14px;color:#52465f;margin:0;line-height:1.55}
.pd-price{display:flex;align-items:baseline;gap:12px;margin:20px 0}
.pd-price .now{font-family:'Poppins';font-weight:800;font-size:38px;color:var(--ink)}
.pd-price .was{font-size:18px;color:var(--muted);text-decoration:line-through}
.pd-price .save{background:var(--grad-cool);color:#06303a;font-weight:800;font-size:12.5px;padding:5px 12px;border-radius:999px}
.pd-desc{color:#473a5e;font-size:15.5px;line-height:1.7;margin-bottom:24px}
.spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;margin-bottom:28px}
.spec-grid div{background:#fff;padding:14px 18px}
.spec-grid .k{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:3px}
.spec-grid .v{font-family:'Poppins';font-weight:600;color:var(--ink)}
.buybar{display:flex;gap:14px;align-items:center;margin-bottom:18px;flex-wrap:wrap}
.qty{display:flex;align-items:center;border:2px solid var(--line);border-radius:999px;overflow:hidden}
.qty button{width:46px;height:50px;font-size:22px;color:var(--ink);transition:.2s}
.qty button:hover{background:var(--mist);color:var(--magenta)}
.qty input{width:46px;text-align:center;border:none;outline:none;font-family:'Poppins';font-weight:700;font-size:16px;color:var(--ink)}
.buybar .btn-primary{flex:1;min-width:200px;height:54px;font-size:16px}
.pd-assure{display:flex;gap:22px;flex-wrap:wrap;padding-top:18px;border-top:1px solid var(--line)}
.pd-assure div{display:flex;gap:9px;align-items:center;font-size:13.5px;color:var(--muted)}
.pd-assure svg{color:var(--teal)}

/* ---------- Cart ---------- */
.page-head{padding:38px 0 8px}
.page-head h1{font-size:clamp(28px,4vw,42px);font-weight:800}
.page-head p{color:var(--muted);margin-top:6px}
.cart-layout{display:grid;grid-template-columns:1fr 360px;gap:34px;align-items:start;padding:24px 0 0}
.cart-items{display:flex;flex-direction:column;gap:14px}
.cart-row{display:grid;grid-template-columns:96px 1fr auto;gap:18px;align-items:center;background:#fff;
  border:1px solid var(--line);border-radius:var(--radius);padding:16px;transition:.25s}
.cart-row:hover{box-shadow:var(--shadow)}
.cart-row .thumb{width:96px;height:110px;background:radial-gradient(circle at 50% 30%,var(--mist),#fff);border-radius:12px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.cart-row .thumb svg.bottle{height:90px}
.cart-row .thumb .media-frame,.cart-row .thumb img.pimg{width:100%;height:100%;object-fit:cover;border-radius:12px}
.co-mini .thumb{overflow:hidden}
.co-mini .thumb .media-frame,.co-mini .thumb img.pimg{width:100%;height:100%;object-fit:cover;border-radius:10px}
.cart-row h3{font-family:'Poppins';font-size:16px;font-weight:600;color:var(--ink)}
.cart-row .sub{font-size:13px;color:var(--muted);margin:2px 0 10px}
.cart-row .rowfoot{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.cart-row .qty{border-width:1.5px}.cart-row .qty button{width:36px;height:38px;font-size:18px}.cart-row .qty input{width:36px;font-size:14px}
.cart-row .rmv{font-size:13px;color:var(--muted);text-decoration:underline}
.cart-row .rmv:hover{color:var(--coral)}
.cart-row .linep{font-family:'Poppins';font-weight:800;font-size:20px;color:var(--ink);text-align:right;min-width:80px}
.summary{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:26px;position:sticky;top:calc(var(--header-h) + 20px)}
.summary h3{font-size:20px;margin-bottom:18px}
.sumrow{display:flex;justify-content:space-between;padding:9px 0;font-size:14.5px;color:var(--text)}
.sumrow.total{border-top:1px solid var(--line);margin-top:10px;padding-top:16px;font-family:'Poppins';font-weight:800;font-size:22px;color:var(--ink)}
.summary .btn{margin-top:18px}
.promo-in{display:flex;gap:8px;margin:14px 0}
.promo-in input{flex:1;border:1.5px solid var(--line);border-radius:999px;padding:11px 16px;outline:none;font-size:14px}
.promo-in input:focus{border-color:var(--magenta)}
.empty-cart{text-align:center;padding:70px 20px}
.empty-cart .ic{width:90px;height:90px;margin:0 auto 20px;border-radius:50%;background:var(--mist);display:flex;align-items:center;justify-content:center;color:var(--violet)}

/* ---------- Checkout ---------- */
.co-layout{display:grid;grid-template-columns:1fr 380px;gap:40px;align-items:start;padding:24px 0 0}
.co-section{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;margin-bottom:22px}
.co-section h3{font-size:19px;margin-bottom:6px;display:flex;align-items:center;gap:10px}
.co-section h3 .step{width:28px;height:28px;border-radius:50%;background:var(--grad-brand);color:#fff;font-size:14px;display:flex;align-items:center;justify-content:center;font-family:'Poppins';font-weight:700}
.co-section .hint{font-size:13px;color:var(--muted);margin-bottom:18px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:6px}
.field input,.field select{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;font-size:15px;outline:none;font-family:inherit;transition:.2s}
.field input:focus,.field select:focus{border-color:var(--magenta);box-shadow:0 0 0 3px rgba(255,45,134,.1)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.pay-note{background:var(--mist);border-radius:12px;padding:14px 16px;font-size:13px;color:var(--muted);display:flex;gap:10px;align-items:flex-start}
.pay-note svg{color:var(--violet);flex-shrink:0;margin-top:1px}
.co-mini{display:flex;gap:12px;align-items:center;padding:10px 0;border-bottom:1px solid var(--line)}
.co-mini:last-of-type{border-bottom:none}
.co-mini .thumb{width:50px;height:58px;background:var(--mist);border-radius:10px;display:flex;align-items:center;justify-content:center}
.co-mini .thumb svg.bottle{height:48px}
.co-mini .nm{font-size:13.5px;font-weight:600;color:var(--ink);line-height:1.2}
.co-mini .q{font-size:12px;color:var(--muted)}
.co-mini .pp{margin-left:auto;font-family:'Poppins';font-weight:700;color:var(--ink)}
.success{text-align:center;padding:70px 20px;max-width:560px;margin:0 auto}
.success .check{width:104px;height:104px;margin:0 auto 24px;border-radius:50%;background:var(--grad-cool);display:flex;align-items:center;justify-content:center;animation:pop .5s cubic-bezier(.2,.9,.3,1.4)}
@keyframes pop{0%{transform:scale(0)}100%{transform:scale(1)}}
.success h1{font-size:34px;margin-bottom:10px}
.success p{color:var(--muted);margin-bottom:8px}
.success .order-no{font-family:'Poppins';font-weight:800;color:var(--magenta)}

/* ---------- Account ---------- */
.auth-wrap{max-width:430px;margin:50px auto 0;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:38px;box-shadow:var(--shadow)}
.auth-wrap h1{font-size:28px;text-align:center;margin-bottom:6px}
.auth-wrap .sub{text-align:center;color:var(--muted);margin-bottom:26px;font-size:14.5px}
.auth-tabs{display:flex;background:var(--mist);border-radius:999px;padding:5px;margin-bottom:26px}
.auth-tabs button{flex:1;padding:11px;border-radius:999px;font-family:'Poppins';font-weight:700;font-size:14px;color:var(--muted);transition:.25s}
.auth-tabs button.active{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}
.auth-divider{display:flex;align-items:center;gap:14px;color:var(--muted);font-size:13px;margin:22px 0}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:var(--line)}
.social-auth{display:flex;gap:12px}
.social-auth button{flex:1;border:1.5px solid var(--line);border-radius:12px;padding:12px;font-weight:600;font-size:14px;color:var(--ink);transition:.2s;display:flex;align-items:center;justify-content:center;gap:8px}
.social-auth button:hover{border-color:var(--magenta)}
.auth-foot{text-align:center;font-size:12.5px;color:var(--muted);margin-top:18px}

@media (max-width:880px){
  .pd-wrap{grid-template-columns:1fr;gap:24px}
  .pd-media{position:static;min-height:380px}
  .pd-media svg.bottle{height:320px}
  .cart-layout,.co-layout{grid-template-columns:1fr}
  .summary,.co-side{position:static}
}
@media (max-width:560px){
  .spec-grid,.field-row{grid-template-columns:1fr}
  .cart-row{grid-template-columns:72px 1fr}
  .cart-row .linep{grid-column:2;text-align:left}
  .cart-row .thumb{width:72px;height:84px}
}

/* ---------- Content / info / legal pages ---------- */
.content-wrap{max-width:880px;margin:0 auto;padding:48px 0 10px}
.content-wide{max-width:var(--maxw)}
.prose h2{font-size:clamp(22px,2.6vw,30px);font-weight:800;margin:34px 0 12px}
.prose h3{font-size:19px;font-weight:700;margin:24px 0 8px}
.prose p{color:#473a5e;font-size:15.5px;line-height:1.75;margin-bottom:14px}
.prose ul{margin:0 0 16px;padding-left:0;list-style:none;display:grid;gap:10px}
.prose ul li{position:relative;padding-left:30px;color:#473a5e;font-size:15.5px;line-height:1.6}
.prose ul li::before{content:"";position:absolute;left:6px;top:9px;width:8px;height:8px;border-radius:50%;background:var(--grad-brand)}
.prose a{color:var(--magenta);font-weight:600;text-decoration:underline}
.prose .lead{font-size:18px;color:#352a48}
.prose hr{border:none;border-top:1px solid var(--line);margin:34px 0}
.prose .muted-note{font-size:13.5px;color:var(--muted);background:var(--mist);border-radius:12px;padding:14px 18px;margin-top:10px}

.info-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:30px 0}
.info-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;transition:.3s}
.info-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.info-card .ic{width:50px;height:50px;border-radius:14px;background:var(--grad-brand);color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.info-card h3{font-size:18px;margin-bottom:7px}
.info-card p{font-size:14px;color:var(--muted);margin:0;line-height:1.6}

/* FAQ accordion */
.faq{display:flex;flex-direction:column;gap:12px;margin-top:8px}
.faq-item{border:1px solid var(--line);border-radius:var(--radius);background:#fff;overflow:hidden;transition:.25s}
.faq-item:hover{border-color:var(--mist-2)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 22px;
  font-family:'Poppins';font-weight:600;font-size:16px;color:var(--ink);text-align:left;cursor:pointer;background:none}
.faq-q .chev{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--mist);display:flex;align-items:center;justify-content:center;transition:.3s;color:var(--violet)}
.faq-item.open .faq-q .chev{transform:rotate(45deg);background:var(--grad-brand);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a .inner{padding:0 22px 20px;color:#473a5e;font-size:15px;line-height:1.7}
.faq-item.open .faq-a{max-height:340px}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;padding:44px 0 0}
.contact-info .ci-item{display:flex;gap:14px;align-items:flex-start;margin-bottom:22px}
.contact-info .ci-item .ic{width:46px;height:46px;border-radius:13px;background:var(--mist);color:var(--magenta);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-info h4{font-size:15px;margin-bottom:2px}.contact-info p{font-size:14.5px;color:var(--muted);margin:0;line-height:1.6}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow)}
.contact-card h3{font-size:21px;margin-bottom:6px}.contact-card .sub{color:var(--muted);font-size:14.5px;margin-bottom:22px}

/* Careers roles */
.roles{display:flex;flex-direction:column;gap:14px;margin-top:10px}
.role{display:flex;align-items:center;justify-content:space-between;gap:18px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:20px 24px;transition:.25s;flex-wrap:wrap}
.role:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.role h3{font-size:17px;margin-bottom:3px}
.role .meta{font-size:13px;color:var(--muted)}
.role .tag{font-size:12px;font-weight:700;color:var(--violet);background:var(--mist);padding:5px 12px;border-radius:999px}

@media (max-width:760px){
  .info-cards{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:28px}
}

/* ---------- Mobile nav drawer ---------- */
.mobile-nav{display:none;position:fixed;inset:0;z-index:200;background:rgba(20,8,33,.6);backdrop-filter:blur(4px)}
.mobile-nav.open{display:block}
.mobile-nav .panel{position:absolute;top:0;right:0;width:min(82vw,340px);height:100%;background:#fff;
  padding:24px;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow-lg);overflow-y:auto}
.mobile-nav .panel a{font-family:'Poppins';font-weight:600;font-size:17px;padding:13px 10px;border-radius:12px;color:var(--ink)}
.mobile-nav .panel a:hover{background:var(--mist);color:var(--magenta)}
.mobile-nav .panel .close{align-self:flex-end;font-size:26px;color:var(--muted);padding:4px 10px}

/* ---------------- Corporate / distribution header ---------------- */
.corp-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.corp-bar{display:flex;align-items:center;gap:20px;height:76px}
.corp-logo{color:var(--ink);flex-shrink:0}.corp-logo svg{height:46px;width:auto}
.corp-nav{display:flex;gap:4px;margin-left:10px}
.corp-nav a{font-family:'Poppins';font-weight:600;font-size:14.5px;color:var(--ink);padding:9px 15px;border-radius:10px;transition:.2s}
.corp-nav a:hover,.corp-nav a.active{color:var(--magenta);background:var(--mist)}
.corp-right{margin-left:auto;display:flex;align-items:center;gap:16px;flex-shrink:0}
.corp-right .shoplink{font-family:'Poppins';font-weight:600;font-size:14px;color:var(--ink);display:inline-flex;align-items:center;gap:6px}
.corp-right .shoplink:hover{color:var(--magenta)}
@media(max-width:920px){.corp-nav{display:none}.corp-right .shoplink span{display:none}}

/* ---------------- Shared corporate content primitives ---------------- */
.corp-hero{position:relative;overflow:hidden;background:var(--grad-night);color:#fff;padding:84px 0 70px;isolation:isolate}
.corp-hero .blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.55;z-index:1}
.corp-hero .b1{width:460px;height:460px;background:#8B2FE6;top:-150px;left:-80px}
.corp-hero .b2{width:400px;height:400px;background:#00B4D8;bottom:-180px;right:4%}
.corp-hero .grid-ov{position:absolute;inset:0;z-index:1;opacity:.2;background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);background-size:46px 46px;mask-image:radial-gradient(circle at 75% 45%,#000,transparent 75%)}
.corp-hero .container{position:relative;z-index:3;max-width:880px}
.corp-hero .eyebrow{color:var(--teal)}.corp-hero .eyebrow::before{background:var(--grad-cool)}
.corp-hero h1{font-size:clamp(36px,5.4vw,62px);font-weight:900;color:#fff;letter-spacing:-1.5px;line-height:1.04}
.corp-hero h1 .g{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent}
.corp-hero p.lead{font-size:18.5px;color:#d6c9ec;max-width:640px;margin:20px 0 32px}
.corp-cta{display:flex;gap:14px;flex-wrap:wrap;position:relative;z-index:3}
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:54px;position:relative;z-index:3}
.statband .n{font-family:'Poppins';font-weight:800;font-size:clamp(28px,3.6vw,40px);background:var(--grad-cool);-webkit-background-clip:text;background-clip:text;color:transparent}
.statband .l{font-size:13.5px;color:#b6a9cc;margin-top:5px}
.num-band{position:relative;overflow:hidden;border-radius:var(--radius-lg);background:var(--ink);color:#fff;padding:48px 44px}
.num-band::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 15% 0%,rgba(139,47,230,.4),transparent 60%),radial-gradient(600px 300px at 85% 100%,rgba(255,45,134,.3),transparent 60%)}
.num-grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:26px;text-align:center}
.num-grid .n{font-family:'Poppins';font-weight:900;font-size:clamp(30px,4vw,46px);background:var(--grad-cool);-webkit-background-clip:text;background-clip:text;color:transparent}
.num-grid .l{font-size:13.5px;color:#cabfe0;margin-top:6px}
.tile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tile{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;transition:.25s}
.tile:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.tile .ic{width:48px;height:48px;border-radius:13px;background:var(--mist);display:flex;align-items:center;justify-content:center;color:var(--violet);flex-shrink:0}
.tile h3{font-size:16px;margin-bottom:3px}.tile p{font-size:13.5px;color:var(--muted);margin:0}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.step-c{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.step-c .num{font-family:'Poppins';font-weight:900;font-size:34px;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.step-c h3{font-size:16px;margin:10px 0 6px}.step-c p{font-size:13.5px;color:var(--muted);margin:0}
.split-cta{display:grid;grid-template-columns:1.1fr 1fr;background:var(--ink);color:#fff;border-radius:var(--radius-lg);overflow:hidden;position:relative}
.split-cta .pad{padding:50px 46px}
.split-cta h2{color:#fff;font-size:clamp(24px,3vw,34px)}
.split-cta p{color:#cabfe0;margin:14px 0 24px;max-width:460px}
.split-cta .visual{background:var(--grad-brand);min-height:260px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;color:#fff}
.art-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.art-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;transition:.25s;display:flex;flex-direction:column}
.art-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.art-card .thumb{height:158px;background:var(--grad-brand);position:relative;display:flex;align-items:flex-end;padding:14px}
.art-card .thumb .tag{background:rgba(0,0,0,.35);color:#fff;backdrop-filter:blur(4px)}
.art-card .body{padding:18px 20px 22px;display:flex;flex-direction:column;gap:8px;flex:1}
.art-card .tag{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--violet);padding:4px 10px;border-radius:999px;align-self:flex-start}
.art-card h3{font-size:17px;line-height:1.3}
.art-card p{font-size:13.5px;color:var(--muted);margin:0;flex:1}
.art-card .meta{font-size:12px;color:var(--muted);margin-top:6px}
.topic-row{display:flex;flex-wrap:wrap;gap:10px}
.topic-chip{font-family:'Poppins';font-weight:600;font-size:13.5px;color:var(--ink);background:#fff;border:1px solid var(--line);padding:9px 16px;border-radius:999px;transition:.2s}
.topic-chip:hover,.topic-chip.active{background:var(--grad-brand);color:#fff;border-color:transparent}
@media(max-width:880px){.statband{grid-template-columns:1fr 1fr;gap:20px}.num-grid{grid-template-columns:1fr 1fr;gap:22px}.tile-grid{grid-template-columns:1fr}.steps{grid-template-columns:1fr 1fr}.art-grid{grid-template-columns:1fr}.split-cta{grid-template-columns:1fr}.info-cards{grid-template-columns:1fr!important}}
