/* ===== DESIGN TOKENS ===== */
:root {
  --ink:       #0F0D0A;
  --ink2:      #1E1A15;
  --gold:      #BF9B5A;
  --gold2:     #D4B483;
  --gold3:     #F0E0BB;
  --sand:      #F7F2EA;
  --cream:     #FDFBF7;
  --stone:     #E8E0D0;
  --mist:      #F2EDE4;
  --text:      #3D3427;
  --muted:     #9A8B7A;
  --border:    #E0D6C4;
  --white:     #FFFFFF;
  --success:   #4A7C59;
  --danger:    #B84040;
  --r:         0px;
  --shadow-sm: 0 2px 12px rgba(15,13,10,.06);
  --shadow:    0 8px 40px rgba(15,13,10,.12);
  --shadow-lg: 0 20px 80px rgba(15,13,10,.18);
  --transition: all .3s cubic-bezier(.4,0,.2,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Jost',sans-serif;
  background:var(--cream);
  color:var(--text);
  overflow-x:hidden;
  cursor:none;
}

/* ===== CUSTOM CURSOR ===== */
#cursor{
  width:10px;height:10px;
  border-radius:50%;
  background:var(--gold);
  position:fixed;pointer-events:none;
  z-index:99999;
  transform:translate(-50%,-50%);
  transition:transform .1s,width .2s,height .2s,background .2s;
}
#cursor-ring{
  width:36px;height:36px;
  border-radius:50%;
  border:1.5px solid var(--gold);
  position:fixed;pointer-events:none;
  z-index:99998;
  transform:translate(-50%,-50%);
  transition:transform .15s,width .3s,height .3s,opacity .3s;
  opacity:0.5;
}
body:hover #cursor{opacity:1}

/* ===== MARQUEE ===== */
.marquee-bar{
  background:var(--ink);
  color:var(--gold3);
  padding:10px 0;
  overflow:hidden;
  position:relative;
}
.marquee-track{
  display:flex;gap:60px;
  animation:marquee 22s linear infinite;
  white-space:nowrap;
}
.marquee-track span{
  font-size:11px;letter-spacing:3px;text-transform:uppercase;font-weight:300;
  display:flex;align-items:center;gap:16px;
}
.marquee-track span::after{content:'✦';color:var(--gold);font-size:9px}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== HEADER / NAV ===== */
header{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(253,251,247,.92);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  transition:var(--transition);
  width:100%;
  max-width:100%;
  overflow-x:clip;
}

header.scrolled{box-shadow:var(--shadow-sm)}

nav{
  max-width:1400px;
  margin:0 auto;
  padding:0 48px;
  height:72px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  width:100%;
  min-width:0;
}

.nav-logo{
  font-family:'Cormorant Garamond',serif;
  font-size:32px;
  font-weight:600;
  letter-spacing:6px;
  color:var(--ink);
  cursor:pointer;
  user-select:none;
  flex:0 1 auto;
  min-width:0;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.nav-logo span{color:var(--gold)}

.nav-links{
  display:flex;
  align-items:center;
  gap:40px;
  list-style:none;
  min-width:0;
}

.nav-links li a{
  font-size:12px;
  letter-spacing:2.5px;
  text-transform:uppercase;
  font-weight:500;
  color:var(--text);
  text-decoration:none;
  position:relative;
  padding-bottom:3px;
  cursor:pointer;
  transition:color .25s;
}

.nav-links li a::after{
  content:'';
  position:absolute;
  bottom:0;
  left:0;
  width:0;
  height:1px;
  background:var(--gold);
  transition:width .3s ease;
}

.nav-links li a:hover,
.nav-links li a.active{color:var(--gold)}

.nav-links li a:hover::after,
.nav-links li a.active::after{width:100%}

.nav-actions{
  display:flex;
  align-items:center;
  gap:12px;
  flex:0 0 auto;
  min-width:0;
}

.nav-icon{
  width:40px;
  height:40px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  color:var(--text);
  font-size:16px;
  border-radius:50%;
  transition:var(--transition);
  position:relative;
  flex:0 0 40px;
}

.nav-icon:hover{
  color:var(--gold);
  background:var(--sand);
}

.cart-count{
  position:absolute;
  top:4px;
  right:4px;
  width:17px;
  height:17px;
  background:var(--gold);
  color:var(--ink);
  font-size:9px;
  font-weight:700;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  border:2px solid var(--cream);
  transition:transform .3s;
}

.cart-count.bump{transform:scale(1.4)}

.hamburger{
  display:none;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
  padding:4px;
  flex:0 0 auto;
}

.hamburger span{
  width:22px;
  height:1.5px;
  background:var(--ink);
  transition:var(--transition);
  display:block;
}
.cart-actions-row {
  display: flex;
  justify-content: space-between;
  margin-top: 20px;
  flex-wrap: wrap;
  gap: 12px;
}

/* ===== CART MOBILE FIXES ===== */
@media (max-width: 992px) {
  .cart-layout {
    grid-template-columns: 1fr;
    gap: 28px;
    padding: 32px 20px;
  }

  .order-summary {
    position: static !important;
    top: auto !important;
    order: -1; /* move summary above cart items on tablet/mobile */
  }

  .cart-page-title {
    font-size: 34px;
  }
}

@media (max-width: 768px) {
  .cart-layout {
    padding: 24px 14px 40px;
    gap: 22px;
  }

  .cart-item-row {
    grid-template-columns: 72px 1fr;
    gap: 14px;
    padding: 16px 14px;
  }

  .cart-item-thumb {
    width: 72px;
    height: 92px;
    font-size: 34px;
  }

  .cart-item-right {
    grid-column: 1 / -1;
    text-align: left;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px 16px;
    padding-top: 6px;
  }

  .cart-item-name {
    font-size: 18px;
  }

  .cart-item-cat {
    font-size: 10px;
    letter-spacing: 1.5px;
  }

  .cart-item-attrs {
    gap: 8px;
  }

  .cart-item-attr {
    font-size: 11px;
    padding: 3px 8px;
  }

  .cart-item-price {
    font-size: 20px;
    margin-bottom: 0;
  }

  .qty-control {
    margin-bottom: 0;
  }

  .cart-page-title {
    font-size: 30px;
  }

  .cart-page-sub {
    font-size: 12px;
    margin-bottom: 24px;
  }

  .order-summary-header,
  .order-summary-body {
    padding-left: 18px;
    padding-right: 18px;
  }

  .coupon-row {
    flex-direction: column;
  }

  .coupon-input,
  .coupon-btn {
    width: 100%;
  }

   .cart-actions-row {
    flex-direction: column;
  }

  .cart-actions-row .btn-ghost {
    width: 100%;
    text-align: center;
    justify-content: center;
  }
}

@media (max-width: 560px) {
  .cart-layout {
    padding: 20px 12px 36px;
  }

  .cart-item-row {
    grid-template-columns: 64px 1fr;
    gap: 12px;
    padding: 14px 12px;
  }

  .cart-item-thumb {
    width: 64px;
    height: 82px;
    font-size: 28px;
  }

  .cart-item-name {
    font-size: 17px;
  }

  .cart-item-right {
    gap: 10px 12px;
  }

  .summary-row {
    font-size: 13px;
  }

  .summary-row.total {
    font-size: 20px;
  }
}

/* ===== MOBILE NAV ===== */
.mobile-menu{
  position:fixed;
  inset:0;
  z-index:2000;
  background:var(--cream);
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:32px;
  transform:translateY(-100%);
  transition:transform .4s cubic-bezier(.4,0,2,1);
  width:100vw;
  max-width:100vw;
  overflow-x:hidden;
}

.mobile-menu.open{transform:translateY(0)}

.mobile-menu a{
  font-family:'Cormorant Garamond',serif;
  font-size:36px;
  font-weight:300;
  color:var(--ink);
  cursor:pointer;
  text-decoration:none;
  letter-spacing:2px;
  transition:color .2s;
  max-width:90vw;
  text-align:center;
}

.mobile-menu a:hover{color:var(--gold)}

.mobile-close{
  position:absolute;
  top:24px;
  right:24px;
  font-size:24px;
  cursor:pointer;
  color:var(--muted);
  transition:color .2s;
}

.mobile-close:hover{color:var(--gold)}

/* ===== RESPONSIVE ===== */
@media (max-width:1024px){
  nav{
    padding:0 20px;
  }
}

@media (max-width:900px){
  .nav-links{
    display:none;
  }

  .hamburger{
    display:flex;
  }

  nav{
    padding:0 16px;
    gap:10px;
  }

  .nav-logo{
    font-size:24px;
    letter-spacing:3px;
    max-width:calc(100vw - 180px);
  }

  .nav-actions{
    gap:8px;
  }

  .nav-icon{
    width:36px;
    height:36px;
    font-size:15px;
    flex:0 0 36px;
  }
}

@media (max-width:560px){
  header{
    width:100%;
    max-width:100%;
  }

  nav{
    height:64px;
    padding:0 12px;
    gap:8px;
    width:100%;
  }

  .nav-logo{
    font-size:20px;
    letter-spacing:2px;
    max-width:calc(100vw - 140px);
  }

  .nav-actions{
    gap:6px;
  }

  .nav-icon{
    width:34px;
    height:34px;
    font-size:14px;
    flex:0 0 34px;
  }

  .cart-count{
    width:15px;
    height:15px;
    font-size:8px;
    top:2px;
    right:2px;
  }

  .nav-user{
    display:none;
  }

  .mobile-menu a{
    font-size:28px;
    letter-spacing:1px;
  }
  
}

.nav-account-mobile {
  display: none;
}

@media (max-width: 768px) {
  .nav-search {
    display: none !important;
  }

  #nav-guest,
  #nav-user {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .nav-account-mobile {
    display: flex !important;
  }

  nav {
    padding: 0 12px;
    gap: 8px;
  }

  .nav-actions {
    gap: 8px;
  }

  .nav-logo {
    font-size: 22px;
    letter-spacing: 2px;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .hero-text {
    padding: 0 !important;
  }
  
}

@media (max-width: 480px) {
  nav {
    padding: 0 10px;
  }

  .nav-logo {
    font-size: 20px;
    letter-spacing: 1.5px;
  }

  .nav-icon {
    width: 34px;
    height: 34px;
    font-size: 14px;
  }
}

/* ===== PAGES ===== */
page{display:none;animation:pageIn .4s ease both}
.page.active{display:block}
@keyframes pageIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* ===== HOME PAGE ===== */
/* Hero */
.hero{
  min-height:calc(100vh - 73px);
  display:grid;grid-template-columns:1fr 1fr;
  max-width:1400px;margin:0 auto;
  padding:0 48px;
  align-items:center;
  gap:0;
  position:relative;
}
.hero-text{padding:80px 0}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-size:11px;letter-spacing:4px;text-transform:uppercase;
  color:var(--gold);font-weight:500;margin-bottom:28px;
}
.hero-eyebrow::before{content:'';width:40px;height:1px;background:var(--gold)}
.hero-h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(56px,7vw,88px);
  line-height:1.02;
  color:var(--ink);
  font-weight:300;
  margin-bottom:28px;
}
.hero-h1 em{font-style:italic;color:var(--gold)}
.hero-desc{
  font-size:15px;line-height:1.8;color:var(--muted);
  max-width:440px;margin-bottom:44px;font-weight:300;
}
.hero-btns{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.btn-primary{
  padding:15px 40px;
  background:var(--ink);
  color:var(--gold3);
  font-family:'Jost',sans-serif;
  font-size:12px;letter-spacing:2.5px;text-transform:uppercase;
  font-weight:500;
  border:none;cursor:pointer;
  transition:var(--transition);
  position:relative;overflow:hidden;
}
.btn-primary::before{
  content:'';position:absolute;inset:0;
  background:var(--gold);
  transform:translateX(-101%);
  transition:transform .35s ease;
}
.btn-primary:hover::before{transform:translateX(0)}
.btn-primary span{position:relative;z-index:1}
.btn-primary:hover span{color:var(--ink)}
.btn-ghost{
  padding:14px 32px;
  background:transparent;
  color:var(--text);
  font-family:'Jost',sans-serif;
  font-size:12px;letter-spacing:2.5px;text-transform:uppercase;
  font-weight:500;
  border:1px solid var(--border);cursor:pointer;
  transition:var(--transition);
}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.hero-visual{
  position:relative;height:600px;
  display:flex;align-items:center;justify-content:center;
}
.hero-card-stack{position:relative;width:100%;height:100%}
.hero-card{
  position:absolute;
  border-radius:0;
  overflow:hidden;
  transition:transform .4s ease;
}
.hero-card-main{
  width:72%;height:78%;
  top:10%;left:14%;
  background:linear-gradient(160deg,var(--ink2) 0%,#3D2E1E 100%);
  display:flex;align-items:center;justify-content:center;
  font-size:110px;
  box-shadow:var(--shadow-lg);
  z-index:2;
}
.hero-card-accent{
  width:42%;height:42%;
  bottom:4%;right:0;
  background:var(--gold3);
  display:flex;align-items:flex-end;justify-content:flex-start;
  padding:24px;z-index:3;
  box-shadow:var(--shadow);
}
.hero-card-accent2{
  width:32%;height:30%;
  top:0;left:0;
  background:var(--sand);
  border:1px solid var(--border);
  z-index:1;
  display:flex;align-items:center;justify-content:center;
  font-size:40px;
}
.hero-card-tag{
  font-family:'Cormorant Garamond',serif;
  font-size:16px;font-weight:600;
  color:var(--ink);line-height:1.3;
}
.hero-scroll{
  position:absolute;bottom:40px;left:48px;
  display:flex;align-items:center;gap:12px;
  font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);
}
.hero-scroll::before{
  content:'';width:40px;height:1px;background:var(--muted);
}

/* Categories Strip */
.cats-strip{
  background:var(--sand);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:48px 0;overflow:hidden;
}
.cats-strip-inner{
  max-width:1400px;margin:0 auto;padding:0 48px;
}
.cats-strip-title{
  font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--muted);
  margin-bottom:28px;font-weight:400;
}
.cats-row{
  display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;
  scrollbar-width:none;
}
.cats-row::-webkit-scrollbar{display:none}
.cat-chip{
  flex-shrink:0;
  padding:10px 28px;
  border:1px solid var(--border);
  font-size:12px;letter-spacing:2px;text-transform:uppercase;
  cursor:pointer;transition:var(--transition);
  background:var(--cream);color:var(--text);font-weight:400;
}
.cat-chip:hover,.cat-chip.active{
  background:var(--ink);color:var(--gold3);border-color:var(--ink);
}

