/* ============================================================
   PlayDoor Admin — Dashboard CSS
   Même ADN que le site vitrine mais interface dense
   ============================================================ */

:root {
  /* Fonds */
  --bg:         #0e0f15;
  --bg2:        #13151f;
  --bg3:        #181b27;
  --card:       #1a1d2a;
  --card2:      #1f2235;

  /* Bordures */
  --border:     rgba(255,255,255,.07);
  --border2:    rgba(255,255,255,.13);

  /* Couleurs PlayDoor */
  --orange:     #FF6B2B;
  --orange-d:   #C74A10;
  --yellow:     #FFD60A;
  --yellow-d:   #E6BE00;
  --purple:     #7C3AED;
  --green:      #22C55E;
  --green-d:    #15803D;
  --red:        #EF4444;
  --blue:       #3B82F6;
  --teal:       #14B8A6;

  /* Texte */
  --text:       #E8EAF2;
  --muted:      #6B7394;
  --muted2:     #9095AF;

  /* Layout */
  --sidebar-w:  248px;
  --topbar-h:   60px;
  --radius:     10px;
  --radius-lg:  16px;

  /* Typo */
  --font: 'Plus Jakarta Sans', 'DM Sans', sans-serif;
}

/* ─── RESET ──────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{height:100%}
body{background:var(--bg);color:var(--text);font-family:var(--font);
     font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;
     min-height:100vh;overflow-x:hidden}
a{color:var(--orange);text-decoration:none;transition:color .15s}
a:hover{color:var(--yellow)}

/* ─── WRAPPER ────────────────────────────────────────────── */
.pd-wrap{display:flex;min-height:100vh}

/* ─── SIDEBAR ────────────────────────────────────────────── */
.pd-sidebar{
  width:var(--sidebar-w);
  background:var(--bg2);
  border-right:1px solid var(--border);
  position:fixed;top:0;left:0;bottom:0;
  z-index:100;display:flex;flex-direction:column;
  transition:transform .25s ease;
}

/* Brand */
.pd-brand{
  display:flex;align-items:center;gap:10px;
  padding:16px 20px;
  border-bottom:1px solid var(--border);
  min-height:var(--topbar-h);
}
.pd-brand__icon{
  width:36px;height:36px;background:var(--orange);
  border-radius:10px;display:flex;align-items:center;
  justify-content:center;font-size:18px;flex-shrink:0;
  box-shadow:0 4px 12px rgba(255,107,43,.35);
}
.pd-brand__name{font-size:16px;font-weight:800;color:var(--text);letter-spacing:-.3px}
.pd-brand__name span{color:var(--orange)}
.pd-brand__role{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.7px}

/* Nav */
.pd-nav{flex:1;overflow-y:auto;padding:12px 0;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.pd-nav__section{padding:14px 18px 4px;font-size:10px;font-weight:700;
  color:var(--muted);text-transform:uppercase;letter-spacing:.8px}

.pd-nav__item{
  display:flex;align-items:center;gap:10px;
  padding:9px 18px;color:var(--muted2);font-size:13.5px;font-weight:600;
  border-left:3px solid transparent;cursor:pointer;transition:all .15s;
  text-decoration:none;
}
.pd-nav__item i{font-size:16px;width:20px;text-align:center;flex-shrink:0}
.pd-nav__item:hover{color:var(--text);background:rgba(255,255,255,.04)}
.pd-nav__item.active{color:var(--orange);background:rgba(255,107,43,.08);border-left-color:var(--orange)}

/* Badge count nav */
.pd-nav__badge{
  margin-left:auto;background:var(--orange);color:#fff;
  border-radius:100px;font-size:10px;font-weight:800;
  padding:2px 7px;min-width:18px;text-align:center;
}

/* User bas sidebar */
.pd-user{
  padding:14px 18px;border-top:1px solid var(--border);
  display:flex;align-items:center;gap:10px;
}
.pd-avatar{
  width:34px;height:34px;border-radius:50%;
  background:var(--orange);display:flex;align-items:center;
  justify-content:center;font-size:13px;font-weight:800;color:#fff;flex-shrink:0;
}
.pd-user__name{font-size:13px;font-weight:700;color:var(--text)}
.pd-user__role{font-size:11px;color:var(--muted)}

/* ─── MAIN ────────────────────────────────────────────────── */
.pd-main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}

/* ─── TOPBAR ─────────────────────────────────────────────── */
.pd-topbar{
  height:var(--topbar-h);background:var(--bg2);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;padding:0 24px;gap:14px;
  position:sticky;top:0;z-index:90;
}
.pd-topbar__title{font-size:16px;font-weight:700;color:var(--text);flex:1}
.pd-topbar__toggle{display:none;background:none;border:none;color:var(--text);font-size:22px;cursor:pointer}

/* ─── CONTENT ─────────────────────────────────────────────── */
.pd-content{padding:24px;flex:1}

/* ─── STAT CARDS ──────────────────────────────────────────── */
.pd-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px;margin-bottom:24px}

