@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Raleway:wght@300;400;500;600;700&family=Dancing+Script:wght@600;700&display=swap');

/* ===========================
   VARIABLES
=========================== */
:root {
  --dark:   #2C3531;
  --teal:   #116466;
  --beige:  #D9B08C;
  --peach:  #FFCB9A;
  --mint:   #D1E8E2;
  --cream:  #FDFAF5;
  --white:  #FFFFFF;
  --text:   #2C3531;
  --muted:  #5a6a65;
  --shadow: rgba(44,53,49,0.10);
}

/* ===========================
   RESET & BASE
=========================== */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: 'Raleway', sans-serif;
  color: var(--text);
  background: var(--cream);
  line-height: 1.6;
  font-size: 16px;
}

img { display: block; max-width: 100%; }

a { text-decoration: none; color: inherit; }

ul { list-style: none; }

/* ===========================
   HEADER
=========================== */
header {
  background: var(--dark);
  padding: 1rem 2.5rem;
  position: sticky;
  top: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: space-between;
  box-shadow: 0 3px 25px rgba(0,0,0,0.35);
}

/* Logo */
.logo {
  display: flex;
  align-items: center;
  gap: 0.9rem;
}

.logo-icon {
  width: 44px;
  height: 44px;
  flex-shrink: 0;
  color: var(--beige);
  transition: color 0.3s;
}

.logo:hover .logo-icon { color: var(--peach); }

.logo-text {
  display: flex;
  flex-direction: column;
  line-height: 1.1;
}

.logo-text .brand {
  font-family: 'Raleway', sans-serif;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--mint);
  opacity: 0.8;
}

.logo-text .name {
  font-family: 'Playfair Display', serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--beige);
}

.logo-text .sub {
  font-family: 'Dancing Script', cursive;
  font-size: 1.2rem;
  color: var(--peach);
  line-height: 1;
}

/* Nav */
nav {
  display: flex;
  gap: 2.5rem;
  align-items: center;
}

nav a {
  color: var(--mint);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition: color 0.3s;
  position: relative;
  padding-bottom: 3px;
}

nav a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 1.5px;
  background: var(--beige);
  transition: width 0.35s ease;
}

nav a:hover,
nav a.active { color: var(--beige); }
nav a:hover::after,
nav a.active::after { width: 100%; }

.nav-cart {
  background: var(--teal);
  color: var(--cream) !important;
  padding: 0.55rem 1.2rem;
  border-radius: 3px;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  transition: background 0.3s !important;
  border: 1.5px solid transparent;
}

.nav-cart:hover {
  background: transparent !important;
  color: var(--peach) !important;
  border-color: var(--teal) !important;
}

.nav-cart::after { display: none !important; }

.cart-count {
  background: var(--peach);
  color: var(--dark);
  font-size: 0.72rem;
  font-weight: 700;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

/* ===========================
   BUTTONS
=========================== */
.btn {
  display: inline-block;
  padding: 0.85rem 2.2rem;
  font-family: 'Raleway', sans-serif;
  font-weight: 700;
  font-size: 0.82rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  border-radius: 2px;
  cursor: pointer;
  transition: all 0.3s;
  border: 2px solid transparent;
}

.btn-light {
  background: var(--beige);
  color: var(--dark);
  border-color: var(--beige);
}
.btn-light:hover {
  background: transparent;
  color: var(--beige);
}

.btn-outline {
  background: transparent;
  color: var(--mint);
  border-color: rgba(209,232,226,0.4);
}
.btn-outline:hover {
  background: rgba(209,232,226,0.1);
  border-color: var(--mint);
}

.btn-dark {
  background: var(--dark);
  color: var(--mint);
  border-color: var(--dark);
}
.btn-dark:hover {
  background: var(--teal);
  border-color: var(--teal);
  color: white;
}

.btn-teal {
  background: var(--teal);
  color: white;
  border-color: var(--teal);
}
.btn-teal:hover {
  background: var(--dark);
  border-color: var(--dark);
}

/* ===========================
   HERO
=========================== */
.hero {
  min-height: 92vh;
  background: linear-gradient(135deg, var(--dark) 0%, #1a3a3a 50%, var(--teal) 100%);
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  overflow: hidden;
  position: relative;
}

.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 70% 40%, rgba(255,203,154,0.12) 0%, transparent 65%);
  pointer-events: none;
}

/* Texture overlay */
.hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4'%3E%3Ccircle cx='1' cy='1' r='0.5' fill='%23ffffff08'/%3E%3C/svg%3E");
  pointer-events: none;
}

.hero-content {
  padding: 5rem 4rem 5rem 6rem;
  position: relative;
  z-index: 1;
}

.hero-eyebrow {
  font-family: 'Dancing Script', cursive;
  font-size: 1.5rem;
  color: var(--beige);
  display: block;
  margin-bottom: 0.8rem;
}

.hero h1 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(2.8rem, 5vw, 4.5rem);
  color: var(--cream);
  line-height: 1.1;
  margin-bottom: 1.5rem;
}

.hero h1 em {
  color: var(--peach);
  font-style: italic;
  display: block;
}

.hero-desc {
  color: var(--mint);
  font-size: 1.05rem;
  font-weight: 300;
  max-width: 420px;
  margin-bottom: 2.5rem;
  opacity: 0.9;
}

.hero-btns {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

.hero-visual {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4rem 3rem;
  position: relative;
  z-index: 1;
}

.hero-lamp-svg {
  width: min(360px, 90%);
  filter: drop-shadow(0 20px 60px rgba(255,203,154,0.25));
  animation: float 5s ease-in-out infinite;
}

@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}

/* ===========================
   SECTION COMMONS
=========================== */
section { padding: 5rem 2.5rem; }

.container {
  max-width: 1200px;
  margin: 0 auto;
}

