/* =========================================================
   Koobs CCH — Nebulas UI Kit
   Matches OrderTech console.ordertech.me design language
   Light/Dark via data-theme="light|dark" on <html>
   Apple-clean SaaS with glassmorphism + subtle depth
   ========================================================= */

/* ── 1. Design Tokens ──────────────────────────────────── */
:root {
  --font: ui-sans-serif, system-ui, -apple-system, "SF Pro Display", "SF Pro Text",
          "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --s4:4px; --s8:8px; --s12:12px; --s16:16px;
  --s20:20px; --s24:24px; --s32:32px; --s40:40px;
  --r8:8px; --r10:10px; --r12:12px; --r14:14px; --r16:16px; --r20:20px;
  --ease: cubic-bezier(.2,.8,.2,1);
  --t-fast:120ms; --t-med:220ms;
  --sh1: 0 1px 1px rgba(0,0,0,.03), 0 4px 16px rgba(0,0,0,.05);
  --sh2: 0 2px 6px rgba(0,0,0,.06), 0 12px 32px rgba(0,0,0,.10);
  --focus: 0 0 0 3px rgba(10,132,255,.22);
  --accent:#0A84FF; --accent-g:#30D158; --warn:#FF9F0A;
  --danger:#FF453A; --purple:#BF5AF2;
  --sidebar-w:240px; --topbar-h:56px;
}

/* ── 2. Light Theme (Nebulas) ────────────────────────── */
[data-theme="light"] {
  --bg:#F5F6F8; --panel:rgba(255,255,255,.82); --panel-solid:#FFF;
  --card:rgba(255,255,255,.9); --text:#0B0F17; --text2:rgba(11,15,23,.72);
  --muted:rgba(11,15,23,.46); --border:rgba(11,15,23,.09);
  --border2:rgba(11,15,23,.14); --hover:rgba(11,15,23,.04);
  --active-bg:rgba(10,132,255,.10); --active-text:#0B0F17;
  --active-border:rgba(10,132,255,.28);
  --glass:saturate(180%) blur(20px);
  --table-head:rgba(11,15,23,.03); --table-row:rgba(11,15,23,.02);
  --input-bg:rgba(11,15,23,.04); --scrollbar:rgba(11,15,23,.12);
  --badge-green:rgba(48,209,88,.14); --badge-red:rgba(255,69,58,.12);
  --badge-yellow:rgba(255,159,10,.12); --badge-blue:rgba(10,132,255,.12);
  --badge-purple:rgba(191,90,242,.12);
}

/* ── 3. Dark Theme (OrderTech style) ─────────────────── */
[data-theme="dark"] {
  --bg:#0C1017; --panel:rgba(20,28,44,.92); --panel-solid:#141C2C;
  --card:rgba(24,33,52,.98); --text:#F0F4FC; --text2:rgba(240,244,252,.87);
  --muted:rgba(240,244,252,.58); --border:rgba(255,255,255,.07);
  --border2:rgba(255,255,255,.13); --hover:rgba(255,255,255,.05);
  --active-bg:rgba(10,132,255,.16); --active-text:#5AABFF;
  --active-border:rgba(10,132,255,.35);
  --glass:saturate(140%) blur(20px);
  --table-head:rgba(255,255,255,.04); --table-row:rgba(255,255,255,.025);
  --input-bg:rgba(255,255,255,.07); --scrollbar:rgba(255,255,255,.14);
  --badge-green:rgba(48,209,88,.20); --badge-red:rgba(255,69,58,.20);
  --badge-yellow:rgba(255,159,10,.20); --badge-blue:rgba(10,132,255,.20);
  --badge-purple:rgba(191,90,242,.20);
}

/* ── 4. Base ──────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;font-family:var(--font);background:var(--bg);color:var(--text);
  font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
::selection{background:rgba(10,132,255,.22)}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:10px}

/* ── 5. App Layout ────────────────────────────────────── */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}

/* ── 6. Sidebar ───────────────────────────────────────── */
.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;
  background:var(--panel);backdrop-filter:var(--glass);-webkit-backdrop-filter:var(--glass);
  border-right:1px solid var(--border);overflow:hidden;z-index:50}

.sidebar-brand{display:flex;align-items:center;gap:var(--s12);
  padding:var(--s16) var(--s16) var(--s12);border-bottom:1px solid var(--border);flex-shrink:0}

