/* ============================================================
   v3 — screen-specific styles: WhatsApp rail · Message Center · Automations
   ============================================================ */

/* ---------- WHATSAPP COMPOSER RAIL ---------- */
.warail { width: var(--rail-right); flex: none; background: var(--paper); border-left: 1px solid var(--grid);
  display: flex; flex-direction: column; min-height: 0; }
.wr-head { padding: 16px 18px 12px; border-bottom: 1px solid var(--grid); }
.wr-title { font-family: var(--font-serif); font-size: 17px; font-weight: 600; margin: 0; display: flex; align-items: center; gap: 8px; }
.wr-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--wa-green); }
.wr-sub { font-size: 12px; color: var(--text-muted); margin-top: 3px; }
.wr-body { flex: 1; overflow-y: auto; padding: 14px 16px; display: flex; flex-direction: column; gap: 14px; }
.wr-block { display: flex; flex-direction: column; gap: 9px; }
.wr-step { display: flex; align-items: center; gap: 8px; font-size: 10.5px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .08em; color: var(--text-muted); }
.wr-num { width: 18px; height: 18px; border-radius: 50%; background: var(--accent); color: #fff; display: grid; place-items: center;
  font-size: 10px; font-weight: 800; letter-spacing: 0; }
.wr-recip { background: var(--warm-2); border: 1px solid var(--grid); border-radius: 12px; padding: 12px 14px; }
.wr-recip-row { font-size: 13px; }
.wr-recip-row b { font-size: 18px; color: var(--accent-dark); font-family: var(--font-mono); }
.wr-elig { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--status-good); font-weight: 600; margin-top: 7px; }
.wr-names { font-size: 11px; color: var(--text-muted); margin-top: 6px; }
.wr-allbtn { width: 100%; margin-top: 10px; padding: 8px; border: 1px dashed var(--grid-strong); background: transparent;
  border-radius: 8px; font: inherit; font-size: 12px; color: var(--accent-dark); cursor: pointer; }
.wr-allbtn:hover { border-color: var(--accent); background: var(--warm); }
.wr-note { font-size: 11px; color: var(--text-muted); }
.wr-draft { border: 1px solid var(--grid-strong); border-radius: 8px; padding: 10px; font-size: 12.5px; min-height: 78px;
  background: var(--warm-2); color: var(--text-soft); }
.wr-check, .wr-radio { display: flex; align-items: center; gap: 9px; font-size: 12.5px; color: var(--text-soft); cursor: pointer; }
.radio { width: 17px; height: 17px; border-radius: 50%; border: 1.5px solid var(--grid-strong); flex: none; position: relative; }
.radio.on { border-color: var(--accent); }
.radio.on::after { content: ''; position: absolute; inset: 3px; border-radius: 50%; background: var(--accent); }
.wr-foot { border-top: 1px solid var(--grid); padding: 13px 16px; }
.wr-cost { font-size: 11.5px; color: var(--text-muted); margin-bottom: 9px; }
.wr-cost b { color: var(--text); font-family: var(--font-mono); }
.wr-free { color: var(--status-good); }
.wr-send { width: 100%; border: 0; border-radius: 11px; background: var(--wa-green); color: #062b13; font: inherit;
  font-size: 14px; font-weight: 800; padding: 12px; cursor: pointer; }
.wr-send:hover { filter: brightness(1.04); }
.wr-send.off { background: var(--status-good-bg); color: var(--status-good); cursor: not-allowed; }
.wr-health { display: flex; align-items: center; gap: 7px; font-size: 11.5px; color: var(--text-muted); margin-top: 11px; }
.wr-hdot { width: 8px; height: 8px; border-radius: 50%; background: var(--status-good); }
.wr-det { margin-left: auto; color: var(--accent); display: inline-flex; align-items: center; gap: 2px; cursor: pointer; }
.wr-disc { font-size: 10.5px; color: var(--text-muted); text-align: center; margin-top: 9px; }

/* ============================================================
   MESSAGE CENTER (3-pane)
   ============================================================ */