/* Featured Products */
.section{
  max-width:1400px;margin:0 auto;
  padding:80px 48px;
}
.section-header{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:48px;
}
.section-label{
  font-size:11px;letter-spacing:4px;text-transform:uppercase;
  color:var(--gold);font-weight:400;margin-bottom:12px;
}
.section-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(36px,4vw,52px);
  font-weight:300;color:var(--ink);line-height:1.1;
}
.section-title em{font-style:italic}
.view-all-link{
  font-size:12px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--gold);font-weight:500;cursor:pointer;
  display:flex;align-items:center;gap:8px;
  border-bottom:1px solid var(--gold);padding-bottom:2px;
  text-decoration:none;transition:var(--transition);
}
.view-all-link:hover{color:var(--text);border-color:var(--text)}

/* Product Grid */
.product-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(270px,1fr));
  gap:28px;
}
.product-card{
  cursor:pointer;
  group:true;
}
.product-card-img{
  aspect-ratio:3/4;
  background:var(--sand);
  position:relative;overflow:hidden;
  margin-bottom:18px;
  display:flex;align-items:center;justify-content:center;
  font-size:80px;
}
.product-card-img-bg{
  position:absolute;inset:0;
  transition:transform .6s ease;
}
.product-card:hover .product-card-img-bg{transform:scale(1.05)}
.product-card-emoji{
  position:relative;z-index:1;
  font-size:80px;
  transition:transform .4s ease;
}
.product-card:hover .product-card-emoji{transform:scale(1.1) translateY(-6px)}
.product-card-overlay{
  position:absolute;inset:0;
  background:rgba(15,13,10,.0);
  display:flex;align-items:flex-end;justify-content:center;
  padding:20px;
  transition:background .3s;
  z-index: 3;
}
.product-card:hover .product-card-overlay{background:rgba(15,13,10,.25)}
.product-card-actions{
  display:flex;gap:10px;
  transform:translateY(20px);
  opacity:0;
  transition:all .3s ease;
}
.product-card:hover .product-card-actions{transform:translateY(0);opacity:1}
.pca-btn{
  flex:1;padding:12px 16px;
  font-family:'Jost',sans-serif;
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  font-weight:500;border:none;cursor:pointer;
  transition:var(--transition);
}
.pca-add{background:var(--gold3);color:var(--ink)}
.pca-add:hover{background:var(--gold)}
.pca-wish{
  width:44px;height:44px;flex:none;
  background:var(--cream);color:var(--text);
  display:flex;align-items:center;justify-content:center;
}
.pca-wish:hover{color:var(--danger)}
.product-card-badge{
  position:absolute;top:14px;left:14px;
  padding:4px 12px;
  font-size:10px;letter-spacing:2px;text-transform:uppercase;font-weight:600;
  z-index:2;
}
.badge-new{background:var(--ink);color:var(--gold3)}
.badge-sale{background:var(--gold);color:var(--ink)}
.badge-sold{background:var(--stone);color:var(--text)}
.product-card-info{padding:0 4px}
.product-cat{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.product-name{
  font-family:'Cormorant Garamond',serif;
  font-size:20px;font-weight:400;color:var(--ink);
  margin-bottom:10px;line-height:1.2;
}
.product-price-row{display:flex;align-items:center;gap:10px}
.product-price{
  font-family:'Cormorant Garamond',serif;
  font-size:22px;font-weight:600;color:var(--ink);
}
.product-price-old{font-size:14px;color:var(--muted);text-decoration:line-through}
.product-rating{
  display:flex;align-items:center;gap:4px;
  font-size:11px;color:var(--gold);margin-top:6px;
}
.product-rating span{color:var(--muted)}

/* Promise Strip */
.promise-strip{
  background:var(--ink);
  padding:60px 48px;
}
.promise-strip-inner{
  max-width:1400px;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:40px;
}
.promise-item{text-align:center}
.promise-icon{
  font-size:28px;margin-bottom:16px;
  display:block;
}
.promise-title{
  font-family:'Cormorant Garamond',serif;
  font-size:18px;color:var(--gold3);margin-bottom:6px;
}
.promise-text{font-size:13px;color:rgba(240,224,187,.5);line-height:1.6;font-weight:300}

/* Testimonials */
.testimonials-wrap{
  background:var(--sand);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.testimonials{
  max-width:1400px;margin:0 auto;
  padding:80px 48px;
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:40px;
}
.testimonial-card{
  background:var(--cream);
  padding:36px 32px;
  border:1px solid var(--border);
  position:relative;
}
.testimonial-card::before{
  content:'"';
  font-family:'Cormorant Garamond',serif;
  font-size:80px;
  color:var(--gold3);
  position:absolute;top:16px;left:28px;
  line-height:1;
}
.testimonial-text{
  font-family:'Cormorant Garamond',serif;
  font-size:17px;line-height:1.7;color:var(--text);
  margin-top:32px;font-style:italic;
}
.testimonial-author{
  margin-top:20px;
  display:flex;align-items:center;gap:12px;
}
.testimonial-avatar{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold2),var(--gold));
  display:flex;align-items:center;justify-content:center;
  font-weight:600;font-size:14px;color:var(--ink);
}
.testimonial-name{font-size:13px;font-weight:500;color:var(--ink)}
.testimonial-stars{color:var(--gold);font-size:12px;margin-top:2px}

/* ===== SHOP PAGE ===== */
.shop-layout{
  max-width:1400px;margin:0 auto;
  padding:48px;
  display:grid;grid-template-columns:260px 1fr;
  gap:48px;
  align-items:start;
}
/* Filter Sidebar */
.filter-sidebar{}
.filter-section{
  padding:24px 0;
  border-bottom:1px solid var(--border);
}
.filter-section:first-child{padding-top:0}
.filter-title{
  font-size:11px;letter-spacing:3px;text-transform:uppercase;
  font-weight:600;color:var(--ink);
  margin-bottom:18px;
  display:flex;align-items:center;justify-content:space-between;
  cursor:pointer;
}
.filter-options{display:flex;flex-direction:column;gap:10px}
.filter-opt{
  display:flex;align-items:center;gap:10px;cursor:pointer;
  font-size:14px;color:var(--text);transition:color .2s;
}
.filter-opt:hover{color:var(--gold)}
.filter-opt input[type=checkbox]{
  width:15px;height:15px;
  accent-color:var(--gold);cursor:pointer;
}
/* .price-inputs{display:flex;gap:8px;align-items:center;max-width: 100%;flex-wrap: nowrap;}

.price-input{
  flex:1;padding:8px 12px;
  border:1px solid var(--border);
  font-family:'Jost',sans-serif;font-size:13px;
  background:var(--cream);color:var(--text);outline:none;
} */

.price-inputs {
    display: flex;
    align-items: center;
    gap: 8px;               /* space between inputs and dash */
    flex-wrap: nowrap;       /* prevent wrapping if you want single line */
    max-width: 100%;         /* ensure it doesn’t overflow parent */
}

.price-input {
    flex: 1 1 0;            /* grow/shrink proportionally */
    min-width: 0;           /* prevents overflow in flex containers */
    padding: 8px 12px;
    border:1px solid var(--border);
    font-family:'Jost',sans-serif;font-size:13px;
    background:var(--cream);color:var(--text);outline:none;
}

.price-input:focus{border-color:var(--gold)}
.color-dots{display:flex;flex-wrap:wrap;gap:8px}
.color-dot{
  width:24px;height:24px;border-radius:50%;
  cursor:pointer;border:2px solid transparent;
  transition:border-color .2s;
}
.color-dot:hover,.color-dot.active{border-color:var(--gold)}

/* Shop Main */
.shop-main{
  min-width:0;
  width:100%;
  overflow:hidden;
}
.shop-search input{
  min-width:0;
  width:100%;
}

.shop-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:32px;padding-bottom:20px;
  border-bottom:1px solid var(--border);
  flex-wrap:wrap;gap:14px;
}
.shop-count{font-size:13px;color:var(--muted);font-weight:300}
.shop-right{display:flex;align-items:center;gap:16px}
.sort-select{
  padding:8px 14px;
  border:1px solid var(--border);
  font-family:'Jost',sans-serif;font-size:13px;
  color:var(--text);background:var(--cream);
  outline:none;cursor:pointer;
}
.sort-select:focus{border-color:var(--gold)}
.grid-toggle{display:flex;gap:4px}
.grid-btn{
  width:34px;height:34px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--border);cursor:pointer;
  background:transparent;color:var(--muted);
  font-size:13px;transition:var(--transition);
}
.grid-btn.active,.grid-btn:hover{background:var(--ink);color:var(--gold3);border-color:var(--ink)}

/* Shop search bar */
.shop-search{
  display:flex;align-items:center;
  border:1px solid var(--border);
  background:var(--cream);
  padding:0 14px;gap:10px;
  margin-bottom:24px;
}
.shop-search input{
  flex:1;padding:12px 0;
  border:none;background:transparent;
  font-family:'Jost',sans-serif;font-size:14px;
  color:var(--text);outline:none;
}
.shop-search i{color:var(--muted);font-size:14px}

/* ===== ABOUT PAGE ===== */
.about-hero{
  background:var(--ink);
  padding:100px 48px;
  text-align:center;
  position:relative;overflow:hidden;
}
.about-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 100%,rgba(191,155,90,.18) 0%,transparent 60%);
}
.about-hero-tag{
  font-size:11px;letter-spacing:5px;text-transform:uppercase;
  color:var(--gold);margin-bottom:20px;font-weight:400;
}
.about-hero-h{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(48px,6vw,80px);
  color:var(--cream);font-weight:300;line-height:1.1;
  margin-bottom:24px;
}
.about-hero-h em{font-style:italic;color:var(--gold2)}
.about-hero-p{
  font-size:16px;color:rgba(253,251,247,.6);
  max-width:560px;margin:0 auto;
  font-weight:300;line-height:1.8;
}
.about-body{max-width:1400px;margin:0 auto;padding:80px 48px}
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
  margin-bottom:80px;
}
.about-visual{
  aspect-ratio:4/5;
  background:linear-gradient(160deg,var(--sand),var(--stone));
  display:flex;align-items:center;justify-content:center;
  font-size:120px;
  border:1px solid var(--border);
}
.about-content{}
.about-label{
  font-size:10px;letter-spacing:4px;text-transform:uppercase;
  color:var(--gold);margin-bottom:16px;
}
.about-h{
  font-family:'Cormorant Garamond',serif;
  font-size:44px;font-weight:300;color:var(--ink);
  line-height:1.15;margin-bottom:24px;
}
.about-h em{font-style:italic}
.about-p{
  font-size:15px;line-height:1.9;color:var(--muted);
  font-weight:300;margin-bottom:18px;
}
.about-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:32px;
  padding:40px 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  margin:40px 0;
}
.about-stat-n{
  font-family:'Cormorant Garamond',serif;
  font-size:48px;font-weight:600;color:var(--gold);
  line-height:1;
}
.about-stat-l{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-top:6px}
.team-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:32px;margin-top:40px;
}
.team-card{text-align:center}
.team-avatar{
  width:100%;aspect-ratio:1;
  background:linear-gradient(160deg,var(--sand),var(--stone));
  display:flex;align-items:center;justify-content:center;
  font-size:60px;margin-bottom:16px;
  border:1px solid var(--border);
}
.team-name{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--ink)}
.team-role{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-top:4px}

