/* ============================================================
   BOUTIQUE GRIS — Style "Chic Made in France"
   Police : Playfair Display (serif) + DM Sans (sans-serif)
   Palette : crème / noir / doré / rouge FR
============================================================ */

:root{
  --creme:#F7F3EC;
  --creme-clair:#FBF8F2;
  --ivoire:#FAF7F1;
  --noir:#1A1A1A;
  --gris-fonce:#3D3D3D;
  --gris:#8B8680;
  --gris-clair:#E8E2D6;
  --dore:#B8946A;
  --dore-clair:#D4B896;
  --rouge-francais:#C8553D;
  --vert-ok:#4F7B4F;
  --shadow-soft:0 4px 16px rgba(0,0,0,.04);
  --shadow-md:0 12px 32px rgba(0,0,0,.08);
  --shadow-lg:0 30px 60px rgba(0,0,0,.1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'DM Sans',-apple-system,sans-serif;
  color:var(--noir);
  background:var(--ivoire);
  line-height:1.6;
  font-size:15px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
.serif{font-family:'Playfair Display',serif}
a{color:var(--noir);text-decoration:none;transition:color .2s}
a:hover{color:var(--dore)}
img{max-width:100%;height:auto;display:block}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit;font-size:inherit}

/* ============ CONTENEUR ============ */
.container{max-width:1280px;margin:0 auto;padding:0 32px}
@media (max-width:768px){.container{padding:0 20px}}

/* ============ BOUTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 28px;
  font-family:'DM Sans',sans-serif;font-weight:500;font-size:13px;
  letter-spacing:1.5px;text-transform:uppercase;
  border:none;cursor:pointer;text-decoration:none;
  transition:all .25s;
}
.btn-primary{background:var(--noir);color:var(--creme)}
.btn-primary:hover{background:var(--dore);color:#fff;transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--noir);border:1px solid var(--noir)}
.btn-outline:hover{background:var(--noir);color:var(--creme)}
.btn-ghost{background:transparent;color:var(--noir);border-bottom:1px solid var(--noir);padding:8px 0}
.btn-ghost:hover{color:var(--dore);border-color:var(--dore);gap:14px}
.btn-cream{background:var(--creme);color:var(--noir)}
.btn-cream:hover{background:var(--dore);color:#fff}
.btn-sm{padding:8px 16px;font-size:11px}
.btn-block{width:100%;justify-content:center}
.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none !important}

/* ============ TOP BAR ============ */
.topbar{
  background:var(--noir);color:var(--creme);
  font-size:12px;padding:10px 0;text-align:center;
  letter-spacing:1px;text-transform:uppercase;font-weight:500;
}
.topbar .sep{color:var(--dore);margin:0 12px}
.topbar a{color:var(--creme)}
.topbar a:hover{color:var(--dore)}

/* ============ NAV ============ */
.site-nav{
  background:var(--ivoire);
  border-bottom:1px solid var(--gris-clair);
  position:sticky;top:0;z-index:100;
}
.site-nav-inner{
  max-width:1280px;margin:0 auto;padding:22px 32px;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:40px;
}
.nav-left{display:flex;gap:28px}
.nav-left a{color:var(--noir);font-weight:500;font-size:14px;letter-spacing:0.3px}
.nav-left a:hover,.nav-left a.active{color:var(--dore)}
.site-logo{
  font-family:'Playfair Display',serif;
  font-size:30px;font-weight:500;letter-spacing:0.04em;
  text-align:center;color:var(--noir);
}
.site-logo small{
  display:block;font-family:'DM Sans';
  font-size:10px;font-weight:500;letter-spacing:4px;
  color:var(--gris);text-transform:uppercase;margin-top:2px;
}
.nav-right{display:flex;justify-content:flex-end;gap:20px;align-items:center}
.nav-icon{
  cursor:pointer;font-size:18px;color:var(--noir);
  position:relative;transition:color .2s;
  background:none;border:none;padding:0;
}
.nav-icon:hover{color:var(--dore)}
.nav-icon .badge{
  position:absolute;top:-8px;right:-10px;
  background:var(--rouge-francais);color:#fff;
  font-size:10px;font-weight:700;
  min-width:18px;height:18px;padding:0 5px;border-radius:9px;
  display:grid;place-items:center;
}
.nav-cta{
  background:var(--noir);color:var(--creme);
  padding:10px 18px;font-size:13px;letter-spacing:0.5px;
  transition:all .2s;
}
.nav-cta:hover{background:var(--dore);color:#fff}

/* Menu burger mobile */
.nav-burger{display:none;background:none;border:none;font-size:24px;cursor:pointer}

/* ============ BREADCRUMB ============ */
.breadcrumb{padding:20px 0;font-size:13px;color:var(--gris)}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:8px}
.breadcrumb li:not(:last-child)::after{content:"›";margin-left:8px;color:var(--gris-clair)}
.breadcrumb a{color:var(--gris)}
.breadcrumb a:hover{color:var(--dore)}
.breadcrumb [aria-current="page"]{color:var(--noir);font-weight:500}

/* ============ HERO HOMEPAGE ============ */
.hero{background:var(--creme);padding:80px 0 100px;position:relative}
.hero-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center}
.hero-tag{
  display:inline-flex;align-items:center;gap:12px;
  margin-bottom:28px;
  color:var(--dore);font-size:12px;
  letter-spacing:3px;text-transform:uppercase;font-weight:600;
}
.hero-tag::before{content:"";width:40px;height:1px;background:var(--dore)}
.hero h1{
  font-family:'Playfair Display',serif;
  font-size:clamp(40px,5.2vw,72px);font-weight:400;
  line-height:1.05;letter-spacing:-0.02em;
  margin-bottom:28px;color:var(--noir);
}
.hero h1 em{font-style:italic;color:var(--dore)}
.hero-lead{font-size:17px;color:var(--gris-fonce);max-width:520px;margin-bottom:36px;line-height:1.7}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;align-items:center}

