/* ============================================================
   REPLYO — app surfaces (dashboard · builder · settings · onboarding)
   Builds on ledger.css tokens. Same ink/cream/phosphor world.
   ============================================================ */

/* ---------- APP SHELL ---------- */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
@media(max-width:900px){.app{grid-template-columns:1fr}}

.side{
  position:sticky;top:0;height:100vh;display:flex;flex-direction:column;
  border-right:1px solid var(--hair);padding:22px 16px;gap:6px;
  background:linear-gradient(180deg,var(--ink-2),var(--ink-1));
}
@media(max-width:900px){.side{position:static;height:auto;flex-direction:row;align-items:center;overflow-x:auto;padding:12px 16px}}
.side .brand{padding:6px 10px 18px;font-size:22px}
@media(max-width:900px){.side .brand{padding:0 12px 0 4px}}
.navitem{
  display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:var(--r-sm);
  color:var(--cream-2);font-size:14px;font-weight:480;cursor:pointer;border:1px solid transparent;
  transition:background .15s,color .15s,border-color .15s;white-space:nowrap;
}
.navitem svg{width:18px;height:18px;flex:none;opacity:.8}
.navitem:hover{background:rgba(244,241,234,.04);color:var(--cream)}
.navitem.on{background:var(--money-soft);color:var(--money);border-color:var(--money-line)}
.navitem.on svg{opacity:1}
.side .spacer{flex:1}
@media(max-width:900px){.side .spacer{display:none}}

/* account switcher */
.acct{margin-top:auto;border-top:1px solid var(--hair);padding-top:14px}
@media(max-width:900px){.acct{margin:0 0 0 auto;border:0;padding:0}}
.acct .lbl{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);padding:0 10px 8px}
@media(max-width:900px){.acct .lbl{display:none}}
.acct-pill{
  display:flex;align-items:center;gap:9px;width:100%;padding:8px 10px;border-radius:var(--r-sm);
  background:none;border:1px solid transparent;color:var(--cream-2);cursor:pointer;font-size:13px;text-align:left;
  transition:.15s;
}
.acct-pill:hover{background:rgba(244,241,234,.04)}
.acct-pill.on{border-color:var(--hair-2);background:rgba(244,241,234,.03)}
.acct-pill .ava{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;color:#04130C;font-weight:700;font-size:12px;flex:none}
.acct-pill .acct-name{font-weight:500;color:var(--cream);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acct-pill .badge{margin-left:auto;font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--money);font-style:normal}
.acct-pill.add{color:var(--muted);justify-content:flex-start;margin-top:4px}
.acct-pill.add:hover{color:var(--cream)}

/* ---------- MAIN / TOPBAR ---------- */
.main{min-width:0;display:flex;flex-direction:column}
.topbar{
  position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:18px 32px;border-bottom:1px solid var(--hair);
  background:linear-gradient(180deg,rgba(10,12,13,.92),rgba(10,12,13,.7));backdrop-filter:blur(12px);
}
@media(max-width:640px){.topbar{padding:14px 18px}}
.topbar h1{font-family:var(--serif);font-size:24px;letter-spacing:-.02em}
.topbar .sub{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.04em;margin-top:2px}
.status-dot{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--money);padding:6px 12px;border:1px solid var(--money-line);border-radius:var(--r-pill);background:var(--money-soft)}
.status-dot.dry{color:var(--muted);border-color:var(--hair);background:transparent}
.status-dot .d{width:7px;height:7px;border-radius:50%;background:currentColor;box-shadow:0 0 8px currentColor}

.view{padding:32px;max-width:1180px;width:100%}
@media(max-width:640px){.view{padding:22px 18px}}
.view[hidden]{display:none}