/* ===== CONTACT PAGE ===== */
.contact-layout{
  max-width:1400px;margin:0 auto;
  padding:80px 48px;
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;
}
.contact-info{}
.contact-info-label{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.contact-info-h{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(36px,4vw,52px);color:var(--ink);font-weight:300;
  line-height:1.1;margin-bottom:24px;
}
.contact-info-p{font-size:15px;color:var(--muted);line-height:1.8;font-weight:300;margin-bottom:40px}
.contact-items{display:flex;flex-direction:column;gap:24px}
.contact-item{display:flex;gap:18px;align-items:flex-start}
.contact-item-icon{
  width:46px;height:46px;flex-shrink:0;
  background:var(--sand);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold);font-size:16px;
}
.contact-item-label{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.contact-item-val{font-size:15px;color:var(--ink);font-weight:400}
.contact-form{
  background:var(--sand);
  border:1px solid var(--border);
  padding:48px 44px;
}
.contact-form-h{
  font-family:'Cormorant Garamond',serif;
  font-size:28px;color:var(--ink);margin-bottom:32px;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{margin-bottom:20px}
.form-label{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:8px;display:block;font-weight:500}
.form-input{
  width:100%;padding:12px 16px;
  border:1px solid var(--border);
  background:var(--cream);
  font-family:'Jost',sans-serif;font-size:14px;
  color:var(--text);outline:none;
  transition:border-color .25s;
}
.form-input:focus{border-color:var(--gold)}
textarea.form-input{resize:vertical;min-height:120px}
.social-links{display:flex;gap:12px;margin-top:32px}
.social-link{
  width:40px;height:40px;
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);font-size:15px;cursor:pointer;
  transition:var(--transition);
}
.social-link:hover{background:var(--ink);color:var(--gold3);border-color:var(--ink)}

/* ===== CART PAGE ===== */
.cart-layout{
  max-width:1200px;margin:0 auto;
  padding:60px 48px;
  display:grid;grid-template-columns:1fr 360px;
  gap:48px;
  align-items:start;
}
.cart-main{}
.cart-page-title{
  font-family:'Cormorant Garamond',serif;
  font-size:42px;font-weight:300;color:var(--ink);
  margin-bottom:8px;
}
.cart-page-sub{font-size:13px;color:var(--muted);margin-bottom:36px;letter-spacing:0.5px}
.cart-empty{
  text-align:center;padding:80px 40px;
  border:1px solid var(--border);background:var(--sand);
}
.cart-empty-icon{font-size:56px;margin-bottom:20px;display:block;opacity:.5}
.cart-empty h3{font-family:'Cormorant Garamond',serif;font-size:28px;color:var(--ink);margin-bottom:10px}
.cart-empty p{font-size:14px;color:var(--muted);margin-bottom:28px}
.cart-items{border:1px solid var(--border)}
.cart-item-row{
  display:grid;grid-template-columns:88px 1fr auto;
  gap:20px;align-items:center;
  padding:20px 24px;
  border-bottom:1px solid var(--border);
  transition:background .2s;
}
.cart-item-row:last-child{border-bottom:none}
.cart-item-row:hover{background:var(--sand)}
.cart-item-thumb{
  width:88px;height:110px;
  background:var(--sand);
  display:flex;align-items:center;justify-content:center;
  font-size:44px;border:1px solid var(--border);
  flex-shrink:0;
}
.cart-item-details{}
.cart-item-name{
  font-family:'Cormorant Garamond',serif;
  font-size:20px;color:var(--ink);margin-bottom:4px;
}
.cart-item-cat{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.cart-item-attrs{display:flex;gap:16px;flex-wrap:wrap}
.cart-item-attr{
  font-size:12px;color:var(--text);
  border:1px solid var(--border);
  padding:3px 10px;
}
.cart-item-right{text-align:right}
.cart-item-price{
  font-family:'Cormorant Garamond',serif;
  font-size:22px;color:var(--ink);
  margin-bottom:14px;font-weight:600;
}
.qty-control{
  display:inline-flex;align-items:center;
  border:1px solid var(--border);
  margin-bottom:14px;
}
.qty-btn2{
  width:36px;height:36px;
  background:transparent;border:none;
  cursor:pointer;font-size:16px;color:var(--text);
  transition:var(--transition);
  display:flex;align-items:center;justify-content:center;
}
.qty-btn2:hover{background:var(--gold);color:var(--ink)}
.qty-val{
  width:40px;text-align:center;
  font-size:14px;font-weight:500;
  border-left:1px solid var(--border);
  border-right:1px solid var(--border);
  height:36px;line-height:36px;
}
.remove-btn{
  font-size:11px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--muted);cursor:pointer;
  border:none;background:transparent;
  font-family:'Jost',sans-serif;
  transition:color .2s;
}
.remove-btn:hover{color:var(--danger)}

/* Order Summary (cart sidebar) */
.order-summary{
  border:1px solid var(--border);
  background:var(--sand);
  position:sticky;top:100px;
}
.order-summary-header{
  padding:24px 28px;
  border-bottom:1px solid var(--border);
  background:var(--ink);
}
.order-summary-header h3{
  font-family:'Cormorant Garamond',serif;
  font-size:22px;color:var(--gold3);font-weight:300;
}
.order-summary-body{padding:28px}
.summary-row{
  display:flex;justify-content:space-between;
  font-size:14px;margin-bottom:14px;
}
.summary-row.total{
  padding-top:16px;margin-top:8px;
  border-top:1px solid var(--border);
  font-family:'Cormorant Garamond',serif;
  font-size:22px;font-weight:600;color:var(--ink);
}
.coupon-row{display:flex;gap:8px;margin:20px 0}
.coupon-input{
  flex:1;padding:10px 14px;
  border:1px solid var(--border);background:var(--cream);
  font-family:'Jost',sans-serif;font-size:13px;
  color:var(--text);outline:none;
}
.coupon-input:focus{border-color:var(--gold)}
.coupon-btn{
  padding:10px 18px;
  background:var(--ink);color:var(--gold3);
  border:none;cursor:pointer;
  font-family:'Jost',sans-serif;font-size:12px;
  letter-spacing:1.5px;text-transform:uppercase;
  transition:var(--transition);
}
.coupon-btn:hover{background:var(--gold);color:var(--ink)}

/* ===== ORDERS PAGE ===== */
.orders-wrap{max-width:900px;margin:0 auto;padding:60px 48px}
.orders-title{
  font-family:'Cormorant Garamond',serif;
  font-size:42px;font-weight:300;color:var(--ink);margin-bottom:32px;
}
.orders-empty{
  text-align:center;padding:80px;
  border:1px solid var(--border);background:var(--sand);
}
.order-card{
  border:1px solid var(--border);
  margin-bottom:16px;overflow:hidden;
  transition:box-shadow .25s;
}
.order-card:hover{box-shadow:var(--shadow-sm)}
.order-card-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px;
  background:var(--sand);
  border-bottom:1px solid var(--border);
  flex-wrap:wrap;gap:12px;
}
.order-id{font-size:13px;font-weight:600;letter-spacing:1px;color:var(--ink)}
.order-date{font-size:12px;color:var(--muted)}
.order-status{
  padding:5px 14px;
  font-size:10px;letter-spacing:2px;text-transform:uppercase;font-weight:600;
}
.status-processing{background:rgba(191,155,90,.15);color:#8B6914}
.status-shipped{background:rgba(41,128,185,.12);color:#1A5276}
.status-delivered{background:rgba(74,124,89,.15);color:var(--success)}
.status-cancelled{background:rgba(184,64,64,.1);color:var(--danger)}
.order-card-body{padding:18px 24px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.order-thumb{
  width:56px;height:70px;
  background:var(--sand);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:26px;flex-shrink:0;
}
.order-item-info{flex:1}
.order-item-name{font-size:15px;color:var(--ink);font-weight:400}
.order-item-meta{font-size:12px;color:var(--muted);margin-top:3px}
.order-total{
  font-family:'Cormorant Garamond',serif;
  font-size:24px;font-weight:600;color:var(--ink);margin-left:auto;
}
.order-card-footer{
  padding:14px 24px;
  border-top:1px solid var(--border);
  background:var(--cream);
  display:flex;align-items:center;justify-content:flex-end;gap:10px;
}
.btn-sm-outline{
  padding:8px 20px;
  border:1px solid var(--border);background:transparent;
  font-family:'Jost',sans-serif;font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:var(--text);cursor:pointer;transition:var(--transition);
}
.btn-sm-outline:hover{border-color:var(--gold);color:var(--gold)}
.btn-sm-gold{
  padding:8px 20px;
  background:var(--gold);color:var(--ink);
  border:none;
  font-family:'Jost',sans-serif;font-size:11px;letter-spacing:2px;text-transform:uppercase;
  font-weight:600;cursor:pointer;transition:var(--transition);
}
.btn-sm-gold:hover{background:var(--ink);color:var(--gold3)}

/* ===== CHECKOUT PAGE ===== */
.checkout-layout{
  max-width:1200px;margin:0 auto;
  padding:60px 48px;
  display:grid;grid-template-columns:1fr 380px;
  gap:48px;align-items:start;
}
.checkout-steps{display:flex;align-items:center;gap:0;margin-bottom:40px}
.ck-step{
  display:flex;align-items:center;gap:10px;
  font-size:12px;letter-spacing:2px;text-transform:uppercase;
  color:var(--muted);font-weight:500;
}
.ck-step-num{
  width:28px;height:28px;border-radius:50%;
  background:var(--stone);color:var(--muted);
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;flex-shrink:0;
  transition:var(--transition);
}
.ck-step.active .ck-step-num{background:var(--gold);color:var(--ink)}
.ck-step.done .ck-step-num{background:var(--success);color:var(--cream)}
.ck-step.active{color:var(--ink)}
.ck-divider{flex:1;height:1px;background:var(--border);margin:0 16px}
.ck-divider.done{background:var(--gold)}
.checkout-section{margin-bottom:36px}
.checkout-section-title{
  font-family:'Cormorant Garamond',serif;
  font-size:26px;color:var(--ink);margin-bottom:20px;
  padding-bottom:14px;border-bottom:1px solid var(--border);
}
.ck-method-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}
.ck-method{
  padding:16px;border:1.5px solid var(--border);
  cursor:pointer;text-align:center;transition:var(--transition);
}
.ck-method.active{border-color:var(--gold);background:rgba(191,155,90,.05)}
.ck-method i{font-size:22px;color:var(--muted);margin-bottom:8px;display:block;transition:color .2s}
.ck-method.active i{color:var(--gold)}
.ck-method-label{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text)}
.ck-order-item{
  display:flex;align-items:center;gap:14px;
  padding:14px 0;border-bottom:1px solid var(--border);
}
.ck-item-thumb{
  width:56px;height:70px;
  background:var(--sand);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:28px;flex-shrink:0;position:relative;
}
.ck-qty-badge{
  position:absolute;top:-6px;right:-6px;
  width:18px;height:18px;
  background:var(--gold);color:var(--ink);
  border-radius:50%;font-size:10px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}
.ck-item-name{font-size:14px;color:var(--ink);flex:1}
.ck-item-price{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--ink);font-weight:600}
.ck-summary-totals{margin:16px 0}
.ck-row{display:flex;justify-content:space-between;font-size:14px;margin-bottom:10px;color:var(--text)}
.ck-row.total{
  font-family:'Cormorant Garamond',serif;font-size:24px;
  color:var(--ink);font-weight:600;
  padding-top:14px;margin-top:6px;
  border-top:1px solid var(--border);
}
.checkout-nav{display:flex;gap:14px;justify-content:space-between;margin-top:36px}

/* Success */
.order-success{
  max-width:600px;margin:80px auto;
  padding:0 48px;text-align:center;
}
.success-icon{
  width:80px;height:80px;
  background:var(--success);color:white;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:34px;margin:0 auto 32px;
  animation:successPop .6s ease both;
}
@keyframes successPop{
  0%{transform:scale(0)}
  70%{transform:scale(1.15)}
  100%{transform:scale(1)}
}
.success-h{
  font-family:'Cormorant Garamond',serif;
  font-size:44px;color:var(--ink);margin-bottom:14px;font-weight:300;
}
.success-p{font-size:15px;color:var(--muted);line-height:1.8;margin-bottom:36px}
.success-order-num{
  display:inline-block;
  background:var(--sand);border:1px solid var(--border);
  padding:12px 32px;
  font-size:13px;letter-spacing:3px;text-transform:uppercase;
  color:var(--gold-dark,var(--gold));
  margin-bottom:36px;font-weight:600;
}


/* ===== CHECKOUT MOBILE FIXES ===== */
@media (max-width: 992px) {
  .checkout-layout {
    grid-template-columns: 1fr;
    gap: 28px;
    padding: 32px 20px;
  }

  .order-summary {
    position: static !important;
    top: auto !important;
    order: -1; /* show summary before form on tablet/mobile if preferred */
  }

  .checkout-steps {
    flex-wrap: wrap;
    row-gap: 10px;
    column-gap: 8px;
    margin-bottom: 28px;
  }

  .ck-divider {
    min-width: 24px;
    flex: 0 0 24px;
    margin: 0 4px;
  }

  .checkout-section-title {
    font-size: 22px;
    margin-bottom: 16px;
  }

  .ck-method-grid {
    grid-template-columns: 1fr;
  }

  .checkout-nav {
    flex-wrap: wrap;
    gap: 12px;
  }

  .checkout-nav .btn-ghost,
  .checkout-nav .btn-primary {
    width: 100%;
    justify-content: center;
    text-align: center;
  }
}

