/* ================================================
   Vetisilk Aroma — Front Store
   Theme: Cream · Tea Gold · Soft Lavender (Sales-friendly)
   ================================================ */
:root{
  --cream-50:#fffdf7;
  --cream-100:#fdf8ee;
  --cream-200:#faf3e1;
  --cream-300:#f5e9c5;
  --warm-100:#fdf3e6;
  --warm-200:#f4e2c8;

  --gold-700:#a8852b;
  --gold-600:#b8923a;
  --gold-500:#d4af37;
  --gold-400:#e8c970;
  --gold-200:#f5e9c5;

  --lav-50:#f8f3fc;
  --lav-100:#efe5f6;
  --lav-200:#dcc7eb;
  --lav-300:#c9a9dc;
  --lav-400:#a989c9;
  --lav-500:#8b6cad;
  --lav-600:#6f4f93;
  --lav-700:#553a73;
  --lav-800:#3d2855;

  --purple-700:#3d1f5e; /* legacy alias */
  --purple-800:#2d1454;
  --purple-600:#5b2c8c;
  --purple-500:#7a3fb8;
  --purple-400:#a572d8;
  --purple-200:#dcc7eb;
  --purple-900:#1a0b2e;

  --ink:#2a1f3d;
  --muted:#6b5b87;
  --shadow-sm: 0 4px 14px rgba(85,58,115,.08);
  --shadow-md: 0 10px 30px rgba(85,58,115,.10);
  --shadow-lg: 0 18px 50px rgba(85,58,115,.14);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Prompt', system-ui, sans-serif;
  font-weight:400;
  font-size:16px;
  line-height:1.7;
  color:var(--ink);
  background:var(--cream-100);
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Prompt',sans-serif;font-weight:600;letter-spacing:.2px;line-height:1.3}
.serif{font-family:'Cormorant Garamond', serif;font-weight:500}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ============ Floating particles (subtle on light bg) ============ */
.bg-particles{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.bg-particles span{
  position:absolute;display:block;width:8px;height:8px;border-radius:50%;
  background:radial-gradient(circle,rgba(212,175,55,.5) 0%, transparent 70%);
  opacity:.55;animation: drift 22s linear infinite;
}
.bg-particles span:nth-child(1){left:5%;top:15%;animation-duration:24s}
.bg-particles span:nth-child(2){left:15%;top:80%;animation-delay:-3s;animation-duration:28s;background:radial-gradient(circle,rgba(169,137,201,.5),transparent 70%)}
.bg-particles span:nth-child(3){left:30%;top:30%;width:12px;height:12px;animation-delay:-7s}
.bg-particles span:nth-child(4){left:45%;top:60%;animation-delay:-2s;animation-duration:30s;background:radial-gradient(circle,rgba(169,137,201,.45),transparent 70%)}
.bg-particles span:nth-child(5){left:55%;top:10%;width:6px;height:6px;animation-delay:-10s}
.bg-particles span:nth-child(6){left:70%;top:50%;width:10px;height:10px;animation-delay:-5s}
.bg-particles span:nth-child(7){left:80%;top:75%;animation-delay:-12s;animation-duration:26s;background:radial-gradient(circle,rgba(169,137,201,.45),transparent 70%)}
.bg-particles span:nth-child(8){left:90%;top:25%;animation-delay:-8s}
.bg-particles span:nth-child(9){left:25%;top:50%;animation-delay:-15s}
.bg-particles span:nth-child(10){left:65%;top:90%;animation-delay:-1s}
@keyframes drift{
  0%{transform:translate(0,0) scale(1);opacity:0}
  10%{opacity:.6}
  50%{transform:translate(40px,-90px) scale(1.3);opacity:.8}
  90%{opacity:.3}
  100%{transform:translate(-30px,-180px) scale(.8);opacity:0}
}

/* ============ Falling Leaves ============ */
.leaves{
  position:fixed;top:0;left:0;right:0;bottom:0;
  pointer-events:none;z-index:55;overflow:hidden;
}
.leaf{
  position:absolute;top:-80px;width:36px;height:36px;
  will-change:transform,opacity;opacity:.9;
  animation:leaf-fall 22s linear infinite, leaf-sway 6s ease-in-out infinite;
}
.leaf svg{width:100%;height:100%;display:block;
  filter:drop-shadow(0 4px 8px rgba(85,58,115,.15))}
@keyframes leaf-fall{
  0%  {transform:translateY(-80px) rotate(0deg);opacity:0}
  6%  {opacity:.9}
  94% {opacity:.9}
  100%{transform:translateY(110vh) rotate(720deg);opacity:0}
}
@keyframes leaf-sway{
  0%,100%{margin-left:0}
  25%{margin-left:60px}
  75%{margin-left:-60px}
}

/* ============ Sound Toggle Button ============ */
.sound-toggle{
  position:fixed;right:20px;bottom:20px;z-index:60;
  width:54px;height:54px;border-radius:50%;border:0;cursor:pointer;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-700));
  color:#fff;display:grid;place-items:center;font-size:20px;
  box-shadow:0 10px 28px rgba(168,133,43,.4);
  transition:.3s cubic-bezier(.2,.8,.2,1);
  font-family:inherit;
}
.sound-toggle:hover{transform:translateY(-3px) scale(1.08);box-shadow:0 14px 36px rgba(168,133,43,.55)}
.sound-toggle::before{
  content:"";position:absolute;inset:-4px;border-radius:50%;
  border:2px solid var(--gold-500);opacity:0;
  animation:none;
}
.sound-toggle.playing::before{
  opacity:.6;animation:sound-ring 1.6s ease-out infinite;
}
@keyframes sound-ring{
  0%{transform:scale(.95);opacity:.7}
  100%{transform:scale(1.6);opacity:0}
}
.sound-toggle .lbl{
  position:absolute;right:64px;top:50%;transform:translateY(-50%) translateX(8px);
  background:var(--lav-800);color:#fff;padding:6px 14px;border-radius:999px;
  font-size:12px;white-space:nowrap;opacity:0;pointer-events:none;
  transition:.3s;font-weight:500;
}
.sound-toggle:hover .lbl{transform:translateY(-50%);opacity:1}
@media(max-width:540px){.sound-toggle{width:46px;height:46px;font-size:17px;right:14px;bottom:14px}.sound-toggle .lbl{display:none}}

