/* =========================================================
   Ely — Portal styles (componentry, layout, screens)
   ========================================================= */

/* ---------- App frame ---------- */
.ely-app {
  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  min-height: 100vh;
  background: var(--bg-canvas);
  transition: grid-template-columns var(--dur-med) var(--ease-out);
}
.ely-app[data-collapsed="true"] { grid-template-columns: 64px 1fr; }
.ely-main { min-width: 0; display: flex; flex-direction: column; }

/* ---------- Sidebar ---------- */
.ely-sidebar {
  background: var(--bg-sidebar);
  border-right: 1px solid var(--border-soft);
  display: flex; flex-direction: column;
  padding: 14px 12px 12px;
  position: sticky; top: 0; height: 100vh;
  overflow-y: auto;
}
.ely-sidebar__brand { padding: 6px 6px 18px; }
.ely-sidebar__logo { display: flex; align-items: center; gap: 10px; width: 100%; }
.ely-sidebar__wordmark { display: flex; flex-direction: column; line-height: 1.15; text-align: left; }
.ely-sidebar__name { font-size: 17px; font-weight: 700; letter-spacing: -0.01em; }
.ely-sidebar__tag { font-size: 11px; color: var(--text-muted); }
.ely-sidebar__nav { display: flex; flex-direction: column; gap: 2px; flex: 1; overflow-y: auto; min-height: 0; }
.ely-sidebar__divider {
  height: 1px;
  background: var(--border-soft);
  margin: 10px 8px;
  opacity: 0.7;
}
.ely-navitem {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  border-radius: var(--r-md);
  color: var(--text-secondary);
  font-size: 13px; font-weight: 500;
  transition: background var(--dur-fast), color var(--dur-fast);
  text-align: left; width: 100%;
}
.ely-navitem:hover { background: var(--bg-nav-hover); color: var(--text-primary); }
.ely-navitem[data-active] { background: var(--bg-nav-active); color: var(--text-primary); }
.ely-navitem__label { flex: 1; min-width: 0; white-space: nowrap; }
.ely-navitem__badge {
  font-size: 10.5px; font-family: var(--font-mono); color: var(--text-muted);
  padding: 0 6px; background: var(--bg-card); border: 1px solid var(--border-soft); border-radius: var(--r-full); min-width: 20px; text-align: center;
}
.ely-navitem[data-active] .ely-navitem__badge { background: var(--accent-soft); color: var(--accent-ink); border-color: transparent; }
.ely-sidebar__foot { margin-top: 8px; display: flex; flex-direction: column; gap: 6px; }
.ely-agents { padding: 10px 10px 8px; }
.ely-agents__head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.ely-agents__stack { display: flex; }
.ely-agents__stack .avatar { margin-left: -6px; box-shadow: 0 0 0 2px var(--bg-sidebar); }
.ely-agents__stack .avatar:first-child { margin-left: 0; }
.ely-collapse { justify-content: center; color: var(--text-muted); }

/* ---------- Avatars ---------- */
.avatar {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--accent-soft); color: var(--accent-ink);
  font-size: 12px; font-weight: 600;
  flex-shrink: 0;
}
.avatar-xs { width: 22px; height: 22px; font-size: 10.5px; }
.avatar-sm { width: 26px; height: 26px; font-size: 11px; }
.avatar-md { width: 32px; height: 32px; font-size: 13px; }
.avatar-lg { width: 44px; height: 44px; font-size: 16px; }
.avatar-more { background: var(--bg-muted); color: var(--text-secondary); }
/* role tints */
.avatar-manager { background: #F8E6DE; color: #8A3F26; }
.avatar-financier { background: #DCEFE0; color: #1F7A3F; }
.avatar-scout { background: #E8EDFA; color: #4A5FA8; }
.avatar-cto { background: #F3E7F7; color: #6B3F82; }
.avatar-sales { background: #FCE4E0; color: #B5453A; }
.avatar-producer { background: #FEF3D4; color: #8B6914; }
.avatar-ops { background: #E2EEE0; color: #3A7A4F; }
.avatar-secretary { background: #F0EADC; color: #6B6B6B; }

/* ---------- Top Bar ---------- */
.ely-topbar {
  height: var(--topbar-h);
  padding: 0 20px;
  display: flex; align-items: center; gap: 14px;
  border-bottom: 1px solid var(--border-soft);
  background: color-mix(in oklab, var(--bg-canvas) 86%, transparent);
  backdrop-filter: blur(8px);
  position: sticky; top: 0; z-index: 40;
}
.ely-crumbs { display: flex; align-items: center; gap: 8px; }
.ely-crumb { font-size: 13px; color: var(--text-secondary); }
.ely-crumb.is-last { color: var(--text-primary); font-weight: 500; }
.ely-crumb__sep { color: var(--text-subtle); }
.ely-search {
  display: flex; align-items: center; gap: 10px;
  height: 34px; padding: 0 12px;
  border: 1px solid var(--border-soft);
  background: var(--bg-card);
  border-radius: var(--r-md);
  flex: 1; max-width: 440px;
  color: var(--text-muted);
  font-size: 13px;
  transition: border-color var(--dur-fast);
}
.ely-search:hover { border-color: var(--border-medium); }
.ely-search__placeholder { flex: 1; text-align: left; }
.ely-search__kbd { display: flex; gap: 4px; }
.ely-topbar__right { margin-left: auto; display: flex; align-items: center; gap: 8px; }
.ely-live { display: flex; align-items: center; gap: 6px; padding: 0 10px 0 8px; height: 28px; border: 1px solid var(--border-soft); border-radius: var(--r-full); background: var(--bg-card); }
.ely-live__text { font-size: 12px; color: var(--text-secondary); }
.ely-notify-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); position: absolute; transform: translate(8px, -8px); }

/* ---------- Screen shell ---------- */
.screen {
  padding: 28px 32px 60px;
  max-width: var(--content-max);
  width: 100%;
  margin: 0 auto;
  position: relative;
}
.screen__pattern {
  position: absolute; inset: 0 0 auto 0; height: 200px;
  pointer-events: none; overflow: hidden;
  mask: linear-gradient(180deg, #000 20%, transparent 100%);
}
.screen__head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 16px; margin-bottom: 28px;
  position: relative;
}
.screen__head--tight { margin-bottom: 10px; }
.tabs--with-action { align-items: stretch; }
.tabs__spacer { flex: 1; }
.tabs__action { align-self: center; margin-bottom: 6px; }
.screen__section { margin-bottom: 20px; }

/* Grids */
.grid-4 { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: var(--density-gap); }
.grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--density-gap); }
.grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--density-gap); }
.grid-overview { display: grid; grid-template-columns: 2fr 1fr; gap: var(--density-gap); }
.grid-overview-2 { display: grid; grid-template-columns: 2fr 1fr; gap: var(--density-gap); }
.span-2 { grid-column: span 1; }

/* Cards */
.card-lg { padding: var(--density-card-pad); }
.card.metric { padding: 16px 18px; display: flex; flex-direction: column; gap: 4px; }
.metric__head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 4px; color: var(--text-muted); }
.metric__value { font-size: 26px; font-weight: 600; letter-spacing: -0.01em; line-height: 1.1; color: var(--text-primary); }
.metric--breakdown { gap: 10px; }
.metric__rows { display: flex; flex-direction: column; margin-top: 2px; }
.metric__row {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 6px 0;
}
.metric__row:first-child { padding-top: 2px; }
.metric__row:first-child .metric__row-v { font-size: 22px; color: var(--text-primary); font-weight: 600; }
.metric__row-v { font-size: 14px; font-weight: 600; color: var(--text-primary); letter-spacing: -0.005em; }
.metric[data-tone="review"] .metric__icon { color: var(--yellow-text); }
.metric[data-tone="done"] .metric__icon { color: var(--status-done); }

.card-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; margin-bottom: 16px; }

/* Briefing */
.brief { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.brief__col { display: flex; flex-direction: column; gap: 2px; }
.brief__col-head {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border-soft);
}
.brief__owner {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: -0.005em;
}

.brief-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 7px 4px;
  border: 0;
  background: transparent;
  width: 100%;
  text-align: left;
}
.brief-row__title {
  font-size: 13.5px;
  color: var(--text-primary);
  font-weight: 500;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  line-height: 1.35;
  min-width: 0;
}
.brief-row__time { font-size: 11.5px; color: var(--text-muted); }
.brief-row__attn {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; font-weight: 500;
  color: var(--yellow-text);
  white-space: nowrap;
}

/* Check circle for MY tasks */
.brief-check {
  width: 18px; height: 18px;
  border-radius: 50%;
  border: 1.5px solid var(--border-strong);
  display: inline-flex; align-items: center; justify-content: center;
  color: transparent;
  flex-shrink: 0;
}
.brief-row--mine.is-done .brief-check {
  background: var(--status-done);
  border-color: var(--status-done);
  color: #fff;
}
.brief-row--mine.is-done .brief-row__title {
  color: var(--text-muted);
  text-decoration: line-through;
  text-decoration-color: color-mix(in oklab, var(--text-muted) 60%, transparent);
}

/* Bullet for ELLY tasks */
.brief-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--accent);
  opacity: 0.55;
  margin-left: 5px;
  flex-shrink: 0;
}

/* Needs attention highlight */
.brief-row--elly.needs-attn {
  background: color-mix(in oklab, var(--yellow-text) 12%, transparent);
  border-radius: var(--r-sm);
  padding: 7px 10px;
}
.brief-row--elly.needs-attn .brief-dot {
  background: var(--yellow-text);
  opacity: 1;
}

/* Sprint */
.sprint { display: flex; gap: 20px; align-items: center; }
.sprint__ring { position: relative; width: 120px; height: 120px; flex-shrink: 0; }
.sprint__ring-label { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.sprint__pct { font-size: 22px; font-weight: 700; letter-spacing: -0.02em; }
.sprint__legend { flex: 1; display: flex; flex-direction: column; gap: 6px; }
.legend-row { display: grid; grid-template-columns: 10px 1fr auto; gap: 10px; align-items: center; font-size: 13px; }
.legend-row__lbl { color: var(--text-secondary); }
.sprint__days { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; margin-top: 16px; }
.sprint__day { display: flex; flex-direction: column; gap: 6px; align-items: center; }
.sprint__bar { width: 100%; height: 56px; background: var(--bg-muted); border-radius: var(--r-sm); position: relative; overflow: hidden; display: flex; align-items: flex-end; }
.sprint__fill { width: 100%; background: var(--accent); opacity: 0.55; transition: height var(--dur-med) var(--ease-out); }
.sprint__over { position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--status-error); }
.sprint__day[data-state="past"] .sprint__fill { opacity: 0.85; }
.sprint__day[data-state="today"] .sprint__fill { opacity: 1; background: repeating-linear-gradient(45deg, var(--accent), var(--accent) 4px, var(--accent-hover) 4px, var(--accent-hover) 8px); }
.sprint__day[data-state="future"] .sprint__fill { opacity: 0.3; background: var(--border-medium); }

/* Activity */
.activity { list-style: none; padding: 0; margin: 0; }

/* Week panel */
.week-goal {
  padding: 18px 18px;
  background: var(--bg-inset);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  margin-bottom: 16px;
  min-height: 72px;
  display: flex;
  align-items: center;
}
.week-goal__title {
  font-size: 17px;
  font-weight: 600;
  line-height: 1.4;
  color: var(--text-primary);
  letter-spacing: -0.005em;
}

.week-days {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
}
.week-day {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 16px;
  align-items: center;
  padding: 12px 4px;
  transition: background var(--dur-fast);
}
.week-day:last-child { border-bottom: 0; }
.week-day__left { display: flex; align-items: baseline; gap: 8px; line-height: 1.15; }
.week-day__dow {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
}
.week-day__date {
  font-size: 11.5px;
  color: var(--text-muted);
}
.week-day__goal-row {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.week-day__icon {
  display: inline-flex;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--bg-inset);
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  flex-shrink: 0;
}
.week-day__goal {
  font-size: 14px;
  color: var(--text-primary);
  line-height: 1.4;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* State: past (muted) */
.week-day[data-state="past"] .week-day__dow { color: var(--text-muted); }
.week-day[data-state="past"] .week-day__date { color: var(--text-subtle); }
.week-day[data-state="past"] .week-day__goal { color: var(--text-secondary); }
.week-day[data-state="past"] .week-day__icon {
  background: color-mix(in oklab, var(--status-done) 14%, transparent);
  color: var(--status-done);
}

/* State: today (accent) */
.week-day[data-state="today"] {
  background: var(--accent-faint);
  border-radius: var(--r-md);
  padding: 12px 14px;
  border-bottom-color: transparent;
  margin: 2px 0;
  position: relative;
}
.week-day[data-state="today"]::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  bottom: 8px;
  width: 3px;
  background: var(--accent);
  border-radius: 0 2px 2px 0;
}
.week-day[data-state="today"] .week-day__dow { color: var(--accent-ink); }
.week-day[data-state="today"] .week-day__date { color: var(--accent-ink); opacity: 0.7; }
.week-day[data-state="today"] .week-day__icon {
  background: var(--accent);
  color: #fff;
}
.week-day[data-state="today"] .week-day__goal {
  color: var(--text-primary);
  font-weight: 600;
}

/* State: future (standard) */
.week-day[data-state="future"] .week-day__dow { color: var(--text-primary); }
.week-day[data-state="future"] .week-day__goal { color: var(--text-primary); }

/* Yesterday panel */
.yday-split { display: grid; grid-template-columns: 1fr; gap: 18px; }
.yday-col__head {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  padding-bottom: 8px;
  margin-bottom: 4px;
  border-bottom: 1px solid var(--border-soft);
  letter-spacing: -0.005em;
}
.yday { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; }
.yday__row {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: center;
  padding: 7px 4px;
}
.yday__icon {
  width: 20px; height: 20px; border-radius: 50%;
  background: color-mix(in oklab, var(--status-done) 14%, transparent);
  color: var(--status-done);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.yday__text { font-size: 13.5px; color: var(--text-primary); line-height: 1.4; }

/* Reports panel */
.reports { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; }
.reports__row {
  display: grid;
  grid-template-columns: 80px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 11px 4px;
  transition: background var(--dur-fast);
}
.reports__row:last-child { border-bottom: 0; }
.reports__row[data-state="today"] { background: var(--accent-faint); border-radius: var(--r-md); padding: 11px 12px; border-bottom-color: transparent; margin: 2px 0; }
.reports__row[data-state="skipped"] { opacity: 0.55; }
.reports__row:hover[data-state="done"] { background: var(--bg-inset); }
.reports__date { font-size: 11.5px; color: var(--text-muted); font-weight: 500; letter-spacing: 0.01em; }
.reports__row[data-state="today"] .reports__date { color: var(--accent-ink); }
.reports__title {
  font-size: 13.5px;
  color: var(--text-primary);
  font-weight: 500;
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.reports__row[data-state="today"] .reports__title { font-weight: 600; }
.reports__hint { font-size: 11.5px; color: var(--text-muted); margin-top: 2px; }
.reports__icon {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-inset);
  color: var(--text-muted);
  flex-shrink: 0;
}
.reports__row[data-state="done"] .reports__icon {
  background: color-mix(in oklab, var(--status-done) 14%, transparent);
  color: var(--status-done);
}
.reports__row[data-state="today"] .reports__icon {
  background: var(--accent);
  color: #fff;
}

/* Role mini */
.role-mini { list-style: none; padding: 0; margin: 0; }
.role-mini__row { display: grid; grid-template-columns: auto 1fr auto; gap: 10px; align-items: center; padding: 8px 0; }
.role-mini__name { font-size: 13.5px; font-weight: 500; }

/* Quick tile */
.quick-tile { display: flex; align-items: center; gap: 14px; padding: 16px; text-align: left; transition: border-color var(--dur-fast), transform var(--dur-fast); }
.quick-tile:hover { border-color: var(--border-medium); transform: translateY(-1px); }
.quick-tile__icon { width: 40px; height: 40px; border-radius: var(--r-md); background: var(--accent-soft); color: var(--accent-ink); display: flex; align-items: center; justify-content: center; }
.quick-tile__body { flex: 1; min-width: 0; }
.quick-tile__arrow { color: var(--text-muted); }
.quick-tile[data-warn] .quick-tile__icon { background: var(--yellow-bg); color: var(--yellow-text); }

/* ---------- Tasks / Kanban ---------- */
.seg { display: inline-flex; background: var(--bg-muted); padding: 3px; border-radius: var(--r-md); border: 1px solid var(--border-soft); }
.seg__btn { padding: 5px 12px; border-radius: calc(var(--r-md) - 3px); font-size: 12px; color: var(--text-secondary); display: inline-flex; gap: 6px; align-items: center; transition: background var(--dur-fast), color var(--dur-fast); }
.seg__btn[data-active] { background: var(--bg-card); color: var(--text-primary); box-shadow: var(--sh-xs); }
.seg-sm .seg__btn { padding: 4px 10px; font-size: 11.5px; }
.seg-wide { display: grid; grid-template-columns: repeat(var(--segw, 3), 1fr); width: 100%; }
.seg-wide .seg__btn { justify-content: center; }

.filters { display: flex; align-items: center; gap: 16px; padding: 8px 0 16px; flex-wrap: wrap; }
.select-sm { height: 28px; padding: 0 10px; font-size: 12.5px; border-radius: var(--r-sm); max-width: 200px; }

.kanban { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; align-items: flex-start; }
.kanban--week {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  align-items: start;
}
.kanban-vcol { display: flex; flex-direction: column; gap: 8px; }
.kanban-col--day { padding: 8px 10px; min-height: 0; min-width: 0; background: var(--bg-canvas); border: 1px solid var(--line); display: flex; flex-direction: column; overflow-y: auto; }
.kanban-col--day[data-today] { background: var(--bg-canvas-2); border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent) inset; }
.kanban-col--day[data-weekend] { background: transparent; border-style: dashed; }
.kanban-col--day[data-weekend] .day-head__title { color: var(--text-secondary); }
.kanban-col--day[data-next] { background: var(--bg-canvas-2); border-style: dashed; border-color: var(--line-strong); }
.kanban-col--day[data-next] .day-head__title { font-size: 12.5px; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.06em; }

