/* ─── Reset ──────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
:root {
  --bg:#181B2E; --card:#22263D; --hover:#2A2F4D; --border:#32375A;
  --accent:#5B7FE8; --accent2:#7B9CF5; --success:#3DBE6E;
  --warn:#E8A030; --danger:#D95555; --t1:#E8EAF6; --t2:#8890C0; --t3:#555A82;
  --radius:8px;
}
html,body { height:100%; }
body {
  font-family:'Segoe UI',system-ui,-apple-system,sans-serif;
  font-size:15px; background:var(--bg); color:var(--t1);
  display:flex; min-height:100vh;
}

/* ─── Layout ──────────────────────────────────────────────────────────────── */
.sidebar {
  width:260px; min-height:100vh; background:var(--card);
  border-right:1px solid var(--border);
  display:flex; flex-direction:column;
  position:fixed; top:0; left:0; bottom:0;
  overflow-y:auto; z-index:10;
}
.main {
  margin-left:260px; flex:1;
  padding:28px 32px 60px 32px;
  max-width:1000px; width:100%;
}

/* ─── Sidebar brand ────────────────────────────────────────────────────────── */
.sidebar-brand {
  display:flex; align-items:center; gap:12px;
  padding:18px 16px 14px; border-bottom:1px solid var(--border);
}
.brand-icon { font-size:1.8rem; }
.brand-title { font-size:1.15rem; font-weight:800; color:var(--accent2); }
.brand-sub   { font-size:0.7rem; color:var(--t3); }

