/* ─────────────────────────────────────────────────────────────────────────────
   DESIGN SYSTEM — Blanc · Ambré · Noir
   Police : Cormorant Garamond (titres) + Jost (corps)
   ───────────────────────────────────────────────────────────────────────────── */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Jost:wght@300;400;500&display=swap');

/* ── Variables ───────────────────────────────────────────────────────────────── */
:root {
  --blanc:      #F8F7F4;
  --blanc-pur:  #FFFFFF;
  --noir:       #0A0A0A;
  --ambre:      #A97B2A;
  --ambre-c:    #C4983F;
  --ambre-p:    #E8D5A0;
  --gris-f:     #1E1E1E;
  --gris-m:     #4A4A4A;
  --gris-c:     #D8D8D3;
  --gris-u:     #F0EFEB;

  --font-serif: 'Cormorant Garamond', Georgia, serif;
  --font-sans:  'Jost', system-ui, sans-serif;

  --border:     1px solid var(--gris-c);
  --radius:     0px;
  --transition: 0.25s ease;

  --max-w:      1160px;
  --pad-h:      2rem;
}

/* ── Reset ───────────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 16px; scroll-behavior: smooth; }

body {
  background:  var(--blanc);
  color:       var(--noir);
  font-family: var(--font-sans);
  font-weight: 400;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

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

button {
  cursor:      pointer;
  font-family: var(--font-sans);
  font-weight: 400;
  border:      none;
  background:  none;
  padding:     0;
}

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

/* ── Typographie ─────────────────────────────────────────────────────────────── */
h1, h2, h3, h4 {
  font-family:  var(--font-serif);
  font-weight:  400;
  line-height:  1.15;
  letter-spacing: 0.01em;
}

h1 { font-size: clamp(3rem, 8vw, 7rem); }
h2 { font-size: clamp(1.8rem, 3.5vw, 3rem); }
h3 { font-size: clamp(1.3rem, 2.5vw, 1.8rem); }

p  { font-size: 0.97rem; color: var(--gris-m); line-height: 1.8;  font-weight: 400; }

.label {
  font-family:    var(--font-sans);
  font-size:      0.65rem;
  font-weight:    400;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color:          var(--gris-m);
}

/* ── Layout ──────────────────────────────────────────────────────────────────── */
.container {
  max-width:  var(--max-w);
  margin:     0 auto;
  padding:    0 var(--pad-h);
}

section { padding: 6rem 0; }

/* ── Header ──────────────────────────────────────────────────────────────────── */
header {
  position:   sticky;
  top:        0;
  z-index:    100;
  background: var(--blanc);
  border-bottom: var(--border);
}

.header-inner {
  max-width:      var(--max-w);
  margin:         0 auto;
  padding:        0 var(--pad-h);
  height:         64px;
  display:        flex;
  align-items:    center;
  justify-content: space-between;
}

.brand-name {
  font-family:    var(--font-serif);
  font-size:      1.4rem;
  font-weight:    300;
  letter-spacing: 0.08em;
  color:          var(--noir);
}

.header-nav {
  display:     flex;
  align-items: center;
  gap:         2rem;
}

.nav-link {
  font-size:      0.75rem;
  font-weight:    400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color:          var(--gris-m);
  transition:     color var(--transition);
}
.nav-link:hover { color: var(--noir); }

.lang-btn {
  font-size:      0.7rem;
  font-weight:    400;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color:          var(--gris-m);
  border-bottom:  1px solid transparent;
  padding-bottom: 1px;
  transition:     all var(--transition);
}
.lang-btn:hover { color: var(--noir); border-color: var(--noir); }

.cart-btn {
  display:     flex;
  align-items: center;
  gap:         0.5rem;
  position:    relative;
}

.cart-icon {
  font-size: 1.1rem;
  color:     var(--noir);
}

#cart-count {
  display:         flex;
  align-items:     center;
  justify-content: center;
  width:           18px;
  height:          18px;
  background:      var(--noir);
  color:           var(--blanc);
  font-size:       0.6rem;
  font-weight:     400;
  border-radius:   50%;
}