.kanban-day-toggle { display: flex; align-items: center; width: 100%; text-align: left; cursor: pointer; padding: 0; }
.kanban-day-toggle:hover .day-head__title { opacity: 0.8; }
.kanban-col--day[data-collapsed] { padding-bottom: 8px; }
.day-head { display: flex; flex-direction: column; line-height: 1.2; gap: 2px; }
.day-head__title { font-family: var(--font-display); font-weight: 700; font-size: 13px; letter-spacing: 0.02em; color: var(--text); white-space: nowrap; }
.day-head__sub { font-size: 10.5px; color: var(--text-tertiary); font-weight: 500; letter-spacing: 0; text-transform: none; }
.kanban-col--day[data-today] .day-head__title { color: var(--accent); }
.day-head__today { font-weight: 500; font-size: 12px; color: var(--accent); letter-spacing: 0; }

.kanban-col--day .kanban-col__body { display: flex; flex-direction: column; gap: 8px; padding-top: 6px; }
.day-section { display: flex; flex-direction: column; gap: 3px; }
.day-section__label { font-size: 9.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-tertiary); padding-bottom: 2px; border-bottom: 1px solid var(--line); margin-bottom: 1px; }
.kanban-empty { font-size: 11px; color: var(--text-tertiary); padding: 4px 0 2px; }

.day-card {
  display: grid; grid-template-columns: 16px 1fr; gap: 7px; align-items: start;
  padding: 4px 7px; border-radius: var(--r-sm);
  background: var(--bg-surface); border: 1px solid var(--line);
  cursor: grab;
  transition: border-color var(--dur-fast), transform var(--dur-fast);
}
.day-card:hover { border-color: var(--line-strong); }
.day-card.is-dragging { opacity: 0.4; cursor: grabbing; }
.day-card.is-done .day-card__title { color: var(--text-subtle); }
.day-card .tt-check { margin-top: 1px; }
.day-card__body { min-width: 0; }
.day-card__title { font-size: 11.5px; line-height: 1.3; color: var(--text); overflow-wrap: anywhere; }

.kanban-col { background: var(--bg-canvas-2); border-radius: var(--r-lg); border: 1px solid transparent; padding: 12px; min-height: 320px; transition: border-color var(--dur-fast), background var(--dur-fast); }
.kanban-col[data-over] { border-color: var(--accent); background: var(--accent-faint); }
.kanban-col__head { display: flex; justify-content: space-between; align-items: center; padding: 4px 6px 10px; }
.kanban-col__title { font-size: 11px; font-weight: 600; letter-spacing: 0.08em; color: var(--text-secondary); }
.kanban-col__body { display: flex; flex-direction: column; gap: 10px; }
.kanban-col__empty { border: 1.5px dashed var(--border-dashed); border-radius: var(--r-md); color: var(--text-muted); font-size: 12px; padding: 18px; text-align: center; }

.task-card {
  background: var(--bg-card);
  border-radius: var(--radius-profile-card);
  border: 1px solid var(--border-soft);
  padding: 12px;
  box-shadow: var(--sh-xs);
  cursor: grab;
  transition: box-shadow var(--dur-fast), border-color var(--dur-fast), transform var(--dur-fast);
}
.task-card:hover { box-shadow: var(--sh-sm); border-color: var(--border-medium); }
.task-card[data-dragging] { opacity: 0.5; transform: rotate(-1deg); }
.task-card__open { display: block; width: 100%; text-align: left; }
.task-card__row1 { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.task-card__title { font-size: 14px; font-weight: 600; line-height: 1.35; margin-bottom: 4px; color: var(--text-primary); }
.task-card__desc { font-size: 12.5px; line-height: 1.5; }
.task-card__foot { display: flex; align-items: center; gap: 8px; margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--border-soft); }
.task-card__action { color: var(--text-secondary); width: 20px; display: flex; justify-content: center; }

.task-card__log-wrap { margin-top: 10px; padding-top: 8px; border-top: 1px dashed var(--border-dashed); }
.task-card__log-btn { display: flex; align-items: center; gap: 8px; padding: 4px 2px; font-size: 11.5px; color: var(--text-secondary); width: 100%; }
.task-card__log-btn .meta { margin-left: auto; }

.inline-log { background: var(--bg-inset); border-radius: var(--r-md); padding: 8px 10px; margin-top: 8px; display: flex; flex-direction: column; gap: 4px; }
.inline-log__row { display: flex; align-items: center; gap: 8px; font-size: 11.5px; color: var(--text-secondary); padding: 2px 0; }
.inline-log__pill { font-size: 9.5px; padding: 1px 6px; letter-spacing: 0.04em; text-transform: uppercase; }
.inline-log__row--run .meta.running { color: var(--accent); }
.inline-log__row--run .meta.running::after { content: "●"; animation: pulse 1s infinite; margin-left: 4px; }
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }
.inline-log__score { display: flex; align-items: center; gap: 10px; margin-top: 4px; padding-top: 6px; border-top: 1px dashed var(--border-dashed); font-size: 11px; }
.score-bar { flex: 1; height: 4px; background: var(--bg-muted); border-radius: 99px; overflow: hidden; }
.score-bar__fill { display: block; height: 100%; background: var(--accent); }

/* ---------- TickTick-style list ---------- */
.screen--tasks {
  max-width: var(--content-max);
  display: flex;
  flex-direction: column;
  padding-bottom: 12px;
}

.tt-layout {
  display: grid;
  grid-template-columns: 232px 1fr;
  gap: 20px;
  min-height: 560px;
}

/* Sidebar */
.tt-sidebar {
  display: flex; flex-direction: column; gap: 18px;
  background: var(--bg-canvas-2);
  border-radius: var(--r-lg);
  padding: 14px 10px;
  border: 1px solid var(--border-soft);
  align-self: start;
  position: sticky;
  top: 72px;
}
.tt-sidebar__section { display: flex; flex-direction: column; gap: 1px; }
.tt-sidebar__eyebrow {
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 600;
  padding: 6px 10px 8px;
}
.tt-list {
  display: grid;
  grid-template-columns: 20px 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 8px 10px;
  border: 0;
  background: transparent;
  border-radius: var(--r-sm);
  font-size: 13.5px;
  color: var(--text-primary);
  cursor: pointer;
  text-align: left;
  transition: background var(--dur-fast);
}
.tt-list:hover { background: var(--bg-inset); }
.tt-list[data-active] {
  background: var(--accent-soft);
  color: var(--accent-ink);
  font-weight: 600;
}
.tt-list[data-active] .tt-list__count { color: var(--accent-ink); opacity: 0.7; }
.tt-list[data-tone="accent"] .tt-list__icon { color: var(--accent); }
.tt-list[data-tone="yellow"] .tt-list__icon { color: var(--yellow-text); }
.tt-list[data-tone="done"] .tt-list__icon { color: var(--status-done); }
.tt-list__icon { display: inline-flex; color: var(--text-muted); }
.tt-list__name { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.tt-list__count { font-size: 12px; color: var(--text-muted); font-variant-numeric: tabular-nums; }
.tt-list--role { grid-template-columns: 22px 1fr auto; }

/* Main */
.tt-main { display: flex; flex-direction: column; gap: 14px; min-width: 0; }
.tt-toolbar {
  display: flex; align-items: center; gap: 12px;
  flex-wrap: wrap;
}
.tt-add {
  flex: 1;
  min-width: 300px;
  display: flex; align-items: center; gap: 10px;
  padding: 11px 14px;
  background: var(--bg-canvas-2);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  color: var(--text-muted);
  transition: border-color var(--dur-fast), background var(--dur-fast);
}
.tt-add:focus-within {
  border-color: var(--accent);
  background: var(--bg-card);
}
.tt-add__input {
  flex: 1;
  border: 0;
  outline: none;
  background: transparent;
  font-size: 13.5px;
  color: var(--text-primary);
  font-family: inherit;
}
.tt-add__input::placeholder { color: var(--text-muted); }

/* List body */
.tt-list-body {
  background: var(--bg-card);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-lg);
  padding: 6px 8px 10px;
  display: flex;
  flex-direction: column;
}

/* Groups */
.tt-group { display: flex; flex-direction: column; margin-top: 4px; border-radius: 8px; transition: background var(--dur-fast); }
.tt-group.is-drop { background: color-mix(in oklab, var(--accent) 8%, transparent); outline: 1px dashed color-mix(in oklab, var(--accent) 45%, transparent); outline-offset: -2px; }
.tt-group__head {
  display: flex; align-items: center; gap: 8px;
  padding: 14px 10px 6px;
  font-size: 10.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 600;
  background: transparent;
  border: 0;
  cursor: pointer;
  width: 100%;
  text-align: left;
}
.tt-group__head:hover { color: var(--text-secondary); }
.tt-group__caret { display: inline-flex; color: var(--text-muted); transition: transform var(--dur-fast); }
.tt-group__caret.is-collapsed { transform: rotate(-90deg); }
.tt-group__count { margin-left: auto; font-weight: 500; letter-spacing: 0; }
.tt-group__empty { padding: 8px 34px 12px; color: var(--text-tertiary); font-size: 12px; }

/* Row */
.tt-row {
  display: grid;
  grid-template-columns: 28px 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 9px 12px 9px 6px;
  border-radius: var(--r-sm);
  position: relative;
  transition: background var(--dur-fast), opacity var(--dur-fast);
  cursor: grab;
}
.tt-row:hover { background: var(--bg-inset); }
.tt-row.is-dragging { opacity: 0.4; cursor: grabbing; }

