/* ── CALENDAR ───────────────────────────────────────────── */
/* Calendar fills exactly the viewport — no page-level scroll.
   Counter-zoom counters the html { zoom:1.15 } in base.css. */
#page-calendar{
  zoom:calc(1 / 1.15);
  padding-bottom:0;
}
#page-calendar.active{
  height:100vh;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.cal-wrap{
  flex:1;
  min-height:0;
  display:flex;
  flex-direction:column;
  padding:0 clamp(14px,3vw,32px) 12px;
  max-width:1480px;
  margin:0 auto;
  width:100%;
  box-sizing:border-box;
}
.cal-shell{
  display:flex;
  flex-direction:column;
  gap:18px;
  flex:1;
  min-height:0;
}

/* ── TOOLBAR ──────────────────────────────────────────── */
/* Two-column grid mirrors the body layout so the mode segment on the right
   aligns perfectly with the 320px side panel underneath it. */
.cal-toolbar{
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  align-items:center;
  gap:18px;
  padding:4px 2px 12px;
}
.cal-toolbar-nav{display:flex;align-items:center;gap:10px;min-width:0}
.cal-toolbar-arrows{display:flex;align-items:center;gap:4px}
.cal-toolbar-r{display:flex;align-items:center;justify-content:stretch;width:100%}
.cal-nav-btn{
  width:32px;height:32px;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--chip-bg);
  color:var(--t2);
  border:1px solid var(--chip-border);
  border-radius:8px;
  cursor:pointer;
}
.cal-nav-btn:hover{background:var(--chip-hover-bg);color:var(--t1);border-color:var(--chip-hover-border)}
.cal-nav-btn:active{transform:scale(.94)}
.cal-today-btn{
  height:32px;
  padding:0 12px;
  background:var(--chip-bg);
  color:var(--t2);
  border:1px solid var(--chip-border);
  border-radius:8px;
  font-weight:600;
  font-size:12.5px;
  font-family:var(--font);
  letter-spacing:.01em;
  cursor:pointer;
}
.cal-today-btn:hover{background:var(--chip-hover-bg);color:var(--t1);border-color:var(--chip-hover-border)}
.cal-title{
  display:flex;
  align-items:baseline;
  justify-content:center;
  gap:7px;
  margin:0 2px;
  min-width:200px;
  font-family:var(--font);
  line-height:1;
  user-select:none;
}
.cal-title-month{
  font-weight:700;
  font-size:clamp(17px,2vw,22px);
  color:var(--t1);
  letter-spacing:-.015em;
  font-style:normal;
}
.cal-title-year{
  font-weight:500;
  font-style:normal;
  font-size:clamp(13px,1.4vw,16px);
  color:var(--t3);
  letter-spacing:.02em;
}
.cal-mode-seg{
  display:flex;
  width:100%;
  padding:3px;
  background:var(--chip-bg);
  border:1px solid var(--chip-border);
  border-radius:10px;
  gap:2px;
  box-sizing:border-box;
}
.cal-mode-btn{
  appearance:none;
  border:none;
  background:transparent;
  color:var(--t2);
  flex:1;
  padding:6px 12px;
  font-size:12.5px;
  font-weight:600;
  letter-spacing:.01em;
  border-radius:7px;
  cursor:pointer;
  text-align:center;
  font-family:var(--font);
}
.cal-mode-btn:hover{color:var(--t1)}
.cal-mode-btn.active{
  background:var(--chip-active-bg);
  color:var(--t1);
  box-shadow:var(--chip-active-shadow),0 1px 2px rgba(0,0,0,.22);
}

/* ── BODY LAYOUT ──────────────────────────────────────── */
.cal-body{
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:18px;
  align-items:stretch;
  flex:1;
  min-height:0;
  overflow:hidden;
}
@media (max-width:1100px){
  .cal-body{grid-template-columns:1fr;overflow:visible}
  .cal-side{order:-1}
  .cal-toolbar{grid-template-columns:1fr;gap:10px}
  .cal-toolbar-r{justify-self:stretch}
}
.cal-main{
  background:var(--card);
  border:1px solid var(--sep);
  border-radius:16px;
  box-shadow:0 10px 28px rgba(0,0,0,.22);
  padding:14px;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}

