/* ================================================================
   LUMINA FIREFLY — Extras: logo · search · cart drawer ·
   deep responsive · shop · product · cart · admin
   ================================================================ */

/* ----------------------------------------------------------------
   LOGO
   ---------------------------------------------------------------- */
.nav__logo {
  display: flex; align-items: center;
}
.nav__logo-img {
  height: 82px; width: auto;
  object-fit: contain;
  /* drop-shadow para que el logo sea visible tanto sobre fondo oscuro (hero) como claro (nav scrolled) */
  filter: drop-shadow(0 1px 6px rgba(0,0,0,0.18));
}
.nav__logo-text {
  display: none;
  font-family: var(--serif);
  font-size: 1.05rem; font-weight: 400;
  letter-spacing: .28em; color: var(--dark);
}
/* If no logo.png exists, show text */
.nav__logo-img[style*="display: none"] + .nav__logo-text { display: block; }

/* Cart count badge */
.nav__cart-btn { position: relative; }
.cart-count {
  position: absolute; top: 2px; right: 2px;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--brown); color: #fff;
  font-size: .55rem; font-weight: 600;
  display: flex; align-items: center; justify-content: center;
  pointer-events: none;
  opacity: 0; transform: scale(0);
  transition: opacity .3s, transform .3s var(--ease-out);
}
.cart-count.has-items { opacity: 1; transform: scale(1); }

/* ----------------------------------------------------------------
   SEARCH OVERLAY
   ---------------------------------------------------------------- */
.search-overlay {
  position: fixed; inset: 0; z-index: 950;
  background: var(--off-white);
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: clamp(6rem, 15vh, 12rem);
  opacity: 0; pointer-events: none;
  transition: opacity .45s var(--ease-out);
}
.search-overlay.is-open { opacity: 1; pointer-events: auto; }

.search-overlay__backdrop {
  position: fixed; inset: 0; z-index: 948;
  background: rgba(44,40,37,.4);
  opacity: 0; pointer-events: none;
  transition: opacity .4s;
}
.search-overlay__backdrop.is-open { opacity: 1; pointer-events: auto; }

.search-overlay__close {
  position: absolute; top: 1.75rem; right: 1.75rem;
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  color: var(--dark-mid); cursor: pointer;
  transition: color .3s, transform .4s var(--ease-out);
  z-index: 1;
}
.search-overlay__close:hover { color: var(--brown); transform: rotate(90deg); }

.search-overlay__inner {
  width: min(780px, 90vw);
  transform: translateY(18px);
  transition: transform .55s var(--ease-out);
}
.search-overlay.is-open .search-overlay__inner { transform: translateY(0); }

.search-overlay__field {
  display: flex; align-items: center; gap: 1rem;
  border-bottom: 1.5px solid var(--dark);
  padding-bottom: .85rem; margin-bottom: 2rem;
}
.search-overlay__field svg { flex-shrink: 0; color: var(--brown); }

.search-overlay__input {
  flex: 1; border: none; background: transparent; outline: none;
  font-family: var(--serif); font-size: clamp(1.4rem, 4vw, 2rem);
  font-weight: 300; color: var(--dark);
}
.search-overlay__input::placeholder { color: var(--warm-gray); }

.search-overlay__results { display: flex; flex-direction: column; gap: .5rem; }

.search-result-item {
  display: flex; align-items: center; gap: 1.25rem;
  padding: 1rem; text-decoration: none; color: var(--dark);
  border: 1px solid transparent;
  transition: border-color .3s, background .3s;
}
.search-result-item:hover {
  border-color: rgba(139,94,60,.2); background: rgba(212,174,152,.08);
}
.search-result-thumb {
  width: 60px; height: 60px; flex-shrink: 0; overflow: hidden;
  background: linear-gradient(135deg, var(--warm-gray), var(--beige));
}
.search-result-thumb img { width: 100%; height: 100%; object-fit: cover; }
.search-result-info { flex: 1; }
.search-result-name {
  font-family: var(--serif); font-size: 1.05rem; font-weight: 400;
  margin-bottom: .2rem;
}
.search-result-collection {
  font-size: .65rem; text-transform: uppercase;
  letter-spacing: .2em; color: var(--brown);
}
.search-result-price {
  font-size: .88rem; font-weight: 500; color: var(--dark);
}
.search-no-results {
  text-align: center; padding: 2rem 0;
  color: var(--dark-mid); font-size: .9rem;
}
.search-hint {
  font-size: .72rem; letter-spacing: .15em; text-transform: uppercase;
  color: var(--warm-gray); margin-bottom: 1rem;
}

/* ----------------------------------------------------------------
   CART DRAWER
   ---------------------------------------------------------------- */
.cart-drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(420px, 100vw); z-index: 920;
  background: var(--off-white);
  display: flex; flex-direction: column;
  transform: translateX(105%);
  transition: transform .6s var(--ease-out);
  box-shadow: -8px 0 40px rgba(44,40,37,.12);
}
.cart-drawer.is-open { transform: translateX(0); }

