/* ===================================================================
   Shankaracharya Chaturangini — App Styles
   Light + Dark theme, fully responsive, mobile-app feel.
   =================================================================== */
:root{
  --bg:#f4f6fb; --surface:#ffffff; --surface-2:#f8fafc; --border:#e6e9f0;
  --text:#1a2233; --text-2:#5a6478; --muted:#8a93a6;
  --primary:#7c3aed; --primary-2:#6d28d9; --primary-soft:#ede9fe;
  --accent:#f59e0b; --green:#16a34a; --red:#ef4444; --blue:#2563eb;
  --shadow:0 1px 3px rgba(16,24,40,.08),0 1px 2px rgba(16,24,40,.04);
  --shadow-lg:0 10px 30px rgba(16,24,40,.12);
  --radius:14px; --radius-sm:10px; --nav-h:64px;
  --safe-b:env(safe-area-inset-bottom,0px);
}
[data-theme="dark"]{
  --bg:#0e1118; --surface:#161b25; --surface-2:#1c2230; --border:#262d3d;
  --text:#e7ebf3; --text-2:#9aa4b8; --muted:#6b7488;
  --primary:#a78bfa; --primary-2:#8b5cf6; --primary-soft:#2a2147;
  --accent:#fbbf24; --green:#22c55e; --red:#f87171; --blue:#60a5fa;
  --shadow:0 1px 3px rgba(0,0,0,.4); --shadow-lg:0 12px 34px rgba(0,0,0,.5);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  font-family:'Inter','Noto Sans Devanagari',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg); color:var(--text); font-size:15px; line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--primary);text-decoration:none}
h1,h2,h3,h4{margin:0 0 .4em;font-weight:700;letter-spacing:-.01em}
.hi{font-family:'Noto Sans Devanagari',sans-serif}

/* ---------- Layout ---------- */
.app{display:flex;min-height:100vh}
.sidebar{
  width:248px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);
  position:sticky;top:0;height:100vh;overflow-y:auto;padding:18px 14px;
}
.brand{display:flex;align-items:center;gap:10px;padding:6px 8px 18px;font-weight:800;font-size:17px}
.brand .logo{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--accent));display:grid;place-items:center;color:#fff;font-weight:800}
.nav-group{margin-top:14px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding:0 8px 6px}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--text-2);font-weight:500;margin-bottom:2px;transition:.15s}
.nav-item:hover{background:var(--surface-2);color:var(--text)}
.nav-item.active{background:var(--primary-soft);color:var(--primary-2);font-weight:600}
.nav-item .ic{width:20px;text-align:center;font-size:18px}
.nav-badge{margin-left:auto;background:var(--red);color:#fff;border-radius:20px;font-size:11px;padding:1px 7px;font-weight:700}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{
  height:60px;display:flex;align-items:center;gap:12px;padding:0 20px;
  background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:30;
}
.topbar h1{font-size:18px;margin:0}
.topbar .spacer{flex:1}
.content{padding:20px;max-width:1280px;width:100%;margin:0 auto}

/* ---------- Components ---------- */
.icon-btn{width:40px;height:40px;border-radius:11px;border:1px solid var(--border);background:var(--surface);
  display:grid;place-items:center;cursor:pointer;color:var(--text-2);font-size:18px;position:relative;transition:.15s}
.icon-btn:hover{background:var(--surface-2);color:var(--text)}
.dot{position:absolute;top:7px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--red);border:2px solid var(--surface)}

.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}
.card-h{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.card-h h3{margin:0;font-size:15px}
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
.stat .v{font-size:26px;font-weight:800;line-height:1}
.stat .l{color:var(--text-2);font-size:13px;margin-top:6px}
.stat .ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:20px;margin-bottom:10px;background:var(--primary-soft);color:var(--primary-2)}

.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;border:none;cursor:pointer;
  font-weight:600;font-size:14px;padding:10px 16px;border-radius:11px;background:var(--primary);color:#fff;transition:.15s;font-family:inherit}
