/* card styles: clock, weather, news, plan, calendar, notes, status bar + 3 layout grids */

/* ---------------- CLOCK ---------------- */
.clk-hero {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 4px 12px;
}
.clk-big {
  font-size: 54px;
  font-weight: 700;
  letter-spacing: -0.04em;
  color: var(--fg);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum", "zero";
  display: flex;
  align-items: baseline;
}
.clk-h { color: var(--fg); }
.clk-sep { color: var(--accent); animation: blink 1s steps(2) infinite; padding: 0 2px; }
.clk-s { color: var(--fg-mute); font-size: 24px; letter-spacing: -0.02em; padding-left: 6px; }
@keyframes blink { 50% { opacity: 0.35; } }
.clk-day {
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--fg-dim);
  align-self: flex-end;
}
.clk-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--rule);
  border-top: 1px solid var(--rule);
  margin: 0 -10px -12px;
}
.clk-stat {
  background: var(--bg-2);
  padding: 8px 10px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.clk-stat-l { font-size: 9px; letter-spacing: 0.14em; color: var(--fg-mute); }
.clk-stat-v { font-size: 12px; color: var(--fg); font-weight: 600; }
.clk-stat-v.is-open { color: var(--up); }
.clk-mkt { font-size: 11px; font-weight: 600; letter-spacing: 0.03em; line-height: 1.4; color: var(--fg-mute); white-space: nowrap; }
.clk-mkt.is-open { color: var(--up); }

.clk-compact {
  display: flex;
  align-items: baseline;
  font-size: 36px;
  font-weight: 700;
  letter-spacing: -0.03em;
  padding: 4px 0;
  font-variant-numeric: tabular-nums;
}
.clk-compact .clk-s { font-size: 18px; }
.clk-session {
  font-size: 10px;
  letter-spacing: 0.14em;
  color: var(--fg-mute);
}
.clk-session.is-open { color: var(--up); }

/* ---------------- WEATHER ---------------- */
.wx-hero {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 4px 0 10px;
  border-bottom: 1px dashed var(--rule);
  margin-bottom: 8px;
}
.wx-now { display: flex; align-items: center; gap: 10px; }
.wx-icon { color: var(--accent); }
.wx-temp { font-size: 42px; font-weight: 700; letter-spacing: -0.03em; line-height: 1; }
.wx-deg { font-size: 16px; color: var(--fg-mute); font-weight: 400; vertical-align: top; margin-left: 2px; }
.wx-meta { display: flex; flex-direction: column; gap: 2px; }
.wx-cond { font-size: 12px; font-weight: 600; }
.wx-feel { font-size: 10px; color: var(--fg-mute); letter-spacing: 0.06em; }

.wx-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  padding: 6px 0 10px;
  font-size: 10px;
}
.wx-stats > div { display: flex; flex-direction: column; gap: 1px; }
.wx-stats span { color: var(--fg-mute); letter-spacing: 0.12em; }
.wx-stats b { color: var(--fg); font-size: 11px; font-weight: 600; }

.wx-section {
  font-size: 9px;
  letter-spacing: 0.18em;
  color: var(--fg-mute);
  padding: 6px 0 4px;
  border-top: 1px dashed var(--rule);
}

.wx-hourly {
  display: grid;
  grid-template-columns: repeat(10, 1fr);
  gap: 2px;
  padding-bottom: 6px;
}
.wx-h {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 4px 2px;
  font-size: 10px;
}
.wx-h-time { color: var(--fg-mute); font-size: 9px; }
.wx-h-icon { color: var(--accent); }
.wx-h-temp { color: var(--fg); font-weight: 600; font-size: 11px; }
.wx-h-bar { width: 100%; height: 24px; background: var(--rule); position: relative; }
.wx-h-fill { position: absolute; bottom: 0; left: 0; right: 0; background: var(--accent); opacity: 0.5; }

.wx-daily { display: flex; flex-direction: column; gap: 2px; padding-top: 4px; }
.wx-d {
  display: grid;
  grid-template-columns: 32px 18px 40px 1fr;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  padding: 2px 0;
}
.wx-d-day { color: var(--fg); font-weight: 600; }
.wx-d-icon { color: var(--accent); display: flex; align-items: center; }
.wx-d-pop { color: var(--fg-mute); font-size: 10px; }
.wx-d-range { display: grid; grid-template-columns: 24px 1fr 24px; align-items: center; gap: 6px; }
.wx-d-lo { color: var(--fg-mute); text-align: right; }
.wx-d-hi { color: var(--fg); text-align: right; }
.wx-d-bar { position: relative; height: 4px; background: var(--rule); border-radius: 2px; }
.wx-d-fill { position: absolute; top: 0; bottom: 0; background: linear-gradient(90deg, var(--accent-2), var(--accent)); border-radius: 2px; }

