/* === COMMON.CSS — Otium Nectere === */

/* Fonts (all pages use the same Google Fonts link - we keep it in HTML but define vars here) */

:root {
  --rouge:#e8003a; --rouge-dark:#c0002e; --rouge-light:rgba(232,0,58,0.07);
  --blanc:#ffffff; --gris-bg:#f2f3f7; --gris-sidebar:#f8f8fb; --gris-border:#e0e1e8;
  --gris-text:#2c2c3a; --gris-mid:#6b6b7e; --gris-light:#9a9aaa;
  --vert:#00a854; --vert-light:rgba(0,168,84,0.08);
  --jaune:#f5a300; --jaune-light:rgba(245,163,0,0.08);
  --bleu:#3b82f6; --bleu-light:rgba(59,130,246,0.08);
  --or:#ffd600; --argent:#b0bec5; --bronze:#bf6c30;
}

/* Reset */
*{margin:0;padding:0;box-sizing:border-box;}
html,body{height:100%;}
body{background:var(--gris-bg);color:var(--gris-text);font-family:"Barlow",sans-serif;display:flex;flex-direction:column;}

/* HEADER */
header{
  position:relative;z-index:20;
  display:flex;align-items:center;justify-content:space-between;
  min-height:58px;padding:8px 20px;flex-wrap:wrap;gap:8px;
  background:var(--blanc);border-bottom:1px solid var(--gris-border);
  box-shadow:0 2px 12px rgba(0,0,0,0.06);flex-shrink:0;
}
header::after{content:"";position:absolute;bottom:-3px;left:0;width:100%;height:3px;background:var(--rouge);z-index:1;}
.header-left{display:flex;align-items:center;gap:12px;}
.logo-header{height:28px;}
.header-sep{width:1px;height:22px;background:var(--gris-border);}
.header-appname{font-family:"Barlow Condensed",sans-serif;font-size:12px;font-weight:600;color:var(--gris-light);letter-spacing:3px;text-transform:uppercase;}
.header-appname span{color:var(--rouge);}
.header-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.header-clock{font-family:"Barlow Condensed",sans-serif;font-size:18px;font-weight:300;color:var(--gris-text);letter-spacing:3px;}
.btn-hdr{background:none;border:1px solid var(--gris-border);color:var(--gris-light);font-family:"Barlow Condensed",sans-serif;font-size:10px;letter-spacing:2px;padding:5px 12px;cursor:pointer;text-transform:uppercase;transition:all 0.2s;white-space:nowrap;}
.btn-hdr:hover{border-color:var(--rouge);color:var(--rouge);}

/* LAYOUT */
main{display:flex;flex:1;overflow:hidden;}

/* SIDEBAR */
.sidebar{
  width:260px;min-width:260px;flex-shrink:0;
  background:var(--gris-sidebar);border-right:1px solid var(--gris-border);
  display:flex;flex-direction:column;overflow-y:auto;
  transition:transform 0.3s;
}
.sidebar::-webkit-scrollbar{width:3px;}
.sidebar::-webkit-scrollbar-thumb{background:var(--rouge);}
.sidebar-toggle{
  display:none;position:fixed;bottom:20px;left:20px;z-index:100;
  width:44px;height:44px;border-radius:50%;
  background:var(--rouge);border:none;color:white;font-size:18px;
  cursor:pointer;box-shadow:0 4px 16px rgba(232,0,58,0.4);
  align-items:center;justify-content:center;
}

.section{padding:16px;border-bottom:1px solid var(--gris-border);}
.section-label{font-family:"Bebas Neue",cursive;font-size:13px;letter-spacing:4px;color:var(--rouge);margin-bottom:10px;display:flex;align-items:center;gap:8px;}
.section-label::after{content:"";flex:1;height:1px;background:linear-gradient(to right,rgba(232,0,58,0.2),transparent);}

/* Stats */
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;}
.stat-box{background:var(--blanc);border:1px solid var(--gris-border);border-top:2px solid var(--rouge);padding:10px;text-align:center;}
.stat-val{font-family:"Bebas Neue",cursive;font-size:22px;letter-spacing:2px;color:var(--rouge);}
.stat-lbl{font-family:"Barlow Condensed",sans-serif;font-size:9px;letter-spacing:2px;color:var(--gris-light);text-transform:uppercase;}

