:root{
  --bone:#f6f1e9;--bone-soft:#faf6ef;--sand:#e8dfd0;
  --terracotta:#b85042;--terracotta-deep:#8a3a2f;--terracotta-soft:#f2dcd6;
  --clay:#d4a88a;
  --ink:#1c1915;--ink-soft:#3d3731;--mute:#807569;--fade:#b8ad9e;--line:#dfd6c5;
  --green-ok:#4a6b3a;--green-deep:#324a26;--green-soft:#d8e4cb;--green-tint:#ebf2e0;
  --red-no:#a83d2f;--red-soft:#f2d6d0;
  --gold-doc:#c89354;

  /* ── Tokens sémantiques (alias de la palette marque) — à utiliser partout ── */
  --ok:var(--green-ok);        --ok-deep:var(--green-deep);  --ok-tint:var(--green-tint);
  --warn:#a9762a;              --warn-tint:#f6ecd8;
  --info:var(--terracotta-deep); --info-tint:var(--terracotta-soft);
  --danger:var(--red-no);      --danger-tint:var(--red-soft);
  /* Rayons */
  --radius-control:6px; --radius-card:12px; --radius-pill:100px;
  /* Ombres */
  --shadow-sm:0 1px 4px rgba(28,25,21,.05);
  --shadow-md:0 4px 16px rgba(28,25,21,.08);
  --shadow-lift:0 10px 30px rgba(28,25,21,.12);
  /* Motion & focus */
  --t-fast:.15s; --t-base:.22s; --ease:cubic-bezier(.2,.7,.3,1);
  --focus-ring:2px solid var(--terracotta);
  /* Hauteur du header (partagée par la sidebar catalogue) */
  --topbar-h:92px;
}
/* ── Accessibilité clavier : anneau de focus visible et homogène ── */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,
textarea:focus-visible,[tabindex]:focus-visible{
  outline:var(--focus-ring);outline-offset:2px;border-radius:3px;
}
/* ── Badge canonique : <span class="badge is-ok|is-pending|is-info|is-closed"> ── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:var(--radius-pill);
  font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;line-height:1.4;white-space:nowrap}
.badge.is-ok{background:var(--ok-tint);color:var(--ok-deep)}
.badge.is-pending{background:var(--warn-tint);color:var(--warn)}
.badge.is-info{background:var(--info-tint);color:var(--info)}
.badge.is-closed{background:var(--sand);color:var(--mute)}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{min-height:100%}
/* Sticky-footer : la page occupe au moins tout l'écran, le footer reste collé en bas */
body{font-family:'Inter',-apple-system,sans-serif;background:var(--bone);color:var(--ink);font-weight:400;line-height:1.55;-webkit-font-smoothing:antialiased;min-height:100vh;display:flex;flex-direction:column}
/* Le footer (dernier élément) se pousse en bas quand le contenu est court */
body > .pro-footer{margin-top:auto}
/* En flex-column, un enfant avec margin:auto se rétracte à son contenu.
   On force la pleine largeur pour que max-width + margin:auto recentrent correctement. */
body > *{width:100%}
.serif{font-family:'DM Serif Display','Georgia',serif;font-weight:400}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;font-size:inherit;color:inherit}
input{font-family:inherit}

/* ───────────── LOGIN ───────────── */
#screen-login{display:grid;grid-template-columns:1.1fr 1fr;min-height:100vh}
.login-left{background:var(--ink);color:var(--bone);padding:48px 64px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.login-left::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 80% 20%,rgba(184,80,66,.22) 0%,transparent 55%),radial-gradient(ellipse at 20% 90%,rgba(212,168,138,.14) 0%,transparent 55%);pointer-events:none}
.login-left>*{position:relative;z-index:1}

.brand-pro-tag{display:inline-block;padding:3px 11px;margin-left:14px;font-size:11px;font-family:'JetBrains Mono',monospace;letter-spacing:.2em;text-transform:uppercase;background:var(--terracotta);color:var(--bone);border-radius:100px;vertical-align:middle;font-weight:600}
.brand-line{display:flex;align-items:center;gap:14px}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:'DM Serif Display',serif;font-style:italic;font-size:38px;color:var(--bone);letter-spacing:-.01em;line-height:1}
.brand-since{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--clay);margin-top:6px;font-weight:500}

.login-editorial{max-width:520px}
.login-editorial .eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.25em;color:var(--clay);text-transform:uppercase;margin-bottom:24px;font-weight:500}
.login-editorial h1{font-family:'DM Serif Display',serif;font-size:68px;font-weight:400;line-height:1;margin:0 0 28px;letter-spacing:-.015em}
.login-editorial h1 em{font-style:italic;color:var(--clay)}
.login-editorial p{font-size:17px;line-height:1.65;color:rgba(246,241,233,.72);max-width:440px;margin:0}

.login-signature{display:flex;align-items:center;gap:20px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(246,241,233,.45);font-weight:500}
.login-signature .brands{font-family:'DM Serif Display',serif;font-style:italic;font-size:13px;letter-spacing:0;text-transform:none;color:var(--clay)}

.login-right{background:var(--bone);padding:48px 64px;display:flex;flex-direction:column;justify-content:center}
.login-form-wrap{max-width:380px;width:100%;margin:0 auto}
.login-form-wrap .eyebrow{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;color:var(--terracotta);text-transform:uppercase;margin-bottom:14px;font-weight:600}
.login-form-wrap h2{font-family:'DM Serif Display',serif;font-size:44px;font-weight:400;margin:0 0 14px;line-height:1.05;letter-spacing:-.01em}
.login-form-wrap .intro{font-size:14px;color:var(--mute);margin:0 0 36px;line-height:1.6}
.field{margin-bottom:20px}
.field label{display:block;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:8px;font-weight:600}
.field input{width:100%;padding:14px 18px;background:var(--bone-soft);border:1px solid var(--line);font-size:15px;color:var(--ink);transition:border-color .2s,background .2s}
.field input:focus{outline:none;border-color:var(--terracotta);background:#fff}
.btn-primary{width:100%;padding:16px 24px;background:var(--ink);color:var(--bone);font-family:'DM Serif Display',serif;font-style:italic;font-size:18px;transition:background .25s,transform .15s;margin-top:8px;display:inline-flex;align-items:center;justify-content:center;gap:10px}
.btn-primary:hover{background:var(--terracotta)}
.btn-primary:active{transform:scale(.98)}
.btn-primary .arr{transition:transform .3s}
.btn-primary:hover .arr{transform:translateX(5px)}
.login-helper{text-align:center;margin-top:24px;font-size:13px;color:var(--mute)}
.login-helper a{color:var(--terracotta);border-bottom:1px solid var(--terracotta);padding-bottom:1px}

.alert-error{background:var(--terracotta-soft);border-left:3px solid var(--terracotta);padding:12px 16px;margin-bottom:20px;font-size:14px;color:var(--terracotta-deep)}
.alert-info{background:var(--green-soft);border-left:3px solid var(--green-ok);padding:12px 16px;margin-bottom:20px;font-size:14px;color:var(--green-deep)}

/* ───────────── TOPBAR ───────────── */
.topbar{background:var(--ink);color:var(--bone);padding:0 56px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(246,241,233,.1);min-height:var(--topbar-h);flex-shrink:0;position:sticky;top:0;z-index:500;box-shadow:0 1px 0 rgba(246,241,233,.04)}
.topbar-brand{display:flex;align-items:center;gap:14px}
.topbar-brand-name{font-family:'DM Serif Display',serif;font-style:italic;font-size:26px;color:var(--bone);line-height:1;letter-spacing:-.01em}
.topbar-brand .pro{display:inline-block;padding:3px 11px;font-size:10px;font-family:'JetBrains Mono',monospace;letter-spacing:.22em;text-transform:uppercase;background:var(--terracotta);color:var(--bone);border-radius:100px;font-weight:700}
.topbar-nav{display:flex;gap:42px;font-family:'JetBrains Mono',monospace;font-size:13px;letter-spacing:.18em;text-transform:uppercase;font-weight:600}
.topbar-nav a{color:rgba(246,241,233,.55);padding:8px 0;border-bottom:2px solid transparent;transition:color .2s,border-color .2s}
.topbar-nav a.active{color:var(--bone);border-bottom-color:var(--terracotta)}
.topbar-nav a:hover{color:var(--bone)}
.topbar-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;padding:0 10px;border:1px solid rgba(246,241,233,.2);border-radius:var(--radius-control);background:rgba(246,241,233,.06)}
.topbar-burger span{display:block;height:2px;width:100%;background:var(--bone);border-radius:2px;transition:transform var(--t-fast),opacity var(--t-fast)}
.topbar.nav-open .topbar-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.topbar.nav-open .topbar-burger span:nth-child(2){opacity:0}
.topbar.nav-open .topbar-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.topbar-user{display:flex;align-items:center;gap:14px}
.avatar{width:42px;height:42px;border-radius:100px;background:var(--terracotta);color:var(--bone);display:inline-flex;align-items:center;justify-content:center;font-family:'DM Serif Display',serif;font-style:italic;font-size:18px}
.topbar-user-info{line-height:1.2;text-align:right}
.topbar-user-info .name{color:var(--bone);font-weight:600;font-size:14px}
.topbar-user-info .company{color:rgba(246,241,233,.5);font-size:11px;font-family:'JetBrains Mono',monospace;letter-spacing:.12em;text-transform:uppercase}
.topbar-logout{color:rgba(246,241,233,.4);font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;font-weight:600;padding:8px 12px;border:1px solid rgba(246,241,233,.15);transition:all .2s}
.topbar-logout:hover{color:var(--bone);border-color:rgba(246,241,233,.4)}