.sidebar-logo-wrap{width:36px;height:36px;border-radius:var(--r10);
  overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.sidebar-logo-img{width:36px;height:36px;object-fit:cover;border-radius:var(--r10)}

.sidebar-title{font-size:15px;font-weight:700;letter-spacing:-.3px;color:var(--text);white-space:nowrap}

.sidebar-tag{font-size:10px;font-weight:700;padding:2px 6px;border-radius:6px;
  background:var(--active-bg);color:var(--accent);border:1px solid var(--active-border);letter-spacing:.5px}

.sidebar-nav{flex:1;overflow-y:auto;padding:var(--s8);display:flex;flex-direction:column;gap:1px}

.nav-group{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;
  color:var(--muted);padding:var(--s12) var(--s12) var(--s4)}

.nav-item{display:flex;align-items:center;gap:var(--s12);padding:8px var(--s12);
  border-radius:var(--r12);color:var(--text2);font-size:13.5px;font-weight:500;cursor:pointer;
  border:1px solid transparent;white-space:nowrap;
  transition:background var(--t-fast) var(--ease),color var(--t-fast) var(--ease),border-color var(--t-fast) var(--ease)}
.nav-item:hover{background:var(--hover);color:var(--text)}
.nav-item.active{background:var(--active-bg);color:var(--active-text);border-color:var(--active-border);font-weight:600}
.nav-item i{width:15px;font-size:13px;text-align:center;flex-shrink:0}
.nav-count{margin-left:auto;min-width:18px;height:18px;padding:0 5px;background:var(--danger);
  color:#fff;font-size:10px;font-weight:700;border-radius:9px;display:flex;align-items:center;justify-content:center}
.nav-count:empty{display:none}

.nav-divider{height:1px;background:var(--border);margin:var(--s8) var(--s12)}

.sidebar-footer{padding:var(--s12);border-top:1px solid var(--border);flex-shrink:0}
.user-pill{display:flex;align-items:center;gap:var(--s12);padding:var(--s8) var(--s12);
  border-radius:var(--r12);cursor:pointer;transition:background var(--t-fast) var(--ease)}
.user-pill:hover{background:var(--hover)}
.user-avatar{width:32px;height:32px;border-radius:var(--r10);
  background:linear-gradient(135deg,var(--accent),#0055cc);display:flex;
  align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}
.user-name{font-size:13px;font-weight:600;color:var(--text)}
.user-role{font-size:11px;color:var(--muted)}

/* ── 7. Topbar ────────────────────────────────────────── */
.topbar{position:sticky;top:0;z-index:40;height:var(--topbar-h);display:flex;align-items:center;
  gap:var(--s12);padding:0 var(--s24);background:var(--panel);
  backdrop-filter:var(--glass);-webkit-backdrop-filter:var(--glass);
  border-bottom:1px solid var(--border)}
.topbar-title{font-size:16px;font-weight:700;letter-spacing:-.3px;color:var(--text)}
.topbar-stats{display:flex;align-items:center;gap:var(--s8);margin-left:auto;flex-wrap:wrap}
.stat-pill{display:flex;align-items:center;gap:var(--s8);background:var(--card);
  border:1px solid var(--border);border-radius:20px;padding:5px var(--s12);
  font-size:12px;font-weight:600;white-space:nowrap}
.stat-pill i{font-size:11px}
.stat-pill small{color:var(--muted);font-weight:400}
.ch-pills{display:flex;gap:var(--s4)}
.ch-pill{font-size:10px;font-weight:700;padding:3px 8px;border-radius:10px;border:1px solid;letter-spacing:.3px}
.ch-pill.on{background:var(--badge-green);color:#27AE60;border-color:rgba(48,209,88,.25)}
.ch-pill.off{background:var(--badge-red);color:var(--danger);border-color:rgba(255,69,58,.2);text-decoration:line-through}
.topbar-actions{display:flex;align-items:center;gap:var(--s8)}

/* ── 8. Main / Content ────────────────────────────────── */
.main{display:flex;flex-direction:column;min-height:100vh;overflow:hidden}
.content{flex:1;overflow-y:auto;padding:var(--s20) var(--s24)}

/* ── 9. Panel/Card ────────────────────────────────────── */
.panel{background:var(--card);border:1px solid var(--border);border-radius:var(--r16);
  overflow:hidden;box-shadow:var(--sh1)}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:var(--s12);
  padding:var(--s16) var(--s20);border-bottom:1px solid var(--border);flex-wrap:wrap;min-height:56px}
.panel-title{display:flex;align-items:center;gap:var(--s8);font-size:15px;font-weight:700;
  letter-spacing:-.2px;color:var(--text)}
.panel-title i{color:var(--accent);font-size:13px}
.panel-actions{display:flex;align-items:center;gap:var(--s8);flex-wrap:wrap}
.panel-body{padding:var(--s20)}

/* ── 10. Table ────────────────────────────────────────── */
.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
thead{background:var(--table-head)}
th{padding:10px var(--s16);text-align:left;font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.6px;color:var(--muted);
  border-bottom:1px solid var(--border);white-space:nowrap}
td{padding:11px var(--s16);border-bottom:1px solid var(--border);
  vertical-align:middle;color:var(--text2)}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--table-row)}

/* ── 11. Badges ───────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;
  border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap;border:1px solid transparent}
.badge-sent,.badge-delivered{background:var(--badge-green);color:#27AE60;border-color:rgba(48,209,88,.22)}
.badge-failed{background:var(--badge-red);color:var(--danger);border-color:rgba(255,69,58,.22)}
.badge-suppressed{background:var(--hover);color:var(--muted);border-color:var(--border2)}
.badge-queued{background:var(--badge-yellow);color:#D4870A;border-color:rgba(255,159,10,.22)}
.badge-push{background:var(--badge-blue);color:var(--accent);border-color:rgba(10,132,255,.22)}
.badge-sms{background:var(--badge-purple);color:var(--purple);border-color:rgba(191,90,242,.22)}
.badge-email{background:var(--badge-yellow);color:#D4870A;border-color:rgba(255,159,10,.22)}
.badge-whatsapp{background:var(--badge-green);color:#27AE60;border-color:rgba(48,209,88,.22)}
.badge-in_app{background:var(--badge-yellow);color:#D4870A;border-color:rgba(255,159,10,.22)}

/* ── 12. Buttons ──────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:var(--s8);padding:0 var(--s16);height:36px;
  border-radius:var(--r12);border:1px solid var(--border2);background:var(--card);color:var(--text);
  font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;text-decoration:none;
  transition:all var(--t-fast) var(--ease)}
.btn:hover{background:var(--hover);border-color:var(--border2)}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);
  box-shadow:0 2px 10px rgba(10,132,255,.28)}
.btn-primary:hover{filter:brightness(1.1);background:var(--accent)}
.btn-warning{background:var(--warn);color:#fff;border-color:var(--warn)}
.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn-sm{height:30px;padding:0 var(--s12);font-size:12px;border-radius:var(--r10)}
.btn-block{width:100%;justify-content:center}
.theme-btn{width:34px;height:34px;border-radius:var(--r10);border:1px solid var(--border2);
  background:var(--card);display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:14px;color:var(--text2);flex-shrink:0;
  transition:all var(--t-fast) var(--ease)}
.theme-btn:hover{background:var(--hover);color:var(--text)}

/* ── 13. Forms ────────────────────────────────────────── */
.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:var(--s16)}
.form-label{font-size:12px;font-weight:600;color:var(--text2)}
.form-input,.form-select,.form-textarea{width:100%;padding:8px var(--s12);
  background:var(--input-bg);border:1px solid var(--border2);border-radius:var(--r12);
  color:var(--text);font-size:13px;
  transition:border-color var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease)}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--accent);box-shadow:var(--focus)}