@media (max-width: 768px) {
  .checkout-layout {
    padding: 24px 14px 40px;
    gap: 22px;
  }

  .form-row {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .checkout-steps {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    align-items: stretch;
  }

  .ck-step {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--border);
    background: var(--white);
  }

  .ck-divider {
    display: none;
  }

  .ck-step-num {
    width: 24px;
    height: 24px;
    font-size: 11px;
  }

  .checkout-section {
    margin-bottom: 24px;
  }

  .checkout-section-title {
    font-size: 20px;
    padding-bottom: 10px;
  }

  .ck-method {
    padding: 14px;
  }

  .ck-method i {
    font-size: 18px;
    margin-bottom: 6px;
  }

  .ck-method-label {
    font-size: 11px;
    letter-spacing: 1.2px;
  }

  .order-summary {
    margin-top: 0;
  }

  .order-summary-header,
  .order-summary-body {
    padding-left: 18px;
    padding-right: 18px;
  }

  .ck-order-item {
    gap: 10px;
    align-items: flex-start;
  }

  .ck-item-thumb {
    width: 48px;
    height: 60px;
    font-size: 22px;
  }

  .ck-item-name {
    font-size: 13px;
    line-height: 1.4;
  }

  .ck-item-price {
    font-size: 16px;
  }

  .ck-row {
    font-size: 13px;
  }

  .ck-row.total {
    font-size: 20px;
  }

  .success-h {
    font-size: 32px;
  }

  .success-p {
    font-size: 14px;
  }
}

@media (max-width: 560px) {
  .checkout-layout {
    padding: 20px 12px 36px;
  }

  .checkout-section-title {
    font-size: 18px;
  }

  .checkout-nav {
    flex-direction: column;
  }

  .checkout-nav .btn-ghost,
  .checkout-nav .btn-primary {
    width: 100%;
  }

  .order-summary {
    border-width: 1px;
  }

  .ck-summary-totals {
    margin: 12px 0;
  }
}

/* ===== FOOTER ===== */
footer{
  background:var(--ink);
  padding:80px 48px 40px;
  margin-top:60px;
}
.footer-inner{
  max-width:1400px;margin:0 auto;
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:48px;margin-bottom:60px;
}
.footer-brand h2{
  font-family:'Cormorant Garamond',serif;
  font-size:36px;color:var(--gold2);letter-spacing:5px;margin-bottom:16px;
}
.footer-brand p{font-size:14px;color:rgba(253,251,247,.45);line-height:1.8;font-weight:400;max-width:280px}
.footer-col-title{
  font-size:10px;letter-spacing:3.5px;text-transform:uppercase;
  color:var(--gold);margin-bottom:20px;font-weight:500;
}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-links li a{
  font-size:14px;color:rgba(253,251,247,.45);
  text-decoration:none;cursor:pointer;
  transition:color .2s;font-weight:400;
}
.footer-links li a:hover{color:var(--gold2)}
.footer-bottom{
  max-width:1400px;margin:0 auto;
  border-top:1px solid rgba(191,155,90,.15);
  padding-top:28px;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:12px;
}
.footer-copy{font-size:12px;color:rgba(253,251,247,.3);font-weight:300}

/* ===== TOAST ===== */
.toasts{
  position:fixed;bottom:28px;right:28px;z-index:9999;
  display:flex;flex-direction:column;gap:10px;
}
.toast{
  background:var(--ink);color:var(--cream);
  padding:14px 20px;
  border-left:3px solid var(--gold);
  font-size:13px;max-width:300px;
  animation:toastIn .3s ease both;
  display:flex;align-items:center;gap:12px;
  box-shadow:var(--shadow);
}
.toast.success{border-color:var(--success)}
.toast.danger{border-color:var(--danger)}
@keyframes toastIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}


/* ===== PRODUCT DETAIL PAGE ===== */
.pdp-shell{
  max-width:1320px;margin:0 auto;
  padding:48px 48px 80px;
}
/* Breadcrumb */
.pdp-breadcrumb{
  display:flex;align-items:center;gap:8px;
  font-size:12px;letter-spacing:0.5px;
  color:var(--muted);margin-bottom:36px;
}
.pdp-breadcrumb a{color:var(--muted);cursor:pointer;text-decoration:none;transition:color .2s}
.pdp-breadcrumb a:hover{color:var(--gold)}
.pdp-breadcrumb span{color:var(--border)}

/* Main layout */
.pdp-main{
  display:grid;
  grid-template-columns:1fr 480px;
  gap:60px;
  margin-bottom:80px;
}

/* ── Gallery ── */
.pdp-gallery{}
.pdp-gallery-main{
  position:relative;
  aspect-ratio:3/4;
  background:var(--sand);
  overflow:hidden;
  margin-bottom:14px;
  border:1px solid var(--border);
}
.pdp-gallery-main img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .6s ease, opacity .35s ease;
  cursor:zoom-in;
}
.pdp-gallery-main:hover img{transform:scale(1.04)}
/* zoom overlay */
.pdp-zoom-overlay{
  position:fixed;inset:0;z-index:8000;
  background:rgba(15,13,10,.92);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .3s;
  cursor:zoom-out;
}
.pdp-zoom-overlay.open{opacity:1;pointer-events:all}
.pdp-zoom-overlay img{
  max-width:85vw;max-height:88vh;
  object-fit:contain;
  border:1px solid rgba(191,155,90,.2);
  box-shadow:var(--shadow-lg);
}
.pdp-zoom-close{
  position:absolute;top:24px;right:28px;
  color:var(--gold3);font-size:22px;cursor:pointer;
  transition:color .2s;z-index:1;
}
.pdp-zoom-close:hover{color:var(--gold)}
/* Badge on main */
.pdp-main-badge{
  position:absolute;top:18px;left:18px;z-index:2;
  padding:5px 14px;
  font-size:10px;letter-spacing:2.5px;text-transform:uppercase;font-weight:700;
}
/* Nav arrows */
.pdp-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:42px;height:42px;
  background:rgba(253,251,247,.9);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:2;
  font-size:14px;color:var(--text);
  transition:var(--transition);
  backdrop-filter:blur(4px);
}
.pdp-arrow:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.pdp-arrow-prev{left:14px}
.pdp-arrow-next{right:14px}
/* Thumbnails */
.pdp-thumbs{
  display:flex;gap:10px;
  overflow-x:auto;
  scrollbar-width:none;
  padding-bottom:4px;
}
.pdp-thumbs::-webkit-scrollbar{display:none}
.pdp-thumb{
  flex-shrink:0;
  width:80px;height:100px;
  background:var(--sand);
  border:2px solid transparent;
  overflow:hidden;cursor:pointer;
  transition:border-color .2s;
  display:flex;align-items:center;justify-content:center;
}
.pdp-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.pdp-thumb:hover img{transform:scale(1.08)}
.pdp-thumb.active{border-color:var(--gold)}
/* Placeholder when no real image */
.pdp-img-placeholder{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  font-size:90px;
  background:linear-gradient(160deg,var(--sand),var(--stone));
}
.pdp-thumb-placeholder{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  font-size:28px;
  background:linear-gradient(160deg,var(--sand),var(--cream));
}

/* ── Product Info Panel ── */
.pdp-info{position:sticky;top:100px}
.pdp-cat{
  font-size:10px;letter-spacing:4px;text-transform:uppercase;
  color:var(--gold);font-weight:500;margin-bottom:10px;
}
.pdp-name{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(32px,3.5vw,44px);
  font-weight:300;color:var(--ink);
  line-height:1.1;margin-bottom:14px;
}
.pdp-rating-row{
  display:flex;align-items:center;gap:12px;
  margin-bottom:20px;
}
.pdp-stars{color:var(--gold);font-size:14px;letter-spacing:1px}
.pdp-rating-count{font-size:13px;color:var(--muted);cursor:pointer;text-decoration:underline}
.pdp-rating-count:hover{color:var(--gold)}
.pdp-price-wrap{
  padding:20px 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  margin-bottom:24px;
  display:flex;align-items:baseline;gap:14px;
}
.pdp-price{
  font-family:'Cormorant Garamond',serif;
  font-size:36px;font-weight:600;color:var(--ink);
}
.pdp-price-old{
  font-size:20px;color:var(--muted);
  text-decoration:line-through;
  font-family:'Cormorant Garamond',serif;
}
.pdp-save{
  font-size:12px;letter-spacing:1.5px;text-transform:uppercase;
  background:rgba(74,124,89,.12);color:var(--success);
  padding:4px 10px;font-weight:600;
}

/* Selector label */
.pdp-selector-label{
  font-size:11px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--text);font-weight:600;margin-bottom:12px;
  display:flex;align-items:center;justify-content:space-between;
}
.pdp-selector-label span{
  font-size:12px;letter-spacing:0;text-transform:none;
  color:var(--gold);cursor:pointer;font-weight:400;
  border-bottom:1px solid rgba(191,155,90,.4);
}
/* Size selector */
.pdp-sizes{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.pdp-size-btn{
  min-width:48px;height:48px;padding:0 14px;
  border:1.5px solid var(--border);background:var(--white);
  font-family:'Jost',sans-serif;font-size:13px;font-weight:500;
  cursor:pointer;transition:var(--transition);color:var(--text);
  display:flex;align-items:center;justify-content:center;
}
.pdp-size-btn:hover{border-color:var(--gold);color:var(--gold)}
.pdp-size-btn.active{background:var(--ink);color:var(--gold3);border-color:var(--ink)}
.pdp-size-btn.unavail{opacity:.35;cursor:not-allowed;text-decoration:line-through}
/* Color selector */
.pdp-colors{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:28px}
.pdp-color-swatch{
  width:32px;height:32px;border-radius:50%;
  cursor:pointer;
  border:3px solid transparent;
  outline:2px solid transparent;
  transition:all .2s;
  position:relative;
}
.pdp-color-swatch:hover{outline-color:var(--gold);outline-offset:2px}
.pdp-color-swatch.active{outline-color:var(--gold);outline-offset:3px}
.pdp-color-label{
  font-size:12px;color:var(--muted);
  margin-bottom:12px;margin-top:-14px;
}
/* Quantity row */
.pdp-qty-row{
  display:flex;align-items:center;gap:16px;
  margin-bottom:20px;
}
.pdp-qty-ctrl{
  display:inline-flex;align-items:center;
  border:1.5px solid var(--border);
}
.pdp-qty-btn{
  width:44px;height:44px;
  border:none;background:transparent;
  font-size:18px;font-weight:300;cursor:pointer;color:var(--text);
  transition:background .2s;
  display:flex;align-items:center;justify-content:center;
}
.pdp-qty-btn:hover{background:var(--sand)}
.pdp-qty-num{
  width:52px;text-align:center;
  font-size:15px;font-weight:600;
  border-left:1.5px solid var(--border);
  border-right:1.5px solid var(--border);
  height:44px;line-height:44px;
}
.pdp-stock-tag{
  font-size:12px;font-weight:500;
}
.pdp-stock-tag.in{color:var(--success)}
.pdp-stock-tag.low{color:var(--warning,#D97706)}
.pdp-stock-tag.out{color:var(--danger)}
/* CTA buttons */
.pdp-cta{display:flex;gap:12px;margin-bottom:20px}
.pdp-add-btn{
  flex:1;padding:16px 24px;
  background:var(--ink);color:var(--gold3);
  border:none;cursor:pointer;
  font-family:'Jost',sans-serif;
  font-size:12px;letter-spacing:2.5px;text-transform:uppercase;
  font-weight:500;
  position:relative;overflow:hidden;transition:var(--transition);
}
.pdp-add-btn::before{
  content:'';position:absolute;inset:0;
  background:var(--gold);transform:translateX(-101%);
  transition:transform .35s ease;
}
.pdp-add-btn:hover::before{transform:translateX(0)}
.pdp-add-btn span{position:relative;z-index:1}
.pdp-add-btn:hover span{color:var(--ink)}
.pdp-add-btn:disabled{opacity:.5;cursor:not-allowed}
.pdp-add-btn:disabled::before{display:none}
.pdp-wish-btn{
  width:54px;height:54px;
  border:1.5px solid var(--border);background:var(--white);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:18px;color:var(--muted);
  transition:var(--transition);flex-shrink:0;
}
.pdp-wish-btn:hover,.pdp-wish-btn.active{
  border-color:var(--danger);color:var(--danger);background:rgba(184,64,64,.05);
}
/* Delivery badges */
.pdp-delivery-badges{
  display:flex;flex-wrap:wrap;gap:10px;
  margin-bottom:24px;
}
.pdp-del-badge{
  display:flex;align-items:center;gap:8px;
  padding:8px 14px;
  background:var(--sand);border:1px solid var(--border);
  font-size:12px;color:var(--text);font-weight:400;
}
.pdp-del-badge i{color:var(--gold);font-size:13px}
/* Share row */
.pdp-share-row{
  display:flex;align-items:center;gap:12px;
  padding-top:20px;border-top:1px solid var(--border);
  font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);
}
.pdp-share-icon{
  width:34px;height:34px;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:13px;color:var(--muted);
  transition:var(--transition);
}
.pdp-share-icon:hover{background:var(--ink);color:var(--gold3);border-color:var(--ink)}

/* ── Tabs (Description / Details / Reviews) ── */
.pdp-tabs{margin-bottom:60px}
.pdp-tab-nav{
  display:flex;
  border-bottom:1px solid var(--border);
  margin-bottom:36px;
  gap:0;
}
.pdp-tab-btn{
  padding:14px 28px;
  font-size:12px;letter-spacing:2.5px;text-transform:uppercase;font-weight:500;
  color:var(--muted);cursor:pointer;border:none;background:transparent;
  font-family:'Jost',sans-serif;
  border-bottom:2px solid transparent;
  margin-bottom:-1px;
  transition:color .2s,border-color .2s;
}
.pdp-tab-btn.active{color:var(--gold);border-bottom-color:var(--gold)}
.pdp-tab-btn:hover:not(.active){color:var(--text)}
.pdp-tab-panel{display:none}
.pdp-tab-panel.active{display:block;animation:pageIn .3s ease}

/* Description panel */
.pdp-desc-text{
  font-size:15px;line-height:1.9;color:var(--text);
  font-weight:300;max-width:760px;margin-bottom:24px;
}
.pdp-features{
  display:grid;grid-template-columns:1fr 1fr;
  gap:12px;margin-top:16px;
}
.pdp-feature{
  display:flex;align-items:flex-start;gap:10px;
  font-size:14px;color:var(--text);
}
.pdp-feature-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--gold);margin-top:6px;flex-shrink:0;
}

