@font-face{
  font-family:'Fira Code';
  src:url('../fonts/FiraCodeNerdFont-Light.ttf') format('truetype');
  font-weight:300;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Fira Code';
  src:url('../fonts/FiraCodeNerdFont-Medium.ttf') format('truetype');
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Fira Code';
  src:url('../fonts/FiraCodeNerdFont-Bold.ttf') format('truetype');
  font-weight:700;font-style:normal;font-display:swap;
}

:root {
  --bg: #000000;        /* zinc-950 */
  --surface: #000000;
  --surface2: #09090b;  /* zinc-900 */
  --border: #18181b;    /* zinc-800 */
  --border-glow: #00d4ff; /* zinc-700 */
  --accent: #00d4ff;
  --accent2: #8826f9;
  --warn: #ff3b6b;
  --ok: #00ff88;
  --amber: #ffaa00;
  --text: #fafafa;      /* zinc-50 */
  --muted: #71717a;     /* zinc-500 */
}

*{box-sizing:border-box;margin:0;padding:0}

::-webkit-scrollbar{
  width:6px;
  height:6px;
}
::-webkit-scrollbar-track{
  background:var(--bg);
}
::-webkit-scrollbar-thumb{
  background:var(--accent);
  border-radius:3px;
}
*{
  scrollbar-width:thin;
  scrollbar-color:var(--accent) var(--bg);
}

body{
  background:var(--bg);color:var(--text);
  font-family:'Fira Code',monospace;font-size:15px;font-weight:700;
  min-height:100vh;display:flex;flex-direction:column;
  align-items:center;padding:40px 16px 80px;
  background-image:
    radial-gradient(ellipse 60% 40% at 50% 0%,rgba(0,212,255,0.04) 0%,transparent 70%),
    repeating-linear-gradient(0deg,transparent,transparent 39px,rgba(26,35,50,0.4) 39px,rgba(26,35,50,0.4) 40px),
    repeating-linear-gradient(90deg,transparent,transparent 39px,rgba(26,35,50,0.2) 39px,rgba(26,35,50,0.2) 40px);
}
.container{width:100%;max-width:1080px}

/* NAV TABS */
.nav-tabs{display:flex;gap:0;margin-bottom:28px;border:1px solid var(--border)}
.nav-tab{
  flex:1;background:transparent;border:none;border-right:1px solid var(--border);
  color:var(--muted);font-family:'Fira Code',monospace;font-size:13px;
  letter-spacing:2px;padding:12px 8px;cursor:pointer;text-transform:uppercase;
  transition:all 0.15s;
}
.nav-tab:last-child{border-right:none}
.nav-tab:hover{color:var(--text);background:rgba(255,255,255,0.02)}
.nav-tab.active{color:var(--accent);background:rgba(0,212,255,0.06);border-bottom:1px solid var(--accent)}
.view{display:none}.view.active{display:block}

/* HEADER */
header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:28px;padding-bottom:18px;
  border-bottom:1px solid var(--border);position:relative;
}
header::after{
  content:'';position:absolute;bottom:-1px;left:0;
  width:80px;height:1px;background:var(--accent);box-shadow:0 0 8px var(--accent);
}
.logo-title{
  font-family:'Fira Code',monospace;font-size:26px;
  letter-spacing:6px;color:var(--accent);text-shadow:0 0 12px rgba(0,212,255,0.4);
}
.logo-sub{font-size:13px;letter-spacing:3px;color:var(--muted);text-transform:uppercase;margin-top:3px}
.status-badge{
  display:flex;align-items:center;gap:6px;
  font-family:'Fira Code',monospace;font-size:12px;letter-spacing:2px;
  color:var(--muted);border:1px solid var(--border);padding:7px 11px;background:var(--surface);
}
.dot{width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 6px var(--ok);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.3}}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}

/* NOTICE */
.notice{
  font-family:'Fira Code',monospace;font-size:13px;color:var(--muted);
  letter-spacing:1px;padding:12px 16px;border-left:2px solid var(--accent2);
  background:rgba(136,38,249,0.06);margin-bottom:20px;line-height:1.6;
}
.notice span{color:var(--accent)}

/* Initial focus state — task form stands out, rest fades in on first interaction */
#view-tasks .notice,
#view-tasks .task-panel,
#view-tasks footer { transition: opacity 0.6s ease; }

#view-tasks.initial .task-form {
  border-color: rgba(0,212,255,0.45);
  box-shadow: 0 0 0 1px rgba(0,212,255,0.12), 0 0 24px rgba(0,212,255,0.07) inset;
  transition: border-color 0.6s ease, box-shadow 0.6s ease;
}
#view-tasks.initial .notice    { opacity: 0.35; }
#view-tasks.initial .task-panel,
#view-tasks.initial footer { opacity: 0.4; }

/* LABEL BAR */
.label-bar{display:flex;flex-wrap:wrap;gap:6px;align-items:center;padding:10px 16px;border-bottom:1px solid var(--border)}
.label-chip{
  display:inline-flex;align-items:center;gap:5px;
  font-family:'Fira Code',monospace;font-size:12px;
  letter-spacing:1px;padding:5px 10px;border:1px solid;
  cursor:pointer;transition:all 0.15s;user-select:none;
}
.label-chip.active{background:rgba(255,255,255,0.06)}
.label-chip .lx{opacity:0.5;transition:opacity 0.15s}
.label-chip .lx:hover{opacity:1}
.label-add-wrap{display:flex;gap:6px;align-items:center}
.label-add-input{
  background:var(--surface);border:1px solid var(--border);color:var(--text);
  font-family:'Fira Code',monospace;font-size:13px;padding:6px 11px;
  outline:none;width:130px;letter-spacing:1px;transition:border-color 0.2s;
}
.label-add-input:focus{border-color:var(--accent)}
.label-add-input::placeholder{color:var(--muted)}
.color-palette{display:flex;gap:5px;align-items:center;flex-wrap:wrap}
.swatch{
  width:20px;height:20px;border:1px solid var(--border);
  background:var(--c);cursor:pointer;padding:0;
  transition:transform 0.1s ease,box-shadow 0.15s ease,border-color 0.15s ease;
}
.swatch:hover{transform:scale(1.15);border-color:var(--text)}
.swatch.sel{border-color:var(--text);box-shadow:0 0 0 1px var(--c),0 0 8px var(--c)}
.swatch:focus-visible{outline:none;border-color:var(--text);box-shadow:0 0 0 2px var(--c)}
.label-add-btn{
  background:transparent;border:1px solid var(--border);color:var(--muted);
  font-family:'Fira Code',monospace;font-size:13px;letter-spacing:1px;
  padding:6px 12px;cursor:pointer;transition:all 0.15s;
}
.label-add-btn:hover{border-color:var(--accent);color:var(--accent)}