.cart-drawer__backdrop {
  position: fixed; inset: 0; z-index: 915;
  background: rgba(44,40,37,.45);
  opacity: 0; pointer-events: none;
  transition: opacity .45s;
}
.cart-drawer__backdrop.is-open { opacity: 1; pointer-events: auto; }

.cart-drawer__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.5rem 1.75rem;
  border-bottom: 1px solid rgba(197,192,184,.3);
}
.cart-drawer__title {
  font-family: var(--serif); font-size: 1.35rem; font-weight: 400;
  letter-spacing: .05em; color: var(--dark);
}
.cart-drawer__close {
  width: 36px; height: 36px; display: flex; align-items: center;
  justify-content: center; color: var(--dark-mid); cursor: pointer;
  transition: color .3s, transform .35s var(--ease-out);
}
.cart-drawer__close:hover { color: var(--brown); transform: rotate(90deg); }

.cart-drawer__body {
  flex: 1; overflow-y: auto;
  padding: 1.25rem 1.75rem;
  scroll-behavior: smooth;
}

.cart-empty {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 3rem 1rem; color: var(--dark-mid);
  gap: .75rem;
}
.cart-empty svg { opacity: .35; }
.cart-empty p { font-size: .88rem; letter-spacing: .04em; }

.cart-items { display: flex; flex-direction: column; gap: 1.25rem; }

.cart-item {
  display: grid;
  grid-template-columns: 72px 1fr auto;
  gap: .85rem; align-items: start;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid rgba(197,192,184,.25);
}
.cart-item:last-child { border-bottom: none; }

.cart-item__thumb {
  width: 72px; height: 72px; overflow: hidden; flex-shrink: 0;
  background: linear-gradient(135deg, var(--warm-gray), var(--beige));
}
.cart-item__thumb img { width: 100%; height: 100%; object-fit: cover; }