/* ── MONTH ────────────────────────────────────────────── */
.cal-month{display:flex;flex-direction:column;flex:1;min-height:0}
.cal-month-head{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:4px;
  padding:2px 4px 10px;
}
.cal-dow{
  text-align:center;
  font-size:10.5px;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--t3);
  user-select:none;
}
.cal-month-grid{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  grid-auto-rows:minmax(80px,1fr);
  gap:4px;
  flex:1;
  min-height:0;
}
.cal-day{
  position:relative;
  appearance:none;
  text-align:left;
  background:rgba(255,255,255,.012);
  border:1px solid transparent;
  border-radius:10px;
  padding:8px 8px 6px;
  color:var(--t2);
  cursor:pointer;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.cal-day:hover{
  background:rgba(255,255,255,.045);
  border-color:var(--sep);
}
.cal-day-weekend{background:rgba(255,255,255,.022)}
.cal-day-other{opacity:.38}
.cal-day-other .cal-day-num{font-weight:300}
.cal-day-num{
  display:inline-block;
  font-size:13px;
  font-weight:500;
  color:var(--t1);
  line-height:1;
}
.cal-day-other .cal-day-num{color:var(--t2)}
.cal-day-mo{
  display:inline-block;
  margin-left:6px;
  font-size:10px;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--t3);
  vertical-align:middle;
}
.cal-day-pill{
  position:absolute;
  top:6px;right:8px;
  font-size:9.5px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  padding:2px 6px;
  border-radius:99px;
  background:rgba(111,151,246,.16);
  color:var(--acc);
}
.cal-day-today{
  border-color:rgba(111,151,246,.3);
  background:radial-gradient(120% 120% at 0% 0%,rgba(111,151,246,.09),rgba(111,151,246,0) 70%);
}
.cal-day-today .cal-day-num{color:var(--acc);font-weight:700}
.cal-day-selected{
  border-color:rgba(255,255,255,.22);
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
  box-shadow:0 0 0 1px rgba(111,151,246,.18),0 6px 14px rgba(0,0,0,.24);
}
.cal-day-selected.cal-day-today{
  border-color:rgba(111,151,246,.55);
  box-shadow:0 0 0 1px rgba(111,151,246,.3),0 6px 14px rgba(0,0,0,.26);
}
.cal-day-entries{
  margin-top:6px;
  display:flex;
  flex-direction:column;
  gap:2px;
  overflow:hidden;
}
.cal-entry{
  display:flex;
  align-items:center;
  gap:6px;
  padding:3px 6px;
  border-radius:6px;
  background:rgba(255,255,255,.04);
  /* Preview-only — clicks fall through to the parent day cell. */
  cursor:default;
  pointer-events:none;
  min-width:0;
}
.cal-entry-dot{
  flex-shrink:0;
  width:6px;height:6px;
  border-radius:99px;
  background:var(--t3);
}
.cal-entry-lbl{
  flex:1;
  min-width:0;
  font-size:11.5px;
  line-height:1.35;
  color:var(--t1);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.cal-entry-more{
  font-size:10.5px;
  font-weight:500;
  color:var(--t2);
  padding:2px 6px;
  cursor:pointer;
  letter-spacing:.02em;
}
.cal-entry-more:hover{color:var(--t1)}

/* Status tints */
.cal-sw-urgent .cal-entry-dot,.cal-sw-urgent .cal-agenda-dot{background:var(--urgent);box-shadow:0 0 8px rgba(228,58,58,.55)}
.cal-sw-ongoing .cal-entry-dot,.cal-sw-ongoing .cal-agenda-dot{background:var(--ongoing)}
.cal-sw-hold .cal-entry-dot,.cal-sw-hold .cal-agenda-dot{background:var(--hold)}
.cal-sw-done .cal-entry-dot,.cal-sw-done .cal-agenda-dot{background:var(--done)}
.cal-sw-empty .cal-entry-dot,.cal-sw-empty .cal-agenda-dot{background:var(--t3)}

.cal-sw-urgent.cal-entry{background:linear-gradient(90deg,rgba(228,58,58,.14),rgba(228,58,58,.04))}
.cal-sw-urgent.cal-entry:hover{background:linear-gradient(90deg,rgba(228,58,58,.22),rgba(228,58,58,.06))}
.cal-sw-urgent .cal-entry-lbl{color:#f2cfcf}
.cal-sw-ongoing .cal-entry-lbl,.cal-sw-hold .cal-entry-lbl{color:var(--t1)}
.cal-sw-done .cal-entry-lbl{color:var(--t2);text-decoration:line-through;text-decoration-color:rgba(85,194,121,.45)}

/* ── WEEK ─────────────────────────────────────────────── */
.cal-week{
  display:grid;
  grid-template-columns:repeat(7,minmax(0,1fr));
  gap:10px;
  flex:1;
  min-height:0;
}
.cal-week-col{
  display:flex;
  flex-direction:column;
  background:rgba(255,255,255,.02);
  border:1px solid var(--sep);
  border-radius:12px;
  overflow:hidden;
  min-height:460px;
}
.cal-week-col:hover{background:rgba(255,255,255,.035)}
.cal-week-col.cal-week-selected{
  border-color:rgba(255,255,255,.22);
  box-shadow:0 0 0 1px rgba(111,151,246,.18);
}
.cal-week-col.cal-week-today .cal-week-num{color:var(--acc)}
.cal-week-col-head{
  appearance:none;
  background:transparent;
  border:none;
  border-bottom:1px solid var(--sep);
  padding:10px 12px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:2px;
  cursor:pointer;
  text-align:left;
}
.cal-week-col-head:hover{background:rgba(255,255,255,.04)}
.cal-week-dow{
  font-size:10px;
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--t3);
}
.cal-week-num{
  font-family:var(--font);
  font-style:normal;
  font-weight:600;
  font-size:22px;
  color:var(--t1);
  line-height:1;
}
.cal-week-col-body{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:10px;
  flex:1;
}
.cal-week-empty{
  color:var(--t3);
  font-size:11.5px;
  text-align:center;
  padding:18px 4px;
  user-select:none;
}
.cal-week-add{
  margin-top:auto;
  appearance:none;
  background:transparent;
  border:1px dashed var(--sep);
  border-radius:8px;
  padding:7px 8px;
  color:var(--t2);
  font-size:11px;
  font-weight:500;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:4px;
  cursor:pointer;
}
.cal-week-add:hover{color:var(--t1);border-color:var(--chip-hover-border);background:rgba(255,255,255,.03)}
.cal-week-add span{font-weight:600;font-size:13px;line-height:1}
.cal-week-add em{font-style:normal;letter-spacing:.04em}

/* ── AGENDA ───────────────────────────────────────────── */
.cal-agenda{
  display:flex;
  flex-direction:column;
  gap:22px;
  padding:2px 0 12px;
  flex:1;
  min-height:0;
  overflow-y:auto;
}
.cal-agenda-group{display:flex;flex-direction:column;gap:6px}
.cal-agenda-group-head{
  font-size:10.5px;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--t3);
  padding:0 2px 4px;
}
.cal-agenda-day{
  display:grid;
  grid-template-columns:80px 1fr;
  gap:14px;
  padding:12px 2px;
  border-top:1px solid var(--sep);
  cursor:pointer;
  border-radius:6px;
}
.cal-agenda-day:first-child{border-top:none}
.cal-agenda-day:hover{background:rgba(255,255,255,.02)}
.cal-agenda-day-date{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:1px;
  padding-top:2px;
  user-select:none;
}
.cal-agenda-day-num{
  font-family:var(--font);
  font-style:normal;
  font-weight:600;
  font-size:30px;
  line-height:1;
  color:var(--t1);
}
.cal-agenda-day-dow{
  font-size:10.5px;
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--t2);
  margin-top:3px;
}
.cal-agenda-day-mo{
  font-size:10px;
  font-weight:500;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--t3);
}
.cal-agenda-day-today .cal-agenda-day-num{color:var(--acc)}
.cal-agenda-day-overdue .cal-agenda-day-num{color:var(--urgent)}
.cal-agenda-day-overdue .cal-agenda-day-dow{color:rgba(228,58,58,.85)}
.cal-agenda-day-list{display:flex;flex-direction:column;gap:6px;min-width:0}
.cal-agenda-item{
  appearance:none;
  text-align:left;
  display:flex;
  align-items:center;
  gap:10px;
  padding:9px 12px;
  background:rgba(255,255,255,.025);
  border:1px solid var(--sep);
  border-radius:9px;
  cursor:pointer;
  min-width:0;
  color:var(--t1);
}
.cal-agenda-item:hover{background:rgba(255,255,255,.05);border-color:var(--chip-hover-border)}
.cal-agenda-item:active{transform:scale(.996)}
.cal-agenda-dot{
  flex-shrink:0;
  width:8px;height:8px;
  border-radius:99px;
  background:var(--t3);
}
.cal-agenda-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.cal-agenda-text{
  font-size:13px;
  line-height:1.3;
  color:var(--t1);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.cal-agenda-meta{
  font-size:11px;
  color:var(--t3);
  letter-spacing:.01em;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.cal-agenda-link{
  flex-shrink:0;
  color:var(--t3);
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.cal-sw-urgent.cal-agenda-item{
  background:linear-gradient(90deg,rgba(228,58,58,.1),rgba(228,58,58,.03));
  border-color:rgba(228,58,58,.3);
}
.cal-sw-urgent.cal-agenda-item:hover{background:linear-gradient(90deg,rgba(228,58,58,.18),rgba(228,58,58,.04))}
.cal-sw-done.cal-agenda-item .cal-agenda-text{text-decoration:line-through;text-decoration-color:rgba(85,194,121,.45);color:var(--t2)}

.cal-agenda-empty{
  text-align:center;
  padding:70px 20px;
  color:var(--t2);
}

/* ── SIDE PANEL ───────────────────────────────────────── */
.cal-side{
  background:var(--card);
  border:1px solid var(--sep);
  border-radius:16px;
  box-shadow:0 10px 28px rgba(0,0,0,.22);
  padding:20px 18px 16px;
  display:flex;
  flex-direction:column;
  gap:14px;
  overflow:hidden;
}
.cal-side-head{display:flex;flex-direction:column;gap:2px}
.cal-side-kicker{
  font-size:10.5px;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--t3);
}
.cal-side-title{
  display:flex;
  align-items:baseline;
  gap:10px;
  font-family:var(--font);
  line-height:1;
}
.cal-side-title-num{
  font-style:normal;
  font-weight:700;
  font-size:42px;
  color:var(--t1);
  letter-spacing:-.02em;
}
.cal-side-title-mo{
  font-weight:500;
  font-style:normal;
  font-size:17px;
  color:var(--t2);
  letter-spacing:.02em;
}
.cal-side-reltags{display:flex;gap:6px;margin-top:4px;flex-wrap:wrap}
.cal-side-pill{
  display:inline-flex;
  align-items:center;
  padding:3px 9px;
  border-radius:99px;
  background:rgba(255,255,255,.06);
  border:1px solid var(--sep);
  font-size:10.5px;
  font-weight:500;
  letter-spacing:.04em;
  color:var(--t2);
}
.cal-side-pill-today{
  background:rgba(111,151,246,.16);
  border-color:rgba(111,151,246,.3);
  color:var(--acc);
}
.cal-side-pill-overdue{
  background:rgba(228,58,58,.14);
  border-color:rgba(228,58,58,.28);
  color:#e88282;
}

.cal-side-summary{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  padding-bottom:2px;
}
.cal-side-sum-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:3px 9px;
  border-radius:99px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--sep);
  font-size:10.5px;
}
.cal-side-sum-dot{
  width:6px;height:6px;border-radius:99px;
  background:var(--sum-c,var(--t3));
}
.cal-side-sum-num{font-weight:600;color:var(--t1)}
.cal-side-sum-lbl{color:var(--t2);letter-spacing:.02em}