.btn:hover{background:var(--primary-2)}
.btn:active{transform:scale(.98)}
.btn-ghost{background:var(--surface-2);color:var(--text)}
.btn-ghost:hover{background:var(--border)}
.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}
.btn-danger{background:var(--red)}
.btn-success{background:var(--green)}
.btn-sm{padding:6px 12px;font-size:13px;border-radius:9px}
.btn-block{width:100%}
.btn-wa{background:#25d366}.btn-wa:hover{background:#1eb455}

.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600;color:#fff}
.tag{display:inline-block;padding:2px 9px;border-radius:7px;font-size:12px;background:var(--surface-2);color:var(--text-2);border:1px solid var(--border)}

label{display:block;font-size:13px;font-weight:600;color:var(--text-2);margin:0 0 6px}
.input,select,textarea{
  width:100%;padding:11px 13px;border:1px solid var(--border);border-radius:11px;background:var(--surface);
  color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:.15s}
.input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}
.field{margin-bottom:14px}
.row{display:flex;gap:12px;flex-wrap:wrap}
.row>*{flex:1;min-width:0}

table{width:100%;border-collapse:collapse;font-size:14px}
th{text-align:left;color:var(--text-2);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em;padding:10px 12px;border-bottom:1px solid var(--border)}
td{padding:12px;border-bottom:1px solid var(--border)}
tr:last-child td{border-bottom:none}
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface)}

.alert{padding:12px 16px;border-radius:11px;margin-bottom:16px;font-size:14px;font-weight:500}
.alert-success{background:rgba(22,163,74,.12);color:var(--green);border:1px solid rgba(22,163,74,.25)}
.alert-error{background:rgba(239,68,68,.12);color:var(--red);border:1px solid rgba(239,68,68,.25)}
.alert-info{background:var(--primary-soft);color:var(--primary-2)}

/* timeline */
.timeline{position:relative;padding-left:26px}
.timeline:before{content:'';position:absolute;left:9px;top:4px;bottom:4px;width:2px;background:var(--border)}
.tl-item{position:relative;padding:0 0 18px}
.tl-item:before{content:'';position:absolute;left:-21px;top:3px;width:14px;height:14px;border-radius:50%;background:var(--primary);border:3px solid var(--surface)}
.tl-meta{font-size:12px;color:var(--muted)}
.tl-body{margin-top:3px}

/* chat */
.chat-list{display:flex;flex-direction:column;gap:10px;padding:12px}
.bubble{max-width:78%;padding:9px 13px;border-radius:14px;font-size:14px;position:relative}
.bubble.in{background:var(--surface-2);border:1px solid var(--border);align-self:flex-start;border-bottom-left-radius:4px}
.bubble.out{background:var(--primary);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.bubble .t{font-size:10px;opacity:.7;margin-top:3px;text-align:right}
.link-prev{display:block;border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-top:6px;background:var(--surface)}
.link-prev img{width:100%;height:120px;object-fit:cover;display:block}
.link-prev .lp-b{padding:8px 10px}
.link-prev .lp-t{font-weight:700;font-size:13px;color:var(--text)}
.link-prev .lp-d{font-size:12px;color:var(--text-2)}

/* ---------- Mobile bottom nav + app feel ---------- */
.bottom-nav{display:none}
.mobile-top{display:none}
.fab{display:none}

@media(max-width:860px){
  .sidebar{display:none}
  .topbar{display:none}
  .mobile-top{display:flex;align-items:center;gap:10px;height:56px;padding:0 16px;
    background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:30}
  .mobile-top h1{font-size:17px;margin:0;flex:1}
  .content{padding:14px 14px calc(var(--nav-h) + var(--safe-b) + 16px)}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr 1fr}
  .bottom-nav{
    display:flex;position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-h) + var(--safe-b));
    padding-bottom:var(--safe-b);background:var(--surface);border-top:1px solid var(--border);
    z-index:50;box-shadow:0 -2px 14px rgba(0,0,0,.06)}
  .bn-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
    color:var(--muted);font-size:10.5px;font-weight:600;position:relative}
  .bn-item .ic{font-size:21px}
  .bn-item.active{color:var(--primary)}
  .bn-item .nav-badge{position:absolute;top:6px;left:54%;font-size:9px;padding:0 5px}
  .fab{display:grid;place-items:center;position:fixed;right:18px;bottom:calc(var(--nav-h) + var(--safe-b) + 14px);
    width:56px;height:56px;border-radius:50%;background:var(--primary);color:#fff;font-size:26px;
    box-shadow:var(--shadow-lg);z-index:49;cursor:pointer;border:none}
  .card{padding:15px}
  .content h1{font-size:20px}
}
@media(min-width:861px){ .stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px} }
.stats-row{display:grid;gap:14px}