.form-input-sm,.form-select-sm{height:30px;padding:4px var(--s12);font-size:12px;border-radius:var(--r10)}

/* Panel action controls: auto-width so they sit side by side */
.panel-actions select,.panel-actions .form-select,.panel-actions .form-select-sm{
  width:auto;min-width:100px;max-width:160px}
.panel-actions input,.panel-actions .form-input,.panel-actions .form-input-sm{
  width:auto;min-width:120px;max-width:180px}
.form-textarea{resize:vertical}
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--s12)}

/* ── 14. Pagination ───────────────────────────────────── */
.pagination{display:flex;align-items:center;justify-content:flex-end;gap:var(--s8);
  padding:var(--s16) var(--s20);border-top:1px solid var(--border)}
.page-info{font-size:12px;color:var(--muted)}
.page-btn{min-width:32px;height:32px;padding:0 var(--s12);background:var(--card);
  border:1px solid var(--border2);border-radius:var(--r10);font-size:12px;font-weight:600;
  cursor:pointer;color:var(--text2);transition:all var(--t-fast) var(--ease)}
.page-btn:hover:not(:disabled){background:var(--hover);color:var(--text)}
.page-btn:disabled{opacity:.35;cursor:not-allowed}

/* ── 15. Empty state ──────────────────────────────────── */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:var(--s8);padding:48px var(--s20);color:var(--muted);font-size:13px;text-align:center}
.empty-state i{font-size:28px;opacity:.3}