.cal-side-list{
  display:flex;
  flex-direction:column;
  gap:6px;
  overflow-y:auto;
  overflow-x:hidden;
  padding-right:4px;
  margin:0 -2px;
  padding-left:2px;
  flex:1;
  min-height:0;
}
.cal-side-item{
  display:flex;
  align-items:stretch;
  gap:6px;
}
.cal-side-item-main{
  flex:1;
  min-width:0;
}
.cal-side-item-body{
  min-width:0;
}
.cal-side-item-main .cal-agenda-link{
  margin-left:auto;
}
.cal-side-item-jump{
  width:34px;
  flex:0 0 34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.025);
  border:1px solid var(--sep);
  border-radius:9px;
  color:var(--t2);
  cursor:pointer;
}
.cal-side-item-jump:hover{
  background:rgba(255,255,255,.05);
  border-color:var(--chip-hover-border);
  color:var(--t1);
}
.cal-side-item-jump:active{transform:scale(.996)}
.cal-side-item-jump svg{
  width:13px;
  height:13px;
  transform:rotate(-90deg);
}
.cal-side-empty{
  text-align:center;
  padding:28px 8px;
  color:var(--t2);
}
.cal-empty-title{font-size:13px;color:var(--t1);font-weight:500;margin-bottom:4px}
.cal-empty-sub{font-size:11.5px;color:var(--t3)}

