
/* ══ VARIABLES ══ */
:root{
  --navy:#0a1f44;--blue-mid:#1a4a8a;--blue:#2563be;--blue-lt:#4a90d9;
  --sky:#dbeafe;--sky-pale:#eff6ff;--gold:#c9a227;--gold-lt:#f5e0a0;
  --bg:#f8fafc;--surface:#ffffff;--surface2:#f1f5f9;
  --border:#e2e8f0;--border2:#cbd5e1;
  --text:#1e293b;--text2:#475569;--text3:#94a3b8;
  --red:#dc2626;--green:#16a34a;--purple:#7c3aed;--cyan:#0891b2;--pink:#db2777;
  --shadow:0 1px 6px rgba(10,31,68,.08),0 4px 20px rgba(10,31,68,.05);
  --font-s:'Libre Baskerville',Georgia,serif;--font-b:'DM Sans',system-ui,sans-serif;
  --r:12px;--hh:60px;
}
[data-theme="dark"]{
  --bg:#0d1117;--surface:#161b22;--surface2:#21262d;
  --border:#30363d;--border2:#484f58;
  --text:#e6edf3;--text2:#8b949e;--text3:#6e7681;
  --sky:#1c3a5e;--sky-pale:#162033;
  --shadow:0 1px 6px rgba(0,0,0,.3),0 4px 20px rgba(0,0,0,.2);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-b);background:var(--bg);color:var(--text);min-height:100vh;transition:background .25s,color .25s}