/* ── Hero ────────────────────────────────────────────────────────────────────── */
.hero {
  padding:     10rem 0 8rem;
  text-align:  center;
  border-bottom: var(--border);
}

.hero-eyebrow {
  display:        block;
  font-size:      0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color:          var(--ambre);
  margin-bottom:  1.5rem;
}

.hero h1 {
  color:         var(--noir);
  margin-bottom: 1.5rem;
}

.hero-tagline {
  font-size:   1rem;
  color:       var(--gris-m);
  font-weight: 400;
  max-width:   420px;
  margin:      0 auto 0.5rem;
}

.hero-sub {
  font-family:    var(--font-serif);
  font-style:     italic;
  font-size:      1.1rem;
  color:          var(--ambre);
  margin-top:     0.5rem;
}

/* ── Boutique ────────────────────────────────────────────────────────────────── */
.boutique { border-bottom: var(--border); }

.boutique-header {
  display:         flex;
  align-items:     baseline;
  justify-content: space-between;
  margin-bottom:   4rem;
  padding-bottom:  1.5rem;
  border-bottom:   var(--border);
}

.products-grid {
  display:               grid;
  grid-template-columns: repeat(2, 1fr);
  gap:                   1px;
  background:            var(--gris-c);
  border:                var(--border);
}

/* ── Carte produit ───────────────────────────────────────────────────────────── */
.product-card {
  background:  var(--blanc);
  padding:     2.5rem;
  display:     flex;
  flex-direction: column;
  gap:         1.5rem;
  transition:  background var(--transition);
}
.product-card:hover { background: var(--gris-u); }

.product-image {
  width:           100%;
  aspect-ratio:    4/3;
  background:      var(--gris-u);
  border:          var(--border);
  display:         flex;
  align-items:     center;
  justify-content: center;
  overflow:        hidden;
  position:        relative;
}

.product-image-placeholder {
  width:      60px;
  height:     60px;
  border:     1px solid var(--ambre-p);
  border-radius: 50%;
  position:   relative;
}
.product-image-placeholder::after {
  content:     '';
  position:    absolute;
  inset:       8px;
  border:      1px solid var(--ambre-c);
  border-radius: 50%;
}

.product-image img {
  width:      100%;
  height:     100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}
.product-card:hover .product-image img { transform: scale(1.03); }

.product-info { display: flex; flex-direction: column; gap: 0.75rem; flex: 1; }

.product-name {
  font-family: var(--font-serif);
  font-size:   1.6rem;
  font-weight: 300;
  color:       var(--noir);
}

.product-subtitle {
  font-size:      0.65rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color:          var(--ambre);
}

.product-notes {
  font-size:   0.85rem;
  color:       var(--gris-m);
  font-style:  italic;
  font-family: var(--font-serif);
  font-weight: 400;
}

.product-description {
  font-size:   0.92rem;
  color:       var(--gris-m);
  line-height: 1.75;
  font-weight: 400;
  flex:        1;
}

.product-footer {
  display:     flex;
  align-items: center;
  justify-content: space-between;
  margin-top:  0.5rem;
  padding-top: 1.25rem;
  border-top:  var(--border);
}

.product-price {
  font-family:    var(--font-serif);
  font-size:      1.3rem;
  color:          var(--noir);
}

.product-price-sub {
  display:     block;
  font-size:   0.65rem;
  color:       var(--gris-m);
  letter-spacing: 0.08em;
  font-family: var(--font-sans);
  font-weight: 300;
}

.btn-add {
  font-size:      0.7rem;
  font-weight:    400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color:          var(--blanc);
  background:     var(--noir);
  padding:        0.65rem 1.25rem;
  border:         1px solid var(--noir);
  transition:     all var(--transition);
}
.btn-add:hover {
  background: var(--ambre);
  border-color: var(--ambre);
}

