/* ============================================================================
   ybank — Member portal skin ("Trust Teal").
   Hand-written, dependency-free. Loaded ONLY by App/Views/layouts/portal.php,
   AFTER theme.css, and fully scoped to `.pt-shell` so it never affects the
   admin/platform realms. Dark mode = body.pt-dark (portal-local, not the global
   theme). No third-party CSS, fonts, or icon libraries.
   ========================================================================== */

.pt-shell{
  /* light tokens */
  --pt-brand:#0d7d6e; --pt-brand-dark:#0a5f54; --pt-brand-soft:#e3f4f1;
  --pt-accent:#b8810f; --pt-accent-soft:#fdf0d9;
  --pt-bg:#f4f7f6; --pt-surface:#ffffff; --pt-surface-2:#eef3f2;
  --pt-text:#0f1b18; --pt-muted:#5b6b66; --pt-faint:#8aa39c;
  --pt-border:#e3eae8; --pt-cr:#0d7d6e; --pt-dr:#b4474e;
  --pt-danger:#b4474e; --pt-danger-soft:#fbe9ea;
  --pt-radius:16px; --pt-radius-sm:10px;
  --pt-shadow:0 1px 2px rgba(16,40,34,.04), 0 8px 24px rgba(16,40,34,.06);
  --pt-shadow-lg:0 12px 40px rgba(10,60,52,.18);
  --pt-hero:linear-gradient(135deg,#0f8a78 0%,#0a5f54 100%);

  background:var(--pt-bg); color:var(--pt-text);
  min-height:100vh; display:flex; flex-direction:column;
  font-variant-numeric:tabular-nums;
}
body.pt-dark .pt-shell{
  --pt-brand:#2bb9a6; --pt-brand-dark:#1d8c7d; --pt-brand-soft:#0f2d29;
  --pt-accent:#f6b545; --pt-accent-soft:#3a2c12;
  --pt-bg:#0b1412; --pt-surface:#11201d; --pt-surface-2:#16302b;
  --pt-text:#e6efec; --pt-muted:#9fb4ae; --pt-faint:#6f8780;
  --pt-border:#1f322e; --pt-cr:#46d3bd; --pt-dr:#f08a90;
  --pt-danger:#f08a90; --pt-danger-soft:#3a1d1f;
  --pt-shadow:0 1px 2px rgba(0,0,0,.4), 0 8px 24px rgba(0,0,0,.35);
  --pt-shadow-lg:0 12px 40px rgba(0,0,0,.5);
  --pt-hero:linear-gradient(135deg,#0f8a78 0%,#063f38 100%);
}
body.pt-dark{background:#0b1412;}

.pt-shell *{box-sizing:border-box}
.pt-shell .mono{font-variant-numeric:tabular-nums}
.pt-ico{display:inline-flex;width:1.25em;height:1.25em}
.pt-ico svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

/* ---- top bar ---- */
.pt-topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:10px;
  padding:10px 16px;background:color-mix(in srgb,var(--pt-surface) 90%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--pt-border)}
.pt-brand{display:flex;align-items:center;gap:9px;text-decoration:none;color:var(--pt-text);font-weight:700}
.pt-brand .pt-logo{width:30px;height:30px;border-radius:9px;background:var(--pt-hero);color:#fff;
  display:grid;place-items:center;font-weight:800;box-shadow:var(--pt-shadow)}
.pt-brand small{display:block;font-size:11px;font-weight:500;color:var(--pt-faint)}
.pt-spacer{flex:1}
.pt-seg{display:inline-flex;background:var(--pt-surface-2);border:1px solid var(--pt-border);border-radius:999px;padding:2px}
.pt-seg a{text-decoration:none;color:var(--pt-muted);font-size:12px;padding:4px 9px;border-radius:999px;line-height:1.3}
.pt-seg a.on{background:var(--pt-surface);color:var(--pt-brand);font-weight:700;box-shadow:var(--pt-shadow)}
.pt-iconbtn{width:36px;height:36px;border-radius:10px;border:1px solid var(--pt-border);background:var(--pt-surface);
  color:var(--pt-text);cursor:pointer;display:grid;place-items:center;padding:0}
.pt-logout-form{display:inline-flex}
.pt-logout{border:0;background:none;color:var(--pt-dr);font:inherit;font-size:13px;cursor:pointer;font-weight:600}
.pt-avatar{width:34px;height:34px;border-radius:50%;background:var(--pt-brand-soft);color:var(--pt-brand);
  display:grid;place-items:center;font-weight:700;border:1px solid var(--pt-border);font-size:13px}

/* ---- layout ---- */
.pt-body{flex:1;display:block;width:100%}
.pt-flash{max-width:760px;margin:0 auto;padding:12px 16px 0}
.pt-alert{margin-bottom:8px;padding:11px 14px;border-radius:var(--pt-radius-sm);font-size:13.5px;border:1px solid}
.pt-alert--success{background:var(--pt-brand-soft);color:var(--pt-brand-dark);border-color:transparent}
.pt-alert--error{background:var(--pt-danger-soft);color:var(--pt-danger);border-color:transparent}
.pt-alert--info,.pt-alert--warning{background:var(--pt-accent-soft);color:var(--pt-accent);border-color:transparent}
.pt-main{max-width:760px;margin:0 auto;padding:16px 16px 100px;width:100%}

@media(min-width:880px){
  .pt-body{max-width:1060px;margin:0 auto;display:grid;grid-template-columns:240px 1fr;gap:8px;align-items:start}
  .pt-sidebar{display:flex !important}
  .pt-bottomnav{display:none !important}
  .pt-main{max-width:none;padding-bottom:40px}
  .pt-flash{max-width:none}
}

/* ---- desktop sidebar ---- */
.pt-sidebar{display:none;flex-direction:column;gap:3px;padding:18px 12px;position:sticky;top:58px}
.pt-sidebar a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:11px;color:var(--pt-muted);
  text-decoration:none;font-weight:600;font-size:14px}
.pt-sidebar a:hover{background:var(--pt-surface-2);color:var(--pt-text)}
.pt-sidebar a.on{background:var(--pt-brand-soft);color:var(--pt-brand)}
.pt-sidebar .pt-ico{width:20px;height:20px}

/* ---- greeting ---- */
.pt-greet{margin:4px 2px 14px}
.pt-greet h1{font-size:21px;margin:0;font-weight:750}
.pt-greet .sub{color:var(--pt-faint);font-size:13px;margin-top:2px}

/* ---- hero ---- */
.pt-hero{background:var(--pt-hero);color:#fff;border-radius:var(--pt-radius);padding:18px 20px;
  box-shadow:var(--pt-shadow-lg);position:relative;overflow:hidden}
.pt-hero::after{content:"";position:absolute;right:-40px;top:-40px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.08)}
.pt-hero .cap{font-size:12.5px;opacity:.85}
.pt-hero .amt{font-size:31px;font-weight:800;margin:4px 0 2px;letter-spacing:-.02em}
.pt-hero .asof{font-size:11.5px;opacity:.8}
.pt-hero .row{display:flex;gap:22px;margin-top:14px;flex-wrap:wrap}
.pt-hero .mini .k{font-size:11px;opacity:.82}
.pt-hero .mini .v{font-size:15px;font-weight:700}

