/* =========================================================
   Signal - app stylesheet
   Tokens live under :root (dark) and [data-theme="light"].
========================================================= */

:root{
  /* dark palette */
  --bg: #09090b;
  --bg-1: #0c0c0f;
  --surface: #121216;
  --surface-1: #17171c;
  --surface-2: #1c1c22;
  --elev: #20202a;

  --line: rgba(255,255,255,0.06);
  --line-2: rgba(255,255,255,0.10);
  --line-3: rgba(255,255,255,0.16);

  --text: #ededf0;
  --text-2: #a5a5ae;
  --text-3: #6e6e77;
  --text-4: #4a4a52;

  --emerald: #10b981;
  --emerald-2: #34d399;
  --emerald-soft: rgba(16,185,129,0.12);
  --emerald-line: rgba(16,185,129,0.28);

  --amber: #d97706;
  --amber-2: #f59e0b;
  --amber-soft: rgba(217,119,6,0.12);
  --amber-line: rgba(245,158,11,0.3);

  --violet: #8b5cf6;
  --violet-soft: rgba(139,92,246,0.12);

  --rose: #f43f5e;
  --rose-soft: rgba(244,63,94,0.10);

  --sky: #38bdf8;
  --sky-soft: rgba(56,189,248,0.10);

  --shadow-sm: 0 1px 0 rgba(255,255,255,0.03), 0 1px 2px rgba(0,0,0,0.4);
  --shadow-md: 0 1px 0 rgba(255,255,255,0.04), 0 10px 30px rgba(0,0,0,0.45);

  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 14px;

  --code-bg: var(--bg);
}

[data-theme="light"]{
  --bg: #fafaf8;
  --bg-1: #f3f3ef;
  --surface: #ffffff;
  --surface-1: #f7f7f5;
  --surface-2: #eeeeea;
  --elev: #ffffff;

  --line: rgba(17,17,20,0.07);
  --line-2: rgba(17,17,20,0.12);
  --line-3: rgba(17,17,20,0.22);

  --text: #1a1a1e;
  --text-2: #52525a;
  --text-3: #77777f;
  --text-4: #a0a0a8;

  --emerald: #059669;
  --emerald-2: #047857;
  --emerald-soft: rgba(5,150,105,0.10);
  --emerald-line: rgba(5,150,105,0.30);

  --amber: #b45309;
  --amber-2: #c2410c;
  --amber-soft: rgba(180,83,9,0.10);
  --amber-line: rgba(180,83,9,0.30);

  --violet: #6d28d9;
  --violet-soft: rgba(109,40,217,0.10);

  --rose: #be123c;
  --rose-soft: rgba(190,18,60,0.08);

  --sky: #0369a1;
  --sky-soft: rgba(3,105,161,0.08);

  --shadow-sm: 0 1px 0 rgba(0,0,0,0.02), 0 1px 2px rgba(0,0,0,0.06);
  --shadow-md: 0 1px 0 rgba(0,0,0,0.03), 0 10px 30px rgba(0,0,0,0.08);

  --code-bg: #f3f3ef;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Hanken Grotesk',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  letter-spacing:-0.005em;
  font-feature-settings:"ss01","cv11";
}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
input,textarea,select{font:inherit;color:inherit}

body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:-1;
  background:
    radial-gradient(1000px 600px at 60% -10%, rgba(16,185,129,0.05), transparent 60%),
    radial-gradient(800px 400px at 10% 110%, rgba(139,92,246,0.04), transparent 60%),
    var(--bg);
}
[data-theme="light"] body::before{
  background:
    radial-gradient(1000px 600px at 60% -10%, rgba(5,150,105,0.06), transparent 60%),
    radial-gradient(800px 400px at 10% 110%, rgba(109,40,217,0.04), transparent 60%),
    var(--bg);
}