/* ---------- REVENUE OVERVIEW ---------- */
.rev-hero{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:30px}
.rev-hero .k{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.rev-hero .big{font-family:var(--serif);font-size:clamp(48px,8vw,92px);line-height:.95;color:var(--money);letter-spacing:-.03em;font-variant-numeric:tabular-nums;text-shadow:0 0 40px rgba(54,226,154,.3);margin-top:6px}
.rev-hero .big .cur{font-size:.5em;opacity:.8;vertical-align:.08em}
.rev-hero .ctx{font-size:14px;color:var(--muted);max-width:18em}
.rev-hero .ctx b{color:var(--money);font-family:var(--serif);font-size:18px}

.statgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:30px}
@media(max-width:820px){.statgrid{grid-template-columns:1fr 1fr}}
.statcard{padding:18px;border-radius:var(--r);border:1px solid var(--hair);background:linear-gradient(180deg,var(--ink-3),var(--ink-2))}
.statcard .label{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.statcard .v{font-family:var(--serif);font-size:30px;letter-spacing:-.02em;margin-top:10px;font-variant-numeric:tabular-nums}
.statcard .s{font-size:12px;color:var(--faint);margin-top:4px;font-family:var(--mono)}
.statcard.accent .v{color:var(--money)}

.panel-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:18px}
@media(max-width:900px){.panel-grid{grid-template-columns:1fr}}
.panel{padding:20px;border-radius:var(--r-lg);border:1px solid var(--hair);background:linear-gradient(180deg,var(--ink-2),var(--ink-1))}
.panel-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.panel-h .t{font-size:14px;font-weight:560}
.panel-h .m{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.04em}

/* per-automation attribution table */
.atable{width:100%;border-collapse:collapse;font-size:13.5px}
.atable th{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);text-align:right;font-weight:500;padding:0 8px 10px}
.atable th:first-child{text-align:left}
.atable td{padding:13px 8px;border-top:1px solid var(--hair);text-align:right;vertical-align:middle}
.atable td:first-child{text-align:left}
.atable .nm{color:var(--cream);font-weight:500}
.atable .kw{font-family:var(--mono);font-size:11px;color:var(--faint);display:block;margin-top:2px}
.atable .rev{font-family:var(--serif);font-size:17px;color:var(--money);letter-spacing:-.02em}
.atable .perdm{font-family:var(--mono);font-size:12px;color:var(--cream-2)}
.atable tr.row{cursor:pointer;transition:background .15s}
.atable tr.row:hover{background:var(--money-soft)}

/* 14-day activity chart */
.schart{display:flex;align-items:flex-end;gap:5px;height:120px;padding-top:8px}
.sbar{flex:1;display:flex;align-items:flex-end;height:100%}
.sbar i{display:block;width:100%;border-radius:3px 3px 0 0;background:linear-gradient(180deg,var(--money),rgba(54,226,154,.25));min-height:3px;transition:height .5s var(--ease)}
.sbar.dim i{background:var(--hair-2)}
.chart-x{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;color:var(--faint);margin-top:8px}

