/* HEADER */
header {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:rgba(26,26,24,.97); backdrop-filter:blur(20px);
  padding:16px max(60px, env(safe-area-inset-right, 0px)) 16px max(60px, env(safe-area-inset-left, 0px));
  padding-top:max(16px, env(safe-area-inset-top, 0px));
  display:flex; align-items:center; justify-content:space-between;
  box-shadow:0 2px 40px rgba(0,0,0,.3);
}
.logo { font-family:'Playfair Display',serif; font-size:26px; font-weight:700; color:var(--white); letter-spacing:6px; text-decoration:none; }
.logo span { color:var(--gold); }
.header-right { display:flex; align-items:center; gap:30px; }
.nav-links { display:flex; gap:28px; }
.nav-links a { color:rgba(255,255,255,.7); text-decoration:none; font-size:11px; letter-spacing:2px; text-transform:uppercase; transition:color .3s; }
.nav-links a:hover, .nav-links a.active { color:var(--gold); }
.interest-chip, .toolbar-interest-link {
  display:inline-flex; align-items:center; gap:10px; text-decoration:none;
  padding:11px 14px; border:1px solid rgba(201,168,76,.28); color:var(--gold);
  font-size:11px; letter-spacing:1.4px; text-transform:uppercase; transition:all .3s;
}
.interest-chip:hover, .toolbar-interest-link:hover { border-color:var(--gold); background:rgba(201,168,76,.08); }
.interest-chip.filled, .toolbar-interest-link.filled { background:var(--gold); color:var(--dark); border-color:var(--gold); }

/* CART BUTTON */
.cart-btn {
  position:relative; background:transparent; border:1px solid var(--gold);
  color:var(--gold); width:44px; height:44px; display:flex; align-items:center;
  justify-content:center; cursor:pointer; transition:all .3s; font-size:16px;
}
.cart-btn:hover { background:var(--gold); color:var(--dark); }
.cart-badge {
  position:absolute; top:-8px; right:-8px;
  background:var(--gold); color:var(--dark);
  width:20px; height:20px; border-radius:50%;
  font-size:11px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  animation:pop .3s ease;
}
@keyframes pop { 0%{transform:scale(0)} 70%{transform:scale(1.2)} 100%{transform:scale(1)} }

/* PAGE HERO */
.page-hero {
  padding:140px max(60px, env(safe-area-inset-right, 0px)) 60px max(60px, env(safe-area-inset-left, 0px));
  background:var(--dark);
  position:relative;
  overflow:hidden;
}
.page-hero::before {
  content:'';
  position:absolute; inset:0;
  opacity:.05;
  background-image:linear-gradient(45deg,var(--gold) 25%,transparent 25%),linear-gradient(-45deg,var(--gold) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--gold) 75%),linear-gradient(-45deg,transparent 75%,var(--gold) 75%);
  background-size:40px 40px;
}
.page-hero-content { position:relative; z-index:1; }
.page-tag { font-size:10px; letter-spacing:4px; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:14px; }
.page-tag::before { content:''; display:inline-block; width:20px; height:1px; background:var(--gold); vertical-align:middle; margin-right:10px; }
.page-title { font-family:'Playfair Display',serif; font-size:clamp(36px,5vw,64px); font-weight:700; color:var(--white); margin-bottom:16px; }
.page-title em { font-style:italic; color:var(--gold-light); }
.page-subtitle { font-family:'Cormorant Garamond',serif; font-size:18px; color:rgba(255,255,255,.5); font-weight:300; }
.breadcrumb { display:flex; gap:10px; align-items:center; margin-top:24px; font-size:12px; color:rgba(255,255,255,.4); }
.breadcrumb a { color:rgba(255,255,255,.4); text-decoration:none; transition:color .3s; }
.breadcrumb a:hover { color:var(--gold); }
.breadcrumb span { color:var(--gold); }

/* MAIN LAYOUT */
.catalog-layout {
  display:grid;
  grid-template-columns:280px 1fr;
  gap:0;
  min-height:100vh;
}
.mobile-filter-bar { display:none; }
.sidebar-overlay { display:none; }

