/* 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: 100dvh; overflow-y: auto; -webkit-overflow-scrolling: touch; }
.sg-brand { display: flex; align-items: center; gap: 10px; padding: 6px 8px 14px; text-decoration: none; }
.sg-brandlogo { height: 34px; width: auto; max-width: 100%; object-fit: contain; }
.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; justify-content: flex-start; 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; margin: 0; appearance: none; -webkit-appearance: 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 ---------- */
/* Content column beside the sidebar: lets a full-width banner stack above the
   page's own .sg-main without disturbing the sidebar/content flex row. */
.sg-shell { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.sg-shell > .sg-main { flex: 1; }
.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; }
  /* labels voltam no drawer → realinhar à esquerda (desfaz o center do modo ícone ≤1100). */
  .sg-sidebar .sg-nav { justify-content: flex-start; }
  .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; }
.sg-viewer { display: flex; flex-direction: column; gap: 8px; max-width: 92vw; max-height: 88vh; }
.sg-viewer img { max-width: 92vw; max-height: 84vh; border-radius: var(--sg-radius); }
.sg-viewer-pdf { width: 86vw; height: 84vh; border: none; border-radius: var(--sg-radius); background: #fff; }
.sg-viewer-text { background: #fff; color: var(--sg-text); border-radius: var(--sg-radius); padding: 16px; width: 86vw; max-width: 900px; max-height: 80vh; overflow: auto; font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size: 12.5px; line-height: 1.5; white-space: pre-wrap; word-break: break-word; }
.sg-viewer-foot { color: #fff; font-size: 12px; text-align: center; }
.sg-viewer-foot a { color: #fff; text-decoration: underline; }

/* 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; }
}

/* ================= Meta do Dia (Metas) ================= */
.sg-today { margin-left: auto; font-size: 12.5px; color: var(--sg-text-soft); display: flex; align-items: center; gap: 6px; }
.sg-metagrid { display: grid; grid-template-columns: 1fr 380px; gap: 16px; margin: 14px 24px 40px; align-items: start; }
.sg-panel { background: var(--sg-bg-primary); border: 1px solid var(--sg-line); border-radius: var(--sg-radius); box-shadow: var(--sg-shadow); }
.sg-phead { display: flex; align-items: center; gap: 10px; padding: 14px 16px; border-bottom: 1px solid var(--sg-line); }
.sg-phead b { font-size: 14px; }
.sg-psub { font-size: 11.5px; color: var(--sg-text-faint); }
.sg-pillrow { display: flex; gap: 6px; margin-left: auto; flex-wrap: wrap; }
.sg-qfilter { font-size: 11px; font-weight: 700; padding: 3px 9px; border-radius: 20px; border: 1px solid var(--sg-line); color: var(--sg-text-soft); }
.sg-qfilter[data-q="1"].sg-on { background: var(--sg-q1-bg); color: var(--sg-q1); border-color: var(--sg-q1-bd); }
.sg-qfilter[data-q="2"].sg-on { background: var(--sg-q2-bg); color: var(--sg-q2); border-color: var(--sg-q2-bd); }
.sg-qfilter[data-q="3"].sg-on { background: var(--sg-q3-bg); color: var(--sg-q3); border-color: var(--sg-q3-bd); }
.sg-qfilter[data-q="4"].sg-on { background: var(--sg-q4-bg); color: var(--sg-q4); border-color: var(--sg-q4-bd); }

.sg-plist { padding: 8px; display: flex; flex-direction: column; gap: 7px; max-height: 560px; overflow-y: auto; }
.sg-ptask { display: flex; gap: 10px; align-items: center; padding: 10px; border: 1px solid var(--sg-line); border-radius: var(--sg-radius-sm); cursor: pointer; transition: .12s; }
.sg-ptask:hover { border-color: #C7D2DD; background: #FAFCFE; }
.sg-ptask.sg-sel { border-color: var(--sg-accent); background: var(--sg-accent-soft); }
.sg-qbar2 { width: 4px; align-self: stretch; border-radius: 4px; flex: none; background: var(--sg-q4); }
[data-q="1"] > .sg-qbar2 { background: var(--sg-q1); }
[data-q="2"] > .sg-qbar2 { background: var(--sg-q2); }
[data-q="3"] > .sg-qbar2 { background: var(--sg-q3); }
[data-q="4"] > .sg-qbar2 { background: var(--sg-q4); }
.sg-tcheck { width: 20px; height: 20px; border-radius: 6px; border: 2px solid #C7D2DD; flex: none; display: grid; place-items: center; color: #fff; transition: .12s; }
.sg-ptask.sg-sel .sg-tcheck { background: var(--sg-accent); border-color: var(--sg-accent); }
.sg-tbody { flex: 1; min-width: 0; }
.sg-ttitle2 { font-size: 13.5px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sg-tmeta { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-top: 5px; }
.sg-mb { font-size: 11px; color: var(--sg-text-soft); display: inline-flex; align-items: center; gap: 4px; font-weight: 500; }
.sg-mb.sg-due-over { color: var(--sg-q1); font-weight: 700; }
.sg-qtag[data-q="1"] { background: var(--sg-q1-bg); color: var(--sg-q1); }
.sg-qtag[data-q="2"] { background: var(--sg-q2-bg); color: var(--sg-q2); }
.sg-qtag[data-q="3"] { background: var(--sg-q3-bg); color: var(--sg-q3); }
.sg-qtag[data-q="4"] { background: var(--sg-q4-bg); color: var(--sg-q4); }

/* coluna direita: meta */
.sg-goalcard { position: sticky; top: 16px; display: flex; flex-direction: column; }
.sg-ghead { padding: 16px 16px 12px; border-bottom: 1px solid var(--sg-line); }
.sg-ghead b { font-size: 15px; display: flex; align-items: center; gap: 8px; color: var(--sg-accent); }
.sg-ghead p { font-size: 11.5px; color: var(--sg-text-soft); margin-top: 3px; }
.sg-ghead p.sg-calib { color: var(--sg-accent-ink); font-weight: 600; margin-top: 6px; }

.sg-budget { padding: 14px 16px; border-bottom: 1px solid var(--sg-line); }
.sg-blabel { display: flex; justify-content: space-between; font-size: 12px; font-weight: 600; color: var(--sg-text-soft); margin-bottom: 8px; }
.sg-blabel b { color: var(--sg-accent-ink); }
.sg-budget input[type=range] { width: 100%; accent-color: var(--sg-accent); }
.sg-gauge { margin-top: 12px; }
.sg-gnums { display: flex; justify-content: space-between; font-size: 11px; color: var(--sg-text-faint); margin-bottom: 5px; font-weight: 600; }
.sg-gbar { height: 10px; border-radius: 6px; background: #EEF2F6; overflow: hidden; display: flex; }
.sg-gfill { height: 100%; background: linear-gradient(90deg, var(--sg-accent), #5C6BC0); transition: width .25s; }
.sg-gfill.sg-over { background: linear-gradient(90deg, #E67E22, var(--sg-q1)); }
.sg-ghint { font-size: 11px; margin-top: 6px; color: var(--sg-text-soft); }
.sg-ghint.sg-over { color: var(--sg-q1); font-weight: 600; }

.sg-q2flag { margin: 12px 16px 0; display: flex; align-items: center; gap: 9px; padding: 9px 11px; border-radius: var(--sg-radius-sm); background: var(--sg-q2-bg); border: 1px solid var(--sg-q2-bd); font-size: 11.5px; color: #1E7D45; font-weight: 500; }
.sg-q2flag.sg-miss { background: var(--sg-q3-bg); border-color: var(--sg-q3-bd); color: #9A6206; }

.sg-glist { padding: 12px 14px; display: flex; flex-direction: column; gap: 7px; min-height: 60px; }
.sg-gempty { text-align: center; color: var(--sg-text-faint); font-size: 12px; padding: 18px 8px; }
.sg-gitem { display: flex; align-items: center; gap: 9px; padding: 8px 10px; border: 1px solid var(--sg-line); border-radius: var(--sg-radius-sm); }
.sg-gitem.sg-done .sg-gn { text-decoration: line-through; color: var(--sg-text-faint); }
.sg-gt { flex: 1; min-width: 0; }
.sg-gn { font-size: 12.5px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sg-gd { font-size: 10.5px; color: var(--sg-text-faint); font-weight: 600; margin-top: 2px; }
.sg-rm { color: var(--sg-text-faint); padding: 3px; border-radius: 5px; }
.sg-rm:hover { background: var(--sg-q1-bg); color: var(--sg-q1); }

.sg-gactions { padding: 12px 16px; border-top: 1px solid var(--sg-line); display: flex; flex-direction: column; gap: 8px; }
.sg-btn { display: flex; align-items: center; justify-content: center; gap: 7px; padding: 10px; border-radius: var(--sg-radius-sm); font-weight: 700; font-size: 13px; color: #fff; }
.sg-btn-suggest { background: linear-gradient(135deg, #F39C12, #E67E22); }
.sg-btn-suggest:hover { filter: brightness(1.04); }
.sg-btn-start { background: var(--sg-q2); }
.sg-btn-start:hover { background: #1F8B4C; }
.sg-btn-start:disabled { background: #D5DBDB; cursor: not-allowed; }
.sg-linkrow { display: flex; align-items: center; gap: 7px; font-size: 11.5px; color: var(--sg-text-soft); padding: 2px 2px 0; flex-wrap: wrap; }
.sg-linkrow select { font-family: inherit; font-size: 11.5px; border: 1px solid var(--sg-line); border-radius: 6px; padding: 3px 6px; color: var(--sg-text); background: #fff; }

@media (max-width: 980px) { .sg-metagrid { grid-template-columns: 1fr; } .sg-goalcard { position: static; } }
@media (max-width: 760px) { .sg-metagrid { margin: 14px 14px 40px; } }

/* ================= Relatórios (/relatorios) ================= */
.sg-rep-sub { font-size: 12px; font-weight: 500; color: var(--sg-text-faint); }
.sg-rep-period { margin: 4px 24px 0; font-size: 12px; color: var(--sg-text-soft); }
.sg-rep-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; margin: 12px 24px 40px; }
.sg-rep-wide { grid-column: 1 / -1; }
.sg-rep-card { background: var(--sg-bg-primary); border: 1px solid var(--sg-line); border-radius: var(--sg-radius); padding: 16px 18px; display: flex; flex-direction: column; gap: 10px; }
.sg-rep-h { font-size: 14px; font-weight: 700; display: flex; align-items: center; justify-content: space-between; }
.sg-rep-streak { font-size: 12px; font-weight: 700; color: var(--sg-q3); }
.sg-rep-more { margin-left: auto; font-size: 11.5px; font-weight: 600; color: var(--sg-accent); }
.sg-insight { font-size: 12.5px; line-height: 1.5; color: var(--sg-text-soft); background: var(--sg-bg-app); border-radius: var(--sg-radius-sm); padding: 9px 11px; border-left: 3px solid var(--sg-accent-soft); }
.sg-rep-legend { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.sg-rep-avg { font-size: 11.5px; font-weight: 700; color: var(--sg-accent-ink); }
.sg-tiles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.sg-tile { background: var(--sg-bg-app); border-radius: var(--sg-radius-sm); padding: 12px; text-align: center; }
.sg-tile-v { font-size: 22px; font-weight: 700; letter-spacing: -.4px; }
.sg-tile-l { font-size: 10.5px; color: var(--sg-text-faint); margin-top: 2px; line-height: 1.3; }
.sg-rep-hyg { display: flex; flex-direction: column; gap: 6px; }
.sg-rep-hrow { display: flex; justify-content: space-between; gap: 10px; font-size: 13px; padding: 6px 8px; background: var(--sg-bg-app); border-radius: var(--sg-radius-sm); }
.sg-rep-hrow span { color: var(--sg-text-soft); text-align: right; }
/* charts */
.sg-chart { width: 100%; height: auto; display: block; }
.sg-chart-lbl { font-size: 8px; fill: var(--sg-text-faint); }
.sg-chart-num { font-size: 8px; font-weight: 700; fill: var(--sg-text-soft); }
.sg-hbars { display: flex; flex-direction: column; gap: 8px; }
.sg-hbar-row { display: grid; grid-template-columns: 110px 1fr 56px; align-items: center; gap: 8px; }
.sg-hbar-name { font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sg-hbar-track { height: 14px; background: var(--sg-bg-app); border-radius: 7px; overflow: hidden; }
.sg-hbar-fill { height: 100%; background: var(--sg-accent); border-radius: 7px; }
.sg-hbar-val { font-size: 11.5px; color: var(--sg-text-soft); text-align: right; }
@media (max-width: 900px) {
    .sg-rep-grid { grid-template-columns: 1fr; margin-left: 14px; margin-right: 14px; }
    .sg-rep-period { margin-left: 14px; }
    .sg-hbar-row { grid-template-columns: 90px 1fr 48px; }
}

/* ================= Cofre (/cofre) ================= */
.sg-vault-lock { display: grid; place-items: center; padding: 48px 16px; }
.sg-vault-card { width: 100%; max-width: 420px; background: var(--sg-bg-primary); border: 1px solid var(--sg-line); border-radius: var(--sg-radius); padding: 28px; display: flex; flex-direction: column; gap: 12px; text-align: center; box-shadow: 0 10px 40px rgba(16,32,48,.06); }
.sg-vault-hero { width: 56px; height: 56px; border-radius: 16px; background: var(--sg-accent-soft); color: var(--sg-accent); display: grid; place-items: center; margin: 0 auto; }
.sg-vault-card h2 { font-size: 19px; font-weight: 700; margin: 0; }
.sg-vault-card p { font-size: 13px; color: var(--sg-text-soft); margin: 0; }
.sg-vault-card .sg-input { text-align: left; }
.sg-vault-warn { background: var(--sg-q3-bg); color: #8a5a00; border-radius: var(--sg-radius-sm); padding: 10px 12px; font-size: 12px; text-align: left; line-height: 1.5; }
.sg-vault-err { color: var(--sg-q1); font-size: 12.5px; font-weight: 600; }

.sg-vault-bar { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; margin: 14px 24px; }
.sg-vault-banner { display: flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600; color: var(--sg-q2); background: var(--sg-q2-bg); padding: 5px 10px; border-radius: 20px; }
.sg-vault-seal { display: flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600; color: var(--sg-accent-ink); background: var(--sg-accent-soft); padding: 5px 10px; border-radius: 20px; }
.sg-vault-search { flex: 1; min-width: 160px; max-width: 320px; }
.sg-vault-form-wrap { margin: 0 24px 14px; }
#vault-form { display: flex; flex-direction: column; gap: 8px; max-width: 480px; background: var(--sg-bg-primary); border: 1px solid var(--sg-line); border-radius: var(--sg-radius); padding: 16px; }
.sg-vault-formrow { display: flex; align-items: center; gap: 10px; }
.sg-vault-formrow label { font-size: 12px; color: var(--sg-text-soft); width: 50px; }
.sg-vault-formbtns { display: flex; gap: 8px; }

.sg-vault-list { margin: 0 24px 40px; display: flex; flex-direction: column; gap: 8px; }
.sg-vault-item { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; background: var(--sg-bg-primary); border: 1px solid var(--sg-line); border-radius: var(--sg-radius-sm); padding: 12px 14px; }
.sg-vault-item > .sg-cal-cd { background: var(--sg-accent); }
.sg-vault-main { flex: 1; min-width: 200px; }
.sg-vault-title { font-size: 14px; display: flex; align-items: center; gap: 7px; }
.sg-vault-type { font-size: 15px; }
.sg-vault-val { font-size: 12px; color: var(--sg-text-faint); margin-top: 2px; }
.sg-vault-secret { font-family: ui-monospace, Menlo, Consolas, monospace; color: var(--sg-text); }
.sg-vault-atts { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
.sg-vault-att { font-size: 11px; }
.sg-vault-actions { display: flex; flex-wrap: wrap; gap: 4px; }
.sg-vault-attbox { display: flex; gap: 8px; align-items: center; width: 100%; padding-top: 8px; border-top: 1px dashed var(--sg-line); margin-top: 4px; }
/* vault inputs always fill their container (sg-input has no width of its own) */
.sg-vault-card .sg-input, #vault-form .sg-input, #vault-form textarea, .sg-vault-formrow select { width: 100%; }
@media (max-width: 760px) {
    .sg-vault-bar, .sg-vault-list, .sg-vault-form-wrap { margin-left: 14px; margin-right: 14px; }
    .sg-vault-lock { padding: 24px 14px; }
    .sg-vault-card { padding: 20px; }
    /* search drops to its own full-width line; nothing forces the bar wider than the screen */
    .sg-vault-bar { gap: 8px; }
    .sg-vault-search { order: 9; flex-basis: 100%; min-width: 0; max-width: none; }
    /* item content takes the full row; actions wrap onto the next line */
    .sg-vault-main { min-width: 0; flex-basis: 100%; }
    .sg-vault-item { gap: 8px; }
    #vault-form { max-width: none; }
}

/* ================= Calendário (/calendario) ================= */
.sg-cal-toolbar { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; margin: 14px 24px; }
.sg-cal-nav { display: flex; align-items: center; gap: 6px; }
.sg-cal-lbl { font-weight: 700; font-size: 15px; min-width: 150px; text-align: center; }
.sg-cal-toggle, .sg-cal-filters { display: flex; gap: 6px; }
.sg-cal-legend { display: flex; gap: 12px; margin-left: auto; align-items: center; }
.sg-cal-leg { display: flex; align-items: center; gap: 5px; font-size: 11.5px; color: var(--sg-text-soft); }
.sg-cal-dot, .sg-cal-cd { width: 8px; height: 8px; border-radius: 50%; flex: none; background: var(--sg-text-faint); }
.sg-cal-dot[data-q="1"], .sg-cal-cd[data-q="1"] { background: var(--sg-q1); }
.sg-cal-dot[data-q="2"], .sg-cal-cd[data-q="2"] { background: var(--sg-q2); }
.sg-cal-dot[data-q="3"], .sg-cal-cd[data-q="3"] { background: var(--sg-q3); }
.sg-cal-dot[data-q="4"], .sg-cal-cd[data-q="4"] { background: var(--sg-q4); }

/* minmax(0,1fr): columns stay equal even when a cell has a long chip — 1fr alone
   won't shrink below content, which let one weekday column grow wider. */
.sg-cal-grid { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 1px; background: var(--sg-line); border: 1px solid var(--sg-line); border-radius: var(--sg-radius); overflow: hidden; margin: 0 24px 40px; }
.sg-cal-dow { background: var(--sg-bg-primary); padding: 8px; text-align: center; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--sg-text-faint); }
.sg-cal-cell { background: var(--sg-bg-primary); min-width: 0; min-height: 104px; padding: 6px; display: flex; flex-direction: column; gap: 3px; cursor: pointer; transition: background .12s; }
.sg-cal-grid.sg-week .sg-cal-cell { min-height: 340px; }
.sg-cal-cell:hover { background: var(--sg-bg-app); }
.sg-cal-cell.sg-other { background: #FAFBFC; }
.sg-cal-cell.sg-other .sg-cal-daynum b { color: var(--sg-text-faint); }
.sg-cal-cell.sg-weekend { background: #FCFCFD; }
.sg-cal-cell.sg-today { box-shadow: inset 0 0 0 2px var(--sg-accent); }
.sg-cal-daynum { display: flex; align-items: center; justify-content: space-between; font-size: 12.5px; }
.sg-cal-cell.sg-today .sg-cal-daynum b { background: var(--sg-accent); color: #fff; width: 21px; height: 21px; border-radius: 50%; display: grid; place-items: center; }
.sg-cal-ring { font-size: 10px; font-weight: 700; padding: 1px 6px; border-radius: 20px; }
.sg-cal-ring[data-band="ok"] { color: var(--sg-q2); background: var(--sg-q2-bg); }
.sg-cal-ring[data-band="mid"] { color: var(--sg-q3); background: var(--sg-q3-bg); }
.sg-cal-ring[data-band="low"] { color: var(--sg-q1); background: var(--sg-q1-bg); }
.sg-cal-chip { display: flex; align-items: center; gap: 5px; min-width: 0; max-width: 100%; font-size: 11.5px; padding: 2px 6px; border-radius: 5px; background: var(--sg-bg-app); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sg-cal-chip.sg-over { box-shadow: inset 0 0 0 1px var(--sg-q1); color: var(--sg-q1); }
.sg-cal-more { font-size: 10.5px; color: var(--sg-text-faint); font-weight: 600; padding-left: 2px; }

.sg-cal-scrim { position: fixed; inset: 0; background: rgba(16,32,48,.28); z-index: 70; display: flex; justify-content: flex-end; }
.sg-daypanel { width: 380px; max-width: 92vw; height: 100dvh; background: var(--sg-bg-primary); box-shadow: -8px 0 40px rgba(16,32,48,.18); display: flex; flex-direction: column; overflow: hidden; }
.sg-dp-head { display: flex; align-items: flex-start; justify-content: space-between; padding: 18px 18px 8px; }
.sg-dp-dow { font-size: 11px; text-transform: uppercase; letter-spacing: .6px; color: var(--sg-text-faint); font-weight: 600; }
.sg-dp-sub { padding: 0 18px 12px; font-size: 12.5px; color: var(--sg-text-soft); border-bottom: 1px solid var(--sg-line); }
.sg-dp-body { padding: 10px; overflow-y: auto; display: flex; flex-direction: column; gap: 6px; }
.sg-dp-item { display: flex; align-items: flex-start; gap: 9px; padding: 9px 10px; border-radius: var(--sg-radius-sm); background: var(--sg-bg-app); }
.sg-dp-item .sg-cal-cd { margin-top: 5px; }
.sg-dp-main { flex: 1; min-width: 0; cursor: pointer; }
.sg-dp-title { font-size: 13.5px; font-weight: 500; }
.sg-dp-meta { display: flex; flex-wrap: wrap; gap: 8px; font-size: 11px; color: var(--sg-text-faint); margin-top: 2px; }
.sg-dp-over { color: var(--sg-q1); font-weight: 700; }
.sg-dp-actions { display: flex; gap: 4px; }
@media (max-width: 760px) { .sg-cal-toolbar, .sg-cal-grid { margin-left: 14px; margin-right: 14px; } .sg-cal-cell { min-height: 76px; } .sg-cal-legend { display: none; } }

/* ================= Ajuda (/ajuda) ================= */
.sg-helpgrid { display: grid; grid-template-columns: 260px 1fr; gap: 16px; margin: 14px 24px 40px; align-items: start; }
.sg-help-nav { position: sticky; top: 16px; display: flex; flex-direction: column; overflow: hidden; }
.sg-help-search { display: flex; align-items: center; gap: 8px; padding: 12px 14px; border-bottom: 1px solid var(--sg-line); color: var(--sg-text-faint); }
.sg-help-search input { border: none; outline: none; background: none; font: inherit; font-size: 13px; color: var(--sg-text); width: 100%; }
.sg-help-seclist { display: flex; flex-direction: column; padding: 8px; gap: 2px; max-height: 70vh; overflow-y: auto; }
.sg-help-secitem { display: block; width: 100%; text-align: left; justify-content: flex-start; padding: 9px 11px; border-radius: var(--sg-radius-sm); font-size: 13px; font-weight: 500; color: var(--sg-text-soft); }
.sg-help-secitem:hover { background: var(--sg-bg-app); color: var(--sg-text); }
.sg-help-secitem.sg-active { background: var(--sg-accent-soft); color: var(--sg-accent-ink); font-weight: 600; }
.sg-help-content { padding: 22px 26px; font-size: 14px; line-height: 1.6; color: var(--sg-text); max-width: 820px; }
.sg-help-content h1 { font-size: 22px; font-weight: 700; margin: 0 0 14px; letter-spacing: -.2px; }
.sg-help-content h2 { font-size: 17px; font-weight: 700; margin: 22px 0 8px; }
.sg-help-content h3 { font-size: 15px; font-weight: 700; margin: 18px 0 6px; color: var(--sg-text-soft); }
.sg-help-content p { margin: 0 0 12px; }
.sg-help-content ul, .sg-help-content ol { margin: 0 0 12px 22px; display: flex; flex-direction: column; gap: 5px; }
.sg-help-content a { color: var(--sg-accent); }
.sg-help-content code { background: var(--sg-bg-app); border-radius: 5px; padding: 1px 5px; font-family: ui-monospace, Menlo, Consolas, monospace; font-size: 12.5px; }
.sg-help-content table { border-collapse: collapse; width: 100%; margin: 6px 0 16px; font-size: 13px; }
.sg-help-content th, .sg-help-content td { border: 1px solid var(--sg-line); padding: 7px 10px; text-align: left; vertical-align: top; }
.sg-help-content th { background: var(--sg-bg-app); font-weight: 700; }
.sg-help-content blockquote { border-left: 3px solid var(--sg-accent-soft); margin: 0 0 12px; padding: 4px 0 4px 12px; color: var(--sg-text-soft); }
@media (max-width: 900px) { .sg-helpgrid { grid-template-columns: 1fr; margin: 14px 14px 40px; } .sg-help-nav { position: static; } .sg-help-seclist { max-height: 240px; } }

/* vínculo Projeto/Cliente (SgTaskLink) */
.sg-link { display: flex; flex-direction: column; gap: 12px; }
.sg-link-field { display: flex; flex-direction: column; gap: 5px; }
.sg-link-field label { font-size: 12px; font-weight: 600; color: var(--sg-text-soft); display: flex; align-items: center; gap: 6px; }
.sg-selectwrap select { width: 100%; font-family: inherit; font-size: 13.5px; color: var(--sg-text); background: #fff; border: 1px solid var(--sg-line); border-radius: 9px; padding: 10px 12px; cursor: pointer; }
.sg-selectwrap select:hover { border-color: #C7D2DD; }
.sg-selectwrap select:disabled { background: #F4F6F8; color: var(--sg-text-soft); cursor: not-allowed; }
.sg-inherited { font-size: 11.5px; color: var(--sg-inflight); display: flex; align-items: center; gap: 5px; font-weight: 600; }

/* arquivados / confirmação */
.sg-quad.sg-arch { opacity: .58; }
.sg-confirm { font-size: 14px; color: var(--sg-text); }
.sg-confirm-detail { font-size: 12.5px; color: var(--sg-text-soft); margin-top: 8px; background: var(--sg-bg-app); border-radius: var(--sg-radius-sm); padding: 8px 10px; }
