﻿:root {
  --bg: #26211d;
  --bg-2: #302925;
  --fg: #f6f0e8;
  --muted-fg: #b8aea1;
  --card: #342d28;
  --card-2: #3c3530;
  --border: #514741;
  --primary: #8a7cec;
  --primary-2: #6d61d5;
  --success: #7fb396;
  --warning: #e2b167;
  --danger: #df7b6f;
  --radius: 14px;
  --shadow-lg: 0 18px 40px rgba(20, 14, 10, 0.24);
  --shadow-sm: 0 10px 24px rgba(20, 14, 10, 0.17);
  --transition: all .2s ease;
  --font-display: 'Space Grotesk', sans-serif;
  --font-body: 'Inter', sans-serif;
}

.light {
  --bg: #f6efe7;
  --bg-2: #fffdf9;
  --fg: #1f1a17;
  --muted-fg: #776b61;
  --card: #fffdfa;
  --card-2: #f3ece4;
  --border: #e7dbcf;
  --primary: #7a6fe1;
  --primary-2: #655bc9;
  --success: #67956f;
  --warning: #d59d49;
  --danger: #cf6c60;
  --shadow-lg: 0 18px 34px rgba(57, 42, 26, 0.09);
  --shadow-sm: 0 8px 20px rgba(57, 42, 26, 0.06);
}

.dark {
  --bg: #26211d;
  --bg-2: #302925;
  --fg: #f6f0e8;
  --muted-fg: #b8aea1;
  --card: #342d28;
  --card-2: #3c3530;
  --border: #514741;
  --primary: #8a7cec;
  --primary-2: #6d61d5;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { min-height: 100%; }
html {
  background: #26211d;
  color-scheme: dark;
}
html.light {
  background: #f6efe7;
  color-scheme: light;
}
html.dark {
  background: #26211d;
  color-scheme: dark;
}
body {
  font-family: var(--font-body);
  background: linear-gradient(180deg, var(--bg), var(--bg-2));
  color: var(--fg);
  line-height: 1.45;
  transition: var(--transition);
}

html.auth-pending #app {
  visibility: hidden;
}

body.auth-locked {
  overflow: hidden;
}

body.auth-locked #app {
  visibility: hidden;
}

body.light {
  background: linear-gradient(180deg, var(--bg), var(--bg-2));
}
h1, h2, h3, h4 { font-family: var(--font-display); }

::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-thumb { background: color-mix(in srgb, var(--primary) 36%, var(--border)); border-radius: 999px; }
::-webkit-scrollbar-track { background: transparent; }

.auth-gate {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(8, 10, 14, 0.62);
  backdrop-filter: blur(10px);
}

.auth-shell {
  width: min(560px, 100%);
}

.auth-card {
  display: grid;
  gap: 20px;
  padding: 28px;
  border: 1px solid var(--border);
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--primary) 10%, transparent), transparent 32%),
    linear-gradient(180deg, color-mix(in srgb, var(--card) 98%, #ffffff), var(--card));
  box-shadow: var(--shadow-lg);
}

.auth-hero {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}

.auth-brand-mark {
  width: 54px;
  height: 54px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  font-size: 24px;
  font-weight: 800;
  color: #fff;
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  box-shadow: 0 14px 26px color-mix(in srgb, var(--primary) 24%, transparent);
}

.auth-copy {
  display: grid;
  gap: 8px;
}

.auth-eyebrow {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--warning);
}

.auth-title {
  font-size: clamp(28px, 3vw, 34px);
  line-height: 1.02;
  letter-spacing: -0.04em;
}

.auth-text {
  color: var(--muted-fg);
  line-height: 1.6;
}

.auth-divider {
  height: 1px;
  background: color-mix(in srgb, var(--border) 84%, transparent);
}

.auth-panel {
  display: grid;
  gap: 16px;
  padding: 18px;
  border: 1px solid color-mix(in srgb, var(--border) 88%, transparent);
  border-radius: 22px;
  background: color-mix(in srgb, var(--card-2) 54%, transparent);
}

.auth-panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.auth-panel-title {
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -0.03em;
}

.auth-panel-copy {
  margin-top: 4px;
  color: var(--muted-fg);
  font-size: 13px;
}

.auth-chip {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--border) 88%, transparent);
  background: color-mix(in srgb, var(--card) 72%, transparent);
  font-size: 11px;
  font-weight: 700;
  color: var(--muted-fg);
}

.auth-form {
  display: grid;
  gap: 12px;
}

.auth-field {
  display: grid;
  gap: 6px;
}

.auth-field > span {
  font-size: 12px;
  font-weight: 700;
  color: var(--muted-fg);
}

.auth-field input {
  min-height: 48px;
  padding: 0 14px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--border) 92%, transparent);
  background: color-mix(in srgb, var(--card) 80%, transparent) !important;
  color: var(--fg);
  box-shadow: none;
}

.auth-field input::placeholder {
  color: color-mix(in srgb, var(--muted-fg) 84%, transparent);
}

.auth-field input:focus {
  border-color: color-mix(in srgb, var(--primary) 42%, var(--border));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--primary) 12%, transparent);
}

.auth-field input:-webkit-autofill,
.auth-field input:-webkit-autofill:hover,
.auth-field input:-webkit-autofill:focus {
  -webkit-text-fill-color: var(--fg);
  -webkit-box-shadow: 0 0 0 1000px color-mix(in srgb, var(--card) 80%, transparent) inset;
  transition: background-color 9999s ease-in-out 0s;
}

.auth-error {
  font-size: 12px;
  color: var(--danger);
  padding-top: 2px;
}

.auth-submit {
  min-height: 48px;
  margin-top: 6px;
  border-radius: 16px;
  font-size: 14px;
}

.auth-footnote {
  color: var(--muted-fg);
  font-size: 12px;
  line-height: 1.5;
}

.light .auth-gate {
  background: rgba(246, 238, 228, 0.74);
}

.light .auth-card {
  background:
    radial-gradient(circle at top right, rgba(122, 111, 225, 0.12), transparent 34%),
    linear-gradient(180deg, #fffdfa, #faf5ef);
}

.light .auth-panel {
  background: linear-gradient(180deg, #fffdfa, #f6efe7);
  border-color: #e7dbcf;
}

.dark .auth-card {
  background:
    radial-gradient(circle at top right, rgba(138,124,236,0.14), transparent 34%),
    linear-gradient(180deg, #3a322d, #332c27);
}

.dark .auth-panel {
  background: linear-gradient(180deg, rgba(47,40,35,0.84), rgba(56,48,42,0.84));
  border-color: #4b433d;
}

@media (max-width: 640px) {
  .auth-card {
    padding: 22px;
    border-radius: 22px;
  }

  .auth-hero {
    grid-template-columns: 1fr;
  }

  .auth-brand-mark {
    width: 48px;
    height: 48px;
    border-radius: 16px;
  }

  .auth-panel {
    padding: 16px;
  }
}

.container {
  max-width: 1620px;
  margin: 0 auto;
  padding: 20px 18px 64px;
}

.space-y > * + * { margin-top: 18px; }
.space-y-sm > * + * { margin-top: 10px; }
.text-xs { font-size: 11px; }
.text-sm { font-size: 13px; }
.text-lg { font-size: 18px; font-weight: 700; }
.text-muted { color: var(--muted-fg); }
.text-center { text-align: center; }
.ml-auto { margin-left: auto; }
.w-full { width: 100%; }
.truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.flex { display: flex; }
.flex-1 { flex: 1; }
.flex-wrap { flex-wrap: wrap; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }
.justify-center { justify-content: center; }
.gap-1 { gap: 4px; }
.gap-2 { gap: 8px; }
.gap-3 { gap: 12px; }
.gap-4 { gap: 16px; }
.grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.grid-7 { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); }

.card {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: linear-gradient(180deg, color-mix(in srgb, var(--card) 98%, #fffaf4), var(--card));
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.card-header {
  border-bottom: 1px solid var(--border);
  padding: 14px 16px;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  background: color-mix(in srgb, var(--card-2) 70%, transparent);
}

.card-body {
  padding: 16px;
}

.card-section .card-body {
  padding: 14px 16px 16px;
}

.card-section-compact .card-body {
  padding: 12px 16px 16px;
}

.section-intro {
  margin-top: 2px;
  font-size: 12px;
  color: var(--muted-fg);
}

.section-body-compact {
  padding: 12px 16px 16px;
}

.badge {
  font-size: 11px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--card-2) 75%, transparent);
  color: var(--fg);
}

.badge-success {
  color: #d8ffea;
  background: color-mix(in srgb, var(--success) 28%, var(--card));
  border-color: color-mix(in srgb, var(--success) 46%, var(--border));
}

.badge-warning {
  color: #fff4dd;
  background: color-mix(in srgb, var(--warning) 28%, var(--card));
  border-color: color-mix(in srgb, var(--warning) 46%, var(--border));
}

.badge-calendar-lifeos {
  color: #dce8ff;
  background: color-mix(in srgb, var(--primary) 18%, var(--card));
  border-color: color-mix(in srgb, var(--primary) 42%, var(--border));
}

.badge-calendar-synced {
  color: #fff8da;
  background: color-mix(in srgb, #ffd84d 22%, var(--card));
  border-color: color-mix(in srgb, #ffd84d 46%, var(--border));
}



.light .badge-destructive {
  color: #8f2033;
  background: linear-gradient(135deg, color-mix(in srgb, var(--danger) 24%, #ffffff), color-mix(in srgb, var(--danger) 14%, var(--card)));
  border-color: color-mix(in srgb, var(--danger) 34%, var(--border));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.5);
}

input[type='text'],
input[type='search'],
input[type='date'],
input[type='time'],
input[type='url'],
input[type='number'],
textarea,
select {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 9px 11px;
  font-size: 13px;
  background: color-mix(in srgb, var(--card) 90%, #18120f);
  color: var(--fg);
  outline: none;
  transition: var(--transition);
}

input:focus,
textarea:focus,
select:focus {
  border-color: color-mix(in srgb, var(--primary) 70%, var(--border));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 18%, transparent);
}

textarea {
  resize: vertical;
  min-height: 88px;
}

.btn {
  border: 1px solid transparent;
  border-radius: 10px;
  padding: 8px 12px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-decoration: none;
}

.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); filter: brightness(1.04); }

.btn-primary {
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  color: #ffffff;
  border-color: color-mix(in srgb, var(--primary) 55%, var(--border));
}

.btn-ghost {
  background: color-mix(in srgb, var(--card-2) 92%, transparent);
  color: var(--fg);
  border-color: var(--border);
}

#themeBtn {
  min-width: 118px;
  justify-content: center;
  font-weight: 700;
}

#themeBtn.is-active {
  border-color: color-mix(in srgb, var(--primary) 48%, var(--border));
  background: linear-gradient(135deg, color-mix(in srgb, var(--primary) 18%, var(--card)), color-mix(in srgb, var(--card-2) 82%, transparent));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--primary) 16%, transparent);
}



