/* ══════════════════════════════════════════
   THEME TOKENS
══════════════════════════════════════════ */
:root,[data-theme="emerald"]{
  --accent:#10b981;--accent-dim:#059669;--accent-pale:#ecfdf5;--accent-light:#d1fae5;
  --accent-rgb:16,185,129;
}
[data-theme="rose"]{
  --accent:#f43f5e;--accent-dim:#e11d48;--accent-pale:#fff1f2;--accent-light:#fecdd3;
  --accent-rgb:244,63,94;
}
[data-theme="slate"]{
  --accent:#6366f1;--accent-dim:#4f46e5;--accent-pale:#eef2ff;--accent-light:#c7d2fe;
  --accent-rgb:99,102,241;
}
[data-theme="amber"]{
  --accent:#f59e0b;--accent-dim:#d97706;--accent-pale:#fffbeb;--accent-light:#fde68a;
  --accent-rgb:245,158,11;
}

/* LIGHT MODE BASE */
:root{
  color-scheme:light;
  --bg:#fafaf9;--surface:#ffffff;--surface2:#f5f5f4;--surface3:#eeece9;
  --border:#e7e5e4;--border2:#d6d3d1;
  --text:#1c1917;--text2:#78716c;--text3:#a8a29e;
  --shadow-color:rgba(0,0,0,.06);
  --red:#ef4444;--red-pale:#fef2f2;
  --amber-warn:#f59e0b;
}

/* DARK MODE */
[data-dark="true"]{
  color-scheme:dark;
  --bg:#0f0f0f;--surface:#1a1a1a;--surface2:#242424;--surface3:#2e2e2e;
  --border:#2e2e2e;--border2:#3a3a3a;
  --text:#f5f5f4;--text2:#a8a29e;--text3:#78716c;
  --shadow-color:rgba(0,0,0,.3);
  --red:#f87171;--red-pale:#2d1a1a;
  --amber-warn:#fbbf24;
  --accent-pale:rgba(var(--accent-rgb),.08);
  --accent-light:rgba(var(--accent-rgb),.18);
}
/* Dark mode native form controls */
[data-dark="true"] select,
[data-dark="true"] input,
[data-dark="true"] textarea{
  color-scheme:dark;
}
[data-dark="true"] select.fi,
[data-dark="true"] input.fi,
[data-dark="true"] textarea.fi{
  background:var(--surface2);color:var(--text);border-color:var(--border);
}
[data-dark="true"] select.fi option{
  background:var(--surface2);color:var(--text);
}
[data-dark="true"] .dur-spinner-input{
  background:var(--surface2);color:var(--text);border-color:var(--border);
}
[data-dark="true"] .journal-ta{
  background:var(--surface2);color:var(--text);border-color:var(--border);
}
[data-dark="true"] .splash-name-input{
  background:var(--surface2);color:var(--text);border-color:var(--border);
}
[data-dark="true"] .search-input{
  color:var(--text);
}
[data-dark="true"] .sp-input{
  background:var(--surface2);color:var(--text);border-color:var(--border);
}
[data-dark="true"] .qe-input{
  background:var(--surface2);color:var(--text);border-color:var(--accent);
}
[data-dark="true"] .bd-ta{
  background:var(--surface2);color:var(--text);border-color:var(--border);
}
[data-dark="true"] .qa-input{
  background:var(--surface2);color:var(--text);
}
[data-dark="true"] .qa-fi{
  background:var(--surface2);color:var(--text);border-color:var(--border);
}

*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);display:flex;flex-direction:column;overflow:hidden;font-size:14px;transition:background .3s,color .3s}

/* ══ SPLASH NAME INPUT ════════════════════════════ */
.splash-name-wrap{
  margin-top:20px;animation:splashFadeUp .5s ease 1s both;
}
.splash-name-input{
  width:240px;padding:12px 18px;border:2px solid var(--border);border-radius:14px;
  font-family:'DM Sans',sans-serif;font-size:16px;color:var(--text);
  background:var(--surface);outline:none;text-align:center;
  transition:border-color .2s,box-shadow .2s;
}
.splash-name-input:focus{
  border-color:var(--accent);box-shadow:0 0 0 4px rgba(var(--accent-rgb),.15);
}
.splash-name-input::placeholder{color:var(--text3);font-weight:400}

/* Splash greeting for returning users */
.splash-greeting{
  font-family:'DM Serif Display',serif;font-size:24px;color:var(--text);
  margin-top:20px;animation:splashFadeUp .5s ease 1s both;
}

/* ══ GUIDED TOUR (contextual onboarding) ═════════ */
.tour-card{
  position:fixed;z-index:9999;
  background:var(--surface);border:1.5px solid var(--accent);
  border-radius:14px;padding:16px 18px;
  box-shadow:0 12px 40px rgba(0,0,0,.18);
  max-width:300px;width:calc(100% - 40px);
  animation:tourPop .3s cubic-bezier(.34,1.56,.64,1);
  /* Prevent the card from ever overflowing the viewport */
  max-height:calc(100vh - 32px);
  overflow-y:auto;
}
@keyframes tourPop{from{opacity:0;transform:scale(.92) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}
.tour-card::before{
  content:'';position:absolute;width:12px;height:12px;
  background:var(--surface);border:1.5px solid var(--accent);
  transform:rotate(45deg);
}
.tour-card.arrow-top::before{top:-7px;left:50%;margin-left:-6px;border-bottom:none;border-right:none}
.tour-card.arrow-bottom::before{bottom:-7px;left:50%;margin-left:-6px;border-top:none;border-left:none}
.tour-card.arrow-right::before{right:-7px;top:20px;border-bottom:none;border-left:none}
.tour-title{font-family:'DM Serif Display',serif;font-size:16px;color:var(--text);margin-bottom:4px}
.tour-body{font-size:12px;color:var(--text2);line-height:1.65;margin-bottom:12px}
.tour-actions{display:flex;gap:8px;align-items:center}
.tour-btn{
  flex:1;padding:9px;background:var(--accent);color:#fff;border:none;
  border-radius:9px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;
  cursor:pointer;transition:background .15s;
}
.tour-btn:hover{background:var(--accent-dim)}
.tour-skip{
  background:none;border:none;color:var(--text3);font-size:11px;
  cursor:pointer;font-family:'DM Sans',sans-serif;white-space:nowrap;
}
.tour-skip:hover{color:var(--text2)}
.tour-step-dots{display:flex;gap:5px;justify-content:center;margin-top:10px}
.tour-step-dot{width:6px;height:6px;border-radius:50%;background:var(--border)}
.tour-step-dot.active{background:var(--accent)}
.tour-tap-hint{font-size:10px;color:var(--text3);text-align:center;margin-top:6px;opacity:.7}
.tour-success-flash{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(34,197,94,.9);color:#fff;font-size:18px;font-weight:800;
  border-radius:12px;animation:flashIn .3s ease-out;z-index:10;
}
@keyframes flashIn{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}
.tour-backdrop{
  position:fixed;inset:0;z-index:9998;
  background:rgba(0,0,0,.35);
  animation:onboardFadeIn .25s ease;
}
@keyframes onboardFadeIn{from{opacity:0}to{opacity:1}}

/* ══ DAY GREETING ════════════════════════════════ */
.day-greeting{
  font-size:14px;color:var(--text2);font-weight:400;margin-bottom:2px;
}

/* ══ JOURNAL PROMPT ══════════════════════════════ */
.journal-prompt{
  font-size:12px;color:var(--accent);font-weight:500;font-style:italic;
  padding:8px 12px;margin-bottom:8px;background:var(--accent-pale);
  border-radius:8px;line-height:1.5;
}

/* ══ TYPE TOGGLE (Task / Event) ═════════════════ */
.type-toggle-row{display:flex;gap:2px;background:var(--surface2);border-radius:8px;padding:3px;margin-bottom:10px}

/* ══ MODAL DETAIL TABS ═════════════════════════ */
.modal-detail-tabs{
  display:flex;gap:0;border-bottom:2px solid var(--border);margin-top:12px;
}
.modal-dtab{
  flex:1;padding:8px 4px;border:none;background:none;
  font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;
  color:var(--text3);cursor:pointer;transition:all .15s;
  border-bottom:2px solid transparent;margin-bottom:-2px;
  display:flex;align-items:center;justify-content:center;gap:5px;
}
.modal-dtab:hover{color:var(--text)}
.modal-dtab.active{color:var(--accent);border-bottom-color:var(--accent)}
.dtab-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);display:none}
.dtab-dot.visible{display:inline-block}
.dtab-badge{
  font-size:9px;font-weight:700;background:var(--accent);color:#fff;
  border-radius:99px;padding:0 5px;min-width:16px;text-align:center;
  line-height:16px;display:none;
}
.dtab-badge.visible{display:inline-block}
.modal-dpanel{display:none;padding-top:10px}
.modal-dpanel.active{display:block}
.type-btn{
  flex:1;padding:6px;border:none;border-radius:6px;font-family:'DM Sans',sans-serif;
  font-size:12px;font-weight:600;color:var(--text3);background:none;cursor:pointer;
  transition:all .15s;
}
.type-btn.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px var(--shadow-color)}
.type-btn:hover:not(.active){color:var(--text2)}