/* ---------------- NEWS ---------------- */
.news-filter { display: flex; gap: 4px; flex-wrap: wrap; }
.news-chip {
  background: transparent;
  border: 1px solid var(--rule);
  color: var(--fg-mute);
  font-family: var(--sans);
  font-weight: 700;
  font-size: 9px;
  letter-spacing: 0.06em;
  padding: 2px 7px;
  border-radius: 999px;
  cursor: pointer;
  text-transform: uppercase;
}
.news-chip.is-on { background: var(--accent); color: #fff; border-color: var(--accent); }
.news-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.news-item {
  border-bottom: 1px dashed var(--rule);
}
.news-item:last-child { border-bottom: 0; }
.news-link {
  display: grid;
  grid-template-columns: 42px 64px 80px 1fr;
  gap: 8px;
  padding: 6px 4px;
  font-size: 12px;
  align-items: baseline;
  text-decoration: none;
  color: inherit;
  border-radius: 5px;
  cursor: pointer;
}
.news-link:hover { background: var(--bg-hover); }
.news-link:hover .news-title { color: var(--accent); }
.news-link:focus-visible { outline: 1px solid var(--accent); outline-offset: -1px; }
.news-time { color: var(--fg-mute); font-size: 11px; }
.news-cat {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 2px 7px;
  border: 0;
  border-radius: 4px;
  text-align: center;
  color: var(--tl-ink);
  background: var(--fg-mute);
  text-transform: uppercase;
  align-self: start;
}
.news-cat-makro, .news-cat-ekonomi { background: var(--tl-blue); }
.news-cat-bist, .news-cat-abd { background: var(--tl-sky); }
.news-cat-kripto { background: var(--tl-purple); }
.news-cat-emtia { background: var(--tl-orange); }
.news-cat-enerji { background: var(--tl-red); }
.news-cat-global, .news-cat-asia, .news-cat-politik { background: var(--tl-lime); }
.news-src { color: var(--fg-dim); font-size: 11px; }
.news-title { color: var(--fg); line-height: 1.4; }

/* ---------------- PLAN ---------------- */
.plan-progress {
  display: inline-block;
  width: 80px;
  height: 6px;
  background: var(--rule);
  position: relative;
  margin-right: 4px;
}
.plan-progress-fill {
  position: absolute;
  top: 0; bottom: 0; left: 0;
  background: var(--up);
  transition: width 200ms;
}
.plan-add {
  background: transparent;
  border: 1px solid var(--rule);
  color: var(--accent);
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.14em;
  padding: 2px 6px;
  cursor: pointer;
}
.plan-add:hover { background: var(--bg-hover); border-color: var(--accent); }

.plan-add-form {
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
  margin-bottom: 8px; padding-bottom: 10px; border-bottom: 1px solid var(--rule);
}
.plan-af-time, .plan-af-title, .plan-af-tag, .plan-af-dur input {
  background: var(--bg); color: var(--fg); border: 1px solid var(--rule);
  border-radius: 5px; font-family: var(--mono); font-size: 11px; padding: 5px 7px; outline: none;
}
.plan-af-time { width: 56px; flex: 0 0 56px; }
.plan-af-title { flex: 1 1 120px; min-width: 90px; }
.plan-af-tag { flex: 0 0 auto; font-family: var(--sans); cursor: pointer; text-transform: capitalize; }
.plan-af-dur { display: inline-flex; align-items: center; gap: 3px; }
.plan-af-dur input { width: 52px; }
.plan-af-dur-u { color: var(--fg-mute); font-size: 10px; }
.plan-af-time:focus, .plan-af-title:focus, .plan-af-tag:focus, .plan-af-dur input:focus { border-color: var(--accent); }
.plan-af-btn {
  background: var(--accent); color: #fff; border: 0; border-radius: 5px;
  font-family: var(--sans); font-weight: 700; font-size: 10px; letter-spacing: 0.08em;
  padding: 6px 13px; cursor: pointer;
}
.plan-af-btn:hover { filter: brightness(1.08); }
.plan-tag-btn { border: 0; cursor: pointer; font-family: inherit; }
.plan-tag-btn:hover { filter: brightness(1.12); outline: 1px solid var(--fg-mute); }
.plan-tag-cal { background: var(--accent-2, var(--tl-sky)); color: #fff; }
.plan-row-cal .plan-grip-cal { cursor: default; color: var(--accent-2, var(--fg-mute)); opacity: 0.7; }
.plan-x-ghost { visibility: hidden; }
.plan-empty { color: var(--fg-mute); font-size: 12px; font-style: italic; padding: 14px 4px; }
.plan-time[contenteditable]:focus, .plan-dur[contenteditable]:focus { background: var(--bg-hover); outline: 1px solid var(--accent); border-radius: 3px; }

.plan-list { list-style: none; margin: 0; padding: 0; }
.plan-row {
  display: grid;
  grid-template-columns: 14px 18px 44px 1fr 60px 32px 18px;
  align-items: center;
  gap: 6px;
  padding: 6px 4px;
  border-bottom: 1px dashed var(--rule);
  font-size: 12px;
  cursor: grab;
  transition: background 80ms;
}
.plan-row:hover { background: var(--bg-hover); }
.plan-row.is-dragging { opacity: 0.4; }
.plan-row.is-over { border-top: 2px solid var(--accent); padding-top: 4px; }
.plan-grip { color: var(--fg-mute); cursor: grab; user-select: none; font-size: 14px; }
.plan-check {
  width: 16px; height: 16px;
  border: 1px solid var(--rule-2);
  background: transparent;
  color: var(--up);
  font-size: 11px;
  font-family: var(--mono);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  padding: 0;
}
.plan-check.is-on { background: var(--up-soft); border-color: var(--up); }
.plan-time { color: var(--fg-dim); font-size: 11px; font-variant-numeric: tabular-nums; }
.plan-title { color: var(--fg); outline: none; padding: 1px 2px; min-width: 0; }
.plan-title:focus { background: var(--bg-hover); }
.plan-row.is-done .plan-title { color: var(--fg-mute); text-decoration: line-through; text-decoration-color: var(--fg-mute); }
.plan-tag {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.02em;
  padding: 2px 7px;
  border: 0;
  border-radius: 4px;
  color: var(--tl-ink);
  background: var(--fg-mute);
  text-transform: uppercase;
  text-align: center;
}
.plan-tag-iş { background: var(--tl-sky); }
.plan-tag-derin { background: var(--tl-purple); }
.plan-tag-kişisel { background: var(--tl-pink); }
.plan-tag-finans { background: var(--tl-green); }
.plan-tag-sağlık { background: var(--tl-orange); }
.plan-dur { color: var(--fg-mute); font-size: 11px; text-align: right; }
.plan-x {
  background: transparent;
  border: 0;
  color: var(--fg-mute);
  font-size: 16px;
  cursor: pointer;
  padding: 0;
  width: 18px; height: 18px;
}
.plan-x:hover { color: var(--dn); }
.plan-footer {
  display: flex;
  justify-content: space-between;
  padding-top: 8px;
  margin-top: 4px;
  border-top: 1px solid var(--rule);
  font-size: 11px;
  color: var(--fg-mute);
  letter-spacing: 0.1em;
}
.plan-footer b { color: var(--accent); }

/* ---------------- CALENDAR ---------------- */
.cal-nav { display: flex; gap: 4px; }
.cal-nav button {
  background: transparent;
  border: 1px solid var(--rule);
  color: var(--fg-dim);
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.14em;
  padding: 2px 6px;
  cursor: pointer;
}
.cal-nav button:hover { color: var(--accent); border-color: var(--accent); }

.cal-wrap { display: grid; grid-template-columns: 1.4fr 1fr; gap: 12px; }
.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
}
.cal-h {
  background: var(--bg-3);
  padding: 4px 6px;
  font-size: 9px;
  letter-spacing: 0.12em;
  color: var(--fg-mute);
  text-align: center;
  text-transform: uppercase;
}
.cal-h-w { color: var(--fg-mute); }
.cal-c {
  background: var(--bg-2);
  min-height: 44px;
  padding: 4px 5px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  font-size: 11px;
  position: relative;
}
.cal-c.is-muted { color: var(--fg-mute); background: var(--bg); }
.cal-c.is-wknd .cal-d { color: var(--fg-mute); }
.cal-c.is-today { background: color-mix(in srgb, var(--accent) 14%, transparent); outline: 1px solid var(--accent); outline-offset: -1px; z-index: 1; }
.cal-c.is-today .cal-d { color: var(--accent); font-weight: 700; }
.cal-d { font-variant-numeric: tabular-nums; }
.cal-evs { display: flex; gap: 2px; }
.cal-ev {
  width: 6px; height: 6px;
  display: inline-block;
}
.cal-ev-amber { background: var(--tl-yellow); }
.cal-ev-green { background: var(--tl-green); }
.cal-ev-red   { background: var(--tl-red); }
.cal-ev-blue  { background: var(--tl-blue); }

.cal-up { display: flex; flex-direction: column; gap: 4px; }
.cal-up-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; padding-bottom: 4px; border-bottom: 1px solid var(--rule); }
.cal-up-hd { font-size: 9px; letter-spacing: 0.16em; color: var(--fg-mute); }
.cal-up-clear {
  background: transparent; border: 1px solid var(--rule); color: var(--fg-dim);
  font-family: var(--sans); font-size: 9px; font-weight: 700; letter-spacing: 0.06em;
  border-radius: 4px; padding: 2px 7px; cursor: pointer; white-space: nowrap;
}
.cal-up-clear:hover { border-color: var(--accent); color: var(--accent); }
.cal-up-empty { color: var(--fg-mute); font-size: 11px; padding: 8px 2px; font-style: italic; }
.cal-add-hint { color: var(--fg-mute); font-size: 11px; font-style: italic; }
.cal-day-row { grid-template-columns: 8px 44px 1fr; }
.cal-up-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px; }
.cal-up-row {
  display: grid;
  grid-template-columns: 8px 40px 36px 1fr;
  align-items: center;
  gap: 6px;
  padding: 4px 0;
  border-bottom: 1px dashed var(--rule);
  font-size: 11px;
}
.cal-up-row:last-child { border-bottom: 0; }
.cal-up-dot { width: 6px; height: 6px; }
.cal-up-date { color: var(--fg); font-weight: 600; }
.cal-up-time { color: var(--fg-mute); font-size: 10px; }
.cal-up-title { color: var(--fg-dim); }