/* ----------------------------------------------------------
   Layout
---------------------------------------------------------- */
.app{
  display:grid;
  grid-template-columns:220px 1fr;
  grid-template-rows:52px 1fr;
  height:100vh;
}
.topnav{
  grid-column:1 / -1;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 20px;
  border-bottom:1px solid var(--line);
  background:color-mix(in srgb, var(--bg) 85%, transparent);
  backdrop-filter:saturate(1.2) blur(8px);
  z-index:5;
}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{
  width:22px;height:22px;border-radius:6px;
  background:linear-gradient(135deg,var(--emerald),#0e9268);
  display:flex;align-items:center;justify-content:center;
  color:#0b1a14;font-weight:700;font-size:12px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.3);
  position:relative;
}
[data-theme="light"] .brand-mark{color:#fff}
.brand-mark::after{
  content:"";position:absolute;inset:3px;border-radius:3px;
  background:radial-gradient(circle at 30% 30%,rgba(255,255,255,0.25),transparent 60%);
}
.brand-name{font-weight:600;font-size:14px;letter-spacing:-0.01em}
.brand-slash{color:var(--text-4);font-weight:300}
.brand-scope{color:var(--text-2);font-size:13px}
.brand-badge{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  color:var(--text-3);background:var(--surface-1);
  border:1px solid var(--line-2);border-radius:4px;
  padding:2px 6px;margin-left:4px;
}

.topnav-meta{
  display:flex;align-items:center;gap:10px;
  font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-3);
}
.topnav-meta .v{color:var(--text-2)}
.topnav-meta .dot{
  width:6px;height:6px;border-radius:50%;background:var(--emerald-2);
  box-shadow:0 0 0 3px rgba(16,185,129,0.14);
}
.topnav-actions{display:flex;align-items:center;gap:10px}

.theme-toggle{
  width:30px;height:30px;border-radius:7px;
  border:1px solid var(--line-2);color:var(--text-2);
  display:inline-flex;align-items:center;justify-content:center;
  transition:all 0.15s;
}
.theme-toggle:hover{background:var(--surface-1);color:var(--text);border-color:var(--line-3);box-shadow:0 0 0 3px var(--emerald-soft)}
.theme-toggle .t-sun{display:none}
.theme-toggle .t-moon{display:inline-block}
[data-theme="light"] .theme-toggle .t-sun{display:inline-block}
[data-theme="light"] .theme-toggle .t-moon{display:none}

/* ----------------------------------------------------------
   Sidebar
---------------------------------------------------------- */
.sidebar{
  border-right:1px solid var(--line);
  background:var(--bg-1);
  padding:14px 10px;
  display:flex;flex-direction:column;gap:2px;
  overflow-y:auto;
}
.side-label{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  color:var(--text-4);text-transform:uppercase;letter-spacing:0.08em;
  padding:10px 10px 6px;
}
.side-link{
  display:flex;align-items:center;gap:10px;
  padding:7px 10px;border-radius:6px;
  font-size:13px;color:var(--text-2);
  transition:background 0.12s,color 0.12s;
  position:relative;
}
.side-link:hover{background:var(--surface-1);color:var(--text)}
.side-link.active{background:var(--surface-1);color:var(--text);font-weight:500}
.side-link.active::before{
  content:"";position:absolute;left:0;top:7px;bottom:7px;width:2px;
  background:var(--emerald-2);border-radius:2px;
}
.side-ico{
  width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;
  color:var(--text-3);flex:0 0 auto;
}
.side-link.active .side-ico{color:var(--emerald-2)}
.side-count{
  margin-left:auto;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  color:var(--text-3);
  background:var(--surface-2);border:1px solid var(--line);
  border-radius:4px;padding:1px 6px;
}
.side-count.accent{color:var(--emerald-2);border-color:var(--emerald-line);background:var(--emerald-soft)}
.side-count.warn{color:var(--amber-2);border-color:var(--amber-line);background:var(--amber-soft)}

.side-foot{
  margin-top:auto;padding:10px;
  font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-4);
  border-top:1px solid var(--line);
}
.side-foot kbd{
  font-family:'JetBrains Mono',monospace;
  background:var(--surface-1);border:1px solid var(--line-2);
  border-radius:3px;padding:1px 4px;color:var(--text-3);
}

/* ----------------------------------------------------------
   Main + page head
---------------------------------------------------------- */
.main{overflow-y:auto}
.focus-head-top{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  margin-bottom:10px;min-height:32px;
}
.focus-head-spacer{min-width:1px}
.focus-breadcrumb-anchor{
  justify-self:center;display:inline-flex;align-items:center;gap:8px;
  min-height:30px;max-width:min(700px, 90vw);padding:6px 10px;
  border:1px dashed var(--line-2);border-radius:999px;background:rgba(255,255,255,0.02);
  color:var(--text-3);font-family:'JetBrains Mono',monospace;font-size:10.5px;
  letter-spacing:0.03em;overflow:hidden;
}
.focus-breadcrumb-anchor.has-crumb{border-color:var(--emerald-line);background:rgba(16,185,129,0.08)}
.crumb-mini-label{
  text-transform:uppercase;color:var(--emerald-2);flex:0 0 auto;
}
.crumb-mini-text,.crumb-mini-empty{
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.crumb-mini-empty{color:var(--text-4)}

.page-head{
  padding:22px 32px 16px;
  border-bottom:1px solid var(--line);
  background:var(--bg-1);
  position:sticky;top:0;z-index:3;
}
.page-crumb{
  font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-3);
  display:flex;gap:6px;align-items:center;margin-bottom:10px;letter-spacing:0.04em;
}
.page-crumb .sep{color:var(--text-4)}
.page-crumb .now{color:var(--text-2)}
.page-title{
  font-size:24px;font-weight:600;letter-spacing:-0.02em;
  display:flex;align-items:center;gap:10px;margin-bottom:6px;
}
.page-title .dot{
  width:8px;height:8px;border-radius:50%;background:var(--emerald-2);
  box-shadow:0 0 0 3px rgba(16,185,129,0.14);
}
.page-title em{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  color:var(--emerald-2);letter-spacing:-0.01em;
}
.page-sub{color:var(--text-2);font-size:13.5px;line-height:1.55;max-width:700px}