/* TASK FORM */
.task-form{
  background:var(--surface);border:1px solid var(--border);
  padding:14px;margin-bottom:16px;display:flex;flex-direction:column;gap:10px;
  transition:border-color 0.6s ease, box-shadow 0.6s ease;
}
.form-row{display:flex;gap:8px}
.task-input-wrap{
  flex:1;position:relative;display:flex;
  background:var(--surface2);border:1px solid var(--border);
  transition:border-color 0.2s,box-shadow 0.2s;
}
.task-input-wrap:focus-within{
  border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 0 16px rgba(0,212,255,0.08) inset;
}
.task-input{
  flex:1;width:100%;background:transparent;border:none;
  color:transparent;-webkit-text-fill-color:transparent;caret-color:var(--text);
  font-family:'Fira Code',monospace;font-size:16px;padding:12px 15px;outline:none;
  letter-spacing:0.5px;
  position:relative;z-index:2;
}
.task-input::placeholder{color:var(--muted);-webkit-text-fill-color:var(--muted)}
.task-input::selection{background:rgba(0,212,255,0.25);color:transparent;-webkit-text-fill-color:transparent}
.task-input-hl{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  font-family:'Fira Code',monospace;font-size:16px;padding:12px 15px;letter-spacing:0.5px;
  color:var(--text);white-space:pre;overflow:hidden;
  line-height:normal;
}
.qa-tok-label{color:var(--accent)}
.qa-tok-prio {color:var(--warn)}
.qa-tok-date {color:var(--ok)}
.qa-tok-time {color:var(--accent2)}
.qa-tok-recur{color:var(--amber)}
.qa-tok-desc {color:var(--muted);font-style:italic}
.add-btn{
  background:transparent;border:1px solid var(--accent);color:var(--accent);
  font-family:'Fira Code',monospace;font-size:14px;letter-spacing:2px;
  padding:12px 20px;cursor:pointer;transition:all 0.2s;text-transform:uppercase;white-space:nowrap;
}
.add-btn:hover{background:var(--accent);color:var(--bg);box-shadow:0 0 20px rgba(0,212,255,0.3)}
.add-btn:active{transform:scale(0.98)}
.form-row2{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.recur-interval-wrap{display:flex;align-items:center;gap:4px;transition:opacity 0.15s}
.recur-interval-wrap.disabled{opacity:0.3;pointer-events:none}
.recur-ends-wrap{display:flex;align-items:center;gap:4px;transition:opacity 0.15s}
.recur-ends-wrap.hidden{display:none}
.recur-ends-row{display:flex;align-items:center;gap:8px;margin-top:4px}
.recur-ends-row.hidden{display:none}
.recur-interval{
  width:46px;background:var(--surface2);border:1px solid var(--border);color:var(--text);
  font-family:'Fira Code',monospace;font-size:11px;letter-spacing:0.5px;
  padding:7px 6px;outline:none;text-align:center;
  -moz-appearance:textfield;appearance:textfield;
  transition:border-color 0.2s;
}
.recur-interval::-webkit-outer-spin-button,
.recur-interval::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.recur-interval:focus{border-color:var(--accent)}
.modal-recur-row{display:flex;gap:8px;align-items:center}
.modal-recur-row .sel-trigger{flex:1}
.form-hint{
  display:flex;flex-wrap:wrap;align-items:center;gap:6px;
  font-family:'Fira Code',monospace;font-size:10px;letter-spacing:1px;color:var(--muted);
  padding:4px 0 0;
}
.form-hint span{color:var(--accent);letter-spacing:2px}
.form-hint code{
  background:var(--surface2);border:1px solid var(--border);
  padding:2px 6px;font-size:10px;color:var(--text);
  font-family:inherit;
}
.meta-label{
  font-family:'Fira Code',monospace;font-size:11px;letter-spacing:2px;
  color:var(--muted);white-space:nowrap;display:flex;align-items:center;
}
.form-label-select{display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.form-label-chip{
  font-family:'Fira Code',monospace;font-size:11px;letter-spacing:1px;
  padding:4px 9px;border:1px solid;cursor:pointer;transition:all 0.15s;opacity:0.4;
}
.form-label-chip.sel{opacity:1}

/* ════════════════════════════════════════════════════════════════════
   FORM CONTROLS — custom select; date/time use a JS popover (see below)
   ════════════════════════════════════════════════════════════════════
   Native date/time pickers are inconsistent across browsers and OSes —
   their popups are not stylable. We replace them with custom <button>
   triggers (.dt-trigger) and a JS-rendered popover (.dt-picker) so the
   look is identical everywhere.
*/

/* Shared field surface for select + the .dt-trigger buttons */
.styled-select,
.meta-input,
select.modal-input{
  background:var(--surface2);border:1px solid var(--border);color:var(--text);
  font-family:'Fira Code',monospace;letter-spacing:0.5px;
  outline:none;color-scheme:dark;
  transition:border-color 0.2s,box-shadow 0.2s;
}
.styled-select:focus,
.meta-input:focus,
select.modal-input:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 1px var(--accent),0 0 12px rgba(0,212,255,0.08) inset;
}

/* Compact form sizing */
.styled-select{font-size:13px;padding:12px 32px 12px 12px;cursor:pointer}
.meta-input{font-size:13px;padding:8px 32px 8px 11px}

/* Custom dropdown arrow — same SVG for all .sel-trigger (form + modal) */
.styled-select,
.meta-input.sel-trigger,
.sel-trigger.modal-input{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'><path d='M2 4 L5 7 L8 4' stroke='%234a6080' stroke-width='1.3' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;
  background-position:right 12px center;
  padding-right:32px;
}
.styled-select:hover,
.meta-input.sel-trigger:hover,
.sel-trigger.modal-input:hover{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'><path d='M2 4 L5 7 L8 4' stroke='%23c8d8e8' stroke-width='1.3' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  border-color:var(--accent);
}
.styled-select:focus,
.sel-trigger.open,
.meta-input.sel-trigger:focus,
.sel-trigger.modal-input:focus{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'><path d='M2 4 L5 7 L8 4' stroke='%2300d4ff' stroke-width='1.3' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  color:var(--text);
}

/* .sel-trigger button — text-align so label sits left like a select would */
.sel-trigger{cursor:pointer;text-align:left}
.sel-trigger.open{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 0 12px rgba(0,212,255,0.08) inset}

/* Description input (add form) */
.task-desc-input{
  width:100%;background:transparent;border:none;border-bottom:1px solid var(--border);
  color:var(--muted);font-family:'Fira Code',monospace;font-size:11px;
  padding:4px 2px;outline:none;letter-spacing:0.5px;
}
.task-desc-input::placeholder{color:var(--muted)}
.task-desc-input:focus{border-bottom-color:var(--accent)}

/* Description text in task card */
.task-desc{font-size:11px;color:var(--muted);font-family:'Fira Code',monospace;margin-top:2px;letter-spacing:0.3px;white-space:pre-wrap;word-break:break-word}

/* Labels dropdown trigger */
.lab-trigger{font-size:10px;letter-spacing:1.5px;padding:8px 10px;cursor:pointer;white-space:nowrap}
.lab-trigger.has-val{border-color:var(--accent);color:var(--accent)}

/* Labels dropdown popover */
.lab-picker{
  position:absolute;z-index:200;
  background:var(--surface);border:1px solid var(--border-glow);
  box-shadow:0 0 30px rgba(0,212,255,0.12),0 8px 24px rgba(0,0,0,0.5);
  font-family:'Fira Code',monospace;
  display:none;min-width:140px;animation:dtIn 0.12s ease;
}
.lab-picker.open{display:block}
.lab-opt{
  padding:8px 12px;cursor:pointer;display:flex;align-items:center;gap:8px;
  font-size:11px;letter-spacing:1px;color:var(--muted);transition:background 0.1s;
}
.lab-opt:hover{background:rgba(136,38,249,0.08)}
.lab-opt.sel{color:var(--text)}
.lab-dot{width:8px;height:8px;border-radius:50%;border:1.5px solid var(--lc);flex-shrink:0;transition:background 0.1s}
.lab-opt.sel .lab-dot{background:var(--lc)}
.lab-empty{padding:10px 12px;font-size:10px;letter-spacing:1px;color:var(--muted)}

/* Label autocomplete */
.qa-ac{
  position:absolute;z-index:300;
  background:var(--surface);border:1px solid var(--border-glow);
  box-shadow:0 8px 24px rgba(0,0,0,0.5);
  font-family:'Fira Code',monospace;
  display:none;min-width:160px;max-height:200px;overflow-y:auto;
  animation:dtIn 0.1s ease;
  scrollbar-width:thin;scrollbar-color:var(--accent) var(--bg);
}
.qa-ac.open{display:block}
.qa-ac-item{
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;cursor:pointer;font-size:12px;
  color:var(--muted);letter-spacing:0.5px;transition:background 0.1s;
}
.qa-ac-item:hover,.qa-ac-item.active{background:rgba(0,212,255,0.06);color:var(--accent)}
.qa-ac-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* .dt-trigger button styling — looks like the field it replaces */
.dt-trigger{
  cursor:pointer;text-align:left;
  background-repeat:no-repeat;background-position:right 10px center;
}
.meta-input.dt-trigger[data-kind="date"]{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14' fill='none' stroke='%234a6080' stroke-width='1.2'><rect x='2' y='3' width='10' height='9' rx='1'/><path d='M2 6 H12 M5 1.5 V4 M9 1.5 V4'/></svg>");
}
.meta-input.dt-trigger[data-kind="time"]{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14' fill='none' stroke='%234a6080' stroke-width='1.2'><circle cx='7' cy='7' r='5.5'/><path d='M7 4 V7 L9.5 8.5'/></svg>");
}
.modal-input.dt-trigger{
  background-repeat:no-repeat;
  background-position:right 12px center;
  padding-right:36px;
}
.modal-input.dt-trigger[data-kind="date"]{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14' fill='none' stroke='%234a6080' stroke-width='1.2'><rect x='2' y='3' width='10' height='9' rx='1'/><path d='M2 6 H12 M5 1.5 V4 M9 1.5 V4'/></svg>");
}
.modal-input.dt-trigger[data-kind="time"]{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14' fill='none' stroke='%234a6080' stroke-width='1.2'><circle cx='7' cy='7' r='5.5'/><path d='M7 4 V7 L9.5 8.5'/></svg>");
}
.dt-trigger:not(.has-val){color:var(--muted);font-size:11px;letter-spacing:2px}
.dt-trigger.open{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 0 12px rgba(0,212,255,0.08) inset}

/* FILTERS */
/* Collapsible task panel — same visual rhythm as the backup panel */
.task-panel{margin-bottom:16px;border:1px solid var(--border);background:var(--surface);overflow:hidden}
.task-panel-header{
  padding:14px 16px;cursor:pointer;display:flex;align-items:center;
  justify-content:space-between;transition:background 0.15s;
}
.task-panel-header:hover{background:rgba(255,255,255,0.02)}
.task-panel-header-left{
  display:flex;align-items:center;gap:10px;
  font-family:'Fira Code',monospace;font-size:13px;letter-spacing:2px;
  color:var(--text);text-transform:uppercase;
}
.task-panel-header-left > span:first-child{color:var(--accent)}
.task-panel-count{color:var(--muted);letter-spacing:1px;text-transform:none}
.task-panel-toggle{font-family:'Fira Code',monospace;font-size:12px;color:var(--muted);transition:transform 0.2s}
.task-panel-toggle.open{transform:rotate(180deg)}
.task-panel-body{display:none;padding:16px;flex-direction:column;gap:0}
.task-panel-body.open{display:flex}

.filters{display:flex;gap:0;margin-bottom:16px;border:1px solid var(--border);overflow-x:auto}
.filter-btn{
  flex:1;min-width:fit-content;background:transparent;border:none;
  border-right:1px solid var(--border);color:var(--muted);
  font-family:'Fira Code',monospace;font-size:12px;letter-spacing:1px;
  padding:10px 12px;cursor:pointer;text-transform:uppercase;transition:all 0.15s;white-space:nowrap;
}
.filter-btn:last-child{border-right:none}
.filter-btn:hover{color:var(--text);background:rgba(255,255,255,0.03)}
.filter-btn.active{color:var(--accent);background:rgba(0,212,255,0.06)}

/* TASK LIST */
.task-list{display:flex;flex-direction:column;gap:6px}
.task-item{
  background:var(--surface);border:1px solid var(--border);
  transition:border-color 0.2s,opacity 0.4s;animation:slideIn 0.2s ease;
  position:relative;overflow:hidden;
  contain:content;
}
@keyframes slideIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.task-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px}
.task-item[data-priority="HIGH"]::before{background:var(--warn);box-shadow:0 0 6px var(--warn)}
.task-item[data-priority="MED"]::before{background:var(--amber);box-shadow:0 0 4px var(--amber)}
.task-item[data-priority="LOW"]::before{background:var(--muted)}
.task-item:hover{border-color:var(--border-glow)}
.task-item.kb-sel{border-color:rgba(0,212,255,0.5);background:rgba(0,212,255,0.04)}
.task-item[draggable]{cursor:grab}
.task-item.dragging{opacity:0.3;cursor:grabbing}
.task-item.drag-over{box-shadow:inset 0 2px 0 var(--accent)}
.task-item.done{opacity:0.38}
.task-item.done .task-text{text-decoration:line-through;color:var(--muted)}
.task-item.overdue:not(.done){border-color:rgba(255,59,107,0.4)}