/* ───────────── SÉLECTEUR DE LANGUE (dropdown) ───────────── */
.lang-dropdown{position:relative;display:inline-block}
.lang-dd-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:rgba(246,241,233,.7);border:1px solid rgba(246,241,233,.25);border-radius:5px;background:rgba(246,241,233,.07);cursor:pointer;transition:all .15s;line-height:1;white-space:nowrap}
.lang-dd-btn:hover{color:#fff;border-color:rgba(246,241,233,.45);background:rgba(246,241,233,.13)}
.lang-caret{opacity:.6;transition:transform .2s;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;flex-shrink:0}
.lang-dropdown.open .lang-caret{transform:rotate(180deg)}
.lang-dd-menu{display:none;position:absolute;top:calc(100% + 6px);right:0;background:var(--ink);border:1px solid rgba(246,241,233,.15);border-radius:8px;padding:4px;min-width:100px;z-index:9999;box-shadow:0 8px 24px rgba(0,0,0,.4)}
.lang-dropdown.open .lang-dd-menu{display:block}
.lang-dd-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:5px;color:rgba(246,241,233,.65);text-decoration:none;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;transition:background .12s,color .12s;white-space:nowrap}
.lang-dd-item:hover{background:rgba(246,241,233,.1);color:#fff}
.lang-dd-item.lang-active{color:#fff;background:rgba(246,241,233,.12)}
.lang-flag{display:block;border-radius:2px;flex-shrink:0}
.lang-code{display:inline}
/* Sélecteur sur fond clair (page login) */
.lang-dropdown-light .lang-dd-btn{color:rgba(60,50,40,.6);border-color:rgba(60,50,40,.2);background:transparent}
.lang-dropdown-light .lang-dd-btn:hover{color:var(--ink);background:rgba(60,50,40,.05)}
.lang-dropdown-light .lang-dd-menu{background:#fff;border-color:rgba(60,50,40,.15);box-shadow:0 6px 20px rgba(0,0,0,.12)}
.lang-dropdown-light .lang-dd-item{color:rgba(60,50,40,.65)}
.lang-dropdown-light .lang-dd-item:hover{background:rgba(60,50,40,.05);color:var(--ink)}
.lang-dropdown-light .lang-dd-item.lang-active{color:var(--terracotta);background:var(--terracotta-soft)}

/* ───────────── DASHBOARD ───────────── */
.dash-hero{padding:64px 56px 48px;max-width:1400px;margin:0 auto}
.dash-hero .eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.25em;color:var(--terracotta);text-transform:uppercase;margin-bottom:22px;font-weight:600}
.dash-hero h1{font-family:'DM Serif Display',serif;font-size:72px;font-weight:400;line-height:1;margin:0 0 20px;letter-spacing:-.02em}
.dash-hero h1 em{font-style:italic;color:var(--terracotta)}
.dash-hero .lead{font-size:17px;color:var(--mute);max-width:620px;line-height:1.65;margin:0}
.dash-stats{max-width:1400px;margin:0 auto 72px;padding:0 56px;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stat{background:var(--bone);padding:36px 40px;position:relative}
.stat .label{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);margin-bottom:12px;font-weight:600}
.stat .num{font-family:'DM Serif Display',serif;font-size:56px;line-height:1;color:var(--ink);margin-bottom:8px}
.stat .num em{font-style:italic;color:var(--terracotta)}
.stat .num.text-num{font-style:italic;font-size:32px;padding-top:8px}
.stat .sub{font-size:13px;color:var(--mute)}
.section-head{padding:0 56px 20px;max-width:1400px;margin:0 auto;display:flex;align-items:baseline;justify-content:space-between;border-bottom:1px solid var(--line)}
.section-head h2{font-family:'DM Serif Display',serif;font-size:34px;font-weight:400;margin:0;letter-spacing:-.01em}
.section-head h2 em{font-style:italic;color:var(--terracotta)}
.section-head .count{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);font-weight:600}
.selections{padding:0 56px 100px;max-width:1400px;margin:0 auto}
.selection-row{display:grid;grid-template-columns:140px 1fr auto auto 40px;gap:32px;align-items:center;padding:30px 20px;border-bottom:1px solid var(--line);transition:background .2s;cursor:pointer;margin:0 -20px;text-decoration:none;color:inherit}
.selection-row:hover{background:var(--bone-soft)}
.sel-date{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--mute);font-weight:600}
.sel-date .day{font-family:'DM Serif Display',serif;font-style:italic;font-size:30px;color:var(--ink);display:block;text-transform:none;letter-spacing:0;line-height:1;margin-bottom:4px}
.sel-body h3{font-family:'DM Serif Display',serif;font-size:24px;font-weight:400;margin:0 0 6px;letter-spacing:-.005em}
.sel-body .from{font-size:13px;color:var(--mute)}
.sel-body .from strong{color:var(--ink-soft);font-weight:500}
.sel-stats{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--mute);text-align:right;font-weight:600}
.sel-stats .big{font-family:'DM Serif Display',serif;font-style:italic;font-size:26px;color:var(--ink);display:block;text-transform:none;letter-spacing:0;line-height:1;margin-bottom:4px}
.tag{display:inline-block;padding:6px 14px;border-radius:100px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;font-weight:600}
.tag-new{background:var(--terracotta);color:var(--bone)}
.tag-pending{background:var(--sand);color:var(--ink-soft)}
.tag-reserved{background:#e3d4a8;color:#6b5616}
.tag-done{background:var(--green-soft);color:var(--green-ok)}
.sel-arrow{font-family:'DM Serif Display',serif;font-size:28px;color:var(--terracotta);transition:transform .3s;text-align:center}
.selection-row:hover .sel-arrow{transform:translateX(8px)}
.no-offers{padding:80px 56px;text-align:center;color:var(--mute)}
.no-offers h3{font-family:'DM Serif Display',serif;font-style:italic;font-size:32px;color:var(--ink);margin:0 0 12px;font-weight:400}

/* ───────────── DÉTAIL layout 2-colonnes ───────────── */
.detail-layout{display:grid;grid-template-columns:1fr 360px;gap:0;align-items:start}
.detail-main{padding:0;min-width:0}
.detail-aside{position:sticky;top:0;align-self:start;height:100vh;overflow-y:auto;background:var(--ink);color:var(--bone);padding:32px 28px;display:flex;flex-direction:column;gap:24px;border-left:1px solid var(--line)}

.detail-head{background:var(--bone);padding:48px 56px 32px;border-bottom:1px solid var(--line)}
.breadcrumb{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);margin-bottom:24px;font-weight:600}
.breadcrumb a{color:var(--terracotta);border-bottom:1px solid transparent;transition:border-color .2s}
.breadcrumb a:hover{border-bottom-color:var(--terracotta)}
.breadcrumb .sep{color:var(--fade);margin:0 8px}
.detail-head h1{font-family:'DM Serif Display',serif;font-size:52px;font-weight:400;line-height:1;margin:0 0 18px;letter-spacing:-.02em}
.detail-head h1 em{font-style:italic;color:var(--terracotta)}
.detail-meta{display:flex;gap:36px;font-size:14px;color:var(--mute);margin-top:14px;flex-wrap:wrap}
.detail-meta .meta-item .lbl{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--fade);display:block;margin-bottom:4px;font-weight:600}
.detail-meta .meta-item .val{color:var(--ink);font-weight:500;font-size:15px}
.detail-message{background:var(--bone-soft);border-left:3px solid var(--terracotta);padding:22px 28px;margin:28px 0 0;font-family:'DM Serif Display',serif;font-style:italic;font-size:18px;color:var(--ink-soft);line-height:1.55}
.detail-message .from{font-family:'JetBrains Mono',monospace;font-style:normal;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--terracotta);display:block;margin-bottom:12px;font-weight:600}

/* Onglets */
.tabs-bar{background:var(--bone);padding:0 56px;border-bottom:1px solid var(--line);display:flex;gap:0;align-items:center;justify-content:space-between}
.tabs{display:flex;gap:0}
.tab{padding:18px 24px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);border-bottom:2px solid transparent;transition:all .2s;font-weight:600;display:flex;align-items:center;gap:8px;cursor:pointer}
.tab:hover{color:var(--ink-soft)}
.tab.active{color:var(--ink);border-bottom-color:var(--terracotta)}
.tab .badge{background:var(--terracotta);color:var(--bone);font-size:9px;padding:2px 8px;border-radius:100px;letter-spacing:.1em;font-weight:700;line-height:1.4}
.bulk-actions{display:flex;gap:10px}
.btn-bulk{padding:8px 16px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;font-weight:600;border:1px solid var(--line);background:transparent;color:var(--ink-soft);transition:all .2s;cursor:pointer}
.btn-bulk:hover{border-color:var(--ink);background:var(--bone-soft)}
.btn-bulk.green{color:var(--green-ok);border-color:var(--green-soft)}
.btn-bulk.green:hover{background:var(--green-tint)}

