/* SUPERAI-GTD — Dashboard custom surfaces.
   Faithful port of superai-gtd-dashboard-mockup.html, prefixed `.sg-*`
   (same pattern as RKSAM's `.rx-*` RaioX surfaces). MudBlazor is used only for
   the shell (theme, dialog, snackbar) — never for these surfaces. */

:root {
  --sg-bg-app: #F0F3F7;
  --sg-bg-primary: #FFFFFF;
  --sg-bg-elevated: #FFFFFF;
  --sg-text: #1C2733;
  --sg-text-soft: #5A6B7B;
  --sg-text-faint: #8A9AAA;
  --sg-line: #E3E9EF;
  --sg-accent: #2E75B6;
  --sg-accent-soft: #E6F1FB;
  --sg-accent-ink: #1B4F72;

  --sg-q1: #C0392B; --sg-q1-bg: #FDEDEC; --sg-q1-bd: #F5B7B1;
  --sg-q2: #27AE60; --sg-q2-bg: #EAFAF1; --sg-q2-bd: #ABEBC6;
  --sg-q3: #F39C12; --sg-q3-bg: #FEF9E7; --sg-q3-bd: #F9E79F;
  --sg-q4: #95A5A6; --sg-q4-bg: #F4F6F6; --sg-q4-bd: #D5DBDB;

  --sg-inflight: #7D3CB5; --sg-inflight-bg: #F3EBFB;

  --sg-radius: 12px; --sg-radius-sm: 8px;
  --sg-sidebar-w: 220px;
  --sg-shadow: 0 1px 2px rgba(16,32,48,.06), 0 4px 16px rgba(16,32,48,.05);
  --sg-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, system-ui, sans-serif;
}

.sg-root, .sg-root * { box-sizing: border-box; }
.sg-root { font-family: var(--sg-font); background: var(--sg-bg-app); color: var(--sg-text); font-size: 14px; -webkit-font-smoothing: antialiased; }
.sg-root button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
.sg-ic { width: 18px; height: 18px; stroke: currentColor; stroke-width: 2; fill: none; stroke-linecap: round; stroke-linejoin: round; flex: none; }
.sg-ic-sm { width: 14px; height: 14px; }

.sg-app { display: flex; min-height: 100vh; }

/* ---------- Sidebar ---------- */
.sg-sidebar { width: var(--sg-sidebar-w); background: var(--sg-bg-primary); border-right: 1px solid var(--sg-line);
  display: flex; flex-direction: column; padding: 16px 12px; gap: 4px; position: sticky; top: 0; height: 100vh; }