/* completing animation */
.task-item.completing{
  border-color:var(--ok) !important;
  box-shadow:0 0 12px rgba(0,255,136,0.15);
  transition:all 0.3s;
}
.task-item.completing::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(0,255,136,0.08),transparent);
  animation:sweep 0.6s ease;
}
@keyframes sweep{from{transform:translateX(-100%)}to{transform:translateX(100%)}}

.task-main{display:flex;align-items:flex-start;gap:12px;padding:14px 15px 11px}
.check-btn{
  width:20px;height:20px;border:1px solid var(--muted);background:transparent;
  cursor:pointer;flex-shrink:0;margin-top:2px;
  display:flex;align-items:center;justify-content:center;
  transition:all 0.15s;color:transparent;font-size:13px;
}
.task-item.done .check-btn{border-color:var(--accent);background:rgba(0,212,255,0.15);color:var(--accent)}
.check-btn:hover{border-color:var(--accent)}
.task-body{flex:1;min-width:0;cursor:pointer}
.task-text{font-size:17px;font-weight:500;letter-spacing:0.3px;word-break:break-word}
.task-sub{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:7px}

.priority-tag{font-family:'Fira Code',monospace;font-size:11px;letter-spacing:1px;padding:3px 7px;border:1px solid}
.priority-tag.HIGH{color:var(--warn);border-color:var(--warn)}
.priority-tag.MED{color:var(--amber);border-color:var(--amber)}
.priority-tag.LOW{color:var(--muted);border-color:var(--muted)}

.task-label-chip{font-family:'Fira Code',monospace;font-size:11px;letter-spacing:1px;padding:3px 8px;border:1px solid}
.task-date{font-family:'Fira Code',monospace;font-size:12px;color:var(--muted);letter-spacing:1px;display:flex;align-items:center;gap:4px}
.task-date.overdue{color:var(--warn)}
.task-date.today{color:var(--ok)}
.task-date.soon{color:var(--amber)}

.recur-badge{
  font-family:'Fira Code',monospace;font-size:11px;letter-spacing:1px;
  color:var(--accent2);border:1px solid var(--accent2);padding:3px 7px;opacity:0.85;
}
.streak-badge{
  font-family:'Fira Code',monospace;font-size:11px;letter-spacing:1px;
  color:var(--amber);border:1px solid var(--amber);padding:3px 7px;opacity:0.85;
}

.task-actions{display:flex;gap:2px;flex-shrink:0;margin-top:1px}
.act-btn{
  background:transparent;border:none;color:var(--muted);cursor:pointer;
  font-size:16px;padding:4px 7px;transition:color 0.15s;line-height:1;
  font-family:'Fira Code',monospace;
}
.act-btn:hover{color:var(--text)}
.act-btn.del:hover{color:var(--warn)}

/* HISTORY DRAWER */
.task-history{
  display:none;border-top:1px solid var(--border);
  padding:11px 14px 11px 48px;background:rgba(0,0,0,0.2);
}
.task-history.open{display:block}
.history-title{
  font-family:'Fira Code',monospace;font-size:11px;
  letter-spacing:2px;color:var(--muted);margin-bottom:9px;
}
.history-entry{
  display:flex;align-items:center;gap:10px;
  font-family:'Fira Code',monospace;font-size:12px;
  color:var(--muted);padding:4px 0;border-bottom:1px solid rgba(26,35,50,0.5);
  letter-spacing:0.5px;
}
.history-entry:last-child{border-bottom:none}
.history-entry .hdate{color:var(--ok);opacity:0.8}
.history-entry .htype{
  font-size:11px;padding:2px 6px;border:1px solid;letter-spacing:1px;
}
.htype.completed{color:var(--ok);border-color:var(--ok)}
.htype.recurred{color:var(--accent2);border-color:var(--accent2)}

/* EMPTY */
.empty{
  text-align:center;padding:48px 20px;
  font-family:'Fira Code',monospace;font-size:14px;
  letter-spacing:2px;color:var(--muted);border:1px dashed var(--border);
}
.empty .icon{font-size:32px;margin-bottom:14px;opacity:0.4}