.page-meta{display:flex;gap:6px;margin-top:14px;flex-wrap:wrap}
.meta-chip{
  display:inline-flex;align-items:center;gap:6px;
  font-family:'JetBrains Mono',monospace;font-size:10.5px;
  color:var(--text-2);background:var(--surface);
  border:1px solid var(--line);border-radius:5px;
  padding:4px 8px;
}
.meta-chip .k{color:var(--text-3)}
.meta-chip .v{color:var(--text)}
.meta-chip.accent{border-color:var(--emerald-line);background:var(--emerald-soft);color:var(--emerald-2)}
.meta-chip.accent .v{color:var(--emerald-2)}
.meta-chip.warn{border-color:var(--amber-line);background:var(--amber-soft);color:var(--amber-2)}
.meta-chip.warn .v{color:var(--amber-2)}

.page-body{padding:22px 32px 60px}

/* ----------------------------------------------------------
   Capture + buttons
---------------------------------------------------------- */
.capture{
  display:flex;gap:8px;align-items:stretch;
  background:var(--surface);border:1px solid var(--line-2);
  border-radius:var(--r-md);
  padding:6px;margin-bottom:18px;
  transition:border-color 0.15s;
}
.capture:focus-within{border-color:var(--emerald-line);box-shadow:0 0 0 3px var(--emerald-soft)}
.capture input, .capture textarea{
  flex:1;background:transparent;border:0;outline:0;
  padding:8px 10px;font-size:14px;color:var(--text);
  letter-spacing:-0.005em;resize:none;
}
.capture input::placeholder,.capture textarea::placeholder{color:var(--text-3);font-style:italic}
.capture .caps{display:flex;gap:6px;align-items:center;padding-right:4px}

