/* ============================================================
   Épicerie des Résistants — CSS
============================================================ */
:root {
  --ardoise:#2c3530;--ardoise-lg:#3e4e46;--creme:#f5f0e8;--creme-lg:#faf7f2;
  --mousse:#5a7a52;--mousse-lg:#7a9e70;--terre:#9d4a3f;--ocre:#c79a3a;
  --bleu-fc:#3a60aa;--gris:#8a8a8a;--gris-lg:#e8e4dc;--blanc:#ffffff;
  --font-display:'Libre Baskerville',Georgia,serif;
  --font-body:'DM Sans',system-ui,sans-serif;
  --shadow-sm:0 1px 3px rgba(44,53,48,.10);--shadow-md:0 4px 16px rgba(44,53,48,.12);
  --radius:8px;--radius-lg:14px;--sidebar-w:240px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-body);background:var(--creme);color:var(--ardoise);font-size:14px;line-height:1.5}

/* LOGIN */
.page-login{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative}
.login-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 20% 80%,rgba(90,122,82,.18) 0%,transparent 60%),radial-gradient(ellipse 60% 80% at 80% 20%,rgba(58,96,170,.10) 0%,transparent 60%),var(--creme)}
.login-card{position:relative;background:var(--blanc);border-radius:var(--radius-lg);padding:44px 40px;width:100%;max-width:400px;box-shadow:var(--shadow-md);border:1px solid var(--gris-lg)}
.login-logo{text-align:center;margin-bottom:32px}
.logo-icon{font-size:36px;display:block;margin-bottom:8px}
.login-logo h1{font-family:var(--font-display);font-size:18px;font-weight:700}
.login-logo p{font-size:12px;color:var(--gris);margin-top:4px;letter-spacing:.05em;text-transform:uppercase}

/* APP */
#app{display:flex;min-height:100vh}

/* SIDEBAR */
.sidebar{width:var(--sidebar-w);min-height:100vh;background:var(--ardoise);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100}
.sidebar-header{padding:20px 20px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.08);font-size:22px}
.sidebar-title{font-family:var(--font-display);color:var(--creme);font-size:15px;font-weight:700}
.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}
.nav-section-label{display:block;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.35);padding:12px 20px 4px}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 20px;color:rgba(255,255,255,.65);text-decoration:none;font-size:13.5px;transition:all .15s;border-left:2px solid transparent}
.nav-item:hover{color:var(--creme);background:rgba(255,255,255,.06)}
.nav-item.active{color:var(--creme);background:rgba(90,122,82,.25);border-left-color:var(--mousse-lg)}
.sidebar-footer{padding:16px 20px;border-top:1px solid rgba(255,255,255,.08)}
.user-info{font-size:12px;color:rgba(255,255,255,.5);margin-bottom:8px;line-height:1.4}
.user-info strong{display:block;color:rgba(255,255,255,.8);font-size:13px}
.btn-logout{width:100%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.6);padding:7px 12px;border-radius:var(--radius);font-size:12px;cursor:pointer;font-family:var(--font-body);transition:all .15s}
.btn-logout:hover{background:rgba(157,74,63,.3);color:var(--creme);border-color:transparent}

/* MAIN */
.main-content{margin-left:var(--sidebar-w);flex:1;min-height:100vh;padding:32px 36px;max-width:calc(100vw - var(--sidebar-w))}

/* PAGE HEADER */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;gap:16px;flex-wrap:wrap}
.page-title h2{font-family:var(--font-display);font-size:22px;font-weight:700}
.page-title p{font-size:13px;color:var(--gris);margin-top:3px}
.page-actions{display:flex;gap:8px;align-items:center}
.section-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--gris)}

/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:28px}
.stat-card{background:var(--blanc);border:1px solid var(--gris-lg);border-radius:var(--radius-lg);padding:20px 22px;box-shadow:var(--shadow-sm)}
.stat-value{font-family:var(--font-display);font-size:32px;font-weight:700;line-height:1}
.stat-label{font-size:11.5px;color:var(--gris);margin-top:6px;text-transform:uppercase;letter-spacing:.05em}
.stat-bleu .stat-value{color:var(--bleu-fc)}
.stat-mousse .stat-value{color:var(--mousse)}

/* TOOLBAR */
.toolbar{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap;align-items:center}
.search-input{flex:1;min-width:200px;max-width:320px;padding:9px 14px 9px 36px;border:1px solid var(--gris-lg);border-radius:var(--radius);font-size:13.5px;background:var(--blanc) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238a8a8a' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E") no-repeat 11px center;font-family:var(--font-body);color:var(--ardoise);transition:border-color .15s}
.search-input:focus{outline:none;border-color:var(--mousse)}
.filter-select{padding:9px 14px;border:1px solid var(--gris-lg);border-radius:var(--radius);font-size:13.5px;background:var(--blanc);font-family:var(--font-body);color:var(--ardoise);cursor:pointer}

/* TABLE */
.table-wrap{background:var(--blanc);border:1px solid var(--gris-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}
.data-table{width:100%;border-collapse:collapse}
.data-table thead tr{background:var(--creme-lg);border-bottom:1px solid var(--gris-lg)}
.data-table th{text-align:left;padding:11px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--gris);white-space:nowrap}
.data-table td{padding:12px 16px;border-bottom:1px solid var(--gris-lg);font-size:13.5px}
.data-table tr:last-child td{border-bottom:none}
.data-table tbody tr:hover{background:var(--creme-lg)}
.td-actions{white-space:nowrap;text-align:right}

/* BADGES */
.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:99px;font-size:11px;font-weight:600}
.badge-green{background:rgba(90,122,82,.12);color:var(--mousse)}
.badge-red{background:rgba(157,74,63,.12);color:var(--terre)}
.badge-blue{background:rgba(58,96,170,.12);color:var(--bleu-fc)}
.badge-gray{background:rgba(138,138,138,.12);color:var(--gris)}