.section-title {
  text-align: center;
  margin-bottom: 3.5rem;
}

.section-title .eyebrow {
  font-family: 'Dancing Script', cursive;
  font-size: 1.3rem;
  color: var(--teal);
  display: block;
  margin-bottom: 0.4rem;
}

.section-title h2 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  color: var(--dark);
  line-height: 1.2;
}

.section-title .divider {
  width: 50px;
  height: 2px;
  background: var(--beige);
  margin: 1rem auto 0;
  border-radius: 2px;
}

/* ===========================
   SAVOIR-FAIRE / FEATURES
=========================== */
.features {
  background: var(--mint);
}

.features-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 2rem;
}

.feature-card {
  text-align: center;
  padding: 2rem 1.5rem;
  background: rgba(255,255,255,0.5);
  border-radius: 4px;
  transition: transform 0.3s, box-shadow 0.3s;
}

.feature-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 30px rgba(17,100,102,0.15);
}

.feature-icon {
  width: 52px;
  height: 52px;
  margin: 0 auto 1.2rem;
  color: var(--teal);
}

.feature-card h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.05rem;
  color: var(--dark);
  margin-bottom: 0.5rem;
}

.feature-card p {
  font-size: 0.88rem;
  color: var(--muted);
  font-weight: 300;
  line-height: 1.6;
}

/* ===========================
   PRODUCT CARDS
=========================== */
.products-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(265px, 1fr));
  gap: 2rem;
}

.product-card {
  background: var(--white);
  border-radius: 4px;
  overflow: hidden;
  box-shadow: 0 2px 20px var(--shadow);
  transition: transform 0.35s, box-shadow 0.35s;
}

.product-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 40px rgba(44,53,49,0.18);
}

/* Placeholder image area */
.product-image {
  width: 100%;
  aspect-ratio: 5/4;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.product-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.product-card:hover .product-image img {
  transform: scale(1.06);
}

/* CSS placeholder when no image */
.img-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.img-placeholder svg {
  width: 45%;
  height: 45%;
  opacity: 0.35;
}

.ph-suspension {
  background: linear-gradient(145deg, var(--dark) 0%, var(--teal) 100%);
  color: var(--mint);
}

.ph-table {
  background: linear-gradient(145deg, #c49a6c 0%, var(--peach) 100%);
  color: var(--dark);
}

.ph-applique {
  background: linear-gradient(145deg, var(--teal) 0%, var(--mint) 100%);
  color: var(--dark);
}

.product-badge {
  position: absolute;
  top: 1rem;
  left: 1rem;
  background: var(--beige);
  color: var(--dark);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.25rem 0.65rem;
  border-radius: 2px;
  z-index: 2;
}

.product-badge.new {
  background: var(--teal);
  color: white;
}

.product-info {
  padding: 1.3rem 1.6rem 1.6rem;
}

.product-category {
  font-size: 0.72rem;
  color: var(--teal);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 0.35rem;
}

.product-name {
  font-family: 'Playfair Display', serif;
  font-size: 1.15rem;
  color: var(--dark);
  margin-bottom: 0.4rem;
}

.product-desc {
  font-size: 0.85rem;
  color: var(--muted);
  font-weight: 300;
  line-height: 1.55;
  margin-bottom: 1.2rem;
}

.product-comment {
  font-family: 'Raleway', sans-serif;
  font-size: 0.85rem;
  color: var(--muted);
  line-height: 1.55;
  margin: 0.3rem 0 0.5rem;
  font-weight: 300;
}

.product-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}

.product-price {
  font-family: 'Playfair Display', serif;
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--teal);
}

.add-to-cart {
  background: var(--dark);
  color: var(--mint);
  border: none;
  padding: 0.55rem 1.1rem;
  border-radius: 2px;
  font-family: 'Raleway', sans-serif;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.3s, color 0.3s;
}

.add-to-cart:hover {
  background: var(--teal);
  color: white;
}

.add-to-cart.added {
  background: #2d8a5a;
  color: white;
}

/* ===========================
   CATEGORIES CARDS
=========================== */
.categories-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}

.category-card {
  border-radius: 4px;
  overflow: hidden;
  position: relative;
  aspect-ratio: 3/4;
  cursor: pointer;
  display: block;
}

.cat-bg {
  width: 100%;
  height: 100%;
  transition: transform 0.5s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}

.category-card:hover .cat-bg {
  transform: scale(1.06);
}

.cat-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(20,30,28,0.85) 0%, rgba(20,30,28,0.2) 50%, transparent 100%);
  display: flex;
  align-items: flex-end;
  padding: 2rem 1.8rem;
  transition: background 0.3s;
}

.category-card:hover .cat-overlay {
  background: linear-gradient(to top, rgba(17,100,102,0.85) 0%, rgba(17,100,102,0.25) 60%, transparent 100%);
}

.cat-text { color: white; }

.cat-label {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--peach);
  opacity: 0.9;
  display: block;
  margin-bottom: 0.3rem;
}

.cat-name {
  font-family: 'Playfair Display', serif;
  font-size: 1.5rem;
  color: var(--cream);
  display: block;
  margin-bottom: 0.2rem;
}

.cat-count {
  font-size: 0.8rem;
  color: var(--mint);
  opacity: 0.8;
}

.cat-arrow {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  width: 36px;
  height: 36px;
  background: rgba(255,255,255,0.1);
  border: 1.5px solid rgba(255,255,255,0.3);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  transition: all 0.3s;
}

.category-card:hover .cat-arrow {
  background: var(--peach);
  border-color: var(--peach);
  color: var(--dark);
}

/* ===========================
   PAGE HERO (inner pages)
=========================== */
.page-hero {
  background: linear-gradient(135deg, var(--dark) 0%, var(--teal) 100%);
  padding: 5rem 2.5rem 3.5rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, rgba(255,203,154,0.1) 0%, transparent 70%);
}