.cart-item__info { overflow: hidden; }
.cart-item__name {
  font-family: var(--serif); font-size: 1rem; font-weight: 400;
  color: var(--dark); margin-bottom: .2rem;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cart-item__collection {
  font-size: .6rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--brown); margin-bottom: .4rem;
}
.cart-item__custom {
  font-size: .72rem; color: var(--dark-mid); margin-bottom: .35rem;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.cart-item__price { font-size: .9rem; font-weight: 500; color: var(--dark); }

.cart-item__remove {
  color: var(--warm-gray); cursor: pointer;
  transition: color .3s; padding: 2px;
}
.cart-item__remove:hover { color: var(--dusty-rose); }

.cart-drawer__footer {
  padding: 1.25rem 1.75rem;
  border-top: 1px solid rgba(197,192,184,.3);
  display: flex; flex-direction: column; gap: .75rem;
}
.cart-subtotal {
  display: flex; justify-content: space-between; align-items: baseline;
  font-size: .88rem; font-weight: 500; color: var(--dark);
}
.cart-note {
  font-size: .65rem; color: var(--warm-gray); text-align: center;
  letter-spacing: .05em;
}

/* ----------------------------------------------------------------
   TOAST
   ---------------------------------------------------------------- */
.toast {
  position: fixed; bottom: 2rem; left: 50%; transform: translateX(-50%) translateY(1.5rem);
  background: var(--dark); color: var(--off-white);
  font-size: .78rem; letter-spacing: .04em;
  padding: .85rem 1.75rem;
  z-index: 9998; pointer-events: none; opacity: 0;
  transition: opacity .4s, transform .4s var(--ease-out);
  white-space: nowrap; max-width: 90vw;
}
.toast.is-visible { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ----------------------------------------------------------------
   SHARED PAGE HEADER (shop, product, cart, admin)
   ---------------------------------------------------------------- */
.page-nav {
  position: sticky; top: 0; z-index: 800;
  background: rgba(240,235,227,.92); backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(197,192,184,.2);
  height: var(--nav-h);
}
.page-nav .nav__container { max-width: 1440px; margin: 0 auto; padding: 0 var(--s3); height: 100%; display: flex; align-items: center; justify-content: space-between; }

/* Card visual link wrapper */
.card__visual-link { display: block; }

/* ----------------------------------------------------------------
   DEEP RESPONSIVE FIXES
   ---------------------------------------------------------------- */

/* ── Touch targets ── */
@media (pointer: coarse) {
  .btn, .nav__link, .nav__icon-btn, .card__link,
  .footer__social-link, .footer__col a {
    -webkit-tap-highlight-color: transparent;
  }
  .nav__icon-btn { min-width: 44px; min-height: 44px; }
  .btn { min-height: 48px; }
}

/* ── iPad landscape 1024px ── */
@media (max-width: 1024px) {
  .hero__content { max-width: 760px; }
  .collections { padding: var(--s5) 2rem; }
}

/* ── iPad portrait / medium tablet 768–834px ── */
@media (max-width: 834px) {
  :root { --nav-h: 62px; }

  .collections__grid { grid-template-columns: 1fr 1fr; gap: 1rem; }
  .card__visual { aspect-ratio: 1/1; }

  .stats__grid { grid-template-columns: repeat(3,1fr); }

  .about__inner { grid-template-columns: 1fr; gap: 2rem; text-align: center; }
  .about__body  { max-width: 560px; margin: 0 auto; }

  /* atelier responsive now handled in styles.css */
}

/* ── Mobile 600px ── */
@media (max-width: 600px) {
  :root {
    --nav-h: 58px;
    --s4: 2.5rem;
    --s5: 3.8rem;
  }

  .nav__container { padding: 0 1rem; }
  .nav__logo-img { height: 54px; }
  .nav__logo-text { font-size: .88rem; letter-spacing: .18em; }

  /* Hero tighter */
  .hero__content { padding: 0 1rem; padding-top: var(--nav-h); }
  .hero__title { font-size: clamp(2.8rem, 14vw, 5.5rem); }
  .hero__eyebrow { letter-spacing: .22em; font-size: .6rem; }
  .hero__subtitle { font-size: .72rem; margin-bottom: 2rem; }
  .hero__cta { flex-direction: column; align-items: center; gap: .75rem; width: 100%; }
  .hero__cta .btn { width: min(280px, 80vw); justify-content: center; }

  /* Marquee smaller */
  .marquee-track { font-size: .8rem; gap: 1.25rem; }

  /* Collections single column on small phones */
  .collections { padding: 3rem 1rem; }
  .collections__grid { grid-template-columns: 1fr; max-width: 340px; margin: 0 auto; }
  .card__visual { aspect-ratio: 4/3; }

  /* About */
  .about { padding: 3rem 1rem; }
  .about__orb-wrap { width: min(300px, 86vw); aspect-ratio: 1; }

  /* Stats column */
  .stats { padding: 2.5rem 1rem; }
  .stats__grid { grid-template-columns: 1fr; gap: 0; }
  .stat { padding: 1.5rem; border-bottom: 1px solid rgba(197,192,184,.12); }
  .stat:last-child { border-bottom: none; }
  .stat__number { font-size: clamp(2.5rem, 10vw, 3.5rem); }

  /* atelier responsive now handled in styles.css */

  /* Quote */
  .quote-section { padding: 3rem 1rem; }
  .quote__text  { font-size: clamp(1.1rem, 5vw, 1.6rem); }
  .quote-section::before { font-size: 60vw; }

  /* Contact */
  .contact { padding: 3rem 1rem; }
  .contact__row { flex-direction: column; gap: 0; }
  .contact__input { border: 1px solid var(--warm-gray); border-bottom: none; }
  .contact__input:focus { border-color: var(--brown); }
  .contact__row .btn { width: 100%; justify-content: center; }

  /* Footer */
  .footer { padding: 3rem 1rem 2rem; }
  .footer__main { grid-template-columns: 1fr; gap: 2rem; }
  .footer__brand { text-align: center; align-items: center; }
  .footer__social { justify-content: center; }
  .footer__nav { grid-template-columns: 1fr 1fr; gap: 2rem 1rem; }
  .footer__col { text-align: left; }
  .footer__bottom { flex-direction: column; text-align: center; gap: .75rem; }
  .footer__legal { justify-content: center; flex-wrap: wrap; gap: 1rem; }

  /* Section titles */
  .section-title { font-size: clamp(2rem, 8.5vw, 3rem); }

  /* Buttons */
  .btn { padding: 13px 28px; font-size: .68rem; }
}

/* ── Tiny phones 360px ── */
@media (max-width: 380px) {
  .hero__title { font-size: clamp(2.4rem, 13vw, 3.5rem); }
  .section-title { font-size: clamp(1.85rem, 9vw, 2.5rem); }
  .nav__logo-text { letter-spacing: .12em; font-size: .82rem; }
  .collections { padding: 2.5rem .75rem; }
  .about { padding: 2.5rem .75rem; }
  .quote-section { padding: 2.5rem .75rem; }
  .contact { padding: 2.5rem .75rem; }
}

/* ================================================================
   SHOP PAGE
   ================================================================ */
.shop-hero {
  background: var(--bg);
  padding: calc(var(--nav-h) + 3rem) var(--s3) 3rem;
  text-align: center;
}
.shop-hero__eyebrow { color: var(--brown); font-size: .65rem; letter-spacing: .32em; text-transform: uppercase; margin-bottom: .75rem; }
.shop-hero__title { font-family: var(--serif); font-size: clamp(2.4rem, 5vw, 4rem); font-weight: 300; color: var(--dark); margin-bottom: .75rem; }
.shop-hero__sub { color: var(--dark-mid); font-size: .88rem; }

/* Filters */
.shop-filters {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 1rem;
  padding: 1.5rem var(--s3);
  border-top: 1px solid rgba(197,192,184,.3);
  border-bottom: 1px solid rgba(197,192,184,.3);
  background: var(--off-white);
  position: sticky; top: var(--nav-h); z-index: 100;
}
.filter-pills { display: flex; gap: .5rem; flex-wrap: wrap; }
.filter-pill {
  padding: .45rem 1.1rem;
  border: 1px solid rgba(197,192,184,.5);
  font-size: .65rem; letter-spacing: .15em; text-transform: uppercase;
  color: var(--dark-mid); cursor: pointer;
  transition: all .3s var(--ease-out);
  background: transparent;
}
.filter-pill:hover, .filter-pill.is-active {
  background: var(--dark); color: var(--off-white); border-color: var(--dark);
}
.filter-sort {
  display: flex; align-items: center; gap: .75rem;
}
.filter-sort label { font-size: .65rem; letter-spacing: .15em; text-transform: uppercase; color: var(--dark-mid); }
.filter-sort select {
  background: transparent; border: 1px solid rgba(197,192,184,.5); padding: .45rem .85rem;
  font-family: var(--sans); font-size: .75rem; color: var(--dark); outline: none; cursor: pointer;
}

/* Product Grid */
.shop-grid {
  max-width: 1440px; margin: 0 auto;
  padding: 3rem var(--s3) var(--s5);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}
.product-card {
  cursor: pointer;
  transition: transform .5s var(--ease-out);
}
.product-card:hover { transform: translateY(-8px); }

.product-card__visual {
  position: relative; overflow: hidden; aspect-ratio: 3/4;
  background: linear-gradient(145deg, var(--warm-gray), var(--beige));
}
.product-card__visual img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .7s var(--ease-out);
}
.product-card:hover .product-card__visual img { transform: scale(1.05); }

.product-card__badges {
  position: absolute; top: .85rem; left: .85rem;
  display: flex; flex-direction: column; gap: .35rem;
}
.badge {
  padding: .3rem .65rem;
  font-size: .58rem; letter-spacing: .14em; text-transform: uppercase;
  font-weight: 500;
}
.badge--unique { background: var(--dark); color: var(--off-white); }
.badge--custom { background: var(--brown); color: #fff; }
.badge--new    { background: var(--dusty-rose); color: #fff; }

.product-card__action {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: var(--dark); color: var(--off-white);
  padding: .9rem; text-align: center;
  font-size: .65rem; letter-spacing: .2em; text-transform: uppercase;
  transform: translateY(100%); transition: transform .4s var(--ease-out);
}
.product-card:hover .product-card__action { transform: translateY(0); }

.product-card__body { padding: 1rem 0; }
.product-card__collection { font-size: .6rem; letter-spacing: .2em; text-transform: uppercase; color: var(--brown); margin-bottom: .35rem; }
.product-card__name { font-family: var(--serif); font-size: 1.15rem; font-weight: 400; color: var(--dark); margin-bottom: .35rem; }
.product-card__price { font-size: .88rem; font-weight: 500; color: var(--dark); }

.shop-empty {
  text-align: center; padding: var(--s5) var(--s3); color: var(--dark-mid);
  grid-column: 1/-1;
}

/* Shop responsive */
@media (max-width: 1024px) { .shop-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 600px) {
  .shop-hero { padding: calc(var(--nav-h) + 2rem) 1rem 2rem; }
  .shop-filters { padding: 1rem; flex-direction: column; align-items: flex-start; position: static; }
  .shop-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; padding: 2rem 1rem 3rem; }
  .product-card__visual { aspect-ratio: 1/1; }
  .product-card__body { padding: .75rem 0; }
}
@media (max-width: 400px) {
  .shop-grid { grid-template-columns: 1fr; max-width: 320px; margin: 0 auto; }
  .product-card__visual { aspect-ratio: 4/3; }
}

/* ================================================================
   PRODUCT PAGE
   ================================================================ */
.product-layout {
  max-width: 1200px; margin: 0 auto;
  padding: calc(var(--nav-h) + 2rem) var(--s3) var(--s5);
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 4rem; align-items: start;
}
.product-gallery__main {
  aspect-ratio: 1/1; overflow: hidden;
  background: linear-gradient(145deg, var(--warm-gray), var(--beige));
}
.product-gallery__main img { width: 100%; height: 100%; object-fit: cover; }

.product-gallery__thumbs { display: flex; gap: .5rem; margin-top: .5rem; }
.product-gallery__thumb {
  width: 64px; height: 64px; overflow: hidden;
  background: linear-gradient(135deg, var(--warm-gray), var(--beige));
  cursor: pointer; border: 2px solid transparent;
  transition: border-color .3s;
}
.product-gallery__thumb.is-active { border-color: var(--brown); }
.product-gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }

.product-info__breadcrumb {
  font-size: .62rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--warm-gray); margin-bottom: 1.25rem;
}
.product-info__breadcrumb a { color: var(--warm-gray); transition: color .3s; }
.product-info__breadcrumb a:hover { color: var(--brown); }
.product-info__collection {
  font-size: .65rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--brown); margin-bottom: .5rem;
}
.product-info__name {
  font-family: var(--serif); font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  font-weight: 300; color: var(--dark); margin-bottom: .75rem; line-height: 1.1;
}
.product-info__price {
  font-size: 1.35rem; font-weight: 500; color: var(--dark); margin-bottom: 1.5rem;
}
.product-info__desc {
  font-size: .9rem; line-height: 1.85; color: var(--dark-mid); margin-bottom: 2rem;
}
.product-info__unique {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .5rem 1rem; background: rgba(139,94,60,.08);
  border: 1px solid rgba(139,94,60,.2); color: var(--brown);
  font-size: .65rem; letter-spacing: .15em; text-transform: uppercase;
  margin-bottom: 2rem;
}