.btn{
  display:inline-flex;align-items:center;gap:6px;
  height:32px;padding:0 12px;border-radius:6px;
  font-size:12.5px;font-weight:500;
  background:var(--surface-1);border:1px solid var(--line-2);color:var(--text);
  transition:all 0.15s;
}
.btn:hover{background:var(--surface-2);border-color:var(--line-3)}
.btn.primary{
  background:linear-gradient(180deg,var(--emerald),#0e9268);
  border-color:#0c8b63;color:#fff;font-weight:600;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.2);
}
[data-theme=""] .btn.primary,:root:not([data-theme="light"]) .btn.primary{color:#051b13}
.btn.primary:hover{filter:brightness(1.08)}
.btn.ghost{background:transparent}
.btn.sm{height:26px;padding:0 8px;font-size:11.5px}
.btn.danger{color:#fca5a5}
[data-theme="light"] .btn.danger{color:#be123c}
.btn.danger:hover{background:rgba(244,63,94,0.08);border-color:rgba(244,63,94,0.3);color:#fb7185}
[data-theme="light"] .btn.danger:hover{color:#9f1239}
.btn .kbd{
  font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-3);
  background:rgba(255,255,255,0.04);border:1px solid var(--line);border-radius:3px;
  padding:1px 4px;
}
[data-theme="light"] .btn .kbd{background:rgba(0,0,0,0.04)}

/* ----------------------------------------------------------
   Task cards
---------------------------------------------------------- */
.task-list{display:flex;flex-direction:column;gap:8px}

.task-wrap{display:flex;flex-direction:column}

.task{
  position:relative;
  display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:start;
  background:var(--surface-1);
  border:1px solid var(--line);
  border-radius:var(--r-md);
  padding:12px 14px;
  transition:border-color 0.15s,transform 0.15s,box-shadow 0.15s;
  cursor:pointer;
}
.task:hover{border-color:var(--line-3);box-shadow:var(--shadow-sm)}
.task.doing{
  border-color:var(--emerald-line);
  background:linear-gradient(180deg,var(--emerald-soft),var(--surface-1) 60%);
  box-shadow:inset 0 0 0 1px rgba(16,185,129,0.08);
}
.task.waiting{border-color:rgba(245,158,11,0.25);background:var(--amber-soft)}
.task.done{cursor:default}
.task.done .t-text{color:var(--text-3);text-decoration:line-through}
.task.expanded{border-bottom-left-radius:0;border-bottom-right-radius:0}

.t-bullet{
  width:18px;height:18px;border-radius:50%;
  border:1.5px solid var(--line-3);margin-top:1px;flex:0 0 auto;
  background:transparent;position:relative;transition:all 0.15s;
  cursor:pointer;
}
.t-bullet:hover{border-color:var(--emerald-2)}
.t-bullet.on{border-color:var(--emerald-2);background:var(--emerald-2)}
.t-bullet.on::after{
  content:"";position:absolute;inset:4px;border-radius:50%;
  background:var(--bg);
}
[data-theme="light"] .t-bullet.on::after{background:var(--surface)}
.task.doing .t-bullet{border-color:var(--emerald-2);background:var(--emerald-soft)}
.task.doing .t-bullet::after{
  content:"";position:absolute;inset:3px;border-radius:50%;
  background:var(--emerald-2);box-shadow:0 0 8px var(--emerald-2);
  animation:pulse 1.6s ease-in-out infinite;
}
@keyframes pulse{50%{opacity:0.55}}

.t-body{min-width:0;display:flex;flex-direction:column;gap:6px}
.t-text{
  font-size:14px;color:var(--text);letter-spacing:-0.005em;line-height:1.45;
  word-break:break-word;
}
.t-meta{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-3);
  letter-spacing:0.02em;
}
.t-tag{
  font-family:'JetBrains Mono',monospace;font-size:9.5px;font-weight:500;
  padding:1px 6px;border-radius:3px;
  background:var(--surface-2);border:1px solid var(--line-2);color:var(--text-2);
  letter-spacing:0.04em;text-transform:uppercase;
}
.t-tag.emerald{color:var(--emerald-2);background:var(--emerald-soft);border-color:var(--emerald-line)}
.t-tag.amber{color:var(--amber-2);background:var(--amber-soft);border-color:var(--amber-line)}
.t-tag.sky{color:var(--sky);background:var(--sky-soft);border-color:rgba(56,189,248,0.3)}
.t-tag.rose{color:#fb7185;background:var(--rose-soft);border-color:rgba(244,63,94,0.28)}
[data-theme="light"] .t-tag.rose{color:var(--rose)}

.t-chips{display:flex;gap:6px;flex-wrap:wrap;margin-top:2px}
.t-chip{
  display:inline-flex;align-items:center;gap:4px;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  color:var(--text-2);background:var(--surface);
  border:1px solid var(--line);border-radius:4px;
  padding:2px 7px;
}
.t-chip .k{color:var(--text-4);font-size:9px;text-transform:uppercase;letter-spacing:0.05em}

.t-progress-mini{
  display:flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;
  font-size:10px;color:var(--text-3);
}
.t-progress-mini .bar{
  flex:1;height:3px;min-width:60px;max-width:120px;
  background:var(--surface-2);border-radius:2px;overflow:hidden;
}
.t-progress-mini .bar > i{display:block;height:100%;background:var(--emerald-2)}

.t-actions{display:flex;gap:4px;align-items:center;opacity:0;transition:opacity 0.15s}
.task:hover .t-actions,.task.expanded .t-actions{opacity:1}
.t-actions .btn.sm{padding:0 7px}

/* Focus timer block */
.task.doing .t-body{gap:10px}
.task.doing .t-text{font-size:15px;font-weight:500}
.focus-timer{
  margin:14px 0 18px;text-align:center;padding:24px;
  background:radial-gradient(ellipse at center,rgba(16,185,129,0.08),transparent 70%);
  border:1px dashed var(--emerald-line);border-radius:var(--r-md);
}
.focus-timer .time{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:56px;color:var(--emerald-2);letter-spacing:-0.02em;line-height:1;
}
.focus-timer .label{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  color:var(--text-3);text-transform:uppercase;letter-spacing:0.1em;margin-top:6px;
}

/* ----------------------------------------------------------
   Task detail (inline expand)
---------------------------------------------------------- */
.t-detail{
  background:var(--surface);
  border:1px solid var(--line);border-top:0;
  border-radius:0 0 var(--r-md) var(--r-md);
  padding:18px 18px 16px;
  display:flex;flex-direction:column;gap:18px;
  animation:slideDown 0.2s ease-out;
  overflow:hidden;
}
@keyframes slideDown{from{opacity:0;max-height:0;padding-top:0;padding-bottom:0}to{opacity:1;max-height:2000px}}

.detail-section{display:flex;flex-direction:column;gap:8px}
.detail-label{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  color:var(--text-3);text-transform:uppercase;letter-spacing:0.08em;
}

.detail-fields{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.detail-fields.single{grid-template-columns:1fr}
.detail-fields label{display:flex;flex-direction:column;gap:4px;font-size:11px;color:var(--text-3);font-family:'JetBrains Mono',monospace;letter-spacing:0.04em;text-transform:uppercase}
.detail-fields input, .detail-fields textarea{
  font-family:'Hanken Grotesk',sans-serif;font-size:13px;
  background:var(--bg);border:1px solid var(--line-2);border-radius:var(--r-sm);
  padding:8px 10px;color:var(--text);letter-spacing:-0.005em;
  transition:border-color 0.15s;text-transform:none;
}
.detail-fields input:focus, .detail-fields textarea:focus{
  outline:0;border-color:var(--emerald-line);box-shadow:0 0 0 3px var(--emerald-soft);
}
.detail-fields textarea{min-height:60px;resize:vertical}

.detail-actions{display:flex;gap:6px;justify-content:space-between;align-items:center;padding-top:8px;border-top:1px dashed var(--line-2)}
.detail-actions .left{display:flex;gap:6px}
.detail-actions .right{display:flex;gap:6px}

/* subtasks */
.subtasks{display:flex;flex-direction:column;gap:6px}
.subtask{
  display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;
  background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:8px 10px;font-size:12.5px;
  transition:border-color 0.15s;
}
.subtask:hover{border-color:var(--line-3)}
.subtask .sb-bullet{
  width:16px;height:16px;border-radius:50%;border:1.5px solid var(--line-3);
  background:transparent;cursor:pointer;position:relative;transition:all 0.15s;
}
.subtask .sb-bullet:hover{border-color:var(--emerald-2)}
.subtask .sb-bullet.on{background:var(--emerald-2);border-color:var(--emerald-2)}
.subtask .sb-bullet.on::after{
  content:"";position:absolute;inset:3px;border-radius:50%;background:var(--bg);
}
[data-theme="light"] .subtask .sb-bullet.on::after{background:var(--surface)}
.subtask.done .sb-text{color:var(--text-3);text-decoration:line-through}
.subtask .sb-idx{
  font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--text-4);
  padding-right:2px;
}

.progress-row{
  display:flex;align-items:center;gap:10px;padding-top:4px;
  font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-3);
}
.progress-row .bar{flex:1;height:4px;background:var(--surface-2);border-radius:2px;overflow:hidden}
.progress-row .bar > i{display:block;height:100%;background:var(--emerald-2);transition:width 0.3s ease}

/* comments */
.comment-form{display:flex;gap:8px;align-items:stretch}
.comment-form textarea{
  flex:1;font-family:'Hanken Grotesk',sans-serif;font-size:13px;
  background:var(--bg);border:1px solid var(--line-2);border-radius:var(--r-sm);
  padding:8px 10px;color:var(--text);resize:vertical;min-height:36px;
}
.comment-form textarea:focus{outline:0;border-color:var(--emerald-line);box-shadow:0 0 0 3px var(--emerald-soft)}

.comments{display:flex;flex-direction:column;gap:6px}
.comment{
  background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:8px 12px;display:flex;flex-direction:column;gap:4px;
  position:relative;
}
.comment-when{
  font-family:'JetBrains Mono',monospace;font-size:9.5px;color:var(--text-3);
  letter-spacing:0.05em;display:flex;justify-content:space-between;align-items:center;
}
.comment-text{font-size:13px;color:var(--text);line-height:1.5;white-space:pre-wrap}
.comment-del{
  width:20px;height:20px;border-radius:4px;color:var(--text-4);
  display:inline-flex;align-items:center;justify-content:center;font-size:11px;
  opacity:0;transition:all 0.15s;
}
.comment:hover .comment-del{opacity:1}
.comment-del:hover{color:#fb7185;background:rgba(244,63,94,0.08)}

/* ----------------------------------------------------------
   Snippets
---------------------------------------------------------- */
.snip{
  background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r-md);
  padding:12px 14px;display:flex;flex-direction:column;gap:8px;
  transition:border-color 0.15s;
}
.snip:hover{border-color:var(--line-3)}
.snip-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.snip-title{font-size:13.5px;font-weight:500;letter-spacing:-0.005em}
.snip-meta{display:flex;gap:6px;align-items:center}
.snip pre{
  font-family:'JetBrains Mono',monospace;font-size:12px;
  color:var(--emerald-2);background:var(--code-bg);
  border:1px solid var(--line);border-radius:var(--r-sm);
  padding:10px 12px;overflow-x:auto;white-space:pre;
  line-height:1.5;cursor:copy;
}

/* ----------------------------------------------------------
   Templates
---------------------------------------------------------- */
.tpl-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;
}
.tpl{
  background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r-md);
  padding:16px;display:flex;flex-direction:column;gap:10px;
  transition:all 0.15s;
}
.tpl:hover{border-color:var(--emerald-line);box-shadow:var(--shadow-sm)}
.tpl-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.tpl-name{font-size:14.5px;font-weight:600;letter-spacing:-0.01em}
.tpl-meta{display:flex;gap:4px;align-items:center}
.tpl-count{
  font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--text-3);
  text-transform:uppercase;letter-spacing:0.06em;
}
.tpl-steps{
  font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-3);
  line-height:1.7;max-height:140px;overflow:hidden;position:relative;
  white-space:pre-wrap;
}
.tpl-steps::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:40px;
  background:linear-gradient(180deg,transparent,var(--surface-1));
  pointer-events:none;
}
.tpl-form{
  display:grid;grid-template-columns:1fr auto;gap:6px;
  padding-top:10px;border-top:1px dashed var(--line-2);margin-top:auto;
}
.tpl-form .row{display:grid;grid-template-columns:1fr 1fr;gap:6px;grid-column:1 / -1}
.tpl-form input{
  background:var(--bg);border:1px solid var(--line-2);border-radius:var(--r-sm);
  padding:6px 8px;font-size:12px;color:var(--text);
}
.tpl-form input:focus{outline:0;border-color:var(--emerald-line);box-shadow:0 0 0 2px var(--emerald-soft)}
.tpl-form .tpl-submit{grid-column:1 / -1;display:flex;justify-content:space-between;align-items:center}

