/* NGL Access Manager — shared styles */
:root{
  --navy:#002369; --navy-700:#001a4f; --navy-50:#f0f4ff;
  --yellow:#DDE000; --cyan:#00AEEF;
  --gray-50:#fafbfc; --gray-100:#f1f3f6; --gray-200:#e2e5ea;
  --gray-300:#cdd2d9; --gray-500:#6b7380; --gray-700:#3a414d; --gray-900:#1a1f29;
  --green:#1b9e4b; --amber:#d97706; --red:#dc2626;
  --r-sm:6px; --r-md:10px; --r-lg:14px;
  --shadow:0 1px 2px rgba(0,30,90,.04),0 4px 16px rgba(0,30,90,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:'Montserrat',Arial,sans-serif;color:var(--gray-900);background:var(--gray-100);font-size:14px}
button{font-family:inherit;cursor:pointer}
a{color:var(--navy);text-decoration:none}

.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.sidebar{background:var(--navy);color:#fff;padding:22px 0;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:10px;padding:0 22px 24px;border-bottom:1px solid rgba(255,255,255,.1)}
.brand-mark{width:36px;height:36px;background:#fff;color:var(--navy);border-radius:7px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px}
.brand-text{font-weight:700;font-size:14px;line-height:1.1}
.brand-sub{font-size:11px;opacity:.7;margin-top:2px}
.nav{padding:16px 12px}
.nav-item{display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:var(--r-sm);cursor:pointer;color:rgba(255,255,255,.85);font-weight:500;font-size:13px;text-decoration:none}
.nav-item:hover{background:rgba(255,255,255,.08);color:#fff}
.nav-item.active{background:rgba(255,255,255,.14);color:#fff;font-weight:600}
.nav-item .icon{width:18px;text-align:center}

.main{padding:0;min-height:100vh}
.topbar{background:#fff;border-bottom:1px solid var(--gray-200);padding:18px 32px;display:flex;justify-content:space-between;align-items:center}
.topbar h1{margin:0;font-size:20px;font-weight:700;color:var(--navy)}
.topbar-sub{font-size:12px;color:var(--gray-500);margin-top:3px}
.crumb{font-size:12px;color:var(--gray-500);margin-bottom:4px}

.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:var(--r-sm);font-weight:600;font-size:13px;border:0;transition:all .12s}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--navy-700)}
.btn-ghost{background:#fff;color:var(--navy);border:1px solid var(--gray-200)}
.btn-ghost:hover{background:var(--gray-50)}
.btn-danger{background:#fff;color:var(--red);border:1px solid #fcc;padding:6px 10px;font-size:12px}

.content{padding:24px 32px 60px}

.tabs{display:flex;gap:0;border-bottom:1px solid var(--gray-200);margin-bottom:24px}
.tab{padding:11px 18px;font-size:13px;font-weight:600;color:var(--gray-500);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;display:flex;align-items:center;gap:7px}
.tab:hover{color:var(--gray-900)}
.tab.active{color:var(--navy);border-bottom-color:var(--navy)}
.tab-count{background:var(--gray-100);padding:1px 8px;border-radius:999px;font-size:11px}
.tab.active .tab-count{background:var(--navy-50);color:var(--navy)}

.app-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.app-card{background:#fff;border-radius:var(--r-md);box-shadow:var(--shadow);padding:16px;cursor:pointer;transition:all .12s;border:2px solid transparent;text-decoration:none;display:block;color:inherit}
.app-card:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,30,90,.1);border-color:var(--gray-200)}
.app-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}
.app-title{font-weight:700;font-size:14px;color:var(--gray-900);display:flex;align-items:center;gap:8px}
.app-status{font-size:10px;font-weight:700;padding:2px 7px;border-radius:999px;letter-spacing:.04em;text-transform:uppercase}
.app-status.live{background:#dcfce7;color:#166534}
.app-status.building{background:#fef3c7;color:#92400e}
.app-status.draft{background:#f1f5f9;color:#475569}
.app-desc{font-size:11px;color:var(--gray-500);margin-bottom:8px;line-height:1.4}
.who-line{font-size:11px;color:var(--gray-700);display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.who-pill{background:var(--navy-50);color:var(--navy);padding:2px 8px;border-radius:var(--r-sm);font-weight:600}
.who-pill.customer{background:#fef3c7;color:#92400e}
.who-pill.contractor{background:#dcfce7;color:#166534}
.who-pill.scoper{background:#f3e8ff;color:#6b21a8}

.app-header{background:#fff;border-radius:var(--r-md);box-shadow:var(--shadow);padding:22px 26px;margin-bottom:24px;display:flex;gap:18px;align-items:flex-start}
.icon-circle{width:54px;height:54px;border-radius:var(--r-md);background:var(--navy-50);display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}

.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:14px;flex-wrap:wrap}
.search{flex:1;min-width:260px;position:relative}
.search input{width:100%;padding:9px 12px 9px 34px;border:1px solid var(--gray-200);border-radius:var(--r-sm);font-family:inherit;font-size:13px;background:#fff}

.people-card{background:#fff;border-radius:var(--r-md);box-shadow:var(--shadow);overflow:hidden}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{text-align:left;padding:12px 16px;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-500);background:var(--gray-50);border-bottom:1px solid var(--gray-200)}
tbody td{padding:13px 16px;border-bottom:1px solid var(--gray-100);vertical-align:middle}
tbody tr:hover{background:var(--gray-50)}
tbody tr:last-child td{border-bottom:0}
.avatar{width:32px;height:32px;border-radius:50%;background:var(--navy-50);color:var(--navy);display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;margin-right:10px;vertical-align:middle}
.user-cell{display:flex;align-items:center}
.user-name{font-weight:600;color:var(--gray-900)}
.user-email{font-size:11px;color:var(--gray-500)}
.type-tag{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700}
.type-staff{background:#e7eeff;color:var(--navy)}
.type-customer{background:#fef3c7;color:#92400e}
.type-contractor{background:#dcfce7;color:#166534}
.type-scoper{background:#f3e8ff;color:#6b21a8}
.level-select{padding:6px 10px;border:1px solid var(--gray-200);border-radius:var(--r-sm);font-family:inherit;font-size:12px;background:#fff;font-weight:600;color:var(--navy)}

.modal-backdrop{position:fixed;inset:0;background:rgba(0,15,40,.5);display:none;align-items:center;justify-content:center;z-index:100}
.modal-backdrop.open{display:flex}
.modal{background:#fff;border-radius:var(--r-lg);width:500px;max-width:92vw;box-shadow:0 20px 50px rgba(0,15,40,.25)}
.modal-head{padding:22px 26px 14px;border-bottom:1px solid var(--gray-200)}
.modal-head h2{margin:0;font-size:17px;font-weight:700;color:var(--navy)}
.modal-head p{margin:4px 0 0;color:var(--gray-500);font-size:12px}
.modal-body{padding:18px 26px}
.modal-foot{padding:14px 26px;border-top:1px solid var(--gray-200);display:flex;justify-content:space-between;gap:10px;background:var(--gray-50);border-radius:0 0 var(--r-lg) var(--r-lg)}
.field{margin-bottom:14px}
.field-q{font-size:12px;font-weight:600;color:var(--gray-700);margin-bottom:6px}
.field-input,.field-select{width:100%;padding:10px 12px;border:1px solid var(--gray-200);border-radius:var(--r-sm);font-family:inherit;font-size:13px;background:#fff}
.field-help{font-size:11px;color:var(--gray-500);margin-top:4px;line-height:1.4}

.setup-grid{display:grid;grid-template-columns:1fr;gap:20px}
.setup-card{background:#fff;border-radius:var(--r-md);box-shadow:var(--shadow);padding:20px 24px}
.setup-card h3{margin:0 0 4px;font-size:14px;font-weight:700;color:var(--navy)}
.setup-card p.help{margin:0 0 14px;font-size:12px;color:var(--gray-500);line-height:1.45}
.level-list{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.level-row{display:flex;gap:8px;align-items:center;padding:10px 13px;background:var(--gray-50);border-radius:var(--r-sm)}
.level-name{font-weight:700;color:var(--navy);min-width:120px;font-size:12px}
.level-restriction{font-size:10px;color:#6b21a8;background:#f3e8ff;padding:1px 7px;border-radius:3px;font-weight:700;margin-left:6px}
.level-desc{flex:1;font-size:12px;color:var(--gray-700)}

.empty-state{padding:60px 30px;text-align:center;color:var(--gray-500)}
.empty-state .ic{font-size:36px;margin-bottom:10px;opacity:.5}

.loading{padding:40px;text-align:center;color:var(--gray-500);font-size:13px}

.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(180deg,#f0f4ff 0%,#fafbfc 60%)}
.login-card{width:440px;max-width:100%;background:#fff;border-radius:var(--r-lg);box-shadow:0 6px 30px rgba(0,30,90,.08);padding:36px 38px}
.login-logo{display:flex;align-items:center;gap:11px;margin-bottom:24px}
.login-logo-mark{width:46px;height:46px;background:var(--navy);color:#fff;border-radius:9px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px}
.login-logo-text{font-weight:700;font-size:16px;color:var(--navy);line-height:1.1}
.login-logo-sub{font-size:11px;color:var(--gray-500);margin-top:2px}
.login-heading{font-size:18px;font-weight:700;color:var(--gray-900);margin:8px 0 4px}
.login-sub{font-size:13px;color:var(--gray-500);margin-bottom:22px;line-height:1.45}
.form-group{margin-bottom:14px}
.form-label{display:block;font-size:12px;font-weight:600;color:var(--gray-700);margin-bottom:6px}
.form-input{width:100%;padding:10px 12px;border:1px solid var(--gray-200);border-radius:var(--r-sm);font-family:inherit;font-size:13px;background:#fff}
.btn-primary.full{width:100%;justify-content:center;padding:11px}
.login-footer{margin-top:18px;font-size:11px;color:var(--gray-500);text-align:center;line-height:1.5}