.pd-stat{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:18px;
  display:flex;align-items:center;gap:14px;
  transition:border-color .15s;
}
.pd-stat:hover{border-color:var(--border2)}

.pd-stat__icon{
  width:46px;height:46px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;
}
.pd-stat__icon.orange {background:rgba(255,107,43,.14);color:var(--orange)}
.pd-stat__icon.yellow {background:rgba(255,214,10,.12);color:var(--yellow)}
.pd-stat__icon.green  {background:rgba(34,197,94,.12);color:var(--green)}
.pd-stat__icon.purple {background:rgba(124,58,237,.12);color:var(--purple)}
.pd-stat__icon.blue   {background:rgba(59,130,246,.12);color:var(--blue)}
.pd-stat__icon.red    {background:rgba(239,68,68,.12);color:var(--red)}
.pd-stat__icon.teal   {background:rgba(20,184,166,.12);color:var(--teal)}

.pd-stat__val{font-size:24px;font-weight:800;color:var(--text);line-height:1}
.pd-stat__lbl{font-size:12px;color:var(--muted);margin-top:3px}

/* ─── CARDS ───────────────────────────────────────────────── */
.pd-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-lg);
}
.pd-card__hd{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid var(--border);
}
.pd-card__title{font-size:14px;font-weight:700;color:var(--text)}
.pd-card__body{padding:20px}

/* ─── TABLES ──────────────────────────────────────────────── */
.pd-table-wrap{overflow-x:auto}
.pd-table{width:100%;border-collapse:collapse;font-size:13px}
.pd-table th{
  background:rgba(255,255,255,.03);color:var(--muted);
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
  padding:10px 16px;border-bottom:1px solid var(--border);white-space:nowrap;
}
.pd-table td{
  padding:11px 16px;border-bottom:1px solid rgba(255,255,255,.04);
  color:var(--text);vertical-align:middle;
}
.pd-table tr:last-child td{border-bottom:none}
.pd-table tr:hover td{background:rgba(255,255,255,.02)}

/* ─── FORMULAIRES ─────────────────────────────────────────── */
.pd-form-group{margin-bottom:16px}
.pd-form-group label{
  display:block;font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:7px;
}
.pd-form-group .hint{font-size:11px;color:var(--muted);margin-top:5px}

.pd-input{
  width:100%;background:var(--bg);border:1px solid var(--border2);
  border-radius:9px;padding:9px 13px;color:var(--text);
  font-size:13.5px;font-family:var(--font);transition:border-color .15s;
}
.pd-input:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,107,43,.12)}
.pd-input::placeholder{color:var(--muted)}
select.pd-input{cursor:pointer}

.pd-input.is-invalid{border-color:var(--red) !important}
.pd-error{font-size:11px;color:var(--red);margin-top:5px}

/* ─── BOUTONS ─────────────────────────────────────────────── */
.pd-btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 16px;border-radius:9px;font-size:13px;font-weight:700;
  font-family:var(--font);cursor:pointer;border:none;
  text-decoration:none;transition:all .15s;white-space:nowrap;
}
.pd-btn:hover{transform:translateY(-1px)}
.pd-btn:active{transform:translateY(0)}