.tpl-edit{
  background:var(--surface);border:1px solid var(--emerald-line);border-radius:var(--r-md);
  padding:16px;display:flex;flex-direction:column;gap:10px;
}
.tpl-edit input[name="name"]{
  font-size:15px;font-weight:600;background:transparent;border:0;border-bottom:1px solid var(--line-2);
  padding:4px 0;color:var(--text);outline:0;
}
.tpl-edit input[name="name"]:focus{border-color:var(--emerald-line)}
.tpl-edit textarea{
  font-family:'JetBrains Mono',monospace;font-size:11px;line-height:1.7;
  background:var(--bg);border:1px solid var(--line-2);border-radius:var(--r-sm);
  padding:10px;color:var(--text);resize:vertical;min-height:180px;
}
.tpl-edit textarea:focus{outline:0;border-color:var(--emerald-line);box-shadow:0 0 0 3px var(--emerald-soft)}
.tpl-edit .row-check{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-2)}
.tpl-edit .row-check input{accent-color:var(--emerald-2)}
.tpl-edit-actions{display:flex;justify-content:space-between;gap:6px;padding-top:6px;border-top:1px dashed var(--line-2)}

.new-template-drawer{
  background:var(--surface);border:1px dashed var(--line-3);border-radius:var(--r-md);
  padding:16px;margin-bottom:18px;display:none;flex-direction:column;gap:10px;
}
.new-template-drawer.open{display:flex}
.new-template-drawer input, .new-template-drawer textarea{
  background:var(--bg);border:1px solid var(--line-2);border-radius:var(--r-sm);
  padding:8px 10px;color:var(--text);font-size:13px;
}
.new-template-drawer textarea{font-family:'JetBrains Mono',monospace;font-size:11px;min-height:140px;resize:vertical;line-height:1.7}