.hero-visual{position:relative}
.hero-frame{
  aspect-ratio:3/4;background:#fff;padding:50px 32px;
  position:relative;box-shadow:var(--shadow-lg);
}
.hero-frame::before{content:"";position:absolute;inset:16px;border:1px solid var(--gris-clair)}
.hero-frame-inner{
  width:100%;height:100%;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--creme-clair) 0%,#fff 100%);
  position:relative;
}
.hero-icon{font-size:160px;opacity:.4;color:var(--dore)}
.hero-stamp{
  position:absolute;bottom:30px;right:30px;width:110px;height:110px;
  border-radius:50%;border:1px solid var(--dore);background:#fff;
  display:grid;place-items:center;color:var(--dore);
  font-family:'Playfair Display',serif;font-size:12px;
  text-align:center;line-height:1.3;font-weight:500;
}
.hero-stamp strong{font-size:24px;display:block;font-weight:500;margin:2px 0}

/* ============ TRUST BAND ============ */
.trust-band{
  background:var(--ivoire);padding:40px 0;
  border-top:1px solid var(--gris-clair);
  border-bottom:1px solid var(--gris-clair);
}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.trust-item{text-align:center;padding:0 24px;border-right:1px solid var(--gris-clair)}
.trust-item:last-child{border-right:none}
.trust-item .icon{font-size:22px;margin-bottom:12px;color:var(--dore)}
.trust-item strong{font-family:'Playfair Display',serif;font-size:16px;font-weight:500;display:block;margin-bottom:4px}
.trust-item span{font-size:13px;color:var(--gris)}

/* ============ SECTIONS ============ */
.section{padding:90px 0}
.section-alt{background:var(--creme)}
.section-head{text-align:center;max-width:640px;margin:0 auto 60px}
.section-head.left{text-align:left;margin-left:0}
.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  color:var(--dore);font-size:12px;font-weight:600;
  letter-spacing:3px;text-transform:uppercase;margin-bottom:20px;
}
.eyebrow::before,.eyebrow::after{content:"";width:30px;height:1px;background:var(--dore)}
.section-head.left .eyebrow::after{display:none}
.section-head h2{
  font-family:'Playfair Display',serif;
  font-size:clamp(32px,4vw,44px);font-weight:400;
  letter-spacing:-0.01em;line-height:1.15;margin-bottom:16px;
}
.section-head h2 em{font-style:italic;color:var(--dore)}
.section-head p{color:var(--gris-fonce);font-size:16px}