.page-hero .eyebrow {
  font-family: 'Dancing Script', cursive;
  font-size: 1.4rem;
  color: var(--beige);
  display: block;
  margin-bottom: 0.5rem;
  position: relative;
}

.page-hero h1 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(2rem, 5vw, 3.5rem);
  color: var(--cream);
  position: relative;
}

.page-hero p {
  color: var(--mint);
  font-size: 1rem;
  font-weight: 300;
  margin-top: 1rem;
  opacity: 0.85;
  position: relative;
}

/* ===========================
   FILTERS (articles)
=========================== */
.filters-bar {
  display: flex;
  gap: 0.8rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 3rem;
  padding: 0 1rem;
}

.filter-btn {
  background: transparent;
  border: 2px solid var(--teal);
  color: var(--teal);
  padding: 0.5rem 1.5rem;
  border-radius: 2px;
  font-family: 'Raleway', sans-serif;
  font-weight: 700;
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.25s;
}

.filter-btn:hover,
.filter-btn.active {
  background: var(--teal);
  color: white;
}

/* ===========================
   CONTACT PAGE
=========================== */
.contact-layout {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 4rem;
  align-items: start;
  max-width: 960px;
  margin: 0 auto;
}

.contact-aside h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.5rem;
  color: var(--dark);
  margin-bottom: 1rem;
}

.contact-aside .tagline {
  font-size: 0.95rem;
  color: var(--muted);
  font-weight: 300;
  line-height: 1.7;
  margin-bottom: 2rem;
}

.contact-info-item {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.contact-info-icon {
  width: 40px;
  height: 40px;
  background: var(--mint);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--teal);
}

.contact-info-text strong {
  display: block;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--teal);
  margin-bottom: 0.15rem;
}

.contact-info-text span {
  font-size: 0.9rem;
  color: var(--muted);
}

/* Form */
.form-group {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  margin-bottom: 1.4rem;
}

.form-group label {
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--teal);
}

.form-group input,
.form-group textarea,
.form-group select {
  width: 100%;
  padding: 0.85rem 1rem;
  border: 2px solid var(--mint);
  border-radius: 2px;
  font-family: 'Raleway', sans-serif;
  font-size: 0.95rem;
  color: var(--dark);
  background: white;
  transition: border-color 0.3s, box-shadow 0.3s;
  outline: none;
  appearance: none;
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(17,100,102,0.08);
}

.form-group textarea {
  min-height: 140px;
  resize: vertical;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

/* ===========================
   CHECKOUT PAGE
=========================== */
.checkout-layout {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 2.5rem;
  max-width: 1100px;
  margin: 0 auto;
  align-items: start;
}

.checkout-block {
  background: white;
  border-radius: 4px;
  padding: 2rem;
  box-shadow: 0 2px 20px var(--shadow);
  margin-bottom: 1.5rem;
}

.checkout-block h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.15rem;
  color: var(--dark);
  margin-bottom: 1.5rem;
  padding-bottom: 0.8rem;
  border-bottom: 2px solid var(--mint);
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.checkout-block h3 svg {
  width: 20px;
  height: 20px;
  color: var(--teal);
}

/* Cart items */
.cart-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.9rem 0;
  border-bottom: 1px solid #f2f2f2;
}

.cart-item:last-of-type { border-bottom: none; }

