/* === 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;}
}