/* Customization zone */
.customization-zone {
  background: var(--bg); padding: 1.5rem;
  border: 1px solid rgba(197,192,184,.4); margin-bottom: 2rem;
}
.customization-zone__title {
  font-family: var(--serif); font-size: 1.1rem; font-weight: 400;
  color: var(--dark); margin-bottom: 1rem;
}
.custom-tabs { display: flex; gap: 0; margin-bottom: 1.25rem; border-bottom: 1px solid rgba(197,192,184,.3); }
.custom-tab {
  flex: 1; padding: .75rem .5rem; text-align: center;
  font-size: .65rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--dark-mid); cursor: pointer;
  border-bottom: 2px solid transparent; transition: all .3s;
  background: transparent;
}
.custom-tab.is-active { color: var(--brown); border-bottom-color: var(--brown); }
.custom-tab:hover { color: var(--dark); }

.custom-panel { display: none; }
.custom-panel.is-active { display: block; }

.custom-label {
  display: block; font-size: .65rem; letter-spacing: .15em;
  text-transform: uppercase; color: var(--dark-mid); margin-bottom: .5rem;
}
.custom-input {
  width: 100%; padding: .75rem 1rem;
  border: 1px solid rgba(197,192,184,.5); background: var(--off-white);
  font-family: var(--sans); font-size: .88rem; color: var(--dark); outline: none;
  transition: border-color .3s; resize: none;
}
.custom-input:focus { border-color: var(--brown); }
.custom-char-count { font-size: .62rem; color: var(--warm-gray); text-align: right; margin-top: .3rem; }