/* BOUTONS */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--radius);font-size:13.5px;font-weight:500;font-family:var(--font-body);cursor:pointer;border:1px solid transparent;transition:all .15s;text-decoration:none;white-space:nowrap;line-height:1}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-primary{background:var(--mousse);color:var(--blanc)}
.btn-primary:hover:not(:disabled){background:var(--ardoise-lg)}
.btn-secondary{background:var(--blanc);color:var(--ardoise);border-color:var(--gris-lg)}
.btn-secondary:hover{background:var(--creme);border-color:var(--gris)}
.btn-danger{background:rgba(157,74,63,.1);color:var(--terre);border-color:rgba(157,74,63,.2)}
.btn-danger:hover{background:var(--terre);color:var(--blanc)}
.btn-ghost{background:transparent;color:var(--gris);border-color:transparent}
.btn-ghost:hover{background:var(--creme);color:var(--ardoise)}
.btn-sm{padding:5px 10px;font-size:12px}
.btn-full{width:100%;justify-content:center;padding:12px}

/* FORMULAIRES */
.form-card{background:var(--blanc);border:1px solid var(--gris-lg);border-radius:var(--radius-lg);padding:24px;margin-bottom:24px;box-shadow:var(--shadow-sm)}
.form-card h3{font-family:var(--font-display);font-size:16px;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--gris-lg)}
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;font-weight:600;color:var(--ardoise);margin-bottom:5px}
.field input,.field select,.field textarea{width:100%;padding:9px 12px;border:1px solid var(--gris-lg);border-radius:var(--radius);font-size:13.5px;font-family:var(--font-body);color:var(--ardoise);background:var(--blanc);transition:border-color .15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--mousse);box-shadow:0 0 0 3px rgba(90,122,82,.10)}
.field textarea{resize:vertical;min-height:70px}
.field-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px;padding-top:16px;border-top:1px solid var(--gris-lg)}

/* ALERTS */
.alert{padding:10px 16px;border-radius:var(--radius);margin-bottom:16px;font-size:13.5px}
.alert-success{background:rgba(90,122,82,.10);color:var(--mousse);border:1px solid rgba(90,122,82,.2)}
.error-msg{background:rgba(157,74,63,.08);color:var(--terre);border:1px solid rgba(157,74,63,.2);border-radius:var(--radius);padding:9px 12px;font-size:13px;margin-bottom:14px}

/* TOGGLE */
.toggle{position:relative;display:inline-flex;align-items:center;cursor:pointer;gap:8px}
.toggle input{display:none}
.toggle-slider{width:36px;height:20px;background:var(--gris-lg);border-radius:99px;transition:.2s;position:relative}
.toggle-slider::after{content:'';position:absolute;width:14px;height:14px;background:var(--blanc);border-radius:50%;top:3px;left:3px;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle input:checked + .toggle-slider{background:var(--mousse)}
.toggle input:checked + .toggle-slider::after{transform:translateX(16px)}

/* HISTORIQUE */
.history-feed{background:var(--blanc);border:1px solid var(--gris-lg);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.history-item{display:flex;align-items:flex-start;gap:14px;padding:14px 18px;border-bottom:1px solid var(--gris-lg)}
.history-item:last-child{border-bottom:none}
.history-item:hover{background:var(--creme-lg)}
.history-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;margin-top:2px}
.history-body{flex:1}
.history-title{font-size:13.5px;font-weight:500}
.history-meta{font-size:11.5px;color:var(--gris);margin-top:3px}

/* IMPRESSION */
.produit-selector{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:8px}
.selector-list{border:1px solid var(--gris-lg);border-radius:var(--radius-lg);overflow:hidden;max-height:55vh;overflow-y:auto;background:var(--blanc)}
.selector-list-header{background:var(--creme-lg);padding:12px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--gris);border-bottom:1px solid var(--gris-lg);position:sticky;top:0}
.selector-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--gris-lg);cursor:pointer;transition:.12s}
.selector-item:last-child{border-bottom:none}
.selector-item:hover{background:var(--creme-lg)}
.selector-item.selected{background:rgba(90,122,82,.08)}
.selector-item-name{font-size:13px;font-weight:500}
.selector-item-meta{font-size:11px;color:var(--gris)}
.item-check{font-size:18px;flex-shrink:0}
.panier-item{display:flex;align-items:center;gap:10px;padding:8px 14px;border-bottom:1px solid var(--gris-lg)}
.panier-item:last-child{border-bottom:none}
.panier-item-name{flex:1;font-size:13px}
.panier-qty{display:flex;align-items:center;gap:4px}
.qty-btn{width:24px;height:24px;border-radius:50%;border:1px solid var(--gris-lg);background:var(--blanc);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.12s}
.qty-btn:hover{background:var(--creme)}
.qty-value{width:28px;text-align:center;font-weight:600;font-size:13px}
