:root {
    --bg-0: #07080d;
    --bg-1: #0c0e16;
    --bg-2: #11141e;
    --panel: rgba(22, 25, 36, 0.72);
    --panel-solid: #161924;
    --panel-2: #1c2030;
    --line: rgba(255, 255, 255, 0.07);
    --line-2: rgba(255, 255, 255, 0.14);
    --text: #e9ecf3;
    --text-dim: #b6bdcc;
    --muted: #8a93a6;
    --muted-2: #5c6577;
    --accent: #7aa7ff;
    --accent-2: #a78bfa;
    --warn: #ff8a65;
    --danger: #ff5470;
    --ok: #4ade80;
    --gold: #facc15;
    --gmail: #ea4335;
    --calendar: #4285f4;
    --granola: #b07ad8;
    --plaud: #f0a830;
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
    margin: 0;
    color: var(--text);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Inter, Roboto, sans-serif;
    line-height: 1.45;
    font-size: 14px;
    background:
      radial-gradient(1200px 600px at 8% -10%, rgba(122,167,255,0.10), transparent 60%),
      radial-gradient(1000px 500px at 100% 10%, rgba(167,139,250,0.10), transparent 60%),
      radial-gradient(900px 600px at 50% 110%, rgba(76,222,128,0.06), transparent 60%),
      linear-gradient(180deg, var(--bg-0), var(--bg-1));
    min-height: 100%;
}

