    :root {
      --gold: #C9A84C;
      --gold-light: #E8D5A3;
      --gold-dark: #8B6914;
      --cream: #F7F2EA;
      --dark: #0D0A05;
      --charcoal: #1A1208;
      --wine: #5C1A1A;
      --text-muted: #8C7B5E;
      --border: rgba(201, 168, 76, 0.2);
    }

    * {
      margin: 0;
      padding: 0;
      box-sizing: border-box;
    }

    html {
      scroll-behavior: smooth;
    }

    body {
      background: var(--dark);
      color: var(--cream);
      font-family: 'Raleway', sans-serif;
      font-weight: 300;
      overflow-x: hidden;
    }

    /* NAV */
    nav {
      position: sticky;
      top: 0;
      z-index: 100;
      background: rgba(13, 10, 5, 0.97);
      border-bottom: 1px solid var(--border);
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 18px 60px;
      backdrop-filter: blur(12px);
    }

    .nav-logo {
      font-family: 'Cinzel', serif;
      font-size: 20px;
      letter-spacing: 0.15em;
      color: var(--gold);
      text-decoration: none;
    }

    .nav-logo span {
      color: var(--cream);
    }

    .nav-links {
      display: flex;
      gap: 36px;
      list-style: none;
    }

    .nav-links a {
      font-size: 11px;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: rgba(247, 242, 234, 0.6);
      text-decoration: none;
      transition: color 0.3s;
    }

    .nav-links a:hover {
      color: var(--gold);
    }

    .nav-cart {
      display: flex;
      align-items: center;
      gap: 10px;
      font-family: 'Raleway';
      font-size: 11px;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: var(--gold);
      cursor: pointer;
      background: none;
      border: 1px solid var(--border);
      padding: 9px 20px;
      transition: background 0.3s;
    }

    .nav-cart:hover {
      background: rgba(201, 168, 76, 0.1);
    }

    .cart-count {
      background: var(--gold);
      color: var(--dark);
      width: 20px;
      height: 20px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 11px;
      font-weight: 500;
    }

    /* BOUTIQUE HERO */
    .boutique-hero {
      position: relative;
      padding: 100px 60px 80px;
      text-align: center;
      overflow: hidden;
    }

    .boutique-hero::before {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(ellipse at 50% 0%, rgba(201, 168, 76, 0.07) 0%, transparent 65%);
      pointer-events: none;
    }

    .boutique-hero-eyebrow {
      font-size: 10px;
      letter-spacing: 0.45em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 20px;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 14px;
    }

    .boutique-hero-eyebrow::before,
    .boutique-hero-eyebrow::after {
      content: '◆';
      font-size: 6px;
    }

    .boutique-hero h1 {
      font-family: 'Cinzel', serif;
      font-size: clamp(40px, 5vw, 72px);
      font-weight: 400;
      letter-spacing: 0.04em;
      margin-bottom: 20px;
      line-height: 1.1;
    }

    .boutique-hero h1 em {
      font-family: 'Cormorant Garamond', serif;
      font-style: italic;
      font-weight: 300;
      color: var(--gold);
    }

    .boutique-hero p {
      font-size: 14px;
      color: rgba(247, 242, 234, 0.5);
      max-width: 540px;
      margin: 0 auto 50px;
      line-height: 2;
    }

    .boutique-divider {
      width: 1px;
      height: 60px;
      background: linear-gradient(to bottom, var(--gold), transparent);
      margin: 0 auto;
    }

    /* FILTERS */
    .filters {
      display: flex;
      justify-content: center;
      gap: 4px;
      padding: 0 60px 60px;
      flex-wrap: wrap;
    }

    .filter-btn {
      font-family: 'Raleway';
      font-size: 10px;
      letter-spacing: 0.25em;
      text-transform: uppercase;
      color: rgba(247, 242, 234, 0.5);
      background: none;
      border: 1px solid transparent;
      padding: 10px 24px;
      cursor: pointer;
      transition: all 0.3s;
    }

    .filter-btn:hover,
    .filter-btn.active {
      color: var(--gold);
      border-color: var(--border);
    }

    .filter-btn.active {
      background: rgba(201, 168, 76, 0.06);
    }

    /* PRODUCTS SECTION — pile verticale de featured cards */
    .products-section {
      padding: 0 60px 120px;
      display: flex;
      flex-direction: column;
      gap: 3px;
    }

    /* FEATURED PRODUCT CARD (format unifié) */
    .featured-product {
      background: var(--charcoal);
      display: grid;
      grid-template-columns: 1fr 1fr;
      overflow: hidden;
      transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
      cursor: default;
    }

    .featured-product:hover {
      transform: translateY(-3px);
    }

    /* Alternance gauche/droite */
    .featured-product.reverse {
      direction: rtl;
    }

    .featured-product.reverse>* {
      direction: ltr;
    }

    .featured-product-img {
      position: relative;
      min-height: 480px;
      background: var(--dark);
      display: flex;
      align-items: center;
      justify-content: center;
      overflow: hidden;
    }

    .featured-product-img::before {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(ellipse at 50% 90%, rgba(92, 26, 26, 0.25) 0%, transparent 65%);
    }

    .featured-product-img.blue-tint::before {
      background: radial-gradient(ellipse at 50% 90%, rgba(26, 50, 92, 0.2) 0%, transparent 65%);
    }

    .featured-product-img.green-tint::before {
      background: radial-gradient(ellipse at 50% 90%, rgba(26, 92, 26, 0.15) 0%, transparent 65%);
    }

    .featured-product-img img {
      max-height: 380px;
      max-width: 75%;
      object-fit: contain;
      filter: drop-shadow(0 40px 60px rgba(0, 0, 0, 0.8));
      position: relative;
      z-index: 1;
      transition: transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .featured-product:hover .featured-product-img img {
      transform: translateY(-10px) scale(1.03);
    }

    /* Badges */
    .product-badge-wrap {
      position: absolute;
      top: 24px;
      left: 24px;
      display: flex;
      flex-direction: column;
      gap: 6px;
      z-index: 3;
    }

    .badge {
      font-size: 9px;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      padding: 5px 12px;
      font-family: 'Raleway';
    }

    .badge-type {
      background: rgba(13, 10, 5, 0.85);
      color: var(--gold);
      border: 1px solid var(--border);
    }

    .badge-new {
      background: var(--gold);
      color: var(--dark);
    }

    .badge-limited {
      background: var(--wine);
      color: var(--cream);
    }

    .featured-product-body {
      padding: 56px 56px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      border-left: 1px solid var(--border);
    }

    .featured-product.reverse .featured-product-body {
      border-left: none;
      border-right: 1px solid var(--border);
    }

    .featured-label {
      font-size: 9px;
      letter-spacing: 0.4em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 24px;
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .featured-label::before {
      content: '';
      width: 28px;
      height: 1px;
      background: var(--gold);
    }

    .product-name {
      font-family: 'Cinzel', serif;
      font-size: 30px;
      font-weight: 400;
      letter-spacing: 0.06em;
      margin-bottom: 8px;
      color: var(--cream);
      line-height: 1.2;
    }

    .product-vintage {
      font-family: 'Cormorant Garamond', serif;
      font-size: 15px;
      font-style: italic;
      color: var(--text-muted);
      margin-bottom: 20px;
    }

    .product-rating {
      display: flex;
      gap: 3px;
      margin-bottom: 20px;
    }

    .star {
      color: var(--gold);
      font-size: 11px;
    }

    .star.dim {
      opacity: 0.3;
    }

    .product-desc {
      font-size: 13px;
      line-height: 1.9;
      color: rgba(247, 242, 234, 0.5);
      margin-bottom: 28px;
    }

    .tasting-notes {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 12px;
      margin-bottom: 36px;
    }

    .tasting-note {
      padding: 14px 16px;
      background: rgba(201, 168, 76, 0.04);
      border: 1px solid var(--border);
    }

    .tasting-note-label {
      font-size: 9px;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: var(--text-muted);
      margin-bottom: 5px;
    }

    .tasting-note-value {
      font-family: 'Cormorant Garamond', serif;
      font-size: 13px;
      color: var(--gold-light);
      font-style: italic;
    }

    .featured-footer {
      display: flex;
      align-items: center;
      gap: 20px;
      padding-top: 28px;
      border-top: 1px solid var(--border);
    }

    .featured-price {
      font-family: 'Cormorant Garamond', serif;
      font-size: 36px;
      color: var(--gold);
      white-space: nowrap;
    }

    .featured-price span {
      font-size: 13px;
      color: var(--text-muted);
      font-family: 'Raleway';
      letter-spacing: 0.05em;
    }

    .btn-add-featured {
      flex: 1;
      font-family: 'Raleway';
      font-size: 11px;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      background: var(--gold);
      color: var(--dark);
      border: none;
      padding: 15px 28px;
      cursor: pointer;
      transition: background 0.3s, transform 0.3s;
    }

    .btn-add-featured:hover {
      background: var(--gold-light);
      transform: translateY(-2px);
    }

    /* FOOD SECTION */
    .food-section {
      padding: 80px 60px 120px;
    }

    .food-header {
      text-align: center;
      margin-bottom: 60px;
    }

    .food-header .section-eyebrow {
      font-size: 10px;
      letter-spacing: 0.4em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 20px;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 14px;
    }

    .food-header .section-eyebrow::before,
    .food-header .section-eyebrow::after {
      content: '◆';
      font-size: 6px;
    }

    .food-header h2 {
      font-family: 'Cinzel', serif;
      font-size: clamp(28px, 3vw, 44px);
      font-weight: 400;
    }

    /* Food cards — même format featured */
    .food-cards {
      display: flex;
      flex-direction: column;
      gap: 3px;
    }

    .food-featured {
      background: var(--charcoal);
      display: grid;
      grid-template-columns: 1fr 1fr;
      overflow: hidden;
      transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .food-featured:hover {
      transform: translateY(-3px);
    }

    .food-featured.reverse {
      direction: rtl;
    }

    .food-featured.reverse>* {
      direction: ltr;
    }

    .food-featured-img {
      min-height: 420px;
      background: var(--dark);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 100px;
      position: relative;
      overflow: hidden;
    }

    .food-featured-img::before {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(ellipse at 50% 80%, rgba(201, 168, 76, 0.06) 0%, transparent 65%);
    }

    .food-featured-body {
      padding: 56px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      border-left: 1px solid var(--border);
    }

    .food-featured.reverse .food-featured-body {
      border-left: none;
      border-right: 1px solid var(--border);
    }

    .food-card-type {
      font-size: 9px;
      letter-spacing: 0.4em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 24px;
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .food-card-type::before {
      content: '';
      width: 28px;
      height: 1px;
      background: var(--gold);
    }

    .food-card-name {
      font-family: 'Cinzel', serif;
      font-size: 28px;
      font-weight: 400;
      margin-bottom: 16px;
      color: var(--cream);
      line-height: 1.2;
    }

    .food-card-desc {
      font-size: 13px;
      line-height: 1.9;
      color: rgba(247, 242, 234, 0.45);
      margin-bottom: 36px;
    }

    .food-featured-footer {
      display: flex;
      align-items: center;
      gap: 20px;
      padding-top: 28px;
      border-top: 1px solid var(--border);
    }

    .food-price {
      font-family: 'Cormorant Garamond', serif;
      font-size: 36px;
      color: var(--gold);
    }

    .food-add {
      flex: 1;
      font-family: 'Raleway';
      font-size: 11px;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      background: var(--gold);
      color: var(--dark);
      border: none;
      padding: 15px 28px;
      cursor: pointer;
      transition: background 0.3s, transform 0.3s;
    }

    .food-add:hover {
      background: var(--gold-light);
      transform: translateY(-2px);
    }

    /* CART SIDEBAR */
    .cart-overlay {
      position: fixed;
      inset: 0;
      background: rgba(0, 0, 0, 0.6);
      z-index: 200;
      opacity: 0;
      pointer-events: none;
      transition: opacity 0.4s;
      backdrop-filter: blur(4px);
    }

    .cart-overlay.open {
      opacity: 1;
      pointer-events: all;
    }

    .cart-sidebar {
      position: fixed;
      right: 0;
      top: 0;
      bottom: 0;
      width: 440px;
      background: var(--charcoal);
      border-left: 1px solid var(--border);
      transform: translateX(100%);
      transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
      display: flex;
      flex-direction: column;
      z-index: 201;
      overflow: hidden;
    }

    .cart-sidebar.open {
      transform: translateX(0);
    }

    .cart-header {
      padding: 32px 36px 24px;
      border-bottom: 1px solid var(--border);
      display: flex;
      justify-content: space-between;
      align-items: center;
    }

    .cart-title {
      font-family: 'Cinzel', serif;
      font-size: 18px;
      letter-spacing: 0.1em;
    }

    .cart-close {
      background: none;
      border: none;
      color: var(--cream);
      font-size: 24px;
      cursor: pointer;
      opacity: 0.5;
      transition: opacity 0.3s;
    }

    .cart-close:hover {
      opacity: 1;
    }

    .cart-items {
      flex: 1;
      overflow-y: auto;
      padding: 24px 36px;
    }

    .cart-empty {
      text-align: center;
      padding: 60px 0;
      color: rgba(247, 242, 234, 0.3);
      font-size: 13px;
      letter-spacing: 0.1em;
    }

    .cart-empty-icon {
      font-size: 48px;
      margin-bottom: 16px;
      opacity: 0.3;
      display: block;
    }

    .cart-item {
      display: grid;
      grid-template-columns: 70px 1fr auto;
      gap: 16px;
      align-items: center;
      padding: 20px 0;
      border-bottom: 1px solid var(--border);
    }

    .cart-item-img {
      height: 70px;
      background: var(--dark);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 28px;
    }

    .cart-item-name {
      font-family: 'Cinzel', serif;
      font-size: 13px;
      letter-spacing: 0.05em;
      margin-bottom: 6px;
    }

    .cart-item-price {
      font-family: 'Cormorant Garamond', serif;
      font-size: 18px;
      color: var(--gold);
    }

    .cart-item-qty {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-top: 8px;
    }

    .qty-btn {
      background: none;
      border: 1px solid var(--border);
      color: var(--cream);
      width: 24px;
      height: 24px;
      cursor: pointer;
      font-size: 14px;
      transition: border-color 0.3s;
    }

    .qty-btn:hover {
      border-color: var(--gold);
    }

    .qty-val {
      font-size: 13px;
      min-width: 20px;
      text-align: center;
    }

    .cart-remove {
      background: none;
      border: none;
      color: rgba(247, 242, 234, 0.3);
      cursor: pointer;
      font-size: 18px;
      padding: 4px;
      transition: color 0.3s;
      align-self: start;
      margin-top: 4px;
    }

    .cart-remove:hover {
      color: #c0392b;
    }

    .cart-footer {
      padding: 24px 36px 36px;
      border-top: 1px solid var(--border);
    }

    .cart-subtotal {
      display: flex;
      justify-content: space-between;
      margin-bottom: 10px;
      font-size: 12px;
      color: rgba(247, 242, 234, 0.5);
      letter-spacing: 0.1em;
    }

    .cart-total {
      display: flex;
      justify-content: space-between;
      align-items: baseline;
      margin-bottom: 28px;
      padding-top: 14px;
      border-top: 1px solid var(--border);
    }

    .cart-total-label {
      font-family: 'Cinzel', serif;
      font-size: 13px;
      letter-spacing: 0.15em;
    }

    .cart-total-amount {
      font-family: 'Cormorant Garamond', serif;
      font-size: 30px;
      color: var(--gold);
    }

    .btn-checkout {
      width: 100%;
      font-family: 'Raleway';
      font-size: 11px;
      letter-spacing: 0.3em;
      text-transform: uppercase;
      background: var(--gold);
      color: var(--dark);
      border: none;
      padding: 18px;
      cursor: pointer;
      transition: background 0.3s;
      margin-bottom: 12px;
    }

    .btn-checkout:hover {
      background: var(--gold-light);
    }

    .btn-continue {
      width: 100%;
      font-family: 'Raleway';
      font-size: 11px;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      background: none;
      border: 1px solid var(--border);
      color: rgba(247, 242, 234, 0.5);
      padding: 14px;
      cursor: pointer;
      transition: border-color 0.3s, color 0.3s;
    }

    .btn-continue:hover {
      border-color: var(--gold);
      color: var(--gold);
    }

    /* ORDER MODAL */
    .modal-overlay {
      position: fixed;
      inset: 0;
      background: rgba(0, 0, 0, 0.85);
      z-index: 300;
      display: flex;
      align-items: center;
      justify-content: center;
      opacity: 0;
      pointer-events: none;
      transition: opacity 0.4s;
      backdrop-filter: blur(8px);
    }

    .modal-overlay.open {
      opacity: 1;
      pointer-events: all;
    }

    .modal {
      background: var(--charcoal);
      border: 1px solid var(--border);
      width: 90%;
      max-width: 560px;
      max-height: 90vh;
      overflow-y: auto;
      padding: 56px 52px;
      transform: scale(0.94);
      transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .modal-overlay.open .modal {
      transform: scale(1);
    }

    .modal-eyebrow {
      font-size: 9px;
      letter-spacing: 0.4em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 20px;
    }

    .modal-title {
      font-family: 'Cinzel', serif;
      font-size: 28px;
      font-weight: 400;
      margin-bottom: 36px;
      letter-spacing: 0.05em;
    }

    .modal-title em {
      font-family: 'Cormorant Garamond', serif;
      font-style: italic;
      color: var(--gold);
    }

    .form-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
      margin-bottom: 16px;
    }

    .form-group {
      display: flex;
      flex-direction: column;
      gap: 8px;
      margin-bottom: 16px;
    }

    .form-group label {
      font-size: 10px;
      letter-spacing: 0.25em;
      text-transform: uppercase;
      color: var(--text-muted);
    }

    .form-group input,
    .form-group select,
    .form-group textarea {
      background: var(--dark);
      border: 1px solid var(--border);
      color: var(--cream);
      padding: 14px 16px;
      font-family: 'Raleway';
      font-size: 13px;
      outline: none;
      transition: border-color 0.3s;
      width: 100%;
    }

    .form-group input:focus,
    .form-group select:focus,
    .form-group textarea:focus {
      border-color: var(--gold);
    }

    .form-group select {
      appearance: none;
      cursor: pointer;
    }

    .form-group textarea {
      resize: vertical;
      min-height: 80px;
    }

    .modal-order-summary {
      background: var(--dark);
      border: 1px solid var(--border);
      padding: 24px;
      margin-bottom: 28px;
    }

    .order-sum-title {
      font-size: 10px;
      letter-spacing: 0.3em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 16px;
    }

    .order-sum-item {
      display: flex;
      justify-content: space-between;
      font-size: 12px;
      color: rgba(247, 242, 234, 0.6);
      padding: 8px 0;
      border-bottom: 1px solid var(--border);
    }

    .order-sum-item:last-child {
      border: none;
    }

    .order-sum-total {
      display: flex;
      justify-content: space-between;
      font-family: 'Cormorant Garamond', serif;
      font-size: 22px;
      color: var(--gold);
      margin-top: 16px;
      padding-top: 16px;
      border-top: 1px solid var(--border);
    }

    .modal-actions {
      display: flex;
      gap: 16px;
    }

    .btn-order {
      flex: 1;
      font-family: 'Raleway';
      font-size: 11px;
      letter-spacing: 0.25em;
      text-transform: uppercase;
      background: var(--gold);
      color: var(--dark);
      border: none;
      padding: 16px;
      cursor: pointer;
      transition: background 0.3s;
    }

    .btn-order:hover {
      background: var(--gold-light);
    }

    .btn-modal-cancel {
      font-family: 'Raleway';
      font-size: 11px;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      background: none;
      border: 1px solid var(--border);
      color: rgba(247, 242, 234, 0.5);
      padding: 16px 24px;
      cursor: pointer;
      transition: all 0.3s;
    }

    .btn-modal-cancel:hover {
      border-color: var(--gold);
      color: var(--gold);
    }

    /* SUCCESS */
    .success-modal {
      text-align: center;
    }

    .success-icon {
      font-size: 56px;
      margin-bottom: 24px;
      display: block;
    }

    .success-title {
      font-family: 'Cinzel', serif;
      font-size: 26px;
      margin-bottom: 12px;
      color: var(--gold);
    }

    .success-text {
      font-size: 13px;
      line-height: 2;
      color: rgba(247, 242, 234, 0.6);
      margin-bottom: 32px;
    }

    /* FOOTER */
    footer {
      background: #060402;
      padding: 40px 60px;
      border-top: 1px solid var(--border);
      display: flex;
      justify-content: space-between;
      align-items: center;
    }

    .footer-logo-small {
      font-family: 'Cinzel', serif;
      font-size: 18px;
      color: var(--gold);
      letter-spacing: 0.1em;
    }

    .footer-copy {
      font-size: 11px;
      color: rgba(247, 242, 234, 0.25);
      letter-spacing: 0.1em;
    }

    /* REVEAL */
    .reveal {
      opacity: 0;
      transform: translateY(24px);
      transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1), transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .reveal.visible {
      opacity: 1;
      transform: none;
    }

    /* Toast */
    .toast {
      position: fixed;
      bottom: 20px;
      left: 50%;
      transform: translateX(-50%) translateY(80px);
      background: var(--charcoal);
      border: 1px solid var(--gold);
      border-radius: 0;
      padding: 16px 32px;
      font-size: 13px;
      color: var(--cream);
      z-index: 500;
      transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
      white-space: nowrap;
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .toast.show {
      transform: translateX(-50%) translateY(0);
    }

    .toast-icon {
      color: var(--gold);
    }

    /* MOBILE MENU */
    .menu-toggle {
      display: none;
      width: 52px;
      height: 52px;
      border: 1px solid rgba(201, 168, 76, 0.25);
      background: rgba(13, 10, 5, 0.85);
      backdrop-filter: blur(10px);
      cursor: pointer;
      position: relative;
      z-index: 1001;
      transition: border-color 0.3s;
    }

    .menu-toggle:hover {
      border-color: var(--gold);
    }

    .menu-toggle span {
      position: absolute;
      left: 50%;
      width: 22px;
      height: 1px;
      background: var(--gold);
      transition: 0.4s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .menu-toggle span:first-child {
      top: 22px;
      transform: translateX(-50%);
    }

    .menu-toggle span:last-child {
      top: 30px;
      transform: translateX(-50%);
    }

    .menu-toggle.active span:first-child {
      transform: translateX(-50%) rotate(45deg);
      top: 26px;
    }

    .menu-toggle.active span:last-child {
      transform: translateX(-50%) rotate(-45deg);
      top: 26px;
    }

    .mobile-menu {
      position: fixed;
      inset: 0;
      background: linear-gradient(rgba(13, 10, 5, 0.97), rgba(13, 10, 5, 0.98)), radial-gradient(circle at top right, rgba(201, 168, 76, 0.08), transparent 40%);
      z-index: 999;
      display: flex;
      align-items: center;
      justify-content: center;
      opacity: 0;
      visibility: hidden;
      transition: 0.5s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .mobile-menu.active {
      opacity: 1;
      visibility: visible;
    }

    .mobile-menu-inner {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 26px;
      transform: translateY(30px);
      transition: 0.6s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .mobile-menu.active .mobile-menu-inner {
      transform: translateY(0);
    }

    .mobile-menu a {
      font-family: 'Cinzel', serif;
      font-size: clamp(28px, 7vw, 42px);
      letter-spacing: 0.08em;
      color: var(--cream);
      text-decoration: none;
      transition: color 0.3s, transform 0.3s;
    }

    .mobile-menu a:hover {
      color: var(--gold);
      transform: translateX(4px);
    }

    .mobile-menu-footer {
      margin-top: 40px;
      font-size: 11px;
      letter-spacing: 0.25em;
      text-transform: uppercase;
      color: rgba(247, 242, 234, 0.35);
    }

    /* ── RESPONSIVE ── */
    @media (max-width: 1100px) {
      nav {
        padding: 20px 30px;
      }

      .nav-links {
        gap: 22px;
      }

      .boutique-hero,
      .filters,
      .products-section,
      .food-section,
      footer {
        padding-left: 30px;
        padding-right: 30px;
      }

      .featured-product,
      .food-featured {
        grid-template-columns: 1fr;
        direction: ltr !important;
      }

      .featured-product-img,
      .food-featured-img {
        min-height: 380px;
      }

      .featured-product-body,
      .food-featured-body {
        border-left: none !important;
        border-right: none !important;
        border-top: 1px solid var(--border);
      }
    }

    @media (max-width: 768px) {
      nav {
        padding: 18px 20px;
      }

      .nav-links,
      .nav-cart {
        display: none;
      }

      .menu-toggle {
        display: block;
      }

      .boutique-hero {
        padding: 80px 20px 60px;
      }

      .boutique-hero h1 {
        font-size: clamp(36px, 10vw, 60px);
      }

      .filters {
        padding: 0 20px 40px;
        gap: 8px;
      }

      .filter-btn {
        font-size: 9px;
        padding: 9px 16px;
      }

      .products-section,
      .food-section,
      footer {
        padding-left: 20px;
        padding-right: 20px;
      }

      .products-section {
        padding-bottom: 90px;
      }

      .food-section {
        padding: 60px 20px 90px;
      }

      .featured-product-img,
      .food-featured-img {
        min-height: 300px;
        font-size: 80px;
      }

      .featured-product-img img {
        max-height: 260px;
      }

      .featured-product-body,
      .food-featured-body {
        padding: 36px 24px;
      }

      .product-name,
      .food-card-name {
        font-size: 24px;
      }

      .tasting-notes {
        grid-template-columns: 1fr;
      }

      .featured-footer,
      .food-featured-footer {
        flex-direction: column;
        align-items: stretch;
        gap: 16px;
      }

      .cart-sidebar {
        width: 100%;
        max-width: 100%;
      }

      .cart-header {
        padding: 24px 20px 20px;
      }

      .cart-items {
        padding: 20px;
      }

      .cart-item {
        grid-template-columns: 60px 1fr auto;
        gap: 12px;
        padding: 16px 0;
      }

      .cart-footer {
        padding: 20px;
      }

      .cart-total-amount {
        font-size: 26px;
      }

      .modal {
        width: 95%;
        padding: 40px 24px;
        max-height: 95vh;
      }

      .modal-title {
        font-size: 24px;
      }

      .form-row {
        grid-template-columns: 1fr;
      }

      .modal-actions {
        flex-direction: column;
      }

      .btn-modal-cancel {
        width: 100%;
      }

      footer {
        flex-direction: column;
        gap: 20px;
        text-align: center;
        padding: 30px 20px;
      }

      .toast {
        bottom: 20px;
        width: calc(100% - 40px);
        max-width: 340px;
        padding: 14px 20px;
        font-size: 12px;
      }
    }

    @media (max-width: 480px) {
      .boutique-hero h1 {
        font-size: 34px;
      }

      .featured-product-img {
        min-height: 260px;
      }

      .featured-product-img img {
        max-height: 200px;
      }

      .product-name,
      .food-card-name {
        font-size: 20px;
      }

      .featured-price,
      .food-price {
        font-size: 28px;
      }
    }