/* Tab panels */
.tab-panel{display:none}
.tab-panel.active{display:block}

/* Barre de filtres */
.filters-bar{padding:24px 56px;background:var(--bone-soft);border-bottom:1px solid var(--line);display:flex;gap:16px;align-items:flex-end;flex-wrap:wrap}
.filter-group{display:flex;flex-direction:column;gap:6px;min-width:0}
.filter-group label{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);font-weight:600}
.filter-group input,.filter-group select{padding:10px 14px;background:#fff;border:1px solid var(--line);font-size:13px;color:var(--ink);font-family:inherit;min-width:160px;transition:border-color .2s}
.filter-group input:focus,.filter-group select:focus{outline:none;border-color:var(--terracotta)}
.filter-group select{cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1.5L6 6.5L11 1.5' stroke='%23807569' stroke-width='1.5' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
.filter-search{flex:1;min-width:180px}
.filter-search input{width:100%}
.filter-reset{padding:10px 16px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;font-weight:600;border:1px solid var(--line);background:transparent;color:var(--mute);transition:all .2s;display:inline-flex;align-items:center;gap:6px;height:38px;cursor:pointer}
.filter-reset:hover{border-color:var(--terracotta);color:var(--terracotta)}
.filter-count{margin-left:auto;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--mute);font-weight:600;padding-bottom:10px}
.filter-count span{font-family:'DM Serif Display',serif;font-style:italic;color:var(--ink);font-size:18px;letter-spacing:0;text-transform:none;font-weight:400;margin-right:4px}

.empty-state{padding:80px 40px;text-align:center;color:var(--mute);grid-column:1/-1}
.empty-state h3{font-family:'DM Serif Display',serif;font-style:italic;font-size:32px;color:var(--ink);margin:0 0 12px;font-weight:400}
.empty-state p{font-size:14px;margin:0}

/* Grille produits */
.products-grid{padding:36px 56px 60px;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.product-card{background:var(--bone);border:2px solid var(--line);transition:all .25s;position:relative;overflow:hidden;display:flex;flex-direction:column}
.product-card:hover{border-color:var(--clay)}
.product-card.accepted{border-color:var(--green-ok);background:var(--green-tint)}
.product-card.refused{opacity:.45;border-color:var(--red-no);background:var(--bone)}

/* Image */
.product-image{aspect-ratio:1;background:var(--sand);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.product-image img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:var(--sand);opacity:0;transition:opacity .35s ease,transform .4s ease}
.product-card:hover .product-image img.loaded{transform:scale(1.09)}
.product-image img.loaded{opacity:1}
.product-image .ph{font-family:'DM Serif Display',serif;font-style:italic;font-size:60px;color:var(--clay);opacity:.4;position:relative;z-index:1}
.product-image img.loaded + .ph{display:none}
/* Skeleton shimmer pendant lazy-load */
.product-image img.lazy{opacity:0}
.product-image img.lazy::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,var(--sand) 25%,rgba(255,255,255,.35) 50%,var(--sand) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.product-brand-tag{position:absolute;top:14px;left:14px;padding:4px 10px;background:rgba(28,25,21,.85);backdrop-filter:blur(6px);color:var(--bone);font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.18em;text-transform:uppercase;border-radius:100px;font-weight:600;z-index:2}
.product-image .check-overlay{position:absolute;inset:0;background:rgba(74,107,58,.78);display:none;align-items:center;justify-content:center;animation:fadeIn .3s;z-index:3}
.product-card.accepted .product-image .check-overlay{display:flex}
.product-image .check-overlay svg{width:90px;height:90px;color:var(--bone);filter:drop-shadow(0 4px 12px rgba(0,0,0,.3))}
@keyframes fadeIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
.product-card.refused .product-image::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 12px,rgba(168,61,47,.1) 12px,rgba(168,61,47,.1) 24px);z-index:2}

/* Carrousel multi-vues photos produit */
.photo-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:30px;height:30px;border-radius:50%;background:rgba(28,25,21,.55);border:1px solid rgba(255,255,255,.18);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;opacity:0;transition:opacity .2s,background .2s,transform .2s}
.photo-nav.photo-prev{left:8px}
.photo-nav.photo-next{right:8px}
.product-card:hover .photo-nav:not([hidden]){opacity:.92}
.photo-nav:hover{background:var(--terracotta);transform:translateY(-50%) scale(1.07)}
.photo-nav[hidden]{display:none}
.photo-counter{position:absolute;top:10px;right:10px;z-index:4;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.08em;font-weight:700;background:rgba(28,25,21,.66);color:#fff;padding:3px 8px;border-radius:100px;line-height:1.2;pointer-events:none}
.photo-counter[hidden]{display:none}
.photo-thumbs{position:absolute;left:50%;bottom:8px;transform:translateX(-50%);z-index:4;display:flex;gap:5px;padding:5px 6px;background:rgba(28,25,21,.55);border-radius:6px;opacity:0;transition:opacity .2s;backdrop-filter:blur(4px);max-width:calc(100% - 16px)}
.product-card:hover .photo-thumbs:not([hidden]){opacity:1}
.photo-thumbs[hidden]{display:none}
.photo-thumb{width:38px;height:38px;border-radius:4px;border:1.5px solid transparent;padding:0;background:rgba(255,255,255,.06);cursor:pointer;overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s,transform .15s;position:relative}
/* Override de la règle générique `.product-image img` qui force position:absolute,
   opacity:0 et background:var(--sand) — sinon les vignettes sont invisibles. */
.photo-thumb img{position:static;inset:auto;width:100%;height:100%;object-fit:cover;display:block;opacity:1;background:transparent;pointer-events:none;transform:none}
.photo-thumb:hover{border-color:rgba(255,255,255,.7);transform:scale(1.06)}
.photo-thumb.active{border-color:#fff;transform:scale(1.08)}
.product-card.accepted .photo-nav,
.product-card.accepted .photo-counter,
.product-card.accepted .photo-thumbs{display:none !important}

/* Bouton play vidéo argumentaire */
.btn-video-play{position:absolute;bottom:10px;right:10px;z-index:4;background:none;border:none;cursor:pointer;padding:0;line-height:0;opacity:0;transform:translateY(6px) scale(.92);transition:opacity .25s,transform .25s}
.product-card:hover .btn-video-play{opacity:1;transform:translateY(0) scale(1)}
.btn-video-play:hover svg circle{fill:rgba(0,0,0,.8)}
.btn-video-play:focus-visible{outline:2px solid var(--terracotta);outline-offset:2px;border-radius:50%}

/* Modale vidéo */
#videoModal{position:fixed;inset:0;background:rgba(10,8,6,.82);backdrop-filter:blur(6px);z-index:9000;display:none;align-items:center;justify-content:center;padding:24px}
.video-modal-inner{position:relative;width:100%;max-width:900px;background:#000;border-radius:4px;overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,.7)}
.video-modal-close{position:absolute;top:12px;right:12px;z-index:2;background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.2);color:#fff;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .2s}
.video-modal-close:hover{background:rgba(168,61,47,.85)}

.product-body{padding:18px 20px 20px;flex:1;display:flex;flex-direction:column}
.product-name{font-family:'DM Serif Display',serif;font-size:22px;font-weight:400;margin:0 0 4px;line-height:1.15}
.product-ref{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--mute);margin-bottom:14px;font-weight:600}
.product-color{color:var(--terracotta);font-weight:600}

.price-label{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);margin-bottom:6px;font-weight:600}
.product-pricing{display:flex;align-items:baseline;gap:10px;margin-bottom:16px}
.price-current{font-family:'DM Serif Display',serif;font-size:26px;color:var(--terracotta);line-height:1}
.price-was{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--fade);text-decoration:line-through;letter-spacing:.05em}
.price-discount{display:inline-block;background:var(--terracotta);color:var(--bone);font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.12em;padding:3px 8px;border-radius:100px;font-weight:700}

/* Tailles */
.sizes{border-top:1px solid var(--line);padding-top:14px;margin-bottom:14px}
.sizes-label{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--mute);margin-bottom:10px;font-weight:600;display:flex;justify-content:space-between;align-items:center}
.sizes-label .total-pairs{color:var(--ink);font-family:'DM Serif Display',serif;font-style:italic;font-size:14px;letter-spacing:0;text-transform:none;font-weight:400}
.sizes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(46px,1fr));gap:6px}
.size-cell{background:var(--bone-soft);border:1px solid var(--line);padding:4px;text-align:center;transition:border-color .2s}
.size-cell:focus-within{border-color:var(--terracotta)}
.size-cell .s{color:var(--mute);font-size:10px;display:block;line-height:1;margin-bottom:3px;font-family:'JetBrains Mono',monospace;letter-spacing:.05em;font-weight:600}
.size-cell .qty-controls{display:flex;align-items:center;justify-content:space-between;gap:2px}
.size-cell .qty-btn{background:transparent;border:none;color:var(--mute);font-size:14px;cursor:pointer;padding:0;width:14px;line-height:1;transition:color .15s;font-weight:700}
.size-cell .qty-btn:hover{color:var(--terracotta)}
.size-cell .qty-input{width:24px;border:none;background:transparent;text-align:center;font-family:'DM Serif Display',serif;font-size:15px;color:var(--ink);padding:0;font-weight:400}
.size-cell .qty-input:focus{outline:none}
.size-cell .qty-input[type=number]{-moz-appearance:textfield}
.size-cell .qty-input::-webkit-outer-spin-button,.size-cell .qty-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.size-cell .qty-btn:disabled{color:rgba(0,0,0,.18);cursor:not-allowed}
.size-cell .qty-btn:disabled:hover{color:rgba(0,0,0,.18)}
.size-cell .size-cap{display:block;font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--mute);opacity:.55;line-height:1;margin-top:2px;letter-spacing:.04em}