.light .btn-danger {
  background: linear-gradient(135deg, color-mix(in srgb, var(--danger) 72%, #ffffff), color-mix(in srgb, var(--danger) 56%, var(--card)));
  color: #fff;
  border-color: color-mix(in srgb, var(--danger) 62%, var(--border));
  box-shadow: 0 8px 18px rgba(239, 95, 113, 0.16);
}

.btn-sm { padding: 6px 10px; font-size: 12px; }
.btn-icon { width: 34px; height: 34px; padding: 0; }

.delete-btn {
  border: none;
  background: transparent;
  color: var(--muted-fg);
  cursor: pointer;
  border-radius: 8px;
  padding: 4px 6px;
  font-size: 14px;
}

.delete-btn:hover {
  background: color-mix(in srgb, var(--danger) 16%, transparent);
  color: #ffd0d8;
}

.search-bar { position: relative; }
.search-bar input { padding-left: 34px; }
.search-bar::before {
  content: "\2315";
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 13px;
  color: var(--muted-fg);
}

.dot { width: 8px; height: 8px; border-radius: 99px; display: inline-block; }
.dot-green { background: var(--success); }
.dot-red { background: var(--danger); }

.command-header {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 16px;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 16px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--card-2) 95%, #4d382a), var(--card));
  box-shadow: var(--shadow-lg);
}

.header-title-block { display: grid; gap: 2px; }
.brand-title { font-size: 30px; letter-spacing: -0.02em; }
.welcome-line { font-size: 16px; color: var(--muted-fg); }
#welcomeName { color: var(--primary); outline: none; }
.status-line { display: flex; align-items: center; gap: 6px; margin-top: 4px; }

.header-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
}

.command-search { min-width: 330px; }

.dashboard-top-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
}

.widget-card { min-height: 0; }
.widget-card .card-body { padding: 14px 16px; }
.widget-subtext { margin-top: 8px; font-size: 12px; color: var(--muted-fg); }
.dashboard-progress {
  margin-top: 12px;
  display: grid;
  gap: 10px;
}

.dashboard-progress-block {
  display: grid;
  gap: 6px;
}

.focus-indicator {
  font-size: 11px;
  color: var(--muted-fg);
  padding: 6px 8px;
  border-radius: 9px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--card-2) 45%, transparent);
}

.light .header-controls {
  background: linear-gradient(180deg, rgba(255,253,249,0.9), rgba(247,240,231,0.96));
  border-color: color-mix(in srgb, var(--warning) 14%, var(--border));
  box-shadow: 0 10px 24px rgba(122, 88, 48, 0.08);
}

.light .btn-ghost {
  background: color-mix(in srgb, #fffdfa 82%, var(--card-2));
  border-color: color-mix(in srgb, var(--border) 88%, #fff8f0);
}

.light #themeBtn {
  border-color: color-mix(in srgb, var(--primary) 34%, var(--border));
  background: linear-gradient(135deg, rgba(255,252,247,0.98), rgba(244,236,228,0.98));
  color: color-mix(in srgb, var(--primary) 72%, var(--fg));
}

.light #themeBtn.is-active {
  border-color: color-mix(in srgb, var(--primary) 56%, var(--border));
  background: linear-gradient(135deg, color-mix(in srgb, var(--primary) 18%, #fffdfa), color-mix(in srgb, var(--card-2) 85%, #fff7ee));
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--primary) 18%, transparent),
    0 10px 20px rgba(98, 79, 179, 0.12);
}

.focus-indicator.is-ready {
  color: #dce8ff;
  border-color: color-mix(in srgb, var(--primary) 55%, var(--border));
  background: color-mix(in srgb, var(--primary) 18%, var(--card));
}

.mini-list { list-style: none; display: grid; gap: 8px; }
.mini-list li {
  font-size: 12px;
  padding: 6px 8px;
  border-radius: 9px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--card-2) 45%, transparent);
}

.dashboard-card-list {
  display: grid;
  gap: 10px;
}

.dashboard-item-card,
.dashboard-empty {
  border: 1px solid var(--border);
  border-radius: 12px;
  background: color-mix(in srgb, var(--card-2) 44%, transparent);
}

.dashboard-item-card {
  padding: 11px 12px;
  display: grid;
  gap: 7px;
}

.dashboard-empty {
  padding: 10px 12px;
  font-size: 12px;
  color: var(--muted-fg);
}

.dashboard-item-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.dashboard-item-title {
  min-width: 0;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.35;
}

.dashboard-item-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
  flex-shrink: 0;
}

.dashboard-item-meta {
  font-size: 12px;
  color: color-mix(in srgb, var(--fg) 90%, var(--muted-fg));
}

.dashboard-item-submeta {
  font-size: 11px;
  color: var(--muted-fg);
}

.major-stack {
  display: grid;
  gap: 18px;
}

.major-surface .card-body {
  padding: 18px 20px 20px;
}

.productivity-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(360px, 0.82fr);
  gap: 18px;
  align-items: start;
}

.management-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  align-items: start;
}
.module-cluster {
  display: grid;
  gap: 14px;
}

.cluster-heading {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  padding: 0 4px;
}

.cluster-kicker {
  margin: 0 0 6px;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted-fg);
}

.cluster-title {
  margin: 0;
  font-size: 22px;
  line-height: 1.05;
}

.cluster-copy {
  margin: 0;
  max-width: 520px;
  text-align: right;
  color: var(--muted-fg);
  font-size: 13px;
}

.cluster-grid {
  display: grid;
  gap: 16px;
  align-items: stretch;
}

.cluster-grid-productivity {
  grid-template-columns: minmax(0, 1.58fr) minmax(280px, 0.82fr);
  grid-template-areas:
    "habits pomodoro"
    "habits inbox";
}

#habitsSection {
  grid-area: habits;
}

#pomodoroSection {
  grid-area: pomodoro;
}

#captureHubSection {
  grid-area: inbox;
}

.cluster-grid-academic {
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1.05fr) minmax(0, 1.32fr);
}

.cluster-grid-opportunity {
  grid-template-columns: minmax(0, 1.08fr) minmax(0, 1fr) minmax(0, 1.12fr);
}

.module-cluster .card-section,
.module-cluster .compact-capture {
  height: 100%;
}

.module-cluster .card,
.module-cluster details.card {
  display: flex;
  flex-direction: column;
}

.module-cluster .card-body {
  flex: 1;
}

.section-span-2 {
  grid-column: span 2;
}

.section-toolbar {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  align-items: start;
}

.toolbar-grid {
  gap: 10px;
}

.add-panel {
  position: relative;
}

.add-panel summary {
  list-style: none;
}

.add-panel > summary.btn {
  display: inline-flex;
}

.add-panel summary::-webkit-details-marker {
  display: none;
}

.add-panel-body,
.add-inline-panel {
  margin-top: 10px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px;
  background: color-mix(in srgb, var(--card-2) 48%, transparent);
  display: grid;
  gap: 10px;
}

.add-panel-body-wide {
  min-width: min(620px, 70vw);
}

.empty-state {
  border: 1px dashed var(--border);
  border-radius: 12px;
  padding: 18px;
  color: var(--muted-fg);
  text-align: center;
  font-size: 12px;
  background: color-mix(in srgb, var(--card-2) 28%, transparent);
}

.compact-capture[open] .card-body {
  max-height: 520px;
  overflow: auto;
}

#assignmentsSection .card-body,
#coursesSection .card-body,
#internshipsSection .card-body,
#communitiesSection .card-body,
#eventsSection .card-body {
  padding-top: 16px;
}

.stack-list {
  display: grid;
  gap: 10px;
}

.capture-list {
  display: grid;
  gap: 10px;
  max-height: 280px;
  overflow: auto;
}

.stack-item {
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px;
  background: color-mix(in srgb, var(--card-2) 48%, transparent);
  display: grid;
  gap: 10px;
}

.stack-item-collapsible {
  padding: 0;
  overflow: hidden;
}

.stack-item-summary {
  list-style: none;
  padding: 12px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  cursor: pointer;
  transition: var(--transition);
}

.stack-item-summary::-webkit-details-marker {
  display: none;
}

.stack-item-summary::after {
  content: 'Open';
  margin-left: auto;
  font-size: 11px;
  color: var(--muted-fg);
}

.stack-item-summary:hover {
  background: color-mix(in srgb, var(--card) 36%, transparent);
}

.stack-item-collapsible[open] .stack-item-summary {
  border-bottom: 1px solid var(--border);
  background: color-mix(in srgb, var(--card) 40%, transparent);
}

.stack-item-collapsible[open] .stack-item-summary::after {
  content: 'Close';
}

.stack-item-details {
  padding: 12px;
  display: grid;
  gap: 10px;
}

.summary-pills {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.stack-item-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.stack-item-title {
  font-weight: 600;
  font-size: 13px;
}

.stack-item-summary-copy {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.stack-item-summary-event {
  align-items: flex-start;
}

.event-stack-item .stack-item-title,
.event-stack-item .item-meta {
  overflow-wrap: anywhere;
  word-break: break-word;
}

.event-meta-line,
.event-location-line,
.event-sync-meta {
  line-height: 1.5;
}

.event-location-line {
  margin-top: -1px;
}

.event-detail-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.event-field {
  min-width: 0;
  display: grid;
  gap: 6px;
}

.event-field-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.event-link-strip {
  padding: 8px 10px;
  border: 1px dashed var(--border);
  border-radius: 10px;
  background: color-mix(in srgb, var(--card) 76%, transparent);
}

.event-notes-input {
  min-height: 78px;
}

#eventsSection .item-actions {
  padding-top: 2px;
}

#notesSection,
#calendarSection {
  box-shadow: var(--shadow-lg);
}

#notesSection .card-header,
#calendarSection .card-header {
  padding-top: 16px;
  padding-bottom: 16px;
}

.compact-capture {
  overflow: hidden;
}

.compact-capture > summary {
  list-style: none;
  cursor: pointer;
}

.compact-capture > summary::-webkit-details-marker {
  display: none;
}

.compact-capture-summary::after {
  content: 'Open';
  margin-left: 0;
  font-size: 11px;
  color: var(--muted-fg);
}

.compact-capture[open] .compact-capture-summary::after {
  content: 'Close';
}

.compact-capture .card-body {
  padding-top: 12px;
}

.compact-capture .toolbar-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.compact-capture .stack-item-summary {
  padding: 10px 12px;
}

.compact-capture .stack-item-details {
  padding: 10px 12px 12px;
}

.quick-add-modal {
  display: grid;
  gap: 10px;
}

.quick-add-lead {
  line-height: 1.5;
}

.quick-add-section-block {
  display: grid;
  gap: 7px;
}

.quick-add-section-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted-fg);
}

.quick-add-modal-simple .quick-add-hints {
  gap: 6px;
}

.quick-add-shell {
  display: grid;
  gap: 8px;
}

.quick-add-shell input[type='text'] {
  font-size: 15px;
  padding: 13px 14px;
  border-radius: 12px;
}

.quick-add-detected {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-height: 24px;
}

.quick-add-confidence-hint {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--warning) 28%, var(--border));
  background: color-mix(in srgb, var(--warning) 8%, var(--card));
  color: var(--muted-fg);
  font-size: 12px;
}

.quick-add-confidence-badge {
  flex-shrink: 0;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #fff0c2;
  background: color-mix(in srgb, var(--warning) 18%, var(--card-2));
  border: 1px solid color-mix(in srgb, var(--warning) 38%, var(--border));
}

.quick-add-confidence-copy {
  line-height: 1.45;
}

.quick-add-confidence-copy strong {
  color: var(--fg);
  font-weight: 700;
}

