:root{--bg:#f4f7fb;--card:#fff;--text:#172033;--muted:#65758b;--border:#e8eef7;--primary:#2663eb;--primary2:#06b6d4;--ok:#16a34a;--warn:#d97706;--bad:#dc2626;--shadow:0 18px 50px rgba(17,24,39,.08);--sidebar:#0f172a;--sidebar2:#111827;--field:#fff}
html[data-theme=dark]{--bg:#0b1220;--card:#111b2e;--text:#e5eefb;--muted:#94a3b8;--border:#23314a;--primary:#60a5fa;--primary2:#22d3ee;--shadow:0 18px 50px rgba(0,0,0,.24);--sidebar:#07101f;--sidebar2:#0c1728;--field:#0b1220}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text)}
a{color:inherit;text-decoration:none}
.loading-overlay{position:fixed;inset:0;z-index:99999;display:grid;place-items:center;background:rgba(244,247,251,.92);backdrop-filter:blur(8px);transition:.3s}
.loading-overlay.hidden{opacity:0;pointer-events:none}
.loader-card{background:var(--card);border:1px solid var(--border);border-radius:24px;padding:26px;min-width:min(360px,90vw);text-align:center;box-shadow:var(--shadow);display:grid;gap:10px}
.loader-ring{width:52px;height:52px;border:5px solid var(--border);border-top-color:var(--primary);border-radius:50%;margin:auto;animation:spin 1s linear infinite}.loader-card span{color:var(--muted);font-size:14px;line-height:1.5}.loader-progress{height:8px;background:var(--bg);border:1px solid var(--border);border-radius:999px;overflow:hidden}.loader-progress span{display:block;height:100%;width:0%;background:linear-gradient(135deg,var(--primary),var(--primary2));border-radius:999px;transition:width .45s ease}
@keyframes spin{to{transform:rotate(360deg)}}

.app-shell{display:grid;grid-template-columns:290px 1fr;min-height:100vh}
.sidebar{background:linear-gradient(180deg,var(--sidebar),var(--sidebar2));color:#dbeafe;padding:24px;display:flex;flex-direction:column;gap:26px;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{width:48px;height:48px;border-radius:16px;background:linear-gradient(135deg,var(--primary),var(--primary2));display:grid;place-items:center;color:#fff;font-weight:900}
.brand h2,.brand p{margin:0}
.brand p{font-size:12px;color:#aeb8ca}
.nav{display:grid;gap:8px}
.nav a{padding:13px 14px;border-radius:14px;color:#cbd5e1;transition:.2s}
.nav a:hover,.nav a.active{background:rgba(255,255,255,.1);color:#fff}
.sidebar-note{margin-top:auto;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:16px}
.sidebar-note span{font-weight:800;color:#fff}
.sidebar-note p{color:#b9c4d7;font-size:13px;line-height:1.5}
.logout{padding:12px 14px;border-radius:14px;background:rgba(239,68,68,.15);color:#fecaca}
.main{padding:28px;overflow-x:hidden}

.topbar{display:flex;justify-content:space-between;align-items:center;background:var(--card);border:1px solid var(--border);border-radius:26px;padding:22px 24px;margin-bottom:24px;box-shadow:var(--shadow)}
.eyebrow{margin:0 0 6px;color:var(--primary);font-weight:800;text-transform:uppercase;font-size:12px;letter-spacing:.08em}
.topbar h1{margin:0;font-size:30px}
.top-actions{display:flex;align-items:center;gap:12px}
.icon-btn{border:1px solid var(--border);background:var(--field);color:var(--text);width:42px;height:42px;border-radius:14px;cursor:pointer}
.credit-chip,.user-chip{background:var(--bg);border:1px solid var(--border);padding:10px 14px;border-radius:999px;font-weight:800}
.credit-chip{color:var(--ok)}

.toast{padding:14px 16px;border-radius:16px;margin-bottom:18px;border:1px solid var(--border);font-weight:700}
.toast-success{background:#dcfce7;color:#166534}
.toast-error{background:#fee2e2;color:#991b1b}
.toast-info{background:#dbeafe;color:#1d4ed8}

.card,.hero-card,.tender-card,.feature-card,.stat-card,.risk-card{background:var(--card);border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow)}
.card{padding:22px;margin-bottom:22px}
.hero-grid{display:grid;grid-template-columns:1fr 280px;gap:20px;margin-bottom:22px}
.hero-card{padding:28px}
.hero-card h2{font-size:34px;line-height:1.1;margin:0 0 14px}
.hero-card p{color:var(--muted);max-width:760px}
.hero-actions{display:flex;gap:10px;margin-top:18px}
.risk-card{padding:24px;display:grid;align-content:center}
.risk-card strong{font-size:48px}
.risk-label{color:var(--muted);font-weight:800}

.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:22px}
.stat-card{padding:20px}
.stat-card span{color:var(--muted);font-weight:700}
.stat-card strong{display:block;font-size:34px;margin:6px 0}
.stat-card small{color:var(--muted)}
.split-grid{display:grid;grid-template-columns:1.35fr .75fr;gap:20px}
.section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px}
.section-head h3{margin:0;font-size:22px}
.section-head p,.muted{color:var(--muted)}

.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:13px;border-bottom:1px solid var(--border);vertical-align:top}
th{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;background:var(--bg)}
td span,small{color:var(--muted)}

.status,.doc-status,.grade-pill{display:inline-flex;align-items:center;padding:7px 10px;border-radius:999px;font-size:12px;font-weight:900}
.status-drafting{background:#dbeafe;color:#1d4ed8}
.status-couriered{background:#fef3c7;color:#92400e}
.status-submitted,.doc-status.good{background:#dcfce7;color:#166534}
.doc-status.bad{background:#fee2e2;color:#991b1b}
.doc-status.warn{background:#fef3c7;color:#92400e}
.doc-status.neutral,.grade-pill{background:var(--bg);color:var(--text);border:1px solid var(--border)}

.btn-primary,.btn-secondary,button{border:0;border-radius:14px;padding:11px 16px;font-weight:900;cursor:pointer}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff}
.btn-secondary{background:var(--bg);border:1px solid var(--border);color:var(--text)}
.link{color:var(--primary);font-weight:800}

.form,.form-grid{display:grid;gap:14px}
.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.wide{grid-column:1/-1}
.align-end{align-self:end}
label{font-weight:800;font-size:13px;margin-bottom:6px;display:block}
input,select,textarea{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:14px;background:var(--field);color:var(--text)}
input:focus,select:focus,textarea:focus{outline:3px solid rgba(37,99,235,.12);border-color:var(--primary)}

.toolbar-form{display:grid;grid-template-columns:320px 1fr auto;gap:14px;align-items:end}
.tender-list{display:grid;gap:16px}
.tender-card{padding:20px}
.tender-main{display:grid;grid-template-columns:1fr 360px;gap:18px}
.tender-main h3{margin:0 0 8px;font-size:22px}
.tender-meta{display:grid;gap:8px;color:var(--muted);font-size:14px}
details{margin-top:14px;border-top:1px solid var(--border);padding-top:12px}
summary{cursor:pointer;color:var(--primary);font-weight:900}
.details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 20px;margin-top:12px}
.action-row{display:grid;grid-template-columns:1fr auto;gap:12px;margin-top:14px}

.compliance-layout{display:grid;grid-template-columns:1fr 260px;gap:20px}
.compliance-panel{position:sticky;top:22px;align-self:start}
.check-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.check-list li{display:flex;gap:10px;align-items:flex-start;border:1px solid var(--border);border-radius:14px;padding:10px}
.check-list li span{min-width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-weight:900}
.check-list li.ok span{background:#dcfce7;color:#166534}
.check-list li.missing span{background:#fee2e2;color:#991b1b}
.check-list small{display:block}
.compact li{padding:8px}

.company-editor{border:1px solid var(--border);border-radius:18px;padding:16px;margin-bottom:16px}
.company-editor summary{font-size:18px}
.company-editor summary span{font-size:13px;color:var(--muted);margin-left:10px}
.grade-grid{display:grid;grid-template-columns:repeat(4,1fr) repeat(4,1fr);gap:12px}
.price-list{list-style:none;margin:0;padding:0;display:grid;gap:12px}
.price-list li{display:flex;justify-content:space-between;border:1px solid var(--border);border-radius:14px;padding:12px}
.blurred-price{filter:blur(4px);user-select:none}

.auth-shell{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at 15% 15%,rgba(38,99,235,.25),transparent 35%),radial-gradient(circle at 85% 85%,rgba(6,182,212,.22),transparent 35%),var(--bg);padding:24px}
.auth-card{width:min(460px,100%);background:var(--card);border:1px solid var(--border);border-radius:30px;padding:32px;box-shadow:var(--shadow)}
.auth-card h1{margin-bottom:8px}
.auth-card p{color:var(--muted)}
.auth-brand{margin-bottom:20px}
.auth-card a{color:var(--primary);font-weight:900}
.empty{text-align:center;padding:34px;color:var(--muted)}
.ai-hero{margin-bottom:20px}
.features-grid{grid-template-columns:repeat(4,1fr)}
.feature-card{padding:22px}
.feature-card p{color:var(--muted)}

/* Incremental workflow improvements */
.enhanced-toolbar{grid-template-columns:300px 1fr 210px auto}
.small-help{font-size:13px;margin:10px 0 0}
.notification-list{display:grid;gap:12px}
.notification-item{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:flex-start;border:1px solid var(--border);border-radius:18px;padding:14px;background:var(--field);transition:.2s}
.notification-item:hover{transform:translateY(-1px);box-shadow:var(--shadow)}
.notification-item.unread{border-color:var(--primary)}
.notification-item p{margin:4px 0;color:var(--muted)}
.notification-item small{color:var(--muted)}
.feature-card textarea{margin-bottom:10px}
.small-help strong{color:var(--text)}

.nav-notification-link{display:flex;align-items:center;justify-content:space-between;gap:8px}
.nav-badge,.bell-badge{min-width:22px;height:22px;border-radius:999px;background:#ef4444;color:#fff;font-size:12px;font-weight:900;display:inline-grid;place-items:center;padding:0 6px}
.notification-bell{position:relative;display:grid;place-items:center;text-decoration:none}
.bell-badge{position:absolute;top:-7px;right:-7px;min-width:20px;height:20px;font-size:11px}

/* Create Tender Request: collapsed only */
.create-request-collapse{padding:0;overflow:hidden;margin-bottom:24px}
.create-request-collapse>summary{border-top:0;margin:0;padding:26px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px;list-style:none;color:var(--text)}
.create-request-collapse>summary::-webkit-details-marker{display:none}
.create-request-collapse>summary h2,.create-request-collapse>summary h3{margin:0 0 6px}
.create-request-collapse>summary p{margin:0;color:var(--muted);font-weight:500}
.collapse-icon{width:34px;height:34px;border-radius:999px;display:grid;place-items:center;background:var(--bg);border:1px solid var(--border);font-weight:900;color:var(--primary);transition:.25s}
.create-request-collapse[open] .collapse-icon{transform:rotate(45deg)}
.create-request-collapse form{padding:0 28px 28px}

/* My Projects normal list/card */
.project-list{display:grid;gap:16px}
.project-item{border:1px solid var(--border);border-radius:20px;background:var(--field);padding:18px;box-shadow:0 10px 25px rgba(17,24,39,.04)}
.project-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.project-top h3{margin:0 0 8px;font-size:20px;line-height:1.25}
.project-top h3 small{display:block;margin-top:4px;font-size:13px;color:var(--muted);font-weight:700}
.meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:13px}
.meta span{background:var(--bg);border:1px solid var(--border);border-radius:999px;padding:6px 10px}
.price-block{flex:0 0 auto;text-align:right}
.price,.money-nowrap{white-space:nowrap;display:inline-block;font-variant-numeric:tabular-nums;font-weight:900}
.price{font-size:18px;color:var(--text)}
.price.pending{color:var(--warn)}
.blurred-price.money-nowrap,.blurred-price{white-space:nowrap;display:inline-block;min-width:135px;text-align:right;font-weight:900}
.project-bottom{display:flex;gap:14px;flex-wrap:wrap;margin-top:14px;color:var(--muted);font-size:13px}
.project-bottom span{white-space:nowrap}

/* Responsive */
@media(max-width:1050px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:relative;height:auto}
  .stats-grid,.features-grid{grid-template-columns:repeat(2,1fr)}
  .hero-grid,.split-grid,.compliance-layout,.tender-main{grid-template-columns:1fr}
  .toolbar-form{grid-template-columns:1fr}
  .grade-grid{grid-template-columns:1fr 1fr}
  .form-grid{grid-template-columns:1fr}
  .enhanced-toolbar{grid-template-columns:1fr}
  .project-top{flex-direction:column}
  .price-block{text-align:left}
}
@media(max-width:640px){
  .main{padding:16px}
  .topbar,.top-actions{align-items:flex-start;flex-direction:column}
  .stats-grid,.features-grid{grid-template-columns:1fr}
  .action-row{grid-template-columns:1fr}
  .details-grid{grid-template-columns:1fr}
  .hero-card h2{font-size:26px}
  .project-bottom span{white-space:normal}
}
/* Price library edit/re-upload and PayFast package improvements */
.hidden{display:none!important}
.credit-package-grid .package-card{display:grid;gap:12px;align-content:start}
.credit-package-grid .package-card button{margin-top:8px;width:100%}
.price-library-table td{vertical-align:middle}
.editable-instructions{min-width:280px;max-width:520px}
.instruction-view{cursor:text;border:1px dashed transparent;border-radius:12px;padding:8px;white-space:pre-wrap}
.instruction-view:hover{border-color:var(--border);background:var(--bg)}
.inline-edit-form{display:grid;gap:8px}
.inline-actions{display:flex;gap:8px;flex-wrap:wrap}
.replace-form{display:grid;grid-template-columns:minmax(160px,1fr) auto;gap:8px;align-items:center;min-width:300px}
@media(max-width:640px){.replace-form{grid-template-columns:1fr}.editable-instructions{min-width:220px}}

/* NextBid branding additions */
.brand-logo-mark {
  width: 42px;
  height: 42px;
  object-fit: contain;
  border-radius: 12px;
  background: #061538;
  padding: 4px;
}
.auth-brand .brand-logo-mark {
  width: 54px;
  height: 54px;
}
.notification-read-form { width: 100%; }
.notification-actions { display: flex; justify-content: flex-end; margin-bottom: 12px; }
.notification-row { display: grid; grid-template-columns: 34px 1fr; gap: 10px; align-items: stretch; }
.notification-check { display: flex; align-items: center; justify-content: center; }
.notification-check input { width: 18px; height: 18px; }


/* Readability fix: keep dates, money and status badges readable in tables/cards.
   Tables should scroll horizontally on small screens instead of breaking values like R 4 / 300.00. */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.table-wrap table{min-width:720px}
.date-nowrap,.money-nowrap,.num-nowrap,.status-nowrap{white-space:nowrap;word-break:normal;overflow-wrap:normal;font-variant-numeric:tabular-nums}
td.date-nowrap,td.money-nowrap,td.num-nowrap,td.status-nowrap{vertical-align:middle}
.status-nowrap .status{white-space:nowrap}
.tender-meta .date-nowrap,.project-bottom .date-nowrap{display:inline-flex;white-space:nowrap}
@media(max-width:640px){
  .table-wrap{margin-left:-4px;margin-right:-4px;padding-bottom:4px}
  .table-wrap table{min-width:760px}
  th,td{padding:12px 16px}
}


/* Sidebar compact fit/collapse fix */
.app-shell{grid-template-columns:300px 1fr;transition:grid-template-columns .22s ease}
.app-shell.sidebar-collapsed{grid-template-columns:92px 1fr}
.sidebar{height:100dvh;min-height:0;padding:18px 20px;gap:14px;overflow:hidden;display:flex;flex-direction:column}
.sidebar-brand{display:grid;grid-template-columns:42px 1fr;gap:12px;align-items:center;flex:0 0 auto}
.sidebar .brand-logo-mark{width:42px;height:42px;border-radius:12px;flex:0 0 auto}
.brand-copy{min-width:0}
.brand-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0}
.brand-title-row h2{margin:0;font-size:28px;line-height:1;letter-spacing:.02em;white-space:nowrap}
.brand-copy p{margin:4px 0 0;font-size:14px;color:#dbeafe;white-space:nowrap}
.sidebar-toggle{width:38px;height:38px;min-width:38px;border-radius:13px;background:#fff;color:#111827;border:0;display:grid;place-items:center;padding:0;font-size:18px;line-height:1;box-shadow:0 8px 20px rgba(0,0,0,.16)}
.sidebar-nav{display:flex;flex-direction:column;gap:5px;flex:1 1 auto;min-height:0;overflow:hidden;padding-top:8px}
.sidebar-nav .nav-item,.sidebar-footer .support-email,.sidebar-footer .logout{display:flex;align-items:center;gap:14px;min-height:42px;padding:9px 12px;border-radius:14px;color:#e5eefb;line-height:1.1;font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-nav .nav-item:hover,.sidebar-nav .nav-item.active{background:rgba(255,255,255,.1);color:#fff}
.nav-icon{width:22px;min-width:22px;display:inline-grid;place-items:center;text-align:center;font-size:17px;line-height:1}
.nav-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav-badge{margin-left:auto;min-width:22px;height:22px;border-radius:999px;background:#2563eb;color:#fff;font-size:12px;font-weight:900;display:inline-grid;place-items:center;padding:0 6px;flex:0 0 auto}
.sidebar-note{display:none!important}
.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:6px;flex:0 0 auto;min-width:0}
.sidebar-footer .support-email{font-size:14px;color:#dbeafe;background:transparent;border:1px solid rgba(255,255,255,.08)}
.sidebar-footer .logout{background:rgba(239,68,68,.16);color:#fecaca;font-size:16px}

.app-shell.sidebar-collapsed .sidebar{padding:18px 14px;align-items:center}
.app-shell.sidebar-collapsed .sidebar-brand{display:flex;flex-direction:column;gap:10px;width:100%}
.app-shell.sidebar-collapsed .brand-copy{width:100%;display:flex;justify-content:center}
.app-shell.sidebar-collapsed .brand-title-row{justify-content:center;width:100%}
.app-shell.sidebar-collapsed .brand-title-row h2,.app-shell.sidebar-collapsed .brand-copy p,.app-shell.sidebar-collapsed .nav-label,.app-shell.sidebar-collapsed .nav-badge{display:none!important}
.app-shell.sidebar-collapsed .sidebar-toggle{width:42px;height:42px;min-width:42px;border-radius:14px}
.app-shell.sidebar-collapsed .sidebar-nav{align-items:center;width:100%;gap:6px;padding-top:4px}
.app-shell.sidebar-collapsed .sidebar-nav .nav-item,.app-shell.sidebar-collapsed .sidebar-footer .support-email,.app-shell.sidebar-collapsed .sidebar-footer .logout{width:54px;min-height:42px;padding:9px 0;justify-content:center;gap:0;border-radius:14px}
.app-shell.sidebar-collapsed .nav-icon{width:100%;min-width:0;font-size:18px}
.app-shell.sidebar-collapsed .sidebar-footer{align-items:center;width:100%}
@media(max-height:760px){
  .sidebar{padding-top:14px;padding-bottom:14px;gap:10px}
  .brand-title-row h2{font-size:25px}.brand-copy p{font-size:12px}
  .sidebar-nav .nav-item,.sidebar-footer .support-email,.sidebar-footer .logout{min-height:38px;padding-top:7px;padding-bottom:7px;font-size:15px}
  .nav-icon{font-size:15px}.sidebar-footer .support-email{font-size:12px}.sidebar-footer .logout{font-size:14px}
}
@media(max-width:1050px){
  .app-shell,.app-shell.sidebar-collapsed{grid-template-columns:1fr}
  .sidebar{position:relative;height:auto;min-height:auto;overflow:visible}
  .app-shell.sidebar-collapsed .sidebar{align-items:stretch}
  .app-shell.sidebar-collapsed .sidebar-brand{flex-direction:row}
  .app-shell.sidebar-collapsed .brand-title-row h2,.app-shell.sidebar-collapsed .brand-copy p,.app-shell.sidebar-collapsed .nav-label{display:inline!important}
  .app-shell.sidebar-collapsed .sidebar-nav .nav-item,.app-shell.sidebar-collapsed .sidebar-footer .support-email,.app-shell.sidebar-collapsed .sidebar-footer .logout{width:auto;justify-content:flex-start;padding:9px 12px;gap:14px}
}


/* Sidebar notification alignment fix.
   The older .nav-notification-link rule used justify-content:space-between, which pushed
   the Notifications label away from its icon. Keep icon + label together and put the
   unread counter on the far right only when the counter exists. */
.sidebar-nav .nav-notification-link{
  justify-content:flex-start!important;
}
.sidebar-nav .nav-notification-link .nav-label{
  margin-left:0;
}
.sidebar-nav .nav-notification-link .nav-badge{
  margin-left:auto;
}


/* Auth/password reset additions */
.password-field{display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px}
.password-field input{min-width:0}
.password-toggle{height:44px;border:1px solid var(--border);background:var(--card);color:var(--text);border-radius:12px;padding:0 14px;font-weight:800;cursor:pointer}
.password-toggle:hover{border-color:var(--accent);color:var(--accent)}
.field-help{margin:-4px 0 4px;color:var(--muted);font-size:13px;line-height:1.35}
.auth-link-row{margin-top:12px;margin-bottom:0}


/* Mobile menu overlay fix: sidebar slides over content instead of occupying the top of the page. */
.mobile-menu-trigger,
.mobile-sidebar-backdrop{display:none}

@media(max-width:1050px){
  body.mobile-menu-lock{overflow:hidden;touch-action:none}
  .app-shell,
  .app-shell.sidebar-collapsed{display:block;min-height:100vh;grid-template-columns:1fr!important}
  .main{width:100%;padding:18px 12px 28px;transition:filter .22s ease}

  .mobile-menu-trigger{position:fixed;top:14px;left:14px;z-index:10035;width:42px;height:42px;border:0;border-radius:14px;background:#fff;color:#0f172a;display:grid;place-items:center;font-size:20px;font-weight:900;line-height:1;box-shadow:0 12px 30px rgba(15,23,42,.22)}
  .mobile-menu-trigger:active{transform:scale(.97)}

  .mobile-sidebar-backdrop{display:block;position:fixed;inset:0;background:rgba(2,6,23,.52);backdrop-filter:blur(3px);z-index:10010;opacity:0;pointer-events:none;transition:opacity .25s ease}
  .app-shell.mobile-menu-open .mobile-sidebar-backdrop{opacity:1;pointer-events:auto}

  .sidebar{position:fixed!important;top:0!important;left:0!important;bottom:0!important;z-index:10025;width:min(84vw,330px);max-width:330px;height:100dvh!important;min-height:100dvh!important;padding:18px 18px 16px!important;overflow:hidden!important;display:flex!important;flex-direction:column!important;gap:14px!important;box-shadow:22px 0 50px rgba(2,6,23,.38);transform:translateX(-110%);opacity:1;visibility:hidden;transition:transform .28s cubic-bezier(.2,.8,.2,1),visibility .28s ease}
  .app-shell.mobile-menu-open .sidebar{transform:translateX(0);visibility:visible}
  .app-shell.mobile-menu-closing .sidebar{transform:translateX(110%);visibility:visible}

  .sidebar-brand{display:grid!important;grid-template-columns:42px 1fr;gap:12px;width:100%;align-items:center}
  .brand-copy{display:block!important;min-width:0;width:100%}
  .brand-title-row{display:flex!important;align-items:center;justify-content:space-between;gap:8px;width:100%}
  .brand-title-row h2{display:block!important;font-size:26px!important;max-width:190px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .brand-copy p{display:block!important;font-size:12px!important;margin-top:3px!important;color:#dbeafe!important;white-space:nowrap}
  .sidebar-toggle{width:36px!important;height:36px!important;min-width:36px!important;border-radius:12px!important;font-size:0!important;position:relative;flex:0 0 auto}
  .sidebar-toggle::before{content:'×';font-size:26px;line-height:1;color:#111827;font-weight:600}

  .sidebar-nav{display:flex!important;flex-direction:column!important;gap:7px!important;flex:1 1 auto!important;overflow:auto!important;min-height:0!important;padding:10px 0 4px!important;width:100%!important;align-items:stretch!important;-webkit-overflow-scrolling:touch}
  .sidebar-nav .nav-item,
  .sidebar-footer .support-email,
  .sidebar-footer .logout{width:100%!important;min-height:46px!important;padding:11px 14px!important;justify-content:flex-start!important;gap:14px!important;border-radius:15px!important;font-size:16px!important;line-height:1.15!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}
  .nav-icon{width:22px!important;min-width:22px!important;font-size:18px!important;display:inline-grid!important;place-items:center!important}
  .nav-label{display:inline-block!important;min-width:0!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}
  .nav-badge{display:inline-grid!important;margin-left:auto!important;min-width:22px!important;height:22px!important;font-size:12px!important;place-items:center!important}
  .sidebar-footer{margin-top:auto!important;width:100%!important;display:flex!important;flex-direction:column!important;gap:8px!important;align-items:stretch!important;flex:0 0 auto!important}

  .app-shell.sidebar-collapsed .sidebar{padding:18px 18px 16px!important;align-items:stretch!important}
  .app-shell.sidebar-collapsed .sidebar-brand{display:grid!important;grid-template-columns:42px 1fr!important;flex-direction:initial!important}
  .app-shell.sidebar-collapsed .brand-title-row h2,
  .app-shell.sidebar-collapsed .brand-copy p,
  .app-shell.sidebar-collapsed .nav-label,
  .app-shell.sidebar-collapsed .nav-badge{display:inline-block!important}
  .app-shell.sidebar-collapsed .nav-badge{display:inline-grid!important}
  .app-shell.sidebar-collapsed .sidebar-nav .nav-item,
  .app-shell.sidebar-collapsed .sidebar-footer .support-email,
  .app-shell.sidebar-collapsed .sidebar-footer .logout{width:100%!important;justify-content:flex-start!important;padding:11px 14px!important;gap:14px!important}

  .topbar{margin-top:8px;padding:18px 16px;border-radius:22px}
  .topbar h1{font-size:24px}
  .top-actions{gap:7px;flex-wrap:wrap;justify-content:flex-end}
  .icon-btn{width:38px;height:38px;border-radius:13px}
  .credit-chip,.user-chip{padding:9px 11px;font-size:13px}
}


/* Mobile off-canvas menu correction: only the floating menu button is visible when closed. */
@media (max-width: 1050px){
  html,body{overflow-x:hidden}
  .app-shell,
  .app-shell.sidebar-collapsed{
    display:block!important;
    grid-template-columns:1fr!important;
    min-height:100vh!important;
  }
  .main{
    width:100%!important;
    min-width:0!important;
    padding:18px 12px 28px!important;
  }

  /* Floating mobile menu button: always visible and fixed while scrolling. */
  .mobile-menu-trigger{
    display:grid!important;
    position:fixed!important;
    top:max(12px, env(safe-area-inset-top))!important;
    right:14px!important;
    left:auto!important;
    z-index:12050!important;
    width:42px!important;
    height:42px!important;
    min-width:42px!important;
    border:1px solid rgba(255,255,255,.65)!important;
    border-radius:14px!important;
    background:#ffffff!important;
    color:#0f172a!important;
    place-items:center!important;
    font-size:20px!important;
    font-weight:900!important;
    line-height:1!important;
    padding:0!important;
    box-shadow:0 12px 30px rgba(15,23,42,.25)!important;
  }
  .app-shell.mobile-menu-open .mobile-menu-trigger{
    background:#fff!important;
    color:#0f172a!important;
  }

  /* Backdrop overlays the content. */
  .mobile-sidebar-backdrop{
    display:block!important;
    position:fixed!important;
    inset:0!important;
    z-index:12010!important;
    background:rgba(2,6,23,.55)!important;
    backdrop-filter:blur(3px)!important;
    opacity:0!important;
    pointer-events:none!important;
    transition:opacity .24s ease!important;
  }
  .app-shell.mobile-menu-open .mobile-sidebar-backdrop{
    opacity:1!important;
    pointer-events:auto!important;
  }

  /* Sidebar is removed from page flow on mobile. Closed = completely hidden off-canvas. */
  .sidebar,
  .app-shell.sidebar-collapsed .sidebar{
    position:fixed!important;
    top:0!important;
    left:0!important;
    bottom:0!important;
    z-index:12030!important;
    width:min(86vw,340px)!important;
    max-width:340px!important;
    height:100dvh!important;
    min-height:100dvh!important;
    padding:18px 18px 16px!important;
    display:flex!important;
    flex-direction:column!important;
    gap:14px!important;
    overflow:hidden!important;
    transform:translateX(-108%)!important;
    visibility:hidden!important;
    opacity:1!important;
    box-shadow:22px 0 55px rgba(2,6,23,.42)!important;
    transition:transform .28s cubic-bezier(.2,.8,.2,1), visibility .28s ease!important;
  }
  .app-shell.mobile-menu-open .sidebar{
    transform:translateX(0)!important;
    visibility:visible!important;
  }
  .app-shell.mobile-menu-closing .sidebar{
    transform:translateX(-108%)!important;
    visibility:visible!important;
  }

  /* Do not show the old inside-sidebar toggle on mobile; use the floating button only. */
  .sidebar .sidebar-toggle{
    display:none!important;
  }

  .sidebar-brand,
  .app-shell.sidebar-collapsed .sidebar-brand{
    display:grid!important;
    grid-template-columns:42px 1fr!important;
    gap:12px!important;
    width:100%!important;
    align-items:center!important;
    flex:0 0 auto!important;
  }
  .sidebar .brand-logo-mark{width:42px!important;height:42px!important;border-radius:12px!important}
  .brand-copy,
  .app-shell.sidebar-collapsed .brand-copy{display:block!important;width:100%!important;min-width:0!important}
  .brand-title-row,
  .app-shell.sidebar-collapsed .brand-title-row{display:block!important;width:100%!important}
  .brand-title-row h2,
  .app-shell.sidebar-collapsed .brand-title-row h2{display:block!important;font-size:26px!important;line-height:1.05!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}
  .brand-copy p,
  .app-shell.sidebar-collapsed .brand-copy p{display:block!important;font-size:12px!important;margin-top:4px!important;color:#dbeafe!important;white-space:nowrap!important}

  .sidebar-nav,
  .app-shell.sidebar-collapsed .sidebar-nav{
    display:flex!important;
    flex-direction:column!important;
    align-items:stretch!important;
    width:100%!important;
    gap:7px!important;
    flex:1 1 auto!important;
    min-height:0!important;
    overflow:auto!important;
    padding:10px 0 4px!important;
    -webkit-overflow-scrolling:touch!important;
  }
  .sidebar-nav .nav-item,
  .sidebar-footer .support-email,
  .sidebar-footer .logout,
  .app-shell.sidebar-collapsed .sidebar-nav .nav-item,
  .app-shell.sidebar-collapsed .sidebar-footer .support-email,
  .app-shell.sidebar-collapsed .sidebar-footer .logout{
    width:100%!important;
    min-height:46px!important;
    padding:11px 14px!important;
    display:flex!important;
    align-items:center!important;
    justify-content:flex-start!important;
    gap:14px!important;
    border-radius:15px!important;
    font-size:16px!important;
    line-height:1.15!important;
    white-space:nowrap!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
  }
  .nav-icon{width:22px!important;min-width:22px!important;display:inline-grid!important;place-items:center!important;font-size:18px!important;line-height:1!important}
  .nav-label,
  .app-shell.sidebar-collapsed .nav-label{display:inline-block!important;min-width:0!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}
  .nav-badge,
  .app-shell.sidebar-collapsed .nav-badge{display:inline-grid!important;margin-left:auto!important;min-width:22px!important;height:22px!important;font-size:12px!important;place-items:center!important;flex:0 0 auto!important}
  .sidebar-footer,
  .app-shell.sidebar-collapsed .sidebar-footer{margin-top:auto!important;width:100%!important;display:flex!important;flex-direction:column!important;gap:8px!important;align-items:stretch!important;flex:0 0 auto!important}

  body.mobile-menu-lock{overflow:hidden!important;touch-action:none!important}
}

@media (max-width: 480px){
  .mobile-menu-trigger{top:max(10px, env(safe-area-inset-top))!important;right:10px!important;width:40px!important;height:40px!important;min-width:40px!important;border-radius:13px!important}
  .sidebar,.app-shell.sidebar-collapsed .sidebar{width:min(88vw,330px)!important;padding:16px 16px 14px!important}
}


/* Friendly error dialog */
.error-page-shell{min-height:62vh;display:flex;align-items:center;justify-content:center;padding:28px}
.error-dialog{width:min(560px,100%);background:var(--card);border:1px solid var(--border);border-radius:28px;padding:30px;box-shadow:var(--shadow);text-align:center}
.error-dialog-icon{width:54px;height:54px;border-radius:18px;margin:0 auto 14px;background:#fee2e2;color:#991b1b;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:900}
.error-message{color:var(--muted);font-size:16px;line-height:1.55;margin:10px 0 0}
.error-after-three{margin:14px 0 0;color:#991b1b;font-weight:800}
.error-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:22px}
.error-actions .btn-primary,.error-actions .btn-secondary{width:auto;min-width:150px;text-align:center}
.hidden{display:none!important}
@media(max-width:640px){.error-page-shell{padding:18px}.error-dialog{padding:24px;border-radius:24px}.error-actions .btn-primary,.error-actions .btn-secondary{width:100%}}

/* Compliance uploaded documents alignment + delete button fix */
.compliance-documents-table,
.uploaded-documents-table{
  width:100%;
  table-layout:fixed;
}
.compliance-documents-table th,
.compliance-documents-table td,
.uploaded-documents-table th,
.uploaded-documents-table td{
  vertical-align:middle;
}
.compliance-documents-table th:last-child,
.compliance-documents-table td:last-child,
.uploaded-documents-table th:last-child,
.uploaded-documents-table td:last-child,
table[aria-label="Uploaded Documents"] th:last-child,
table[aria-label="Uploaded Documents"] td:last-child{
  text-align:right;
  white-space:nowrap;
  width:130px;
}
.document-delete-form,
.compliance-delete-form{
  display:inline-flex;
  margin:0;
  padding:0;
  width:auto;
  min-width:0;
  vertical-align:middle;
}
.btn-danger,
.delete-document-btn,
button[name="delete_document"]{
  background:#f3f4f6;
  color:#111827;
  border:0;
  border-radius:16px;
  padding:11px 22px;
  min-width:102px;
  line-height:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.btn-danger:hover,
.delete-document-btn:hover,
button[name="delete_document"]:hover{
  background:#fee2e2;
  color:#991b1b;
}
@media(max-width:760px){
  .compliance-documents-table,
  .uploaded-documents-table,
  table[aria-label="Uploaded Documents"]{
    min-width:880px;
  }
}