.tt-check {
  width: 18px; height: 18px;
  border-radius: 4px;
  border: 1.5px solid var(--border-strong);
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--bg-card);
  color: transparent;
  cursor: pointer;
  padding: 0;
  margin-left: 4px;
  transition: border-color var(--dur-fast), background var(--dur-fast), color var(--dur-fast);
}
.tt-check:hover { border-color: var(--text-primary); }
/* Priority tint on the checkbox (open state) */
.tt-check[data-priority="high"] { border-color: #D04A3B; }
.tt-check[data-priority="med"]  { border-color: #E0A23B; }
.tt-check[data-priority="low"]  { border-color: #3B9A5B; }
.tt-check[data-priority="high"]:hover,
.tt-check[data-priority="med"]:hover,
.tt-check[data-priority="low"]:hover { filter: brightness(0.92); }
/* Done state — simple tick, no fill. Tint from priority still shows via the border. */
.tt-row.is-done .tt-check,
.day-card.is-done .tt-check,
.cal-item.is-done .tt-check {
  background: var(--bg-card);
  color: var(--text-subtle);
  border-color: var(--text-subtle);
}
.tt-row.is-done .tt-check[data-priority="high"],
.day-card.is-done .tt-check[data-priority="high"],
.cal-item.is-done .tt-check[data-priority="high"] { color: #D04A3B; border-color: #D04A3B; }
.tt-row.is-done .tt-check[data-priority="med"],
.day-card.is-done .tt-check[data-priority="med"],
.cal-item.is-done .tt-check[data-priority="med"] { color: #E0A23B; border-color: #E0A23B; }
.tt-row.is-done .tt-check[data-priority="low"],
.day-card.is-done .tt-check[data-priority="low"],
.cal-item.is-done .tt-check[data-priority="low"] { color: #3B9A5B; border-color: #3B9A5B; }

.tt-row__body {
  display: flex; align-items: baseline; gap: 10px;
  padding: 0;
  border: 0;
  background: transparent;
  text-align: left;
  cursor: pointer;
  min-width: 0;
}
.tt-row__title {
  flex: 1;
  font-size: 14px;
  color: var(--text-primary);
  line-height: 1.35;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  min-width: 0;
}
.tt-row__tag {
  flex-shrink: 0;
  font-size: 12.5px;
  color: var(--text-muted);
  font-weight: 400;
}
.tt-row.is-done .tt-row__title {
  color: var(--text-subtle);
}
.tt-row.is-done .tt-row__tag { color: var(--text-subtle); }

/* Owner badge */
.tt-owner {
  display: inline-flex; align-items: center;
  padding: 2px 9px;
  border-radius: var(--r-full);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.02em;
  white-space: nowrap;
  flex-shrink: 0;
}
.tt-owner--mine {
  background: color-mix(in oklab, var(--text-secondary) 10%, transparent);
  color: var(--text-secondary);
}
.tt-owner--ellie {
  background: color-mix(in oklab, var(--accent) 14%, transparent);
  color: var(--accent);
}
.tt-row.is-done .tt-owner { opacity: 0.5; }

.tt-empty {
  padding: 40px 16px;
  text-align: center;
  color: var(--text-muted);
  font-size: 13px;
}

/* Task list table */
.tbl-wrap { overflow: hidden; }
.tbl { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.tbl thead th { text-align: left; font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-muted); padding: 12px 16px; background: var(--bg-inset); border-bottom: 1px solid var(--border-soft); font-weight: 600; }
.tbl tbody td { padding: 12px 16px; border-bottom: 1px solid var(--border-soft); vertical-align: middle; }
.tbl tbody tr { cursor: pointer; transition: background var(--dur-fast); }
.tbl tbody tr:hover { background: var(--bg-inset); }
.tbl tbody tr:last-child td { border-bottom: 0; }
.tbl-title { font-weight: 500; margin-bottom: 2px; }

/* ---------- Drawer ---------- */
.drawer-scrim {
  position: fixed; inset: 0; background: rgba(26, 18, 10, 0.2); backdrop-filter: blur(2px);
  z-index: 80; display: flex; justify-content: flex-end;
  animation: fadeOnly var(--dur-med) var(--ease-out) both;
}
@keyframes fadeOnly { from { opacity: 0; } to { opacity: 1; } }
.drawer {
  background: var(--bg-card);
  width: 520px; max-width: 100%;
  height: 100vh;
  display: flex; flex-direction: column;
  box-shadow: var(--sh-lg);
  animation: slideIn var(--dur-med) var(--ease-out) both;
  border-left: 1px solid var(--border-soft);
}
.drawer-wide { width: 640px; }
@keyframes slideIn { from { transform: translateX(30px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
.drawer__head { padding: 18px 24px 16px; border-bottom: 1px solid var(--border-soft); position: relative; overflow: hidden; background: var(--bg-canvas-2); }
.drawer__pattern { position: absolute; inset: 0; pointer-events: none; }
.drawer__head-row { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; position: relative; z-index: 1; }
.drawer__body { flex: 1; overflow-y: auto; padding: 20px 24px; }
.drawer__foot { display: flex; gap: 10px; padding: 12px 20px; border-top: 1px solid var(--border-soft); background: var(--bg-inset); }
.drawer__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px 20px; padding: 4px 0 16px; border-bottom: 1px solid var(--border-soft); }
.drawer__section { padding: 16px 0; border-bottom: 1px solid var(--border-soft); }
.drawer__section:last-child { border-bottom: 0; }
.drawer__two { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.drawer__desc { line-height: 1.6; color: var(--text-primary); font-size: 13.5px; margin: 6px 0 0; }
.drawer__tabs { display: flex; gap: 2px; border-bottom: 1px solid var(--border-soft); margin-bottom: 10px; }
.drawer__tab { padding: 8px 12px; font-size: 12.5px; color: var(--text-secondary); border-bottom: 2px solid transparent; display: inline-flex; gap: 6px; align-items: center; }
.drawer__tab[data-active] { color: var(--text-primary); border-bottom-color: var(--accent); }

.prompt-box { background: var(--bg-inset); border: 1px solid var(--border-soft); border-radius: var(--r-md); padding: 12px 14px; font-size: 12.5px; line-height: 1.6; white-space: pre-wrap; margin-top: 8px; color: var(--text-primary); }
.chip-list { list-style: none; padding: 0; margin: 6px 0 0; display: flex; flex-wrap: wrap; gap: 6px; }
.chip { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; background: var(--bg-inset); border: 1px solid var(--border-soft); border-radius: var(--r-full); font-size: 11.5px; color: var(--text-primary); }
.files { list-style: none; padding: 0; margin: 6px 0 0; display: flex; flex-direction: column; gap: 4px; }
.files li { display: flex; align-items: center; gap: 8px; padding: 8px 10px; background: var(--bg-inset); border-radius: var(--r-sm); font-size: 13px; }
.files__name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ---------- New drawer styling (title, metabar, details, activity) ---------- */
.drawer__title { margin: 10px 0 0; font-size: 22px; line-height: 1.25; letter-spacing: -0.015em; }
.drawer__title-input { margin: 10px 0 0; font-size: 22px; line-height: 1.25; letter-spacing: -0.015em; font-family: var(--font-display); font-weight: 600; width: 100%; background: transparent; border: 1px solid var(--accent); border-radius: var(--r-sm); padding: 4px 8px; color: var(--text-primary); }
.drawer__title-input:focus { outline: none; box-shadow: 0 0 0 3px var(--accent-soft); }
.drawer__metabar { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 12px; align-items: center; }
.drawer__chip { display: inline-flex; align-items: center; gap: 5px; padding: 4px 10px; font-size: 11.5px; border-radius: var(--r-full); background: var(--accent-soft); color: var(--accent-ink); border: 1px solid transparent; }
.drawer__chip--muted { background: var(--bg-card); border: 1px solid var(--border-soft); color: var(--text-secondary); }
/* Tap-to-cycle priority chip. */
.priority-chip { cursor: pointer; display: inline-flex; align-items: center; gap: 6px; border: 1px solid var(--border-soft); background: var(--bg-card); color: var(--text-secondary); transition: all 0.12s var(--ease-out); }
.priority-chip:hover { border-color: var(--text-primary); color: var(--text-primary); }
.priority-chip__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--text-tertiary); border: 1px solid var(--border-strong); flex-shrink: 0; }
.priority-chip--high { background: color-mix(in oklab, #D04A3B 12%, var(--bg-card)); border-color: color-mix(in oklab, #D04A3B 35%, var(--border-soft)); color: #9E3020; }
.priority-chip--high .priority-chip__dot { background: #D04A3B; border-color: #D04A3B; }
.priority-chip--med { background: color-mix(in oklab, #E0A23B 12%, var(--bg-card)); border-color: color-mix(in oklab, #E0A23B 40%, var(--border-soft)); color: #7a5612; }
.priority-chip--med .priority-chip__dot { background: #E0A23B; border-color: #E0A23B; }
.priority-chip--low { background: color-mix(in oklab, #3B9A5B 10%, var(--bg-card)); border-color: color-mix(in oklab, #3B9A5B 35%, var(--border-soft)); color: #286b40; }
.priority-chip--low .priority-chip__dot { background: #3B9A5B; border-color: #3B9A5B; }
.drawer__copied { margin-top: 8px; font-size: 11.5px; color: var(--text-secondary); background: var(--accent-faint); border: 1px solid var(--accent-soft); border-radius: var(--r-sm); padding: 5px 9px; animation: fadeIn var(--dur-fast) var(--ease-out); }
@keyframes fadeIn { from { opacity: 0; transform: translateY(-2px); } to { opacity: 1; transform: none; } }

.eyebrow--green { color: #2b7a4b; }
.eyebrow--red { color: var(--accent); }
.eyebrow--gray { color: var(--text-muted); }
.eyebrow-row { display: flex; justify-content: space-between; align-items: center; gap: 10px; margin-bottom: 10px; }
.eyebrow-meta { display: flex; align-items: center; gap: 8px; font-size: 11.5px; color: var(--text-secondary); }
/* Drawer section headings are larger than global .eyebrow; inline styles on the element handle flex layout & gap. */
.drawer__section .eyebrow { font-size: 13px; letter-spacing: 0.06em; }
.outcome-box { background: color-mix(in oklab, #2b7a4b 10%, var(--bg-card)); border: 1px solid color-mix(in oklab, #2b7a4b 30%, var(--border-soft)); border-radius: var(--r-md); padding: 12px 14px; margin-top: 4px; font-size: 13px; line-height: 1.55; color: var(--text-primary); }
.outcome-box--edit { font: inherit; font-size: 13px; line-height: 1.55; width: 100%; resize: vertical; }
.empty-line { padding: 6px 0; font-size: 12.5px; }

.progress-bar { width: 80px; height: 4px; background: var(--bg-inset); border-radius: var(--r-full); overflow: hidden; }
.progress-bar__fill { height: 100%; background: var(--accent); transition: width 0.3s var(--ease-out); }

/* Simple tick checkbox — no fill, just a checkmark. */
.tick { width: 16px; height: 16px; border-radius: 4px; border: 1.5px solid var(--border-strong); display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; cursor: pointer; transition: border-color 0.12s var(--ease-out), color 0.12s; background: transparent; color: var(--text-secondary); }
.tick:hover { border-color: var(--accent); }
.tick.is-on { border-color: var(--text-primary); color: var(--text-primary); }

/* Checklist rows — no strikethrough, just fade to gray when done. */
.check-list { list-style: none; padding: 0; margin: 8px 0 0; display: flex; flex-direction: column; gap: 2px; }
.check-row { display: flex; align-items: center; gap: 10px; padding: 6px 6px; border-radius: var(--r-sm); font-size: 13px; line-height: 1.45; color: var(--text-primary); }
.check-row:hover { background: var(--bg-inset); }
.check-row.is-done { color: var(--text-subtle); }
.check-row.is-done .tick { color: var(--text-subtle); border-color: var(--text-subtle); }
.check-row__text { flex: 1; min-width: 0; }
.check-row[draggable="true"] { cursor: grab; }
.check-row[draggable="true"]:active { cursor: grabbing; }

.grip { display: inline-flex; color: var(--text-tertiary); cursor: grab; flex-shrink: 0; }
.grip:hover { color: var(--text-secondary); }

.inline-input { flex: 1; min-width: 0; background: transparent; border: 1px solid transparent; border-radius: var(--r-sm); padding: 4px 8px; font: inherit; font-size: 13px; color: var(--text-primary); }
.inline-input:hover { border-color: var(--border-soft); }
.inline-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); background: var(--bg-card); }

.inline-textarea { width: 100%; background: var(--bg-card); border: 1px solid var(--border-soft); border-radius: var(--r-sm); padding: 10px 12px; font: inherit; font-size: 13.5px; line-height: 1.6; color: var(--text-primary); resize: vertical; margin-top: 4px; }
.inline-textarea:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }

/* Resources — no gray background, same as card. */
.res-list { list-style: none; padding: 0; margin: 8px 0 0; display: flex; flex-direction: column; gap: 0; }
.res-list li { display: flex; align-items: center; gap: 10px; padding: 7px 6px; font-size: 13px; color: var(--text-primary); border-radius: var(--r-sm); }
.res-list li:hover { background: var(--bg-inset); }
.res-list__name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.res-list__add-row { display: flex; gap: 6px; padding: 8px 0 0; }

/* Related — no IDs, just titles + status. */
.related { list-style: none; padding: 0; margin: 8px 0 0; display: flex; flex-direction: column; gap: 0; }
.related li { display: flex; align-items: center; gap: 10px; padding: 8px 6px; font-size: 13px; color: var(--text-primary); border-radius: var(--r-sm); }
.related li:hover { background: var(--bg-inset); }
.related__title { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.related__status { display: inline-flex; align-items: center; gap: 5px; color: var(--text-secondary); font-size: 11.5px; flex-shrink: 0; }

/* Attach picker — dropdown for linking related tasks. */
.related-add-btn { margin-top: 8px; width: 100%; display: flex; align-items: center; justify-content: center; gap: 6px; padding: 9px 12px; font-size: 12.5px; color: var(--text-secondary); background: transparent; border: 1px dashed var(--border-strong); border-radius: var(--r-sm); cursor: pointer; transition: all 0.12s var(--ease-out); }
.related-add-btn:hover { color: var(--accent); border-color: var(--accent); background: var(--accent-faint); }
.attach-picker { margin: 4px 0 8px; background: var(--bg-card); border: 1px solid var(--border-soft); border-radius: var(--r-md); box-shadow: var(--sh-md); overflow: hidden; animation: fadeIn var(--dur-fast) var(--ease-out); }
.attach-picker__head { display: flex; align-items: center; gap: 8px; padding: 8px 10px; border-bottom: 1px solid var(--border-soft); color: var(--text-secondary); }
.attach-picker__input { flex: 1; min-width: 0; background: transparent; border: 0; font: inherit; font-size: 13px; color: var(--text-primary); outline: none; }
.attach-picker__list { list-style: none; padding: 4px; margin: 0; max-height: 240px; overflow-y: auto; display: flex; flex-direction: column; gap: 1px; }
.attach-picker__item { width: 100%; display: flex; align-items: center; gap: 8px; padding: 7px 8px; border-radius: var(--r-sm); font-size: 13px; text-align: left; color: var(--text-primary); background: transparent; }
.attach-picker__item:hover { background: var(--accent-faint); }
.attach-picker__title { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.btn-xs { padding: 3px 6px; font-size: 11px; border-radius: var(--r-sm); gap: 4px; }
.btn-icon.btn-xs { width: 22px; height: 22px; padding: 0; }

.activity { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0; position: relative; }
.activity::before { content: ""; position: absolute; left: 6px; top: 6px; bottom: 6px; width: 1px; background: var(--border-soft); }
.activity__item { position: relative; padding: 10px 0 10px 24px; }
.activity__item::before { content: ""; position: absolute; left: 2px; top: 15px; width: 9px; height: 9px; border-radius: 50%; background: var(--bg-card); border: 2px solid var(--text-tertiary); }
.activity__item--update::before { border-color: #6b7280; }
.activity__item--status::before { border-color: var(--accent); }
.activity__item--checklist::before { border-color: #2b7a4b; }
.activity__item--brief::before { border-color: #a855f7; }
.activity__item--created::before { border-color: var(--accent); background: var(--accent); }
.activity__head { display: flex; align-items: center; gap: 10px; font-size: 12px; }
.activity__kind { display: inline-flex; align-items: center; gap: 5px; color: var(--text-primary); font-weight: 500; }
.activity__actor { color: var(--text-secondary); }
.activity__time { margin-left: auto; font-size: 11px; }
.activity__diff { margin-top: 4px; font-size: 12px; color: var(--text-secondary); line-height: 1.5; }
.activity__field { color: var(--text-tertiary); font-size: 11px; }

/* ---------- Tabs ---------- */
.tabs { display: flex; gap: 2px; border-bottom: 1px solid var(--border-soft); margin-bottom: 20px; }
.tab { padding: 10px 14px; font-size: 13px; color: var(--text-secondary); border-bottom: 2px solid transparent; display: inline-flex; gap: 8px; align-items: center; font-weight: 500; }
.tab:hover { color: var(--text-primary); }
.tab[data-active] { color: var(--text-primary); border-bottom-color: var(--accent); }

/* ---------- Memory ---------- */

/* Generic markdown body */
.md { padding: 18px 28px 28px; max-width: 720px; }
.md h2 { font-size: 22px; font-weight: 700; letter-spacing: -0.02em; margin: 0 0 8px; font-family: var(--font-display); }
.md h3 { font-size: 15px; font-weight: 600; margin: 22px 0 8px; }
.md p, .md li { font-size: 13.5px; line-height: 1.65; }
.md ul { padding-left: 20px; margin: 4px 0 10px; }
.md blockquote { border-left: 3px solid var(--accent); background: var(--accent-faint); padding: 10px 14px; margin: 14px 0 0; border-radius: 0 var(--r-md) var(--r-md) 0; font-size: 13px; }

/* Center tabs on memory screens (no h1) */
.tabs--center { justify-content: center; margin-top: 8px; }

/* MemBrain */
.mem-brain { display: grid; grid-template-columns: 1fr 280px; gap: 20px; align-items: flex-start; }
.mem-brain__graph { padding: 0; overflow: hidden; }
.mem-brain__graph-head { display: flex; justify-content: space-between; align-items: center; padding: 14px 18px 8px; }
.mem-graph-canvas { position: relative; background: var(--bg-inset); border-radius: 0; min-height: 440px; overflow: hidden; margin: 0 14px; border-radius: var(--r-md); }
.mem-brain__graph-foot { padding: 10px 18px 14px; }
.mem-brain__stats { gap: 12px; }
.mem-brain__stats-title { padding: 0 4px 4px; }
.metric--accent { border-color: var(--accent); box-shadow: 0 0 0 1px color-mix(in oklab, var(--accent) 30%, transparent) inset; }
.metric__icon { width: 28px; height: 28px; border-radius: var(--r-sm); background: var(--bg-inset); display: inline-flex; align-items: center; justify-content: center; color: var(--accent); }
.metric__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.mem-brain__entities { display: flex; align-items: center; gap: 8px; padding: 14px 18px; width: 100%; text-align: left; background: var(--bg-card); cursor: pointer; }
.mem-brain__entities-icon { display: inline-flex; color: var(--accent); }
.mem-brain__entities-title { font-weight: 600; font-size: 13.5px; color: var(--text-primary); }
.mem-entities { list-style: none; padding: 14px 18px; margin: 0; display: flex; flex-wrap: wrap; gap: 6px; }
.mem-entities li { display: inline-flex; padding: 4px 10px; border: 1px solid var(--border-soft); border-radius: var(--r-full); background: var(--bg-inset); font-size: 11.5px; }

/* MemContext */
.mem-context { padding: 0; overflow: hidden; }
.mem-context__head { display: flex; align-items: flex-start; justify-content: space-between; padding: 16px 22px; border-bottom: 1px solid var(--border-soft); background: var(--bg-inset); }
.mem-context__body { padding: 22px 32px 30px; max-width: 760px; }
.mem-context__body h3 { font-size: 20px; font-weight: 700; letter-spacing: -0.02em; margin: 0 0 10px; font-family: var(--font-display); }
.mem-context__body h4 { font-size: 14px; font-weight: 700; margin: 18px 0 8px; color: var(--text-primary); }
.mem-context__body blockquote { border-left: 3px solid var(--border-medium); background: var(--bg-inset); padding: 10px 14px; margin: 0 0 14px; border-radius: 0; font-size: 13px; }
.mem-context__body blockquote p { margin: 2px 0; font-size: 12.5px; color: var(--text-secondary); font-style: italic; }
.mem-context__body ul { padding-left: 22px; }
.mem-context__body li { font-size: 13.5px; line-height: 1.7; color: var(--text-secondary); }

/* MemDialogs */
.mem-dialogs { display: flex; flex-direction: column; gap: 16px; }
.mem-dialogs__head { display: flex; align-items: flex-start; justify-content: space-between; padding: 0 4px; }
.mem-dialogs__layout { display: grid; grid-template-columns: 200px minmax(0, 1fr); gap: 16px; align-items: flex-start; }
.mem-dialogs__weeks {
  display: flex; flex-direction: column; gap: 4px;
  max-height: calc(100vh - 200px); overflow-y: auto;
  padding-right: 4px;
}
.mem-dialogs__year { padding: 6px 10px; font-size: 11px; color: var(--text-muted); font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; display: flex; justify-content: space-between; }
.mem-dialogs__week {
  display: flex; flex-direction: column; gap: 4px;
  padding: 10px 12px; border-radius: var(--r-md);
  background: transparent; border: 0; cursor: pointer; text-align: left;
  transition: background var(--dur-fast);
}
.mem-dialogs__week:hover { background: var(--bg-nav-hover); }
.mem-dialogs__week[data-active] { background: var(--accent-soft); }
.mem-dialogs__week-top { display: flex; align-items: center; justify-content: space-between; gap: 6px; }
.mem-dialogs__week-key { font-size: 13px; font-weight: 700; color: var(--text-primary); }
.mem-dialogs__week[data-active] .mem-dialogs__week-key { color: var(--accent-ink); }
.mem-dialogs__week-meta { display: flex; align-items: center; justify-content: space-between; gap: 6px; font-size: 11px; color: var(--text-muted); }
.mem-dialogs__week-meta .mono { display: inline-flex; align-items: center; gap: 4px; }
.pill-live { background: color-mix(in oklab, #22c55e 18%, transparent); color: #15803d; border-color: color-mix(in oklab, #22c55e 30%, transparent); font-size: 10px; }

.mem-dialogs__stream { padding: 0; overflow: hidden; min-height: 520px; }
.mem-dialogs__stream-head { display: flex; justify-content: space-between; align-items: center; padding: 12px 18px; border-bottom: 1px solid var(--border-soft); background: var(--bg-inset); }
.mem-dialogs__stream-body { padding: 20px 24px 24px; max-width: 720px; }
.mem-dialogs__msg-meta { padding-bottom: 8px; font-size: 11px; line-height: 1.5; }
.mem-dialogs__msg p { font-size: 13px; line-height: 1.6; color: var(--text-primary); }
.mem-dialogs__transcript { color: var(--text-secondary); }
.mem-dialogs__reply { margin-top: 22px; padding: 12px 16px; background: var(--accent-faint); border-radius: var(--r-md); border-left: 3px solid var(--accent); }
.mem-dialogs__reply-badge { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; font-weight: 600; color: var(--accent-ink); margin-bottom: 4px; }
.mem-dialogs__reply-text { font-size: 13.5px; }

/* MemPeople */
.mem-people { display: flex; flex-direction: column; gap: 16px; }
.mem-people__head { display: flex; align-items: flex-start; justify-content: space-between; padding: 0 4px; }
.mem-people__layout { display: grid; grid-template-columns: 280px minmax(0, 1fr); gap: 16px; align-items: flex-start; }
.mem-people__list { display: flex; flex-direction: column; gap: 4px; }
.mem-people__search { display: flex; align-items: center; gap: 8px; padding: 8px 12px; border: 1px solid var(--border-soft); border-radius: var(--r-md); background: var(--bg-card); }
.mem-people__search input { flex: 1; border: 0; background: transparent; font: inherit; color: var(--text-primary); outline: 0; font-size: 13px; }
.mem-people__search svg { color: var(--text-muted); }
.mem-people__items { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 2px; }
.mem-people__item {
  width: 100%; padding: 10px 12px; border-radius: var(--r-md);
  background: transparent; border: 0; cursor: pointer; text-align: left;
  display: flex; flex-direction: column; gap: 3px;
  transition: background var(--dur-fast);
}
.mem-people__item:hover { background: var(--bg-nav-hover); }
.mem-people__item[data-active] { background: var(--accent-soft); }
.mem-people__item-top { display: flex; align-items: center; gap: 8px; }
.mem-people__item-name { font-size: 13.5px; font-weight: 600; color: var(--text-primary); }
.mem-people__item-sub { font-size: 11.5px; color: var(--text-muted); display: flex; gap: 4px; align-items: center; }
.mem-people__detail { padding: 24px 28px; background: var(--bg-card); border: 1px solid var(--border-soft); border-radius: var(--r-lg); min-height: 420px; }
.mem-people__detail-head { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 20px; }
.mem-people__detail-head .eyebrow { margin-bottom: 4px; }
.mem-people__detail-head .h2 { margin: 0; }
.mem-people__section { margin-top: 20px; }
.mem-people__section .eyebrow { margin-bottom: 8px; }
.mem-people__section p { font-size: 13.5px; line-height: 1.6; color: var(--text-primary); margin: 0; }
.mem-people__link { display: inline-flex; align-items: center; gap: 6px; color: var(--accent-ink); font-size: 13.5px; }
.pill-tone-ok { background: color-mix(in oklab, #22c55e 18%, transparent); color: #15803d; border-color: color-mix(in oklab, #22c55e 28%, transparent); }
.pill-tone-warn { background: color-mix(in oklab, #f59e0b 18%, transparent); color: #b45309; border-color: color-mix(in oklab, #f59e0b 30%, transparent); }
.pill-tone-neutral { background: var(--bg-inset); color: var(--text-secondary); }

@media (max-width: 1100px) {
  .mem-brain { grid-template-columns: 1fr; }
  .mem-dialogs__layout, .mem-people__layout { grid-template-columns: 1fr; }
}

/* Tools */
.tool-card { padding: 16px; display: flex; flex-direction: column; gap: 6px; min-height: 140px; transition: border-color var(--dur-fast), transform var(--dur-fast); }
.tool-card:hover { border-color: var(--border-medium); transform: translateY(-1px); }
.tool-card__head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 2px; }
.tool-card__icon { width: 36px; height: 36px; border-radius: var(--r-md); background: var(--bg-inset); color: var(--text-primary); display: flex; align-items: center; justify-content: center; }
.tool-card__foot { display: flex; justify-content: space-between; align-items: center; margin-top: auto; padding-top: 10px; border-top: 1px solid var(--border-soft); }

/* Skills — two-pane layout */
.skills-split { display: grid; grid-template-columns: 320px 1fr; gap: 20px; align-items: start; }
.skills-list { background: var(--bg-card); border: 1px solid var(--border-soft); border-radius: var(--r-lg); padding: 10px; position: sticky; top: 72px; }
.skills-list__head { display: flex; align-items: center; justify-content: space-between; padding: 6px 8px 10px; }
.skills-list__title { font-size: 12px; font-weight: 600; letter-spacing: 0.04em; color: var(--text-secondary); text-transform: uppercase; }
.skills-list__search { display: flex; align-items: center; gap: 8px; padding: 8px 10px; background: var(--bg-inset); border-radius: var(--r-md); margin-bottom: 8px; }
.skills-list__search input { background: transparent; border: 0; outline: 0; font: inherit; color: inherit; flex: 1; font-size: 13px; }
.skills-list__group { padding: 8px 8px 4px; font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-secondary); display: flex; align-items: center; gap: 6px; }
.skills-list__item { width: 100%; text-align: left; display: flex; align-items: center; gap: 10px; padding: 8px 10px; border-radius: var(--r-sm); border: 0; background: transparent; color: var(--text-primary); font: inherit; cursor: pointer; font-size: 13px; }
.skills-list__item:hover { background: var(--bg-inset); }
.skills-list__item[data-active="true"] { background: var(--accent-soft); color: var(--accent-ink); }
.skills-list__item .mono { font-size: 12.5px; }
.skill-doc { background: var(--bg-card); border: 1px solid var(--border-soft); border-radius: var(--r-lg); overflow: hidden; }
.skill-doc__head { padding: 20px 28px 18px; border-bottom: 1px solid var(--border-soft); display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.skill-doc__title { font-size: 15px; font-weight: 600; }
.skill-doc__meta { display: grid; grid-template-columns: repeat(3, max-content); gap: 24px 32px; margin-top: 14px; }
.skill-doc__meta dt { font-size: 11px; color: var(--text-secondary); letter-spacing: 0.04em; text-transform: uppercase; }
.skill-doc__meta dd { font-size: 13px; margin: 2px 0 0; }
.skill-doc__desc-head { margin-top: 18px; }
.skill-doc__desc { font-size: 13px; color: var(--text-secondary); margin-top: 6px; line-height: 1.55; max-width: 720px; }
.skill-doc__body { padding: 28px; background: var(--bg-canvas); }
.skill-doc__view-tabs { display: flex; gap: 4px; background: var(--bg-inset); padding: 3px; border-radius: var(--r-sm); }
.skill-doc__view-tabs button { border: 0; background: transparent; padding: 4px 8px; border-radius: calc(var(--r-sm) - 2px); cursor: pointer; color: var(--text-secondary); display: flex; align-items: center; }
.skill-doc__view-tabs button[data-active="true"] { background: var(--bg-card); color: var(--text-primary); box-shadow: var(--sh-xs); }

.skill-md-rendered { font-size: 13px; line-height: 1.65; max-width: 820px; }
.skill-md-rendered h1 { font-size: 22px; font-weight: 600; margin: 0 0 8px; }
.skill-md-rendered h2 { font-size: 13px; font-weight: 600; margin: 28px 0 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-secondary); }
.skill-md-rendered h3 { font-size: 14px; font-weight: 600; margin: 20px 0 8px; }
.skill-md-rendered p { margin: 0 0 12px; color: var(--text-primary); }
.skill-md-rendered p.lead { color: var(--text-secondary); }
.skill-md-rendered table { width: 100%; border-collapse: collapse; font-size: 13px; }
.skill-md-rendered th { text-align: left; font-weight: 500; font-size: 11px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-secondary); padding: 10px 12px; border-bottom: 1px solid var(--border-soft); }
.skill-md-rendered td { padding: 10px 12px; border-bottom: 1px solid var(--border-soft); vertical-align: top; }
.skill-md-rendered td.col-chip { width: 40px; }
.skill-md-rendered .swatch { width: 22px; height: 22px; border-radius: 6px; display: inline-flex; align-items: center; justify-content: center; font-size: 11px; color: var(--text-secondary); }
.skill-md-rendered code, .skill-md-rendered .mono-inline { font-family: var(--font-mono); font-size: 12px; background: var(--bg-inset); padding: 1px 5px; border-radius: 4px; }
.skill-md-rendered pre { background: var(--bg-inset); border: 1px solid var(--border-soft); border-radius: var(--r-md); padding: 14px 16px; font-family: var(--font-mono); font-size: 12px; line-height: 1.55; overflow-x: auto; margin: 12px 0; }
.skill-md-rendered pre .tok-str { color: #c26a2b; }
.skill-md-rendered pre .tok-key { color: #7a5a18; }
.skill-md-rendered pre .tok-lang { display: block; font-size: 10.5px; color: var(--text-secondary); margin-bottom: 6px; letter-spacing: 0.04em; }
.skill-md-rendered ul { padding-left: 20px; margin: 8px 0 12px; }
.skill-md-rendered li { margin: 4px 0; }

/* Connector rows (Tools) */
.tools-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; align-items: start; }
@media (max-width: 1080px) { .tools-grid { grid-template-columns: 1fr; } }
.connector-group { background: var(--bg-card); border: 1px solid var(--border-soft); border-radius: var(--r-lg); padding: 0; overflow: hidden; }
.connector-group__head { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--border-soft); }
.connector-group__title { font-size: 14px; font-weight: 600; }
.connector-group__sub { font-size: 12.5px; color: var(--text-secondary); margin-top: 2px; }
.connector-row { display: grid; grid-template-columns: 36px 1fr auto auto; gap: 14px; align-items: center; padding: 14px 20px; border-bottom: 1px solid var(--border-soft); cursor: pointer; transition: background var(--dur-fast); }
.connector-row:last-child { border-bottom: 0; }
.connector-row:hover { background: var(--bg-inset); }
.connector-row__icon { width: 36px; height: 36px; border-radius: var(--r-md); background: var(--bg-inset); color: var(--text-primary); display: flex; align-items: center; justify-content: center; }
.connector-row__name { font-size: 13.5px; font-weight: 500; }
.connector-row__desc { font-size: 12.5px; color: var(--text-secondary); margin-top: 1px; }
.connector-row__status { font-size: 12.5px; color: var(--text-secondary); }
.connector-row__kebab { color: var(--text-secondary); display: flex; padding: 4px; border-radius: 6px; }
.connector-row__kebab:hover { background: var(--bg-card); }

/* Tool function drawer */
.tool-fn { display: grid; grid-template-columns: 28px 1fr; gap: 12px; padding: 12px 4px; border-bottom: 1px solid var(--border-soft); align-items: start; }
.tool-fn:last-child { border-bottom: 0; }
.tool-fn__icon { width: 28px; height: 28px; border-radius: 6px; background: var(--bg-inset); display: flex; align-items: center; justify-content: center; color: var(--text-secondary); }
.tool-fn__name { font-size: 13px; font-weight: 500; font-family: var(--font-mono); }
.tool-fn__desc { font-size: 12.5px; color: var(--text-secondary); margin-top: 2px; line-height: 1.5; }

/* Modal (generic) */
.modal-scrim { position: fixed; inset: 0; background: rgba(26,18,10,0.28); backdrop-filter: blur(3px); z-index: 90; display: flex; align-items: flex-start; justify-content: center; animation: fadeOnly var(--dur-med) var(--ease-out) both; overflow-y: auto; padding: 6vh 20px; }
.modal { background: var(--bg-card); border-radius: var(--r-lg); border: 1px solid var(--border-soft); box-shadow: 0 20px 60px rgba(40,28,16,0.18); width: 100%; max-width: 680px; display: flex; flex-direction: column; max-height: calc(100vh - 12vh); animation: modalIn var(--dur-med) var(--ease-out) both; }
@keyframes modalIn { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: none; } }
.modal__head { padding: 18px 24px; border-bottom: 1px solid var(--border-soft); display: flex; align-items: center; justify-content: space-between; }
.modal__body { padding: 20px 24px; overflow-y: auto; display: flex; flex-direction: column; gap: 14px; }
.modal__foot { padding: 14px 24px; border-top: 1px solid var(--border-soft); display: flex; justify-content: flex-end; gap: 8px; background: var(--bg-muted); border-bottom-left-radius: var(--r-lg); bo
.upload-drop { border: 2px dashed var(--border-soft); border-radius: var(--r-lg); padding: 36px 24px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; background: var(--bg-muted); transition: all .15s; }
.upload-drop[data-drop] { border-color: var(--accent); background: color-mix(in oklch, var(--accent) 8%, var(--bg-muted)); }
.upload-drop__icon { color: var(--text-muted); margin-bottom: 10px; }
.upload-drop__title { font-weight: 600; color: var(--text-strong); }
.upload-drop__sub { color: var(--text-muted); font-size: 13px; margin-top: 4px; }
.hint { color: var(--text-muted); font-size: 12px; line-height: 1.5; }
.hint code { background: var(--bg-muted); padding: 1px 5px; border-radius: 4px; font-size: 11px; }rder-bottom-right-radius: var(--r-lg); }
.form-row { display: flex; flex-direction: column; gap: 6px; }
.form-row--inline { flex-direction: row; align-items: center; gap: 10px; }
.form-label { font-size: 12px; color: var(--text-secondary); font-weight: 500; }
.req { color: #b5482d; }
.input { width: 100%; box-sizing: border-box; border: 1px solid var(--border-medium); background: var(--bg-card); border-radius: var(--r-sm); padding: 8px 10px; font: inherit; font-size: 13px; color: var(--text-primary); outline: 0; transition: border-color var(--dur-fast); }
.input:focus { border-color: var(--accent); }
.input.mono { font-family: var(--font-mono); font-size: 12.5px; }
textarea.input { resize: vertical; min-height: 70px; line-height: 1.5; font-family: var(--font-mono); font-size: 12.5px; }
select.input { appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--text-secondary) 50%), linear-gradient(135deg, var(--text-secondary) 50%, transparent 50%); background-position: calc(100% - 14px) center, calc(100% - 9px) center; background-size: 5px 5px; background-repeat: no-repeat; padding-right: 28px; }
.form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.pulse-active { display: flex; align-items: center; gap: 10px; color: var(--text-secondary); font-size: 13px; cursor: pointer; padding: 4px 0; }
.pulse-active input { accent-color: var(--accent); }

/* Пульс screen */
.pulse-stats { display: grid; grid-template-columns: 1fr; gap: 12px; margin-bottom: 20px; max-width: 720px; }
.pulse-stat { background: var(--bg-card); border: 1px solid var(--border-soft); border-radius: var(--r-md); padding: 14px 18px; }
.pulse-stat--single .pulse-stat__value { font-size: 22px; letter-spacing: -0.01em; }
.pulse-stat__value { font-family: var(--font-display, var(--font-body)); font-size: 28px; font-weight: 500; color: var(--text-primary); line-height: 1; }
.pulse-stat__split { color: var(--text-tertiary); font-size: 22px; font-weight: 400; }
.pulse-stat__label { font-size: 12px; color: var(--text-secondary); margin-top: 6px; }
.form-hint { font-size: 11.5px; color: var(--text-tertiary); margin-top: 2px; }
.pulse-table { background: var(--bg-card); border: 1px solid var(--border-soft); border-radius: var(--r-lg); overflow: hidden; }
.pulse-row { display: grid; grid-template-columns: 1fr 200px 120px 120px 120px 80px; align-items: center; gap: 16px; padding: 14px 20px; border: 0; background: transparent; text-align: left; border-bottom: 1px solid var(--border-soft); cursor: pointer; width: 100%; font: inherit; color: inherit; transition: background var(--dur-fast); }
.pulse-row:last-child { border-bottom: 0; }
.pulse-row:hover:not(.pulse-row--head) { background: var(--bg-muted); }
.pulse-row--head { background: var(--bg-inset); font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-tertiary); cursor: default; padding-top: 10px; padding-bottom: 10px; }
.pulse-row--head:hover { background: var(--bg-inset); }
.pulse-row[data-inactive] .pulse-row__name,
.pulse-row[data-inactive] .pulse-row__desc,
.pulse-row[data-inactive] .pulse-row__sched,
.pulse-row[data-inactive] .pulse-row__meta { opacity: 0.5; }
.pulse-row__name { font-size: 14px; font-weight: 500; color: var(--text-primary); }
.pulse-row__desc { font-size: 12.5px; color: var(--text-secondary); margin-top: 3px; line-height: 1.4; }
.pulse-row__sched { display: flex; align-items: center; gap: 6px; font-size: 12.5px; color: var(--text-secondary); }
.pulse-row__meta { font-size: 12.5px; color: var(--text-secondary); font-variant-numeric: tabular-nums; }
.model-chip { display: inline-block; padding: 3px 8px; border-radius: 999px; background: var(--bg-inset); border: 1px solid var(--border-soft); font-size: 11.5px; font-family: var(--font-mono); color: var(--text-primary); }
.pulse-row__toggle { display: flex; justify-content: center; }
.switch { position: relative; display: inline-block; width: 32px; height: 18px; cursor: pointer; }
.switch input { opacity: 0; width: 0; height: 0; }
.switch__track { position: absolute; inset: 0; background: var(--border-medium); border-radius: 999px; transition: background var(--dur-fast); }
.switch__track::before { content: ""; position: absolute; left: 2px; top: 2px; width: 14px; height: 14px; background: #fff; border-radius: 50%; transition: transform var(--dur-fast); box-shadow: 0 1px 2px rgba(0,0,0,0.2); }
.switch input:checked + .switch__track { background: var(--accent); }
.switch input:checked + .switch__track::before { transform: translateX(14px); }

/* ========= Settings: Models ========= */
.settings-models { display: flex; flex-direction: column; gap: 20px; }
.settings-models__head { display: flex; justify-content: space-between; align-items: flex-end; gap: 20px; flex-wrap: wrap; }
.settings-models__totals { display: flex; gap: 8px; }
.total-chip { display: flex; align-items: center; gap: 8px; padding: 8px 12px; background: var(--bg-card); border: 1px solid var(--border-soft); border-radius: var(--r-md); }
.total-chip__label { font-size: 11px; color: var(--text-tertiary); text-transform: uppercase; letter-spacing: 0.06em; }
.total-chip__val { font-family: var(--font-mono); font-size: 13px; color: var(--text-primary); font-weight: 500; }
.models-list { display: flex; flex-direction: column; gap: 10px; }
.model-row { background: var(--bg-card); border: 1px solid var(--border-soft); border-radius: var(--r-lg); padding: 16px 20px; display: grid; grid-template-columns: 1fr 380px; gap: 20px; align-items: stretch; }
.model-row[data-state="error"] { border-color: color-mix(in oklab, var(--status-error) 35%, var(--border-soft)); }
.model-row[data-state="paused"] { opacity: 0.7; }
.model-row__main { display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.model-row__head { display: flex; align-items: center; gap: 10px; }
.model-row__dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.model-row__dot--active { background: var(--status-done); }
.model-row__dot--paused { background: var(--text-tertiary); }
.model-row__dot--error { background: var(--status-error); }
.model-row__name { font-size: 14.5px; font-weight: 600; color: var(--text-primary); }
.model-row__route { font-size: 12.5px; color: var(--text-secondary); font-family: var(--font-mono); }
.model-row__status { margin-left: auto; font-size: 12px; color: var(--text-tertiary); }
.model-row[data-state="error"] .model-row__status { color: var(--status-error); font-weight: 500; }
.model-row__bar { height: 4px; background: var(--bg-inset); border-radius: 999px; overflow: hidden; }
.model-row__barfill { height: 100%; background: var(--accent); border-radius: 999px; }
.model-row[data-state="error"] .model-row__barfill { background: var(--status-error); }
.model-row__note { font-size: 12.5px; color: var(--text-secondary); }
.model-row__side { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.usage-chip { background: var(--bg-inset); border-radius: var(--r-sm); padding: 10px 12px; display: flex; flex-direction: column; justify-content: center; min-width: 0; }
.usage-chip__top { font-family: var(--font-mono); font-size: 14px; font-weight: 600; color: var(--text-primary); }
.usage-chip__lbl { font-size: 10.5px; color: var(--text-tertiary); text-transform: uppercase; letter-spacing: 0.05em; margin-top: 2px; }

/* ========= Settings: Balance ========= */
.settings-balance { display: flex; flex-direction: column; gap: 24px; }
.balance-top { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 14px; }
.balance-card { background: var(--bg-card); border: 1px solid var(--border-soft); border-radius: var(--r-lg); padding: 18px 20px; }
.balance-card--hero { background: linear-gradient(135deg, color-mix(in oklab, var(--accent) 8%, var(--bg-card)), var(--bg-card)); border-color: color-mix(in oklab, var(--accent) 22%, var(--border-soft)); }
.balance-card__label { font-size: 12px; color: var(--text-secondary); }
.balance-card__value { font-family: var(--font-display, var(--font-body)); font-size: 36px; font-weight: 500; margin-top: 6px; color: var(--text-primary); }
.balance-card--hero .balance-card__value { color: var(--accent); }
.balance-card__sub { font-size: 12.5px; color: var(--text-tertiary); margin-top: 8px; line-height: 1.5; }
.balance-section { }
.balance-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.balance-row { background: var(--bg-card); border: 1px solid var(--border-soft); border-radius: var(--r-md); padding: 14px 16px; display: flex; flex-direction: column; gap: 8px; }
.balance-row__head { display: flex; align-items: center; gap: 10px; }
.balance-row__name { font-size: 14px; font-weight: 500; color: var(--text-primary); flex: 1; min-width: 0; }
.balance-row__cap { font-size: 11px; color: var(--text-tertiary); text-transform: uppercase; letter-spacing: 0.05em; }
.balance-row__cost { font-family: var(--font-mono); font-size: 13px; color: var(--text-primary); font-weight: 500; }
.balance-row__bar { height: 3px; background: var(--bg-inset); border-radius: 999px; overflow: hidden; }
.balance-row__barfill { height: 100%; background: var(--accent); }
.balance-row__stats { display: flex; gap: 14px; font-size: 12px; color: var(--text-tertiary); font-family: var(--font-mono); }
.txn-list { list-style: none; margin: 0; padding: 0; }
.txn-row { display: grid; grid-template-columns: 120px 220px 1fr 100px; gap: 14px; padding: 12px 20px; border-bottom: 1px solid var(--border-soft); align-items: center; }
.txn-row:last-child { border-bottom: 0; }
.txn-row__d { font-family: var(--font-mono); font-size: 12.5px; color: var(--text-secondary); }
.txn-row__m { font-size: 13px; color: var(--text-primary); }
.txn-row__note { font-size: 12.5px; color: var(--text-secondary); }
.txn-row__note[data-err] { color: var(--status-error); }
.txn-row__amt { text-align: right; font-family: var(--font-mono); font-size: 13px; font-weight: 500; color: var(--text-primary); }

/* ========= Settings: Security ========= */
.sec-head { display: flex; justify-content: space-between; align-items: center; padding-bottom: 14px; border-bottom: 1px solid var(--border-soft); margin-bottom: 8px; }
.pill-warn { background: color-mix(in oklab, #c48320 15%, var(--bg-card)); color: #8b5a10; border: 1px solid color-mix(in oklab, #c48320 30%, var(--border-soft)); }
.sec-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px; }
.sec-row { display: grid; grid-template-columns: 44px 1fr auto; gap: 14px; align-items: flex-start; padding: 16px 0; border-bottom: 1px solid var(--border-soft); }
.sec-row:last-child { border-bottom: 0; }
.sec-row__icon { width: 36px; height: 36px; border-radius: var(--r-sm); display: flex; align-items: center; justify-content: center; color: var(--text-secondary); background: var(--bg-inset); margin-top: 2px; }
.sec-row__icon--allow { background: color-mix(in oklab, var(--status-done) 15%, var(--bg-card)); color: var(--status-done); }
.sec-row__icon--ask { background: color-mix(in oklab, #c48320 15%, var(--bg-card)); color: #a36510; }
.sec-row__icon--deny { background: color-mix(in oklab, var(--status-error) 15%, var(--bg-card)); color: var(--status-error); }
.sec-row__head { display: flex; align-items: center; gap: 10px; }
.sec-row__name { font-size: 14px; font-weight: 500; color: var(--text-primary); }
.sec-row__code { font-family: var(--font-mono); font-size: 11.5px; padding: 2px 7px; background: var(--bg-inset); border-radius: 4px; color: var(--text-secondary); }
.sec-row__desc { font-size: 12.5px; color: var(--text-secondary); margin-top: 4px; line-height: 1.5; }
.sec-row__foot { font-size: 11.5px; color: var(--text-tertiary); margin-top: 4px; display: flex; gap: 6px; }
.sec-row__seg { display: flex; border: 1px solid var(--border-soft); border-radius: var(--r-sm); overflow: hidden; align-self: center; }
.sec-opt { border: 0; background: var(--bg-card); padding: 8px 14px; font: inherit; font-size: 12.5px; color: var(--text-secondary); cursor: pointer; transition: all var(--dur-fast); border-right: 1px solid var(--border-soft); }
.sec-opt:last-child { border-right: 0; }
.sec-opt:hover { background: var(--bg-muted); }
.sec-opt--allow[data-active] { background: var(--status-done); color: #fff; }
.sec-opt--ask[data-active] { background: #d19240; color: #fff; }
.sec-opt--deny[data-active] { background: var(--status-error); color: #fff; }

/* ========= Settings: Restart ========= */
.restart-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.restart-card { display: grid; grid-template-columns: 44px 1fr auto; gap: 14px; align-items: center; padding: 16px 18px; background: var(--bg-card); border: 1px solid var(--border-soft); border-radius: var(--r-lg); text-align: left; font: inherit; color: inherit; transition: all var(--dur-fast); }
.restart-card:hover { border-color: var(--border-medium); background: var(--bg-muted); }
.restart-card[data-state="running"] { border-color: var(--accent); }
.restart-card__icon { width: 36px; height: 36px; border-radius: var(--r-sm); display: flex; align-items: center; justify-content: center; }
.restart-card__icon--blue { background: color-mix(in oklab, #3b6bb5 15%, var(--bg-card)); color: #3b6bb5; }
.restart-card__icon--indigo { background: color-mix(in oklab, #5b4cc2 15%, var(--bg-card)); color: #5b4cc2; }
.restart-card__icon--purple { background: color-mix(in oklab, #884ea0 15%, var(--bg-card)); color: #884ea0; }
.restart-card__icon--green { background: color-mix(in oklab, var(--status-done) 15%, var(--bg-card)); color: var(--status-done); }
.restart-card__icon--amber { background: color-mix(in oklab, #c48320 15%, var(--bg-card)); color: #a36510; }
.restart-card__icon--red { background: color-mix(in oklab, var(--status-error) 15%, var(--bg-card)); color: var(--status-error); }
.restart-card__name { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.restart-card__cmd { font-size: 11.5px; color: var(--text-secondary); margin-top: 3px; }
.restart-card__meta { font-size: 12px; color: var(--text-tertiary); white-space: nowrap; }

/* ========= Settings: Logs (terminal) ========= */
.logs-wrap { background: #17201a; border-radius: var(--r-lg); padding: 20px; border: 1px solid #1f2a22; }
.logs-term { background: #101a14; border: 1px solid #243128; border-radius: var(--r-md); overflow: hidden; }
.logs-term__head { display: flex; justify-content: space-between; align-items: center; padding: 10px 16px; border-bottom: 1px solid #243128; background: #0b1410; }
.logs-term__prompt { font-family: var(--font-mono); font-size: 12px; color: #6a8a7a; letter-spacing: 0.04em; }
.logs-term__meta { display: flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: 11px; color: #6a8a7a; }
.logs-term__dot { width: 7px; height: 7px; border-radius: 50%; background: #22c083; box-shadow: 0 0 6px #22c083; }
.logs-term__body { padding: 12px 0; font-family: var(--font-mono); font-size: 12.5px; line-height: 1.7; max-height: 520px; overflow-y: auto; }
.logs-term__line { display: grid; grid-template-columns: 42px 80px 1fr 14px; gap: 12px; padding: 1px 16px; }
.logs-term__line:hover { background: #0e1912; }
.logs-term__n { color: #4a6558; text-align: right; }
.logs-term__lvl { padding: 0 6px; border-radius: 3px; font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.04em; font-weight: 600; align-self: center; text-align: center; }
.logs-term__lvl--model { background: #2d4e6b; color: #9ec7e8; }
.logs-term__lvl--fallba { background: #6b4e2d; color: #e8c49e; }
.logs-term__lvl--dialog { background: #3a2d6b; color: #c8b8f0; }
.logs-term__lvl--pulse { background: #2d6b47; color: #b2e8c7; }
.logs-term__lvl--skill { background: #6b432d; color: #f0c0a8; }
.logs-term__lvl--mem { background: #6b2d5a; color: #f0b8d0; }
.logs-term__lvl--tg { background: #2d5a6b; color: #b8d8e8; }
.logs-term__lvl--http { background: #2d6b6b; color: #b8e8e8; }
.logs-term__lvl--sec { background: #5a2d2d; color: #f0b8b8; }
.logs-term__lvl--auth { background: #6b2d2d; color: #f0a8a8; }
.logs-term__msg { color: #c0d4ca; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.logs-term__tail { color: #6b4e2d; opacity: 0.6; }
.logs-term__caret { padding: 0 16px; color: #22c083; animation: caret 1s steps(2) infinite; }
@keyframes caret { 50% { opacity: 0; } }

/* Coming cards */
.coming-card { padding: 0; overflow: hidden; position: relative; min-height: 200px; display: flex; }
.coming-card__pattern { position: absolute; inset: 0; pointer-events: none; }
.coming-card__inner { padding: 20px; position: relative; display: flex; flex-direction: column; gap: 4px; z-index: 1; }
.coming-card__icon { width: 44px; height: 44px; border-radius: var(--r-md); background: var(--accent-soft); color: var(--accent-ink); display: flex; align-items: center; justify-content: center; margin-bottom: 10px; }

/* Settings */
.api-card { padding: 16px; display: flex; flex-direction: column; gap: 6px; min-height: 140px; }
.api-card__head { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; }
.api-card__foot { display: flex; justify-content: space-between; align-items: center; margin-top: auto; padding-top: 10px; border-top: 1px solid var(--border-soft); }
.heart { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.heart__row { display: flex; align-items: center; gap: 12px; padding: 10px 12px; font-size: 13px; }

.policy { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.policy__row { display: flex; align-items: center; gap: 14px; padding: 12px 10px; border-radius: var(--r-md); font-size: 13.5px; }
.policy__row:hover { background: var(--bg-inset); }
.toggle { width: 34px; height: 20px; border-radius: 99px; background: var(--border-medium); position: relative; flex-shrink: 0; transition: background var(--dur-fast); }
.toggle > span { position: absolute; left: 2px; top: 2px; width: 16px; height: 16px; border-radius: 50%; background: #fff; transition: transform var(--dur-med) var(--ease-out); box-shadow: var(--sh-xs); }
.toggle--on { background: var(--accent); }
.toggle--on > span { transform: translateX(14px); }

.kv { display: grid; grid-template-columns: 1fr; gap: 8px; margin: 0; padding: 0; }
.kv > div { display: grid; grid-template-columns: 180px 1fr; gap: 8px; padding: 6px 0; font-size: 13px; }
.kv dt { font-size: 11.5px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-secondary); margin: 0; }
.kv dd { margin: 0; }

.tutorial { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.tutorial__row { display: flex; align-items: center; gap: 14px; padding: 12px; border: 1px solid var(--border-soft); border-radius: var(--r-md); font-size: 13.5px; }
.tutorial__row[data-done] { background: var(--bg-inset); opacity: 0.7; }
.tutorial__idx { width: 24px; height: 24px; border-radius: 50%; background: var(--bg-muted); display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 600; color: var(--text-secondary); }
.tutorial__row[data-done] .tutorial__idx { background: var(--accent-soft); color: var(--accent-ink); }

/* ---------- Login ---------- */
.login { min-height: 100vh; display: flex; align-items: center; justify-content: center; position: relative; padding: 20px; overflow: hidden; background: var(--bg-canvas); }
.login__bg { position: absolute; inset: 0; pointer-events: none; }
.login__card { background: var(--bg-card); border-radius: var(--r-2xl); padding: 40px 44px; max-width: 420px; width: 100%; text-align: center; border: 1px solid var(--border-soft); box-shadow: var(--sh-lg); position: relative; z-index: 1; }
.login__form { display: flex; flex-direction: column; gap: 8px; text-align: left; margin-top: 24px; }
.login__hint { margin-top: 18px; text-align: center; }

/* ---------- 404 / Empty ---------- */
.empty-screen { display: flex; min-height: calc(100vh - var(--topbar-h) - 60px); align-items: center; justify-content: center; text-align: center; }
.empty-screen__pattern { position: absolute; inset: 0; pointer-events: none; overflow: hidden; opacity: 0.8; }
.empty-screen__inner { position: relative; display: flex; flex-direction: column; align-items: center; gap: 4px; }

/* ---------- Palette ---------- */
.ely-palette-scrim { position: fixed; inset: 0; background: rgba(26, 18, 10, 0.22); backdrop-filter: blur(3px); z-index: 90; display: flex; justify-content: center; align-items: flex-start; padding-top: 10vh; animation: fadeOnly var(--dur-fast) both; }
.ely-palette { width: 600px; max-width: 94vw; background: var(--bg-card); border-radius: var(--r-lg); box-shadow: var(--sh-lg); border: 1px solid var(--border-soft); display: flex; flex-direction: column; overflow: hidden; animation: slideDown var(--dur-med) var(--ease-out) both; }
@keyframes slideDown { from { transform: translateY(-8px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.ely-palette__head { display: flex; align-items: center; gap: 12px; padding: 14px 16px; border-bottom: 1px solid var(--border-soft); color: var(--text-muted); }
.ely-palette__input { flex: 1; border: 0; outline: none; font-size: 15px; background: transparent; color: var(--text-primary); }
.ely-palette__body { max-height: 420px; overflow-y: auto; padding: 8px 8px 10px; }
.ely-palette__group { margin-top: 8px; }
.ely-palette__group:first-child { margin-top: 2px; }
.ely-palette__label { padding: 4px 10px 6px; }
.ely-palette__row { display: flex; align-items: center; gap: 10px; width: 100%; padding: 8px 10px; border-radius: var(--r-sm); text-align: left; font-size: 13.5px; color: var(--text-primary); }
.ely-palette__row[data-active] { background: var(--accent-faint); }
.ely-palette__icon { color: var(--text-secondary); width: 20px; display: flex; justify-content: center; }
.ely-palette__text { flex: 1; }
.ely-palette__foot { display: flex; gap: 16px; padding: 10px 16px; border-top: 1px solid var(--border-soft); background: var(--bg-inset); color: var(--text-muted); }
.ely-palette__empty { padding: 40px; text-align: center; }

/* ---------- Tweaks panel ---------- */
.tweaks { position: fixed; right: 20px; bottom: 20px; top: 80px; width: 320px; background: var(--bg-card); border-radius: var(--r-lg); border: 1px solid var(--border-soft); box-shadow: var(--sh-lg); z-index: 70; display: flex; flex-direction: column; overflow: hidden; animation: slideIn var(--dur-med) var(--ease-out) both; }
.tweaks__head { display: flex; justify-content: space-between; align-items: flex-start; padding: 14px 16px; border-bottom: 1px solid var(--border-soft); background: var(--bg-inset); }
.tweaks__section { padding: 14px 16px; border-bottom: 1px solid var(--border-soft); display: flex; flex-direction: column; gap: 8px; }
.tweaks__section:last-child { border-bottom: 0; }
.tweaks__dirs { display: flex; flex-direction: column; gap: 4px; }
.tweaks__dir { display: flex; gap: 10px; align-items: center; padding: 8px; border-radius: var(--r-sm); text-align: left; border: 1px solid transparent; transition: border-color var(--dur-fast), background var(--dur-fast); }
.tweaks__dir:hover { background: var(--bg-inset); }
.tweaks__dir[data-active] { border-color: var(--accent); background: var(--accent-faint); }
.tweaks__dir-name { font-size: 13px; }
.tweaks__dir-swatch { display: flex; width: 40px; height: 28px; border-radius: var(--r-sm); overflow: hidden; border: 1px solid var(--border-soft); }
.tweaks__dir-swatch span { flex: 1; }
.tweaks__dir-swatch[data-variant="A"] span:nth-child(1) { background: #F5F0E8; }
.tweaks__dir-swatch[data-variant="A"] span:nth-child(2) { background: #FFFFFF; }
.tweaks__dir-swatch[data-variant="A"] span:nth-child(3) { background: #D97757; }
.tweaks__dir-swatch[data-variant="B"] span:nth-child(1) { background: #FAF6EE; }
.tweaks__dir-swatch[data-variant="B"] span:nth-child(2) { background: #FFFFFF; }
.tweaks__dir-swatch[data-variant="B"] span:nth-child(3) { background: #C5653F; }
.tweaks__dir-swatch[data-variant="C"] span:nth-child(1) { background: #F2EEE5; }
.tweaks__dir-swatch[data-variant="C"] span:nth-child(2) { background: #FFFFFF; }
.tweaks__dir-swatch[data-variant="C"] span:nth-child(3) { background: #CC6A46; }
.tweaks__dir-swatch[data-variant="D"] span:nth-child(1) { background: #EFE7D5; }
.tweaks__dir-swatch[data-variant="D"] span:nth-child(2) { background: #FBF7EE; }
.tweaks__dir-swatch[data-variant="D"] span:nth-child(3) { background: #D36A43; }
.tweaks__colors { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
.tweaks__color { width: 100%; aspect-ratio: 1; border-radius: var(--r-full); border: 2px solid transparent; transition: transform var(--dur-fast); }
.tweaks__color:hover { transform: scale(1.08); }
.tweaks__color[data-active] { border-color: var(--text-primary); }

/* ---------- Mobile ---------- */
@media (max-width: 960px) {
  .ely-app { grid-template-columns: 1fr !important; }
  .ely-sidebar { display: none; }
  .ely-sidebar.is-open { display: flex; position: fixed; inset: 0 auto 0 0; width: 260px; z-index: 95; box-shadow: var(--sh-lg); }
  .mobile-scrim { position: fixed; inset: 0; background: rgba(26,18,10,0.25); z-index: 94; }
  .screen { padding: 20px 16px 40px; }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: 1fr; }
  .grid-2 { grid-template-columns: 1fr; }
  .grid-overview, .grid-overview-2 { grid-template-columns: 1fr; }
  .kanban { grid-template-columns: 1fr; gap: 12px; }
  .kanban--week { grid-template-columns: 1fr; }
  .mem-brain { grid-template-columns: 1fr; }
  .mem-core { grid-template-columns: 1fr; }
  .roadmap { grid-template-columns: 1fr; }
  .ely-search { display: none; }
  .screen__head { flex-direction: column; align-items: flex-start; }
  .drawer { width: 100%; }
  .tweaks { right: 12px; left: 12px; width: auto; top: auto; bottom: 12px; max-height: 70vh; overflow-y: auto; }
  .tbl thead { display: none; }
  .tbl tbody tr { display: grid; grid-template-columns: 1fr; padding: 10px 0; border-bottom: 1px solid var(--border-soft); }
  .tbl tbody td { border: 0; padding: 4px 14px; }
  .filters { gap: 10px; }
  .ely-topbar { padding: 0 12px; }
  .ely-live { display: none; }
}

/* Tweaks toggle button (outside the panel, floating) */
.tweaks-fab { position: fixed; right: 20px; bottom: 20px; z-index: 60; height: 40px; padding: 0 14px; border-radius: var(--r-full); background: var(--text-primary); color: #fff; font-size: 12.5px; display: flex; align-items: center; gap: 6px; box-shadow: var(--sh-md); }
.tweaks-fab:hover { background: #000; }

/* ===================== MONTH CALENDAR ===================== */
.cal-month {
  display: flex; flex-direction: column; gap: 14px;
  height: 100%;
  min-height: 0;
}
.cal-month__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0;
}
.cal-month__title {
  font-size: 20px;
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: -0.01em;
}
.cal-month__nav { display: inline-flex; align-items: center; gap: 8px; }
.seg--compact { height: 30px; }
.seg--compact .seg__btn { padding: 0 12px; font-size: 12.5px; }

.cal-nav__btn, .cal-nav__today {
  display: inline-flex; align-items: center; justify-content: center;
  height: 30px; padding: 0 12px;
  border-radius: 6px;
  background: transparent;
  border: 1px solid var(--border-soft);
  color: var(--text-secondary);
  font-size: 12.5px; font-weight: 500;
  cursor: pointer;
  transition: background var(--dur-fast), color var(--dur-fast), border-color var(--dur-fast);
}
.cal-nav__btn { width: 30px; padding: 0; }
.cal-nav__btn:hover, .cal-nav__today:hover {
  background: var(--bg-inset);
  color: var(--text-primary);
  border-color: var(--border-strong);
}

.cal-month__weekhead {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 0;
}
.cal-month__wh {
  font-size: 10.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 600;
  padding: 6px 10px 10px;
  text-align: left;
}
.cal-month__wh.is-weekend { color: var(--text-muted); }

.cal-month__grid {
  flex: 1; min-height: 0;
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  grid-auto-rows: minmax(0, 1fr);
  gap: 0;
  overflow: hidden;
  width: 100%;
  border-top: 1px solid var(--border-soft);
  border-left: 1px solid var(--border-soft);
}
.cal-month__grid.is-week {
  grid-auto-rows: minmax(0, 1fr);
  grid-template-rows: 1fr;
}
.cal-month__grid.is-week .cal-cell { overflow-y: auto; }
.cal-month__grid.is-week .cal-cell__items { gap: 3px; }

.cal-cell {
  background: transparent;
  display: flex; flex-direction: column;
  min-height: 110px;
  min-width: 0;
  padding: 6px 8px 8px;
  position: relative;
  border-right: 1px solid var(--border-soft);
  border-bottom: 1px solid var(--border-soft);
  transition: background var(--dur-fast);
  overflow: hidden;
}
.cal-cell.is-past { background: rgba(0, 0, 0, 0.055); }
.cal-cell.is-past .cal-cell__date { color: var(--text-muted); }
.cal-cell.is-past .cal-item { opacity: 0.55; }
.cal-cell.is-future { background: transparent; }
.cal-cell.is-today { background: color-mix(in oklab, var(--yellow) 22%, transparent); }
/* Other-month cells: keep same bg, add a very light diagonal hatch overlay */
.cal-cell.is-other {
  background-image: repeating-linear-gradient(
    -45deg,
    transparent 0,
    transparent 7px,
    color-mix(in oklab, var(--border-soft) 65%, transparent) 7px,
    color-mix(in oklab, var(--border-soft) 65%, transparent) 8px
  );
}
.cal-cell.is-other.is-past {
  background-color: rgba(0, 0, 0, 0.055);
}
.cal-cell.is-drop {
  background: color-mix(in oklab, var(--text-secondary) 7%, transparent);
}
.cal-cell.is-expanded {
  overflow-y: auto;
  z-index: 2;
}

.cal-cell__head {
  display: flex; align-items: center; gap: 6px;
  margin-bottom: 4px;
  min-height: 20px;
}
.cal-cell__date {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-secondary);
  width: 22px; height: 22px;
  display: inline-flex; align-items: center; justify-content: center;
}
.cal-cell.is-today .cal-cell__date {
  background: var(--yellow-text, #8B6914);
  color: var(--bg-card);
  border-radius: 50%;
  font-weight: 600;
}

.cal-cell__items { display: flex; flex-direction: column; gap: 2px; min-height: 0; }

.cal-item {
  display: flex; align-items: center; gap: 6px;
  padding: 2px 6px;
  border-radius: 2px;
  font-size: 11.5px;
  line-height: 1.3;
  cursor: grab;
  background: transparent;
  border: 0;
  text-align: left;
  transition: filter var(--dur-fast), opacity var(--dur-fast);
  overflow: hidden;
}
.cal-item:hover { background: color-mix(in oklab, var(--text-primary) 5%, transparent); }
.cal-item.is-dragging { opacity: 0.35; cursor: grabbing; }
.cal-item--mine {
  color: var(--text-primary);
  border-left: 2px solid color-mix(in oklab, var(--text-secondary) 55%, transparent);
}
.cal-item--ellie {
  color: var(--text-primary);
  border-left: 2px solid #C4934A;
}
.cal-item__title {
  flex: 1;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  font-weight: 500;
}
.cal-item.is-done { opacity: 1; }
.cal-item.is-done .cal-item__title {
  color: var(--text-subtle);
}
/* Priority tint on calendar pill — left accent bar. */
.cal-item[data-priority] { position: relative; overflow: hidden; }
.cal-item[data-priority]::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; border-radius: 2px 0 0 2px; }
.cal-item[data-priority="high"]::before { background: #D04A3B; }
.cal-item[data-priority="med"]::before  { background: #E0A23B; }
.cal-item[data-priority="low"]::before  { background: #3B9A5B; }

.cal-more {
  display: inline-flex; align-items: center;
  padding: 2px 6px;
  border: 0;
  background: transparent;
  color: var(--text-muted);
  font-size: 11px;
  cursor: pointer;
  text-align: left;
  border-radius: 3px;
}
.cal-more:hover { background: var(--bg-inset); color: var(--text-secondary); }


/* ============================================================
   PLANNING SCREEN
   ============================================================ */

/* --- Document view --- */
.plan-doc {
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr);
  gap: 20px;
  align-items: flex-start;
}

.plan-doc__toc {
  position: sticky;
  top: 24px;
  padding: 14px 14px 16px;
  max-height: calc(100vh - 80px);
  overflow-y: auto;
}
.plan-doc__toc-head { padding: 4px 4px 10px; border-bottom: 1px solid var(--border-soft); margin-bottom: 8px; }

.plan-toc { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 1px; }
.plan-toc a {
  display: block; padding: 5px 8px; border-radius: var(--r-sm);
  font-size: 12.5px; color: var(--text-secondary); text-decoration: none;
  line-height: 1.45;
}
.plan-toc a:hover { background: var(--bg-nav-hover); color: var(--text-primary); }
.plan-toc__h1 > a { font-weight: 600; color: var(--text-primary); margin-top: 6px; }
.plan-toc__h2 > a { padding-left: 18px; color: var(--text-secondary); font-size: 12px; }

.plan-doc__page { padding: 0; overflow: hidden; }
.plan-doc__meta {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 28px; border-bottom: 1px solid var(--border-soft);
  background: var(--bg-inset);
}
.plan-doc__body { padding: 28px 36px 40px; max-width: 760px; }
.plan-doc__body h1 { font-size: 28px; font-weight: 700; letter-spacing: -0.025em; margin: 0 0 12px; font-family: var(--font-display); }
.plan-doc__body h2 { font-size: 20px; font-weight: 700; letter-spacing: -0.018em; margin: 28px 0 10px; font-family: var(--font-display); padding-top: 12px; border-top: 1px solid var(--border-soft); }
.plan-doc__body h2:first-of-type { border-top: none; padding-top: 0; }
.plan-doc__body h3 { font-size: 14.5px; font-weight: 600; margin: 18px 0 8px; color: var(--text-primary); }
.plan-doc__body .lede { font-size: 14.5px; line-height: 1.6; color: var(--text-secondary); margin: 0 0 18px; }

.plan-doc__body .callout {
  background: var(--accent-faint);
  border-left: 3px solid var(--accent);
  padding: 12px 16px;
  border-radius: 0 var(--r-md) var(--r-md) 0;
  margin: 12px 0 18px;
}
.plan-doc__body .callout__title { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--accent-ink, var(--accent)); margin-bottom: 4px; }
.plan-doc__body .callout p { margin: 0; font-size: 13.5px; line-height: 1.55; }

.plan-table { width: 100%; border-collapse: collapse; margin: 8px 0 14px; font-size: 13px; }
.plan-table th { text-align: left; padding: 8px 10px; border-bottom: 1px solid var(--border-medium); font-weight: 600; color: var(--text-secondary); font-size: 12px; }
.plan-table td { padding: 10px; border-bottom: 1px solid var(--border-soft); vertical-align: top; }
.plan-table tr:last-child td { border-bottom: none; }

.role-pill {
  display: inline-block; font-size: 11px; padding: 1px 8px; border-radius: var(--r-full);
  background: var(--bg-muted); color: var(--text-secondary); font-family: var(--font-mono);
}
.status-pill {
  display: inline-block; font-size: 11px; padding: 1px 9px; border-radius: var(--r-full);
  font-weight: 500;
}
.status-pill--ok { background: color-mix(in oklab, #7BAA75 18%, transparent); color: #4d7548; }
.status-pill--warn { background: color-mix(in oklab, #C68E3F 22%, transparent); color: #8a5e22; }
.status-pill--soft { background: var(--bg-muted); color: var(--text-secondary); }

.plan-project {
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  padding: 14px 16px;
  margin: 10px 0;
  background: var(--bg-inset);
}
.plan-project__head { display: flex; align-items: center; gap: 10px; margin-bottom: 6px; }
.plan-project__head h3 { margin: 0; font-size: 15px; font-weight: 600; flex: 1; }
.plan-project__dot { width: 10px; height: 10px; border-radius: 50%; }
.plan-project p { margin: 4px 0 10px; font-size: 13px; color: var(--text-secondary); line-height: 1.5; }
.plan-project__bar { height: 4px; background: var(--bg-muted); border-radius: 2px; overflow: hidden; margin-bottom: 4px; }
.plan-project__bar-fill { height: 100%; background: var(--accent); border-radius: 2px; }

/* --- Mind Map view --- */
.plan-mind { padding: 0; overflow: hidden; }
.plan-mind__toolbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 16px; border-bottom: 1px solid var(--border-soft);
  background: var(--bg-inset);
}
.plan-mind__canvas {
  background: var(--bg-canvas);
  min-height: 600px;
  padding: 16px;
  overflow-x: auto;
  overflow-y: hidden;
}
.plan-mind__svg { display: block; width: 100%; min-width: 980px; }

.mind-node {
  background: var(--bg-card);
  border: 1.5px solid var(--border-medium);
  border-radius: var(--r-md);
  padding: 8px 12px;
  font-size: 12.5px;
  box-shadow: var(--sh-sm);
  display: flex; align-items: center; gap: 8px;
  height: 100%;
  box-sizing: border-box;
}
.mind-node--center {
  background: var(--accent);
  color: white;
  border-color: transparent;
  flex-direction: column;
  align-items: flex-start;
  gap: 3px;
  padding: 12px 18px;
  justify-content: center;
}
.mind-node--center .mind-node__eyebrow { font-size: 10px; opacity: 0.85; letter-spacing: 0.12em; text-transform: uppercase; font-family: var(--font-mono); line-height: 1.2; white-space: nowrap; }
.mind-node--center .mind-node__title { font-size: 18px; font-weight: 700; letter-spacing: -0.015em; font-family: var(--font-display); line-height: 1.15; }
.mind-node--center .mind-node__meta { font-size: 10.5px; opacity: 0.82; font-family: var(--font-mono); margin-top: 2px; line-height: 1.2; }

.mind-node--branch {
  font-weight: 600;
  border-width: 1px;
  border-left-width: 4px;
  justify-content: flex-start;
  padding: 8px 12px;
  box-shadow: var(--sh-sm);
}

.mind-node__branch-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.mind-node__branch-note { font-size: 10.5px; font-weight: 500; color: var(--text-muted); font-family: var(--font-mono); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mind-node__dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.mind-node__label { font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.mind-node--leaf-wrap { }
.mind-node--leaf {
  background: var(--bg-card);
  border: 1px solid var(--border-soft);
  border-left: 3px solid var(--accent);
  border-radius: var(--r-md);
  padding: 6px 10px;
  font-size: 12px;
  box-shadow: none;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 2px;
  height: 100%;
  box-sizing: border-box;
}
.mind-node__leaf-title { font-size: 12.5px; font-weight: 600; color: var(--text-primary); line-height: 1.25; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mind-node__leaf-note { font-size: 10.5px; color: var(--text-muted); font-family: var(--font-mono); line-height: 1.3; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* --- Sprints list (archive view) --- */
.plan-sprints-list { display: flex; flex-direction: column; gap: 10px; }

.plan-sprint-row {
  padding: 0;
  overflow: hidden;
  transition: box-shadow 120ms ease, border-color 120ms ease;
}
.plan-sprint-row:hover { border-color: var(--border-medium); }
.plan-sprint-row[data-status="active"] {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-faint);
}
.plan-sprint-row[data-status="done"] { opacity: 0.94; }

.plan-sprint-row__head {
  display: grid;
  grid-template-columns: 24px 1fr 220px;
  gap: 14px;
  align-items: center;
  width: 100%;
  padding: 14px 18px;
  background: transparent;
  border: none;
  text-align: left;
  cursor: pointer;
  transition: background 120ms ease;
}
.plan-sprint-row__head:hover { background: var(--bg-inset); }
.plan-sprint-row[data-open] .plan-sprint-row__head { background: var(--bg-inset); }

.plan-sprint-row__chev {
  display: flex; align-items: center; justify-content: center;
  color: var(--text-muted);
  transition: transform 180ms ease;
}

.plan-sprint-row__main { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.plan-sprint-row__top { display: flex; align-items: center; gap: 12px; }
.plan-sprint-row__title { display: flex; align-items: baseline; gap: 10px; }
.plan-sprint-row__num { font-size: 12px; color: var(--text-muted); }
.plan-sprint-row__dates { font-size: 15px; font-weight: 600; letter-spacing: -0.01em; font-family: var(--font-display); color: var(--text-primary); }
.plan-sprint-row__sub { font-size: 12.5px; color: var(--text-secondary); }

.plan-sprint-row__stats { display: flex; flex-direction: column; gap: 6px; align-items: stretch; }
.plan-sprint-row__bar { height: 4px; background: var(--bg-muted); border-radius: 2px; overflow: hidden; }
.plan-sprint-row__bar-fill { height: 100%; background: var(--accent); border-radius: 2px; transition: width 200ms ease; }
.plan-sprint-row[data-status="done"] .plan-sprint-row__bar-fill { background: #7BAA75; }
.plan-sprint-row__count { font-size: 11px; color: var(--text-muted); text-align: right; }

.plan-sprint-row__body {
  padding: 4px 18px 16px 56px;
  background: var(--bg-inset);
  border-top: 1px solid var(--border-soft);
  animation: fade-in 180ms ease;
}
.plan-sprint-row__projects { display: flex; flex-wrap: wrap; gap: 6px; padding-top: 12px; }
.plan-sprint-row__items { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 2px; }
.plan-sprint-row__item {
  display: grid;
  grid-template-columns: 18px 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 6px 8px;
  border-radius: var(--r-sm);
  font-size: 13px;
}
.plan-sprint-row__item:hover { background: var(--bg-card); }
.plan-sprint-row__item-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--border-medium);
}
.plan-sprint-row__item[data-st="done"] .plan-sprint-row__item-dot { background: #7BAA75; }
.plan-sprint-row__item[data-st="doing"] .plan-sprint-row__item-dot { background: var(--accent); box-shadow: 0 0 0 3px var(--accent-faint); }
.plan-sprint-row__item[data-st="done"] .plan-sprint-row__item-text { text-decoration: line-through; color: var(--text-muted); }
.plan-sprint-row__item-status { font-size: 10.5px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.06em; }
.plan-sprint-row__footer { margin-top: 10px; display: flex; justify-content: flex-start; }

@media (max-width: 780px) {
  .plan-sprint-row__head { grid-template-columns: 20px 1fr; }
  .plan-sprint-row__stats { grid-column: 1 / -1; margin-left: 30px; margin-top: 4px; }
  .plan-sprint-row__body { padding-left: 20px; }
}

/* --- Doc editing mode --- */
.plan-doc__page[data-editing] .plan-doc__body {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
  background: color-mix(in oklab, var(--accent-faint) 50%, var(--bg-card));
}
.plan-doc__body:focus { outline: 2px solid var(--accent); outline-offset: -2px; }

/* --- Sprints view (legacy, unused) --- */
.plan-sprints {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
}
.plan-sprint { padding: 16px 18px; display: flex; flex-direction: column; gap: 10px; }
.plan-sprint--active { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-faint); }
.plan-sprint--done { opacity: 0.85; }
.plan-sprint__head { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; }
.plan-sprint__title { font-size: 16px; font-weight: 600; letter-spacing: -0.01em; margin-top: 2px; font-family: var(--font-display); }
.plan-sprint__bar { height: 4px; background: var(--bg-muted); border-radius: 2px; overflow: hidden; }
.plan-sprint__bar-fill { height: 100%; background: var(--accent); border-radius: 2px; }
.plan-sprint--done .plan-sprint__bar-fill { background: #7BAA75; }
.plan-sprint__meta { display: flex; justify-content: space-between; font-size: 12px; color: var(--text-secondary); }
.plan-sprint__projects { display: flex; flex-wrap: wrap; gap: 6px; }
.pill-soft { background: var(--bg-muted); border: none; color: var(--text-secondary); }
.plan-sprint__open { align-self: flex-start; margin-top: 4px; }

@media (max-width: 900px) {
  .plan-doc { grid-template-columns: 1fr; }
  .plan-doc__toc { position: static; max-height: none; }
}


/* ============================================================
   PLAN · REPORTS (diary view)
   ============================================================ */
.plan-reports {
  display: grid;
  grid-template-columns: 340px minmax(0, 1fr);
  gap: 20px;
  align-items: flex-start;
}
.plan-reports__nav {
  display: flex; flex-direction: column; gap: 10px;
  position: sticky; top: 24px;
  max-height: calc(100vh - 80px);
  overflow-y: auto;
  padding-right: 4px;
}
.plan-reports__nav-head { padding: 2px 2px 4px; }

.plan-diary-month {
  background: var(--bg-card);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  overflow: hidden;
}
.plan-diary-month__head {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 12px;
  width: 100%;
  text-align: left;
  font-size: 13px; font-weight: 600;
  color: var(--text-primary);
  background: transparent;
}
.plan-diary-month__head:hover { background: var(--bg-nav-hover); }
.plan-diary-month__icon { color: var(--text-muted); display: inline-flex; }
.plan-diary-month__label { flex: 1; }
.plan-diary-month__count { font-size: 11px; color: var(--text-muted); font-family: var(--font-mono); }
.plan-diary-month__chev { color: var(--text-muted); display: inline-flex; transition: transform 160ms ease; }
.plan-diary-month[data-open] .plan-diary-month__head { border-bottom: 1px solid var(--border-soft); }
.plan-diary-month__body { padding: 4px 2px 8px; }

.plan-diary-days { list-style: none; padding: 4px 0; margin: 0; display: flex; flex-direction: column; gap: 0; }
.plan-diary-day {
  display: grid; grid-template-columns: 14px 26px 1fr; align-items: center;
  gap: 6px;
  padding: 4px 10px;
  font-size: 12px;
  color: var(--text-secondary);
  min-height: 26px;
}
.plan-diary-day__dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--border-medium);
  margin-left: 3px;
}
.plan-diary-day[data-status="done"] .plan-diary-day__dot { background: #7BAA75; }
.plan-diary-day[data-status="active"] .plan-diary-day__dot { background: var(--accent); box-shadow: 0 0 0 3px var(--accent-faint); }
.plan-diary-day[data-status="empty"] .plan-diary-day__dot { background: var(--bg-muted); border: 1px solid var(--border-soft); }
.plan-diary-day__num { font-size: 11px; color: var(--text-muted); }
.plan-diary-day__title {
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  color: var(--text-primary);
  font-size: 12px;
}
.plan-diary-day[data-status="empty"] .plan-diary-day__title::after { content: ""; }

.plan-diary-weeks { display: flex; flex-direction: column; gap: 4px; padding: 6px 8px 8px; border-top: 1px dashed var(--border-soft); margin-top: 4px; }
.plan-diary-week {
  display: grid; grid-template-columns: 14px 1fr auto;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border-radius: var(--r-sm);
  background: transparent;
  text-align: left;
  color: var(--text-secondary);
  font-size: 12.5px;
}
.plan-diary-week:hover { background: var(--bg-nav-hover); color: var(--text-primary); }
.plan-diary-week[data-active] { background: var(--accent); color: white; }
.plan-diary-week[data-active] .plan-diary-week__sub { color: rgba(255,255,255,0.78); }
.plan-diary-week__label { font-weight: 600; }
.plan-diary-week__sub { font-size: 11px; color: var(--text-muted); }

.plan-reports__page { padding: 0; overflow: hidden; }
.plan-reports__page-head {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 12px;
  padding: 16px 28px;
  border-bottom: 1px solid var(--border-soft);
  background: var(--bg-inset);
}
.plan-reports__title { font-size: 22px; font-weight: 700; letter-spacing: -0.02em; font-family: var(--font-display); margin: 2px 0 0; }

.plan-reports__body { padding: 22px 32px 36px; max-width: 760px; }
.plan-reports__body h3 {
  font-size: 16px; font-weight: 700; margin: 24px 0 10px;
  letter-spacing: -0.01em; font-family: var(--font-display);
  padding-top: 14px; border-top: 1px solid var(--border-soft);
}
.plan-reports__body h3:first-of-type { border-top: none; padding-top: 0; }
.plan-reports__body h4 { font-size: 13.5px; font-weight: 600; margin: 14px 0 6px; color: var(--text-primary); }

.callout--accent { background: var(--accent-faint); border-left: 3px solid var(--accent); padding: 14px 16px 12px; margin: 0 0 14px; border-radius: 0 var(--r-md) var(--r-md) 0; }
.callout--accent .callout__title { font-size: 11.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--accent-ink, var(--accent)); margin-bottom: 6px; }

.plan-reports__checklist, .plan-reports__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 3px; }
.plan-reports__checklist li,
.plan-reports__list li {
  position: relative; padding-left: 22px;
  font-size: 13.5px; line-height: 1.55;
  color: var(--text-primary);
}
.plan-reports__checklist li::before {
  content: "✓";
  position: absolute; left: 0; top: 0;
  color: #7BAA75;
  font-weight: 700; font-size: 13px;
}
.plan-reports__list li::before {
  content: "•";
  position: absolute; left: 6px; top: 0;
  color: var(--text-muted);
}

@media (max-width: 1100px) {
  .plan-reports { grid-template-columns: 1fr; }
  .plan-reports__nav { position: static; max-height: none; }
}


/* ============================================================
   PLAN · REPORTS — editing mode
   ============================================================ */
.plan-reports__page[data-editing] .plan-reports__body {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
  background: color-mix(in oklab, var(--accent-faint) 50%, var(--bg-card));
  min-height: 200px;
}
.plan-reports__body:focus { outline: 2px solid var(--accent); outline-offset: -2px; }

/* ============================================================
   PLAN · PHOTOS (фото дня, календарная сетка)
   ============================================================ */
.plan-photos { display: flex; flex-direction: column; gap: 12px; }

.plan-photos__head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0 4px;
}
.plan-photos__title { font-size: 20px; font-weight: 700; letter-spacing: -0.02em; font-family: var(--font-display); }
.plan-photos__sub { font-size: 12px; color: var(--text-muted); margin-top: 2px; }

.plan-photos__wd {
  display: grid; grid-template-columns: repeat(7, 1fr);
  gap: 6px;
  padding: 0 2px;
}
.plan-photos__wd-cell {
  font-size: 11px; font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase; letter-spacing: 0.08em;
  padding: 4px 6px;
}

.plan-photos__grid {
  display: grid; grid-template-columns: repeat(7, 1fr);
  gap: 6px;
}

.plan-photos__cell {
  position: relative;
  aspect-ratio: 1 / 1;
  background: var(--bg-card);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  overflow: hidden;
  padding: 0;
  text-align: left;
  cursor: pointer;
  transition: transform 120ms ease, box-shadow 120ms ease;
}
.plan-photos__cell:hover:not([data-empty]) {
  transform: translateY(-1px);
  box-shadow: var(--sh-md);
  border-color: var(--border-medium);
}
.plan-photos__cell--empty {
  background: transparent;
  border: 1px dashed var(--border-soft);
  cursor: default;
}
.plan-photos__cell[data-empty] {
  background: var(--bg-inset);
  cursor: default;
}
.plan-photos__cell[data-empty]:hover { transform: none; box-shadow: none; }

.plan-photos__day {
  position: absolute;
  top: 8px; left: 10px;
  z-index: 2;
  font-size: 11px;
  color: white;
  background: rgba(26, 18, 10, 0.55);
  padding: 2px 6px;
  border-radius: var(--r-sm);
  backdrop-filter: blur(4px);
  font-weight: 600;
}
.plan-photos__cell[data-empty] .plan-photos__day {
  background: transparent;
  color: var(--text-muted);
  padding: 0;
  backdrop-filter: none;
}

.plan-photos__img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}

.plan-photos__cap {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 16px 10px 8px;
  font-size: 11.5px;
  color: white;
  background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.65) 100%);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-weight: 500;
  z-index: 1;
}

.plan-photos__empty-mark {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  color: var(--border-medium);
  font-size: 18px;
}

/* Portrait vs landscape - no special handling; object-fit: cover handles it.
   Subtle aspect-indicator ribbon. */
.plan-photos__img[data-ratio="portrait"]::after { /* no-op, just semantic */ }

/* ============================================================
   LIGHTBOX
   ============================================================ */
.plan-lightbox {
  position: fixed; inset: 0;
  background: rgba(18, 14, 10, 0.88);
  z-index: 200;
  display: flex; align-items: center; justify-content: center;
  padding: 40px;
  animation: lb-fade 180ms ease;
}
@keyframes lb-fade { from { opacity: 0; } to { opacity: 1; } }

.plan-lightbox__close {
  position: absolute;
  top: 20px; right: 20px;
  width: 40px; height: 40px;
  border-radius: var(--r-full);
  background: rgba(255,255,255,0.1);
  color: white;
  display: flex; align-items: center; justify-content: center;
  border: none;
  transition: background 120ms ease;
}
.plan-lightbox__close:hover { background: rgba(255,255,255,0.2); }

.plan-lightbox__frame {
  max-width: min(90vw, 1400px);
  max-height: 90vh;
  display: flex; flex-direction: column;
  gap: 12px;
  animation: lb-zoom 220ms cubic-bezier(0.2, 0.8, 0.2, 1);
}
@keyframes lb-zoom { from { transform: scale(0.94); opacity: 0; } to { transform: scale(1); opacity: 1; } }

.plan-lightbox__img {
  max-width: 100%;
  max-height: calc(90vh - 80px);
  object-fit: contain;
  border-radius: var(--r-md);
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
  display: block;
  margin: 0 auto;
}

.plan-lightbox__cap {
  text-align: center;
  color: white;
}
.plan-lightbox__date { font-size: 12px; opacity: 0.7; letter-spacing: 0.08em; text-transform: uppercase; }
.plan-lightbox__title { font-size: 18px; font-weight: 600; margin-top: 4px; font-family: var(--font-display); }

@media (max-width: 700px) {
  .plan-photos__grid, .plan-photos__wd { gap: 3px; }
  .plan-photos__cap { font-size: 10px; padding: 12px 6px 6px; }
  .plan-photos__day { top: 4px; left: 5px; font-size: 10px; padding: 1px 4px; }
  .plan-lightbox { padding: 16px; }
}


/* ============ ЯДРО ============ */
.screen__sub { color: var(--text-secondary); font-size: 13px; margin-top: 6px; max-width: 720px; }

.core-cards {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
}
.core-card {
  display: grid; grid-template-columns: 44px 1fr auto; gap: 14px; align-items: start;
  padding: 18px 18px;
  background: var(--bg-card);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-profile-card);
  text-align: left; cursor: pointer;
  transition: border-color var(--dur-fast), background var(--dur-fast), transform var(--dur-fast), box-shadow var(--dur-fast);
  position: relative;
  font: inherit; color: inherit;
}
.core-card:hover { border-color: var(--border-strong); background: var(--bg-inset); }
.core-card:hover .core-card__open { opacity: 1; }
.core-card__icon {
  width: 44px; height: 44px; border-radius: 12px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--bg-muted);
  color: var(--text-secondary);
  border: 1px solid var(--border-soft);
}
.core-card__title { display: inline-flex; align-items: center; gap: 8px; font-size: 16px; font-weight: 600; color: var(--text-primary); font-family: var(--font-display); letter-spacing: -0.005em; }
.core-card__lock { color: var(--text-muted); }
.core-card__sub { font-size: 13px; color: var(--text-secondary); margin-top: 4px; line-height: 1.4; }
.core-card__meta { font-size: 11px; color: var(--text-muted); margin-top: 10px; font-family: var(--font-mono); letter-spacing: 0.04em; }
.core-card__open { color: var(--text-muted); opacity: 0; transition: opacity var(--dur-fast); align-self: start; margin-top: 4px; }

.core-card[data-tone="indigo"] .core-card__icon { background: #E6E1F2; color: #5B4D8A; border-color: #D9D2E8; }
.core-card[data-tone="rose"]   .core-card__icon { background: #F5E1DA; color: #9C5340; border-color: #ECD3C9; }
.core-card[data-tone="violet"] .core-card__icon { background: #EAD9E8; color: #6E3A66; border-color: #DEC9DA; }
.core-card[data-tone="amber"]  .core-card__icon { background: #F2E5C8; color: #7A5A1F; border-color: #E5D4AC; }

.core-card[data-featured] {
  background: var(--accent-faint);
  border-color: var(--accent-soft);
}
.core-card[data-featured] .core-card__icon { background: var(--accent-soft); color: var(--accent-ink); border-color: rgba(217,119,87,0.3); }

.core-status__grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
}

/* ---- Tab 2: ядро личности (доки) ---- */
.core-doc {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 16px;
  align-items: stretch;
  min-height: 600px;
}
.core-doc__tree { padding: 12px 8px; }
.core-doc__group { margin-bottom: 6px; }
.core-doc__group-head {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  width: 100%; padding: 8px 10px;
  font-size: 11px; font-weight: 600; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: 0.08em;
  font-family: var(--font-mono);
}
.core-doc__group-title { flex: 1; }
.core-doc__group-count { color: var(--text-muted); font-family: var(--font-mono); font-size: 11px; font-weight: 600; }
.core-doc__list { list-style: none; margin: 4px 0 8px; padding: 0; }
.core-doc__add {
  display: inline-flex; align-items: center; gap: 6px;
  width: 100%; padding: 8px 10px; margin-top: 4px;
  background: transparent; border: 1px dashed var(--border-soft); border-radius: 8px;
  color: var(--text-muted); font-size: 12px; cursor: pointer;
  transition: all var(--dur-fast);
}
.core-doc__add:hover { border-color: var(--accent); color: var(--accent); background: color-mix(in oklab, var(--accent) 5%, transparent); }
.core-doc__item {
  display: block; width: 100%;
  padding: 7px 10px; border-radius: 7px;
  background: transparent; border: 0; cursor: pointer; text-align: left;
  font-size: 13px; color: var(--text-secondary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  transition: background var(--dur-fast), color var(--dur-fast);
}
.core-doc__item:hover { background: var(--bg-nav-hover); color: var(--text-primary); }
.core-doc__item[data-active] { background: var(--bg-nav-active); color: var(--text-primary); font-weight: 600; }
.core-doc__empty { padding: 6px 10px; font-size: 12px; color: var(--text-muted); list-style: none; }

.core-doc__editor { padding: 0; display: flex; flex-direction: column; }
.core-doc__crumbs {
  display: flex; align-items: center; gap: 8px;
  padding: 14px 20px;
  border-bottom: 1px solid var(--border-soft);
  font-size: 12px; color: var(--text-secondary);
}
.core-doc__crumbs-sep { color: var(--text-muted); }
.core-doc__crumbs-actions { margin-left: auto; display: inline-flex; gap: 2px; }

.core-doc__head {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 22px 24px 10px;
}
.core-doc__h { font-family: var(--font-display); font-size: 24px; font-weight: 600; letter-spacing: -0.01em; margin: 0; }
.core-doc__listen { white-space: nowrap; }

.core-doc__yaml {
  margin: 4px 24px 16px;
  padding: 14px 16px;
  border-radius: 10px;
  background: var(--bg-inset);
  border: 1px solid var(--border-soft);
  font-size: 12.5px;
  line-height: 1.7;
  color: var(--text-primary);
}
.core-doc__yaml .yk { color: var(--accent-ink); }
.core-doc__yaml .yv { color: var(--text-secondary); }
.core-doc__yaml .yaml-list { margin: 4px 0 4px 18px; padding: 0; color: var(--text-secondary); }

.core-doc__body { padding: 0 24px 24px; }

@media (max-width: 980px) {
  .core-cards { grid-template-columns: 1fr; }
  .core-status__grid { grid-template-columns: repeat(2, 1fr); }
  .core-doc { grid-template-columns: 1fr; }
}

/* ========= Settings: Development (Kanban) ========= */
.kanban { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; align-items: start; }
.kanban--dev3 { grid-template-columns: 1fr 1fr 1fr; }
@media (max-width: 1080px) { .kanban, .kanban--dev3 { grid-template-columns: 1fr; } }

/* Scope badges */
.scope-badges { display: inline-flex; gap: 4px; flex-shrink: 0; }
.scope-badge {
  display: inline-flex; align-items: center;
  font-size: 10.5px; font-weight: 600; letter-spacing: 0.02em;
  padding: 2px 7px; border-radius: 999px;
  border: 1px solid transparent; white-space: nowrap;
  line-height: 1.4;
}
.scope-badge--ely {
  background: color-mix(in oklab, var(--accent) 12%, transparent);
  color: var(--accent);
  border-color: color-mix(in oklab, var(--accent) 30%, transparent);
}
.scope-badge--office {
  background: var(--bg-inset);
  color: var(--text-secondary);
  border-color: var(--border-soft);
}
.kanban-card__title-row {
  display: flex; align-items: flex-start; gap: 8px;
  justify-content: space-between;
  margin-bottom: 2px;
}
.drawer__title-row {
  display: flex; align-items: center; gap: 10px;
  flex-wrap: wrap;
}
.kanban-col { background: var(--bg-card); border: 1px solid var(--border-soft); border-radius: var(--r-lg); padding: 14px; display: flex; flex-direction: column; gap: 10px; min-height: 360px; transition: all var(--dur-fast); }
.kanban-col[data-hover] { border-color: color-mix(in oklab, var(--accent) 45%, var(--border-soft)); background: color-mix(in oklab, var(--accent) 4%, var(--bg-card)); }
.kanban-col--backlog { background: color-mix(in oklab, var(--accent) 3%, var(--bg-card)); }
.kanban-col__head { display: flex; align-items: center; gap: 10px; padding: 2px 4px 10px; border-bottom: 1px solid var(--border-soft); }
.kanban-col__title { font-size: 13px; font-weight: 600; color: var(--text-primary); text-transform: uppercase; letter-spacing: 0.06em; }
.kanban-col__count { margin-left: auto; font-family: var(--font-mono); font-size: 12px; color: var(--text-tertiary); background: var(--bg-inset); padding: 2px 8px; border-radius: 999px; min-width: 24px; text-align: center; }
.kanban-col__body { display: flex; flex-direction: column; gap: 8px; min-height: 200px; }
.kanban-col__empty { padding: 24px 8px; text-align: center; font-size: 12.5px; color: var(--text-tertiary); border: 1px dashed var(--border-soft); border-radius: var(--r-md); }
.kanban-col__queue { margin-top: 6px; padding: 10px 12px; font-size: 12px; color: var(--text-tertiary); background: var(--bg-inset); border-radius: var(--r-md); font-family: var(--font-mono); letter-spacing: 0.02em; text-align: center; }

.kanban-card { display: grid; grid-template-columns: 16px 1fr; gap: 10px; align-items: flex-start; background: var(--bg-muted); border: 1px solid var(--border-soft); border-radius: var(--r-md); padding: 12px 14px; cursor: pointer; transition: all var(--dur-fast); user-select: none; }
.kanban-card:hover { border-color: var(--border-medium); box-shadow: var(--sh-xs); background: var(--bg-card); }
.kanban-card[data-dragging] { opacity: 0.4; }
.kanban-card__grip { font-size: 14px; line-height: 1; color: var(--text-tertiary); letter-spacing: -2px; padding-top: 2px; cursor: grab; }
.kanban-card:active .kanban-card__grip { cursor: grabbing; }
.kanban-card__body { min-width: 0; display: flex; flex-direction: column; gap: 4px; }
.kanban-card__title { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.kanban-card__desc { font-size: 12.5px; color: var(--text-secondary); line-height: 1.5; }

.idea-source { display: inline-flex; align-items: center; gap: 8px; margin-top: 8px; padding: 10px 14px; background: var(--bg-inset); border: 1px solid var(--border-soft); border-radius: var(--r-md); color: var(--text-primary); font-size: 13px; text-decoration: none; transition: all var(--dur-fast); }
.idea-source:hover { border-color: var(--accent); color: var(--accent-ink); background: var(--accent-faint); }
.idea-source__url { margin-top: 6px; font-family: var(--font-mono); font-size: 11.5px; color: var(--text-tertiary); word-break: break-all; line-height: 1.5; }
.idea-foot { justify-content: space-between; }
.idea-btn { flex: 1; justify-content: center; }
.idea-btn--dislike:hover { border-color: var(--status-error); color: var(--status-error); }
