
:root {
  --burgundy: #7b1737;
  --burgundy-dark: #5b0f28;
  --rose: #d98ba7;
  --pink: #f3c5d2;
  --blush: #f9edf1;
  --soft: #fff7f9;
  --text: #23161d;
  --muted: #6f5b63;
  --border: #ead4dc;
  --white: #ffffff;
  --shadow: 0 18px 45px rgba(123, 23, 55, 0.10);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Arial, Helvetica, sans-serif;
  color: var(--text);
  background: linear-gradient(180deg, #fffdfd 0%, #fff7fa 45%, #fffdfd 100%);
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button, input { font: inherit; }
.container { width: min(1280px, calc(100% - 32px)); margin: 0 auto; }
.section { padding: 34px 0; }
.muted { color: var(--muted); }
.top-strip {
  background: linear-gradient(90deg, var(--burgundy-dark), var(--burgundy), #9a3556);
  color: #fff; padding: 10px 0; font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase;
}
.top-strip .container { display:flex; justify-content:space-between; gap:16px; align-items:center; }
.site-header {
  position: sticky; top:0; z-index:50; background:rgba(255,255,255,0.92); backdrop-filter: blur(12px);
  border-bottom:1px solid rgba(123, 23, 55, 0.08);
}
.site-header.scrolled { box-shadow: 0 12px 30px rgba(35, 22, 29, 0.08); }
.header-wrap { display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:12px; min-height:84px; position:relative; }
.nav-left, .nav-right { display:flex; align-items:center; gap:18px; }
.nav-left a, .nav-right a, .nav-right button { font-size:14px; text-transform:uppercase; letter-spacing:0.08em; background:none; border:0; cursor:pointer; padding:0; }
.logo img { height:50px; width:auto; margin:0 auto; }
.mobile-toggle { display:none; align-items:center; justify-content:center; width:42px; height:42px; border-radius:50%; background:var(--blush); border:1px solid var(--border); color:var(--burgundy); font-size:22px; }
.icon-badge { display:inline-flex; align-items:center; justify-content:center; min-width:50px; height:50px; border-radius:999px; background:var(--blush); color:var(--burgundy); border:1px solid var(--border); }
.nav-menu { display:flex; align-items:center; gap:18px; }
.hero { padding: 26px 0 38px; }
.hero-card { position:relative; border-radius:34px; overflow:hidden; min-height:620px; box-shadow:var(--shadow); background:#f8e7ed; display:grid; align-items:center; }
.hero-card::after { content:''; position:absolute; inset:0; background:linear-gradient(90deg, rgba(74, 12, 35, 0.48) 0%, rgba(74, 12, 35, 0.18) 32%, rgba(74, 12, 35, 0.00) 60%); }
.hero-image { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero-content { position:relative; z-index:1; max-width:510px; padding:42px; color:#fff; }
.eyebrow { display:inline-block; padding:10px 14px; border-radius:999px; background:rgba(255,255,255,0.16); border:1px solid rgba(255,255,255,0.28); backdrop-filter:blur(6px); font-size:12px; text-transform:uppercase; letter-spacing:0.12em; margin-bottom:16px; }
.hero h1 { font-size:clamp(36px, 5vw, 68px); line-height:0.98; margin:0 0 16px; letter-spacing:-0.04em; }
.hero p { font-size:17px; line-height:1.7; margin:0 0 26px; color:rgba(255,255,255,0.92); }
.btn, .ghost-btn { display:inline-flex; align-items:center; justify-content:center; gap:10px; min-height:50px; padding:0 24px; border-radius:999px; font-weight:700; text-transform:uppercase; letter-spacing:0.08em; border:1px solid transparent; transition:0.25s ease; }
.btn { background:linear-gradient(135deg, var(--burgundy), #b14e6f); color:#fff; box-shadow:0 14px 32px rgba(123, 23, 55, 0.24); }
.btn:hover { transform:translateY(-2px); }
.ghost-btn { background:rgba(255,255,255,0.14); color:#fff; border-color:rgba(255,255,255,0.28); }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; }
.feature-grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:18px; margin-top:24px; }
.feature-card { background:var(--white); border:1px solid var(--border); border-radius:24px; padding:20px; box-shadow:0 10px 22px rgba(35,22,29,0.04); }
.feature-card strong { display:block; color:var(--burgundy); font-size:24px; margin-bottom:8px; }
.section-head { display:flex; justify-content:space-between; align-items:end; gap:16px; margin-bottom:18px; }
.section-head h2, .page-hero h1 { margin:0; font-size:clamp(28px, 4vw, 42px); letter-spacing:-0.03em; }
.section-head p { margin:8px 0 0; max-width:620px; color:var(--muted); line-height:1.7; }
.chip-row { display:flex; gap:10px; flex-wrap:wrap; }
.chip { display:inline-flex; padding:10px 14px; border-radius:999px; background:var(--soft); border:1px solid var(--border); color:var(--burgundy); font-weight:700; font-size:12px; text-transform:uppercase; letter-spacing:0.08em; }
.horizontal-products { display:grid; grid-auto-flow:column; grid-auto-columns:minmax(250px, 1fr); gap:18px; overflow-x:auto; padding-bottom:8px; scroll-snap-type:x proximity; }
.horizontal-products::-webkit-scrollbar { height:8px; }
.horizontal-products::-webkit-scrollbar-thumb { background:#d7bcc6; border-radius:999px; }
.product-card { scroll-snap-align:start; background:var(--white); border-radius:24px; overflow:hidden; border:1px solid var(--border); box-shadow:0 16px 34px rgba(123, 23, 55, 0.07); transition:transform 0.28s ease, box-shadow 0.28s ease; }
.product-card:hover { transform:translateY(-6px); box-shadow:0 24px 40px rgba(123, 23, 55, 0.14); }
.product-image-wrap { position:relative; aspect-ratio:3/4; background:linear-gradient(180deg, #faf5f7, #fff); }
.product-image-wrap img { width:100%; height:100%; object-fit:cover; }
.badge { position:absolute; top:16px; left:16px; padding:9px 14px; border-radius:999px; color:#fff; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.08em; background:linear-gradient(135deg, #ca5577, var(--burgundy)); }
.product-body { padding:18px; }
.product-title { margin:0 0 6px; font-size:23px; line-height:1.1; letter-spacing:-0.03em; }
.price-row { display:flex; align-items:center; gap:10px; margin:10px 0 14px; }
.price { font-weight:700; color:var(--burgundy); font-size:18px; }
.old-price { color:#9a8089; text-decoration:line-through; font-size:14px; }
.swatches { display:flex; gap:8px; align-items:center; margin-bottom:16px; flex-wrap:wrap; }
.swatch { width:18px; height:18px; border-radius:50%; border:2px solid #fff; box-shadow:0 0 0 1px rgba(0,0,0,.08); }
.product-actions { display:flex; gap:10px; }
.product-actions .btn, .product-actions .ghost { min-height:44px; flex:1; padding:0 14px; border-radius:14px; font-size:12px; }
.ghost { display:inline-flex; align-items:center; justify-content:center; border:1px solid var(--border); background:var(--soft); color:var(--burgundy); font-weight:700; text-transform:uppercase; letter-spacing:0.08em; }
.banner-grid { display:grid; grid-template-columns:1.2fr 0.8fr; gap:18px; }
.promo-tile { position:relative; border-radius:28px; overflow:hidden; min-height:360px; background:linear-gradient(180deg, #f9eef2, #fff); border:1px solid var(--border); box-shadow:var(--shadow); }
.promo-tile img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.promo-overlay { position:absolute; inset:auto 0 0 0; padding:28px; background:linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(66, 7, 25, 0.78) 100%); color:#fff; }
.promo-overlay h3 { margin:0 0 8px; font-size:30px; }
.promo-overlay p { margin:0 0 16px; line-height:1.65; color:rgba(255,255,255,.92); }
.category-links { display:grid; grid-template-columns:repeat(5, 1fr); gap:14px; }
.category-link { background:var(--white); border:1px solid var(--border); border-radius:22px; padding:18px; text-align:center; box-shadow:0 10px 20px rgba(35, 22, 29, 0.04); transition:0.25s ease; }
.category-link:hover { transform:translateY(-4px); color:var(--burgundy); box-shadow:var(--shadow); }
.category-link strong { display:block; font-size:18px; margin-bottom:6px; }
.page-hero { padding:34px 0 12px; }
.page-hero-card { position:relative; min-height:320px; border-radius:28px; overflow:hidden; border:1px solid var(--border); box-shadow:var(--shadow); background:linear-gradient(135deg, #fdeff3, #ffffff); }
.page-hero-card::after { content:''; position:absolute; inset:0; background:linear-gradient(90deg, rgba(255,255,255,0.95) 0%, rgba(255,255,255,0.74) 42%, rgba(255,255,255,0.10) 100%); }
.page-hero-card img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.page-hero-content { position:relative; z-index:1; max-width:520px; padding:36px; }
.page-hero p { color:var(--muted); line-height:1.75; }
.product-grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:18px; }
.newsletter { background:linear-gradient(135deg, #fceff3, #f8dee8 58%, #f4cdd7 100%); border-top:1px solid rgba(123, 23, 55, 0.1); border-bottom:1px solid rgba(123, 23, 55, 0.1); margin-top:24px; }
.newsletter-wrap { display:grid; grid-template-columns:0.9fr 1.1fr; gap:20px; align-items:center; padding:44px 0; }
.newsletter h3 { margin:0 0 10px; font-size:clamp(26px, 4vw, 38px); }
.newsletter p { margin:0; color:var(--muted); line-height:1.7; }
.newsletter-form { display:flex; align-items:center; gap:10px; padding:10px; background:rgba(255,255,255,0.75); border:1px solid rgba(123,23,55,0.12); border-radius:999px; box-shadow:0 14px 32px rgba(123, 23, 55, 0.08); }
.newsletter-form input { flex:1; min-width:0; background:transparent; border:0; outline:0; padding:10px 16px; font-size:15px; }
.newsletter-form button { white-space:nowrap; }
.site-footer { padding:34px 0 42px; background:#fff; }
.footer-grid { display:grid; grid-template-columns:1.2fr 1fr 1fr 1fr; gap:22px; }
.footer-brand img { height:44px; width:auto; margin-bottom:14px; }
.footer-brand p { color:var(--muted); max-width:330px; line-height:1.7; }
.footer-title { font-size:15px; text-transform:uppercase; letter-spacing:0.08em; margin:8px 0 14px; color:var(--burgundy); }
.footer-links { display:grid; gap:10px; }
.footer-links a { color:var(--muted); }
.footer-bottom { display:flex; justify-content:space-between; gap:12px; align-items:center; border-top:1px solid var(--border); margin-top:24px; padding-top:18px; color:var(--muted); font-size:14px; }
.socials { display:flex; gap:10px; }
.socials span { width:38px; height:38px; display:inline-flex; align-items:center; justify-content:center; border-radius:999px; border:1px solid var(--border); background:var(--soft); }
.chat-bubble { position:fixed; right:18px; bottom:18px; z-index:40; padding:14px 18px; border-radius:999px; background:#111; color:#fff; box-shadow:0 16px 30px rgba(0,0,0,0.25); font-weight:700; display:inline-flex; gap:10px; align-items:center; }
.chat-bubble::after { content:'1'; position:absolute; top:-4px; right:-4px; width:22px; height:22px; border-radius:50%; background:#ff477c; color:#fff; display:grid; place-items:center; font-size:12px; }
@media (max-width:1100px) { .feature-grid, .category-links { grid-template-columns:repeat(2,1fr);} .product-grid{grid-template-columns:repeat(3,1fr);} .footer-grid{grid-template-columns:repeat(2,1fr);} .banner-grid, .newsletter-wrap{grid-template-columns:1fr;} }
@media (max-width:860px) { .header-wrap{grid-template-columns:auto 1fr auto;} .nav-left{gap:10px;} .nav-left .nav-menu{display:none;} .mobile-toggle{display:inline-flex;} .nav-right{justify-content:end;} .logo img{height:42px;} .hero-card{min-height:520px;} .hero-content{padding:30px; max-width:420px;} .product-grid{grid-template-columns:repeat(2,1fr);} .nav-menu.mobile-panel{position:absolute; top:100%; left:16px; right:16px; display:none; flex-direction:column; align-items:stretch; background:#fff; border:1px solid var(--border); border-radius:18px; padding:16px; box-shadow:var(--shadow);} .nav-menu.mobile-panel.open{display:flex;} .nav-menu.mobile-panel a{padding:12px 4px; border-bottom:1px solid rgba(123,23,55,0.06);} .nav-menu.mobile-panel a:last-child{border-bottom:0;} }
@media (max-width:640px) { .container{width:min(100% - 20px, 1280px);} .top-strip .container{justify-content:center; text-align:center;} .nav-right .hide-mobile{display:none;} .hero-card{min-height:460px; border-radius:24px;} .hero-content{padding:22px;} .hero p{font-size:15px;} .feature-grid,.category-links,.product-grid,.footer-grid{grid-template-columns:1fr;} .horizontal-products{grid-auto-columns:80%;} .section-head{flex-direction:column; align-items:start;} .newsletter-form{flex-direction:column; border-radius:22px;} .newsletter-form button,.newsletter-form .btn{width:100%;} .footer-bottom{flex-direction:column; align-items:start;} .chat-bubble{padding:12px 15px;} }


/* ===== NAVBAR FIX + BEAUTIFUL HOVER UPDATE ===== */
.site-header {
  background: rgba(255, 255, 255, 0.96);
  border-bottom: 1px solid rgba(123, 23, 55, 0.10);
}

.header-wrap {
  min-height: 86px;
  position: relative;
}

.logo img {
  height: 54px;
  max-width: 290px;
  object-fit: contain;
}

.nav-left .nav-menu {
  display: flex;
  align-items: center;
  gap: 8px;
}

.nav-left .nav-menu a {
  position: relative;
  padding: 11px 14px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: #351923;
  transition: color 0.25s ease, background 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
}

.nav-left .nav-menu a:hover {
  color: var(--burgundy);
  background: linear-gradient(135deg, #fff7f9, #f8dfe8);
  box-shadow: 0 10px 22px rgba(123, 23, 55, 0.10);
  transform: translateY(-1px);
}

.nav-left .nav-menu a::after {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 5px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--burgundy), var(--rose));
  opacity: 0;
  transform: scaleX(0.3);
  transition: 0.25s ease;
}

.nav-left .nav-menu a:hover::after {
  opacity: 1;
  transform: scaleX(1);
}

.nav-right {
  justify-content: flex-end;
}

.nav-right .hide-mobile {
  color: #351923;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.icon-badge {
  
  background: linear-gradient(180deg, #fff, #fff4f7);
  color: var(--burgundy);
  border-color: rgba(123, 23, 55, 0.14);
  transition: 0.25s ease;
}

.icon-badge:hover {
  background: linear-gradient(135deg, var(--burgundy), #b14e6f);
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 12px 24px rgba(123, 23, 55, 0.18);
}

.nav-menu.mobile-panel {
  display: none;
}

@media (max-width: 860px) {
  .header-wrap {
    min-height: 78px;
  }

  .logo img {
    height: 44px;
    max-width: 210px;
  }

  .nav-left .nav-menu {
    display: none;
  }

  .mobile-toggle {
    display: inline-flex;
  }

  .nav-menu.mobile-panel {
    position: absolute;
    top: calc(100% + 10px);
    left: 10px;
    right: 10px;
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 4px;
    background: rgba(255,255,255,0.98);
    border: 1px solid rgba(123,23,55,0.12);
    border-radius: 22px;
    padding: 12px;
    box-shadow: 0 22px 50px rgba(123,23,55,0.16);
  }

  .nav-menu.mobile-panel.open {
    display: flex;
  }

  .nav-menu.mobile-panel a {
    padding: 13px 14px;
    border-radius: 14px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.12em;
    color: #351923;
  }

  .nav-menu.mobile-panel a:hover {
    background: var(--blush);
    color: var(--burgundy);
  }
}