.quick-add-meta-chip {
  display: inline-flex;
  align-items: center;
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  font-size: 11px;
  color: var(--fg);
  background: color-mix(in srgb, var(--card-2) 58%, transparent);
}

.quick-add-meta-chip.token-date,
.quick-add-meta-chip.token-time {
  color: #fff0c2;
  border-color: color-mix(in srgb, var(--warning) 42%, var(--border));
  background: color-mix(in srgb, var(--warning) 14%, var(--card));
}

.quick-add-meta-chip.token-tag {
  color: #dce8ff;
  border-color: color-mix(in srgb, var(--primary) 44%, var(--border));
  background: color-mix(in srgb, var(--primary) 15%, var(--card));
}

.quick-add-meta-chip.token-link {
  color: #dffcff;
  border-color: color-mix(in srgb, #55d3dd 42%, var(--border));
  background: color-mix(in srgb, #55d3dd 14%, var(--card));
}

.quick-add-meta-chip.token-location {
  color: #dff8e8;
  border-color: color-mix(in srgb, var(--success) 40%, var(--border));
  background: color-mix(in srgb, var(--success) 12%, var(--card));
}

.quick-add-meta-chip.token-priority {
  font-weight: 700;
}

.quick-add-meta-chip.priority-p1 {
  color: #ffe4e9;
  border-color: color-mix(in srgb, var(--danger) 58%, var(--border));
  background: color-mix(in srgb, var(--danger) 24%, var(--card));
}

.quick-add-meta-chip.priority-p2 {
  color: #fff0c2;
  border-color: color-mix(in srgb, var(--warning) 52%, var(--border));
  background: color-mix(in srgb, var(--warning) 20%, var(--card));
}

.quick-add-meta-chip.priority-p3 {
  color: #dce8ff;
  border-color: color-mix(in srgb, var(--primary) 44%, var(--border));
  background: color-mix(in srgb, var(--primary) 15%, var(--card));
}

.quick-add-meta-chip.priority-p4 {
  color: #d7dde8;
  border-color: color-mix(in srgb, var(--muted-fg) 44%, var(--border));
  background: color-mix(in srgb, var(--muted-fg) 12%, var(--card));
}

.quick-add-details {
  border: 1px solid var(--border);
  border-radius: 12px;
  background: color-mix(in srgb, var(--card-2) 44%, transparent);
}

.quick-add-details > summary {
  cursor: pointer;
  list-style: none;
  padding: 10px 12px;
  font-size: 12px;
  color: var(--muted-fg);
  font-weight: 600;
}

.quick-add-details > summary::-webkit-details-marker {
  display: none;
}

.quick-add-details[open] > summary {
  border-bottom: 1px solid var(--border);
}

.quick-add-preview-compact {
  border: none;
  background: transparent;
  padding: 10px;
  box-shadow: none;
}

.quick-add-hints {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.quick-add-hints-simple {
  opacity: 0.82;
}

.quick-add-hint {
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--card-2) 58%, transparent);
  color: #dce8ff;
  font-size: 11px;
}

.quick-add-hint:hover {
  border-color: color-mix(in srgb, var(--primary) 48%, var(--border));
  background: color-mix(in srgb, var(--primary) 14%, var(--card));
  cursor: pointer;
}

.quick-add-preview-card {
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--card-2) 62%, transparent), color-mix(in srgb, var(--card) 88%, transparent));
  display: grid;
  gap: 10px;
}

.quick-add-preview-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px 12px;
}

.quick-add-preview-grid > div,
.quick-add-preview-grid > label {
  display: grid;
  gap: 2px;
}

.quick-add-preview-grid strong {
  font-size: 13px;
  color: var(--fg);
}

.quick-add-preview-grid input,
.quick-add-preview-grid select {
  margin-top: 2px;
  padding: 7px 9px;
  font-size: 12px;
  border-radius: 9px;
}

.preview-link-grid {
  margin-top: -2px;
}

.quick-add-preview-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.quick-add-pill {
  padding: 4px 9px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--primary) 44%, var(--border));
  background: color-mix(in srgb, var(--primary) 16%, var(--card));
  color: #dce8ff;
  font-size: 11px;
}

.quick-add-preview-link {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.quick-add-link {
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--warning) 38%, var(--border));
  background: color-mix(in srgb, var(--warning) 14%, var(--card));
  color: #fff0c2;
  font-size: 11px;
}

.quick-add-suggestions-block {
  display: grid;
  gap: 8px;
}

.quick-add-suggestions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.quick-add-suggestion {
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 6px 10px;
  color: var(--muted-fg);
  font-size: 11px;
  background: color-mix(in srgb, var(--card-2) 40%, transparent);
}

.quick-add-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.quick-add-chip-btn {
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 6px 10px;
  background: color-mix(in srgb, var(--card-2) 56%, transparent);
  color: #dce8ff;
  font-size: 11px;
  cursor: pointer;
  transition: var(--transition);
}

.quick-add-chip-btn:hover {
  border-color: color-mix(in srgb, var(--primary) 48%, var(--border));
  background: color-mix(in srgb, var(--primary) 14%, var(--card));
  transform: translateY(-1px);
}

.quick-add-chip-btn.is-highlighted {
  border-color: color-mix(in srgb, var(--primary) 64%, var(--border));
  background: color-mix(in srgb, var(--primary) 22%, var(--card));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--primary) 24%, transparent);
}

.quick-add-hint {
  cursor: pointer;
  transition: var(--transition);
}

.quick-add-hint:hover {
  border-color: color-mix(in srgb, var(--primary) 44%, var(--border));
  background: color-mix(in srgb, var(--primary) 12%, var(--card));
}

.light .modal {
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(240,245,253,0.98));
  border-color: color-mix(in srgb, var(--primary) 16%, var(--border));
  box-shadow: 0 20px 40px rgba(37, 79, 175, 0.12);
}

.light .quick-add-shell input[type='text'] {
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(244,247,253,0.98));
  border-color: color-mix(in srgb, var(--primary) 22%, var(--border));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);
}

.light .quick-add-detected {
  padding: 2px 0;
}

.light .quick-add-meta-chip {
  background: color-mix(in srgb, #ffffff 86%, var(--card-2));
  border-color: color-mix(in srgb, var(--border) 86%, #ffffff);
  color: var(--fg);
}

.light .quick-add-details {
  background: linear-gradient(180deg, rgba(255,255,255,0.88), rgba(239,244,252,0.96));
  border-color: color-mix(in srgb, var(--primary) 16%, var(--border));
}

.light .quick-add-details > summary {
  background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(233,239,251,0.96));
  color: color-mix(in srgb, var(--primary) 58%, var(--fg));
}

.light .quick-add-preview-card,
.light .quick-add-preview-compact {
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(240,245,253,0.98));
  border-color: color-mix(in srgb, var(--primary) 14%, var(--border));
}

.light .quick-add-preview-grid input,
.light .quick-add-preview-grid select {
  background: rgba(255,255,255,0.96);
  border-color: color-mix(in srgb, var(--primary) 18%, var(--border));
}

.light .quick-add-hint,
.light .quick-add-suggestion,
.light .quick-add-chip-btn {
  background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(236,242,252,0.96));
  border-color: color-mix(in srgb, var(--primary) 14%, var(--border));
  color: color-mix(in srgb, var(--primary) 52%, var(--fg));
}

.light .quick-add-chip-btn:hover,
.light .quick-add-hint:hover,
.light .quick-add-chip-btn.is-highlighted {
  border-color: color-mix(in srgb, var(--primary) 36%, var(--border));
}

.light .quick-add-pill {
  background: color-mix(in srgb, var(--primary) 12%, #ffffff);
  color: color-mix(in srgb, var(--primary) 72%, var(--fg));
}

.light .quick-add-link {
  background: color-mix(in srgb, var(--warning) 12%, #ffffff);
  color: color-mix(in srgb, var(--warning) 82%, #6b4a00);
}

.capture-open-flash {
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--primary) 48%, var(--border)), 0 0 22px color-mix(in srgb, var(--primary) 18%, transparent);
  transition: box-shadow .2s ease;
}

.item-meta {
  font-size: 11px;
  color: var(--muted-fg);
}

.item-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.item-note {
  font-size: 12px;
  color: color-mix(in srgb, var(--fg) 92%, var(--muted-fg));
  background: color-mix(in srgb, var(--card) 86%, transparent);
  border: 1px dashed var(--border);
  border-radius: 10px;
  padding: 8px;
}



.light .overdue-pill {
  color: #8f2033;
  background: linear-gradient(135deg, color-mix(in srgb, var(--danger) 24%, #ffffff), color-mix(in srgb, var(--danger) 16%, var(--card)));
  border-color: color-mix(in srgb, var(--danger) 36%, var(--border));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.6);
}

.habit-days-picker {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.habit-days-picker label {
  font-size: 12px;
  color: var(--muted-fg);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.q1 { background: color-mix(in srgb, var(--danger) 14%, var(--card)); }
.q2 { background: color-mix(in srgb, var(--primary) 12%, var(--card)); }
.q3 { background: color-mix(in srgb, var(--warning) 14%, var(--card)); }
.q4 { background: color-mix(in srgb, var(--muted-fg) 12%, var(--card)); }

.quadrant {
  min-height: 210px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 10px;
}

.quad-title {
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 8px;
}

.quadrant.drag-over {
  box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--primary) 65%, var(--border));
}

.task-chip {
  border: 1px solid var(--border);
  border-radius: 16px;
  background: color-mix(in srgb, var(--card) 94%, transparent);
  margin-bottom: 10px;
  overflow: hidden;
}

.task-chip.completed { opacity: .82; }
.task-chip.overdue { border-color: color-mix(in srgb, var(--danger) 70%, var(--border)); }

.task-chip-collapsible {
  display: block;
}

.task-chip-summary {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  gap: 12px;
  padding: 12px;
  list-style: none;
  cursor: pointer;
}

.task-chip-summary::-webkit-details-marker {
  display: none;
}

.task-chip-summary::marker {
  display: none;
}

.task-chip-summary:hover {
  background: color-mix(in srgb, var(--card) 36%, transparent);
}

.task-chip-collapsible[open] .task-chip-summary {
  border-bottom: 1px solid var(--border);
  background: color-mix(in srgb, var(--card) 40%, transparent);
}

.task-chip-summary-copy {
  min-width: 0;
  display: grid;
  gap: 8px;
}

.task-chip-summary-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.task-chip-summary-title {
  font-size: 15px;
  font-weight: 700;
  line-height: 1.35;
}

.task-chip-summary-pills {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 8px;
}

.task-chip-summary-meta,
.task-chip-summary-note {
  color: var(--muted-fg);
  font-size: 13px;
}

.task-chip-summary-note {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.task-chip.completed .task-chip-summary-title {
  text-decoration: line-through;
}

.task-chip-details {
  padding: 12px;
}

.task-chip-rail {
  display: grid;
  justify-items: center;
  align-content: start;
  gap: 10px;
  padding-top: 2px;
}

.task-chip-content {
  min-width: 0;
  display: grid;
  gap: 10px;
}

.task-chip-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.task-chip-title {
  font-weight: 700;
  font-size: 15px;
}

.task-chip-meta-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.task-chip-secondary-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 10px;
}

.task-chip-field {
  display: grid;
  gap: 6px;
}

.task-chip-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted-fg);
}