/* ----------------------------------------------------------
   Breadcrumbs
---------------------------------------------------------- */
.crumb{
  position:relative;
  background:var(--surface-1);border:1px solid var(--line);border-radius:var(--r-md);
  border-left:3px solid var(--sky);
  padding:12px 14px 12px 16px;display:flex;flex-direction:column;gap:4px;
}
.crumb:hover .crumb-actions{opacity:1}
.crumb-when{
  font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--sky);
  text-transform:uppercase;letter-spacing:0.08em;
}
.crumb-text{font-size:13.5px;color:var(--text);line-height:1.5}
.crumb-actions{position:absolute;top:8px;right:10px;opacity:0;transition:opacity 0.15s}

/* Done day headings */
.day-head{
  font-family:'JetBrains Mono',monospace;font-size:10.5px;
  color:var(--text-3);text-transform:uppercase;letter-spacing:0.08em;
  padding:14px 4px 8px;border-bottom:1px solid var(--line);margin-bottom:10px;
  display:flex;justify-content:space-between;align-items:center;
}
.day-head .count{color:var(--text-4)}

.t-detail-open{
  margin-top:-12px; margin-bottom:16px;
}
.t-detail-open .detail-section{gap:10px}
.t-detail-open .detail-label{color:var(--text-4)}