.sg-brand { display: flex; align-items: center; gap: 10px; padding: 6px 8px 14px; }
.sg-brand .sg-logo { width: 30px; height: 30px; border-radius: 9px; background: linear-gradient(135deg, var(--sg-accent), #1B4F72);
  display: grid; place-items: center; color: #fff; font-weight: 700; font-size: 13px; letter-spacing: .5px; }
.sg-brand .sg-name { font-weight: 700; font-size: 14px; letter-spacing: .2px; }
.sg-brand .sg-name small { display: block; font-weight: 500; font-size: 10px; color: var(--sg-text-faint); letter-spacing: .4px; }

.sg-userhead { display: flex; align-items: center; gap: 10px; padding: 8px; border-radius: var(--sg-radius-sm); background: var(--sg-bg-app); margin-bottom: 8px; }
.sg-avatar { width: 32px; height: 32px; border-radius: 50%; background: #CBD6E2; color: #1B4F72; font-weight: 700; display: grid; place-items: center; font-size: 13px; flex: none; }
.sg-userhead .sg-meta { line-height: 1.2; overflow: hidden; }
.sg-userhead .sg-meta b { font-size: 13px; display: block; white-space: nowrap; text-overflow: ellipsis; overflow: hidden; }
.sg-userhead .sg-status { font-size: 11px; color: #27AE60; display: flex; align-items: center; gap: 4px; }
.sg-dot { width: 7px; height: 7px; border-radius: 50%; background: #27AE60; flex: none; }

.sg-navlabel { font-size: 10px; letter-spacing: .8px; text-transform: uppercase; color: var(--sg-text-faint); padding: 10px 10px 4px; font-weight: 600; }
.sg-nav { display: flex; align-items: center; gap: 10px; padding: 9px 10px; border-radius: var(--sg-radius-sm); color: var(--sg-text-soft); font-weight: 500; font-size: 13.5px; width: 100%; text-align: left; text-decoration: none; }
.sg-nav:hover { background: var(--sg-bg-app); color: var(--sg-text); }
.sg-nav.sg-active { background: var(--sg-accent-soft); color: var(--sg-accent-ink); font-weight: 600; }
.sg-nav .sg-badge { margin-left: auto; background: #E3E9EF; color: var(--sg-text-soft); font-size: 11px; font-weight: 600; padding: 1px 7px; border-radius: 20px; }
.sg-nav.sg-active .sg-badge { background: #fff; color: var(--sg-accent-ink); }
.sg-sidebar .sg-spacer { flex: 1; }

/* ---------- Main ---------- */
.sg-main { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.sg-topbar { padding: 18px 24px 0; display: flex; flex-direction: column; gap: 14px; }
.sg-crumb { display: flex; align-items: center; gap: 8px; color: var(--sg-text-faint); font-size: 12px; }
.sg-crumb b { color: var(--sg-text); }
.sg-titlerow { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.sg-titlerow h1 { font-size: 20px; font-weight: 700; letter-spacing: -.2px; }
.sg-search { margin-left: auto; display: flex; align-items: center; gap: 8px; background: var(--sg-bg-primary); border: 1px solid var(--sg-line); border-radius: 20px; padding: 7px 12px; color: var(--sg-text-faint); min-width: 200px; }
.sg-search input { border: none; outline: none; background: none; font-size: 13px; color: var(--sg-text); width: 100%; }

.sg-filterbar { display: flex; gap: 8px; flex-wrap: wrap; }
.sg-pill { padding: 6px 12px; border-radius: 20px; border: 1px solid var(--sg-line); background: var(--sg-bg-primary); font-size: 12.5px; font-weight: 500; color: var(--sg-text-soft); display: flex; align-items: center; gap: 6px; white-space: nowrap; }
.sg-pill:hover { border-color: #C7D2DD; }
.sg-pill.sg-on { background: var(--sg-accent-ink); border-color: var(--sg-accent-ink); color: #fff; }
.sg-pill .sg-swatch { width: 9px; height: 9px; border-radius: 3px; flex: none; }

/* ---------- Stats / WIP ---------- */
.sg-stats { margin: 0 24px; display: flex; gap: 10px; flex-wrap: wrap; align-items: stretch; }
.sg-stat { background: var(--sg-bg-primary); border: 1px solid var(--sg-line); border-radius: var(--sg-radius); padding: 10px 14px; display: flex; flex-direction: column; gap: 2px; min-width: 96px; }
.sg-stat .sg-k { font-size: 11px; color: var(--sg-text-faint); font-weight: 600; letter-spacing: .2px; display: flex; align-items: center; gap: 5px; }
.sg-stat .sg-v { font-size: 20px; font-weight: 700; line-height: 1; }
.sg-stat .sg-v small { font-size: 12px; color: var(--sg-text-faint); font-weight: 600; }
.sg-stat.sg-danger .sg-v { color: var(--sg-q1); }
.sg-qchips { display: flex; gap: 6px; margin-top: 3px; }
.sg-qchip { font-size: 11px; font-weight: 700; color: #fff; border-radius: 6px; padding: 2px 7px; }

/* WIP — highlight surface */
.sg-wip { background: linear-gradient(180deg, #fff, #FBF7FF); border: 1px solid #E7D7F5; border-radius: var(--sg-radius); padding: 10px 14px; display: flex; flex-direction: column; gap: 6px; min-width: 230px; flex: 1; }
.sg-wip .sg-top { display: flex; align-items: center; gap: 8px; }
.sg-wip .sg-top b { font-size: 12.5px; color: var(--sg-inflight); letter-spacing: .2px; display: flex; align-items: center; gap: 6px; }
.sg-wip .sg-count { margin-left: auto; font-size: 13px; font-weight: 700; color: var(--sg-inflight); }
.sg-wip .sg-count small { color: var(--sg-text-faint); font-weight: 600; }
.sg-wipmeter { display: flex; gap: 5px; }
.sg-wipseg { flex: 1; height: 7px; border-radius: 4px; background: #EADCF7; }
.sg-wipseg.sg-full { background: var(--sg-inflight); }
.sg-wip .sg-hint { font-size: 11px; color: var(--sg-text-soft); }
.sg-wip.sg-maxed { border-color: #E0B7B0; background: linear-gradient(180deg, #fff, #FDF1EF); }
.sg-wip.sg-maxed .sg-top b, .sg-wip.sg-maxed .sg-count { color: var(--sg-q1); }
.sg-wip.sg-maxed .sg-wipseg.sg-full { background: var(--sg-q1); }

/* ---------- Matrix ---------- */
.sg-matrix { margin: 16px 24px 100px; display: grid; grid-template-columns: 1fr 1fr; gap: 12px; flex: 1; align-content: start; }
.sg-matrix.sg-zoomed { display: flex; flex-direction: column; }
.sg-quad { background: var(--sg-bg-primary); border: 1px solid var(--sg-line); border-top: 3px solid var(--sg-qc, var(--sg-accent)); border-radius: var(--sg-radius); display: flex; flex-direction: column; min-height: 230px; box-shadow: var(--sg-shadow); }
.sg-quad[data-q="1"] { --sg-qc: var(--sg-q1); --sg-qbg: var(--sg-q1-bg); --sg-qbd: var(--sg-q1-bd); }
.sg-quad[data-q="2"] { --sg-qc: var(--sg-q2); --sg-qbg: var(--sg-q2-bg); --sg-qbd: var(--sg-q2-bd); }
.sg-quad[data-q="3"] { --sg-qc: var(--sg-q3); --sg-qbg: var(--sg-q3-bg); --sg-qbd: var(--sg-q3-bd); }
.sg-quad[data-q="4"] { --sg-qc: var(--sg-q4); --sg-qbg: var(--sg-q4-bg); --sg-qbd: var(--sg-q4-bd); }
.sg-qhead { display: flex; align-items: center; gap: 10px; padding: 12px 14px; border-bottom: 1px solid var(--sg-line); }
.sg-qbadge { width: 30px; height: 30px; border-radius: 8px; background: var(--sg-qbg); color: var(--sg-qc); display: grid; place-items: center; flex: none; }
.sg-qhead .sg-lbl { line-height: 1.25; }
.sg-qhead .sg-lbl b { font-size: 14px; display: block; }
.sg-qhead .sg-lbl span { font-size: 10px; letter-spacing: .6px; color: var(--sg-text-faint); font-weight: 700; text-transform: uppercase; }
.sg-qhead .sg-cnt { margin-left: auto; font-size: 12px; font-weight: 700; color: var(--sg-qc); background: var(--sg-qbg); border-radius: 20px; padding: 2px 9px; }
.sg-qexpand { color: var(--sg-text-faint); padding: 4px; border-radius: 6px; }
.sg-qexpand:hover { background: var(--sg-bg-app); color: var(--sg-text); }
.sg-qbody { padding: 10px; display: flex; flex-direction: column; gap: 8px; overflow-y: auto; }

.sg-matrix.sg-zoomed .sg-quad { display: none; }
.sg-matrix.sg-zoomed .sg-quad.sg-show { display: flex; }
.sg-matrix.sg-zoomed .sg-quad.sg-show .sg-qbody { flex-direction: row; flex-wrap: nowrap; overflow-x: auto; gap: 10px; }
.sg-matrix.sg-zoomed .sg-quad.sg-show .sg-card { min-width: 240px; }
.sg-matrix.sg-zoomed .sg-minirow { display: flex; gap: 12px; }
.sg-matrix.sg-zoomed .sg-minirow .sg-quad { display: flex; flex: 1; min-height: auto; }
.sg-matrix.sg-zoomed .sg-minirow .sg-quad .sg-qbody { max-height: 84px; flex-direction: row; overflow-x: auto; }

/* ---------- Task card ---------- */
.sg-card { border: 1px solid var(--sg-line); border-radius: var(--sg-radius-sm); padding: 10px; display: flex; gap: 9px; align-items: flex-start; background: #fff; transition: border-color .12s, box-shadow .12s; }
.sg-card:hover { border-color: #C7D2DD; box-shadow: 0 2px 8px rgba(16,32,48,.06); }
.sg-card.sg-inflight { border-left: 3px solid var(--sg-inflight); background: var(--sg-inflight-bg); }
.sg-check { width: 18px; height: 18px; border-radius: 6px; border: 2px solid #C7D2DD; flex: none; margin-top: 1px; display: grid; place-items: center; color: #fff; transition: .12s; }
.sg-check:hover { border-color: var(--sg-accent); }
.sg-card.sg-done .sg-check { background: var(--sg-q2); border-color: var(--sg-q2); }
.sg-card.sg-done .sg-ctitle { text-decoration: line-through; color: var(--sg-text-faint); }
.sg-cmain { min-width: 0; flex: 1; }
.sg-ctitle { font-size: 13.5px; font-weight: 600; line-height: 1.3; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sg-cmeta { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-top: 7px; }
.sg-tag { font-size: 11px; font-weight: 600; padding: 2px 8px; border-radius: 20px; display: inline-flex; align-items: center; gap: 5px; }
.sg-tag .sg-swatch { width: 8px; height: 8px; border-radius: 3px; }
.sg-meta-b { font-size: 11px; color: var(--sg-text-soft); display: inline-flex; align-items: center; gap: 4px; font-weight: 500; }
.sg-meta-b.sg-due-over { color: var(--sg-q1); font-weight: 700; }
.sg-meta-b.sg-due-soon { color: #B9770E; font-weight: 700; }
.sg-inflight-tag { font-size: 10px; font-weight: 700; color: var(--sg-inflight); background: #fff; border: 1px solid #E0CBF2; padding: 1px 7px; border-radius: 20px; letter-spacing: .3px; }

/* ---------- FABs ---------- */
.sg-fabs { position: fixed; right: 26px; bottom: 26px; display: flex; flex-direction: column; gap: 12px; z-index: 30; }
.sg-fab { width: 52px; height: 52px; border-radius: 50%; display: grid; place-items: center; color: #fff; box-shadow: 0 6px 18px rgba(16,32,48,.22); }
.sg-fab.sg-add { background: var(--sg-accent); }
.sg-fab.sg-add:hover { background: #266299; }
.sg-fab.sg-suggest { background: linear-gradient(135deg, #F39C12, #E67E22); }
.sg-fab.sg-suggest:hover { filter: brightness(1.05); }
.sg-fab .sg-ic { width: 24px; height: 24px; }

/* ---------- Suggest sheet ---------- */
.sg-scrim { position: fixed; inset: 0; background: rgba(16,32,48,.28); opacity: 0; pointer-events: none; transition: .18s; z-index: 40; }
.sg-scrim.sg-open { opacity: 1; pointer-events: auto; }
.sg-sheet { position: fixed; right: 26px; bottom: 26px; width: 380px; max-width: calc(100vw - 32px); background: #fff; border-radius: 16px; box-shadow: 0 20px 60px rgba(16,32,48,.3); z-index: 50; transform: translateY(20px) scale(.98); opacity: 0; pointer-events: none; transition: .18s; overflow: hidden; }
.sg-sheet.sg-open { transform: none; opacity: 1; pointer-events: auto; }
.sg-shead { padding: 16px 18px; background: linear-gradient(135deg, #FEF9E7, #FFF); border-bottom: 1px solid var(--sg-line); }
.sg-shead b { font-size: 15px; display: flex; align-items: center; gap: 8px; }
.sg-shead p { font-size: 12px; color: var(--sg-text-soft); margin-top: 3px; }
.sg-sctrl { padding: 14px 18px; display: flex; flex-direction: column; gap: 12px; border-bottom: 1px solid var(--sg-line); }
.sg-slabel { font-size: 12px; font-weight: 600; color: var(--sg-text-soft); display: flex; justify-content: space-between; }
.sg-slabel b { color: var(--sg-accent-ink); }
.sg-sctrl input[type=range] { width: 100%; accent-color: var(--sg-accent); }
.sg-toggle { display: flex; align-items: center; gap: 9px; font-size: 12.5px; color: var(--sg-text-soft); font-weight: 500; cursor: pointer; }
.sg-switch { width: 38px; height: 22px; border-radius: 20px; background: #CBD6E2; position: relative; transition: .15s; flex: none; }
.sg-switch.sg-on { background: var(--sg-q2); }
.sg-switch::after { content: ""; position: absolute; width: 18px; height: 18px; border-radius: 50%; background: #fff; top: 2px; left: 2px; transition: .15s; }
.sg-switch.sg-on::after { left: 18px; }
.sg-slist { padding: 12px 14px; display: flex; flex-direction: column; gap: 9px; max-height: 280px; overflow-y: auto; }
.sg-suggestion { border: 1px solid var(--sg-line); border-radius: 10px; padding: 11px 12px; }
.sg-suggestion .sg-row1 { display: flex; align-items: center; gap: 8px; }
.sg-suggestion .sg-row1 b { font-size: 13px; flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sg-score { font-size: 11px; font-weight: 800; color: #fff; background: var(--sg-accent); border-radius: 7px; padding: 2px 7px; flex: none; }
.sg-reasons { display: flex; gap: 5px; flex-wrap: wrap; margin: 8px 0; }
.sg-reason { font-size: 10.5px; font-weight: 600; color: var(--sg-accent-ink); background: var(--sg-accent-soft); padding: 2px 7px; border-radius: 20px; }
.sg-start { margin-top: 2px; width: 100%; background: var(--sg-q2); color: #fff; font-weight: 700; font-size: 12.5px; border-radius: 8px; padding: 8px; display: flex; align-items: center; justify-content: center; gap: 6px; }
.sg-start:hover { background: #1F8B4C; }
.sg-start:disabled { background: #D5DBDB; color: #fff; cursor: not-allowed; }

.sg-empty { padding: 24px; text-align: center; color: var(--sg-text-faint); font-size: 13px; }

/* ---------- Responsive ---------- */
@media (max-width: 1100px) {
  .sg-sidebar .sg-navtext, .sg-sidebar .sg-navlabel, .sg-brand .sg-name, .sg-userhead .sg-meta { display: none; }
  .sg-sidebar { width: 64px; align-items: center; }
  .sg-userhead { justify-content: center; }
  .sg-brand { justify-content: center; padding: 6px 0 14px; }
  .sg-nav { justify-content: center; }
  .sg-nav .sg-badge { display: none; }
}
@media (max-width: 760px) {
  .sg-sidebar { position: fixed; left: -100%; z-index: 60; width: 200px; align-items: stretch; transition: .2s; }
  .sg-sidebar.sg-open { left: 0; box-shadow: 0 0 0 100vw rgba(0,0,0,.3); }
  .sg-sidebar .sg-navtext, .sg-sidebar .sg-navlabel, .sg-brand .sg-name, .sg-userhead .sg-meta { display: flex; }
  .sg-sidebar .sg-navtext { display: inline; }
  .sg-matrix { grid-template-columns: 1fr; margin: 14px 14px 100px; }
  .sg-search { display: none; }
  .sg-stats { margin: 0 14px; }
  .sg-topbar { padding: 14px 14px 0; }
  .sg-hamb { display: grid !important; }
}
.sg-hamb { display: none; width: 38px; height: 38px; border-radius: 9px; background: #fff; border: 1px solid var(--sg-line); place-items: center; color: var(--sg-text); }

/* ================= GTD screens (v2) ================= */
.sg-cclick { cursor: pointer; }
.sg-input { border: 1px solid var(--sg-line); border-radius: var(--sg-radius-sm); padding: 8px 10px; font: inherit; font-size: 13px; color: var(--sg-text); outline: none; background: #fff; }
.sg-input:focus { border-color: var(--sg-accent); }
.sg-note { margin: 14px 24px 0; padding: 10px 14px; background: var(--sg-accent-soft); color: var(--sg-accent-ink); border-radius: var(--sg-radius-sm); font-size: 12.5px; }

/* Capture bar (Entrada) */
.sg-capture { margin: 16px 24px 0; display: flex; align-items: center; gap: 10px; background: #fff; border: 1px solid var(--sg-line); border-radius: var(--sg-radius); padding: 10px 14px; box-shadow: var(--sg-shadow); color: var(--sg-text-faint); }
.sg-capture input { flex: 1; border: none; outline: none; font: inherit; font-size: 14px; color: var(--sg-text); background: none; }

/* Generic list / rows (Entrada, Algum dia, Aguardando, Foco picker) */
.sg-list { margin: 16px 24px 100px; display: flex; flex-direction: column; gap: 8px; }
.sg-row { display: flex; align-items: center; gap: 12px; background: #fff; border: 1px solid var(--sg-line); border-radius: var(--sg-radius); padding: 12px 14px; box-shadow: var(--sg-shadow); }
.sg-row-main { flex: 1; min-width: 0; cursor: pointer; }
.sg-row-title { font-size: 14px; font-weight: 600; line-height: 1.3; }
.sg-row-sub { font-size: 11.5px; color: var(--sg-text-soft); margin-top: 4px; display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.sg-row-actions { display: flex; gap: 6px; flex-wrap: wrap; justify-content: flex-end; }
.sg-row.sg-row-stale { border-color: #E0B7B0; background: linear-gradient(180deg, #fff, #FDF1EF); }
.sg-stale-tag { color: var(--sg-q1); font-weight: 700; }

/* Task detail dialog */
.sg-detail { display: flex; flex-direction: column; gap: 12px; }
.sg-detail-title { font-size: 17px; font-weight: 700; }
.sg-detail-meta { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.sg-detail-desc { font-size: 13px; color: var(--sg-text-soft); white-space: pre-wrap; }
.sg-detail-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.sg-detail-sec { border-top: 1px solid var(--sg-line); padding-top: 12px; }
.sg-detail-seclbl { font-size: 11px; font-weight: 700; letter-spacing: .4px; text-transform: uppercase; color: var(--sg-text-faint); margin-bottom: 8px; }
.sg-detail-tri { display: flex; gap: 6px; flex-wrap: wrap; }
.sg-detail-wait { display: flex; gap: 8px; margin-top: 10px; }
.sg-detail-wait .sg-input { flex: 1; }

/* Attachments */
.sg-attach { border-top: 1px solid var(--sg-line); padding-top: 12px; }
.sg-attach-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.sg-attach-head b { display: flex; align-items: center; gap: 6px; font-size: 13px; }
.sg-attach-add { position: relative; overflow: hidden; cursor: pointer; }
.sg-attach-input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
.sg-attach-busy { font-size: 12px; color: var(--sg-text-soft); margin-bottom: 8px; }
.sg-attach-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 10px; }
.sg-attach-item { position: relative; border: 1px solid var(--sg-line); border-radius: var(--sg-radius-sm); padding: 8px; background: #fff; }
.sg-attach-del { position: absolute; top: 4px; right: 4px; width: 22px; height: 22px; border-radius: 50%; background: rgba(28,39,51,.6); color: #fff; display: grid; place-items: center; z-index: 2; }
.sg-attach-del:hover { background: var(--sg-q1); }
.sg-attach-thumb { width: 100%; height: 90px; border-radius: 6px; background-size: cover; background-position: center; background-color: var(--sg-bg-app); cursor: zoom-in; }
.sg-attach-audio { display: flex; flex-direction: column; gap: 6px; }
.sg-attach-audio audio { width: 100%; height: 32px; }
.sg-attach-file { display: flex; flex-direction: column; align-items: center; gap: 4px; text-decoration: none; color: var(--sg-text); padding: 10px 4px; }
.sg-attach-file:hover { color: var(--sg-accent); }
.sg-attach-fname { font-size: 11.5px; font-weight: 600; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sg-attach-size { font-size: 10.5px; color: var(--sg-text-faint); }

/* Lightbox */
.sg-lightbox { position: fixed; inset: 0; background: rgba(16,32,48,.82); display: grid; place-items: center; z-index: 80; padding: 24px; }
.sg-lightbox img { max-width: 92vw; max-height: 88vh; border-radius: var(--sg-radius); box-shadow: 0 20px 60px rgba(0,0,0,.4); }
.sg-lightbox-close { position: fixed; top: 18px; right: 18px; width: 40px; height: 40px; border-radius: 50%; background: rgba(255,255,255,.15); color: #fff; display: grid; place-items: center; }

/* Review */
.sg-review { margin: 16px 24px 100px; display: flex; flex-direction: column; gap: 12px; max-width: 720px; }
.sg-review-step { background: #fff; border: 1px solid var(--sg-line); border-radius: var(--sg-radius); padding: 14px 16px; box-shadow: var(--sg-shadow); }
.sg-review-h { font-size: 13px; font-weight: 700; display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.sg-review-item { font-size: 13px; color: var(--sg-text-soft); padding: 3px 0; }
.sg-review-num { font-size: 22px; font-weight: 800; color: var(--sg-accent-ink); }
.sg-review-num small { font-size: 12px; font-weight: 600; color: var(--sg-text-faint); margin-left: 6px; }
.sg-check-row { display: flex; align-items: center; gap: 8px; font-size: 13px; padding: 6px 0; color: var(--sg-text); }
.sg-check-row a { color: var(--sg-accent); }
.sg-review-done { align-self: flex-start; }

/* Foco */
.sg-focus { margin: 24px; display: flex; flex-direction: column; align-items: center; gap: 18px; text-align: center; }
.sg-focus-task { font-size: 20px; font-weight: 700; max-width: 640px; }
.sg-timer { font-size: 72px; font-weight: 800; letter-spacing: 2px; font-variant-numeric: tabular-nums; color: var(--sg-inflight); }
.sg-timer-done { color: var(--sg-q2); }
.sg-focus-ctrl, .sg-focus-min { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; }
.sg-noise { background: #fff; border: 1px solid var(--sg-line); border-radius: var(--sg-radius); padding: 14px 18px; box-shadow: var(--sg-shadow); display: flex; flex-direction: column; gap: 10px; min-width: 300px; }
.sg-noise-label { font-size: 12px; font-weight: 700; color: var(--sg-text-soft); display: flex; align-items: center; gap: 6px; justify-content: center; }
.sg-noise-types { display: flex; gap: 8px; justify-content: center; }
.sg-noise-vol { width: 100%; accent-color: var(--sg-inflight); }

@media (max-width: 760px) {
  .sg-capture, .sg-note { margin-left: 14px; margin-right: 14px; }
  .sg-list, .sg-review { margin-left: 14px; margin-right: 14px; }
  .sg-row { flex-direction: column; align-items: stretch; }
  .sg-row-actions { justify-content: flex-start; }
  .sg-timer { font-size: 56px; }
}