.custom-upload-zone {
  border: 2px dashed rgba(197,192,184,.5); padding: 2rem;
  text-align: center; cursor: pointer;
  transition: border-color .3s, background .3s;
}
.custom-upload-zone:hover, .custom-upload-zone.drag-over {
  border-color: var(--brown); background: rgba(139,94,60,.04);
}
.custom-upload-zone input { display: none; }
.custom-upload-zone p { font-size: .78rem; color: var(--dark-mid); margin-top: .5rem; }
.custom-upload-preview { max-width: 100%; max-height: 160px; object-fit: contain; margin: .75rem auto 0; display: none; }

/* Product actions */
.product-actions { display: flex; flex-direction: column; gap: .85rem; }
.product-actions .btn { justify-content: center; }

/* Stock indicator */
.product-stock {
  font-size: .65rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--brown); margin-bottom: 1.25rem;
  display: flex; align-items: center; gap: .5rem;
}
.product-stock::before {
  content: ''; width: 8px; height: 8px; border-radius: 50%;
  background: var(--brown); display: block;
}
.product-stock.out-of-stock { color: var(--warm-gray); }
.product-stock.out-of-stock::before { background: var(--warm-gray); }

/* Product responsive */
@media (max-width: 900px) {
  .product-layout { grid-template-columns: 1fr; gap: 2.5rem;
    padding: calc(var(--nav-h) + 1.5rem) 2rem var(--s5); }
  .product-gallery__main { max-width: 520px; }
}
@media (max-width: 600px) {
  .product-layout { padding: calc(var(--nav-h) + 1rem) 1rem 3rem; gap: 2rem; }
  .product-info__name { font-size: clamp(1.6rem, 7vw, 2.2rem); }
  .product-gallery__thumbs { gap: .35rem; }
  .product-gallery__thumb { width: 52px; height: 52px; }
}

/* ================================================================
   CART PAGE
   ================================================================ */