/* ---------- AUTOMATION BUILDER ---------- */
.builder-top{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.builder-top .acts{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.toolbtn{font-family:var(--sans);font-size:13px;color:var(--cream-2);background:none;border:1px solid var(--hair-2);border-radius:var(--r-pill);padding:9px 14px;cursor:pointer;transition:.15s}
.toolbtn:hover{border-color:var(--cream);color:var(--cream)}
.searchbox{display:flex;align-items:center;gap:8px;border:1px solid var(--hair-2);border-radius:var(--r-pill);padding:8px 14px;color:var(--muted)}
.searchbox input{background:none;border:0;color:var(--cream);font-size:13px;outline:none;width:150px;font-family:var(--sans)}
.saved-note{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--muted)}
.saved-note.unsaved{color:#E0B341}
.saved-note.ok{color:var(--money)}

.builder-grid{display:grid;grid-template-columns:1fr 360px;gap:24px;align-items:start}
@media(max-width:1040px){.builder-grid{grid-template-columns:1fr}}
.rules-col{display:flex;flex-direction:column;gap:16px}

/* rule card */
.dm-rule{border:1px solid var(--hair);border-radius:var(--r-lg);background:linear-gradient(180deg,var(--ink-3),var(--ink-2));padding:18px 18px 20px;transition:opacity .2s}
.dm-rule.off{opacity:.55}
.dm-rule-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.dm-rule-head .name{flex:1;font-family:var(--serif);font-size:18px}
.mini-x{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--muted);background:none;border:1px solid var(--hair);border-radius:var(--r-pill);padding:5px 10px;cursor:pointer;transition:.15s}
.mini-x:hover{color:var(--cream);border-color:var(--hair-2)}

/* toggle switch */
.switch{position:relative;display:inline-block;width:40px;height:23px;flex:none;cursor:pointer}
.switch input{position:absolute;opacity:0}
.switch .track{position:absolute;inset:0;background:var(--ink-4);border:1px solid var(--hair-2);border-radius:999px;transition:.2s}
.switch .track::after{content:"";position:absolute;top:2px;left:2px;width:17px;height:17px;border-radius:50%;background:var(--cream-2);transition:.2s}
.switch input:checked + .track{background:var(--money);border-color:var(--money)}
.switch input:checked + .track::after{transform:translateX(17px);background:#04130C}

.field{margin-top:14px}
.flabel{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.flabel em{font-style:normal;color:var(--faint);text-transform:none;letter-spacing:0;font-size:11px}
.in{
  width:100%;background:var(--ink-1);border:1px solid var(--hair-2);border-radius:var(--r-sm);
  color:var(--cream);font-family:var(--sans);font-size:14px;padding:10px 12px;outline:none;transition:border-color .15s;
}
.in:focus{border-color:var(--money)}
textarea.in{resize:vertical;line-height:1.5}
select.in{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%238C9491' stroke-width='2'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
.in.name{font-family:var(--serif);font-size:18px;padding:6px 10px;background:transparent;border-color:transparent}
.in.name:focus{border-color:var(--hair-2);background:var(--ink-1)}
.btn-row{display:grid;grid-template-columns:1fr 1.4fr auto;gap:8px;margin-bottom:8px}
.btn-row.single{grid-template-columns:1fr auto}
.idea-btn{font-family:var(--sans);font-size:12.5px;color:var(--money);background:var(--money-soft);border:1px solid var(--money-line);border-radius:var(--r-pill);padding:8px 13px;cursor:pointer;transition:.15s;margin-top:4px}
.idea-btn:hover{background:rgba(54,226,154,.18)}
.idea-btn.primary{background:var(--money);color:#04130C;font-weight:600;border-color:var(--money)}

.rule-stats{display:flex;gap:18px;font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.03em;padding:10px 0;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);margin-bottom:4px}
.rule-stats b{color:var(--cream);font-weight:500}
.rule-stats .rev b{color:var(--money)}
.rule-stats.muted{color:var(--faint)}

/* post picker */
.post-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.post-chip{display:flex;align-items:center;gap:7px;background:var(--ink-1);border:1px solid var(--hair-2);border-radius:var(--r-pill);padding:4px 6px 4px 4px;font-size:12px;color:var(--cream-2)}
.post-chip img{width:22px;height:22px;border-radius:5px;object-fit:cover}
.post-chip .ph{width:22px;height:22px;border-radius:5px;display:grid;place-items:center;background:var(--ink-4);color:var(--faint);font-size:11px}
.post-chip .px{background:none;border:0;color:var(--muted);cursor:pointer;font-size:13px;padding:0 2px}
.picker{display:grid;grid-template-columns:repeat(auto-fill,minmax(84px,1fr));gap:8px;margin:10px 0}
.pick{position:relative;border:1px solid var(--hair);border-radius:var(--r-sm);overflow:hidden;cursor:pointer;aspect-ratio:1;background:var(--ink-1)}
.pick img{width:100%;height:100%;object-fit:cover}
.pick .ph{width:100%;height:100%;display:grid;place-items:center;color:var(--faint)}
.pick .cap{position:absolute;left:0;right:0;bottom:0;font-size:9px;padding:3px 4px;background:linear-gradient(transparent,rgba(0,0,0,.8));color:var(--cream-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pick .tick{position:absolute;top:5px;right:5px;width:18px;height:18px;border-radius:50%;background:var(--money);color:#04130C;display:none;place-items:center;font-size:11px}
.pick.on{border-color:var(--money);box-shadow:0 0 0 1px var(--money)}
.pick.on .tick{display:grid}
.manual-add{display:flex;gap:8px;margin-top:8px}
.empty-note{font-size:12.5px;color:var(--faint);font-style:italic}

/* empty state */
.empty-state{text-align:center;padding:60px 20px;border:1px dashed var(--hair-2);border-radius:var(--r-lg)}
.empty-state .es-mark{width:46px;height:46px;border-radius:12px;margin:0 auto 18px;background:var(--money-soft);border:1px solid var(--money-line);display:grid;place-items:center;color:var(--money);font-size:20px}
.empty-state h3{font-family:var(--serif);font-size:22px;margin-bottom:8px}
.empty-state p{color:var(--muted);font-size:14px;max-width:30em;margin:0 auto 18px}

/* ---------- LIVE IG-DM PREVIEW (sticky) ---------- */
.preview-col{position:sticky;top:96px}
.preview-card{border:1px solid var(--hair);border-radius:var(--r-lg);background:linear-gradient(180deg,var(--ink-2),var(--ink-1));padding:18px;overflow:hidden}
.preview-card .ph-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.preview-card .ph-head .t{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.preview-note{font-size:11.5px;color:var(--faint);margin-top:14px;line-height:1.5;font-family:var(--mono);letter-spacing:.01em}

/* phone */
.phone{width:100%;max-width:300px;margin:0 auto;border-radius:30px;background:#000;padding:9px;box-shadow:0 30px 60px -25px rgba(0,0,0,.9),0 0 0 1px var(--hair-2)}
.phone .screen{background:#fff;border-radius:23px;overflow:hidden;color:#0a0a0a}
.ig-status{display:flex;align-items:center;justify-content:space-between;padding:8px 16px 4px;font-size:12px;font-weight:600;color:#000}
.ig-head{display:flex;align-items:center;gap:9px;padding:8px 14px;border-bottom:1px solid #efefef}
.ig-head .back{color:#222;font-size:20px}
.ig-head .av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#f58529,#dd2a7b,#8134af)}
.ig-head .who b{font-size:13px;color:#111;display:block;line-height:1.2}
.ig-head .who small{font-size:10px;color:#888}
.ig-body{padding:14px;min-height:230px;background:#fff;display:flex;flex-direction:column;gap:8px}
.ig-time{text-align:center;font-size:10px;color:#aaa;margin:4px 0}
.ig-time b{color:#555}
.ig-quote{align-self:flex-end;max-width:78%;background:#fff;border:1px solid #efefef;border-radius:16px 16px 4px 16px;padding:7px 11px}
.ig-quote .ql{font-size:9.5px;color:#999;margin-bottom:2px}
.ig-quote .qb{font-size:12.5px;color:#222}
.ig-msg{align-self:flex-start;max-width:82%;background:#f0f0f0;border-radius:16px 16px 16px 4px;padding:9px 12px;font-size:12.5px;color:#111;line-height:1.4;white-space:pre-wrap;word-break:break-word}
.ig-linkcard{align-self:flex-start;max-width:86%;border:1px solid #e8e8e8;border-radius:14px;overflow:hidden;margin-top:2px;width:100%}
.ig-linkcard .lc-btn{padding:11px;text-align:center;font-size:13px;font-weight:600;color:#0a0a0a;border-top:1px solid #efefef}
.ig-linkcard .lc-btn + .lc-btn{border-top:1px solid #efefef}
.ig-reply{align-self:flex-start;display:flex;align-items:center;gap:7px;margin-top:6px;font-size:11px;color:#888}
.ig-reply .rb{background:#f0f0f0;border-radius:12px;padding:5px 9px;color:#333;font-size:11.5px}

/* ---------- SETTINGS ---------- */
.set-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:760px){.set-grid{grid-template-columns:1fr}}
.set-card{padding:22px;border-radius:var(--r-lg);border:1px solid var(--hair);background:linear-gradient(180deg,var(--ink-2),var(--ink-1))}
.set-card .ico{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;margin-bottom:14px;background:var(--ink-4);border:1px solid var(--hair-2)}
.set-card h3{font-family:var(--serif);font-size:19px;margin-bottom:6px}
.set-card p{font-size:13.5px;color:var(--muted);margin:0 0 16px;line-height:1.5}
.set-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-top:1px solid var(--hair);font-size:13.5px}
.set-row .lbl{color:var(--cream-2)}
.set-row .val{font-family:var(--mono);font-size:12px;color:var(--cream)}
.pill-on{color:var(--money);font-family:var(--mono);font-size:11px;letter-spacing:.04em;display:inline-flex;align-items:center;gap:6px}
.pill-on .d{width:7px;height:7px;border-radius:50%;background:var(--money);box-shadow:0 0 8px var(--money)}
.pill-off{color:var(--muted);font-family:var(--mono);font-size:11px}

/* ---------- MODAL ---------- */
.modal{position:fixed;inset:0;z-index:100;display:grid;place-items:center;background:rgba(4,6,5,.7);backdrop-filter:blur(4px);padding:20px}
.modal.hidden{display:none}
.modal-card{width:min(440px,94vw);background:linear-gradient(180deg,var(--ink-3),var(--ink-2));border:1px solid var(--hair-2);border-radius:var(--r-lg);padding:26px;box-shadow:var(--shadow)}
.modal-card h3{font-family:var(--serif);font-size:22px;margin-bottom:8px}
.modal-card p{font-size:13.5px;color:var(--muted);margin:0 0 18px;line-height:1.5}
.modal-acts{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}

/* skeleton */
.skel{background:linear-gradient(90deg,var(--ink-2),var(--ink-3),var(--ink-2));background-size:200% 100%;animation:shimmer 1.3s infinite;border-radius:var(--r)}
@keyframes shimmer{to{background-position:-200% 0}}
.skel-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:30px}
.skel-stats .skel{height:96px}
.skel-rule{height:150px;margin-bottom:16px}

/* ---------- ONBOARDING ---------- */
.ob-wrap{max-width:560px;margin:0 auto;padding:60px 24px 80px}
.ob-steps{display:flex;flex-direction:column;gap:16px;margin-top:34px}
.ob-step{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:22px;border:1px solid var(--hair);border-radius:var(--r-lg);background:linear-gradient(180deg,var(--ink-3),var(--ink-2));transition:border-color .2s,opacity .2s}
.ob-step.done{border-color:var(--money-line)}
.ob-step.locked{opacity:.5}
.ob-num{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-family:var(--serif);font-size:18px;background:var(--ink-1);border:1px solid var(--hair-2);color:var(--cream)}
.ob-step.done .ob-num{background:var(--money);color:#04130C;border-color:var(--money)}
.ob-step h3{font-size:17px;font-weight:560;margin-bottom:5px}
.ob-step p{font-size:13.5px;color:var(--muted);margin:0 0 14px;line-height:1.5}
.ob-time{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:10px}
.btn-ig{--bg:#fff;--fg:#111;font-weight:560}
.btn-ig svg{width:18px;height:18px}
.ob-trust{text-align:center;margin-top:30px;font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.03em;line-height:1.8}
