  /* ===== KALENDARZ ===== */
  .cal-body { padding:0 0 80px; }
  .cal-loading { text-align:center; padding:40px; color:var(--ink-faded); font-size:17px; }

  /* Lista — karty zdarzeń */
  .cal-month-hdr { padding:18px 16px 6px; font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-faded); }
  .cal-card { background:var(--paper); border:1px solid var(--line); border-radius:12px; margin:6px 16px; cursor:pointer; overflow:hidden; transition:box-shadow .15s; }
  .cal-card:hover { box-shadow:0 2px 12px rgba(0,0,0,.09); }
  .cal-card.cal-past { opacity:.5; }
  .cal-card-header { display:flex; align-items:center; justify-content:space-between; padding:9px 14px; border-bottom:1px solid var(--line-soft); gap:8px; }
  .cal-card-meta { display:flex; align-items:center; flex-wrap:wrap; gap:5px; }
  .cal-today-badge { font-size:11px; font-weight:700; background:var(--ink); color:var(--paper); padding:1px 7px; border-radius:4px; }
  .cal-card-date { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-faded); }
  .cal-card-time { font-size:12px; color:var(--ink-faded); }
  .cal-holiday-lbl { font-size:11px; color:var(--gold); font-style:italic; }
  .cal-card-title { font-family:'Fraunces',serif; font-size:16px; font-weight:700; color:var(--ink); padding:10px 14px 0; }
  .cal-card-chips { display:flex; flex-wrap:wrap; gap:4px; padding:6px 14px 10px; }
  .cal-chip { font-size:12px; padding:2px 8px; border-radius:12px; font-weight:600; }
  .cal-chip-proc { background:var(--line-soft); color:var(--ink-soft); font-weight:400; border:1px solid var(--line); }
  .cal-chip-pet  { background:var(--paper-dark); color:var(--ink-faded); font-weight:400; }
  .cal-chip-tag  { background:none; color:var(--ink-faded); font-weight:400; padding:2px 2px; }

  /* Nawigacja (tydzień/miesiąc) */
  .cal-nav { display:flex; align-items:center; justify-content:space-between; padding:10px 16px 6px; }
  .cal-nav-btn { font-size:26px; background:none; border:none; cursor:pointer; color:var(--ink); padding:0 4px; line-height:1; }
  .cal-nav-title { font-size:16px; font-weight:700; font-family:'Fraunces',serif; color:var(--ink); text-align:center; }

  /* Tydzień — siatka godzinowa */
  .cal-wk-wrap { margin:0 8px 8px; border-radius:8px; overflow:hidden; border:1px solid var(--line); }
  .cal-wscroll { display:flex; overflow-x:scroll; scroll-snap-type:x mandatory; scrollbar-width:none; -webkit-overflow-scrolling:touch; user-select:none; }
  .cal-wscroll::-webkit-scrollbar { display:none; }
  .cal-wslide { flex-shrink:0; width:100%; scroll-snap-align:start; }
  .cal-tg-outer { overflow-x:auto; scrollbar-width:thin; scrollbar-color:var(--line) transparent; }
  .cal-tg-outer::-webkit-scrollbar { height:4px; }
  .cal-tg-outer::-webkit-scrollbar-track { background:transparent; }
  .cal-tg-outer::-webkit-scrollbar-thumb { background:var(--line); border-radius:2px; }
  .cal-tg-inner { min-width:0; }
  .cal-tg-head { display:flex; border-bottom:2px solid var(--line); background:var(--paper); position:sticky; top:0; z-index:2; }
  .cal-tg-corner { width:40px; flex-shrink:0; }
  .cal-tg-hdr-cell { flex:1; min-width:36px; text-align:center; padding:6px 2px; border-left:1px solid var(--line-soft); }
  .cal-tg-hdr-today { background:rgba(31,42,58,.04); }
  .cal-tg-hdr-past { opacity:.65; }
  .cal-tg-hdr-dow { display:block; font-size:11px; color:var(--ink-faded); text-transform:uppercase; letter-spacing:.04em; }
  .cal-tg-hdr-num { display:inline-flex; align-items:center; justify-content:center; font-size:17px; font-weight:700; color:var(--ink); width:26px; height:26px; }
  .cal-tg-hdr-num-today { background:var(--ink); color:var(--paper); border-radius:50%; }
  .cal-tg-hdr-holiday { display:block; font-size:10px; color:#92400e; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; padding:0 2px; }
  .cal-tg-allday-row { display:flex; border-bottom:2px solid var(--line); min-height:24px; }
  .cal-tg-ad-lbl { width:40px; flex-shrink:0; font-size:9px; color:var(--ink-faded); text-align:right; padding:4px 4px 0; line-height:1.2; }
  .cal-tg-ad-col { flex:1; min-width:70px; padding:2px; border-left:1px solid var(--line-soft); display:flex; flex-direction:column; gap:2px; }
  .cal-tg-ad-ev { font-size:11px; padding:1px 4px; border-radius:3px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; cursor:pointer; color:var(--ink); }
  .cal-tg-scroll { overflow-y:auto; max-height:480px; }
  .cal-tg-body { display:flex; }
  .cal-tg-times { width:40px; flex-shrink:0; position:relative; user-select:none; }
  .cal-tg-time-lbl { position:absolute; right:5px; font-size:10px; color:var(--ink-faded); transform:translateY(-50%); line-height:1; white-space:nowrap; }
  .cal-tg-col { flex:1; min-width:36px; position:relative; border-left:1px solid var(--line-soft); }
  .cal-tg-col-today { background:rgba(31,42,58,.03); }
  .cal-tg-col-past { opacity:.7; }
  .cal-tg-slot { height:36px; box-sizing:border-box; }
  .cal-tg-slot-h  { border-bottom:1px solid var(--line-soft); }
  .cal-tg-slot-hh { border-bottom:1px dashed var(--line-soft); opacity:.6; }
  .cal-tg-event { position:absolute; border-radius:4px; padding:2px 4px; font-size:11px; overflow:hidden; cursor:pointer; z-index:1; box-sizing:border-box; color:var(--ink); }
  .cal-tg-ev-time { font-size:10px; opacity:.85; display:block; }
  .cal-tg-ev-title { display:block; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
  .cal-tg-now-line { position:absolute; left:0; right:0; height:2px; background:var(--accent); z-index:2; pointer-events:none; }
  .cal-tg-now-dot  { position:absolute; left:-4px; top:-3px; width:8px; height:8px; border-radius:50%; background:var(--accent); }
  .cal-bell { font-size:10px; margin-left:2px; line-height:1; }
  .cal-month-ev-time { font-size:9px; opacity:.85; }