.cart-item-thumb {
  width: 64px;
  height: 64px;
  border-radius: 3px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.cart-item-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cart-item-details { flex: 1; }

.cart-item-name {
  font-family: 'Playfair Display', serif;
  font-size: 0.95rem;
  color: var(--dark);
}

.cart-item-cat {
  font-size: 0.72rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.cart-item-qty {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.4rem;
}

.qty-btn {
  width: 24px;
  height: 24px;
  background: var(--mint);
  border: none;
  border-radius: 2px;
  cursor: pointer;
  font-size: 1rem;
  color: var(--dark);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}

.qty-btn:hover { background: var(--beige); }
.qty-display { font-size: 0.9rem; font-weight: 600; min-width: 20px; text-align: center; }

.cart-item-price {
  font-family: 'Playfair Display', serif;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--teal);
  white-space: nowrap;
}

.cart-item-remove {
  background: none;
  border: none;
  cursor: pointer;
  color: #ccc;
  padding: 4px;
  line-height: 1;
  transition: color 0.2s;
  font-size: 1.1rem;
}

.cart-item-remove:hover { color: #e74c3c; }

/* Order summary */
.summary-row {
  display: flex;
  justify-content: space-between;
  font-size: 0.9rem;
  padding: 0.4rem 0;
  color: var(--muted);
}

.summary-row.total {
  border-top: 2px solid var(--dark);
  margin-top: 0.5rem;
  padding-top: 1rem;
  font-weight: 700;
  color: var(--dark);
  font-size: 1rem;
}

.summary-row.total .total-amount {
  font-family: 'Playfair Display', serif;
  font-size: 1.4rem;
  color: var(--teal);
}

/* Card visual */
.card-visual {
  background: linear-gradient(130deg, var(--dark) 0%, var(--teal) 100%);
  border-radius: 12px;
  padding: 1.6rem;
  color: white;
  margin-bottom: 1.5rem;
  position: relative;
  overflow: hidden;
}

.card-visual::before {
  content: '';
  position: absolute;
  top: -30px;
  right: -30px;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background: rgba(255,255,255,0.05);
}

.card-chip {
  width: 36px;
  height: 26px;
  background: linear-gradient(135deg, var(--beige), var(--peach));
  border-radius: 4px;
  margin-bottom: 1.2rem;
}

.card-number {
  font-size: 1.1rem;
  letter-spacing: 0.22em;
  margin-bottom: 1rem;
  font-weight: 300;
  opacity: 0.9;
}

.card-details {
  display: flex;
  justify-content: space-between;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  opacity: 0.7;
}

/* Payment methods visual */
.payment-methods {
  display: flex;
  gap: 0.8rem;
  margin-bottom: 1.5rem;
}

.pay-method {
  padding: 0.5rem 1rem;
  border: 2px solid var(--mint);
  border-radius: 4px;
  font-size: 0.8rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
  color: var(--muted);
}

.pay-method.active {
  border-color: var(--teal);
  color: var(--teal);
  background: rgba(17,100,102,0.05);
}

/* ===========================
   EMPTY CART
=========================== */
.empty-cart {
  text-align: center;
  padding: 3rem 2rem;
  color: var(--muted);
}

.empty-cart svg {
  width: 80px;
  height: 80px;
  opacity: 0.25;
  margin: 0 auto 1.2rem;
  display: block;
}

.empty-cart p {
  margin-bottom: 1.5rem;
  font-size: 1rem;
}

/* ===========================
   FOOTER
=========================== */
footer {
  background: var(--dark);
  padding: 4rem 2.5rem 1.5rem;
  color: var(--mint);
}

.footer-inner {
  max-width: 1100px;
  margin: 0 auto;
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 3rem;
  margin-bottom: 3rem;
}

.footer-brand .logo { margin-bottom: 1rem; }

.footer-brand p {
  font-size: 0.85rem;
  font-weight: 300;
  opacity: 0.7;
  line-height: 1.7;
  max-width: 260px;
}

.footer-col h4 {
  font-family: 'Playfair Display', serif;
  font-size: 0.85rem;
  color: var(--beige);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 1.2rem;
}

.footer-col li {
  margin-bottom: 0.6rem;
}

.footer-col a {
  font-size: 0.85rem;
  font-weight: 300;
  color: var(--mint);
  opacity: 0.7;
  transition: opacity 0.2s, color 0.2s;
}

.footer-col a:hover {
  opacity: 1;
  color: var(--beige);
}

.footer-bottom {
  border-top: 1px solid rgba(209,232,226,0.12);
  padding-top: 1.5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  font-size: 0.78rem;
  opacity: 0.45;
}

/* ===========================
   TOAST NOTIFICATION
=========================== */
.toast {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  background: var(--teal);
  color: white;
  padding: 0.9rem 1.6rem;
  border-radius: 4px;
  font-size: 0.9rem;
  font-weight: 500;
  z-index: 9999;
  transform: translateY(120px);
  opacity: 0;
  transition: all 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
  box-shadow: 0 6px 25px rgba(0,0,0,0.25);
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.toast.show {
  transform: translateY(0);
  opacity: 1;
}

/* ===========================
   SCROLL REVEAL
=========================== */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ===========================
   RESPONSIVE
=========================== */
@media (max-width: 1024px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .hero { grid-template-columns: 1fr; }
  .hero-visual { display: none; }
  .hero-content { padding: 5rem 3rem; text-align: center; }
  .hero-desc { margin-left: auto; margin-right: auto; }
  .hero-btns { justify-content: center; }
  .categories-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
  header { flex-wrap: wrap; gap: 0.8rem; padding: 1rem 1.5rem; }
  nav { gap: 1.2rem; width: 100%; justify-content: center; }
  section { padding: 3.5rem 1.5rem; }
  .checkout-layout { grid-template-columns: 1fr; }
  .contact-layout { grid-template-columns: 1fr; gap: 2.5rem; }
  .form-row { grid-template-columns: 1fr; }
  .categories-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
}

@media (max-width: 480px) {
  .footer-grid { grid-template-columns: 1fr; }
  .hero-content { padding: 4rem 1.5rem; }
}

/* ===========================
   THEME TOGGLE BUTTON
=========================== */
.theme-toggle {
  background: none;
  border: 1.5px solid rgba(209,232,226,0.25);
  color: var(--mint);
  width: 38px;
  height: 38px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color 0.3s, color 0.3s, background 0.3s;
  padding: 0;
  flex-shrink: 0;
}
.theme-toggle:hover {
  border-color: var(--beige);
  color: var(--beige);
  background: rgba(217,176,140,0.1);
}
.icon-sun { display: none; }
[data-theme="dark"] .icon-moon { display: none; }
[data-theme="dark"] .icon-sun  { display: block; }

/* ===========================
   DARK MODE — VARIABLES
=========================== */
[data-theme="dark"] {
  --cream:  #0c1310;
  --white:  #131c18;
  --text:   #e4d8c8;
  --muted:  #7a9490;
  --shadow: rgba(0,0,0,0.55);
}

/* Smooth theme transition */
html { transition: background-color 0.45s ease; }
body { transition: color 0.35s ease; }
.product-card,
.checkout-block,
.feature-card,
.form-group input,
.form-group textarea,
.form-group select {
  transition: background 0.4s ease, border-color 0.3s ease, box-shadow 0.35s ease, transform 0.35s ease;
}

/* ===========================
   DARK MODE — GLOBAL
=========================== */
[data-theme="dark"] body   { background: var(--cream); color: var(--text); }
[data-theme="dark"] header { background: #070d0b; box-shadow: 0 3px 30px rgba(0,0,0,0.7); }
[data-theme="dark"] footer { background: #050a08; }

/* ===========================
   DARK MODE — HERO
=========================== */
[data-theme="dark"] .hero h1          { color: #f0e8d8; }
[data-theme="dark"] .hero h1 em       { color: var(--peach); }
[data-theme="dark"] .section-title h2 { color: #f0e8d8; }
[data-theme="dark"] .section-title .eyebrow { color: var(--peach); }
[data-theme="dark"] h2 { color: #f0e8d8; }
[data-theme="dark"] h3 { color: #d8cfc0; }
[data-theme="dark"] p  { color: #b0bab6; }
[data-theme="dark"] .hero-eyebrow     { color: var(--beige); }
[data-theme="dark"] .hero .hero-desc  { color: var(--mint); opacity: 0.9; }

[data-theme="dark"] .hero {
  background: linear-gradient(135deg, #04080600 0%, #0a2020 55%, #0d3030 100%);
  background: linear-gradient(135deg, #050a07 0%, #0b2222 55%, #0d2e2e 100%);
}
[data-theme="dark"] .hero::before {
  background: radial-gradient(ellipse at 68% 42%, rgba(255,203,154,0.22) 0%, transparent 62%);
}
/* Hero lamp glows and breathes in dark mode */
[data-theme="dark"] .hero-lamp-svg {
  filter:
    drop-shadow(0 20px 60px rgba(255,203,154,0.55))
    drop-shadow(0  0px 40px rgba(255,180, 80,0.30));
  animation: float 5s ease-in-out infinite, lamp-breathe 4s ease-in-out infinite;
}
@keyframes lamp-breathe {
  0%, 100% {
    filter: drop-shadow(0 20px 60px rgba(255,203,154,0.55)) drop-shadow(0 0 40px rgba(255,180,80,0.30));
  }
  50% {
    filter: drop-shadow(0 28px 90px rgba(255,203,154,0.80)) drop-shadow(0 0 65px rgba(255,190,90,0.45));
  }
}

/* ===========================
   DARK MODE — SECTIONS
=========================== */
[data-theme="dark"] .features         { background: #08100d; }
[data-theme="dark"] .feature-card     { background: rgba(255,255,255,0.04); }
[data-theme="dark"] .feature-card h3  { color: var(--text); }
[data-theme="dark"] .page-hero        { background: linear-gradient(135deg, #050a07 0%, #0c2020 100%); }

/* Inline-style sections override */
[data-theme="dark"] section[style*="background: var(--cream)"]  { background: var(--cream) !important; }
[data-theme="dark"] section[style*="background: var(--mint)"]   { background: #07100d !important; }
[data-theme="dark"] section[style*="background: var(--dark)"]   { background: #060c09 !important; }
[data-theme="dark"] section[style*="background: var(--teal)"]   { background: #093535 !important; }
[data-theme="dark"] section[style*="background: var(--beige)"]  { background: #16120b !important; }
[data-theme="dark"] section[style*="background: var(--beige)"] p { color: var(--text) !important; }

/* ===========================
   DARK MODE — PRODUCT CARDS
   Lamps are the ONLY light sources
=========================== */
[data-theme="dark"] .product-card {
  background: var(--white);
  box-shadow: 0 4px 30px rgba(0,0,0,0.55);
}

/* Darken placeholders to pure near-black → lamp glow = only light */
[data-theme="dark"] .ph-suspension {
  background: linear-gradient(180deg, #060e0b 0%, #0a1a16 100%) !important;
  color: rgba(209,232,226,0.5);
}
[data-theme="dark"] .ph-table {
  background: linear-gradient(180deg, #0e0c07 0%, #1a1407 100%) !important;
  color: rgba(217,176,140,0.5);
}
[data-theme="dark"] .ph-applique {
  background: linear-gradient(180deg, #060e0c 0%, #0a1c16 100%) !important;
  color: rgba(209,232,226,0.5);
}

/* Lamp icon itself glows */
[data-theme="dark"] .img-placeholder svg {
  opacity: 0.65;
  filter: drop-shadow(0 0 8px rgba(255,203,154,0.7));
}

/* THE KEY EFFECT — warm light cone radiating downward from the lamp */
[data-theme="dark"] .img-placeholder::after {
  content: '';
  position: absolute;
  bottom: -5px;
  left: 50%;
  transform: translateX(-50%);
  width: 110%;
  height: 75%;
  background: radial-gradient(
    ellipse at 50% 55%,
    rgba(255,203,154,0.50) 0%,
    rgba(255,190,100,0.20) 25%,
    rgba(255,170, 80,0.07) 50%,
    transparent 72%
  );
  pointer-events: none;
  z-index: 1;
  animation: lamp-flicker 5s ease-in-out infinite;
}

@keyframes lamp-flicker {
  0%,  100% { opacity: 1.00; }
  15%        { opacity: 0.88; }
  30%        { opacity: 0.96; }
  55%        { opacity: 0.84; }
  70%        { opacity: 0.98; }
  85%        { opacity: 0.90; }
}

/* Light spills into the info section below */
[data-theme="dark"] .product-info {
  background: linear-gradient(to bottom, rgba(255,203,154,0.055) 0%, transparent 45%);
}
[data-theme="dark"] .product-name  { color: var(--text); }
[data-theme="dark"] .product-price { color: var(--beige); }

/* Hover — crank up the light */
[data-theme="dark"] .product-card:hover .img-placeholder::after {
  background: radial-gradient(
    ellipse at 50% 55%,
    rgba(255,215,130,0.75) 0%,
    rgba(255,200,100,0.35) 22%,
    rgba(255,170, 80,0.12) 48%,
    transparent 70%
  );
  animation: none;
  opacity: 1;
}
[data-theme="dark"] .product-card:hover {
  box-shadow:
    0 14px 45px rgba(0,0,0,0.65),
    0  0px 50px rgba(255,203,154,0.13),
    0 -6px 25px rgba(255,203,154,0.07);
}

/* ===========================
   DARK MODE — CATEGORY CARDS
=========================== */
[data-theme="dark"] .ph-suspension.cat-bg {
  background: linear-gradient(180deg, #060e0b 0%, #0a2020 100%) !important;
}
[data-theme="dark"] .ph-table.cat-bg {
  background: linear-gradient(180deg, #100c06 0%, #1a1406 100%) !important;
}
[data-theme="dark"] .ph-applique.cat-bg {
  background: linear-gradient(180deg, #060e0c 0%, #081a14 100%) !important;
}

/* ===========================
   DARK MODE — FORMS & INPUTS
=========================== */
[data-theme="dark"] .form-group input,
[data-theme="dark"] .form-group textarea,
[data-theme="dark"] .form-group select {
  background: #1a2620;
  border-color: #2a3c35;
  color: var(--text);
}
[data-theme="dark"] .form-group input:focus,
[data-theme="dark"] .form-group textarea:focus,
[data-theme="dark"] .form-group select:focus {
  border-color: var(--teal);
  background: #1f2e28;
  box-shadow: 0 0 0 3px rgba(17,100,102,0.18);
}
[data-theme="dark"] .form-group input::placeholder,
[data-theme="dark"] .form-group textarea::placeholder { color: #3a5550; }
[data-theme="dark"] .form-group label { color: #7ecac8; }

/* ===========================
   DARK MODE — CHECKOUT
=========================== */
[data-theme="dark"] .checkout-block        { background: var(--white); }
[data-theme="dark"] .checkout-block h3     { color: var(--text); border-color: #2a3c35; }
[data-theme="dark"] .cart-item             { border-color: #222e28; }
[data-theme="dark"] .cart-item-name        { color: var(--text); }
[data-theme="dark"] .summary-row           { color: var(--muted); }
[data-theme="dark"] .summary-row.total     { color: var(--text); border-color: #3a5050; }
[data-theme="dark"] .total-amount          { color: var(--beige) !important; }
[data-theme="dark"] .qty-btn               { background: #2a3c35; color: var(--text); }
[data-theme="dark"] .qty-btn:hover         { background: var(--beige); color: var(--dark); }
[data-theme="dark"] .cart-item-remove      { color: #3a5050; }
[data-theme="dark"] .order-total           { border-color: #3a5050; }
[data-theme="dark"] .livraison-note        { background: rgba(17,100,102,0.15); border-color: var(--teal); }

/* Cart item thumbnail in dark mode glows a touch */
[data-theme="dark"] .cart-item-thumb       { position: relative; }
[data-theme="dark"] .cart-item-thumb::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 60%, rgba(255,203,154,0.25) 0%, transparent 70%);
  pointer-events: none;
  animation: lamp-flicker 5s ease-in-out infinite;
}

/* ===========================
   DARK MODE — CONTACT
=========================== */
[data-theme="dark"] .contact-aside h3     { color: var(--text); }
[data-theme="dark"] .contact-aside .tagline { color: var(--muted); }
[data-theme="dark"] .contact-info-icon    { background: #1a2e28; }
[data-theme="dark"] .contact-info-text strong { color: #7ecac8; }
[data-theme="dark"] .contact-info-text span   { color: var(--muted); }

/* ===========================
   DARK MODE — FILTER BUTTONS
=========================== */
[data-theme="dark"] .filter-btn {
  border-color: #2a5050;
  color: #7ecac8;
}
[data-theme="dark"] .filter-btn:hover,
[data-theme="dark"] .filter-btn.active {
  background: var(--teal);
  color: white;
  border-color: var(--teal);
}

/* ===========================
   DARK MODE — ADD TO CART
=========================== */
[data-theme="dark"] .add-to-cart {
  background: #1e3030;
  color: var(--mint);
  border: 1.5px solid #2a4444;
}
[data-theme="dark"] .add-to-cart:hover { background: var(--teal); border-color: var(--teal); }

/* ===========================
   DARK MODE — FOOTER
=========================== */
[data-theme="dark"] .footer-bottom { border-color: rgba(209,232,226,0.08); }

/* ============================================================
   ARTISANAL ANIMATIONS & TEXTURES
   ============================================================ */

/* Grain overlay */
.grain-overlay {
  position: fixed;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  pointer-events: none;
  z-index: 9999;
  opacity: 0.035;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
}
[data-theme="dark"] .grain-overlay { opacity: 0; }

/* Cart burst dots */
@keyframes burst-dot {
  0%   { transform: translate(0,0) scale(1); opacity: 1; }
  100% { transform: translate(var(--tx), var(--ty)) scale(0); opacity: 0; }
}
.burst-dot {
  position: fixed;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--teal);
  pointer-events: none;
  z-index: 9998;
  animation: burst-dot 0.55s ease-out forwards;
}

/* Hero title word-by-word reveal */
.hero-title-anim .word {
  display: inline-block;
  opacity: 0;
  transform: translateY(28px) rotate(-2deg);
  animation: word-rise 0.7s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
@keyframes word-rise {
  to { opacity: 1; transform: translateY(0) rotate(0deg); }
}

/* Scroll reveal base state */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.reveal.visible {
  opacity: 1;
  transform: none;
}

/* Hand-drawn SVG section divider */
.divider-wave {
  display: block;
  width: 100%;
  height: 48px;
  margin: 0;
  padding: 0;
  line-height: 0;
}
.divider-wave svg {
  width: 100%;
  height: 48px;
  display: block;
}

/* Wax seal decoration */
.wax-seal {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: var(--teal);
  color: #fff;
  font-family: 'Dancing Script', cursive;
  font-size: 1.4rem;
  box-shadow: 0 4px 18px rgba(17,100,102,0.35), inset 0 -3px 6px rgba(0,0,0,0.18);
  position: relative;
  margin: 0 auto 1.5rem;
}
.wax-seal::before {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  border: 2px dashed rgba(17,100,102,0.4);
}

/* Floating badge on product card */
.card-badge-new {
  position: absolute;
  top: 12px;
  left: 12px;
  background: var(--peach);
  color: var(--dark);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 20px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
}

/* Ink stamp effect on promo badges */
.stamp {
  display: inline-block;
  border: 2px solid currentColor;
  border-radius: 4px;
  padding: 2px 10px;
  font-family: 'Raleway', sans-serif;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-size: 0.7rem;
  transform: rotate(-2deg);
  opacity: 0.8;
}

/* Paper texture sections */
.section-paper {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='paper'%3E%3CfeTurbulence baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23paper)' opacity='0.04'/%3E%3C/svg%3E");
}

/* Price tag style */
.price-tag {
  display: inline-block;
  background: var(--peach);
  color: var(--dark);
  font-weight: 700;
  padding: 0.25rem 0.9rem;
  border-radius: 3px 3px 3px 0;
  position: relative;
  font-family: 'Raleway', sans-serif;
}
.price-tag::before {
  content: '';
  position: absolute;
  left: -8px;
  top: 50%;
  transform: translateY(-50%);
  border: 8px solid transparent;
  border-right-color: var(--peach);
  width: 0;
  height: 0;
}

/* Artisanal hand-underline on headings */
.hand-underline {
  position: relative;
  display: inline-block;
}
.hand-underline::after {
  content: '';
  position: absolute;
  bottom: -6px;
  left: 0;
  width: 100%;
  height: 3px;
  background: var(--teal);
  border-radius: 2px;
  transform-origin: left;
  animation: underline-draw 0.8s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
@keyframes underline-draw {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}

/* Dark mode artisanal tweaks */
[data-theme="dark"] .card-badge-new {
  background: var(--peach);
  color: var(--dark);
}
[data-theme="dark"] .wax-seal {
  background: var(--teal);
  box-shadow: 0 4px 24px rgba(17,100,102,0.6), inset 0 -3px 6px rgba(0,0,0,0.3);
}

/* ===========================
   PRODUCT DETAIL MODAL
=========================== */

/* Overlay */
.pdm-overlay {
  position: fixed;
  inset: 0;
  background: rgba(20, 28, 24, 0.82);
  backdrop-filter: blur(6px);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
}
.pdm-overlay.pdm-open {
  opacity: 1;
  pointer-events: all;
}

/* Dialog */
.pdm-dialog {
  background: var(--white);
  border-radius: 6px;
  width: 100%;
  max-width: 980px;
  max-height: 90vh;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr 1fr;
  position: relative;
  transform: translateY(30px) scale(0.97);
  transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
  box-shadow: 0 30px 80px rgba(0,0,0,0.45);
}
.pdm-overlay.pdm-open .pdm-dialog {
  transform: translateY(0) scale(1);
}

/* Close button */
.pdm-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: none;
  background: rgba(44,53,49,0.1);
  color: var(--text);
  font-size: 1.2rem;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  transition: background 0.2s, color 0.2s;
}
.pdm-close:hover {
  background: var(--dark);
  color: white;
}

/* ── Gallery (left) ── */
.pdm-gallery {
  display: flex;
  flex-direction: column;
  background: var(--cream);
  overflow: hidden;
  position: relative;
}

.pdm-main-wrap {
  flex: 1;
  position: relative;
  overflow: hidden;
  cursor: zoom-in;
  min-height: 0;
}

.pdm-main-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}
.pdm-main-wrap:hover .pdm-main-img { transform: scale(1.03); }

/* SVG placeholder in main */
.pdm-main-ph {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pdm-main-ph svg {
  width: 42%;
  height: 42%;
  opacity: 0.45;
}

/* Nav arrows on main image */
.pdm-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: none;
  background: rgba(255,255,255,0.88);
  color: var(--dark);
  font-size: 1.1rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 4;
  transition: background 0.2s, color 0.2s;
  box-shadow: 0 2px 10px rgba(0,0,0,0.18);
}
.pdm-arrow:hover { background: var(--teal); color: white; }
.pdm-arrow-prev { left: 0.75rem; }
.pdm-arrow-next { right: 0.75rem; }
.pdm-arrow:disabled { opacity: 0.25; cursor: default; }
.pdm-arrow:disabled:hover { background: rgba(255,255,255,0.88); color: var(--dark); }

/* Thumbnails */
.pdm-thumbs {
  display: flex;
  gap: 0.5rem;
  padding: 0.6rem 0.8rem;
  overflow-x: auto;
  background: var(--cream);
  scrollbar-width: thin;
  flex-shrink: 0;
}
.pdm-thumbs::-webkit-scrollbar { height: 4px; }
.pdm-thumbs::-webkit-scrollbar-track { background: transparent; }
.pdm-thumbs::-webkit-scrollbar-thumb { background: var(--beige); border-radius: 2px; }

.pdm-thumb {
  width: 58px;
  height: 50px;
  flex-shrink: 0;
  border-radius: 3px;
  overflow: hidden;
  cursor: pointer;
  border: 2px solid transparent;
  transition: border-color 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pdm-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.pdm-thumb.active { border-color: var(--teal); }
.pdm-thumb:hover:not(.active) { border-color: var(--beige); }

/* ── Info panel (right) ── */
.pdm-info {
  display: flex;
  flex-direction: column;
  padding: 2.2rem 2rem 2rem;
  overflow-y: auto;
  gap: 0.6rem;
}

.pdm-category {
  font-size: 0.72rem;
  color: var(--teal);
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.pdm-name {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  color: var(--dark);
  line-height: 1.2;
  margin: 0;
}

.pdm-badge {
  display: inline-block;
  background: var(--beige);
  color: var(--dark);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.2rem 0.65rem;
  border-radius: 2px;
  width: fit-content;
}
.pdm-badge.new { background: var(--teal); color: white; }

.pdm-desc {
  font-size: 0.9rem;
  color: var(--muted);
  font-weight: 300;
  line-height: 1.65;
}

.pdm-comment {
  font-size: 0.88rem;
  color: var(--muted);
  font-style: italic;
  font-weight: 300;
  border-left: 3px solid var(--beige);
  padding-left: 0.8rem;
}

.pdm-price-row {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  margin-top: 0.4rem;
}

.pdm-price {
  font-family: 'Playfair Display', serif;
  font-size: 2rem;
  font-weight: 700;
  color: var(--teal);
}

.pdm-price-currency {
  font-size: 1rem;
  color: var(--muted);
  font-weight: 400;
}

/* Action buttons */
.pdm-actions {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 0.4rem;
}

.pdm-btn-cart {
  background: var(--teal);
  color: white;
  border: none;
  padding: 0.85rem 1.5rem;
  border-radius: 3px;
  font-family: 'Raleway', sans-serif;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.25s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}
.pdm-btn-cart:hover { background: var(--dark); }
.pdm-btn-cart.added { background: #2d8a5a; }

.pdm-btn-question {
  background: transparent;
  color: var(--teal);
  border: 2px solid var(--teal);
  padding: 0.75rem 1.5rem;
  border-radius: 3px;
  font-family: 'Raleway', sans-serif;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.25s, color 0.25s;
}
.pdm-btn-question:hover { background: var(--teal); color: white; }

/* Inline question form */
.pdm-question-form {
  display: none;
  flex-direction: column;
  gap: 0.65rem;
  background: var(--cream);
  border-radius: 4px;
  padding: 1.1rem;
  border: 1px solid rgba(17,100,102,0.15);
}
.pdm-question-form.open { display: flex; }

.pdm-question-form label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--teal);
}

.pdm-question-form input,
.pdm-question-form textarea {
  width: 100%;
  padding: 0.6rem 0.8rem;
  border: 2px solid var(--mint);
  border-radius: 2px;
  font-family: 'Raleway', sans-serif;
  font-size: 0.88rem;
  color: var(--dark);
  background: var(--white);
  transition: border-color 0.25s;
  outline: none;
}
.pdm-question-form input:focus,
.pdm-question-form textarea:focus {
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(17,100,102,0.08);
}
.pdm-question-form textarea { min-height: 80px; resize: vertical; }

.pdm-btn-send {
  background: var(--dark);
  color: var(--mint);
  border: none;
  padding: 0.65rem 1.2rem;
  border-radius: 2px;
  font-family: 'Raleway', sans-serif;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.2s;
  align-self: flex-start;
}
.pdm-btn-send:hover { background: var(--teal); }

.pdm-sent-msg {
  display: none;
  font-size: 0.88rem;
  color: #2d8a5a;
  font-weight: 600;
  text-align: center;
  padding: 0.5rem 0;
}
.pdm-sent-msg.visible { display: block; }

/* ── Lightbox zoom overlay ── */
.pdm-lightbox {
  position: fixed;
  inset: 0;
  background: rgba(5, 10, 8, 0.96);
  z-index: 10100;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.25s ease;
  pointer-events: none;
}
.pdm-lightbox.open {
  opacity: 1;
  pointer-events: all;
}
.pdm-lightbox img {
  max-width: 92vw;
  max-height: 92vh;
  object-fit: contain;
  border-radius: 4px;
  box-shadow: 0 20px 80px rgba(0,0,0,0.7);
}
.pdm-lightbox-close {
  position: absolute;
  top: 1.2rem;
  right: 1.2rem;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.3);
  background: transparent;
  color: white;
  font-size: 1.3rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color 0.2s, background 0.2s;
}
.pdm-lightbox-close:hover {
  background: rgba(255,255,255,0.12);
  border-color: white;
}

/* ── Dark mode for modal ── */
[data-theme="dark"] .pdm-dialog {
  background: var(--white);
  box-shadow: 0 30px 90px rgba(0,0,0,0.75);
}
[data-theme="dark"] .pdm-gallery { background: #080f0c; }
[data-theme="dark"] .pdm-thumbs  { background: #080f0c; }
[data-theme="dark"] .pdm-arrow   { background: rgba(255,255,255,0.08); color: var(--text); }
[data-theme="dark"] .pdm-arrow:hover { background: var(--teal); color: white; }
[data-theme="dark"] .pdm-arrow:disabled:hover { background: rgba(255,255,255,0.08); color: var(--text); }
[data-theme="dark"] .pdm-close   { background: rgba(255,255,255,0.06); color: var(--text); }
[data-theme="dark"] .pdm-close:hover { background: var(--teal); color: white; }
[data-theme="dark"] .pdm-name    { color: var(--text); }
[data-theme="dark"] .pdm-price   { color: var(--beige); }
[data-theme="dark"] .pdm-question-form { background: #0a1410; border-color: #2a4040; }
[data-theme="dark"] .pdm-question-form input,
[data-theme="dark"] .pdm-question-form textarea {
  background: #1a2620;
  border-color: #2a3c35;
  color: var(--text);
}
[data-theme="dark"] .pdm-question-form input:focus,
[data-theme="dark"] .pdm-question-form textarea:focus {
  background: #1f2e28;
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(17,100,102,0.18);
}
[data-theme="dark"] .pdm-question-form input::placeholder,
[data-theme="dark"] .pdm-question-form textarea::placeholder { color: #3a5550; }
[data-theme="dark"] .pdm-btn-cart:hover { background: #1e3030; }

/* ── Responsive ── */
@media (max-width: 768px) {
  .pdm-overlay { padding: 0; align-items: flex-end; }
  .pdm-dialog {
    grid-template-columns: 1fr;
    grid-template-rows: 52vw auto;
    max-height: 96vh;
    border-radius: 8px 8px 0 0;
  }
  .pdm-gallery { min-height: 0; }
  .pdm-info { padding: 1.5rem 1.3rem 2rem; }
  .pdm-name { font-size: 1.4rem; }
  .pdm-price { font-size: 1.7rem; }
}

@media (max-width: 480px) {
  .pdm-dialog { grid-template-rows: 55vw auto; }
  .pdm-thumb { width: 48px; height: 42px; }
}
