/* ===== CA PMS — Sawant & Kadrekar LLP ===== */
:root{
  --navy:#13233f; --navy-2:#1d3557; --gold:#c9a14a; --gold-soft:#e4c97a;
  --ink:#1a2233; --muted:#6b7790; --line:#e4e8f0; --bg:#f4f6fb;
  --card:#ffffff; --ok:#2e9e6b; --warn:#d98324; --bad:#c0392b;
  --shadow:0 8px 30px rgba(19,35,63,.10);
}
[data-theme="dark"]{
  --navy:#0c1626; --navy-2:#15233c; --ink:#e8ecf4; --muted:#94a0b8;
  --line:#28344c; --bg:#0a1220; --card:#13203a; --shadow:0 8px 30px rgba(0,0,0,.45);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Spectral',Georgia,serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;transition:background .3s,color .3s}
h1,h2,h3,.brand{font-family:'Fraunces','Spectral',serif;letter-spacing:-.01em}
.ui,button,input,select,textarea,table,.muted{font-family:'Outfit',system-ui,sans-serif}
.shell{display:flex;min-height:100vh}
.sidebar{width:248px;background:linear-gradient(180deg,var(--navy),var(--navy-2));color:#dfe5f0;position:fixed;inset:0 auto 0 0;display:flex;flex-direction:column;padding:22px 14px;z-index:30;transition:transform .3s}
.sidebar.collapsed{transform:translateX(-260px)}
.brand{color:#fff;font-size:20px;padding:6px 10px 2px;line-height:1.15}
.brand b{color:var(--gold)}
.brand small{display:block;font-family:'Outfit',sans-serif;font-size:11px;color:#9fb0cf;letter-spacing:.08em;text-transform:uppercase;margin-top:4px}
.nav{margin-top:22px;display:flex;flex-direction:column;gap:2px;flex:1}
.nav a{display:flex;align-items:center;gap:11px;color:#c4cfe2;text-decoration:none;padding:10px 13px;border-radius:10px;font:500 14px/1 'Outfit',sans-serif;cursor:pointer;transition:.15s}
.nav a i{width:18px;text-align:center;font-size:14px;opacity:.85}
.nav a:hover{background:rgba(255,255,255,.07);color:#fff}
.nav a.active{background:var(--gold);color:#1a1304;font-weight:600}
.nav a.active i{opacity:1}
.side-foot{font:12px 'Outfit',sans-serif;color:#8a99b8;padding:10px 13px;border-top:1px solid rgba(255,255,255,.08)}
.main{flex:1;margin-left:248px;min-width:0;transition:margin .3s}
.main.full{margin-left:0}
.topbar{position:sticky;top:0;z-index:20;background:var(--card);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:13px 22px}
.topbar .ham{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer}
.topbar h2{font-size:19px}
.search{flex:1;max-width:420px;position:relative}
.search input{width:100%;padding:9px 14px 9px 36px;border:1px solid var(--line);border-radius:10px;background:var(--bg);color:var(--ink);font-size:14px}
.search i{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--muted)}
.iconbtn{background:var(--bg);border:1px solid var(--line);color:var(--ink);width:38px;height:38px;border-radius:10px;cursor:pointer;font-size:15px}
.who{display:flex;align-items:center;gap:9px;font:13px 'Outfit',sans-serif}
.who .av{width:34px;height:34px;border-radius:50%;background:var(--gold);color:#1a1304;display:grid;place-items:center;font-weight:700}
.content{padding:24px 22px 60px}
.grid{display:grid;gap:16px}
.stats{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:18px}
.stat{position:relative;overflow:hidden}
.stat .lab{font:600 11px/1 'Outfit',sans-serif;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.stat .val{font-family:'Fraunces',serif;font-size:34px;margin-top:8px;line-height:1}
.stat .ic{position:absolute;right:14px;top:14px;font-size:20px;color:var(--gold);opacity:.65}
.stat.bad .val{color:var(--bad)}.stat.warn .val{color:var(--warn)}.stat.ok .val{color:var(--ok)}
.sec-title{font-size:17px;margin:26px 0 12px;display:flex;align-items:center;gap:9px}
.sec-title:before{content:"";width:4px;height:18px;background:var(--gold);border-radius:2px}
.tablewrap{overflow:auto;border-radius:12px;border:1px solid var(--line)}
table{width:100%;border-collapse:collapse;font-size:13.5px;background:var(--card)}
th{background:var(--navy);color:#e6ecf7;text-align:left;padding:11px 13px;font:600 12px 'Outfit',sans-serif;letter-spacing:.04em;position:sticky;top:0}
td{padding:10px 13px;border-top:1px solid var(--line);vertical-align:middle}
tr:hover td{background:rgba(201,161,74,.06)}
.pill{display:inline-block;padding:3px 10px;border-radius:20px;font:600 11px 'Outfit',sans-serif}
.pill.ok{background:#e4f5ec;color:var(--ok)}.pill.warn{background:#fdf0df;color:var(--warn)}
.pill.bad{background:#fae6e3;color:var(--bad)}.pill.def{background:#eef1f7;color:var(--muted)}
[data-theme="dark"] .pill.ok{background:#17372a}[data-theme="dark"] .pill.warn{background:#3a2a14}
[data-theme="dark"] .pill.bad{background:#3a1c18}[data-theme="dark"] .pill.def{background:#23304a}
.btn{font:600 13.5px 'Outfit',sans-serif;border:none;border-radius:10px;padding:9px 16px;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:.15s}
.btn.primary{background:var(--gold);color:#1a1304}.btn.primary:hover{background:var(--gold-soft)}
.btn.ghost{background:var(--bg);color:var(--ink);border:1px solid var(--line)}
.btn.danger{background:var(--bad);color:#fff}
.btn.sm{padding:6px 11px;font-size:12px}
.row-actions{display:flex;gap:6px}
.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:14px}
input,select,textarea{font-size:14px;padding:9px 12px;border:1px solid var(--line);border-radius:10px;background:var(--card);color:var(--ink);width:100%}
label{font:600 12px 'Outfit',sans-serif;color:var(--muted);display:block;margin:0 0 5px}
.field{margin-bottom:13px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
.form-grid .full{grid-column:1/-1}
.modal-bg{position:fixed;inset:0;background:rgba(10,18,32,.55);backdrop-filter:blur(3px);display:none;place-items:center;z-index:50;padding:20px}
.modal-bg.show{display:grid}
.modal{background:var(--card);border-radius:18px;box-shadow:0 30px 80px rgba(0,0,0,.4);width:100%;max-width:640px;max-height:90vh;overflow:auto;animation:pop .22s ease}
@keyframes pop{from{transform:translateY(14px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal header{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line)}
.modal header h3{font-size:18px}.modal .body{padding:20px 22px}
.modal footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--line)}
.x{background:none;border:none;font-size:20px;color:var(--muted);cursor:pointer}
.login-wrap{min-height:100vh;display:grid;place-items:center;background:radial-gradient(900px 500px at 80% -10%,rgba(201,161,74,.18),transparent),linear-gradient(160deg,var(--navy),var(--navy-2))}
.login{background:var(--card);width:100%;max-width:390px;border-radius:20px;box-shadow:0 30px 90px rgba(0,0,0,.45);padding:34px 30px}
.login .brand{color:var(--ink);font-size:25px;padding:0 0 4px}
.login .brand b{color:var(--gold)}
.login .tag{color:var(--muted);font:12px 'Outfit',sans-serif;letter-spacing:.1em;text-transform:uppercase;margin-bottom:24px}
.muted{color:var(--muted);font-size:13px}
.toast{position:fixed;bottom:24px;right:24px;background:var(--ink);color:#fff;padding:13px 18px;border-radius:12px;font:14px 'Outfit',sans-serif;box-shadow:0 10px 30px rgba(0,0,0,.3);z-index:80;opacity:0;transform:translateY(12px);transition:.25s}
.toast.show{opacity:1;transform:none}
.toast.err{background:var(--bad)}.toast.ok{background:var(--ok)}
.skeleton{background:linear-gradient(90deg,var(--line),#f0f2f8,var(--line));background-size:200% 100%;animation:sk 1.2s infinite;border-radius:8px;height:14px}
@keyframes sk{to{background-position:-200% 0}}
.eye{background:none;border:none;cursor:pointer;color:var(--muted)}
.hide{display:none!important}
.chips{display:flex;gap:7px;flex-wrap:wrap}
.chip{background:var(--bg);border:1px solid var(--line);border-radius:20px;padding:5px 12px;font:13px 'Outfit',sans-serif;cursor:pointer}
.chip.active{background:var(--gold);color:#1a1304;border-color:var(--gold)}
@media(max-width:860px){.sidebar{transform:translateX(-260px)}.sidebar.show{transform:none}.main{margin-left:0}.form-grid{grid-template-columns:1fr}}