/* SIDEBAR */
.sidebar {
  background:var(--cream);
  padding:40px 32px;
  border-right:1px solid rgba(0,0,0,.06);
  position:sticky;
  top:calc(76px + env(safe-area-inset-top, 0px));
  height:calc(100vh - 76px - env(safe-area-inset-top, 0px));
  overflow-y:auto;
}
.sidebar-mobile-head { display:none; }
.sidebar::-webkit-scrollbar { width:3px; }
.filter-section { margin-bottom:36px; }
.filter-title {
  font-size:10px; letter-spacing:3px; text-transform:uppercase;
  color:var(--muted); margin-bottom:16px; font-weight:500;
  display:flex; align-items:center; justify-content:space-between;
}
.filter-title button {
  font-size:10px; color:var(--gold); background:none; border:none;
  cursor:pointer; letter-spacing:1px; text-transform:uppercase;
  font-family:'Jost',sans-serif;
}

/* SEARCH */
.search-wrap { position:relative; margin-bottom:8px; }
.search-wrap input {
  width:100%; padding:12px 40px 12px 16px;
  border:1px solid #ddd; background:var(--white);
  font-family:'Jost',sans-serif; font-size:14px; color:var(--dark);
  outline:none; transition:border-color .3s;
}
.search-wrap input:focus { border-color:var(--gold); }
.search-wrap i { position:absolute; right:14px; top:50%; transform:translateY(-50%); color:var(--muted); font-size:14px; }

/* FILTER CHIPS */
.filter-chips { display:flex; flex-wrap:wrap; gap:8px; }
.chip {
  padding:8px 14px; border:1px solid #ddd; background:var(--white);
  font-size:12px; color:var(--text); cursor:pointer;
  transition:all .25s; font-family:'Jost',sans-serif;
  letter-spacing:.5px; appearance:none;
}
.chip:hover { border-color:var(--gold); color:var(--gold); }
.chip:focus-visible { outline:2px solid rgba(201,168,76,.35); outline-offset:2px; }
.chip.active { background:var(--gold); border-color:var(--gold); color:var(--dark); font-weight:500; }

/* COLOR FILTERS */
.color-filters { display:flex; flex-wrap:wrap; gap:10px; }
.color-dot {
  width:32px; height:32px; border-radius:50%; cursor:pointer;
  border:3px solid transparent; transition:all .25s;
  position:relative; appearance:none; padding:0;
}
.color-dot:hover { transform:scale(1.1); }
.color-dot:focus-visible { outline:2px solid rgba(201,168,76,.35); outline-offset:2px; }
.color-dot.active { border-color:var(--gold); transform:scale(1.1); }
.color-dot.active::after {
  content:'✓'; position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:700; color:white;
  text-shadow:0 1px 2px rgba(0,0,0,.5);
}

/* PRICE RANGE */
.price-range { padding:8px 0; }
.price-inputs { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:12px; }
.price-inputs input {
  padding:10px 12px; border:1px solid #ddd; background:var(--white);
  font-family:'Jost',sans-serif; font-size:13px; color:var(--dark);
  outline:none; transition:border-color .3s; width:100%;
}
.price-inputs input:focus { border-color:var(--gold); }
.price-slider { width:100%; accent-color:var(--gold); }

/* RESET FILTERS */
.reset-btn {
  width:100%; padding:12px; background:transparent;
  border:1px solid rgba(0,0,0,.15); color:var(--muted);
  font-family:'Jost',sans-serif; font-size:11px;
  letter-spacing:2px; text-transform:uppercase;
  cursor:pointer; transition:all .3s; margin-top:8px;
}
.reset-btn:hover { border-color:var(--gold); color:var(--gold); }

/* CATALOG MAIN */
.catalog-main { padding:36px 40px; }