/* ══ HEADER ══ */
header{background:linear-gradient(135deg,var(--navy) 0%,var(--blue-mid) 60%,var(--blue) 100%);
  color:#fff;position:sticky;top:0;z-index:300;box-shadow:0 2px 16px rgba(10,31,68,.35)}
.hdr{max-width:1400px;margin:0 auto;padding:0 16px;height:var(--hh);display:flex;align-items:center;gap:10px}
.hdr-brand{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
.hdr-title h1{font-family:var(--font-s);font-size:1rem;font-weight:700;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hdr-title p{font-size:.63rem;opacity:.7;letter-spacing:.07em;text-transform:uppercase}

/* desktop right actions */
.hdr-right-desktop{display:flex;align-items:center;gap:8px}
@media(max-width:680px){.hdr-right-desktop{display:none}}

/* mobile hamburger */
.hdr-menu-btn{display:none;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;width:36px;height:36px;border-radius:8px;cursor:pointer;align-items:center;justify-content:center;flex-shrink:0}
@media(max-width:680px){.hdr-menu-btn{display:flex}}

/* mobile dropdown menu */
.hdr-menu-panel{display:none;position:absolute;top:calc(var(--hh) + 4px);right:12px;background:var(--navy);border:1px solid rgba(255,255,255,.15);border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,.4);min-width:220px;z-index:400;overflow:hidden}
.hdr-menu-panel.open{display:block}
.hdr-menu-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;font-size:.84rem;color:rgba(255,255,255,.85);border-bottom:1px solid rgba(255,255,255,.08);cursor:pointer;gap:10px}
.hdr-menu-item:last-child{border-bottom:none}
.hdr-menu-item:hover{background:rgba(255,255,255,.08)}
.hdr-menu-label{display:flex;align-items:center;gap:8px}
.hdr-menu-sep{height:1px;background:rgba(255,255,255,.08);margin:4px 0}
.hdr-login-row{padding:10px 12px}

/* ══ ADMIN BAR ══ */
.admin-bar{background:linear-gradient(90deg,#1a4a8a,#0a1f44);border-bottom:2px solid var(--gold);
  padding:6px 16px;display:none;align-items:center;gap:8px;flex-wrap:wrap}
.admin-bar.on{display:flex}
.admin-bar-txt{font-size:.73rem;color:var(--gold-lt);font-weight:500;flex:1;min-width:0}
.sync-badge{display:inline-flex;align-items:center;gap:5px;font-size:.68rem;padding:3px 9px;border-radius:20px}
.sync-badge.ok{background:rgba(22,163,74,.2);color:#86efac}
.sync-badge.err{background:rgba(220,38,38,.2);color:#fca5a5}
.sync-badge.load{background:rgba(255,255,255,.08);color:rgba(255,255,255,.55)}
.sync-dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}
.sync-dot.pulse{animation:pulse 1.4s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.2}}

/* ══ TOOLBAR ══ */
.toolbar{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:var(--hh);z-index:200;transition:background .25s}
.toolbar-inner{max-width:1400px;margin:0 auto;padding:0 16px}

/* month row */
.month-row{display:flex;align-items:center;gap:5px;padding:7px 0 5px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.year-badge{font-family:var(--font-s);font-size:.88rem;color:var(--gold);font-weight:700;letter-spacing:.04em;flex-shrink:0;margin-right:3px}
.month-tabs{display:flex;gap:2px;flex-wrap:wrap;flex:1}
.mtab{padding:4px 9px;border-radius:5px;font-size:.73rem;font-weight:500;color:var(--text2);cursor:pointer;border:1px solid transparent;background:transparent;font-family:var(--font-b);transition:all .15s}
.mtab:hover{color:var(--text);background:var(--surface2)}
.mtab.on{color:#fff;background:var(--blue);border-color:var(--blue);font-weight:600}
  .today-btn{padding:4px 11px;border-radius:5px;font-size:.73rem;font-weight:600;color:var(--text);cursor:pointer;border:1.5px solid var(--border2);background:var(--surface);font-family:var(--font-b);transition:all .15s;flex-shrink:0}
.today-btn:hover{border-color:var(--blue);color:var(--blue)}
.today-btn.dim{opacity:.4;pointer-events:none}

/* cal header row: title + controls */
.cal-header-row{display:flex;align-items:center;gap:8px;padding:8px 0 6px;flex-wrap:wrap}
.cal-title{font-family:var(--font-s);font-size:1.3rem;color:var(--navy);font-weight:700;flex-shrink:0;margin-right:4px}
[data-theme="dark"] .cal-title{color:var(--blue-lt)}
.cal-title span{color:var(--blue);font-style:italic}

/* info (i) button for stats */
.info-btn{width:26px;height:26px;border-radius:50%;background:var(--surface2);border:1.5px solid var(--border2);color:var(--text2);cursor:pointer;font-size:.78rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;transition:all .15s}
.info-btn:hover{border-color:var(--blue);color:var(--blue)}
.stats-popup{position:absolute;top:calc(100% + 6px);left:0;background:var(--surface);border:1px solid var(--border2);border-radius:10px;box-shadow:0 4px 20px rgba(0,0,0,.15);padding:10px 14px;min-width:180px;z-index:250;display:none;white-space:nowrap}
.stats-popup.open{display:block}
.stat-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:.78rem;border-bottom:1px solid var(--border)}
.stat-row:last-child{border-bottom:none}
.stat-row-lbl{color:var(--text2)}
.stat-row-val{font-weight:700;color:var(--blue)}

/* search */
.search-wrap{position:relative;margin-left:auto}
.search-wrap svg{position:absolute;left:8px;top:50%;transform:translateY(-50%);opacity:.38;pointer-events:none}
#searchInput{width:150px;padding:6px 8px 6px 27px;border:1.5px solid var(--border2);border-radius:7px;font-family:var(--font-b);font-size:.76rem;background:var(--surface);color:var(--text);transition:all .15s}
#searchInput:focus{outline:none;border-color:var(--blue);width:200px}
@media(max-width:480px){#searchInput{width:110px}#searchInput:focus{width:140px}}

/* add btn (admin) */
#addEventBtn{display:none}

/* filter row */
.filter-row{display:flex;align-items:center;gap:6px;padding:5px 0 7px;flex-wrap:wrap}
/* category filter as dropdown */
.cat-filter-wrap{position:relative}
.cat-filter-btn{display:flex;align-items:center;gap:5px;padding:4px 11px;border-radius:20px;border:1.5px solid var(--border2);background:var(--surface);color:var(--text2);font-family:var(--font-b);font-size:.73rem;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}
.cat-filter-btn:hover{border-color:var(--blue);color:var(--blue)}
.cat-filter-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.cat-filter-dropdown{position:absolute;top:calc(100% + 4px);left:0;background:var(--surface);border:1px solid var(--border2);border-radius:10px;box-shadow:0 4px 20px rgba(0,0,0,.14);min-width:180px;z-index:250;display:none;overflow:hidden}
.cat-filter-dropdown.open{display:block}
.cat-filter-opt{display:flex;align-items:center;gap:8px;padding:9px 14px;font-size:.8rem;color:var(--text2);cursor:pointer;transition:background .12s}
.cat-filter-opt:hover{background:var(--surface2)}
.cat-filter-opt.on{color:var(--blue);font-weight:600}
.cat-filter-dot{width:9px;height:9px;border-radius:2px;flex-shrink:0}

/* ══ BUTTONS ══ */
.btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:6px;font-family:var(--font-b);font-size:.8rem;font-weight:500;cursor:pointer;border:none;transition:all .18s;white-space:nowrap}
.btn-outline{background:transparent;border:1.5px solid rgba(255,255,255,.4);color:#fff}
.btn-outline:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.8)}
.btn-ghost{background:var(--surface2);border:1.5px solid var(--border);color:var(--text2)}
.btn-ghost:hover{border-color:var(--blue-lt);color:var(--text)}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-mid)}
.btn-success{background:var(--green);color:#fff}
.btn-success:hover{background:#15803d}
.btn-sm{padding:4px 9px;font-size:.74rem}
.btn:disabled{opacity:.4;cursor:not-allowed}

/* toggles */
.tog{display:flex;align-items:center;gap:6px;cursor:pointer;user-select:none;font-size:.74rem;color:rgba(255,255,255,.8)}
.tog-track{width:29px;height:16px;border-radius:8px;background:rgba(255,255,255,.2);position:relative;transition:background .2s;flex-shrink:0}
.tog-track.on{background:var(--gold)}
.tog-thumb{position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:#fff;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.25)}
.tog-track.on .tog-thumb{left:15px}
.login-badge{display:inline-flex;align-items:center;gap:4px;font-size:.68rem;padding:3px 9px;border-radius:20px;background:rgba(255,255,255,.1);color:rgba(255,255,255,.8)}
.login-badge.on{background:rgba(201,162,39,.25);color:var(--gold-lt)}

/* ══ CALENDAR ══ */
main{max-width:1400px;margin:0 auto;padding:14px 16px 60px}
.cal-section{animation:fadeUp .3s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.cal-grid{background:var(--surface);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;border:1px solid var(--border);transition:background .25s;width:100%;table-layout:fixed}
.cal-names{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));background:var(--navy);width:100%}
[data-theme="dark"] .cal-names{background:#0d1b2a}
.cal-name{text-align:center;font-size:.64rem;font-weight:600;color:rgba(255,255,255,.7);padding:7px 2px;letter-spacing:.06em;text-transform:uppercase}
.cal-name:first-child{color:var(--gold)}.cal-name:last-child{color:var(--gold-lt)}
.cal-body{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));width:100%}
.cal-cell{min-height:96px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:5px 4px 4px;display:flex;flex-direction:column;gap:2px;position:relative;transition:background .12s}
.cal-cell:nth-child(7n){border-right:none}
.cal-cell.empty{background:var(--surface2)}
.cal-cell.today{background:var(--sky-pale)}
[data-theme="dark"] .cal-cell.today{background:#162033}
.cal-cell.today .cal-num{background:var(--blue);color:#fff}
.cal-num{font-size:.75rem;font-weight:700;color:var(--text2);width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0;line-height:1;margin-bottom:1px}
.cal-cell.sunday .cal-num{color:var(--red)}.cal-cell.saturday .cal-num{color:var(--purple)}
.cal-cell:not(.empty):hover .cal-num{background:var(--sky);color:var(--blue)}
.cal-add{position:absolute;top:3px;right:3px;width:17px;height:17px;border-radius:50%;background:var(--blue);color:#fff;border:none;cursor:pointer;font-size:13px;display:none;align-items:center;justify-content:center;opacity:.7;line-height:1}
.cal-add:hover{opacity:1}
body.admin-mode .cal-cell:not(.empty):hover .cal-add{display:flex}

/* ── EVENT PILL (Apple Cal style: single line, colored dot) ── */
.event-pill{display:flex;align-items:center;gap:3px;border-radius:4px;padding:1px 5px;
  font-size:.65rem;line-height:1.45;cursor:pointer;position:relative;
  overflow:hidden;white-space:nowrap;text-overflow:ellipsis;
  background:var(--surface2);color:var(--text);border:none;
  transition:filter .12s;user-select:none;min-width:0}
.event-pill:hover{filter:brightness(.88)}
.ev-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.ev-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}
.ev-time-inline{font-size:.58rem;opacity:.7;flex-shrink:0;margin-left:1px}
/* category background tints */
.ev-koor        {background:#ede9fe;color:#4c1d95}
.ev-ibadah      {background:#fef9c3;color:#713f12}
.ev-rapat       {background:#e0f2fe;color:#0c4a6e}
.ev-latihan     {background:#dcfce7;color:#14532d}
.ev-reversement {background:#fce7f3;color:#831843}
.ev-doa         {background:#dbeafe;color:#1e3a8a}
.ev-other       {background:var(--surface2);color:var(--text2)}
[data-theme="dark"] .ev-koor       {background:#2e1065;color:#c4b5fd}
[data-theme="dark"] .ev-ibadah     {background:#292000;color:#fde68a}
[data-theme="dark"] .ev-rapat      {background:#082f49;color:#7dd3fc}
[data-theme="dark"] .ev-latihan    {background:#052e16;color:#86efac}
[data-theme="dark"] .ev-reversement{background:#500724;color:#f9a8d4}
[data-theme="dark"] .ev-doa        {background:#1e3a5f;color:#93c5fd}
[data-theme="dark"] .ev-other      {background:#21262d;color:#8b949e}
/* admin delete on hover */
.ev-del{display:none;position:absolute;right:2px;top:50%;transform:translateY(-50%);background:var(--red);color:#fff;border:none;border-radius:3px;font-size:.56rem;padding:1px 4px;cursor:pointer;z-index:2;line-height:1.4}
body.admin-mode .event-pill:hover .ev-del{display:block}
body.admin-mode .event-pill:hover .ev-label{padding-right:18px}
/* drag */
.event-pill[draggable="true"]{cursor:grab}
.event-pill.dragging{opacity:.35}
.cal-cell.drag-over{background:var(--sky)!important;outline:2px dashed var(--blue);outline-offset:-2px}
/* more indicator */
.ev-more{font-size:.6rem;color:var(--text3);padding:1px 4px;cursor:pointer;text-align:left;background:none;border:none;font-family:var(--font-b)}
.ev-more:hover{color:var(--blue)}
/* search dim */
.cal-cell.no-match{opacity:.2}
.ev-hl{outline:2px solid var(--gold)!important;outline-offset:1px}

/* ══ LEGEND ══ */
.legend{display:flex;flex-wrap:wrap;gap:7px;padding:11px 15px;background:var(--surface);border-radius:var(--r);border:1px solid var(--border);margin-top:14px;transition:background .25s}
.leg-item{display:flex;align-items:center;gap:5px;font-size:.7rem;color:var(--text2)}
.leg-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* ══ MODAL ══ */
.overlay{position:fixed;inset:0;background:rgba(10,31,68,.55);backdrop-filter:blur(4px);z-index:500;
  display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity .2s}
.overlay.on{opacity:1;pointer-events:auto}
.modal{background:var(--surface);border-radius:14px;width:100%;max-width:480px;
  box-shadow:0 20px 60px rgba(0,0,0,.28);transform:translateY(20px);transition:transform .2s,background .25s;overflow:hidden}
.overlay.on .modal{transform:translateY(0)}
.modal-hdr{background:linear-gradient(135deg,var(--navy),var(--blue-mid));padding:14px 18px;display:flex;align-items:center;justify-content:space-between}
.modal-hdr h2{font-family:var(--font-s);font-size:.9rem;color:#fff;font-weight:700}
.modal-x{background:rgba(255,255,255,.15);border:none;color:#fff;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center}
.modal-x:hover{background:rgba(255,255,255,.3)}
.modal-body{padding:16px 18px;max-height:75vh;overflow-y:auto}
.modal-foot{padding:10px 18px;background:var(--surface2);border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}
.form-g{margin-bottom:12px}
.form-g label{display:block;font-size:.72rem;font-weight:600;color:var(--text2);margin-bottom:4px;letter-spacing:.04em;text-transform:uppercase}
.form-g input,.form-g select,.form-g textarea{width:100%;padding:8px 10px;border:1.5px solid var(--border2);border-radius:7px;font-family:var(--font-b);font-size:.83rem;color:var(--text);background:var(--surface);transition:border-color .15s}
.form-g input:focus,.form-g select:focus,.form-g textarea:focus{outline:none;border-color:var(--blue)}
.form-row{display:flex;gap:9px}.form-row .form-g{flex:1}
.pw-wrap{position:relative}.pw-wrap input{padding-right:36px}
.pw-eye{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text3);padding:2px;display:flex;align-items:center}
.pw-eye:hover{color:var(--text2)}
.login-err{color:var(--red);font-size:.74rem;display:none;margin-top:-6px;margin-bottom:4px}

/* cat inline manager */
.cat-row-inline{display:flex;align-items:center;gap:7px}
.cat-row-inline select{flex:1;padding:8px 10px;border:1.5px solid var(--border2);border-radius:7px;font-family:var(--font-b);font-size:.83rem;color:var(--text);background:var(--surface)}
.cat-row-inline select:focus{outline:none;border-color:var(--blue)}
.cat-mgr-toggle{flex-shrink:0;padding:7px 9px;border:1.5px solid var(--border2);border-radius:7px;background:var(--surface);color:var(--text2);cursor:pointer;font-size:.73rem;font-family:var(--font-b);transition:all .15s}
.cat-mgr-toggle:hover{border-color:var(--blue-lt);color:var(--text)}
.cat-mgr-panel{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:9px;margin-top:5px;display:none}
.cat-mgr-panel.open{display:block}
.cat-list-item{display:flex;align-items:center;gap:6px;padding:3px 0;border-bottom:1px solid var(--border)}
.cat-list-item:last-child{border-bottom:none}
.cat-swatch{width:9px;height:9px;border-radius:2px;flex-shrink:0}
.cat-lbl{flex:1;font-size:.77rem;color:var(--text)}
.cat-built{font-size:.62rem;color:var(--text3)}
.cat-del-btn{background:none;border:none;color:var(--red);cursor:pointer;font-size:14px;padding:1px 3px;border-radius:3px;opacity:.7}
.cat-del-btn:hover{opacity:1;background:rgba(220,38,38,.1)}
.cat-add-row{display:flex;gap:5px;margin-top:7px}
.cat-add-row input{flex:1;padding:5px 8px;border:1.5px solid var(--border2);border-radius:6px;font-family:var(--font-b);font-size:.78rem;background:var(--surface);color:var(--text)}
.cat-add-row input:focus{outline:none;border-color:var(--blue)}

/* detail modal */
.det-card{padding:2px}
.det-date{font-size:.7rem;color:var(--blue);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.det-title{font-size:.95rem;font-weight:600;color:var(--text);line-height:1.35}
.det-time{font-size:.79rem;color:var(--text2);margin-top:4px}
.det-note{margin-top:9px;font-size:.81rem;color:var(--text2);line-height:1.6;word-break:break-word;overflow-wrap:anywhere;white-space:pre-wrap}
.det-cat{display:inline-block;margin-top:9px;font-size:.67rem;padding:3px 9px;border-radius:20px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}

/* ══ TOAST ══ */
.toast{position:fixed;bottom:20px;right:16px;background:var(--navy);color:#fff;padding:10px 15px;border-radius:8px;font-size:.81rem;box-shadow:0 4px 20px rgba(0,0,0,.25);transform:translateY(80px);opacity:0;transition:all .25s;z-index:900;max-width:290px;border-left:4px solid var(--gold)}
.toast.on{transform:translateY(0);opacity:1}
.toast.err{border-left-color:var(--red)}
.toast.ok{border-left-color:var(--green)}

/* ══ FOOTER ══ */
footer{background:var(--navy);color:rgba(255,255,255,.4);text-align:center;padding:12px 16px;font-size:.7rem;line-height:1.9}
footer strong{color:rgba(255,255,255,.75)}

/* ══ EXPORT MODAL ══ */
.export-modal{max-width:500px}
.export-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.export-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 10px;border-radius:10px;border:2px solid var(--border);background:var(--surface2);cursor:pointer;transition:all .18s;text-align:center}
.export-card:hover{border-color:var(--blue);background:var(--sky-pale)}
.export-card.selected{border-color:var(--blue);background:var(--sky);box-shadow:0 0 0 3px rgba(37,99,190,.15)}
[data-theme="dark"] .export-card.selected{background:var(--sky)}
.export-card-icon{font-size:1.6rem;line-height:1}
.export-card-title{font-size:.78rem;font-weight:700;color:var(--text)}
.export-card-desc{font-size:.65rem;color:var(--text2);line-height:1.3}
.export-section-title{font-size:.72rem;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}
.export-scope-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.export-scope-btn{padding:5px 13px;border-radius:20px;font-size:.73rem;font-weight:600;border:1.5px solid var(--border2);background:var(--surface);color:var(--text2);cursor:pointer;font-family:var(--font-b);transition:all .15s}
.export-scope-btn:hover{border-color:var(--blue);color:var(--blue)}
.export-scope-btn.on{background:var(--blue);color:#fff;border-color:var(--blue)}
.export-progress{display:none;text-align:center;padding:18px 0 6px}
.export-progress.on{display:block}
.export-progress-bar{width:100%;height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin:8px 0}
.export-progress-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--blue-lt));border-radius:3px;width:0%;transition:width .3s}
.export-progress-txt{font-size:.74rem;color:var(--text2)}

/* ══ LOADING ══ */
.loading-box{text-align:center;padding:60px 20px;color:var(--text3)}
.spinner{width:30px;height:30px;border:3px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 10px}
@keyframes spin{to{transform:rotate(360deg)}}

@media(max-width:700px){
  .ev-time-inline{display:none}
  .ev-more{font-size:.56rem}
}
@media(max-width:540px){
  .cal-cell{min-height:0;padding:3px 2px 4px}
  .cal-num{font-size:.64rem;width:16px;height:16px}
  .event-pill{font-size:.56rem;padding:1px 3px;gap:2px}
  .ev-dot{width:5px;height:5px}
  .ev-more{font-size:.52rem;padding:0 2px}
  .cal-title{font-size:1.05rem}
  main{padding:10px 6px 50px}
  .cal-name{font-size:.6rem;padding:6px 1px;letter-spacing:.02em}
  .toolbar-inner{padding:0 8px}
  .cal-grid{font-size:.7rem}
}
@media(max-width:380px){
  .cal-num{font-size:.58rem;width:14px;height:14px}
  .event-pill{font-size:.5rem}
  .cal-name{font-size:.55rem}
}
.event-preview{
  position:absolute;
  background:#1f2937;
  color:#fff;
  padding:10px 12px;
  border-radius:8px;
  font-size:13px;
  width:240px;
  box-shadow:0 8px 24px rgba(0,0,0,0.25);
  z-index:9999;
  pointer-events:none;
  opacity:0;
  transition:opacity .15s ease;
}

.event-preview.show{
  opacity:1;
}