/* Filters */
.filter-label{font-family:"Barlow Condensed",sans-serif;font-size:10px;font-weight:600;letter-spacing:3px;color:var(--gris-light);text-transform:uppercase;margin-bottom:4px;}
.filter-input{
  width:100%;padding:9px 10px;margin-bottom:8px;
  background:var(--blanc);border:1px solid var(--gris-border);
  border-bottom:2px solid var(--gris-border);
  font-family:"Barlow",sans-serif;font-size:13px;color:var(--gris-text);
  outline:none;border-radius:0;transition:border-bottom-color 0.2s;
  box-shadow:inset 0 1px 3px rgba(0,0,0,0.04);
}
.filter-input:focus{border-bottom-color:var(--rouge);}

/* Shortcut buttons */
.shortcut-btn{
  width:100%;padding:9px 12px;
  background:var(--blanc);border:1px solid var(--gris-border);
  font-family:"Barlow Condensed",sans-serif;font-size:13px;font-weight:600;
  letter-spacing:2px;color:var(--gris-text);cursor:pointer;text-align:left;
  transition:all 0.2s;display:flex;align-items:center;gap:8px;
}
.shortcut-btn:hover{border-color:var(--rouge);color:var(--rouge);background:var(--rouge-light);}
.shortcut-btn.active{border-color:var(--rouge);color:var(--rouge);background:var(--rouge-light);}
.shortcut-icon{font-size:14px;flex-shrink:0;}

/* PANEL */
.panel-main{flex:1;display:flex;flex-direction:column;overflow:hidden;}
.panel-topbar{
  padding:14px 20px;border-bottom:1px solid var(--gris-border);
  display:flex;align-items:center;justify-content:space-between;
  background:var(--blanc);flex-shrink:0;flex-wrap:wrap;gap:8px;
}
.panel-title{font-family:"Bebas Neue",cursive;font-size:20px;letter-spacing:6px;color:var(--gris-text);}
.panel-title span{color:var(--rouge);}
.panel-meta{font-family:"Barlow Condensed",sans-serif;font-size:11px;color:var(--gris-light);letter-spacing:2px;}
.panel-body{flex:1;overflow-y:auto;padding:16px 20px;}
.panel-body::-webkit-scrollbar{width:3px;}
.panel-body::-webkit-scrollbar-thumb{background:rgba(232,0,58,0.3);}

/* Live indicator */
.live-pill{font-family:"Barlow Condensed",sans-serif;font-size:10px;font-weight:600;letter-spacing:3px;color:var(--vert);display:flex;align-items:center;gap:5px;text-transform:uppercase;}
.live-dot{width:6px;height:6px;border-radius:50%;background:var(--vert);animation:ld 1s ease-in-out infinite;}
@keyframes ld{0%,100%{opacity:1}50%{opacity:0.2}}

/* Empty state */
.empty-state{height:60%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;}
.empty-icon{font-size:52px;opacity:0.1;animation:eFloat 4s ease-in-out infinite;}
.empty-text{font-family:"Bebas Neue",cursive;font-size:18px;letter-spacing:5px;color:var(--gris-light);}
.empty-sub{font-family:"Barlow Condensed",sans-serif;font-size:11px;color:var(--gris-border);letter-spacing:2px;}
@keyframes eFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* Loading */
.loading{display:flex;align-items:center;justify-content:center;height:50%;}
.loading-spinner{width:32px;height:32px;border:3px solid var(--gris-border);border-top-color:var(--rouge);border-radius:50%;animation:spin 0.7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}

/* Toast */
.toast{
  position:fixed;bottom:24px;right:24px;z-index:200;
  background:var(--gris-text);color:var(--blanc);
  font-family:"Barlow Condensed",sans-serif;font-size:13px;letter-spacing:2px;
  padding:10px 18px;box-shadow:0 4px 20px rgba(0,0,0,0.2);
  opacity:0;transition:opacity 0.3s;pointer-events:none;
}
.toast.show{opacity:1;}
.toast.ok,.toast.success{background:var(--vert);}
.toast.err,.toast.error{background:var(--rouge);}
.toast.info{background:var(--jaune);}