.cart-page {
  max-width: 1100px; margin: 0 auto;
  padding: calc(var(--nav-h) + 2.5rem) var(--s3) var(--s5);
  display: grid; grid-template-columns: 1.5fr 1fr;
  gap: 3.5rem; align-items: start;
}
.cart-page__title {
  font-family: var(--serif); font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 300; color: var(--dark); margin-bottom: 2rem;
  grid-column: 1/-1;
}
.cart-line-items { display: flex; flex-direction: column; gap: 1.5rem; }
.cart-line {
  display: grid; grid-template-columns: 90px 1fr auto;
  gap: 1.25rem; align-items: start;
  padding-bottom: 1.5rem; border-bottom: 1px solid rgba(197,192,184,.3);
}
.cart-line:last-child { border-bottom: none; }
.cart-line__thumb {
  width: 90px; height: 90px; overflow: hidden;
  background: linear-gradient(135deg, var(--warm-gray), var(--beige));
}
.cart-line__thumb img { width: 100%; height: 100%; object-fit: cover; }
.cart-line__name { font-family: var(--serif); font-size: 1.1rem; font-weight: 400; margin-bottom: .3rem; }
.cart-line__collection { font-size: .6rem; text-transform: uppercase; letter-spacing: .2em; color: var(--brown); margin-bottom: .4rem; }
.cart-line__custom { font-size: .75rem; color: var(--dark-mid); margin-bottom: .5rem; }
.cart-line__price { font-size: .95rem; font-weight: 500; }
.cart-line__remove { color: var(--warm-gray); cursor: pointer; font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; transition: color .3s; }
.cart-line__remove:hover { color: var(--dusty-rose); }

/* Order summary */
.order-summary {
  background: var(--off-white); padding: 2rem;
  border: 1px solid rgba(197,192,184,.3); position: sticky; top: calc(var(--nav-h) + 1.5rem);
}
.order-summary__title { font-family: var(--serif); font-size: 1.2rem; font-weight: 400; margin-bottom: 1.5rem; }
.order-row { display: flex; justify-content: space-between; font-size: .85rem; margin-bottom: .75rem; color: var(--dark-mid); }
.order-row--total { font-weight: 600; color: var(--dark); font-size: 1rem; padding-top: 1rem; border-top: 1px solid rgba(197,192,184,.4); margin-top: .75rem; }

/* Checkout form */
.checkout-section { margin-top: 2rem; }
.checkout-section__title { font-size: .65rem; letter-spacing: .2em; text-transform: uppercase; color: var(--dark); margin-bottom: 1rem; font-weight: 500; }
.checkout-field { margin-bottom: 1rem; }
.checkout-field label { display: block; font-size: .65rem; letter-spacing: .12em; text-transform: uppercase; color: var(--dark-mid); margin-bottom: .4rem; }
.checkout-field input, .checkout-field select {
  width: 100%; padding: .75rem 1rem;
  border: 1px solid rgba(197,192,184,.5); background: var(--bg);
  font-family: var(--sans); font-size: .85rem; color: var(--dark); outline: none;
  transition: border-color .3s;
}
.checkout-field input:focus, .checkout-field select:focus { border-color: var(--brown); }
.checkout-row { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }

/* Stripe card element */
.stripe-card-element {
  padding: .85rem 1rem; border: 1px solid rgba(197,192,184,.5); background: var(--bg);
}

.secure-note { display: flex; align-items: center; gap: .5rem; font-size: .65rem; color: var(--warm-gray); margin-top: .75rem; }

/* Cart page responsive */
@media (max-width: 900px) {
  .cart-page { grid-template-columns: 1fr; gap: 2rem; }
  .order-summary { position: static; }
}
@media (max-width: 600px) {
  .cart-page { padding: calc(var(--nav-h) + 1.5rem) 1rem 3rem; }
  .cart-line { grid-template-columns: 72px 1fr auto; gap: .85rem; }
  .cart-line__thumb { width: 72px; height: 72px; }
  .checkout-row { grid-template-columns: 1fr; }
}

/* ================================================================
   ADMIN PANEL
   ================================================================ */
.admin-body { background: #f7f5f2; min-height: 100vh; }

/* Login */
.admin-login {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  background: var(--bg); padding: 2rem;
}
.admin-login__box {
  width: min(420px, 100%); background: var(--off-white);
  padding: 3rem 2.5rem; border: 1px solid rgba(197,192,184,.4);
}
.admin-login__logo { font-family: var(--serif); font-size: 1.1rem; letter-spacing: .28em; text-transform: uppercase; margin-bottom: 2rem; color: var(--dark); text-align: center; }
.admin-login__title { font-family: var(--serif); font-size: 1.5rem; font-weight: 300; text-align: center; margin-bottom: 2rem; }

/* Admin shell */
.admin-shell { display: grid; grid-template-columns: 240px 1fr; min-height: 100vh; }
.admin-sidebar {
  background: var(--dark); padding: 2rem 0; display: flex; flex-direction: column;
  position: sticky; top: 0; height: 100vh; overflow-y: auto;
}
.admin-sidebar__brand { font-family: var(--serif); font-size: .88rem; letter-spacing: .22em; color: var(--beige); padding: 0 1.5rem 2rem; border-bottom: 1px solid rgba(197,192,184,.1); margin-bottom: 1.5rem; }
.admin-nav { display: flex; flex-direction: column; gap: .25rem; padding: 0 .75rem; }
.admin-nav-item {
  display: flex; align-items: center; gap: .75rem;
  padding: .75rem 1rem; color: var(--warm-gray);
  font-size: .78rem; letter-spacing: .08em; cursor: pointer;
  transition: all .25s; border-radius: 2px; background: transparent;
  width: 100%; text-align: left;
}
.admin-nav-item:hover { background: rgba(212,174,152,.1); color: var(--beige); }
.admin-nav-item.is-active { background: rgba(212,174,152,.15); color: var(--beige); }
.admin-nav-item svg { flex-shrink: 0; opacity: .75; }
.admin-logout { margin-top: auto; padding: 1.5rem .75rem 0; }

/* Admin main */
.admin-main { padding: 2rem 2.5rem; overflow-y: auto; }
.admin-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 2rem; flex-wrap: wrap; gap: 1rem; }
.admin-header h1 { font-family: var(--serif); font-size: 1.6rem; font-weight: 300; color: var(--dark); }