/* Details panel (size guide, care) */
.pdp-detail-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:32px;
}
.pdp-detail-block h4{
  font-size:12px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;font-weight:600;
}
.pdp-detail-table{width:100%;border-collapse:collapse;font-size:14px}
.pdp-detail-table td{
  padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text);
}
.pdp-detail-table td:first-child{color:var(--muted);width:40%}
.pdp-care-icons{display:flex;flex-wrap:wrap;gap:14px}
.pdp-care-item{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  font-size:11px;text-align:center;color:var(--muted);
}
.pdp-care-item i{font-size:20px;color:var(--text)}

/* Reviews panel */
.pdp-review-summary{
  display:flex;gap:48px;align-items:center;
  padding:28px 32px;background:var(--sand);border:1px solid var(--border);
  margin-bottom:28px;flex-wrap:wrap;
  width:100%;
}
.pdp-avg-score{text-align:center;min-width:100px}
.pdp-avg-num{
  font-family:'Cormorant Garamond',serif;
  font-size:56px;font-weight:600;color:var(--ink);line-height:1;
}
.pdp-avg-stars{color:var(--gold);font-size:18px;margin:4px 0}
.pdp-avg-label{font-size:12px;color:var(--muted)}
.pdp-rating-bars{flex:1;min-width:200px}
.pdp-rating-bar-row{
  display:flex;align-items:center;gap:10px;margin-bottom:6px;font-size:12px;
}
.pdp-rating-bar-label{width:12px;color:var(--muted)}
.pdp-rating-bar-track{
  flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden;
}
.pdp-rating-bar-fill{height:100%;background:var(--gold);border-radius:3px;transition:width .6s ease}
.pdp-rating-bar-count{width:20px;text-align:right;color:var(--muted)}
.pdp-review-list{display:flex;flex-direction:column;gap:20px}


.pdp-rb-row{display:flex;align-items:center;gap:10px;margin-bottom:6px;font-size:12px}
.pdp-rb-label{width:12px;color:var(--muted)}
.pdp-rb-track{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}
.pdp-rb-fill{height:100%;background:var(--gold);border-radius:3px}
.pdp-rb-count{width:20px;text-align:right;color:var(--muted)}


.pdp-review-card{
  background:var(--white);border:1px solid var(--border);
  padding:22px 26px;transition:box-shadow .2s;
}
.pdp-review-card:hover{box-shadow:var(--shadow-sm)}
.pdp-review-header{
  display:flex;align-items:flex-start;justify-content:space-between;
  margin-bottom:10px;flex-wrap:wrap;gap:8px;
}
.pdp-review-author{font-size:14px;font-weight:600;color:var(--ink)}
.pdp-review-date{font-size:12px;color:var(--muted)}
.pdp-review-stars{color:var(--gold);font-size:13px;margin-bottom:8px}
.pdp-review-text{font-size:14px;color:var(--text);line-height:1.7;font-weight:300}
.pdp-review-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.pdp-review-tag{
  font-size:10px;letter-spacing:1.5px;text-transform:uppercase;
  padding:3px 10px;background:var(--sand);color:var(--muted);border:1px solid var(--border);
}
.pdp-verified{
  font-size:10px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--success);font-weight:600;
  display:flex;align-items:center;gap:5px;
}
/* Write review form */
.pdp-write-review{
  margin-top:28px;padding:28px 32px;
  background:var(--sand);border:1px solid var(--border);
}
.pdp-write-review h4{
  font-family:'Cormorant Garamond',serif;
  font-size:22px;color:var(--ink);margin-bottom:20px;
}
.pdp-star-picker{display:flex;gap:6px;margin-bottom:18px}
.pdp-star-pick{
  font-size:24px;cursor:pointer;color:var(--border);transition:color .15s;
}
.pdp-star-pick:hover,.pdp-star-pick.lit{color:var(--gold)}

/* ── Related Products ── */
.pdp-related{}
.pdp-related-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(28px,3vw,38px);
  font-weight:300;color:var(--ink);
  margin-bottom:8px;
}
.pdp-related-sub{font-size:13px;color:var(--muted);margin-bottom:28px}

/* Responsive */
@media(max-width:1024px){
  .pdp-shell{padding:32px 24px 60px}
  .pdp-main{grid-template-columns:1fr;gap:36px}
  .pdp-info{position:static}
  .pdp-detail-grid{grid-template-columns:1fr}
  .pdp-features{grid-template-columns:1fr}
}
@media(max-width:560px){
  .pdp-thumbs{gap:6px}
  .pdp-thumb{width:64px;height:80px}
  .pdp-sizes{gap:6px}
  .pdp-size-btn{min-width:44px;height:44px;font-size:12px}
  .pdp-cta{flex-direction:column}
  .pdp-wish-btn{width:100%;height:44px}
  .pdp-tab-btn{padding:12px 16px;font-size:11px}
  .pdp-review-summary{flex-direction:column}
}


/* ===== AUTH PAGES ===== */
.auth-shell{
  min-height:calc(100vh - 73px);
  display:grid;
  grid-template-columns:1fr 1fr;
}
.auth-visual{
  /* background:var(--ink); */
  position:relative;
  overflow:hidden;
  display:flex;flex-direction:column;
  justify-content:center;
  padding:60px;
  min-height:600px;
}
.auth-visual-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 20% 80%, rgba(191,155,90,.22) 0%, transparent 55%),
    radial-gradient(ellipse at 80% 20%, rgba(191,155,90,.1) 0%, transparent 50%);
}
.auth-visual-pattern{
  position:absolute;inset:0;
  opacity:.04;
  background-image:
    repeating-linear-gradient(45deg, var(--gold) 0, var(--gold) 1px, transparent 0, transparent 50%);
  background-size:28px 28px;
}
.auth-visual-floats{
  position:absolute;inset:0;
  pointer-events:none;
}
.auth-float{
  position:absolute;
  border:1px solid rgba(191,155,90,.18);
  animation:floatDrift 8s ease-in-out infinite;
}
.auth-float:nth-child(1){width:180px;height:220px;top:8%;left:12%;animation-delay:0s}
.auth-float:nth-child(2){width:100px;height:130px;top:30%;right:15%;animation-delay:2s;border-color:rgba(191,155,90,.1)}
.auth-float:nth-child(3){width:60px;height:60px;bottom:30%;left:20%;animation-delay:4s}
@keyframes floatDrift{
  0%,100%{transform:translateY(0) rotate(0deg)}
  33%{transform:translateY(-14px) rotate(1deg)}
  66%{transform:translateY(8px) rotate(-1deg)}
}
.auth-visual-content{position:relative;z-index:1}
.auth-visual-badge{
  display:inline-flex;align-items:center;gap:10px;
  font-size:10px;letter-spacing:4px;text-transform:uppercase;
  color:var(--gold);margin-bottom:28px;font-weight:400;
}
.auth-visual-badge::before{content:'';width:28px;height:1px;background:var(--gold)}
.auth-visual-h{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(40px,4.5vw,58px);
  color:var(--ink);
  font-weight:300;
  line-height:1.1;
  margin-bottom:20px;
}
.auth-visual-h em{font-style:italic;color:var(--gold2)}
.auth-visual-p{
  font-size:14px;color:var(--ink);
  font-weight:300;line-height:1.8;
  max-width:340px;
  margin-bottom:36px;
}
.auth-visual-perks{display:flex;flex-direction:column;gap:12px}
.auth-perk{
  display:flex;align-items:center;gap:12px;
  font-size:13px;color:(var(--ink));font-weight:300;
}
.auth-perk-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--gold);flex-shrink:0;
}
.auth-visual-logo{
  position:absolute;top:40px;left:60px;
  font-family:'Cormorant Garamond',serif;
  font-size:28px;color:var(--gold2);letter-spacing:5px;
  cursor:pointer;z-index:1;
}
.auth-visual-logo span{color:var(--gold)}

/* Auth Form Panel */
.auth-panel{
  display:flex;flex-direction:column;
  justify-content:center;
  padding:60px 72px;
  background:var(--cream);
  position:relative;
  overflow-y:auto;
}
.auth-panel-back{
  position:absolute;top:32px;left:32px;
  display:flex;align-items:center;gap:8px;
  font-size:12px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--muted);cursor:pointer;
  transition:color .2s;
  font-weight:500;
}
.auth-panel-back:hover{color:var(--gold)}
.auth-panel-back i{font-size:11px}
.auth-eyebrow{
  font-size:10px;letter-spacing:4px;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;font-weight:500;
}
.auth-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(34px,3.5vw,46px);
  color:var(--ink);font-weight:300;
  line-height:1.1;margin-bottom:8px;
}
.auth-subtitle{
  font-size:14px;color:var(--muted);
  margin-bottom:40px;font-weight:300;line-height:1.6;
}
.auth-subtitle a{
  color:var(--gold);cursor:pointer;font-weight:500;
  text-decoration:none;border-bottom:1px solid rgba(191,155,90,.3);
  transition:border-color .2s;
}
.auth-subtitle a:hover{border-color:var(--gold)}

/* Input Groups */
.auth-form{display:flex;flex-direction:column;gap:0}
.auth-field{
  margin-bottom:18px;
  position:relative;
}
.auth-label{
  display:block;
  font-size:10px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--muted);margin-bottom:8px;font-weight:600;
}
.auth-input-wrap{position:relative}
.auth-input{
  width:100%;padding:14px 44px 14px 16px;
  border:1.5px solid var(--border);
  background:var(--white);
  font-family:'Jost',sans-serif;font-size:14px;
  color:var(--text);outline:none;
  transition:border-color .25s, box-shadow .25s;
  border-radius:0;
}
.auth-input:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(191,155,90,.08);
}
.auth-input.error{border-color:var(--danger)}
.auth-input-icon{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);
  color:var(--muted);font-size:14px;
  transition:color .2s;pointer-events:none;
}
.auth-input:focus ~ .auth-input-icon{color:var(--gold)}
.auth-input-toggle{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);
  color:var(--muted);font-size:14px;cursor:pointer;
  transition:color .2s;
}
.auth-input-toggle:hover{color:var(--gold)}
.auth-error-msg{
  font-size:11px;color:var(--danger);
  margin-top:5px;display:none;
  letter-spacing:0.3px;
}
.auth-error-msg.show{display:block}