/* TOOLBAR */
.toolbar {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:30px; flex-wrap:wrap; gap:16px;
}
.results-info { font-size:13px; color:var(--muted); }
.results-info strong { color:var(--dark); font-weight:600; }
.toolbar-right { display:flex; align-items:center; gap:16px; }
.toolbar-interest-link { color:var(--text); border-color:rgba(0,0,0,.12); }
.toolbar-filter-btn { display:none; padding:10px 14px; border:1px solid #ddd; background:var(--white); color:var(--text); cursor:pointer; font-family:'Jost',sans-serif; font-size:12px; letter-spacing:1px; transition:all .3s; }
.toolbar-filter-btn:hover { border-color:var(--gold); color:var(--gold); }
.sort-select {
  padding:10px 16px; border:1px solid #ddd; background:var(--white);
  font-family:'Jost',sans-serif; font-size:13px; color:var(--dark);
  outline:none; cursor:pointer; transition:border-color .3s;
}
.sort-select:focus { border-color:var(--gold); }
.view-btns { display:flex; gap:4px; }
.view-btn {
  width:36px; height:36px; border:1px solid #ddd; background:var(--white);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all .3s; color:var(--muted); font-size:14px;
}
.view-btn.active { background:var(--gold); border-color:var(--gold); color:var(--dark); }

/* ACTIVE FILTERS BAR */
.active-filters { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:24px; }
.active-filter-tag {
  display:flex; align-items:center; gap:8px;
  padding:6px 12px; background:rgba(201,168,76,.12);
  border:1px solid rgba(201,168,76,.3); font-size:12px; color:var(--text);
}
.active-filter-tag button { background:none; border:none; color:var(--gold); cursor:pointer; font-size:14px; line-height:1; }

/* PRODUCTS GRID */
.products-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:2px;
  transition:all .3s;
}
.products-grid.list-view {
  grid-template-columns:1fr;
  gap:2px;
}

/* PRODUCT CARD */
.product-card {
  background:var(--white);
  position:relative;
  overflow:hidden;
  cursor:pointer;
  transition:all .4s cubic-bezier(.16,1,.3,1);
  animation:fadeIn .5s ease forwards;
  border:1px solid transparent;
}
.product-card:hover { border-color:var(--gold); transform:translateY(-4px); box-shadow:0 20px 60px rgba(0,0,0,.12); }
@keyframes fadeIn { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }

.product-img-wrap {
  position:relative; overflow:hidden;
  aspect-ratio:1;
  background:linear-gradient(160deg,#e7dfd2 0%,#f4eee4 100%);
}
.product-img-wrap::before {
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg,rgba(14,14,13,.04) 0%,rgba(14,14,13,0) 28%,rgba(14,14,13,.22) 100%),
    radial-gradient(circle at top right,rgba(255,255,255,.26),transparent 34%);
  z-index:1;
  pointer-events:none;
  transition:opacity .35s ease;
}
.product-img-wrap::after {
  content:'';
  position:absolute;
  inset:14px;
  border:1px solid rgba(255,255,255,.34);
  opacity:0;
  transform:scale(.96);
  transition:all .4s cubic-bezier(.16,1,.3,1);
  z-index:2;
  pointer-events:none;
}
.product-image-link { display:block; width:100%; height:100%; }
.products-grid.list-view .product-img-wrap { aspect-ratio:4/3; width:280px; flex-shrink:0; }
.products-grid.list-view .product-card { display:flex; }
.products-grid.list-view .product-info { flex:1; padding:32px; display:flex; flex-direction:column; justify-content:center; }

.product-img-wrap img {
  width:100%; height:100%; object-fit:cover;
  filter:saturate(.88) contrast(.96) brightness(.98);
  transform:scale(1.01);
  transition:transform .9s cubic-bezier(.16,1,.3,1), filter .45s ease;
}
.product-card:hover .product-img-wrap::before { opacity:.78; }
.product-card:hover .product-img-wrap::after { opacity:1; transform:scale(1); }
.product-card:hover .product-img-wrap img {
  transform:scale(1.08);
  filter:saturate(1.02) contrast(1.02) brightness(1.02);
}