/* Stats cards */
.admin-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.25rem; margin-bottom: 2.5rem; }
.admin-stat-card {
  background: var(--off-white); padding: 1.5rem; border: 1px solid rgba(197,192,184,.3);
}
.admin-stat-card__label { font-size: .62rem; text-transform: uppercase; letter-spacing: .18em; color: var(--dark-mid); margin-bottom: .5rem; }
.admin-stat-card__value { font-family: var(--serif); font-size: 2rem; font-weight: 300; color: var(--dark); }
.admin-stat-card__sub { font-size: .7rem; color: var(--warm-gray); margin-top: .3rem; }

/* Table */
.admin-table-wrap { background: var(--off-white); border: 1px solid rgba(197,192,184,.3); overflow-x: auto; }
.admin-table { width: 100%; border-collapse: collapse; }
.admin-table th, .admin-table td { padding: 1rem 1.25rem; text-align: left; font-size: .82rem; border-bottom: 1px solid rgba(197,192,184,.2); }
.admin-table th { font-size: .62rem; letter-spacing: .18em; text-transform: uppercase; color: var(--dark-mid); font-weight: 500; background: rgba(197,192,184,.08); }
.admin-table tr:last-child td { border-bottom: none; }
.admin-table tr:hover td { background: rgba(212,174,152,.05); }
.admin-table img { width: 44px; height: 44px; object-fit: cover; }

/* Toggle switch */
.toggle { position: relative; display: inline-block; width: 38px; height: 22px; }
.toggle input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
  position: absolute; cursor: pointer; inset: 0;
  background: var(--warm-gray); border-radius: 22px;
  transition: .35s;
}
.toggle-slider::before {
  position: absolute; content: ""; width: 16px; height: 16px;
  left: 3px; bottom: 3px; background: white; border-radius: 50%;
  transition: .35s;
}
.toggle input:checked + .toggle-slider { background: var(--brown); }
.toggle input:checked + .toggle-slider::before { transform: translateX(16px); }

/* Admin action buttons */
.admin-btn { display: inline-flex; align-items: center; gap: .4rem; padding: .55rem 1.1rem; font-family: var(--sans); font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; cursor: pointer; transition: all .3s; }
.admin-btn--primary { background: var(--dark); color: var(--off-white); border: 1px solid var(--dark); }
.admin-btn--primary:hover { background: var(--brown); border-color: var(--brown); }
.admin-btn--ghost { background: transparent; color: var(--dark-mid); border: 1px solid rgba(197,192,184,.5); }
.admin-btn--ghost:hover { border-color: var(--dark); color: var(--dark); }
.admin-btn--danger { background: transparent; color: #c0392b; border: 1px solid rgba(192,57,43,.3); }
.admin-btn--danger:hover { background: rgba(192,57,43,.08); }

/* Modal */
.admin-modal-overlay {
  position: fixed; inset: 0; background: rgba(44,40,37,.55);
  z-index: 990; display: flex; align-items: center; justify-content: center;
  padding: 1.5rem; opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity .35s, visibility .35s;
}
.admin-modal-overlay.is-open { opacity: 1; visibility: visible; pointer-events: auto; }
.admin-modal {
  background: var(--off-white); width: min(700px, 100%);
  max-height: 90vh; overflow-y: auto; padding: 2rem 2.5rem;
  transform: translateY(12px); transition: transform .45s var(--ease-out);
}
.admin-modal-overlay.is-open .admin-modal { transform: translateY(0); }
.admin-modal__header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1.75rem; }
.admin-modal__title { font-family: var(--serif); font-size: 1.4rem; font-weight: 300; }
.admin-modal__close { width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; color: var(--dark-mid); cursor: pointer; transition: color .3s; }
.admin-modal__close:hover { color: var(--brown); }