/* ============ Top Trust Bar ============ */
.trust-bar{
  background:linear-gradient(90deg,var(--lav-700),var(--lav-600),var(--lav-700));
  color:#fff;font-size:13px;text-align:center;padding:8px 6vw;
  letter-spacing:.3px;
}
.trust-bar strong{color:var(--gold-400);font-weight:600}
.trust-bar .sep{margin:0 14px;opacity:.4}
@media(max-width:640px){.trust-bar .sep{display:none}.trust-bar span{display:block;padding:2px 0}}

/* ============ Header ============ */
.site-header{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 6vw;
  background:rgba(255,253,247,.92);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(168,133,43,.18);
  color:var(--ink);
}
.brand{display:flex;align-items:center;gap:14px}
.brand-logo{
  height:34px;width:auto;display:block;
  filter:drop-shadow(0 2px 6px rgba(85,58,115,.15));
  transition:.3s;
}
.brand:hover .brand-logo{transform:scale(1.05) rotate(-3deg)}
.brand-icon{
  font-size:28px;color:var(--gold-600);
  animation:rot 8s linear infinite;display:inline-block;
}
@media(max-width:780px){
  .brand-logo{height:28px}
}
@keyframes rot{to{transform:rotate(360deg)}}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-size:22px;font-weight:700;
  background:linear-gradient(120deg,var(--gold-700),var(--gold-500),var(--gold-700));
  background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:shine 4s linear infinite;
}
@keyframes shine{to{background-position:200% 0}}
.brand-tagline{font-size:11px;color:var(--lav-600);letter-spacing:1.2px;text-transform:uppercase;font-weight:500}

.main-nav{display:flex;gap:28px}
.main-nav a{
  color:var(--lav-700);font-size:15px;font-weight:500;position:relative;padding:6px 0;transition:.25s
}
.main-nav a:hover, .main-nav a.active{color:var(--gold-700)}
.main-nav a::after{
  content:"";position:absolute;left:50%;bottom:0;height:2px;width:0;
  background:linear-gradient(90deg,var(--gold-500),var(--gold-700));
  transition:.3s;transform:translateX(-50%)
}
.main-nav a:hover::after, .main-nav a.active::after{width:100%}

.cart-btn{
  position:relative;display:grid;place-items:center;width:46px;height:46px;
  border-radius:50%;background:linear-gradient(135deg,var(--gold-500),var(--gold-600));
  border:0;color:#fff;transition:.3s;box-shadow:0 6px 18px rgba(168,133,43,.3);
}
.cart-btn:hover{transform:translateY(-2px) rotate(-6deg);box-shadow:0 10px 26px rgba(168,133,43,.5)}
.cart-count{
  position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;border-radius:10px;
  background:var(--lav-700);color:#fff;font-size:11px;font-weight:700;
  display:grid;place-items:center;padding:0 5px;border:2px solid #fff;
}

/* ============ Hero (light & inviting) ============ */
.hero{
  position:relative;min-height:88vh;display:grid;place-items:center;
  background:
    radial-gradient(1200px 600px at 15% 10%, rgba(220,199,235,.6), transparent 60%),
    radial-gradient(900px 700px at 85% 95%, rgba(245,233,197,.7), transparent 55%),
    radial-gradient(600px 400px at 50% 50%, rgba(255,255,255,.5), transparent 60%),
    linear-gradient(180deg,var(--cream-100),var(--warm-100));
  overflow:hidden;color:var(--ink);text-align:center;padding:60px 6vw 80px;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(2px 2px at 12% 20%, rgba(168,133,43,.18), transparent),
    radial-gradient(1px 1px at 30% 70%, rgba(139,108,173,.15), transparent),
    radial-gradient(2px 2px at 60% 30%, rgba(168,133,43,.16), transparent),
    radial-gradient(1px 1px at 80% 80%, rgba(139,108,173,.18), transparent),
    radial-gradient(2px 2px at 90% 10%, rgba(168,133,43,.18), transparent);
  background-size:300px 300px;opacity:.7;animation:starfield 80s linear infinite;
  pointer-events:none;
}
@keyframes starfield{to{background-position: 600px 600px}}

.hero-content{position:relative;z-index:2;max-width:980px;animation:rise 1s ease-out both}
@keyframes rise{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}