/* Colis standards embarqués dans une sélection (info client) */
.product-colis{
  margin:0 0 14px;padding:9px 11px;
  background:rgba(184,80,66,.045);
  border:1px dashed rgba(184,80,66,.28);
  border-radius:8px;
}
.product-colis .pc-label{
  display:block;
  font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--terracotta,#b85042);
  margin-bottom:6px;
}
.product-colis .pc-list{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:5px}
.product-colis .pc-pill{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 9px;background:#fff;
  border:1px solid rgba(184,80,66,.32);border-radius:100px;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  color:var(--terracotta,#b85042);white-space:nowrap;
}
.product-colis .pc-pill b{font-weight:800;font-size:10.5px;letter-spacing:.04em}
.product-colis .pc-pill .pc-lib{
  color:var(--ink-soft,#3a3530);font-size:9.5px;font-weight:600;
  overflow:hidden;text-overflow:ellipsis;max-width:140px;
}
.product-colis .pc-pill .pc-x{
  font-weight:800;color:#a04032;margin-left:1px;font-size:11px;
}
.product-colis .pc-sub{
  font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--mute);
  letter-spacing:.02em;
}

/* Actions */
.product-actions{display:grid;grid-template-columns:1fr;gap:6px;margin-top:auto}
.btn-action{padding:11px 8px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;border:1px solid var(--line);background:var(--bone-soft);color:var(--ink-soft);transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:5px;cursor:pointer;min-height:44px}
.btn-action:hover{border-color:var(--ink);background:var(--bone)}
.btn-action.selected-accept{background:var(--green-ok);border-color:var(--green-ok);color:var(--bone)}
.btn-action.selected-refuse{background:var(--red-no);border-color:var(--red-no);color:var(--bone)}

/* Saving indicator */
.product-card.saving{opacity:.7;pointer-events:none}

/* ───────────── PANIER LATÉRAL ───────────── */
.cart-aside-head{padding-bottom:20px;border-bottom:1px solid rgba(246,241,233,.15)}
.cart-aside-head .lbl{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--clay);margin-bottom:8px;font-weight:600}
.cart-aside-head .title{font-family:'DM Serif Display',serif;font-size:28px;color:var(--bone);line-height:1;margin:0}
.cart-aside-head .title em{font-style:italic;color:var(--clay)}

.cart-counters{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:rgba(246,241,233,.1)}
.cart-counter{padding:14px 10px;background:var(--ink);text-align:center}
.cart-counter .num{font-family:'DM Serif Display',serif;font-style:italic;font-size:24px;line-height:1;margin-bottom:4px;color:var(--bone)}
.cart-counter .num.green{color:#c3d9a0}
.cart-counter .num.red{color:#e8a896}
.cart-counter .lbl{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:rgba(246,241,233,.5);font-weight:600}

.cart-totals{padding:20px 0;border-top:1px solid rgba(246,241,233,.15);border-bottom:1px solid rgba(246,241,233,.15);display:flex;flex-direction:column;gap:10px}
.cart-totals-row{display:flex;justify-content:space-between;align-items:baseline;font-size:14px;color:rgba(246,241,233,.7)}
.cart-totals-row strong{font-family:'DM Serif Display',serif;font-style:italic;color:var(--bone);font-size:17px;font-weight:400}
.cart-totals-row.big{padding-top:8px;border-top:1px dashed rgba(246,241,233,.15);margin-top:4px}
.cart-totals-row.big strong{font-size:28px;color:var(--clay)}
.cart-totals-row.big .lbl{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--bone);font-weight:600}

.cart-progress{padding:18px 0;font-size:13px;color:rgba(246,241,233,.7)}
.cart-progress .progress-bar{background:rgba(246,241,233,.15);height:6px;border-radius:100px;overflow:hidden;margin:10px 0}
.cart-progress .progress-fill{background:var(--terracotta);height:100%;border-radius:100px;transition:width .3s}
.cart-progress .progress-meta{display:flex;justify-content:space-between;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:rgba(246,241,233,.55);font-weight:600}

.btn-reserve{width:100%;padding:16px 20px;background:var(--terracotta);color:var(--bone);font-family:'DM Serif Display',serif;font-style:italic;font-size:18px;transition:all .25s;display:inline-flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;border:none;min-height:56px}
.btn-reserve:hover:not(:disabled){background:var(--terracotta-deep)}
.btn-reserve:disabled{background:rgba(184,80,66,.3);cursor:not-allowed}
.btn-reserve .arr{transition:transform .3s}
.btn-reserve:hover:not(:disabled) .arr{transform:translateX(5px)}

/* Reserved / Confirmed state */
.selection-reserved-msg{background:var(--green-tint);border:2px solid var(--green-ok);padding:20px 28px;text-align:center;font-family:'DM Serif Display',serif;font-style:italic;font-size:22px;color:var(--green-deep)}
.selection-reserved-msg .sub{font-family:'JetBrains Mono',monospace;font-style:normal;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--green-ok);display:block;margin-bottom:10px;font-weight:600}

/* Footer */
.page-foot{background:var(--ink);color:rgba(246,241,233,.5);padding:40px 56px;text-align:center;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;font-weight:600}
.page-foot .sig{font-family:'DM Serif Display',serif;font-style:italic;font-size:13px;letter-spacing:0;text-transform:none;color:var(--clay);display:block;margin-bottom:6px;font-weight:400}

/* Responsive */
@media (max-width:1200px){
  .detail-layout{grid-template-columns:1fr}
  .detail-aside{position:static;height:auto;border-left:none;border-top:1px solid rgba(246,241,233,.1)}
}
@media (max-width:700px){
  #screen-login{grid-template-columns:1fr}
  .login-left{display:none}
  .products-grid{grid-template-columns:1fr;padding:24px}
  .dash-stats{grid-template-columns:1fr}
  .topbar{padding:14px 24px;min-height:64px;flex-wrap:wrap;row-gap:0}
  .topbar-burger{display:flex;order:3}
  .topbar-user{order:2;margin-left:auto;margin-right:14px}
  /* Nav en tiroir : masquée par défaut, dépliée quand .nav-open */
  .topbar-nav{order:4;display:flex;flex-direction:column;gap:0;width:100%;
    max-height:0;overflow:hidden;transition:max-height var(--t-base) var(--ease)}
  .topbar.nav-open .topbar-nav{max-height:420px;padding-top:8px}
  .topbar-nav a{padding:14px 4px;border-bottom:1px solid rgba(246,241,233,.1)}
  .topbar-nav a.active{border-bottom-color:rgba(246,241,233,.1);color:var(--terracotta)}
  .dash-hero{padding:32px 24px 24px}
  .dash-hero h1{font-size:48px}
  .selections{padding:0 24px 60px}
  .section-head{padding:0 24px 20px}
}

/* ───────────── MON PROFIL ───────────── */
.profile-hero{padding:56px 56px 36px;max-width:1400px;margin:0 auto}
.profile-hero .eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.25em;color:var(--terracotta);text-transform:uppercase;margin-bottom:18px;font-weight:600}
.profile-hero h1{font-family:'DM Serif Display',serif;font-size:58px;font-weight:400;line-height:1;margin:0 0 14px;letter-spacing:-.02em}
.profile-hero h1 em{font-style:italic;color:var(--terracotta)}
.profile-hero p{font-size:15px;color:var(--mute);max-width:520px;line-height:1.6;margin:0}

.profile-layout{max-width:1400px;margin:0 auto;padding:0 56px 80px;display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}
@media(max-width:900px){.profile-layout{grid-template-columns:1fr;padding:0 24px 60px}}
@media(max-width:700px){.profile-hero{padding:32px 24px 24px}.profile-hero h1{font-size:40px}}

.profile-card{background:var(--bone-soft);border:1px solid var(--line);padding:30px 32px;margin-bottom:28px}
.profile-card:last-child{margin-bottom:0}
.profile-card-head{margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.profile-card-head .lbl{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--terracotta);margin-bottom:6px;font-weight:600;display:block}
.profile-card-head h3{font-family:'DM Serif Display',serif;font-size:26px;font-weight:400;margin:0;line-height:1.1}