/* ---------------- NOTES ---------------- */
.notes-area {
  width: 100%;
  min-height: 180px;
  background: var(--bg);
  color: var(--fg);
  border: 1px solid var(--rule);
  font-family: var(--mono);
  font-size: 12px;
  line-height: 1.55;
  padding: 8px 10px;
  resize: vertical;
  outline: none;
}
.notes-area:focus { border-color: var(--accent); }
.note-btn {
  background: transparent;
  border: 1px solid var(--rule);
  color: var(--fg-mute);
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.12em;
  padding: 2px 6px;
  cursor: pointer;
}
.note-btn:hover { color: var(--dn); border-color: var(--dn); }

/* ---------------- STATUS BAR ---------------- */
.status-bar {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 6px 14px;
  background: var(--bg-2);
  border-top: 1px solid var(--rule);
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--fg-mute);
  text-transform: uppercase;
}
.sb-spacer { flex: 1; }
.sb-item { display: inline-flex; align-items: center; gap: 6px; }
.sb-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--fg-mute); }
.sb-dot.is-live { background: var(--up); animation: pulse 1.6s ease-in-out infinite; }
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(43, 212, 122, 0.4); }
  50% { box-shadow: 0 0 0 6px rgba(43, 212, 122, 0); }
}

/* ---------------- KPIs (command layout) ---------------- */
.kpi {
  background: var(--bg-2);
  border: 1px solid var(--rule);
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
  position: relative;
  overflow: hidden;
}
.kpi::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--rule-2), transparent);
}
.kpi[data-flash="1"] { box-shadow: inset 0 0 0 1px var(--up); }
.kpi[data-flash="-1"] { box-shadow: inset 0 0 0 1px var(--dn); }
.kpi-hd { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
.kpi-sym { color: var(--accent); font-weight: 700; letter-spacing: 0.06em; font-size: 12px; }
.kpi-name { color: var(--fg-mute); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; }
.kpi-px { font-size: 22px; font-weight: 700; letter-spacing: -0.02em; }
.kpi-ft { display: flex; justify-content: space-between; align-items: center; }

/* ============================================================
   LAYOUT A — BENTO
   ============================================================ */
.dash-bento { padding: 0; }
.bento-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--gap);
  padding: var(--gap);
  grid-auto-flow: row dense;
}
.bb { min-width: 0; display: flex; }
.bb > .tbox { width: 100%; }

.b-clock   { grid-column: span 3; }
.b-weather { grid-column: span 4; }
.b-metals  { grid-column: span 5; }
.b-bist    { grid-column: span 5; }
.b-us      { grid-column: span 5; }
.b-fx      { grid-column: span 2; }
.b-crypto  { grid-column: span 4; }
.b-commod  { grid-column: span 4; }
.b-news    { grid-column: span 4; }
.b-plan    { grid-column: span 5; }
.b-cal     { grid-column: span 5; }
.b-notes   { grid-column: span 2; }