/* ---------- Top bar ---------- */
.topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 28px;
    border-bottom: 1px solid var(--line);
    background: rgba(10, 12, 18, 0.55);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    position: sticky; top: 0; z-index: 10;
}
.brand { display: flex; align-items: center; gap: 12px; }
.brand h1 {
    font-size: 16px; font-weight: 700; margin: 0;
    letter-spacing: 0.04em; text-transform: uppercase;
}
.brand .sub {
    font-size: 11px; color: var(--muted); margin-left: 6px;
    letter-spacing: 0.12em; text-transform: uppercase;
}
.logo-dot {
    width: 14px; height: 14px; border-radius: 50%;
    background: conic-gradient(from 0deg, var(--accent), var(--accent-2), var(--ok), var(--gold), var(--accent));
    box-shadow: 0 0 16px rgba(122,167,255,0.6);
    animation: spin 8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

.topbar-right { display: flex; align-items: center; gap: 14px; }
.clock {
    font-variant-numeric: tabular-nums;
    font-weight: 600;
    font-size: 13px;
    color: var(--text-dim);
    padding: 6px 12px;
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 8px;
}
.clock .date { color: var(--muted); margin-left: 8px; font-weight: 400; }
.sync-btn {
    background: linear-gradient(135deg, var(--accent), var(--accent-2));
    color: #0c1018;
    border: 0; padding: 9px 16px; border-radius: 8px;
    font-weight: 700; font-size: 13px;
    cursor: pointer;
    box-shadow: 0 4px 14px rgba(122,167,255,0.30);
    transition: transform .12s ease, box-shadow .12s ease;
}
.sync-btn:hover { transform: translateY(-1px); box-shadow: 0 6px 22px rgba(122,167,255,0.45); }
.sync-btn:active { transform: translateY(0); }

.logout-form { margin: 0; }
.logout-btn {
    background: transparent;
    color: var(--muted);
    border: 1px solid rgba(255,255,255,0.08);
    padding: 7px 12px; border-radius: 8px;
    font-size: 12px; font-weight: 500;
    cursor: pointer;
    transition: color .12s ease, border-color .12s ease, background .12s ease;
}
.logout-btn:hover { color: var(--text); border-color: rgba(255,255,255,0.18); background: var(--panel-2); }

/* ---------- Top nav ---------- */
.topnav {
    display: flex; gap: 4px;
}
.topnav a {
    color: var(--muted); text-decoration: none;
    padding: 6px 12px; border-radius: 6px;
    font-size: 13px; font-weight: 500;
}
.topnav a:hover { color: var(--text); background: var(--panel-2); }
.topnav a.active { color: var(--text); background: var(--panel-2); }

.plaud-page { max-width: 920px; margin: 0 auto; }
.plaud-page .card-head h2 { color: var(--plaud); }

/* ---------- Container ---------- */
.container { padding: 24px 28px 80px; max-width: 1480px; margin: 0 auto; }

/* ---------- Greeting + hero ---------- */
.greeting {
    display: flex; align-items: end; justify-content: space-between;
    margin-bottom: 18px;
}
.greeting h2 {
    margin: 0; font-size: 24px; font-weight: 700; letter-spacing: -0.01em;
}
.greeting h2 .accent {
    background: linear-gradient(120deg, var(--accent) 0%, var(--accent-2) 70%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.greeting .tag {
    font-size: 12px; color: var(--muted); letter-spacing: 0.04em;
}

.hero {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    margin-bottom: 18px;
}
.hero-card {
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 16px 18px;
    position: relative;
    overflow: hidden;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}
.hero-card::after {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(255,255,255,0.04), transparent 60%);
    pointer-events: none;
}
.hero-card .label {
    font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
    color: var(--muted);
}
.hero-card .value {
    font-size: 36px; font-weight: 800; margin-top: 6px;
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.02em;
}
.hero-card .hint { font-size: 12px; color: var(--text-dim); margin-top: 4px; }
.hero-card .hint .up { color: var(--ok); }
.hero-card .hint .down { color: var(--danger); }
.hero-card .accent-bar {
    position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
    background: linear-gradient(180deg, var(--accent), var(--accent-2));
}
.hero-card.warn .accent-bar { background: linear-gradient(180deg, var(--warn), var(--danger)); }
.hero-card.ok   .accent-bar { background: linear-gradient(180deg, var(--ok), #22c55e); }
.hero-card.cool .accent-bar { background: linear-gradient(180deg, var(--accent-2), #ec4899); }

.hero-card .spark {
    margin-top: 8px; width: 100%; height: 36px; display: block;
}

/* ---------- Stats row ---------- */
.stats-row {
    display: grid;
    grid-template-columns: 1.2fr 1fr 1fr;
    gap: 14px;
    margin-bottom: 18px;
}
.panel {
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 16px 18px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    display: flex; flex-direction: column;
}
.panel-head {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 12px;
}
.panel-head h3 {
    font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
    margin: 0; color: var(--muted); font-weight: 600;
}
.panel-head .badge-soft {
    font-size: 11px; color: var(--text-dim);
    background: rgba(255,255,255,0.05);
    padding: 2px 8px; border-radius: 10px;
    border: 1px solid var(--line);
}

/* Donut chart */
.donut-wrap {
    display: flex; align-items: center; gap: 16px;
}
.donut { width: 120px; height: 120px; flex-shrink: 0; }
.donut text {
    font-size: 18px; font-weight: 700; fill: var(--text);
    font-variant-numeric: tabular-nums;
}
.donut text.label-sm { font-size: 9px; fill: var(--muted); font-weight: 500; letter-spacing: 0.1em; }
.legend { list-style: none; padding: 0; margin: 0; flex: 1; display: flex; flex-direction: column; gap: 6px; }
.legend li { display: flex; align-items: center; gap: 8px; font-size: 12px; }
.legend .dot { width: 8px; height: 8px; border-radius: 2px; flex-shrink: 0; }
.legend .name { flex: 1; color: var(--text-dim); }
.legend .num { font-variant-numeric: tabular-nums; color: var(--text); font-weight: 600; }

/* Due distribution bars */
.bars { display: flex; flex-direction: column; gap: 8px; }
.bar-row { display: grid; grid-template-columns: 88px 1fr 28px; align-items: center; gap: 10px; }
.bar-row .label { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; }
.bar-row .track {
    height: 8px; background: rgba(255,255,255,0.05);
    border-radius: 100px; overflow: hidden; position: relative;
}
.bar-row .fill {
    height: 100%; border-radius: 100px;
    background: linear-gradient(90deg, var(--accent), var(--accent-2));
}
.bar-row.warn .fill   { background: linear-gradient(90deg, var(--warn), var(--danger)); }
.bar-row.today .fill  { background: linear-gradient(90deg, var(--gold), var(--warn)); }
.bar-row.week .fill   { background: linear-gradient(90deg, var(--accent), #22d3ee); }
.bar-row.later .fill  { background: linear-gradient(90deg, var(--accent-2), #ec4899); }
.bar-row.none .fill   { background: linear-gradient(90deg, #475569, #64748b); }
.bar-row .num { font-variant-numeric: tabular-nums; font-weight: 700; font-size: 13px; text-align: right; }

/* Progress ring */
.ring-wrap { display: flex; align-items: center; gap: 16px; }
.ring { width: 120px; height: 120px; flex-shrink: 0; transform: rotate(-90deg); }
.ring-bg { fill: none; stroke: rgba(255,255,255,0.06); stroke-width: 10; }
.ring-fg { fill: none; stroke: url(#ringGrad); stroke-width: 10; stroke-linecap: round;
           transition: stroke-dashoffset 1s ease; }
.ring-center { transform: rotate(90deg); transform-origin: center; }
.ring-num { font-size: 22px; font-weight: 800; font-variant-numeric: tabular-nums; }
.ring-meta { display: flex; flex-direction: column; gap: 4px; }
.ring-meta .big { font-size: 22px; font-weight: 800; font-variant-numeric: tabular-nums; }
.ring-meta .sub { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; }

/* ---------- Focus + waiting row ---------- */
.focus-row {
    display: grid;
    grid-template-columns: 1.6fr 1fr;
    gap: 14px;
    margin-bottom: 18px;
}
.focus-row .panel { padding: 18px 20px; }
.focus-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.focus-item {
    display: grid; grid-template-columns: auto 1fr auto auto; gap: 12px; align-items: center;
    padding: 10px 12px;
    background: rgba(255,255,255,0.02);
    border: 1px solid var(--line);
    border-radius: 10px;
    transition: background .12s, border-color .12s, transform .12s;
}
.focus-item:hover { background: rgba(255,255,255,0.04); border-color: var(--line-2); transform: translateX(2px); }
.focus-item.overdue { border-color: rgba(255,84,112,0.35); }
.focus-item .source-chip {
    width: 26px; height: 26px; border-radius: 8px;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 11px; font-weight: 800; letter-spacing: 0; flex-shrink: 0;
    color: #0a0d14;
}
.focus-item .source-chip.gmail    { background: var(--gmail); }
.focus-item .source-chip.calendar { background: var(--calendar); color: white; }
.focus-item .source-chip.granola  { background: var(--granola); color: white; }
.focus-item .source-chip.plaud    { background: var(--plaud); }
.focus-item .focus-title {
    font-size: 13.5px; color: var(--text);
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.focus-item .focus-title a { color: inherit; text-decoration: none; }
.focus-item .focus-title a:hover { color: var(--accent); }
.focus-item .focus-meta {
    font-size: 11px; color: var(--muted);
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.focus-item .due-pill {
    font-size: 11px; padding: 3px 9px; border-radius: 100px;
    font-weight: 600; font-variant-numeric: tabular-nums;
    background: rgba(122,167,255,0.12); color: var(--accent);
    white-space: nowrap;
}
.focus-item .due-pill.overdue { background: rgba(255,84,112,0.15); color: var(--danger); }
.focus-item .due-pill.today   { background: rgba(250,204,21,0.15); color: var(--gold); }

.waiting-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.waiting-item {
    padding: 10px 12px;
    border: 1px solid var(--line); border-radius: 10px;
    background: rgba(255,255,255,0.02);
    display: flex; align-items: center; gap: 10px;
}
.waiting-item .wt-title { font-size: 13px; color: var(--text-dim); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1; }
.waiting-item .wt-tag {
    font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--granola); background: rgba(176,122,216,0.12);
    padding: 3px 7px; border-radius: 100px;
}
.empty-soft { color: var(--muted); font-size: 13px; font-style: italic; padding: 14px 4px; }

/* ---------- Source grid ---------- */
.grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(330px, 1fr));
    gap: 14px;
}
.card {
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 16px 18px;
    display: flex; flex-direction: column;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    position: relative;
    overflow: hidden;
}
.card::before {
    content: "";
    position: absolute; top: 0; left: 0; right: 0; height: 2px;
    background: var(--line);
}
.card.source-gmail::before    { background: linear-gradient(90deg, var(--gmail), transparent); }
.card.source-calendar::before { background: linear-gradient(90deg, var(--calendar), transparent); }
.card.source-granola::before  { background: linear-gradient(90deg, var(--granola), transparent); }
.card.source-plaud::before    { background: linear-gradient(90deg, var(--plaud), transparent); }

.card-head {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 10px;
}
.card-head .left { display: flex; align-items: center; gap: 10px; }
.card-head h2 {
    font-size: 12px; font-weight: 700; margin: 0;
    letter-spacing: 0.12em; text-transform: uppercase; color: var(--text);
}
.card-head .src-dot {
    width: 8px; height: 8px; border-radius: 50%;
}
.source-gmail    .src-dot { background: var(--gmail); box-shadow: 0 0 8px var(--gmail); }
.source-calendar .src-dot { background: var(--calendar); box-shadow: 0 0 8px var(--calendar); }
.source-granola  .src-dot { background: var(--granola); box-shadow: 0 0 8px var(--granola); }
.source-plaud    .src-dot { background: var(--plaud); box-shadow: 0 0 8px var(--plaud); }

.count {
    background: rgba(255,255,255,0.05);
    border: 1px solid var(--line);
    padding: 3px 10px; border-radius: 100px;
    font-size: 12px; font-weight: 700;
    font-variant-numeric: tabular-nums;
}

.meta { font-size: 11px; color: var(--muted); margin: 0 0 12px; letter-spacing: 0.02em; }
.meta-warn { color: var(--warn); }

.todos { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.todo {
    display: flex; align-items: flex-start; gap: 10px;
    background: rgba(255,255,255,0.02);
    border: 1px solid var(--line); border-radius: 10px;
    padding: 9px 12px;
    transition: background .12s, border-color .12s, transform .12s;
}
.todo:hover { background: rgba(255,255,255,0.05); border-color: var(--line-2); }
.todo-main { flex: 1; min-width: 0; }
.todo-title { font-size: 13.5px; line-height: 1.35; }
.todo-title a { color: var(--text); text-decoration: none; }
.todo-title a:hover { color: var(--accent); }
.todo-meta { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 5px; font-size: 11px; color: var(--muted); }
.todo-notes { color: var(--muted); font-size: 11px; font-style: italic; }

.badge {
    display: inline-block; padding: 2px 8px; border-radius: 100px;
    background: rgba(122,167,255,0.12); color: var(--accent);
    font-size: 10.5px; font-weight: 600;
    letter-spacing: 0.02em;
}
.badge-warn { background: rgba(255,138,101,0.16); color: var(--warn); }
.badge-waiting { background: rgba(176,122,216,0.18); color: var(--granola); }
.badge-project { background: rgba(74,222,128,0.14); color: var(--ok); }

.waiting .todo-title { color: var(--muted); }
.overdue { border-color: rgba(255,84,112,0.30); }

.todo-actions { flex-shrink: 0; }
.done-btn {
    background: transparent; color: var(--muted);
    border: 1px solid var(--line); width: 28px; height: 28px;
    border-radius: 8px; cursor: pointer; font-size: 14px;
    transition: color .12s, border-color .12s, background .12s, transform .12s;
}
.done-btn:hover { color: var(--ok); border-color: var(--ok); background: rgba(74,222,128,0.08); transform: scale(1.05); }

.empty { color: var(--muted); font-style: italic; font-size: 13px; padding: 6px 0; }

/* ---------- Projects strip (optional bottom) ---------- */
.projects-strip {
    margin-top: 18px;
}
.proj-list { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.proj-pill {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--line);
    padding: 6px 12px; border-radius: 100px;
    font-size: 12px;
}
.proj-pill .nm { color: var(--text-dim); }
.proj-pill .n {
    font-variant-numeric: tabular-nums; font-weight: 700;
    color: var(--accent);
    background: rgba(122,167,255,0.10);
    padding: 1px 7px; border-radius: 100px;
    font-size: 11px;
}

/* ---------- Priority pills + action buttons ---------- */
.prio-pill {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 28px; height: 22px;
    padding: 0 8px;
    border-radius: 100px;
    font-size: 11px; font-weight: 800;
    letter-spacing: 0.04em;
    font-variant-numeric: tabular-nums;
    background: rgba(255,255,255,0.05);
    color: var(--text-dim);
    border: 1px solid var(--line);
}
.prio-pill.p5 { background: linear-gradient(135deg, rgba(255,84,112,0.20), rgba(255,138,101,0.20)); color: var(--danger); border-color: rgba(255,84,112,0.30); }
.prio-pill.p4 { background: rgba(255,138,101,0.16); color: var(--warn); border-color: rgba(255,138,101,0.30); }
.prio-pill.p3 { background: rgba(250,204,21,0.14); color: var(--gold); border-color: rgba(250,204,21,0.28); }
.prio-pill.p2 { background: rgba(122,167,255,0.12); color: var(--accent); border-color: rgba(122,167,255,0.20); }
.prio-pill.p1 { background: rgba(140,150,170,0.10); color: var(--muted); }

.triage-notes {
    color: var(--text-dim); font-style: italic;
}

.focus-pills {
    display: flex; align-items: center; gap: 6px;
    flex-wrap: wrap; justify-content: flex-end;
}
.focus-actions-row, .todo-actions-row, .today-actions {
    display: flex; align-items: center; gap: 6px; flex-shrink: 0;
}
.mini-btn {
    display: inline-flex; align-items: center; justify-content: center;
    height: 26px; padding: 0 10px;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--line);
    border-radius: 8px;
    font-size: 11px; font-weight: 600;
    color: var(--text-dim);
    text-decoration: none;
    letter-spacing: 0.02em;
    cursor: pointer;
    transition: background .12s, color .12s, border-color .12s, transform .12s;
}
.mini-btn:hover {
    color: var(--text); border-color: var(--line-2);
    background: rgba(255,255,255,0.08); transform: translateY(-1px);
}
.todo-actions.inline { display: inline-flex; }

/* Adjust focus-item grid to accommodate pills + actions cleanly */
.focus-item { grid-template-columns: auto 1fr auto auto; }
.focus-item .focus-pills + .focus-actions-row { margin-left: 0; }

.drop-btn:hover { color: var(--danger); border-color: var(--danger); background: rgba(255,84,112,0.08); }

/* ---------- Today page ---------- */
.today-hero { margin-bottom: 18px; }
.today-list {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: 8px;
    counter-reset: today;
}
.today-item {
    display: grid;
    grid-template-columns: 28px auto 1fr auto auto;
    gap: 12px; align-items: center;
    padding: 12px 14px;
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--line);
    border-radius: 12px;
    transition: background .12s, border-color .12s;
}
.today-item:hover {
    background: rgba(255,255,255,0.05);
    border-color: var(--line-2);
}
.today-item.overdue { border-color: rgba(255,84,112,0.30); }
.today-item .num {
    width: 28px; height: 28px; border-radius: 8px;
    background: linear-gradient(135deg, var(--accent), var(--accent-2));
    color: #0a0d14;
    display: inline-flex; align-items: center; justify-content: center;
    font-weight: 800; font-size: 13px;
    font-variant-numeric: tabular-nums;
}
.today-item .today-body { min-width: 0; }
.today-item .today-body .focus-title {
    font-size: 14.5px;
    white-space: normal;
    overflow: visible;
    text-overflow: initial;
}
.today-item .today-body .focus-meta { font-size: 11.5px; margin-top: 3px; }

.today-secondary {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-top: 14px;
}
.stale-strip { margin-top: 14px; border-color: rgba(140,150,170,0.20); }
.focus-item.stale { opacity: 0.85; }

/* ---------- Review page ---------- */
.review-cols {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 14px;
    margin-bottom: 14px;
}
.closed-list { max-height: 540px; overflow-y: auto; }

/* ---------- Draft reply page ---------- */
.draft-panel { margin-bottom: 14px; }
.draft-action { padding: 6px 2px; }
.draft-fields {
    display: flex; flex-direction: column; gap: 10px;
    margin-bottom: 14px;
}
.draft-fields label {
    display: flex; flex-direction: column; gap: 4px;
    font-size: 11px;
    color: var(--muted);
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
.draft-fields input,
.draft-fields textarea {
    background: var(--bg-2);
    border: 1px solid var(--line);
    border-radius: 8px;
    color: var(--text);
    padding: 10px 12px;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 13px;
    line-height: 1.5;
    resize: vertical;
}
.draft-fields input:focus,
.draft-fields textarea:focus {
    outline: none; border-color: var(--accent);
}
.draft-actions {
    display: flex; align-items: center; gap: 8px;
    flex-wrap: wrap;
}
.sync-btn.ghost {
    background: var(--panel);
    color: var(--text);
    box-shadow: none;
    border: 1px solid var(--line-2);
    text-decoration: none;
    display: inline-flex; align-items: center;
}
.sync-btn.ghost:hover { background: var(--panel-2); border-color: var(--accent); color: var(--accent); }

/* ---------- Search ---------- */
.search-form {
    display: flex; align-items: center; gap: 12px;
    margin: 0 0 18px;
}
.search-input {
    flex: 1; max-width: 640px;
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 10px 14px;
    font-size: 13.5px;
    color: var(--text);
    outline: none;
    transition: border-color .12s, box-shadow .12s, background .12s;
}
.search-input::placeholder { color: var(--muted-2); }
.search-input:focus {
    border-color: var(--accent);
    background: rgba(122,167,255,0.06);
    box-shadow: 0 0 0 3px rgba(122,167,255,0.16);
}
.search-clear {
    color: var(--muted); text-decoration: none;
    font-size: 12px; font-weight: 600;
    padding: 6px 10px; border-radius: 6px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,0.03);
}
.search-clear:hover { color: var(--text); border-color: var(--line-2); }
.search-meta {
    font-size: 11.5px; color: var(--muted);
    letter-spacing: 0.04em;
}

/* ---------- Plaud meetings ---------- */
.summary {
    display: flex; gap: 14px; margin-bottom: 16px;
}
.summary .stat {
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 12px 18px;
    min-width: 120px;
}
.summary .stat-num {
    font-size: 24px; font-weight: 800;
    font-variant-numeric: tabular-nums;
    color: var(--plaud);
}
.summary .stat-label {
    font-size: 11px; letter-spacing: 0.12em;
    text-transform: uppercase; color: var(--muted);
}

.meetings {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-direction: column; gap: 10px;
}
.meeting {
    background: rgba(255,255,255,0.02);
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 14px 16px;
    transition: background .12s, border-color .12s;
}
.meeting:hover { background: rgba(255,255,255,0.04); border-color: var(--line-2); }
.meeting-head {
    display: flex; flex-direction: column; gap: 6px;
    margin-bottom: 8px;
}
.meeting-title {
    font-size: 14.5px; font-weight: 600; color: var(--text);
}
.meeting-title a { color: inherit; text-decoration: none; }
.meeting-title a:hover { color: var(--plaud); }
.meeting-meta {
    display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
    font-size: 11px; color: var(--muted);
}
.meeting-filename {
    color: var(--muted); font-size: 11px; font-style: italic;
}
.meeting-summary {
    color: var(--text-dim); font-size: 13px;
    white-space: pre-wrap; line-height: 1.55;
    border-top: 1px dashed var(--line);
    padding-top: 10px; margin-top: 4px;
    max-height: 320px; overflow-y: auto;
}

/* ---------- Responsive ---------- */
@media (max-width: 1100px) {
    .hero { grid-template-columns: repeat(2, 1fr); }
    .stats-row { grid-template-columns: 1fr; }
    .focus-row { grid-template-columns: 1fr; }
    .today-secondary { grid-template-columns: 1fr; }
    .review-cols { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
    .hero { grid-template-columns: 1fr 1fr; }
    .container { padding: 16px 16px 60px; }
    .greeting { flex-direction: column; align-items: flex-start; gap: 6px; }
    .topbar { padding: 12px 16px; }
    .clock .date { display: none; }
    .focus-item { grid-template-columns: auto 1fr auto; row-gap: 6px; }
    .focus-item .focus-pills,
    .focus-item .focus-actions-row { grid-column: 1 / -1; justify-content: flex-end; }
    .today-item { grid-template-columns: 28px auto 1fr; }
    .today-item .prio-pill,
    .today-item .today-actions { grid-column: 1 / -1; justify-content: flex-end; }
}
