/* ================================================================
   HEAVEN OF DESSERT - hod.css  v4
   All CSS variables unified. Old --hod-* aliased for backward compat.
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700;800&family=Nunito:wght@400;600;700;800&display=swap');

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Nunito',system-ui,sans-serif;background:#FFF8F0;color:#5C2D0A;overflow-x:hidden;line-height:1.65;min-height:100vh}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer;border:none;background:none;line-height:1}
ul,ol{list-style:none}
input,textarea,select{font-family:inherit}

/* ── CSS Variables ── */
:root{
  /* New names */
  --red:#C5282A;--red-d:#A01E20;--red-l:#e84040;
  --cream:#FFF8F0;--cream-d:#F5E6D8;--cream-m:#fce4d6;
  --brown:#5C2D0A;--br-lt:#9a7558;--br-xs:#c4a882;
  --gold:#D4A853;

  /* Legacy aliases (for old templates) */
  --hod-red:#C5282A;--hod-red-dark:#A01E20;
  --hod-cream:#FFF8F0;--hod-brown:#5C2D0A;
  --hod-gold:#D4A853;

  --sh-xs:0 1px 8px rgba(92,45,10,.06);
  --sh-sm:0 2px 16px rgba(92,45,10,.09);
  --sh-md:0 6px 30px rgba(92,45,10,.13);
  --sh-lg:0 16px 52px rgba(92,45,10,.17);
  --sh-xl:0 28px 80px rgba(92,45,10,.21);
  --r-xs:6px;--r-sm:10px;--r-md:16px;--r-lg:20px;--r-xl:28px;--r-2xl:36px;
  --tr:.22s cubic-bezier(.4,0,.2,1);
  --font-d:'Playfair Display',Georgia,serif;
  --font-b:'Nunito',system-ui,sans-serif;
  --nav-h:68px;
}

/* ── Page Loader ── */
#hod-loader{
  position:fixed;inset:0;z-index:9999;background:var(--red);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;
  transition:opacity .7s ease,visibility .7s ease;
}
#hod-loader.gone{opacity:0;visibility:hidden;pointer-events:none}
#hod-loader img{width:140px;height:auto;animation:ldPulse 1.3s ease-in-out infinite;object-fit:contain}
.ld-bar{width:200px;height:4px;background:rgba(255,255,255,.22);border-radius:2px;overflow:hidden}
.ld-fill{height:100%;background:#fff;border-radius:2px;animation:ldFill 1.7s ease-out forwards}
.ld-text{color:rgba(255,255,255,.8);font-size:.78rem;letter-spacing:2.5px;text-transform:uppercase;font-weight:700}
@keyframes ldPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.07)}}
@keyframes ldFill{from{width:0}to{width:100%}}

/* ── Navbar ── */
.hod-nav{
  position:sticky;top:0;z-index:900;
  background:var(--red);
  box-shadow:0 2px 20px rgba(160,30,32,.4);
}
.nav-wrap{
  max-width:1300px;margin:0 auto;padding:0 24px;
  height:var(--nav-h);
  display:flex;align-items:center;
  gap:16px;
}