/* TOP NAV (PANO / BOT sekmeleri) + BOT SAYFASI */
.topnav { display: inline-flex; gap: 4px; margin-left: 14px; }
.topnav-tab {
  font: inherit; font-size: 11px; font-weight: 600; letter-spacing: 0.06em;
  padding: 5px 12px; border-radius: 7px; border: 1px solid transparent;
  background: transparent; color: var(--fg-mute); cursor: pointer;
}
.topnav-tab:hover { color: var(--fg); background: var(--bg-3); }
.topnav-tab.is-active { color: var(--fg); background: var(--bg-3); border-color: var(--rule); }
.dash-bot { min-height: 100vh; display: flex; flex-direction: column; }
.botpage-wrap { flex: 1; padding: var(--gap); }
.botpage-grid {
  display: grid; grid-template-columns: 1fr 380px; gap: var(--gap);
  align-items: start; max-width: 1400px; margin: 0 auto;
}
.botpage-col { display: flex; flex-direction: column; gap: var(--gap); min-width: 0; }
.botpage-grid .tbox { overflow: visible; } /* "?" balonu kart dışına taşabilsin — kesilmesin */
@media (max-width: 980px) { .botpage-grid { grid-template-columns: 1fr; } }

/* Panel başlığı yanı "?" + hover açıklama balonu */
.help-dot {
  display: inline-flex; align-items: center; justify-content: center;
  width: 15px; height: 15px; margin-left: 7px; border-radius: 50%;
  border: 1px solid var(--rule); color: var(--fg-mute);
  font-size: 10px; font-weight: 700; line-height: 1; cursor: help;
  position: relative; user-select: none; flex: none;
}
.help-dot:hover, .help-dot:focus { color: var(--fg); border-color: var(--fg-mute); outline: none; }
.help-pop {
  display: none; position: absolute; top: calc(100% + 8px); left: 0;
  z-index: 80; width: 260px; max-width: 80vw; padding: 10px 12px;
  background: var(--bg-2); border: 1px solid var(--rule-2); border-radius: 9px;
  color: var(--fg-dim); font-size: 11.5px; font-weight: 400; line-height: 1.5;
  letter-spacing: 0; text-transform: none; white-space: normal; text-align: left;
  box-shadow: 0 12px 34px rgba(0, 0, 0, 0.6);
}
.help-pop::before {
  content: ""; position: absolute; bottom: 100%; left: 12px;
  border: 6px solid transparent; border-bottom-color: var(--rule-2);
}
.help-dot:hover .help-pop, .help-dot:focus .help-pop { display: block; }
/* sağ koldaki paneller — balon sağa hizalansın, kenardan taşmasın */
.botpage-col:last-child .help-pop { left: auto; right: 0; }
.botpage-col:last-child .help-pop::before { left: auto; right: 12px; }

/* Bot sayfası üst bar + "Nasıl Çalışır?" */
.botpage-bar { display: flex; align-items: center; justify-content: space-between; gap: 10px; max-width: 1400px; margin: 0 auto var(--gap); padding: 0 2px; }
.botpage-bar-title { font-size: 12px; font-weight: 700; letter-spacing: 0.08em; color: var(--fg-mute); }
.bothelp-open { font: inherit; font-size: 11px; font-weight: 700; letter-spacing: 0.04em; cursor: pointer; padding: 7px 14px; border-radius: 8px; border: 1px solid var(--rule-2); background: var(--bg-2); color: var(--fg); }
.bothelp-open:hover { background: var(--bg-hover); }

/* Bot kaynak sekmeleri (Polymarket | BTC) */
.botpage-tabs { display: inline-flex; gap: 4px; padding: 3px; border-radius: 10px; background: var(--bg-3, #ffffff08); border: 1px solid var(--rule); }
.botpage-tab { font: inherit; font-size: 11px; font-weight: 700; letter-spacing: 0.06em; cursor: pointer; padding: 6px 14px; border-radius: 7px; border: 0; background: transparent; color: var(--fg-mute); }
.botpage-tab:hover { color: var(--fg); }
.botpage-tab.on { background: var(--bg-2); color: var(--fg); box-shadow: 0 1px 0 rgba(0,0,0,0.15); }

/* Nasıl Çalışır — tam ekran doküman */
.bothelp-overlay { position: fixed; inset: 0; z-index: 200; background: rgba(0,0,0,0.62); display: flex; align-items: flex-start; justify-content: center; padding: 40px 16px; overflow-y: auto; }
.bothelp-doc { width: 100%; max-width: 760px; background: var(--bg-2); border: 1px solid var(--rule-2); border-radius: 14px; box-shadow: 0 24px 70px rgba(0,0,0,0.6); display: flex; flex-direction: column; max-height: calc(100vh - 80px); }
.bothelp-hd { display: flex; align-items: flex-start; justify-content: space-between; padding: 18px 22px; border-bottom: 1px solid var(--rule); }
.bothelp-title { font-size: 16px; font-weight: 800; letter-spacing: 0.02em; color: var(--fg); }
.bothelp-meta { font-size: 11px; color: var(--fg-mute); margin-top: 3px; }
.bothelp-close { font: inherit; font-size: 24px; line-height: 1; cursor: pointer; background: transparent; border: 0; color: var(--fg-mute); padding: 0 4px; }
.bothelp-close:hover { color: var(--fg); }
.bothelp-scroll { overflow-y: auto; padding: 6px 22px 22px; }
.bothelp-sec { padding: 14px 0; border-bottom: 1px dashed var(--rule); }
.bothelp-sec:last-of-type { border-bottom: 0; }
.bothelp-h3 { font-size: 13.5px; font-weight: 700; color: var(--fg); margin: 0 0 7px; display: flex; align-items: center; gap: 8px; }
.bothelp-num { display: inline-flex; align-items: center; justify-content: center; width: 22px; height: 22px; border-radius: 6px; background: var(--bg-3); color: var(--fg-dim); font-size: 12px; flex: none; }
.bothelp-txt { font-size: 12.5px; line-height: 1.6; color: var(--fg-dim); }
.bothelp-txt b { color: var(--fg); }
.bothelp-txt ul { margin: 6px 0; padding-left: 18px; }
.bothelp-txt li { margin: 3px 0; }
.bothelp-ex { margin-top: 8px; padding: 9px 11px; background: var(--bg-3); border-left: 3px solid var(--rule-2); border-radius: 6px; font-size: 12px; }
.bothelp-foot { margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--rule); font-size: 11px; color: var(--fg-mute); font-style: italic; }
@media (max-width: 640px) { .bothelp-overlay { padding: 14px 8px; } .bothelp-doc { max-height: calc(100vh - 28px); } }
.botnews-link:hover, .botnews-x:hover { text-decoration: underline !important; }

/* ============================================================
   LAYOUT B — TERMINAL
   ============================================================ */
.dash-terminal { padding: 0; }
.term-grid {
  display: grid;
  grid-template-columns: 320px 1fr 380px;
  gap: var(--gap);
  padding: var(--gap);
}
.term-col { display: flex; flex-direction: column; gap: var(--gap); min-width: 0; }
.term-bottom {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gap);
  padding: 0 var(--gap) var(--gap);
}