.mc { display: flex; flex: 1; min-height: 0; background: var(--warm); }
.mc-list { width: 320px; flex: none; background: var(--paper); border-right: 1px solid var(--grid); display: flex; flex-direction: column; min-height: 0; }
.mc-list.wide { width: 360px; }
.mc-listhead { padding: 15px 18px 12px; border-bottom: 1px solid var(--grid); }
.mc-listhead h2 { font-family: var(--font-serif); font-size: 17px; margin: 0; }
.mc-listhead .sub { font-size: 11.5px; color: var(--text-muted); margin-top: 3px; display: flex; gap: 8px; align-items: center; }
.mc-search { padding: 10px 14px; border-bottom: 1px solid var(--grid); }
.mc-filters { display: flex; gap: 7px; padding: 10px 14px; border-bottom: 1px solid var(--grid); flex-wrap: wrap; }
.mc-convos { flex: 1; overflow-y: auto; min-height: 0; }
.mc-convo { display: flex; gap: 11px; padding: 12px 16px; border-bottom: 1px solid var(--grid); cursor: pointer; align-items: flex-start; border-left: 3px solid transparent; }
.mc-convo:hover { background: var(--warm-2); }
.mc-convo.active { background: var(--status-good-bg); border-left-color: var(--accent); }
:root[data-theme="dark"] .mc-convo.active { background: rgba(44,140,153,.14); }
.mc-av { width: 38px; height: 38px; border-radius: 50%; display: grid; place-items: center; color: #fff; font-weight: 700; font-size: 13px; flex: none; }
.mc-cmain { flex: 1; min-width: 0; }
.mc-crow1 { display: flex; align-items: baseline; justify-content: space-between; gap: 8px; }
.mc-cname { font-weight: 700; font-size: 13px; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mc-ctime { font-size: 10.5px; color: var(--text-muted); flex: none; }
.mc-cprev { font-size: 12px; color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 3px; }
.mc-cmeta { display: flex; align-items: center; gap: 7px; margin-top: 6px; }
.mc-unread { width: 8px; height: 8px; border-radius: 50%; background: var(--status-mora2); flex: none; }

/* thread */
.mc-thread { flex: 1; display: flex; flex-direction: column; min-width: 0; background: var(--warm); }
.mc-threadhead { padding: 14px 20px; border-bottom: 1px solid var(--grid); background: var(--paper); display: flex; align-items: center; gap: 12px; }
.mc-threadhead h2 { font-family: var(--font-serif); font-size: 17px; margin: 0; }
.mc-threadhead .sub { font-size: 12px; color: var(--text-muted); margin-top: 2px; }
.mc-msgs { flex: 1; overflow-y: auto; padding: 18px 24px; display: flex; flex-direction: column; gap: 12px; }
.mc-daypill { align-self: center; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--text-muted);
  background: var(--warm-2); border: 1px solid var(--grid); padding: 3px 12px; border-radius: 999px; }
.bubble { max-width: 76%; padding: 10px 13px; border-radius: 14px; font-size: 13px; line-height: 1.5; position: relative; }
.bubble.out { align-self: flex-end; background: #DCF8C6; color: #0C1F12; border-bottom-right-radius: 4px; }
:root[data-theme="dark"] .bubble.out { background: #1E3A2A; color: #D4F0DD; }
.bubble.in { align-self: flex-start; background: var(--paper); border: 1px solid var(--grid); border-bottom-left-radius: 4px; }
.bubble .bt { display: block; font-size: 10px; color: var(--text-muted); margin-top: 5px; text-align: right; }
.bubble.out .bt { color: rgba(12,31,18,.5); }
:root[data-theme="dark"] .bubble.out .bt { color: rgba(212,240,221,.5); }
.bubble.pay { align-self: flex-end; background: var(--paper); border: 1px solid var(--accent); border-radius: 12px; max-width: 60%; }
.bubble.pay .pl { font-weight: 700; color: var(--accent-dark); display: flex; align-items: center; gap: 7px; }
.bubble.pay .lk { font-family: var(--font-mono); font-size: 11.5px; color: var(--text-muted); margin-top: 4px; }
.mc-composer { border-top: 1px solid var(--grid); background: var(--paper); padding: 12px 18px; }
.mc-quick { display: flex; gap: 8px; margin-bottom: 10px; flex-wrap: wrap; }
.mc-qr { font-size: 12px; font-weight: 600; padding: 6px 12px; border-radius: 999px; border: 1px solid var(--grid-strong); background: var(--paper); color: var(--text-soft); cursor: pointer; }
.mc-qr:hover { border-color: var(--accent); color: var(--accent); }
.mc-ta { width: 100%; border: 1px solid var(--grid-strong); border-radius: 10px; padding: 10px; font: inherit; font-size: 13px; min-height: 56px; resize: none; background: var(--paper); color: var(--text); }
.mc-warn { font-size: 11.5px; color: var(--status-mora2); background: var(--status-mora2-bg); border-radius: 8px; padding: 8px 11px; margin: 9px 0; }
.mc-send { width: 100%; border: 0; border-radius: 11px; background: var(--wa-green); color: #062b13; font: inherit; font-size: 14px; font-weight: 800; padding: 12px; cursor: pointer; }
.mc-send.off { background: var(--status-good-bg); color: var(--status-good); cursor: not-allowed; }

/* family profile rail */
.mc-fam { width: 300px; flex: none; background: var(--paper); border-left: 1px solid var(--grid); padding: 16px 18px; overflow-y: auto; }
.mc-famhead h2 { font-family: var(--font-serif); font-size: 17px; margin: 0; }
.mc-famhead .sub { font-size: 12px; color: var(--text-muted); margin-top: 2px; }
.mc-balcard { margin-top: 14px; }
.mc-stu { display: flex; align-items: center; gap: 10px; padding: 9px 0; border-bottom: 1px solid var(--grid); }
.mc-stu:last-child { border-bottom: 0; }
.mc-disc { font-size: 11px; color: var(--text-muted); margin-top: 14px; line-height: 1.5; }

/* ============================================================
   AUTOMATIONS — journey studio
   ============================================================ */
.au { display: flex; flex: 1; min-height: 0; }
.au-list { width: 300px; flex: none; border-right: 1px solid var(--grid); background: var(--paper); overflow-y: auto; padding: 14px; }
.au-list.dense { width: 270px; }
.au-listhead { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--text-muted); margin: 4px 4px 10px; }
.au-jstats { display: flex; gap: 7px; margin-bottom: 12px; flex-wrap: wrap; }
.au-jrow { display: flex; align-items: center; gap: 11px; padding: 11px 12px; border-radius: 11px; border: 1px solid var(--grid); margin-bottom: 8px; cursor: pointer; background: var(--paper); }
.au-jrow:hover { border-color: var(--grid-strong); background: var(--warm-2); }
.au-jrow.active { border-color: var(--accent); background: var(--status-good-bg); box-shadow: var(--shadow-sm); }
:root[data-theme="dark"] .au-jrow.active { background: rgba(44,140,153,.12); }
.au-jico { width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; flex: none; }
.au-jmain { flex: 1; min-width: 0; }
.au-jname { font-weight: 700; font-size: 13px; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.au-jmeta { font-size: 11px; color: var(--text-muted); margin-top: 2px; font-family: var(--font-mono); }
.au-jdot { width: 9px; height: 9px; border-radius: 50%; flex: none; }
.au-jdot.on { background: var(--status-good); }
.au-jdot.draft { background: var(--status-mora1); }
.au-jdot.phase2 { background: var(--text-muted); }

/* canvas */
.au-canvas { flex: 1; min-width: 0; overflow-y: auto; background: var(--warm); padding: 22px 28px; position: relative; }
.au-canvas.grid-bg { background-image: radial-gradient(var(--grid) 1px, transparent 1px); background-size: 22px 22px; }
.au-cvhead { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 8px; }
.au-cvtitle { font-family: var(--font-serif); font-size: 19px; font-weight: 600; display: flex; align-items: center; gap: 8px; }
.au-cvsub { font-size: 12px; color: var(--text-muted); margin-top: 3px; }
.au-hint { background: var(--status-pagado-bg); color: var(--status-pagado); border-radius: 9px; padding: 9px 13px; font-size: 12px; font-weight: 600; margin: 12px 0 18px; display: flex; align-items: center; gap: 8px; }
:root[data-theme="dark"] .au-hint { color: #93C5FD; }

/* node flow */
.au-flow { display: flex; flex-direction: column; align-items: center; }
.au-node { display: flex; align-items: stretch; gap: 14px; width: 100%; max-width: 540px; }
.au-rail { display: flex; flex-direction: column; align-items: center; width: 52px; flex: none; }
.au-badge { width: 46px; height: 46px; border-radius: 13px; display: grid; place-items: center; color: #fff; flex: none; box-shadow: var(--shadow-md); position: relative; z-index: 1; }
.au-badge.entry { background: var(--accent); }
.au-badge.wait { background: linear-gradient(160deg, #E8A33D, #C9822A); }
.au-badge.msg { background: linear-gradient(160deg, #2FB463, #15803D); }
.au-badge.decision { background: linear-gradient(160deg, #8B6FE0, #6D4FCB); }
.au-badge.goal { background: linear-gradient(160deg, #4F86E0, #1E40AF); }
.au-connector { flex: 1; width: 2px; background: var(--grid-strong); min-height: 18px; }
.au-body { flex: 1; min-width: 0; padding-bottom: 14px; }
.au-pill-entry { display: inline-flex; align-items: center; background: var(--status-good-bg); color: var(--status-good); border-radius: 999px;
  padding: 8px 16px; font-size: 13px; font-weight: 700; margin-top: 8px; }
.au-wait { display: inline-flex; align-items: center; gap: 9px; background: var(--status-mora1-bg); color: var(--status-mora1); border-radius: 999px;
  padding: 7px 14px; font-size: 13px; font-weight: 700; margin-top: 8px; }
.au-wait input { width: 44px; border: 1px solid var(--status-mora1); border-radius: 6px; padding: 3px 6px; font: inherit; font-weight: 700; text-align: center; background: var(--paper); color: var(--status-mora1); }
.au-card { background: var(--paper); border: 1px solid var(--grid); border-radius: 13px; padding: 14px 16px; box-shadow: var(--shadow-card); cursor: pointer; transition: border-color .12s, box-shadow .12s; }
.au-card:hover { border-color: var(--accent); box-shadow: var(--shadow-md); }
.au-card.sel { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(44,140,153,.16), var(--shadow-md); }
.au-card-tags { display: flex; gap: 7px; margin-bottom: 8px; }
.au-card-title { font-weight: 700; font-size: 14px; color: var(--text); }
.au-card-prev { font-size: 12px; color: var(--text-muted); margin-top: 4px; }
.au-decision { background: var(--status-remate-bg); border: 1.5px solid var(--status-remate); border-radius: 13px; padding: 14px 16px; }
:root[data-theme="dark"] .au-decision { background: rgba(124,58,237,.12); }
.au-decision-q { font-weight: 700; color: var(--status-remate); font-size: 14px; margin-bottom: 10px; }
:root[data-theme="dark"] .au-decision-q { color: #C4B5FD; }
.au-branches { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.au-branch { border-radius: 10px; padding: 10px 12px; font-size: 12px; }
.au-branch .bh { font-weight: 800; font-size: 11px; text-transform: uppercase; letter-spacing: .04em; }
.au-branch.yes { background: var(--status-good-bg); color: var(--status-good); }
.au-branch.no { background: var(--paper); border: 1px solid var(--grid); color: var(--text-soft); }
.au-branch .bs { color: var(--text-muted); margin-top: 2px; }

/* performance sidebar */
.au-perf { width: 290px; flex: none; border-left: 1px solid var(--grid); background: var(--paper); overflow-y: auto; padding: 18px; }
.au-perf.dense { width: 300px; }
.au-perfhead { font-family: var(--font-serif); font-size: 17px; margin: 0 0 14px; }
.au-metrics { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 18px; }
.au-metric { border: 1px solid var(--grid); border-radius: 11px; padding: 11px 13px; }
.au-metric .mv { font-family: var(--font-mono); font-size: 19px; font-weight: 700; color: var(--text); }
.au-metric .ml { font-size: 9.5px; text-transform: uppercase; letter-spacing: .06em; color: var(--text-muted); font-weight: 700; margin-top: 3px; }
.au-metric.good .mv { color: var(--status-good); }
.au-metric.warn .mv { color: var(--status-mora2); }
.au-metric.accent .mv { color: var(--accent-dark); }
.au-funnel-h { font-family: var(--font-serif); font-size: 14px; margin: 4px 0 12px; }
.au-frow { margin-bottom: 11px; }
.au-frow-top { display: flex; justify-content: space-between; font-size: 12px; margin-bottom: 5px; }
.au-frow-top .fn { color: var(--text-soft); font-weight: 600; }
.au-frow-top .fp { font-family: var(--font-mono); font-weight: 700; color: var(--text); }
.au-fbar { height: 8px; border-radius: 999px; background: var(--warm-2); overflow: hidden; }
.au-fbar > i { display: block; height: 100%; border-radius: 999px; background: var(--accent); }
.au-fbar.paid > i { background: var(--status-good); }
.au-disc { font-size: 11px; color: var(--text-muted); font-style: italic; margin-top: 6px; }

/* node editor (overlay panel) */
.au-editor { position: absolute; top: 0; right: 0; bottom: 0; width: 320px; background: var(--paper); border-left: 1px solid var(--grid-strong);
  box-shadow: var(--shadow-pop); padding: 18px; overflow-y: auto; z-index: 30; }
.au-ed-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
.au-ed-title { font-family: var(--font-serif); font-size: 17px; }
.au-ed-x { background: transparent; border: 0; color: var(--text-muted); cursor: pointer; }
.au-ed-sub { font-size: 12px; color: var(--text-muted); margin-bottom: 16px; }
.au-ed-label { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--text-muted); margin: 14px 0 7px; }
.au-imgslot { border: 1.5px dashed var(--grid-strong); border-radius: 10px; aspect-ratio: 16/9; display: grid; place-items: center;
  color: var(--text-muted); background: var(--warm-2); font-size: 11px; text-align: center; }
.stripe-ph { background-image: repeating-linear-gradient(45deg, var(--grid) 0 8px, transparent 8px 16px); }

/* ============================================================
   LEDGER — calm roster (Direction A)
   ============================================================ */
.kpis.cols5 { grid-template-columns: repeat(5, 1fr); }
.kpis.cols4 { grid-template-columns: repeat(4, 1fr); }

.roster { padding: 6px 26px 26px; }
.roster-row { display: grid; grid-template-columns: 26px 42px 1fr 150px 210px 130px 108px; align-items: center; gap: 14px;
  background: var(--paper); border: 1px solid var(--grid); border-radius: 12px; padding: 12px 16px; margin-bottom: 9px; box-shadow: var(--shadow-card);
  transition: border-color .12s, box-shadow .12s; }
.roster-row:hover { border-color: var(--grid-strong); box-shadow: var(--shadow-md); }
.roster-row.sel { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(44,140,153,.14), var(--shadow-card); }
.roster-head { display: grid; grid-template-columns: 26px 42px 1fr 150px 210px 130px 108px; gap: 14px; padding: 4px 16px 8px; }
.roster-head span { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--text-muted); }
.r-av { width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center; color: #fff; font-weight: 700; font-size: 14px; flex: none; }
.r-name { font-weight: 700; font-size: 14px; color: var(--text); }
.r-meta { font-size: 11.5px; color: var(--text-muted); margin-top: 2px; }
.r-prog { display: flex; flex-direction: column; gap: 5px; }
.r-bars { display: flex; gap: 3px; }
.r-bars i { flex: 1; height: 18px; border-radius: 3px; background: var(--warm-2); position: relative; }
.r-bars i.paid { background: var(--status-good); }
.r-bars i.mora { background: var(--status-mora2); }
.r-bars i.cur { box-shadow: 0 0 0 2px var(--status-mora1); }
.r-proglabel { font-size: 10.5px; color: var(--text-muted); }
.r-saldo { font-family: var(--font-mono); font-size: 14px; font-weight: 700; text-align: right; }
.r-saldo.mora { color: var(--status-mora2); }
.r-saldo.zero { color: var(--text-muted); }
.r-act { display: flex; justify-content: flex-end; }

/* dense KPI inline strip (Direction B) */
.kpibar { display: flex; align-items: stretch; background: var(--paper); border-bottom: 1px solid var(--grid); flex: none; }
.kpibar .kc { padding: 11px 22px; border-right: 1px solid var(--grid); display: flex; flex-direction: column; justify-content: center; }
.kpibar .kc:last-child { border-right: 0; }
.kpibar .kl { font-size: 10px; text-transform: uppercase; letter-spacing: .07em; color: var(--text-muted); font-weight: 700; white-space: nowrap; }
.kpibar .kv { font-family: var(--font-mono); font-size: 18px; font-weight: 700; color: var(--text); margin-top: 3px; line-height: 1.1; }
.kpibar .kv .cur { font-family: var(--font-sans); font-size: 10px; color: var(--text-muted); margin-left: 5px; vertical-align: 2px; }
.kpibar .kc.good .kv { color: var(--status-good); }
.kpibar .kc.warn .kv { color: var(--status-mora2); }
