:root{
  --navy:#10233f; --navy-2:#16315a; --paper:#f6f7f9; --ink:#1b2433;
  --line:#dfe3ea; --muted:#6b7587; --accent:#c4622d; --accent-2:#e8a23d;
  --green:#2f7d5e; --red:#b3402f; --amber:#b8852a; --white:#ffffff;
}
*{box-sizing:border-box;}
body{margin:0;font-family:"Inter",Arial,sans-serif;background:var(--paper);color:var(--ink);}
h1,h2,h3,h4{font-family:"Georgia","Times New Roman",serif;margin:0;letter-spacing:.2px;}
::-webkit-scrollbar{width:8px;height:8px;}
::-webkit-scrollbar-thumb{background:#c9ccd4;border-radius:4px;}
a{color:var(--navy);}

/* ===== LOGIN ===== */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--navy) 0%,#0c1a30 60%,#1d3661 100%);padding:20px;}
.login-card{background:#fff;border-radius:14px;width:100%;max-width:400px;padding:30px 28px;box-shadow:0 20px 60px rgba(0,0,0,.35);}
.login-brand{display:flex;align-items:center;gap:10px;margin-bottom:22px;}
.login-brand .mark{width:38px;height:38px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-family:Georgia,serif;font-weight:bold;color:#1b1208;font-size:18px;}
.login-brand .name{font-family:Georgia,serif;font-size:19px;}
.login-brand .name small{display:block;font-family:Arial,sans-serif;font-size:10px;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;}
.login-card h2{font-size:17px;margin-bottom:4px;}
.login-card .sub{color:var(--muted);font-size:12.5px;margin-bottom:18px;}
.demo-box{margin-top:18px;border-top:1px solid var(--line);padding-top:14px;}
.demo-box .lbl{font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:8px;}
.demo-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;}
.demo-chip{border:1px solid var(--line);border-radius:7px;padding:7px 8px;font-size:11.3px;cursor:pointer;background:#fafbfc;text-align:left;text-decoration:none;color:var(--ink);}
.demo-chip:hover{border-color:var(--accent);background:#fdf3ec;}
.demo-chip b{display:block;font-size:11.8px;}
.otp-box input{text-align:center;font-size:22px;letter-spacing:6px;}

/* ===== SHELL ===== */
html,body{height:100%;}
/* The .main region scrolls, not the window. .shell is exactly one viewport tall,
   so the app never produces a body scrollbar; the login (guest) page is unaffected. */
.shell{display:grid;grid-template-columns:230px 1fr;height:100vh;overflow:hidden;}
/* Sidebar: full height, does not scroll as a whole. Brand + user-box are pinned;
   only the <nav> list scrolls when the menu is taller than the viewport. */
.side{background:var(--navy);color:#dfe6f2;padding:0;display:flex;flex-direction:column;height:100vh;overflow:hidden;position:relative;}
.brand{flex:0 0 auto;display:flex;align-items:center;gap:10px;padding:16px 16px 14px;border-bottom:1px solid #2a3f63;}
.brand .mark{width:30px;height:30px;border-radius:6px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-family:Georgia,serif;font-weight:bold;color:#1b1208;}
.brand .name{font-family:Georgia,serif;font-size:15px;line-height:1.1;}
.brand .name small{display:block;font-family:Arial,sans-serif;font-size:10px;letter-spacing:1.5px;color:#90a2c2;text-transform:uppercase;}
.side nav{flex:1 1 auto;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:2px;padding:12px;}
.side nav::-webkit-scrollbar{width:6px;}
.side nav::-webkit-scrollbar-thumb{background:#2a3f63;border-radius:3px;}
.side nav{scrollbar-width:thin;scrollbar-color:#2a3f63 transparent;}
.nav-item{padding:9px 10px;border-radius:7px;font-size:13.5px;cursor:pointer;color:#c4cfe2;display:flex;align-items:center;gap:9px;text-decoration:none;}
.nav-item:hover{background:#1c3460;color:#fff;}
.nav-item.active{background:var(--accent);color:#fff;}
.nav-item .dot{width:6px;height:6px;border-radius:50%;background:#5f72a3;flex:0 0 auto;}
.nav-item.active .dot{background:#fff;}
.side .user-box{flex:0 0 auto;padding:12px 14px 16px;border-top:1px solid #2a3f63;background:var(--navy);position:relative;}
.user-trigger{display:flex;align-items:center;gap:10px;width:100%;background:transparent;border:1px solid #2a3f63;border-radius:8px;padding:8px 10px;cursor:pointer;text-align:left;color:#dfe6f2;}
.user-trigger:hover{background:#1c3460;}
.user-trigger .uavatar{width:34px;height:34px;flex:0 0 auto;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;color:#1b1208;font-family:Georgia,serif;font-weight:bold;font-size:15px;}
.user-trigger .uinfo{display:flex;flex-direction:column;min-width:0;flex:1 1 auto;}
.user-trigger .who{font-size:12.5px;color:#dfe6f2;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.user-trigger .role{font-size:10.5px;color:#90a2c2;text-transform:uppercase;letter-spacing:.5px;}
.user-trigger .ucaret{flex:0 0 auto;color:#90a2c2;font-size:12px;transition:transform .18s;}
.user-box.menu-open .user-trigger .ucaret{transform:rotate(180deg);}
/* Menu pops upward above the trigger (user-box sits at the bottom of the sidebar). */
.user-menu{position:absolute;left:14px;right:14px;bottom:calc(100% - 8px);background:#16315a;border:1px solid #2a3f63;border-radius:8px;padding:6px;box-shadow:0 -10px 30px rgba(0,0,0,.35);display:flex;flex-direction:column;gap:2px;opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .15s,transform .15s,visibility .15s;z-index:30;}
.user-box.menu-open .user-menu{opacity:1;visibility:visible;transform:translateY(0);}
.umenu-item{display:block;width:100%;text-align:left;background:transparent;border:none;color:#c4cfe2;padding:9px 10px;border-radius:6px;font-size:12.5px;cursor:pointer;text-decoration:none;}
.umenu-item:hover{background:#1c3460;color:#fff;}
.umenu-item.danger:hover{background:#5a2320;color:#fff;}
.user-menu form{margin:0;}
.hamburger{display:none;}

/* Main region is the scroll container; the topbar sticks to its top. */
.main{height:100vh;overflow-y:auto;overflow-x:hidden;padding:0 28px 60px;min-width:0;}
.main > .alert{margin-top:16px;}
.topbar{position:sticky;top:0;z-index:20;background:var(--paper);display:flex;justify-content:space-between;align-items:baseline;padding:18px 0 14px;margin-bottom:18px;border-bottom:1px solid var(--line);flex-wrap:wrap;gap:8px;}
.topbar h1{font-size:22px;}
.topbar .sub{color:var(--muted);font-size:12.5px;margin-top:3px;}

/* buttons (Bootstrap-compatible overrides) */
.btn{border-radius:7px;font-size:13px;font-weight:600;}
.btn-rms{background:var(--navy);color:#fff;border:none;padding:9px 16px;}
.btn-rms:hover{background:var(--navy-2);color:#fff;}
.btn-accent{background:var(--accent);color:#fff;border:none;padding:9px 16px;}
.btn-accent:hover{background:#a8521f;color:#fff;}
.btn-ghost{background:transparent;color:var(--navy);border:1px solid var(--line);padding:9px 16px;}
.btn-ghost:hover{background:#f0f2f5;color:var(--navy);}
.btn-sm-rms{padding:5px 10px;font-size:11.5px;border-radius:6px;}
.btn-danger-ghost{background:transparent;border:1px solid var(--red);color:var(--red);}
.btn-danger-ghost:hover{background:var(--red);color:#fff;}

.scope-banner{background:#eef3fb;border:1px solid #cfe0f7;color:#1d5fb8;font-size:12px;padding:8px 12px;border-radius:8px;margin-bottom:14px;}
.scope-banner.warn{background:#fdeedb;border-color:#f4d8b0;color:var(--amber);}
.scope-banner.danger{background:#fae3e0;border-color:#f3c3bd;color:var(--red);}
.scope-banner a{color:inherit;}

.grid{display:grid;gap:14px;}
.kpis{grid-template-columns:repeat(6,1fr);margin-bottom:18px;}
@media (max-width:1200px){.kpis{grid-template-columns:repeat(3,1fr);}}
.kpi{background:var(--white);border:1px solid var(--line);border-radius:10px;padding:14px 16px;position:relative;overflow:hidden;}
.kpi .num{font-family:Georgia,serif;font-size:26px;}
.kpi .lbl{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-top:2px;}
.kpi::after{content:"";position:absolute;right:-10px;top:-10px;width:46px;height:46px;border-radius:50%;background:var(--accent);opacity:.08;}

.panel{background:var(--white);border:1px solid var(--line);border-radius:10px;padding:18px;margin-bottom:18px;}
.panel h3{font-size:14px;text-transform:uppercase;letter-spacing:.6px;color:var(--navy);margin-bottom:12px;font-family:Arial,sans-serif;font-weight:700;}
.two-col{display:grid;grid-template-columns:1.3fr 1fr;gap:14px;}
@media (max-width:1000px){.two-col{grid-template-columns:1fr;}}

table{width:100%;border-collapse:collapse;font-size:12.8px;}
.panel th,.table-wrap th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);border-bottom:1px solid var(--line);padding:7px 8px;white-space:nowrap;}
.panel td,.table-wrap td{padding:8px 8px;border-bottom:1px solid #eef0f4;vertical-align:middle;}
.panel tr:hover td{background:#fafbfc;}
.table-wrap{overflow-x:auto;}

.badge-rms{display:inline-block;padding:3px 9px;border-radius:20px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;}
.b-open{background:#e7f0ff;color:#1d5fb8;}
.b-assigned{background:#fdeedb;color:var(--amber);}
.b-progress{background:#e7f4ec;color:var(--green);}
.b-hold{background:#f4e4d8;color:var(--accent);}
.b-closed{background:#e9eaee;color:#444b58;}
.b-cancelled{background:#fae3e0;color:var(--red);}
.b-high{background:#fae3e0;color:var(--red);}
.b-med{background:#fdeedb;color:var(--amber);}
.b-low{background:#e7f4ec;color:var(--green);}
.b-active{background:#e7f4ec;color:var(--green);}
.b-inactive{background:#e9eaee;color:#444b58;}

.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:9px;}
.bar-row .lbl{width:130px;font-size:12px;flex:0 0 auto;color:var(--ink);}
.bar-track{flex:1;height:9px;background:#eef0f4;border-radius:5px;overflow:hidden;}
.bar-fill{height:100%;background:var(--accent);border-radius:5px;}
.bar-row .val{width:34px;text-align:right;font-size:12px;color:var(--muted);}

.rms-input,.panel input,.panel select,.panel textarea,.modal input,.modal select,.modal textarea{width:100%;padding:8px 9px;border:1px solid var(--line);border-radius:6px;font-size:12.8px;font-family:inherit;background:#fff;}
input:disabled{background:#f3f4f6;color:var(--muted);}
.rms-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;display:block;margin-bottom:4px;}
.field{margin-bottom:11px;}
.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:11px;}
@media (max-width:900px){.form-grid{grid-template-columns:repeat(2,1fr);}}
.checkrow{display:flex;align-items:center;gap:7px;font-size:12.5px;}
.checkrow input{width:auto;}

.empty{text-align:center;padding:40px 12px;color:var(--muted);}
.empty .big{font-size:32px;margin-bottom:6px;}

.pill-filter{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:14px;}
.pill-filter a{border:1px solid var(--line);background:#fff;padding:6px 13px;border-radius:20px;font-size:12px;cursor:pointer;text-decoration:none;color:var(--ink);}
.pill-filter a.active{background:var(--navy);color:#fff;border-color:var(--navy);}

.muted{color:var(--muted);}
.right{text-align:right;}
.flex-between{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;}
a.link{color:var(--navy);text-decoration:underline;cursor:pointer;font-size:12px;}
.notif-item{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid #eef0f4;font-size:12.8px;}
.notif-item .ic{width:30px;height:30px;border-radius:50%;background:#eef0f4;display:flex;align-items:center;justify-content:center;flex:0 0 auto;font-size:13px;}
.stage-track{display:flex;gap:4px;margin-top:5px;}
.stage-track span{flex:1;height:5px;border-radius:3px;background:#eef0f4;}
.stage-track span.on{background:var(--green);}

.platform-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
@media (max-width:900px){.platform-cards{grid-template-columns:1fr;}}
.platform-card{border:1px solid var(--line);border-radius:10px;padding:16px;}
.platform-card .icon{font-size:26px;margin-bottom:8px;}
.platform-card h4{font-size:14px;margin-bottom:6px;}
.platform-card p{font-size:12.3px;color:var(--muted);margin:0;line-height:1.5;}
.phone-mock{width:230px;border:10px solid #10233f;border-radius:30px;overflow:hidden;margin:0 auto;box-shadow:0 12px 30px rgba(0,0,0,.18);position:relative;}
.phone-mock .screen{background:#fff;height:420px;overflow:hidden;font-size:11px;position:relative;}
.phone-bar{background:var(--navy);color:#fff;padding:10px 12px;font-size:12px;display:flex;justify-content:space-between;}
.phone-kpi{display:grid;grid-template-columns:1fr 1fr;gap:7px;padding:10px 12px;}
.phone-kpi div{background:#f6f7f9;border-radius:7px;padding:8px;text-align:center;}
.phone-kpi .n{font-family:Georgia,serif;font-size:16px;}
.phone-row{padding:8px 12px;border-bottom:1px solid #eef0f4;font-size:11px;display:flex;justify-content:space-between;}
.phone-nav{display:flex;justify-content:space-around;border-top:1px solid var(--line);padding:9px 0;position:absolute;bottom:0;width:100%;background:#fff;font-size:9px;color:var(--muted);}

.toast-rms{position:fixed;bottom:22px;right:22px;background:var(--navy);color:#fff;padding:11px 18px;border-radius:8px;font-size:13px;z-index:1090;max-width:340px;box-shadow:0 8px 24px rgba(0,0,0,.25);}

.modal-content{border-radius:12px;}
.modal-title{font-family:Georgia,serif;font-size:18px;}

/* ===== RESPONSIVE SHELL ===== */
@media (max-width:880px){
  .shell{grid-template-columns:1fr;}
  /* Off-canvas sidebar keeps its pinned brand/user and internally-scrolling nav. */
  .side{position:fixed;top:0;left:0;height:100vh;width:230px;z-index:1060;transform:translateX(-100%);transition:transform .25s;box-shadow:4px 0 24px rgba(0,0,0,.25);}
  .side.open{transform:translateX(0);}
  .hamburger{display:flex;position:fixed;top:14px;left:14px;z-index:1061;background:var(--navy);color:#fff;width:38px;height:38px;border-radius:8px;align-items:center;justify-content:center;font-size:18px;cursor:pointer;border:none;}
  .main{height:100vh;overflow-y:auto;padding:0 16px 50px;}
  /* Sticky topbar sits below/clears the fixed hamburger button. */
  .topbar{padding-left:52px;}
  .form-grid{grid-template-columns:1fr;}
  .kpis{grid-template-columns:repeat(2,1fr);}
  .two-col{grid-template-columns:1fr;}
  .backdrop-side{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:1055;}
}

/* ===== Module additions: clients, reports, users, platform, notifications ===== */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
@media (max-width:1100px){.card-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:680px){.card-grid{grid-template-columns:1fr;}}
.client-card{display:flex;flex-direction:column;gap:12px;}
.client-head{display:flex;align-items:center;gap:12px;}
.client-avatar{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,var(--navy),var(--navy-2));color:#fff;display:flex;align-items:center;justify-content:center;font-family:Georgia,serif;font-size:20px;flex:0 0 auto;}
.client-name{font-weight:700;color:var(--navy);font-size:15px;}
.client-meta{display:grid;grid-template-columns:1fr 1fr;gap:6px 14px;font-size:12.5px;}
.client-meta .rms-label{display:block;font-size:10px;}
.client-stats{display:flex;gap:10px;margin-top:auto;}
.client-stats .kpi{flex:1;text-align:center;padding:10px;}

.report-controls{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:12px;align-items:end;}
@media (max-width:900px){.report-controls{grid-template-columns:1fr 1fr;}}
.report-actions-inline{margin-bottom:11px;}
.report-export{display:flex;gap:10px;margin-top:14px;border-top:1px solid var(--line);padding-top:14px;}
.panel-title{font-size:14px;text-transform:uppercase;letter-spacing:.6px;color:var(--navy);margin-bottom:12px;font-weight:700;}

.row-actions{display:flex;gap:6px;flex-wrap:wrap;}
.perm-yes{color:var(--green);font-weight:700;}
.perm-no{color:var(--line);}
.err{color:var(--red);font-size:11.5px;margin-top:3px;}
.field-check{display:flex;align-items:center;}
.field-check .rms-label{display:flex;align-items:center;gap:8px;margin:0;}
.field-check input{width:auto;}
.form-actions{display:flex;gap:10px;margin-top:8px;}

.platform-grid{align-items:start;}
.platform-card{background:var(--white);border:1px solid var(--line);border-radius:10px;padding:18px;margin-bottom:16px;}
.platform-icon{font-size:30px;margin-bottom:6px;}
.platform-card h3{font-size:15px;color:var(--navy);margin-bottom:6px;}
.platform-card p{font-size:12.8px;color:var(--ink);margin-bottom:10px;}
.platform-list{margin:0 0 12px 18px;padding:0;font-size:12.5px;color:var(--muted);}
.platform-list li{margin-bottom:4px;}

.phone-mock{width:280px;max-width:100%;margin:0 auto;background:var(--navy);border-radius:30px;padding:12px;box-shadow:0 14px 40px rgba(16,35,63,.35);position:relative;}
.phone-notch{width:120px;height:18px;background:#0c1a30;border-radius:0 0 14px 14px;margin:0 auto 8px;}
.phone-screen{background:var(--paper);border-radius:20px;padding:16px;min-height:420px;}
.phone-header{margin-bottom:14px;}
.phone-title{font-family:Georgia,serif;font-size:18px;color:var(--navy);}
.phone-sub{font-size:11px;color:var(--muted);}
.phone-section-title{font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:8px;}
.phone-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:10px 12px;margin-bottom:8px;}
.phone-card-name{font-weight:700;font-size:13px;color:var(--navy);}
.phone-card-meta{font-size:11.5px;color:var(--muted);}

.notif-row{display:flex;gap:12px;align-items:flex-start;padding:11px 4px;border-bottom:1px solid #eef0f4;}
.notif-row:last-child{border-bottom:none;}
.notif-icon{font-size:18px;flex:0 0 auto;}
.notif-text{font-size:13px;color:var(--ink);}
.notif-time{font-size:11px;color:var(--muted);margin-top:2px;}

/* ===== Detailed intake form layout (candidate form: workarea / col-sm grid) ===== */
.pagearea{background:var(--white);border:1px solid var(--line);border-radius:10px;margin-bottom:18px;overflow:hidden;}
.workhead{background:var(--navy);color:#fff;font-size:12.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:10px 16px;}
.workarea{display:flex;flex-wrap:wrap;gap:0 16px;padding:16px;}
/* col widths (simple responsive grid, no Bootstrap .row wrapper needed) */
.workarea .col-sm-3{flex:0 0 calc(25% - 12px);max-width:calc(25% - 12px);}
.workarea .col-sm-4{flex:0 0 calc(33.333% - 11px);max-width:calc(33.333% - 11px);}
.workarea .col-sm-6{flex:0 0 calc(50% - 8px);max-width:calc(50% - 8px);}
.workarea .col-sm-12{flex:0 0 100%;max-width:100%;}
.workarea .form-group{margin-bottom:14px;}
.workarea .form-group > label{display:block;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px;}
.workarea .form-control{width:100%;padding:8px 9px;border:1px solid var(--line);border-radius:6px;font-size:12.8px;font-family:inherit;background:#fff;color:var(--ink);}
.workarea .form-control:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(196,98,45,.15);}
.workarea .form-control:disabled{background:#f1f3f6;color:var(--muted);cursor:not-allowed;}
.workarea .clear{flex:0 0 100%;height:0;}
@media (max-width:1000px){
  .workarea .col-sm-3{flex:0 0 calc(50% - 8px);max-width:calc(50% - 8px);}
  .workarea .col-sm-4{flex:0 0 calc(50% - 8px);max-width:calc(50% - 8px);}
}
@media (max-width:640px){
  .workarea{gap:0;}
  .workarea .col-sm-3,.workarea .col-sm-4,.workarea .col-sm-6{flex:0 0 100%;max-width:100%;}
}

/* ===== Profile page ===== */
.profile-head{display:flex;align-items:center;gap:16px;margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid var(--line);}
.profile-avatar{width:56px;height:56px;flex:0 0 auto;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--navy-2));color:#fff;display:flex;align-items:center;justify-content:center;font-family:Georgia,serif;font-size:24px;}
.profile-name{font-family:Georgia,serif;font-size:20px;color:var(--navy);}

/* ===== Pipeline stage controls (Back / Next grouped, distinct colours) ===== */
.stage-btns{display:inline-flex;align-items:stretch;}
.stage-btns form{margin:0;}
.stage-btns .btn{border-radius:0;}
.stage-btns form:first-child .btn{border-top-left-radius:6px;border-bottom-left-radius:6px;}
.stage-btns form:last-child .btn{border-top-right-radius:6px;border-bottom-right-radius:6px;}
/* Back = neutral/navy-tinted */
.btn-back{background:#e7ebf2;color:var(--navy);border:1px solid var(--line);border-right:none;}
.btn-back:hover{background:#d6dce8;color:var(--navy);}
/* Next = accent (orange) */
.btn-next{background:var(--accent);color:#fff;border:1px solid var(--accent);}
.btn-next:hover{background:#a8521f;color:#fff;border-color:#a8521f;}
.stage-btns .btn:disabled{opacity:.5;cursor:not-allowed;}