.admin-field { margin-bottom: 1.25rem; }
.admin-field label { display: block; font-size: .62rem; text-transform: uppercase; letter-spacing: .15em; color: var(--dark-mid); margin-bottom: .4rem; font-weight: 500; }
.admin-field input, .admin-field select, .admin-field textarea {
  width: 100%; padding: .7rem 1rem;
  border: 1px solid rgba(197,192,184,.5); background: var(--bg);
  font-family: var(--sans); font-size: .85rem; color: var(--dark); outline: none;
  transition: border-color .3s;
}
.admin-field input:focus, .admin-field select:focus, .admin-field textarea:focus { border-color: var(--brown); }
.admin-field textarea { resize: vertical; min-height: 100px; }
.admin-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.admin-field-checkboxes { display: flex; flex-direction: column; gap: .5rem; }
.admin-field-checkbox { display: flex; align-items: center; gap: .6rem; font-size: .8rem; cursor: pointer; }
.admin-field-checkbox input { width: auto; border: none; background: none; }
.admin-form-actions { display: flex; gap: .75rem; justify-content: flex-end; margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid rgba(197,192,184,.3); }

/* Image upload in admin */
.admin-upload-zone {
  border: 2px dashed rgba(197,192,184,.5); padding: 1.5rem;
  text-align: center; cursor: pointer; transition: border-color .3s, background .3s;
}
.admin-upload-zone:hover { border-color: var(--brown); background: rgba(139,94,60,.03); }
.admin-upload-zone input { display: none; }
.admin-upload-zone p { font-size: .78rem; color: var(--dark-mid); margin-top: .5rem; }
.admin-upload-preview { display: flex; gap: .5rem; flex-wrap: wrap; margin-top: .75rem; }
.admin-upload-preview-item { position: relative; width: 72px; height: 72px; }
.admin-upload-preview-item img { width: 100%; height: 100%; object-fit: cover; }
.admin-upload-preview-item .remove { position: absolute; top: -4px; right: -4px; width: 18px; height: 18px; background: var(--dusty-rose); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .65rem; cursor: pointer; }

/* Admin responsive */
@media (max-width: 1024px) { .admin-stats { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 768px) {
  .admin-shell { grid-template-columns: 1fr; }
  .admin-sidebar { height: auto; position: fixed; bottom: 0; left: 0; right: 0; top: auto; flex-direction: row; padding: 0; z-index: 900; }
  .admin-sidebar__brand { display: none; }
  .admin-nav { flex-direction: row; overflow-x: auto; padding: .5rem; gap: .25rem; border-bottom: none; margin-bottom: 0; width: 100%; }
  .admin-nav-item { flex-direction: column; gap: .25rem; padding: .5rem .75rem; font-size: .58rem; }
  .admin-logout { display: none; }
  .admin-main { padding: 1.25rem; padding-bottom: 5rem; }
  .admin-stats { grid-template-columns: 1fr 1fr; }
  .admin-field-row { grid-template-columns: 1fr; }
}

/* ================================================================
   PROMO CODE SECTION (Cart page)
   ================================================================ */
.promo-section {
  margin: 1.25rem 0;
  border: 1px solid rgba(197,192,184,.35);
  border-radius: 2px;
  overflow: hidden;
}
.promo-toggle {
  width: 100%; display: flex; align-items: center; gap: .6rem;
  padding: .85rem 1rem; background: transparent; cursor: pointer;
  font-family: var(--sans); font-size: .75rem; letter-spacing: .1em;
  text-transform: uppercase; color: var(--dark-mid); text-align: left;
  border: none; transition: color .3s;
}
.promo-toggle:hover { color: var(--brown); }
.promo-toggle svg { flex-shrink: 0; transition: transform .35s; }
.promo-toggle.is-open svg { transform: rotate(180deg); }
.promo-form {
  padding: .85rem 1rem 1rem; border-top: 1px solid rgba(197,192,184,.25);
  background: rgba(240,235,227,.5);
}
.promo-input-row {
  display: flex; gap: .5rem;
}
.promo-input-row input {
  flex: 1; padding: .65rem .85rem;
  border: 1px solid rgba(197,192,184,.5); background: var(--off-white);
  font-family: var(--sans); font-size: .85rem; color: var(--dark);
  outline: none; text-transform: uppercase; letter-spacing: .05em;
  transition: border-color .3s;
}
.promo-input-row input:focus { border-color: var(--brown); }
.promo-apply-btn { white-space: nowrap; padding: .65rem 1.15rem; font-size: .68rem; }
.promo-feedback {
  min-height: 1.4rem; font-size: .75rem; margin-top: .6rem; letter-spacing: .02em;
}
.promo-feedback.is-success { color: #5a8a5a; }
.promo-feedback.is-error   { color: var(--dusty-rose); }
.promo-applied-badge {
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(90,138,90,.08); border: 1px solid rgba(90,138,90,.25);
  padding: .5rem .85rem; margin-top: .6rem; font-size: .75rem;
}
.promo-applied-badge span { color: #5a8a5a; font-weight: 500; }
.promo-remove-btn {
  background: none; border: none; cursor: pointer; color: var(--dusty-rose);
  font-size: .7rem; text-transform: uppercase; letter-spacing: .1em;
  padding: 0; transition: opacity .3s;
}
.promo-remove-btn:hover { opacity: .7; }
.order-row--discount { color: #5a8a5a; font-weight: 500; }