/* ── Garanties ───────────────────────────────────────────────────────────────── */
.garanties { background: var(--gris-u); border-bottom: var(--border); }

.garanties-titre {
  text-align:    center;
  margin-bottom: 4rem;
}

.garanties-grid {
  display:               grid;
  grid-template-columns: repeat(3, 1fr);
  gap:                   3rem;
}

.garantie-item { text-align: center; }

.garantie-num {
  font-family:    var(--font-serif);
  font-size:      3rem;
  color:          var(--ambre-p);
  display:        block;
  margin-bottom:  0.5rem;
}

.garantie-titre-item {
  font-family:    var(--font-serif);
  font-size:      1.25rem;
  color:          var(--noir);
  margin-bottom:  0.75rem;
}

/* ── À propos ────────────────────────────────────────────────────────────────── */
.apropos { border-bottom: var(--border); }

.apropos-inner {
  display:     grid;
  grid-template-columns: 1fr 1fr;
  gap:         6rem;
  align-items: start;
}

.apropos-texte { font-size: 1rem; line-height: 1.85; color: var(--gris-m); font-weight: 400; }

.apropos-img {
  aspect-ratio: 3/4;
  background:   var(--gris-u);
  border:       var(--border);
  display:      flex;
  align-items:  center;
  justify-content: center;
  color:        var(--gris-c);
  font-size:    0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/* ── Footer ──────────────────────────────────────────────────────────────────── */
footer {
  padding:       3rem 0;
  border-top:    var(--border);
}

.footer-inner {
  max-width:      var(--max-w);
  margin:         0 auto;
  padding:        0 var(--pad-h);
  display:        flex;
  align-items:    center;
  justify-content: space-between;
}

.footer-brand {
  font-family:    var(--font-serif);
  font-size:      1.1rem;
  font-weight:    300;
  letter-spacing: 0.08em;
}

.footer-info {
  text-align: center;
  font-size:  0.75rem;
  color:      var(--gris-m);
  line-height: 1.8;
}

.footer-contact {
  font-size:   0.75rem;
  color:       var(--gris-m);
  transition:  color var(--transition);
}
.footer-contact:hover { color: var(--noir); }

/* ── Panier ──────────────────────────────────────────────────────────────────── */
.cart-overlay {
  position:   fixed;
  inset:      0;
  background: rgba(10,10,10,0.4);
  z-index:    200;
  opacity:    0;
  pointer-events: none;
  transition: opacity var(--transition);
}
.cart-overlay.visible {
  opacity:        1;
  pointer-events: all;
}

.cart-panel {
  position:   fixed;
  top:        0;
  right:      0;
  bottom:     0;
  width:      min(420px, 100vw);
  background: var(--blanc-pur);
  z-index:    300;
  display:    flex;
  flex-direction: column;
  transform:  translateX(100%);
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  border-left: var(--border);
}
.cart-panel.open { transform: translateX(0); }

.cart-header {
  display:     flex;
  align-items: center;
  justify-content: space-between;
  padding:     1.5rem 2rem;
  border-bottom: var(--border);
  flex-shrink: 0;
}

.cart-title {
  font-family: var(--font-serif);
  font-size:   1.3rem;
  font-weight: 300;
}

.cart-close {
  font-size:  1.5rem;
  color:      var(--gris-m);
  line-height: 1;
  transition: color var(--transition);
}
.cart-close:hover { color: var(--noir); }

.cart-items {
  flex:       1;
  overflow-y: auto;
  padding:    1.5rem 2rem;
  display:    flex;
  flex-direction: column;
  gap:        1.25rem;
}

.cart-empty {
  font-size:  0.88rem;
  color:      var(--gris-m);
  text-align: center;
  margin-top: 2rem;
}

.cart-item {
  display:       flex;
  flex-direction: column;
  gap:           0.5rem;
  padding-bottom: 1.25rem;
  border-bottom: var(--border);
}

.cart-item-info {
  display:         flex;
  justify-content: space-between;
  align-items:     baseline;
}

.cart-item-name  { font-size: 0.9rem; color: var(--noir); font-weight: 400; }
.cart-item-price { font-family: var(--font-serif); font-size: 1rem; font-weight: 400; }

.cart-item-actions {
  display:     flex;
  align-items: center;
  gap:         0.75rem;
}

.qty-btn {
  width:       28px;
  height:      28px;
  border:      var(--border);
  font-size:   1rem;
  color:       var(--gris-m);
  display:     flex;
  align-items: center;
  justify-content: center;
  transition:  all var(--transition);
}
.qty-btn:hover { border-color: var(--noir); color: var(--noir); }

.qty-value { font-size: 0.88rem; min-width: 20px; text-align: center; }

.remove-btn {
  margin-left: auto;
  font-size:   1.1rem;
  color:       var(--gris-c);
  transition:  color var(--transition);
}
.remove-btn:hover { color: var(--noir); }

.cart-footer {
  padding:     1.5rem 2rem;
  border-top:  var(--border);
  flex-shrink: 0;
  display:     flex;
  flex-direction: column;
  gap:         1rem;
}

.cart-total-row {
  display:         flex;
  justify-content: space-between;
  align-items:     baseline;
}

.cart-total-label { font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gris-m); }
.cart-total-amount { font-family: var(--font-serif); font-size: 1.4rem; }