.pd-btn-primary  {background:var(--orange);color:#fff;box-shadow:0 4px 12px rgba(255,107,43,.3)}
.pd-btn-primary:hover{background:var(--orange-d);color:#fff}
.pd-btn-success  {background:var(--green);color:#fff}
.pd-btn-success:hover{background:var(--green-d);color:#fff}
.pd-btn-danger   {background:var(--red);color:#fff}
.pd-btn-warning  {background:var(--yellow);color:var(--bg)}
.pd-btn-purple   {background:var(--purple);color:#fff}
.pd-btn-outline  {background:transparent;border:1px solid var(--border2);color:var(--muted2)}
.pd-btn-outline:hover{border-color:var(--border);color:var(--text);background:rgba(255,255,255,.04)}

.pd-btn-sm{padding:5px 10px;font-size:12px;border-radius:7px}
.pd-btn-xs{padding:3px 8px;font-size:11px;border-radius:6px}
.pd-btn-lg{padding:11px 22px;font-size:15px;border-radius:11px}

/* ─── BADGES ──────────────────────────────────────────────── */
.pd-badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 9px;border-radius:100px;font-size:11px;font-weight:700;
}
.pd-badge-orange {background:rgba(255,107,43,.15);color:var(--orange)}
.pd-badge-yellow {background:rgba(255,214,10,.12);color:var(--yellow)}
.pd-badge-green  {background:rgba(34,197,94,.12);color:var(--green)}
.pd-badge-red    {background:rgba(239,68,68,.12);color:var(--red)}
.pd-badge-purple {background:rgba(124,58,237,.12);color:var(--purple)}
.pd-badge-blue   {background:rgba(59,130,246,.12);color:var(--blue)}
.pd-badge-muted  {background:rgba(255,255,255,.07);color:var(--muted2)}

/* ─── SIMULATOR ───────────────────────────────────────────── */
.sim-card{
  background:linear-gradient(135deg,rgba(255,107,43,.08),rgba(255,214,10,.05));
  border:1px solid rgba(255,107,43,.2);border-radius:var(--radius-lg);
  padding:24px;
}
.sim-result{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;
  margin-top:20px;
}
.sim-item{
  background:var(--card2);border:1px solid var(--border);
  border-radius:var(--radius);padding:14px;text-align:center;
}
.sim-item__val{font-size:20px;font-weight:800;color:var(--text);margin-bottom:4px}
.sim-item__lbl{font-size:11px;color:var(--muted)}
.sim-item.highlight{border-color:rgba(34,197,94,.3);background:rgba(34,197,94,.06)}
.sim-item.highlight .sim-item__val{color:var(--green)}

/* ─── QUOTA MENSUEL ───────────────────────────────────────── */
.quota-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:16px;
}
.quota-month{
  background:var(--bg);border:1px solid var(--border2);
  border-radius:var(--radius);padding:12px;
}
.quota-month.current{border-color:rgba(255,107,43,.4);background:rgba(255,107,43,.05)}
.quota-month label{font-size:11px;font-weight:700;color:var(--muted);display:block;margin-bottom:6px}
.quota-month input{
  width:100%;background:var(--card);border:1px solid var(--border);
  border-radius:7px;padding:7px 10px;color:var(--text);
  font-size:16px;font-weight:800;text-align:center;font-family:var(--font);
}
.quota-month input:focus{outline:none;border-color:var(--orange)}

/* ─── PROGRESS BAR ────────────────────────────────────────── */
.pd-progress{background:rgba(255,255,255,.07);border-radius:100px;height:8px;overflow:hidden;margin-top:6px}
.pd-progress__bar{height:100%;border-radius:100px;transition:width .4s ease;background:var(--orange)}
.pd-progress__bar.green{background:var(--green)}
.pd-progress__bar.red{background:var(--red)}

/* ─── LOGIN PAGE ──────────────────────────────────────────── */
.pd-login{
  min-height:100vh;display:flex;align-items:center;
  justify-content:center;background:var(--bg);padding:20px;
}
.pd-login__box{
  width:100%;max-width:400px;background:var(--card);
  border:1px solid var(--border2);border-radius:20px;padding:40px;
}
.pd-login__logo{text-align:center;margin-bottom:32px}
.pd-login__logo .icon{
  width:60px;height:60px;background:var(--orange);border-radius:16px;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:30px;margin-bottom:14px;
  box-shadow:0 8px 24px rgba(255,107,43,.4);
}
.pd-login__logo h1{font-size:22px;font-weight:800;color:var(--text)}
.pd-login__logo p{font-size:13px;color:var(--muted);margin-top:4px}

/* ─── ALERTS ──────────────────────────────────────────────── */
.pd-alert{padding:12px 16px;border-radius:9px;margin-bottom:16px;font-size:13.5px;display:flex;align-items:flex-start;gap:10px}
.pd-alert-success{background:rgba(34,197,94,.1);border-left:3px solid var(--green);color:var(--green)}
.pd-alert-danger {background:rgba(239,68,68,.1);border-left:3px solid var(--red);color:var(--red)}
.pd-alert-warning{background:rgba(255,214,10,.1);border-left:3px solid var(--yellow);color:var(--yellow)}
.pd-alert-info   {background:rgba(59,130,246,.1);border-left:3px solid var(--blue);color:var(--blue)}

/* ─── OVERLAY MOBILE ──────────────────────────────────────── */
.pd-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:99}
.pd-overlay.show{display:block}

/* ─── RESPONSIVE ──────────────────────────────────────────── */
@media(max-width:768px){
  .pd-sidebar{transform:translateX(-100%)}
  .pd-sidebar.open{transform:translateX(0);box-shadow:4px 0 30px rgba(0,0,0,.5)}
  .pd-main{margin-left:0}
  .pd-topbar__toggle{display:block}
  .pd-stats{grid-template-columns:1fr 1fr}
  .pd-content{padding:16px}
  .quota-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:480px){
  .pd-stats{grid-template-columns:1fr}
  .quota-grid{grid-template-columns:repeat(2,1fr)}
}

/* ─── UTILS ───────────────────────────────────────────────── */
.fw-700{font-weight:700}
.fw-800{font-weight:800}
.fs-12{font-size:12px}
.fs-13{font-size:13px}
.text-muted{color:var(--muted)!important}
.text-orange{color:var(--orange)!important}
.text-green{color:var(--green)!important}
.text-red{color:var(--red)!important}
.gap-2{gap:8px}
.d-flex{display:flex}
.align-center{align-items:center}
.flex-wrap{flex-wrap:wrap}
.ms-auto{margin-left:auto}
.mt-0{margin-top:0!important}
.mb-0{margin-bottom:0!important}