.task-chip-actions {
  padding-top: 2px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.task-chip-delete {
  align-self: start;
  margin-top: 1px;
}

.task-chip .checkbox {
  width: 20px;
  height: 20px;
  border-radius: 999px;
  border: 2px solid var(--muted-fg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  cursor: pointer;
  flex-shrink: 0;
}

.task-chip .checkbox.checked {
  border-color: var(--success);
  background: var(--success);
  color: #052013;
}

.priority-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  margin-top: 0;
  box-shadow: 0 0 0 4px color-mix(in srgb, currentColor 16%, transparent);
}
.priority-high { background: var(--danger); color: var(--danger); }
.priority-medium { background: var(--warning); color: var(--warning); }
.priority-low { background: var(--success); color: var(--success); }

.habit-grid {
  display: grid;
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  background: color-mix(in srgb, var(--card) 92%, transparent);
}

.habit-grid-header { display: contents; }

.habit-grid-header > div {
  border-bottom: 1px solid var(--border);
  border-right: 1px solid var(--border);
  padding: 11px 8px;
  text-align: center;
  font-size: 12px;
  color: var(--muted-fg);
  background: color-mix(in srgb, var(--card-2) 70%, transparent);
  font-weight: 700;
}

.habit-grid-header > div:first-child { text-align: left; padding-left: 14px; }
.habit-grid-row { display: contents; }

.habit-grid-row > div {
  border-bottom: 1px solid var(--border);
  border-right: 1px solid var(--border);
  padding: 10px 8px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.habit-grid-row > div:first-child { justify-content: flex-start; padding-left: 14px; }

.habit-schedule {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.habit-day-toggle {
  border: 1px solid var(--border);
  border-radius: 7px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--card) 88%, transparent), color-mix(in srgb, var(--card-2) 54%, transparent));
  color: var(--muted-fg);
  font-size: 10px;
  line-height: 1;
  padding: 5px 6px;
  cursor: pointer;
  transition: background .22s ease, border-color .22s ease, color .22s ease, transform .16s ease, box-shadow .22s ease;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.02);
}

.habit-day-toggle:hover {
  color: #d7e5ff;
  border-color: color-mix(in srgb, var(--primary) 34%, var(--border));
  background: linear-gradient(180deg, color-mix(in srgb, var(--card-2) 78%, var(--card)), color-mix(in srgb, var(--primary) 10%, var(--card)));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--primary) 10%, transparent);
}

.habit-day-toggle:active {
  transform: scale(0.95);
}

.habit-day-toggle.active {
  color: #eef4ff;
  border-color: color-mix(in srgb, var(--primary) 64%, var(--border));
  background: linear-gradient(180deg, color-mix(in srgb, var(--primary) 32%, var(--card-2)), color-mix(in srgb, var(--primary) 18%, var(--card)));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 0 0 1px color-mix(in srgb, var(--primary) 20%, transparent),
    0 8px 18px color-mix(in srgb, var(--primary) 14%, transparent);
  transform: translateY(-1px);
  text-shadow: 0 0 10px rgba(122, 162, 255, 0.2);
}

.habit-day-toggle.active:hover {
  border-color: color-mix(in srgb, var(--primary) 78%, var(--border));
  background: linear-gradient(180deg, color-mix(in srgb, var(--primary) 40%, var(--card-2)), color-mix(in srgb, var(--primary) 22%, var(--card)));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.1),
    0 0 0 1px color-mix(in srgb, var(--primary) 28%, transparent),
    0 10px 22px color-mix(in srgb, var(--primary) 16%, transparent);
}

.habit-check {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  cursor: pointer;
}

.cell {
  width: 26px;
  height: 26px;
  border-radius: 6px;
  border: 2px solid rgba(255,255,255,0.25);
  background: rgba(255,255,255,0.04);
  display: grid;
  place-items: center;
  transition: transform 0.12s ease, box-shadow 0.12s ease, border-color 0.12s ease, background 0.12s ease;
}

.cell:hover {
  border-color: #9bb8ff;
  box-shadow: 0 0 8px rgba(155,184,255,0.5);
  cursor: pointer;
}

.cell.scheduled {
  background: rgba(120,160,255,0.08);
  border-color: rgba(120,160,255,0.4);
}

.cell.not-scheduled {
  opacity: 0.45;
  background: rgba(255,255,255,0.01);
  border-color: rgba(255,255,255,0.08);
}

.cell.not-scheduled:hover {
  opacity: 0.7;
}

.cell.active,
.habit-check.done {
  background: #FFD84D;
  border: 3px solid #FFFFFF;
  box-shadow:
    0 0 0 2px rgba(255,216,77,0.6),
    0 0 14px rgba(255,216,77,0.9);
  transform: scale(1.1);
}

.cell.active::after,
.habit-check.done::after {
  content: "\2713";
  color: #111827;
  font-size: 16px;
  font-weight: 900;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  inset: 0;
}

.cell:active,
.habit-check:active {
  transform: scale(0.95);
}

.habit-check.muted { opacity: .35; }
.habit-grid .col-highlight {
  background: rgba(255,216,77,0.12);
  box-shadow: inset 0 0 0 1px rgba(255,216,77,0.18);
}
.today-col {
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--primary) 58%, var(--border)),
    inset 0 0 0 999px color-mix(in srgb, var(--primary) 7%, transparent);
}

#habitGrid {
  overflow-x: auto;
  padding-bottom: 2px;
}

#habitGrid .habit-grid {
  min-width: 680px;
  width: 100%;
}

.notes-grid {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  min-height: 620px;
  border-top: 1px solid var(--border);
}

.notes-sidebar {
  border-right: 1px solid var(--border);
  padding: 12px;
  overflow-y: auto;
  background: color-mix(in srgb, var(--card-2) 55%, transparent);
}

.note-item {
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 12px 13px;
  margin-bottom: 10px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  transition: var(--transition);
}

.note-item-copy {
  min-width: 0;
  flex: 1;
  display: grid;
  gap: 5px;
}

.note-item-title-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.note-item-title {
  font-weight: 700;
  display: block;
}

.note-item-pin {
  flex-shrink: 0;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--warning) 78%, #ffffff);
  background: color-mix(in srgb, var(--warning) 16%, transparent);
}

.note-item-date {
  font-size: 11px;
  color: var(--muted-fg);
}

.note-item-excerpt {
  display: block;
  font-size: 12px;
  color: color-mix(in srgb, var(--muted-fg) 88%, var(--fg));
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.note-delete-btn {
  flex-shrink: 0;
}

.note-item:hover {
  border-color: color-mix(in srgb, var(--primary) 45%, var(--border));
  transform: translateY(-1px);
}

.note-item.active {
  border-color: color-mix(in srgb, var(--primary) 60%, var(--border));
  background: color-mix(in srgb, var(--primary) 10%, transparent);
  box-shadow: inset 3px 0 0 color-mix(in srgb, var(--primary) 65%, transparent);
}

.note-item.pinned {
  box-shadow: inset 3px 0 0 var(--warning);
}

.note-editor {
  padding: 24px 26px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.notes-header-tools {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.notes-search {
  min-width: 280px;
  width: min(360px, 40vw);
}

.note-editor-head {
  display: grid;
  gap: 10px;
  padding-bottom: 6px;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 84%, transparent);
}

.note-tags-row,
.note-tag-panel {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.note-tag-panel {
  min-height: 26px;
  align-items: center;
}

.note-tag {
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 11px;
  cursor: pointer;
  color: color-mix(in srgb, var(--primary) 72%, var(--fg));
  background: color-mix(in srgb, var(--primary) 10%, var(--card));
  transition: var(--transition);
}

.note-tag:hover {
  border-color: color-mix(in srgb, var(--primary) 65%, var(--border));
  background: color-mix(in srgb, var(--primary) 22%, var(--card));
}

.note-editor input[data-note-field='title'] {
  font-size: 24px;
  font-weight: 800;
  border: none;
  background: transparent;
  padding: 0;
  letter-spacing: -0.03em;
  box-shadow: none;
  border-radius: 0;
}

.note-editor-toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.note-editor-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.note-writing-surface {
  flex: 1;
  display: grid;
  gap: 10px;
  min-height: 460px;
  padding: 14px 18px 18px;
  border: 1px solid var(--border);
  border-radius: 20px;
  background: color-mix(in srgb, var(--card) 92%, transparent);
}

.note-writing-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted-fg);
}

.note-editor textarea {
  flex: 1;
  border: none;
  background: transparent;
  font-size: 17px;
  line-height: 1.85;
  min-height: 360px;
  padding: 0;
  resize: none;
  box-shadow: none;
  border-radius: 0;
}

.dashboard-addictions {
  display: grid;
  gap: 8px;
}

.addiction-row {
  position: relative;
}

.addiction-chip {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 11px;
  padding: 9px 38px 9px 10px;
  background: color-mix(in srgb, var(--card-2) 45%, transparent);
  color: var(--fg);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  cursor: pointer;
  transition: var(--transition);
}

.addiction-chip:hover {
  border-color: color-mix(in srgb, var(--primary) 42%, var(--border));
  transform: translateY(-1px);
}

.addiction-chip.is-clear {
  border-color: color-mix(in srgb, var(--success) 46%, var(--border));
  background: color-mix(in srgb, var(--success) 14%, var(--card));
}

.addiction-delete-btn {
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%) scale(0.92);
  width: 22px;
  height: 22px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--danger) 35%, var(--border));
  background: color-mix(in srgb, var(--card-2) 82%, transparent);
  color: var(--muted-fg);
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease, border-color .18s ease, color .18s ease;
}

.addiction-row:hover .addiction-delete-btn,
.addiction-row:focus-within .addiction-delete-btn {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(-50%) scale(1);
}

.addiction-delete-btn:hover {
  color: #fff;
  border-color: color-mix(in srgb, var(--danger) 62%, var(--border));
}

.addiction-chip-state {
  font-size: 11px;
  color: var(--muted-fg);
}
.addiction-composer {
  display: grid;
  gap: 12px;
}

.addiction-composer input[type="text"] {
  width: 100%;
}

.addiction-clear-toggle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--fg);
  font-size: 14px;
}

.addiction-clear-toggle input {
  accent-color: var(--primary);
}

.addiction-manager-list {
  display: grid;
  gap: 8px;
}

.addiction-manager-row,
.addiction-manager-add {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
}

.note-meta {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
  font-size: 11px;
  color: var(--muted-fg);
  padding-bottom: 4px;
}

.note-meta-chip {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--card-2) 62%, transparent);
  font-size: 12px;
  color: var(--muted-fg);
}

.note-meta-chip-accent {
  color: color-mix(in srgb, var(--warning) 76%, #ffffff);
  border-color: color-mix(in srgb, var(--warning) 34%, var(--border));
  background: color-mix(in srgb, var(--warning) 14%, transparent);
}

.note-editor-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 300px;
  border: 1px dashed var(--border);
  border-radius: 12px;
  background: color-mix(in srgb, var(--card-2) 24%, transparent);
}

.note-editor-foot {
  padding: 0 2px;
}

.note-writing-surface:focus-within {
  border-color: color-mix(in srgb, var(--primary) 34%, var(--border));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 10%, transparent);
}

.cal-header-row {
  margin-bottom: 8px;
  font-size: 11px;
  color: var(--muted-fg);
  text-align: center;
  font-weight: 700;
}

#calendarSection .card-body {
  padding: 18px 20px 20px;
}

.cal-grid {
  gap: 1px;
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  background: var(--border);
}