.detail-help{font-size:11px;line-height:1.5;color:var(--text-3);margin-top:-2px}
.t-detail.collapsed-by-click{display:none}
.tpl-inline-note{grid-column:1 / -1;font-size:12px;line-height:1.5;color:var(--text-3);padding:10px 12px;border:1px dashed var(--line-2);border-radius:12px;background:var(--surface-1)}
.focus-breadcrumb-anchor{justify-self:center}
.modal-backdrop{background:rgba(2,6,23,0.86);backdrop-filter:blur(5px)}
.crumb-modal{width:min(640px, calc(100vw - 24px));padding:28px;box-shadow:0 30px 80px rgba(0,0,0,0.45)}
.crumb-modal-head{align-items:center}
.crumb-modal h3{font-size:30px}
.crumb-modal-sub{max-width:54ch}

.modal-backdrop{
  position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(2,6,23,0.74);backdrop-filter:blur(3px);z-index:120;
}
.crumb-modal{
  width:min(720px, calc(100vw - 32px));
  background:linear-gradient(180deg, var(--surface), var(--bg-1));
  border:1px solid var(--line-2);border-radius:16px;box-shadow:var(--shadow-md);
  padding:20px;display:flex;flex-direction:column;gap:12px;
}
.crumb-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.crumb-modal-kicker{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:0.08em;color:var(--emerald-2);margin-bottom:4px}
.crumb-modal h3{font-size:28px;letter-spacing:-0.02em;margin:0;color:var(--text)}
.crumb-modal-sub{margin:0;color:var(--text-3);max-width:62ch;line-height:1.5}
.crumb-modal-task{
  border:1px solid var(--line);background:var(--surface-1);border-radius:12px;
  padding:12px 14px;color:var(--text-2);font-size:14px;
}
.crumb-modal-form textarea{
  width:100%;background:var(--bg);border:1px solid var(--line-2);border-radius:12px;
  min-height:120px;padding:12px 14px;color:var(--text);font-size:14px;resize:vertical;
}
.crumb-modal-form textarea:focus{outline:0;border-color:var(--emerald-line);box-shadow:0 0 0 3px var(--emerald-soft)}
.crumb-modal-actions{display:flex;justify-content:flex-end;gap:8px}
.crumb-close{font-size:14px;line-height:1}

/* ----------------------------------------------------------
   Toasts + popover
---------------------------------------------------------- */
#toasts{
  position:fixed;bottom:20px;right:20px;z-index:80;
  display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none;
}
.toast{
  pointer-events:auto;
  background:var(--surface-2);border:1px solid var(--line-2);border-radius:var(--r-sm);
  padding:10px 14px;font-size:12.5px;color:var(--text);
  box-shadow:var(--shadow-md);
  animation:toastIn 0.25s ease-out, toastOut 0.35s ease-in 2.7s forwards;
  max-width:360px;
}
.toast.toast-warn{border-color:var(--amber-line);background:var(--amber-soft);color:var(--amber-2)}
@keyframes toastIn{from{opacity:0;transform:translateX(10px)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{to{opacity:0;transform:translateX(10px)}}

.popover{
  position:absolute;z-index:40;
  background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-md);
  box-shadow:var(--shadow-md);padding:12px;
  min-width:260px;display:none;
}
.popover.open{display:block}
.popover h4{
  font-family:'JetBrains Mono',monospace;font-size:10.5px;font-weight:500;
  color:var(--text-3);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:8px;
}
.popover-row{display:flex;gap:6px;margin-bottom:8px}
.popover-row input{
  flex:1;background:var(--bg);border:1px solid var(--line-2);border-radius:var(--r-sm);
  padding:6px 8px;font-size:12px;color:var(--text);
}
.popover-row input:focus{outline:0;border-color:var(--emerald-line)}
.popover-chips{display:flex;gap:4px;margin-bottom:8px;flex-wrap:wrap}
.popover-chip{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  padding:3px 8px;border-radius:4px;
  border:1px solid var(--line-2);background:var(--surface-1);color:var(--text-2);
  cursor:pointer;
}
.popover-chip.on{border-color:var(--emerald-line);background:var(--emerald-soft);color:var(--emerald-2)}
.popover-actions{display:flex;gap:6px;justify-content:flex-end}

.empty{
  border:1px dashed var(--line-2);border-radius:var(--r-md);
  padding:32px;text-align:center;color:var(--text-3);
  font-size:13px;
}
.empty strong{color:var(--text-2);font-weight:500;font-size:14px;display:block;margin-bottom:4px}

.main::-webkit-scrollbar,.sidebar::-webkit-scrollbar{width:8px}
.main::-webkit-scrollbar-thumb,.sidebar::-webkit-scrollbar-thumb{
  background:var(--surface-2);border-radius:4px;border:2px solid var(--bg);
}

.search-row{display:flex;gap:8px;margin-bottom:16px}
.search-row input{
  flex:1;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-md);
  padding:9px 12px;font-size:13px;color:var(--text);
}
.search-row input:focus{outline:0;border-color:var(--emerald-line);box-shadow:0 0 0 3px var(--emerald-soft)}

