/* ============================================================
   SCREENS — log flow, detail, analyse, settings, share, onboarding.
   ============================================================ */

/* ---------------- Overlay / modal ---------------- */
/* Overlays are visible by default — never gate visibility on an animation
   (capture/background tabs pause animations and would leave them hidden). */
.scrim {
  position: fixed; inset: 0; z-index: 60;
  background: color-mix(in oklab, var(--bg) 40%, #000 55%);
  backdrop-filter: blur(3px);
  display: flex; align-items: stretch; justify-content: flex-end;
}
.sheet {
  width: min(520px, 100%); height: 100%;
  background: color-mix(in oklab, var(--clay) 5%, var(--panel-2));
  border-left: var(--hair) solid var(--border); box-shadow: var(--shadow-pop);
  display: flex; flex-direction: column;
}
@media (prefers-reduced-motion: no-preference) {
  .sheet { animation: slideIn .26s cubic-bezier(.2,.8,.2,1); }
}
@keyframes slideIn { from { transform: translateX(28px); } to { transform: none; } }
.sheet-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px; border-bottom: var(--hair) solid var(--border); }
.sheet-head h2 { margin: 0; font-size: 16px; font-weight: 700; letter-spacing: -0.01em; }
.sheet-body { flex: 1; overflow-y: auto; padding: 22px; }
.sheet-body img { max-width: 100%; }
.sheet-foot { padding: 16px 22px; border-top: var(--hair) solid var(--border); display: flex; gap: 10px; align-items: center; }
.iconbtn { width: 30px; height: 30px; border-radius: var(--radius); border: var(--hair) solid var(--border); background: var(--panel-2); color: var(--muted); display: grid; place-items: center; cursor: pointer; transition: all .12s; }
.iconbtn:hover { color: var(--ink); border-color: var(--muted); }

/* steps */
.steps { display: flex; gap: 6px; padding: 0 22px 16px; }
.step-dot { flex: 1; height: 3px; border-radius: 2px; background: var(--border); transition: background .2s; }
.step-dot.done { background: var(--clay); }
.step-dot.cur { background: color-mix(in oklab, var(--clay) 60%, var(--border)); }

.field-label { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); margin-bottom: 10px; display: block; }
.seg { display: grid; gap: 8px; }
.seg.two { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); }
.seg.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.optbtn {
  padding: 15px; border-radius: var(--radius); border: var(--hair) solid var(--border);
  background: var(--panel-2); color: var(--ink-2); cursor: pointer; font-weight: 600; font-size: 14px;
  transition: all .12s; display: flex; flex-direction: column; align-items: center; gap: 4px; font-family: var(--font-sans);
  min-width: 0; overflow-wrap: anywhere; text-align: center;
}
.optbtn .om { font-family: var(--font-mono); font-size: 11px; color: var(--muted); font-weight: 500; }
.optbtn:hover { border-color: var(--muted); color: var(--ink); }
.optbtn.sel { border-color: var(--clay); background: var(--clay-bg); color: var(--ink); box-shadow: inset 0 0 0 1px var(--clay); }
.optbtn.sel.long { border-color: var(--long); box-shadow: inset 0 0 0 1px var(--long); background: var(--long-soft); }
.optbtn.sel.short { border-color: var(--short); box-shadow: inset 0 0 0 1px var(--short); background: var(--short-soft); }

/* pnl input */
.pnl-input { display: flex; align-items: center; gap: 10px; border: var(--hair) solid var(--border); border-radius: var(--radius); background: var(--inset); padding: 0 14px; transition: border-color .12s; }
.pnl-input:focus-within { border-color: var(--clay); }
.pnl-sign { display: flex; gap: 4px; }
.pnl-sign button { width: 34px; height: 34px; border-radius: var(--radius); border: var(--hair) solid var(--border); background: var(--panel-2); color: var(--muted); font-family: var(--font-mono); font-size: 18px; cursor: pointer; }
.pnl-sign button.on.plus { color: var(--long); border-color: var(--long); background: var(--long-soft); }
.pnl-sign button.on.minus { color: var(--short); border-color: var(--short); background: var(--short-soft); }
.pnl-input input { flex: 1; border: 0; background: none; outline: none; color: var(--ink); font-family: var(--font-mono); font-size: 22px; font-weight: 600; padding: 14px 0; }
.pnl-input .cur { font-family: var(--font-mono); font-size: 18px; color: var(--muted); }

/* upload zone */
.drop { border: 1.5px dashed var(--border); border-radius: var(--radius-lg); background: var(--inset); padding: 30px; text-align: center; color: var(--muted); cursor: pointer; transition: all .14s; }
.drop:hover { border-color: var(--clay); color: var(--ink); background: var(--clay-bg); }
.drop .ph {
  background-image: repeating-linear-gradient(135deg, transparent 0 10px, color-mix(in oklab, var(--muted) 18%, transparent) 10px 11px);
  border-radius: var(--radius); height: 120px; display: grid; place-items: center; margin-bottom: 14px; border: var(--hair) solid var(--border);
}
.drop .ph .lab { font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; color: var(--muted); }
.shot-preview { position: relative; border-radius: var(--radius-lg); overflow: hidden; border: var(--hair) solid var(--border); }
.shot-preview .bar { background-image: repeating-linear-gradient(135deg, var(--inset) 0 14px, var(--panel-2) 14px 28px); height: 170px; display:grid; place-items:center; }
.shot-preview .rm { position: absolute; top: 8px; right: 8px; }