/* ---- quick actions ---- */
.pt-qa{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin:16px 0}
.pt-qa a{text-decoration:none;background:var(--pt-surface);border:1px solid var(--pt-border);border-radius:14px;
  padding:11px 4px 9px;display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--pt-text);box-shadow:var(--pt-shadow)}
.pt-qa .bub{width:38px;height:38px;border-radius:11px;background:var(--pt-brand-soft);color:var(--pt-brand);display:grid;place-items:center}
.pt-qa .bub .pt-ico{width:19px;height:19px}
.pt-qa .lbl{font-size:11px;color:var(--pt-muted);text-align:center;line-height:1.2}

/* ---- sections + cards ---- */
.pt-section{margin-top:22px}
.pt-section-head{display:flex;align-items:center;justify-content:space-between;margin:0 2px 10px}
.pt-section-head h2{font-size:15px;margin:0}
.pt-section-head a{font-size:12.5px;color:var(--pt-brand);text-decoration:none;font-weight:600}
.pt-stack{display:flex;flex-direction:column;gap:10px}
.pt-card{background:var(--pt-surface);border:1px solid var(--pt-border);border-radius:var(--pt-radius);box-shadow:var(--pt-shadow)}

.pt-acct{display:flex;align-items:center;gap:13px;padding:14px 16px;text-decoration:none;color:inherit}
.pt-acct .ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex:none;background:var(--pt-brand-soft);color:var(--pt-brand)}
.pt-acct .ic--fd{background:var(--pt-accent-soft);color:var(--pt-accent)}
.pt-acct .ic .pt-ico{width:20px;height:20px}
.pt-acct .grow{flex:1;min-width:0}
.pt-acct .t{font-weight:650;font-size:14.5px}
.pt-acct .s{font-size:12.5px;color:var(--pt-faint)}
.pt-acct .amt{font-weight:750;text-align:right;white-space:nowrap}
.pt-acct .avail{font-size:11.5px;color:var(--pt-faint);text-align:right}
.pt-acct .chev{color:var(--pt-faint)}