.cal-cell {
  min-height: 130px;
  background: var(--card);
  padding: 8px;
  cursor: pointer;
  transition: var(--transition);
}

.cal-cell-empty {
  cursor: default;
  background: color-mix(in srgb, var(--card-2) 42%, var(--card));
}

.cal-cell:hover { background: color-mix(in srgb, var(--card-2) 56%, var(--card)); }
.cal-cell.today { box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--primary) 72%, var(--border)); }
.cal-cell.selected {
  background: color-mix(in srgb, var(--primary) 14%, var(--card));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--primary) 55%, var(--border));
}

.cal-cell-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 4px;
}

.cal-day-number {
  font-size: 12px;
  font-weight: 700;
}

.cal-event {
  font-size: 10px;
  margin-top: 3px;
  padding: 3px 7px;
  border-radius: 6px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  border: 1px solid transparent;
}

.cal-event-task { background: color-mix(in srgb, var(--primary) 30%, var(--card)); color: #d8e6ff; }
.cal-event-google { background: color-mix(in srgb, var(--success) 30%, var(--card)); color: #d8ffea; }
.cal-event-assignment { background: color-mix(in srgb, var(--danger) 26%, var(--card)); color: #ffe4e9; }
.cal-event-lifeos {
  background: color-mix(in srgb, var(--primary) 18%, var(--card));
  color: #dce8ff;
  border-color: color-mix(in srgb, var(--primary) 34%, var(--border));
}

.cal-event-synced {
  background: color-mix(in srgb, #ffd84d 22%, var(--card));
  color: #fff3c4;
  border-color: color-mix(in srgb, #ffd84d 42%, var(--border));
}

.cal-event-more {
  color: var(--muted-fg);
  background: color-mix(in srgb, var(--card-2) 70%, transparent);
  border-color: var(--border);
}

.calendar-day-panel {
  margin-top: 12px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px;
  color: var(--muted-fg);
  font-size: 12px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--card-2) 54%, transparent), color-mix(in srgb, var(--card) 88%, transparent));
}

.calendar-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}

.calendar-panel-stack {
  display: grid;
  gap: 10px;
  margin-top: 10px;
}

.calendar-panel-group {
  display: grid;
  gap: 6px;
}

.calendar-panel-title {
  font-size: 12px;
  font-weight: 600;
}

.calendar-panel-list {
  list-style: none;
  display: grid;
  gap: 6px;
}

.calendar-panel-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: color-mix(in srgb, var(--card) 88%, transparent);
}

.calendar-panel-copy {
  min-width: 0;
  display: grid;
  gap: 2px;
}

#internshipsSection .stack-item-summary,
#communitiesSection .stack-item-summary,
#eventsSection .stack-item-summary,
#assignmentsSection .stack-item-summary,
#coursesSection .stack-item-summary {
  padding: 10px 11px;
}

#internshipsSection .stack-item-details,
#communitiesSection .stack-item-details,
#eventsSection .stack-item-details,
#assignmentsSection .stack-item-details,
#coursesSection .stack-item-details {
  padding: 10px 11px 11px;
  gap: 8px;
}

#internshipsSection .stack-item,
#communitiesSection .stack-item,
#eventsSection .stack-item,
#assignmentsSection .stack-item,
#coursesSection .stack-item {
  border-radius: 11px;
}

.pomodoro-block { text-align: center; }

.pomodoro-ring {
  width: 156px;
  height: 156px;
  margin: 0 auto;
  position: relative;
}

.pomodoro-ring svg { width: 100%; height: 100%; transform: rotate(-90deg); }
.pomodoro-ring circle { fill: none; stroke-width: 7; stroke-linecap: round; }
.pomodoro-ring .track { stroke: color-mix(in srgb, var(--border) 82%, transparent); }
.pomodoro-ring .progress { stroke: var(--primary); }

.timer-text {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.timer-text .time {
  font-size: 30px;
  font-weight: 800;
  font-family: var(--font-display);
}

.timer-text .label {
  font-size: 11px;
  color: var(--muted-fg);
  letter-spacing: .08em;
  text-transform: uppercase;
}

.pomodoro-stats {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px 20px;
  margin-top: 12px;
  font-size: 11px;
  color: var(--muted-fg);
}

.tab-bar {
  display: flex;
  gap: 5px;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 3px;
  background: color-mix(in srgb, var(--card) 85%, transparent);
}

.tab {
  border: none;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  color: var(--muted-fg);
  background: transparent;
  cursor: pointer;
}

.tab.active {
  color: #091126;
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
}

.progress-bar {
  width: 100%;
  height: 7px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--border) 70%, transparent);
  overflow: hidden;
}

.progress-bar .fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--primary), #9db8ff);
}

.toast-container {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 9999;
  display: grid;
  gap: 8px;
}

.toast {
  min-width: 260px;
  border-radius: 12px;
  padding: 12px 14px;
  color: #eff6ff;
  font-size: 13px;
  box-shadow: var(--shadow-lg);
}

.toast-success { background: linear-gradient(135deg, #1f9e6a, #35bf84); }
.toast-error { background: linear-gradient(135deg, #d24b5f, #f06b7a); }
.toast-info { background: linear-gradient(135deg, #466fdd, #6f90ee); }

.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(3, 8, 20, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  z-index: 9998;
}

.modal {
  width: min(560px, 92vw);
  max-width: 100%;
  max-height: min(90vh, 960px);
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--card);
  box-shadow: var(--shadow-lg);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.modal-header {
  flex-shrink: 0;
  padding: 20px 20px 0;
}

.modal-body {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 12px 20px 0;
}

.modal-actions {
  flex-shrink: 0;
  padding: 16px 20px 20px;
  border-top: 1px solid var(--border);
  background: color-mix(in srgb, var(--card-2) 42%, transparent);
}

.help-center {
  display: grid;
  gap: 14px;
  max-height: min(72vh, 860px);
}

.help-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 14px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: linear-gradient(135deg, color-mix(in srgb, var(--card-2) 76%, transparent), color-mix(in srgb, var(--card) 92%, transparent));
}

.help-kicker {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted-fg);
  margin-bottom: 6px;
}

.help-highlight-chip {
  flex-shrink: 0;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--primary) 42%, var(--border));
  background: color-mix(in srgb, var(--primary) 16%, var(--card));
  color: #dce8ff;
  font-size: 11px;
  font-weight: 600;
}

.help-toolbar {
  display: grid;
}

.help-stack {
  display: grid;
  gap: 10px;
  overflow: auto;
  padding-right: 4px;
}

.help-section {
  border: 1px solid var(--border);
  border-radius: 12px;
  background: color-mix(in srgb, var(--card-2) 36%, transparent);
  overflow: hidden;
}

.help-section > summary {
  list-style: none;
  cursor: pointer;
  padding: 12px 14px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.help-section > summary::-webkit-details-marker {
  display: none;
}

.help-section > summary::after {
  content: '+';
  color: var(--muted-fg);
  font-size: 18px;
  line-height: 1;
}

.help-section[open] > summary {
  border-bottom: 1px solid var(--border);
}

.help-section[open] > summary::after {
  content: '−';
}

.help-section-body {
  display: grid;
  gap: 10px;
  padding: 14px;
  color: var(--fg);
  font-size: 13px;
  line-height: 1.6;
}

.help-subheading {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted-fg);
}

.help-list {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 6px;
}

.help-callout {
  display: grid;
  gap: 4px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--primary) 24%, var(--border));
  background: color-mix(in srgb, var(--primary) 10%, var(--card));
}

.help-examples {
  display: grid;
  gap: 10px;
}

.help-example {
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px dashed var(--border);
  background: color-mix(in srgb, var(--card) 88%, transparent);
}

.help-example code,
.help-section code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  color: #dce8ff;
}

.help-columns {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.help-footer-note {
  font-size: 12px;
  color: var(--muted-fg);
  text-align: center;
}

.light .help-hero {
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(242,246,253,0.98));
}

.light .help-section,
.light .help-example {
  background: rgba(255,255,255,0.9);
}

.light .help-example code,
.light .help-section code {
  color: var(--primary);
}

.modal h3 { margin-bottom: 0; }

.fade-in { animation: fadeIn .45s ease-out both; }
.fade-in-1 { animation-delay: .04s; }
.fade-in-2 { animation-delay: .08s; }
.fade-in-3 { animation-delay: .12s; }

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

@media (max-width: 1500px) {
  .dashboard-top-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .management-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 1180px) {
  .cluster-heading {
    align-items: start;
    flex-direction: column;
  }

  .cluster-copy {
    max-width: none;
    text-align: left;
  }

  .cluster-grid-productivity,
  .cluster-grid-academic,
  .cluster-grid-opportunity,
  .productivity-grid,
  .management-grid {
    grid-template-columns: 1fr;
  }

  .cluster-grid-productivity {
    grid-template-areas: none;
  }

  #habitsSection,
  #pomodoroSection,
  #captureHubSection {
    grid-area: auto;
  }

  .section-span-2 {
    grid-column: span 1;
  }
}

@media (max-width: 960px) {
  .command-header { grid-template-columns: 1fr; }
  .header-controls { justify-content: flex-start; }
  .command-search { min-width: 100%; }
  .grid-4 { grid-template-columns: 1fr 1fr; }
  .grid-3 { grid-template-columns: 1fr; }
  .section-toolbar { grid-template-columns: 1fr; }
  .notes-grid { grid-template-columns: 1fr; }
  .task-chip-meta-grid,
  .task-chip-secondary-grid {
    grid-template-columns: 1fr;
  }

  .task-chip-summary-head {
    flex-direction: column;
  }

  .task-chip-summary-pills {
    justify-content: flex-start;
  }

  .notes-sidebar {
    border-right: none;
    border-bottom: 1px solid var(--border);
    max-height: 220px;
  }
}

@media (max-width: 640px) {
  .dashboard-top-grid,
  .grid-4,
  .grid-3,
  .grid-2 {
    grid-template-columns: 1fr;
  }

  .brand-title { font-size: 24px; }
  .timer-text .time { font-size: 24px; }
  .pomodoro-ring { width: 138px; height: 138px; }
  .modal-overlay { padding: 12px; }
  .modal-header { padding: 16px 16px 0; }
  .modal-body { padding: 10px 16px 0; }
  .modal-actions { padding: 14px 16px 16px; }
}





.quick-add-suggestions {
  display: grid;
  gap: 6px;
}

.quick-add-suggestion {
  border: 1px dashed var(--border);
  border-radius: 10px;
  padding: 7px 10px;
  font-size: 12px;
  color: var(--muted-fg);
  background: color-mix(in srgb, var(--card-2) 24%, transparent);
}

.quick-add-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.quick-add-chip-btn {
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 6px 10px;
  background: color-mix(in srgb, var(--card-2) 54%, transparent);
  color: var(--fg);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition);
}

.quick-add-chip-btn:hover,
.quick-add-chip-btn.is-highlighted {
  border-color: color-mix(in srgb, var(--primary) 48%, var(--border));
  background: color-mix(in srgb, var(--primary) 14%, var(--card));
  color: #eaf1ff;
}

.light .quick-add-confidence-hint {
  background: linear-gradient(180deg, rgba(255, 244, 216, 0.92), rgba(255, 249, 236, 0.98));
  border-color: color-mix(in srgb, var(--warning) 36%, var(--border));
  color: #6d5631;
}