/* Logo - bigger */
.nav-logo{
  display:flex;align-items:center;gap:11px;
  flex-shrink:0;text-decoration:none;
}
.nav-logo img{
  height:50px;   /* was 40px - now bigger */
  width:auto;
  object-fit:contain;
  flex-shrink:0;
}
.nav-logo-text{display:flex;flex-direction:column;line-height:1}
.nav-logo-name{color:#fff;font-family:var(--font-d);font-size:1.05rem;font-weight:700;white-space:nowrap}
.nav-logo-sub{color:rgba(255,255,255,.62);font-size:.65rem;letter-spacing:.5px;white-space:nowrap;margin-top:2px}

/* Center nav links */
.nav-links{
  display:flex;align-items:center;gap:2px;
  flex:1;justify-content:center;
}
.nav-links a{
  color:rgba(255,255,255,.88);font-size:.875rem;font-weight:700;
  padding:7px 14px;border-radius:var(--r-sm);
  transition:background var(--tr),color var(--tr);white-space:nowrap;
}
.nav-links a:hover,.nav-links a.active{background:rgba(255,255,255,.18);color:#fff}

/* Right side actions - flex row, no wrap */
.nav-right{
  display:flex;align-items:center;gap:4px;
  flex-shrink:0;
}

/* Icon buttons (search, heart) */
.nav-icon{
  position:relative;
  width:40px;height:40px;border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  color:#fff;transition:background var(--tr);
  flex-shrink:0;
}
.nav-icon:hover{background:rgba(255,255,255,.18)}
.nav-icon svg{
  width:21px;height:21px;
  stroke:#fff;fill:none;stroke-width:2;
  stroke-linecap:round;stroke-linejoin:round;
}

/* Cart icon - with badge, must be relative positioned */
.nav-cart{
  position:relative;
  width:40px;height:40px;border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  color:#fff;transition:background var(--tr);
  flex-shrink:0;
}
.nav-cart:hover{background:rgba(255,255,255,.18)}
.nav-cart svg{
  width:22px;height:22px;
  stroke:#fff;fill:none;stroke-width:2;
  stroke-linecap:round;stroke-linejoin:round;
}
.cart-badge{
  position:absolute;
  top:-4px;right:-4px;
  background:var(--gold);color:var(--brown);
  font-size:.58rem;font-weight:900;
  min-width:18px;height:18px;
  border-radius:9px;padding:0 4px;
  display:flex;align-items:center;justify-content:center;
  border:2px solid var(--red);
  line-height:1;z-index:1;
}

/* Sign-in / profile button */
.nav-user-btn{
  display:flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.18);color:#fff;
  padding:8px 16px;border-radius:50px;
  font-size:.82rem;font-weight:700;
  border:2px solid rgba(255,255,255,.3);
  transition:all var(--tr);white-space:nowrap;
  flex-shrink:0;
}
.nav-user-btn:hover{background:rgba(255,255,255,.28);border-color:rgba(255,255,255,.6)}
.nav-user-btn svg{
  width:16px;height:16px;stroke:#fff;fill:none;
  stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;
}

/* Hamburger */
.nav-ham{
  display:none;width:40px;height:40px;border-radius:var(--r-sm);
  align-items:center;justify-content:center;
  background:rgba(255,255,255,.15);transition:background var(--tr);
}
.nav-ham:hover{background:rgba(255,255,255,.25)}
.nav-ham svg{width:22px;height:22px;stroke:#fff;fill:none;stroke-width:2.2;stroke-linecap:round}

/* ── Mobile Drawer ── */
.mob-drawer{position:fixed;inset:0;z-index:1000;visibility:hidden;opacity:0;transition:opacity .3s ease,visibility .3s ease}
.mob-drawer.open{visibility:visible;opacity:1}
.mob-back{position:absolute;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.mob-panel{
  position:absolute;top:0;left:0;bottom:0;width:min(300px,85vw);
  background:var(--brown);
  transform:translateX(-100%);transition:transform .36s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;overflow-y:auto;
}
.mob-drawer.open .mob-panel{transform:translateX(0)}
.mob-head{
  padding:16px 18px;background:var(--red);
  display:flex;align-items:center;justify-content:space-between;flex-shrink:0;
}
.mob-head img{height:40px;width:auto;object-fit:contain}
.mob-x{
  width:34px;height:34px;border-radius:8px;
  background:rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;transition:background var(--tr);
}
.mob-x:hover{background:rgba(255,255,255,.25)}
.mob-x svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round}
.mob-body{flex:1;padding:10px 0}
.mob-body a{
  display:flex;align-items:center;gap:13px;padding:13px 20px;
  color:rgba(255,255,255,.82);font-size:.93rem;font-weight:600;
  transition:background var(--tr),color var(--tr);
}
.mob-body a:hover{background:rgba(255,255,255,.09);color:#fff}
.mob-body a svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.mob-divider{height:1px;background:rgba(255,255,255,.1);margin:8px 18px}
.mob-foot{padding:14px 18px;border-top:1px solid rgba(255,255,255,.1)}
.mob-foot a{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:13px;border-radius:var(--r-lg);
  background:var(--red);color:#fff;font-weight:700;font-size:.9rem;
}

/* ── Buttons ── */
.btn,.btn-hod-primary,.btn-hod-outline{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:inherit;font-weight:700;font-size:.875rem;
  padding:11px 24px;border-radius:50px;
  border:2px solid transparent;cursor:pointer;
  transition:transform var(--tr),box-shadow var(--tr),background var(--tr),border-color var(--tr),color var(--tr);
  white-space:nowrap;line-height:1;text-decoration:none;
}
.btn:hover,.btn-hod-primary:hover,.btn-hod-outline:hover{transform:translateY(-2px)}
.btn:active,.btn-hod-primary:active{transform:translateY(0)!important}
.btn svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}

.btn-primary,.btn-hod-primary{
  background:var(--red);color:#fff;border-color:var(--red);
  box-shadow:0 4px 18px rgba(197,40,42,.32);
}
.btn-primary:hover,.btn-hod-primary:hover{
  background:var(--red-d);border-color:var(--red-d);
  box-shadow:0 8px 28px rgba(197,40,42,.44);color:#fff;
}
.btn-gold{background:var(--gold);color:var(--brown);border-color:var(--gold);box-shadow:0 4px 18px rgba(212,168,83,.3)}
.btn-gold:hover{box-shadow:0 8px 28px rgba(212,168,83,.44)}
.btn-outline,.btn-hod-outline{background:transparent;color:var(--red);border-color:var(--red)}
.btn-outline:hover,.btn-hod-outline:hover{background:var(--red);color:#fff}
.btn-outline-w{background:transparent;color:#fff;border-color:rgba(255,255,255,.65)}
.btn-outline-w:hover{background:rgba(255,255,255,.18);border-color:#fff}
.btn-ghost{background:var(--cream-d);color:var(--br-lt);border-color:transparent}
.btn-ghost:hover{background:var(--cream-m);color:var(--brown)}
.btn-sm{padding:8px 18px!important;font-size:.8rem!important}
.btn-lg{padding:14px 32px!important;font-size:1rem!important}
.btn-block,.w-full{width:100%}
.btn[disabled]{opacity:.55;pointer-events:none}
.btn.loading{pointer-events:none;opacity:.75}
.btn.done{background:#10B981!important;border-color:#10B981!important}

/* Legacy layout helpers */
.max-w-7xl{max-width:1280px}
.mx-auto{margin-left:auto;margin-right:auto}
.px-4{padding-left:1rem;padding-right:1rem}
.grid{display:grid}
.grid-cols-1{grid-template-columns:1fr}
.grid-cols-2{grid-template-columns:repeat(2,1fr)}
.gap-4{gap:1rem}
.gap-8{gap:2rem}
.mb-4{margin-bottom:1rem}
.justify-center{justify-content:center}
.text-center{text-align:center}
@media(min-width:1024px){.lg\:col-span-2{grid-column:span 2}.lg\:col-span-1{grid-column:span 1}.lg\:grid-cols-3{grid-template-columns:repeat(3,1fr)}}

/* ── Inputs (new + legacy) ── */
.form-group{margin-bottom:18px}
.form-label{display:block;margin-bottom:6px;font-size:.825rem;font-weight:700;color:var(--brown)}
.form-input,.hod-input{
  width:100%;padding:12px 16px;
  border:2px solid #e5d5c8;border-radius:var(--r-sm);
  font-family:inherit;font-size:.9rem;color:var(--brown);
  background:#fff;outline:none;
  transition:border-color var(--tr),box-shadow var(--tr);
  -webkit-appearance:none;
}
.form-input:focus,.hod-input:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(197,40,42,.12)}
.form-input::placeholder,.hod-input::placeholder{color:#bba898}
.form-error{color:#c53030;font-size:.78rem;margin-top:4px}

/* ── Alerts ── */
.alert,.hod-message{
  display:flex;align-items:flex-start;gap:11px;
  padding:13px 15px;border-radius:var(--r-sm);
  font-weight:600;font-size:.875rem;margin-bottom:14px;
}
.alert svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;flex-shrink:0;margin-top:1px}
.alert-close{margin-left:auto;cursor:pointer;opacity:.55;transition:opacity var(--tr);padding:0 0 0 8px;flex-shrink:0}
.alert-close:hover{opacity:1}
.alert-success{background:#dcfce7;color:#166534}
.alert-error,.hod-message.error{background:#fee2e2;color:#991b1b}
.alert-info{background:#dbeafe;color:#1e40af}
.alert-warn{background:#fef9c3;color:#854d0e}

/* ── Section headings ── */
.sec-head{text-align:center;margin-bottom:44px}
.sec-eyebrow{display:inline-block;font-size:.72rem;font-weight:800;letter-spacing:2.5px;text-transform:uppercase;color:var(--red);margin-bottom:8px}
.sec-title{font-family:var(--font-d);font-size:clamp(1.75rem,4vw,2.75rem);color:var(--brown);line-height:1.2;margin-bottom:10px}
.sec-line{display:block;width:52px;height:3px;background:var(--red);border-radius:2px;margin:0 auto 14px}
.sec-sub{color:var(--br-lt);font-size:clamp(.875rem,2vw,1rem);max-width:520px;margin:0 auto;line-height:1.65}

/* ── Product Card - perfected ── */
.product-card{
  background:#fff;border-radius:22px;overflow:hidden;
  position:relative;box-shadow:0 2px 16px rgba(92,45,10,.08);
  display:flex;flex-direction:column;height:100%;
  transition:transform .36s cubic-bezier(.175,.885,.32,1.275),box-shadow .36s ease;
  border:1.5px solid rgba(92,45,10,.06);
}
.product-card:hover{
  transform:translateY(-8px) scale(1.01);
  box-shadow:0 24px 64px rgba(92,45,10,.18);
  border-color:transparent;
}

/* Image area */
.pc-img{
  position:relative;overflow:hidden;
  aspect-ratio:4/3;flex-shrink:0;
  background:linear-gradient(135deg,var(--cream-d) 0%,var(--cream-m) 100%);
}
.pc-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s ease;display:block;
}
.product-card:hover .pc-img img{transform:scale(1.08)}
.pc-img-ph{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:8px;
}
/* Styled placeholder - no ??? */
.pc-img-ph-icon{
  width:80px;height:80px;
  background:linear-gradient(135deg,rgba(197,40,42,.12),rgba(197,40,42,.06));
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.pc-img-ph-icon svg{width:40px;height:40px;stroke:var(--red);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;opacity:.5}
.pc-img-ph-label{font-size:.68rem;font-weight:700;color:var(--br-xs);letter-spacing:1px;text-transform:uppercase}

/* Badges */
.pc-badge{
  position:absolute;top:11px;left:11px;z-index:2;
  font-size:.62rem;font-weight:800;letter-spacing:.8px;text-transform:uppercase;
  padding:4px 10px;border-radius:50px;
  display:inline-flex;align-items:center;gap:4px;line-height:1.2;
}
.pc-badge svg{width:10px;height:10px;fill:currentColor;stroke:none;flex-shrink:0}
.b-best{background:var(--red);color:#fff}
.b-pop{background:var(--gold);color:var(--brown)}
.b-new{background:#dbeafe;color:#1e40af}
.b-sf{background:#dcfce7;color:#166534}
.b-sea{background:#fef9c3;color:#854d0e}

/* Favorite button */
.fav-btn{
  position:absolute;top:11px;right:11px;z-index:2;
  width:34px;height:34px;border-radius:50%;
  background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.13);
  display:flex;align-items:center;justify-content:center;
  transition:transform var(--tr),box-shadow var(--tr);
}
.fav-btn:hover{transform:scale(1.18);box-shadow:0 4px 16px rgba(197,40,42,.28)}
.fav-btn svg{
  width:17px;height:17px;stroke:#c4a882;fill:none;
  stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
  transition:stroke var(--tr),fill var(--tr);
}
.fav-btn.on svg{stroke:var(--red);fill:var(--red)}
.fav-btn.pop{animation:favPop .42s cubic-bezier(.175,.885,.32,1.275)}
@keyframes favPop{0%,100%{transform:scale(1)}50%{transform:scale(1.45)}}

/* Card body */
.pc-body{padding:15px;display:flex;flex-direction:column;flex:1;gap:3px}
.pc-cat{font-size:.66rem;font-weight:800;color:var(--red);text-transform:uppercase;letter-spacing:.9px;line-height:1}
.pc-name{
  font-family:var(--font-d);font-size:1rem;color:var(--brown);
  line-height:1.3;margin-top:3px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.pc-sub{font-size:.72rem;color:var(--br-lt);line-height:1.4;margin-top:1px}

.pc-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:5px}
.tag{font-size:.61rem;font-weight:700;padding:2px 8px;border-radius:50px;line-height:1.4}
.t-sf{background:#dcfce7;color:#166534}
.t-sea{background:#fef9c3;color:#854d0e}

/* Price */
.pc-price{
  margin-top:auto;padding-top:10px;
  display:flex;align-items:baseline;flex-wrap:wrap;gap:3px;
}
.p-main{font-size:1.18rem;font-weight:800;color:var(--red)}
.p-label{font-size:.7rem;color:var(--br-lt);margin-right:1px}
.p-sep{font-size:.78rem;color:var(--br-xs);margin:0 1px}
.p-orig{font-size:.76rem;color:var(--br-lt);text-decoration:line-through}
.p-disc{font-size:.6rem;font-weight:800;background:var(--red);color:#fff;padding:2px 6px;border-radius:4px}

/* Actions */
.pc-actions{display:flex;gap:7px;margin-top:12px}
.pc-actions .btn{
  flex:1;padding:9px 8px;font-size:.8rem;gap:5px;
  border-radius:12px;justify-content:center;
}
.btn-qv{
  flex:0 0 38px!important;width:38px;padding:0!important;
  background:var(--cream-d);color:var(--br-lt);
  border:2px solid #e5d5c8;border-radius:10px!important;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--tr);
}
.btn-qv:hover{background:var(--cream-m);border-color:var(--red);color:var(--red);transform:none!important}
.btn-qv svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* Product grid */
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:20px}

/* ── Qty controls ── */
.qty-row,.qty-controls{display:flex;align-items:center;gap:8px}
.qty-btn{
  width:32px;height:32px;border-radius:8px;
  border:2px solid #e5d5c8;display:flex;align-items:center;justify-content:center;
  transition:border-color var(--tr),background var(--tr);background:#fff;cursor:pointer;
}
.qty-btn:hover{border-color:var(--red);background:rgba(197,40,42,.06)}
.qty-btn svg{width:15px;height:15px;stroke:var(--brown);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.qty-num{font-weight:800;font-size:1rem;min-width:28px;text-align:center;color:var(--brown)}

/* ── Cart page ── */
.cart-layout{display:grid;grid-template-columns:1fr 360px;gap:24px;align-items:start}
.cart-item-row{
  background:#fff;border-radius:18px;padding:18px 20px;
  display:flex;align-items:center;gap:16px;
  box-shadow:var(--sh-xs);
  transition:opacity .3s ease,transform .3s ease;
  border:1.5px solid rgba(92,45,10,.05);
}
.cart-item-row:not(:last-child){margin-bottom:12px}
.cart-item-row.removing{opacity:0;transform:translateX(20px)}
.cart-img{
  width:78px;height:78px;border-radius:14px;overflow:hidden;flex-shrink:0;
  background:linear-gradient(135deg,var(--cream-d),var(--cream-m));
  display:flex;align-items:center;justify-content:center;
}
.cart-img img{width:100%;height:100%;object-fit:cover;display:block}
.cart-img-ph{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
}
.cart-img-ph svg{width:34px;height:34px;stroke:var(--red);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;opacity:.35}
.cart-item-name{font-family:var(--font-d);font-size:1rem;color:var(--brown);line-height:1.3;margin-bottom:3px}
.cart-item-meta{font-size:.78rem;color:var(--br-lt)}
.cart-item-price{font-size:.875rem;font-weight:700;color:var(--red);margin-top:4px}
.cart-summary{
  background:#fff;border-radius:22px;padding:26px;
  box-shadow:var(--sh-md);position:sticky;top:calc(var(--nav-h) + 20px);
  border:1.5px solid rgba(92,45,10,.05);
}
.cart-summary-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 0;font-size:.9rem;
}
.cart-summary-row.total{
  padding:14px 0 0;margin-top:4px;
  border-top:2px solid var(--cream-d);
  font-size:1.1rem;font-weight:800;
}
.coupon-row{display:flex;gap:8px;margin-top:14px}
.coupon-row .hod-input{padding:10px 14px;text-transform:uppercase;letter-spacing:1px;border-radius:var(--r-sm)}
.remove-btn{
  width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--cream-d);color:var(--br-lt);flex-shrink:0;
  transition:all var(--tr);
}
.remove-btn:hover{background:#fee2e2;color:#991b1b}
.remove-btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round}

/* ── Chatbot FAB - Ice cream style ── */
#cb-fab{
  position:fixed;bottom:24px;right:24px;z-index:990;
  width:62px;height:62px;border-radius:50%;
  background:linear-gradient(160deg,var(--red) 0%,var(--red-l) 100%);
  box-shadow:0 8px 32px rgba(197,40,42,.45),0 0 0 0 rgba(197,40,42,.3);
  display:flex;align-items:center;justify-content:center;
  transition:transform var(--tr),box-shadow var(--tr);
  animation:cbFloat 3.2s ease-in-out infinite;
  overflow:hidden;
}
#cb-fab:hover{
  transform:scale(1.1)!important;
  box-shadow:0 14px 40px rgba(197,40,42,.58);
  animation:none;
}
/* Ice cream SVG icon in FAB */
#cb-fab svg{width:36px;height:36px}

@keyframes cbFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}

#cb-panel{
  position:fixed;bottom:98px;right:24px;z-index:989;
  width:min(360px,calc(100vw - 32px));
  background:#fff;border-radius:22px;
  box-shadow:0 20px 64px rgba(92,45,10,.22);
  display:flex;flex-direction:column;overflow:hidden;max-height:520px;
  transform:translateY(18px) scale(.94);opacity:0;visibility:hidden;
  transition:transform .32s cubic-bezier(.175,.885,.32,1.275),opacity .32s ease,visibility .32s;
}
#cb-panel.open{transform:none;opacity:1;visibility:visible}
.cb-head{
  padding:15px 16px;
  background:linear-gradient(135deg,var(--red),var(--red-l));
  display:flex;align-items:center;gap:11px;flex-shrink:0;
}
.cb-av{
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.cb-av svg{width:24px;height:24px}
.cb-name{color:#fff;font-weight:700;font-size:.9rem}
.cb-status{color:rgba(255,255,255,.75);font-size:.72rem;display:flex;align-items:center;gap:5px;margin-top:2px}
.cb-dot{width:7px;height:7px;border-radius:50%;background:#4ade80;display:inline-block;animation:cbBlink 2s infinite;flex-shrink:0}
@keyframes cbBlink{0%,100%{opacity:1}50%{opacity:.3}}
.cb-x{margin-left:auto;opacity:.75;transition:opacity var(--tr)}
.cb-x:hover{opacity:1}
.cb-x svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round}
.cb-msgs{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px}
.cb-msg{max-width:84%;padding:10px 13px;border-radius:15px;font-size:.84rem;line-height:1.55;animation:cbIn .24s ease;word-break:break-word}
@keyframes cbIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.cb-msg.user{background:var(--red);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.cb-msg.bot{background:var(--cream);color:var(--brown);align-self:flex-start;border-bottom-left-radius:4px}
.cb-typing{display:flex;gap:5px;align-items:center;padding:4px 0}
.cb-typing span{width:8px;height:8px;background:var(--red);border-radius:50%;animation:cbDot 1.2s ease infinite}
.cb-typing span:nth-child(2){animation-delay:.22s}
.cb-typing span:nth-child(3){animation-delay:.44s}
@keyframes cbDot{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-8px)}}
.cb-footer{padding:10px 12px;border-top:1px solid #f0e8e0;display:flex;gap:8px;align-items:center;flex-shrink:0}
.cb-input{flex:1;padding:9px 14px;border:2px solid #e5d5c8;border-radius:50px;font-size:.84rem;outline:none;transition:border-color var(--tr);background:#fff;color:var(--brown)}
.cb-input:focus{border-color:var(--red)}
.cb-send{width:38px;height:38px;border-radius:50%;background:var(--red);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background var(--tr),transform var(--tr)}
.cb-send:hover{background:var(--red-d);transform:scale(1.09)}
.cb-send svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}

/* ── Quick View Modal ── */
.modal-bg{
  position:fixed;inset:0;z-index:1100;
  background:rgba(0,0,0,.58);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);
  display:flex;align-items:center;justify-content:center;padding:16px;
  opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;
}
.modal-bg.open{opacity:1;visibility:visible}
.modal-box{
  background:#fff;border-radius:var(--r-2xl);
  width:100%;max-width:760px;max-height:90vh;overflow-y:auto;
  position:relative;
  transform:scale(.9) translateY(20px);
  transition:transform .35s cubic-bezier(.175,.885,.32,1.275);
}
.modal-bg.open .modal-box{transform:none}
.modal-close{
  position:absolute;top:14px;right:14px;z-index:2;
  width:36px;height:36px;border-radius:50%;
  background:rgba(0,0,0,.07);
  display:flex;align-items:center;justify-content:center;transition:background var(--tr);
}
.modal-close:hover{background:rgba(0,0,0,.14)}
.modal-close svg{width:18px;height:18px;stroke:var(--brown);fill:none;stroke-width:2.5;stroke-linecap:round}

/* ── Footer ── */
.hod-footer{background:var(--brown);color:rgba(255,255,255,.8)}
.foot-wrap{max-width:1300px;margin:0 auto;padding:60px 24px 0}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.3fr;gap:44px}
.foot-logo{height:46px;width:auto;object-fit:contain;margin-bottom:14px}
.foot-tag{font-size:.875rem;line-height:1.7;color:rgba(255,255,255,.58);max-width:220px}
.foot-social{display:flex;gap:10px;margin-top:18px}
.soc{width:36px;height:36px;border-radius:9px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;transition:background var(--tr),transform var(--tr)}
.soc:hover{background:rgba(255,255,255,.22);transform:translateY(-2px)}
.soc svg{width:17px;height:17px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.foot-h{color:var(--gold);font-size:.72rem;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:16px}
.foot-links{display:flex;flex-direction:column;gap:10px}
.foot-links a{font-size:.875rem;color:rgba(255,255,255,.6);transition:color var(--tr)}
.foot-links a:hover{color:#fff}
.foot-contact{display:flex;flex-direction:column;gap:12px}
.foot-contact li{display:flex;align-items:flex-start;gap:10px}
.foot-contact svg{width:16px;height:16px;stroke:var(--gold);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;margin-top:2px}
.foot-contact span,.foot-contact a{font-size:.875rem;color:rgba(255,255,255,.6);line-height:1.5;transition:color var(--tr)}
.foot-contact a:hover{color:#fff}
.foot-bar{border-top:1px solid rgba(255,255,255,.1);margin-top:44px;padding:20px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.foot-bar span{font-size:.78rem;color:rgba(255,255,255,.36)}

/* ── Layout ── */
.container{max-width:1300px;margin:0 auto;padding:0 24px}
.section{padding:72px 0}
.section-sm{padding:48px 0}
.page-head{background:linear-gradient(155deg,var(--red) 0%,var(--red-d) 100%);padding:52px 24px 42px;text-align:center}
.page-head h1{font-family:var(--font-d);color:#fff;font-size:clamp(1.8rem,5vw,3rem);font-weight:700;margin-bottom:8px}
.page-head p{color:rgba(255,255,255,.78);font-size:clamp(.875rem,2vw,1rem)}
.card{background:#fff;border-radius:var(--r-lg);box-shadow:var(--sh-sm);overflow:hidden}
.card-body{padding:28px}

/* Filter chips */
.chip-row{display:flex;flex-wrap:wrap;gap:7px}
.chip,.f-chip{
  padding:7px 15px;border-radius:50px;border:2px solid #e5d5c8;
  font-size:.8rem;font-weight:700;cursor:pointer;
  background:#fff;color:var(--brown);
  transition:all var(--tr);white-space:nowrap;
}
.chip:hover,.chip.active,.f-chip:hover,.f-chip.active{background:var(--red);border-color:var(--red);color:#fff}

/* Range input */
input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:4px;border-radius:2px;background:#e5d5c8;outline:none;cursor:pointer}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--red);cursor:pointer;box-shadow:0 2px 8px rgba(197,40,42,.3)}
input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--red);cursor:pointer;border:none}

/* ── Auth pages ── */
.auth-wrap{
  min-height:calc(100vh - var(--nav-h));
  background:linear-gradient(150deg,var(--cream) 0%,var(--cream-d) 100%);
  display:flex;align-items:center;justify-content:center;
  padding:40px 20px;
  position:relative;overflow:hidden;
}
.auth-wrap::before{
  content:'';position:absolute;top:-100px;left:-100px;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(197,40,42,.06) 0%,transparent 70%);
  pointer-events:none;
}
.auth-wrap::after{
  content:'';position:absolute;bottom:-100px;right:-100px;
  width:350px;height:350px;border-radius:50%;
  background:radial-gradient(circle,rgba(212,168,83,.07) 0%,transparent 70%);
  pointer-events:none;
}
.auth-card{
  width:100%;max-width:460px;
  background:#fff;border-radius:28px;overflow:hidden;
  box-shadow:0 24px 72px rgba(92,45,10,.15);
  position:relative;z-index:1;
}
.auth-card-wide{max-width:540px}
.auth-header{
  background:linear-gradient(150deg,var(--red) 0%,var(--red-d) 100%);
  padding:40px 40px 32px;text-align:center;position:relative;overflow:hidden;
}
.auth-header::before{
  content:'';position:absolute;top:-30px;left:50%;transform:translateX(-50%);
  width:200px;height:200px;border-radius:50%;
  background:rgba(255,255,255,.05);
}
.auth-header-icon{
  width:72px;height:72px;border-radius:50%;
  background:rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;
  box-shadow:0 8px 24px rgba(0,0,0,.15);
  position:relative;z-index:1;
}
.auth-header-icon svg{width:38px;height:38px}
.auth-header h1{
  font-family:var(--font-d);color:#fff;font-size:1.7rem;
  font-weight:700;margin-bottom:6px;position:relative;z-index:1;
}
.auth-header p{color:rgba(255,255,255,.78);font-size:.88rem;position:relative;z-index:1}
.auth-body{padding:36px 36px 32px}
.auth-footer-text{
  text-align:center;margin-top:22px;
  color:var(--br-lt);font-size:.88rem;
}
.auth-footer-text a{color:var(--red);font-weight:700}
.auth-footer-text a:hover{text-decoration:underline}
.auth-divider{
  display:flex;align-items:center;gap:12px;margin:20px 0;
}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--cream-d)}
.auth-divider span{font-size:.75rem;color:var(--br-xs);font-weight:700;white-space:nowrap}

/* Input with icon */
.input-icon-wrap{position:relative}
.input-icon-wrap svg{
  position:absolute;left:14px;top:50%;transform:translateY(-50%);
  width:17px;height:17px;stroke:var(--br-xs);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
  pointer-events:none;transition:stroke var(--tr);
}
.input-icon-wrap .form-input,.input-icon-wrap .hod-input{padding-left:44px}
.input-icon-wrap:focus-within svg{stroke:var(--red)}

/* Two col form grid */
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* ── Responsive ── */
@media(max-width:1100px){.foot-grid{grid-template-columns:1fr 1fr;gap:32px}}

@media(max-width:900px){
  .nav-links{display:none}
  .nav-ham{display:flex}
  .nav-logo-text{display:none}
  .product-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
  .cart-layout{grid-template-columns:1fr}
  .cart-summary{position:static}
}

@media(max-width:768px){
  :root{--nav-h:62px}
  .nav-wrap{padding:0 16px;gap:8px}
  .nav-logo img{height:44px}
  .container{padding:0 16px}
  .section{padding:52px 0}
  .page-head{padding:40px 16px 32px}
  .foot-wrap{padding:44px 16px 0}
  .auth-body{padding:28px 24px 24px}
  .auth-header{padding:32px 28px 26px}
  .form-row-2{grid-template-columns:1fr}
}

@media(max-width:640px){
  .product-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .pc-body{padding:12px}
  .pc-name{font-size:.93rem}
  .pc-actions .btn{padding:8px 6px;font-size:.75rem;gap:4px}
  .foot-grid{grid-template-columns:1fr;gap:26px}
  .cart-item-row{flex-wrap:wrap;gap:12px}
}

@media(max-width:480px){
  .nav-icon{width:36px;height:36px}
  .nav-cart{width:36px;height:36px}
  .nav-user-btn{padding:7px 12px;font-size:.78rem}
  #cb-fab{bottom:16px;right:16px;width:56px;height:56px}
  #cb-panel{right:16px;bottom:82px;width:calc(100vw - 32px)}
  .auth-card{border-radius:20px}
}

@media(max-width:380px){
  .product-grid{grid-template-columns:1fr}
}

/* ── Animations ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes bounceIn{0%{transform:scale(.8);opacity:0}60%{transform:scale(1.06)}100%{transform:scale(1);opacity:1}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* AOS */
[data-aos]{opacity:0;transition-property:opacity,transform}
[data-aos=fade-up]{transform:translateY(28px)}
[data-aos=fade-right]{transform:translateX(-28px)}
[data-aos=fade-left]{transform:translateX(28px)}
[data-aos=zoom-in]{transform:scale(.88)}
[data-aos].aos-animate{opacity:1!important;transform:none!important}

/* Scrollbar */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#d4a89a;border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--red)}
*{scrollbar-width:thin;scrollbar-color:#d4a89a transparent}
::selection{background:rgba(197,40,42,.2);color:var(--brown)}
:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:4px}
@media print{.hod-nav,.hod-footer,#cb-fab,#cb-panel,#hod-loader,.mob-drawer{display:none!important}}

/* ── Additional keyframes for auth pages ── */
@keyframes float {
  0%,100%{transform:translateY(0) rotate(0deg)}
  33%{transform:translateY(-12px) rotate(3deg)}
  66%{transform:translateY(-6px) rotate(-2deg)}
}
@keyframes bounceIn {
  0%{opacity:0;transform:scale(.85) translateY(20px)}
  60%{transform:scale(1.03) translateY(-4px)}
  80%{transform:scale(.98)}
  100%{opacity:1;transform:scale(1) translateY(0)}
}

/* ── Product card action button text truncation fix ── */
.pc-actions .btn span { white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }

/* ── Ensure no ??? in cart thumbnails ── */
.cart-thumb-ph { background:linear-gradient(135deg,var(--cream-d),var(--cream-m)); }

/* ── Fix nav-right alignment: all items vertically centred ── */
.nav-right { align-items:center; }

/* ── Extra auth card perks section ── */
.auth-perks {
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
  padding:18px 36px 0;border-top:1px solid var(--cream-d);margin:0 -36px;
}
.auth-perk {
  text-align:center;padding:12px 8px;border-radius:12px;
  background:var(--cream);transition:background var(--tr);
}
.auth-perk-icon {
  width:36px;height:36px;border-radius:10px;
  background:linear-gradient(135deg,rgba(197,40,42,.1),rgba(197,40,42,.06));
  display:flex;align-items:center;justify-content:center;margin:0 auto 6px;
}
.auth-perk-icon svg { width:18px;height:18px;stroke:var(--red);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round; }
.auth-perk-text { font-size:.68rem;font-weight:700;color:var(--br-lt);line-height:1.3; }

/* Fix mobile: auth-perks */
@media(max-width:480px){
  .auth-perks { grid-template-columns:1fr;padding:16px 24px 0;margin:0 -24px; }
}