/* ── 16. Skeleton ─────────────────────────────────────── */
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
.skeleton{border-radius:var(--r8);height:36px;margin-bottom:8px;
  background:linear-gradient(90deg,var(--hover) 25%,var(--border2) 50%,var(--hover) 75%);
  background-size:200% 100%;animation:shimmer 1.4s infinite}

/* ── 17. Toggle ───────────────────────────────────────── */
.toggle{position:relative;width:40px;height:22px;flex-shrink:0;cursor:pointer}
.toggle-track{position:absolute;inset:0;border-radius:11px;transition:background var(--t-med) var(--ease)}
.toggle-track.on{background:var(--accent-g)} .toggle-track.off{background:var(--border2)}
.toggle-knob{position:absolute;top:2px;width:18px;height:18px;background:#fff;border-radius:50%;
  box-shadow:0 1px 4px rgba(0,0,0,.2);transition:left var(--t-med) var(--ease)}
.toggle-track.on .toggle-knob{left:20px} .toggle-track.off .toggle-knob{left:2px}

/* ── 18. Info Banner ──────────────────────────────────── */
.info-banner{display:flex;align-items:center;gap:var(--s8);padding:var(--s8) var(--s12);
  background:var(--active-bg);border:1px solid var(--active-border);border-radius:var(--r12);
  font-size:12px;color:var(--accent);margin-bottom:var(--s16)}

/* ── 19. Bar Chart ────────────────────────────────────── */
.bar-chart{display:flex;flex-direction:column;gap:var(--s8);margin-top:var(--s8)}
.bar-row{display:flex;align-items:center;gap:var(--s8);font-size:12px}
.bar-label{width:72px;text-align:right;color:var(--muted);flex-shrink:0}
.bar-track{flex:1;height:7px;background:var(--hover);border-radius:4px;overflow:hidden}
.bar-fill{height:100%;border-radius:4px;background:var(--accent);transition:width .5s var(--ease)}
.bar-val{width:36px;text-align:right;font-weight:600;flex-shrink:0}

/* ── 20. Grids ────────────────────────────────────────── */
.send-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:var(--s20)}
.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--s16)}
.channels-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--s16)}
.analytics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--s16)}

/* ── 21. Template/Channel Cards ──────────────────────── */
.tmpl-card,.channel-card{background:var(--card);border:1px solid var(--border);
  border-radius:var(--r16);padding:var(--s16);box-shadow:var(--sh1)}
.tmpl-name,.channel-name{font-size:13px;font-weight:700;color:var(--text);
  display:flex;align-items:center;gap:var(--s8)}
.tmpl-body{font-size:12px;color:var(--text2);line-height:1.6;margin-top:var(--s8)}
.tmpl-body-ar{direction:rtl;font-size:12px;color:var(--muted);margin-top:var(--s4)}
.tmpl-footer,.channel-footer{display:flex;gap:var(--s8);margin-top:var(--s12)}
.channel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--s12)}
.channel-detail{font-size:12px;color:var(--muted);line-height:2}