.cart-checkout-btn {
  width:          100%;
  padding:        1rem;
  background:     var(--noir);
  color:          var(--blanc);
  font-size:      0.75rem;
  font-weight:    400;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  border:         1px solid var(--noir);
  transition:     all var(--transition);
}
.cart-checkout-btn:hover:not(:disabled) {
  background:   var(--ambre);
  border-color: var(--ambre);
}
.cart-checkout-btn:disabled { opacity: 0.6; cursor: not-allowed; }

.cart-livraison {
  text-align: center;
  font-size:  0.7rem;
  color:      var(--gris-m);
  letter-spacing: 0.05em;
}

/* ── Success page ────────────────────────────────────────────────────────────── */
.success-page {
  min-height:      100vh;
  display:         flex;
  align-items:     center;
  justify-content: center;
  padding:         4rem var(--pad-h);
}

.success-inner {
  max-width:  520px;
  text-align: center;
}

.success-check {
  font-size:     3rem;
  margin-bottom: 2rem;
  color:         var(--ambre);
}

.success-inner h1 {
  font-size:     2.5rem;
  margin-bottom: 1.5rem;
}

.success-inner p {
  margin-bottom: 2.5rem;
  font-size:     0.95rem;
  line-height:   1.8;
}

.btn-retour {
  display:        inline-block;
  padding:        0.8rem 2rem;
  border:         1px solid var(--noir);
  font-size:      0.7rem;
  font-weight:    400;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  transition:     all var(--transition);
}
.btn-retour:hover { background: var(--noir); color: var(--blanc); }

/* ── Admin page ──────────────────────────────────────────────────────────────── */
.admin-page { min-height: 100vh; background: var(--gris-u); }

.admin-header {
  background:    var(--blanc-pur);
  border-bottom: var(--border);
  padding:       1.25rem 2rem;
  display:       flex;
  align-items:   center;
  justify-content: space-between;
}

.admin-title {
  font-family: var(--font-serif);
  font-size:   1.3rem;
  font-weight: 300;
}

.admin-content { max-width: 900px; margin: 0 auto; padding: 3rem 2rem; }

#login-section {
  max-width:  400px;
  margin:     4rem auto;
  text-align: center;
}

.login-form {
  display:        flex;
  flex-direction: column;
  gap:            1rem;
  margin-top:     2rem;
}

.admin-input {
  width:       100%;
  padding:     0.75rem 1rem;
  border:      var(--border);
  background:  var(--blanc-pur);
  font-family: var(--font-sans);
  font-size:   0.9rem;
  font-weight: 300;
  outline:     none;
  transition:  border-color var(--transition);
}
.admin-input:focus { border-color: var(--noir); }