.pf{margin-bottom:18px}
.pf label{display:block;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:7px;font-weight:600}
.pf input{width:100%;padding:12px 15px;background:#fff;border:1px solid var(--line);font-size:14px;color:var(--ink);transition:border-color .2s,background .2s;font-family:inherit}
.pf input:focus{outline:none;border-color:var(--terracotta);background:#fff}
.pf input[readonly]{background:var(--sand);color:var(--mute);cursor:not-allowed;border-color:var(--line)}
.pf .fn{font-size:11px;color:var(--mute);margin-top:5px;font-family:'JetBrains Mono',monospace;letter-spacing:.05em;line-height:1.4}
.pf-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:500px){.pf-row{grid-template-columns:1fr}}

.btn-save{padding:12px 26px;background:var(--ink);color:var(--bone);font-family:'DM Serif Display',serif;font-style:italic;font-size:16px;transition:background .25s;display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:none;margin-top:6px}
.btn-save:hover{background:var(--terracotta)}
.btn-save:disabled{background:var(--mute);cursor:not-allowed;opacity:.6}
.btn-save .arr{transition:transform .3s}
.btn-save:hover:not(:disabled) .arr{transform:translateX(4px)}

.pf-alert{padding:10px 14px;font-size:13px;margin-bottom:14px;border-left:3px solid;display:none;animation:fadeSlideIn .2s}
.pf-alert.ok{background:var(--green-tint);border-color:var(--green-ok);color:var(--green-deep)}
.pf-alert.err{background:var(--terracotta-soft);border-color:var(--terracotta);color:var(--terracotta-deep)}
.pf-alert.show{display:block}
@keyframes fadeSlideIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}

.profile-email-row{display:flex;align-items:center;gap:10px;padding:12px 15px;background:var(--sand);border:1px solid var(--line);margin-bottom:18px}
.profile-email-row .ico{color:var(--mute);font-size:16px}
.profile-email-row .val{font-size:14px;color:var(--mute);font-family:'JetBrains Mono',monospace;letter-spacing:.04em}
.profile-email-row .note{font-size:11px;color:var(--fade);margin-left:auto;font-family:'JetBrains Mono',monospace;letter-spacing:.06em;text-transform:uppercase;font-weight:600}

/* ───────────── VISITE GUIDÉE ───────────── */
.btn-tour{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;border:1px solid rgba(246,241,233,.18);color:rgba(246,241,233,.55);background:transparent;cursor:pointer;transition:all .2s;flex-shrink:0}
.btn-tour:hover{color:var(--bone);border-color:rgba(246,241,233,.45);background:rgba(246,241,233,.05)}

.tour-overlay{display:none;position:fixed;inset:0;z-index:9990;pointer-events:none}
.tour-overlay.active{display:block;pointer-events:auto}
.tour-spotlight{position:fixed;border-radius:3px;box-shadow:0 0 0 9999px rgba(28,25,21,.82);z-index:9991;pointer-events:none;transition:left .35s cubic-bezier(.25,.8,.25,1),top .35s cubic-bezier(.25,.8,.25,1),width .35s cubic-bezier(.25,.8,.25,1),height .35s cubic-bezier(.25,.8,.25,1)}
.tour-tooltip{position:fixed;z-index:9992;background:var(--bone);border:1px solid var(--line);padding:22px 26px 20px;width:310px;box-shadow:0 12px 48px rgba(28,25,21,.22);opacity:0;transform:translateY(10px);transition:opacity .22s,transform .22s;pointer-events:none}
.tour-tooltip.visible{opacity:1;transform:translateY(0);pointer-events:auto}
.tour-step-badge{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--terracotta);font-weight:700;margin-bottom:8px}
.tour-tooltip h4{font-family:'DM Serif Display',serif;font-size:21px;font-weight:400;margin:0 0 8px;line-height:1.2;letter-spacing:-.01em}
.tour-tooltip p{font-size:13px;color:var(--mute);margin:0 0 18px;line-height:1.6}
.tour-nav{display:flex;align-items:center;justify-content:space-between}
.tour-nav-right{display:flex;gap:8px}
.tour-btn-next{padding:9px 16px;background:var(--ink);color:var(--bone);font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;font-weight:700;border:none;cursor:pointer;transition:background .2s}
.tour-btn-next:hover{background:var(--terracotta)}
.tour-btn-next[data-last]{background:var(--green-ok)}
.tour-btn-next[data-last]:hover{background:var(--green-deep)}
.tour-btn-prev,.tour-btn-skip{padding:9px 12px;background:transparent;color:var(--mute);font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;border:1px solid var(--line);cursor:pointer;transition:all .2s}

/* ───────────── CATALOGUE ACCESS CARDS (dashboard) ───────────── */
.catalog-access{padding:0 56px 52px;max-width:1400px;margin:0 auto}
.catalog-access-eyebrow{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--mute);font-weight:600;margin-bottom:18px}
.catalog-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2px;background:var(--line);border:1px solid var(--line)}
.catalog-card-item{background:var(--bone-soft);text-decoration:none;color:inherit;display:block;transition:background .2s}
.catalog-card-item:not(.catalog-card-closed):hover{background:#fff}
.catalog-card-closed{opacity:.5;cursor:default}
.catalog-card-inner{padding:36px 40px}
.catalog-card-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px;gap:12px}
.catalog-card-tag{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);font-weight:600}
.catalog-card-badge{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.15em;text-transform:uppercase;font-weight:700;padding:3px 12px;border-radius:100px;flex-shrink:0}
.badge-open{background:var(--green-tint);color:var(--green-ok)}
.badge-closed{background:var(--sand);color:var(--mute)}
.catalog-card-title{font-family:'DM Serif Display',serif;font-size:30px;font-weight:400;margin:0 0 8px;line-height:1.1;letter-spacing:-.01em}
.catalog-card-title-em{font-style:italic;color:var(--terracotta)}
.catalog-card-sub{font-size:14px;color:var(--mute);line-height:1.55;margin-bottom:22px;max-width:360px}
.catalog-card-cta{display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;color:var(--terracotta)}
.cta-arr{transition:transform .25s;display:inline-block}
.catalog-card-item:hover .cta-arr{transform:translateX(6px)}
@media(max-width:700px){.catalog-access{padding:0 24px 36px}.catalog-card-inner{padding:24px 20px}.catalog-card-title{font-size:24px}}

/* ───────────── CATALOGUE PAGES (stock physique + ES) ───────────── */
.catalog-hero{padding:40px 56px 28px;max-width:1400px;margin:0 auto}
.catalog-hero .eyebrow{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--terracotta);font-weight:600;margin-bottom:16px}
.catalog-hero h1{font-family:'DM Serif Display',serif;font-size:52px;font-weight:400;line-height:1;margin:0 0 14px;letter-spacing:-.02em}
.catalog-hero h1 em{font-style:italic;color:var(--terracotta)}
.catalog-hero .lead{font-size:15px;color:var(--mute);max-width:560px;line-height:1.6;margin:0}
.catalog-hero-meta{display:flex;gap:16px;flex-wrap:wrap;margin-top:16px}
.catalog-hero-tag{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;padding:4px 12px;border:1px solid var(--line);color:var(--mute)}

/* Catalogue layout 2-col with sticky cart sidebar */
.catalog-layout{display:grid;grid-template-columns:1fr 320px;gap:0;min-height:calc(100vh - 80px);align-items:start}
.catalog-content{min-width:0;border-right:1px solid var(--line)}
.catalog-sidebar{position:sticky;top:var(--topbar-h);height:calc(100vh - var(--topbar-h));overflow-y:auto;background:var(--ink);color:var(--bone);padding:28px 24px;display:flex;flex-direction:column;gap:20px}
/* Bloc d'actions toujours visible (épinglé en bas de la sidebar) */
.cs-actions{flex-shrink:0;display:flex;flex-direction:column;gap:10px;position:sticky;bottom:0;
  background:var(--ink);padding-top:14px;margin-top:4px;
  box-shadow:0 -16px 20px -8px var(--ink)}