/* Action buttons */
.btn-action{
  background:none;border:1px solid var(--gris-border);color:var(--gris-light);
  font-family:"Barlow Condensed",sans-serif;font-size:10px;letter-spacing:2px;
  padding:4px 10px;cursor:pointer;text-transform:uppercase;transition:all 0.2s;
  white-space:nowrap;
}
.btn-action:hover{border-color:var(--rouge);color:var(--rouge);}
.btn-action.btn-danger:hover{border-color:#c00;color:#c00;}

/* RESPONSIVE — Sidebar pages */
@media(max-width:768px){
  html,body{height:auto;overflow:auto;}
  main{flex-direction:column;overflow:visible;}
  .sidebar{
    width:100%;min-width:unset;
    position:fixed;left:0;top:58px;bottom:0;z-index:50;
    transform:translateX(-100%);overflow-y:auto;
    box-shadow:4px 0 24px rgba(0,0,0,0.15);
  }
  .sidebar.open{transform:translateX(0);}
  .sidebar-toggle{display:flex;}
  .panel-main{min-height:calc(100vh - 58px);}
  .panel-body{overflow:visible;height:auto;}
}
@media(max-width:480px){
  .header-appname,.header-sep{display:none;}
  .stats-grid{grid-template-columns:1fr 1fr;}
}

/* === DRAWER (panneau coulissant droite) === */
.otium-drawer-backdrop{
  position:fixed;inset:0;background:rgba(15,15,25,0.45);z-index:300;
  opacity:0;pointer-events:none;transition:opacity 0.2s;
}
.otium-drawer-backdrop.open{opacity:1;pointer-events:auto;}

.otium-drawer{
  position:fixed;right:0;top:0;height:100vh;width:420px;max-width:100vw;
  background:var(--blanc);box-shadow:-4px 0 24px rgba(0,0,0,0.18);
  z-index:310;display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform 0.25s ease;
}
.otium-drawer.open{transform:translateX(0);}

.drawer-head{
  display:flex;align-items:flex-start;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid var(--gris-border);
  background:var(--blanc);
}
.drawer-head small{font-family:"Barlow Condensed",sans-serif;font-size:10px;letter-spacing:3px;color:var(--gris-light);text-transform:uppercase;}
.drawer-head h2{font-family:"Bebas Neue",cursive;font-size:22px;letter-spacing:3px;color:var(--gris-text);margin-top:2px;}
.drawer-head h2 span{color:var(--rouge);}
.drawer-close{
  background:none;border:none;font-size:26px;line-height:1;color:var(--gris-light);
  cursor:pointer;padding:4px 8px;transition:color 0.2s;
}
.drawer-close:hover{color:var(--rouge);}

.drawer-toolbar{
  display:flex;gap:8px;align-items:center;
  padding:12px 16px;border-bottom:1px solid var(--gris-border);background:var(--gris-sidebar);
}
.drawer-toolbar input{
  flex:1;padding:9px 12px;background:var(--blanc);border:1px solid var(--gris-border);
  border-bottom:2px solid var(--gris-border);
  font-family:"Barlow",sans-serif;font-size:13px;color:var(--gris-text);outline:none;
  transition:border-bottom-color 0.2s;
}
.drawer-toolbar input:focus{border-bottom-color:var(--rouge);}
.drawer-toolbar button{
  padding:9px 14px;background:var(--rouge);border:none;color:var(--blanc);
  font-family:"Barlow Condensed",sans-serif;font-size:11px;letter-spacing:2px;
  cursor:pointer;text-transform:uppercase;white-space:nowrap;
}
.drawer-toolbar button:hover{background:var(--rouge-dark);}

.drawer-form{padding:14px 16px;background:var(--rouge-light);border-bottom:1px solid var(--gris-border);}
.drawer-form input{width:100%;margin-bottom:8px;padding:8px 10px;border:1px solid var(--gris-border);font-family:"Barlow",sans-serif;font-size:13px;outline:none;}
.drawer-form input:focus{border-color:var(--rouge);}
.drawer-form .form-row{display:flex;gap:8px;}
.drawer-form .form-row button{flex:1;padding:9px;background:var(--rouge);color:var(--blanc);border:none;font-family:"Barlow Condensed",sans-serif;font-size:12px;letter-spacing:2px;cursor:pointer;text-transform:uppercase;}
.drawer-form .form-row button.cancel{background:var(--gris-light);}

.drawer-list{flex:1;overflow-y:auto;list-style:none;padding:0;margin:0;}
.drawer-list::-webkit-scrollbar{width:4px;}
.drawer-list::-webkit-scrollbar-thumb{background:rgba(232,0,58,0.3);}

.player-row{
  display:flex;align-items:center;gap:10px;padding:10px 16px;
  border-bottom:1px solid var(--gris-border);transition:background 0.15s;cursor:grab;
}
.player-row:hover{background:var(--gris-sidebar);}
.player-row.is-ingame{opacity:0.45;cursor:not-allowed;}
.player-row.is-new{background:var(--vert-light);animation:flashNew 1.6s ease-out;}
@keyframes flashNew{0%{background:var(--vert);} 100%{background:var(--vert-light);}}
.player-name{flex:1;font-family:"Barlow",sans-serif;font-size:14px;color:var(--gris-text);font-weight:500;}
.player-actions{display:flex;gap:6px;}

/* Status pills (joueurs) */
.pill{
  font-family:"Barlow Condensed",sans-serif;font-size:9px;letter-spacing:2px;
  padding:3px 8px;text-transform:uppercase;white-space:nowrap;border-radius:2px;
}
.pill-enrolled{background:var(--vert-light);color:var(--vert);border:1px solid var(--vert);}
.pill-waiting{background:var(--jaune-light);color:var(--jaune);border:1px solid var(--jaune);}
.pill-nobadge{background:var(--gris-bg);color:var(--gris-mid);border:1px solid var(--gris-border);}
.pill-ingame{background:var(--bleu-light);color:var(--bleu);border:1px solid var(--bleu);}

.btn-mini{
  padding:5px 10px;background:var(--rouge);border:none;color:var(--blanc);
  font-family:"Barlow Condensed",sans-serif;font-size:10px;letter-spacing:1.5px;
  cursor:pointer;text-transform:uppercase;
}
.btn-mini:hover{background:var(--rouge-dark);}
.btn-mini.ghost{background:none;color:var(--rouge);border:1px solid var(--rouge);}
.btn-mini.ghost:hover{background:var(--rouge-light);}

@media(max-width:600px){.otium-drawer{width:100vw;}}

/* === MODAL (édition lampe) === */
.otium-modal{
  border:none;padding:0;width:480px;max-width:92vw;background:var(--blanc);
  box-shadow:0 16px 48px rgba(0,0,0,0.3);
}
.otium-modal::backdrop{background:rgba(15,15,25,0.55);}
.otium-modal .modal-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;border-bottom:1px solid var(--gris-border);
}
.otium-modal .modal-head h3{font-family:"Bebas Neue",cursive;font-size:18px;letter-spacing:3px;color:var(--gris-text);}
.otium-modal .modal-body{padding:18px;display:flex;flex-direction:column;gap:12px;}
.otium-modal .modal-foot{padding:12px 18px;border-top:1px solid var(--gris-border);display:flex;justify-content:flex-end;gap:8px;background:var(--gris-sidebar);}
.otium-modal label{font-family:"Barlow Condensed",sans-serif;font-size:11px;letter-spacing:2px;color:var(--gris-mid);text-transform:uppercase;display:block;margin-bottom:4px;}
.otium-modal input,.otium-modal select{width:100%;padding:8px 10px;border:1px solid var(--gris-border);font-family:"Barlow",sans-serif;font-size:13px;outline:none;}
.otium-modal input:focus,.otium-modal select:focus{border-color:var(--rouge);}

/* === Pills statut lampes === */
.lamp-pill{
  font-family:"Barlow Condensed",sans-serif;font-size:10px;letter-spacing:2px;
  padding:3px 9px;text-transform:uppercase;display:inline-flex;align-items:center;gap:5px;
}
.lamp-pill::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor;}
.lamp-pill.online{color:var(--vert);background:var(--vert-light);}
.lamp-pill.online::before{animation:ld 1.4s ease-in-out infinite;}
.lamp-pill.offline{color:var(--rouge);background:var(--rouge-light);}
.lamp-pill.never_seen{color:var(--gris-mid);background:var(--gris-bg);}
.lamp-pill.inactive{color:var(--gris-light);background:var(--gris-bg);}

.color-dot{display:inline-block;width:14px;height:14px;border-radius:50%;border:1px solid rgba(0,0,0,0.15);vertical-align:middle;}

