/* ============================================================
   Transaction Tracker — shared styles (admin + client)
   ============================================================ */
:root{
  --bg:#f4f1ea; --panel:#fbfaf6; --ink:#2b2b2b; --muted:#8a8578; --line:#e2ddd0;
  --blue:#8C52FF; --blue-soft:#efe7ff;   /* primary brand accent (Ratifyly purple) */
  --orange:#6E3AD6; --orange-soft:#e7dafb;   /* Loan accent — deeper shade of the brand purple, in sequence with Contract */
  --teal:#3f8a82;
  --green:#5a9367;
  --red:#c0705f;
  --shadow:0 10px 40px rgba(60,50,30,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;}
.script{font-family:'Caveat',cursive;}
.hidden{display:none !important;}
a{color:var(--blue);}

/* ---------- buttons ---------- */
.btn{border:0;border-radius:10px;font:600 13.5px 'Inter';padding:10px 16px;cursor:pointer;transition:.15s;}
.btn.primary{background:var(--blue);color:#fff;}
.btn.primary:hover{background:#7338f0;}
.btn.ghost{background:var(--panel);border:1px solid var(--line);color:var(--ink);}
.btn.ghost:hover{background:#fff;}
.btn.danger{background:transparent;border:1px solid #e0c4bd;color:var(--red);}
.btn.danger:hover{background:#fbeeea;}
.btn.sm{padding:7px 12px;font-size:12.5px;border-radius:9px;}

/* ---------- login ---------- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);
  padding:32px 30px;width:100%;max-width:380px;}
.login-card h1{font-family:'Caveat';font-size:34px;font-weight:700;margin-bottom:2px;}
.login-card p.sub{color:var(--muted);font-size:13px;margin-bottom:20px;}
.field{margin-bottom:14px;}
.field label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:5px;}
.field input{width:100%;border:1px solid var(--line);border-radius:10px;padding:11px 12px;font:500 14px 'Inter';background:#fff;color:var(--ink);}
.field input:focus{outline:none;border-color:var(--blue);}
.login-err{color:var(--red);font-size:12.5px;margin-top:4px;min-height:16px;}

/* ---------- admin chrome ---------- */
.topbar{background:var(--panel);border-bottom:1px solid var(--line);padding:14px 22px;
  display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10;}
.topbar .brand{font-family:'Caveat';font-size:24px;font-weight:700;}
.topbar .right{display:flex;gap:10px;align-items:center;}
.topbar .who{font-size:12.5px;color:var(--muted);}
.container{max-width:980px;margin:0 auto;padding:26px 20px 80px;}

/* ---------- dashboard ---------- */
.dash-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:12px;}
.dash-head h2{font-size:20px;font-weight:700;}
.deal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;}
.deal-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px;transition:.15s;}
.deal-card:hover{box-shadow:var(--shadow);}
.deal-card .addr{font-family:'Caveat';font-size:24px;font-weight:700;line-height:1.05;}
.deal-card .meta{font-size:12.5px;color:var(--muted);margin:3px 0 12px;}
.deal-card .prog{height:7px;border-radius:6px;background:#eae4d6;overflow:hidden;margin-bottom:6px;}
.deal-card .prog i{display:block;height:100%;background:var(--orange);border-radius:6px;}
.deal-card .progtxt{font-size:11.5px;color:var(--muted);margin-bottom:14px;}
.deal-card .row{display:flex;gap:8px;flex-wrap:wrap;}
.empty{text-align:center;color:var(--muted);padding:60px 20px;}
.empty .script{font-size:30px;color:var(--orange);display:block;margin-bottom:6px;}

/* ---------- transaction card (admin editor + client) ---------- */
.stage{display:flex;justify-content:center;}
.phone{max-width:580px;width:100%;background:var(--panel);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);overflow:hidden;}
.screen{padding:28px 30px 34px;}
@media (max-width:600px){
  .phone{border-radius:16px;}
  .screen{padding:20px 18px 28px;}
}

.kicker{font-size:11px;letter-spacing:.13em;color:var(--muted);font-weight:600;text-transform:uppercase;}
.address{font-size:30px;line-height:1.05;margin:2px 0 4px;font-weight:700;}
.subline{font-size:12.5px;color:var(--muted);}
.subline [contenteditable]{outline:none;}
.photo{margin:14px 0 6px;height:170px;border-radius:12px;border:1px dashed #cdbf9e;
  background:repeating-linear-gradient(45deg,#efe7d4,#efe7d4 9px,#f6f0e2 9px,#f6f0e2 18px);
  display:flex;align-items:center;justify-content:center;color:#b6a986;font-size:12.5px;letter-spacing:.04em;
  background-size:cover;background-position:center;}
.photo.has-img{border:0;}

.tabs{display:flex;border:1px solid var(--line);border-radius:12px;overflow:hidden;margin:16px 0 14px;}
.tabs button{flex:1;border:0;background:transparent;cursor:pointer;font:600 14px 'Inter';color:var(--ink);padding:11px 0;transition:.15s;}
.tabs button[data-tab="contract"].on{background:var(--blue);color:#fff;}
.tabs button[data-tab="loan"].on{background:var(--orange);color:#fff;}

.tabhint{font-family:'Caveat';font-size:17px;margin:0 0 12px 2px;}
.tabhint.contract{color:var(--blue);}
.tabhint.loan{color:var(--orange);}

.closing{background:var(--blue-soft);border:1px solid #ddccf7;border-radius:14px;padding:14px 16px;display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;}
.closing .lbl{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:#9277c2;font-weight:600;}
.closing .date{font-size:18px;font-weight:700;color:#4b2a8a;margin-top:2px;}
.closing .big{font-family:'Caveat';font-size:40px;font-weight:700;color:var(--blue);line-height:.9;text-align:right;}
.closing .big small{display:block;font-family:'Inter';font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#9277c2;}

.timeline{position:relative;}
.ms{display:flex;gap:12px;padding:0 0 18px;position:relative;}
.ms .rail{display:flex;flex-direction:column;align-items:center;}
.dot{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex:0 0 auto;font-size:12px;color:#fff;border:2px solid transparent;background:#cfc8b7;}
.ms.done .dot{background:var(--blue);}
.ms.current .dot{background:#fff;border-color:var(--blue);}
.ms.current .dot::after{content:"";width:8px;height:8px;border-radius:50%;background:var(--blue);}
.ms.upcoming .dot{background:#fff;border:2px solid #d8d1c0;}
.connector{width:2px;flex:1;background:#e0d9c8;margin:3px 0;min-height:14px;}
.ms:last-child .connector{display:none;}
.ms .body{padding-top:1px;flex:1;}
.ms .title{font-size:14px;font-weight:700;}
.ms.upcoming .title{color:#a59f90;font-weight:600;}
.ms.current .title{color:var(--blue);}
.ms .when{font-size:12px;color:var(--muted);margin:1px 0 5px;}
.badge{display:inline-block;font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:999px;}
.badge.done,.badge.soon{background:var(--blue);color:#fff;}
.badge.future{background:transparent;border:1px solid #cdbf9e;color:#9a8f76;}

.phase{border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-bottom:12px;background:#fff;}
.phase .head{display:flex;align-items:center;gap:10px;padding:11px 14px;}
.rom{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font:700 12px 'Inter';color:#fff;background:#a98fe0;flex:0 0 auto;}
.phase .pname{font-size:14px;font-weight:700;flex:1;}
.pstatus{font-size:10px;letter-spacing:.1em;font-weight:700;text-transform:uppercase;color:var(--muted);}
.phase.complete .head{background:var(--orange-soft);}
.phase.progress{border-color:var(--orange);}
.phase.progress .head{background:var(--orange);}
.phase.progress .pname,.phase.progress .pstatus{color:#fff;}
.phase.progress .rom{background:rgba(255,255,255,.25);}
.phase.upcoming .head{background:#f2eefb;}
.phase.upcoming .rom{background:#c9bce8;}
.checklist{padding:6px 14px 12px;display:flex;flex-direction:column;gap:9px;}
.check{display:flex;align-items:center;gap:10px;font-size:13px;}
.box{width:18px;height:18px;border-radius:5px;border:2px solid #cdbf9e;flex:0 0 auto;display:flex;align-items:center;justify-content:center;cursor:pointer;background:#fff;transition:.12s;}
.check.done .box{background:var(--green);border-color:var(--green);}
.check.done .box::after{content:"✓";color:#fff;font-size:12px;line-height:1;}
.check.done .lab{color:#6c6a62;}
.check.active .lab{color:var(--orange);font-weight:600;}
.check.active .box{border-color:var(--orange);}

/* ---------- edit affordances (admin only) ---------- */
[contenteditable="true"]{background:#fffdf3;border-radius:4px;box-shadow:inset 0 0 0 1px #e4d9b8;padding:0 3px;}
.editrow{display:none;gap:8px;align-items:center;margin-top:6px;}
.editmode .editrow{display:flex;flex-wrap:wrap;}
.editrow select,.editrow input[type=date]{font:500 11px 'Inter';border:1px solid var(--line);border-radius:7px;padding:4px 6px;background:#fff;color:var(--ink);}
.addrow{display:none;}
.editmode .addrow{display:flex;justify-content:center;margin:2px 0 6px;}
.addrow button{border:1px dashed #c9bb98;background:transparent;color:#9a8f76;border-radius:9px;font:600 12px 'Inter';padding:7px 12px;cursor:pointer;}
.delx{display:none;margin-left:auto;border:0;background:transparent;color:#c08a7a;cursor:pointer;font-size:15px;line-height:1;}
.editmode .delx{display:block;}
.editmode .photo{cursor:pointer;}

.toggle{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);justify-content:center;margin-top:6px;}
.toggle input{accent-color:var(--blue);width:15px;height:15px;}

/* ---------- editor toolbar ---------- */
.editor-bar{max-width:580px;margin:0 auto 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.linkbox{display:flex;gap:8px;align-items:center;max-width:580px;margin:0 auto 18px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:10px 12px;}
.linkbox input{flex:1;border:0;background:transparent;font:500 12.5px 'Inter';color:var(--ink);}
.linkbox input:focus{outline:none;}

/* ---------- toast ---------- */
.toast{position:fixed;bottom:18px;left:50%;transform:translateX(-50%) translateY(20px);background:#2b2b2b;color:#fff;font:600 12px 'Inter';padding:9px 18px;border-radius:999px;opacity:0;transition:.25s;pointer-events:none;z-index:50;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* ---------- Ratifyly brand logo ---------- */
.brand-logo{display:inline-flex;align-items:center;gap:.32em;line-height:1;white-space:nowrap;}
.brand-mark{width:1.18em;height:1.18em;flex:0 0 auto;}
.brand-word{font-family:'Outfit','Inter',sans-serif;font-weight:600;letter-spacing:-.02em;color:#1a1a1a;}
.brand-word .accent{color:var(--blue);}
.tool-tag{font:600 11px 'Inter';letter-spacing:.04em;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:3px 9px;}
.client-brand{display:flex;flex-direction:column;align-items:center;gap:4px;margin:0 auto 16px;}
.client-brand .brand-logo{font-size:26px;}
.client-brand .tool-tag{font-size:10.5px;}

/* ---------- client page extras ---------- */
.client-foot{text-align:center;color:var(--muted);font-size:11.5px;margin:18px auto 0;max-width:420px;}
.loading{text-align:center;color:var(--muted);padding:80px 20px;font-size:14px;}
