:root{
  --bg:#F7F5F2;--sidebar:#1B2B3A;--accent:#2E5FA3;--gold:#C8A56A;
  --text:#1A1A1A;--tl:#6B7280;--border:#E2DDD8;--red:#C0392B;--green:#27AE60;
  --sidebar-w:240px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);font-size:14px}

/* ── LOGIN ─────────────────────────────────────────────── */
#login-page{display:flex;min-height:100vh;align-items:center;justify-content:center;background:linear-gradient(135deg,#1B2B3A,#2E4A65,#1B2B3A);padding:16px}
.login-card{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:420px;box-shadow:0 40px 80px rgba(0,0,0,.3)}
.login-logo{width:100%;max-width:280px;margin:0 auto 24px;display:block}
.login-title{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:#1B2B3A;text-align:center;margin-bottom:4px}
.login-sub{font-size:13px;color:var(--tl);text-align:center;margin-bottom:20px}
.role-sel{display:flex;gap:8px;margin-bottom:16px}
.role-btn{flex:1;padding:10px;border:1.5px solid var(--border);border-radius:8px;background:#fff;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;cursor:pointer;color:var(--tl);transition:all .2s}
.role-btn.on{border-color:var(--accent);background:rgba(46,95,163,.08);color:var(--accent);font-weight:600}
.err-box{background:#FEE2E2;color:var(--red);padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:14px;display:none}
.fg{margin-bottom:14px}
.fg label{display:block;font-size:11px;font-weight:600;color:#1B2B3A;text-transform:uppercase;letter-spacing:.05em;margin-bottom:5px}
.inp{width:100%;padding:11px 13px;border:1.5px solid var(--border);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:14px;outline:none;transition:border-color .2s;background:var(--bg)}
.inp:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(46,95,163,.1)}
select.inp{cursor:pointer}
.btn-login{width:100%;padding:13px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}
.btn-login:hover{background:#1B3A6B}
.login-foot{text-align:center;margin-top:14px;font-size:12px;color:var(--tl)}

/* ── APP LAYOUT ─────────────────────────────────────────── */
#app{display:none;height:100vh;flex-direction:row;position:relative;overflow:hidden}
#app.on{display:flex}

/* SIDEBAR */
.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--sidebar);display:flex;flex-direction:column;z-index:200;transition:transform .3s ease}
.sb-head{padding:16px 16px 12px;border-bottom:1px solid rgba(255,255,255,.07)}
.sb-logo{width:100%;filter:brightness(0) invert(1);opacity:.9;max-height:44px;object-fit:contain}
.sb-role{font-size:10px;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:.1em;margin-top:6px}
.sb-nav{flex:1;padding:12px 10px;overflow-y:auto}
.nav-sec{font-size:10px;font-weight:600;color:rgba(255,255,255,.3);text-transform:uppercase;letter-spacing:.1em;padding:0 8px;margin:12px 0 4px}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;color:rgba(255,255,255,.6);font-size:13px;margin-bottom:2px;transition:all .2s;user-select:none}
.nav-item svg{width:17px;height:17px;flex-shrink:0;opacity:.7}
.nav-item:hover{background:rgba(255,255,255,.07);color:#fff}
.nav-item.on{background:var(--accent);color:#fff}
.nav-item.on svg{opacity:1}
.nav-badge{margin-left:auto;background:var(--gold);color:#1a1a1a;font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px}
.sb-user{padding:12px 16px;border-top:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:10px}
.av{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;font-size:12px}
.sb-un{font-size:13px;color:#fff;font-weight:500;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-ut{font-size:11px;color:rgba(255,255,255,.4)}
.btn-lo{background:none;border:none;cursor:pointer;color:rgba(255,255,255,.35);padding:4px;transition:color .2s}
.btn-lo:hover{color:#fff}

/* Overlay mobile sidebar */
.sb-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:190}
.sb-backdrop.on{display:block}

/* MAIN */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.topbar{background:#fff;border-bottom:1px solid var(--border);padding:0 20px;height:56px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;gap:8px}
.topbar-title{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:600;color:#1B2B3A;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-r{display:flex;align-items:center;gap:8px;flex-shrink:0}
.topbar-l{display:flex;align-items:center;gap:10px;min-width:0;flex:1}

/* Hamburger */
.btn-menu{background:none;border:none;cursor:pointer;padding:6px;color:var(--text);display:none;flex-shrink:0}
.btn-menu svg{width:22px;height:22px}

/* Buttons */
.btn{padding:7px 14px;border:1.5px solid var(--border);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;cursor:pointer;color:var(--text);background:#fff;transition:all .2s;display:inline-flex;align-items:center;gap:5px;white-space:nowrap}
.btn:hover{border-color:var(--accent);color:var(--accent)}
.btn.p{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.p:hover{background:#1B3A6B}
.btn.g{background:var(--green);border-color:var(--green);color:#fff}
.btn.r{background:var(--red);border-color:var(--red);color:#fff}
.btn.sm{padding:5px 10px;font-size:11px}

/* Content */
.content{flex:1;overflow-y:auto;padding:20px;overflow-x:hidden}
.view{display:none}
.view.on{display:block}

/* ── STATS ──────────────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
.stat-card{background:#fff;border-radius:12px;padding:16px;border:1px solid var(--border)}
.stat-val{font-size:26px;font-weight:700;color:#1B2B3A;line-height:1}
.stat-lbl{font-size:11px;color:var(--tl);margin-top:4px}

/* ── CARD ───────────────────────────────────────────────── */
.card{background:#fff;border-radius:12px;border:1px solid var(--border);overflow:hidden;margin-bottom:14px}
.card-h{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.card-title{font-size:14px;font-weight:600;color:#1B2B3A}
.card-b{padding:14px 16px}

/* ── DASHBOARD GRID ─────────────────────────────────────── */
.dash-grid{display:grid;grid-template-columns:1fr 300px;gap:14px}

/* ── CALENDAR ───────────────────────────────────────────── */
.cal-tb{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:8px;flex-wrap:wrap}
.cal-nav{display:flex;align-items:center;gap:6px}
.cal-nav button{background:#fff;border:1.5px solid var(--border);border-radius:8px;width:30px;height:30px;cursor:pointer;font-size:18px;transition:all .2s;display:flex;align-items:center;justify-content:center}
.cal-nav button:hover{border-color:var(--accent)}
.cal-period{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:600;color:#1B2B3A;min-width:150px;text-align:center}
.month-grid{background:#fff;border-radius:12px;border:1px solid var(--border);overflow:hidden}
.month-dow-row{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--border)}
.month-dow{text-align:center;padding:8px 4px;font-size:10px;font-weight:600;color:var(--tl);text-transform:uppercase;letter-spacing:.04em}
.month-body{display:grid;grid-template-columns:repeat(7,1fr)}
.mday{min-height:64px;padding:5px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}
.mday:hover{background:var(--bg)}
.mday:nth-child(7n){border-right:none}
.mday.other{color:#ccc}
.mday.today .dnum{background:var(--accent);color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center}
.dnum{font-size:11px;font-weight:500;color:#1B2B3A;width:20px;height:20px;display:flex;align-items:center;justify-content:center;margin-bottom:2px}
.mev{font-size:9px;border-radius:3px;padding:1px 4px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}
.mev.blue{background:rgba(46,95,163,.12);color:#1B3A6B}
.mev.green{background:rgba(125,168,123,.18);color:#2D5E2B}
.mev.red{background:rgba(192,57,43,.12);color:var(--red)}
.mev.gold{background:rgba(200,165,106,.18);color:#7A5C1E}

/* ── TABLE ──────────────────────────────────────────────── */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.tbl{width:100%;border-collapse:collapse;min-width:500px}
.tbl th{text-align:left;padding:10px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--tl);border-bottom:1px solid var(--border)}
.tbl td{padding:10px 12px;font-size:13px;border-bottom:1px solid var(--border);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--bg)}
.pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600}
.pill.admin{background:rgba(46,95,163,.1);color:var(--accent)}
.pill.super{background:rgba(200,165,106,.2);color:#7A5C1E}
.pill.collab{background:rgba(125,168,123,.15);color:#2D5E2B}
.pill.ok{background:rgba(39,174,96,.1);color:var(--green)}
.pill.ko{background:rgba(192,57,43,.1);color:var(--red)}
.pill.warn{background:rgba(214,137,16,.12);color:#D68910}
.tbl-act{background:none;border:none;cursor:pointer;color:var(--tl);padding:4px;border-radius:4px;font-size:14px}

/* ── ABSENCES ───────────────────────────────────────────── */
.abs-item{background:#fff;border-radius:10px;border:1px solid var(--border);padding:12px 16px;display:flex;align-items:flex-start;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.abs-info{flex:1;min-width:150px}
.abs-name{font-size:14px;font-weight:600;color:#1B2B3A}
.abs-det{font-size:12px;color:var(--tl);margin-top:2px}
.abs-acts{display:flex;gap:6px;flex-wrap:wrap;align-items:center}

/* ── SOLDES ─────────────────────────────────────────────── */
.sol-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.sol-card{background:var(--bg);border-radius:10px;padding:12px;text-align:center;border:1px solid var(--border)}
.sol-val{font-size:22px;font-weight:700;color:#1B2B3A}
.sol-lbl{font-size:11px;color:var(--tl);margin-top:2px}

/* ── TEAM WEEK ──────────────────────────────────────────── */
.tw-grid{background:#fff;border-radius:12px;border:1px solid var(--border);overflow:hidden;overflow-x:auto;-webkit-overflow-scrolling:touch}
.tw-inner{min-width:480px}
.tw-row{display:grid;grid-template-columns:36px 140px repeat(5,1fr);align-items:center;border-bottom:1px solid var(--border)}
.tw-row:last-child{border-bottom:none}
.tw-av{display:flex;align-items:center;justify-content:center;height:46px}
.tw-name{padding:6px 8px;font-size:12px;font-weight:500;color:#1B2B3A}
.tw-cell{display:flex;align-items:center;justify-content:center;height:46px}
.tw-blk{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}

/* ── AGENDA LAYOUT ──────────────────────────────────────── */
.ag-layout{display:grid;grid-template-columns:1fr 270px;gap:14px}

/* ── MODAL ──────────────────────────────────────────────── */
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1000;align-items:flex-end;justify-content:center;padding:0}
.overlay.on{display:flex}
.modal{background:#fff;border-radius:20px 20px 0 0;padding:24px;width:100%;max-width:480px;max-height:92vh;overflow-y:auto;box-shadow:0 -8px 40px rgba(0,0,0,.2)}
.modal h2{font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:600;color:#1B2B3A;margin-bottom:16px}
.modal-foot{display:flex;gap:8px;justify-content:flex-end;margin-top:18px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* ── PROFILE ────────────────────────────────────────────── */
.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* ── TOAST ──────────────────────────────────────────────── */
.toast{position:fixed;bottom:16px;left:16px;right:16px;padding:12px 16px;border-radius:10px;font-size:13px;font-weight:500;box-shadow:0 8px 24px rgba(0,0,0,.2);z-index:9999;display:flex;align-items:center;gap:10px;color:#fff;max-width:400px;margin:auto}
.toast.ok{background:#1A5C33}.toast.err{background:#7B1A1A}.toast.info{background:#1B2B3A}

/* ── SEARCH BAR ─────────────────────────────────────────── */
.search-bar{display:flex;gap:8px;margin-bottom:14px;align-items:center;flex-wrap:wrap}

/* ── SCROLLBAR ──────────────────────────────────────────── */
::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE — TABLETTE (< 1024px)
   ══════════════════════════════════════════════════════════ */
@media (max-width:1024px){
  .stats-grid{grid-template-columns:1fr 1fr}
  .dash-grid{grid-template-columns:1fr}
  .ag-layout{grid-template-columns:1fr}
  .settings-grid{grid-template-columns:1fr}
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE — MOBILE (< 768px)
   ══════════════════════════════════════════════════════════ */
@media (max-width:768px){

  /* Sidebar cachée, slide depuis la gauche */
  .sidebar{
    position:fixed;left:0;top:0;bottom:0;
    transform:translateX(-100%);
    transition:transform .3s ease;
    z-index:200;
    box-shadow:4px 0 20px rgba(0,0,0,.3);
  }
  .sidebar.open{transform:translateX(0)}

  /* Hamburger visible */
  .btn-menu{display:flex}

  /* Layout plein écran */
  #app.on{flex-direction:column}
  .main{width:100%;height:100vh}
  .topbar{padding:0 12px;height:52px}
  .topbar-title{font-size:16px}
  .content{padding:12px}

  /* Stats en 2 colonnes serrées */
  .stats-grid{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
  .stat-card{padding:12px}
  .stat-val{font-size:22px}
  .stat-lbl{font-size:10px}

  /* Dashboard grille en colonne */
  .dash-grid{grid-template-columns:1fr}

  /* Agenda layout en colonne */
  .ag-layout{grid-template-columns:1fr}

  /* Settings en colonne */
  .settings-grid{grid-template-columns:1fr}

  /* Row2 en colonne sur très petit écran */
  .row2{grid-template-columns:1fr}

  /* Modal en bas (drawer) */
  .overlay{align-items:flex-end;padding:0}
  .modal{border-radius:20px 20px 0 0;padding:20px;max-height:85vh;max-width:100%}

  /* Calendrier — jours plus petits */
  .mday{min-height:48px;padding:3px}
  .dnum{font-size:10px;width:18px;height:18px}
  .mev{display:none}
  .mday.today .dnum{width:18px;height:18px}
  .cal-period{min-width:120px;font-size:16px}

  /* Absences */
  .abs-item{padding:10px 12px}

  /* Search bar wrappée */
  .search-bar{gap:6px}
  .search-bar .inp{width:100% !important}

  /* Toast en bas au centre */
  .toast{left:12px;right:12px;bottom:12px;max-width:none}

  /* Boutons filtre absences wrappés */
  #v-absences > div:first-child{gap:6px}
  #v-absences .btn{font-size:11px;padding:6px 10px}
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE — TRÈS PETIT (< 400px)
   ══════════════════════════════════════════════════════════ */
@media (max-width:400px){
  .stats-grid{grid-template-columns:1fr 1fr;gap:6px}
  .stat-card{padding:10px}
  .stat-val{font-size:20px}
  .login-card{padding:24px 20px}
  .content{padding:10px}
}

/* ── VIEW TOGGLE ────────────────────────────────────────── */
.view-tg{display:flex;background:#fff;border:1.5px solid var(--border);border-radius:8px;overflow:hidden}
.view-tg button{padding:6px 12px;border:none;background:none;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;cursor:pointer;color:var(--tl);transition:all .2s;white-space:nowrap}
.view-tg button.on{background:var(--accent);color:#fff}

/* ── WEEK VIEW ──────────────────────────────────────────── */
.week-wrap{background:#fff;border-radius:12px;border:1px solid var(--border);overflow:hidden;display:flex;flex-direction:column}
.week-header{display:grid;border-bottom:2px solid var(--border);background:#fff;position:sticky;top:0;z-index:10}
.wh-time{width:52px;flex-shrink:0}
.wh-day{padding:10px 4px;text-align:center;border-left:1px solid var(--border)}
.wh-day .wd-dow{display:block;font-size:10px;font-weight:600;color:var(--tl);text-transform:uppercase;letter-spacing:.05em}
.wh-day .wd-num{display:block;font-size:20px;font-weight:700;color:#1B2B3A;line-height:1.2;margin-top:2px}
.wh-day.today .wd-num{background:var(--accent);color:#fff;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:16px;margin:2px auto 0}
.week-scroll{overflow-y:auto;max-height:calc(100vh - 240px)}
.week-body{display:grid;position:relative}
.week-time-col{width:52px;flex-shrink:0}
.wt-slot{height:60px;display:flex;align-items:flex-start;justify-content:flex-end;padding:2px 6px 0 0;font-size:10px;color:var(--tl);border-bottom:1px solid rgba(226,221,216,.5)}
.week-day-col{position:relative;border-left:1px solid var(--border)}
.wd-slot{height:60px;border-bottom:1px solid rgba(226,221,216,.4)}
.wd-slot.half{border-bottom:1px dashed rgba(226,221,216,.3)}
.week-event{position:absolute;left:2px;right:2px;border-radius:6px;padding:3px 7px;font-size:11px;font-weight:500;cursor:pointer;overflow:hidden;line-height:1.3;z-index:5;transition:opacity .15s;border-left:3px solid transparent}
.week-event:hover{opacity:.85;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.week-event .ev-title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.week-event .ev-creator{font-size:10px;opacity:.8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.week-event .ev-time{font-size:10px;opacity:.75}
.week-event.blue{background:rgba(46,95,163,.15);color:#1B3A6B;border-color:var(--accent)}
.week-event.green{background:rgba(125,168,123,.2);color:#2D5E2B;border-color:#7DA87B}
.week-event.gold{background:rgba(200,165,106,.2);color:#7A5C1E;border-color:var(--gold)}
.week-event.red{background:rgba(192,57,43,.15);color:var(--red);border-color:var(--red)}
.week-event.purple{background:rgba(142,68,173,.15);color:#6C3483;border-color:#8E44AD}
/* Ligne heure courante */
.now-line{position:absolute;left:0;right:0;height:2px;background:var(--red);z-index:6;pointer-events:none}
.now-dot{position:absolute;left:-4px;top:-4px;width:8px;height:8px;background:var(--red);border-radius:50%}

/* ── DAY VIEW ───────────────────────────────────────────── */
.day-wrap{background:#fff;border-radius:12px;border:1px solid var(--border);overflow:hidden}
.day-header{padding:14px 20px;border-bottom:2px solid var(--border);text-align:center}
.day-title{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;color:#1B2B3A}
.day-subtitle{font-size:12px;color:var(--tl);margin-top:2px}
.day-body{display:grid;grid-template-columns:52px 1fr;overflow-y:auto;max-height:calc(100vh - 260px)}
.day-time-col{border-right:1px solid var(--border)}
.day-event-col{position:relative}
.day-slot{height:60px;border-bottom:1px solid rgba(226,221,216,.4)}
.day-event{position:absolute;left:4px;right:4px;border-radius:8px;padding:6px 10px;font-size:12px;cursor:pointer;overflow:hidden;z-index:5;border-left:4px solid transparent}
.day-event:hover{box-shadow:0 4px 12px rgba(0,0,0,.15)}
.day-event .ev-title{font-weight:600;margin-bottom:2px}
.day-event .ev-creator{font-size:11px;opacity:.8}
.day-event .ev-time{font-size:11px;opacity:.75}
.day-event .ev-loc{font-size:11px;opacity:.7;margin-top:2px}
.day-event.blue{background:rgba(46,95,163,.15);color:#1B3A6B;border-color:var(--accent)}
.day-event.green{background:rgba(125,168,123,.2);color:#2D5E2B;border-color:#7DA87B}
.day-event.gold{background:rgba(200,165,106,.2);color:#7A5C1E;border-color:var(--gold)}
.day-event.red{background:rgba(192,57,43,.15);color:var(--red);border-color:var(--red)}
.day-event.purple{background:rgba(142,68,173,.15);color:#6C3483;border-color:#8E44AD}
.no-events{padding:40px;text-align:center;color:var(--tl);font-size:13px}

/* ── MONTH VIEW: nom intervenant ────────────────────────── */
.mev .ev-who{font-size:9px;opacity:.75;margin-left:3px}

/* Responsive semaine/jour */
@media(max-width:768px){
  .week-scroll{max-height:calc(100vh - 180px)}
  .day-body{max-height:calc(100vh - 200px)}
  .view-tg button{padding:5px 8px;font-size:11px}
  .wh-day .wd-num{font-size:16px}
  .cal-tb{gap:6px}
}

/* ── NOTIFS ADMIN ───────────────────────────────────────── */
.notif-dot-red{display:inline-block;width:8px;height:8px;background:var(--red);border-radius:50%;margin-left:6px;vertical-align:middle;animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.notif-list{display:flex;flex-direction:column;gap:0}
.notif-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.notif-item:last-child{border-bottom:none}
.notif-item.unread{background:rgba(46,95,163,.04);margin:0 -16px;padding:12px 16px}
.notif-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.notif-text{flex:1;min-width:0}
.notif-title{font-size:13px;font-weight:500;color:#1B2B3A}
.notif-sub{font-size:11px;color:var(--tl);margin-top:2px}
.notif-time{font-size:11px;color:var(--tl);white-space:nowrap;flex-shrink:0}

/* ── QUOTAS ─────────────────────────────────────────────── */
.quota-bar{height:8px;background:var(--border);border-radius:4px;overflow:hidden;margin-top:4px}
.quota-fill{height:100%;border-radius:4px;background:var(--accent);transition:width .5s}
.quota-fill.warn{background:var(--gold)}
.quota-fill.over{background:var(--red)}

/* ── MONTH EVENTS FIX ───────────────────────────────────── */
.month-body .mday{overflow:visible}