.light .quick-add-confidence-badge {
  color: #7b5100;
  background: rgba(255, 219, 125, 0.4);
  border-color: rgba(242, 168, 74, 0.45);
}

.light .quick-add-suggestion {
  background: rgba(255,255,255,0.8);
  border-color: color-mix(in srgb, var(--border) 90%, #ffffff);
}

.light .quick-add-chip-btn {
  background: rgba(255,255,255,0.92);
  border-color: color-mix(in srgb, var(--border) 92%, #ffffff);
}

/* 2026-04-04 layout refinement: wider desktop shell + stronger subpage navigation */
.container {
  max-width: 1980px;
  padding: 22px 30px 72px;
}

.command-header {
  display: grid;
  grid-template-columns: minmax(220px, 300px) minmax(0, 1fr);
  grid-template-areas:
    "title nav"
    "title controls";
  gap: 14px 22px;
  align-items: center;
  padding: 18px 22px;
}

.header-title-block {
  grid-area: title;
  align-self: stretch;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.header-nav {
  grid-area: nav;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 10px;
}

.header-controls {
  grid-area: controls;
  max-width: none;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
}

.brand-title {
  font-size: clamp(30px, 3.2vw, 44px);
  line-height: 1;
}

.welcome-line {
  font-size: 16px;
}

.page-link,
a.page-link,
a.page-link:visited {
  border: 1px solid transparent;
  border-radius: 999px;
  padding: 10px 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  color: var(--muted-fg);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: var(--transition);
}

.page-link:hover {
  color: var(--fg);
  border-color: color-mix(in srgb, var(--border) 90%, #ffffff);
  background: color-mix(in srgb, var(--card-2) 40%, transparent);
}

.page-link.is-active {
  color: var(--fg);
  border-color: color-mix(in srgb, var(--warning) 36%, var(--border));
  background: linear-gradient(180deg, color-mix(in srgb, var(--card) 90%, transparent), color-mix(in srgb, var(--warning) 10%, transparent));
  box-shadow: 0 8px 20px rgba(6, 10, 22, 0.12);
}

.command-search {
  min-width: 320px;
  flex: 1 1 360px;
}

[data-page-target] {
  transition: opacity .2s ease, transform .2s ease;
}

.page-hidden {
  display: none !important;
}

.page-banner {
  overflow: hidden;
}

.page-banner-compact .page-banner-body {
  padding-top: 18px;
  padding-bottom: 18px;
}

.page-banner-compact .page-title {
  max-width: 24ch;
  font-size: clamp(24px, 2.4vw, 34px);
}

.page-banner-compact .page-copy {
  font-size: 14px;
}

.page-banner-body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 20px;
  align-items: end;
  padding: 24px 28px;
}

.page-eyebrow {
  margin-bottom: 8px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--warning);
}

.page-title {
  max-width: 18ch;
  font-size: clamp(28px, 3.8vw, 44px);
  line-height: 1.04;
}

.page-copy {
  max-width: 74ch;
  margin-top: 10px;
  color: var(--muted-fg);
  font-size: 15px;
}

.page-banner-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
}

.workspace-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.workspace-grid-home {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.workspace-link-card,
a.workspace-link-card,
a.workspace-link-card:visited {
  display: flex;
  min-height: 160px;
  flex-direction: column;
  justify-content: space-between;
  gap: 12px;
  padding: 16px;
  color: var(--fg);
  text-decoration: none;
  transition: var(--transition);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--card) 96%, #1c2c4d), color-mix(in srgb, var(--card-2) 86%, #0b1020));
}

.workspace-link-card > * {
  color: inherit;
}

.workspace-link-card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--primary) 34%, var(--border));
  box-shadow: var(--shadow-lg);
}

.workspace-link-kicker {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--warning);
}

.workspace-link-title {
  font-family: var(--font-display);
  font-size: 21px;
  line-height: 1;
}

.workspace-link-copy {
  color: var(--muted-fg);
  font-size: 13px;
  line-height: 1.45;
}

.workspace-link-cta {
  font-size: 12px;
  font-weight: 700;
  color: var(--primary);
}

.dashboard-top-grid {
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 16px;
  align-items: start;
}

.dashboard-top-grid .widget-card:nth-child(1),
.dashboard-top-grid .widget-card:nth-child(2),
.dashboard-top-grid .widget-card:nth-child(3) {
  grid-column: span 4;
}

.dashboard-top-grid .widget-card:nth-child(4),
.dashboard-top-grid .widget-card:nth-child(5) {
  grid-column: span 6;
}

body[data-page='home'] .dashboard-addictions {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body[data-page='home'] .widget-card .card-header,
body[data-page='home'] .widget-card .card-body {
  padding-left: 18px;
  padding-right: 18px;
}

.major-stack,
.module-cluster {
  gap: 20px;
}

.major-surface .card-body,
#calendarSection .card-body {
  padding: 18px 20px 20px;
}

.notes-grid {
  grid-template-columns: 360px minmax(0, 1fr);
  min-height: 620px;
}

.note-editor {
  padding: 22px 26px;
}

.note-editor textarea {
  min-height: 420px;
}

.cal-cell {
  min-height: 126px;
}

.cluster-grid-productivity {
  grid-template-columns: minmax(0, 1.95fr) minmax(360px, 0.95fr);
}

.cluster-grid-academic {
  grid-template-columns: repeat(12, minmax(0, 1fr));
  align-items: start;
}

.cluster-grid-opportunity {
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1.1fr) minmax(0, 1.24fr);
}

#assignmentsSection {
  grid-column: span 7;
}

#coursesSection {
  grid-column: span 5;
}

#matrixSection {
  grid-column: 1 / -1;
}

#matrixGrid {
  gap: 14px;
}

.quadrant {
  min-height: 180px;
  padding: 12px;
}

.quad-head {
  display: grid;
  gap: 4px;
  margin-bottom: 10px;
}

#habitGrid .habit-grid {
  min-width: 760px;
}

.quad-caption {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted-fg);
}

.light .page-link {
  color: #60708f;
}

.light .page-link:hover {
  color: var(--fg);
  background: rgba(255,255,255,0.82);
}

.light .page-link.is-active {
  color: var(--primary);
  border-color: color-mix(in srgb, var(--primary) 28%, var(--border));
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(244,247,253,0.98));
}

/* 2026-04-04 light mode cleanup: clearer surfaces, calmer contrast, better 100% zoom readability */
.light .card,
.light .page-banner,
.light .command-header,
.light .calendar-day-panel,
.light .quadrant,
.light .workspace-link-card,
.light .modal,
.light .day-column,
.light .note-editor,
.light .sidebar-list,
.light .calendar-grid-shell,
.light .habit-grid-shell {
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(246,249,253,0.98));
  border-color: color-mix(in srgb, var(--primary) 10%, var(--border));
  box-shadow: 0 10px 26px rgba(63, 86, 133, 0.08);
}

.light .card-header,
.light .section-header,
.light .page-banner .card-header,
.light .command-header .card-header {
  background: linear-gradient(180deg, rgba(248,250,254,0.98), rgba(241,245,251,0.98));
  border-color: color-mix(in srgb, var(--primary) 8%, var(--border));
}

.light .page-banner {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(245,248,253,0.98)),
    linear-gradient(135deg, rgba(49,94,204,0.04), rgba(255,255,255,0));
}

.light .command-header {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.95), rgba(244,247,252,0.97)),
    linear-gradient(135deg, rgba(49,94,204,0.05), rgba(255,255,255,0));
}

.light .page-link,
.light a.page-link,
.light a.page-link:visited {
  color: #60708f;
  background: rgba(255,255,255,0.42);
}

.light .page-link:hover,
.light .header-nav .page-link:hover {
  color: var(--fg) !important;
  background: rgba(255,255,255,0.92);
  border-color: color-mix(in srgb, var(--primary) 14%, var(--border));
}

.light .page-link.is-active,
.light .header-nav .page-link.is-active,
.light .header-nav .page-link[aria-current='page'] {
  color: var(--primary) !important;
  border-color: color-mix(in srgb, var(--primary) 26%, var(--border));
  background: linear-gradient(180deg, rgba(255,255,255,1), rgba(241,245,252,0.98));
  box-shadow: 0 8px 20px rgba(49, 94, 204, 0.08);
}

.light input[type='text'],
.light input[type='search'],
.light input[type='date'],
.light input[type='time'],
.light input[type='url'],
.light input[type='number'],
.light textarea,
.light select {
  background: rgba(255,255,255,0.96);
  border-color: color-mix(in srgb, var(--primary) 12%, var(--border));
  color: var(--fg);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);
}

.light input::placeholder,
.light textarea::placeholder {
  color: #8a98b2;
}

.light .btn-ghost,
.light #themeBtn,
.light .btn.btn-ghost {
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(242,246,252,0.98));
  border-color: color-mix(in srgb, var(--primary) 14%, var(--border));
  color: var(--fg);
  box-shadow: none;
}

.light .mini-list li,
.light .task-chip,
.light .habit-chip,
.light .event-chip,
.light .assignment-chip,
.light .list-chip {
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(243,247,252,0.98));
  border-color: color-mix(in srgb, var(--primary) 10%, var(--border));
}

.light .workspace-link-card,
.light a.workspace-link-card,
.light a.workspace-link-card:visited {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(244,248,253,0.98)),
    linear-gradient(135deg, rgba(49,94,204,0.04), rgba(255,255,255,0));
}

.light .workspace-link-copy,
.light .page-copy,
.light .item-meta,
.light .section-copy,
.light .quad-caption {
  color: #687894;
}

.light .event-link-strip {
  background: linear-gradient(180deg, rgba(250,252,255,0.98), rgba(242,246,252,0.98));
  border-color: color-mix(in srgb, var(--primary) 12%, var(--border));
}

.light .cal-cell,
.light .calendar-day-panel,
.light .quadrant {
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(245,248,253,0.98));
}

.light .cal-cell-empty {
  background: linear-gradient(180deg, rgba(244,247,252,0.94), rgba(239,243,249,0.98));
}

.light .cal-cell:hover {
  background: linear-gradient(180deg, rgba(255,255,255,1), rgba(240,245,252,0.98));
}

.light .cal-cell.selected,
.light .quadrant.drag-over {
  background: linear-gradient(180deg, rgba(239,245,255,0.98), rgba(233,240,252,0.98));
}

.light .dashboard-top-grid .widget-card {
  min-height: 204px;
}

/* 2026-04-04 palette refresh inspired by NeetCode */
.dark .card,
.dark .page-banner,
.dark .command-header,
.dark .calendar-day-panel,
.dark .quadrant,
.dark .workspace-link-card,
.dark .modal,
.dark .note-editor,
.dark .sidebar-list,
.dark .calendar-grid-shell,
.dark .habit-grid-shell {
  background: linear-gradient(180deg, rgba(50,52,60,0.98), rgba(44,46,53,0.98));
  border-color: #434650;
  box-shadow: 0 12px 28px rgba(12, 12, 16, 0.18);
}

.dark .card-header,
.dark .section-header,
.dark .command-header,
.dark .page-banner {
  border-color: #434650;
}

.dark .btn-ghost,
.dark #themeBtn,
.dark .page-link,
.dark a.page-link,
.dark a.page-link:visited {
  background: rgba(255,255,255,0.02);
  border-color: #434650;
  color: #d2ced8;
}