/* ============ CATÉGORIES ============ */
.cats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.cat-card{
  text-align:center;cursor:pointer;transition:all .3s;
  padding:36px 24px;border:1px solid var(--gris-clair);
  background:#fff;position:relative;color:inherit;
}
.cat-card:hover{transform:translateY(-4px);border-color:var(--dore);color:inherit}
.cat-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--dore);transform:scaleX(0);transform-origin:left;transition:transform .4s;
}
.cat-card:hover::before{transform:scaleX(1)}
.cat-num{font-family:'Playfair Display',serif;font-size:28px;color:var(--dore);font-style:italic;margin-bottom:14px;font-weight:400}
.cat-card h3{font-family:'Playfair Display',serif;font-size:20px;font-weight:500;margin-bottom:8px}
.cat-card p{font-size:13px;color:var(--gris);margin-bottom:14px}
.cat-count{font-size:11px;color:var(--dore);letter-spacing:2px;text-transform:uppercase;font-weight:600}

/* ============ PRODUITS GRID ============ */
.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.products-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.product-card{background:#fff;transition:all .3s;cursor:pointer;color:inherit;position:relative}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);color:inherit}
.product-card a.product-link{display:block;color:inherit}
.product-visual{
  aspect-ratio:1;background:var(--creme-clair);
  display:grid;place-items:center;position:relative;overflow:hidden;
}
.product-visual img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.product-card:hover .product-visual img{transform:scale(1.04)}
.product-visual .icon{font-size:72px;opacity:.3;color:var(--gris-fonce)}
.product-badge{
  position:absolute;top:14px;left:14px;background:#fff;color:var(--noir);
  font-size:10px;padding:6px 11px;letter-spacing:2px;text-transform:uppercase;font-weight:600;
}
.product-badge.stock{background:var(--noir);color:var(--creme)}
.product-badge.promo{background:var(--rouge-francais);color:#fff}
.product-fav{
  position:absolute;top:14px;right:14px;font-size:18px;
  color:var(--gris);background:rgba(255,255,255,.9);
  border-radius:50%;width:34px;height:34px;
  display:grid;place-items:center;cursor:pointer;transition:color .2s;border:none;
}
.product-fav:hover{color:var(--rouge-francais)}
.product-body{padding:22px;text-align:center}
.product-ref{font-size:11px;color:var(--gris);letter-spacing:2px;text-transform:uppercase;margin-bottom:8px;font-weight:500}
.product-card h3{
  font-family:'Playfair Display',serif;font-size:17px;font-weight:500;
  margin-bottom:6px;line-height:1.3;min-height:44px;
}
.product-compat{font-size:12px;color:var(--gris);font-style:italic;margin-bottom:18px;min-height:18px}
.product-foot{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:14px;border-top:1px solid var(--gris-clair);
}
.product-price{font-family:'Playfair Display',serif;font-size:22px;font-weight:500;color:var(--noir)}
.product-price small{font-size:11px;color:var(--gris);font-weight:400;font-family:'DM Sans';letter-spacing:1px;margin-left:4px}
.product-price del{color:var(--gris);font-size:15px;margin-right:6px}
.product-add{
  background:transparent;color:var(--noir);border:1px solid var(--noir);
  padding:8px 16px;font-size:11px;letter-spacing:2px;text-transform:uppercase;
  font-weight:600;transition:all .2s;
}
.product-add:hover{background:var(--noir);color:var(--creme)}

/* ============ FICHE PRODUIT ============ */
.product-detail{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;padding:40px 0 80px}
.product-gallery{position:relative}
.product-gallery-main{
  background:#fff;aspect-ratio:1;display:grid;place-items:center;
  border:1px solid var(--gris-clair);overflow:hidden;
}
.product-gallery-main img{width:100%;height:100%;object-fit:cover}
.product-gallery-main .icon{font-size:180px;color:var(--dore);opacity:.35}
.product-gallery-thumbs{display:flex;gap:10px;margin-top:14px}
.product-gallery-thumbs button{
  width:80px;height:80px;border:1px solid var(--gris-clair);
  background:#fff;padding:0;cursor:pointer;transition:border .2s;overflow:hidden;
}
.product-gallery-thumbs button:hover,
.product-gallery-thumbs button.active{border-color:var(--dore)}
.product-gallery-thumbs img{width:100%;height:100%;object-fit:cover}

.product-info .product-ref{text-align:left;margin-bottom:14px}
.product-info h1{
  font-family:'Playfair Display',serif;font-size:38px;font-weight:400;
  letter-spacing:-0.01em;line-height:1.15;margin-bottom:16px;
}
.product-info .product-price{font-size:32px;margin-bottom:8px;display:block}
.product-vat-note{color:var(--gris);font-size:13px;margin-bottom:22px}
.product-info .product-short{color:var(--gris-fonce);font-size:16px;line-height:1.7;margin-bottom:28px}
.product-stock{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;margin-bottom:24px}
.product-stock.ok{color:var(--vert-ok)}
.product-stock.low{color:var(--rouge-francais)}
.product-stock.out{color:var(--rouge-francais)}
.product-stock::before{content:"●";font-size:12px}

.product-buy{display:flex;gap:14px;align-items:stretch;margin-bottom:32px}
.qty-selector{display:flex;align-items:center;border:1px solid var(--noir)}
.qty-selector button{background:#fff;border:none;padding:0 16px;font-size:18px;cursor:pointer}
.qty-selector input{width:60px;text-align:center;border:none;border-left:1px solid var(--gris-clair);border-right:1px solid var(--gris-clair);padding:12px 0;font-weight:600}
.qty-selector input::-webkit-outer-spin-button,
.qty-selector input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.qty-selector input[type=number]{-moz-appearance:textfield}

.product-meta{border-top:1px solid var(--gris-clair);padding-top:20px;font-size:14px}
.product-meta dl{display:grid;grid-template-columns:auto 1fr;gap:6px 24px}
.product-meta dt{color:var(--gris);font-weight:500}
.product-meta dd{color:var(--noir)}
.product-compat-list{margin-top:12px;display:flex;flex-wrap:wrap;gap:6px}
.product-compat-list span{background:var(--creme);padding:4px 10px;font-size:12px;border:1px solid var(--gris-clair)}

.product-tabs{margin-top:60px;border-top:1px solid var(--gris-clair);padding-top:40px}
.product-tabs h2{font-family:'Playfair Display',serif;font-size:24px;margin-bottom:16px}
.product-tabs p,.product-tabs ul{color:var(--gris-fonce);line-height:1.8}
.product-tabs ul{padding-left:20px}

/* ============ CATALOGUE (liste produits) ============ */
.catalogue-layout{display:grid;grid-template-columns:260px 1fr;gap:48px;padding:30px 0 80px}
.catalogue-sidebar h3{
  font-family:'Playfair Display',serif;font-size:18px;font-weight:500;
  margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--gris-clair);
}
.catalogue-sidebar h3:not(:first-child){margin-top:32px}
.catalogue-sidebar ul{list-style:none}
.catalogue-sidebar li{margin-bottom:8px}
.catalogue-sidebar a{font-size:14px;color:var(--gris-fonce)}
.catalogue-sidebar a:hover,.catalogue-sidebar a.active{color:var(--dore)}
.catalogue-sidebar .cat-count{color:var(--gris);font-size:12px;letter-spacing:0}

.catalogue-toolbar{
  display:flex;justify-content:space-between;align-items:center;
  padding-bottom:18px;border-bottom:1px solid var(--gris-clair);margin-bottom:28px;
  gap:20px;flex-wrap:wrap;
}
.catalogue-search{display:flex;gap:8px;flex:1;max-width:420px}
.catalogue-search input{flex:1;padding:10px 14px;border:1px solid var(--gris-clair);font-size:14px;background:#fff}
.catalogue-search button{padding:10px 16px;background:var(--noir);color:var(--creme);border:none;font-size:12px;letter-spacing:1px;text-transform:uppercase}
.catalogue-sort select{padding:10px 14px;border:1px solid var(--gris-clair);background:#fff;font-size:14px}

.catalogue-empty{text-align:center;padding:80px 20px;color:var(--gris)}
.catalogue-empty h2{font-family:'Playfair Display',serif;font-size:28px;color:var(--noir);margin-bottom:12px}

.pagination{display:flex;gap:6px;justify-content:center;margin-top:40px}
.pagination a,.pagination span{
  padding:10px 14px;border:1px solid var(--gris-clair);
  background:#fff;color:var(--noir);font-size:14px;
}
.pagination a:hover{border-color:var(--dore);color:var(--dore)}
.pagination .current{background:var(--noir);color:var(--creme);border-color:var(--noir)}

/* ============ PANIER ============ */
.cart-layout{display:grid;grid-template-columns:1.6fr 1fr;gap:48px;padding:40px 0 80px}
.cart-lines{background:#fff;border:1px solid var(--gris-clair)}
.cart-line{
  display:grid;grid-template-columns:100px 1fr auto;gap:20px;align-items:center;
  padding:20px;border-bottom:1px solid var(--gris-clair);
}
.cart-line:last-child{border-bottom:none}
.cart-line img{width:100px;height:100px;object-fit:cover;background:var(--creme-clair)}
.cart-line-name{font-family:'Playfair Display',serif;font-size:17px;font-weight:500;margin-bottom:4px}
.cart-line .product-ref{text-align:left;margin:0 0 6px 0}
.cart-line .qty-selector{margin-top:10px}
.cart-line-remove{background:none;border:none;color:var(--gris);font-size:13px;cursor:pointer;margin-top:4px;text-decoration:underline}
.cart-line-remove:hover{color:var(--rouge-francais)}
.cart-line-price{font-family:'Playfair Display',serif;font-size:22px;font-weight:500;text-align:right}

.cart-summary{background:var(--creme);padding:32px;height:fit-content;position:sticky;top:100px}
.cart-summary h2{font-family:'Playfair Display',serif;font-size:24px;margin-bottom:24px;font-weight:500}
.cart-summary-row{display:flex;justify-content:space-between;padding:10px 0;font-size:15px}
.cart-summary-row.total{
  border-top:1px solid var(--gris-clair);margin-top:12px;padding-top:16px;
  font-family:'Playfair Display',serif;font-size:22px;font-weight:500;
}
.cart-summary .shipping-free{color:var(--vert-ok);font-size:13px;margin-top:8px}
.cart-summary .btn{margin-top:24px}

.cart-empty{text-align:center;padding:80px 20px}
.cart-empty h2{font-family:'Playfair Display',serif;font-size:32px;margin-bottom:16px}

/* ============ FORMULAIRES ============ */
.form-row{margin-bottom:20px}
.form-row label{display:block;font-size:13px;font-weight:500;color:var(--gris-fonce);margin-bottom:6px;letter-spacing:0.3px}
.form-row input[type=text],
.form-row input[type=email],
.form-row input[type=tel],
.form-row input[type=password],
.form-row input[type=number],
.form-row textarea,
.form-row select{
  width:100%;padding:12px 14px;
  background:#fff;border:1px solid var(--gris-clair);
  font-size:15px;color:var(--noir);transition:border .2s;
}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{
  outline:none;border-color:var(--noir);
}
.form-row textarea{min-height:100px;resize:vertical;font-family:inherit}
.form-row .help{font-size:12px;color:var(--gris);margin-top:4px}
.form-row .error{font-size:13px;color:var(--rouge-francais);margin-top:4px}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-check{display:flex;gap:10px;align-items:flex-start}
.form-check input{margin-top:4px}

/* ============ FLASH MESSAGES ============ */
.flash{padding:14px 20px;margin:20px auto;max-width:1280px;font-size:14px;border-left:4px solid}
.flash-success{background:#EFF6EF;border-color:var(--vert-ok);color:#2A4A2A}
.flash-error{background:#FBEEEA;border-color:var(--rouge-francais);color:#7A2E20}
.flash-warning{background:#FDF4E3;border-color:#C89A3F;color:#6B4E0E}
.flash-info{background:#EEF3F8;border-color:#5A7FA0;color:#2A4A66}

/* ============ STORY BLOCK ============ */
.story{padding:100px 0;background:#fff}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.story-visual{aspect-ratio:3/4;background:var(--creme);position:relative;display:grid;place-items:center}
.story-visual::before{content:"";position:absolute;inset:24px;border:1px solid var(--dore);opacity:.4}
.story-visual .icon{font-size:140px;opacity:.3;color:var(--dore)}
.story-content h2{font-family:'Playfair Display',serif;font-size:38px;font-weight:400;line-height:1.15;margin-bottom:24px}
.story-content h2 em{font-style:italic;color:var(--dore)}
.story-content p{color:var(--gris-fonce);font-size:16px;margin-bottom:18px;line-height:1.75}
.story-quote{
  font-family:'Playfair Display',serif;font-style:italic;font-size:18px;
  color:var(--noir);padding-left:20px;border-left:2px solid var(--dore);margin:24px 0;
}
.story-sign{font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--dore);font-weight:600}

/* ============ CTA BANNER ============ */
.cta-banner{padding:90px 0;background:var(--noir);color:var(--creme);text-align:center}
.cta-banner .eyebrow{color:var(--dore)}
.cta-banner .eyebrow::before,.cta-banner .eyebrow::after{background:var(--dore)}
.cta-banner h2{font-family:'Playfair Display',serif;font-size:40px;font-weight:400;max-width:700px;margin:0 auto 16px;line-height:1.2}
.cta-banner h2 em{font-style:italic;color:var(--dore)}
.cta-banner p{color:var(--gris-clair);max-width:580px;margin:0 auto 32px}

/* ============ FOOTER ============ */
.site-footer{background:var(--creme);padding:72px 0 24px;border-top:1px solid var(--gris-clair)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:56px;padding-bottom:40px;border-bottom:1px solid var(--gris-clair)}
.footer-col h5{font-family:'Playfair Display',serif;font-size:17px;font-weight:500;color:var(--noir);margin-bottom:22px}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:10px}
.footer-col a{color:var(--gris-fonce);font-size:14px}
.footer-col a:hover{color:var(--dore)}
.footer-brand p{color:var(--gris-fonce);font-size:14px;max-width:340px;margin:16px 0;line-height:1.7}
.footer-bottom{padding-top:24px;display:flex;justify-content:space-between;font-size:12px;color:var(--gris);flex-wrap:wrap;gap:16px}

/* ============ PAGES DE CONNEXION / COMPTE ============ */
.auth-layout{max-width:440px;margin:40px auto 80px;padding:40px;background:#fff;border:1px solid var(--gris-clair)}
.auth-layout h1{font-family:'Playfair Display',serif;font-size:32px;font-weight:400;margin-bottom:8px}
.auth-layout .eyebrow{margin-bottom:8px}
.auth-layout .auth-switch{text-align:center;margin-top:24px;font-size:14px;color:var(--gris)}
.auth-layout .auth-switch a{color:var(--dore);font-weight:500}

.account-layout{display:grid;grid-template-columns:240px 1fr;gap:40px;padding:30px 0 80px}
.account-sidebar{background:#fff;padding:24px;border:1px solid var(--gris-clair);height:fit-content}
.account-sidebar h3{font-family:'Playfair Display',serif;font-size:17px;font-weight:500;margin-bottom:12px}
.account-sidebar ul{list-style:none}
.account-sidebar li{margin-bottom:10px}
.account-sidebar a{font-size:14px;color:var(--gris-fonce)}
.account-sidebar a.active{color:var(--dore);font-weight:500}
.account-main h1{font-family:'Playfair Display',serif;font-size:32px;font-weight:400;margin-bottom:24px}

.orders-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--gris-clair)}
.orders-table th,.orders-table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--gris-clair);font-size:14px}
.orders-table th{font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--gris);font-weight:600}
.status-pill{display:inline-block;padding:3px 10px;font-size:11px;letter-spacing:1px;text-transform:uppercase;font-weight:600}
.status-pending{background:#FEF4E3;color:#8B6B1E}
.status-paid,.status-processing{background:#E6F2E6;color:var(--vert-ok)}
.status-shipped,.status-delivered{background:#E4EEF4;color:#2A5A7A}
.status-cancelled,.status-refunded{background:#FBEEEA;color:var(--rouge-francais)}

/* ============ RESPONSIVE ============ */
@media (max-width:1024px){
  .hero-grid,.story-grid,.product-detail,.cart-layout{grid-template-columns:1fr;gap:40px}
  .catalogue-layout{grid-template-columns:1fr}
  .account-layout{grid-template-columns:1fr}
  .products-grid,.cats-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:768px){
  .site-nav-inner{grid-template-columns:auto 1fr auto;gap:16px}
  .nav-left{display:none}
  .nav-burger{display:block}
  .products-grid,.cats-grid{grid-template-columns:repeat(2,1fr)}
  .trust-grid{grid-template-columns:repeat(2,1fr);gap:28px}
  .trust-item{border:none;padding:16px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .form-grid-2{grid-template-columns:1fr}
  .cart-line{grid-template-columns:70px 1fr;gap:12px}
  .cart-line-price{grid-column:1/-1;text-align:left}
  .product-info h1{font-size:28px}
  .product-info .product-price{font-size:26px}
  .section-head h2,.cta-banner h2,.story-content h2{font-size:28px}
}