/* FOOTER */
footer{
  margin-top:20px;display:flex;justify-content:space-between;align-items:center;
  padding-top:14px;border-top:1px solid var(--border);
}
.footer-stat{font-family:'Fira Code',monospace;font-size:12px;letter-spacing:2px;color:var(--muted)}
.snooze-menu{
  position:absolute;z-index:200;display:flex;gap:4px;
  background:var(--surface);border:1px solid var(--accent);
  padding:5px;box-shadow:0 6px 20px rgba(0,0,0,0.5);
  animation:dtIn 0.1s ease;
}
.snooze-opt{
  background:var(--surface2);border:1px solid var(--border);color:var(--text);
  font-family:'Fira Code',monospace;font-size:11px;letter-spacing:1px;
  padding:5px 9px;cursor:pointer;transition:all 0.15s;
}
.snooze-opt:hover{border-color:var(--accent);color:var(--accent)}
.notify-toggle{
  background:transparent;border:1px solid var(--border);color:var(--muted);
  font-family:'Fira Code',monospace;font-size:10px;letter-spacing:1.5px;
  padding:4px 9px;cursor:pointer;transition:all 0.15s;text-transform:uppercase;
}
.notify-toggle:hover{border-color:var(--accent);color:var(--accent)}
.notify-toggle.on{border-color:var(--accent);color:var(--accent)}
.notify-toggle.blocked{border-color:var(--warn);color:var(--warn);cursor:help}
.footer-links{display:flex;gap:14px}
.footer-links a{font-family:'Fira Code',monospace;font-size:10px;letter-spacing:1.5px;color:var(--muted);text-decoration:none;text-transform:uppercase;opacity:0.6;transition:opacity 0.15s}
.footer-links a:hover{opacity:1;color:var(--accent)}
.clear-btn{
  background:transparent;border:1px solid var(--border);color:var(--muted);
  font-family:'Fira Code',monospace;font-size:12px;letter-spacing:2px;
  padding:6px 12px;cursor:pointer;transition:all 0.15s;text-transform:uppercase;
}
.clear-btn:hover{border-color:var(--warn);color:var(--warn)}

/* ── METRICS VIEW ── */
.metrics-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}
.metric-card{
  background:var(--surface);border:1px solid var(--border);
  padding:18px;display:flex;flex-direction:column;gap:5px;position:relative;overflow:hidden;
}
.metric-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,var(--accent),transparent);opacity:0.4;
}
.metric-val{
  font-family:'Fira Code',monospace;font-size:32px;
  color:var(--accent);letter-spacing:2px;line-height:1;
}
.metric-val.warn{color:var(--warn)}
.metric-val.ok{color:var(--ok)}
.metric-val.amber{color:var(--amber)}
.metric-val.purple{color:var(--accent2)}
.metric-label{font-family:'Fira Code',monospace;font-size:12px;letter-spacing:2px;color:var(--muted)}
.metric-sub{font-family:'Fira Code',monospace;font-size:11px;letter-spacing:1px;color:var(--muted);opacity:0.7;margin-top:2px}

.metrics-section-title{
  font-family:'Fira Code',monospace;font-size:13px;letter-spacing:3px;
  color:var(--muted);text-transform:uppercase;margin:22px 0 11px;
  padding-bottom:9px;border-bottom:1px solid var(--border);
}

/* HEATMAP — GitHub-style contribution grid (fluid, fits container width) */
.heatmap-wrap{
  background:var(--surface);border:1px solid var(--border);
  padding:18px;margin-bottom:12px;
}
.heatmap-title{font-family:'Fira Code',monospace;font-size:12px;letter-spacing:2px;color:var(--muted);margin-bottom:13px}
.heatmap{
  display:flex;flex-direction:column;gap:5px;
  font-family:'Fira Code',monospace;
  --hm-gap:3px; --hm-weeks:52;
  width:100%;
}
.hm-months{
  display:grid;grid-template-columns:repeat(var(--hm-weeks),1fr);gap:var(--hm-gap);
  margin-left:30px;font-size:10px;color:var(--muted);letter-spacing:1px;
  height:14px;
}
.hm-months span{white-space:nowrap;height:14px;display:flex;align-items:center;overflow:hidden}
.hm-body{display:flex;gap:6px;align-items:stretch}
.hm-weekdays{
  display:flex;flex-direction:column;gap:var(--hm-gap);
  font-size:9px;color:var(--muted);width:24px;letter-spacing:0.5px;flex-shrink:0;
}
.hm-weekdays span{flex:1;display:flex;align-items:center;min-height:0}
.hm-grid{
  display:grid;
  grid-template-columns:repeat(var(--hm-weeks),1fr);
  grid-template-rows:repeat(7,1fr);
  grid-auto-flow:column;gap:var(--hm-gap);
  flex:1;min-width:0;
}
.hm-cell{
  aspect-ratio:1;width:100%;
  background:var(--surface2);border:1px solid var(--border);
  transition:transform 0.1s,outline 0.1s;cursor:default;
}
.hm-cell:hover{transform:scale(1.4);outline:1px solid var(--accent);z-index:1;position:relative}
.hm-cell.l1{background:rgba(0,212,255,0.18);border-color:rgba(0,212,255,0.25)}
.hm-cell.l2{background:rgba(0,212,255,0.4); border-color:rgba(0,212,255,0.5)}
.hm-cell.l3{background:rgba(0,212,255,0.65);border-color:rgba(0,212,255,0.75)}
.hm-cell.l4{background:rgba(0,212,255,0.95);border-color:var(--accent)}
.hm-empty{visibility:hidden}
.hm-legend{
  display:flex;align-items:center;gap:4px;justify-content:flex-end;
  font-size:9px;color:var(--muted);letter-spacing:1px;margin-top:6px;
}
.hm-legend .hm-cell{width:11px;height:11px;aspect-ratio:auto;transform:none;cursor:default;pointer-events:none}

/* BAR CHART */
.bar-chart{background:var(--surface);border:1px solid var(--border);padding:18px;margin-bottom:12px}
.bar-chart-title{font-family:'Fira Code',monospace;font-size:12px;letter-spacing:2px;color:var(--muted);margin-bottom:15px}
.bar-rows{display:flex;flex-direction:column;gap:9px}
.bar-row{display:flex;align-items:center;gap:10px}
.bar-label{font-family:'Fira Code',monospace;font-size:12px;color:var(--muted);width:90px;flex-shrink:0;letter-spacing:0.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{flex:1;height:16px;background:var(--surface2);border:1px solid var(--border);overflow:hidden}
.bar-fill{height:100%;transition:width 0.4s ease;background:var(--accent)}
.bar-fill.warn{background:var(--warn)}
.bar-fill.amber{background:var(--amber)}
.bar-fill.purple{background:var(--accent2)}
.bar-fill.ok{background:var(--ok)}
.bar-val{font-family:'Fira Code',monospace;font-size:12px;color:var(--muted);width:38px;text-align:right;flex-shrink:0}

/* STREAK DISPLAY */
.streak-display{
  background:var(--surface);border:1px solid var(--border);
  padding:18px;margin-bottom:12px;display:flex;align-items:center;gap:22px;
}
.streak-number{font-family:'Fira Code',monospace;font-size:56px;color:var(--amber);line-height:1;letter-spacing:2px}
.streak-info{display:flex;flex-direction:column;gap:5px}
.streak-label{font-family:'Fira Code',monospace;font-size:13px;letter-spacing:2px;color:var(--muted)}
.streak-sub{font-family:'Fira Code',monospace;font-size:12px;letter-spacing:1px;color:var(--muted);opacity:0.6}

/* ── TODAY VIEW ── */
.today-hero{
  background:var(--surface);border:1px solid var(--border);
  padding:20px;margin-bottom:16px;position:relative;overflow:hidden;
}
.today-hero::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,var(--accent),transparent);opacity:0.4;
}
.today-date{font-family:'Fira Code',monospace;font-size:13px;letter-spacing:3px;color:var(--muted);margin-bottom:12px}
.today-progress-row{display:flex;align-items:center;gap:14px;margin-bottom:12px}
.today-progress-pct{
  font-family:'Fira Code',monospace;font-size:38px;line-height:1;
  color:var(--accent);letter-spacing:2px;flex-shrink:0;min-width:96px;
}
.today-progress-pct.warn{color:var(--warn)}
.today-progress-pct.amber{color:var(--amber)}
.today-progress-pct.ok{color:var(--ok)}
.today-progress-bar{
  flex:1;height:10px;background:var(--surface2);border:1px solid var(--border);overflow:hidden;
}
.today-progress-fill{
  height:100%;background:var(--accent);transition:width 0.5s ease;
  box-shadow:0 0 12px rgba(0,212,255,0.35);
}
.today-progress-fill.warn{background:var(--warn);box-shadow:0 0 12px rgba(255,59,107,0.35)}
.today-progress-fill.amber{background:var(--amber);box-shadow:0 0 12px rgba(255,170,0,0.35)}
.today-progress-fill.ok{background:var(--ok);box-shadow:0 0 12px rgba(0,255,136,0.35)}
.today-counts{
  display:flex;gap:16px;font-family:'Fira Code',monospace;font-size:13px;
  letter-spacing:1px;color:var(--muted);flex-wrap:wrap;
}
.today-counts span strong{color:var(--text);font-weight:normal}
.today-counts .c-done strong{color:var(--ok)}
.today-counts .c-due strong{color:var(--amber)}
.today-counts .c-over strong{color:var(--warn)}