.dark .page-link:hover,
.dark .header-nav .page-link:hover,
.dark .btn-ghost:hover {
  background: rgba(122,115,232,0.12);
  border-color: rgba(122,115,232,0.4);
  color: #f5f5f7 !important;
}

.dark .page-link.is-active,
.dark .header-nav .page-link.is-active,
.dark .header-nav .page-link[aria-current='page'],
.dark #themeBtn.is-active {
  background: linear-gradient(180deg, rgba(122,115,232,0.26), rgba(99,92,214,0.2));
  border-color: rgba(122,115,232,0.44);
  color: #ffffff !important;
  box-shadow: none;
}

.light .card,
.light .page-banner,
.light .command-header,
.light .calendar-day-panel,
.light .quadrant,
.light .workspace-link-card,
.light .modal,
.light .note-editor,
.light .sidebar-list,
.light .calendar-grid-shell,
.light .habit-grid-shell {
  background: linear-gradient(180deg, rgba(255,255,255,0.99), rgba(249,249,252,0.99));
  border-color: #e5e6ec;
  box-shadow: 0 10px 24px rgba(31, 32, 39, 0.05);
}

.light .card-header,
.light .section-header,
.light .command-header,
.light .page-banner {
  border-color: #e7e7ee;
}

.light .page-link,
.light a.page-link,
.light a.page-link:visited,
.light .btn-ghost,
.light #themeBtn {
  background: rgba(255,255,255,0.9);
  border-color: #e6e7ee;
  color: #676d79;
}

.light .page-link:hover,
.light .header-nav .page-link:hover,
.light .btn-ghost:hover {
  background: rgba(114,105,222,0.08);
  border-color: rgba(114,105,222,0.18);
  color: #18191e !important;
}

.light .page-link.is-active,
.light .header-nav .page-link.is-active,
.light .header-nav .page-link[aria-current='page'],
.light #themeBtn.is-active {
  background: linear-gradient(180deg, rgba(118,108,223,0.14), rgba(118,108,223,0.08));
  border-color: rgba(114,105,222,0.26);
  color: #5f57c9 !important;
  box-shadow: none;
}

.badge-success {
  color: #eefcf5;
  background: color-mix(in srgb, var(--success) 24%, var(--card));
  border-color: color-mix(in srgb, var(--success) 42%, var(--border));
}

.badge-calendar-lifeos {
  color: #f4f2ff;
  background: color-mix(in srgb, var(--primary) 22%, var(--card));
  border-color: color-mix(in srgb, var(--primary) 42%, var(--border));
}

.badge-calendar-synced {
  color: #fff4dd;
  background: color-mix(in srgb, var(--warning) 18%, var(--card));
  border-color: color-mix(in srgb, var(--warning) 40%, var(--border));
}

/* 2026-04-04 shell refinement: make the app read closer to NeetCode */
:root {
  --radius: 18px;
  --font-display: 'Inter', sans-serif;
}

.main-header {
  border-radius: 20px;
  box-shadow: none;
}

.brand-title {
  font-size: clamp(24px, 2.2vw, 32px);
  font-weight: 800;
  letter-spacing: -0.03em;
}

.welcome-line {
  font-size: 15px;
  color: var(--muted-fg);
}

.card,
.stack-item,
.modal,
.page-banner,
.workspace-link-card {
  box-shadow: none;
}

.card-header,
.section-header {
  background: transparent;
}

.page-banner {
  border-radius: 22px;
}

.page-title {
  letter-spacing: -0.04em;
  font-weight: 800;
}

.page-copy {
  max-width: 62ch;
  line-height: 1.6;
}

.page-link,
a.page-link,
a.page-link:visited,
.btn,
#themeBtn,
input[type='text'],
input[type='search'],
input[type='date'],
input[type='time'],
input[type='url'],
input[type='number'],
textarea,
select {
  border-radius: 16px;
}

.page-link,
a.page-link,
a.page-link:visited {
  font-weight: 700;
}

.btn {
  font-weight: 700;
}

.workspace-link-card,
a.workspace-link-card,
a.workspace-link-card:visited {
  border-radius: 20px;
}

.workspace-link-title {
  letter-spacing: -0.03em;
}

.workspace-link-cta {
  color: var(--muted-fg);
}

.stack-item {
  border-radius: 16px;
}

.stack-item-summary::after,
.compact-capture-summary::after {
  font-weight: 600;
}

.dark .main-header {
  background: linear-gradient(180deg, #34353c, #33343a);
  border-color: #42444d;
}

.dark .card,
.dark .stack-item,
.dark .page-banner,
.dark .workspace-link-card,
.dark .modal,
.dark .calendar-day-panel,
.dark .quadrant,
.dark .command-header {
  background: linear-gradient(180deg, #32343a, #2e3036);
}

.dark .page-link,
.dark a.page-link,
.dark a.page-link:visited,
.dark .btn-ghost,
.dark #themeBtn {
  background: transparent;
  border-color: #444752;
  color: #d4d0d9;
}

.dark .page-link.is-active,
.dark .header-nav .page-link.is-active,
.dark .header-nav .page-link[aria-current='page'],
.dark #themeBtn.is-active {
  background: #191b20;
  border-color: #191b20;
  color: #ffffff !important;
}

.dark .btn-primary {
  background: linear-gradient(135deg, #8380ef, #6f69df);
  border-color: #7a73e8;
}

.dark input[type='text'],
.dark input[type='search'],
.dark input[type='date'],
.dark input[type='time'],
.dark input[type='url'],
.dark input[type='number'],
.dark textarea,
.dark select {
  background: #2a2c31;
  border-color: #42454e;
}

.light .main-header {
  background: linear-gradient(180deg, #ffffff, #fcfcfe);
  border-color: #e7e8ee;
}

.light .card,
.light .stack-item,
.light .page-banner,
.light .workspace-link-card,
.light .modal,
.light .calendar-day-panel,
.light .quadrant,
.light .command-header {
  background: linear-gradient(180deg, #ffffff, #fbfbfd);
}

.light .page-link,
.light a.page-link,
.light a.page-link:visited,
.light .btn-ghost,
.light #themeBtn {
  background: transparent;
  border-color: #e4e5ec;
  color: #5e6571;
}

.light .page-link.is-active,
.light .header-nav .page-link.is-active,
.light .header-nav .page-link[aria-current='page'],
.light #themeBtn.is-active {
  background: #eceef4;
  border-color: #eceef4;
  color: #15171d !important;
}

.light .btn-primary {
  background: linear-gradient(135deg, #dfe1fb, #d4d7f7);
  border-color: #d7daf6;
  color: #1b1d23;
}

.light input[type='text'],
.light input[type='search'],
.light input[type='date'],
.light input[type='time'],
.light input[type='url'],
.light input[type='number'],
.light textarea,
.light select {
  background: #f7f8fb;
  border-color: #e3e5ed;
}

/* 2026-04-04 light-mode contrast pass: keep the NeetCode shell, strengthen the color carriers */
.light {
  --primary: #6461df;
  --primary-2: #504dca;
  --success: #56b881;
  --warning: #d99a42;
  --danger: #dd6d78;
}

.light .page-eyebrow {
  color: #c78a32;
}

.light .page-link.is-active,
.light .header-nav .page-link.is-active,
.light .header-nav .page-link[aria-current='page'],
.light #themeBtn.is-active {
  background: #e7eaf2;
  border-color: #e7eaf2;
  color: #17181d !important;
}

.light .btn-primary {
  background: linear-gradient(135deg, #d6d9fb, #c9cdf7);
  border-color: #c8ccf7;
  color: #20222a;
}

.light .btn-primary:hover {
  background: linear-gradient(135deg, #cfd4fb, #c2c7f5);
}

.light .badge-success {
  color: #1e6d43;
  background: rgba(100, 212, 149, 0.18);
  border-color: rgba(86, 184, 129, 0.42);
}

.light .badge-warning,
.light .badge-calendar-synced {
  color: #8b5a0f;
  background: rgba(232, 187, 99, 0.22);
  border-color: rgba(217, 154, 66, 0.42);
}

.light .badge-calendar-lifeos {
  color: #4f46cb;
  background: rgba(100, 97, 223, 0.16);
  border-color: rgba(100, 97, 223, 0.34);
}

.light .badge-destructive,
.light .overdue-pill {
  color: #a03b49;
  background: rgba(221, 109, 120, 0.16);
  border-color: rgba(221, 109, 120, 0.34);
}

.light .quick-add-pill {
  background: rgba(100, 97, 223, 0.14);
  color: #4f46cb;
}

.light .quick-add-link {
  background: rgba(232, 187, 99, 0.18);
  color: #8b5a0f;
}

.light .cal-cell.today {
  box-shadow: inset 0 0 0 2px rgba(100, 97, 223, 0.48);
}

.light .cal-cell.selected,
.light .quadrant.drag-over {
  background: linear-gradient(180deg, rgba(238,239,251,0.98), rgba(233,235,248,0.98));
  box-shadow: inset 0 0 0 1px rgba(100, 97, 223, 0.5);
}

.light .cal-event-task {
  background: rgba(100, 97, 223, 0.18);
  color: #4941c0;
  border-color: rgba(100, 97, 223, 0.34);
}

.light .cal-event-google {
  background: rgba(86, 184, 129, 0.18);
  color: #216c45;
  border-color: rgba(86, 184, 129, 0.34);
}

.light .cal-event-assignment {
  background: rgba(221, 109, 120, 0.16);
  color: #a03b49;
  border-color: rgba(221, 109, 120, 0.32);
}

.light .cal-event-lifeos {
  background: rgba(100, 97, 223, 0.16);
  color: #4f46cb;
  border-color: rgba(100, 97, 223, 0.34);
}

.light .cal-event-synced {
  background: rgba(232, 187, 99, 0.18);
  color: #8b5a0f;
  border-color: rgba(217, 154, 66, 0.38);
}

body[data-page='notes'] .page-banner .page-banner-body {
  padding: 10px 18px;
  align-items: center;
}

body[data-page='notes'] .page-title {
  max-width: 20ch;
  font-size: clamp(24px, 2.45vw, 34px);
  line-height: 1.06;
}

body[data-page='notes'] .page-copy {
  max-width: 48ch;
  font-size: 14px;
}

body[data-page='notes'] .page-banner-actions .btn {
  min-height: 40px;
}

body[data-page='notes'] #notesSection {
  overflow: hidden;
}

body[data-page='notes'] #notesSection .card-header {
  padding: 14px 16px;
}

body[data-page='notes'] #notesSection .section-intro {
  max-width: 46ch;
}

body[data-page='notes'] .notes-grid {
  grid-template-columns: 370px minmax(0, 1fr);
  min-height: 650px;
}

body[data-page='notes'] .notes-sidebar {
  padding: 14px;
}