/* ---------- Bottom sheet ---------- */
.sheet-overlay{position:fixed;inset:0;background:rgba(8,12,20,.5);z-index:100;opacity:0;visibility:hidden;transition:.25s}
.sheet-overlay.open{opacity:1;visibility:visible}
.sheet{position:fixed;left:0;right:0;bottom:0;background:var(--surface);border-radius:22px 22px 0 0;z-index:101;
  transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);max-height:92vh;overflow-y:auto;
  padding:8px 18px calc(20px + var(--safe-b));box-shadow:var(--shadow-lg)}
.sheet.open{transform:translateY(0)}
.sheet-grip{width:42px;height:5px;border-radius:3px;background:var(--border);margin:8px auto 14px}
.sheet h3{margin:0 0 14px}
@media(min-width:861px){
  .sheet{left:50%;right:auto;bottom:50%;transform:translate(-50%,60%) scale(.98);width:520px;max-width:92vw;
    border-radius:var(--radius);opacity:0}
  .sheet.open{transform:translate(-50%,50%) scale(1);opacity:1}
  .sheet-grip{display:none}
}

.muted{color:var(--muted)}
.flex{display:flex;align-items:center;gap:10px}
.between{justify-content:space-between}
.mt{margin-top:16px}.mb{margin-bottom:16px}
.pill-tabs{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}
.pill-tabs a{white-space:nowrap;padding:7px 14px;border-radius:20px;background:var(--surface);border:1px solid var(--border);color:var(--text-2);font-size:13px;font-weight:600}
.pill-tabs a.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.empty{text-align:center;padding:40px 20px;color:var(--muted)}
.empty .ic{font-size:42px;opacity:.4;margin-bottom:10px}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--primary-soft);color:var(--primary-2);display:grid;place-items:center;font-weight:700;flex-shrink:0}
.list-row{display:flex;align-items:center;gap:12px;padding:12px;border-bottom:1px solid var(--border)}
.list-row:last-child{border-bottom:none}

/* ===== Hierarchy tree ===== */
.hierarchy-tree{padding:6px 2px}
.hier-node{position:relative;margin-bottom:8px}
.hier-badge{display:flex;align-items:center;gap:10px;color:#fff;padding:10px 14px;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.12)}
.hier-badge .hn-name{font-weight:800;font-size:15px}
.hier-badge .hn-meta{font-size:12px;opacity:.85}
.hier-node .hier-line{position:absolute;left:-12px;top:0;bottom:0;width:2px;background:var(--border)}
@media(max-width:640px){.hier-node{margin-left:0 !important}.hier-badge{flex-wrap:wrap}}

/* ===== Checkbox grid (campaign assign) ===== */
.check-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:4px}
.check-grid .chk{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:10px;font-size:13px;cursor:pointer;background:var(--surface)}
.check-grid .chk input{accent-color:var(--primary)}
@media(max-width:560px){.check-grid{grid-template-columns:1fr}}