.today-section-title{
  font-family:'Fira Code',monospace;font-size:13px;letter-spacing:3px;
  color:var(--muted);text-transform:uppercase;margin:24px 0 9px;
  padding-bottom:7px;border-bottom:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;
}
.today-section-title .count{color:var(--accent);opacity:0.8}
.today-section-title.warn .count{color:var(--warn)}

/* BACKUP */
.backup-panel{margin-top:16px;border:1px solid var(--border);background:var(--surface);overflow:hidden}
.backup-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;border-bottom:1px solid var(--border);
  cursor:pointer;user-select:none;transition:background 0.15s;
}
.backup-header:hover{background:rgba(255,255,255,0.02)}
.backup-header-left{
  display:flex;align-items:center;gap:10px;
  font-family:'Fira Code',monospace;font-size:13px;
  letter-spacing:2px;color:var(--muted);text-transform:uppercase;
}
.backup-toggle{font-family:'Fira Code',monospace;font-size:12px;color:var(--muted);transition:transform 0.2s}
.backup-toggle.open{transform:rotate(180deg)}
.backup-body{display:none;padding:16px;flex-direction:column;gap:12px}
.backup-body.open{display:flex}
.backup-row{display:flex;gap:8px}
.backup-btn{
  flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  background:transparent;border:1px solid var(--border);color:var(--muted);
  font-family:'Fira Code',monospace;font-size:13px;letter-spacing:2px;
  padding:11px 14px;cursor:pointer;transition:all 0.15s;text-transform:uppercase;
}
.backup-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(0,212,255,0.04)}
.backup-btn.danger:hover{border-color:var(--warn);color:var(--warn);background:rgba(255,59,107,0.04)}
.backup-divider{font-family:'Fira Code',monospace;font-size:11px;letter-spacing:2px;color:var(--muted);text-align:center;opacity:0.5}
.import-drop{
  border:1px dashed var(--border);padding:20px;text-align:center;
  font-family:'Fira Code',monospace;font-size:13px;letter-spacing:1px;
  color:var(--muted);cursor:pointer;transition:all 0.15s;position:relative;
}
.import-drop:hover,.import-drop.dragover{border-color:var(--accent);color:var(--accent);background:rgba(0,212,255,0.03)}
.import-drop input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.import-drop .drop-icon{font-size:24px;margin-bottom:7px;opacity:0.5}
.backup-toast{
  position:fixed;bottom:20px;right:20px;z-index:1000;
  font-family:'Fira Code',monospace;font-size:12px;letter-spacing:1px;
  padding:9px 14px;border:1px solid var(--border);border-left:2px solid var(--accent);
  background:var(--surface);color:var(--accent);display:none;
  box-shadow:0 4px 16px rgba(0,0,0,0.4);max-width:min(360px,calc(100vw - 40px));
}
.backup-toast.err{border-color:var(--warn);background:var(--surface);color:var(--warn)}
.backup-toast.show{display:block}

