:root{
  --pink-50:#fff6f8;
  --pink-100:#ffecef;
  --pink-200:#ffdbe3;
  --rose:#f6e2e7;
  --gold:#C69214;
  --gold-2:#B38310;
  --ink:#2a2228;
  --text:#4a3f45;
  --muted:#8c7680;
  --shadow: 0 10px 30px rgba(148,87,128,.15);
  --radius:22px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;overflow-x:hidden}
body{
  font-family:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text); background:var(--pink-50);
}
.container{max-width:1160px;margin-inline:auto;padding:0 20px}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Playfair Display',serif;color:var(--ink);margin:0 0 10px}
.logo-script{font-family:'Great Vibes',cursive;color:var(--gold);font-size:44px;line-height:1}
.footer-logo{font-size:40px}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;
  background:linear-gradient(90deg,#ffdde1,#ee9ca7);
  box-shadow:0 8px 20px rgba(238,156,167,.25);
}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;height:84px}
.main-nav a{margin-left:24px;font-weight:500;position:relative}
.main-nav a:hover{color:var(--gold)}
.badge{background:var(--gold);color:#fff;border-radius:16px;padding:2px 8px;margin-left:8px;font-size:12px}

/* Hero */
.hero {
  height: 80vh;
  background: linear-gradient(rgba(255, 253, 253, 0.6), rgba(255,192,203,0.6)), 
              url("images/banner-bg.jpg") center/cover no-repeat;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  border-radius: 20px;
  box-shadow: 0px 10px 20px rgba(0,0,0,0.1);
}

.hero-content h1 {
  font-size: 3rem;
  color: #2c2c2c;
}

.hero-content p {
  margin: 1rem 0;
  font-size: 1.2rem;
  color: #444;
}

.hero-buttons .btn {
  margin: 0 10px;
  padding: 10px 20px;
  border-radius: 30px;
  font-weight: bold;
}

/* Buttons */
.btn{display:inline-block;padding:12px 24px;border-radius:14px;font-weight:600}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{filter:brightness(.95)}
.btn-outline{border:2px solid var(--gold);color:var(--gold);background:#fff}
.btn-outline:hover{background:var(--gold);color:#fff}

/* Sections */
.section{padding:42px 0}
.sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.link{color:var(--gold)}

/* Product grid */
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.card{background:#fff;border-radius:18px;box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}
.card .img{aspect-ratio:4/3;background:var(--pink-100)}
.card .body{padding:14px 16px;display:flex;flex-direction:column;gap:8px}
.title{font-weight:600;line-height:1.2;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.price{color:var(--gold-2);font-weight:600}
.card .cta{margin-top:auto}
.card .cta .btn{width:100%;text-align:center}

/* Sidebar + content */
.with-sidebar{display:grid;grid-template-columns:280px 1fr;gap:28px;padding:32px 0}
.sidebar{background:#fff;border-radius:18px;box-shadow:var(--shadow);padding:18px}
.filter-block{margin:10px 0 18px}
.filter-block label{display:block;font-weight:600;margin-bottom:8px}
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{padding:8px 14px;border-radius:999px;border:1.5px solid var(--pink-200);background:#fff;cursor:pointer}
.chip.active,.chip:hover{border-color:var(--gold);color:var(--gold)}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 360px;gap:24px;margin-top:10px}
.contact-form{background:#fff;border-radius:18px;box-shadow:var(--shadow);padding:18px}
.contact-form input,.contact-form textarea{width:100%;padding:12px 14px;margin-bottom:12px;border:1.5px solid var(--pink-200);border-radius:12px}
.contact-card{background:#fff;border-radius:18px;box-shadow:var(--shadow);padding:18px}

/* Cart */
.cart-list{display:flex;flex-direction:column;gap:14px;margin:18px 0}
.cart-item{display:grid;grid-template-columns:80px 1fr auto auto;gap:14px;align-items:center;background:#fff;border-radius:14px;box-shadow:var(--shadow);padding:10px 14px}
.qty{display:flex;align-items:center;gap:8px}
.qty button{width:28px;height:28px;border-radius:8px;border:1px solid var(--pink-200);background:#fff;cursor:pointer}
.cart-summary{display:flex;gap:16px;align-items:center;justify-content:flex-end}

/* Footer */
html, body {
  height: 100%;
  margin: 0;
  display: flex;
  flex-direction: column;
}

main {
  flex: 1;
}

.site-footer{background:linear-gradient(180deg,#fff, #fff 30%, #f8eef1);padding-top:28px;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:20px}
.site-footer h4{margin:0 0 8px}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin:6px 0}
.newsletter{display:flex;gap:10px;margin:8px 0}
.newsletter input{flex:1;border:1.5px solid var(--pink-200);border-radius:12px;padding:10px 12px}
.newsletter button{background:var(--gold);border:none;color:#fff;border-radius:12px;padding:10px 16px;font-weight:600}
.tagline,.social{color:var(--muted)}
.copyright{text-align:center;color:var(--muted);padding:12px 0 20px}

/* Responsive */
@media (max-width: 1100px){
  .product-grid{grid-template-columns:repeat(3,1fr)}
  .with-sidebar{grid-template-columns:1fr}
}
@media (max-width: 720px){
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width: 520px){
  .product-grid{grid-template-columns:1fr}
}


/* ===== Header layout upgrades ===== */
.site-header{ position: sticky; top: 0; background: var(--pink-50); backdrop-filter: blur(6px); z-index: 20; box-shadow: var(--shadow); }
.nav-wrap{ display:flex; align-items:center; justify-content:space-between; gap:18px; padding:10px 0; }
.nav-wrap .brand{ flex:0 0 auto; text-decoration:none; }
.site-search{ flex:1 1 520px; display:flex; align-items:center; justify-content:center; }
.site-search input{ width:100%; max-width:520px; padding:10px 14px; border-radius: 40px; border:1px solid #f0d6de; background:#fff; }
.site-search button{ margin-left:8px; border:none; background:var(--gold); color:#fff; padding:10px 16px; border-radius:30px; cursor:pointer; }
.main-nav{ display:flex; align-items:center; gap:18px; }
.main-nav a{ text-decoration:none; }

/* Account area */
.account-area{ display:flex; gap:10px; align-items:center; }
.btn.mini{ padding:8px 14px; border-radius:22px; font-weight:600; background:#fff; border:1.5px solid var(--gold); color:var(--gold); }
.btn.mini.outline{ background:#fff; }
.dropdown{ position:relative; }
.avatar-btn{ display:flex; align-items:center; gap:10px; padding:6px 12px; border-radius:30px; border:1.5px solid var(--gold); background:#fff; cursor:pointer; }
.avatar-btn img{ width:28px; height:28px; border-radius:50%; object-fit:cover; }
.dropdown .menu{ position:absolute; right:0; top:110%; background:#fff; border:1px solid #f0d6de; border-radius:16px; box-shadow:var(--shadow); padding:8px; min-width:180px; display:none; }
.dropdown .menu.open{ display:block; }
.dropdown .menu a, .dropdown .menu .linklike{ display:block; padding:10px 12px; border-radius:10px; text-decoration:none; color:var(--text); background:transparent; border:none; width:100%; text-align:left; cursor:pointer; }
.dropdown .menu a:hover, .dropdown .menu .linklike:hover{ background:var(--pink-100); }

/* Remove floating auth pinning (legacy) */
.floating-auth{ position: static !important; display:none !important; }


/* Product detail */
.pd-wrap{ display:grid; grid-template-columns: 520px 1fr; gap:32px; align-items:start; margin: 30px 0; }
.pd-img{ width:100%; padding-top:100%; background:#ffecef; border-radius: var(--radius); box-shadow: var(--shadow); }
.pd-info h1{ margin:0 0 6px; }
.pd-price{ font-size:22px; color:var(--gold); font-weight:700; margin-bottom:14px; }
.pd-actions .btn{ margin-right:10px; }
@media(max-width:900px){ .pd-wrap{ grid-template-columns:1fr; } }

/* Buttons outline variant */
.btn.btn-outline{ background:#fff; border:2px solid var(--gold); color: var(--gold); }


.orders .order-card{ border:1px solid #f0d6de; border-radius:16px; padding:14px; margin:12px 0; box-shadow: var(--shadow); background:#fff; }
.orders .row{ display:flex; justify-content:space-between; align-items:center; margin:6px 0; }
.orders .oid{ font-weight:700; }
.track .track-form{ display:flex; gap:8px; }
.track .track-form input{ flex:1; padding:10px 14px; border-radius:14px; border:1px solid #f0d6de; }
.track .track-card{ border:1px solid #f0d6de; padding:16px; border-radius:16px; background:#fff; box-shadow: var(--shadow); }
.track .progress{ display:grid; grid-template-columns:repeat(5,1fr); gap:8px; margin:12px 0; }
.track .step{ padding:8px; border-radius:10px; background:#ffecef; text-align:center; }
.track .step.done{ background:linear-gradient(90deg, var(--pink-200), #ffdbe3 60%); border:1px solid var(--gold); }

.ck-wrap{ display:grid; grid-template-columns: 1fr 1fr; gap:24px; }
.summary, .address{ background:#fff; border:1px solid #f0d6de; border-radius:16px; padding:16px; box-shadow: var(--shadow); }
.summary .item, .summary .total{ display:flex; justify-content:space-between; padding:8px 0; }
.address input{ width:100%; padding:10px 12px; border:1px solid #f0d6de; border-radius:12px; margin:8px 0; }
@media(max-width:900px){ .ck-wrap{ grid-template-columns:1fr; } }


/* --- Product gallery & zoom --- */
.pd-wrap { display: grid; grid-template-columns: 1.2fr 1fr; gap: 2rem; align-items: start; }
.pd-gallery { display: grid; gap: 0.75rem; }
.gallery-main { overflow: hidden; border-radius: 1rem; border: 1px solid rgba(255,215,0,.3); }
.gallery-main img { width: 100%; height: auto; display: block; transition: transform .2s ease; }
.gallery-thumbs { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: .5rem; }
.gallery-thumbs img { width: 100%; aspect-ratio: 1/1; object-fit: cover; border-radius: .75rem; border: 1px solid rgba(255,215,0,.35); cursor: pointer; }
.pd-title { font-size: clamp(1.4rem, 1.2rem + 1.2vw, 2.2rem); color: #7a004b; margin: 0 0 .25rem; }
.pd-price { font-weight: 600; color: #b8860b; margin-bottom: .75rem; }
.pd-actions .btn { margin-right: .5rem; }
@media (max-width: 900px){ .pd-wrap { grid-template-columns: 1fr; } }


/* --- Shop grid --- */
.shop-container { padding: 2rem 1rem; }
.shop-toolbar { display:flex; justify-content:space-between; align-items:center; gap:1rem; margin-bottom:1rem; flex-wrap:wrap; }
.chip { border:1px solid rgba(184,134,11,.45); padding:.4rem .8rem; border-radius:999px; background:transparent; cursor:pointer; }
.chip.active, .chip:hover { background:linear-gradient(90deg,#ffc0cb,#ffd700); color:#5a0040; border-color:transparent; }
.product-grid { display:grid; grid-template-columns: repeat(auto-fill,minmax(220px,1fr)); gap:1rem; }
.card { background:white; border:1px solid rgba(255,215,0,.25); border-radius:1rem; overflow:hidden; display:flex; flex-direction:column; }
.card-img img{ width:100%; aspect-ratio:1/1; object-fit:cover; display:block; }
.card-body{ padding:.75rem .9rem; display:flex; flex-direction:column; gap:.4rem; }
.card-title{ margin:0; font-size:1rem; color:#7a004b; }
.card-price{ color:#b8860b; font-weight:600; }
.card-actions{ padding:.75rem .9rem 1rem; }
.btn{ display:inline-block; padding:.5rem .9rem; border-radius:.75rem; text-decoration:none; border:none; }
.btn-gold{ background:linear-gradient(90deg,#ffc0cb,#ffd700); color:#5a0040; font-weight:600; }
.btn-outline{ background:transparent; border:1px solid rgba(184,134,11,.5); }


/* === Responsive Adjustments === */

/* Shop grid responsiveness */
.shop-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 1.2rem;
}

@media (max-width: 1024px) {
  .shop-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .shop-grid {
    grid-template-columns: 1fr;
  }
}

/* Product detail responsiveness */
.product-detail {
  display: flex;
  gap: 2rem;
}
.product-gallery {
  flex: 1;
}
.product-info {
  flex: 1;
}

@media (max-width: 1024px) {
  .product-detail {
    flex-direction: column;
  }
  .product-thumbs {
    display: flex;
    overflow-x: auto;
    gap: .5rem;
  }
  .product-thumbs img {
    flex: 0 0 auto;
  }
}

/* Navbar responsiveness */
.navbar {
  flex-wrap: wrap;
}
.navbar a {
  padding: .5rem 1rem;
}

/* Footer responsiveness */
footer .footer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
}


/* === Mobile Navbar === */
.menu-toggle {
  display: none;
  font-size: 2rem;
  cursor: pointer;
  color: #d4af37; /* golden */
}

@media (max-width: 768px) {
  .nav-links {
    display: none;
    flex-direction: column;
    background: #ffe4ec; /* light pink */
    width: 100%;
    position: absolute;
    top: 60px;
    left: 0;
    padding: 1rem 0;
    z-index: 999;
  }
  .nav-links.active {
    display: flex;
  }
  .menu-toggle {
    display: block;
  }
}
/* --- Responsive upgrades --- */

/* Shop sidebar collapse on mobile */
@media (max-width: 768px) {
  .with-sidebar {
    grid-template-columns: 1fr;
  }
  .sidebar {
    order: 2;
    margin-top: 1.5rem;
  }
  .content {
    order: 1;
  }
}

/* Header navigation collapse */
@media (max-width: 768px) {
  .main-nav {
    display: none;
    flex-direction: column;
    background: var(--pink-100);
    padding: 1rem;
    border-radius: 14px;
    margin-top: 0.5rem;
  }
  .main-nav.active {
    display: flex;
  }
  .menu-toggle {
    display: block;
    font-size: 1.6rem;
    cursor: pointer;
    color: var(--gold);
  }
}

/* Footer grid stack */
@media (max-width: 768px) {
  .footer-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 520px) {
  .footer-grid {
    grid-template-columns: 1fr;
  }
  .hero-content h1 {
    font-size: 2rem;
  }
}
/* Mobile nav styles */
.menu-toggle {
  display: none;
  font-size: 28px;
  cursor: pointer;
  z-index: 1001; /* button always on top */
}

@media (max-width: 768px) {
  .main-nav {
    display: none;
    flex-direction: column;
    background: #fff;
    position: absolute;
    top: 70px;
    right: 20px;
    width: 220px;
    padding: 15px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    border-radius: 12px;
    z-index: 1000;
  }

  .main-nav a,
  .main-nav .account-area {
    display: block;
    padding: 10px;
    text-align: left;
  }

  .main-nav.active {
    display: flex;
  }

  .menu-toggle {
    display: block;
    font-size: 1.8rem;
    cursor: pointer;
    color: var(--gold);
  }
}


/* === Responsive Navbar + Search === */
header .menu-toggle{ display:none; font-size:28px; cursor:pointer; padding:8px 12px; border-radius:12px; }
header .search-toggle{ display:none; font-size:22px; background:transparent; border:0; padding:8px 10px; }
@media (max-width: 1023px){
  header .menu-toggle, header .search-toggle{ display:inline-block; }
  nav.main-nav{ max-height:0; overflow:hidden; transition:max-height .35s ease; background:#fff6f8; border-radius:16px; box-shadow: var(--shadow); margin-top:8px; }
  nav.main-nav.active{ max-height:auto; }
  .mobile-search{ display:none; margin-top:8px; }
  .mobile-search.active{ display:block; }
  .mobile-search input[type="search"]{ width:100%; padding:12px 16px; border-radius:999px; border:1.5px solid var(--gold); }
}
@media (min-width:1024px){
  nav.main-nav{ display:flex; align-items:center; gap:22px; }
}

/* Buttons unify */
.btn{ display:inline-block; padding:12px 22px; border-radius:999px; font-weight:600; }
.btn-gold{ background: linear-gradient(135deg, #f9d778, #C69214); color:#fff; border:0; box-shadow:0 10px 20px rgba(198,146,20,.25); transition: transform .18s ease, box-shadow .18s ease; }
.btn-gold:hover{ transform: translateY(-2px); box-shadow:0 14px 28px rgba(198,146,20,.32); }
.btn-outline{ border:2px solid var(--gold); color: var(--gold); background:transparent; transition: transform .18s ease, box-shadow .18s ease, background .18s ease; }
.btn-outline:hover{ transform: translateY(-2px); box-shadow:0 10px 20px rgba(198,146,20,.18); background:#fff3cc; }

/* Product grid */
.product-grid{ display:grid; gap:16px; }
.product-grid .card{ border-radius:18px; background:#fff; overflow:hidden; transition: transform .18s ease, box-shadow .18s ease; }
.product-grid .card:hover{ transform: translateY(-4px); box-shadow:0 14px 34px rgba(148,87,128,.20); }
.product-grid .card-img{ aspect-ratio:1/1; overflow:hidden; }
.product-grid .card-img img{ width:100%; height:100%; object-fit:cover; transition: transform .25s ease; }
.product-grid .card:hover .card-img img{ transform: scale(1.03); }
@media (max-width:479px){ .product-grid{ grid-template-columns: repeat(2,1fr); gap:12px; } }
@media (min-width:480px) and (max-width:767px){ .product-grid{ grid-template-columns: repeat(2,1fr);} }
@media (min-width:768px) and (max-width:1023px){ .product-grid{ grid-template-columns: repeat(3,1fr);} }
@media (min-width:1024px){ .product-grid{ grid-template-columns: repeat(4,1fr);} }

/* Safe padding and headings */
@media (max-width:768px){
  body, .container, section, header, footer{ padding-left:16px; padding-right:16px; }
  .sec-head, .section-title, h2, h3{ padding-left:4px; padding-right:4px; }
  header .brand a, header .logo{ pointer-events:none; } /* non-clickable logo */
  header .brand{ font-size:20px; }
}

/* Footer two-column on mobile: Quick Links left, Support right */
.footer-grid{ display:grid; gap:18px; }
@media (max-width:767px){
  .footer-grid{ grid-template-columns: 1fr; }
  .footer-columns{ display:grid; grid-template-columns: 1fr 1fr; gap:16px; }
}

/* Newsletter animations */
.newsletter input[type="email"], .newsletter button{ transition: all .25s ease; }
.newsletter input[type="email"]:focus{ border-color: var(--gold); box-shadow: 0 0 0 3px rgba(198,146,20,.2); }
.newsletter button:hover{ transform: translateY(-2px); }


/* === Global responsive & header cleanup === */
header .menu-toggle{ display:none; font-size:28px; cursor:pointer; padding:8px 10px; background:transparent; border:0; }
header .search-toggle{ display:none; font-size:22px; padding:8px 8px; background:transparent; border:0; }
header .controls *{ background: transparent !important; box-shadow: none !important; } /* remove boxy pills */

@media (max-width:1023px){
  header .menu-toggle{ display:inline-block; }
  /* Only show desktop search on desktop; mobile search via toggle */
  header form.site-search.desktop{ display:none; }
  nav.main-nav{ max-height:0; overflow:hidden; transition:max-height .35s ease; background:#fff6f8; border-radius:16px; box-shadow: 0 10px 24px rgba(0,0,0,.06); margin-top:8px; }
  nav.main-nav.active{ max-height: fit-content; }
  .mobile-search{ display:none; margin-top:8px; }
  .mobile-search.active{ display:block; }
  .mobile-search input[type="search"]{ width:100%; padding:12px 16px; border-radius:999px; border:1.5px solid var(--gold); }
  /* Smaller logo on phones */
  .logo, .logo-text{ font-size: 20px !important; line-height:1.1; }
}
@media (max-width:480px){
  .logo, .logo-text{ font-size: 18px !important; }
}

@media (min-width:1024px){
  header form.site-search.desktop{ display:block; }
  .mobile-search{ display:none !important; }
}

/* Footer columns */
.footer-columns{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (min-width:768px){ .footer-columns{ gap:24px; }}

/* Newsletter glowing button */
.newsletter .btn-subscribe{
  background: linear-gradient(135deg, #f9d778, #C69214);
  color:#fff; border:0; border-radius:999px; padding:10px 18px; font-weight:600;
  box-shadow: 0 10px 20px rgba(198,146,20,.35);
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
}
.newsletter .btn-subscribe:hover{ transform: translateY(-2px); box-shadow:0 16px 30px rgba(198,146,20,.45); filter: brightness(1.04); }

/* Safe side paddings so text doesn't touch edges */
@media (max-width:768px){
  main, section, .section, .sec, .container{ padding-left: 12px; padding-right: 12px; }
  .sec-head, h2.section-title, .section h2, .section .title{ padding-left:4px; padding-right:4px; }
}



/* === Category Filter UI (from reference zip; style-only) === */
.with-sidebar{ display:grid; grid-template-columns: 280px 1fr; gap:28px; padding:32px 0; }
.sidebar{ background:#fff; border-radius:18px; box-shadow: var(--shadow); padding:18px; }
.filter-block{ margin:10px 0 18px; }
.filter-block label{ display:block; font-weight:600; margin-bottom:8px; }
.chips{ display:flex; flex-wrap:wrap; gap:10px; }
.chip{ padding:8px 14px; border-radius:999px; border:1.5px solid var(--pink-200); background:#fff; cursor:pointer; }
.chip.active, .chip:hover{ border-color: var(--gold); color: var(--gold-2); }
.range-val{ font-weight:700; color: var(--ink); }
@media (max-width: 720px){
  .with-sidebar{ display:block; padding:18px 0; }
  .sidebar{ position: static; }
}


/* === Desktop card & section tweaks (non-mobile) === */
@media (min-width: 992px){
  .content.shop-grid{ padding-top: 0; }
  .shop-grid .sec-head{ margin-top: 0; margin-bottom: 16px; text-align:left; }
  .product-grid{ align-items: stretch; }
  .product-grid .card{ display:flex; flex-direction:column; }
  .product-grid .card .body{ display:flex; flex-direction:column; gap:8px; }
  .product-grid .card .cta{ margin-top:auto; }
}



/* === Desktop product card bottom-fixed actions === */
@media (min-width: 1025px){
  .product-grid .card{ display:flex; flex-direction:column; height:100%; }
  .product-grid .card-body{ display:flex; flex-direction:column; gap:.4rem; }
  .product-grid .card-actions{ margin-top:auto; }
}


/* === Clean Filter Card === */
.filter-card{ background:#fff; border-radius:20px; box-shadow: var(--shadow); padding:20px; }
.filter-title{ margin:0 0 10px; font-size:1.4rem; color:#2a0c1f; }
.filter-card .filter-block{ margin:14px 0 18px; }
.filter-card label{ display:block; font-weight:600; color:#5a2d82; margin-bottom:8px; }
.filter-card .chips{ display:flex; flex-wrap:wrap; gap:10px; }
.filter-card .chip{ padding:8px 14px; border-radius:999px; border:1px solid #f1cfe1; background:#fff; cursor:pointer; transition:all .2s ease; }
.filter-card .chip:hover{ border-color:#d4af37; color:#7a004b; }
.filter-card .chip.active{ background:linear-gradient(90deg,#ffd5e5,#ffe9a6); border-color: #eec86b; box-shadow: 0 6px 16px rgba(212,175,55,.16); color:#5a2d82; }
.filter-card .price-note{ margin-top:10px; color:#555; font-weight:500; }

/* === Product Detail: force square main image === */
.gallery-main img{ width:100%; aspect-ratio:1/1; object-fit:cover; display:block; }


@media (max-width: 768px){
  .product-grid .card-actions{ padding-bottom: 14px; }
}