/* ============================================================
   LAYOUT C — COMMAND
   ============================================================ */
.dash-command { padding: 0; }
.cmd-hero {
  display: grid;
  grid-template-columns: 280px 1fr 280px;
  gap: var(--gap);
  padding: var(--gap);
  align-items: stretch;
}
.cmd-kpis {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--gap);
}
.cmd-hero-clock, .cmd-hero-weather { display: flex; }
.cmd-hero-clock > .tbox, .cmd-hero-weather > .tbox { width: 100%; }
.cmd-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr 1fr;
  gap: var(--gap);
  padding: var(--gap);
}
.cmd-col { display: flex; flex-direction: column; gap: var(--gap); min-width: 0; }

/* ============================================================
   SOURCE BADGE
   ============================================================ */
.src-badge {
  font-family: var(--sans);
  font-weight: 800;
  font-size: 8px;
  letter-spacing: 0.08em;
  padding: 2px 6px;
  border-radius: 999px;
  text-transform: uppercase;
  line-height: 1.4;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.src-badge.src-live { background: var(--up-soft); color: var(--up); }
.src-badge.src-live::before { content: ""; width: 5px; height: 5px; border-radius: 50%; background: var(--up); animation: pulse 1.6s ease-in-out infinite; }
.src-badge.src-mock { background: color-mix(in srgb, var(--warn) 18%, transparent); color: var(--warn); }
.src-badge.src-load { background: var(--bg-3); color: var(--fg-mute); }

/* ============================================================
   CALENDAR — clickable days + add form
   ============================================================ */
.cal-c { cursor: pointer; transition: background 80ms; }
.cal-c:hover:not(.is-muted) { background: var(--bg-hover); }
.cal-c.is-sel { outline: 1px dashed var(--accent); outline-offset: -1px; z-index: 2; }
.cal-up-row { position: relative; }
.cal-up-x {
  background: transparent; border: 0; color: var(--fg-mute);
  font-size: 14px; cursor: pointer; padding: 0 2px; line-height: 1;
}
.cal-up-x:hover { color: var(--dn); }
.cal-add { margin-top: 8px; border-top: 1px solid var(--rule); padding-top: 8px; }
.cal-add-hd { font-size: 9px; letter-spacing: 0.12em; color: var(--fg-mute); margin-bottom: 6px; font-weight: 700; }
.cal-add-row { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.cal-add-time { width: 52px; flex: 0 0 52px; }
.cal-add-title { flex: 1 1 90px; min-width: 80px; }
.cal-add-time, .cal-add-title {
  background: var(--bg); color: var(--fg); border: 1px solid var(--rule);
  border-radius: 5px; font-family: var(--mono); font-size: 11px; padding: 4px 7px; outline: none;
}
.cal-add-time:focus, .cal-add-title:focus { border-color: var(--accent); }
.cal-add-colors { display: flex; gap: 3px; }
.cal-add-col { width: 15px; height: 15px; border-radius: 50%; border: 2px solid transparent; cursor: pointer; padding: 0; }
.cal-add-col.is-on { border-color: var(--fg); }
.cal-add-btn {
  background: var(--accent); color: #fff; border: 0; border-radius: 5px;
  font-family: var(--sans); font-weight: 700; font-size: 10px; letter-spacing: 0.08em;
  padding: 5px 12px; cursor: pointer;
}
.cal-add-btn:hover { filter: brightness(1.08); }

/* ============================================================
   SETTINGS — floating launcher + modal
   ============================================================ */
.settings-fab {
  position: fixed; left: 16px; bottom: 16px; z-index: 9000;
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--bg-2, #161719); color: var(--fg, #eceef1);
  border: 1px solid var(--rule, #26282c); border-radius: 999px;
  font-family: var(--sans); font-weight: 700; font-size: 11px; letter-spacing: 0.08em;
  padding: 9px 15px; cursor: pointer;
  box-shadow: 0 4px 16px rgba(0,0,0,0.28);
}
.settings-fab:hover { border-color: var(--accent); }
.settings-fab-gear { font-size: 14px; }
.settings-overlay {
  position: fixed; inset: 0; z-index: 9001;
  background: rgba(9, 16, 28, 0.6); backdrop-filter: blur(3px);
  display: flex; align-items: center; justify-content: center; padding: 24px;
}
.settings-modal {
  width: min(560px, 96vw); max-height: 88vh; overflow: auto;
  background: var(--bg-2); color: var(--fg);
  border: 1px solid var(--rule-2); border-radius: 12px;
  box-shadow: 0 24px 64px rgba(0,0,0,0.4);
  font-family: var(--sans);
}
.settings-hd {
  display: flex; justify-content: space-between; align-items: flex-start; gap: 12px;
  padding: 18px 20px; border-bottom: 1px solid var(--rule);
  position: sticky; top: 0; background: var(--bg-2); z-index: 1;
}
.settings-title { font-weight: 800; font-size: 14px; letter-spacing: 0.06em; color: var(--accent); }
.settings-sub { font-size: 11px; color: var(--fg-mute); margin-top: 3px; }
.settings-close { background: transparent; border: 0; color: var(--fg-mute); font-size: 24px; cursor: pointer; line-height: 1; padding: 0 4px; }
.settings-close:hover { color: var(--fg); }
.settings-body { padding: 16px 20px 20px; }
.settings-section { font-size: 10px; font-weight: 800; letter-spacing: 0.14em; color: var(--fg-mute); margin: 18px 0 8px; text-transform: uppercase; }
.settings-section:first-child { margin-top: 0; }
.sec-note { font-weight: 500; letter-spacing: 0; text-transform: none; color: var(--fg-mute); }
.settings-status { display: flex; flex-direction: column; gap: 2px; }
.ss-row { display: grid; grid-template-columns: 12px 96px 64px 1fr; align-items: center; gap: 8px; padding: 4px 0; font-size: 12px; border-bottom: 1px dashed var(--rule); }
.ss-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--fg-mute); }
.ss-dot.ss-live { background: var(--up); box-shadow: 0 0 6px var(--up); }
.ss-dot.ss-error { background: var(--dn); }
.ss-dot.ss-loading { background: var(--warn); }
.ss-label { font-weight: 600; }
.ss-state { font-size: 9px; font-weight: 800; letter-spacing: 0.06em; padding: 1px 6px; border-radius: 4px; text-align: center; text-transform: uppercase; }
.ss-state-live { background: var(--up-soft); color: var(--up); }
.ss-state-mock, .ss-state-error { background: color-mix(in srgb, var(--warn) 18%, transparent); color: var(--warn); }
.ss-state-loading { background: var(--bg-3); color: var(--fg-mute); }
.ss-state-off { background: var(--bg-3); color: var(--fg-mute); }
.ss-dot.ss-off { background: var(--rule-2); }
.ss-how { color: var(--fg-mute); font-size: 10px; text-align: right; }
.settings-field { display: flex; flex-direction: column; gap: 5px; margin-bottom: 12px; }
.settings-field-row { flex-direction: row; align-items: center; justify-content: space-between; }
.sf-label { font-size: 12px; font-weight: 600; }
.sf-label em { font-style: normal; color: var(--fg-mute); font-weight: 400; }
.sf-input {
  background: var(--bg); color: var(--fg); border: 1px solid var(--rule);
  border-radius: 6px; font-family: var(--mono); font-size: 12px; padding: 8px 10px; outline: none; width: 100%;
}
.sf-input:focus { border-color: var(--accent); }
.sf-help { font-size: 11px; color: var(--accent); text-decoration: none; }
.sf-help:hover { text-decoration: underline; }
.sf-select {
  background: var(--bg); color: var(--fg); border: 1px solid var(--rule);
  border-radius: 6px; font-family: var(--sans); font-size: 12px; padding: 6px 10px; cursor: pointer;
}
.sf-toggle {
  width: 40px; height: 22px; border-radius: 999px; border: 0; background: var(--rule-2);
  position: relative; cursor: pointer; transition: background 140ms; flex: 0 0 40px;
}
.sf-toggle.is-on { background: var(--up); }
.sf-toggle-knob { position: absolute; top: 2px; left: 2px; width: 18px; height: 18px; border-radius: 50%; background: #fff; transition: left 140ms; }
.sf-toggle.is-on .sf-toggle-knob { left: 20px; }
.settings-actions { display: flex; align-items: center; gap: 12px; margin-top: 16px; }
.settings-btn {
  background: var(--bg-3); color: var(--fg); border: 1px solid var(--rule);
  border-radius: 6px; font-family: var(--sans); font-weight: 700; font-size: 12px; padding: 8px 14px; cursor: pointer;
}
.settings-btn-primary { background: var(--accent); color: #fff; border-color: var(--accent); }
.settings-btn-primary:hover { filter: brightness(1.08); }
.settings-last { font-size: 11px; color: var(--fg-mute); }
.settings-foot { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--rule); font-size: 11px; color: var(--fg-dim); line-height: 1.6; }
.settings-foot b { color: var(--fg); }
.settings-foot .ss-state { display: inline-block; }

/* === scrollbar polish === */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--rule-2); border: 2px solid var(--bg); }
::-webkit-scrollbar-thumb:hover { background: var(--fg-mute); }