/* Password strength */
.pw-strength{margin-top:8px}
.pw-strength-bars{
  display:flex;gap:4px;margin-bottom:5px;
}
.pw-bar{
  flex:1;height:3px;border-radius:2px;
  background:var(--border);
  transition:background .3s;
}
.pw-bar.weak{background:var(--danger)}
.pw-bar.fair{background:var(--warning,#E07B39)}
.pw-bar.good{background:var(--gold)}
.pw-bar.strong{background:var(--success)}
.pw-label{font-size:11px;color:var(--muted)}

/* Checkbox */
.auth-check-row{
  display:flex;align-items:flex-start;gap:10px;
  margin-bottom:24px;
}
.auth-check-row input[type=checkbox]{
  width:16px;height:16px;
  accent-color:var(--gold);
  margin-top:2px;flex-shrink:0;cursor:pointer;
}
.auth-check-label{
  font-size:13px;color:var(--muted);line-height:1.5;cursor:pointer;
}
.auth-check-label a{color:var(--gold);cursor:pointer;text-decoration:none}

/* Divider */
.auth-divider{
  display:flex;align-items:center;gap:16px;
  margin:24px 0;
}
.auth-divider::before,.auth-divider::after{
  content:'';flex:1;height:1px;background:var(--border);
}
.auth-divider span{
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:var(--muted);white-space:nowrap;
}

/* Social login */
.auth-socials{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:4px}
.auth-social-btn{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:12px 16px;
  border:1.5px solid var(--border);
  background:var(--white);cursor:pointer;
  font-family:'Jost',sans-serif;font-size:13px;
  color:var(--text);font-weight:500;
  transition:var(--transition);
}
.auth-social-btn:hover{border-color:var(--gold);color:var(--gold)}
.auth-social-btn i{font-size:16px}

/* Submit button */
.auth-submit{
  width:100%;padding:16px;
  background:var(--ink);color:var(--gold3);
  border:none;cursor:pointer;
  font-family:'Jost',sans-serif;
  font-size:12px;letter-spacing:3px;text-transform:uppercase;
  font-weight:500;
  position:relative;overflow:hidden;
  transition:var(--transition);
  margin-bottom:8px;
}
.auth-submit::before{
  content:'';position:absolute;inset:0;
  background:var(--gold);
  transform:translateX(-101%);
  transition:transform .35s ease;
}
.auth-submit:hover::before{transform:translateX(0)}
.auth-submit span{position:relative;z-index:1}
.auth-submit:hover span{color:var(--ink)}
.auth-submit.loading span::after{content:' ...'}

/* Forgot password link */
.auth-forgot{
  text-align:right;margin-bottom:20px;
}
.auth-forgot a{
  font-size:12px;letter-spacing:0.5px;color:var(--muted);
  cursor:pointer;text-decoration:none;
  border-bottom:1px solid transparent;
  transition:color .2s, border-color .2s;
}
.auth-forgot a:hover{color:var(--gold);border-color:rgba(191,155,90,.3)}

/* User nav state */
.user-nav-pill{
  display:flex;align-items:center;gap:10px;
  cursor:pointer;padding:4px 12px 4px 4px;
  border:1px solid var(--border);
  border-radius:30px;
  transition:var(--transition);
  position:relative;
}
.user-nav-pill:hover{border-color:var(--gold);background:var(--sand)}
.user-nav-avatar{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:13px;color:var(--ink);
  flex-shrink:0;
}
.user-nav-name{font-size:12px;font-weight:500;color:var(--text);letter-spacing:0.3px}
.user-dropdown{
  position:absolute;top:calc(100% + 10px);right:0;
  background:var(--white);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  min-width:200px;
  z-index:500;
  display:none;
  animation:dropIn .2s ease;
}
@keyframes dropIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.user-nav-pill:hover .user-dropdown{display:block}
.user-dropdown-header{
  padding:16px 20px;
  border-bottom:1px solid var(--border);
  background:var(--sand);
}
.user-dropdown-name{font-size:15px;font-weight:600;color:var(--ink)}
.user-dropdown-email{font-size:12px;color:var(--muted);margin-top:2px}
.user-dropdown-item{
  display:flex;align-items:center;gap:12px;
  padding:12px 20px;
  font-size:13px;color:var(--text);
  cursor:pointer;transition:background .15s;
}
.user-dropdown-item:hover{background:var(--sand);color:var(--gold)}
.user-dropdown-item i{width:16px;color:var(--gold);font-size:13px}
.user-dropdown-divider{height:1px;background:var(--border);margin:4px 0}

/* Account dashboard (my account page) */
.account-layout{
  max-width:1100px;margin:0 auto;
  padding:60px 48px;
  display:grid;grid-template-columns:240px 1fr;
  gap:40px;align-items:start;
}
.account-sidebar{
  background:var(--white);
  border:1px solid var(--border);
  overflow:hidden;
  position:sticky;top:100px;
  height: 420px;
}
.account-sidebar-header{
  background:var(--ink);
  padding:28px 24px;
  text-align:center;
}
.account-avatar-big{
  width:68px;height:68px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  display:flex;align-items:center;justify-content:center;
  font-size:26px;font-weight:700;color:var(--ink);
  margin:0 auto 12px;border:3px solid rgba(255,255,255,.15);
}
.account-sidebar-name{
  font-family:'Cormorant Garamond',serif;
  font-size:20px;color:var(--cream);font-weight:400;
}
.account-sidebar-email{font-size:12px;color:rgba(253,251,247,.45);margin-top:3px}
.account-nav {
  display: grid;
  grid-template-columns: 1fr 1fr; /* 2 per row */
  gap: 8px;
  padding: 8px;
}

.account-nav-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 10px;
  font-size: 13px;
  color: var(--text);
  cursor: pointer;
  transition: all 0.15s ease;
  border-radius: 6px;
  background: var(--white);
  border: 1px solid var(--border);
}

.account-nav-item i {
  width: 16px;
  font-size: 13px;
  color: var(--muted);
  transition: color 0.2s;
}

.account-nav-item:hover {
  background: var(--sand);
  color: var(--gold);
}

.account-nav-item:hover i {
  color: var(--gold);
}

.account-nav-item.active {
  background: rgba(191,155,90,.1);
  color: var(--gold);
  border-color: var(--gold);
}

.account-nav-item.active i {
  color: var(--gold);
}

/* Make Sign Out full width */
.account-nav-item:last-child {
  grid-column: span 2;
  justify-content: center;
  border-top: 1px solid var(--border);
  margin-top: 0px;
}

.account-nav-item:nth-last-child(2) {
  grid-column: span 2;
  justify-content: center;
  border-top: 1px solid var(--border);
  margin-top: 0px;
}
.account-content{}
.account-section{display:none}
.account-section.active{display:block;animation:pageIn .3s ease}
.account-section-title{
  font-family:'Cormorant Garamond',serif;
  font-size:30px;color:var(--ink);font-weight:300;
  margin-bottom:6px;
}
.account-section-sub{font-size:13px;color:var(--muted);margin-bottom:28px}
.account-card{
  background:var(--white);border:1px solid var(--border);
  padding:28px 32px;margin-bottom:20px;
}
.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}

@media(max-width:900px){
  .auth-shell{grid-template-columns:1fr}
  .auth-visual{display:none}
  .auth-panel{padding:48px 28px}
  .account-layout{grid-template-columns:1fr}
  .account-sidebar{position:static}
}
@media(max-width:560px){
  .auth-panel{padding:36px 20px}
  .auth-socials{grid-template-columns:1fr}
  .profile-grid{grid-template-columns:1fr}
}

/* ===== MOBILE NAV ===== */
.mobile-menu{
  position:fixed;inset:0;z-index:2000;
  background:var(--cream);
  display:flex;flex-direction:column;
  justify-content:center;align-items:center;gap:32px;
  transform:translateY(-100%);
  transition:transform .4s cubic-bezier(.4,0,.2,1);
}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu a{
  font-family:'Cormorant Garamond',serif;
  font-size:36px;font-weight:300;color:var(--ink);cursor:pointer;
  text-decoration:none;letter-spacing:2px;
  transition:color .2s;
}
.mobile-menu a:hover{color:var(--gold)}
.mobile-close{
  position:absolute;top:24px;right:24px;
  font-size:24px;cursor:pointer;color:var(--muted);
  transition:color .2s;
}
.mobile-close:hover{color:var(--gold)}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  nav{padding:0 24px}
  .section,.shop-layout,.cart-layout,.checkout-layout,.contact-layout,.about-body,.footer-inner{padding-left:24px;padding-right:24px}
  .hero{padding:0 24px;gap:40px}
  .promise-strip{padding:48px 24px}
  .testimonials{padding:60px 24px}
  .about-hero{padding:80px 24px}
  .orders-wrap{padding:48px 24px}
  footer{padding:60px 24px 32px}
}
@media(max-width:900px){
  .nav-links{display:none}
  .hamburger{display:flex}
  .hero{grid-template-columns:1fr;gap:32px;padding-top:48px;padding-bottom:48px;min-height:auto}
  .hero-visual{height:360px}
  .shop-layout{grid-template-columns:1fr}
  .filter-sidebar{display:none}
  .promise-strip-inner{grid-template-columns:1fr 1fr}
  .testimonials{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .contact-layout{grid-template-columns:1fr}
  .cart-layout,.checkout-layout{grid-template-columns:1fr}
  .order-summary{position:static}
  .footer-inner{grid-template-columns:1fr 1fr}
  .about-stats{grid-template-columns:1fr 1fr}
  .hero-card-main{font-size:80px}
  .ck-method-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .hero-h1{font-size:42px}
  .product-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .footer-inner{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .promise-strip-inner{grid-template-columns:1fr}
  .section-header{flex-direction:column;align-items:flex-start;gap:12px}

  /* .nav-logo{
    font-size:12px;
  }
  .nav-user{
    display:none;
} */
}










/* ===== BLOG ===== */
/* Nav link */
.nav-links li a#nav-blog{}

/* Blog listing page */
.blog-hero{background:var(--ink);padding:80px 48px;text-align:center;position:relative;overflow:hidden}
.blog-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 120%,rgba(191,155,90,.18) 0%,transparent 60%)}
.blog-hero-label{font-size:10px;letter-spacing:5px;text-transform:uppercase;color:var(--gold);margin-bottom:16px;font-weight:400;position:relative;z-index:1}
.blog-hero-h{font-family:'Cormorant Garamond',serif;font-size:clamp(42px,6vw,76px);color:var(--cream);font-weight:300;line-height:1.05;margin-bottom:16px;position:relative;z-index:1}
.blog-hero-h em{font-style:italic;color:var(--gold2)}
.blog-hero-p{font-size:15px;color:rgba(253,251,247,.5);font-weight:300;max-width:520px;margin:0 auto;position:relative;z-index:1}

/* Blog filter bar */
.blog-filter-bar{background:var(--sand);border-bottom:1px solid var(--border);padding:0 48px}
.blog-filter-inner{max-width:1320px;margin:0 auto;display:flex;align-items:center;gap:0;overflow-x:auto;scrollbar-width:none}
.blog-filter-inner::-webkit-scrollbar{display:none}
.blog-filter-btn{padding:18px 24px;font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);cursor:pointer;border:none;background:transparent;font-family:'Jost',sans-serif;font-weight:500;white-space:nowrap;border-bottom:2.5px solid transparent;margin-bottom:-1px;transition:color .2s,border-color .2s}
.blog-filter-btn:hover{color:var(--text)}
.blog-filter-btn.active{color:var(--gold);border-bottom-color:var(--gold)}

/* Blog grid */
.blog-shell{max-width:1320px;margin:0 auto;padding:60px 48px 80px}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;margin-bottom:48px}
.blog-card{background:var(--white);border:1px solid var(--border);overflow:hidden;cursor:pointer;transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.blog-card-featured{grid-column:span 2}
.blog-card-img{position:relative;overflow:hidden;background:var(--sand)}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.blog-card:hover .blog-card-img img{transform:scale(1.06)}
.blog-card-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:72px}
.blog-card-normal .blog-card-img{height:220px}
.blog-card-featured .blog-card-img{height:320px}
.blog-card-tag{position:absolute;bottom:16px;left:16px;padding:5px 14px;font-size:10px;letter-spacing:2.5px;text-transform:uppercase;font-weight:700;z-index:2}
.blog-card-body{padding:24px 28px;flex:1;display:flex;flex-direction:column}
.blog-cat-label{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:10px}
.blog-card-title{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:400;color:var(--ink);line-height:1.25;margin-bottom:12px;transition:color .2s}
.blog-card:hover .blog-card-title{color:var(--gold)}
.blog-card-featured .blog-card-title{font-size:28px}
.blog-card-excerpt{font-size:14px;color:var(--muted);line-height:1.7;font-weight:300;margin-bottom:18px;flex:1}
.blog-card-meta{display:flex;align-items:center;gap:14px;font-size:12px;color:var(--muted);padding-top:16px;border-top:1px solid var(--border)}
.blog-card-author{display:flex;align-items:center;gap:8px}
.blog-author-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--ink)}
.blog-read-time{margin-left:auto;display:flex;align-items:center;gap:5px}

/* Blog search */
.blog-search-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:36px;flex-wrap:wrap;gap:14px}
.blog-search{display:flex;align-items:center;border:1px solid var(--border);background:var(--white);padding:0 16px;gap:10px;width:280px}
.blog-search input{flex:1;padding:12px 0;border:none;background:transparent;font-family:'Jost',sans-serif;font-size:14px;color:var(--text);outline:none}
.blog-search i{color:var(--muted);font-size:14px}

/* Newsletter in blog */
.blog-newsletter{background:linear-gradient(135deg,var(--ink) 0%,#2C2010 100%);padding:56px 48px;text-align:center;margin:60px 0;position:relative;overflow:hidden}
.blog-newsletter::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 150%,rgba(191,155,90,.2) 0%,transparent 60%)}
.blog-newsletter-h{font-family:'Cormorant Garamond',serif;font-size:36px;color:var(--cream);font-weight:300;margin-bottom:10px;position:relative;z-index:1}
.blog-newsletter-h em{font-style:italic;color:var(--gold2)}
.blog-newsletter-p{font-size:14px;color:rgba(253,251,247,.5);margin-bottom:28px;position:relative;z-index:1}
.blog-newsletter-form{display:flex;max-width:420px;margin:0 auto;position:relative;z-index:1}

/* ===== BLOG DETAIL PAGE ===== */
.bdet-shell{max-width:820px;margin:0 auto;padding:60px 48px 80px}
.bdet-shell-wide{max-width:1100px}
.bdet-back{display:inline-flex;align-items:center;gap:8px;font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);cursor:pointer;margin-bottom:36px;transition:color .2s;font-weight:500;text-decoration:none}
.bdet-back:hover{color:var(--gold)}
.bdet-cat{font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:14px}
.bdet-title{font-family:'Cormorant Garamond',serif;font-size:clamp(36px,5vw,56px);font-weight:300;color:var(--ink);line-height:1.1;margin-bottom:20px}
.bdet-meta{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:36px;padding-bottom:28px;border-bottom:1px solid var(--border)}
.bdet-author-pill{display:flex;align-items:center;gap:10px}
.bdet-author-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;color:var(--ink);flex-shrink:0}
.bdet-author-name{font-size:14px;font-weight:500;color:var(--ink)}
.bdet-author-role{font-size:12px;color:var(--muted)}
.bdet-meta-dot{width:4px;height:4px;border-radius:50%;background:var(--border)}
.bdet-meta-item{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px}
.bdet-meta-item i{font-size:12px;color:var(--gold)}
.bdet-share-row{display:flex;align-items:center;gap:10px;margin-left:auto}
.bdet-share-icon{width:32px;height:32px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;color:var(--muted);transition:var(--t)}
.bdet-share-icon:hover{background:var(--ink);color:var(--gold3);border-color:var(--ink)}

