
:root{
  --navy:#06162d;--navy2:#071b35;--navy3:#0d2e56;--maroon:#a50f36;--red:#b90f3d;
  --gold:#d6a85a;--gold2:#f2d78b;--soft:#f5f7fb;--line:#e7ecf3;--muted:#667085;
  --green:#0aa65a;--blue:#075da8;--orange:#e16800;--purple:#5b0db7;--text:#0c1830;
}
*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,Helvetica,sans-serif;color:var(--text);background:#eef3fa}a{text-decoration:none;color:inherit}button,input,select,textarea{font-family:inherit}
.btn,button.primary{border:0;border-radius:14px;padding:13px 18px;background:linear-gradient(135deg,var(--maroon),var(--red));color:#fff;font-weight:900;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.btn.gold,.gold{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--navy)}.btn.dark{background:var(--navy)}.full-btn{width:100%;height:48px;margin-top:18px}
input,select,textarea{width:100%;border:1px solid var(--line);border-radius:13px;padding:13px 14px;background:#fff;font-size:14px}textarea{min-height:95px}label{display:block;font-weight:900;margin:16px 0 8px}
.ok,.err{padding:12px 14px;border-radius:12px;margin:12px 0;font-weight:900}.ok{background:#e8fff2;color:#0d7a3a}.err{background:#ffe8ee;color:#a50f36}
.login-body{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at 20% 20%,rgba(214,168,90,.16),transparent 30%),linear-gradient(135deg,var(--navy),#270f2d 42%,#7d0f31);padding:28px}
.login-shell{width:min(1180px,96vw);min-height:620px;display:grid;grid-template-columns:.96fr 1.04fr;background:#fff;border-radius:34px;overflow:hidden;border:2px solid var(--gold);box-shadow:0 32px 90px rgba(0,0,0,.38)}
.login-brand{padding:54px 48px;color:#fff;background:radial-gradient(circle at 18% 12%,rgba(214,168,90,.25),transparent 28%),linear-gradient(145deg,var(--navy),#150d28 52%,#8a0d31);display:flex;flex-direction:column;justify-content:center}
.login-brand img{width:210px;max-width:80%;margin-bottom:30px;object-fit:contain}.eyebrow{display:inline-block;color:var(--gold2);font-size:12px;letter-spacing:3px;text-transform:uppercase;font-weight:900}
.login-brand h1{font-family:"Playfair Display",Georgia,serif;font-size:58px;line-height:1;margin:12px 0 18px}.login-brand p{font-size:18px;line-height:1.7;color:#e5e7eb}
.login-form{padding:54px;display:flex;flex-direction:column;justify-content:center}.login-form h2{font-family:"Playfair Display",Georgia,serif;font-size:48px;line-height:1.05;margin:0 0 12px;color:var(--navy)}.login-form p{color:var(--muted);line-height:1.6}
.app{min-height:100vh;padding:10px;display:grid;grid-template-columns:275px 1fr;background:#eaf0f8}
.sidebar{background:linear-gradient(180deg,#06162d,#08264a);color:#fff;border:1.5px solid var(--gold);border-radius:14px 0 0 14px;padding:18px 16px;position:sticky;top:10px;height:calc(100vh - 20px);overflow:auto}
.logo-area{text-align:center;padding:4px 4px 18px;border-bottom:1px solid rgba(214,168,90,.35);margin-bottom:16px}.logo-area img{width:165px;max-width:90%;object-fit:contain}.logo-area small{display:block;color:#d9e3f2;font-size:11px;margin-top:5px}
.nav-item{width:100%;display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:8px;border:0;background:transparent;color:#eaf2ff;padding:11px 13px;border-radius:9px;text-align:left;font-weight:800;font-size:14px;cursor:pointer;margin:3px 0}
.nav-item:hover{background:rgba(255,255,255,.08)}.nav-item.active{background:linear-gradient(90deg,var(--maroon),var(--red));color:#fff}.pill-count{background:var(--maroon);color:#fff;border-radius:7px;padding:3px 7px;font-size:11px}
.admin-card{margin-top:28px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:14px;display:flex;gap:12px;align-items:center}
.avatar,.staff-photo{width:45px;height:45px;border-radius:50%;background:#fff;color:var(--navy);display:grid;place-items:center;font-weight:900;object-fit:cover;border:2px solid rgba(255,255,255,.75)}.online{font-size:11px;color:#22c55e;margin-top:7px}
.main{background:rgba(255,255,255,.96);border-radius:0 14px 14px 0;padding:18px 20px 20px;overflow:hidden;min-height:calc(100vh - 20px)}
.topbar{display:grid;grid-template-columns:1fr 360px 80px 230px 150px;gap:14px;align-items:center;margin-bottom:14px}.title-wrap{display:flex;align-items:center;gap:14px}.title-icon{width:42px;height:42px;border-radius:12px;background:var(--navy);color:var(--gold);display:grid;place-items:center;font-size:20px}
.main h1{font-size:34px;line-height:1;margin:0;font-weight:900}.subtitle{margin:5px 0 0;color:var(--muted);font-weight:600;font-size:13px}.search{height:42px}
.bell{height:50px;background:#fff;border:1px solid var(--line);border-radius:14px;position:relative;display:grid;place-items:center;font-size:24px}.bell span{position:absolute;right:8px;top:5px;background:var(--maroon);color:#fff;border-radius:8px;font-size:11px;padding:2px 6px}
.health{height:58px;border:1px solid var(--gold);border-radius:13px;background:#fff9e9;display:flex;align-items:center;gap:12px;padding:9px 12px}.health-icon{width:40px;height:40px;border-radius:12px;background:var(--gold);color:#fff;display:grid;place-items:center;font-size:22px}.health strong{font-size:24px}.health small{display:block;color:var(--muted);font-size:10px}.date{text-align:right;font-size:12px;color:#24344d;font-weight:700}.date strong{display:block;font-size:13px;margin-top:4px}
.quick-tabs{display:grid;grid-template-columns:repeat(10,1fr);gap:9px;margin:8px 0 10px}.quick-tabs.second{grid-template-columns:repeat(11,1fr)}.qtab{height:38px;border:1px solid var(--line);border-radius:9px;background:#fff;color:#24344d;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;gap:7px;white-space:nowrap;cursor:pointer}.qtab:hover{border-color:var(--gold);box-shadow:0 8px 18px rgba(6,22,45,.07)}
.stats{display:grid;grid-template-columns:repeat(8,1fr);gap:10px;margin:14px 0}.stat{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px;display:grid;grid-template-columns:48px 1fr;gap:12px;align-items:center;min-height:92px;box-shadow:0 6px 16px rgba(6,22,45,.04)}.stat-icon{width:47px;height:47px;border-radius:12px;color:#fff;display:grid;place-items:center;font-size:22px}.stat h3{margin:0;color:var(--muted);font-size:11px;text-transform:uppercase;font-weight:900}.stat b{display:block;font-size:24px;margin:5px 0}.green{color:var(--green)!important}.orange{color:var(--orange)!important}.purple{color:var(--purple)!important}
.grid{display:grid;gap:12px}.grid.two{grid-template-columns:1.45fr 1fr}.grid.three{grid-template-columns:.85fr .85fr 1fr .95fr}.grid.four{grid-template-columns:1fr 1fr 1fr 1fr}.panel{background:#fff;border:1px solid var(--line);border-radius:14px;padding:15px;box-shadow:0 8px 18px rgba(6,22,45,.035);min-width:0}.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.panel h2{font-size:17px;margin:0;font-weight:900}
.tablewrap{overflow:auto}table{width:100%;border-collapse:collapse}th{font-size:11px;text-align:left;color:#384860;background:#f7f9fd;border-bottom:1px solid var(--line);padding:10px}td{font-size:12px;border-bottom:1px solid var(--line);padding:9px 10px;vertical-align:middle}
.staff-name{display:flex;align-items:center;gap:9px}.staff-name img{width:36px;height:36px;border-radius:50%;object-fit:cover}.staff-name b{display:block}.staff-name small{color:var(--muted)}.whatsapp{color:var(--green);font-weight:900;display:flex;align-items:center;gap:6px}.score{width:43px;height:43px;border-radius:50%;border:3px solid var(--green);display:grid;place-items:center;font-weight:900;color:var(--navy)}
.pipeline{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.stage{border:1px solid var(--line);border-radius:10px;background:#fff;min-height:178px;padding:12px;position:relative}.stage:before{content:"";position:absolute;left:0;right:0;top:0;height:3px;border-radius:10px 10px 0 0;background:var(--blue)}.stage.red:before{background:var(--maroon)}.stage.orange:before{background:var(--orange)}.stage.purple:before{background:var(--purple)}.stage.green:before{background:var(--green)}.stage h3{font-size:11px;margin:8px 0 10px}.stage b{display:block;font-size:22px}.stage a{display:block;color:#49709f;font-size:11px;margin:10px 0}
.action{display:grid;grid-template-columns:18px 1fr 90px 72px;gap:8px;align-items:center;border-bottom:1px solid var(--line);padding:8px 0}.adot{width:14px;height:14px;border-radius:50%;background:var(--maroon)}.priority,.status{border-radius:999px;padding:6px 10px;color:#fff;font-size:10px;font-weight:900;text-align:center;background:var(--blue)}.priority.medium{background:var(--orange)}.priority.urgent,.priority.high{background:var(--maroon)}.doc-row,.feed-row,.deadline-row,.update-row{display:grid;grid-template-columns:28px 1fr auto;gap:8px;align-items:center;border-bottom:1px solid var(--line);padding:8px 0}.approved{background:#dcfce7;color:var(--green)}.pending{background:#fff0d5;color:var(--orange)}
.quick-actions{background:var(--navy);border-color:var(--gold);color:#fff}.actions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.action-btn{height:74px;border:1px solid var(--gold);border-radius:8px;background:#0c2547;color:#fff;font-weight:800;display:grid;place-items:center;text-align:center;cursor:pointer}.tool-btn{height:58px;background:#fff;border:1px solid #ead49a;border-radius:9px;font-weight:800;font-size:11px;color:#21314b;display:flex;align-items:center;justify-content:center;gap:7px;cursor:pointer;text-align:center;padding:4px}.tools-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.permission{display:flex;gap:14px;align-items:center;border:1px solid #f0dcc1;border-radius:12px;padding:12px;margin:10px 0}.calendar{width:42px;text-align:center;border-radius:9px;overflow:hidden;border:1px solid var(--line)}.calendar b{display:block;background:var(--maroon);color:#fff;font-size:10px;padding:3px}.calendar span{display:block;font-weight:900;padding:4px;font-size:13px}.feed-photo{width:30px;height:30px;border-radius:50%;object-fit:cover}.tab-page{display:none}.tab-page.active{display:block}
.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}.full{grid-column:1/-1}.module-hero{background:linear-gradient(135deg,var(--navy),#14345c 55%,#7e0f31);color:#fff;border-radius:16px;padding:18px;margin-bottom:14px;border:1px solid var(--gold)}.module-hero h2{font-family:Georgia,serif;font-size:28px;margin:5px 0}.module-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px;margin:12px 0}.module-card{background:#f8fafc;border:1px solid var(--line);border-radius:14px;padding:14px}.module-card b{display:block;color:var(--maroon);font-size:22px;margin-top:5px}
.client-app{min-height:100vh;display:grid;grid-template-columns:230px 1fr;background:#eef3fa}.client-side{background:#f7f8fb;border-right:1px solid var(--line);padding:16px;min-height:100vh}.client-side img{width:130px;display:block;margin:0 auto 20px}.client-side button{width:100%;justify-content:flex-start;margin:5px 0;background:#fff;color:var(--navy);border:1px solid var(--line)}.client-side button.active{background:var(--maroon);color:#fff}.client-main{padding:24px}.client-top{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid var(--line);border-radius:20px;padding:16px 20px;margin-bottom:20px}.client-content .tab-page{display:none}.client-content .tab-page.active{display:block}.service-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px}.service-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px}.service-card h3{margin:8px 0}.invoice-preview{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;margin-top:14px}
@media(max-width:1300px){.app,.client-app{grid-template-columns:1fr}.sidebar{position:relative;height:auto;border-radius:14px}.main{border-radius:14px}.topbar,.stats,.quick-tabs,.quick-tabs.second,.grid.two,.grid.three,.grid.four{grid-template-columns:1fr}.pipeline,.tools-grid,.actions-grid,.form-grid{grid-template-columns:1fr}.login-shell{grid-template-columns:1fr}}


/* ============================================================
   PHASE 4800 CLIENT PORTAL + REQUEST WORKFLOW
   ============================================================ */
.client-app{min-height:100vh;background:#f6f8fc;display:grid;grid-template-columns:292px 1fr}
.client-sidebar{background:#06162d;color:#fff;min-height:100vh;padding:24px 18px;position:sticky;top:0;align-self:start;border-right:1px solid rgba(214,166,56,.35)}
.client-logo{text-align:center;padding-bottom:24px;border-bottom:1px solid rgba(214,166,56,.25);margin-bottom:18px}
.client-logo img{width:170px;max-width:92%;object-fit:contain}
.client-logo small{display:block;color:#d7e0ef;margin-top:8px;font-size:11px}
.client-command{font-size:13px;color:#f4d77a;text-transform:uppercase;letter-spacing:1px;margin:18px 10px 10px;font-weight:900}
.client-nav-btn{width:100%;display:grid;grid-template-columns:30px 1fr auto;align-items:center;gap:10px;color:#eaf2ff;background:transparent;border:0;border-radius:0;padding:15px 14px;text-align:left;font-weight:800;font-size:15px;cursor:pointer}
.client-nav-btn:hover{background:rgba(255,255,255,.08)}
.client-nav-btn.active{background:linear-gradient(90deg,#7e0f31,#b4083f);border-right:4px solid #d6a638}
.client-nav-btn .badge{background:#b4083f;color:#fff;border-radius:999px;padding:4px 8px;font-size:11px}
.client-main{padding:28px 32px;min-width:0}
.client-top{display:grid;grid-template-columns:1fr 520px;gap:22px;align-items:center;margin-bottom:22px}
.client-heading h1{font-family:Georgia,serif;font-size:48px;line-height:1;margin:0;color:#06162d}
.client-heading p{font-size:17px;margin:10px 0 0;color:#24344d}
.client-heading b{color:#8c1237}
.consultant-card{background:#fff;border:1px solid #e4e9f2;border-radius:18px;box-shadow:0 12px 32px rgba(6,22,45,.08);padding:14px;display:grid;grid-template-columns:88px 1fr auto;gap:18px;align-items:center}
.consultant-card img{width:78px;height:78px;object-fit:cover;border-radius:50%;border:2px solid #d6a638}
.consultant-card small{display:block;color:#a27722;font-weight:900;text-transform:uppercase;font-size:10px}
.consultant-card h3{margin:4px 0;color:#06162d;font-family:Georgia,serif;font-size:22px}
.whatsapp-btn{background:#25d366;color:#fff;border:0;border-radius:999px;padding:13px 16px;font-weight:900;white-space:nowrap}
.profile-banner{background:linear-gradient(100deg,#6c0827,#8d0e34 55%,#06162d);border:1px solid #d6a638;border-radius:18px;color:#fff;padding:24px 26px;display:grid;grid-template-columns:82px 1fr auto;gap:20px;align-items:center;box-shadow:0 16px 36px rgba(6,22,45,.15);margin-bottom:16px;position:relative;overflow:hidden}
.profile-banner:after{content:"JJ";position:absolute;right:26px;font-family:Georgia,serif;font-size:150px;font-weight:900;color:rgba(255,255,255,.06);line-height:1}
.company-icon{width:78px;height:78px;border-radius:50%;border:2px solid #d6a638;display:grid;place-items:center;font-size:34px;color:#d6a638;background:rgba(255,255,255,.05)}
.profile-banner .eyebrow{color:#f4d77a;margin:0;font-size:12px}
.profile-banner h2{font-family:Georgia,serif;font-size:32px;margin:4px 0}
.active-pill{background:#0b7d3b;color:#fff;border:1px solid #d6a638;border-radius:999px;padding:10px 20px;font-weight:900;z-index:1}
.client-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:16px 0}
.client-kpi{background:#fff;border:1px solid #e4e9f2;border-radius:18px;box-shadow:0 10px 28px rgba(6,22,45,.07);padding:18px;display:grid;grid-template-columns:64px 1fr;gap:16px;align-items:center}
.client-kpi-icon{width:58px;height:58px;border-radius:50%;display:grid;place-items:center;font-size:26px;color:#fff;background:#8d0e34}
.client-kpi:nth-child(2) .client-kpi-icon{background:#bd8a2d}.client-kpi:nth-child(3) .client-kpi-icon{background:#06162d}.client-kpi:nth-child(4) .client-kpi-icon{background:#8d0e34}
.client-kpi h3{font-size:15px;margin:0;color:#384860}.client-kpi b{display:block;font-size:28px;margin:3px 0;color:#06162d}.client-kpi a{font-size:13px;color:#8d0e34;font-weight:900}
.client-grid{display:grid;grid-template-columns:1.35fr .85fr;gap:18px}
.client-card{background:#fff;border:1px solid #e4e9f2;border-radius:18px;box-shadow:0 12px 32px rgba(6,22,45,.07);padding:18px;min-width:0}
.client-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.client-card h2{font-family:Georgia,serif;font-size:23px;margin:0;color:#06162d}
.progress-table{width:100%;border-collapse:collapse}
.progress-table th{background:#fafbfd;color:#65748b;text-align:left;padding:10px;font-size:12px;border-bottom:1px solid #e4e9f2}
.progress-table td{padding:12px 10px;border-bottom:1px solid #e4e9f2;font-size:14px}
.service-pill{display:inline-flex;align-items:center;gap:8px}.round-icon{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:#fff;background:#8d0e34}
.status-chip{border-radius:999px;padding:6px 12px;font-weight:900;font-size:12px}.status-complete{background:#dcfce7;color:#0b7d3b}.status-progress{background:#eaf2ff;color:#075da8}.status-pending{background:#fff0d5;color:#bd7a00}.status-open{background:#ffe8ee;color:#8d0e34}
.request-list{display:grid;gap:10px}
.request-option{background:#fff;border:1px solid #ead49a;border-radius:12px;padding:14px;display:grid;grid-template-columns:34px 1fr auto;gap:12px;align-items:center;font-weight:900;cursor:pointer;color:#06162d}
.request-option:hover{border-color:#8d0e34;box-shadow:0 10px 25px rgba(6,22,45,.07)}
.client-bottom{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}
.big-illustration{height:105px;display:flex;align-items:center;justify-content:flex-end;font-size:76px;opacity:.88}
.client-page-section{display:none}.client-page-section.active{display:block}
.client-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.client-form-grid .full{grid-column:1/-1}
.request-status-board{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.request-status-card{border:1px solid #e4e9f2;border-radius:14px;padding:14px;background:#fff}
.request-status-card b{display:block;font-size:22px;color:#8d0e34;margin-top:8px}
.consultant-mini{display:flex;gap:10px;align-items:center}
.consultant-mini img{width:42px;height:42px;border-radius:50%;object-fit:cover;border:2px solid #d6a638}
.staff-request-row{display:grid;grid-template-columns:1.1fr .8fr .9fr .8fr .8fr 1.4fr;gap:10px;align-items:center;border-bottom:1px solid #e4e9f2;padding:12px 0}
.staff-request-actions{display:flex;gap:8px;flex-wrap:wrap}
.staff-request-actions button{padding:8px 10px;border-radius:9px;border:1px solid #e4e9f2;background:#fff;font-weight:800}
@media(max-width:1200px){.client-app{grid-template-columns:1fr}.client-sidebar{position:relative;min-height:auto}.client-top,.client-grid,.client-bottom,.client-kpis,.request-status-board{grid-template-columns:1fr}.consultant-card{grid-template-columns:70px 1fr}.whatsapp-btn{grid-column:1/-1}.client-form-grid{grid-template-columns:1fr}.profile-banner{grid-template-columns:1fr}.staff-request-row{grid-template-columns:1fr}}


/* ============================================================
   PHASE 4900 FIXES: Dynamic Client, Booking, Signup, Status
   ============================================================ */
.notice-box{background:#fff9e9;border:1px solid #ead49a;border-radius:14px;padding:14px;margin:12px 0;color:#4a3512}
.link-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px}
.portal-empty{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:14px;padding:18px;color:#65748b}
.public-form-page{min-height:100vh;background:linear-gradient(135deg,#06162d,#1b1230 45%,#7e0f31);padding:28px}
.public-form-shell{max-width:1120px;margin:auto;background:#fff;border:2px solid #d6a638;border-radius:28px;overflow:hidden;display:grid;grid-template-columns:.85fr 1.15fr;box-shadow:0 30px 80px rgba(0,0,0,.32)}
.public-form-brand{background:linear-gradient(145deg,#06162d,#7e0f31);color:#fff;padding:42px}
.public-form-brand img{width:190px;max-width:85%;margin-bottom:25px}
.public-form-brand h1{font-family:Georgia,serif;font-size:48px;line-height:1;margin:0 0 16px}
.public-form-brand p{line-height:1.7;color:#e7edf7}
.public-form-content{padding:42px}
.public-form-content h2{font-family:Georgia,serif;font-size:38px;color:#06162d;margin:0 0 12px}
.form-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px}
.request-controls{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}
.request-note{min-height:70px;margin-top:8px}
.update-ok{background:#dcfce7;color:#0b7d3b;border-radius:10px;padding:10px;margin-top:8px;font-weight:900}
.client-login-links{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.client-login-links a{font-weight:900;color:#b4083f}
@media(max-width:900px){.public-form-shell{grid-template-columns:1fr}.request-controls{grid-template-columns:1fr}}


/* ============================================================
   PHASE 4920 CONSULTANT PROFILE + MANAGER APPROVAL
   ============================================================ */
.consultant-profile-card{
  background:linear-gradient(135deg,#06162d,#12345b 55%,#7e0f31);
  color:#fff;border:1px solid var(--gold);border-radius:18px;padding:18px;
  display:grid;grid-template-columns:84px 1fr auto;gap:16px;align-items:center;margin-bottom:14px;
  box-shadow:0 14px 35px rgba(6,22,45,.14)
}
.consultant-profile-card img{width:78px;height:78px;border-radius:50%;object-fit:cover;border:2px solid #d6a638;background:#fff}
.consultant-profile-card h2{font-family:Georgia,serif;font-size:28px;margin:0 0 4px;color:#fff}
.consultant-profile-card p{margin:4px 0;color:#e5e7eb}
.role-badge{display:inline-flex;align-items:center;border-radius:999px;background:#fff9e9;color:#7a520b;padding:7px 12px;font-weight:900;font-size:12px}
.permissions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:14px 0}
.permission-card{background:#fff;border:1px solid #e4e9f2;border-radius:14px;padding:14px}
.permission-card b{display:block;color:#06162d;margin-bottom:6px}
.my-work-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:14px}
.client-status-editor{background:#fff;border:1px solid #e4e9f2;border-radius:14px;padding:14px;margin-top:12px}
.status-note-box{min-height:85px}
.approval-status{border-radius:999px;padding:6px 10px;font-size:11px;font-weight:900;display:inline-block}
.approval-pending{background:#fff0d5;color:#b15c00}
.approval-approved{background:#dcfce7;color:#0b7d3b}
.approval-returned{background:#ffe8ee;color:#a50f36}
.manager-approval-card{border:1px solid #ead49a;background:#fffdf5;border-radius:14px;padding:14px;margin:10px 0}
.approval-buttons{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.approval-buttons button{border:0;border-radius:10px;padding:9px 12px;font-weight:900;cursor:pointer}
.approve-btn{background:#0b7d3b;color:#fff}.return-btn{background:#a50f36;color:#fff}.review-btn{background:#d6a638;color:#06162d}
@media(max-width:1000px){.consultant-profile-card,.my-work-grid,.permissions-grid{grid-template-columns:1fr}}

/* PHASE 4940 */
button[disabled],.btn[disabled]{opacity:.7!important;cursor:not-allowed!important}
.loading-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.45);border-top-color:#fff;border-radius:50%;animation:jjspin .8s linear infinite;margin-right:7px;vertical-align:-2px}@keyframes jjspin{to{transform:rotate(360deg)}}
.admin-profile-duo{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:14px 0}.admin-person-card{background:#fff;border:1px solid #e4e9f2;border-radius:16px;padding:16px;display:flex;gap:14px;align-items:center}.admin-person-card img{width:68px;height:68px;border-radius:50%;object-fit:cover;border:2px solid #d6a638}.admin-person-card h3{margin:0;color:#06162d}.admin-person-card p{margin:4px 0;color:#65748b}
.invoice-preview,.retainer-result,.resource-output{background:#fff;border:1px solid #e4e9f2;border-radius:16px;padding:18px;margin-top:14px}.invoice-total{font-size:28px;font-weight:900;color:#b4083f}.scope-list,.resource-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.scope-item,.resource-card,.sars-tool-card{background:#fff;border:1px solid #ead49a;border-radius:14px;padding:14px}.resource-card,.sars-tool-card{cursor:pointer}.sars-suite-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.resource-card h3,.sars-tool-card b{color:#06162d}.resource-card p,.sars-tool-card small{color:#65748b}
@media(max-width:1100px){.admin-profile-duo,.scope-list,.resource-grid,.sars-suite-grid{grid-template-columns:1fr}}


/* ============================================================
   PHASE 4950: SERVICE PROGRESS SYNC + DOCUMENT WORKFLOW
   ============================================================ */
.doc-workflow-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:14px}
.doc-card{background:#fff;border:1px solid #e4e9f2;border-radius:14px;padding:14px;margin:10px 0;box-shadow:0 8px 20px rgba(6,22,45,.05)}
.doc-card h3{margin:0 0 8px;color:#06162d}
.doc-status{display:inline-block;border-radius:999px;padding:6px 10px;font-size:11px;font-weight:900;margin-top:6px}
.doc-pending{background:#fff0d5;color:#a15b00}.doc-approved{background:#dcfce7;color:#0b7d3b}.doc-client{background:#eaf2ff;color:#075da8}.doc-returned{background:#ffe8ee;color:#a50f36}
.upload-drop{border:2px dashed #d6a638;border-radius:16px;background:#fffdf6;padding:18px;text-align:center;margin:10px 0}
.client-upload-list{display:grid;gap:10px;margin-top:12px}
.progress-sync-note{background:#eff6ff;border:1px solid #bfdbfe;color:#0b3d74;border-radius:12px;padding:12px;margin:10px 0}
.mini-timeline{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin:12px 0}
.mini-step{background:#fff;border:1px solid #e4e9f2;border-radius:12px;padding:10px;text-align:center;font-weight:900;font-size:12px}
.mini-step.active{background:#dcfce7;color:#0b7d3b;border-color:#86efac}
@media(max-width:1000px){.doc-workflow-grid,.mini-timeline{grid-template-columns:1fr}}


/* ============================================================
   PHASE 4960 DOCUMENT UPLOAD FIX + NALEDI ADMIN PROFILE
   ============================================================ */
.admin-profile-duo.admin-naledi-only{grid-template-columns:1fr!important;max-width:560px}
.file-upload-progress{background:#eff6ff;border:1px solid #bfdbfe;color:#0b3d74;border-radius:12px;padding:12px;margin-top:10px;font-weight:800}
.file-upload-success{background:#dcfce7;border:1px solid #86efac;color:#0b7d3b;border-radius:12px;padding:12px;margin-top:10px;font-weight:800}
.file-upload-error{background:#ffe8ee;border:1px solid #fecdd3;color:#a50f36;border-radius:12px;padding:12px;margin-top:10px;font-weight:800}
.doc-actions-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.doc-actions-row button{border:0;border-radius:10px;padding:9px 12px;font-weight:900;cursor:pointer}
.manager-doc-section{margin-top:18px}

/* PHASE 4980 ADMIN NALEDI + UPLOAD FIX */
.admin-footer-card img,.sidebar-user img,.user-card img{object-fit:cover!important}
#jj4980_admin_footer_profile img{width:54px;height:54px;border-radius:50%;object-fit:cover;border:2px solid #d6a638}
#jj4980_admin_footer_profile{display:flex;gap:12px;align-items:center}


/* ============================================================
   PHASE 4990 FINAL FIXES: NALEDI PROFILE, CLIENT PUBLISH, CALCULATORS
   ============================================================ */
.jj4990-admin-card-fix img{object-fit:cover!important}
.jj4990-client-publish-box{background:#fff;border:1px solid #e4e9f2;border-radius:16px;padding:16px;margin:12px 0}
.jj4990-client-publish-box h3{margin:0 0 8px;color:#06162d}
.jj4990-select-row{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;align-items:end;margin-top:10px}
.jj4990-doc-link{display:inline-flex;align-items:center;gap:6px;font-weight:900;color:#075da8;text-decoration:none}
.jj4990-calc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px}
.jj4990-calc-card{background:#fff;border:1px solid #e4e9f2;border-radius:16px;padding:16px;box-shadow:0 10px 26px rgba(6,22,45,.06)}
.jj4990-calc-card h3{margin:0 0 8px;color:#06162d}
.jj4990-calc-card input,.jj4990-calc-card select{width:100%;border:1px solid #dbe3ee;border-radius:10px;padding:10px;margin:5px 0}
.jj4990-calc-card button{width:100%;border:0;border-radius:10px;padding:10px;background:#b4083f;color:#fff;font-weight:900;margin-top:8px;cursor:pointer}
.jj4990-calc-result{background:#fff9e9;border:1px solid #d6a638;border-radius:12px;padding:12px;margin-top:10px;font-weight:900;color:#06162d}
.jj4990-client-work-docs{background:#f8fafc;border:1px solid #e4e9f2;border-radius:14px;padding:12px;margin-top:12px}
@media(max-width:1100px){.jj4990-calc-grid,.jj4990-select-row{grid-template-columns:1fr}}

/* ============================================================
   PHASE 5010 DOCUMENT FOLDERS, DELETE AUTHORISATION, REPORTS
   ============================================================ */
.jj5010-folder-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}
.jj5010-folder-tab{border:1px solid #d6a638;background:#fff;border-radius:999px;padding:9px 14px;font-weight:900;cursor:pointer;color:#06162d}
.jj5010-folder-tab.active{background:#b4083f;color:#fff;border-color:#b4083f}
.jj5010-folder-section{background:#fff;border:1px solid #e4e9f2;border-radius:16px;padding:16px;margin:14px 0;box-shadow:0 8px 22px rgba(6,22,45,.05)}
.jj5010-folder-title{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}
.jj5010-folder-title h3{margin:0;color:#06162d}
.jj5010-folder-count{background:#fff0d5;color:#9a5f00;border-radius:999px;padding:6px 10px;font-weight:900}
.jj5010-danger{background:#9f1239!important;color:#fff!important}
.jj5010-muted{background:#f8fafc;border:1px solid #e4e9f2;color:#65748b;border-radius:12px;padding:12px;margin:8px 0}
.jj5010-report-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.jj5010-report-card{background:#fff;border:1px solid #e4e9f2;border-radius:16px;padding:16px;margin:10px 0;box-shadow:0 8px 22px rgba(6,22,45,.05)}
.jj5010-report-card h3{margin:0 0 8px;color:#06162d}
.jj5010-report-metric{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:10px 0}
.jj5010-metric{background:#f8fafc;border:1px solid #e4e9f2;border-radius:12px;padding:10px;text-align:center}
.jj5010-metric b{display:block;font-size:20px;color:#b4083f}
.jj5010-challenge-box textarea{width:100%;min-height:80px;border:1px solid #dbe3ee;border-radius:12px;padding:12px}
.jj5010-client-folder-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.jj5010-client-folder{background:#fff;border:1px solid #e4e9f2;border-radius:16px;padding:14px}
.jj5010-client-folder h3{margin:0 0 8px;color:#06162d}
@media(max-width:1100px){.jj5010-report-grid,.jj5010-report-metric,.jj5010-client-folder-grid{grid-template-columns:1fr}}

/* PHASE 5011 FORCE VISIBLE */
.jj5011-active-badge{position:fixed;right:18px;bottom:18px;background:#06162d;color:#fff;border:2px solid #d6a638;border-radius:999px;padding:10px 14px;font-weight:900;z-index:99999;box-shadow:0 12px 30px rgba(0,0,0,.25)}
.jj5011-force-panel{border:2px solid #d6a638!important;box-shadow:0 12px 35px rgba(6,22,45,.10)!important}
.jj5011-folder-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}
.jj5011-folder-tabs button{border:1px solid #d6a638;background:#fff;border-radius:999px;padding:9px 14px;font-weight:900;cursor:pointer}
.jj5011-folder-tabs button.active{background:#b4083f;color:#fff}
.jj5011-doc-folder{background:#fff;border:1px solid #e4e9f2;border-radius:16px;padding:16px;margin:12px 0}
.jj5011-doc-card{background:#f8fafc;border:1px solid #e4e9f2;border-radius:14px;padding:12px;margin:10px 0}
.jj5011-doc-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.jj5011-doc-actions button{border:0;border-radius:10px;padding:9px 12px;font-weight:900;cursor:pointer}
.jj5011-danger{background:#9f1239!important;color:#fff!important}
.jj5011-report-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.jj5011-report-card{background:#fff;border:1px solid #e4e9f2;border-radius:16px;padding:16px}
.jj5011-report-card textarea{width:100%;min-height:90px;border:1px solid #dbe3ee;border-radius:12px;padding:12px}
.jj5011-client-folders{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.jj5011-client-folder{background:#fff;border:1px solid #e4e9f2;border-radius:16px;padding:14px}
@media(max-width:1100px){.jj5011-report-grid,.jj5011-client-folders{grid-template-columns:1fr}}

/* PHASE 5012 DELETE CLIENTS / INVOICES + CONSULTANT PICTURES FIX */
.jj5012-delete-btn{background:#9f1239!important;color:#fff!important;border:0!important;border-radius:10px!important;padding:9px 12px!important;font-weight:900!important;cursor:pointer!important}
.jj5012-delete-request{background:#fff0f4;border:1px solid #fecdd3;color:#9f1239;border-radius:12px;padding:10px;margin:8px 0;font-weight:800}
.jj5012-row-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.jj5012-pic-fix-badge{display:inline-block;background:#dcfce7;color:#0b7d3b;border-radius:999px;padding:4px 8px;font-size:11px;font-weight:900;margin-left:8px}

/* PHASE 5013 FORCE CLIENT DELETE + PICTURE FIX */
.jj5013-force-badge{position:fixed;left:18px;bottom:18px;background:#7e0f31;color:#fff;border:2px solid #d6a638;border-radius:999px;padding:10px 14px;font-weight:900;z-index:999999;box-shadow:0 12px 30px rgba(0,0,0,.25)}
.jj5013-client-delete-panel,.jj5013-invoice-delete-panel{background:#fff;border:2px solid #d6a638;border-radius:16px;padding:16px;margin:14px 0;box-shadow:0 12px 30px rgba(6,22,45,.08)}
.jj5013-delete-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;background:#fff7f7;border:1px solid #fecdd3;border-radius:12px;padding:12px;margin:8px 0}
.jj5013-delete-btn{background:#9f1239!important;color:#fff!important;border:0!important;border-radius:10px!important;padding:9px 12px!important;font-weight:900!important;cursor:pointer!important}
.jj5013-consultant-picture-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:12px 0}
.jj5013-consultant-card{background:#fff;border:1px solid #e4e9f2;border-radius:16px;padding:14px;text-align:center}
.jj5013-consultant-card img{width:88px;height:88px;border-radius:50%;object-fit:cover;border:3px solid #d6a638}
@media(max-width:1000px){.jj5013-client-delete-row,.jj5013-consultant-picture-grid{grid-template-columns:1fr}}

/* PHASE 5014 CLEAN REPAIR */
.jj5011-active-badge,.jj5013-force-badge{display:none!important}
.jj5014-clean-panel{background:#fff;border:1px solid #e4e9f2;border-radius:16px;padding:16px;margin:14px 0;box-shadow:0 10px 28px rgba(6,22,45,.06)}
.jj5014-delete-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;background:#fff7f7;border:1px solid #fecdd3;border-radius:12px;padding:12px;margin:8px 0}
.jj5014-delete-btn{background:#9f1239!important;color:#fff!important;border:0!important;border-radius:10px!important;padding:9px 12px!important;font-weight:900!important;cursor:pointer!important}
.jj5014-small-note{background:#f8fafc;border:1px solid #e4e9f2;border-radius:12px;padding:10px;margin:8px 0;color:#334155}
.jj5014-consultant-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:12px 0}
.jj5014-consultant-card{background:#fff;border:1px solid #e4e9f2;border-radius:16px;padding:14px;text-align:center}
.jj5014-consultant-card img{width:86px;height:86px;border-radius:50%;object-fit:cover;border:3px solid #d6a638}
@media(max-width:1000px){.jj5014-delete-row,.jj5014-consultant-grid{grid-template-columns:1fr}}

/* PHASE 5015 REAL CONSULTANT PICTURES + ADMIN DELETE BUTTONS */
.jj5011-active-badge,.jj5013-force-badge{display:none!important}
.jj5015-admin-delete-panel{background:#fff;border:2px solid #d6a638;border-radius:16px;padding:16px;margin:14px 0;box-shadow:0 10px 28px rgba(6,22,45,.06)}
.jj5015-admin-delete-panel h2{margin:0 0 8px;color:#06162d}
.jj5015-delete-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;background:#fff7f7;border:1px solid #fecdd3;border-radius:12px;padding:12px;margin:8px 0}
.jj5015-delete-btn{background:#9f1239!important;color:#fff!important;border:0!important;border-radius:10px!important;padding:9px 12px!important;font-weight:900!important;cursor:pointer!important}
.jj5015-delete-btn:hover{filter:brightness(.95)}
.jj5015-small-note{background:#f8fafc;border:1px solid #e4e9f2;border-radius:12px;padding:10px;margin:8px 0;color:#334155}
.jj5015-pic-note{background:#ecfdf5;border:1px solid #86efac;border-radius:12px;padding:8px 10px;margin:8px 0;color:#166534;font-weight:800}
.jj5015-consultant-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:12px 0}
.jj5015-consultant-card{background:#fff;border:1px solid #e4e9f2;border-radius:16px;padding:14px;text-align:center}
.jj5015-consultant-card img{width:88px;height:88px;border-radius:50%;object-fit:cover;border:3px solid #d6a638}
@media(max-width:1000px){.jj5015-delete-row,.jj5015-consultant-grid{grid-template-columns:1fr}}
