/* ══════════════════════════════════════════════
   DIKALIO — admin.css (dashboard BOUTIQUE)
   ══════════════════════════════════════════════ */

:root {
  --cream:   #f5f0e8;
  --white:   #ffffff;
  --cream-d: #ede6d6;
  --gold:    #b8975a;
  --gold-l:  #d4b278;
  --gold-p:  #f0e4c4;
  --noir:    #111008;
  --noir-s:  #1a1810;
  --ink:     #2c2820;
  --muted:   #7a7060;
  --border:  rgba(184,151,90,.2);
  --sidebar: #15130c;
  --serif:   'Cormorant Garamond', Georgia, serif;
  --sans:    'Jost', sans-serif;
  --tr:      all .28s ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);background:#ffffff;color:var(--ink);min-height:100vh}
h1,h2,h3,h4{font-family:var(--serif);font-weight:300}
a{text-decoration:none;color:inherit}

/* ── SIDEBAR ── */
.admin-body{display:grid;grid-template-columns:220px 1fr;min-height:100vh}
.sidebar{background:var(--sidebar);display:flex;flex-direction:column;padding:2rem 0;position:sticky;top:0;height:100vh;overflow-y:auto}
.sb-logo{font-family:var(--serif);font-size:1.4rem;color:var(--gold);letter-spacing:.08em;padding:.5rem 1.5rem 2rem;border-bottom:1px solid rgba(184,151,90,.15);margin-bottom:1rem}
.sb-nav{display:flex;flex-direction:column;gap:.2rem;padding:0 .75rem;flex:1}
.sb-link{font-size:.72rem;font-weight:400;letter-spacing:.1em;color:rgba(255,255,255,.55);padding:.75rem .9rem;border-radius:3px;transition:var(--tr)}
.sb-link:hover{color:var(--gold);background:rgba(184,151,90,.08)}
.sb-link.active{color:var(--gold);background:rgba(184,151,90,.12)}
.sb-logout{margin-top:auto;color:rgba(255,100,100,.5)!important}
.sb-logout:hover{color:#f87171!important;background:rgba(239,68,68,.08)!important}
.sb-user{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.3);padding:1rem 1.5rem;border-top:1px solid rgba(184,151,90,.1);margin-top:auto}

/* ── MAIN ── */
.admin-main{padding:2.5rem;overflow-y:auto;max-height:100vh;background:#ffffff}
.admin-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:2.5rem}
.admin-title{font-size:2.2rem;color:var(--noir)}
.breadcrumb{font-size:.72rem;color:var(--gold);letter-spacing:.1em;display:block;margin-bottom:.3rem;transition:var(--tr)}
.breadcrumb:hover{opacity:.7}
.btn-sm-outline{font-family:var(--sans);font-size:.68rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;background:var(--gold);color:var(--noir);border:1px solid var(--gold);padding:.55rem 1.2rem;border-radius:2px;cursor:pointer;transition:var(--tr)}
.btn-sm-outline:hover{background:var(--noir);color:var(--gold);border-color:var(--noir)}