/* multi-screenshot grid (log trade) */
.shot-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.shot-thumb { position: relative; border-radius: var(--radius); overflow: hidden; border: var(--hair) solid var(--border); aspect-ratio: 16 / 10; background: var(--inset); }
.shot-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.shot-thumb .bar { width: 100%; height: 100%; background-image: repeating-linear-gradient(135deg, var(--inset) 0 10px, var(--panel-2) 10px 20px); }
.shot-rm { position: absolute; top: 4px; right: 4px; width: 20px; height: 20px; border-radius: 4px; border: 0; background: #000000aa; color: #fff; display: grid; place-items: center; cursor: pointer; }
.shot-add { aspect-ratio: 16 / 10; border: 1.5px dashed var(--border); border-radius: var(--radius); background: var(--inset); color: var(--muted); cursor: pointer; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; font-size: 11px; font-family: var(--font-sans); transition: all .12s; }
.shot-add:hover { border-color: var(--clay); color: var(--ink); background: var(--clay-bg); }
.shot-maxhint { margin-top: 8px; font-family: var(--font-mono); font-size: 11px; color: var(--faint); }
.shot-err { margin-top: 6px; font-size: 12px; color: var(--short); line-height: 1.4; }

/* screenshot gallery (trade detail) */
.detail-shots { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
.detail-shot-item { border-radius: var(--radius-lg); overflow: hidden; border: var(--hair) solid var(--border); display: block; aspect-ratio: 16 / 10; }
.detail-shot-item img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* counter */
.confcount { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 14px; }
.confcount .big { font-family: var(--font-mono); font-size: 28px; font-weight: 600; letter-spacing: -.02em; white-space: nowrap; }
.confcount .warnflag { font-family: var(--font-mono); font-size: 11px; color: var(--warn); background: var(--warn-soft); padding: 4px 9px; border-radius: 3px; }
.conf-grid { display: flex; flex-wrap: wrap; gap: 8px; }

textarea.note {
  width: 100%; border: var(--hair) solid var(--border); border-radius: var(--radius); background: var(--inset);
  color: var(--ink); font-family: var(--font-sans); font-size: 14px; line-height: 1.55; padding: 14px; resize: vertical; min-height: 130px; outline: none;
}
textarea.note:focus { border-color: var(--clay); }

/* ---------------- Trade detail ---------------- */
.detail-pnl { font-family: var(--font-mono); font-size: 40px; font-weight: 600; letter-spacing: -.03em; line-height: 1; }
.detail-row { display: flex; justify-content: space-between; align-items: center; padding: 13px 0; border-bottom: var(--hair) solid var(--border-2); }
.detail-row:last-child { border-bottom: 0; }
.detail-k { font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
.detail-v { font-size: 14px; font-weight: 600; }
.detail-shot { background-image: repeating-linear-gradient(135deg, var(--inset) 0 16px, var(--panel-2) 16px 32px); height: 200px; border-radius: var(--radius-lg); border: var(--hair) solid var(--border); display:grid; place-items:center; }
.detail-note { background: var(--inset); border-left: 2px solid var(--clay); border-radius: 0 var(--radius) var(--radius) 0; padding: 14px 16px; font-size: 14px; line-height: 1.6; color: var(--ink-2); font-style: italic; }

/* ---------------- Analyse ---------------- */
.an-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.an-grid .span2 { grid-column: span 2; }
.ring-wrap { display: flex; align-items: center; gap: 26px; }
.ring-wrap svg { flex: 0 0 128px; width: 128px; height: 128px; }
.ring-legend { font-size: 13px; color: var(--muted); line-height: 1.6; }
.ring-legend b { color: var(--ink); font-weight: 700; }
.legend-row { display: flex; gap: 16px; justify-content: center; margin-top: 12px; font-family: var(--font-mono); font-size: 11px; color: var(--muted); }
.legend-row .sw { width: 8px; height: 8px; border-radius: 2px; display: inline-block; margin-right: 6px; transform: translateY(0); }

.bar-row { display: grid; grid-template-columns: 54px 1fr 96px; align-items: center; gap: 12px; padding: 9px 0; }
.bar-row .lab { font-family: var(--font-mono); font-size: 13px; color: var(--ink-2); }
.bar-track { height: 26px; background: var(--inset); border-radius: 3px; overflow: hidden; position: relative; }
.bar-fill { height: 100%; border-radius: 3px; display: flex; align-items: center; transition: width .5s cubic-bezier(.2,.8,.2,1); }
.bar-row .val { font-family: var(--font-mono); font-size: 12.5px; color: var(--muted); text-align: right; }

.combo { display: flex; align-items: center; gap: 14px; padding: 12px 0; border-bottom: var(--hair) solid var(--border-2); }
.combo:last-child { border: 0; }
.combo-rank { font-family: var(--font-mono); font-size: 12px; color: var(--clay); width: 22px; font-weight: 600; }
.combo-names { flex: 1; display: flex; flex-wrap: wrap; gap: 4px; }
.combo-wr { font-family: var(--font-mono); font-size: 18px; font-weight: 600; }
.combo-n { font-family: var(--font-mono); font-size: 11px; color: var(--muted); }

.freq-row { display: grid; grid-template-columns: 132px 1fr 70px; align-items: center; gap: 12px; padding: 7px 0; }
.freq-row .lab { font-family: var(--font-mono); font-size: 12.5px; }
.freq-track { height: 8px; background: var(--inset); border-radius: 99px; overflow: hidden; }
.freq-fill { height: 100%; background: var(--clay); border-radius: 99px; transition: width .5s; }
.freq-row .val { font-family: var(--font-mono); font-size: 11.5px; color: var(--muted); text-align: right; }

/* equity */
.eq-wrap { position: relative; }
.eq-legend { display: flex; gap: 18px; justify-content: center; margin-top: 12px; font-family: var(--font-mono); font-size: 11px; color: var(--muted); }

/* ---------------- Settings ---------------- */
.set-list { display: flex; flex-direction: column; }
.set-conf { display: flex; align-items: center; gap: 12px; padding: 11px 0; border-bottom: var(--hair) solid var(--border-2); }
.set-conf { border-radius: var(--radius); transition: opacity .12s, box-shadow .12s, background .12s; }
.set-conf.dragging { opacity: .35; background: var(--inset); box-shadow: var(--shadow-pop); }
.set-conf .grip { display: grid; place-items: center; width: 24px; height: 30px; color: var(--faint); cursor: grab; touch-action: none; flex-shrink: 0; }
.set-conf .grip:hover { color: var(--muted); }
.set-conf .grip:active { cursor: grabbing; }
.set-conf .nm { flex: 1; font-family: var(--font-mono); font-size: 13.5px; }
.set-conf .nm-edit { flex: 1; min-width: 0; font-family: var(--font-mono); font-size: 13.5px; color: var(--ink); background: none; border: 0; border-bottom: 1px solid transparent; padding: 3px 0; outline: none; transition: border-color .12s; }
.set-conf .nm-edit:hover { border-bottom-color: var(--border); }
.set-conf .nm-edit:focus { border-bottom-color: var(--clay); }
.set-conf .uses { font-family: var(--font-mono); font-size: 11px; color: var(--muted); white-space: nowrap; }
.addconf { display: flex; gap: 8px; margin-top: 14px; }
.addconf input { flex: 1; min-width: 0; border: var(--hair) solid var(--border); border-radius: var(--radius); background: var(--inset); color: var(--ink); padding: 10px 12px; font-family: var(--font-mono); font-size: 13px; outline: none; }
.addconf input:focus { border-color: var(--clay); }
.set-section { display: grid; gap: 18px; }
.kv { display: flex; justify-content: space-between; align-items: center; padding: 13px 0; border-bottom: var(--hair) solid var(--border-2); }
.kv:last-child { border: 0; }
.kv .k { font-size: 13.5px; font-weight: 600; }
.kv .kdesc { font-size: 12px; color: var(--muted); margin-top: 2px; }

/* ---------------- Share card ---------------- */
.share-scrim { position: fixed; inset: 0; z-index: 70; background: #000a; backdrop-filter: blur(4px); display: grid; place-items: center; padding: 24px; }
.share-card {
  width: 440px; border-radius: 16px; overflow: hidden; position: relative;
  background: #18120b; /* flat, solid — no gradients, no grid */
  border: 1px solid #3a3122;
  box-shadow: 0 34px 90px -24px #000d, inset 0 0 0 1px #ffffff08;
}
.share-card .sc-grid, .share-card .sc-glow { display: none; }

/* light variant — clean warm paper, solid */
.share-card.light {
  background: #faf7f0;
  border-color: #e6dfcd;
  box-shadow: 0 30px 70px -26px #6b573330, inset 0 0 0 1px #00000008;
}
.share-card.light .sc-pad { color: #2a2118; }
.share-card.light .sc-meta, .share-card.light .sc-stat .k, .share-card.light .sc-wr-pct, .share-card.light .sc-cmp-k, .share-card.light .sc-cmp-v { color: #8a7e68; }
.share-card.light .sc-chip { background: #00000009; color: #5c5240; }
.share-card.light .sc-foot { border-top-color: #00000014; }
.share-card.light .sc-cmp-bar { background: #00000010; }
.share-card.light .sc-cmp-bar i.off { background: #c0b59c; }
.share-card.light .sc-wr { color: #2f9e63; }
.share-card.light .sc-spark-net.up { color: #2f9e63; } .share-card.light .sc-spark-net.down { color: #c4452f; }
.share-card.light .sc-glow { background: radial-gradient(closest-side, #c47b5222, transparent); }

/* card toolbar (dark/light + language) above the card — not in the exported PNG */
.sc-toolbar { display: flex; align-items: center; justify-content: center; gap: 8px; margin-bottom: 14px; }
/* segmented theme toggle */
.sc-seg { display: inline-flex; background: var(--inset); border: var(--hair) solid var(--border); border-radius: 99px; padding: 3px; }
.sc-seg-btn { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: 11px; letter-spacing: .02em; color: var(--muted); background: none; border: 0; border-radius: 99px; padding: 6px 13px; cursor: pointer; transition: color .12s, background .12s; }
.sc-seg-btn:hover { color: var(--ink); }
.sc-seg-btn.on { color: var(--ink); background: var(--panel); box-shadow: 0 1px 2px #0000001f; }
.sc-seg-btn.on svg { color: var(--clay); }
/* language picker — matches the segmented control */
.sc-langwrap { position: relative; display: inline-flex; align-items: center; }
.sc-langwrap > svg { position: absolute; left: 11px; color: var(--muted); pointer-events: none; }
.sc-lang { font-family: var(--font-mono); font-size: 11px; letter-spacing: .02em; color: var(--ink); background: var(--inset); border: var(--hair) solid var(--border); border-radius: 99px; padding: 7px 30px 7px 30px; cursor: pointer; transition: border-color .12s; }
.sc-lang:hover { border-color: var(--muted); }
[dir="rtl"] .sc-langwrap > svg { left: auto; right: 11px; }

/* native select chevron sits flush against the right edge — replace it with a
   custom chevron that has breathing room. Applies to every app dropdown. */
.sc-lang, .fc-acctsel select, .pa-f select, .led-acct {
  -webkit-appearance: none; appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a8170' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat: no-repeat; background-position: right 11px center; background-size: 11px;
  padding-right: 30px;
}
[dir="rtl"] .sc-lang, [dir="rtl"] .fc-acctsel select, [dir="rtl"] .pa-f select, [dir="rtl"] .led-acct {
  background-position: left 11px center; padding-right: 12px; padding-left: 30px;
}
/* sc-lang has a left globe icon, so keep room on both sides */
[dir="rtl"] .sc-lang { padding-right: 30px; padding-left: 30px; }
.sc-pad { position: relative; padding: 28px; color: #efe9da; }
.sc-head { display: flex; align-items: center; justify-content: space-between; }
.sc-mark { display: flex; align-items: center; gap: 9px; }
.sc-mark .m { width: 24px; height: 24px; border-radius: 6px; background: var(--clay); display: grid; place-items: center; font-family: var(--font-mono); font-weight: 700; color: #fff; font-size: 13px; }
.sc-meta { font-family: var(--font-mono); font-size: 11px; color: #b8ac95; letter-spacing: .04em; }
.sc-wr { font-family: var(--font-mono); font-size: 64px; font-weight: 600; letter-spacing: -.03em; line-height: 1; color: #37b074; }
.sc-combo-names { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 10px; }
.sc-chip { font-family: var(--font-mono); font-size: 11.5px; padding: 3px 8px; border-radius: 3px; background: #ffffff10; color: #d8cdb6; }
.sc-foot { display: flex; justify-content: space-between; align-items: flex-end; gap: 8px; margin-top: 22px; padding-top: 16px; border-top: 1px solid #ffffff14; }
.sc-stat .k { font-family: var(--font-mono); font-size: 9px; letter-spacing: .1em; text-transform: uppercase; color: #b8ac95; white-space: nowrap; }
.sc-stat .v { font-family: var(--font-mono); font-size: 18px; font-weight: 600; margin-top: 5px; white-space: nowrap; }
.sc-actions { display: flex; gap: 10px; margin-top: 18px; }

/* share card: depth glow, hero %, equity sparkline, on/off-plan compare */
.share-card .sc-glow { position: absolute; top: -40%; right: -25%; width: 70%; height: 90%; background: radial-gradient(closest-side, #c47b5238, transparent); pointer-events: none; }
.sc-wr { display: flex; align-items: baseline; }
.sc-wr-pct { font-size: 30px; margin-left: 2px; color: #b8ac95; }
.sc-spark-wrap { margin-top: 22px; }
.sc-spark-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 6px; }
.sc-spark-net { font-family: var(--font-mono); font-size: 13px; font-weight: 700; }
.sc-spark-net.up { color: #37b074; } .sc-spark-net.down { color: #d2553f; }
.sc-spark { display: block; width: 100%; height: 58px; }
.sc-cmp { margin-top: 20px; display: flex; flex-direction: column; gap: 9px; }
.sc-cmp-row { display: grid; grid-template-columns: 92px 1fr 44px; align-items: center; gap: 12px; }
.sc-cmp-k { font-family: var(--font-mono); font-size: 11px; color: #b8ac95; letter-spacing: .02em; }
.sc-cmp-bar { height: 8px; background: #ffffff12; border-radius: 99px; overflow: hidden; }
.sc-cmp-bar i { display: block; height: 100%; border-radius: 99px; }
.sc-cmp-bar i.on { background: #37b074; }
.sc-cmp-bar i.off { background: #6f6450; }
.sc-cmp-v { font-family: var(--font-mono); font-size: 14px; font-weight: 700; text-align: right; color: #b8ac95; }
.sc-cmp-v.up { color: #37b074; }

/* ---------------- Onboarding ---------------- */
.onb { position: fixed; inset: 0; z-index: 80; background: var(--bg); display: grid; place-items: center; padding: 24px; }
.onb-card { width: min(540px, 100%); }
.onb-kicker { display: flex; align-items: center; justify-content: space-between; margin-bottom: 26px; }
.onb-q { font-size: 27px; font-weight: 800; letter-spacing: -0.025em; line-height: 1.1; margin: 0 0 6px; }
.onb-sub { color: var(--muted); font-size: 14px; margin-bottom: 26px; }
.onb-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 28px; }
.onb-steps { display: flex; gap: 5px; }
.onb-steps .d { width: 22px; height: 3px; border-radius: 2px; background: var(--border); }
.onb-steps .d.on { background: var(--clay); }
.onb-steps .d.done { background: color-mix(in oklab, var(--clay) 55%, var(--border)); }

/* responsive: collapse rail */
@media (max-width: 920px) {
  .app { grid-template-columns: 1fr; }
  .rail { display: none; }
  .an-grid { grid-template-columns: 1fr; }
  .an-grid .span2 { grid-column: span 1; }
  .strip { grid-template-columns: repeat(2, 1fr); }
}

/* ---------------- Prop firms ---------------- */
.pf-read { margin-bottom: 22px; }
.pf-read-line { font-size: 17px; font-weight: 600; letter-spacing: -0.01em; margin-top: 8px; line-height: 1.4; }
.pf-read-line.muted { font-size: 13.5px; font-weight: 500; color: var(--muted); margin-top: 4px; }
.pf-logmore { margin-top: 12px; font-family: var(--font-mono); font-size: 11.5px; color: var(--clay); }

.pf-top { background: var(--panel); border: var(--hair) solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: 22px; position: relative; overflow: hidden; }
.pf-top::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 3px; background: var(--clay); }
.pf-top-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.pf-top-name { font-size: 26px; font-weight: 800; letter-spacing: -0.025em; margin: 6px 0 0; }
.pf-score { text-align: right; white-space: nowrap; }
.pf-score-n { font-size: 30px; font-weight: 700; color: var(--clay); letter-spacing: -0.02em; }
.pf-score-k { display: block; font-family: var(--font-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }
.pf-top-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; margin-top: 20px; }
.pf-sub { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin-bottom: 10px; }
.pf-reasons { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 9px; }
.pf-reasons li { display: flex; gap: 8px; font-size: 13.5px; line-height: 1.45; align-items: flex-start; }
.pf-reasons li svg { flex-shrink: 0; margin-top: 2px; }
.pf-reasons.ok li svg { color: var(--long); }
.pf-reasons.warn li svg { color: var(--warn); }
.pf-rulebox { display: flex; flex-direction: column; gap: 10px; }
.pf-rule { display: flex; flex-direction: column; gap: 2px; padding-bottom: 9px; border-bottom: var(--hair) solid var(--border-2); }
.pf-rule:last-child { border-bottom: 0; }
.pf-rule-k { font-family: var(--font-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); }
.pf-rule-v { font-size: 13px; line-height: 1.4; color: var(--ink-2); }
.pf-visit { width: 100%; margin-top: 20px; }

.pf-sec-title { font-size: 13px; font-weight: 700; letter-spacing: -0.01em; margin: 30px 0 14px; }
.pf-others { display: flex; flex-direction: column; gap: 8px; }
.pf-other { display: grid; grid-template-columns: 160px 1fr 48px 16px; align-items: center; gap: 14px; padding: 13px 14px; background: var(--panel); border: var(--hair) solid var(--border-2); border-radius: 8px; box-shadow: var(--shadow); color: var(--ink); cursor: pointer; transition: border-color .12s, transform .08s; }
.pf-other:hover { border-color: var(--muted); transform: translateY(-1px); }
.pf-other:hover svg { color: var(--clay); }
.pf-other svg { color: var(--faint); }
.pf-other-name { font-weight: 600; font-size: 14px; }
.pf-bar { height: 7px; background: var(--inset); border-radius: 99px; overflow: hidden; }
.pf-bar-fill { display: block; height: 100%; background: var(--clay); border-radius: 99px; }
.pf-other-score { font-size: 13px; font-weight: 600; color: var(--muted); text-align: right; }

.pf-table-wrap { overflow-x: auto; border: var(--hair) solid var(--border); border-radius: var(--radius-lg); }
.pf-table { border-collapse: collapse; width: 100%; min-width: 720px; font-size: 12.5px; }
.pf-table th, .pf-table td { text-align: left; padding: 12px 14px; border-bottom: var(--hair) solid var(--border-2); vertical-align: top; line-height: 1.45; }
.pf-table thead th { background: var(--panel-2); font-weight: 700; font-size: 12.5px; white-space: nowrap; position: sticky; top: 0; }
.pf-table tbody th { font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); white-space: nowrap; background: var(--panel); }
.pf-table td { color: var(--ink-2); }
.pf-table tr:last-child th, .pf-table tr:last-child td { border-bottom: 0; }

.pf-disclaimer { margin-top: 22px; font-size: 12px; line-height: 1.6; color: var(--muted); padding: 14px 16px; background: var(--inset); border: var(--hair) solid var(--border-2); border-radius: var(--radius); }

@media (max-width: 920px) {
  .pf-top-grid { grid-template-columns: 1fr; gap: 18px; }
  .pf-other { grid-template-columns: 1fr 60px 40px 14px; gap: 10px; }
  .pf-other .pf-bar { display: none; }
}

/* prop firms: how-calculated + all-firms */
.pf-how { background: var(--inset); border: var(--hair) solid var(--border-2); border-radius: var(--radius-lg); padding: 20px; margin-top: 30px; }
.pf-how-intro { font-size: 13.5px; line-height: 1.6; color: var(--ink-2); margin: 0 0 16px; max-width: 640px; }
.pf-nums { display: flex; flex-wrap: wrap; gap: 8px; }
.pf-numchip { font-family: var(--font-mono); font-size: 12px; padding: 6px 10px; border-radius: var(--radius); background: var(--panel); border: var(--hair) solid var(--border-2); color: var(--ink-2); }
.pf-weights { margin: 10px 0 0; padding-left: 18px; display: flex; flex-direction: column; gap: 7px; }
.pf-weights li { font-size: 12.5px; line-height: 1.55; color: var(--muted); }

.pf-firms { display: flex; flex-direction: column; gap: 10px; }
.pf-firm { background: var(--panel); border: var(--hair) solid var(--border-2); border-radius: 10px; padding: 15px 16px; box-shadow: var(--shadow); }
.pf-firm.top { border-color: color-mix(in oklab, var(--clay) 45%, transparent); box-shadow: var(--shadow), inset 0 0 0 1px color-mix(in oklab, var(--clay) 22%, transparent); }
.pf-firm-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.pf-firm-name { display: inline-flex; align-items: center; gap: 6px; font-weight: 700; font-size: 15px; color: var(--ink); letter-spacing: -0.01em; }
.pf-firm-name svg { color: var(--faint); }
.pf-firm-name:hover svg { color: var(--clay); }
.pf-firm-score { font-size: 16px; font-weight: 700; color: var(--clay); }
.pf-firm .pf-bar { display: block; margin: 10px 0 12px; }
.pf-firm-reasons { display: flex; flex-wrap: wrap; gap: 6px; }
.pf-tag { display: inline-flex; align-items: center; gap: 5px; font-size: 11.5px; line-height: 1.3; padding: 4px 9px; border-radius: 99px; border: var(--hair) solid var(--border-2); background: var(--inset); color: var(--ink-2); }
.pf-tag svg { flex-shrink: 0; }
.pf-tag.ok svg { color: var(--long); }
.pf-tag.warn svg { color: var(--warn); }

/* prop firms: point-weighted reason tags + baseline */
.pf-tag b { font-size: 10.5px; font-weight: 700; }
.pf-tag.ok b { color: var(--long); }
.pf-tag.warn { border-color: color-mix(in oklab, var(--short) 30%, var(--border-2)); }
.pf-tag.warn b { color: var(--short); }
.pf-tag.note { color: var(--muted); }
.pf-tag.note svg { color: var(--faint); }
.pf-tag.base { color: var(--muted); }
.pf-tag.base b { color: var(--ink-2); }
.pf-how-intro.pf-base { font-size: 12.5px; color: var(--muted); border-left: 2px solid var(--clay); padding-left: 12px; margin-bottom: 16px; }

/* prop firms: per-firm account-type (plans) table */
.pf-plans-wrap { margin-top: 14px; overflow-x: auto; border: var(--hair) solid var(--border-2); border-radius: var(--radius); }
.pf-plans { border-collapse: collapse; width: 100%; min-width: 680px; font-size: 12px; }
.pf-plans th, .pf-plans td { text-align: left; padding: 9px 11px; border-bottom: var(--hair) solid var(--border-2); vertical-align: top; line-height: 1.4; }
.pf-plans thead th { background: var(--inset); font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); white-space: nowrap; }
.pf-plans td { color: var(--ink-2); }
.pf-plans .pf-plan-name { font-weight: 600; color: var(--ink); white-space: nowrap; }
.pf-plans tr:last-child td { border-bottom: 0; }

/* prop firms: best-plan highlight + plan match */
.pf-top-plan { font-size: 13px; color: var(--ink-2); margin-top: 8px; }
.pf-top-plan b { color: var(--clay); font-weight: 700; }
.pf-plan-match { color: var(--clay); font-weight: 700; white-space: nowrap; }
.pf-plans tr.best td { background: var(--clay-bg); }
.pf-plans tr.best .pf-plan-name { color: var(--clay); }

/* prop firms: red-folder news calendar */
.pf-news { margin-bottom: 28px; }
.pf-news-head { margin-bottom: 14px; }
.news-dot { display: inline-block; width: 9px; height: 9px; border-radius: 2px; background: var(--short); margin-right: 6px; vertical-align: middle; box-shadow: 0 0 0 3px var(--short-soft); }
.pf-news-sub { font-size: 12.5px; color: var(--muted); margin-top: 6px; line-height: 1.5; max-width: 640px; }
.pf-news-msg { font-size: 13px; color: var(--muted); padding: 16px; background: var(--inset); border: var(--hair) solid var(--border-2); border-radius: var(--radius); }
.news-week { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; }
.news-day { background: var(--panel); border: var(--hair) solid var(--border-2); border-radius: 10px; box-shadow: var(--shadow); padding: 12px 14px; }
.news-day-h { font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--clay); font-weight: 600; padding-bottom: 9px; margin-bottom: 9px; border-bottom: var(--hair) solid var(--border-2); }
.news-ev { display: grid; grid-template-columns: 42px auto 1fr; align-items: baseline; gap: 8px; padding: 7px 0; border-bottom: var(--hair) solid var(--border-2); }
.news-ev:last-child { border-bottom: 0; padding-bottom: 0; }
.news-time { font-size: 11.5px; color: var(--muted); }
.news-cur { font-family: var(--font-mono); font-size: 10px; font-weight: 700; color: var(--ink-2); background: var(--inset); border: var(--hair) solid var(--border-2); border-radius: 3px; padding: 1px 5px; align-self: center; }
.news-title { font-size: 12.5px; line-height: 1.35; color: var(--ink); }
.news-fp { grid-column: 2 / -1; font-size: 10.5px; color: var(--faint); margin-top: 2px; }
.news-dash { margin-top: 30px; }

/* prop firms: calm layout (slim rec + expandable list + tucked-away how) */
.pf-top-why { display: flex; align-items: flex-start; gap: 8px; font-size: 14px; line-height: 1.45; margin-top: 16px; color: var(--ink-2); }
.pf-top-why svg { color: var(--long); flex-shrink: 0; margin-top: 2px; }
.pf-top-meta { font-family: var(--font-mono); font-size: 12px; color: var(--muted); margin-top: 12px; }
.pf-list { display: flex; flex-direction: column; gap: 8px; }
.pf-item { background: var(--panel); border: var(--hair) solid var(--border-2); border-radius: 10px; box-shadow: var(--shadow); overflow: hidden; }
.pf-item.open { border-color: color-mix(in oklab, var(--clay) 35%, var(--border-2)); }
.pf-item-head { display: grid; grid-template-columns: 1fr auto 84px 16px; align-items: center; gap: 14px; width: 100%; background: none; border: 0; cursor: pointer; color: var(--ink); padding: 14px 16px; text-align: left; }
.pf-item-head svg { color: var(--faint); }
.pf-item-name { font-weight: 700; font-size: 14.5px; }
.pf-item-score { font-family: var(--font-mono); font-weight: 700; color: var(--clay); text-align: right; }
.pf-item-lead { padding: 0 16px 13px; font-size: 12.5px; color: var(--muted); line-height: 1.45; }
.pf-item-body { padding: 14px 16px 16px; border-top: var(--hair) solid var(--border-2); }
.pf-item-visit { display: inline-flex; align-items: center; gap: 6px; margin-top: 12px; font-family: var(--font-mono); font-size: 12px; color: var(--clay); }
.pf-howtoggle { display: flex; align-items: center; gap: 8px; width: 100%; margin-top: 26px; padding: 13px 16px; background: var(--inset); border: var(--hair) solid var(--border-2); border-radius: var(--radius); color: var(--ink-2); font-family: var(--font-sans); font-size: 13px; font-weight: 600; cursor: pointer; }
.pf-howtoggle:hover { color: var(--ink); border-color: var(--muted); }
.pf-howtoggle svg { color: var(--muted); }
.pf-how { margin-top: 8px; }
@media (max-width: 920px) { .pf-item-head { grid-template-columns: 1fr auto 14px; gap: 10px; } .pf-item-head .pf-bar { display: none; } }

/* prop match: calm fit word (replaces bare %) + per-firm details */
.pf-fit { font-family: var(--font-mono); font-size: 10.5px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; padding: 4px 10px; border-radius: 99px; white-space: nowrap; }
.pf-fit.great { color: var(--long); background: color-mix(in oklab, var(--long) 15%, transparent); }
.pf-fit.good { color: var(--clay); background: var(--clay-bg); }
.pf-fit.ok { color: var(--ink-2); background: var(--inset); }
.pf-fit.weak { color: var(--muted); background: var(--inset); }
.pf-top .pf-fit { display: inline-block; margin-top: 14px; }
.pf-detail-h { font-size: 13.5px; color: var(--ink-2); margin-bottom: 12px; }
.pf-detail-h b { color: var(--ink); font-weight: 700; }
.pf-how-mini { display: inline-flex; align-items: center; gap: 6px; margin: 6px 0 0; padding: 0; background: none; border: 0; color: var(--clay); font-family: var(--font-mono); font-size: 11.5px; cursor: pointer; }
.pa-adv { display: inline-flex; align-items: center; gap: 6px; margin-top: 12px; padding: 0; background: none; border: 0; color: var(--clay); font-family: var(--font-mono); font-size: 11.5px; cursor: pointer; }

/* prop firms: "what you need" bridge + per-firm needs checklist */
.pf-needs { margin: 0 0 20px; padding: 16px 18px; background: var(--inset); border: var(--hair) solid var(--border-2); border-left: 2px solid var(--clay); border-radius: var(--radius); }
.pf-needs-list { list-style: none; margin: 10px 0 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.pf-needs-list li { display: flex; gap: 9px; align-items: flex-start; font-size: 13.5px; line-height: 1.45; color: var(--ink); }
.pf-needs-list li svg { color: var(--clay); flex-shrink: 0; margin-top: 3px; }
.pf-top-met { font-family: var(--font-mono); font-size: 11px; letter-spacing: .04em; color: var(--long); font-weight: 700; margin-top: 16px; }
.pf-need-check { list-style: none; margin: 10px 0 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.pf-need-check li { display: flex; gap: 8px; align-items: flex-start; font-size: 13px; line-height: 1.4; color: var(--ink-2); }
.pf-need-check li svg { flex-shrink: 0; margin-top: 2px; }
.pf-need-check li.ok svg { color: var(--long); }
.pf-need-check li.no { color: var(--muted); }
.pf-need-check li.no svg { color: var(--short); }
.pf-need-check.sm { margin: 0 0 14px; }
.pf-need-check.sm li { font-size: 12.5px; }
.pf-list-explain { font-size: 12.5px; line-height: 1.55; color: var(--muted); margin: -6px 0 14px; max-width: 620px; }
.pf-item-met { display: inline-block; font-family: var(--font-mono); font-size: 11px; font-weight: 700; color: var(--long); margin-right: 8px; }

/* prop firms: paywall (no subscription) + empty (no trades) */
.pf-pay-card { background: var(--panel); border: var(--hair) solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow-pop); padding: 28px; position: relative; overflow: hidden; }
.pf-pay-card::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 3px; background: var(--clay); }
.pf-pay-badge { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--clay); font-weight: 700; }
.pf-pay-badge svg { color: var(--clay); }
.pf-pay-title { font-size: 25px; font-weight: 800; letter-spacing: -0.025em; margin: 12px 0 0; }
.pf-pay-lede { font-size: 14.5px; line-height: 1.55; color: var(--ink-2); margin: 10px 0 0; max-width: 460px; }
.pf-pay-price { display: flex; align-items: baseline; gap: 6px; margin: 20px 0 4px; }
.pf-pay-amt { font-size: 38px; font-weight: 700; color: var(--clay); letter-spacing: -0.02em; }
.pf-pay-per { font-family: var(--font-mono); font-size: 12px; color: var(--muted); }
.pf-pay-list { list-style: none; margin: 18px 0 0; padding: 0; display: flex; flex-direction: column; gap: 11px; }
.pf-pay-list li { display: flex; gap: 9px; align-items: flex-start; font-size: 13.5px; line-height: 1.45; color: var(--ink); }
.pf-pay-list li svg { color: var(--long); flex-shrink: 0; margin-top: 2px; }
.pf-pay-cta { width: 100%; margin-top: 22px; }
.pf-pay-soon { margin-top: 12px; font-size: 12.5px; line-height: 1.5; color: var(--ink-2); padding: 11px 13px; background: var(--clay-bg); border: var(--hair) solid color-mix(in oklab, var(--clay) 30%, var(--border-2)); border-radius: var(--radius); }
.pf-pay-free { margin-top: 14px; font-size: 12px; color: var(--muted); text-align: center; }
.pf-empty-card { background: var(--panel); border: var(--hair) solid var(--border-2); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: 30px 28px; text-align: center; }
.pf-empty-ico { width: 52px; height: 52px; margin: 0 auto 14px; display: flex; align-items: center; justify-content: center; border-radius: 50%; background: var(--inset); border: var(--hair) solid var(--border-2); color: var(--clay); }
.pf-empty-title { font-size: 18px; font-weight: 700; letter-spacing: -0.015em; margin: 0; }
.pf-empty-p { font-size: 13.5px; line-height: 1.6; color: var(--muted); margin: 10px auto 0; max-width: 400px; }

/* nav: premium lock badge (rail + mobile) */
.nav-lock { margin-left: auto; display: inline-flex; color: var(--faint); }
.nav-item:hover .nav-lock, .nav-item.active .nav-lock { color: var(--clay); }
.mnav-ico { position: relative; display: inline-flex; }
.mnav-lock { position: absolute; top: -5px; right: -9px; display: inline-flex; align-items: center; justify-content: center; width: 14px; height: 14px; border-radius: 50%; background: var(--clay); color: #fff; box-shadow: 0 0 0 2px var(--panel); }
.mnav-lock svg { color: #fff; }

/* prop match: Match / My accounts tab switch */
.pf-tabs { display: inline-flex; gap: 4px; padding: 4px; background: var(--inset); border: var(--hair) solid var(--border-2); border-radius: 99px; margin-bottom: 22px; }
.pf-tab { font-family: var(--font-sans); font-size: 13px; font-weight: 600; padding: 7px 16px; border-radius: 99px; border: 0; background: none; color: var(--muted); cursor: pointer; white-space: nowrap; }
.pf-tab.on { background: var(--panel); color: var(--ink); box-shadow: var(--shadow); }

/* prop match: funded-account tracker + portfolio */
.pa-port { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 10px; margin-bottom: 18px; }
.pa-port-cell { background: var(--panel); border: var(--hair) solid var(--border-2); border-radius: 10px; box-shadow: var(--shadow); padding: 12px 14px; display: flex; flex-direction: column; gap: 4px; }
.pa-port-k { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); }
.pa-port-v { font-size: 19px; font-weight: 700; letter-spacing: -0.02em; }
.pa-port-v.pos { color: var(--long); } .pa-port-v.neg { color: var(--short); }
.pa-first { text-align: center; }
.pa-list { display: flex; flex-direction: column; gap: 12px; }
.pa-card { background: var(--panel); border: var(--hair) solid var(--border-2); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: 18px; border-left: 3px solid var(--border); }
.pa-card.st-safe { border-left-color: var(--long); }
.pa-card.st-caution { border-left-color: var(--warn); }
.pa-card.st-breached { border-left-color: var(--short); }
.pa-card.st-target { border-left-color: var(--clay); }
.pa-card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 16px; }
.pa-card-name { font-size: 15.5px; font-weight: 700; letter-spacing: -0.01em; }
.pa-card-sub { font-family: var(--font-mono); font-size: 11px; color: var(--muted); margin-top: 4px; }
.pa-phase { display: inline-block; vertical-align: middle; margin-left: 6px; font-family: var(--font-mono); font-size: 9px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: 2px 7px; border-radius: 99px; }
.pa-phase.funded { color: var(--long); background: color-mix(in oklab, var(--long) 14%, transparent); }
.pa-phase.eval { color: var(--warn); background: color-mix(in oklab, var(--warn) 15%, transparent); }
.pa-phase-seg { margin-bottom: 12px; }
.pa-phase-btn { flex-shrink: 0; height: 36px; padding: 0 12px; border-radius: var(--radius); border: var(--hair) solid var(--border-2); background: var(--inset); color: var(--ink-2); font-family: var(--font-mono); font-size: 11px; cursor: pointer; white-space: nowrap; }
.pa-phase-btn:hover { color: var(--clay); border-color: var(--clay); }

/* prop match: cashflow ledger (payouts in / eval costs out) */
.led-add { background: var(--panel); border: var(--hair) solid var(--border-2); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: 16px; margin-bottom: 16px; }
.led-kind { max-width: 280px; margin-bottom: 12px; }
.led-add-row { display: flex; flex-wrap: wrap; align-items: stretch; gap: 10px; }
.led-amt { display: flex; align-items: center; gap: 4px; flex: 1; min-width: 120px; padding: 0 12px; border-radius: var(--radius); border: var(--hair) solid var(--border); background: var(--inset); }
.led-amt .cur { color: var(--muted); font-family: var(--font-mono); font-size: 14px; }
.led-amt input { flex: 1; min-width: 0; border: 0; background: none; color: var(--ink); font-family: var(--font-sans); font-size: 15px; padding: 10px 0; }
.led-amt input:focus, .led-amt input:focus-visible { outline: none; }
.led-amt:focus-within { border-color: var(--clay); outline: 2px solid var(--clay); outline-offset: 2px; }
.led-acct { padding: 0 12px; border-radius: var(--radius); border: var(--hair) solid var(--border); background: var(--inset); color: var(--ink); font-family: var(--font-sans); font-size: 13.5px; min-width: 120px; }
.led-list { display: flex; flex-direction: column; gap: 8px; }
.led-row { display: flex; align-items: center; gap: 12px; background: var(--panel); border: var(--hair) solid var(--border-2); border-radius: 10px; box-shadow: var(--shadow); padding: 12px 14px; }
.led-dot { flex-shrink: 0; width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; }
.led-dot.payout { color: var(--long); background: color-mix(in oklab, var(--long) 14%, transparent); }
.led-dot.cost { color: var(--short); background: color-mix(in oklab, var(--short) 14%, transparent); }
.led-row-main { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.led-row-amt { font-size: 15px; font-weight: 700; }
.led-row-sub { font-family: var(--font-mono); font-size: 11px; color: var(--muted); }
.led-filter { display: inline-flex; gap: 4px; padding: 4px; background: var(--inset); border: var(--hair) solid var(--border-2); border-radius: 99px; margin-bottom: 16px; }
.led-fbtn { font-family: var(--font-sans); font-size: 12.5px; font-weight: 600; padding: 6px 14px; border-radius: 99px; border: 0; background: none; color: var(--muted); cursor: pointer; }
.led-fbtn.on { background: var(--panel); color: var(--ink); box-shadow: var(--shadow); }
.led-days { display: flex; flex-direction: column; gap: 16px; }
.led-day-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; padding: 0 2px 8px; margin-bottom: 8px; border-bottom: var(--hair) solid var(--border-2); }
.led-day-date { font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); font-weight: 600; }
.led-day-total { font-size: 13.5px; font-weight: 700; }
.led-day .led-row { margin-bottom: 8px; }
.led-day .led-row:last-child { margin-bottom: 0; }
.led-nofilter { font-size: 13px; color: var(--muted); padding: 18px; background: var(--inset); border: var(--hair) solid var(--border-2); border-radius: var(--radius); text-align: center; }
.pa-chip { font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 4px 9px; border-radius: 99px; white-space: nowrap; }
.pa-chip.safe { color: var(--long); background: color-mix(in oklab, var(--long) 14%, transparent); }
.pa-chip.caution { color: var(--warn); background: color-mix(in oklab, var(--warn) 16%, transparent); }
.pa-chip.breached { color: var(--short); background: color-mix(in oklab, var(--short) 16%, transparent); }
.pa-chip.target { color: var(--clay); background: var(--clay-bg); }
.pa-metric { margin-bottom: 14px; }
.pa-metric-row { display: flex; justify-content: space-between; align-items: baseline; font-size: 13px; color: var(--ink-2); margin-bottom: 7px; }
.pa-metric-row .mono { font-weight: 700; color: var(--ink); }
.pa-bar { height: 8px; background: var(--inset); border-radius: 99px; overflow: hidden; }
.pa-bar-fill { display: block; height: 100%; border-radius: 99px; background: var(--long); }
.pa-bar-fill.caution { background: var(--warn); }
.pa-bar-fill.breached { background: var(--short); }
.pa-bar-fill.target { background: var(--clay); }
.pa-bar-fill.tgt { background: var(--clay); }
.pa-metric-note { font-family: var(--font-mono); font-size: 10.5px; color: var(--muted); margin-top: 6px; }
.pa-cons { display: flex; gap: 7px; align-items: flex-start; font-size: 12.5px; line-height: 1.45; color: var(--ink-2); background: var(--inset); border: var(--hair) solid var(--border-2); border-radius: var(--radius); padding: 10px 12px; margin-bottom: 14px; }
.pa-cons svg { color: var(--warn); flex-shrink: 0; margin-top: 3px; }
.pa-edit { display: flex; align-items: flex-end; gap: 12px; padding-top: 14px; border-top: var(--hair) solid var(--border-2); }
.pa-f { display: flex; flex-direction: column; gap: 5px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); flex: 1; min-width: 0; }
.pa-f input, .pa-f select { font-family: var(--font-sans); font-size: 13.5px; text-transform: none; letter-spacing: 0; padding: 8px 10px; border-radius: var(--radius); border: var(--hair) solid var(--border); background: var(--inset); color: var(--ink); width: 100%; min-width: 0; }
.pa-del { flex-shrink: 0; width: 36px; height: 36px; border-radius: var(--radius); border: var(--hair) solid var(--border-2); background: var(--inset); color: var(--muted); cursor: pointer; display: grid; place-items: center; }
.pa-del:hover { color: var(--short); border-color: var(--short); }
.pa-add { display: inline-flex; align-items: center; gap: 8px; margin-top: 12px; padding: 11px 18px; border-radius: var(--radius); border: 1px dashed var(--border); background: none; color: var(--ink-2); font-family: var(--font-sans); font-size: 13px; font-weight: 600; cursor: pointer; }
.pa-add:hover { color: var(--clay); border-color: var(--clay); }
.pa-form { background: var(--panel); border: var(--hair) solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: 18px; }
.pa-form-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 12px; }
.pa-form-hint { font-size: 12px; line-height: 1.5; color: var(--muted); margin: 14px 0 0; }
.pa-form-foot { display: flex; gap: 8px; margin-top: 14px; }
@media (max-width: 560px) { .pa-edit { flex-wrap: wrap; } }

/* compatibility page: independence disclaimer */
.pf-pay-legal { margin-top: 14px; font-size: 10.5px; line-height: 1.55; color: var(--muted); }
.pf-disclaimer b { color: var(--ink-2); font-weight: 600; }

/* forecast (Pro €7): projection + patterns */
.fc-acctsel { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; font-size: 13px; color: var(--ink-2); }
.fc-acctsel select { padding: 8px 12px; border-radius: var(--radius); border: var(--hair) solid var(--border); background: var(--inset); color: var(--ink); font-family: var(--font-sans); font-size: 13.5px; }
.fc-chartwrap { background: var(--panel); border: var(--hair) solid var(--border-2); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: 16px 18px; }
.fc-chart-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 8px; }
.fc-band { font-family: var(--font-mono); font-size: 10.5px; color: var(--muted); }
.fc-fan { display: block; width: 100%; height: 150px; }
.fc-note { margin-top: 14px; font-size: 12.5px; line-height: 1.5; color: var(--muted); }
.fc-leaks { display: flex; flex-direction: column; gap: 10px; }
.fc-leak { display: flex; gap: 11px; align-items: flex-start; background: var(--panel); border: var(--hair) solid var(--border-2); border-radius: 10px; box-shadow: var(--shadow); padding: 14px 16px; border-left: 3px solid var(--border); }
.fc-leak.warn { border-left-color: var(--warn); }
.fc-leak.good { border-left-color: var(--long); }
.fc-leak-ico { flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%; display: grid; place-items: center; }
.fc-leak.warn .fc-leak-ico { color: var(--warn); background: color-mix(in oklab, var(--warn) 15%, transparent); }
.fc-leak.good .fc-leak-ico { color: var(--long); background: color-mix(in oklab, var(--long) 14%, transparent); }
.fc-leak-txt { font-size: 13.5px; line-height: 1.5; color: var(--ink); padding-top: 4px; }
.pf-pay-card.pro7::before { background: linear-gradient(90deg, var(--clay), color-mix(in oklab, var(--clay) 50%, #d3a44a)); }

/* Pro: goal input, insight blocks, grades, two-line legend */
.fc-basis { font-size: 12px; line-height: 1.5; color: var(--muted); background: var(--inset); border: var(--hair) solid var(--border-2); border-radius: var(--radius); padding: 11px 14px; margin-bottom: 20px; }
.fc-goal-input { width: 130px; padding: 8px 12px; border-radius: var(--radius); border: var(--hair) solid var(--border); background: var(--inset); color: var(--ink); font-size: 13.5px; }
.fc-block { margin-top: 18px; background: var(--panel); border: var(--hair) solid var(--border-2); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: 16px 18px; }
.fc-block-h { display: flex; align-items: center; gap: 9px; font-size: 13px; font-weight: 700; letter-spacing: -0.01em; margin-bottom: 8px; }
.fc-block-h svg { color: var(--clay); }
.fc-block-p { font-size: 13.5px; line-height: 1.55; color: var(--ink-2); margin: 0; }
.fc-block-p b { font-weight: 700; }
.fc-cons-rows { display: flex; flex-direction: column; gap: 7px; margin-top: 12px; }
.fc-cons-row { display: flex; align-items: center; justify-content: space-between; font-size: 12.5px; padding: 8px 11px; background: var(--inset); border: var(--hair) solid var(--border-2); border-radius: 8px; }
.fc-cons-row .pos { color: var(--long); font-weight: 600; } .fc-cons-row .neg { color: var(--short); font-weight: 600; }
.fc-legend2 { font-family: var(--font-mono); font-size: 10.5px; color: var(--muted); display: inline-flex; align-items: center; }
.fc-legend2 i { display: inline-block; width: 14px; height: 0; border-top: 2px solid var(--muted); margin-right: 5px; vertical-align: middle; }
.fc-legend2 i.dash { border-top-style: dashed; }
.fc-legend2 i.clay { border-top-color: var(--clay); border-top-width: 2.5px; }
.fc-grades { display: flex; flex-direction: column; gap: 8px; }
.fc-grade { display: grid; grid-template-columns: 20px 1fr 26px auto; align-items: center; gap: 10px; }
.fc-grade-let { font-family: var(--font-mono); font-weight: 700; font-size: 13px; text-align: center; color: var(--muted); }
.fc-grade-let.pos { color: var(--long); } .fc-grade-let.neg { color: var(--short); } .fc-grade-let.warn { color: var(--warn); }
.fc-grade-bar { height: 8px; background: var(--inset); border-radius: 99px; overflow: hidden; }
.fc-grade-bar i { display: block; height: 100%; border-radius: 99px; background: var(--muted); }
.fc-grade-bar i.pos { background: var(--long); } .fc-grade-bar i.neg { background: var(--short); } .fc-grade-bar i.warn { background: var(--warn); }
.fc-grade-n { font-family: var(--font-mono); font-size: 12px; font-weight: 600; text-align: right; }
.fc-grade-lab { font-size: 11.5px; color: var(--muted); white-space: nowrap; }

/* prop accounts: auto-derived balance from tagged trades */
.pa-balrow { display: flex; align-items: flex-end; justify-content: space-between; gap: 12px; margin-bottom: 14px; padding-bottom: 14px; border-bottom: var(--hair) solid var(--border-2); }
.pa-balk { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); }
.pa-balv { font-size: 22px; font-weight: 700; letter-spacing: -0.02em; margin-top: 3px; }
.pa-balauto { font-family: var(--font-mono); font-size: 10px; color: var(--muted); text-align: right; }
.pa-edit-auto { align-items: center; }
.pa-auto-hint { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; color: var(--muted); }
.pa-auto-hint svg { color: var(--clay); }

/* day view: trades · accounts subline */
.dv-meta { font-size: 11.5px; color: var(--muted); margin-top: 6px; letter-spacing: .02em; }