/* Hero image */
.bdet-hero-img{width:100%;margin-bottom:44px;border:1px solid var(--border);overflow:hidden;position:relative}
.bdet-hero-img img{width:100%;object-fit:cover;display:block;transition:transform .6s ease}
.bdet-hero-img:hover img{transform:scale(1.02)}
.bdet-hero-caption{padding:10px 16px;background:var(--sand);border-top:1px solid var(--border);font-size:12px;color:var(--muted);font-style:italic}

/* Content blocks */
.bdet-content{line-height:1.9}
.bc-p{font-size:16px;color:var(--text);font-weight:300;margin-bottom:28px;line-height:1.9}
.bc-h2{font-family:'Cormorant Garamond',serif;font-size:clamp(28px,3.5vw,38px);color:var(--ink);font-weight:300;margin:48px 0 18px;line-height:1.15}
.bc-h3{font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--ink);font-weight:400;margin:32px 0 14px}
.bc-quote{border-left:4px solid var(--gold);padding:20px 28px;margin:36px 0;background:var(--sand)}
.bc-quote-text{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--ink);font-style:italic;line-height:1.5;margin-bottom:10px}
.bc-quote-author{font-size:13px;color:var(--muted);font-weight:500}
.bc-img{margin:36px 0}
.bc-img img{width:100%;display:block;border:1px solid var(--border)}
.bc-img-caption{font-size:12px;color:var(--muted);font-style:italic;margin-top:8px;text-align:center}
.bc-img-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:36px 0}
.bc-img-grid img{width:100%;height:240px;object-fit:cover;border:1px solid var(--border);display:block;cursor:pointer;transition:transform .3s}
.bc-img-grid img:hover{transform:scale(1.02)}
.bc-img-grid-3{grid-template-columns:1fr 1fr 1fr}
.bc-tip{background:rgba(191,155,90,.08);border:1px solid rgba(191,155,90,.25);padding:20px 24px;margin:28px 0;display:flex;gap:14px;align-items:flex-start}
.bc-tip-icon{color:var(--gold);font-size:18px;flex-shrink:0;margin-top:2px}
.bc-tip-text{font-size:14px;color:var(--text);line-height:1.7}
.bc-list{margin:0 0 28px 0;padding-left:0;list-style:none}
.bc-list li{display:flex;gap:10px;align-items:flex-start;font-size:15px;color:var(--text);font-weight:300;margin-bottom:10px;line-height:1.7}
.bc-list-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);margin-top:8px;flex-shrink:0}
.bc-divider{border:none;border-top:1px solid var(--border);margin:48px 0}
.bc-video{margin:36px 0;position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border:1px solid var(--border)}
.bc-video iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}
.bc-video-placeholder{width:100%;aspect-ratio:16/9;background:var(--ink);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;cursor:pointer;position:relative;overflow:hidden}
.bc-video-placeholder img.bc-thumb{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;opacity:.5}
.bc-video-play{width:72px;height:72px;border-radius:50%;background:rgba(191,155,90,.9);display:flex;align-items:center;justify-content:center;font-size:28px;color:var(--ink);position:relative;z-index:1;transition:transform .25s,background .25s;cursor:pointer}
.bc-video-placeholder:hover .bc-video-play{transform:scale(1.1);background:var(--gold)}
.bc-video-title{color:var(--cream);font-family:'Cormorant Garamond',serif;font-size:18px;position:relative;z-index:1;text-align:center;padding:0 20px}
.bc-audio{background:var(--sand);border:1px solid var(--border);padding:20px 24px;margin:28px 0;display:flex;align-items:center;gap:16px}
.bc-audio-icon{width:48px;height:48px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;color:var(--ink);font-size:18px;flex-shrink:0;cursor:pointer;transition:transform .2s}
.bc-audio-icon:hover{transform:scale(1.08)}
.bc-audio audio{flex:1;min-width:0}
.bc-audio-label{font-size:13px;color:var(--text);font-weight:500;margin-bottom:4px}
.bc-audio-sub{font-size:11px;color:var(--muted)}

/* Chart block */
.bc-chart{background:var(--white);border:1px solid var(--border);padding:28px 24px;margin:36px 0}
.bc-chart-title{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--ink);margin-bottom:6px}
.bc-chart-sub{font-size:12px;color:var(--muted);margin-bottom:24px}
.bc-bar-chart{display:flex;align-items:flex-end;gap:14px;height:180px;padding:0 8px}
.bc-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px}
.bc-bar-fill{width:100%;border-radius:4px 4px 0 0;transition:height .8s cubic-bezier(.68,-0.55,.27,1.55);background:linear-gradient(180deg,var(--gold),var(--gold-dark,#9B7A3F));min-height:4px;cursor:pointer;position:relative}
.bc-bar-fill:hover{background:var(--gold2)}
.bc-bar-lbl{font-size:11px;color:var(--muted);text-align:center}
.bc-bar-val{font-size:11px;font-weight:600;color:var(--gold)}
.bc-pie-wrap{display:flex;align-items:center;gap:32px;flex-wrap:wrap}
.bc-pie-canvas{flex-shrink:0}
.bc-pie-legend{display:flex;flex-direction:column;gap:10px}
.bc-pie-legend-item{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text)}
.bc-pie-legend-dot{width:12px;height:12px;border-radius:2px;flex-shrink:0}

/* Product feature in blog */
.bc-product-feature{display:grid;grid-template-columns:200px 1fr;gap:24px;padding:24px;background:var(--sand);border:1px solid var(--border);margin:28px 0;align-items:center}
.bc-product-feature img{width:100%;aspect-ratio:3/4;object-fit:cover;border:1px solid var(--border)}
.bc-product-feature-name{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--ink);margin-bottom:8px}
.bc-product-feature-desc{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:16px}
.bc-product-feature-price{font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--gold);margin-bottom:14px;font-weight:600}

/* Tags */
.bdet-tags{display:flex;flex-wrap:wrap;gap:8px;margin:40px 0 48px}
.bdet-tag{padding:6px 16px;border:1px solid var(--border);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:var(--t)}
.bdet-tag:hover{background:var(--gold);border-color:var(--gold);color:var(--ink)}

/* Author box */
.bdet-author-box{background:var(--sand);border:1px solid var(--border);padding:32px 36px;display:flex;gap:24px;align-items:flex-start;margin-bottom:48px}
.bdet-author-box-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:var(--ink);flex-shrink:0}
.bdet-author-box-name{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--ink);margin-bottom:4px}
.bdet-author-box-role{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.bdet-author-box-bio{font-size:14px;color:var(--muted);line-height:1.7;font-weight:300}

/* Related posts */
.bdet-related{border-top:1px solid var(--border);padding-top:48px}
.bdet-related-title{font-family:'Cormorant Garamond',serif;font-size:32px;color:var(--ink);font-weight:300;margin-bottom:28px}
.bdet-related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

/* Comments */
.bdet-comments{border-top:1px solid var(--border);padding-top:48px;margin-top:48px}
.bdet-comments-title{font-family:'Cormorant Garamond',serif;font-size:28px;color:var(--ink);font-weight:300;margin-bottom:28px}
.bdet-comment{display:flex;gap:16px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border)}
.bdet-comment:last-child{border-bottom:none}
.bdet-comment-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--stone),var(--border));display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:var(--text);flex-shrink:0}
.bdet-comment-name{font-size:14px;font-weight:600;color:var(--ink)}
.bdet-comment-date{font-size:12px;color:var(--muted);margin-left:8px}
.bdet-comment-text{font-size:14px;color:var(--text);line-height:1.7;font-weight:300;margin-top:6px}
.bdet-comment-form{background:var(--sand);border:1px solid var(--border);padding:28px 32px;margin-top:28px}
.bdet-comment-form h4{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--ink);margin-bottom:20px}