.hero-eyebrow{
  display:inline-block;padding:7px 20px;border-radius:999px;
  background:rgba(255,255,255,.7);backdrop-filter:blur(10px);
  border:1px solid rgba(168,133,43,.35);color:var(--gold-700);
  letter-spacing:3px;font-size:12px;text-transform:uppercase;margin-bottom:22px;
  font-weight:600;box-shadow:0 4px 14px rgba(168,133,43,.12);
}
.hero h1{
  font-family:'Cormorant Garamond',serif;font-size:clamp(44px, 6.5vw, 86px);
  font-weight:600;line-height:1.05;margin:0 0 14px;color:var(--lav-800);
}
.hero h1 .grad{
  background:linear-gradient(120deg, var(--gold-700), var(--gold-500) 40%, var(--gold-700) 60%, var(--gold-600));
  background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:shine 5s linear infinite;font-style:italic;
}
.hero p{font-size:18px;color:var(--muted);max-width:620px;margin:0 auto 30px;line-height:1.75}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:36px}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 32px;border-radius:999px;font-weight:600;font-size:15px;
  cursor:pointer;border:0;transition:.3s;text-align:center;letter-spacing:.3px;
  font-family:inherit;
}
.btn-gold{
  background:linear-gradient(135deg,var(--gold-500),var(--gold-700));
  color:#fff;box-shadow:0 10px 28px rgba(168,133,43,.38);
}
.btn-gold:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 14px 38px rgba(168,133,43,.55)}
.btn-ghost{background:rgba(255,255,255,.7);color:var(--lav-700);border:1.5px solid var(--lav-300)}
.btn-ghost:hover{background:#fff;border-color:var(--gold-500);color:var(--gold-700)}
.btn-purple{background:linear-gradient(135deg,var(--lav-600),var(--lav-700));color:#fff}
.btn-purple:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}

/* ============ Hero trust badges ============ */
.hero-badges{display:flex;justify-content:center;gap:30px;flex-wrap:wrap;margin-top:6px}
.hero-badge{display:flex;align-items:center;gap:8px;color:var(--lav-700);font-size:13px;font-weight:500}
.hero-badge .ic{
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-600));
  display:grid;place-items:center;color:#fff;font-size:16px;
  box-shadow:0 4px 12px rgba(168,133,43,.3);
}
@media(max-width:640px){.hero-badges{gap:14px}.hero-badge{font-size:12px}}

.hero-bottle{
  position:absolute;width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle, rgba(212,175,55,.35), transparent 60%);
  filter:blur(50px);animation:float 6s ease-in-out infinite;
}
.hero-bottle.b1{top:18%;left:8%}
.hero-bottle.b2{bottom:12%;right:8%;animation-delay:-2s;
  background:radial-gradient(circle, rgba(169,137,201,.4), transparent 60%);}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-30px)}}

.scroll-cue{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);color:var(--gold-700);font-size:11px;letter-spacing:3px;font-weight:600;animation:bounce 2s infinite;z-index:2}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ============ Sections ============ */
section{position:relative;z-index:1}
.section{padding:90px 6vw;background:var(--cream-50)}
.section.alt{background:var(--cream-100)}
.section-head{text-align:center;max-width:760px;margin:0 auto 56px}
.section-eyebrow{color:var(--gold-700);letter-spacing:4px;font-size:12px;text-transform:uppercase;font-weight:600}
.section-title{
  font-family:'Cormorant Garamond',serif;font-size:clamp(34px, 4.2vw, 52px);
  color:var(--lav-800);font-weight:600;margin:8px 0 14px;
}
.section-title em{color:var(--gold-700);font-style:italic}
.section-sub{color:var(--muted);font-size:17px}

/* ============ Category cards ============ */
.cats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;max-width:1200px;margin:0 auto}
.cat-card{
  position:relative;padding:36px 28px;border-radius:24px;text-align:center;cursor:pointer;
  background:linear-gradient(160deg,#fff,var(--cream-200));
  border:1px solid rgba(168,133,43,.18);transition:.4s cubic-bezier(.2,.8,.2,1);
  overflow:hidden;
}
.cat-card::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, var(--lav-600), var(--lav-700));
  opacity:0;transition:.4s;
}
.cat-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.cat-card:hover::before{opacity:1}
.cat-card > *{position:relative;z-index:1;transition:.3s}
.cat-card:hover > *{color:#fff}
.cat-icon{font-size:54px;margin-bottom:14px;display:block;transition:.4s}
.cat-card:hover .cat-icon{transform:scale(1.15) rotate(-6deg)}
.cat-card h3{color:var(--lav-800);font-size:20px;margin-bottom:6px}
.cat-card:hover h3{color:var(--gold-400)}
.cat-card p{color:var(--muted);font-size:14px;line-height:1.5}

.cat-count{
  display:inline-block;margin-top:12px;padding:3px 12px;border-radius:999px;
  background:var(--cream-200);color:var(--gold-700);font-size:12px;font-weight:600;
  transition:.3s;
}
.cat-card:hover .cat-count{background:rgba(255,255,255,.2);color:var(--gold-300)}

.cat-card.cat-empty{
  cursor:not-allowed;opacity:.7;filter:grayscale(.3);
  background:linear-gradient(160deg,#f8f4f0,#e9e1d4);
  border-color:rgba(168,133,43,.12);
}
.cat-card.cat-empty:hover{transform:none;box-shadow:none}
.cat-card.cat-empty:hover::before{opacity:0}
.cat-card.cat-empty:hover > *{color:initial}
.cat-card.cat-empty:hover h3{color:var(--lav-800)}
.cat-card.cat-empty .cat-icon{filter:grayscale(.5);opacity:.7}
.cat-coming{
  display:inline-block;margin-top:12px;padding:5px 14px;border-radius:999px;
  background:#fef3c7;color:#92400e;font-size:12px;font-weight:600;letter-spacing:.3px;
}

/* ============ Product grid ============ */
.products{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:28px;max-width:1280px;margin:0 auto}
.product-card{
  background:#fff;border-radius:20px;overflow:hidden;position:relative;
  border:1px solid rgba(168,133,43,.15);transition:.4s cubic-bezier(.2,.8,.2,1);
  display:flex;flex-direction:column;box-shadow:var(--shadow-sm);
}
.product-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--gold-500)}
.product-img{
  aspect-ratio:1;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--lav-50),var(--cream-200));
  position:relative;overflow:hidden;
}
.product-img svg, .product-img img{
  width:65%;height:65%;object-fit:contain;
  transition:.6s cubic-bezier(.2,.8,.2,1);
  filter:drop-shadow(0 12px 25px rgba(85,58,115,.14));
}
.product-card:hover .product-img svg, .product-card:hover .product-img img{transform:scale(1.1) rotate(-3deg)}
.product-img::before{
  content:"";position:absolute;inset:-50%;
  background:radial-gradient(circle, rgba(212,175,55,.25), transparent 50%);
  opacity:0;transition:.5s;animation:rotateAura 8s linear infinite;
}
.product-card:hover .product-img::before{opacity:1}
@keyframes rotateAura{to{transform:rotate(360deg)}}

