/* REality™ MLS Collection · shared theme (Direction A: Trusted SaaS) */
:root{
  --blue:#3c64dc; --blue-700:#2f50c0; --blue-800:#27429e; --blue-50:#eef2fe; --blue-100:#dbe4fc;
  --green:#39bd54; --green-600:#2da045; --green-700:#23823a; --green-50:#e9f9ed; --green-100:#cdeed5;
  --red:#dc3c4f; --red-50:#fdecee; --amber:#d98a1f;
  --ink:#0f1b3d;
  --s900:#0f172a; --s800:#1e293b; --s700:#334155; --s600:#475569;
  --s500:#64748b; --s400:#94a3b8; --s300:#cbd5e1; --s200:#e2e8f0;
  --s100:#f1f5f9; --s50:#f8fafc;
  --ui:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,monospace;
  --shadow-card:0 1px 2px rgba(15,23,42,.04),0 12px 30px -18px rgba(15,23,42,.22);
  --shadow-pop:0 8px 28px -8px rgba(15,23,42,.28),0 2px 6px rgba(15,23,42,.08);
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:var(--ui);color:var(--s800);-webkit-font-smoothing:antialiased}

/* form primitives */
.lbl{font-size:12.5px;font-weight:600;color:var(--s600);margin-bottom:6px;display:block}
.req{color:var(--blue)}
.inp{width:100%;height:44px;border:1px solid var(--s200);border-radius:9px;padding:0 12px;font:inherit;font-size:14px;color:var(--s800);background:#fff;transition:border-color .12s,box-shadow .12s}
.inp::placeholder{color:var(--s400)}
.inp:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-50)}
.inp.bad{border-color:var(--red);box-shadow:0 0 0 3px var(--red-50)}
textarea.inp{height:auto;padding:10px 12px;resize:vertical;line-height:1.5}
.err{color:var(--red);font-size:11.5px;margin-top:5px;display:block}

.btn{height:46px;border:none;border-radius:10px;background:var(--blue);color:#fff;font:inherit;font-weight:700;font-size:15px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;transition:background .14s,transform .06s}
.btn:hover{background:var(--blue-700)}
.btn:active{transform:translateY(1px)}
.btn:disabled{background:var(--s300);cursor:not-allowed;transform:none}
.btn-sm{height:36px;font-size:13px;border-radius:8px;padding:0 14px}
.btn-ghost{background:#fff;border:1px solid var(--s200);color:var(--s700)}
.btn-ghost:hover{background:var(--s50);border-color:var(--s300)}
.btn-green{background:var(--green)}.btn-green:hover{background:var(--green-600)}
.btn-danger{background:#fff;border:1px solid var(--s200);color:var(--red)}.btn-danger:hover{background:var(--red-50);border-color:#f3c4ca}
.btn-dash{background:#fff;border:1.5px dashed var(--s300);color:var(--blue);font-weight:600;height:46px;border-radius:10px;font:inherit;font-size:14px;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;transition:border-color .12s,background .12s}
.btn-dash:hover{border-color:var(--blue);background:var(--blue-50)}

.seclbl{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue)}
.chip{display:inline-flex;align-items:center;gap:6px;height:24px;padding:0 10px;border-radius:20px;font-size:12px;font-weight:600;background:var(--blue-50);color:var(--blue-700)}
.chip-green{background:var(--green-50);color:var(--green-600)}
.chip-slate{background:var(--s100);color:var(--s600)}
.mono{font-family:var(--mono)}
.securenote{display:flex;gap:10px;align-items:flex-start;background:var(--green-50);border:1px solid var(--green-100);border-radius:10px;padding:11px 13px;font-size:12.5px;color:var(--green-700);line-height:1.45}

/* scrollbars */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--s300);border-radius:6px;border:2px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:var(--s400);background-clip:content-box}

/* modal */
.modal-back{position:fixed;inset:0;background:rgba(15,27,61,.45);backdrop-filter:blur(2px);display:flex;align-items:flex-start;justify-content:center;padding:40px 20px;z-index:60;overflow:auto;animation:fade .15s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(8px) scale(.99)}to{opacity:1;transform:none}}
.spin{width:18px;height:18px;border:2.5px solid var(--blue-100);border-top-color:var(--blue);border-radius:50%;animation:rot .7s linear infinite;display:inline-block}
@keyframes rot{to{transform:rotate(360deg)}}