/* ===== BLOG ADMIN ===== */
.badmin-layout{max-width:1200px;margin:0 auto;padding:60px 48px}
.badmin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:36px;flex-wrap:wrap;gap:14px}
.badmin-title{font-family:'Cormorant Garamond',serif;font-size:36px;color:var(--ink);font-weight:300}
.badmin-grid{display:grid;grid-template-columns:1fr 360px;gap:32px;align-items:start}
.badmin-form-section{background:var(--white);border:1px solid var(--border);padding:28px 32px;margin-bottom:20px}
.badmin-form-title{font-size:12px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.badmin-posts-list{background:var(--white);border:1px solid var(--border);padding:0}
.badmin-post-item{display:flex;align-items:center;gap:14px;padding:16px 20px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}
.badmin-post-item:last-child{border-bottom:none}
.badmin-post-item:hover{background:var(--sand)}
.badmin-post-thumb{width:56px;height:56px;border:1px solid var(--border);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:24px;background:var(--sand)}
.badmin-post-thumb img{width:100%;height:100%;object-fit:cover}
.badmin-post-info{flex:1;min-width:0}
.badmin-post-name{font-size:14px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.badmin-post-meta{font-size:12px;color:var(--muted);margin-top:3px}
.badmin-post-status{padding:3px 10px;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;font-weight:600;flex-shrink:0}
.status-pub{background:rgba(74,124,89,.12);color:var(--success)}
.status-draft{background:rgba(191,155,90,.12);color:#8B6914}
.block-picker{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:4px}
.block-pick-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;border:1.5px solid var(--border);background:transparent;cursor:pointer;font-family:'Jost',sans-serif;font-size:11px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;transition:var(--t)}
.block-pick-btn:hover{border-color:var(--gold);color:var(--gold)}
.block-pick-btn i{font-size:18px}
.content-blocks-list{display:flex;flex-direction:column;gap:10px;min-height:60px;border:1.5px dashed var(--border);padding:12px;background:var(--cream)}
.cb-item{background:var(--white);border:1px solid var(--border);padding:12px 16px;display:flex;gap:10px;align-items:flex-start}
.cb-item-drag{color:var(--muted);cursor:grab;padding-top:2px;font-size:14px}
.cb-item-content{flex:1;min-width:0}
.cb-item-type{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:6px}
.cb-item-preview{font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cb-item-del{color:var(--muted);cursor:pointer;font-size:14px;flex-shrink:0;padding-top:2px;transition:color .2s}
.cb-item-del:hover{color:var(--danger)}

/* Image zoom overlay (shared) */
.img-zoom-overlay{position:fixed;inset:0;z-index:8500;background:rgba(15,13,10,.9);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;cursor:zoom-out}
.img-zoom-overlay.open{opacity:1;pointer-events:all}
.img-zoom-overlay img{max-width:90vw;max-height:90vh;object-fit:contain}
.img-zoom-close{position:absolute;top:20px;right:24px;color:var(--gold3);font-size:24px;cursor:pointer}

/* Progress bar */
.blog-progress{position:fixed;top:0;left:0;height:3px;background:var(--gold);z-index:9999;width:0;transition:width .1s linear}

@media(max-width:900px){
  .blog-grid{grid-template-columns:1fr}
  .blog-card-featured{grid-column:span 1}
  .badmin-grid{grid-template-columns:1fr}
  .bdet-related-grid{grid-template-columns:1fr 1fr}
  .bc-img-grid{grid-template-columns:1fr}
  .bc-product-feature{grid-template-columns:1fr}
  .bdet-shell{padding:40px 24px 60px}
  .blog-shell,.badmin-layout{padding-left:24px;padding-right:24px}
  .blog-filter-bar{padding:0 24px}
}
@media(max-width:560px){.bdet-related-grid{grid-template-columns:1fr}.block-picker{grid-template-columns:1fr 1fr}.bc-img-grid-3{grid-template-columns:1fr 1fr}}





/* ===== CHAT LAUNCHER ===== */
.chat-launcher{
  position:fixed;bottom:28px;right:28px;z-index:3000;
  display:flex;flex-direction:column;align-items:flex-end;gap:12px;
}
.chat-fab{
  width:60px;height:60px;border-radius:50%;
  background:linear-gradient(135deg,var(--ink),#3D2E1E);
  border:2px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  box-shadow:0 6px 28px rgba(15,13,10,.35),0 0 0 0 rgba(191,155,90,.4);
  animation:fabPulse 3s ease infinite;
  transition:transform .25s,box-shadow .25s;
  position:relative;
}
.chat-fab:hover{transform:scale(1.08);box-shadow:0 10px 36px rgba(15,13,10,.45)}
.chat-fab .fab-icon{font-size:22px;color:var(--gold);transition:transform .3s}
.chat-fab .fab-close{position:absolute;font-size:20px;color:var(--gold3);opacity:0;transition:opacity .25s,transform .25s;transform:rotate(-90deg)}
.chat-fab.open .fab-icon{opacity:0;transform:rotate(90deg)}
.chat-fab.open .fab-close{opacity:1;transform:rotate(0deg)}
.chat-fab .fab-badge{
  position:absolute;top:-4px;right:-4px;
  width:20px;height:20px;border-radius:50%;
  background:var(--danger);color:white;
  font-size:10px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  border:2px solid var(--cream);
  animation:badgeBounce .4s ease;
}
@keyframes fabPulse{0%,100%{box-shadow:0 6px 28px rgba(15,13,10,.35),0 0 0 0 rgba(191,155,90,.4)}50%{box-shadow:0 6px 28px rgba(15,13,10,.35),0 0 0 8px rgba(191,155,90,0)}}
@keyframes badgeBounce{0%{transform:scale(0)}70%{transform:scale(1.3)}100%{transform:scale(1)}}

/* ===== CHAT WINDOW ===== */
.chat-window{
  position:fixed;bottom:104px;right:28px;z-index:2999;
  width:388px;height:620px;
  background:var(--cream);
  border:1px solid var(--border);
  box-shadow:var(--shadow-lg);
  display:flex;flex-direction:column;
  border-radius:16px;overflow:hidden;
  transform:scale(.92) translateY(20px);
  opacity:0;pointer-events:none;
  transition:all .3s cubic-bezier(.34,1.56,.64,1);
}
.chat-window.open{transform:scale(1) translateY(0);opacity:1;pointer-events:all}

/* ===== CHAT HEADER ===== */
.chat-header{
  background:var(--ink);
  padding:16px 20px;
  display:flex;align-items:center;gap:14px;
  flex-shrink:0;
  position:relative;
}
.chat-header-avatar{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  display:flex;align-items:center;justify-content:center;
  font-size:20px;flex-shrink:0;
  border:2px solid rgba(191,155,90,.4);
}
.chat-header-info{flex:1}
.chat-header-name{
  font-family:'Cormorant Garamond',serif;
  font-size:17px;color:var(--cream);letter-spacing:1px;
}
.chat-header-status{
  font-size:11px;color:rgba(253,251,247,.55);
  display:flex;align-items:center;gap:5px;margin-top:2px;
}
.status-dot{
  width:7px;height:7px;border-radius:50%;
  background:#4CAF50;flex-shrink:0;
  box-shadow:0 0 6px #4CAF50;
}
.status-dot.away{background:#FFC107;box-shadow:0 0 6px #FFC107}
.status-dot.offline{background:var(--muted);box-shadow:none}
.chat-header-actions{display:flex;gap:8px}
.chat-hbtn{
  width:32px;height:32px;border-radius:8px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  color:rgba(253,251,247,.6);font-size:13px;cursor:pointer;
  transition:all .2s;
}
.chat-hbtn:hover{background:rgba(191,155,90,.2);color:var(--gold);border-color:rgba(191,155,90,.3)}

/* ===== MODE TABS ===== */
.chat-mode-tabs{
  display:flex;background:var(--ink2);flex-shrink:0;
  border-bottom:1px solid rgba(191,155,90,.15);
}
.chat-tab{
  flex:1;padding:10px 6px;
  font-size:11px;letter-spacing:1.5px;text-transform:uppercase;
  text-align:center;cursor:pointer;color:rgba(253,251,247,.4);
  font-weight:500;border-bottom:2px solid transparent;
  transition:all .2s;font-family:'Jost',sans-serif;
}
.chat-tab:hover{color:rgba(253,251,247,.7)}
.chat-tab.active{color:var(--gold);border-bottom-color:var(--gold)}
.chat-tab i{display:block;font-size:15px;margin-bottom:3px}

/* ===== CHAT PANEL ===== */
.chat-panel{display:none;flex-direction:column;flex:1;overflow:hidden}
.chat-panel.active{display:flex}

/* Messages area */
.chat-messages{
  flex:1;overflow-y:auto;
  padding:16px 14px;
  display:flex;flex-direction:column;gap:10px;
  scrollbar-width:thin;
  scrollbar-color:var(--border) transparent;
}
.chat-messages::-webkit-scrollbar{width:4px}
.chat-messages::-webkit-scrollbar-track{background:transparent}
.chat-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}

/* Bubble */
.chat-bubble-wrap{display:flex;gap:8px;align-items:flex-end;max-width:92%}
.chat-bubble-wrap.user{flex-direction:row-reverse;align-self:flex-end}
.chat-bubble-wrap.bot,.chat-bubble-wrap.agent{align-self:flex-start}
.bubble-avatar{
  width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;color:var(--ink);
  flex-shrink:0;margin-bottom:2px;
}
.bubble-avatar.user-av{background:linear-gradient(135deg,var(--stone),var(--border));color:var(--text)}
.chat-bubble{
  padding:10px 14px;
  font-size:13.5px;line-height:1.55;
  max-width:100%;word-break:break-word;
}
.chat-bubble.bot,.chat-bubble.agent{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:16px 16px 16px 4px;
  color:var(--text);
}
.chat-bubble.user{
  background:var(--ink);
  color:var(--cream);
  border-radius:16px 16px 4px 16px;
}
.chat-bubble.agent{border-color:rgba(191,155,90,.3);background:rgba(191,155,90,.05)}
.bubble-time{font-size:10px;color:var(--muted);margin-top:3px;padding:0 4px;align-self:flex-end}
.bubble-time.user-t{text-align:right}

/* Quick replies */
.quick-replies{
  display:flex;flex-wrap:wrap;gap:6px;
  padding:2px 0 4px;
}
.qr-btn{
  padding:6px 13px;
  border:1px solid var(--gold);
  background:transparent;color:var(--gold);
  font-family:'Jost',sans-serif;font-size:12px;font-weight:500;
  cursor:pointer;border-radius:20px;transition:all .2s;white-space:nowrap;
}
.qr-btn:hover{background:var(--gold);color:var(--ink)}

/* Product card in chat */
.chat-product-card{
  background:var(--white);border:1px solid var(--border);
  display:flex;gap:12px;padding:10px 12px;border-radius:10px;
  cursor:pointer;transition:border-color .2s;max-width:280px;
  margin-top:4px;
}
.chat-product-card:hover{border-color:var(--gold)}
.chat-prod-img{
  width:50px;height:62px;flex-shrink:0;overflow:hidden;
  background:var(--sand);border-radius:6px;
  display:flex;align-items:center;justify-content:center;font-size:22px;
}
.chat-prod-img img{width:100%;height:100%;object-fit:cover}
.chat-prod-name{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:3px;line-height:1.3}
.chat-prod-price{font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--gold);font-weight:600}
.chat-prod-action{font-size:11px;color:var(--muted);margin-top:3px}

/* Typing indicator */
.typing-indicator{display:flex;gap:4px;align-items:center;padding:8px 0 2px}
.typing-dot{width:7px;height:7px;border-radius:50%;background:var(--muted);animation:typingBounce 1.4s ease infinite}
.typing-dot:nth-child(2){animation-delay:.2s}
.typing-dot:nth-child(3){animation-delay:.4s}
@keyframes typingBounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-8px)}}

/* System message */
.chat-system-msg{
  text-align:center;font-size:11px;letter-spacing:1px;
  color:var(--muted);padding:4px 0;
  display:flex;align-items:center;gap:8px;
}
.chat-system-msg::before,.chat-system-msg::after{content:'';flex:1;height:1px;background:var(--border)}

/* Chat input bar */
.chat-input-bar{
  padding:12px 14px;
  border-top:1px solid var(--border);
  display:flex;gap:8px;align-items:flex-end;
  background:var(--white);flex-shrink:0;
}
.chat-input-wrap{
  flex:1;
  border:1.5px solid var(--border);
  border-radius:20px;
  display:flex;align-items:flex-end;
  padding:8px 14px;gap:8px;
  background:var(--cream);
  transition:border-color .2s;
}
.chat-input-wrap:focus-within{border-color:var(--gold)}
.chat-textarea{
  flex:1;border:none;background:transparent;
  font-family:'Jost',sans-serif;font-size:13.5px;color:var(--text);
  resize:none;outline:none;max-height:100px;min-height:20px;
  line-height:1.5;
}
.chat-emoji-btn{color:var(--muted);font-size:17px;cursor:pointer;flex-shrink:0;transition:color .2s;padding-bottom:1px}
.chat-emoji-btn:hover{color:var(--gold)}
.chat-send-btn{
  width:40px;height:40px;border-radius:50%;
  background:var(--ink);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--gold);font-size:15px;
  transition:all .25s;flex-shrink:0;
}
.chat-send-btn:hover{background:var(--gold);color:var(--ink);transform:scale(1.05)}
.chat-attach-btn{color:var(--muted);font-size:17px;cursor:pointer;transition:color .2s;padding-bottom:1px}
.chat-attach-btn:hover{color:var(--gold)}

/* ===== FAQ PANEL ===== */
.chat-faq{padding:16px 14px;overflow-y:auto;flex:1}
.faq-category{margin-bottom:20px}
.faq-cat-title{
  font-size:10px;letter-spacing:3px;text-transform:uppercase;
  color:var(--gold);font-weight:600;margin-bottom:10px;
}
.faq-item{
  border:1px solid var(--border);margin-bottom:6px;overflow:hidden;
  border-radius:8px;
}
.faq-question{
  padding:11px 14px;font-size:13px;font-weight:500;color:var(--text);
  cursor:pointer;display:flex;align-items:center;justify-content:space-between;
  transition:background .2s;
}
.faq-question:hover{background:var(--sand)}
.faq-question i{color:var(--gold);font-size:12px;transition:transform .2s;flex-shrink:0}
.faq-question.open i{transform:rotate(180deg)}
.faq-answer{
  font-size:13px;color:var(--muted);line-height:1.65;
  padding:0 14px;max-height:0;overflow:hidden;
  transition:max-height .3s ease,padding .3s ease;
}
.faq-answer.open{max-height:200px;padding:0 14px 12px}

/* ===== AGENT PANEL ===== */
.agent-offline-msg{
  text-align:center;padding:30px 20px;
}
.agent-offline-emoji{font-size:44px;margin-bottom:14px}
.agent-offline-h{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--ink);margin-bottom:8px}
.agent-offline-p{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:20px}
.agent-card{
  background:var(--sand);border:1px solid var(--border);
  padding:16px 18px;margin:0 14px 12px;border-radius:10px;
  display:flex;align-items:center;gap:14px;cursor:pointer;
  transition:border-color .2s;
}
.agent-card:hover{border-color:var(--gold)}
.agent-av{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:700;color:var(--ink);flex-shrink:0;
}
.agent-name{font-size:14px;font-weight:600;color:var(--ink)}
.agent-role{font-size:12px;color:var(--muted)}
.agent-status-badge{
  margin-left:auto;font-size:10px;letter-spacing:1px;text-transform:uppercase;font-weight:600;
  padding:3px 10px;border-radius:20px;flex-shrink:0;
}
.agent-online-b{background:rgba(76,175,80,.12);color:#388E3C}
.agent-away-b{background:rgba(255,193,7,.12);color:#F57F17}
.whatsapp-cta{
  margin:10px 14px;
  background:linear-gradient(135deg,#25D366,#128C7E);
  border:none;width:calc(100% - 28px);padding:13px;cursor:pointer;
  font-family:'Jost',sans-serif;font-size:13px;font-weight:600;
  letter-spacing:1px;text-transform:uppercase;color:white;
  border-radius:10px;display:flex;align-items:center;justify-content:center;gap:10px;
  transition:opacity .2s;
}
.whatsapp-cta:hover{opacity:.9}
.call-cta{
  margin:8px 14px 14px;
  background:var(--ink);border:1px solid rgba(191,155,90,.3);
  width:calc(100% - 28px);padding:12px;cursor:pointer;
  font-family:'Jost',sans-serif;font-size:13px;font-weight:500;
  color:var(--gold3);border-radius:10px;
  display:flex;align-items:center;justify-content:center;gap:10px;
  transition:background .2s;
}
.call-cta:hover{background:#2C2010}
.leave-msg-form{padding:10px 14px 14px}
.leave-msg-form h4{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--ink);margin-bottom:14px}

/* ===== EMOJI PICKER ===== */
.emoji-picker{
  position:absolute;bottom:72px;right:14px;
  background:var(--white);border:1px solid var(--border);
  box-shadow:var(--shadow);border-radius:12px;
  padding:12px;display:none;z-index:10;width:260px;
}
.emoji-picker.open{display:block;animation:pageIn .2s ease}
.emoji-grid{display:flex;flex-wrap:wrap;gap:2px}
.emoji-item{font-size:22px;cursor:pointer;padding:4px 6px;border-radius:6px;transition:background .15s}
.emoji-item:hover{background:var(--sand)}

/* ===== CHAT FOOTER ===== */
.chat-footer-brand{
  text-align:center;padding:8px;font-size:10px;color:var(--muted);
  letter-spacing:.5px;border-top:1px solid var(--border);flex-shrink:0;
}
.chat-footer-brand a{color:var(--gold);text-decoration:none}

/* Dark/light adjustments */
@media(max-width:480px){
  .chat-window{width:calc(100vw - 24px);right:12px;bottom:90px;height:540px}
  .chat-launcher{right:14px;bottom:20px}
}