/* ---- loan card ---- */
.pt-loan{padding:15px 16px;text-decoration:none;color:inherit;display:block}
.pt-loan .top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.pt-loan .t{font-weight:650}
.pt-loan .s{font-size:12.5px;color:var(--pt-faint)}
.pt-loan .os{text-align:right;white-space:nowrap}
.pt-loan .os .k{font-size:11px;color:var(--pt-faint)}
.pt-loan .os .v{font-weight:750}
.pt-bar{height:8px;border-radius:999px;background:var(--pt-surface-2);margin:12px 0 8px;overflow:hidden}
.pt-bar>span{display:block;height:100%;border-radius:999px;background:var(--pt-brand)}
.pt-loan .foot{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:12.5px;color:var(--pt-muted)}
.pt-chip{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:650;padding:3px 9px;border-radius:999px;white-space:nowrap}
.pt-chip--due{background:var(--pt-accent-soft);color:var(--pt-accent)}
.pt-chip--over{background:var(--pt-danger-soft);color:var(--pt-danger)}
.pt-chip--ok{background:var(--pt-brand-soft);color:var(--pt-brand)}

/* ---- transactions ---- */
.pt-dayhdr{font-size:11.5px;color:var(--pt-faint);font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:13px 16px 6px}
.pt-txn{display:flex;align-items:center;gap:12px;padding:11px 16px;border-top:1px solid var(--pt-border)}
.pt-txn:first-of-type{border-top:0}
.pt-txn .ic{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;flex:none}
.pt-txn .ic-cr{background:var(--pt-brand-soft);color:var(--pt-cr)}
.pt-txn .ic-dr{background:var(--pt-danger-soft);color:var(--pt-dr)}
.pt-txn .ic .pt-ico{width:16px;height:16px}
.pt-txn .grow{flex:1;min-width:0}
.pt-txn .d{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pt-txn .m{font-size:12px;color:var(--pt-faint)}
.pt-txn .a{font-weight:700}
.pt-txn .a--cr{color:var(--pt-cr)} .pt-txn .a--dr{color:var(--pt-dr)}

.pt-empty{padding:34px 16px;text-align:center;color:var(--pt-faint);font-size:13.5px}

/* ---- bottom nav (mobile) ---- */
.pt-bottomnav{position:fixed;bottom:0;inset-inline:0;z-index:30;display:flex;padding:6px 4px;
  padding-bottom:calc(6px + env(safe-area-inset-bottom));
  background:color-mix(in srgb,var(--pt-surface) 94%,transparent);backdrop-filter:blur(10px);border-top:1px solid var(--pt-border)}
.pt-bottomnav a,.pt-bottomnav button{flex:1;border:0;background:none;cursor:pointer;text-decoration:none;
  display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 2px;color:var(--pt-faint);font:inherit}
.pt-bottomnav .pt-ico{width:22px;height:22px}
.pt-bottomnav .lbl{font-size:10.5px;font-weight:600}
.pt-bottomnav a.on,.pt-bottomnav button.on{color:var(--pt-brand)}

/* ---- More sheet ---- */
.pt-sheet-bg{position:fixed;inset:0;background:rgba(8,20,17,.45);z-index:40;opacity:0;visibility:hidden;transition:.2s}
.pt-sheet-bg.open{opacity:1;visibility:visible}
.pt-sheet{position:fixed;inset-inline:0;bottom:0;z-index:41;background:var(--pt-surface);border-radius:20px 20px 0 0;
  padding:8px 12px calc(16px + env(safe-area-inset-bottom));box-shadow:var(--pt-shadow-lg);
  transform:translateY(102%);transition:transform .25s ease;max-width:760px;margin:0 auto}
.pt-sheet.open{transform:translateY(0)}
.pt-sheet .grip{width:40px;height:4px;border-radius:999px;background:var(--pt-border);margin:6px auto 10px}
.pt-sheet h3{margin:0 6px 8px;font-size:13px;color:var(--pt-faint);text-transform:uppercase;letter-spacing:.05em}
.pt-sheet a{display:flex;align-items:center;gap:12px;padding:12px 10px;border-radius:12px;text-decoration:none;color:var(--pt-text);font-weight:600}
.pt-sheet a:hover{background:var(--pt-surface-2)}
.pt-sheet a .ic{width:36px;height:36px;border-radius:10px;background:var(--pt-brand-soft);color:var(--pt-brand);display:grid;place-items:center;flex:none}
.pt-sheet a .ic .pt-ico{width:18px;height:18px}
.pt-sheet a .s{font-size:12px;color:var(--pt-faint);font-weight:400}
@media(min-width:880px){.pt-sheet,.pt-sheet-bg{display:none}}

@media(prefers-reduced-motion:reduce){.pt-sheet,.pt-sheet-bg{transition:none}}

/* ===========================================================================
   Shared components used across the inner screens (CSP-clean: no inline style).
   ========================================================================== */

/* skip link */
.pt-skip{position:absolute;left:-9999px;top:auto}
.pt-skip:focus{left:8px;top:8px;z-index:60;background:var(--pt-brand);color:#fff;padding:8px 12px;border-radius:8px;font-size:13px}
.pt-sheet a .s{display:block}

/* page head + breadcrumb */
.pt-pagehead{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin:2px 2px 16px}
.pt-pagehead h1{font-size:20px;margin:0;font-weight:750}
.pt-pagehead .sub{color:var(--pt-faint);font-size:13px;margin-top:3px}
.pt-crumb{font-size:13px;color:var(--pt-faint);margin:0 2px 12px}
.pt-crumb a{color:var(--pt-brand);text-decoration:none}
.pt-crumb a:hover{text-decoration:underline}
.pt-crumb .sep{margin:0 6px}
.pt-crumb .cur{color:var(--pt-text);font-weight:600}
.pt-link{color:var(--pt-brand);text-decoration:underline}
.pt-mb{margin-bottom:14px}
.pt-mt{margin-top:12px}
.pt-center{text-align:center;margin-top:8px}
.pt-pre{white-space:pre-wrap;margin:8px 0 0;font-size:14px}

/* ticket conversation messages */
.pt-msg{border:1px solid var(--pt-border);background:var(--pt-surface-2);border-radius:12px;padding:11px 13px;margin-bottom:10px}
.pt-msg:last-child{margin-bottom:0}
.pt-msg--staff{background:var(--pt-brand-soft);border-color:transparent}
.pt-msg .hd{display:flex;justify-content:space-between;font-size:11.5px;color:var(--pt-faint)}
.pt-msg .hd .who{font-weight:700;color:var(--pt-text)}
.pt-msg .pt-pre{margin-top:4px}

/* buttons */
.pt-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font:inherit;font-size:14px;font-weight:650;
  padding:10px 16px;border-radius:11px;border:1px solid transparent;cursor:pointer;text-decoration:none;line-height:1.1}
.pt-btn--primary{background:var(--pt-brand);color:#fff}
.pt-btn--primary:hover{background:var(--pt-brand-dark)}
.pt-btn--secondary{background:var(--pt-surface);color:var(--pt-text);border-color:var(--pt-border)}
.pt-btn--secondary:hover{background:var(--pt-surface-2)}
.pt-btn--danger{background:var(--pt-danger);color:#fff}
.pt-btn--ghost{background:none;color:var(--pt-brand);padding-inline:6px}
.pt-btn--block{display:flex;width:100%}
.pt-btn--sm{padding:7px 12px;font-size:13px;border-radius:9px}
.pt-btnrow{display:flex;gap:10px;flex-wrap:wrap}

/* forms */
.pt-form{display:flex;flex-direction:column;gap:14px}
.pt-grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:540px){.pt-grid2{grid-template-columns:1fr}}
.pt-field{display:block;min-width:0}
.pt-field.col2{grid-column:1 / -1}
.pt-label{display:block;font-size:12.5px;font-weight:600;color:var(--pt-muted);margin-bottom:5px}
.pt-input,.pt-select,.pt-textarea{width:100%;background:var(--pt-surface);color:var(--pt-text);border:1px solid var(--pt-border);
  border-radius:11px;padding:10px 12px;font:inherit;font-size:14.5px}
.pt-input,.pt-textarea{-webkit-appearance:none;appearance:none}
.pt-textarea{min-height:96px;resize:vertical}
.pt-input:focus,.pt-select:focus,.pt-textarea:focus{outline:none;border-color:var(--pt-brand);box-shadow:0 0 0 3px var(--pt-brand-soft)}
.pt-hint{font-size:12px;color:var(--pt-faint);margin-top:5px}
.pt-check{display:flex;align-items:flex-start;gap:9px;font-size:13.5px;color:var(--pt-text)}
.pt-check input{margin-top:2px}
/* selectable option cards (e.g. part-payment restructure strategy) */
.pt-opts{display:grid;gap:8px;margin:4px 0 2px}
.pt-opt{display:flex;align-items:flex-start;gap:10px;padding:11px 13px;border:1px solid var(--pt-border);
  border-radius:12px;background:var(--pt-surface);cursor:pointer}
.pt-opt input{margin-top:3px}
.pt-opt .t{font-weight:600;font-size:13.5px}
.pt-opt .d{font-size:12px;color:var(--pt-faint);margin-top:1px}
.pt-opt:has(input:checked){border-color:var(--pt-brand);background:var(--pt-brand-soft)}
.pt-grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media(max-width:540px){.pt-grid3{grid-template-columns:1fr}}
.pt-subform{background:var(--pt-surface-2);border:1px solid var(--pt-border);border-radius:12px;padding:14px;margin-top:10px}
summary.pt-sum{cursor:pointer;color:var(--pt-brand);font-weight:600;font-size:13.5px;list-style:none}
summary.pt-sum::-webkit-details-marker{display:none}

/* profile header */
.pt-profilehead{text-align:center;padding:20px 16px}
.pt-profilehead .pic{width:64px;height:64px;border-radius:50%;background:var(--pt-brand-soft);color:var(--pt-brand);display:grid;place-items:center;font-size:24px;font-weight:700;margin:0 auto 10px}
.pt-profilehead .nm{font-size:17px;font-weight:700}
.pt-profilehead .mt{font-size:12.5px;color:var(--pt-faint);margin-top:2px}

/* generic list (rows in a card) */
.pt-list{background:var(--pt-surface);border:1px solid var(--pt-border);border-radius:var(--pt-radius);box-shadow:var(--pt-shadow);overflow:hidden}
.pt-li{display:flex;align-items:center;gap:12px;padding:13px 16px;border-top:1px solid var(--pt-border);text-decoration:none;color:inherit}
.pt-li:first-child{border-top:0}
.pt-li .grow{flex:1;min-width:0}
.pt-li .t{font-weight:600;font-size:14.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pt-li .s{font-size:12.5px;color:var(--pt-faint)}
.pt-li .r,.pt-txn .r{text-align:right;white-space:nowrap}
.pt-li .r .amt{font-weight:700}

/* definition list (detail key/value) */
.pt-dl{background:var(--pt-surface);border:1px solid var(--pt-border);border-radius:var(--pt-radius);box-shadow:var(--pt-shadow);overflow:hidden;margin:0 0 14px}
.pt-dl .row{display:flex;justify-content:space-between;gap:12px;padding:12px 16px;border-top:1px solid var(--pt-border);font-size:14px}
.pt-dl .row:first-child{border-top:0}
.pt-dl .k{color:var(--pt-muted)}
.pt-dl .v{font-weight:600;text-align:right}

/* small 3-up stat tiles */
.pt-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:14px 0}
.pt-stat{background:var(--pt-surface);border:1px solid var(--pt-border);border-radius:14px;padding:12px 8px;text-align:center;box-shadow:var(--pt-shadow)}
.pt-stat .k{font-size:11px;color:var(--pt-faint)}
.pt-stat .v{font-size:16px;font-weight:750;margin-top:2px}

/* status badges */
.pt-badge{display:inline-flex;align-items:center;font-size:11px;font-weight:650;padding:2px 9px;border-radius:999px}
.pt-badge--ok{background:var(--pt-brand-soft);color:var(--pt-brand)}
.pt-badge--warn{background:var(--pt-accent-soft);color:var(--pt-accent)}
.pt-badge--danger{background:var(--pt-danger-soft);color:var(--pt-danger)}
.pt-badge--muted{background:var(--pt-surface-2);color:var(--pt-muted)}

/* table */
.pt-tablewrap{overflow-x:auto;background:var(--pt-surface);border:1px solid var(--pt-border);border-radius:var(--pt-radius);box-shadow:var(--pt-shadow);margin:0 0 14px}
.pt-table{width:100%;border-collapse:collapse;font-size:13px}
.pt-table th,.pt-table td{padding:9px 12px;text-align:left;border-bottom:1px solid var(--pt-border);white-space:nowrap}
.pt-table th{background:var(--pt-surface-2);color:var(--pt-muted);font-size:11px;text-transform:uppercase;letter-spacing:.04em;font-weight:700}
.pt-table tbody tr:last-child td{border-bottom:0}
.pt-table .num{text-align:right;font-variant-numeric:tabular-nums}
.pt-table .empty{text-align:center;color:var(--pt-faint);padding:28px;white-space:normal}

/* tabs / sub-nav */
.pt-tabs{display:flex;gap:8px;margin:0 0 14px}
.pt-tabs a{flex:1;text-align:center;padding:10px;border-radius:11px;background:var(--pt-surface);border:1px solid var(--pt-border);
  color:var(--pt-muted);text-decoration:none;font-weight:600;font-size:13.5px;box-shadow:var(--pt-shadow)}
.pt-tabs a.on{background:var(--pt-brand-soft);color:var(--pt-brand);border-color:transparent}

/* card with padding (forms / blocks) */
.pt-block{background:var(--pt-surface);border:1px solid var(--pt-border);border-radius:var(--pt-radius);box-shadow:var(--pt-shadow);padding:16px}
.pt-block{margin:0 0 16px}
.pt-block h2{font-size:15px;margin:0 0 4px}
.pt-block .blurb{font-size:12.5px;color:var(--pt-faint);margin:0 0 12px}
.pt-inline{display:inline-flex;align-items:center;gap:10px}

/* notes / callouts */
.pt-note{border-radius:12px;padding:11px 14px;font-size:13px;margin:0 0 14px}
.pt-note--info{background:var(--pt-brand-soft);color:var(--pt-brand-dark)}
.pt-note--warn{background:var(--pt-accent-soft);color:var(--pt-accent)}

/* pager */
.pt-pager{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:14px;font-size:13px;color:var(--pt-muted)}
.pt-pager .pages{display:flex;gap:8px}
.pt-pager a{padding:7px 12px;border:1px solid var(--pt-border);border-radius:10px;text-decoration:none;color:var(--pt-text);background:var(--pt-surface)}
.pt-pager a:hover{background:var(--pt-surface-2)}

/* loan-tinted hero variant (you-owe) */
.pt-hero--loan{background:linear-gradient(135deg,#b4474e 0%,#7e2e36 100%)}
.pt-hero .hbar{height:8px;border-radius:999px;background:rgba(255,255,255,.25);margin-top:10px;overflow:hidden}
.pt-hero .hbar>span{display:block;height:100%;border-radius:999px;background:#fff}
.pt-hero .hbar-cap{display:flex;justify-content:space-between;font-size:11.5px;opacity:.9;margin-top:10px}

/* ============================================================================
   Sign-in (layouts.portal-auth) — Trust Teal split card.
   ========================================================================== */
.pt-auth{flex:1;display:grid;grid-template-columns:1fr;min-height:100vh}
.pt-auth-hero{display:none}
.pt-auth-cardwrap{position:relative;display:flex;align-items:center;justify-content:center;padding:28px 18px}
/* Stand-alone centered auth (agent login) — fills the space below the top bar
   and centres the card on both axes, regardless of the app-shell grid. */
.pt-authmain{flex:1;display:flex;align-items:center;justify-content:center;padding:clamp(24px,6vh,56px) 18px}
.pt-authbox{width:100%;max-width:400px}
.pt-authbox .pt-auth-card{max-width:none}
.pt-authbox .pt-flash:empty{display:none}
.pt-authbox .pt-flash .pt-alert{margin-bottom:12px}
.pt-auth-card{width:100%;max-width:380px;background:var(--pt-surface);border:1px solid var(--pt-border);
  border-radius:var(--pt-radius);box-shadow:var(--pt-shadow);padding:26px 22px}
.pt-auth-brandsm{margin:0 0 18px}
.pt-auth-title{font-size:20px;margin:0 0 2px}
.pt-auth-sub{font-size:13px;color:var(--pt-faint);margin:0 0 18px}
.pt-auth-note{margin-top:16px;padding-top:14px;border-top:1px solid var(--pt-border)}
.pt-auth-langs{display:flex;gap:6px;justify-content:center;margin-top:18px}
.pt-auth-langs a{padding:5px 12px;border-radius:999px;text-decoration:none;font-size:12.5px;font-weight:600;
  color:var(--pt-muted);border:1px solid var(--pt-border)}
.pt-auth-langs a.on{background:var(--pt-brand-soft);color:var(--pt-brand);border-color:transparent}
.pt-auth-theme{position:absolute;top:16px;right:16px}
.pt-input--code{letter-spacing:.4em;font-variant-numeric:tabular-nums;text-align:center;font-size:18px}

@media (min-width:880px){
  .pt-auth{grid-template-columns:1.05fr .95fr}
  .pt-auth-hero{display:flex;flex-direction:column;justify-content:center;gap:18px;padding:48px;
    background:var(--pt-hero);color:#fff}
  .pt-auth-hero .pt-brand{color:#fff}
  .pt-auth-hero .pt-brand small{color:rgba(255,255,255,.8)}
  .pt-auth-hero .pt-logo{background:rgba(255,255,255,.16)}
  .pt-auth-hero h1{font-size:30px;line-height:1.18;margin:6px 0 4px;max-width:13ch}
  .pt-auth-feats{list-style:none;margin:6px 0 0;padding:0;display:grid;gap:12px}
  .pt-auth-feats li{position:relative;padding-left:28px;font-size:14px;opacity:.95}
  .pt-auth-feats li::before{content:"";position:absolute;left:0;top:2px;width:18px;height:18px;border-radius:50%;
    background:rgba(255,255,255,.18);
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:center;background-size:11px}
  .pt-auth-foot{margin-top:14px;font-size:12px;opacity:.75}
  .pt-auth-brandsm{display:none}
}