.catalog-sidebar .cs-lbl{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--clay);font-weight:600;margin-bottom:6px}
.catalog-sidebar .cs-title{font-family:'DM Serif Display',serif;font-size:26px;line-height:1;margin:0;color:var(--bone)}
.catalog-sidebar .cs-title em{font-style:italic;color:var(--clay)}
.cs-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(246,241,233,.1);margin:0 -24px}
.cs-stat{background:var(--ink);padding:14px 16px;text-align:center}
.cs-stat .n{font-family:'DM Serif Display',serif;font-style:italic;font-size:28px;color:var(--clay);line-height:1;margin-bottom:3px}
.cs-stat .l{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:rgba(246,241,233,.45);font-weight:600}
.cs-cart-items{flex:1;overflow-y:auto;min-height:0}
.cs-cart-item{padding:10px 0;border-bottom:1px solid rgba(246,241,233,.1);font-size:12px}
.cs-cart-item .ref{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;color:rgba(246,241,233,.5);margin-bottom:2px}
.cs-cart-item .nom{color:var(--bone);font-weight:500;margin-bottom:4px}
.cs-cart-item .sizes-row{display:flex;flex-wrap:wrap;gap:4px}
.cs-cart-item .sz-chip{font-family:'JetBrains Mono',monospace;font-size:9px;padding:2px 6px;background:rgba(246,241,233,.08);color:var(--clay);border-radius:3px;letter-spacing:.05em}
.cs-empty{padding:32px 0;text-align:center;color:rgba(246,241,233,.3);font-family:'DM Serif Display',serif;font-style:italic;font-size:18px}
.btn-submit-order{flex-shrink:0;width:100%;padding:14px 18px;background:var(--terracotta);color:var(--bone);font-family:'DM Serif Display',serif;font-style:italic;font-size:17px;border:none;cursor:pointer;transition:all .25s;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-submit-order:hover:not(:disabled){background:var(--terracotta-deep)}
.btn-submit-order:disabled{background:rgba(184,80,66,.25);cursor:not-allowed;opacity:.6}
.btn-submit-order .arr{transition:transform .3s}
.btn-submit-order:hover:not(:disabled) .arr{transform:translateX(4px)}
.btn-reset-order{flex-shrink:0;width:100%;padding:10px;background:transparent;border:1px solid rgba(246,241,233,.15);color:rgba(246,241,233,.4);font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;cursor:pointer;transition:all .2s}
.btn-reset-order:hover{color:var(--bone);border-color:rgba(246,241,233,.35)}
/* Bouton brouillon */
.btn-save-draft{flex-shrink:0;width:100%;padding:9px;background:transparent;border:1px solid rgba(246,241,233,.2);color:rgba(246,241,233,.55);font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px}
.btn-save-draft:hover:not(:disabled){color:var(--clay);border-color:var(--clay)}
.btn-save-draft:disabled{opacity:.3;cursor:not-allowed}
.btn-save-draft.saved{color:#5cb85c;border-color:#5cb85c}

/* ── CATALOG FILTERS BAR ── */
.cat-filters{position:sticky;top:0;z-index:50;background:var(--bone);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px 56px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.cat-filters-input{flex:1;min-width:240px;font-family:'Inter',sans-serif;font-size:13px;padding:9px 14px;background:#fff;border:1px solid var(--line);color:var(--ink);border-radius:2px;outline:none;transition:border-color .15s}
.cat-filters-input:focus{border-color:var(--terracotta)}
.cat-filters-select{font-family:'Inter',sans-serif;font-size:12px;padding:9px 12px;background:#fff;border:1px solid var(--line);color:var(--ink);border-radius:2px;cursor:pointer;outline:none;min-width:140px;transition:border-color .15s}
.cat-filters-select:focus{border-color:var(--terracotta)}
.cat-filters-reset{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;font-weight:600;padding:9px 14px;background:transparent;border:1px solid var(--line);color:var(--mute);cursor:pointer;border-radius:2px;transition:all .15s}
.cat-filters-reset:hover{border-color:var(--terracotta);color:var(--terracotta)}
.cat-filters-count{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.12em;color:var(--mute);font-weight:600;margin-left:auto;white-space:nowrap}
.cat-filters-count strong{color:var(--ink);font-weight:700}
.cat-card.hidden{display:none}
.cat-empty-state{padding:60px 20px;text-align:center;color:var(--mute);font-style:italic;grid-column:1/-1}
@media (max-width:768px){
  .cat-filters{padding:12px 16px}
  .cat-filters-input{min-width:100%}
  .cat-filters-select{flex:1;min-width:0}
}

/* ─────────────────────────────────────────────────────────────────────────
   PRODUCT CARDS v3 — Layout e-commerce : photo grande au-dessus + méta
   ──────────────────────────────────────────────────────────────────────────
   Utilisé par : entree_saison.php (precommande libre)
                 catalogue_stock.php (réassort, qty bornée stock)
   Composant unifié, le HTML reste identique :
     .cat-card > .cat-card-top > [.cat-card-img-wrap > img + overlays] + .cat-card-meta
                > .cat-card-sizes (chips pointures)
                > .cat-card-total
*/
.cat-cards-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(270px,1fr));
  gap:16px;
  padding:18px 56px 40px;
  background:transparent;
}

.cat-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:6px;
  display:flex;flex-direction:column;
  overflow:hidden;
  transition:border-color .18s,box-shadow .18s,transform .18s;
  /* Perf : skip rendering des cartes hors-vue (gain massif sur 700+ items) */
  content-visibility:auto;contain-intrinsic-size:0 470px;
}
.cat-card:hover{border-color:var(--clay);box-shadow:0 6px 22px rgba(0,0,0,.06)}
.cat-card.has-qty{border-color:var(--terracotta);box-shadow:0 6px 22px rgba(184,80,66,.18)}

/* ── Bloc top : conteneur photo (display:block, plus de flex row) ── */
.cat-card-top{display:block;padding:0;position:relative}

/* Wrapper photo (sert d'ancre pour overlays badge vidéo / multi-vues / stock) */
.cat-card-img-wrap{
  position:relative;
  width:100%;
  aspect-ratio:1/1;
  max-height:280px;
  background:var(--sand);
  overflow:hidden;
  border-bottom:1px solid var(--line);
  cursor:zoom-in;
}
.cat-card-img-wrap::after{
  /* loupe discrète au survol pour signaler l'ouverture de la fiche */
  content:'';position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;
  background:rgba(255,255,255,.85) center / 14px no-repeat
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231c1915' stroke-width='2.4' stroke-linecap='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.5-3.5'/%3E%3C/svg%3E");
  opacity:0;transition:opacity .2s;pointer-events:none;z-index:2;
  box-shadow:0 2px 6px rgba(0,0,0,.18);
}
.cat-card-img-wrap:hover::after{opacity:1}
/* Si un badge stock occupe le coin haut-droite, on planque la loupe (évite chevauchement) */
.cat-card-img-wrap:has(> .cat-card-badge)::after{display:none}
.cat-card-img-wrap .cat-card-img,
.cat-card-img-wrap .cat-card-img-ph{
  width:100%;height:100%;display:block;object-fit:contain;
}
.cat-card-img-wrap .cat-card-img{transition:transform .4s ease}
.cat-card:hover .cat-card-img-wrap .cat-card-img{transform:scale(1.05)}
.cat-card-img-wrap .cat-card-img-ph{
  display:flex;align-items:center;justify-content:center;
  font-size:68px;color:var(--clay);background:var(--sand);
}
.cat-card-img-wrap .cat-card-img-ph.no-photo{
  flex-direction:column;gap:8px;
  background:#f8f8f6;color:var(--mute);
  font-size:11px;font-weight:500;text-align:center;line-height:1.4;padding:16px;
}

/* Fallback : HTML legacy sans .cat-card-img-wrap (catalogue_stock pré-refonte) */
.cat-card-top > .cat-card-img:not(.cat-card-img-wrap *),
.cat-card-top > .cat-card-img-ph:not(.cat-card-img-wrap *){
  width:100%;aspect-ratio:1/1;max-height:280px;object-fit:contain;
  background:var(--sand);border-bottom:1px solid var(--line);display:block;
}

/* ── Méta sous la photo ── */
.cat-card-meta{
  padding:14px 16px 6px;
  display:flex;flex-direction:column;
  flex:initial;min-width:0;
}
.cat-card-brand{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--terracotta);font-weight:700;margin-bottom:5px}
.cat-card-name{font-family:'DM Serif Display',serif;font-size:20px;font-weight:400;line-height:1.15;margin:0 0 3px;color:var(--ink);letter-spacing:-.005em}
.cat-card-ref{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--mute);letter-spacing:.06em;margin-bottom:4px}
.cat-card-color{font-size:12.5px;color:var(--mute);margin-bottom:6px;line-height:1.3}
.cat-card-price{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-soft);letter-spacing:.04em;margin-top:auto;padding-top:4px}
.cat-card-dispo{display:inline-flex;align-items:center;gap:5px;margin-top:7px;font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--green-ok);background:var(--green-tint);padding:3px 9px;border-radius:100px;width:fit-content}