/* ─── User badge ──────────────────────────────────────────────────────────── */
.user-badge {
  display:flex; align-items:center; gap:10px;
  padding:10px 14px; margin:10px 10px 0;
  background:var(--hover); border-radius:var(--radius);
  border:1px solid var(--border);
}
.user-icon { font-size:1.4rem; flex-shrink:0; }
.user-nom  { font-size:0.85rem; font-weight:700; color:var(--t1); }
.user-role { font-size:0.72rem; color:var(--t3); }
.logout-btn {
  margin-left:auto; color:var(--t3); font-size:1.1rem;
  text-decoration:none; padding:4px 6px; border-radius:4px;
}
.logout-btn:hover { color:var(--danger); background:#3D1A1A; }

/* ─── Navigation ──────────────────────────────────────────────────────────── */
.nav { padding:10px 10px 0; display:flex; flex-direction:column; gap:3px; }
.nav-btn, a.nav-btn {
  display:block; width:100%; padding:9px 14px;
  background:transparent; color:var(--t2);
  border:none; border-radius:var(--radius);
  text-align:left; font-size:0.88rem; font-weight:600;
  cursor:pointer; transition:all .15s; text-decoration:none;
}
.nav-btn:hover { background:var(--hover); color:var(--t1); }
.nav-btn.active { background:var(--accent); color:white; }

/* ─── Sidebar sections ────────────────────────────────────────────────────── */
.sidebar-section { padding:0 10px 8px; }
.sidebar-label {
  font-size:0.68rem; font-weight:700; letter-spacing:0.12em;
  color:var(--t3); padding:12px 4px 4px;
}
.divider { border:none; border-top:1px solid var(--border); margin:8px 10px; }

/* ─── Jours ────────────────────────────────────────────────────────────────── */
.jour-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:3px; }
.jour-btn {
  padding:6px 2px; border:none; border-radius:6px;
  background:var(--bg); color:var(--t2);
  font-size:0.78rem; font-weight:700; cursor:pointer; transition:all .15s;
  width:100%;
}
.jour-btn:hover  { background:var(--hover); color:var(--t1); }
.jour-btn.active { background:var(--accent); color:white; }
.jour-btn.expired{ background:#2A1A1A; color:#664444; cursor:default; }

/* ─── Récap ──────────────────────────────────────────────────────────────── */
.recap-line { font-size:0.82rem; padding:2px 4px; color:var(--t3); }
.recap-line.ok      { color:var(--success); font-weight:700; }
.recap-line.expired { color:#664444; }

/* ─── Select ──────────────────────────────────────────────────────────────── */
.select-field {
  width:100%; padding:7px 10px; border-radius:var(--radius);
  background:var(--bg); color:var(--t1); border:1px solid var(--border);
  font-size:0.88rem; cursor:pointer;
}
.select-field:focus { outline:2px solid var(--accent); }

/* ─── Page header ─────────────────────────────────────────────────────────── */
.page-header { display:flex; align-items:baseline; gap:20px; margin-bottom:12px; }
.page-header h1 { font-size:2rem; font-weight:800; }
.week-info  { color:var(--t2); font-size:0.95rem; }
.page-title { font-size:1.5rem; font-weight:800; margin-bottom:18px; }
.page-sub   { color:var(--t2); margin-bottom:16px; font-size:0.9rem; }

/* ─── Deadline ────────────────────────────────────────────────────────────── */
.deadline-info {
  background:#1A2A3A; border:1px solid #2E75B6;
  border-radius:var(--radius); padding:8px 16px;
  color:#90C4E8; font-size:0.88rem; margin-bottom:16px;
}
.deadline-alert {
  background:#3D1A1A; border:1px solid var(--danger);
  border-radius:var(--radius); padding:12px 16px;
  color:#F08080; font-size:0.9rem; margin-bottom:16px;
}

/* ─── Flash ───────────────────────────────────────────────────────────────── */
.flash {
  padding:10px 16px; border-radius:var(--radius);
  margin-bottom:16px; font-weight:600; font-size:0.9rem;
}
.flash-success { background:#1A3D28; border:1px solid var(--success); color:var(--success); }
.flash-error   { background:#3D1A1A; border:1px solid var(--danger);  color:#F08080; }
.flash-warning { background:#3D2A00; border:1px solid var(--warn);    color:var(--warn); }

/* ─── Cat blocks ──────────────────────────────────────────────────────────── */
.cat-block { border-radius:var(--radius); margin-bottom:14px; overflow:hidden; border:1px solid #32375A; }
.cat-header {
  padding:8px 16px; font-weight:700;
  font-size:0.82rem; letter-spacing:0.07em; color:white;
}
.cat-items {
  display:grid; grid-template-columns:1fr 1fr;
  gap:2px; padding:10px 12px 8px; background:var(--card);
}
.item-label {
  display:flex; align-items:center; gap:10px;
  padding:7px 10px; border-radius:6px; cursor:pointer;
  transition:background .12s;
}
.item-label:hover { background:var(--hover); }
.item-label.checked { background:#1A2A4A; }
.item-label input[type=checkbox] { accent-color:var(--accent); width:16px; height:16px; flex-shrink:0; }
.item-text { font-size:0.92rem; }

.carte-sep {
  background:#3AACAC18; border:1.5px solid #3AACAC;
  border-radius:var(--radius); padding:10px 18px;
  margin:22px 0 10px; color:#3AACAC; font-weight:700; font-size:0.9rem;
}

/* ─── Bouton valider ──────────────────────────────────────────────────────── */
.btn-valider {
  width:100%; margin-top:20px; padding:14px;
  background:var(--success); color:white;
  border:none; border-radius:var(--radius);
  font-size:1rem; font-weight:700; cursor:pointer; transition:opacity .15s;
}
.btn-valider:hover { opacity:.88; }

/* ─── Boutons ─────────────────────────────────────────────────────────────── */
.btn {
  display:inline-block; padding:9px 18px; border-radius:var(--radius);
  font-weight:700; font-size:0.88rem; cursor:pointer;
  border:none; transition:opacity .15s; text-decoration:none;
}
.btn:hover    { opacity:.85; }
.btn-primary  { background:var(--accent);  color:white; }
.btn-secondary{ background:var(--hover);   color:var(--t2); }
.btn-warn     { background:var(--warn);    color:#1A1A1A; }
.btn-danger   { background:var(--danger);  color:white; }
.btn-success  { background:var(--success); color:white; }
.btn-sm       { padding:4px 10px; font-size:0.78rem; }
.btn-row      { display:flex; gap:10px; margin-top:14px; flex-wrap:wrap; }

/* ─── Cards ────────────────────────────────────────────────────────────────── */
.card {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); padding:20px 22px; margin-bottom:18px;
}
.card h3   { font-size:1rem; margin-bottom:6px; }
.card h4   { font-size:0.88rem; color:var(--t2); }
.card-sub  { color:var(--t2); font-size:0.85rem; margin-bottom:12px; }

/* ─── Forms ───────────────────────────────────────────────────────────────── */
.text-input {
  width:100%; padding:8px 12px; border-radius:6px;
  background:var(--bg); color:var(--t1);
  border:1px solid var(--border); font-size:0.9rem;
}
.text-input:focus { outline:2px solid var(--accent); }
.textarea {
  width:100%; padding:8px 12px; border-radius:6px;
  background:var(--bg); color:var(--t1);
  border:1px solid var(--border); font-size:0.88rem;
  resize:vertical; min-height:90px; font-family:inherit;
}
.textarea:focus { outline:2px solid var(--accent); }
.form-row   { display:flex; align-items:center; gap:10px; margin-bottom:12px; flex-wrap:wrap; }
.form-row label { color:var(--t2); font-size:0.88rem; white-space:nowrap; }
.form-grid  { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:16px; }
.form-field label { display:block; color:var(--t2); font-size:0.82rem; margin-bottom:5px; font-weight:600; }
.file-input { color:var(--t2); font-size:0.88rem; }
.import-form { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }

/* ─── Tabs ────────────────────────────────────────────────────────────────── */
.tabs { display:flex; gap:4px; margin-bottom:16px; flex-wrap:wrap; }
.tab-btn {
  padding:7px 14px; border-radius:6px;
  background:var(--bg); color:var(--t2);
  border:1px solid var(--border); font-size:0.85rem;
  font-weight:600; cursor:pointer; transition:all .13s;
}
.tab-btn:hover  { background:var(--hover); color:var(--t1); }
.tab-btn.active { background:var(--accent); color:white; border-color:var(--accent); }
.menu-cat-label {
  padding:6px 14px; border-radius:6px;
  font-weight:700; font-size:0.82rem; color:white; margin:12px 0 4px;
}

/* ─── Tables ──────────────────────────────────────────────────────────────── */
.table-wrap    { overflow-x:auto; }
.recap-table   { width:100%; border-collapse:collapse; font-size:0.88rem; }
.recap-table th, .recap-table td { padding:8px 12px; border:1px solid var(--border); text-align:center; }
.recap-table th { background:#2B3270; color:white; font-weight:700; }
.recap-table tr:nth-child(even) td { background:#1E2240; }
.sal-cell      { text-align:left !important; font-weight:600; }
.cmd-ok        { color:var(--success); font-weight:700; }
.cmd-none      { color:var(--t3); }

/* ─── Empty ───────────────────────────────────────────────────────────────── */
.empty-state {
  background:var(--card); border:1px dashed var(--border);
  border-radius:var(--radius); padding:40px;
  text-align:center; color:var(--t2); line-height:1.8;
}
.empty-text { color:var(--t2); font-style:italic; }

/* ─── Week list ───────────────────────────────────────────────────────────── */
.week-list  { display:flex; flex-direction:column; gap:4px; }
.week-item  { padding:6px 10px; border-radius:6px; font-size:0.85rem; color:var(--t2); }
.week-item.active { border:1px solid var(--accent); color:var(--accent2); background:#1A2050; }
.week-item code   { color:var(--accent2); }

/* ─── MOBILE ──────────────────────────────────────────────────────────────── */
@media (max-width:768px) {
  .sidebar {
    width:100%; min-height:auto; position:relative;
    flex-direction:column;
  }
  .main { margin-left:0; padding:16px 12px 40px; max-width:100%; }
  body  { flex-direction:column; }
  .cat-items { grid-template-columns:1fr; }
  .form-grid { grid-template-columns:1fr; }
  .page-header { flex-direction:column; gap:4px; }
  .page-header h1 { font-size:1.5rem; }
  .item-label { padding:10px 8px; }
  .item-text  { font-size:1rem; }
  .btn-valider { padding:16px; font-size:1.05rem; }
  .user-badge { margin:8px 8px 0; }
  .nav { padding:6px 8px 0; }
  .nav-btn { padding:11px 14px; font-size:0.92rem; }
  .sidebar-section { padding:0 8px 6px; }
  .jour-btn { padding:8px 2px; font-size:0.82rem; }
}

@media (max-width:480px) {
  .tabs { gap:3px; }
  .tab-btn { padding:6px 10px; font-size:0.78rem; }
  .card { padding:14px 14px; }
}
</style>