.product-badge {
  position:absolute; top:14px; left:14px;
  padding:5px 12px; font-size:10px; letter-spacing:2px;
  text-transform:uppercase; font-weight:500;
}
.badge-new { background:var(--gold); color:var(--dark); }
.badge-hit { background:var(--dark); color:var(--white); }
.badge-sale { background:#e05252; color:var(--white); }
.badge-low { background:#c08c2f; color:var(--white); }
.badge-out { background:#727272; color:var(--white); top:46px; }

.wishlist-btn {
  position:absolute; top:14px; right:14px;
  width:36px; height:36px; background:rgba(255,255,255,.9);
  border:none; display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all .3s; font-size:15px; color:var(--muted);
  opacity:0; transform:translateY(-8px);
}
.product-card:hover .wishlist-btn { opacity:1; transform:translateY(0); }
.wishlist-btn.liked { color:#e05252; opacity:1; transform:translateY(0); }
.wishlist-btn:hover { background:var(--white); color:#e05252; }

.quick-view {
  position:absolute; bottom:0; left:0; right:0;
  padding:14px; background:var(--dark); color:var(--white);
  text-align:center; font-size:11px; letter-spacing:2px;
  text-transform:uppercase; transform:translateY(100%);
  transition:transform .3s; cursor:pointer; border:none;
  font-family:'Jost',sans-serif;
}
.product-card:hover .quick-view { transform:translateY(0); }

.product-info { padding:20px; }
.products-grid:not(.list-view) .product-info {
  background:linear-gradient(180deg,rgba(255,255,255,.98) 0%,#f9f5ee 100%);
}
.product-category { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:6px; }
.product-name-link { text-decoration:none; color:inherit; }
.product-name { font-family:'Playfair Display',serif; font-size:17px; font-weight:700; color:var(--dark); margin-bottom:6px; line-height:1.2; }
.product-size { font-size:12px; color:var(--muted); margin-bottom:12px; }
.product-stock {
  font-size:11px;
  margin-bottom:10px;
  letter-spacing:.6px;
  text-transform:uppercase;
  color:var(--muted);
}
.product-stock.in { color:#2c7c4d; }
.product-stock.low { color:#a66f06; }
.product-stock.out { color:#8a8a8a; }
.product-footer { display:flex; align-items:center; justify-content:space-between; }
.product-actions { display:flex; gap:14px; flex-wrap:wrap; margin-top:14px; }
.product-link { color:var(--text); text-decoration:none; border-bottom:1px solid rgba(0,0,0,.15); padding-bottom:2px; font-size:12px; transition:all .3s; }
.product-link:hover { color:var(--gold); border-color:var(--gold); }
.product-price { font-family:'Playfair Display',serif; font-size:20px; font-weight:700; color:var(--dark); }
.product-price .old-price { font-size:13px; color:var(--muted); text-decoration:line-through; margin-left:6px; font-family:'Jost',sans-serif; font-weight:400; }
.product-price .per { font-size:11px; color:var(--muted); font-family:'Jost',sans-serif; font-weight:400; }
.add-to-cart {
  width:40px; height:40px; background:var(--gold); border:none;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all .3s; color:var(--dark); font-size:16px;
}
.add-to-cart:hover { background:var(--dark); color:var(--gold); }
.add-to-cart.added { background:var(--success); color:var(--white); }
.add-to-cart.disabled,
.add-to-cart:disabled {
  background:#c8c8c8;
  color:#6a6a6a;
  cursor:not-allowed;
}
.add-to-cart.disabled:hover,
.add-to-cart:disabled:hover {
  background:#c8c8c8;
  color:#6a6a6a;
}
.product-card.is-sold-out { border-color:#d7d7d7; }
.product-card.is-sold-out .product-img-wrap img {
  filter:grayscale(1) contrast(.85);
}

/* EMPTY STATE */
.empty-state { text-align:center; padding:80px 40px; }
.empty-state i { font-size:48px; color:var(--warm); margin-bottom:20px; display:block; }
.empty-state h3 { font-family:'Playfair Display',serif; font-size:24px; margin-bottom:10px; }
.empty-state p { color:var(--muted); font-size:14px; }

/* CART DRAWER */
.cart-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,.5);
  z-index:2000; opacity:0; pointer-events:none;
  transition:opacity .3s;
}
.cart-overlay.open { opacity:1; pointer-events:all; }
.cart-drawer {
  position:fixed; top:0; right:0; bottom:0;
  width:420px; background:var(--white);
  z-index:2001; transform:translateX(100%);
  transition:transform .4s cubic-bezier(.16,1,.3,1);
  display:flex; flex-direction:column;
}
.cart-drawer.open { transform:translateX(0); }
.cart-header {
  padding:28px 28px 20px;
  border-bottom:1px solid rgba(0,0,0,.08);
  display:flex; align-items:center; justify-content:space-between;
}
.cart-header h2 { font-family:'Playfair Display',serif; font-size:22px; }
.cart-header span { font-size:13px; color:var(--muted); }
.cart-stepper {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  padding: 0 28px 14px;
  border-bottom: 1px solid rgba(0,0,0,.08);
}
.cart-step {
  font-size: 11px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #9a9388;
  padding: 8px 6px;
  border: 1px solid #e5ded2;
  border-radius: 999px;
  text-align: center;
}
.cart-step.active {
  background: rgba(201,168,76,.14);
  border-color: var(--gold);
  color: #5f4e25;
}
.cart-close { background:none; border:none; font-size:22px; color:var(--muted); cursor:pointer; transition:color .3s; }
.cart-close:hover { color:var(--dark); }
.cart-items { flex:1; overflow-y:auto; padding:20px 28px; }
.cart-items::-webkit-scrollbar { width:3px; }
.cart-empty { text-align:center; padding:60px 20px; }
.cart-empty i { font-size:48px; color:var(--warm); margin-bottom:16px; display:block; }
.cart-empty p { color:var(--muted); font-size:14px; }
.cart-item {
  display:flex; gap:16px; padding:16px 0;
  border-bottom:1px solid rgba(0,0,0,.06);
  animation:fadeIn .3s ease;
}
.cart-item-img { width:80px; height:80px; object-fit:cover; flex-shrink:0; background:var(--warm); }
.cart-item-info { flex:1; }
.cart-item-name { font-family:'Playfair Display',serif; font-size:15px; margin-bottom:4px; }
.cart-item-size { font-size:12px; color:var(--muted); margin-bottom:8px; }
.cart-item-controls { display:flex; align-items:center; gap:0; }
.qty-btn {
  width:30px; height:30px; border:1px solid #ddd;
  background:var(--white); cursor:pointer; font-size:16px;
  display:flex; align-items:center; justify-content:center;
  transition:all .2s; color:var(--dark);
}
.qty-btn:hover { background:var(--gold); border-color:var(--gold); color:var(--dark); }
.qty-num { width:40px; height:30px; border-top:1px solid #ddd; border-bottom:1px solid #ddd; display:flex; align-items:center; justify-content:center; font-size:14px; font-weight:500; }
.cart-item-price { font-family:'Playfair Display',serif; font-size:17px; font-weight:700; color:var(--gold); }
.remove-item { background:none; border:none; color:var(--muted); cursor:pointer; font-size:16px; transition:color .3s; margin-left:8px; }
.remove-item:hover { color:#e05252; }
.cart-footer { padding:20px 28px; border-top:1px solid rgba(0,0,0,.08); }
.cart-summary { margin-bottom:16px; }
.summary-row { display:flex; justify-content:space-between; margin-bottom:10px; font-size:14px; }
.summary-row.total { font-family:'Playfair Display',serif; font-size:20px; font-weight:700; padding-top:12px; border-top:1px solid rgba(0,0,0,.08); margin-top:4px; }
.checkout-btn {
  width:100%; padding:16px; background:var(--gold); color:var(--dark);
  border:none; font-family:'Jost',sans-serif; font-size:12px;
  letter-spacing:2px; text-transform:uppercase; font-weight:500;
  cursor:pointer; transition:all .3s; margin-bottom:10px;
}
.checkout-btn:hover { background:var(--dark); color:var(--gold); }
.checkout-btn:disabled {
  opacity: .55;
  cursor: not-allowed;
  background: #d8c79a;
  color: #5f5436;
}
.continue-btn {
  width:100%; padding:14px; background:transparent; color:var(--muted);
  border:1px solid #ddd; font-family:'Jost',sans-serif; font-size:11px;
  letter-spacing:2px; text-transform:uppercase; cursor:pointer; transition:all .3s;
}
.continue-btn:hover { border-color:var(--gold); color:var(--gold); }

.cart-order-step {
  padding-top: 26px;
}

.cart-order-summary {
  grid-template-columns: 1fr;
  gap: 10px;
  margin-bottom: 20px;
}

.cart-order-form {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

.cart-order-row {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.cart-order-row label {
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--muted);
}
.field-note {
  margin-top: -2px;
  font-size: 11px;
  color: #8a8478;
}

.cart-order-row input,
.cart-order-row textarea {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid #ddd;
  background: rgba(255,255,255,.98);
  font-family: 'Jost',sans-serif;
  font-size: 14px;
  color: var(--dark);
  outline: none;
  transition: border-color .25s, box-shadow .25s;
}

.cart-order-row input:focus,
.cart-order-row textarea:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201,168,76,.12);
}

.cart-order-row textarea {
  min-height: 130px;
  resize: vertical;
}

.cart-order-actions {
  flex-direction: column;
}

.cart-order-success {
  padding: 12px 0;
}

/* ORDER MODAL */
.order-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.56);
  z-index: 2500;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.order-modal-overlay.open { opacity: 1; pointer-events: all; }
.order-modal {
  position: relative;
  width: min(720px, 100%);
  max-height: 90vh;
  overflow-y: auto;
  padding: 32px;
  background: linear-gradient(180deg,#fffdf8 0%,#f7f1e5 100%);
  border: 1px solid rgba(201,168,76,.24);
  box-shadow: 0 30px 90px rgba(0,0,0,.26);
}
.order-modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 40px;
  height: 40px;
  border: 1px solid rgba(0,0,0,.1);
  background: var(--white);
  color: var(--text);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .25s;
}
.order-modal-close:hover { border-color: var(--gold); color: var(--gold); }
.order-modal-head { padding-right: 44px; margin-bottom: 24px; }
.order-modal-head h2 {
  font-family: 'Playfair Display',serif;
  font-size: 34px;
  margin: 10px 0 12px;
}
.order-modal-head p {
  color: var(--muted);
  font-size: 15px;
  line-height: 1.7;
}
.order-summary-box {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 24px;
}
.order-summary-row {
  padding: 16px 18px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(0,0,0,.06);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.order-summary-row span {
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
}
.order-summary-row strong {
  font-family: 'Playfair Display',serif;
  font-size: 24px;
}
.order-summary-row.total {
  background: rgba(201,168,76,.12);
  border-color: rgba(201,168,76,.28);
}
.order-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
.order-form-row {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.order-form-row-full { grid-column: 1 / -1; }
.order-form-row label {
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--muted);
}
.order-form-row input,
.order-form-row textarea {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid #ddd;
  background: rgba(255,255,255,.95);
  font-family: 'Jost',sans-serif;
  font-size: 14px;
  color: var(--dark);
  outline: none;
  transition: border-color .25s;
}
.order-form-row input:focus,
.order-form-row textarea:focus { border-color: var(--gold); }
.order-form-row textarea {
  min-height: 130px;
  resize: vertical;
}
.order-modal-actions {
  display: flex;
  gap: 12px;
  margin-top: 24px;
}
.order-modal-actions .checkout-btn,
.order-modal-actions .continue-btn,
.order-link-btn {
  flex: 1;
  width: auto;
  margin-bottom: 0;
  text-decoration: none;
  text-align: center;
}
.order-success-state {
  text-align: center;
  padding: 16px 0 4px;
}
.order-success-state i {
  display: block;
  margin-bottom: 18px;
  font-size: 48px;
  color: var(--gold);
}
.order-success-state h3 {
  font-family: 'Playfair Display',serif;
  font-size: 32px;
  margin-bottom: 12px;
}
.order-success-state p {
  max-width: 460px;
  margin: 0 auto;
  color: var(--muted);
  line-height: 1.7;
}

/* PRODUCT MODAL */
.modal-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,.7);
  z-index:3000; display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none; transition:opacity .3s; padding:20px;
}
.modal-overlay.open { opacity:1; pointer-events:all; }
.modal {
  background:var(--white); max-width:800px; width:100%;
  max-height:90vh; overflow-y:auto;
  transform:translateY(30px); transition:transform .4s cubic-bezier(.16,1,.3,1);
  position:relative;
}
.modal-overlay.open .modal { transform:translateY(0); }
.modal-close {
  position:absolute; top:20px; right:20px;
  width:36px; height:36px; background:var(--dark);
  border:none; color:var(--white); cursor:pointer;
  font-size:18px; display:flex; align-items:center; justify-content:center; z-index:1;
  transition:background .3s;
}
.modal-close:hover { background:var(--gold); color:var(--dark); }
.modal-grid { display:grid; grid-template-columns:1fr 1fr; }
.modal-img { aspect-ratio:1; object-fit:cover; width:100%; }
.modal-info { padding:40px; }
.modal-category { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:10px; }
.modal-name { font-family:'Playfair Display',serif; font-size:28px; font-weight:700; margin-bottom:8px; line-height:1.2; }
.modal-price { font-family:'Playfair Display',serif; font-size:32px; font-weight:700; color:var(--gold); margin-bottom:20px; }
.modal-desc { font-family:'Cormorant Garamond',serif; font-size:16px; color:var(--muted); line-height:1.7; margin-bottom:24px; }
.modal-specs { margin-bottom:24px; }
.spec-row { display:flex; justify-content:space-between; padding:10px 0; border-bottom:1px solid rgba(0,0,0,.06); font-size:13px; }
.spec-row span:first-child { color:var(--muted); }
.spec-row span:last-child { font-weight:500; }
.modal-qty { display:flex; align-items:center; gap:16px; margin-bottom:20px; }
.modal-qty label { font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); }
.modal-links { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:20px; }
.modal-link { color:var(--text); text-decoration:none; border-bottom:1px solid rgba(0,0,0,.15); padding-bottom:2px; transition:all .3s; }
.modal-link:hover { color:var(--gold); border-color:var(--gold); }
.modal-add-btn {
  width:100%; padding:16px; background:var(--gold); color:var(--dark);
  border:none; font-family:'Jost',sans-serif; font-size:12px;
  letter-spacing:2px; text-transform:uppercase; font-weight:500;
  cursor:pointer; transition:all .3s;
}
.modal-add-btn:hover { background:var(--dark); color:var(--gold); }

/* TOAST */
.toast {
  position:fixed; bottom:30px; right:30px; z-index:9999;
  background:var(--dark); color:var(--white);
  padding:16px 24px; display:flex; align-items:center; gap:12px;
  font-size:14px; transform:translateY(100px); opacity:0;
  transition:all .4s cubic-bezier(.16,1,.3,1);
  border-left:3px solid var(--gold);
}
.toast.show { transform:translateY(0); opacity:1; }
.toast i { color:var(--gold); font-size:18px; }

/* PAGINATION */
.pagination { display:flex; justify-content:center; gap:8px; margin-top:50px; padding-bottom:40px; }
.page-btn {
  width:42px; height:42px; border:1px solid #ddd; background:var(--white);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all .3s; font-size:14px; color:var(--text);
  font-family:'Jost',sans-serif;
}
.page-btn:hover { border-color:var(--gold); color:var(--gold); }
.page-btn.active { background:var(--gold); border-color:var(--gold); color:var(--dark); font-weight:700; }
.page-ellipsis {
  min-width: 30px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  font-size: 13px;
}

/* RESPONSIVE */
@media(max-width:1100px) {
  .catalog-layout { grid-template-columns:1fr; }
  .mobile-filter-bar { display:flex; align-items:center; justify-content:space-between; gap:16px; padding:20px 20px 0; }
  .mobile-filter-btn { border:none; background:var(--dark); color:var(--white); padding:12px 16px; font-family:'Jost',sans-serif; font-size:12px; letter-spacing:1.5px; text-transform:uppercase; cursor:pointer; }
  .mobile-results { color:var(--muted); font-size:13px; }
  .sidebar-overlay { display:block; position:fixed; inset:0; background:rgba(0,0,0,.45); opacity:0; pointer-events:none; transition:opacity .3s; z-index:1800; }
  .sidebar-overlay.open { opacity:1; pointer-events:auto; }
  .sidebar { position:fixed; top:0; left:0; bottom:0; width:min(360px, 92vw); height:auto; z-index:1900; transform:translateX(-100%); transition:transform .35s cubic-bezier(.16,1,.3,1); border-right:none; box-shadow:0 20px 60px rgba(0,0,0,.15); }
  .sidebar.open { transform:translateX(0); }
  .sidebar-mobile-head { display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:24px; }
  .sidebar-close { border:none; background:transparent; color:var(--text); cursor:pointer; font-size:18px; }
  .products-grid { grid-template-columns:repeat(2,1fr); }
  .products-grid.list-view .product-img-wrap { width:240px; }
  .toolbar-filter-btn { display:inline-flex; align-items:center; gap:8px; }
}
@media(max-width:768px) {
  header { padding:16px max(20px, env(safe-area-inset-right, 0px)) 16px max(20px, env(safe-area-inset-left, 0px)); padding-top:max(16px, env(safe-area-inset-top, 0px)); }
  .logo { font-size:22px; letter-spacing:4px; }
  .header-right { gap:10px; }
  .cart-btn { width:40px; height:40px; }
  .nav-links { display:none; }
  .interest-chip { display:none; }
  .page-hero { padding:110px max(24px, env(safe-area-inset-right, 0px)) 40px max(24px, env(safe-area-inset-left, 0px)); }
  .page-title { font-size:44px; line-height:1.05; }
  .page-subtitle { margin-top:8px; font-size:14px; }
  .breadcrumb { display:none; }
  .catalog-main { padding:14px 12px 20px; }
  .mobile-filter-bar {
    position: sticky;
    top: calc(72px + env(safe-area-inset-top, 0px));
    z-index: 25;
    background: rgba(250,247,241,.96);
    backdrop-filter: blur(8px);
    margin: 0 -12px 10px;
    padding: 10px 12px;
    border-bottom: 1px solid rgba(0,0,0,.06);
  }
  .mobile-filter-btn { padding:10px 12px; font-size:11px; font-weight:500; }
  .mobile-results { font-size:12px; }
  .toolbar { align-items:stretch; }
  .results-info { font-size:12px; display:none; }
  .toolbar-right { justify-content:space-between; width:100%; flex-wrap:wrap; gap:8px; }
  .toolbar-interest-link { display:none; }
  .view-btns { display:none; }
  .sort-select { flex:1; min-width:0; width:100%; }
  .toolbar-filter-btn { width:100%; justify-content:center; }
  .active-filters { display:flex; margin-bottom:16px; gap:6px; }
  .products-grid { grid-template-columns:1fr; gap:10px; }
  .products-grid.list-view .product-card { display:block; }
  .products-grid.list-view .product-img-wrap { width:auto; aspect-ratio:4/5; }
  .product-img-wrap { aspect-ratio:4/5; }
  .quick-view { display:none; }
  .product-info { padding:16px; }
  .product-name { font-size:22px; }
  .product-size { margin-bottom:8px; font-size:11px; }
  .product-actions { display:flex; gap:16px; margin-top:14px; }
  .product-actions .product-link:last-child { display:none; }
  .product-actions .product-link { font-size: 11px; }
  .product-stock { font-size: 11px; }
  .product-footer { align-items: center; }
  .add-to-cart { width: 42px; height: 42px; }
  .old-price { font-size:11px; margin-left:4px; }
  .cart-drawer { width:100%; padding-bottom:env(safe-area-inset-bottom, 0px); }
  .cart-header { padding:20px 18px 16px; }
  .cart-stepper { padding: 0 18px 12px; gap: 6px; }
  .cart-step { font-size: 10px; letter-spacing: 0.6px; padding: 6px 4px; }
  .cart-items { padding:14px 18px; }
  .cart-footer { padding:16px 18px; }
  .sidebar { width:min(330px, 88vw); padding:26px 20px; }
  .modal-grid { grid-template-columns:1fr; }
  .order-modal { padding: 26px 20px; }
  .order-summary-box,
  .order-form-grid { grid-template-columns: 1fr; }
  .order-modal-actions { flex-direction: column; }
  .pagination { margin-top: 26px; padding-bottom: 18px; }
  .page-btn { width: 36px; height: 36px; font-size: 12px; }
  .page-ellipsis { height: 36px; min-width: 24px; }
}

@media(max-width:520px) {
  .page-hero { padding:96px max(16px, env(safe-area-inset-right, 0px)) 30px max(16px, env(safe-area-inset-left, 0px)); }
  .page-title { font-size: 36px; }
  .page-subtitle { font-size: 13px; }
  .catalog-main { padding: 12px 8px 16px; }
  .mobile-filter-bar {
    top: calc(64px + env(safe-area-inset-top, 0px));
    margin: 0 -8px 8px;
    padding: 8px;
  }
  .product-info { padding: 14px; }
  .product-name { font-size: 20px; }
  .product-size { font-size: 10px; }
  .product-actions { margin-top: 10px; }
  .product-actions .product-link { font-size: 10px; }
  .cart-header h2 { font-size: 20px; }
  .cart-header span { font-size: 12px; }
  .cart-item { grid-template-columns: 76px 1fr auto; gap: 10px; }
  .cart-item-img { width: 76px; height: 76px; }
  .qty-btn { width: 30px; height: 30px; }
  .checkout-btn, .continue-btn { min-height: 46px; font-size: 13px; }
}
