/* ============================================================
   WorkOS Multi-Company Platform — Stylesheet
   ============================================================ */
:root {
  --indigo:#5B48F5; --indigo-lt:#EEF0FE; --indigo-dk:#3C2FC0;
  --green:#1D9E75;  --green-lt:#E1F5EE;
  --red:#E24B4A;    --red-lt:#FDEEEE;
  --amber:#EF9F27;  --amber-lt:#FEF3DE;
  --blue:#378ADD;   --blue-lt:#E6F1FB;
  --coral:#D85A30;  --coral-lt:#FAECE7;
  --sidebar:#141825;
  --surface:#FFFFFF; --bg:#F4F5F7;
  --border:rgba(0,0,0,0.09);
  --text:#1A1A2E; --muted:#6B7280; --hint:#9CA3AF;
  --shadow:0 2px 12px rgba(0,0,0,0.08);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;font-size:14px;color:var(--text);background:var(--bg)}

/* ---- Login ----------------------------------------------- */
.login-mode{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#1A1F2E 0%,#2D3561 100%)}
.login-wrap{width:100%;max-width:420px;padding:20px}
.login-card{background:var(--surface);border-radius:16px;padding:36px 32px;box-shadow:0 20px 60px rgba(0,0,0,0.25)}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:28px}
.logo-icon{width:40px;height:40px;background:var(--indigo);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;flex-shrink:0}
.logo-icon.sm{width:32px;height:32px;font-size:16px;border-radius:8px}
.logo-name{font-size:18px;font-weight:600;color:var(--text)}
.logo-sub{font-size:11px;color:var(--muted)}
.login-hint{background:var(--bg);border-radius:8px;padding:12px;font-size:11px;color:var(--muted);margin-top:14px;line-height:1.8}

/* ---- App shell ------------------------------------------- */
.app-mode{display:flex;height:100vh;overflow:hidden}
#app{display:flex;width:100%;height:100vh;overflow:hidden}