/* ── Bandeau colis standards AS400 (interactif) ── */
.cat-card-colis{
  display:flex;align-items:center;gap:8px;
  padding:10px 16px;
  border-top:1px solid var(--line);
  background:rgba(184,80,66,.025);
  flex-wrap:nowrap;
}
/* Sélecteur de date de livraison (créneaux prédéfinis) */
.cat-card-delivery{
  display:flex;align-items:center;gap:10px;
  padding:10px 16px;border-top:1px solid var(--line);
  background:rgba(74,107,58,.04);
}
.cat-card-delivery .ccd-label{
  display:inline-flex;align-items:center;gap:5px;flex:0 0 auto;
  font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--ok-deep);
}
.cat-card-delivery .ccd-select{
  flex:1 1 auto;min-width:0;padding:7px 10px;
  border:1px solid var(--line);border-radius:var(--radius-control);
  background:#fff;font-family:inherit;font-size:12px;font-weight:600;color:var(--ink);
  cursor:pointer;transition:border-color var(--t-fast);
}
.cat-card-delivery .ccd-select:hover{border-color:var(--ok)}
.cat-card-colis .cccs-label{
  flex:0 0 auto;
  font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);
}
/* Conteneur des pills : scrolle horizontalement si plus de 2 colis */
.cat-card-colis .cccs-row{
  flex:1 1 auto;min-width:0;
  display:flex;align-items:center;gap:6px;
  overflow-x:auto;flex-wrap:nowrap;
  scrollbar-width:thin;
  padding:2px 8px 2px 0;
}
.cat-card-colis .cccs-row::-webkit-scrollbar{height:4px}
.cat-card-colis .cccs-row::-webkit-scrollbar-thumb{background:rgba(184,80,66,.25);border-radius:2px}
.cat-card-colis .cccs-pill{
  display:inline-flex;align-items:center;gap:5px;flex-shrink:0;
  padding:3px 4px 3px 10px;background:#fff;
  border:1.5px solid rgba(184,80,66,.32);border-radius:100px;
  white-space:nowrap;
  transition:border-color .15s, background .15s, box-shadow .15s;
}
.cat-card-colis .cccs-pill.has-qty{
  border-color:var(--terracotta,#b85042);
  background:var(--terracotta-soft,rgba(184,80,66,.08));
  box-shadow:0 2px 6px rgba(184,80,66,.18);
}
.cat-card-colis .cccs-pill b{
  font-family:'JetBrains Mono',monospace;font-weight:800;font-size:11px;
  letter-spacing:.06em;color:var(--terracotta-deep,#a04032);
}
.cat-card-colis .cccs-pill .cccs-lib{
  font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--ink-soft);
  overflow:hidden;text-overflow:ellipsis;max-width:140px;
}
/* Stepper inline (au bout de chaque pill) */
.cat-card-colis .cccs-step{
  display:inline-flex;align-items:center;gap:1px;
  margin-left:3px;background:#fff;border-radius:100px;padding:1px;
  border:1px solid rgba(184,80,66,.18);
}
.cat-card-colis .cccs-pill.has-qty .cccs-step{background:#fffcf5;border-color:rgba(184,80,66,.35)}
.cat-card-colis .cccs-btn{
  width:18px;height:18px;border-radius:50%;
  border:none;background:transparent;
  font-size:13px;line-height:1;color:var(--ink-soft);font-weight:700;
  cursor:pointer;padding:0;
  display:flex;align-items:center;justify-content:center;
  transition:all .12s;font-family:inherit;
}
.cat-card-colis .cccs-btn:hover:not(:disabled){
  background:var(--terracotta,#b85042);color:#fff;
}
.cat-card-colis .cccs-btn:disabled{
  opacity:.28;cursor:not-allowed;
}
.cat-card-colis .cccs-pill.has-qty .cccs-btn{
  border-color:rgba(184,80,66,.3);
}
.cat-card-colis .cccs-q{
  font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;
  color:var(--ink);min-width:14px;text-align:center;line-height:1;
}
.cat-card-colis .cccs-pill.has-qty .cccs-q{color:var(--terracotta-deep,#a04032)}

/* ── Chips tailles : grille compacte sous la méta ── */
.cat-card-sizes{
  padding:10px 16px 14px;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(56px,1fr));
  gap:6px;
  border-top:1px solid var(--line);
}

.cat-chip{display:flex;flex-direction:column;align-items:center;background:var(--bone);border:1.5px solid var(--line);border-radius:6px;padding:6px 4px 4px;min-width:0;cursor:default;transition:border-color .15s,background .15s}
.cat-chip.has-qty{border-color:var(--terracotta);background:var(--terracotta-soft)}
.cat-chip.no-stock{opacity:.3;pointer-events:none}

.cat-chip-size{font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:700;color:var(--ink);line-height:1;margin-bottom:2px}
.cat-chip-price{font-family:'Inter',sans-serif;font-size:9.5px;font-weight:600;color:var(--terracotta);line-height:1;margin-bottom:3px;letter-spacing:.02em}
.cat-chip-stock{font-family:'JetBrains Mono',monospace;font-size:8.5px;font-weight:600;color:var(--green-ok);line-height:1;margin-bottom:5px;letter-spacing:.04em}
.cat-chip.has-qty .cat-chip-stock{color:var(--terracotta-deep)}

.cat-chip-stepper{display:flex;align-items:center;gap:3px;margin-top:auto}
.cat-step-btn{width:20px;height:20px;border-radius:50%;border:1.5px solid var(--line);background:var(--bone-soft);color:var(--ink-soft);font-size:13px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s;padding:0;font-family:inherit;flex-shrink:0}
.cat-step-btn:hover{border-color:var(--terracotta);color:var(--terracotta);background:var(--terracotta-soft)}
.cat-step-btn:disabled{opacity:.25;cursor:not-allowed;pointer-events:none}
.cat-chip.has-qty .cat-step-btn{border-color:rgba(184,80,66,.3);background:rgba(184,80,66,.06)}
.cat-chip.has-qty .cat-step-btn:hover{background:var(--terracotta);color:#fff;border-color:var(--terracotta)}

.cat-chip-qty{font-family:'JetBrains Mono',monospace;font-size:14px;font-weight:700;color:var(--ink);min-width:20px;text-align:center;line-height:1}
.cat-chip.has-qty .cat-chip-qty{color:var(--terracotta-deep)}

/* Card footer: total line */
.cat-card-total{padding:0 16px 14px;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;color:var(--terracotta);letter-spacing:.1em;min-height:18px}

@media(max-width:900px){
  .catalog-layout{grid-template-columns:1fr}
  .catalog-sidebar{position:static;height:auto}
  .catalog-hero{padding:28px 24px 20px}.catalog-hero h1{font-size:36px}
  .cat-cards-grid{grid-template-columns:1fr}
}
@media(max-width:600px){.cat-card-top{padding:14px 14px 10px}.cat-card-sizes{padding:0 10px 14px}}
.tour-btn-prev:hover,.tour-btn-skip:hover{border-color:var(--ink);color:var(--ink)}

/* ───────────── MODALE CONFIRMATION RÉSERVATION ───────────── */
.rm-overlay{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  background:rgba(28,25,21,.72);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  animation:rm-fade .18s ease-out;
}
.rm-overlay[hidden]{display:none}
@keyframes rm-fade{from{opacity:0}}
@keyframes rm-pop{from{opacity:0;transform:translateY(8px) scale(.97)}}
.rm-card{
  background:var(--bone);
  width:100%;max-width:480px;
  padding:36px 40px 32px;
  position:relative;
  box-shadow:0 24px 64px rgba(0,0,0,.32),0 4px 12px rgba(0,0,0,.18);
  animation:rm-pop .22s cubic-bezier(.22,.9,.2,1);
}
.rm-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:var(--terracotta);
}
.rm-eye{
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--terracotta);font-weight:700;margin-bottom:10px;
}
.rm-card h2{
  font-family:'DM Serif Display',serif;font-weight:400;
  font-size:30px;line-height:1.1;color:var(--ink);margin:0 0 24px;
  letter-spacing:-.01em;
}
.rm-card h2 em{font-style:italic;color:var(--terracotta)}

.rm-stats{
  display:grid;grid-template-columns:1fr auto 1fr;gap:14px;
  align-items:center;margin-bottom:22px;
}
.rm-stat{
  text-align:center;padding:16px 12px;border:1px solid var(--line);
  background:var(--bone-soft);
}
.rm-stat-ok{border-color:rgba(74,107,58,.4);background:var(--green-tint)}
.rm-stat-warn{border-color:rgba(184,80,66,.32);background:var(--terracotta-soft)}
.rm-stat-num{
  font-family:'DM Serif Display',serif;font-size:38px;font-weight:400;
  line-height:1;color:var(--ink);letter-spacing:-.02em;
}
.rm-stat-ok .rm-stat-num{color:var(--green-deep)}
.rm-stat-warn .rm-stat-num{color:var(--terracotta-deep)}
.rm-stat-lbl{
  font-family:'JetBrains Mono',monospace;font-size:9.5px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--mute);font-weight:600;
  margin-top:8px;line-height:1.35;
}
.rm-stat-sep{
  font-family:'DM Serif Display',serif;font-size:24px;color:var(--mute);
  text-align:center;line-height:1;
}

.rm-text{
  font-size:13.5px;color:var(--ink-soft);line-height:1.55;margin:0 0 26px;
}
.rm-text strong{color:var(--ink)}

.rm-actions{display:grid;grid-template-columns:1fr 2fr;gap:10px}
.rm-btn{
  padding:14px 18px;font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:.16em;text-transform:uppercase;font-weight:700;
  border:1px solid var(--line);background:var(--bone-soft);color:var(--ink-soft);
  cursor:pointer;transition:all .18s;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
}
.rm-btn-cancel:hover{border-color:var(--ink);color:var(--ink);background:var(--bone)}
.rm-btn-confirm{
  background:var(--terracotta);border-color:var(--terracotta);color:#fff;
  font-family:'DM Serif Display',serif;font-style:italic;font-size:15px;
  letter-spacing:0;text-transform:none;font-weight:400;
}
.rm-btn-confirm:hover{background:var(--terracotta-deep);border-color:var(--terracotta-deep)}
.rm-btn-confirm .arr{transition:transform .25s}
.rm-btn-confirm:hover .arr{transform:translateX(4px)}
.rm-btn:disabled{opacity:.55;cursor:wait}

@media(max-width:520px){
  .rm-card{padding:28px 24px 24px}
  .rm-card h2{font-size:24px}
  .rm-stat-num{font-size:30px}
  .rm-actions{grid-template-columns:1fr;gap:8px}
}

/* ── Badges statut produit (stock épuisé / en production) ──
   Positionnement absolu DANS le wrap photo (haut-droite, opposé au badge
   vidéo qui est haut-gauche, et hors zone du strip multi-vues qui apparait
   en bas au hover). */
.cat-card-img-wrap .cat-card-badge{
  position:absolute;
  top:8px;right:8px;
  margin-top:0;
  backdrop-filter:blur(4px);
  z-index:3;
}
.cat-card-badge{
  display:inline-block;margin-top:7px;padding:3px 8px;
  font-family:'JetBrains Mono',monospace;font-size:9.5px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;border-radius:3px;
  line-height:1.5;
}
.badge-en-production{
  background:rgba(184,120,10,.92);color:#fff;
  border:1px solid rgba(184,120,10,.4);
}
.badge-epuise{
  background:rgba(184,80,66,.92);color:#fff;
  border:1px solid rgba(184,80,66,.4);
}



/* ════════════════════════════════════════════════════════════════════════
   Multi-vues photos + Badge vidéo + Player overlay (catalogues PRO)
   Utilisé par : entree_saison.php, catalogue_stock.php
   ════════════════════════════════════════════════════════════════════════ */
.cat-photo-strip{
  position:absolute;left:0;right:0;bottom:0;display:flex;gap:5px;
  padding:6px 8px;background:linear-gradient(0deg,rgba(0,0,0,.6),rgba(0,0,0,0));
  max-height:0;opacity:0;overflow:hidden;pointer-events:none;
  transition:max-height .25s ease,opacity .2s ease;z-index:2;
}
.cat-card-img-wrap:hover .cat-photo-strip{max-height:46px;opacity:1;pointer-events:all}
.cat-v-dot{
  width:32px;height:32px;border-radius:5px;background-size:cover;background-position:center;
  border:2px solid rgba(255,255,255,.55);cursor:pointer;flex-shrink:0;
  transition:transform .15s,border-color .15s;position:relative;
}
.cat-v-dot:hover{transform:scale(1.08);border-color:#fff}
.cat-v-dot.cat-v-active{border-color:var(--terracotta,#b85042);box-shadow:0 0 0 2px rgba(184,80,66,.35)}
.cat-v-dot-num{
  position:absolute;top:1px;right:2px;font-family:'JetBrains Mono',monospace;font-size:8px;
  color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.6);font-weight:700;
}
.cat-vid-badge{
  position:absolute;top:8px;left:8px;z-index:4;display:inline-flex;align-items:center;gap:5px;
  padding:4px 9px;border-radius:100px;background:rgba(167,139,250,.92);backdrop-filter:blur(6px);
  color:#fff;font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;cursor:pointer;border:none;box-shadow:0 2px 10px rgba(124,58,237,.35);
  transition:all .18s;white-space:nowrap;
}
.cat-vid-badge:hover{background:rgba(124,58,237,.95);transform:scale(1.06);box-shadow:0 4px 16px rgba(124,58,237,.5)}
.cat-vid-badge svg{flex-shrink:0}

/* Player vidéo overlay (shared) */
.pro-player-bg{
  position:fixed;inset:0;z-index:9999;background:rgba(15,17,21,.88);backdrop-filter:blur(10px);
  display:none;align-items:center;justify-content:center;padding:24px;
}
.pro-player-bg.open{display:flex;animation:fadeIn .15s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.pro-player-modal{
  background:#0d1117;border-radius:14px;max-width:1120px;width:100%;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.5);position:relative;
}
.pro-player-head{
  padding:14px 22px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:14px;
  color:#fff;
}
.pro-player-head .ttl{flex:1}
.pro-player-head .ttl h3{font-family:'DM Serif Display',serif;font-style:italic;font-size:20px;margin:0;color:#fff}
.pro-player-head .ttl .meta{font-family:'JetBrains Mono',monospace;font-size:9.5px;letter-spacing:.12em;color:rgba(255,255,255,.55);margin-top:3px}
.pro-player-close{
  background:rgba(255,255,255,.06);color:#fff;border:none;width:34px;height:34px;border-radius:50%;
  font-size:18px;cursor:pointer;display:grid;place-items:center;transition:all .15s;
}
.pro-player-close:hover{background:rgba(255,255,255,.14)}
.pro-player-video{width:100%;display:block;background:#000;max-height:75vh}
.pro-vid-list{display:flex;gap:8px;padding:12px 22px;background:#0d1117;border-top:1px solid rgba(255,255,255,.06);flex-wrap:wrap}
.pro-vid-chip{
  font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;padding:6px 12px;background:rgba(255,255,255,.05);color:rgba(255,255,255,.75);
  border:1px solid rgba(255,255,255,.1);border-radius:100px;cursor:pointer;transition:all .15s;
}
.pro-vid-chip:hover{background:rgba(255,255,255,.1);color:#fff}
.pro-vid-chip.active{background:rgba(167,139,250,.18);color:rgba(167,139,250,.95);border-color:rgba(167,139,250,.35)}

/* ════════════════════════════════════════════════════════════════════════
   Fiche produit (modal au clic sur la photo d'une .cat-card)
   ════════════════════════════════════════════════════════════════════════ */
.product-sheet-bg{
  position:fixed;inset:0;z-index:9998;background:rgba(28,25,21,.78);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;padding:24px;
}
.product-sheet-bg.open{display:flex;animation:fadeIn .18s ease}
.product-sheet-modal{
  background:var(--bone);max-width:980px;width:100%;max-height:90vh;
  overflow:hidden;border-radius:6px;display:grid;grid-template-columns:1fr 1fr;
  box-shadow:0 30px 80px rgba(0,0,0,.45);position:relative;
}
.ps-close{
  position:absolute;top:14px;right:14px;z-index:5;width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.92);color:var(--ink);border:1px solid var(--line);
  font-size:20px;line-height:1;cursor:pointer;display:grid;place-items:center;transition:all .15s;
}
.ps-close:hover{background:#fff;border-color:var(--ink);transform:scale(1.05)}
.ps-photo-col{background:var(--sand);position:relative;overflow:hidden;min-height:380px}
.ps-photo-img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:contain;display:block;
}
.ps-photo-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:80px;color:var(--clay)}
.ps-photo-strip{
  position:absolute;left:0;right:0;bottom:0;display:flex;gap:6px;
  padding:10px 14px;background:linear-gradient(0deg,rgba(0,0,0,.55),rgba(0,0,0,0));
}
.ps-photo-strip .cat-v-dot{width:46px;height:46px}
.ps-info-col{padding:38px 36px 28px;display:flex;flex-direction:column;overflow-y:auto;max-height:90vh}
.ps-brand{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--terracotta);font-weight:700;margin-bottom:8px}
.ps-name{font-family:'DM Serif Display',serif;font-size:32px;font-weight:400;line-height:1.05;color:var(--ink);margin:0 0 8px;letter-spacing:-.01em}
.ps-ref{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--mute);letter-spacing:.06em;margin-bottom:18px}
.ps-meta-grid{display:grid;grid-template-columns:auto 1fr;gap:8px 18px;font-size:13px;margin-bottom:22px;padding-bottom:20px;border-bottom:1px solid var(--line)}
.ps-meta-grid dt{font-family:'JetBrains Mono',monospace;font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--mute);font-weight:600;align-self:start;padding-top:2px}
.ps-meta-grid dd{margin:0;color:var(--ink);font-weight:500}
.ps-prices{display:flex;gap:24px;margin-bottom:16px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.ps-price-block{flex:1}
.ps-price-lbl{font-family:'JetBrains Mono',monospace;font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--mute);font-weight:600;margin-bottom:4px}
.ps-price-val{font-family:'DM Serif Display',serif;font-style:italic;font-size:24px;color:var(--ink);line-height:1}
.ps-sizes-title{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);font-weight:700;margin:0 0 10px}
.ps-sizes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:8px}
.ps-size-cell{padding:8px 4px;background:var(--bone-soft);border:1px solid var(--line);border-radius:6px;text-align:center}
.ps-size-cell .s{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:700;color:var(--ink);line-height:1;display:block;margin-bottom:3px}
.ps-size-cell .p{font-size:10px;color:var(--terracotta);font-weight:600}
.ps-size-cell .q{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--green-ok);font-weight:600;margin-top:2px}
.ps-status-pill{display:inline-block;align-self:flex-start;margin-bottom:18px;padding:4px 10px;border-radius:100px;font-family:'JetBrains Mono',monospace;font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:700}
.ps-status-pill.s-prod{background:rgba(184,120,10,.12);color:#9a6800;border:1px solid rgba(184,120,10,.3)}
.ps-status-pill.s-epu{background:rgba(184,80,66,.1);color:var(--terracotta-deep);border:1px solid rgba(184,80,66,.28)}

@media(max-width:760px){
  .product-sheet-modal{grid-template-columns:1fr;max-height:95vh}
  .ps-photo-col{min-height:280px;max-height:40vh}
  .ps-info-col{padding:24px 22px 20px;max-height:55vh}
  .ps-name{font-size:24px}
}