.light .notes-sidebar {
  background: linear-gradient(180deg, #f6f7fb, #f3f4f8);
}

.light .note-item {
  background: #ffffff;
  border-color: #e6e7ee;
}

.light .note-item.active {
  background: #eceef8;
  border-color: rgba(100, 97, 223, 0.34);
}

.light .note-writing-surface {
  background: #fdfdff;
  border-color: #e8e9f0;
}

.light body[data-page='notes'] .page-banner,
.light body[data-page='notes'] #notesSection {
  background: linear-gradient(180deg, #ffffff, #fbfbfd);
}

.light .note-item:hover {
  border-color: rgba(100, 97, 223, 0.26);
  box-shadow: 0 8px 18px rgba(31, 32, 39, 0.05);
}

/* 2026-04-05 contrast refinement: make action colors warmer, darker, and more readable across the app */
.dark .main-header {
  background: linear-gradient(180deg, #302925, #2b2521);
  border-color: #4d433d;
}

.dark .card,
.dark .stack-item,
.dark .page-banner,
.dark .workspace-link-card,
.dark .modal,
.dark .calendar-day-panel,
.dark .quadrant,
.dark .command-header {
  background: linear-gradient(180deg, #362f2a, #312a26);
  border-color: #4f453f;
}

.dark .btn-ghost,
.dark #themeBtn,
.dark .page-link,
.dark a.page-link,
.dark a.page-link:visited {
  color: #ece5dc;
  border-color: #554a44;
}

.dark .page-link.is-active,
.dark .header-nav .page-link.is-active,
.dark .header-nav .page-link[aria-current='page'],
.dark #themeBtn.is-active {
  background: #181411;
  border-color: #181411;
  color: #ffffff !important;
}

.dark .btn-primary {
  background: linear-gradient(135deg, #897ceb, #6a60d3);
  border-color: #7c6fe2;
}

.light .page-link,
.light a.page-link,
.light a.page-link:visited,
.light .btn-ghost,
.light #themeBtn {
  background: #fffaf4;
  border-color: #ddcfbf;
  color: #3b322b;
}

.light .page-link:hover,
.light .header-nav .page-link:hover,
.light .btn-ghost:hover {
  background: #f4eadf;
  border-color: #cbb7a0;
  color: #1f1a17 !important;
}

.light .page-link.is-active,
.light .header-nav .page-link.is-active,
.light .header-nav .page-link[aria-current='page'],
.light #themeBtn.is-active {
  background: #dfd6f6;
  border-color: #cbbdf1;
  color: #2f235f !important;
  box-shadow: 0 8px 18px rgba(101, 91, 201, 0.14);
}

.light .btn-primary {
  background: linear-gradient(135deg, #8a7cec, #6d61d5);
  border-color: #7769de;
  color: #ffffff;
  box-shadow: 0 10px 22px rgba(109, 97, 213, 0.2);
}

.light .btn-primary:hover {
  background: linear-gradient(135deg, #8173e7, #665acf);
}

.light .btn-danger,
.light .btn.btn-danger {
  background: linear-gradient(135deg, #d97c76, #c9655f);
  border-color: #c9655f;
  color: #ffffff;
  box-shadow: 0 10px 20px rgba(201, 101, 95, 0.18);
}

.light .badge-success {
  color: #1f5d39;
  background: rgba(103, 149, 111, 0.24);
  border-color: rgba(103, 149, 111, 0.42);
}

.light .badge-warning,
.light .badge-calendar-synced {
  color: #7f4d10;
  background: rgba(213, 157, 73, 0.24);
  border-color: rgba(213, 157, 73, 0.42);
}

.light .badge-calendar-lifeos {
  color: #4437b5;
  background: rgba(122, 111, 225, 0.2);
  border-color: rgba(122, 111, 225, 0.38);
}

.light .badge-destructive,
.light .overdue-pill {
  color: #8d2f37;
  background: rgba(207, 108, 96, 0.2);
  border-color: rgba(207, 108, 96, 0.38);
}

.light .note-item.active {
  background: #e6def8;
  border-color: rgba(122, 111, 225, 0.48);
  box-shadow: inset 3px 0 0 rgba(101, 91, 201, 0.78);
}

.light .note-tag,
.light .note-meta-chip,
.light .addiction-chip,
.light .mini-list li,
.light .quick-add-pill,
.light .workspace-link-cta {
  color: #41372f;
}

.light .note-editor input[data-note-field='title'],
.light .note-editor textarea {
  background: transparent !important;
  border: none !important;
}

.dark .notes-sidebar {
  background: linear-gradient(180deg, #2d2f35, #2b2d33);
}

.dark .note-item {
  background: rgba(255,255,255,0.02);
  border-color: #434650;
}

.dark .note-item.active {
  background: rgba(122,115,232,0.12);
  border-color: rgba(122,115,232,0.36);
}

.dark .note-writing-surface {
  background: #2b2d33;
  border-color: #434650;
}

.dark body[data-page='notes'] .page-banner,
.dark body[data-page='notes'] #notesSection {
  background: linear-gradient(180deg, #33343a, #2f3037);
}

.dark .note-item:hover {
  border-color: rgba(122,115,232,0.28);
  box-shadow: 0 10px 18px rgba(0,0,0,0.14);
}

.dark .note-editor input[data-note-field='title'],
.dark .note-editor textarea {
  background: transparent !important;
  border: none !important;
}

.dark .note-editor-head {
  border-bottom-color: rgba(255,255,255,0.06);
}

@media (max-width: 1400px) {
  .command-header {
    grid-template-columns: 1fr;
    grid-template-areas:
      "title"
      "nav"
      "controls";
    align-items: start;
  }

  .header-nav {
    justify-content: flex-start;
  }

  .header-controls {
    max-width: none;
    justify-content: flex-start;
  }

  .dashboard-top-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }

  .dashboard-top-grid .widget-card:nth-child(-n + 3) {
    grid-column: span 3;
  }

  .dashboard-top-grid .widget-card:nth-child(4),
  .dashboard-top-grid .widget-card:nth-child(5) {
    grid-column: span 6;
  }

  .workspace-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .workspace-grid-home {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  #assignmentsSection,
  #coursesSection,
  #matrixSection {
    grid-column: 1 / -1;
  }
}

@media (max-width: 960px) {
  .container {
    padding: 18px 14px 64px;
  }

  .event-detail-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .notes-grid {
    grid-template-columns: 1fr;
    min-height: 0;
  }

  body[data-page='notes'] .notes-grid {
    grid-template-columns: 1fr;
    min-height: 0;
  }

  .notes-header-tools {
    width: 100%;
    justify-content: space-between;
  }

  .notes-search {
    width: 100%;
    min-width: 0;
  }

  .note-editor {
    padding: 20px 18px;
  }

  .note-editor-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .note-writing-surface {
    min-height: 360px;
  }

  .note-item {
    padding: 11px 12px;
  }

  body[data-page='notes'] .page-banner .page-banner-body {
    padding: 12px 14px;
  }

  .dashboard-top-grid {
    grid-template-columns: 1fr;
  }

  .dashboard-top-grid .widget-card,
  .dashboard-top-grid .widget-card:nth-child(5) {
    grid-column: auto;
    min-height: 0;
  }

  body[data-page='home'] .dashboard-addictions {
    grid-template-columns: 1fr;
  }

  .page-banner-body {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .page-banner-actions {
    justify-content: flex-start;
  }

  .workspace-grid {
    grid-template-columns: 1fr;
  }

  .workspace-grid-home {
    grid-template-columns: 1fr;
  }

  .command-search {
    min-width: 100%;
    flex-basis: 100%;
  }

  body[data-page='home'] .dashboard-addictions {
    grid-template-columns: 1fr;
  }
}

/* 2026-04-04 polish: stable cross-page rendering + slightly smaller desktop scale */
.container {
  max-width: 1920px;
  padding: 18px 24px 60px;
}

.command-header {
  grid-template-columns: minmax(210px, 280px) minmax(0, 1fr);
  gap: 12px 18px;
  padding: 16px 18px;
}

.brand-title {
  font-size: clamp(28px, 2.7vw, 38px);
}

.welcome-line {
  font-size: 15px;
}

.header-nav {
  gap: 8px;
}

.header-nav .page-link,
.header-nav .page-link:link,
.header-nav .page-link:visited,
.header-nav .page-link:hover,
.header-nav .page-link:active {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 8px 14px;
  border: 1px solid transparent;
  border-radius: 999px;
  color: var(--muted-fg) !important;
  background: transparent;
  text-decoration: none !important;
}

.header-nav .page-link:hover {
  color: var(--fg) !important;
  border-color: color-mix(in srgb, var(--border) 90%, #ffffff);
  background: color-mix(in srgb, var(--card-2) 40%, transparent);
}

.header-nav .page-link.is-active,
.header-nav .page-link[aria-current='page'] {
  color: var(--fg) !important;
  border-color: color-mix(in srgb, var(--warning) 36%, var(--border));
  background: linear-gradient(180deg, color-mix(in srgb, var(--card) 90%, transparent), color-mix(in srgb, var(--warning) 10%, transparent));
  box-shadow: 0 8px 20px rgba(6, 10, 22, 0.12);
}

.header-controls {
  gap: 8px;
}

.command-search {
  min-width: 280px;
  flex: 1 1 320px;
}

.btn {
  padding: 7px 11px;
  font-size: 12px;
}

input[type='text'],
input[type='search'],
input[type='date'],
input[type='time'],
input[type='url'],
input[type='number'],
textarea,
select {
  padding: 8px 10px;
  font-size: 12px;
}

.text-lg {
  font-size: 16px;
}

.card-header {
  padding: 12px 14px;
}

.card-body,
.card-section .card-body,
.card-section-compact .card-body,
.section-body-compact {
  padding: 12px 14px 14px;
}

body:not([data-page='home']) .page-banner .page-banner-body,
body[data-page='home'] .page-banner.page-banner-compact .page-banner-body {
  padding: 16px 18px;
  gap: 14px;
}

body:not([data-page='home']) .page-title,
body[data-page='home'] .page-banner.page-banner-compact .page-title {
  max-width: 24ch;
  font-size: clamp(22px, 2.3vw, 32px);
  line-height: 1.08;
}

body:not([data-page='home']) .page-copy,
body[data-page='home'] .page-banner.page-banner-compact .page-copy {
  font-size: 13px;
}

.workspace-link-card,
a.workspace-link-card,
a.workspace-link-card:visited {
  min-height: 144px;
  padding: 14px;
}

.workspace-link-title {
  font-size: 19px;
}

.workspace-link-copy {
  font-size: 12px;
}

.dashboard-top-grid {
  gap: 14px;
}

.dashboard-top-grid .widget-card {
  min-height: 220px;
}

.major-surface .card-body,
#calendarSection .card-body {
  padding: 14px 16px 16px;
}

.notes-grid {
  min-height: 560px;
}

.note-editor {
  padding: 18px 22px;
}

.note-editor textarea {
  min-height: 360px;
}

.cal-cell {
  min-height: 112px;
}

#matrixGrid {
  gap: 12px;
}

.quadrant {
  min-height: 160px;
  padding: 10px;
}

.quad-title {
  font-size: 11px;
}

.quad-caption {
  font-size: 10px;
}

@media (max-width: 1400px) {
  .workspace-grid-home {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 960px) {
  .container {
    padding: 16px 12px 56px;
  }

  .command-header {
    grid-template-columns: 1fr;
    grid-template-areas:
      "title"
      "nav"
      "controls";
    gap: 12px;
    padding: 14px;
  }

  .header-nav {
    justify-content: flex-start;
  }

  .header-controls {
    justify-content: flex-start;
  }

  .header-nav .page-link,
  .header-nav .page-link:link,
  .header-nav .page-link:visited,
  .header-nav .page-link:hover,
  .header-nav .page-link:active {
    min-height: 34px;
    padding: 7px 12px;
  }
}