/* REMOTE SYNC */
.sync-panel{display:flex;flex-direction:column;gap:10px}
.sync-help{
  font-family:'Fira Code',monospace;font-size:11px;line-height:1.5;letter-spacing:0.5px;
  color:var(--muted);padding:10px 12px;border-left:2px solid var(--accent);
  background:rgba(136,38,249,0.04);
}
.sync-row{display:flex;align-items:center;gap:10px}
.sync-label{
  flex:0 0 110px;font-family:'Fira Code',monospace;font-size:10px;letter-spacing:2px;
  color:var(--muted);text-transform:uppercase;
}
.sync-input{
  flex:1;background:var(--bg);border:1px solid var(--border);color:var(--text);
  font-family:'Fira Code',monospace;font-size:12px;padding:8px 10px;
  transition:border-color 0.15s;min-width:0;
}
.sync-input:focus{outline:none;border-color:var(--accent)}
.sync-copy-btn{
  flex:0 0 auto;background:var(--surface2);border:1px solid var(--border);
  color:var(--muted);padding:6px 9px;font-family:'Fira Code',monospace;
  font-size:12px;cursor:pointer;transition:all 0.15s;
}
.sync-copy-btn:hover{color:var(--accent);border-color:var(--accent)}
.sync-actions{display:flex;gap:8px;flex-wrap:wrap}
.sync-actions .backup-btn{flex:1 1 auto;min-width:90px}
.sync-versions{
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
  font-family:'Fira Code',monospace;font-size:10px;letter-spacing:1.5px;
  color:var(--muted);padding:4px 0 0 0;text-transform:uppercase;
}
.sync-versions .sv-lbl{opacity:0.6}
.sync-versions .sv-val{color:var(--text);padding:0 4px}
.sync-versions .sv-val.same{color:var(--ok,#39ff14)}
.sync-versions .sv-val.ahead{color:var(--amber,#ffaa00)}
.sync-versions .sv-val.behind{color:var(--warn,#ff3b6b)}
.sync-versions .sv-sep{opacity:0.4}
.sync-versions .sv-tz{margin-left:auto;opacity:0.55}
.sync-status{
  font-family:'Fira Code',monospace;font-size:11px;letter-spacing:1px;
  color:var(--muted);min-height:14px;padding:2px 0;
}
.sync-status.err{color:var(--warn)}
@media (max-width:560px){
  .sync-row{flex-direction:column;align-items:stretch;gap:4px}
  .sync-label{flex:0 0 auto}
}

/* SUPPORT */
/* Floating donate trigger — cyberpunk pink, distinct from the cyan/violet
   palette so it reads at a glance without fighting the task UI. */
.donate-trigger{
  --pink:#ff2a8a;
  position:fixed;left:14px;bottom:14px;z-index:900;
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 12px;border:1px solid color-mix(in srgb,var(--pink) 55%,transparent);
  background:color-mix(in srgb,var(--pink) 8%,var(--surface));
  font-family:'Fira Code',monospace;font-size:11px;letter-spacing:2px;
  color:var(--pink);cursor:pointer;opacity:0.78;
  box-shadow:0 0 12px color-mix(in srgb,var(--pink) 18%,transparent);
  transition:opacity 0.15s,border-color 0.15s,background 0.15s,box-shadow 0.2s,transform 0.15s;
}
.donate-trigger:hover,.donate-trigger:focus-visible{
  opacity:1;border-color:var(--pink);
  background:color-mix(in srgb,var(--pink) 14%,var(--surface));
  box-shadow:0 0 22px color-mix(in srgb,var(--pink) 40%,transparent);
  outline:none;transform:translateY(-1px);
}
.donate-trigger-mark{font-size:13px;line-height:1;text-shadow:0 0 8px currentColor}
.donate-trigger-text{text-transform:uppercase}

.support-options{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.support-card{
  min-width:0;
  display:flex;
  flex-direction:column;
  border:1px solid var(--border);
  background:var(--surface2);
  color:var(--text);
  text-decoration:none;
  transition:border-color 0.15s,background 0.15s,transform 0.15s;
}
.support-card-link:hover{
  border-color:var(--accent);
  background:rgba(0,212,255,0.04);
  transform:translateY(-1px);
}
.support-card-head{
  padding:12px 13px;
  border-bottom:1px solid var(--border);
}
.support-card-kicker{
  display:block;
  margin-bottom:5px;
  font-family:'Fira Code',monospace;
  font-size:10px;
  letter-spacing:2px;
  color:var(--muted);
}
.support-card h3{
  font-family:'Fira Code',monospace;
  font-size:13px;
  line-height:1.35;
  letter-spacing:1px;
  color:var(--accent);
  font-weight:400;
}
.support-card-body{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding:12px 13px;
  flex:1;
}
.support-key{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-family:'Fira Code',monospace;
  font-size:11px;
  letter-spacing:0.5px;
  color:var(--text);
}
.support-copy,.support-cta{
  flex-shrink:0;
  border:1px solid var(--border);
  background:transparent;
  color:var(--muted);
  font-family:'Fira Code',monospace;
  font-size:10px;
  letter-spacing:2px;
  padding:6px 8px;
  transition:all 0.15s;
}
.support-copy{
  cursor:pointer;
}
.support-copy:hover,.support-copy.copied,.support-card-link:hover .support-cta{
  border-color:var(--accent);
  color:var(--accent);
  background:rgba(0,212,255,0.05);
}

/* ════════════════════════════════════════════════════════════════════
   LABELS VIEW
   ════════════════════════════════════════════════════════════════════ */
.labels-panel{border:1px solid var(--border);background:var(--surface);margin-bottom:14px;overflow:hidden}
.labels-panel-header{
  padding:12px 16px;border-bottom:1px solid var(--border);
  font-family:'Fira Code',monospace;font-size:12px;letter-spacing:2px;color:var(--muted);
}
.labels-panel-body{padding:14px 16px;display:flex;flex-direction:column;gap:12px}
.labels-add-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.labels-name-input{
  flex:1;min-width:120px;background:var(--surface2);border:1px solid var(--border);
  color:var(--text);font-family:'Fira Code',monospace;font-size:13px;
  padding:8px 11px;outline:none;transition:border-color 0.2s;
}
.labels-name-input:focus{border-color:var(--accent)}
.labels-name-input::placeholder{color:var(--muted)}
.labels-name-input.invalid{border-color:var(--error,#ff2a6d);animation:shake 0.25s ease}
.labels-name-input.edit-inline{flex:1;min-width:80px;font-size:12px;padding:5px 8px}
.labels-list{padding:8px 0}
.labels-empty{
  padding:20px 16px;font-family:'Fira Code',monospace;font-size:12px;
  letter-spacing:1px;color:var(--muted);text-align:center;
}
.label-row{
  display:flex;align-items:center;gap:10px;
  padding:10px 16px;border-bottom:1px solid var(--border);transition:background 0.1s;
}
.label-row:last-child{border-bottom:none}
.label-row:hover{background:rgba(255,255,255,0.02)}
.label-row-dot{
  width:10px;height:10px;border-radius:50%;flex-shrink:0;transition:box-shadow 0.2s;cursor:pointer;
}
.label-row-name{
  flex:1;font-family:'Fira Code',monospace;font-size:13px;letter-spacing:1px;
}
.label-row-name.editable{cursor:pointer;border-bottom:1px dashed transparent;transition:border-color 0.15s}
.label-row-name.editable:hover{border-bottom-color:currentColor}
.label-row-actions{display:flex;gap:6px;flex-shrink:0}
.label-row-btn{
  background:transparent;border:1px solid var(--border);color:var(--muted);
  font-family:'Fira Code',monospace;font-size:10px;letter-spacing:1.5px;
  padding:4px 10px;cursor:pointer;transition:all 0.15s;
}
.label-row-btn:hover{border-color:var(--accent);color:var(--accent)}
.label-row-btn.del:hover{border-color:var(--error,#ff2a6d);color:var(--error,#ff2a6d)}
.label-row-btn.primary{border-color:var(--accent);color:var(--accent)}
.label-row-btn.primary:hover{background:var(--accent);color:var(--bg)}
.label-inline-pal{display:flex;gap:4px;align-items:center;flex-wrap:wrap}

/* ════════════════════════════════════════════════════════════════════
   MONTHLY CALENDAR VIEW
   ════════════════════════════════════════════════════════════════════ */
.cal-wrap{display:flex;flex-direction:column;gap:14px}

/* Header */
.cal-header{
  display:flex;align-items:center;gap:12px;
}
.cal-month-title{
  flex:1;text-align:center;
  font-family:'Fira Code',monospace;font-size:15px;font-weight:400;
  letter-spacing:4px;text-transform:uppercase;color:var(--accent);
}
.cal-nav-btn{
  background:transparent;border:1px solid var(--border);color:var(--muted);
  font-family:'Fira Code',monospace;font-size:12px;
  padding:7px 14px;cursor:pointer;transition:all 0.15s;
}
.cal-nav-btn:hover{border-color:var(--accent);color:var(--accent)}
.cal-today-btn{
  background:transparent;border:1px solid var(--border);color:var(--muted);
  font-family:'Fira Code',monospace;font-size:10px;letter-spacing:1.5px;
  text-transform:uppercase;padding:7px 12px;cursor:pointer;transition:all 0.15s;
}
.cal-today-btn:hover{border-color:var(--accent);color:var(--accent)}

/* Grid */
.cal-grid{
  display:grid;
  grid-template-columns:repeat(7,minmax(0,1fr));
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  width:100%;
  box-sizing:border-box;
}
.cal-weekday{
  background:var(--surface);
  font-family:'Fira Code',monospace;font-size:10px;letter-spacing:2px;
  color:var(--muted);text-align:center;padding:9px 4px;text-transform:uppercase;
  min-width:0;
}

/* Cells */
.cal-cell{
  background:var(--surface);
  min-height:110px;padding:7px 6px 6px;
  display:flex;flex-direction:column;gap:3px;
  transition:background 0.1s;
  min-width:0;overflow:hidden;
}
.cal-cell:hover{background:var(--surface2)}
.cal-empty{background:var(--bg);pointer-events:none}
.cal-cell.cal-today{background:rgba(0,212,255,0.04)}
.cal-cell.cal-today .cal-day-num{
  color:var(--accent);
  border:1px solid var(--accent);
  box-shadow:0 0 8px rgba(0,212,255,0.2);
}
.cal-day-num{
  font-family:'Fira Code',monospace;font-size:12px;color:var(--muted);
  width:22px;height:22px;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:color 0.15s;
}
.cal-has-tasks .cal-day-num{color:var(--text)}

/* Task pills */
.cal-pills{display:flex;flex-direction:column;gap:2px;overflow:hidden;flex:1}
.cal-task-pill{
  font-family:'Fira Code',monospace;font-size:10px;letter-spacing:0.3px;
  padding:2px 5px;border-left:2px solid;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  cursor:pointer;transition:opacity 0.1s;
  background:rgba(255,255,255,0.025);
}
.cal-task-pill:hover{opacity:0.75}
.cal-task-pill.done{opacity:0.3;text-decoration:line-through}
.cal-task-pill.prio-high{border-color:var(--warn);color:var(--warn);background:rgba(255,59,107,0.06)}
.cal-task-pill.prio-med {border-color:var(--amber);color:var(--text)}
.cal-task-pill.prio-low {border-color:var(--muted);color:var(--muted)}
.cal-overflow{
  font-family:'Fira Code',monospace;font-size:10px;letter-spacing:1px;
  color:var(--muted);padding:1px 5px;
}

/* Week mode: only 7 cells (one row), so make them taller and show more pills. */
.cal-grid.cal-week .cal-cell{min-height:240px}
.cal-grid.cal-week .cal-pills{gap:3px}
.cal-grid.cal-week .cal-task-pill{font-size:11px;padding:3px 6px}

/* Calendar mode dropdown attached to the Monthly nav-tab. */
.nav-tab-wrap{position:relative;display:inline-flex}
.nav-tab-caret{
  margin-left:6px;padding:0 4px;font-size:10px;color:var(--muted);
  border-left:1px solid transparent;transition:color 0.15s,border-color 0.15s;
}
.nav-tab:hover .nav-tab-caret,.nav-tab.active .nav-tab-caret{color:var(--accent);border-left-color:var(--border)}
.cal-mode-menu{
  position:absolute;top:100%;left:0;z-index:100;
  display:none;flex-direction:column;min-width:140px;
  background:var(--surface);border:1px solid var(--border);
  box-shadow:0 6px 18px rgba(0,0,0,0.45);
}
/* Open on hover (desktop), on click (touch/keyboard via .open). top:100%
   leaves no gap so the cursor can travel from the tab into the menu
   without triggering mouseleave. */
.cal-mode-menu.open,
.nav-tab-wrap:hover .cal-mode-menu,
.cal-mode-menu:hover{display:flex}
.cal-mode-menu button{
  background:transparent;border:none;color:var(--muted);
  font-family:'Fira Code',monospace;font-size:11px;letter-spacing:2px;
  text-align:left;padding:9px 12px;cursor:pointer;transition:all 0.15s;
}
.cal-mode-menu button:hover,.cal-mode-menu button.active{
  background:rgba(0,212,255,0.06);color:var(--accent);
}

/* Responsive */
@media(max-width:680px){
  .cal-cell{min-height:70px;padding:4px}
  .cal-grid.cal-week .cal-cell{min-height:140px}
  .cal-task-pill{font-size:9px;padding:1px 3px}
  .cal-month-title{font-size:12px;letter-spacing:2px}
}

/* EDIT MODAL */
.modal-overlay{
  position:fixed;inset:0;background:rgba(8,11,16,0.92);
  display:flex;align-items:center;justify-content:center;
  z-index:100;padding:16px;
  visibility:hidden;opacity:0;pointer-events:none;
  transition:opacity 0.15s ease;
}
.modal-overlay.open{
  visibility:visible;opacity:1;pointer-events:auto;
  -webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);
}
.modal{
  background:var(--surface);border:1px solid var(--border-glow);
  width:100%;max-width:520px;padding:26px;
  display:flex;flex-direction:column;gap:14px;
  box-shadow:0 0 40px rgba(0,212,255,0.08);animation:modalIn 0.2s ease;
}
@keyframes modalIn{from{opacity:0;transform:scale(0.97)}to{opacity:1;transform:scale(1)}}
.modal-title{
  font-family:'Fira Code',monospace;font-size:14px;letter-spacing:3px;
  color:var(--accent);text-transform:uppercase;border-bottom:1px solid var(--border);padding-bottom:13px;
}
.modal-field{display:flex;flex-direction:column;gap:6px}
.modal-field-label{font-family:'Fira Code',monospace;font-size:12px;letter-spacing:2px;color:var(--muted)}
.modal-input{
  background:var(--surface2);border:1px solid var(--border);color:var(--text);
  font-family:'Fira Code',monospace;font-size:14px;padding:11px 13px;outline:none;
  transition:border-color 0.2s;width:100%;letter-spacing:0.5px;color-scheme:dark;
}
.modal-input:focus{border-color:var(--accent)}
.modal-textarea{
  resize:vertical;min-height:90px;max-height:320px;line-height:1.45;
  font-size:13px;white-space:pre-wrap;word-break:break-word;
  scrollbar-width:thin;scrollbar-color:var(--accent) var(--bg);
}
/* Quick-add overlay inside the edit modal — mirrors .task-input-wrap but
   sized for the modal's compact font/padding. */
.modal-input-wrap{position:relative;display:flex;background:var(--surface2);border:1px solid var(--border);transition:border-color 0.2s}
.modal-input-wrap:focus-within{border-color:var(--accent)}
.modal-input.qa-input{
  background:transparent;border:none;color:transparent;-webkit-text-fill-color:transparent;
  caret-color:var(--text);position:relative;z-index:2;
}
.modal-input.qa-input::placeholder{color:var(--muted);-webkit-text-fill-color:var(--muted)}
.modal-input.qa-input::selection{background:rgba(0,212,255,0.25);color:transparent;-webkit-text-fill-color:transparent}
.modal-input-hl{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  font-family:'Fira Code',monospace;font-size:14px;padding:11px 13px;letter-spacing:0.5px;
  color:var(--text);white-space:pre;overflow:hidden;line-height:normal;
}
.modal-row{display:flex;gap:10px}
.modal-row .modal-field{flex:1}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}
.modal-btn{
  background:transparent;border:1px solid var(--border);color:var(--muted);
  font-family:'Fira Code',monospace;font-size:13px;letter-spacing:2px;
  padding:10px 18px;cursor:pointer;transition:all 0.15s;text-transform:uppercase;
}
.modal-btn.primary{border-color:var(--accent);color:var(--accent)}
.modal-btn.primary:hover{background:var(--accent);color:var(--bg)}
.modal-btn.danger{border-color:#ff2a6d;color:#ff2a6d}
.modal-btn.danger:hover{background:#ff2a6d;color:var(--bg)}
.modal-btn:hover{border-color:var(--text);color:var(--text)}
.confirm-msg{font-family:'Fira Code',monospace;font-size:13px;color:var(--muted);letter-spacing:0.5px;margin:0}
.conflict-opts{display:flex;flex-direction:column;gap:10px}
.conflict-opt{display:flex;align-items:center;gap:12px}
.conflict-btn{white-space:nowrap;min-width:160px}
.conflict-opt-desc{font-family:'Fira Code',monospace;font-size:11px;color:var(--muted);letter-spacing:0.3px;line-height:1.5}
.modal-label-row{display:flex;flex-wrap:wrap;gap:6px}

/* FLASH */
.encrypt-flash{
  position:fixed;inset:0;background:rgba(0,212,255,0.025);
  pointer-events:none;animation:flash 0.3s ease;z-index:999;
}
@keyframes flash{0%{opacity:1}100%{opacity:0}}

/* TOOLTIP on heatmap */
[title]{cursor:default}

/* AUTO-BACKUP */
.auto-backup-row{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
}
.auto-backup-toggle{
  flex:1;min-width:200px;display:flex;align-items:center;gap:10px;
  font-family:'Fira Code',monospace;font-size:12px;
  color:var(--muted);letter-spacing:1px;cursor:pointer;user-select:none;
  transition:color 0.15s;
}
.auto-backup-toggle:hover{color:var(--text)}
.auto-backup-toggle input[type="checkbox"]{
  appearance:none;-webkit-appearance:none;
  width:18px;height:18px;
  border:1px solid var(--border);background:var(--surface2);
  cursor:pointer;position:relative;flex-shrink:0;
  transition:all 0.15s;
}
.auto-backup-toggle:hover input[type="checkbox"]{border-color:var(--accent)}
.auto-backup-toggle input[type="checkbox"]:checked{
  background:var(--accent);border-color:var(--accent);
  box-shadow:0 0 8px rgba(0,212,255,0.3);
}
.auto-backup-toggle input[type="checkbox"]:checked::after{
  content:'✓';position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  color:var(--bg);font-size:13px;font-weight:bold;line-height:1;
}
.auto-backup-toggle input[type="checkbox"]:checked + span{color:var(--accent)}
.auto-backup-row .backup-btn{flex:0 0 auto;min-width:160px}

.snapshots-list{
  display:flex;flex-direction:column;gap:5px;
  max-height:240px;overflow-y:auto;
  padding:1px;
}
.snapshot-row{
  display:flex;align-items:center;gap:8px;
  padding:9px 12px;
  background:var(--surface2);border:1px solid var(--border);
  font-family:'Fira Code',monospace;font-size:11px;
  transition:border-color 0.15s;
}
.snapshot-row:hover{border-color:var(--border-glow)}
.snapshot-info{
  flex:1;min-width:0;display:flex;flex-wrap:wrap;gap:7px;align-items:center;
  color:var(--muted);
}
.snapshot-info .ts{color:var(--text);letter-spacing:0.5px}
.snapshot-info .badge{
  display:inline-block;padding:1px 7px;border:1px solid;
  font-size:9px;letter-spacing:1px;text-transform:uppercase;
}
.snapshot-info .badge.auto{color:var(--accent);border-color:var(--accent)}
.snapshot-info .badge.manual{color:var(--accent2);border-color:var(--accent2)}
.snapshot-info .badge.restore{color:var(--amber);border-color:var(--amber)}
.snapshot-info .snapshot-counts{opacity:0.7;font-size:10px}
.snap-act{
  background:transparent;border:1px solid var(--border);color:var(--muted);
  font-family:'Fira Code',monospace;font-size:13px;
  padding:4px 10px;cursor:pointer;transition:all 0.15s;flex-shrink:0;line-height:1;
}
.snap-act:hover{border-color:var(--accent);color:var(--accent)}
.snap-act.del:hover{border-color:var(--warn);color:var(--warn)}

.snapshots-empty{
  font-family:'Fira Code',monospace;font-size:11px;
  color:var(--muted);opacity:0.5;letter-spacing:1px;
  text-align:center;padding:14px;border:1px dashed var(--border);
}

@media (max-width:720px){
  body{padding:24px 12px 56px}
  header{align-items:flex-start;gap:14px;flex-direction:column}
  .nav-tabs{display:grid;grid-template-columns:1fr 1fr}
  .nav-tab:nth-child(2){border-right:none}
  .nav-tab:nth-child(-n+2){border-bottom:1px solid var(--border)}
  .form-row,.modal-row,.backup-row{flex-direction:column}
  .add-btn,.backup-btn{width:100%}
  .support-options{grid-template-columns:1fr}
  .support-card-body{align-items:flex-start;flex-direction:column}
  .support-copy,.support-cta{width:100%;text-align:center}
}

/* ════════════════════════════════════════════════════════════════════
   DATE / TIME PICKER POPOVER
   ════════════════════════════════════════════════════════════════════ */
.dt-picker{
  position:absolute;z-index:200;
  background:var(--surface);border:1px solid var(--border-glow);
  box-shadow:0 0 30px rgba(0,212,255,0.12),0 8px 24px rgba(0,0,0,0.5);
  font-family:'Fira Code',monospace;color:var(--text);
  display:none;user-select:none;
  animation:dtIn 0.12s ease;
}
.dt-picker.open{display:block}
@keyframes dtIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}

/* Calendar ----------------------------------------------------------- */
.dt-cal-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 12px;border-bottom:1px solid var(--border);
}
.dt-cal-title{
  font-size:12px;letter-spacing:2px;color:var(--accent);text-transform:uppercase;
}
.dt-nav{
  background:transparent;border:1px solid var(--border);color:var(--muted);
  width:26px;height:26px;cursor:pointer;font-size:11px;
  display:flex;align-items:center;justify-content:center;
  transition:all 0.15s;
}
.dt-nav:hover{border-color:var(--accent);color:var(--accent)}
.dt-weekdays{
  display:grid;grid-template-columns:repeat(7,1fr);
  padding:8px 8px 4px;gap:2px;
}
.dt-weekdays span{
  text-align:center;font-size:10px;letter-spacing:1px;color:var(--muted);
  padding:4px 0;
}
.dt-grid{
  display:grid;grid-template-columns:repeat(7,1fr);
  padding:0 8px 8px;gap:2px;
}
.dt-day{
  background:transparent;border:1px solid transparent;color:var(--text);
  font-family:inherit;font-size:12px;
  width:32px;height:32px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all 0.1s;
}
.dt-day:hover{border-color:var(--accent);color:var(--accent)}
.dt-day.dim{color:var(--muted);opacity:0.4}
.dt-day.today{border-color:var(--border-glow);color:var(--accent)}
.dt-day.sel{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.dt-day.sel:hover{background:var(--accent);color:var(--bg)}

/* Time --------------------------------------------------------------- */
.dt-time-cols{display:flex;padding:8px;gap:8px}
.dt-time-col{
  display:flex;flex-direction:column;gap:2px;
  max-height:240px;overflow-y:auto;
  scrollbar-width:thin;scrollbar-color:var(--accent) var(--bg);
}
.dt-hours{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;flex:1}
.dt-mins{min-width:60px}
.dt-h,.dt-m{
  background:transparent;border:1px solid var(--border);color:var(--text);
  font-family:inherit;font-size:12px;padding:7px 4px;cursor:pointer;
  transition:all 0.1s;text-align:center;
}
.dt-h:hover,.dt-m:hover{border-color:var(--accent);color:var(--accent)}
.dt-h.sel,.dt-m.sel{background:var(--accent);color:var(--bg);border-color:var(--accent)}

/* Footer (Today / Now / Clear) -------------------------------------- */
.dt-foot{
  display:flex;gap:6px;padding:8px;border-top:1px solid var(--border);
}
.dt-act{
  flex:1;background:transparent;border:1px solid var(--border);color:var(--muted);
  font-family:inherit;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;
  padding:6px 8px;cursor:pointer;transition:all 0.15s;
}
.dt-act:hover{border-color:var(--accent);color:var(--accent)}

/* Combined picker (date + time + recur + ends) ----------------------- */
.dt-combined{border-top:1px solid var(--border);padding:6px 8px;display:flex;flex-direction:column;gap:0}
.dt-combined-t-head{display:flex;align-items:center;gap:6px;padding:5px 0 3px}
.dt-combined-t-val{flex:1;font-size:11px;font-family:'Fira Code',monospace;color:var(--text);letter-spacing:0.5px}
.dt-combined .dt-time-cols{padding:2px 0 6px;border-bottom:1px solid var(--border)}
.dt-combined-section{display:flex;align-items:center;gap:6px;padding:5px 0}
.dt-combined-section+.dt-combined-section{border-top:1px solid var(--border)}
.dt-combined-ends{display:flex;align-items:center;gap:6px;padding:5px 0;border-top:1px solid var(--border)}
.dt-combined-ends.hidden,.dt-combined-n.hidden{display:none}
.dt-combined-label{font-size:9px;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;width:38px;flex-shrink:0}
.dt-combined-ends-pick{
  flex:1;background:var(--surface2);border:1px solid var(--border);color:var(--muted);
  font-family:'Fira Code',monospace;font-size:11px;padding:5px 7px;
  text-align:left;cursor:pointer;transition:all 0.15s;
}
.dt-combined-ends-pick:hover{border-color:var(--accent);color:var(--accent)}
.dt-combined-ends-pick.has-val{color:var(--text)}
.dt-recur-opts{display:flex;gap:3px;flex:1}
.dt-recur-opt{
  flex:1;background:transparent;border:1px solid var(--border);color:var(--muted);
  font-family:'Fira Code',monospace;font-size:10px;letter-spacing:0.5px;
  padding:5px 2px;cursor:pointer;transition:all 0.1s;text-align:center;
}
.dt-recur-opt:hover{border-color:var(--accent);color:var(--accent)}
.dt-recur-opt.sel{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.dt-combined-n{display:flex;align-items:center;gap:4px}
.dt-combined-x{font-size:11px;color:var(--muted)}
.dt-combined-interval{
  width:38px;background:var(--surface2);border:1px solid var(--border);color:var(--text);
  font-family:'Fira Code',monospace;font-size:11px;padding:5px 4px;text-align:center;outline:none;
}
.dt-combined-interval:focus{border-color:var(--accent)}
.dt-combined-interval::-webkit-outer-spin-button,
.dt-combined-interval::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.dt-combined-clear{
  background:transparent;border:1px solid var(--border);color:var(--muted);
  font-family:'Fira Code',monospace;font-size:10px;
  width:22px;height:22px;flex-shrink:0;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all 0.15s;
}
.dt-combined-clear:hover{border-color:var(--accent);color:var(--accent)}

/* ════════════════════════════════════════════════════════════════════
   CUSTOM SELECT POPOVER
   ════════════════════════════════════════════════════════════════════ */
.sel-picker{
  position:absolute;z-index:200;
  background:var(--surface);border:1px solid var(--border-glow);
  box-shadow:0 0 30px rgba(0,212,255,0.12),0 8px 24px rgba(0,0,0,0.5);
  font-family:'Fira Code',monospace;color:var(--text);
  display:none;user-select:none;min-width:120px;max-height:280px;overflow-y:auto;
  scrollbar-width:thin;scrollbar-color:var(--accent) var(--bg);
  animation:dtIn 0.12s ease;
}
.sel-picker.open{display:block}
.sel-opt{
  display:block;width:100%;
  background:transparent;border:none;color:var(--text);
  font-family:inherit;font-size:13px;letter-spacing:1px;
  padding:10px 14px;cursor:pointer;text-align:left;
  transition:background 0.1s,color 0.1s;
}
.sel-opt:hover{background:rgba(0,212,255,0.08);color:var(--accent)}
.sel-opt.sel{background:var(--accent);color:var(--bg)}
.sel-opt.sel:hover{background:var(--accent);color:var(--bg)}

/* ════════════════════════════════════════════════════════════════════
   REDUCED MOTION — also helps WebKitGTK/Wayland compositor stability
   ════════════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
    scroll-behavior:auto !important;
  }
  .dot{animation:none !important;opacity:1}
}