.cal-side-add-wrap{margin-top:auto}
.cal-side-add{
  width:100%;
  appearance:none;
  background:transparent;
  border:1px dashed var(--sep);
  border-radius:10px;
  padding:10px 12px;
  color:var(--t2);
  font-size:12.5px;
  font-weight:500;
  display:flex;
  align-items:center;
  gap:8px;
  justify-content:center;
  cursor:pointer;
}
.cal-side-add:hover{
  color:var(--t1);
  border-color:var(--chip-hover-border);
  background:rgba(255,255,255,.03);
}
.cal-side-add-plus{
  font-size:15px;
  font-weight:500;
  line-height:1;
  color:var(--t2);
}
.cal-side-add:hover .cal-side-add-plus{color:var(--acc)}

.cal-task-modal .tasks-modal-card{
  width:min(700px,calc(100vw - 28px));
  max-height:min(84vh,760px);
  padding:0;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.cal-task-modal-topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 16px 11px;
  border-bottom:1px solid var(--sep);
  flex-shrink:0;
}
.cal-task-modal-breadcrumb{
  font-size:11.5px;
  font-weight:500;
  color:var(--t3);
  letter-spacing:.02em;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  min-width:0;
}
.cal-task-modal-close{
  flex-shrink:0;
  width:28px;
  height:28px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--sep);
  color:var(--t2);
  cursor:pointer;
  margin-left:12px;
}
.cal-task-modal-close:hover{background:rgba(255,255,255,.08);color:var(--t1)}
.cal-task-modal-close svg{width:14px;height:14px}
.cal-task-modal-body{
  flex:1;
  overflow-y:auto;
  overflow-x:hidden;
  padding:6px 14px 20px;
  display:flex;
  flex-direction:column;
}
.cal-task-modal-body .task{
  border:none !important;
  background:transparent !important;
  box-shadow:none !important;
  border-radius:0;
  cursor:default;
}
.cal-task-modal-body .task.open{
  background:transparent !important;
}
.cal-task-modal-body .task-text{
  cursor:text;
  font-size:16px;
  font-weight:600;
  padding:6px 10px;
  margin:-6px -10px;
  border-radius:8px;
  transition:background .12s ease,box-shadow .12s ease;
}
.cal-task-modal-body .task-text:hover{
  background:rgba(255,255,255,.04);
}
.cal-task-modal-body .task.open .task-text{
  background:rgba(255,255,255,.05);
  box-shadow:inset 0 0 0 1px rgba(111,151,246,.25);
}
body[data-appearance-theme="porcelain"] .cal-task-modal-body .task-text:hover{
  background:rgba(31,26,20,.04);
}
body[data-appearance-theme="porcelain"] .cal-task-modal-body .task.open .task-text{
  background:rgba(31,26,20,.05);
  box-shadow:inset 0 0 0 1px rgba(77,125,240,.28);
}
.cal-task-modal-body .task-opts{
  margin-top:12px;
  padding-top:0;
}