/* ── 22. Modal ────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.48);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;padding:var(--s20);z-index:200}
.modal-overlay.open{display:flex}
.modal{background:var(--panel-solid);border:1px solid var(--border2);border-radius:var(--r20);
  width:100%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--sh2);
  animation:modal-in .18s var(--ease)}
.modal-lg{max-width:760px}
@keyframes modal-in{from{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:none}}
.modal-header{display:flex;justify-content:space-between;align-items:center;
  padding:var(--s16) var(--s20);border-bottom:1px solid var(--border);flex-shrink:0}
.modal-title{font-size:15px;font-weight:700;display:flex;align-items:center;gap:var(--s8);color:var(--text)}
.modal-title i{color:var(--accent)}
.modal-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;
  background:none;border:none;cursor:pointer;color:var(--muted);font-size:14px;border-radius:var(--r8);
  transition:background var(--t-fast) var(--ease),color var(--t-fast) var(--ease)}
.modal-close:hover{background:var(--hover);color:var(--text)}
.modal-body{padding:var(--s20);overflow-y:auto;flex:1}
.modal-footer{padding:var(--s12) var(--s20);border-top:1px solid var(--border);
  display:flex;justify-content:flex-end;gap:var(--s8);flex-shrink:0}

/* ── 23. Toast ────────────────────────────────────────── */
#toastContainer{position:fixed;bottom:20px;right:20px;z-index:500;
  display:flex;flex-direction:column;gap:var(--s8)}
.toast{display:flex;align-items:center;gap:var(--s12);padding:var(--s12) var(--s16);
  background:var(--panel-solid);border:1px solid var(--border2);border-radius:var(--r14);
  font-size:13px;font-weight:500;min-width:260px;max-width:380px;box-shadow:var(--sh2);
  animation:toast-in .2s var(--ease)}
@keyframes toast-in{from{opacity:0;transform:translateY(8px)}}
.toast--success{border-left:3px solid var(--accent-g)}
.toast--error{border-left:3px solid var(--danger)}
.toast--info{border-left:3px solid var(--accent)}

/* ── 24. Intercom Card ────────────────────────────────── */
.intercom-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r16);
  padding:var(--s16) var(--s20);display:flex;gap:var(--s16);align-items:flex-start;
  margin-bottom:var(--s16);box-shadow:var(--sh1)}
.intercom-icon{font-size:28px;color:#5453BC;flex-shrink:0}
.intercom-card p{font-size:12px;color:var(--muted);margin:var(--s4) 0 var(--s12)}

/* ── 25. Login Page ───────────────────────────────────── */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:var(--bg);padding:var(--s20)}
.login-card{background:var(--panel);border:1px solid var(--border2);border-radius:var(--r20);
  padding:var(--s32) var(--s40);width:100%;max-width:400px;text-align:center;
  box-shadow:var(--sh2);display:flex;flex-direction:column;align-items:center;gap:var(--s20)}
.login-logo{width:64px;height:64px;border-radius:18px;
  background:linear-gradient(135deg,#C9A84C,#7C5217);display:flex;
  align-items:center;justify-content:center;font-size:28px;
  box-shadow:0 4px 20px rgba(124,82,23,.3)}
.login-heading{font-size:22px;font-weight:800;letter-spacing:-.5px;color:var(--text)}
.login-sub{font-size:14px;color:var(--muted)}
.login-error{font-size:13px;color:var(--danger);min-height:18px}
.btn-zoho{display:flex;align-items:center;justify-content:center;gap:var(--s12);
  width:100%;height:44px;border-radius:var(--r14);background:var(--accent);color:#fff;
  font-size:14px;font-weight:700;border:none;cursor:pointer;
  box-shadow:0 4px 14px rgba(10,132,255,.3);
  transition:filter var(--t-fast) var(--ease),transform var(--t-fast) var(--ease)}
.btn-zoho:hover{filter:brightness(1.08)} .btn-zoho:active{transform:translateY(1px)}

/* ── 26. Misc ─────────────────────────────────────────── */
.text-muted{color:var(--muted)} .text-sm{font-size:11px}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}
.flex{display:flex;align-items:center} .gap4{gap:var(--s4)} .gap8{gap:var(--s8)}
.mt8{margin-top:var(--s8)} .mt16{margin-top:var(--s16)}

/* ── 27. Responsive ───────────────────────────────────── */
@media(max-width:860px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-100%;transition:left var(--t-med) var(--ease)}
  .sidebar.open{left:0}
  .topbar-stats{display:none}
}
@media(max-width:600px){
  .content{padding:var(--s16)}
  .panel-head{padding:var(--s12) var(--s16)}
}