.badge{position:absolute;top:14px;left:14px;z-index:2;padding:5px 12px;border-radius:999px;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-600));color:#fff;
  font-size:11px;font-weight:700;letter-spacing:.5px;box-shadow:0 4px 10px rgba(168,133,43,.3)}
.badge.hot{background:linear-gradient(135deg,#e85a7c,#c44569);color:#fff}

.product-body{padding:18px 20px 22px;flex:1;display:flex;flex-direction:column}
.product-cat{font-size:11px;letter-spacing:1.5px;color:var(--lav-500);text-transform:uppercase;font-weight:600}
.product-name{font-size:17px;font-weight:600;color:var(--lav-800);margin:6px 0 4px;line-height:1.3}
.product-desc{font-size:13px;color:var(--muted);flex:1;margin-bottom:14px}
.product-foot{display:flex;justify-content:space-between;align-items:center;gap:10px}
.price{font-size:20px;font-weight:700;color:var(--gold-700)}
.price small{font-size:12px;color:#aaa;font-weight:400}
.add-btn{
  border:0;background:linear-gradient(135deg,var(--lav-600),var(--lav-700));color:#fff;
  width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:20px;display:grid;place-items:center;
  transition:.3s;
}
.add-btn:hover{background:linear-gradient(135deg,var(--gold-500),var(--gold-700));transform:rotate(90deg) scale(1.1)}
.add-btn:disabled{opacity:.4;cursor:not-allowed}

/* ============ Reviews / Testimonials ============ */
.reviews-band{padding:90px 6vw;background:linear-gradient(180deg,var(--cream-100),var(--lav-50))}
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:1100px;margin:0 auto}
.review-card{
  background:#fff;padding:30px 26px;border-radius:20px;position:relative;
  border:1px solid rgba(168,133,43,.15);box-shadow:var(--shadow-sm);
  transition:.3s;
}
.review-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.review-card .quote{position:absolute;top:14px;right:20px;font-family:'Cormorant Garamond',serif;font-size:64px;color:var(--gold-200);line-height:.7}
.review-stars{color:var(--gold-500);font-size:16px;letter-spacing:2px;margin-bottom:14px}
.review-text{color:var(--ink);font-size:15px;line-height:1.7;margin-bottom:18px}
.review-meta{display:flex;align-items:center;gap:12px;border-top:1px solid var(--cream-200);padding-top:14px}
.review-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--lav-400),var(--lav-600));color:#fff;display:grid;place-items:center;font-weight:600}
.review-name{font-weight:600;color:var(--lav-800);font-size:14px}
.review-detail{font-size:12px;color:var(--muted)}