/* Outlook event colour + chip */
.cal-ev-outlook { background: var(--accent-2); }
.cal-up-tag {
  font-size: 8px; font-weight: 800; letter-spacing: 0.06em; padding: 1px 5px;
  border-radius: 3px; background: color-mix(in srgb, var(--accent-2) 22%, transparent); color: var(--accent-2);
  text-transform: uppercase;
}

/* ============================================================
   RESPONSIVE / MOBILE
   ============================================================ */
@media (max-width: 1280px) {
  .bento-grid { grid-template-columns: repeat(6, 1fr); }
  .b-clock { grid-column: span 2; }
  .b-weather { grid-column: span 4; }
  .b-metals { grid-column: span 6; }
  .b-cal { grid-column: span 6; }
  .b-plan { grid-column: span 4; }
  .b-notes { grid-column: span 2; }
  .b-fx { grid-column: span 2; }
  .b-bist { grid-column: span 3; }
  .b-us { grid-column: span 3; }
  .b-crypto { grid-column: span 3; }
  .b-commod { grid-column: span 3; }
  .b-news { grid-column: span 6; }
  .b-bot { grid-column: span 6; }
}

@media (max-width: 860px) {
  .bento-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; padding: 10px; }
  .bento-grid .bb { grid-column: span 2 !important; }
  .b-clock, .b-fx, .b-notes { grid-column: span 1 !important; }
  .cal-wrap { grid-template-columns: 1fr; }
  .metals-hero { grid-template-columns: 1fr; }
  /* topbar stacks */
  .topbar { grid-template-columns: 1fr auto; gap: 6px 12px; padding: 10px 12px; }
  .topbar-c { grid-column: 1 / -1; order: 3; justify-self: start; }
  .topbar-c .greet { font-size: 13px; }
  .brand-sub { display: none; }
}