/* ── KPI CARDS ── */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:1.25rem;margin-bottom:2.5rem}
.kpi-card{background:#fff;border:1px solid var(--border);border-radius:3px;padding:1.4rem 1.25rem}
.kpi-val{font-family:var(--serif);font-size:2rem;font-weight:300;color:var(--noir);margin-bottom:.3rem}
.kpi-label{font-size:.63rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}
.kpi-blue .kpi-val{color:#3b82f6}
.kpi-green .kpi-val{color:#10b981}
.kpi-gold .kpi-val{color:var(--gold)}
.kpi-emerald .kpi-val{color:#059669}
.kpi-red .kpi-val{color:#ef4444}

/* ── QUICK STATUTS ── */
.quick-statuts{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}
.qs-btn{font-family:var(--sans);font-size:.65rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;background:#fff;color:var(--muted);border:1px solid var(--border);border-radius:50px;padding:.4rem .9rem;transition:var(--tr)}
.qs-btn:hover,.qs-btn.active{background:rgba(184,151,90,.08)}
.qs-count{background:var(--gold-p);color:var(--noir);border-radius:50px;padding:.1rem .4rem;font-size:.6rem;margin-left:.3rem}

/* ── SEARCH ── */
.search-bar-admin{display:flex;gap:.5rem;margin-bottom:1.5rem;max-width:500px}
.search-bar-admin input{flex:1;font-family:var(--sans);font-size:.88rem;border:1px solid var(--border);border-radius:2px;padding:.65rem 1rem;background:#fff;outline:none;transition:var(--tr)}
.search-bar-admin input:focus{border-color:var(--gold)}
.search-bar-admin button{background:var(--gold);color:var(--noir);border:none;padding:.65rem 1rem;border-radius:2px;cursor:pointer;font-size:.9rem;transition:var(--tr)}
.search-bar-admin button:hover{background:var(--noir);color:var(--gold)}
.clear-search{font-size:.8rem;color:var(--muted);padding:.65rem .5rem;cursor:pointer;transition:var(--tr)}
.clear-search:hover{color:#ef4444}

/* ── TABLE ── */
.table-wrap{background:#fff;border:1px solid var(--border);border-radius:3px;overflow:hidden;margin-bottom:1.5rem;overflow-x:auto}
.cmd-table{width:100%;border-collapse:collapse;font-size:.85rem}
.cmd-table th{font-family:var(--sans);font-size:.6rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--white);background:var(--gold);padding:.85rem 1rem;text-align:left;border-bottom:1px solid var(--border)}
.cmd-table td{padding:.85rem 1rem;border-bottom:1px solid rgba(184,151,90,.07);vertical-align:middle}
.cmd-table tr:last-child td{border:none}
.cmd-table tr:hover td{background:rgba(184,151,90,.04)}
.cmd-num{font-family:var(--serif);font-size:.95rem;color:var(--gold)}
.client-cell{display:flex;flex-direction:column;gap:.1rem}
.client-cell strong{font-weight:500}
.client-cell small{font-size:.72rem;color:var(--muted)}
.pay-badge{font-size:.7rem;font-weight:500}
.statut-pill{display:inline-flex;align-items:center;gap:.3rem;font-size:.65rem;font-weight:500;letter-spacing:.08em;padding:.3rem .7rem;border-radius:50px;border:1px solid}
.statut-pill.big{font-size:.75rem;padding:.45rem 1rem}
.btn-action{font-family:var(--sans);font-size:.65rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;background:transparent;color:var(--gold);border:1px solid var(--border);padding:.35rem .8rem;border-radius:2px;cursor:pointer;transition:var(--tr)}
.btn-action:hover{background:var(--gold);color:var(--noir);border-color:var(--gold)}
.empty-row{text-align:center;color:var(--muted);font-weight:300;padding:3rem!important}

/* ── PAGINATION ── */
.pagination{display:flex;gap:.4rem;justify-content:center;padding:1rem 0}
.pg-btn{font-family:var(--sans);font-size:.72rem;font-weight:400;background:#fff;color:var(--muted);border:1px solid var(--border);width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--tr)}
.pg-btn:hover,.pg-btn.active{background:var(--gold);color:var(--noir);border-color:var(--gold)}

/* ── DETAIL PAGE ── */
.detail-layout{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}
.detail-col{display:flex;flex-direction:column;gap:1.25rem}
.info-card,.action-card{background:#fff;border:1px solid var(--border);border-radius:3px;padding:1.5rem}
.info-card h4,.action-card h4{font-family:var(--sans);font-size:.63rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}
.dl{display:flex;justify-content:space-between;align-items:baseline;padding:.32rem 0;font-size:.85rem;border-bottom:1px solid rgba(184,151,90,.06)}
.dl:last-child{border:none}
.dl span:first-child{color:var(--muted);font-weight:300}
.dl strong{color:var(--ink);font-weight:500}
.dl.highlight{background:var(--gold-p);margin:.1rem -.25rem;padding:.3rem .25rem;border-radius:2px}
.dl.highlight strong{color:var(--gold)}
.notes-dl em{font-size:.82rem;color:var(--muted);font-style:normal}

/* Form détail */
.fg{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1.1rem}
label{font-size:.62rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}
input[type=text],input[type=email],input[type=tel],input[type=number],input[type=date],input[type=file],textarea,select{
  font-family:var(--sans);font-size:.88rem;font-weight:300;color:var(--ink);background:#fff;border:1px solid var(--border);border-radius:2px;padding:.65rem .9rem;outline:none;transition:var(--tr);width:100%
}
input:focus,textarea:focus,select:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,151,90,.1)}
textarea{resize:vertical;min-height:80px}
.sel-wrap{position:relative}
.sel-wrap::after{content:'↓';position:absolute;right:.8rem;top:50%;transform:translateY(-50%);color:var(--gold);pointer-events:none;font-size:.7rem}
select{appearance:none;cursor:pointer}
.btn-update{font-family:var(--sans);font-size:.7rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;background:var(--gold);color:var(--noir);border:1px solid var(--gold);padding:.8rem 1.8rem;border-radius:2px;cursor:pointer;transition:var(--tr);width:100%}
.btn-update:hover{background:var(--noir);color:var(--gold);border-color:var(--noir)}

input[type="file"] {
    width: 100%;
    max-width: 100%;
    display: block;
    padding: 8px;
    font-size: 0.9rem;
    box-sizing: border-box;
}
.fg input[type="file"] {
    width: 100%;
    overflow: hidden;
}

/* Historique */
.hist-list{display:flex;flex-direction:column;gap:.9rem}
.hist-row{display:flex;gap:.9rem;align-items:flex-start}
.hist-dot-small{width:9px;height:9px;border-radius:50%;margin-top:.4rem;flex-shrink:0}
.hist-row>div{flex:1}
.hist-row span{font-size:.85rem;display:block;margin-bottom:.2rem}
.hist-comment-sm{font-size:.78rem;font-weight:300;color:var(--muted);margin:.1rem 0}
.hist-row small{font-size:.7rem;color:var(--muted)}
.empty-hist{font-size:.85rem;color:var(--muted);font-weight:300}

/* WhatsApp quick */
.wa-quick-btn{display:block;background:#f0fdf4;border:1px solid #bbf7d0;color:#166534;border-radius:2px;padding:.65rem 1rem;font-size:.78rem;font-weight:400;line-height:1.5;margin-bottom:.5rem;transition:var(--tr)}
.wa-quick-btn:hover{background:#25D366;color:#fff;border-color:#25D366}

/* Flash */
.flash-success{background:#ecfdf5;border:1px solid #6ee7b7;color:#065f46;border-radius:2px;padding:.9rem 1.25rem;margin-bottom:1.5rem;font-size:.88rem;line-height:1.6}
.alert-error{background:#fef2f2;border:1px solid #fca5a5;color:#b91c1c;border-radius:2px;padding:.8rem 1.1rem;margin-bottom:1rem;font-size:.85rem}

/* ── CATALOGUE ADMIN ── */
.add-form-wrap{background:#fff;border:1px solid var(--border);border-radius:3px;padding:2rem;margin-bottom:2rem;animation:fadeUp .4s ease both}
.add-form-wrap h3{font-family:var(--serif);font-size:1.5rem;color:var(--noir);margin-bottom:1.5rem}
.fields-grid-admin{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:1.5rem}
.fields-grid-admin .span-full{grid-column:1/-1}
.check-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.78rem;text-transform:none;letter-spacing:0;color:var(--ink)}
input[type=checkbox]{width:16px;height:16px;display:inline-block;cursor:pointer}
.form-actions{display:flex;gap:.75rem}
.btn-cancel{font-family:var(--sans);font-size:.7rem;font-weight:400;letter-spacing:.1em;background:transparent;color:var(--muted);border:1px solid var(--border);padding:.8rem 1.4rem;border-radius:2px;cursor:pointer;transition:var(--tr)}
.btn-cancel:hover{color:var(--ink);border-color:var(--ink)}

.models-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.25rem}
.model-admin-card{background:#fff;border:1px solid var(--border);border-radius:3px;overflow:hidden;transition:var(--tr)}
.model-admin-card:hover{box-shadow:0 6px 30px rgba(17,16,8,.1)}
.model-admin-card.inactive{opacity:.55}
.mac-img{width:100%;height:160px;background:var(--cream-d);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.mac-img img{width:100%;height:100%;object-fit:cover}
.mac-emoji{font-size:4rem}
.inactive-badge{position:absolute;top:.5rem;right:.5rem;background:#fef2f2;color:#b91c1c;border:1px solid #fca5a5;font-size:.6rem;padding:.2rem .5rem;border-radius:50px}
.mac-info{padding:1rem}
.mac-name{font-family:var(--serif);font-size:1.05rem;color:var(--noir);margin-bottom:.2rem}
.mac-cat{font-size:.62rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:.3rem}
.mac-price{font-family:var(--serif);font-size:.95rem;color:var(--muted);margin-bottom:.4rem}
.mac-desc{font-size:.75rem;font-weight:300;color:var(--muted);line-height:1.5}
.mac-actions{display:flex;gap:.4rem;padding:.75rem 1rem;border-top:1px solid var(--border)}
.btn-toggle{flex:1;font-family:var(--sans);font-size:.63rem;font-weight:500;letter-spacing:.1em;background:transparent;color:var(--gold);border:1px solid var(--border);padding:.4rem;border-radius:2px;text-align:center;cursor:pointer;transition:var(--tr)}
.btn-toggle:hover{background:var(--gold);color:var(--noir)}
.btn-del{font-family:var(--sans);font-size:.63rem;font-weight:500;letter-spacing:.1em;background:transparent;color:#ef4444;border:1px solid #fca5a5;padding:.4rem .7rem;border-radius:2px;text-align:center;cursor:pointer;transition:var(--tr)}
.btn-del:hover{background:#ef4444;color:#fff}

/* ── LOGIN PAGE ── */
.login-page{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;background:var(--cream)}
.login-deco{background:var(--sidebar);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem}
.deco-text{font-family:var(--serif);font-size:5rem;font-weight:300;color:var(--gold);letter-spacing:.3em}
.deco-sub{font-family:var(--sans);font-size:.7rem;font-weight:300;letter-spacing:.25em;color:rgba(255,255,255,.4);text-transform:uppercase}
.login-form-wrap{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:3rem 2rem}
.login-logo{font-size:2.5rem;color:var(--gold);margin-bottom:1rem}
.login-form-wrap h1{font-size:2.2rem;color:var(--noir);margin-bottom:.4rem}
.login-sub{font-size:.82rem;font-weight:300;color:var(--muted);margin-bottom:2rem}
form{width:100%;max-width:360px}
.lf-group{margin-bottom:1.25rem;display:flex;flex-direction:column;gap:.45rem}
.lf-group label{font-size:.62rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}
.btn-login{width:100%;font-family:var(--sans);font-size:.73rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;background:var(--gold);color:var(--noir);border:1px solid var(--gold);padding:.95rem;border-radius:2px;cursor:pointer;transition:var(--tr);margin-top:.5rem}
.btn-login:hover{background:var(--noir);color:var(--gold);border-color:var(--noir)}
.login-hint{margin-top:1.5rem;font-size:.78rem;color:var(--muted);text-align:center}
.login-hint code{background:var(--cream-d);padding:.15rem .4rem;border-radius:2px;font-size:.78rem}
.back-site{display:block;margin-top:2rem;font-size:.72rem;color:var(--muted);text-align:center;transition:var(--tr)}
.back-site:hover{color:var(--gold)}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.hidden{display:none!important}

/* ── RESPONSIVE ADMIN ── */
@media(max-width:900px){
  .admin-body{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-220px;top:0;bottom:0;z-index:300;transition:var(--tr)}
  .sidebar.open{left:0}
  .admin-main{padding:1.5rem;max-height:none}
  .detail-layout{grid-template-columns:1fr}
  .fields-grid-admin{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .login-page{grid-template-columns:1fr}
  .login-deco{display:none}
}

/* ── RÔLES & UTILISATEURS ── */
.role-badge {
  display: inline-block;
  font-size: .62rem; font-weight: 500; letter-spacing: .15em;
  text-transform: uppercase; color: var(--gold);
  background: rgba(184,151,90,.1); border: 1px solid var(--border);
  padding: .2rem .7rem; border-radius: 50px; margin-left: .5rem;
}
.sb-role-pill {
  display: block; font-size: .58rem; letter-spacing: .1em;
  color: var(--gold); margin-bottom: .2rem;
}
.flash-error {
  background: #fef2f2; border: 1px solid #fca5a5; color: #b91c1c;
  border-radius: 2px; padding: .9rem 1.25rem; margin-bottom: 1.5rem;
  font-size: .88rem; line-height: 1.6;
}
/* Utilisateurs */
.user-row {
  display: flex; align-items: flex-start; gap: 1rem;
  padding: 1rem 0; border-bottom: 1px solid var(--border);
}
.user-row:last-child { border: none; }
.user-row.user-inactive { opacity: .55; }
.user-avatar {
  width: 38px; height: 38px; border-radius: 50%;
  background: var(--gold); color: var(--noir);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-size: 1.1rem; font-weight: 300;
  flex-shrink: 0;
}
.user-info { flex: 1; }
.user-name { font-size: .9rem; font-weight: 500; color: var(--ink); margin-bottom: .1rem; }
.user-login { font-size: .72rem; color: var(--muted); margin-bottom: .2rem; }
.self-badge {
  font-size: .6rem; background: var(--gold); color: var(--noir);
  padding: .1rem .4rem; border-radius: 50px; margin-left: .4rem; font-weight: 500;
}
.inactive-badge-sm {
  font-size: .6rem; background: #fef2f2; color: #b91c1c;
  border: 1px solid #fca5a5; padding: .1rem .4rem; border-radius: 50px; margin-left: .4rem;
}
.user-actions { display: flex; gap: .3rem; flex-shrink: 0; }
.req { color: var(--gold); }





.file-box {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px;
    border: 1px solid var(--border);
    border-radius: 8px;
    cursor: pointer;
    width: 100%;
}

.file-box input {
    display: none;
}