/* ---- Sidebar --------------------------------------------- */
#sidebar{width:230px;min-width:230px;background:var(--sidebar);display:flex;flex-direction:column;height:100vh}
.sb-top{flex:1;overflow-y:auto;padding:0 0 12px}
.sb-logo{padding:18px 16px 12px;display:flex;align-items:center;gap:10px;border-bottom:0.5px solid rgba(255,255,255,0.07)}
.role-badge{font-size:9px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;padding:2px 6px;border-radius:4px;margin-top:3px;display:inline-block}
.role-super_admin{background:#5B48F5;color:#fff}
.role-company_admin{background:#1D9E75;color:#fff}
.role-user{background:rgba(255,255,255,0.15);color:rgba(255,255,255,0.7)}
.company-pill{margin:10px 10px 4px;background:rgba(255,255,255,0.07);border-radius:8px;padding:7px 10px;display:flex;align-items:center;gap:7px;font-size:12px;color:rgba(255,255,255,0.7);border:0.5px solid rgba(255,255,255,0.1)}
.company-pill i{font-size:14px;color:var(--indigo)}
nav{padding:4px 6px}
.nav-section{font-size:10px;font-weight:600;color:rgba(255,255,255,0.25);letter-spacing:.07em;text-transform:uppercase;padding:12px 8px 4px}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:8px;cursor:pointer;color:rgba(255,255,255,0.5);font-size:13px;text-decoration:none;margin-bottom:1px;transition:all .12s}
.nav-item i{font-size:17px;flex-shrink:0}
.nav-item:hover{background:rgba(255,255,255,0.07);color:rgba(255,255,255,0.85)}
.nav-item.active{background:var(--indigo);color:#fff}
.nav-badge{margin-left:auto;background:rgba(255,255,255,0.15);color:rgba(255,255,255,0.7);font-size:10px;padding:1px 6px;border-radius:8px;font-weight:500}
.nav-item.active .nav-badge{background:rgba(255,255,255,0.25)}
.sb-bottom{border-top:0.5px solid rgba(255,255,255,0.07);padding:10px 8px}
.sb-user{display:flex;align-items:center;gap:9px;padding:8px 8px;border-radius:8px;cursor:pointer}
.sb-user:hover{background:rgba(255,255,255,0.06)}
.user-av{width:30px;height:30px;border-radius:50%;background:var(--indigo);display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:600;flex-shrink:0}
.user-info{flex:1;min-width:0}
.user-name{color:rgba(255,255,255,0.8);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{color:rgba(255,255,255,0.3);font-size:10px}
.logout-btn{background:none;border:none;color:rgba(255,255,255,0.3);cursor:pointer;font-size:17px;padding:4px;border-radius:5px}
.logout-btn:hover{color:rgba(255,255,255,0.7);background:rgba(255,255,255,0.08)}

/* ---- Main ------------------------------------------------ */
#main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
#topbar{background:var(--surface);border-bottom:0.5px solid var(--border);padding:0 24px;height:54px;display:flex;align-items:center;gap:14px;flex-shrink:0}
.tb-left{flex:1;min-width:0}
.page-title{font-size:15px;font-weight:600}
.page-crumb{font-size:11px;color:var(--muted)}
.tb-right{display:flex;align-items:center;gap:10px}
.search-wrap{display:flex;align-items:center;gap:7px;background:var(--bg);border:0.5px solid var(--border);border-radius:8px;padding:6px 12px;width:200px}
.search-wrap i{color:var(--hint);font-size:14px}
.search-wrap input{border:none;background:none;outline:none;font-size:12px;color:var(--text);width:100%}
.icon-btn{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);border:0.5px solid var(--border);background:var(--surface);position:relative}
.icon-btn:hover{background:var(--bg)}
.notif-dot{position:absolute;top:7px;right:7px;width:7px;height:7px;background:var(--red);border-radius:50%;border:1.5px solid var(--surface)}
#content{flex:1;overflow-y:auto;padding:20px 24px}

/* ---- Spinner --------------------------------------------- */
.spinner{display:flex;align-items:center;justify-content:center;height:200px;color:var(--hint)}
.spinner i{font-size:28px;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---- Cards ----------------------------------------------- */
.card{background:var(--surface);border:0.5px solid var(--border);border-radius:12px;padding:16px 18px}
.card-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.card-title{font-size:13px;font-weight:600}
.card-sub{font-size:11px;color:var(--muted);margin-top:2px}

/* ---- Stats grid ------------------------------------------ */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.stat-card{background:var(--surface);border:0.5px solid var(--border);border-radius:12px;padding:16px}
.stat-label{font-size:11px;color:var(--muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}
.stat-value{font-size:26px;font-weight:600;line-height:1}
.stat-bar{height:3px;border-radius:2px;margin-top:10px;overflow:hidden;background:var(--border)}
.stat-fill{height:100%;border-radius:2px}

/* ---- Tables ---------------------------------------------- */
.table-wrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;font-size:12px}
table.tbl th{text-align:left;font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;padding:0 10px 10px 0;border-bottom:0.5px solid var(--border);white-space:nowrap}
table.tbl td{padding:10px 10px 10px 0;border-bottom:0.5px solid var(--border);vertical-align:middle}
table.tbl tr:last-child td{border-bottom:none}
table.tbl tr:hover td{background:#FAFAFA}

/* ---- Badges ---------------------------------------------- */
.badge{display:inline-block;font-size:10px;font-weight:500;padding:2px 8px;border-radius:5px}
.badge-active{background:var(--green-lt);color:#0F6E56}
.badge-suspended{background:var(--red-lt);color:#A32D2D}
.badge-invited{background:var(--amber-lt);color:#854F0B}
.badge-super_admin{background:var(--indigo-lt);color:var(--indigo-dk)}
.badge-company_admin{background:var(--blue-lt);color:#185FA5}
.badge-user{background:var(--bg);color:var(--muted)}
.badge-bidi{background:var(--green-lt);color:#0F6E56}
.badge-one{background:var(--amber-lt);color:#854F0B}

/* ---- Forms ----------------------------------------------- */
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:12px;color:var(--muted);margin-bottom:5px;font-weight:500}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:7px 10px;border:0.5px solid var(--border);border-radius:7px;font-size:13px;color:var(--text);background:var(--surface);outline:none;font-family:inherit}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--indigo);box-shadow:0 0 0 2px rgba(91,72,245,.1)}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ---- Buttons --------------------------------------------- */
.btn-primary{background:var(--indigo);color:#fff;border:none;border-radius:8px;padding:7px 16px;font-size:13px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:5px;white-space:nowrap}
.btn-primary:hover{background:var(--indigo-dk)}
.btn-ghost{background:var(--surface);color:var(--muted);border:0.5px solid var(--border);border-radius:8px;padding:6px 12px;font-size:12px;cursor:pointer;display:inline-flex;align-items:center;gap:5px}
.btn-ghost:hover{background:var(--bg)}
.btn-danger{background:var(--red-lt);color:var(--red);border:0.5px solid var(--red-lt);border-radius:8px;padding:5px 10px;font-size:11px;cursor:pointer}
.btn-danger:hover{background:var(--red);color:#fff}
.btn-full{width:100%;justify-content:center;padding:10px}
.btn-sm{padding:4px 10px;font-size:11px}
.link-btn{background:none;border:none;color:var(--indigo);font-size:11px;cursor:pointer;padding:0}

/* ---- Alerts ---------------------------------------------- */
.alert{padding:10px 12px;border-radius:8px;font-size:12px;margin-bottom:12px}
.alert-error{background:var(--red-lt);color:#A32D2D}
.alert-success{background:var(--green-lt);color:#0F6E56}
.alert-info{background:var(--indigo-lt);color:var(--indigo-dk)}

/* ---- Modal ----------------------------------------------- */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:200}
.modal-box{background:var(--surface);border-radius:14px;width:500px;max-width:95vw;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.modal-hd{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:0.5px solid var(--border);font-size:14px;font-weight:600}
.modal-close{background:none;border:none;cursor:pointer;font-size:18px;color:var(--muted);padding:2px}
.modal-body{padding:16px 20px;max-height:65vh;overflow-y:auto}
.modal-footer{padding:12px 20px;border-top:0.5px solid var(--border);display:flex;justify-content:flex-end;gap:8px}

/* ---- Notifications panel --------------------------------- */
.notif-panel{position:fixed;top:54px;right:20px;width:340px;background:var(--surface);border:0.5px solid var(--border);border-radius:12px;box-shadow:var(--shadow);z-index:100;max-height:480px;overflow:hidden;display:flex;flex-direction:column}
.notif-panel-hd{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:0.5px solid var(--border);font-size:13px;font-weight:600}
#notif-list-items{overflow-y:auto;flex:1}
.notif-row{display:flex;gap:10px;padding:10px 16px;border-bottom:0.5px solid var(--border);cursor:pointer}
.notif-row:hover{background:var(--bg)}
.notif-row.unread{background:var(--indigo-lt)}
.notif-icon-wrap{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.notif-content{flex:1;min-width:0}
.notif-title{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.notif-body{font-size:11px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.notif-time{font-size:10px;color:var(--hint);margin-top:3px}

/* ---- Grid layouts ---------------------------------------- */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.content-grid{display:grid;grid-template-columns:1fr 320px;gap:14px}

/* ---- Message thread -------------------------------------- */
.msg-thread{display:flex;flex-direction:column;gap:10px;padding:14px 0}
.msg-bubble{max-width:75%;padding:10px 14px;border-radius:12px;font-size:13px;line-height:1.6}
.msg-bubble.mine{background:var(--indigo);color:#fff;align-self:flex-end;border-radius:12px 12px 4px 12px}
.msg-bubble.theirs{background:var(--bg);border:0.5px solid var(--border);align-self:flex-start;border-radius:12px 12px 12px 4px}
.msg-meta{font-size:10px;color:var(--hint);margin-top:4px;text-align:right}
.msg-meta.theirs{text-align:left}
.msg-row{display:flex;flex-direction:column}
.msg-row.mine{align-items:flex-end}

/* ---- Scope arrows ---------------------------------------- */
.scope-arrow{font-size:18px;color:var(--indigo);margin:0 6px}

/* ---- Activity feed --------------------------------------- */
.activity-item{display:flex;gap:10px;padding:8px 0;border-bottom:0.5px solid var(--border)}
.activity-item:last-child{border-bottom:none}
.act-av{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;background:var(--indigo-lt);color:var(--indigo-dk);flex-shrink:0}
.act-text{font-size:12px;color:var(--muted);line-height:1.5}
.act-text strong{color:var(--text)}
.act-time{font-size:10px;color:var(--hint);margin-top:2px}

/* ---- Responsive ------------------------------------------ */
@media(max-width:900px){
  .stats-grid{grid-template-columns:1fr 1fr}
  .content-grid{grid-template-columns:1fr}
  .grid2,.grid3{grid-template-columns:1fr}
}
@media(max-width:640px){
  #sidebar{display:none}
  .stats-grid{grid-template-columns:1fr 1fr}
}