/* ============ Farm to Bottle ============ */
.farm-band{
  padding:90px 6vw;
  background:
    radial-gradient(800px 400px at 80% 50%, rgba(220,199,235,.5), transparent 60%),
    linear-gradient(135deg,#fff,var(--cream-100));
  border-top:1px solid var(--cream-300);
}
.farm-wrap{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.farm-text .section-title{margin-top:8px}
.farm-text p{font-size:17px;line-height:1.85}
.farm-stats{display:flex;gap:32px;margin-top:30px;padding-top:24px;border-top:1px solid var(--cream-300)}
.farm-stats .num{font-family:'Cormorant Garamond',serif;font-size:42px;font-weight:600;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-700));-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.farm-stats .lbl{font-size:13px;color:var(--muted);margin-top:4px;letter-spacing:.5px}
.farm-visual{position:relative}
.farm-visual svg{width:100%;height:auto;border-radius:50%;box-shadow:var(--shadow-lg);
  animation:floatSlow 6s ease-in-out infinite}
@keyframes floatSlow{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@media(max-width:880px){
  .farm-wrap{grid-template-columns:1fr;gap:36px}
  .farm-visual{max-width:380px;margin:0 auto}
  .farm-stats{justify-content:space-around;gap:16px}
  .farm-stats .num{font-size:32px}
}

/* ============ Review Submission Modal ============ */
.rv-modal{
  position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;
  padding:20px;
}
.rv-modal.show{display:flex}
.rv-backdrop{
  position:absolute;inset:0;background:rgba(45,20,84,.55);backdrop-filter:blur(6px);
  animation:fadeIn .25s ease-out;
}
.rv-card{
  position:relative;max-width:560px;width:100%;max-height:92vh;overflow-y:auto;
  background:#fff;border-radius:24px;padding:36px 32px 28px;
  border:1px solid var(--gold-500);box-shadow:0 30px 80px rgba(0,0,0,.3);
  animation:rvPop .35s cubic-bezier(.2,.8,.2,1.2);
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes rvPop{from{opacity:0;transform:scale(.92) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}
.rv-close{
  position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;
  border:0;background:var(--cream-200);color:var(--lav-700);cursor:pointer;font-size:24px;line-height:1;
  display:grid;place-items:center;transition:.2s;font-family:inherit;
}
.rv-close:hover{background:var(--lav-700);color:#fff;transform:rotate(90deg)}
.rv-head{text-align:center;margin-bottom:24px}
.rv-head h3{font-family:'Cormorant Garamond',serif;font-size:32px;color:var(--lav-800);margin:6px 0 8px}
.rv-head p{color:var(--muted);font-size:14px;line-height:1.6}
.rv-form .f-grp,.rv-form .f-row{margin-bottom:14px}

.rv-stars{display:flex;gap:4px;font-size:36px;color:#ddd;cursor:pointer;user-select:none}
.rv-stars span{transition:.15s;line-height:1}
.rv-stars span:hover{transform:scale(1.15)}
.rv-stars span.on{color:var(--gold-500);text-shadow:0 4px 14px rgba(212,175,55,.4)}

.rv-foot{display:flex;gap:10px;margin-top:8px}
.rv-msg{margin-top:14px;text-align:center;font-size:14px;font-weight:500;min-height:20px}
.rv-msg.ok{color:#15803d}
.rv-msg.err{color:#c44569}

@media(max-width:540px){
  .rv-card{padding:28px 22px 22px}
  .rv-head h3{font-size:26px}
  .rv-stars{font-size:30px}
}

/* ============ Lot Info Box (in product page) ============ */
.lot-info-box{
  margin-top:24px;padding:18px 20px;border-radius:16px;
  background:linear-gradient(135deg,var(--cream-100),#fff);
  border:1px solid var(--gold-500);
  box-shadow:0 6px 18px rgba(168,133,43,.12);
}
.lot-row{display:flex;justify-content:space-between;padding:5px 0;font-size:14px;color:var(--ink);border-bottom:1px dashed rgba(168,133,43,.2)}
.lot-row:last-of-type{border-bottom:0}
.lot-row .lk{color:var(--muted);font-size:13px}
.lot-row strong{color:var(--gold-700);letter-spacing:.5px}
.lot-link{display:inline-block;margin-top:10px;color:var(--lav-700);font-size:13px;font-weight:600;border-bottom:1px solid var(--gold-500);padding-bottom:1px}
.lot-link:hover{color:var(--gold-700)}

/* ============ Latest Batches band on home ============ */
.batch-band{background:linear-gradient(180deg,var(--cream-50),var(--cream-100))}
.batch-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;max-width:1100px;margin:0 auto}
.batch-card{
  background:#fff;padding:24px 22px;border-radius:18px;text-align:center;
  border:1px solid rgba(168,133,43,.18);transition:.35s cubic-bezier(.2,.8,.2,1);
  display:block;color:inherit;position:relative;overflow:hidden;
}
.batch-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--gold-500),var(--lav-500));
}
.batch-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--gold-500)}
.batch-icon{font-size:36px;margin-bottom:8px}
.batch-lot{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-size:18px;
  color:var(--gold-700);letter-spacing:1px;font-weight:600;
  background:var(--cream-100);display:inline-block;padding:3px 12px;border-radius:8px;margin-bottom:8px;
}
.batch-name{font-size:17px;font-weight:600;color:var(--lav-800);margin-bottom:8px}
.batch-meta{display:flex;flex-direction:column;gap:3px;color:var(--muted);font-size:12px;margin-bottom:12px}
.batch-go{color:var(--lav-600);font-size:12px;font-weight:600;letter-spacing:.5px}
.batch-card:hover .batch-go{color:var(--gold-700)}

/* ============ Lot Detail Page (public) ============ */
.lot-detail{max-width:820px;margin:60px auto;padding:0 6vw}
.lot-card{
  background:linear-gradient(160deg,#fff,var(--cream-100));
  border-radius:24px;padding:50px 40px;text-align:center;
  border:1px solid var(--gold-500);box-shadow:var(--shadow-lg);
}
.lot-card .lot-icon{font-size:64px;margin-bottom:14px}
.lot-card h2{font-family:'Cormorant Garamond',serif;font-size:42px;color:var(--lav-800);margin-bottom:8px}
.lot-card .lot-desc{color:var(--muted);font-size:16px;max-width:480px;margin:0 auto 30px}
.lot-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;
  text-align:left;background:#fff;padding:24px;border-radius:18px;
  border:1px solid rgba(168,133,43,.15);margin-top:30px;
}
.lot-grid .lk{font-size:11px;color:var(--muted);letter-spacing:1.2px;text-transform:uppercase;margin-bottom:4px}
.lot-grid .lv{color:var(--ink);font-size:15px;font-weight:500}
.lot-grid .lv strong{color:var(--gold-700);font-family:'Cormorant Garamond',serif;font-style:italic;font-size:18px;letter-spacing:.5px}
.lot-notes{margin-top:24px;padding:14px 18px;background:var(--cream-100);border-left:3px solid var(--gold-500);border-radius:0 10px 10px 0;text-align:left;color:var(--muted);font-size:14px}
.lot-qr-share{
  display:flex;align-items:center;gap:20px;text-align:left;
  margin-top:24px;padding:18px;background:#fff;border-radius:14px;
  border:1px solid var(--gold-500);
}
.lot-qr-share img{width:120px;height:120px;border-radius:8px;background:#fff}
.lot-qr-share .lk{font-size:11px;color:var(--gold-700);letter-spacing:1.5px;text-transform:uppercase;font-weight:600}
@media(max-width:520px){.lot-qr-share{flex-direction:column;text-align:center}}
@media(max-width:640px){.lot-card{padding:36px 24px}.lot-card h2{font-size:32px}}

/* ============ Story / Why us ============ */
.story-band{
  background:linear-gradient(135deg,var(--lav-700),var(--lav-800));
  color:#fff;padding:90px 6vw;position:relative;overflow:hidden;
}
.story-band::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(800px 400px at 70% 30%, rgba(212,175,55,.18), transparent);
}
.story-grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:36px;max-width:1100px;margin:50px auto 0}
.story-band .section-title{color:#fff}
.story-band .section-sub{color:var(--lav-200)}
.story-band .section-eyebrow{color:var(--gold-400)}
.story-item{text-align:center;padding:20px}
.story-icon{
  width:70px;height:70px;margin:0 auto 18px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-700));
  display:grid;place-items:center;font-size:32px;color:#fff;
  box-shadow:0 12px 30px rgba(212,175,55,.35);
  animation:pulse-gold 3s ease-in-out infinite;
}
@keyframes pulse-gold{0%,100%{box-shadow:0 12px 30px rgba(212,175,55,.35)}50%{box-shadow:0 12px 50px rgba(212,175,55,.7)}}
.story-item h4{font-size:18px;color:var(--gold-400);margin-bottom:8px}
.story-item p{color:var(--lav-200);font-size:14px;line-height:1.7}

/* ============ Promo strip ============ */
.promo-strip{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:0;
  background:#fff;border-top:1px solid var(--cream-300);border-bottom:1px solid var(--cream-300);
}
.promo-cell{padding:22px 18px;text-align:center;border-right:1px solid var(--cream-200);display:flex;align-items:center;justify-content:center;gap:12px}
.promo-cell:last-child{border-right:0}
.promo-cell .ic{width:42px;height:42px;border-radius:50%;background:var(--cream-200);display:grid;place-items:center;font-size:20px;color:var(--gold-700);flex-shrink:0}
.promo-cell .tx{text-align:left}
.promo-cell .t1{font-weight:600;color:var(--lav-800);font-size:14px}
.promo-cell .t2{font-size:12px;color:var(--muted);margin-top:2px}
@media(max-width:780px){.promo-cell{border-right:0;border-bottom:1px solid var(--cream-200)}.promo-cell:last-child{border-bottom:0}}

/* ============ Footer ============ */
.site-footer{
  background:var(--lav-800);color:#cdb4e8;padding:60px 6vw 24px;position:relative;
  border-top:1px solid rgba(212,175,55,.2);
}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:36px;max-width:1100px;margin:0 auto 40px}
.footer-brand{font-size:22px;font-weight:600;color:var(--gold-500);margin-bottom:10px}
.site-footer h4{color:var(--gold-400);font-size:14px;letter-spacing:1.5px;margin-bottom:14px;text-transform:uppercase}
.site-footer a{display:block;padding:4px 0;color:#bba6d6;transition:.2s;font-size:14px}
.site-footer a:hover{color:var(--gold-400)}
.copyright{text-align:center;border-top:1px solid rgba(255,255,255,.06);padding-top:20px;font-size:13px;color:#8a78a8}

/* ============ Reveal on scroll ============ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s, transform .8s}
.reveal.in{opacity:1;transform:translateY(0)}

/* ============ Toast ============ */
.toast{
  position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(100px);
  background:linear-gradient(135deg,var(--lav-700),var(--lav-800));
  color:#fff;padding:14px 28px;border-radius:999px;
  border:1px solid var(--gold-500);box-shadow:var(--shadow-lg);
  z-index:200;opacity:0;transition:.4s;font-weight:500;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ============ Shop / Cart / Checkout ============ */
.page-head{
  padding:80px 6vw 50px;text-align:center;
  background:
    radial-gradient(800px 400px at 50% 100%, rgba(220,199,235,.7), transparent 70%),
    linear-gradient(180deg,var(--cream-100),var(--cream-200));
  border-bottom:1px solid var(--cream-300);
}
.page-head h1{font-family:'Cormorant Garamond',serif;font-size:clamp(34px,4.5vw,52px);color:var(--lav-800)}
.page-head p{color:var(--muted);margin-top:8px}

.filter-bar{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;padding:24px 6vw;background:#fff;border-bottom:1px solid var(--cream-200)}
.chip{padding:8px 20px;border-radius:999px;border:1px solid var(--lav-200);background:#fff;color:var(--lav-700);font-size:14px;cursor:pointer;transition:.25s;font-family:inherit}
.chip:hover, .chip.active{background:linear-gradient(135deg,var(--lav-600),var(--lav-700));color:#fff;border-color:transparent}

.cart-wrap{max-width:1100px;margin:60px auto;padding:0 6vw;display:grid;grid-template-columns:1fr 360px;gap:30px}
@media(max-width:880px){.cart-wrap{grid-template-columns:1fr}}
.cart-list{background:#fff;border-radius:20px;border:1px solid var(--cream-300);overflow:hidden;box-shadow:var(--shadow-sm)}
.cart-row{display:grid;grid-template-columns:80px 1fr auto auto;gap:14px;align-items:center;padding:18px 20px;border-bottom:1px solid var(--cream-200)}
.cart-row:last-child{border-bottom:0}
.cart-thumb{width:72px;height:72px;border-radius:14px;background:linear-gradient(135deg,var(--lav-50),var(--cream-200));display:grid;place-items:center;overflow:hidden}
.qty-ctl{display:flex;align-items:center;gap:8px}
.qty-ctl button{
  width:30px;height:30px;border-radius:50%;border:1px solid var(--lav-200);background:#fff;cursor:pointer;
  color:var(--lav-700);font-size:16px;transition:.2s
}
.qty-ctl button:hover{background:var(--lav-600);color:#fff;border-color:transparent}
.qty-ctl span{min-width:24px;text-align:center;font-weight:600}
.remove-btn{background:none;border:0;color:#c44569;cursor:pointer;font-size:13px;padding:6px}

.cart-summary{background:linear-gradient(160deg,var(--lav-700),var(--lav-800));color:#fff;border-radius:20px;padding:28px;height:fit-content;box-shadow:var(--shadow-md)}
.cart-summary h3{color:var(--gold-400);margin-bottom:18px;font-family:'Cormorant Garamond',serif;font-size:28px}
.summary-line{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed rgba(255,255,255,.15);color:var(--lav-200)}
.summary-line.total{font-size:22px;color:var(--gold-400);border-bottom:0;margin-top:8px;font-weight:700}

.empty-cart{text-align:center;padding:80px 20px;color:var(--muted)}
.empty-cart .icon{font-size:60px;margin-bottom:14px;opacity:.5}

.form-grid{display:grid;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}
label{font-size:13px;font-weight:600;color:var(--lav-700);display:block;margin-bottom:5px}
input,textarea,select{
  width:100%;padding:12px 14px;border:1px solid var(--lav-200);border-radius:12px;
  font-family:inherit;font-size:15px;background:#fff;color:var(--ink);transition:.2s
}
input:focus,textarea:focus,select:focus{outline:0;border-color:var(--gold-500);box-shadow:0 0 0 4px rgba(212,175,55,.15)}

.payment-pick{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:8px}
@media(max-width:520px){.payment-pick{grid-template-columns:1fr}}
.pay-opt{
  border:1.5px solid var(--lav-200);border-radius:14px;padding:16px;cursor:pointer;text-align:center;transition:.2s;
  background:#fff;
}
.pay-opt input{display:none}
.pay-opt.selected{border-color:var(--gold-500);background:var(--cream-100);box-shadow:0 6px 18px rgba(212,175,55,.18)}
.pay-icon{font-size:30px;margin-bottom:6px}
.pay-title{font-weight:600;color:var(--lav-800)}
.pay-sub{font-size:12px;color:var(--muted);margin-top:2px}

.order-success{text-align:center;padding:80px 6vw;max-width:560px;margin:0 auto}
.success-icon{
  width:90px;height:90px;border-radius:50%;margin:0 auto 18px;
  background:linear-gradient(135deg,var(--gold-500),var(--gold-700));
  display:grid;place-items:center;font-size:48px;color:#fff;
  animation:pop .6s cubic-bezier(.2,.8,.2,1.5);
}
@keyframes pop{0%{transform:scale(0)}80%{transform:scale(1.15)}100%{transform:scale(1)}}
.qr-box{margin:24px auto;max-width:280px;background:#fff;padding:20px;border-radius:20px;border:2px solid var(--gold-500);box-shadow:var(--shadow-lg)}
.qr-box img{width:100%}

/* ============ Articles ============ */
.articles{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:28px;max-width:1280px;margin:0 auto}
.art-card{
  background:#fff;border-radius:20px;overflow:hidden;
  border:1px solid rgba(168,133,43,.15);transition:.4s cubic-bezier(.2,.8,.2,1);
  display:flex;flex-direction:column;box-shadow:var(--shadow-sm);
}
.art-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--gold-500)}
.art-thumb{position:relative;display:block;aspect-ratio:16/10;overflow:hidden}
.art-thumb img, .art-thumb svg{width:100%;height:100%;object-fit:cover;transition:.6s}
.art-card:hover .art-thumb img, .art-card:hover .art-thumb svg{transform:scale(1.06)}
.art-body{padding:20px 22px;flex:1;display:flex;flex-direction:column}
.art-tag{font-size:11px;color:var(--gold-700);letter-spacing:1.5px;text-transform:uppercase;font-weight:600;margin-bottom:6px}
.art-card h3{font-size:18px;color:var(--lav-800);font-weight:600;line-height:1.4;margin-bottom:8px}
.art-card h3 a:hover{color:var(--gold-700)}
.art-card p{font-size:14px;color:var(--muted);flex:1;margin-bottom:14px;line-height:1.6}
.art-meta{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--muted);border-top:1px solid var(--cream-200);padding-top:12px}
.art-read{color:var(--lav-600);font-weight:600;transition:.2s}
.art-read:hover{color:var(--gold-700)}

/* Home — Article grid (1 ใหญ่ + 2 เล็ก) */
.home-articles{background:linear-gradient(180deg,var(--cream-50),var(--lav-50))}
.home-art-grid{
  display:grid;grid-template-columns:1.4fr 1fr;grid-template-rows:auto auto;gap:24px;
  max-width:1200px;margin:0 auto;
}
.home-art-grid .art-feature{grid-row:span 2}
.home-art-grid .art-feature .art-thumb{aspect-ratio:4/3}
.home-art-grid .art-feature h3{font-size:24px;font-family:'Cormorant Garamond',serif;font-weight:600}
.home-art-grid .art-feature p{font-size:15px;-webkit-line-clamp:4}
.home-art-grid .art-feature .art-body{padding:28px}
.home-art-grid .art-card:not(.art-feature){flex-direction:row;max-height:200px}
.home-art-grid .art-card:not(.art-feature) .art-thumb{aspect-ratio:1;width:180px;flex-shrink:0;height:auto}
.home-art-grid .art-card:not(.art-feature) .art-body{padding:18px 20px}
.home-art-grid .art-card:not(.art-feature) h3{font-size:16px;-webkit-line-clamp:2;
  display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}
.home-art-grid .art-card:not(.art-feature) p{font-size:13px;-webkit-line-clamp:2;
  display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}
@media(max-width:880px){
  .home-art-grid{grid-template-columns:1fr}
  .home-art-grid .art-feature{grid-row:auto}
  .home-art-grid .art-card:not(.art-feature){flex-direction:column;max-height:none}
  .home-art-grid .art-card:not(.art-feature) .art-thumb{aspect-ratio:16/9;width:100%}
}

/* Article detail */
.article-detail{max-width:800px;margin:60px auto;padding:0 6vw}
.article-hero{text-align:center;margin-bottom:24px}
.article-hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(34px,4.5vw,56px);color:var(--lav-800);line-height:1.2;margin:10px 0}
.article-tag-pill{display:inline-block;padding:4px 14px;border-radius:999px;background:linear-gradient(135deg,var(--gold-500),var(--gold-700));color:#fff;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;font-weight:700}
.article-meta{color:var(--muted);font-size:14px;display:flex;gap:6px;justify-content:center;flex-wrap:wrap}
.article-cover{aspect-ratio:16/8;border-radius:24px;overflow:hidden;margin-bottom:36px;box-shadow:var(--shadow-lg)}
.article-cover img, .article-cover svg{width:100%;height:100%;object-fit:cover}
.article-body{font-size:17px;line-height:1.85;color:var(--ink)}
.article-body h2,.article-body h3{font-family:'Prompt',sans-serif;color:var(--lav-800);margin:28px 0 12px}
.article-body h3{font-size:22px}
.article-body p{margin-bottom:18px}
.article-body ul,.article-body ol{margin:0 0 18px 1.5em}
.article-body li{margin-bottom:6px}
.article-body strong{color:var(--lav-700)}
.article-body em{color:var(--gold-700)}
.article-body a{color:var(--lav-600);border-bottom:1px solid var(--gold-500);padding-bottom:1px}
.article-body a:hover{color:var(--gold-700)}
.article-body blockquote{border-left:3px solid var(--gold-500);padding:8px 16px;background:var(--cream-100);margin:18px 0;border-radius:0 10px 10px 0;color:var(--muted)}

/* ============ Article Reactions ============ */
.reactions-bar{
  margin:50px auto 0;padding:30px;border-radius:24px;
  background:linear-gradient(135deg,var(--cream-100),var(--lav-50));
  border:1px solid rgba(168,133,43,.18);
  text-align:center;box-shadow:var(--shadow-sm);
}
.reactions-title{
  color:var(--lav-700);font-size:14px;letter-spacing:1.2px;
  margin-bottom:18px;font-weight:500;
}
.reactions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.react-btn{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:14px 18px;min-width:78px;
  background:#fff;border:2px solid transparent;border-radius:16px;
  cursor:pointer;transition:.3s cubic-bezier(.2,.8,.2,1);
  font-family:inherit;color:var(--lav-700);
  box-shadow:0 4px 12px rgba(85,58,115,.06);position:relative;
}
.react-btn:hover{transform:translateY(-4px) scale(1.04);box-shadow:0 12px 28px rgba(85,58,115,.18);border-color:var(--gold-400)}
.react-btn .emo{font-size:30px;line-height:1;transition:.3s;display:block}
.react-btn:hover .emo{transform:scale(1.25) rotate(-8deg)}
.react-btn .lbl{font-size:11px;letter-spacing:.5px;color:var(--muted)}
.react-btn .cnt{
  display:inline-block;font-size:13px;font-weight:700;color:var(--gold-700);
  background:var(--cream-200);padding:2px 10px;border-radius:999px;min-width:30px;
  margin-top:2px;transition:.2s;
}
.react-btn.active{
  background:linear-gradient(135deg,#fff,var(--cream-100));
  border-color:var(--gold-500);
}
.react-btn.active .cnt{background:linear-gradient(135deg,var(--gold-500),var(--gold-700));color:#fff}
.react-btn.active .emo{transform:scale(1.15)}

/* burst animation when clicked */
.react-btn.burst::after{
  content:attr(data-burst);position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);font-size:48px;pointer-events:none;
  animation:burst 1s ease-out forwards;
}
@keyframes burst{
  0%{opacity:1;transform:translate(-50%,-50%) scale(.4)}
  60%{opacity:.9;transform:translate(-50%,-160%) scale(1.6) rotate(20deg)}
  100%{opacity:0;transform:translate(-50%,-260%) scale(2.2) rotate(40deg)}
}

@media(max-width:540px){
  .reactions{gap:8px}
  .react-btn{padding:10px 12px;min-width:64px}
  .react-btn .emo{font-size:24px}
}

/* Inline product card inside articles */
.art-prod-card{
  display:flex;gap:16px;align-items:center;
  padding:14px;margin:24px 0;border-radius:18px;
  background:linear-gradient(135deg,#fff,var(--cream-100));
  border:1px solid var(--gold-500);
  box-shadow:0 8px 25px rgba(168,133,43,.18);
  text-decoration:none;transition:.3s cubic-bezier(.2,.8,.2,1);
}
.art-prod-card:hover{transform:translateX(4px);box-shadow:0 14px 36px rgba(168,133,43,.3);border-color:var(--lav-600)}
.art-prod-img{width:90px;height:90px;flex-shrink:0;border-radius:14px;background:linear-gradient(135deg,var(--lav-50),var(--cream-200));display:grid;place-items:center;overflow:hidden}
.art-prod-img svg, .art-prod-img img{width:80%;height:80%}
.art-prod-body{flex:1;min-width:0}
.art-prod-name{font-weight:600;color:var(--lav-800);font-size:16px;line-height:1.3}
.art-prod-meta{font-size:13px;color:var(--muted);margin:4px 0 6px}
.art-prod-go{display:inline-block;font-size:12px;font-weight:700;color:var(--gold-700);letter-spacing:1px;text-transform:uppercase;border-bottom:0;padding:0}

@media (max-width:780px){
  .main-nav{display:none}
  .section{padding:60px 5vw}
}