/* ── INLINE ADD ───────────────────────────────────────── */
.cal-side-inline-add{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.cal-side-inline-input{
  width:100%;
  box-sizing:border-box;
  background:rgba(255,255,255,.04);
  border:1.5px solid var(--acc);
  border-radius:10px;
  padding:9px 12px;
  font-family:var(--font);
  font-size:13px;
  font-weight:400;
  color:var(--t1);
  outline:none;
  box-shadow:0 0 0 3px rgba(111,151,246,.12);
}
.cal-side-inline-input::placeholder{color:var(--t3)}
.cal-side-inline-hint{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 3px;
}
.cal-side-inline-loc{
  font-size:11px;
  color:var(--t3);
  letter-spacing:.01em;
}
.cal-side-inline-esc{
  font-size:10.5px;
  color:var(--t3);
  opacity:.65;
}
body[data-appearance-theme="porcelain"] .cal-side-inline-input{
  background:rgba(31,26,20,.04);
}

/* ── CTX-TARGET HIGHLIGHTS ───────────────────────────── */
.cal-day.ctx-target{
  border-color:rgba(111,151,246,.5) !important;
  background:rgba(111,151,246,.1) !important;
  box-shadow:0 0 0 2px rgba(111,151,246,.18);
}
.cal-week-col.ctx-target{
  border-color:rgba(111,151,246,.4) !important;
  background:rgba(111,151,246,.06) !important;
}
.cal-agenda-day.ctx-target{
  background:rgba(111,151,246,.06) !important;
  border-radius:8px;
  outline:1px solid rgba(111,151,246,.25);
}
.cal-agenda-item.ctx-target,
.cal-side-item-main.ctx-target{
  border-color:rgba(111,151,246,.4) !important;
  background:rgba(255,255,255,.07) !important;
}

/* ── RESPONSIVE ───────────────────────────────────────── */
@media (max-width:768px){
  .cal-month-grid{grid-auto-rows:minmax(72px,1fr);gap:2px}
  .cal-day{padding:5px 4px 4px;border-radius:7px}
  .cal-day-num{font-size:12px}
  .cal-day-pill{font-size:8.5px;padding:1px 4px;top:4px;right:4px}
  .cal-entry{padding:2px 4px}
  .cal-entry-lbl{font-size:10.5px}
  .cal-week{grid-template-columns:1fr;gap:8px}
  .cal-week-col{min-height:auto}
  .cal-toolbar{gap:8px}
  .cal-title-month{font-size:17px}
  .cal-title-year{font-size:13px}
  .cal-mode-btn{padding:5px 9px;font-size:11.5px}
  .cal-side{max-height:none}
  .cal-main{padding:10px;min-height:420px}
}
@media (max-width:520px){
  .cal-today-btn{padding:0 10px;font-size:11.5px}
  .cal-dow{font-size:9.5px;letter-spacing:.12em}
  .cal-day-mo{display:none}
  .cal-day-entries{gap:1px}
  .cal-entry-dot{width:5px;height:5px}
  .cal-agenda-day{grid-template-columns:60px 1fr;gap:10px;padding:10px 2px}
  .cal-agenda-day-num{font-size:24px}
}

/* ── PORCELAIN THEME TWEAKS ───────────────────────────── */
body[data-appearance-theme="porcelain"] .cal-day{background:rgba(31,26,20,.025)}
body[data-appearance-theme="porcelain"] .cal-day:hover{background:rgba(31,26,20,.05)}
body[data-appearance-theme="porcelain"] .cal-day-weekend{background:rgba(31,26,20,.04)}
body[data-appearance-theme="porcelain"] .cal-entry{background:rgba(31,26,20,.04)}
body[data-appearance-theme="porcelain"] .cal-entry:hover{background:rgba(31,26,20,.08)}
body[data-appearance-theme="porcelain"] .cal-agenda-item{background:rgba(31,26,20,.025)}
body[data-appearance-theme="porcelain"] .cal-agenda-item:hover{background:rgba(31,26,20,.055)}
body[data-appearance-theme="porcelain"] .cal-day-selected{
  background:linear-gradient(180deg,rgba(31,26,20,.06),rgba(31,26,20,.02));
  box-shadow:0 0 0 1px rgba(77,125,240,.22),0 6px 14px rgba(54,38,26,.08);
}
body[data-appearance-theme="porcelain"] .cal-side-item-jump{background:rgba(31,26,20,.025)}
body[data-appearance-theme="porcelain"] .cal-side-item-jump:hover{background:rgba(31,26,20,.055)}
body[data-appearance-theme="porcelain"] .cal-side-pill-overdue{color:#b83939}