#login-btn, #refresh-btn {
  padding:        0.75rem 1.5rem;
  background:     var(--noir);
  color:          var(--blanc);
  font-size:      0.7rem;
  font-weight:    400;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  transition:     background var(--transition);
}
#login-btn:hover, #refresh-btn:hover { background: var(--ambre); }

#login-error {
  color:     #9B2020;
  font-size: 0.82rem;
  min-height: 1.2em;
}

#dashboard-section { display: none; }

.dashboard-header {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  margin-bottom:   2rem;
}

.orders-count {
  font-size:   0.75rem;
  color:       var(--gris-m);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

#orders-list { display: flex; flex-direction: column; gap: 1rem; }

.admin-empty { color: var(--gris-m); font-size: 0.88rem; text-align: center; padding: 3rem; }

.order-card {
  background:    var(--blanc-pur);
  border:        var(--border);
  overflow:      hidden;
}

.order-header {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  padding:         1rem 1.5rem;
  border-bottom:   var(--border);
  background:      var(--blanc);
}

.order-meta { display: flex; flex-direction: column; gap: 0.15rem; }

.order-name { font-weight: 400; font-size: 0.95rem; }
.order-date { font-size: 0.75rem; color: var(--gris-m); }

.status-badge {
  font-size:      0.65rem;
  font-weight:    400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding:        0.25rem 0.6rem;
  border:         1px solid;
}
.status-badge.new        { color: #1A3A5C; border-color: #1A3A5C; background: #EEF4FB; }
.status-badge.preparing  { color: #7A5F00; border-color: #C4993F; background: #FBF5E6; }
.status-badge.shipped    { color: #1A3A1A; border-color: #2E7A4A; background: #EEF7F1; }

.order-body {
  padding: 1.25rem 1.5rem;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1rem;
}

.order-items { display: flex; flex-direction: column; gap: 0.25rem; }
.order-item  { font-size: 0.85rem; color: var(--noir); }

.order-address { font-size: 0.82rem; color: var(--gris-m); line-height: 1.6; }

.order-total {
  font-family: var(--font-serif);
  font-size:   1.3rem;
  text-align:  right;
}

.tracking-info {
  padding:      0.75rem 1.5rem;
  background:   #EEF7F1;
  border-top:   1px solid #D0EAD8;
  font-size:    0.82rem;
  color:        #1A3A1A;
}

.order-actions {
  padding:     1rem 1.5rem;
  border-top:  var(--border);
  background:  var(--gris-u);
}

.tracking-form { display: flex; gap: 0.75rem; align-items: center; }

.tracking-input {
  flex:        1;
  padding:     0.6rem 0.75rem;
  border:      var(--border);
  background:  var(--blanc-pur);
  font-family: var(--font-sans);
  font-size:   0.85rem;
  font-weight: 300;
  outline:     none;
}
.tracking-input:focus { border-color: var(--noir); }

.btn-action {
  padding:        0.6rem 1.1rem;
  border:         var(--border);
  font-size:      0.7rem;
  font-weight:    400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--noir);
  background:     var(--blanc-pur);
  white-space:    nowrap;
  transition:     all var(--transition);
}
.btn-action:hover    { background: var(--noir); color: var(--blanc); }
.btn-action.primary  { background: var(--noir); color: var(--blanc); }
.btn-action.primary:hover { background: var(--ambre); border-color: var(--ambre); }
.btn-action:disabled { opacity: 0.6; cursor: not-allowed; }

.action-done { font-size: 0.78rem; color: #2E7A4A; letter-spacing: 0.05em; }

/* ── Responsive ──────────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  :root { --pad-h: 1.25rem; }

  section { padding: 4rem 0; }

  .hero { padding: 6rem 0 4rem; }

  .products-grid {
    grid-template-columns: 1fr;
  }

  .product-card { padding: 2rem 1.5rem; }

  .garanties-grid {
    grid-template-columns: 1fr;
    gap:                   2.5rem;
  }

  .apropos-inner {
    grid-template-columns: 1fr;
    gap:                   2rem;
  }

  .apropos-img { aspect-ratio: 16/9; }

  .footer-inner {
    flex-direction: column;
    text-align:     center;
    gap:            1rem;
  }

  .boutique-header {
    flex-direction: column;
    gap:            0.5rem;
    align-items:    flex-start;
  }

  .order-body {
    grid-template-columns: 1fr;
    gap:                   0.75rem;
  }

  .order-total { text-align: left; }

  .tracking-form { flex-direction: column; align-items: stretch; }
}

@media (max-width: 480px) {
  .header-nav .nav-link { display: none; }
  .product-footer { flex-direction: column; align-items: flex-start; gap: 1rem; }
  .btn-add { width: 100%; text-align: center; }
}

/* ── Footer légal v2 ─────────────────────────────────────────────────────────── */
.footer-inner {
  max-width:  var(--max-w);
  margin:     0 auto;
  padding:    0 var(--pad-h);
  display:    grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:        2rem;
  align-items: start;
}

.footer-brand-col { display: flex; flex-direction: column; gap: 0.5rem; }
.footer-social    { display: flex; gap: 1rem; margin-top: 0.5rem; }
.footer-social a  { color: var(--gris-m); transition: color var(--transition); }
.footer-social a:hover { color: var(--noir); }
.footer-social svg { width: 18px; height: 18px; }

.footer-legal-col { display: flex; flex-direction: column; gap: 0.5rem; }
.footer-legal-col a {
  font-size:   0.75rem;
  color:       var(--gris-m);
  transition:  color var(--transition);
  letter-spacing: 0.02em;
}
.footer-legal-col a:hover { color: var(--noir); }

.footer-bottom-col {
  text-align:     right;
  display:        flex;
  flex-direction: column;
  gap:            0.25rem;
}

.footer-bottom-text {
  font-size:   0.72rem;
  color:       var(--gris-m);
  line-height: 1.6;
}

/* ── Avertissements produit ───────────────────────────────────────────────────── */
.product-warnings {
  font-size:      0.72rem;
  color:          var(--gris-m);
  line-height:    1.6;
  font-style:     italic;
  padding-top:    0.75rem;
  border-top:     1px solid var(--gris-u);
  margin-top:     auto;
}

/* ── Bannière cookies ─────────────────────────────────────────────────────────── */
.cookie-banner {
  position:   fixed;
  bottom:     0;
  left:       0;
  right:      0;
  z-index:    500;
  background: var(--noir);
  border-top: 1px solid var(--gris-f);
  padding:    1rem 2rem;
  display:    flex;
  align-items: center;
  justify-content: space-between;
  gap:        2rem;
}

.cookie-banner.hidden { display: none; }

.cookie-text {
  font-size:   0.8rem;
  color:       var(--gris-t, #999);
  line-height: 1.5;
  flex:        1;
}

.cookie-actions { display: flex; gap: 0.75rem; flex-shrink: 0; }

.cookie-btn {
  padding:        0.5rem 1.1rem;
  font-size:      0.7rem;
  font-weight:    400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border:         1px solid var(--gris-m);
  color:          var(--blanc);
  transition:     all var(--transition);
}
.cookie-btn.accept {
  background:  var(--ambre);
  border-color: var(--ambre);
  color:        var(--noir);
}
.cookie-btn:hover       { border-color: var(--blanc); }
.cookie-btn.accept:hover { background: var(--ambre-c); border-color: var(--ambre-c); }

/* ── Pages légales ───────────────────────────────────────────────────────────── */
.legal-page { min-height: 100vh; }

.legal-content {
  max-width:  720px;
  margin:     0 auto;
  padding:    5rem var(--pad-h) 6rem;
}

.legal-back {
  display:        inline-block;
  font-size:      0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--gris-m);
  margin-bottom:  3rem;
  transition:     color var(--transition);
}
.legal-back:hover { color: var(--noir); }

.legal-title {
  font-family: var(--font-serif);
  font-size:   clamp(2rem, 5vw, 3.5rem);
  font-weight: 400;
  margin-bottom: 3rem;
  padding-bottom: 1.5rem;
  border-bottom: var(--border);
}

.legal-section { margin-bottom: 2.5rem; }

.legal-section-title {
  font-family:    var(--font-serif);
  font-size:      1.15rem;
  font-weight:    400;
  color:          var(--noir);
  margin-bottom:  0.75rem;
}

.legal-p {
  font-size:   0.9rem;
  color:       var(--gris-m);
  line-height: 1.8;
  margin-bottom: 0.75rem;
}

.legal-contact-grid {
  display:               grid;
  grid-template-columns: 140px 1fr;
  gap:                   0.5rem 1rem;
  font-size:             0.9rem;
  color:                 var(--gris-m);
}

.legal-contact-label { font-weight: 400; color: var(--noir); }

/* ── Page 404 ────────────────────────────────────────────────────────────────── */
.page-404 {
  min-height:      80vh;
  display:         flex;
  align-items:     center;
  justify-content: center;
  text-align:      center;
  padding:         4rem var(--pad-h);
}

.page-404-inner h1 { font-size: clamp(2rem, 5vw, 3.5rem); margin-bottom: 1rem; }
.page-404-inner p  { margin-bottom: 2rem; }

/* ── Statuts commandes admin v2 ──────────────────────────────────────────────── */
.status-badge.new        { color: #1A3A5C; border-color: #1A3A5C; background: #EEF4FB; }
.status-badge.preparing  { color: #7A5F00; border-color: #C4993F; background: #FBF5E6; }
.status-badge.shipped    { color: #1A4A2A; border-color: #3A8A5A; background: #EEF7F1; }
.status-badge.delivered  { color: #0D3020; border-color: #1A6040; background: #E5F5ED; }
.status-badge.cancelled  { color: #444;    border-color: #AAA;    background: #F5F5F5; }
.status-badge.refunded   { color: #7A1A1A; border-color: #C44;    background: #FBF0F0; }
.status-badge.problem    { color: #7A4400; border-color: #D4840A; background: #FBF3E6; }

/* ── Admin produits ─────────────────────────────────────────────────────────── */
.admin-tabs {
  display:    flex;
  gap:        0;
  border-bottom: var(--border);
  margin-bottom: 2rem;
}

.admin-tab {
  padding:        0.75rem 1.5rem;
  font-size:      0.75rem;
  font-weight:    400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--gris-m);
  border-bottom:  2px solid transparent;
  cursor:         pointer;
  transition:     all var(--transition);
  background:     none;
  border-top:     none;
  border-left:    none;
  border-right:   none;
}
.admin-tab.active { color: var(--noir); border-bottom-color: var(--ambre); }
.admin-tab:hover  { color: var(--noir); }

.products-admin-grid {
  display:               grid;
  grid-template-columns: 1fr 1fr;
  gap:                   1rem;
}

.product-admin-card {
  background:  var(--blanc-pur);
  border:      var(--border);
  padding:     1.25rem;
}

.product-admin-card h4 {
  font-family:   var(--font-serif);
  font-size:     1.1rem;
  font-weight:   400;
  margin-bottom: 1rem;
  padding-bottom: 0.75rem;
  border-bottom: var(--border);
}

.product-admin-field {
  display:        flex;
  flex-direction: column;
  gap:            0.3rem;
  margin-bottom:  0.75rem;
}

.product-admin-field label {
  font-size:      0.65rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--gris-m);
}

.product-admin-field input,
.product-admin-field select {
  padding:     0.5rem 0.75rem;
  border:      var(--border);
  background:  var(--blanc);
  font-family: var(--font-sans);
  font-size:   0.88rem;
  font-weight: 300;
  outline:     none;
  transition:  border-color var(--transition);
  width:       100%;
}
.product-admin-field input:focus,
.product-admin-field select:focus { border-color: var(--noir); }

.product-save-btn {
  width:          100%;
  padding:        0.65rem;
  background:     var(--noir);
  color:          var(--blanc);
  font-size:      0.7rem;
  font-weight:    400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border:         1px solid var(--noir);
  margin-top:     0.5rem;
  transition:     all var(--transition);
}
.product-save-btn:hover   { background: var(--ambre); border-color: var(--ambre); }
.product-save-btn.saved   { background: var(--ambre); border-color: var(--ambre); color: var(--noir); }

/* ── Order card v2 — champs étendus ─────────────────────────────────────────── */
.order-extended {
  padding:    1rem 1.5rem;
  border-top: var(--border);
  display:    grid;
  grid-template-columns: 1fr 1fr;
  gap:        0.75rem;
}

.order-field {
  display:        flex;
  flex-direction: column;
  gap:            0.25rem;
}

.order-field label {
  font-size:      0.62rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--gris-m);
}

.order-field input,
.order-field textarea,
.order-field select {
  padding:     0.45rem 0.6rem;
  border:      var(--border);
  background:  var(--blanc);
  font-family: var(--font-sans);
  font-size:   0.82rem;
  font-weight: 300;
  outline:     none;
  transition:  border-color var(--transition);
}
.order-field input:focus,
.order-field textarea:focus,
.order-field select:focus { border-color: var(--noir); }
.order-field textarea { resize: vertical; min-height: 60px; }

.order-field.full-width { grid-column: 1 / -1; }

.order-actions-row {
  display:    flex;
  flex-wrap:  wrap;
  gap:        0.5rem;
  padding:    0.75rem 1.5rem;
  border-top: var(--border);
  background: var(--gris-u);
}

.order-action-btn {
  padding:        0.45rem 0.85rem;
  border:         var(--border);
  font-size:      0.65rem;
  font-weight:    400;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color:          var(--noir);
  background:     var(--blanc-pur);
  white-space:    nowrap;
  transition:     all var(--transition);
}
.order-action-btn:hover { background: var(--noir); color: var(--blanc); }
.order-action-btn.primary { background: var(--noir); color: var(--blanc); }
.order-action-btn.primary:hover { background: var(--ambre); border-color: var(--ambre); }
.order-action-btn.danger { color: #7A1A1A; border-color: #C44; }
.order-action-btn.danger:hover { background: #7A1A1A; border-color: #7A1A1A; color: var(--blanc); }
.order-action-btn:disabled { opacity: 0.5; cursor: not-allowed; }

.status-actions {
  display:    flex;
  flex-wrap:  wrap;
  gap:        0.5rem;
  padding:    0.75rem 1.5rem;
  border-top: var(--border);
}

@media (max-width: 768px) {
  .footer-inner { grid-template-columns: 1fr; gap: 1.5rem; }
  .footer-bottom-col { text-align: left; }
  .products-admin-grid { grid-template-columns: 1fr; }
  .order-extended { grid-template-columns: 1fr; }
  .cookie-banner { flex-direction: column; align-items: flex-start; }
}

/* ── Codes promo ─────────────────────────────────────────────────────────────── */
.promos-table {
  width:           100%;
  border-collapse: collapse;
  font-size:       0.88rem;
}
.promos-table thead tr {
  background:  var(--gris-c);
  border-top:  2px solid var(--ambre);
}
.promos-table th {
  padding:        10px 14px;
  text-align:     left;
  font-size:      0.65rem;
  font-weight:    400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--blanc-pur);
}
.promos-table td {
  padding:     10px 14px;
  border-bottom: 1px solid var(--gris-u);
  color:       var(--noir);
  vertical-align: middle;
}
.promos-table tbody tr:nth-child(even) { background: var(--gris-u); }
.promos-table tbody tr:hover           { background: var(--gris-u); }