/* Auth + dashboard UI (Saathi theme). Loaded with site.css. */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,var(--bg1),var(--bg2));padding:24px}
.auth-card{background:#fff;border-radius:22px;box-shadow:var(--shadow);padding:32px 28px;max-width:430px;width:100%}
.auth-card h2{font-size:23px;text-align:center}
.auth-sub{color:var(--ink2);text-align:center;margin:8px 0 18px;font-size:14px}
.tabs{display:flex;background:#f3f0ff;border-radius:12px;padding:4px;margin-bottom:18px}
.tabs a{flex:1;text-align:center;padding:9px;border-radius:9px;font-weight:700;font-size:14px;color:var(--ink2)}
.tabs a.on{background:#fff;color:var(--v);box-shadow:var(--shadow-sm)}
.field{margin-bottom:13px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink2);margin-bottom:6px}
.field input{width:100%;border:1.5px solid #e6e2f4;border-radius:11px;padding:12px 14px;font-size:15px;font-family:var(--font);outline:none}
.field input:focus{border-color:var(--v)}
.btn-block{width:100%}
.msg{padding:10px 13px;border-radius:10px;font-size:13.5px;margin-bottom:14px}
.msg.err{background:#fde8e6;color:#b3261e}
.msg.ok{background:#e7f9f0;color:#0e9f6e}
.msg.dev{background:#fff7e6;color:#92560a;border:1px dashed #f0c060}
.divider{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:12px;margin:14px 0}
.divider:before,.divider:after{content:'';flex:1;height:1px;background:var(--line)}
.otp-input{letter-spacing:10px;text-align:center;font-size:24px;font-weight:800}

/* dashboard */
.topbar{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40}
.topbar .wrap{display:flex;align-items:center;gap:14px;height:62px}
.topbar .brand{font-size:18px}
.topbar .sp{margin-left:auto;display:flex;align-items:center;gap:14px}
.topbar .who{font-size:13px;color:var(--ink2)}
.badge{display:inline-block;font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px}
.badge.v{background:#efeaff;color:var(--v)}.badge.g{background:#e7f9f0;color:var(--ok)}.badge.r{background:#fde8e6;color:#b3261e}.badge.m{background:#fff4e5;color:#b25e00}
.dash{max-width:1080px;margin:26px auto;padding:0 20px}
.dash h1{font-size:26px;margin-bottom:4px}
.dash .muted{color:var(--muted);font-size:14px;margin-bottom:22px}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.stat{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:var(--shadow-sm)}
.stat b{font-family:var(--display);font-size:28px;color:var(--ink);display:block}
.stat span{font-size:12.5px;color:var(--muted)}
@media(max-width:760px){.stats{grid-template-columns:1fr 1fr}}
.panel{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:var(--shadow-sm);margin-bottom:18px}
.panel h3{font-size:17px;margin-bottom:12px}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--line);color:var(--ink2)}
th{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
td code{background:#f3f0ff;color:var(--v);padding:2px 7px;border-radius:6px;font-size:13px}
.adminnav{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.adminnav a{padding:8px 14px;border-radius:10px;font-weight:600;font-size:13.5px;color:var(--ink2);background:#fff;border:1px solid var(--line)}
.adminnav a.on{background:var(--v);color:#fff;border-color:var(--v)}
.inline-form{display:flex;gap:8px;flex-wrap:wrap;align-items:end}
.inline-form .field{margin:0}
.small{font-size:12.5px;color:var(--muted)}
.pillplan{display:flex;flex-wrap:wrap;gap:14px}
.pillplan .pp{flex:1;min-width:200px;border:1px solid var(--line);border-radius:14px;padding:18px}
.pillplan .pp.pop{border:2px solid var(--v)}