@media(max-width:760px){
  .app{grid-template-columns:1fr;grid-template-rows:52px auto 1fr}
  .sidebar{
    grid-row:2;display:flex;flex-direction:row;flex-wrap:wrap;gap:4px;padding:8px;
    border-right:none;border-bottom:1px solid var(--line);overflow-x:auto;
  }
  .side-label,.side-foot{display:none}
  .side-link{padding:6px 10px;white-space:nowrap}
  .side-link.active::before{display:none}
  .page-head,.page-body{padding-left:16px;padding-right:16px}
  .page-title{font-size:20px}
  .detail-fields{grid-template-columns:1fr}
  .focus-head-top{grid-template-columns:1fr}
  .focus-breadcrumb-anchor{max-width:100%; width:100%; border-radius:12px}
  .crumb-modal{width:calc(100vw - 20px); padding:16px}
  .crumb-modal h3{font-size:22px}
}


.top-breadcrumb-slot{
  min-width:min(720px, 62vw);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  overflow:hidden;
}
.top-breadcrumb-main{
  min-width:0;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  overflow:hidden;
  white-space:nowrap;
}
.top-crumb-btn{
  flex:0 0 auto;
  white-space:nowrap;
}
.top-breadcrumb-slot.has-crumb{
  padding:6px 10px;
  border:1px solid var(--emerald-line);
  border-radius:999px;
  background:var(--emerald-soft);
}
.crumb-nav-label{
  text-transform:uppercase;
  color:var(--emerald-2);
  letter-spacing:0.08em;
}
.crumb-nav-text{
  color:var(--text);
  overflow:hidden;
  text-overflow:ellipsis;
}
.crumb-backdrop-strong{
  background:rgba(5, 7, 10, 0.82);
  backdrop-filter:blur(8px) saturate(0.9);
}
.crumb-reminder-modal{
  border:1px solid var(--emerald-line);
  box-shadow:0 30px 100px rgba(0,0,0,0.6), 0 0 0 1px rgba(16,185,129,0.16);
}
.crumb-modal-actions.single-action{justify-content:center}
.resume-target{
  outline:2px solid var(--emerald-2);
  box-shadow:0 0 0 6px var(--emerald-soft);
  transition:box-shadow .2s ease, outline-color .2s ease;
}
@media (max-width: 900px){
  .top-breadcrumb-slot{min-width:0;max-width:58vw;gap:6px}
  .top-crumb-btn{padding-left:8px;padding-right:8px}
}

/* ── Auth pages (login / setup / signup) ────────────────── */
.auth-page{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:var(--bg);padding:24px;
}
.auth-card{
  width:100%;max-width:420px;
  background:var(--surface);border:1px solid var(--line-2);
  border-radius:20px;padding:32px;box-shadow:var(--shadow-md);
}
.auth-brand{display:flex;align-items:center;gap:10px;margin-bottom:24px}
.auth-title{font-size:24px;font-weight:700;letter-spacing:-0.02em;margin:0 0 6px;color:var(--text)}
.auth-sub{font-size:13px;color:var(--text-3);margin:0 0 24px;line-height:1.5}
.auth-error{
  background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);
  color:#fca5a5;border-radius:10px;padding:10px 14px;
  font-size:13px;margin-bottom:16px;
}
.auth-form{display:flex;flex-direction:column;gap:14px}
.auth-form label{display:flex;flex-direction:column;gap:5px;font-size:12px;
  font-family:'JetBrains Mono',monospace;text-transform:uppercase;
  letter-spacing:.06em;color:var(--text-3)}
.auth-form input{
  background:var(--bg);border:1px solid var(--line-2);border-radius:10px;
  padding:10px 14px;color:var(--text);font-size:14px;
}
.auth-form input:focus{outline:none;border-color:var(--emerald-line);
  box-shadow:0 0 0 3px var(--emerald-soft)}

/* ── Sidebar user badge ─────────────────────────────────── */
.side-user{
  margin-top:12px;padding-top:12px;border-top:1px solid var(--line);
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
}
.side-user-name{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  color:var(--text-2);flex:1;min-width:0;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