/* ══ EVENT BLOCK (Day/Week view) ════════════════ */
.day-task-block.event-block{
  border-left:none;
  background:var(--accent);color:#fff;
  border-radius:8px;
}
.day-task-block.event-block .day-task-block-name{color:#fff}
.day-task-block.event-block .day-task-block-dur{color:rgba(255,255,255,.75)}
.day-task-block.event-block .event-location{
  font-size:11px;opacity:.8;display:flex;align-items:center;gap:3px;margin-top:1px;
}
.wk-task-block.event-block{
  border-left:none;
  background:var(--accent);color:#fff;
}
.wk-task-block.event-block .wk-task-block-name{color:#fff}

/* ══ UPCOMING EVENTS WIDGET ════════════════════ */
.upcoming-events{margin-top:8px}
.upcoming-toggle{
  font-size:12px;color:var(--accent);font-weight:600;cursor:pointer;
  display:flex;align-items:center;gap:4px;padding:4px 0;
  background:none;border:none;font-family:'DM Sans',sans-serif;
}
.upcoming-toggle:hover{opacity:.8}
.upcoming-list{
  margin-top:6px;display:flex;flex-direction:column;gap:4px;
  animation:upcomingSlide .2s ease;
}
@keyframes upcomingSlide{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.upcoming-item{
  display:flex;align-items:center;gap:8px;padding:6px 10px;
  background:var(--surface2);border-radius:8px;font-size:12px;
  border-left:3px solid var(--accent);
  cursor:pointer;transition:background .12s,box-shadow .12s;
}
.upcoming-item:hover{background:var(--accent-pale);box-shadow:0 1px 6px rgba(var(--accent-rgb),.12)}
.upcoming-item-time{font-weight:700;color:var(--accent);min-width:56px;font-size:11px}
.upcoming-item-name{font-weight:500;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.upcoming-item-day{font-size:10px;color:var(--text3);font-weight:600}
.upcoming-item-loc{font-size:10px;color:var(--text3)}

/* ══ ATTACHMENTS ═══════════════════════════════ */
.attach-list{display:flex;flex-direction:column;gap:4px;margin-bottom:6px}
.attach-item{
  display:flex;align-items:center;gap:8px;padding:6px 10px;
  background:var(--surface2);border-radius:7px;font-size:12px;
  border-left:2px solid var(--accent);
}
.attach-item-icon{font-size:14px;flex-shrink:0}
.attach-item-name{
  flex:1;min-width:0;color:var(--accent);font-weight:500;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  text-decoration:none;
}
.attach-item-name:hover{text-decoration:underline}
.attach-item-del{
  background:none;border:none;color:var(--text3);cursor:pointer;font-size:12px;
  padding:0 2px;opacity:0;transition:opacity .15s;
}
.attach-item:hover .attach-item-del{opacity:1}
.attach-add-row{display:flex;gap:6px;align-items:center}
.attach-add-input{flex:1;font-size:12px;padding:7px 10px}
.attach-add-btn{
  width:32px;height:32px;border:1px solid var(--accent);border-radius:8px;
  background:var(--accent);color:#fff;cursor:pointer;
  font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;
  transition:background .15s;flex-shrink:0;font-family:'DM Sans',sans-serif;
}
.attach-add-btn:hover{background:var(--accent-dim)}
.attach-file-btn{
  width:32px;height:32px;border:1px solid var(--border);border-radius:8px;
  background:var(--surface2);cursor:pointer;
  font-size:14px;display:flex;align-items:center;justify-content:center;
  transition:all .15s;flex-shrink:0;
}
.attach-file-btn:hover{border-color:var(--accent)}

/* Attachment on task block */
.task-attach{
  display:inline-flex;align-items:center;gap:3px;
  font-size:10px;color:var(--accent);text-decoration:none;
  max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  margin-top:1px;
}
.task-attach:hover{text-decoration:underline}

/* ══ SUBTASKS ═════════════════════════════════ */
.subtask-list{display:flex;flex-direction:column;gap:3px;margin-bottom:6px}
.subtask-item{
  display:flex;align-items:center;gap:8px;
  padding:6px 10px 6px 20px;
  background:var(--surface2);border-radius:7px;
  border-left:2px solid var(--border);
  font-size:12px;
}
.subtask-item .subtask-check{
  width:15px;height:15px;border:1.5px solid var(--border);border-radius:4px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:all .15s;background:var(--surface);
}
.subtask-item .subtask-check.checked{
  background:var(--accent);border-color:var(--accent);
}
.subtask-item .subtask-check.checked::after{
  content:'✓';color:#fff;font-size:10px;font-weight:700;
}
.subtask-item .subtask-name{flex:1;min-width:0;color:var(--text);outline:none;cursor:text;padding:1px 4px;border-radius:4px;transition:background .15s}
.subtask-item .subtask-name:focus{background:var(--surface2);box-shadow:0 0 0 1.5px var(--accent)}
.subtask-item .subtask-name:empty::before{content:'Type here…';color:var(--text3);font-style:italic}
.subtask-item .subtask-name.done{text-decoration:line-through;opacity:.5}
.subtask-item .subtask-dur{font-size:10px;color:var(--text3);white-space:nowrap}
.subtask-item .subtask-del{
  background:none;border:none;color:var(--text3);cursor:pointer;font-size:12px;
  padding:0 2px;opacity:0;transition:opacity .15s;
}
.subtask-item:hover .subtask-del{opacity:1}
.subtask-focus-btn{
  background:var(--accent);color:#fff;border:none;border-radius:4px;
  font-size:9px;font-weight:700;padding:3px 7px;cursor:pointer;
  font-family:'DM Sans',sans-serif;transition:background .15s;flex-shrink:0;
}
.subtask-focus-btn:hover{background:var(--accent-dim)}
.subtask-add-row{display:flex;gap:6px;align-items:center}
.subtask-add-input{flex:1;font-size:12px;padding:7px 10px}
.subtask-add-btn{
  width:32px;height:32px;border:1px solid var(--accent);border-radius:8px;
  background:var(--accent);color:#fff;cursor:pointer;
  font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;
  transition:background .15s;flex-shrink:0;font-family:'DM Sans',sans-serif;
}
.subtask-add-btn:hover{background:var(--accent-dim)}
.subtask-gen-btn-full{
  width:100%;padding:7px;margin-top:6px;
  border:1px dashed var(--border);border-radius:8px;
  background:none;color:var(--text3);cursor:pointer;
  font-size:11px;font-weight:500;font-family:'DM Sans',sans-serif;
  transition:all .15s;
}
.subtask-gen-btn-full:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-pale)}

/* Subtask progress on task block */
.subtask-progress{
  display:flex;align-items:center;gap:4px;margin-top:2px;
}
.subtask-progress-bar{
  flex:1;height:3px;background:var(--border);border-radius:99px;overflow:hidden;
}
.subtask-progress-fill{height:100%;background:var(--accent);border-radius:99px;transition:width .3s}
.subtask-progress-label{font-size:9px;color:var(--text3);font-weight:600}

/* Inline subtasks on Day view blocks */
.day-subtask-hdr{
  font-size:9px;font-weight:700;color:var(--text3);letter-spacing:.8px;
  text-transform:uppercase;margin-top:6px;margin-bottom:2px;padding-left:12px;
}
.day-subtask-list{
  margin-top:2px;padding-left:10px;display:flex;flex-direction:column;gap:2px;
  border-left:2px solid rgba(var(--accent-rgb),.25);margin-left:8px;
  /* Cap height so many subtasks don't push the slot row far beyond its scheduled duration.
     Scroll within the list keeps all subtasks accessible without disrupting the timeline. */
  max-height:150px;
  overflow-y:auto;
  /* Thin custom scrollbar so it doesn't look heavy */
  scrollbar-width:thin;
  scrollbar-color:rgba(var(--accent-rgb),.3) transparent;
}
.day-subtask-more{
  font-size:10px;color:var(--accent);font-weight:600;padding:2px 0;cursor:pointer;
}
.day-subtask-more:hover{text-decoration:underline}

/* [+] Add subtask button — sits right after the task name */
.day-add-sub-btn{
  position:relative;
  width:18px;height:18px;border:none;border-radius:4px;
  background:rgba(var(--accent-rgb),.15);color:var(--accent);
  font-size:13px;font-weight:700;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  /* Desktop: hidden until hover. Mobile: always visible (no hover state) */
  opacity:0;transition:opacity .15s;flex-shrink:0;
  font-family:'DM Sans',sans-serif;
}
/* Desktop hover reveals button */
.day-task-block:hover .day-add-sub-btn{opacity:1}
.day-add-sub-btn:hover{background:var(--accent);color:#fff}
.day-add-sub-btn::after{
  content:attr(data-tip);
  position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(4px);
  padding:4px 10px;background:var(--accent);color:#fff;
  font-size:10px;font-weight:600;border-radius:6px;white-space:nowrap;
  opacity:0;pointer-events:none;transition:opacity .15s,transform .15s;
  z-index:200;box-shadow:0 2px 8px rgba(var(--accent-rgb),.3);
}
.day-add-sub-btn:hover::after{opacity:1;transform:translateX(-50%) translateY(0)}

/* Event block [+] button */
.event-add-sub{background:rgba(255,255,255,.2);color:#fff}
.event-add-sub:hover{background:rgba(255,255,255,.4)}
.day-subtask{
  display:flex;align-items:center;gap:5px;cursor:pointer;
  padding:1px 0;transition:opacity .15s;
}
.day-subtask:hover{opacity:.8}
.day-subtask-check{
  width:14px;height:14px;border:1.5px solid var(--border2);border-radius:3px;
  flex-shrink:0;display:flex;align-items:center;justify-content:center;
  transition:all .15s;background:var(--surface);cursor:pointer;
}
.day-subtask-check.checked{
  background:var(--accent);border-color:var(--accent);
}
.day-subtask-check.checked::after{
  content:'✓';color:#fff;font-size:9px;font-weight:700;
}
.day-subtask-name{
  font-size:11px;color:var(--text2);font-weight:400;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  outline:none;cursor:text;padding:0 2px;border-radius:3px;
  transition:background .15s;min-width:20px;
}
.day-subtask-name:focus{
  background:var(--surface);box-shadow:0 0 0 1.5px var(--accent);
  white-space:normal;overflow:visible;
}
.day-subtask-name:empty::before{
  content:'Type here…';color:var(--text3);font-style:italic;
}
.day-subtask.done .day-subtask-name{
  text-decoration:line-through;opacity:.4;
}
/* Subtask drag grip */
.sub-grip{
  font-size:10px;color:var(--text3);cursor:grab;opacity:0;transition:opacity .12s;
  user-select:none;flex-shrink:0;letter-spacing:-2px;padding:0 2px;
}
.day-subtask:hover .sub-grip{opacity:.6}
.sub-grip:active{cursor:grabbing}
.day-subtask.sub-dragging{opacity:.3}
.day-subtask.sub-drop-target{
  box-shadow:0 -2px 0 0 var(--accent);
}
.event-block .sub-grip{color:rgba(255,255,255,.4)}
.event-block .day-subtask:hover .sub-grip{opacity:.7}
.day-subtask-dur{font-size:9px;color:var(--text3);flex-shrink:0}

/* Event block subtasks (white text) */
.event-block .day-subtask-list{border-left-color:rgba(255,255,255,.3)}
.event-block .day-subtask-check{border-color:rgba(255,255,255,.5);background:transparent}
.event-block .day-subtask-check.checked{background:rgba(255,255,255,.9);border-color:rgba(255,255,255,.9)}
.event-block .day-subtask-check.checked::after{color:var(--accent)}
.event-block .day-subtask-name{color:rgba(255,255,255,.85)}
.event-block .day-subtask-name:focus{
  color:var(--text);background:var(--surface);
  box-shadow:0 0 0 1.5px var(--accent);
}
.event-block .day-subtask-name:empty::before{color:rgba(255,255,255,.4)}
.event-block .day-subtask.done .day-subtask-name{color:rgba(255,255,255,.4)}

/* ══════════════════════════════════════════
   SPLASH SCREEN
══════════════════════════════════════════ */
#splash{
  position:fixed;inset:0;z-index:9999;background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:0;transition:opacity .5s,transform .5s;
}
#splash.hiding{opacity:0;transform:translateY(-12px);pointer-events:none}

/* ── Splash dot ── */
.splash-logo-dot{
  width:24px;height:24px;border-radius:50%;background:var(--accent);flex-shrink:0;
  animation:splashDotPulse 1.4s ease-in-out infinite;
}
@keyframes splashDotPulse{
  0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(var(--accent-rgb),.35)}
  50%{transform:scale(1.18);box-shadow:0 0 0 12px rgba(var(--accent-rgb),0)}
}

/* header logo stacked layout */
.logo-btn{
  display:flex;flex-direction:row;align-items:center;justify-content:center;
  gap:8px;cursor:pointer;background:none;border:none;padding:6px 10px;border-radius:8px;
  transition:background .15s;flex-shrink:0;
}
.logo-btn:hover{background:var(--surface2)}
/* Animated dot → hamburger */
.logo-dot-icon{
  width:8px;height:8px;border-radius:50%;background:var(--accent);
  transition:all .28s cubic-bezier(.34,1.56,.64,1);
}
.logo-btn:hover .logo-dot-icon{
  border-radius:1.5px;width:16px;height:2px;
  box-shadow:0 -5px 0 2px var(--accent),0 5px 0 2px var(--accent);
}
.logo-text{font-family:'DM Serif Display',serif;font-size:15px;color:var(--text);
  letter-spacing:-.2px;transition:color .3s;line-height:1;
}

.splash-logo-wrap{display:flex;align-items:center;gap:14px;animation:splashLogoIn .6s cubic-bezier(.34,1.56,.64,1) .3s both}
.splash-logo-text{font-family:'DM Serif Display',serif;font-size:56px;font-weight:400;letter-spacing:-.5px;color:var(--text)}
.splash-tagline{font-size:17px;color:var(--text2);margin-top:16px;font-weight:400;letter-spacing:.1px;animation:splashFadeUp .6s ease .6s both}
.splash-subline{
  font-size:16px;color:var(--text2);margin-top:10px;font-weight:500;
  letter-spacing:.1px;min-height:24px;font-style:italic;
  animation:splashFadeUp .5s ease 1.3s both;
}
.splash-enter-btn{padding:14px 32px;background:var(--accent);color:#fff;border:none;border-radius:12px;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s,transform .1s,box-shadow .15s;animation:splashFadeUp .6s ease .8s both;box-shadow:0 4px 20px rgba(var(--accent-rgb),.35)}
.splash-enter-btn:hover{background:var(--accent-dim);transform:translateY(-2px);box-shadow:0 8px 28px rgba(var(--accent-rgb),.4)}
.splash-enter-btn:active{transform:translateY(0);box-shadow:0 2px 10px rgba(var(--accent-rgb),.3)}

/* ── Auth UI ── */
.splash-google-btn{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 32px;background:#fff;color:#3c4043;border:1.5px solid #dadce0;
  border-radius:12px;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:600;
  cursor:pointer;white-space:nowrap;transition:background .15s,transform .1s,box-shadow .15s;
  box-shadow:0 2px 8px rgba(0,0,0,.08);min-width:240px;
}
.splash-google-btn:hover{background:#f8f9fa;transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.12)}
.splash-google-btn:active{transform:translateY(0);box-shadow:0 1px 4px rgba(0,0,0,.08)}
[data-dark="true"] .splash-google-btn{background:#2a2a2a;color:#e3e3e3;border-color:#444}
[data-dark="true"] .splash-google-btn:hover{background:#333}
.splash-auth-divider{
  display:flex;align-items:center;gap:12px;width:200px;color:var(--text3);font-size:12px;
}
.splash-auth-divider::before,.splash-auth-divider::after{
  content:'';flex:1;height:1px;background:var(--border);
}
@keyframes splashLogoIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes splashFadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
/* ══ CLEAR CONFIRM ════════ */
/* ══ HABIT DRAG CONFIRM ════ */
#habitDragOverlay .modal{max-width:380px}

/* ══════════════════════════════════════════
   HEADER
══════════════════════════════════════════ */
header{
  height:54px;background:var(--surface);border-bottom:1px solid var(--border);
  display:flex;align-items:center;padding:0 14px;gap:10px;flex-shrink:0;z-index:100;
  transition:background .3s,border-color .3s;
}
.hdr-center{display:flex;align-items:center;gap:6px;flex:1;justify-content:center}
.hdr-right{display:flex;align-items:center;gap:6px;margin-left:auto}


.nav-arrow{
  width:26px;height:26px;border:1px solid var(--border);border-radius:7px;background:var(--surface);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:var(--text2);font-size:12px;transition:all .15s;flex-shrink:0;
}
.nav-arrow:hover{border-color:var(--accent);color:var(--accent)}
.cur-label{font-size:13px;font-weight:500;min-width:130px;text-align:center}
.hdr-btn{
  padding:5px 11px;border:1px solid var(--border);border-radius:7px;background:var(--surface);
  font-size:11px;font-weight:500;color:var(--text2);cursor:pointer;font-family:'DM Sans',sans-serif;
  transition:all .15s;white-space:nowrap;
}
.hdr-btn:hover{border-color:var(--accent);color:var(--accent)}
.hdr-btn.accent{background:var(--accent);color:#fff;border-color:var(--accent)}
.hdr-btn.accent:hover{background:var(--accent-dim);border-color:var(--accent-dim);color:#fff}

/* ══ SIDEBAR TOGGLE BUTTON ═══════════════════ */
.sidebar-toggle-btn{
  width:32px;height:32px;border:1px solid var(--border);border-radius:8px;
  background:var(--surface);cursor:pointer;display:flex;align-items:center;
  justify-content:center;color:var(--text2);transition:all .15s;flex-shrink:0;
}
.sidebar-toggle-btn:hover{border-color:var(--accent);color:var(--accent)}

/* ══ MORE MENU ═══════════════════════════════ */
.more-wrap{position:relative}
.more-menu{
  position:fixed;top:54px;right:14px;
  min-width:190px;background:var(--surface);border:1px solid var(--border);
  border-radius:11px;box-shadow:0 8px 32px var(--shadow-color);
  z-index:9000;display:none;flex-direction:column;padding:5px;
  animation:moreDrop .15s cubic-bezier(.34,1.56,.64,1);
}
.more-menu.open{display:flex}
@keyframes moreDrop{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.more-item{
  padding:8px 12px;border-radius:7px;cursor:pointer;font-size:12px;font-weight:500;
  color:var(--text);transition:background .12s;display:flex;align-items:center;gap:8px;
}
.more-item:hover{background:var(--surface2)}
.more-icon{font-size:14px;width:18px;text-align:center;color:var(--text2)}
.more-sep{height:1px;background:var(--border);margin:3px 0}

/* ══ BOTTOM NAVIGATION ═══════════════════════ */
.bottom-nav{
  display:flex;align-items:center;justify-content:space-around;
  height:52px;background:var(--surface);border-top:1px solid var(--border);
  flex-shrink:0;z-index:50;transition:background .3s,border-color .3s;
  overflow:visible;position:relative;
}
.bnav-tab{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:4px 12px;border:none;background:none;cursor:pointer;
  color:var(--text3);font-family:'DM Sans',sans-serif;transition:color .15s;
  border-radius:8px;
}
.bnav-tab span{font-size:9px;font-weight:600;letter-spacing:.2px}
.bnav-tab svg{transition:color .15s}
.bnav-tab:hover{color:var(--text)}
.bnav-tab.active{color:var(--accent)}

/* ══ SIDEBAR TAB TOOLTIPS + ACTIVE LABEL ═════ */
.side-tab{position:relative}
.side-tab::after{
  content:attr(data-tip);
  position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(4px);
  padding:4px 10px;background:var(--accent);color:#fff;
  font-size:10px;font-weight:600;border-radius:6px;white-space:nowrap;
  opacity:0;pointer-events:none;transition:opacity .15s,transform .15s;
  z-index:200;margin-top:4px;
  box-shadow:0 2px 8px rgba(var(--accent-rgb),.3);
}
.side-tab:hover::after{opacity:1;transform:translateX(-50%) translateY(0)}
.side-tab.active::after{
  opacity:1;transform:translateX(-50%) translateY(2px);
  background:none;color:var(--accent);
  font-size:9px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;
  padding:2px 0;box-shadow:none;border-radius:0;
}

/* ══ SEARCH BAR (now below header) ═══════════ */
.search-bar{
  position:absolute;top:54px;left:50%;transform:translateX(-50%);
  width:380px;max-width:calc(100% - 24px);background:var(--surface);
  border:1px solid var(--border);border-radius:12px;
  box-shadow:0 8px 32px var(--shadow-color);
  z-index:500;display:none;flex-direction:column;overflow:hidden;
}
.search-bar.open{display:flex}

/* ══════════════════════════════════════════
   LEFT DRAWER (Settings)
══════════════════════════════════════════ */
.drawer-backdrop{
  position:fixed;inset:0;z-index:400;background:rgba(0,0,0,.25);
  opacity:0;pointer-events:none;transition:opacity .28s;
}
.drawer-backdrop.open{opacity:1;pointer-events:all}

.drawer{
  position:fixed;left:0;top:0;bottom:0;width:280px;z-index:401;
  background:var(--surface);border-right:1px solid var(--border);
  box-shadow:8px 0 32px rgba(0,0,0,.12);
  transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;overflow:hidden;
}
.drawer.open{transform:translateX(0)}

.drawer-header{
  padding:20px 20px 14px;border-bottom:1px solid var(--border);flex-shrink:0;
  display:flex;align-items:center;justify-content:space-between;
}
.drawer-title{font-family:'DM Serif Display',serif;font-size:18px;color:var(--text)}
.drawer-close{
  width:28px;height:28px;border:1px solid var(--border);border-radius:7px;background:none;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:var(--text3);font-size:16px;transition:all .15s;
}
.drawer-close:hover{border-color:var(--border2);color:var(--text)}

.drawer-body{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:4px}

/* Accordion settings */
.drawer-acc{border-radius:10px;overflow:hidden;transition:background .15s}
.drawer-acc:hover{background:var(--surface2)}
.drawer-acc.open{background:var(--surface2)}
.drawer-acc-hdr{
  display:flex;align-items:center;gap:10px;padding:12px 14px;
  cursor:pointer;user-select:none;font-size:13px;font-weight:500;color:var(--text);
}
.drawer-acc-icon{color:var(--text2);flex-shrink:0}
.drawer-acc-arrow{margin-left:auto;font-size:10px;color:var(--text3);transition:transform .2s}
.drawer-acc.open .drawer-acc-arrow{transform:rotate(90deg)}
.drawer-acc-body{
  display:none;padding:0 14px 14px;
}
.drawer-acc.open .drawer-acc-body{display:block}

/* Dark mode toggle */
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--surface2);border-radius:10px}
.toggle-label{font-size:13px;font-weight:500;color:var(--text);display:flex;align-items:center;gap:8px}
.toggle-icon{font-size:16px}
.toggle-track{
  width:40px;height:22px;border-radius:99px;background:var(--border2);
  cursor:pointer;transition:background .2s;position:relative;flex-shrink:0;
  border:none;
}
.toggle-track.on{background:var(--accent)}
.toggle-thumb{
  width:16px;height:16px;border-radius:50%;background:#fff;
  position:absolute;top:3px;left:3px;
  transition:transform .2s cubic-bezier(.34,1.56,.64,1);
  box-shadow:0 1px 3px rgba(0,0,0,.2);
}
.toggle-track.on .toggle-thumb{transform:translateX(18px)}

/* Theme swatches */
.theme-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.theme-swatch{
  padding:12px;border-radius:10px;border:2px solid var(--border);
  cursor:pointer;transition:border-color .15s,transform .1s;
  display:flex;flex-direction:column;align-items:flex-start;gap:6px;
  background:var(--surface2);
}
.theme-swatch:hover{transform:translateY(-1px)}
.theme-swatch.active{border-color:var(--accent)}
.theme-swatch-dot{width:20px;height:20px;border-radius:50%}
.theme-swatch-name{font-size:11px;font-weight:600;color:var(--text2)}
.theme-swatch.active .theme-swatch-name{color:var(--text)}

.drawer-footer{
  padding:16px 20px;border-top:1px solid var(--border);flex-shrink:0;
  font-size:11px;color:var(--text3);text-align:center;
}

/* ══════════════════════════════════════════
   APP LAYOUT
══════════════════════════════════════════ */
.app-body{display:flex;flex:1;overflow:hidden}
.main-area{flex:1;overflow:hidden;display:flex;flex-direction:column;position:relative}
.view{display:none;flex-direction:column;flex:1;overflow:hidden}
.view.active{display:flex}

/* ══════════════════════════════════════════
   YEAR VIEW
══════════════════════════════════════════ */
.year-wrap{padding:20px;overflow-y:auto;flex:1}
.year-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.year-month-card{
  background:var(--surface);border:1px solid var(--border);border-radius:12px;
  padding:16px;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s;
}
.year-month-card:hover{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-pale);transform:translateY(-1px)}
.year-month-card.has-today{border-color:var(--accent)}
.ym-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.ym-name{font-family:'DM Serif Display',serif;font-size:16px;color:var(--text)}
.ym-count{font-size:10px;color:var(--text3);font-weight:500}
.ym-count.has-tasks{color:var(--accent);font-weight:600}
.ym-days-hdr{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:3px}
.ym-day-lbl{text-align:center;font-size:9px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;color:var(--text);padding:2px 0}
.ym-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.ym-day{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:4px;font-size:10px;color:var(--text3);position:relative;cursor:pointer}
.ym-day.other{opacity:.4}
.ym-day.today{background:var(--accent);color:#fff;border-radius:50%;font-weight:700;font-size:10px}
.ym-day.has-tasks{color:var(--text);font-weight:500}
.ym-dot{width:4px;height:4px;border-radius:50%;position:absolute;bottom:2px;left:50%;transform:translateX(-50%)}
.ym-dot.d1{background:rgba(var(--accent-rgb),.3)}
.ym-dot.d2{background:rgba(var(--accent-rgb),.55)}
.ym-dot.d3{background:rgba(var(--accent-rgb),.75)}
.ym-dot.d4{background:var(--accent)}
/* On today's accent circle: dots become white for contrast */
.ym-day.today .ym-dot{background:rgba(255,255,255,.5)}
.ym-day.today .ym-dot.d2{background:rgba(255,255,255,.65)}
.ym-day.today .ym-dot.d3{background:rgba(255,255,255,.8)}
.ym-day.today .ym-dot.d4{background:#fff}

/* Year month popup */
.ym-popup{background:var(--surface);border-radius:16px;padding:20px;width:440px;max-width:90vw;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.ymp-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.ymp-title{font-family:'DM Serif Display',serif;font-size:20px;color:var(--text)}
.ymp-close{width:28px;height:28px;border-radius:50%;border:none;background:var(--surface2);color:var(--text2);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;font-family:'DM Sans',sans-serif;transition:background .12s}
.ymp-close:hover{background:var(--surface3)}
.ymp-dow-row{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:4px}
.ymp-dow{text-align:center;font-size:10px;font-weight:700;color:var(--text);text-transform:uppercase;padding:2px 0}
.ymp-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:16px}
.ymp-day{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:6px;font-size:12px;color:var(--text3);position:relative;cursor:pointer;font-weight:500;transition:background .1s}
.ymp-day:not(.other):hover{background:var(--accent-pale)}
.ymp-day.other{opacity:.3}
.ymp-day.today{background:var(--accent);color:#fff;border-radius:50%;font-weight:700}
.ymp-day.has-tasks{color:var(--text);font-weight:600}
.ymp-day .ym-dot{width:5px;height:5px;bottom:2px}
.ymp-stats{display:flex;gap:8px;margin-bottom:12px}
.ymp-stat-card{flex:1;background:var(--surface2);border-radius:10px;padding:10px;text-align:center;cursor:pointer;transition:background .12s,box-shadow .12s;border:1px solid transparent}
.ymp-stat-card:hover,.ymp-stat-card.hover{background:var(--surface3);border-color:var(--accent);box-shadow:0 0 0 2px rgba(var(--accent-rgb),.15)}
[data-dark="true"] .ymp-stat-card:hover,[data-dark="true"] .ymp-stat-card.hover{background:rgba(var(--accent-rgb),.12)}
.ymp-stat-num{font-size:22px;font-weight:700;color:var(--text);display:block}
.ymp-stat-label{font-size:10px;color:var(--text3);font-weight:500;text-transform:uppercase;letter-spacing:.3px}
.ymp-open-month{width:100%;padding:10px;border:none;border-radius:10px;background:var(--accent);color:#fff;font-size:13px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:background .12s}
.ymp-open-month:hover{background:var(--accent-dim)}
/* Summary list */
.ymp-summary-hdr{margin-bottom:10px}
.ymp-back{border:none;background:none;color:var(--accent);font-size:12px;font-weight:600;cursor:pointer;padding:0;font-family:'DM Sans',sans-serif;margin-bottom:4px;display:block}
.ymp-back:hover{text-decoration:underline}
.ymp-summary-title{font-size:14px;font-weight:700;color:var(--text);display:block}
.ymp-summary-list{display:flex;flex-direction:column;gap:2px}
.ymp-group-hdr{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.3px;padding:8px 0 4px}
.ymp-item{display:flex;align-items:center;gap:8px;padding:8px;border-radius:8px;cursor:pointer;transition:background .1s}
.ymp-item:hover{background:var(--surface2)}
.ymp-item-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.ymp-item-name{font-size:12px;font-weight:500;color:var(--text);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ymp-item-badge{font-size:8px;font-weight:700;text-transform:uppercase;padding:2px 6px;border-radius:4px;letter-spacing:.3px}
.ymp-item-badge.task{background:var(--accent-pale);color:var(--accent)}
.ymp-item-badge.event{background:rgba(var(--accent-rgb),.15);color:var(--accent-dim)}
.ymp-item-time{font-size:10px;color:var(--text3);flex-shrink:0}
.ymp-more{text-align:center;padding:10px;font-size:12px;font-weight:600;color:var(--accent);cursor:pointer;border-radius:8px;transition:background .1s}
.ymp-more:hover{background:var(--accent-pale)}

/* ══ SUBTASK PILL (collapsed on task cards) ═══════════ */
.sub-pill-row{
  display:inline-flex;align-items:center;gap:5px;
  font-size:12px;font-weight:500;color:var(--text2);
  padding:4px 12px;border-radius:6px;margin-left:auto;
  background:var(--surface3);cursor:pointer;
  transition:background .12s;
}
.sub-pill-row:hover{background:var(--surface2)}
.sub-pill-icon{font-size:11px;opacity:.5}
.sub-pill-done{opacity:.5;font-weight:400}
.sub-pill-compact{padding:3px 8px;font-size:10px;gap:3px}
.sub-pill-compact .sub-pill-done{display:none}
.event-block .sub-pill-row{background:rgba(255,255,255,.2);color:#fff}
.event-block .sub-pill-row:hover{background:rgba(255,255,255,.3)}

/* ══ SUBTASK POPUP ════════════════════════════════════ */
.sub-popup{
  background:var(--surface);border-radius:16px;
  width:min(400px,90vw);max-height:80vh;
  display:flex;flex-direction:column;
  box-shadow:0 20px 60px rgba(0,0,0,.18);
  overflow:hidden;
}
.sp-hdr{
  padding:18px 20px 14px;border-bottom:1px solid var(--border);
  display:flex;align-items:flex-start;justify-content:space-between;
}
.sp-hdr-left{display:flex;flex-direction:column;gap:2px;min-width:0}
.sp-title{font-size:16px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sp-count{font-size:13px;color:var(--text3)}
.sp-close{
  width:30px;height:30px;border-radius:8px;border:none;
  background:var(--surface3);color:var(--text2);font-size:18px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-family:'DM Sans',sans-serif;transition:background .12s;
}
.sp-close:hover{background:var(--surface2)}
.sp-list{flex:1;overflow-y:auto;padding:6px 20px}
.sp-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 0;border-bottom:1px solid var(--border);
  font-size:15px;color:var(--text);
}
.sp-item:last-child{border-bottom:none}
.sp-item.done{opacity:.5}
.sp-item.done .sp-name{text-decoration:line-through}
.sp-item.sp-dragging{opacity:.3}
.sp-item.sp-drop-target{border-top:2px solid var(--accent)}
.sp-check{
  width:18px;height:18px;border:2px solid var(--border2);border-radius:5px;
  flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .12s,border-color .12s;
}
.sp-check.checked{background:var(--accent);border-color:var(--accent)}
.sp-check.checked::after{content:'✓';color:#fff;font-size:11px;font-weight:700}
.sp-name{flex:1;min-width:0;outline:none;line-height:1.4}
.sp-name:focus{background:var(--accent-pale);border-radius:4px;padding:0 4px;margin:0 -4px}
.sp-grip{color:var(--text3);font-size:16px;cursor:grab;opacity:.3;flex-shrink:0;user-select:none}
.sp-grip:hover{opacity:.6}
.sp-del{
  width:22px;height:22px;border-radius:5px;border:none;
  background:transparent;color:var(--text3);font-size:14px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .12s;flex-shrink:0;font-family:'DM Sans',sans-serif;
}
.sp-item:hover .sp-del{opacity:.6}
.sp-del:hover{background:rgba(239,68,68,.1);color:var(--red);opacity:1}
.sp-empty{padding:24px 0;text-align:center;color:var(--text3);font-size:14px}
.sp-footer{
  padding:12px 20px 16px;border-top:1px solid var(--border);
  display:flex;gap:8px;
}
.sp-input{
  flex:1;padding:10px 12px;border:1.5px solid var(--border);border-radius:10px;
  font-family:'DM Sans',sans-serif;font-size:14px;color:var(--text);
  background:var(--bg);outline:none;transition:border-color .15s;
}
.sp-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-pale)}
.sp-add-btn{
  padding:10px 16px;border:none;border-radius:10px;
  font-size:14px;font-weight:600;background:var(--accent);color:#fff;
  cursor:pointer;font-family:'DM Sans',sans-serif;flex-shrink:0;
  transition:opacity .12s;
}
.sp-add-btn:hover{opacity:.85}

/* ══ QUICK EVENT INPUT ═══════════════════════════════ */
.qe-section{padding:0 12px}
.qe-divider{height:1px;background:var(--border);margin:10px 0 8px}
.qe-label{font-size:10px;font-weight:700;color:var(--text3);letter-spacing:.4px;text-transform:uppercase;display:flex;align-items:center;gap:5px;margin-bottom:6px}
.qe-label svg{opacity:.5}
.qe-row{display:flex;gap:6px;align-items:center}
.qe-wrap{position:relative;flex:1;min-width:0}
.qe-input{width:100%;padding:8px 28px 8px 10px;border:1.5px solid var(--accent);border-radius:10px;font-family:'DM Sans',sans-serif;font-size:12px;color:var(--text);background:var(--bg);outline:none;transition:border-color .15s,box-shadow .15s}
.qe-input:focus{box-shadow:0 0 0 3px var(--accent-pale)}
.qe-input::placeholder{color:var(--text3)}
.qe-enter{position:absolute;right:6px;top:50%;transform:translateY(-50%);font-size:9px;font-weight:700;color:var(--accent);opacity:.5;pointer-events:none}
.qe-add-btn{font-size:11px;font-weight:600;color:#fff;background:var(--accent);border:none;border-radius:8px;padding:8px 12px;cursor:pointer;font-family:'DM Sans',sans-serif;white-space:nowrap;flex-shrink:0;transition:opacity .12s}
.qe-add-btn:hover{opacity:.85}
.qe-hint{font-size:10px;color:var(--text3);margin-top:4px;font-style:italic;line-height:1.5}
.qe-confirm{
  display:flex;align-items:flex-start;gap:10px;margin-top:8px;
  background:var(--accent-pale);border:1px solid var(--accent);
  border-radius:10px;padding:10px 12px;
}
.qe-confirm-icon{
  width:22px;height:22px;border-radius:50%;background:var(--accent);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;
}
.qe-confirm-body{flex:1;min-width:0}
.qe-confirm-title{font-size:13px;font-weight:600;color:var(--text)}
.qe-confirm-detail{font-size:11px;color:var(--text2);margin-top:2px}
.qe-confirm-actions{display:flex;gap:6px;margin-top:6px}
.qe-confirm-btn{
  font-size:11px;font-weight:600;padding:4px 12px;border-radius:6px;
  border:none;cursor:pointer;font-family:'DM Sans',sans-serif;transition:opacity .12s;
}
.qe-edit{background:var(--surface3);color:var(--text2)}
.qe-edit:hover{opacity:.8}
.qe-done{background:var(--accent);color:#fff}
.qe-done:hover{opacity:.85}
/* When today has both task dot and event dot, offset task dot left */
.ym-day.today.has-event .ym-dot{left:calc(50% - 3px)}
.ym-day.today.has-event::after{background:rgba(255,255,255,.7);bottom:3px}
/* Event indicator dot — uses a complementary offset from accent */
.ym-day.has-event::after{content:'';width:4px;height:4px;border-radius:50%;background:var(--accent-dim);position:absolute;bottom:2px;left:calc(50% + 4px)}

/* ══════════════════════════════════════════
   MONTH VIEW
══════════════════════════════════════════ */
.month-wrap{padding:16px;overflow-y:auto}
.month-grid-hdr{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:4px}
.month-day-name{text-align:center;font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text2);padding:6px 0}
.month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.month-cell{
  min-height:130px;background:var(--surface);border:1px solid var(--border);
  border-radius:10px;padding:6px;cursor:pointer;
  transition:border-color .15s,box-shadow .15s;overflow:hidden;
  display:flex;flex-direction:column;
}
.month-cell:hover{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-pale)}
.month-cell.other-month{background:var(--surface2);opacity:.55}
.month-cell.today{border-color:var(--accent);background:var(--accent-pale)}
[data-dark="true"] .month-cell.today{background:rgba(var(--accent-rgb),.14);border-color:var(--accent)}
.month-cell.drag-over{border-color:var(--accent);background:var(--accent-pale);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.22)}
.month-cell.snap-flash{animation:snapFlash .5s ease-out}
.cell-num-circle{width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--text);margin-bottom:3px}
.today .cell-num-circle{background:var(--accent);color:#fff;font-weight:700}
.cell-num-row{display:flex;align-items:center;gap:3px}
.cell-event-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}
.m-chip{
  font-size:10px;font-weight:500;padding:2px 6px;border-radius:4px;margin-bottom:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  border-left:2px solid var(--border2);background:var(--surface2);color:var(--text2);
  display:flex;align-items:center;gap:4px;cursor:grab;
}
.m-chip-time{font-size:9px;font-weight:700;color:var(--accent);flex-shrink:0}
.m-chip-pri{width:5px;height:5px;border-radius:50%;flex-shrink:0}
.m-chip-pri.pri-h{background:#ef4444}
.m-chip-pri.pri-m{background:#f59e0b}
.m-chip-pri.pri-l{background:#10b981}
.m-chip-event{font-weight:600;color:var(--accent)}
.m-chip.done{opacity:.4;text-decoration:line-through}
.more-chip{font-size:9px;color:var(--text3);padding:1px 3px}

/* ══════════════════════════════════════════
   WEEK VIEW
══════════════════════════════════════════ */
.week-view{display:flex;flex-direction:column;flex:1;overflow:hidden}
.week-hdr-row{display:grid;grid-template-columns:68px repeat(7,1fr);border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}
.wk-gutter{border-right:1px solid var(--border)}
.wk-day-head{padding:8px 4px;text-align:center;border-right:1px solid var(--border);cursor:pointer}
.wk-day-head:hover .wdh-num{color:var(--accent)}
.wdh-name{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text2)}
.wdh-num{font-size:18px;font-weight:400;font-family:'DM Serif Display',serif;color:var(--text);transition:color .15s;letter-spacing:-.3px}
.wk-day-head.today .wdh-num,.wk-day-head.today .wdh-name{color:var(--accent)}
.week-scroll{flex:1;overflow-y:auto}
.week-grid{display:grid;grid-template-columns:68px repeat(7,1fr)}
.wk-time-col{border-right:1px solid var(--border)}
.time-lbl{height:48px;display:flex;align-items:flex-start;justify-content:flex-end;padding:3px 7px 0 0;font-size:10px;color:var(--text);font-weight:700;letter-spacing:.2px;white-space:nowrap}
.wk-day-col{border-right:1px solid var(--border)}
.wk-slot{height:54px;border-bottom:1px solid var(--border);padding:2px 3px;cursor:pointer;transition:background .1s;display:flex;flex-direction:column;gap:1px;position:relative}
.wk-slot:hover{background:var(--accent-pale)}
.wk-slot.half{border-bottom-style:dashed;border-bottom-color:var(--surface3)}
.wk-slot.drag-over{background:var(--accent-pale);border:1px dashed var(--accent)}
.wk-slot.snap-flash{animation:snapFlash .5s ease-out}
.slot-task{font-size:9px;font-weight:500;padding:1px 4px;border-radius:3px;background:var(--surface2);border-left:2px solid var(--accent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:grab;display:flex;align-items:center;gap:3px}
.slot-task.done{opacity:.55}
.slot-task.dragging-task{opacity:.35}

/* ══════════════════════════════════════════
   DAY VIEW
══════════════════════════════════════════ */
.day-view{display:flex;flex-direction:column;flex:1;overflow:hidden}
.day-hdr{padding:14px 20px 10px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}
.day-title{font-family:'DM Serif Display',serif;font-size:24px;font-weight:400;letter-spacing:-.3px;color:var(--text)}
.day-sub{font-size:12px;color:var(--text3);margin-top:2px}

/* All-day event banner — pills above the timeline */
.day-allday-bar{
  display:none;flex-wrap:wrap;gap:5px;
  padding:8px 0 2px;
}
.allday-pill{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 12px;border-radius:99px;
  border:2px solid;font-size:11px;font-weight:700;
  cursor:pointer;white-space:nowrap;
  transition:opacity .15s,box-shadow .15s;
}
.allday-pill:hover{opacity:.8;box-shadow:0 1px 6px rgba(0,0,0,.1)}
.allday-pill.done{opacity:.4;text-decoration:line-through}
.allday-pill-type{
  font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
  opacity:.75;color:inherit;
}
.allday-pill-edit{font-size:10px;opacity:.6;margin-left:2px;color:inherit}

/* Day routine chips (skip/unskip) */
.day-routine-chips{
  display:flex;flex-wrap:wrap;gap:6px;padding:8px 20px;
}
.day-routine-chips:empty{display:none}
.day-rt-chip{
  display:flex;align-items:center;gap:5px;padding:4px 6px 4px 8px;
  border-radius:8px;background:var(--surface2);border:1px solid var(--border);
  font-size:11px;color:var(--text);transition:all .15s;
}
.day-rt-chip.skipped{opacity:.45;text-decoration:line-through}
.day-rt-chip.skipped .day-rt-chip-name{text-decoration:line-through}
.day-rt-chip-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.day-rt-chip-name{font-weight:600;white-space:nowrap}
.day-rt-chip-time{font-size:10px;color:var(--text3);white-space:nowrap}
.day-rt-chip-btn{
  font-size:10px;font-weight:600;padding:2px 8px;border-radius:6px;
  border:1px solid var(--border);background:none;color:var(--text3);
  cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .12s;
  opacity:0;margin-left:2px;
}
.day-rt-chip:hover .day-rt-chip-btn{opacity:1}
.day-rt-chip-btn:hover{color:var(--accent);border-color:var(--accent)}
.day-rt-chip-btn.undo{opacity:1;color:var(--accent);border-color:var(--accent)}
.day-rt-chip-badge{font-size:9px;font-weight:600;color:var(--text3);font-style:italic;margin-left:2px}
@media(hover:none){.day-rt-chip-btn{opacity:1}}
[data-dark="true"] .day-rt-chip{background:var(--surface2);border-color:var(--border)}

.day-scroll{flex:1;overflow-y:auto;overflow-x:hidden} /* overflow-x:hidden forces grid 1fr to reflow when sidebar toggles */

/* Timeline grid: two columns — time labels | slots */
.day-timeline{display:grid;grid-template-columns:80px 1fr;padding-bottom:40px;position:relative;min-width:0}

/* Time label: no fixed height — stretches to match its grid-row partner */
.day-time-lbl{
  display:flex;align-items:flex-start;justify-content:flex-end;
  padding:5px 12px 0 0;font-size:14px;color:var(--text);font-weight:700;
  letter-spacing:.2px;border-right:2px solid var(--border2);white-space:nowrap;
  min-height:76px;
}
.day-time-lbl.half-lbl{border-bottom:1px dashed var(--surface3)}
.day-lbl-interior{min-height:0!important;height:0!important;overflow:hidden;border:none;padding:0}
/* Ghost label: on-the-hour ticks inside a multi-slot task — visible but subordinate */
/* Slot: in-flow container.
   Empty slots: min-height from CSS (76px/64px mobile) — always consistent.
   Task slots: the task block's inline min-height drives the row height via flex.
   overflow:hidden on .day-task-block means the block's layout height = its content height,
   so the slot stretches to contain ALL subtasks without bleeding into the next row. */
.day-slot{
  min-height:76px;
  border-bottom:1px solid var(--border);
  cursor:pointer;transition:background .12s;
  position:relative;
  display:flex;flex-direction:column;
  min-width:0; /* prevent slot from expanding the grid column */
}
.day-slot.half{border-bottom-style:dashed;border-bottom-color:var(--surface3)}
.day-slot.has-task{cursor:default;padding:0}
.day-slot:not(.has-task):hover{background:var(--accent-pale)}
.day-slot.drag-over{background:var(--accent-pale)!important;outline:1px dashed var(--accent)}
.day-slot.snap-flash{animation:snapFlash .5s ease-out}
.day-slot-interior{min-height:0!important;height:0!important;overflow:hidden;border:none;padding:0;pointer-events:none}

/* Hour markers inside long tasks — reduced height, keep time labels visible */
.day-lbl-hour-interior{
  min-height:24px!important;height:24px!important;
  font-size:10px;color:var(--text3);padding:2px 8px 0 0;opacity:.5;
  display:flex;align-items:flex-start;justify-content:flex-end;
  border-bottom:none;
}
.day-slot-hour-interior{
  min-height:24px!important;height:24px!important;
  border-bottom:1px dotted var(--border);opacity:.5;
  pointer-events:all;position:relative;
}

/* During active drag: expand interior slots so they become valid drop targets */
.drag-active .day-slot-interior{
  min-height:32px!important;height:auto!important;pointer-events:all;
  border-bottom:1px dashed var(--border);opacity:.6;
  transition:min-height .15s;
}
/* During active drag: dim non-dragged blocks and disable their pointer-events */
.drag-active .day-task-block:not(.dragging-task),
.drag-active .wk-task-block:not(.dragging-task){
  pointer-events:none;opacity:.5;
}
.drag-active .day-task-block.dragging-task,
.drag-active .wk-task-block.dragging-task{
  opacity:.3;
}
/* Blocked routine slots — subtle hatching */
.day-slot.routine-blocked .day-slot-interior{background:repeating-linear-gradient(135deg,transparent,transparent 5px,rgba(239,68,68,.05) 5px,rgba(239,68,68,.05) 10px);cursor:not-allowed}
.wk-slot.routine-blocked{background:repeating-linear-gradient(135deg,transparent,transparent 4px,rgba(239,68,68,.05) 4px,rgba(239,68,68,.05) 8px);cursor:not-allowed}
[data-dark="true"] .day-slot.routine-blocked .day-slot-interior{background:repeating-linear-gradient(135deg,transparent,transparent 5px,rgba(239,68,68,.08) 5px,rgba(239,68,68,.08) 10px)}
[data-dark="true"] .wk-slot.routine-blocked{background:repeating-linear-gradient(135deg,transparent,transparent 4px,rgba(239,68,68,.08) 4px,rgba(239,68,68,.08) 8px)}
.drag-active .day-lbl-interior{
  min-height:32px!important;height:auto!important;overflow:visible;
  font-size:10px;color:var(--text3);padding:4px 8px 0 0;
  display:flex;align-items:flex-start;justify-content:flex-end;
}
.drag-active .day-slot-hour-interior,
.drag-active .day-lbl-hour-interior{
  opacity:1;
}

/* Wrapper around each task block + its resize handle.
   position:relative so the handle can be absolutely positioned outside overflow:hidden.
   The slot (flex column) sizes to fit this wrapper, which sizes to fit the block. */
.day-task-slot-wrap{
  position:relative;
  display:flex;flex-direction:column;
  /* min-height set inline per scheduled duration */
}

.recur-icon{font-size:10px;opacity:.5;flex-shrink:0}

/* ── Absolute task blocks (week only now; day blocks are in-flow) ── */
.wk-day-col{position:relative}
.wk-task-layer{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:2}
.wk-routine-band{position:absolute;left:0;right:0;border-radius:5px;pointer-events:none;z-index:0;border-left:3px solid var(--rb-color,transparent);box-shadow:inset 0 0 0 1px rgba(0,0,0,.04)}
.wk-routine-lbl{position:absolute;top:2px;left:4px;font-size:9px;font-weight:700;opacity:.75;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 8px);display:flex;align-items:center;gap:3px}
.wk-routine-dot{width:4px;height:4px;border-radius:50%;flex-shrink:0}
.wk-task-block{
  position:absolute;left:2px;right:2px;
  border-radius:0 4px 4px 0;border-left:3px solid var(--accent);border-top:2px solid var(--accent);
  background:rgba(var(--accent-rgb),.13);
  overflow:hidden;cursor:pointer;
  pointer-events:all;
  display:flex;flex-direction:column;justify-content:flex-start;
  padding:0 5px 10px;min-height:16px;
  transition:box-shadow .15s;
  user-select:none;
}
/* Drag grip bar */
.drag-grip{
  width:100%;height:12px;cursor:grab;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;border-radius:0 4px 0 0;position:relative;
  transition:background .12s;
}
.drag-grip:hover{background:rgba(0,0,0,.08)}
.drag-grip:active{cursor:grabbing;background:rgba(0,0,0,.13)}
.grip-dots{display:flex;gap:3px;opacity:.25;transition:opacity .15s}
.grip-dots::before{content:'';display:inline-block;width:24px;height:3px;border-radius:1.5px;background:currentColor}
.drag-grip:hover .grip-dots{opacity:.55}
.event-block .drag-grip:hover{background:rgba(255,255,255,.12)}
.event-block .drag-grip:active{background:rgba(255,255,255,.2)}
.event-block .grip-dots::before{background:rgba(255,255,255,.45)}
.event-block .drag-grip:hover .grip-dots::before{background:rgba(255,255,255,.7)}
[data-dark="true"] .drag-grip:hover{background:rgba(255,255,255,.06)}
[data-dark="true"] .drag-grip:active{background:rgba(255,255,255,.1)}
.wk-task-block:hover{box-shadow:0 2px 10px rgba(var(--accent-rgb),.28)}
.wk-task-block.done-block{opacity:.5}
.wk-task-block-name{font-size:11px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.wk-task-block-dur{font-size:9px;color:var(--text2);line-height:1.2;min-width:28px;text-align:center}
.wk-task-meta-row{display:flex;align-items:center;gap:3px;margin-top:1px}
.wk-sub-pill{font-size:8px;color:var(--text3);cursor:pointer;display:flex;align-items:center;gap:2px}
.wk-sub-pill:hover{color:var(--text2)}
.event-block .wk-sub-pill{color:rgba(255,255,255,.6)}
.event-block .wk-sub-pill:hover{color:rgba(255,255,255,.9)}
.event-block .wk-task-block-dur{color:rgba(255,255,255,.7)}
.wk-dur-stepper{display:flex;align-items:center;gap:0;margin-left:auto}
.wk-dur-btn{
  width:14px;height:14px;border:none;background:none;
  color:var(--text3);font-size:9px;font-weight:500;cursor:pointer;
  font-family:'DM Sans',sans-serif;display:flex;align-items:center;
  justify-content:center;padding:0;opacity:0;transition:opacity .12s;border-radius:3px;
}
.wk-task-block:hover .wk-dur-btn{opacity:1}
.wk-dur-btn:hover{background:var(--surface2);color:var(--accent)}
.event-block .wk-dur-btn{color:rgba(255,255,255,.5)}
.event-block .wk-dur-btn:hover{background:rgba(255,255,255,.2);color:#fff}

/* Day task block — in-flow inside .day-slot, min-height set per duration in JS */
.day-task-block{
  position:relative;
  align-self:stretch;
  flex:1;
  min-width:0;
  margin:3px 6px 3px 8px;
  border-radius:0 8px 8px 0;border-left:4px solid var(--accent);border-top:2.5px solid var(--accent);
  background:rgba(var(--accent-rgb),.13);
  cursor:pointer;
  pointer-events:all;
  display:flex;flex-direction:column;justify-content:flex-start;
  padding:0 14px 16px;
  transition:box-shadow .15s;
  user-select:none;
}
.day-task-block.event-block{border-left:none;border-radius:8px;margin:3px 6px 3px 8px;}

.day-task-block:hover{box-shadow:0 4px 18px rgba(var(--accent-rgb),.25)}
.day-task-block.done-block{opacity:.5}
.day-task-block-name{
  font-size:15px;font-weight:600;color:var(--text);
  /* Wrap long titles to next line — slot width stays fixed */
  overflow:hidden; /* clip, don't expand horizontally */
  white-space:normal;word-break:break-word;
  flex:1;min-width:0;
}
/* Override task-lbl's position:relative strikethrough with proper multi-line version */
.day-task-block-name.task-lbl::after{display:none} /* disable width-animation on wrapping titles */
.done-block .day-task-block-name,
.done .day-task-block-name{text-decoration:line-through;opacity:.6} /* multi-line strikethrough */

/* ── Narrow overlap columns: compact blocks when 3+ items share a slot ── */
.day-overlay-narrow{
  overflow:hidden!important; /* prevent scrollbars on tiny narrow blocks */
}
.day-overlay-narrow .day-task-block{
  padding:4px 6px 6px;border-radius:5px;border-left-width:3px;
}
.day-overlay-narrow .day-task-block-name{
  font-size:11px;white-space:nowrap;text-overflow:ellipsis;line-height:1.3;
}
.day-overlay-narrow .day-task-block-check{
  gap:3px;
}
.day-overlay-narrow .task-check{
  width:14px;height:14px;min-width:14px;
}
/* Extra-narrow: 4+ columns */
.day-overlay-xnarrow .day-task-block-name{
  font-size:10px;
}
.day-overlay-narrow .dur-stepper{border-color:var(--border)}
.day-overlay-narrow .dur-step-btn{opacity:1;width:16px;height:16px;font-size:10px;background:var(--surface2)}
.day-overlay-narrow .day-task-dur-pill{font-size:8px;padding:0 3px}
.day-overlay-narrow .day-add-sub-btn{width:16px;height:16px;font-size:10px;opacity:1}
.day-overlay-xnarrow .day-add-sub-btn{width:14px;height:14px;font-size:9px}
/* Week view narrow columns */
.wk-task-narrow{
  padding:2px 3px 4px!important;border-left-width:2px!important;
}
.wk-task-narrow .wk-task-block-name{
  font-size:8px!important;line-height:1.2!important;
}
/* Time range badge — top-right of the name row */
.day-time-range{
  font-size:10px;font-weight:600;color:var(--accent);
  background:rgba(var(--accent-rgb),.1);
  padding:2px 7px;border-radius:4px;
  white-space:nowrap;flex-shrink:0;margin-left:auto;
}
.event-block .day-time-range{
  background:rgba(255,255,255,.18);color:#fff;
}
/* Meta row: duration pill + Focus pill + notes snippet */
.day-task-meta-row{
  display:flex;align-items:center;gap:5px;
  margin-top:4px;flex-wrap:wrap;
}
.day-task-dur-pill{
  font-size:10px;color:var(--text2);font-weight:500;
  background:var(--surface2);padding:1px 6px;border-radius:4px;
  flex-shrink:0;min-width:36px;text-align:center;
}
/* Duration stepper: − [30m] + */
.dur-stepper{
  display:inline-flex;align-items:center;gap:0;flex-shrink:0;
  border-radius:5px;overflow:hidden;
  border:1px solid transparent;transition:border-color .15s;
}
.dur-stepper:hover{border-color:var(--border2)}
.dur-step-btn{
  width:22px;height:20px;border:none;background:none;
  color:var(--text3);font-size:12px;font-weight:500;cursor:pointer;
  font-family:'DM Sans',sans-serif;transition:all .12s;
  display:flex;align-items:center;justify-content:center;
  opacity:0;padding:0;
}
.dur-stepper:hover .dur-step-btn{opacity:1;background:var(--surface2)}
.dur-step-btn:hover{color:var(--accent);background:var(--accent-pale)!important}
.dur-step-btn:active{transform:scale(.9)}
.event-block .dur-stepper:hover{border-color:rgba(255,255,255,.3)}
.event-block .dur-step-btn{color:rgba(255,255,255,.5)}
.event-block .dur-stepper:hover .dur-step-btn{opacity:1;background:rgba(255,255,255,.15)}
.event-block .dur-step-btn:hover{color:#fff;background:rgba(255,255,255,.25)!important}
.event-block .day-task-dur-pill{background:rgba(255,255,255,.2);color:rgba(255,255,255,.9)}
/* Focus pill — replaces the old inline Focus button */
.day-focus-pill{
  display:inline-flex;align-items:center;gap:3px;
  font-size:9px;font-weight:700;
  background:rgba(var(--accent-rgb),.12);color:var(--accent);
  border:none;border-radius:99px;padding:2px 7px;
  cursor:pointer;flex-shrink:0;
  font-family:'DM Sans',sans-serif;
  transition:background .12s;
}
.day-focus-pill:hover{background:var(--accent);color:#fff;}
.day-task-notes-pill{
  font-size:9px;color:var(--text3);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  max-width:120px;flex-shrink:1;
}
.day-task-attach-pill{
  font-size:9px;color:var(--text2);
  background:var(--surface2);padding:1px 6px;border-radius:4px;
  flex-shrink:0;
}
/* Thin divider between meta row and subtasks */
.day-task-divider{
  height:1px;
  background:rgba(var(--accent-rgb),.15);
  margin:6px 0 5px;
}
.event-block .day-task-divider{background:rgba(255,255,255,.2)}
/* Subtask header row: label left, count right */
.day-subtask-hdr-row{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:4px;
}
.day-subtask-hdr{
  font-size:9px;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;color:var(--text3);
}
.day-subtask-count{
  font-size:9px;color:var(--text3);font-weight:500;
}
/* Keep old dur class for backward compat (week view still uses it) */
.day-task-block-dur{font-size:12px;color:var(--text2);margin-top:2px}
.day-task-block-check{display:flex;align-items:center;gap:6px;min-width:0}

/* Conflict overlap badge */
.day-conflict-badge{
  display:inline-flex;align-items:center;gap:3px;
  font-size:9px;font-weight:700;padding:1px 6px;border-radius:99px;
  background:rgba(245,158,11,.15);color:var(--amber-warn);
  border:1px solid rgba(245,158,11,.35);
  white-space:nowrap;flex-shrink:0;margin-left:auto;
}

/* Duration select in modal */
.dur-select{display:flex;flex-wrap:wrap;gap:5px;margin-top:4px}
.dur-opt{
  padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;
  border:1.5px solid var(--border2);background:var(--surface2);
  color:var(--text2);cursor:pointer;transition:all .12s;white-space:nowrap;
}
.dur-opt:hover{border-color:var(--accent);color:var(--accent)}
.dur-opt.selected{background:var(--accent);border-color:var(--accent);color:#fff}

/* ══ DURATION SPINNER ════════════════════════ */
.dur-spinner-row{display:flex;gap:12px;align-items:center;margin-top:4px}
.dur-spinner{display:flex;align-items:center;gap:6px}
.dur-spinner-input{
  width:56px;padding:8px 4px;
  border:1.5px solid var(--border);border-radius:9px;
  font-family:'DM Sans',sans-serif;font-size:15px;font-weight:600;
  color:var(--text);background:var(--surface);
  text-align:center;outline:none;
  transition:border-color .15s;
  -moz-appearance:textfield;
}
.dur-spinner-input:focus{border-color:var(--accent)}
.dur-spinner-input::-webkit-inner-spin-button{opacity:1;cursor:pointer}
.dur-spinner-label{font-size:12px;color:var(--text3);font-weight:500}

/* Dark mode task blocks */
[data-dark="true"] .wk-task-block,[data-dark="true"] .day-task-block{
  background:rgba(var(--accent-rgb),.18);
}

/* ══════════════════════════════════════════
   CATEGORIES VIEW
══════════════════════════════════════════ */
.cat-view{display:flex;flex-direction:column;flex:1;overflow:hidden}
.cat-view-hdr{
  padding:12px 18px 0;border-bottom:1px solid var(--border);
  background:var(--surface);flex-shrink:0;
  display:flex;flex-direction:column;gap:0;
}
/* Row 1: title + segment toggle — horizontal, space-between */
.cat-hdr-row1{
  display:flex;align-items:center;justify-content:space-between;
  padding-bottom:10px;
}
/* Row 2: chips + buttons — full width, wraps onto next line if needed */
.cat-hdr-row2{
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
  padding-bottom:10px;
}
.cat-view-title{font-family:'DM Serif Display',serif;font-size:20px;font-weight:400;flex-shrink:0}
.cat-chips{display:flex;gap:6px;flex-wrap:wrap;padding:2px 0}
.cat-chip{padding:3px 10px;border-radius:99px;font-size:11px;font-weight:600;cursor:pointer;border:1.5px solid var(--border);transition:all .15s;background:var(--surface3);color:var(--text2);display:flex;align-items:center;gap:4px}
.cat-chip:hover{border-color:var(--accent);color:var(--accent)}
/* Active chip: white text works on all coloured backgrounds except very light ones.
   We use a high-contrast dark text for "All" which uses --text as background. */
.cat-chip.active{color:#fff;border-color:transparent}
/* "All" chip uses var(--text) as bg which is near-black in light, near-white in dark */
.cat-chip.all-chip.active{background:var(--text)!important;color:var(--bg)!important}
.cat-chip-del{font-size:11px;opacity:.6;border:none;background:none;cursor:pointer;color:inherit;line-height:1;padding:2px 4px;transition:opacity .15s}
.cat-chip-del:hover{opacity:1}
.add-cat-btn{padding:5px 12px;border-radius:99px;font-size:11px;font-weight:500;cursor:pointer;border:1.5px dashed var(--border2);background:none;color:var(--text3);font-family:'DM Sans',sans-serif;transition:all .15s;white-space:nowrap}
.add-cat-btn:hover{border-color:var(--accent);color:var(--accent)}
.show-done-btn{padding:5px 12px;border-radius:99px;font-size:11px;font-weight:500;cursor:pointer;border:1.5px solid var(--border);background:var(--surface);color:var(--text2);font-family:'DM Sans',sans-serif;transition:all .15s;white-space:nowrap;flex-shrink:0}
.show-done-btn.on{border-color:var(--accent);color:var(--accent);background:var(--accent-pale)}
.cat-scroll{flex:1;overflow-y:auto;padding:16px 18px}
.cat-section{margin-bottom:24px}
.cat-sec-title{font-size:10px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:var(--text3);padding-bottom:6px;border-bottom:1px solid var(--border);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.cat-task-row{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:9px;margin-bottom:5px;transition:box-shadow .15s;border-left:3px solid var(--border2);cursor:grab}
.cat-task-row:hover{box-shadow:0 1px 4px var(--shadow-color)}
.cat-task-row.done{opacity:.55}
.cat-task-row.dragging-task{opacity:.35}
.cat-task-info{flex:1;min-width:0}
.cat-task-name{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cat-task-meta{font-size:10px;color:var(--text3);margin-top:1px;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.mbadge{font-size:9px;font-weight:600;padding:1px 5px;border-radius:3px;text-transform:uppercase;letter-spacing:.3px}
.mbadge.high{background:rgba(239,68,68,.12);color:var(--red)}.mbadge.medium{background:rgba(245,158,11,.12);color:var(--amber-warn)}.mbadge.low{background:rgba(var(--accent-rgb),.12);color:var(--accent)}
.mbadge.recur{background:rgba(var(--accent-rgb),.12);color:var(--accent)}
.cat-empty{font-size:12px;color:var(--text3);font-style:italic;padding:12px 0;text-align:center}

/* ══════════════════════════════════════════
   CHECKBOX + STRIKETHROUGH
══════════════════════════════════════════ */
.task-check{width:18px;height:18px;border:1.5px solid var(--border2);border-radius:4px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:border-color .15s,background .15s;background:var(--surface);position:relative}
.task-check:hover{border-color:var(--accent)}
.task-check.checked{background:var(--accent);border-color:var(--accent)}
.task-check.checked::after{content:'';width:4px;height:6px;border-right:1.5px solid #fff;border-bottom:1.5px solid #fff;transform:rotate(45deg) translate(-1px,-1px);display:block}
.task-lbl{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;position:relative}
.task-lbl::after{content:'';position:absolute;top:50%;left:0;width:0%;height:1.5px;background:var(--text2);transform:translateY(-50%);transition:width .42s cubic-bezier(.4,0,.2,1)}
.done .task-lbl::after{width:100%}
.done-block .task-lbl::after{width:100%}

/* ══════════════════════════════════════════
   RIGHT SIDEBAR (Brain Dump)
══════════════════════════════════════════ */
.sidebar{width:320px;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;transition:width .28s cubic-bezier(.4,0,.2,1),opacity .22s,background .3s,border-color .3s;overflow:hidden}
.sidebar.collapsed{width:0;opacity:0}
.side-tabs{display:flex;gap:2px;padding:8px 10px 22px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--surface)}
.side-tab{
  flex:1;padding:8px 4px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  color:var(--text3);cursor:pointer;
  border:none;background:none;
  font-family:'DM Sans',sans-serif;transition:all .15s;
}
.side-tab.active{color:var(--accent);background:var(--accent-pale)}
[data-dark="true"] .side-tab.active{background:rgba(var(--accent-rgb),.15)}
.side-tab:hover:not(.active){color:var(--text);background:var(--surface2)}
.side-panel{display:none;flex-direction:column;flex:1;overflow:hidden}
.side-panel.active{display:flex}

.bd-wrap{padding:10px;border-bottom:1px solid var(--border);flex-shrink:0}
.bd-guide{font-size:11px;color:var(--text3);line-height:1.5;margin-bottom:8px;padding:0 2px}
/* Auto-expanding textareas */
.auto-expand{resize:none;overflow:hidden;min-height:36px}
.bd-ta{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:10px;font-family:'DM Sans',sans-serif;font-size:12px;color:var(--text);background:var(--bg);outline:none;resize:none;overflow:hidden;min-height:58px;transition:border-color .15s,box-shadow .15s;line-height:1.5}
.bd-ta:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.12)}
.bd-ta::placeholder{color:var(--text3)}
.bd-ctrls{display:flex;gap:4px;margin-top:6px;align-items:center;flex-wrap:wrap}
.bd-add{padding:5px 11px;background:var(--accent);color:#fff;border:none;border-radius:7px;font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;cursor:pointer;transition:background .15s}
.bd-add:hover{background:var(--accent-dim)}
.bd-list{flex:1;overflow-y:auto;padding:7px 10px;display:flex;flex-direction:column;gap:4px}
.bd-card{padding:8px 10px;background:var(--surface2);border:1px solid var(--border);border-radius:10px;border-left:3px solid var(--accent);cursor:grab;transition:box-shadow .15s,opacity .2s;display:flex;flex-direction:column;gap:3px;user-select:none}
.bd-card:hover{box-shadow:0 4px 14px var(--shadow-color);border-color:var(--accent)}
.bd-card:active{cursor:grabbing;opacity:.7}
.bd-card.dragging{opacity:.35}
.bd-name{font-size:11px;font-weight:500;color:var(--text);line-height:1.4;word-break:break-word;white-space:normal}
.bd-meta{display:flex;gap:4px;align-items:center;flex-wrap:wrap}
.bd-badge{font-size:9px;font-weight:600;padding:1px 5px;border-radius:3px;text-transform:uppercase;letter-spacing:.3px}
.bd-badge.pri-high{background:rgba(239,68,68,.12);color:var(--red)}.bd-badge.pri-medium{background:rgba(245,158,11,.12);color:var(--amber-warn)}.bd-badge.pri-low{background:rgba(var(--accent-rgb),.12);color:var(--accent)}
.bd-del{font-size:10px;color:var(--text3);background:none;border:none;cursor:pointer;padding:4px 6px;border-radius:4px;font-family:'DM Sans',sans-serif;margin-left:auto}
.bd-del:hover{color:var(--red);background:rgba(239,68,68,.1)}
.bd-hint{font-size:10px;color:var(--text3);text-align:center;padding:10px 0;font-style:italic}

.pri-board{flex:1;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:12px}
.pri-sec-title{font-size:10px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:var(--text3);display:flex;align-items:center;gap:5px;padding-bottom:4px;border-bottom:1px solid var(--border);margin-bottom:5px}
.pri-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.pri-dot.high{background:var(--red)}.pri-dot.medium{background:var(--amber-warn)}.pri-dot.low{background:var(--accent)}.pri-dot.none{background:var(--text3)}
.pri-item{padding:6px 8px;background:var(--surface2);border:1px solid var(--border);border-radius:7px;display:flex;align-items:flex-start;gap:6px;transition:box-shadow .15s}
.pri-item:hover{box-shadow:0 1px 4px var(--shadow-color)}
.pri-item.done{opacity:.4}
.pri-name{font-size:11px;font-weight:500;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pri-date{font-size:10px;color:var(--text3);margin-top:1px}
.pri-empty{font-size:11px;color:var(--text3);font-style:italic;padding:3px 1px}

/* ══════════════════════════════════════════
   MODALS
══════════════════════════════════════════ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:500;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(5px);opacity:0;pointer-events:none;transition:opacity .2s}
.modal-overlay.open,.modal-overlay.show{opacity:1;pointer-events:all}
.modal{
  background:var(--surface);border-radius:14px;width:460px;max-width:calc(100vw - 28px);
  box-shadow:0 12px 40px rgba(0,0,0,.18);
  /* Default padding for simple modals (delete confirm, add category, etc.)
     The task modal overrides this via .modal-header/.modal-body/.modal-footer */
  padding:22px;
  display:flex;flex-direction:column;gap:12px;
  max-height:calc(100vh - 80px);
  overflow-y:auto; /* simple modals scroll as a unit if needed */
  transform:translateY(10px) scale(.98);
  transition:transform .2s cubic-bezier(.34,1.56,.64,1),background .3s;
}
.modal-overlay.open .modal{transform:translateY(0) scale(1)}
/* Task modal specifically: three-zone layout overrides the defaults above */
#mOverlay .modal{
  padding:0;       /* header/body/footer provide their own padding */
  gap:0;
  overflow-y:visible; /* body zone handles its own scroll */
}

/* Sticky header — title, sub, type toggle */
.modal-header{
  padding:20px 22px 14px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
  display:flex;flex-direction:column;gap:10px;
}

/* Scrollable body — all fields */
.modal-body{
  flex:1;overflow-y:auto;
  padding:16px 22px;
  display:flex;flex-direction:column;gap:12px;
  /* Subtle bottom fade to signal more content below */
  -webkit-mask-image:linear-gradient(to bottom,#000 85%,transparent 100%);
  mask-image:linear-gradient(to bottom,#000 85%,transparent 100%);
}
/* Remove fade when scrolled to bottom */
.modal-body.at-bottom{
  -webkit-mask-image:none;
  mask-image:none;
}

/* Sticky footer — action buttons */
.modal-footer{
  padding:12px 22px 16px;
  border-top:1px solid var(--border);
  flex-shrink:0;
  display:flex;gap:6px;justify-content:flex-end;
  background:var(--surface); /* ensure it covers scroll content */
}

.modal-title{font-family:'DM Serif Display',serif;font-size:18px;color:var(--text);letter-spacing:-.2px}
.modal-sub{font-size:11px;color:var(--text3);margin-top:1px}
.fg{display:flex;flex-direction:column;gap:4px}
.modal-name-row{display:flex;align-items:flex-start;gap:8px}
.modal-done-check{width:20px;height:20px;border-radius:5px;border:2px solid var(--border2);cursor:pointer;flex-shrink:0;margin-top:8px;transition:all .15s;display:flex;align-items:center;justify-content:center}
.modal-done-check:hover{border-color:var(--accent)}
.modal-done-check.checked{background:var(--accent);border-color:var(--accent)}
.modal-done-check.checked::after{content:'✓';color:#fff;font-size:11px;font-weight:700}
.flbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text2)}
.fi{padding:8px 10px;border:1px solid var(--border);border-radius:10px;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--text);background:var(--bg);outline:none;transition:border-color .15s,box-shadow .15s}
.fi:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.12)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.recur-box{display:flex;align-items:center;gap:8px;padding:9px 10px;background:var(--surface2);border-radius:8px;flex-wrap:wrap}
.recur-box label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;cursor:pointer;user-select:none;white-space:nowrap;color:var(--text)}
.rcb{width:14px;height:14px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}
.recur-opts{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.recur-days-row{display:flex;align-items:center;gap:4px;padding:6px 0 2px;flex-wrap:wrap}
.recur-days-btns{display:flex;gap:3px}
.recur-day-btn{
  width:26px;height:26px;border-radius:50%;border:1.5px solid var(--border);
  background:none;color:var(--text3);font-size:11px;font-weight:600;
  font-family:'DM Sans',sans-serif;cursor:pointer;transition:all .15s;
  display:flex;align-items:center;justify-content:center;padding:0;
}
.recur-day-btn:hover{border-color:var(--accent);color:var(--accent)}
.recur-day-btn.on{background:var(--accent);color:#fff;border-color:var(--accent)}
/* Used by all non-task modals (delete, add category, etc.) */
.modal-acts{display:flex;gap:6px;justify-content:flex-end;margin-top:4px;}
.btn-c{padding:7px 14px;border:1px solid var(--border);border-radius:8px;background:var(--surface);font-family:'DM Sans',sans-serif;font-size:12px;color:var(--text2);cursor:pointer;transition:all .15s}
.btn-c:hover{border-color:var(--border2);color:var(--text)}
.btn-s{padding:7px 16px;border:none;border-radius:8px;background:var(--accent);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;color:#fff;cursor:pointer;transition:background .15s}
.btn-s:hover{background:var(--accent-dim)}
.btn-d{padding:7px 12px;border:none;border-radius:8px;background:rgba(239,68,68,.1);font-family:'DM Sans',sans-serif;font-size:12px;color:var(--red);cursor:pointer;transition:background .15s;margin-right:auto}
.btn-d:hover{background:rgba(239,68,68,.18)}
.recur-del-opts{display:flex;flex-direction:column;gap:8px}
.recur-del-opt{padding:11px 14px;border:1px solid var(--border);border-radius:9px;cursor:pointer;transition:border-color .15s,background .15s;font-size:13px;font-weight:500;color:var(--text);background:var(--surface)}
.recur-del-opt:hover{border-color:var(--accent);background:var(--accent-pale)}
.opt-sub{font-size:11px;font-weight:400;color:var(--text3);margin-top:2px}
.cat-color-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:6px;margin-top:4px}
.cat-color-swatch{width:26px;height:26px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:border-color .15s,transform .1s}
.cat-color-swatch:hover{transform:scale(1.12)}
.cat-color-swatch.selected{border-color:var(--text)}

/* ══════════════════════════════════════════
   ANIMATIONS
══════════════════════════════════════════ */
/* ── SUGGESTIONS PANEL ── */
.sugg-category{margin-bottom:18px}
.sugg-cat-title{font-size:10px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:var(--text3);padding-bottom:5px;border-bottom:1px solid var(--border);margin-bottom:7px;display:flex;align-items:center;gap:5px}
.sugg-cat-icon{font-size:13px}
.sugg-card{padding:8px 10px;background:var(--surface2);border:1px solid var(--border);border-radius:9px;margin-bottom:5px;display:flex;align-items:center;gap:8px;cursor:grab;transition:box-shadow .15s,border-color .15s;user-select:none;border-left:3px solid var(--border2)}
.sugg-card:hover{box-shadow:0 4px 14px var(--shadow-color);border-color:var(--accent)}
.sugg-card:active{cursor:grabbing;opacity:.7}
.sugg-card.dragging{opacity:.35}
.sugg-card-info{flex:1;min-width:0}
.sugg-card-name{font-size:11px;font-weight:500;color:var(--text);line-height:1.3}
.sugg-card-sub{font-size:10px;color:var(--text3);margin-top:1px}
.sugg-add-btn{font-size:10px;font-weight:600;color:var(--accent);background:none;border:none;cursor:pointer;padding:5px 8px;border-radius:5px;font-family:'DM Sans',sans-serif;transition:background .15s;white-space:nowrap;flex-shrink:0}
.sugg-add-btn:hover{background:var(--accent-pale)}
.sugg-hint{font-size:10px;color:var(--text3);text-align:center;padding:8px 6px 14px;font-style:italic;line-height:1.5}

@keyframes snapFlash{0%{background:rgba(var(--accent-rgb),.22)}100%{background:transparent}}
@keyframes ripple-out{0%{transform:translate(-50%,-50%) scale(1);opacity:.5}100%{transform:translate(-50%,-50%) scale(4);opacity:0}}

::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:99px}


/* ══ DAY SLOT AUTO-SPLIT (event + task overlap) ══════ */
/* When a slot has both a timed event and a timed task at the same time,
/* Overlay layer for overlapping items (absolute positioning like week view) */
.day-overlay-layer{pointer-events:none}
.day-overlay-layer>div{pointer-events:all}
.week-allday-row{flex-shrink:0;background:var(--surface2);border-bottom:1px solid var(--border)}
.wk-allday-row{display:grid;grid-template-columns:68px repeat(7,1fr)}
.wk-allday-gutter{display:flex;align-items:center;justify-content:flex-end;padding:4px 8px 4px 0;font-size:9px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.4px;border-right:1px solid var(--border)}
.wk-allday-cell{padding:3px 2px;border-right:1px solid var(--border);min-height:26px;display:flex;flex-direction:column;gap:2px}
.wk-allday-pill{
  font-size:9px;font-weight:600;padding:2px 6px;border-radius:4px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;
  transition:opacity .12s;
}
.wk-allday-pill:hover{opacity:.8}
.wk-event-badge{font-size:8px;opacity:.75;margin-left:3px;font-weight:400}

/* Week multi-day spanning bars */
.wk-multiday-row{display:grid;padding:2px 0;gap:0;align-items:center}
.wk-multiday-bar{
  height:20px;display:flex;align-items:center;padding:0 8px;
  color:#fff;font-size:9px;font-weight:600;cursor:pointer;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  transition:opacity .12s;
}
.wk-multiday-bar:hover{opacity:.85}

/* Event color picker */
.event-color-row{display:flex;gap:8px;padding:4px 0}
.event-color-swatch{
  width:26px;height:26px;border-radius:50%;border:2.5px solid transparent;
  cursor:pointer;transition:all .15s;
}
.event-color-swatch:hover{transform:scale(1.15)}
.event-color-swatch.on{border-color:var(--text);box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--text)}

/* Month multi-day chip */
.m-chip-multiday{
  font-weight:700;font-size:9px;
  border-left-width:0!important;
  margin-left:-3px;margin-right:-3px;
  padding:2px 5px;min-height:16px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

/* ══ MONTH ALLDAY CHIP ════════════════════════ */
.m-chip-allday{
  font-weight:700;color:#fff!important;
  border-left-width:0!important;
  border-radius:4px;
}

/* ══ YEAR COUNT PILLS ════════════════════════ */
.ym-counts{display:flex;gap:4px;align-items:center;flex-wrap:wrap}
.ym-count-tasks{font-size:9px;font-weight:600;padding:1px 7px;border-radius:99px;background:rgba(var(--accent-rgb),.12);color:var(--accent)}
.ym-count-events{font-size:9px;font-weight:600;padding:1px 7px;border-radius:99px;background:rgba(var(--accent-rgb),.08);color:var(--accent-dim)}

/* ══ HOLIDAY SCHEDULER ══════════════════════ */
.holiday-year-section{margin-bottom:20px}
.holiday-year-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:6px}
.holiday-year-title{font-family:'DM Serif Display',serif;font-size:16px;color:var(--text)}
.holiday-year-actions{display:flex;gap:6px}
.holiday-action-btn{
  font-size:11px;padding:4px 12px;border-radius:20px;border:1.5px solid var(--border);
  background:none;color:var(--text3);font-weight:500;cursor:pointer;
  font-family:'DM Sans',sans-serif;transition:all .15s;
}
.holiday-action-btn:hover{border-color:var(--accent);color:var(--accent)}
.holiday-item{
  display:flex;align-items:center;gap:10px;padding:10px 12px;
  border-radius:10px;cursor:pointer;transition:background .12s;
  border:1px solid transparent;
}
.holiday-item:hover{background:var(--surface2)}
.holiday-item.on{background:rgba(var(--accent-rgb),.06);border-color:rgba(var(--accent-rgb),.12)}
.holiday-cb{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}
.holiday-info{display:flex;flex-direction:column;gap:1px}
.holiday-name{font-size:13px;font-weight:500;color:var(--text)}
.holiday-date{font-size:11px;color:var(--text3)}

/* ══ SCHEDULE TAB TOGGLE ════════════════════ */
.sched-seg-wrap{
  display:flex;background:var(--surface2);border-radius:8px;padding:2px;gap:2px;flex-shrink:0;
}
.sched-seg-btn{
  padding:5px 12px;border:none;border-radius:6px;font-family:'DM Sans',sans-serif;
  font-size:11px;font-weight:500;cursor:pointer;white-space:nowrap;
  background:transparent;color:var(--text3);transition:all .15s;
}
.sched-seg-btn.active{background:var(--surface);color:var(--text);font-weight:600;box-shadow:0 1px 3px rgba(0,0,0,.08)}

/* ══ EVENT ROW in Schedule tab ═══════════════ */
.event-row .event-row-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.event-row.past-event{opacity:.55}
.recur-summary-row{
  display:flex;align-items:center;gap:8px;padding:8px 12px;
  margin-bottom:5px;border-radius:8px;cursor:pointer;
  background:var(--surface2);border:1px dashed var(--border);
  transition:background .12s;
}
.recur-summary-row:hover{background:var(--surface3)}
.recur-summary-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.recur-summary-icon{font-size:12px;color:var(--accent);flex-shrink:0;margin-left:auto}
.recur-summary-text{font-size:11px;color:var(--text2);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.recur-summary-text strong{color:var(--text);font-weight:600}
/* ══ IDEA MODAL ══════════════════════════════ */
.idea-modal-header{display:flex;align-items:flex-start;gap:10px;margin-bottom:2px}
.idea-modal-color-bar{width:4px;border-radius:99px;flex-shrink:0;align-self:stretch;min-height:36px}
.idea-modal-name{font-family:'DM Serif Display',serif;font-size:18px;color:var(--text);letter-spacing:-.2px;line-height:1.3}
.idea-modal-sub{font-size:11px;color:var(--text3);margin-top:2px;line-height:1.4}
.idea-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text2)}
.idea-date-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.idea-recur-toggle{display:flex;align-items:center;gap:8px;padding:9px 12px;background:var(--surface2);border-radius:9px;cursor:pointer;user-select:none}
.idea-recur-toggle label{font-size:12px;font-weight:500;color:var(--text);cursor:pointer;flex:1}
.idea-recur-opts{display:flex;gap:6px;align-items:center;flex-wrap:wrap;padding:8px 12px;background:var(--surface2);border-radius:9px;margin-top:-4px}
.idea-recur-opts span{font-size:12px;color:var(--text2)}
.idea-pri-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.idea-pri-btn{padding:6px 4px;border-radius:8px;border:1.5px solid var(--border);background:var(--surface2);font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;color:var(--text2);text-align:center}
.idea-pri-btn:hover{border-color:var(--border2);color:var(--text)}
.idea-pri-btn.active-none{border-color:var(--text3);background:var(--surface3);color:var(--text)}
.idea-pri-btn.active-low{border-color:var(--accent);background:var(--accent-pale);color:var(--accent)}
.idea-pri-btn.active-medium{border-color:var(--amber-warn);background:rgba(245,158,11,.1);color:var(--amber-warn)}
.idea-pri-btn.active-high{border-color:var(--red);background:var(--red-pale);color:var(--red)}
.cat-habit-row{
  display:flex;align-items:flex-start;gap:10px;
  padding:10px 12px;
  background:linear-gradient(135deg,var(--surface) 0%,var(--accent-pale) 100%);
  border:1px solid var(--accent-light);
  border-radius:10px;margin-bottom:6px;
  border-left:3px solid var(--accent);
  transition:box-shadow .15s;
}
[data-dark="true"] .cat-habit-row{
  background:linear-gradient(135deg,var(--surface) 0%,rgba(var(--accent-rgb),.08) 100%);
  border-color:rgba(var(--accent-rgb),.3);
}
.cat-habit-row:hover{box-shadow:0 2px 10px var(--shadow-color)}
.cat-habit-icon{
  font-size:16px;color:var(--accent);flex-shrink:0;
  width:24px;height:24px;display:flex;align-items:center;justify-content:center;
  background:var(--accent-pale);border-radius:6px;margin-top:1px;
}
[data-dark="true"] .cat-habit-icon{background:rgba(var(--accent-rgb),.15)}
.cat-habit-desc{font-size:10px;color:var(--accent);font-weight:500;margin-top:2px;line-height:1.4}
.cat-habit-count{opacity:.75}
.cat-habit-change-note{
  font-size:10px;color:var(--amber-warn);font-weight:500;
  margin-top:3px;line-height:1.4;
  display:flex;align-items:center;gap:4px;
}
.cat-habit-check-wrap{display:flex;flex-direction:column;align-items:center;gap:3px;flex-shrink:0;margin-top:1px}
.cat-habit-today-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text3)}

/* Edit hint — appears on hover on every cat row */
.cat-edit-hint{
  font-size:10px;font-weight:600;color:var(--text3);
  padding:2px 7px;border-radius:5px;
  border:1px solid var(--border);
  background:var(--surface);
  cursor:pointer;white-space:nowrap;flex-shrink:0;
  opacity:0;transition:opacity .15s,color .15s,border-color .15s;
  font-family:'DM Sans',sans-serif;
  align-self:center;
}
.cat-task-row:hover .cat-edit-hint,
.cat-habit-row:hover .cat-edit-hint{opacity:1}
.cat-edit-hint:hover{color:var(--accent);border-color:var(--accent)}

/* ══ IDEA ALREADY-ADDED WARNING ════════════════ */
.sugg-card-warned{
  background:rgba(245,158,11,.08);
  border-color:rgba(245,158,11,.4)!important;
}
[data-dark="true"] .sugg-card-warned{background:rgba(245,158,11,.07)}
.sugg-already-badge{
  display:flex;align-items:center;gap:3px;
  font-size:9px;font-weight:600;color:var(--amber-warn);
  background:rgba(245,158,11,.12);
  border-radius:4px;padding:2px 6px;
  white-space:nowrap;flex-shrink:0;
  border:1px solid rgba(245,158,11,.25);
}
/* ══ SLOT FULL / DUPLICATE TOAST ════════════════ */
.slot-warn-toast{
  position:fixed;bottom:24px;left:50%;
  transform:translateX(-50%) translateY(12px);
  background:var(--red);color:#fff;
  padding:9px 18px;border-radius:99px;
  font-size:12px;font-weight:600;
  z-index:9100;pointer-events:none;
  opacity:0;transition:opacity .2s,transform .2s;
  white-space:nowrap;
  box-shadow:0 4px 16px rgba(239,68,68,.35);
  display:flex;align-items:center;gap:8px;
}
.slot-warn-toast.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
.slot-warn-toast.persistent{border-radius:12px;white-space:normal;max-width:420px;text-align:left;padding:10px 14px}
.warn-toast-msg{flex:1}
.warn-toast-x{background:transparent;border:none;color:#fff;font-size:18px;font-weight:700;cursor:pointer;padding:0 2px;line-height:1;opacity:.7;flex-shrink:0;font-family:'DM Sans',sans-serif}
.warn-toast-x:hover{opacity:1}

/* ══ RECUR RESCHEDULE DIALOG ════════════════════ */
#recurRescheduleOverlay .modal{max-width:400px}
/* ══ RESCHEDULE OPTIONS (recurring + clear scope) ══════ */
.reschedule-opts{display:flex;flex-direction:column;gap:8px}
.reschedule-opt{
  padding:12px 14px;border:1.5px solid var(--border);border-radius:10px;
  cursor:pointer;transition:border-color .15s,background .15s;
  background:var(--surface);
}
.reschedule-opt:hover{border-color:var(--accent);background:var(--accent-pale)}
[data-dark="true"] .reschedule-opt:hover{background:rgba(var(--accent-rgb),.18)}
.reschedule-opt-title{font-size:13px;font-weight:600;color:var(--text)}
.reschedule-opt-sub{font-size:11px;color:var(--text2);margin-top:3px;line-height:1.4}

/* ══ OVERDUE POPUP ══════════════════════════════════ */
.od-modal{max-width:420px;width:90vw}
.od-hdr{display:flex;align-items:center;gap:10px;padding:16px 20px 12px}
.od-hdr-icon{width:36px;height:36px;border-radius:10px;background:rgba(239,68,68,.1);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.od-hdr-icon-warn{background:rgba(245,158,11,.12);color:var(--amber-warn)}
.od-hdr-text{flex:1}
.od-hdr-title{font-size:15px;font-weight:600;color:var(--text)}
.od-hdr-sub{font-size:11px;color:var(--text2);margin-top:1px}
.od-close{width:28px;height:28px;border-radius:50%;border:none;background:var(--surface2);color:var(--text2);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;font-family:'DM Sans',sans-serif;transition:background .12s}
.od-close:hover{background:var(--surface3)}
.od-batch-bar{display:flex;gap:6px;padding:0 16px 10px}
.od-batch-btn{flex:1;padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);font-size:11px;font-weight:600;color:var(--text2);cursor:pointer;text-align:center;font-family:'DM Sans',sans-serif;transition:all .15s}
.od-batch-btn:hover{border-color:var(--accent);color:var(--text)}
.od-batch-primary{background:var(--accent-pale);color:var(--accent);border-color:var(--accent-pale)}
.od-batch-primary:hover{background:var(--accent);color:#fff}
.od-warn-bar{margin:0 16px 10px;padding:10px 12px;border-radius:8px;background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.2)}
.od-warn-text{font-size:11px;color:var(--text);line-height:1.5}
.od-warn-text strong{font-weight:600}
.od-task-list{padding:0 12px 8px;display:flex;flex-direction:column;gap:3px}
.od-task-list.od-scrollable{max-height:280px;overflow-y:auto}
.od-task-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;background:var(--surface2);transition:background .1s}
.od-task-row:hover{background:var(--surface3)}
.od-task-color{width:3px;height:32px;border-radius:2px;flex-shrink:0}
.od-task-info{flex:1;min-width:0;cursor:pointer}
.od-task-name{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.od-task-meta{font-size:10px;color:var(--text3);margin-top:2px;display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.od-overdue-badge{font-size:9px;font-weight:600;padding:1px 6px;border-radius:4px;background:rgba(239,68,68,.1);color:var(--red)}
.od-overdue-badge.od-severe{background:rgba(239,68,68,.2);color:var(--red)}
.od-conflict-badge{font-size:9px;font-weight:600;padding:1px 6px;border-radius:4px;background:rgba(245,158,11,.12);color:var(--amber-warn)}
.od-ok-badge{font-size:9px;font-weight:600;padding:1px 6px;border-radius:4px;background:rgba(16,185,129,.1);color:#10b981}
.od-placed{font-size:10px;font-weight:600;color:#10b981}
.od-task-actions{display:flex;gap:3px;flex-shrink:0}
.od-act{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:11px;color:var(--text2);font-family:'DM Sans',sans-serif;transition:all .12s;padding:0}
.od-act:hover{border-color:var(--border2);color:var(--text)}
.od-act-move:hover{background:var(--accent-pale);color:var(--accent);border-color:var(--accent)}
.od-act-done:hover{background:rgba(16,185,129,.1);color:#10b981;border-color:#10b981}
.od-act-pick{color:var(--text3)}
.od-act-pick:hover{color:var(--accent);border-color:var(--accent)}
.od-scroll-hint{text-align:center;font-size:10px;color:var(--text3);padding:2px 0 6px}
.od-footer{padding:8px 16px 14px;display:flex;align-items:center;justify-content:space-between}
.od-footer-link{font-size:11px;color:var(--text3);cursor:pointer;transition:color .12s}
.od-footer-link:hover{color:var(--text2)}

/* ══ NOW-LINE ═══════════════════════════════════════ */
.now-line{
  position:absolute;left:0;right:0;pointer-events:none;z-index:10;
  display:flex;align-items:center;
}
.now-line-dot{
  width:9px;height:9px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-left:-4px;
}
.now-line-bar{flex:1;height:2px;background:var(--accent);opacity:.85;}


/* ══ OVERDUE BADGE ══════════════════════════════════ */
.overdue-badge{
  padding:4px 10px;border-radius:99px;font-size:11px;font-weight:600;
  background:rgba(239,68,68,.12);color:var(--red);border:1.5px solid rgba(239,68,68,.3);
  cursor:pointer;white-space:nowrap;font-family:'DM Sans',sans-serif;
  transition:background .15s,border-color .15s;
}
.overdue-badge:hover{background:rgba(239,68,68,.2);border-color:var(--red)}
.overdue-badge.hidden{display:none}

/* ══ QUICK-ADD BAR ══════════════════════════════════ */
#quickAddBar{
  position:fixed;top:90px;left:50%;transform:translateX(-50%);
  z-index:800;width:540px;max-width:calc(100vw - 28px);
  background:var(--surface);border:1px solid var(--border);border-radius:14px;
  box-shadow:0 12px 48px rgba(0,0,0,.22);padding:18px;
  display:none;flex-direction:column;gap:10px;
  animation:qaDrop .18s cubic-bezier(.34,1.56,.64,1);
}
#quickAddBar.open{display:flex}
@keyframes qaDrop{from{opacity:0;transform:translateX(-50%) translateY(-10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.qa-title{font-family:'DM Serif Display',serif;font-size:16px;color:var(--text);margin-bottom:2px}
.qa-input{width:100%;padding:10px 12px;border:1.5px solid var(--accent);border-radius:10px;
  font-family:'DM Sans',sans-serif;font-size:15px;color:var(--text);background:var(--bg);
  outline:none;box-shadow:0 0 0 3px rgba(var(--accent-rgb),.1)}
.qa-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.qa-fi{padding:7px 10px;border:1px solid var(--border);border-radius:8px;
  font-family:'DM Sans',sans-serif;font-size:12px;color:var(--text);background:var(--bg);
  outline:none;transition:border-color .15s}
.qa-fi:focus{border-color:var(--accent)}
.qa-acts{display:flex;gap:7px;justify-content:flex-end}
.qa-dur-row{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}
.qa-dur-row .dur-opt{padding:3px 8px;font-size:10px}

/* ══ IDEA TIP MODAL ══════════════════════════════════ */


/* ══ APP ZOOM ═══════════════════════════════════════ */

/* ══ TIME SLOT CONTRAST ════════════════════════════ */
/* Week view slots */
.wk-slot{
  border-bottom:1px solid var(--border2) !important;
}
.wk-slot.half{
  border-bottom:1px dashed var(--border) !important;
}
.wk-time-col .time-lbl{
  border-right:2px solid var(--border2);
  font-weight:600;
  color:var(--text2);
}
.wk-day-col{
  border-right:1px solid var(--border2) !important;
}

/* Day view slots */
.day-slot{
  border-bottom:1px solid var(--border2) !important;
}
.day-slot.half{
  border-bottom:1px dashed var(--border) !important;
}
.day-time-lbl{
  border-right:2px solid var(--border2);
  font-weight:600;
  color:var(--text2);
}

/* Hour rows get a slightly stronger line */
.wk-slot:not(.half){
  background:var(--surface);
}
.day-slot:not(.half){
  background:var(--surface);
}
.wk-slot.half,.day-slot.half{
  background:var(--surface2);
  opacity:.92;
}
[data-dark="true"] .wk-slot:not(.half),
[data-dark="true"] .day-slot:not(.half){
  background:var(--surface);
}
[data-dark="true"] .wk-slot.half,
[data-dark="true"] .day-slot.half{
  background:var(--surface2);
}

/* ══ TIME FORMAT TOGGLE ══════════════════════════════ */
.tf-toggle-row{display:flex;gap:6px;margin-top:6px}
.tf-btn{
  flex:1;padding:8px 4px;border-radius:8px;border:1.5px solid var(--border);
  background:var(--surface2);font-family:'DM Sans',sans-serif;
  font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;
  color:var(--text2);text-align:center;
}
.tf-btn:hover{border-color:var(--border2);color:var(--text)}
.tf-btn.active{border-color:var(--accent);background:var(--accent-pale);color:var(--accent)}
[data-dark="true"] .tf-btn.active{background:rgba(var(--accent-rgb),.18)}

/* ══ TIP BAR ══════════════════════════════════════ */

/* ══ JOURNAL PANEL ══════════════════════════════════ */

/* ══ STREAK BADGE ══════════════════════════════════ */
.streak-badge{
  display:inline-flex;align-items:center;gap:3px;
  font-size:9px;font-weight:700;padding:2px 7px;border-radius:99px;
  background:rgba(var(--accent-rgb),.12);color:var(--accent);
  white-space:nowrap;
}
.streak-badge.fire{background:rgba(245,158,11,.12);color:var(--amber-warn)}

/* ══ EMPTY STATE ══════════════════════════════════ */
.day-empty-state{
  position:absolute;top:35%;left:50%;transform:translate(-50%,-50%);
  text-align:center;pointer-events:none;z-index:1;
}
.day-empty-icon{font-size:36px;margin-bottom:8px;opacity:.7}
.day-empty-text{font-size:13px;color:var(--text3);line-height:1.6;font-weight:400}
.routine-slot-label{
  font-size:12px;font-weight:700;opacity:.75;padding:2px 8px;
  display:flex;align-items:center;gap:5px;pointer-events:none;
  letter-spacing:.2px;
}
.routine-slot-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;opacity:.8}

/* ══ ROUTINE BANNER (overlay, z-index 5, above tasks) ═══════ */
.routine-banner{
  position:absolute;z-index:5;pointer-events:none;
  display:flex;align-items:center;gap:5px;
  padding:2px 10px;font-size:10px;font-weight:600;
  color:var(--rb-color);letter-spacing:.15px;
  background:transparent;
  border-bottom:1px solid transparent;
  border-radius:0 10px 0 0;
}
.routine-banner-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}
.routine-banner-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.routine-banner-badge{
  font-size:7px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;
  padding:1px 5px;border-radius:3px;flex-shrink:0;
}
.routine-banner-badge.window{background:rgba(255,255,255,.2);color:#fff}
.routine-banner-badge.block{color:rgba(255,255,255,.8);background:rgba(0,0,0,.15)}
[data-dark="true"] .routine-banner-badge.window{background:rgba(255,255,255,.15)}
.routine-banner-time{margin-left:auto;font-size:9px;opacity:.7;font-weight:500;white-space:nowrap}

/* Week view banner */
.wk-routine-banner{
  position:absolute;left:0;right:0;z-index:5;pointer-events:none;
  display:flex;align-items:center;gap:3px;
  padding:2px 4px;font-size:9px;font-weight:700;
  border-radius:4px 4px 0 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

/* ══ ROUTINE CONTAINER NESTING ═══════════════════════ */
.routine-container{
  position:absolute;z-index:1;pointer-events:none;
  border-radius:0 10px 10px 0;
  border-left:3px solid var(--rc-color,#888);
  box-shadow:inset 0 0 0 1px var(--rc-dim,rgba(0,0,0,.06));
  background:var(--rc-bg,transparent);
  overflow:visible;
}
.day-slot[data-routine] .day-task-slot-wrap{margin:0 4px}
.routine-window-hint{font-size:10px;opacity:.55;padding:2px 10px;pointer-events:none;font-style:italic;letter-spacing:.2px;font-weight:600}

/* ══ TASK TOOLTIP ══════════════════════════════════ */
.task-tooltip{
  position:fixed;z-index:9000;max-width:260px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:10px;padding:8px 12px;
  box-shadow:0 6px 24px rgba(0,0,0,.15);
  font-size:11px;color:var(--text2);line-height:1.5;
  pointer-events:none;opacity:0;transition:opacity .15s;
}
.task-tooltip.show{opacity:1}
.task-tooltip-title{font-size:12px;font-weight:600;color:var(--text);margin-bottom:3px}
.task-tooltip-notes{font-style:italic;color:var(--text3)}

/* ══ EXPORT BUTTONS ══════════════════════════════════ */
.drawer-btn-row{display:flex;gap:6px;margin-top:4px}
.drawer-btn{
  flex:1;padding:8px 4px;border-radius:8px;border:1.5px solid var(--border);
  background:var(--surface2);font-family:'DM Sans',sans-serif;
  font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;
  color:var(--text2);text-align:center;
}
.drawer-btn:hover{border-color:var(--accent);color:var(--accent)}
.drawer-file-input{display:none}

.search-bar.open{display:flex}
.search-input{
  padding:10px 14px;border:none;border-bottom:1px solid var(--border);
  font-family:'DM Sans',sans-serif;font-size:13px;color:var(--text);
  background:transparent;outline:none;
}
.search-input::placeholder{color:var(--text3)}
.search-results{max-height:280px;overflow-y:auto;padding:6px}
.search-result{
  padding:8px 10px;border-radius:8px;cursor:pointer;
  display:flex;align-items:center;gap:8px;transition:background .12s;
}
.search-result:hover{background:var(--surface2)}
.sr-name{font-size:12px;font-weight:500;color:var(--text)}
.sr-meta{font-size:10px;color:var(--text3)}
.sr-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.search-empty{padding:16px;text-align:center;font-size:12px;color:var(--text3);font-style:italic}

/* ══ BD REORDER DROP INDICATOR ════════════════════ */
.bd-card.drag-above{border-top:2px solid var(--accent);margin-top:-2px}
.bd-card.drag-below{border-bottom:2px solid var(--accent);margin-bottom:-2px}

/* ══ CONFETTI ══════════════════════════════════════ */
.confetti-canvas{
  position:fixed;inset:0;z-index:99999;pointer-events:none;
}

/* ══ AI SCHEDULE ══════════════════════════════════ */

/* ══ WEEKLY WRAP-UP ═══════════════════════════════ */

/* ══ WEEK PLAN ═══════════════════════════════════ */
.wp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin:8px 0}
.wp-day{
  background:var(--surface2);border:1px solid var(--border);border-radius:8px;
  padding:6px;min-height:120px;font-size:10px;
  display:flex;flex-direction:column;gap:3px;
  transition:border-color .15s;
}
.wp-day.today{border-color:var(--accent)}
.wp-day-hdr{font-weight:700;color:var(--text);margin-bottom:3px;font-size:11px;text-align:center}
.wp-day-date{font-size:9px;color:var(--text3);text-align:center;margin-bottom:4px}
.wp-routine{font-size:9px;color:var(--text3);padding:2px 4px;background:var(--surface3);border-radius:3px;margin-bottom:2px}
.wp-task-mini{
  font-size:9px;padding:3px 5px;background:var(--surface);border:1px solid var(--border);
  border-radius:4px;border-left:2px solid var(--accent);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.wp-task-mini.done{opacity:.4;text-decoration:line-through}
.wp-empty{font-size:9px;color:var(--text3);font-style:italic;text-align:center;padding:8px 0}
.wp-intention{
  width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:9px;
  font-family:'DM Sans',sans-serif;font-size:13px;color:var(--text);
  background:var(--bg);outline:none;transition:border-color .15s;
}
.wp-intention:focus{border-color:var(--accent)}
.wp-intention::placeholder{color:var(--text3);font-style:italic}
[data-dark="true"] .wp-intention{background:var(--surface2);border-color:var(--border)}
@media(max-width:640px){
  .wp-grid{grid-template-columns:repeat(2,1fr)}
}

/* ══ WEEKLY WRAP-UP ═══════════════════════════════ */
.wrapup-card{
  display:flex;flex-direction:column;gap:14px;
}
.wrapup-stat-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:8px;
}
.wrapup-stat{
  padding:12px;background:var(--surface2);border-radius:10px;
  text-align:center;
}
.wrapup-stat-num{
  font-family:'DM Serif Display',serif;font-size:28px;color:var(--accent);
  line-height:1;margin-bottom:2px;
}
.wrapup-stat-label{font-size:10px;color:var(--text3);font-weight:500;text-transform:uppercase;letter-spacing:.5px}
.wrapup-bar-row{display:flex;align-items:center;gap:8px;font-size:11px}
.wrapup-bar-label{min-width:32px;font-weight:600;color:var(--text2);text-align:right}
.wrapup-bar-track{flex:1;height:8px;background:var(--surface2);border-radius:99px;overflow:hidden}
.wrapup-bar-fill{height:100%;border-radius:99px;background:var(--accent);transition:width .5s ease}
.wrapup-bar-val{min-width:24px;font-size:10px;color:var(--text3)}
.wrapup-msg{
  text-align:center;padding:10px;font-size:13px;color:var(--text2);line-height:1.6;
  font-style:italic;
}

/* ══ FOCUS TIMER ══════════════════════════════════ */
.focus-wrap{
  display:flex;flex-direction:column;align-items:center;
  padding:20px 16px;flex:1;overflow-y:auto;gap:4px;
}
.focus-empty{text-align:center;padding:30px 12px}
/* Sidebar compact card */
.focus-sidebar-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:var(--surface2);cursor:pointer;transition:background .12s;width:100%}
.focus-sidebar-card:hover{background:var(--surface3)}
.focus-sidebar-ring{width:36px;height:36px;flex-shrink:0}
.focus-sidebar-ring svg{width:100%;height:100%}
.focus-sidebar-info{flex:1;min-width:0}
.focus-sidebar-name{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.focus-sidebar-time{font-size:18px;font-weight:600;color:var(--accent);letter-spacing:.5px}
.focus-sidebar-open{font-size:10px;font-weight:600;color:var(--accent);flex-shrink:0}
.focus-session-count{font-size:10px;color:var(--text3);text-align:center;margin-top:8px}
/* Focus Overlay */
.fo-overlay{position:fixed;inset:0;background:rgba(0,0,0,.82);z-index:600;display:none;align-items:center;justify-content:center}
.fo-overlay.show{display:flex}
.fo-card{background:var(--surface);border-radius:24px;padding:28px 24px;width:380px;max-width:92vw;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;align-items:center;position:relative}
.fo-exit{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;border:none;background:var(--surface2);color:var(--text2);font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-family:'DM Sans',sans-serif;transition:background .12s;z-index:1}
.fo-exit:hover{background:var(--surface3)}
.fo-task-header{display:flex;align-items:center;gap:10px;justify-content:center;width:100%}
.fo-done-check{width:22px;height:22px;border-radius:6px;border:2px solid var(--border2);cursor:pointer;flex-shrink:0;transition:all .15s;display:flex;align-items:center;justify-content:center}
.fo-done-check:hover{border-color:var(--accent)}
.fo-done-check.checked{background:var(--accent);border-color:var(--accent)}
.fo-done-check.checked::after{content:'✓';color:#fff;font-size:12px;font-weight:700}
.fo-task-name{font-family:'DM Serif Display',serif;font-size:18px;color:var(--text);text-align:center;line-height:1.3;max-width:90%;word-break:break-word}
.fo-task-meta{font-size:11px;color:var(--text3);text-align:center;margin-top:4px;margin-bottom:8px;display:flex;align-items:center;justify-content:center;gap:4px}
.fo-cat-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
/* Mode toggle */
.fo-mode-row{display:flex;gap:0;border-radius:10px;border:1px solid var(--border);overflow:hidden;width:100%;margin-bottom:12px}
.fo-mode-btn{flex:1;padding:9px 6px;font-size:12px;font-weight:600;color:var(--text3);background:var(--surface2);text-align:center;cursor:pointer;border:none;border-right:1px solid var(--border);font-family:'DM Sans',sans-serif;transition:all .12s}
.fo-mode-btn:last-child{border-right:none}
.fo-mode-btn.on{color:var(--accent);background:var(--accent-pale)}
[data-dark="true"] .fo-mode-btn.on{background:rgba(var(--accent-rgb),.15)}
/* Custom slider */
.fo-custom-row{display:flex;align-items:center;gap:10px;width:100%;padding:0 4px;margin-bottom:10px}
.fo-custom-row input[type=range]{flex:1}
.fo-custom-val{font-size:13px;font-weight:600;color:var(--text);min-width:36px;text-align:right}
/* Ring */
.fo-ring-wrap{position:relative;width:180px;height:180px;margin:8px 0}
.fo-ring{width:100%;height:100%}
.fo-ring-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.fo-time{font-family:'DM Sans',sans-serif;font-size:32px;font-weight:300;color:var(--text);letter-spacing:1px}
.fo-time-label{font-size:10px;color:var(--text3);margin-top:2px}
/* Play button */
.fo-play-btn{width:56px;height:56px;border-radius:50%;background:var(--accent);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;margin:8px 0;transition:background .12s}
.fo-play-btn:hover{background:var(--accent-dim)}
.fo-play-btn svg{fill:#fff}
/* Secondary actions */
.fo-sec-row{display:flex;gap:20px;justify-content:center;margin-top:6px}
.fo-sec-link{font-size:12px;color:var(--text3);cursor:pointer;transition:color .12s}
.fo-sec-link:hover{color:var(--text2)}
.fo-sec-end:hover{color:var(--red)}
.fo-divider{width:100%;height:1px;background:var(--border);margin:14px 0}
/* Subtasks in focus */
.fo-sub-label{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px;width:100%}
.fo-sub-row{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--surface2);border-radius:8px;width:100%;margin-bottom:4px;cursor:pointer;transition:background .1s}
.fo-sub-row:hover{background:var(--surface3)}
.fo-sub-check{width:16px;height:16px;border-radius:4px;border:2px solid var(--border2);flex-shrink:0;transition:all .15s;display:flex;align-items:center;justify-content:center}
.fo-sub-check.checked{background:var(--accent);border-color:var(--accent)}
.fo-sub-check.checked::after{content:'✓';color:#fff;font-size:9px;font-weight:700}
.fo-sub-name{font-size:12px;color:var(--text);flex:1}
.fo-sub-name.done{text-decoration:line-through;opacity:.5}
/* Intention */
.fo-intention{width:100%;text-align:center;margin-top:4px}
.fo-intention-text{font-size:11px;color:var(--text3);font-style:italic;line-height:1.5}
/* In-overlay notification */
.fo-notify{display:none;align-items:center;gap:8px;width:100%;padding:8px 10px;border-radius:8px;border-left:3px solid var(--accent);background:var(--accent-pale);margin:6px 0;font-size:11px;color:var(--text);line-height:1.4;border-radius:0 8px 8px 0}
.fo-notify.show{display:flex}
.fo-notify-ok{background:var(--accent-pale)}
.fo-notify-warn{background:rgba(245,158,11,.1)}
.fo-notify-error{background:var(--red-pale)}
.fo-notify-msg{flex:1}
.fo-notify-x{border:none;background:none;color:var(--text3);cursor:pointer;font-size:12px;padding:2px 4px;font-family:'DM Sans',sans-serif;flex-shrink:0}
.fo-notify-x:hover{color:var(--text)}
[data-dark="true"] .fo-notify-ok{background:rgba(var(--accent-rgb),.15)}
[data-dark="true"] .fo-notify-warn{background:rgba(251,191,36,.12)}
[data-dark="true"] .fo-notify-error{background:rgba(248,113,113,.12)}
/* Completion state */
.fo-complete-wrap{display:flex;flex-direction:column;align-items:center;padding:20px 0;gap:8px}
.fo-complete-icon{margin-bottom:4px}
.fo-complete-title{font-family:'DM Serif Display',serif;font-size:20px;color:var(--text)}
.fo-complete-sub{font-size:12px;color:var(--text3)}
.fo-complete-btn{margin-top:12px;padding:10px 32px;border-radius:99px;border:none;background:var(--accent);color:#fff;font-size:14px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:background .12s}
.fo-complete-btn:hover{background:var(--accent-dim)}
/* Floating Mini Timer */
.fmt-pill{position:fixed;bottom:20px;right:20px;z-index:550;display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:50px;padding:8px 14px 8px 10px;cursor:pointer;transition:box-shadow .15s;box-shadow:0 4px 20px rgba(0,0,0,.08)}
.fmt-pill:hover{box-shadow:0 4px 24px rgba(0,0,0,.15)}
[data-dark="true"] .fmt-pill{box-shadow:0 4px 20px rgba(0,0,0,.3)}
.fmt-ring{width:36px;height:36px;flex-shrink:0}
.fmt-ring svg{width:100%;height:100%}
.fmt-info{display:flex;flex-direction:column;min-width:0}
.fmt-name{font-size:11px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}
.fmt-time{font-size:18px;font-weight:600;color:var(--accent);letter-spacing:.5px;line-height:1}
.fmt-close{width:24px;height:24px;border-radius:50%;border:1px solid var(--border);background:var(--surface2);color:var(--text3);font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-left:4px;cursor:pointer;transition:all .12s;font-family:'DM Sans',sans-serif}
.fmt-close:hover{color:var(--red);border-color:var(--red);background:var(--red-pale)}
/* Break message (kept for backward compat) */
.focus-break-msg{text-align:center;padding:16px;background:var(--accent-pale);border-radius:12px;margin:10px 0}
[data-dark="true"] .focus-break-msg{background:rgba(var(--accent-rgb),.12)}
.focus-break-msg-icon{margin-bottom:4px;color:var(--text2);display:flex;align-items:center;justify-content:center}
.focus-break-msg-text{font-size:13px;font-weight:500;color:var(--text)}
.focus-break-msg-sub{font-size:11px;color:var(--text2);margin-top:2px}
.focus-btn{padding:8px 18px;border-radius:10px;border:none;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}
.focus-btn.primary{background:var(--accent);color:#fff;padding:10px 28px;font-size:14px;border-radius:99px}
.focus-btn.primary:hover{background:var(--accent-dim)}
.focus-btn.secondary{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}
.focus-btn.secondary:hover{border-color:var(--accent);color:var(--accent)}

/* ══ REFLOW MODAL ═════════════════════════════════ */
.reflow-task{
  display:flex;align-items:center;gap:8px;padding:7px 10px;
  background:var(--surface2);border-radius:8px;margin-bottom:4px;
  font-size:12px;
}
.reflow-old{text-decoration:line-through;color:var(--text3);font-size:11px}
.reflow-new{color:var(--accent);font-weight:600;font-size:11px}
.reflow-arrow{color:var(--text3);font-size:10px}

/* ══ MY ROUTINE ═══════════════════════════════════ */
.routine-hero{
  background:var(--surface2);border-radius:12px;padding:12px 16px 10px;margin-bottom:14px;
  display:flex;flex-direction:column;max-height:220px;min-height:0;
}
.routine-hero-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:8px;flex-shrink:0}
.routine-hero-title{font-family:'DM Serif Display',serif;font-size:18px;color:var(--text)}
.routine-hero-desc{font-size:12px;color:var(--text3);line-height:1.5;margin-bottom:12px;flex-shrink:0}
.rt-hero-tabs{display:flex;gap:0;background:var(--surface);border-radius:8px;border:1px solid var(--border);overflow:hidden}
.rt-hero-tab{font-size:11px;padding:6px 14px;color:var(--text3);font-weight:500;cursor:pointer;border:none;background:none;font-family:'DM Sans',sans-serif;border-right:1px solid var(--border);transition:all .12s}
.rt-hero-tab:last-child{border-right:none}
.rt-hero-tab.on{color:var(--accent);background:var(--accent-pale)}
[data-dark="true"] .rt-hero-tab.on{background:rgba(var(--accent-rgb),.15)}

/* Day selector */
.rt-day-selector{display:flex;align-items:center;gap:10px;margin-bottom:8px;flex-wrap:wrap;flex-shrink:0}
.rt-day-btns{display:flex;gap:4px}
.rt-day-btn{
  width:30px;height:30px;border-radius:50%;border:1.5px solid var(--border);
  background:none;color:var(--text3);font-size:12px;font-weight:600;
  font-family:'DM Sans',sans-serif;cursor:pointer;transition:all .15s;
  display:flex;align-items:center;justify-content:center;padding:0;
}
.rt-day-btn:hover{border-color:var(--accent);color:var(--accent)}
.rt-day-btn.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.rt-day-presets{display:flex;gap:4px;margin-left:2px}
.rt-day-preset{
  font-size:11px;padding:5px 12px;border-radius:20px;border:1.5px solid var(--border);
  background:none;color:var(--text3);font-weight:500;cursor:pointer;
  font-family:'DM Sans',sans-serif;transition:all .15s;
}
.rt-day-preset:hover{border-color:var(--accent);color:var(--accent)}
.rt-day-preset.on{background:var(--accent);color:#fff;border-color:var(--accent)}
[data-dark="true"] .rt-day-btn{border-color:var(--border)}
[data-dark="true"] .rt-day-preset{border-color:var(--border)}

/* Strip */
.rt-strip-wrap{margin-bottom:4px;flex:1;display:flex;flex-direction:column;min-height:0}
.rt-strip{position:relative;flex:1;min-height:28px;max-height:60px;background:var(--surface);border-radius:8px;border:1px solid var(--border);overflow:hidden}
.rt-strip-blk{
  position:absolute;top:4px;bottom:4px;border-radius:6px;
  display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer;transition:opacity .12s;
}
.rt-strip-blk:hover{opacity:.8!important}
.rt-strip-blk span{font-size:11px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 8px}
.rt-night-r{border-radius:6px 0 0 6px!important}
.rt-night-l{border-radius:0 6px 6px 0!important}
.rt-strip-times{display:flex;justify-content:space-between;padding:0 2px;margin-top:5px;flex-shrink:0}
.rt-strip-times span{font-size:10px;color:var(--text3)}

/* Add button */
.routine-add-row{text-align:center;margin-bottom:18px;flex-shrink:0}
.routine-add-btn{
  font-size:13px;font-weight:600;color:var(--accent);padding:10px 28px;
  border:1.5px solid var(--accent);border-radius:99px;background:none;
  cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s;letter-spacing:.2px;
}
.routine-add-btn:hover{background:var(--accent-pale)}

/* Lower: instructions + block list */
.routine-lower{display:flex;gap:24px;align-items:stretch;flex:1;min-height:0}
.routine-instr{width:190px;flex-shrink:0}
.routine-instr-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:10px}
.routine-instr-item{display:flex;gap:8px;align-items:flex-start;margin-bottom:8px;font-size:11px;color:var(--text2);line-height:1.5}
.routine-instr-item strong{font-weight:600;color:var(--text)}
.routine-instr-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:4px}
.routine-instr-hint{font-size:10px;color:var(--text3);margin-top:10px;line-height:1.5;font-style:italic}
.routine-blocks-list{flex:1;min-width:0;display:flex;flex-direction:column}
.routine-blocks-title{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.4px;margin-bottom:8px}

/* Block cards */
.rt-bk{
  display:flex;align-items:center;gap:12px;padding:11px 14px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:10px;margin-bottom:6px;cursor:pointer;transition:border-color .15s;
}
.rt-bk:hover{border-color:var(--accent)}
.rt-bk-bar{width:4px;height:36px;border-radius:99px;flex-shrink:0}
.rt-bk-info{flex:1;min-width:0}
.rt-bk-name{font-size:13px;font-weight:600;color:var(--text)}
.rt-bk-meta{display:flex;align-items:center;gap:8px;margin-top:2px;font-size:11px;color:var(--text3);flex-wrap:wrap}
.rt-bk-days{display:flex;gap:1px}
.rt-bk-day{width:14px;height:14px;display:inline-flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;color:var(--text3);opacity:.25}
.rt-bk-day.on{opacity:1;color:var(--text2)}
.rt-bk-del{background:none;border:none;cursor:pointer;color:var(--text3);padding:4px;border-radius:6px;transition:all .12s;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.rt-bk-del:hover{color:var(--red);background:rgba(239,68,68,.1)}

/* Empty state */
.routine-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px;color:var(--text3);font-size:12px;text-align:center;line-height:1.5}
.rt-strip-empty{display:flex;align-items:center;justify-content:center;border-style:dashed;min-height:40px}
.rt-strip-empty-hint{font-size:12px;color:var(--text3);font-style:italic}
.routine-empty-list{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  flex:1;min-height:80px;
  padding:40px 16px;color:var(--text3);font-size:12px;text-align:center;line-height:1.5;
  background:var(--surface2);border-radius:10px;border:1px dashed var(--border);
}

/* Mode badges */
.routine-mode-badge{font-size:9px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:2px 7px;border-radius:4px;flex-shrink:0}
.routine-mode-badge.window{color:var(--accent);background:var(--accent-pale)}
.routine-mode-badge.block{color:var(--text3);background:var(--surface3)}
[data-dark="true"] .routine-mode-badge.window{background:rgba(var(--accent-rgb),.15)}

.routine-days{display:flex;gap:3px;margin-top:4px}
.routine-day-btn{
  width:26px;height:26px;border-radius:50%;border:1.5px solid var(--border);
  background:var(--surface2);font-size:9px;font-weight:700;cursor:pointer;
  color:var(--text2);transition:all .12s;font-family:'DM Sans',sans-serif;
}
.routine-day-btn.on{background:var(--accent);border-color:var(--accent);color:#fff}

/* ══ AI SCHEDULE ══════════════════════════════════ */
#aiSpinner{
  display:inline-flex;align-items:center;gap:6px;
}
#aiSpinner::before{
  content:'';width:14px;height:14px;border:2px solid rgba(255,255,255,.3);
  border-top-color:#fff;border-radius:50%;animation:aiSpin .6s linear infinite;
}
@keyframes aiSpin{to{transform:rotate(360deg)}}
.ai-preview-task{
  display:flex;align-items:center;gap:8px;padding:5px 0;
  border-bottom:1px solid var(--border);
}
.ai-preview-task:last-child{border-bottom:none}
.ai-preview-time{
  font-size:11px;font-weight:700;color:var(--accent);min-width:58px;flex-shrink:0;
}
.ai-preview-name{font-size:12px;color:var(--text);font-weight:500}
.ai-preview-dur{font-size:10px;color:var(--text3);margin-left:auto;white-space:nowrap}
.journal-wrap{
  display:flex;flex-direction:column;flex:1;overflow:hidden;
}
.journal-date-bar{
  padding:14px 16px 10px;border-bottom:1px solid var(--border);flex-shrink:0;
}
.journal-date-label{
  font-family:'DM Serif Display',serif;font-size:16px;color:var(--text);letter-spacing:-.2px;
}
.journal-date-sub{
  font-size:10px;color:var(--text3);margin-top:2px;font-weight:500;
}

/* Mood picker */
.mood-row{
  display:flex;gap:6px;margin-top:10px;
}
.mood-btn{
  flex:1;padding:7px 2px;border-radius:9px;border:1.5px solid var(--border);
  background:var(--surface2);cursor:pointer;font-size:17px;text-align:center;
  transition:all .15s;line-height:1;
}
.mood-btn:hover{border-color:var(--border2);transform:scale(1.08)}
.mood-btn.selected{border-color:var(--accent);background:var(--accent-pale);transform:scale(1.1)}
[data-dark="true"] .mood-btn.selected{background:rgba(var(--accent-rgb),.18)}
.mood-label{
  font-size:9px;font-weight:600;letter-spacing:.3px;text-transform:uppercase;
  color:var(--text3);margin-top:8px;margin-bottom:4px;
}

/* Journal textarea */
.journal-body{
  flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:10px;
}
.journal-entry-wrap{
  display:flex;flex-direction:column;gap:6px;
}
.journal-ta{
  width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:11px;
  font-family:'DM Sans',sans-serif;font-size:12px;color:var(--text);
  background:var(--bg);outline:none;resize:none;min-height:90px;
  transition:border-color .15s,box-shadow .15s;line-height:1.6;
}
.journal-ta:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.1)}
.journal-ta::placeholder{color:var(--text3);font-style:italic}

/* Save state */
.journal-save-row{
  display:flex;align-items:center;justify-content:space-between;gap:8px;flex-shrink:0;
}
.journal-saved-hint{
  font-size:10px;color:var(--text3);font-style:italic;
  opacity:0;transition:opacity .3s;
}
.journal-saved-hint.show{opacity:1}
.journal-save-btn{
  padding:6px 14px;background:var(--accent);color:#fff;border:none;
  border-radius:8px;font-family:'DM Sans',sans-serif;font-size:11px;
  font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap;
}
.journal-save-btn:hover{background:var(--accent-dim)}

/* Past entries list */
.journal-past-title{
  font-size:9px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;
  color:var(--text3);padding-top:4px;border-top:1px solid var(--border);margin-top:4px;
}
.journal-past-entry{
  padding:10px 12px;background:var(--surface2);border:1px solid var(--border);
  border-radius:10px;cursor:pointer;transition:border-color .15s,box-shadow .15s;
}
.journal-past-entry:hover{border-color:var(--accent);box-shadow:0 1px 6px var(--shadow-color)}
.jpe-header{display:flex;align-items:center;gap:7px;margin-bottom:4px}
.jpe-mood{font-size:14px;line-height:1}
.jpe-date{font-size:10px;font-weight:600;color:var(--text2)}
.jpe-date-sub{font-size:9px;color:var(--text3);margin-left:auto}
.jpe-text{font-size:11px;color:var(--text2);line-height:1.5;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.journal-empty{
  font-size:11px;color:var(--text3);font-style:italic;text-align:center;
  padding:20px 10px;line-height:1.6;
}

/* ══════════════════════════════════════════
   RESPONSIVE — TABLET (≤900px)
══════════════════════════════════════════ */
@media(max-width:900px){
  .year-grid{grid-template-columns:repeat(3,1fr)}
  .sidebar{width:280px}
  .cur-label{min-width:110px;font-size:12px}
}

/* ══════════════════════════════════════════
   RESPONSIVE — MOBILE (≤640px)
══════════════════════════════════════════ */
@media(max-width:640px){
  /* ── Header ── */
  header{height:48px;padding:0 10px;gap:6px}
  .logo-btn{padding:4px 6px;gap:5px}
  .logo-text{font-size:13px}
  .hdr-right{gap:4px}
  .hdr-btn{padding:5px 10px;font-size:10px}
  .nav-arrow{width:22px;height:22px;font-size:10px}
  .cur-label{min-width:0;font-size:11px}
  .search-bar{width:calc(100vw - 16px);top:48px}
  .sidebar-toggle-btn{width:28px;height:28px}

  /* ── Sidebar backdrop ── */
  #sidebarBackdrop{
    position:fixed;inset:0;background:rgba(0,0,0,.25);z-index:299;
    display:none!important;
  }
  #sidebarBackdrop.open{display:block!important}

  /* ── Sidebar: full-width bottom sheet ── */
  .sidebar{
    position:fixed;bottom:56px;left:0;right:0;top:auto;
    width:100%!important;height:55vh;
    border-left:none;border-top:1px solid var(--border);
    border-radius:16px 16px 0 0;
    z-index:300;
    transform:translateY(100%);
    transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .2s;
    opacity:0;
    box-shadow:0 -4px 32px rgba(0,0,0,.15);
    overflow-y:auto;
  }
  .sidebar:not(.collapsed){
    transform:translateY(0);opacity:1;
  }
  .sidebar.collapsed{
    transform:translateY(100%);opacity:0;width:0;
  }
  .side-panel{overflow-y:auto!important}
  .side-panel.active{overflow-y:auto!important}
  .bd-list{max-height:none;overflow-y:auto}
  .side-tabs{padding-top:6px}
  .side-tabs::before{
    content:'';display:block;width:36px;height:4px;border-radius:99px;
    background:var(--border2);margin:0 auto 6px;
  }

  /* ── Year grid ── */
  .year-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .year-wrap{padding:12px}
  .year-month-card{padding:10px}

  /* ── Month grid ── */
  .month-wrap{padding:8px}
  .month-grid{gap:2px}
  .month-cell{min-height:90px;padding:4px;border-radius:7px}
  .m-chip{font-size:9px;padding:2px 4px;border-radius:3px}
  .cell-num-circle{width:18px;height:18px;font-size:10px}
  .more-chip{font-size:9px}
  .month-day-name{font-size:9px}

  /* ── Week grid ── */
  .week-hdr-row{grid-template-columns:42px repeat(7,1fr)}
  .week-grid{grid-template-columns:42px repeat(7,1fr)}
  .wk-allday-row{grid-template-columns:42px repeat(7,1fr)}
  .wk-day-head{padding:5px 2px}
  .wdh-name{font-size:9px}
  .wdh-num{font-size:12px}
  .wk-time-col .time-lbl,.time-lbl{font-size:9px;padding:0 2px}
  .wk-task-block-name{font-size:10px}
  .wk-task-block-dur{font-size:9px}

  /* ── Day view ── */
  .day-hdr{padding:10px 12px}
  .day-title{font-size:18px}
  .day-time-lbl{font-size:11px;padding:4px 8px 0 0;min-height:64px}
  .day-slot{min-height:64px}
  .day-task-block{margin:2px 4px 2px 6px;padding:5px 10px 10px}
  .day-task-block-name{font-size:13px}
  .allday-pill{font-size:10px;padding:2px 8px}
  .day-conflict-badge{font-size:9px}
  .day-time-range{font-size:9px;padding:1px 5px}
  .day-task-notes-pill{display:none}

  /* ── Schedule/Categories view ── */
  .cat-view-hdr{padding:8px 12px 0}
  .cat-hdr-row1{padding-bottom:8px}
  .cat-hdr-row2{padding-bottom:8px}
  .cat-view-title{font-size:17px}
  .cat-scroll{padding:10px 12px}
  .cat-chip{font-size:10px;padding:2px 8px}

  /* ── Modals — slide up as bottom sheet on mobile ── */
  .modal-overlay{align-items:flex-end}
  .modal{
    max-height:92vh;border-radius:16px 16px 0 0;
    margin-bottom:0;width:100%;max-width:100%;
  }
  .modal-header{padding:14px 16px 12px}
  .modal-body{padding:12px 16px}
  .modal-footer{padding:10px 16px 24px} /* 24px: iOS safe area */
  .modal-title{font-size:16px}
  .frow{grid-template-columns:1fr 1fr}

  /* ── Quick Add ── */
  #quickAddBar{left:8px;right:8px;width:auto}
  .qa-row{grid-template-columns:1fr 1fr}

  /* ── Drawer ── */
  .drawer{width:100%}
  .bd-ta{min-height:44px;font-size:13px}

  /* ── Routine section mobile ── */
  .routine-hero{padding:14px 12px 10px}
  .routine-hero-title{font-size:16px}
  .rt-day-btn{width:26px;height:26px;font-size:11px}
  .rt-day-preset{font-size:10px;padding:4px 9px}
  .routine-lower{flex-direction:column;gap:14px}
  .routine-instr{width:100%}
  .rt-bk{padding:9px 10px}
  .rt-bk-name{font-size:12px}
  .routine-add-btn{font-size:12px;padding:8px 22px}

  /* ── Day routine chips mobile ── */
  .day-routine-chips{padding:6px 12px;gap:4px}
  .day-rt-chip{font-size:10px;padding:3px 5px 3px 7px}
  .day-rt-chip-btn{font-size:9px;padding:2px 6px}

  /* ── Schedule tab 4-button bar mobile ── */
  .sched-seg-btn{padding:5px 8px;font-size:10px}

  /* ── Recur day-of-week buttons in modal ── */
  .recur-day-btn{width:24px;height:24px;font-size:10px}

  /* ── Multi-day subtitle mobile ── */
  .toggle-row>div{min-width:0;flex:1}
  .toggle-row .toggle-sub{font-size:9px}

  /* ── Holiday items mobile ── */
  .holiday-item{padding:8px 10px;gap:8px}
  .holiday-name{font-size:12px}
  .holiday-date{font-size:10px}
  .holiday-year-title{font-size:14px}
  .holiday-action-btn{font-size:10px;padding:3px 10px}

  /* ── Month multi-day chip mobile ── */
  .m-chip-multiday{margin-left:-2px;margin-right:-2px;font-size:8px;padding:1px 3px}

  /* ── Week multi-day bar mobile ── */
  .wk-multiday-bar{height:16px;font-size:8px;padding:0 4px}

  /* ── Drag grip mobile ── */
  .drag-grip{height:14px}
  .grip-dots{opacity:.4}

  /* ── Recur summary row mobile ── */
  .recur-summary-row{padding:5px 10px}
  .recur-summary-text{font-size:10px}
}

/* ══════════════════════════════════════════
   TOUCH / NO-HOVER OVERRIDES
   These fix elements that are opacity:0 and only revealed on :hover.
   On touch devices there is no persistent hover, so they must always be visible.
══════════════════════════════════════════ */
@media(hover:none){
  /* + subtask button on task blocks */
  .day-add-sub-btn{opacity:.7}
  .day-add-sub-btn::after{display:none}

  /* Duration stepper buttons always visible on touch */
  .dur-step-btn{opacity:1;background:var(--surface2)}
  .dur-stepper{border-color:var(--border)}
  .event-block .dur-step-btn{opacity:1;background:rgba(255,255,255,.15)}
  .event-block .dur-stepper{border-color:rgba(255,255,255,.2)}

  /* Subtask grip always visible on touch */
  .sub-grip{opacity:.5}

  /* Week view duration stepper on touch */
  .wk-dur-btn{opacity:1}

  /* ✕ delete button on attachment items in modal */
  .attach-item-del{opacity:.6}

  /* ✕ delete button on subtask items in modal */
  .subtask-item .subtask-del{opacity:.6}

  /* Edit hint on category task/habit rows */
  .cat-edit-hint{opacity:.7}

  /* Make tap targets slightly larger on touch */
  .day-add-sub-btn{width:26px;height:26px}
  .attach-item-del{padding:2px 6px}
  .subtask-item .subtask-del{padding:2px 6px}

  /* Phase 3 touch overrides */
  .day-rt-chip-btn{opacity:1;min-height:28px;min-width:44px}
  .holiday-item{min-height:44px}
  .event-color-swatch{width:32px;height:32px}
  .recur-day-btn{min-width:28px;min-height:28px}
  .rt-day-btn{min-width:28px;min-height:28px}

  /* Drag grip always visible on touch */
  .drag-grip{height:16px}
  .grip-dots{opacity:.5}
  .event-block .grip-dots::before{background:rgba(255,255,255,.5)}
}
@media(max-width:380px){
  .nav-tab{padding:4px 6px;font-size:9px}
  .hdr-btn{font-size:9px;padding:5px 8px}
  .year-grid{grid-template-columns:repeat(1,1fr)}
  .month-cell{min-height:70px}
  .week-hdr-row{grid-template-columns:32px repeat(7,1fr)}
  .week-grid{grid-template-columns:32px repeat(7,1fr)}
  .wk-allday-row{grid-template-columns:32px repeat(7,1fr)}
  .wdh-name{font-size:9px}.wdh-num{font-size:10px}
  .sched-seg-btn{padding:4px 6px;font-size:9px}
  .rt-day-btn{width:22px;height:22px;font-size:10px}
  .rt-day-preset{font-size:9px;padding:3px 7px}
  .rt-day-selector{gap:6px}
  .day-rt-chip-time{display:none}
  .recur-day-btn{width:22px;height:22px;font-size:9px}
}

/* ══ WEEKLY REVIEW (guided) ════════════════════ */
.wrapup-dots,.wr-dots{display:flex;justify-content:center;gap:5px;margin-top:8px}
.wr-dot{width:7px;height:7px;border-radius:50%;background:var(--border2);transition:all .2s}
.wr-dot.on{background:var(--accent);transform:scale(1.2)}
.wr-step-title{font-size:16px;font-weight:700;margin-bottom:6px}
.wr-auto-stat{font-size:12px;color:var(--text2);margin-bottom:10px;line-height:1.5}
.wr-auto-stat strong{color:var(--text);font-weight:700}
.wr-textarea{width:100%;min-height:60px;resize:vertical;font-size:12px;line-height:1.6}
.wr-carry-list{display:flex;flex-direction:column;gap:4px;max-height:220px;overflow-y:auto}
.wr-carry-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;background:var(--surface2);cursor:pointer;transition:all .15s;border:1px solid var(--border)}
.wr-carry-item:hover{border-color:var(--accent)}
.wr-carry-item.dimmed{opacity:.4;text-decoration:line-through}
.wr-carry-check{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}
.wr-carry-item:not(.dimmed) .wr-carry-check{background:var(--accent);color:#fff}
.wr-carry-item.dimmed .wr-carry-check{background:var(--surface3);color:var(--text3)}
.wr-carry-name{font-size:12px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}
.wr-habit-list{display:flex;flex-direction:column;gap:4px}
.wr-habit-row{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--surface2);border-radius:8px}
.wr-habit-name{flex:1;font-size:12px;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.wr-habit-score{font-size:11px;color:var(--text2);font-weight:600}
.wr-habit-pct{font-size:11px;color:var(--accent);font-weight:700;min-width:28px;text-align:right}
.wr-habit-streak{font-size:11px;color:#f59e0b;font-weight:700}

/* ══ PROGRESSIVE HINTS ═════════════════════════ */
.prog-hint{
  display:flex;align-items:center;gap:8px;padding:8px 14px;margin:0 12px 4px;
  background:var(--accent-pale);border:1px solid rgba(var(--accent-rgb),.2);
  border-radius:10px;font-size:11px;color:var(--text2);animation:hintSlide .3s ease-out;
}
.prog-hint-text{flex:1;line-height:1.4}
.prog-hint-btn{padding:4px 12px;border-radius:6px;border:none;background:var(--accent);color:#fff;font-size:10px;font-weight:600;cursor:pointer;white-space:nowrap;font-family:'DM Sans',sans-serif}
.prog-hint-close{padding:2px 6px;border:none;background:none;color:var(--text3);cursor:pointer;font-size:14px;flex-shrink:0}
.prog-hint-close:hover{color:var(--text)}
@keyframes hintSlide{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* ══ ANALYTICS DASHBOARD ═══════════════════════ */
.ana-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:16px}
.ana-stat{padding:10px 8px;background:var(--surface2);border-radius:10px;text-align:center}
.ana-stat-val{font-size:18px;font-weight:800;font-family:'DM Serif Display',serif}
.ana-stat-lbl{font-size:9px;color:var(--text3);margin-top:2px}
.ana-stat-change{font-size:9px;font-weight:700;margin-top:3px}
.ana-up{color:#22c55e}.ana-down{color:#ef4444}
.ana-section{margin-bottom:16px}
.ana-sec-title{font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--text3);margin-bottom:8px}
.ana-bars{display:flex;align-items:flex-end;gap:4px;height:90px;padding-bottom:4px;border-bottom:1px solid var(--border)}
.ana-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;height:100%}
.ana-bar{border-radius:4px 4px 0 0;width:100%;min-height:2px;margin-top:auto}
.ana-bar-val{font-size:9px;color:var(--text3);font-weight:600}
.ana-bar-lbl{font-size:9px;color:var(--text3)}.ana-bar-lbl.ana-today{color:var(--accent);font-weight:700}
.ana-cats{display:flex;flex-direction:column;gap:6px}
.ana-cat-row{display:flex;align-items:center;gap:8px}
.ana-cat-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.ana-cat-name{font-size:11px;font-weight:600;min-width:40px;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ana-cat-bar{flex:1;height:6px;border-radius:3px;background:var(--surface3);overflow:hidden}
.ana-cat-fill{height:100%;border-radius:3px}
.ana-cat-pct{font-size:10px;color:var(--text3);font-weight:600;min-width:28px;text-align:right}
.ana-peak{display:flex;gap:2px}
.ana-peak-cell{flex:1;height:28px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;color:var(--text3)}
@media(max-width:640px){.ana-stats{grid-template-columns:repeat(2,1fr)}}

/* ══ HABIT STREAKS ═════════════════════════════ */
.habit-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:6px;cursor:pointer;transition:border-color .15s;overflow:hidden}
.habit-card:hover{border-color:var(--border2)}
.habit-card.open{border-color:var(--accent)}
.habit-card-hdr{display:flex;align-items:center;gap:8px;padding:10px 12px}
.habit-card-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.habit-card-info{flex:1;min-width:0}
.habit-card-name{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.habit-card-meta{font-size:10px;color:var(--text3);margin-top:1px}
.habit-bar{height:3px;border-radius:2px;background:var(--surface3);margin-top:4px;overflow:hidden}
.habit-bar-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--accent),#f59e0b)}
.habit-streak{font-size:14px;font-weight:800;color:#f59e0b;flex-shrink:0;min-width:32px;text-align:right}
.habit-detail{padding:0 12px 12px;border-top:1px solid var(--border)}
.habit-stat-row{display:flex;gap:4px;margin:8px 0}
.habit-stat{flex:1;text-align:center;padding:6px 4px;background:var(--surface2);border-radius:6px}
.habit-stat-val{display:block;font-size:14px;font-weight:800;color:var(--text)}
.habit-stat-lbl{display:block;font-size:9px;color:var(--text3);margin-top:1px}
.habit-heatmap{margin-top:4px}
.hm-grid{display:flex;flex-wrap:wrap;gap:2px}
.hm-cell{width:10px;height:10px;border-radius:2px;background:var(--surface3);transition:transform .1s}
.hm-cell:hover{transform:scale(1.5)}
.hm-done{background:var(--accent)}
.hm-miss{background:var(--surface3)}
.hm-legend{display:flex;justify-content:center;gap:12px;margin-top:6px;font-size:9px;color:var(--text3)}

/* ══ HELP CENTER ═══════════════════════════════ */
.help-cat{margin-bottom:16px}
.help-cat-title{font-size:10px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--text3);padding:6px 0;border-bottom:1px solid var(--border);margin-bottom:4px}
.help-item{border-bottom:1px solid var(--border)}
.help-item:last-child{border-bottom:none}
.help-q{padding:10px 0;cursor:pointer;display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:600;color:var(--text);transition:color .15s}
.help-q:hover{color:var(--accent)}
.help-q-icon{font-size:11px;color:var(--text3);transition:transform .2s;flex-shrink:0;margin-left:8px}
.help-item.open .help-q-icon{transform:rotate(90deg);color:var(--accent)}
.help-item.open .help-q{color:var(--accent)}
.help-a{display:none;padding:0 0 12px;font-size:12px;color:var(--text2);line-height:1.7}
.help-item.open .help-a{display:block}
.help-a strong{color:var(--text)}
.help-a code{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:1px 5px;font-size:11px;color:var(--accent)}
.help-tip{margin-top:8px;padding:8px 10px;background:var(--surface2);border-radius:8px;border-left:3px solid var(--accent);font-size:11px;color:var(--text2)}
.help-tip strong{color:var(--accent)}
.help-key{display:inline-block;padding:1px 6px;border-radius:4px;background:var(--surface2);border:1px solid var(--border);font-size:10px;font-weight:700;color:var(--text)}

/* ══ AI BRAIN DUMP CHIPS ═══════════════════════ */
.ai-bd-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.ai-bd-chip{
  padding:5px 12px;border-radius:99px;font-size:11px;font-weight:500;
  cursor:pointer;border:1.5px solid var(--border);background:var(--surface2);
  color:var(--text2);transition:all .15s;font-family:'DM Sans',sans-serif;
  display:inline-flex;align-items:center;gap:3px;
}
.ai-bd-chip.selected{color:#fff;font-weight:600}
.ai-bd-chip:hover{opacity:.85}

/* ══ AI PREFERENCE CHIPS ═══════════════════════ */
.ai-pref-row{display:flex;flex-wrap:wrap;gap:6px;margin:4px 0 8px}
.ai-pref-chip{
  padding:4px 10px;border-radius:99px;font-size:10px;font-weight:500;
  cursor:pointer;border:1.5px solid var(--border);background:var(--surface);
  color:var(--text3);transition:all .15s;font-family:'DM Sans',sans-serif;
}
.ai-pref-chip.on{background:var(--accent-pale);border-color:var(--accent);color:var(--accent);font-weight:600}

/* ══ DAY JOURNAL SECTION ═══════════════════════ */
.day-journal-section{
  margin:8px 12px 12px;border-radius:12px;
  background:var(--surface);border:1px solid var(--border);
  overflow:hidden;
}
.day-journal-hdr{
  display:flex;align-items:center;gap:8px;padding:12px 16px;
  cursor:pointer;user-select:none;transition:background .15s;
}
.day-journal-hdr:hover{background:var(--surface2)}
.day-journal-hdr-icon{color:var(--text2);flex-shrink:0;display:flex;align-items:center}
.day-journal-hdr-title{flex:1;font-size:13px;font-weight:600;color:var(--text)}
.day-journal-hdr-arrow{font-size:11px;color:var(--text3);transition:transform .15s}
.day-journal-body{padding:0 16px 16px}
.day-journal-body .mood-row{margin-bottom:12px}
.day-journal-body .journal-prompt{margin-bottom:8px}
.day-journal-body .journal-ta{
  width:100%;min-height:80px;border:1px solid var(--border);border-radius:8px;
  padding:10px 12px;font-family:'DM Sans',sans-serif;font-size:12px;
  color:var(--text);background:var(--surface2);resize:vertical;line-height:1.6;
}
.day-journal-body .journal-save-row{display:flex;justify-content:flex-end;align-items:center;gap:8px;margin-top:8px}

/* ══ MONTH STATS BAR ══════════════════════════ */
.month-stats-bar{display:flex;gap:8px;margin-bottom:12px}
.month-stat-card{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:8px 10px;text-align:center;cursor:pointer;transition:all .15s}
.month-stat-card:hover{border-color:var(--accent);background:var(--surface2)}
[data-dark="true"] .month-stat-card:hover{background:rgba(var(--accent-rgb),.12)}
.month-stat-num{font-size:18px;font-weight:700;color:var(--text);display:block;line-height:1.2}
.month-stat-sub{font-size:9px;color:var(--text3);display:block;margin-top:1px}
.month-stat-label{font-size:9px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.3px;display:block;margin-top:2px}
/* Hover glow */
.glow-tasks .m-cell:not(.has-task){opacity:.2;transition:opacity .2s}
.glow-tasks .m-cell.has-task{background:var(--accent-pale);transition:background .2s}
.glow-events .m-cell:not(.has-event){opacity:.2;transition:opacity .2s}
.glow-events .m-cell.has-event{background:var(--accent-pale);transition:background .2s}

/* ══ MONTHLY PLANNING ═════════════════════════ */
.month-plan-section{
  margin:16px 0 40px;border-radius:12px;
  background:var(--surface);border:1px solid var(--border);
  overflow:hidden;
}
.month-plan-hdr{
  display:flex;align-items:center;gap:8px;padding:12px 16px;
  cursor:pointer;user-select:none;transition:background .15s;
  border-bottom:1px solid var(--border);
}
.month-plan-hdr:hover{background:var(--surface2)}
.month-plan-icon{color:var(--text2);flex-shrink:0;display:flex;align-items:center}
.month-plan-title{font-size:13px;font-weight:600;color:var(--text);flex:1}
.month-plan-toggle{font-size:11px;color:var(--text3);cursor:pointer}
.month-plan-toggle:hover{color:var(--accent)}
.month-plan-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;padding:14px 16px 16px}
@media(max-width:768px){.month-plan-grid{grid-template-columns:1fr;gap:12px}}
.mp-col{display:flex;flex-direction:column;gap:6px;padding:4px 16px 0 0;border-right:1px solid var(--border)}
.mp-col:last-child{padding-right:0;border-right:none}
@media(max-width:768px){.mp-col{padding:4px 0 12px 0;border-right:none;border-bottom:1px solid var(--border)}.mp-col:last-child{padding-bottom:0;border-bottom:none}}
.mp-col-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text2);margin-bottom:4px}
/* Goals */
.mp-goal{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:8px;transition:background .1s;position:relative}
.mp-goal:hover{background:var(--surface2)}
.mp-goal-grip{cursor:grab;color:var(--text3);font-size:12px;opacity:.4;user-select:none}
.mp-goal-grip:hover{opacity:1}
.mp-goal-check{width:16px;height:16px;border-radius:4px;border:2px solid var(--border2);cursor:pointer;flex-shrink:0;transition:all .15s;display:flex;align-items:center;justify-content:center}
.mp-goal-check.checked{background:var(--accent);border-color:var(--accent)}
.mp-goal-check.checked::after{content:'✓';color:#fff;font-size:10px;font-weight:700}
.mp-goal-text{font-size:12px;color:var(--text);flex:1;outline:none;border:none;background:none;font-family:'DM Sans',sans-serif;line-height:1.4}
.mp-goal-text:empty::before{content:attr(data-placeholder);color:var(--text3);font-style:italic;pointer-events:none}
.mp-goal.done .mp-goal-text{text-decoration:line-through;opacity:.5}
.mp-goal-del{opacity:0;font-size:10px;color:var(--text3);cursor:pointer;padding:2px 4px;border-radius:4px;transition:all .1s}
.mp-goal:hover .mp-goal-del{opacity:1}
.mp-goal-del:hover{color:var(--red);background:var(--red-pale)}
.mp-add-goal{font-size:11px;color:var(--accent);cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .1s;display:inline-flex;align-items:center;gap:4px;font-weight:500}
.mp-add-goal:hover{background:var(--accent-pale)}
.mp-add-goal.disabled{opacity:.3;cursor:default;pointer-events:none}
/* Bullet lists (looking forward + reflection) */
.mp-bullet{display:flex;align-items:flex-start;gap:6px;padding:4px 6px;border-radius:6px;transition:background .1s;position:relative;group:bullet}
.mp-bullet:hover{background:var(--surface2)}
.mp-bullet-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:5px}
.mp-bullet-text{font-size:12px;color:var(--text);flex:1;outline:none;border:none;background:none;font-family:'DM Sans',sans-serif;line-height:1.4}
.mp-bullet-actions{display:flex;gap:2px;opacity:0;transition:opacity .1s}
.mp-bullet:hover .mp-bullet-actions{opacity:1}
.mp-bullet-btn{font-size:10px;color:var(--text3);cursor:pointer;padding:2px 4px;border-radius:3px;border:none;background:none;font-family:'DM Sans',sans-serif}
.mp-bullet-btn:hover{color:var(--accent);background:var(--accent-pale)}
.mp-bullet-btn.del:hover{color:var(--red);background:var(--red-pale)}
.mp-input{width:100%;padding:6px 10px;border:1px solid var(--border);border-radius:8px;font-size:11px;font-family:'DM Sans',sans-serif;color:var(--text);background:var(--surface2);outline:none;transition:border-color .15s}
.mp-input:focus{border-color:var(--accent)}
.mp-input::placeholder{color:var(--text3)}
/* Reflection sub-sections */
.mp-reflect-sub{margin-bottom:10px}
.mp-reflect-label{font-size:10px;font-weight:600;color:var(--text2);margin-bottom:4px}