@media (max-width: 560px) {
  body { font-size: 12px; }
  .bento-grid { grid-template-columns: 1fr; }
  .bento-grid .bb, .b-clock, .b-fx, .b-notes { grid-column: 1 / -1 !important; }
  .clk-big { font-size: 44px; }
  /* market tables: drop name + sparkline, keep sym/px/chg */
  .mkt-row { grid-template-columns: 58px 1fr auto !important; }
  .crypto-row { grid-template-columns: 58px 1fr auto 24px !important; }
  .crypto-picker { width: 180px; }
  .mkt-c-name, .mkt-c-spk { display: none; }
  .mkt-head .mkt-c-name, .mkt-head .mkt-c-spk { display: none; }
  /* commodities/fx single column */
  .commod-grid { grid-template-columns: 1fr 1fr; }
  .fx-grid { grid-template-columns: 1fr 1fr; }
  /* news wraps to two lines */
  .news-link { grid-template-columns: 42px auto 1fr; row-gap: 2px; }
  .news-src { display: none; }
  .news-title { grid-column: 1 / -1; }
  /* hourly weather scrolls horizontally */
  .wx-hourly { display: flex; overflow-x: auto; gap: 6px; -webkit-overflow-scrolling: touch; }
  .wx-h { min-width: 38px; flex: 0 0 38px; }
  /* plan: hide grip + duration to save width */
  .plan-row { grid-template-columns: 18px 42px 1fr 56px 18px; }
  .plan-grip, .plan-dur { display: none; }
  /* calendar add form wraps */
  .cal-add-row { gap: 5px; }
  .cal-add-title { flex: 1 1 100%; order: 3; }
  /* settings button shrinks to icon */
  .settings-fab-label { display: none; }
  .settings-fab { padding: 11px; left: 12px; bottom: 12px; }
  .topbar-time { font-size: 13px; }
}

/* ============================================================
   AUTH — top-right bar, modals, admin panel, locked cards
   ============================================================ */
