/* ============================================================
   Batlokwa Business Registry — royal purple + gold on ivory
   (matches the Lekgotla La Batlokwa ba Mokgalong website)
   ============================================================ */
:root{
  --ink:#241226;--ink-soft:#463a52;--bone:#fbf6ec;--bone-2:#f2e9d7;--card:#fffdf7;
  --gold:#e3a52a;--gold-deep:#b9831a;--sage:#4e7a4e;--line:#e6ddc9;--line-soft:#efe7d4;
  --muted:#6d6477;--danger:#a23b2c;--info:#3a5a8c;
  --royal:#4a1768;--royal-deep:#330f48;--royal-lite:#6a2b95;
  --radius:12px;--shadow:0 1px 0 rgba(0,0,0,.04),0 16px 40px -24px rgba(48,16,72,.45);
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--bone);-webkit-font-smoothing:antialiased;line-height:1.6}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:700;line-height:1.1;margin:0}
.hidden{display:none !important}
.muted{color:var(--muted)}.tiny{font-size:11px}
.err{color:var(--danger);font-size:13px;margin:8px 0 0;min-height:16px}
.wrap{max-width:1080px;margin:0 auto;padding:0 22px}
a{color:inherit}
.crest{width:66px;height:66px;border-radius:50%;background:#fff;padding:4px;object-fit:contain;display:inline-block;box-shadow:0 0 0 3px rgba(227,165,42,.55)}
.crest.sm{width:42px;height:42px;padding:2px;box-shadow:0 0 0 2px rgba(227,165,42,.5)}

/* buttons */
.btn{font-family:inherit;font-size:14px;font-weight:600;border:1.5px solid transparent;border-radius:9px;padding:11px 20px;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;gap:7px;justify-content:center}
.btn.sm{padding:7px 14px;font-size:13px}.btn.full{width:100%}
.btn-gold{background:var(--gold);color:#3a2208;border-color:var(--gold-deep)}
.btn-gold:hover{background:var(--gold-deep);color:#fff}
.btn-ghost{background:transparent;color:var(--royal);border-color:var(--line)}
.btn-ghost:hover{background:var(--bone-2)}
.btn-danger{background:transparent;color:var(--danger);border-color:#e0c4bd}
.btn-danger:hover{background:#f6e9e6}

/* gate */
.gate{position:fixed;inset:0;display:grid;place-items:center;overflow:auto;background:radial-gradient(120% 120% at 50% 0%,#6a2b95,#330f48 60%)}
.gate-card{background:var(--card);width:min(380px,92vw);padding:36px 32px;border-radius:16px;box-shadow:var(--shadow);text-align:center;border:1px solid var(--line);margin:24px}
.gate-card h1{font-size:28px;margin:14px 0 4px}
.gate-card .sub{color:var(--muted);font-size:14px;margin:0 0 20px}
.gate-card input{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:9px;font-size:15px;margin-bottom:11px;background:#fff;font-family:inherit}
.gate-card input:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.switch{font-size:13px;color:var(--muted);margin:14px 0 0}.switch a{color:var(--gold-deep);cursor:pointer;font-weight:600}
.gate-foot{margin:18px 0 0;font-size:13px}.gate-foot a{color:var(--royal);font-weight:600}

/* topbar */
.topbar{background:var(--royal);color:#efe7d4;position:sticky;top:0;z-index:30}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:12px}
.brand b{font-family:'Cormorant Garamond',serif;font-size:20px;color:#fff;display:block;line-height:1.05}
.brand span{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.top-actions{display:flex;align-items:center;gap:16px}
.toplink{color:#e8dcf3;font-size:14px;font-weight:500}.toplink:hover{color:var(--gold)}
.who{font-size:13px;color:#e8dcf3;font-weight:600}
.topbar .btn-ghost{color:#fff;border-color:rgba(255,255,255,.35)}.topbar .btn-ghost:hover{background:rgba(255,255,255,.12)}

.view{padding:34px 22px 80px}
.eyebrow{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;margin-bottom:10px}

/* owner hero */
.hero-card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:46px;box-shadow:var(--shadow);max-width:680px}
.hero-card h1{font-size:42px;margin-bottom:12px;color:var(--royal)}
.hero-card p{color:var(--ink-soft);font-size:16px;max-width:560px}
.fee-note{margin-top:18px !important;font-size:15px}.fee-note strong{color:var(--gold-deep)}
.hero-card .btn{margin-top:22px}

/* status panel */
#statusPanel{max-width:760px}
.status-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.status-head h1{font-size:34px;color:var(--royal)}
.status-helper{color:var(--sage);font-weight:600;margin:6px 0 0}
.badge{font-size:12px;font-weight:700;letter-spacing:.04em;padding:6px 14px;border-radius:999px;white-space:nowrap}
.b-draft{background:#f3e9cf;color:var(--gold-deep)}.b-info{background:#e2e8f3;color:var(--info)}
.b-ok{background:#e4eee7;color:var(--sage)}.b-bad{background:#f3ddd7;color:var(--danger)}
.note-reject{background:#f9ece8;border:1px solid #e6c4bb;border-radius:10px;padding:13px 16px;color:#7a2c1e;margin-top:16px;font-size:14px}
.pay-box{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:28px;margin-top:22px;box-shadow:var(--shadow)}
.pay-box h3{font-size:24px;color:var(--royal);margin-bottom:6px}
.pay-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 26px;margin:18px 0}
.pay-grid .k{display:block;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.pay-grid .v{font-weight:600;color:var(--royal);font-size:15px}
.proof-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;border-top:1px dashed var(--line);padding-top:16px}
.pay-state{font-size:13px;color:var(--sage);font-weight:600}
.status-actions{margin-top:20px}

/* forms */
.form-head,.form-foot{display:flex;justify-content:space-between;align-items:center;gap:12px}
.form-head{margin-bottom:8px}.form-head h1{font-size:32px;color:var(--royal)}
.form-foot{margin-top:8px}
.fsec{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:26px;margin:18px 0;box-shadow:var(--shadow)}
.fsec h2{font-size:23px;color:var(--royal);margin-bottom:16px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fld{display:flex;flex-direction:column;gap:5px;font-size:12px;font-weight:600;color:var(--ink-soft);margin-bottom:13px}
.fld input,.fld select,.fld textarea{font-family:inherit;font-size:14px;font-weight:400;padding:10px 12px;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--ink)}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.docs .filecard{display:flex;flex-direction:column;gap:7px;background:var(--bone);border:1px dashed var(--line);border-radius:11px;padding:14px;font-size:13px;font-weight:600;color:var(--ink-soft)}
.fstate{font-size:12px;color:var(--sage);font-weight:600;min-height:14px}

/* admin stats + tabs */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px;text-align:center;box-shadow:var(--shadow)}
.snum{font-family:'Cormorant Garamond',serif;font-size:34px;font-weight:700;color:var(--royal)}
.slbl{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.tabs{display:flex;gap:6px;border-bottom:1px solid var(--line);margin-bottom:20px;flex-wrap:wrap}
.tab{background:none;border:none;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent}
.tab.active{color:var(--royal);border-bottom-color:var(--gold)}
.filters{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.pill{background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 16px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer}
.pill.active{background:var(--royal);color:#fff;border-color:var(--royal)}

/* app cards */
.apps-list{display:flex;flex-direction:column;gap:12px}
.appcard{display:flex;justify-content:space-between;align-items:center;gap:16px;background:var(--card);border:1px solid var(--line);border-radius:13px;padding:18px 20px;cursor:pointer;transition:.15s;box-shadow:var(--shadow)}
.appcard:hover{border-color:var(--gold);transform:translateY(-1px)}
.apptitle{font-family:'Cormorant Garamond',serif;font-size:21px;font-weight:700;color:var(--royal);display:flex;align-items:center;gap:10px}
.appside{display:flex;flex-direction:column;align-items:flex-end;gap:3px}
.paytag{font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px}
.pay-unpaid{background:#f3ddd7;color:var(--danger)}.pay-proof_uploaded{background:#e2e8f3;color:var(--info)}
.pay-verified{background:#e4eee7;color:var(--sage)}.pay-waived{background:#efe7d4;color:var(--gold-deep)}

/* drawer */
.scrim{position:fixed;inset:0;background:rgba(36,18,38,.45);opacity:0;pointer-events:none;transition:.2s;z-index:40}
.scrim.show{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100vh;width:min(540px,96vw);background:var(--card);box-shadow:-18px 0 50px -28px rgba(36,18,38,.6);z-index:50;transform:translateX(100%);transition:transform .22s ease;display:flex;flex-direction:column;border-left:1px solid var(--line)}
.drawer.show{transform:translateX(0)}
.drawer-head{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;border-bottom:1px solid var(--line)}
.drawer-head h3{font-size:22px;color:var(--royal)}
.x{background:none;border:none;font-size:26px;cursor:pointer;color:var(--muted)}
.drawer-body{flex:1;overflow-y:auto;padding:20px 24px}
.dsec{margin-bottom:22px}
.dsec h4{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:10px;font-family:'Inter';font-weight:700}
.drow{display:flex;justify-content:space-between;gap:16px;padding:7px 0;border-bottom:1px solid var(--line-soft);font-size:14px}
.drow .k{color:var(--muted)}.drow .v{font-weight:500;text-align:right;max-width:62%}
.doclinks{display:flex;flex-direction:column;gap:8px}
.doclink{color:var(--royal);font-weight:600;font-size:14px}.doclink:hover{color:var(--gold-deep)}
.drawer-foot{display:flex;gap:8px;flex-wrap:wrap;padding:16px 24px;border-top:1px solid var(--line)}

/* owners + audit (shared) */
.users-list{display:flex;flex-direction:column;gap:12px}
.ucard{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:16px 18px}
.uhead{display:flex;justify-content:space-between;align-items:center;margin-bottom:3px}
.ustatus{font-size:10px;text-transform:uppercase;letter-spacing:.06em;font-weight:700;padding:3px 9px;border-radius:999px}
.s-active{background:#e4eee7;color:var(--sage)}.s-suspended{background:#f3ddd7;color:var(--danger)}
.uactions{display:flex;gap:8px;margin-top:10px}
.settings-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:28px;max-width:620px;box-shadow:var(--shadow)}
.settings-card h2{font-size:24px;color:var(--royal);margin-bottom:16px}
.audit-list{display:flex;flex-direction:column}
.arow{display:grid;grid-template-columns:130px 120px 1fr;gap:8px;align-items:baseline;padding:8px;border-bottom:1px solid var(--line-soft);font-size:13px}
.arow .aact{font-weight:600;color:var(--royal)}.arow .adet{color:var(--ink-soft)}
.arow .muted.tiny{grid-column:1/-1}

@media(max-width:760px){
  .grid2,.pay-grid,.stats{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .arow{grid-template-columns:1fr}
  .topbar .wrap{height:auto;padding:12px 22px;flex-wrap:wrap;gap:10px}
}