.auth-bar { display: inline-flex; align-items: center; gap: 6px; position: relative; }
.auth-btn {
  font-family: var(--sans); font-weight: 700; font-size: 10px; letter-spacing: 0.08em;
  border-radius: 6px; padding: 6px 11px; cursor: pointer; border: 1px solid var(--rule);
  transition: border-color 120ms, background 120ms, color 120ms;
}
.auth-btn-ghost { background: transparent; color: var(--fg-dim); }
.auth-btn-ghost:hover { color: var(--accent); border-color: var(--accent); }
.auth-btn-solid { background: var(--accent); color: #fff; border-color: var(--accent); }
.auth-btn-solid:hover { filter: brightness(1.08); }
.auth-user {
  display: inline-flex; align-items: center; gap: 7px; cursor: pointer;
  background: var(--bg-hover); border: 1px solid var(--rule); border-radius: 999px;
  padding: 4px 10px 4px 4px; color: var(--fg);
}
.auth-user:hover { border-color: var(--accent); }
.auth-avatar {
  width: 24px; height: 24px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center;
  background: var(--accent); color: #fff; font-family: var(--sans); font-weight: 800; font-size: 10px; letter-spacing: 0;
}
.auth-avatar.is-admin { background: var(--accent-2, #b8860b); }
.auth-avatar img { width: 100%; height: 100%; border-radius: 50%; object-fit: cover; }
.auth-user-name { font-family: var(--sans); font-weight: 700; font-size: 11px; max-width: 110px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.auth-caret { font-size: 9px; color: var(--fg-mute); }
.auth-menu {
  position: absolute; top: calc(100% + 8px); right: 0; z-index: 1200; min-width: 200px;
  background: var(--bg); border: 1px solid var(--rule); border-radius: 10px;
  box-shadow: 0 16px 40px rgba(0,0,0,0.4); padding: 6px; text-align: left;
}
.auth-menu-hd { padding: 8px 10px; border-bottom: 1px solid var(--rule); margin-bottom: 4px; }
.auth-menu-name { font-family: var(--sans); font-weight: 700; font-size: 12px; color: var(--fg); }
.auth-menu-mail { font-size: 11px; color: var(--fg-mute); margin-top: 1px; }
.auth-menu-sync { display: flex; align-items: center; gap: 6px; margin-top: 7px; font-family: var(--mono, monospace); font-size: 9.5px; letter-spacing: 0.04em; color: var(--fg-mute); }
.auth-sync-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--fg-mute); flex: none; }
.auth-menu-sync.is-cloud { color: var(--up, #28c76f); }
.auth-menu-sync.is-cloud .auth-sync-dot { background: var(--up, #28c76f); box-shadow: 0 0 6px var(--up, #28c76f); }
.auth-menu-sync.is-local .auth-sync-dot { background: var(--fg-mute); }
.auth-menu-item {
  display: block; width: 100%; text-align: left; background: transparent; border: 0; cursor: pointer;
  padding: 8px 10px; border-radius: 6px; color: var(--fg); font-family: var(--sans); font-size: 12px;
}
.auth-menu-item:hover { background: var(--bg-hover); }
.auth-menu-danger { color: var(--dn); }

.auth-overlay {
  position: fixed; inset: 0; z-index: 1300; background: rgba(0,0,0,0.55);
  display: flex; align-items: flex-start; justify-content: center; padding: 6vh 16px 16px;
  overflow-y: auto; backdrop-filter: blur(2px);
}
.auth-modal {
  width: 100%; max-width: 420px; background: var(--bg); border: 1px solid var(--rule);
  border-radius: 14px; box-shadow: 0 24px 64px rgba(0,0,0,0.5); overflow: hidden;
}
.auth-admin { max-width: 860px; }
.auth-modal:has(.auth-admin) { max-width: 860px; }
.auth-hd { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; padding: 18px 20px 14px; border-bottom: 1px solid var(--rule); }
.auth-title { font-family: var(--sans); font-weight: 800; font-size: 16px; letter-spacing: 0.02em; color: var(--fg); }
.auth-sub { font-size: 12px; color: var(--fg-mute); margin-top: 3px; }
.auth-close { background: transparent; border: 0; color: var(--fg-mute); font-size: 22px; line-height: 1; cursor: pointer; padding: 0 4px; }
.auth-close:hover { color: var(--fg); }
.auth-body { padding: 16px 20px 20px; }
.auth-field { display: block; margin-bottom: 12px; }
.auth-field > span { display: block; font-size: 11px; font-weight: 600; color: var(--fg-dim); margin-bottom: 5px; letter-spacing: 0.02em; }
.auth-field em { color: var(--fg-mute); font-style: normal; font-weight: 400; }
.auth-field input {
  width: 100%; box-sizing: border-box; background: var(--bg-hover); color: var(--fg);
  border: 1px solid var(--rule); border-radius: 8px; padding: 10px 12px; font-family: var(--sans); font-size: 14px; outline: none;
}
.auth-field input:focus { border-color: var(--accent); }
.auth-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.auth-submit {
  width: 100%; background: var(--accent); color: #fff; border: 0; border-radius: 8px;
  font-family: var(--sans); font-weight: 700; font-size: 13px; letter-spacing: 0.06em;
  padding: 12px; cursor: pointer; margin-top: 4px;
}
.auth-submit:hover { filter: brightness(1.08); }
.auth-submit:disabled { opacity: 0.6; cursor: default; }
.auth-err { background: color-mix(in srgb, var(--dn) 14%, transparent); color: var(--dn); border: 1px solid color-mix(in srgb, var(--dn) 35%, transparent); border-radius: 7px; padding: 8px 10px; font-size: 12px; margin-bottom: 10px; }
.auth-links { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 8px; margin-top: 12px; }
.auth-link { background: transparent; border: 0; color: var(--accent); cursor: pointer; font-family: var(--sans); font-size: 12px; padding: 2px; }
.auth-link:hover { text-decoration: underline; }
.auth-divider { display: flex; align-items: center; gap: 10px; margin: 14px 0; color: var(--fg-mute); font-size: 11px; }
.auth-divider::before, .auth-divider::after { content: ""; flex: 1; height: 1px; background: var(--rule); }
.auth-google-wrap { display: flex; flex-direction: column; align-items: center; gap: 6px; min-height: 44px; }
.auth-google-host { display: flex; justify-content: center; width: 100%; color-scheme: light; }
.auth-google-loading { font-family: var(--sans); font-size: 11px; color: var(--fg-mute); }
.auth-google-off {
  display: flex; flex-direction: column; gap: 4px; text-align: center;
  border: 1px dashed var(--rule); border-radius: 8px; padding: 12px;
  font-family: var(--sans); font-size: 12px; color: var(--fg-dim); line-height: 1.5;
}
.auth-google-off span { font-size: 10.5px; color: var(--fg-mute); }
.auth-google-off code { font-family: var(--mono, monospace); font-size: 10px; color: var(--accent); }
.auth-google-g { font-family: var(--sans); font-weight: 800; color: #4285f4; font-size: 15px; }
.auth-temp { text-align: center; padding: 6px 0; }
.auth-temp-hd { font-size: 11px; color: var(--fg-mute); letter-spacing: 0.08em; }
.auth-temp-code { font-family: var(--mono); font-weight: 700; font-size: 26px; letter-spacing: 0.12em; color: var(--accent); margin: 8px 0; }
.auth-temp-note { font-size: 12px; color: var(--fg-dim); line-height: 1.5; margin-bottom: 14px; }

/* admin panel */
.adm-note { font-size: 12px; color: var(--fg-mute); margin-bottom: 12px; line-height: 1.5; }
.adm-table { display: flex; flex-direction: column; border: 1px solid var(--rule); border-radius: 10px; overflow: hidden; }
.adm-row { display: grid; grid-template-columns: 1.4fr 1.6fr 1.2fr 0.8fr 0.7fr 1.4fr; gap: 10px; align-items: center; padding: 10px 12px; border-bottom: 1px solid var(--rule); font-size: 12px; }
.adm-row:last-child { border-bottom: 0; }
.adm-head { background: var(--bg-hover); font-size: 9px; letter-spacing: 0.1em; color: var(--fg-mute); font-weight: 700; }
.adm-row.is-passive { opacity: 0.55; }
.adm-name { font-weight: 700; color: var(--fg); }
.adm-google { font-style: normal; color: #4285f4; font-weight: 800; margin-left: 4px; }
.adm-mail { color: var(--fg-dim); font-family: var(--mono); font-size: 11px; overflow: hidden; text-overflow: ellipsis; }
.adm-note-cell { color: var(--fg-mute); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.adm-date { color: var(--fg-mute); font-family: var(--mono); font-size: 11px; }
.adm-status { font-weight: 700; font-size: 10px; letter-spacing: 0.06em; }
.adm-status.is-on { color: var(--up); }
.adm-status.is-off { color: var(--dn); }
.adm-actions { display: flex; gap: 6px; justify-content: flex-end; }
.adm-act { background: var(--bg-hover); border: 1px solid var(--rule); border-radius: 6px; padding: 5px 9px; cursor: pointer; font-family: var(--sans); font-size: 10px; font-weight: 600; color: var(--fg-dim); }
.adm-act:hover { border-color: var(--accent); color: var(--fg); }
.adm-act-danger:hover { border-color: var(--dn); color: var(--dn); }
.adm-empty { padding: 20px; text-align: center; color: var(--fg-mute); font-size: 12px; }

/* locked private cards */
.locked-card { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; padding: 28px 16px; text-align: center; min-height: 120px; }
.locked-icon { font-size: 26px; opacity: 0.7; }
.locked-text { color: var(--fg-mute); font-size: 12px; max-width: 240px; line-height: 1.5; }
.locked-btn { margin-top: 4px; background: var(--accent); color: #fff; border: 0; border-radius: 7px; padding: 8px 18px; font-family: var(--sans); font-weight: 700; font-size: 12px; cursor: pointer; }
.locked-btn:hover { filter: brightness(1.08); }
.locked-link { background: transparent; border: 0; color: var(--accent); cursor: pointer; font-family: var(--sans); font-size: 11px; }
.locked-link:hover { text-decoration: underline; }

@media (max-width: 720px) {
  .auth-user-name { display: none; }
  .adm-row { grid-template-columns: 1fr 1fr; gap: 6px; }
  .adm-head, .adm-date, .adm-note-cell { display: none; }
  .adm-actions { grid-column: 1 / -1; justify-content: flex-start; }
}
