:root {
  --bg: #03060B;
  --panel: #07111F;
  --panel-2: #0B1B33;
  --line: rgba(192,199,209,.22);
  --text: #F7FAFF;
  --muted: #AEB7C4;
  --brand: #C0C7D1;
  --brand-2: #F7FAFF;
  --warn: #B8C7D8;
  --danger: #ff8b8b;
  --shadow: 0 22px 60px rgba(0,0,0,.34);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, \"Segoe UI\", Arial, sans-serif;
}* { box-sizing: border-box; }
html, body { max-width: 100%; overflow-x: hidden; }
body { margin: 0; color: var(--text); background: radial-gradient(circle at 18% 0%,rgba(18,54,96,.28),transparent 28%),radial-gradient(circle at 86% 8%,rgba(192,199,209,.10),transparent 26%),linear-gradient(180deg,#03060B,#03060B 60%,#01030A); }
.app-shell { min-height: 100vh; display: grid; grid-template-columns: 280px 1fr 380px; }
.sidebar { position: sticky; top: 0; height: 100vh; border-right: 1px solid var(--line); padding: 24px; background: rgba(3,6,11,.88); backdrop-filter: blur(18px); }
.brand { display: flex; gap: 12px; align-items: center; margin-bottom: 34px; }
.mark { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 14px; background: linear-gradient(135deg, var(--brand), #8FA8C4); color: #020814; font-weight: 900; }
.brand span, .chat-head span { display: block; color: var(--muted); font-size: 12px; }
nav { display: grid; gap: 8px; }
nav a { color: var(--muted); text-decoration: none; padding: 12px 14px; border-radius: 14px; }
nav a:hover, nav a.active { background: rgba(192,199,209,.12); color: var(--brand-2); }
.compliance-card { margin-top: 34px; padding: 16px; border: 1px solid rgba(184,199,216,.25); border-radius: 18px; background: rgba(184,199,216,.08); }
.compliance-card p, .note { color: var(--muted); font-size: 13px; line-height: 1.45; }
main { padding: 28px; min-width: 0; }
.topbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; }
h1, h2, p { margin-top: 0; }
h1 { margin-bottom: 0; letter-spacing: -.03em; }
h2 { margin-bottom: 18px; letter-spacing: -.02em; }
.eyebrow { color: var(--brand); text-transform: uppercase; letter-spacing: .12em; font-size: 11px; font-weight: 800; margin-bottom: 6px; }
.user-chip { border: 1px solid var(--line); padding: 10px 14px; border-radius: 999px; color: var(--muted); display: flex; gap: 10px; align-items: center; }
.logout-button { border: 1px solid var(--line); background: rgba(255,255,255,.06); color: var(--text); border-radius: 999px; padding: 6px 10px; cursor: pointer; }
.logout-button:hover { border-color: var(--brand); color: var(--brand-2); }
.dot { width: 9px; height: 9px; border-radius: 50%; background: var(--brand); box-shadow: 0 0 16px var(--brand); }
.section { margin-bottom: 22px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.two-col { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(340px, .8fr); gap: 18px; }
.metric-card, .panel { background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018)); border: 1px solid var(--line); border-radius: 24px; box-shadow: var(--shadow); }
.metric-card { padding: 18px; }
.metric-card span { color: var(--muted); font-size: 13px; }
.metric-card strong { display: block; font-size: 28px; margin: 8px 0; }
.metric-card small { color: var(--brand-2); }
.metric-card.accent { border-color: rgba(192,199,209,.35); }
.panel { padding: 20px; min-width: 0; }
.panel-head { display: flex; justify-content: space-between; gap: 16px; align-items: start; }
.btn { border: 0; border-radius: 14px; padding: 11px 14px; background: var(--brand); color: #020814; font-weight: 800; cursor: pointer; }
.btn.secondary { background: var(--panel-2); color: var(--text); border: 1px solid var(--line); }
.product-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.product-card { border: 1px solid var(--line); border-radius: 18px; padding: 14px; background: rgba(255,255,255,.035); }
.product-photo-wrap { margin: -4px -4px 12px; border-radius: 16px; overflow: hidden; border: 1px solid rgba(255,255,255,.08); background: radial-gradient(circle at top, rgba(192,199,209,.14), rgba(255,255,255,.03)); }
.product-photo { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; display: block; }
.product-photo.placeholder { display: grid; place-items: center; color: var(--brand-2); font-weight: 900; letter-spacing: .18em; background: rgba(192,199,209,.06); }
.product-card h3 { margin: 0 0 8px; font-size: 16px; }
.detail-product-photo { margin: 0 0 14px; border: 1px solid rgba(192,199,209,.18); border-radius: 18px; overflow: hidden; background: rgba(255,255,255,.03); max-width: 280px; }
.detail-product-photo img { width: 100%; display: block; aspect-ratio: 1 / 1; object-fit: cover; }
.tags { display: flex; flex-wrap: wrap; gap: 6px; margin: 10px 0; }
.tag { font-size: 11px; color: var(--brand-2); border: 1px solid rgba(192,199,209,.25); border-radius: 999px; padding: 4px 8px; }
.product-actions { display: flex; gap: 8px; margin-top: 12px; }
.product-actions button, .tabs button, .quick-actions button, .admin-grid button { border: 1px solid var(--line); background: var(--panel-2); color: var(--text); border-radius: 12px; padding: 9px 10px; cursor: pointer; }
.product-actions button:hover, .quick-actions button:hover { border-color: var(--brand); }
.order-list { display: grid; gap: 10px; }
.order-line { display: grid; grid-template-columns: 1fr auto; gap: 8px; border-bottom: 1px solid var(--line); padding-bottom: 10px; color: var(--muted); }
.order-line strong { color: var(--text); }
.qty-actions { display: flex; gap: 6px; align-items: center; }
.qty-actions button { width: 28px; height: 28px; border: 1px solid var(--line); background: var(--panel-2); color: var(--text); border-radius: 9px; cursor: pointer; }
.history-list { margin-top: 16px; border-top: 1px solid var(--line); padding-top: 12px; }
.history-list h3 { font-size: 15px; margin: 0 0 10px; }
.history-row { display: grid; grid-template-columns: 1fr auto auto auto; gap: 10px; color: var(--muted); padding: 9px 0; border-bottom: 1px solid rgba(255,255,255,.06); font-size: 13px; align-items: center; }
.history-row b { color: var(--text); }
.history-row button { border: 1px solid var(--line); background: var(--panel-2); color: var(--text); border-radius: 9px; padding: 6px 8px; cursor: pointer; }
.totals { margin-top: 16px; display: grid; gap: 10px; }
.totals div { display: flex; justify-content: space-between; border-top: 1px solid var(--line); padding-top: 10px; }
.tabs { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.tabs .active { background: rgba(192,199,209,.15); color: var(--brand-2); }
.detail-box { color: var(--muted); line-height: 1.55; border: 1px solid var(--line); border-radius: 18px; padding: 16px; background: rgba(0,0,0,.12); }
.progress-row { display: grid; grid-template-columns: 78px 1fr; gap: 10px; align-items: center; margin: 14px 0; color: var(--muted); }
.progress-row div { height: 10px; background: rgba(255,255,255,.08); border-radius: 999px; overflow: hidden; }
.progress-row i { display: block; height: 100%; background: linear-gradient(90deg, var(--brand), var(--warn)); }
.clean-list { color: var(--muted); line-height: 1.65; }
.policy-banner { margin: 14px 0; padding: 12px 14px; border-radius: 16px; border: 1px solid var(--line); color: var(--muted); background: rgba(255,255,255,.04); font-size: 13px; }
.policy-banner.ok { color: var(--brand-2); border-color: rgba(192,199,209,.35); background: rgba(192,199,209,.08); }
.policy-banner.pending { color: var(--warn); border-color: rgba(184,199,216,.28); background: rgba(184,199,216,.07); }
.security-notice .panel { border-color: rgba(184,199,216,.35); background: linear-gradient(180deg, rgba(184,199,216,.08), rgba(255,255,255,.02)); }
.compliance-notice-panel .panel { border-color: rgba(192,199,209,.35); background: linear-gradient(180deg, rgba(192,199,209,.08), rgba(255,255,255,.02)); }
.readiness-panel.blocked .panel { border-color: rgba(184,199,216,.35); background: linear-gradient(180deg, rgba(184,199,216,.08), rgba(255,255,255,.02)); }
.readiness-panel.ready .panel { border-color: rgba(192,199,209,.42); background: linear-gradient(180deg, rgba(192,199,209,.1), rgba(255,255,255,.02)); }
.readiness-checks { display: grid; gap: 8px; margin-top: 12px; }
.readiness-check { border: 1px solid var(--line); border-radius: 14px; padding: 10px; display: grid; gap: 4px; color: var(--muted); font-size: 13px; }
.readiness-check b { color: var(--text); }
.readiness-check.ok { border-color: rgba(192,199,209,.28); }
.readiness-check.missing { border-color: rgba(184,199,216,.28); }
.compliance-form { gap: 12px; }
.compliance-form label { color: var(--muted); font-size: 13px; line-height: 1.35; display: flex; align-items: flex-start; gap: 8px; }
.compliance-form input[type="checkbox"] { width: auto; margin-top: 2px; }
.inline-form { grid-template-columns: 1fr 1fr auto; align-items: center; }
.course-list, .admin-grid { display: grid; gap: 10px; }
.course-list div { display: flex; justify-content: space-between; padding: 12px; border: 1px solid var(--line); border-radius: 14px; color: var(--muted); }
.course-list b { color: var(--text); }
.training-modules div { display: grid; gap: 8px; }
.training-modules ul { margin: 0; padding-left: 18px; line-height: 1.45; }
.training-modules button { border: 0; border-radius: 12px; padding: 10px; background: var(--brand); color: #020814; font-weight: 800; cursor: pointer; }
.admin-grid { grid-template-columns: repeat(2, 1fr); }
.admin-editable { margin-top: 18px; display: grid; gap: 14px; }
.admin-editable h3 { font-size: 15px; margin: 8px 0 0; }
.mini-form { border: 1px solid var(--line); border-radius: 16px; padding: 12px; display: grid; gap: 9px; background: rgba(255,255,255,.03); }
.mini-form input, .mini-form select, .mini-form textarea { min-width: 0; border: 1px solid var(--line); background: rgba(255,255,255,.06); color: var(--text); border-radius: 12px; padding: 10px; }
.mini-form textarea { resize: vertical; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 12px; line-height: 1.4; }
.mini-form.single-col { grid-template-columns: 1fr; }
.mini-form button { border: 0; border-radius: 12px; padding: 10px; background: var(--brand); color: #020814; font-weight: 800; cursor: pointer; }
.mini-table { display: grid; gap: 8px; }
.mini-table > div { border: 1px solid var(--line); border-radius: 14px; padding: 10px; display: grid; gap: 4px; color: var(--muted); font-size: 13px; }
.mini-table b { color: var(--text); }
.mini-table select { border: 1px solid var(--line); background: var(--panel-2); color: var(--text); border-radius: 10px; padding: 8px; margin-top: 4px; }
.mini-table small { color: var(--muted); line-height: 1.35; }
.row-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 6px; }
.row-actions button { border: 1px solid var(--line); border-radius: 999px; padding: 8px 10px; background: rgba(255,255,255,.06); color: var(--text); cursor: pointer; font-size: 12px; }
.row-actions button:hover { border-color: rgba(192,199,209,.45); color: var(--brand-2); }
.private-doc-list { display: grid; gap: 10px; margin: 14px 0; }
.private-doc-list h3 { margin: 0; font-size: 15px; }
.private-doc-card { display: flex; justify-content: space-between; align-items: center; gap: 12px; border: 1px solid rgba(192,199,209,.22); border-radius: 16px; padding: 12px; background: rgba(192,199,209,.06); }
.private-doc-card div { display: grid; gap: 4px; }
.private-doc-card b { color: var(--text); }
.private-doc-card span, .private-doc-card small { color: var(--muted); line-height: 1.35; }
.private-doc-card button { border: 0; border-radius: 999px; padding: 9px 12px; background: var(--brand); color: #020814; font-weight: 800; cursor: pointer; white-space: nowrap; }
.ops-summary { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 8px; margin: 8px 0 12px; }
.ops-summary div { border: 1px solid var(--line); border-radius: 14px; padding: 10px; background: rgba(192,199,209,.06); display: grid; gap: 2px; }
.ops-summary b { color: var(--brand-2); font-size: 20px; }
.ops-summary span { color: var(--muted); font-size: 12px; }
.preop-verdict { border: 1px solid var(--line); border-radius: 16px; padding: 12px; margin: 8px 0; display: flex; justify-content: space-between; gap: 12px; align-items: center; background: rgba(255,255,255,.04); }
.preop-verdict b { font-size: 22px; }
.preop-verdict.go { border-color: rgba(192,199,209,.42); background: rgba(192,199,209,.08); }
.preop-verdict.no-go { border-color: rgba(184,199,216,.35); background: rgba(184,199,216,.08); }
.preop-verdict.no-go b { color: var(--warn); }
.chat-widget { height: 100vh; position: sticky; top: 0; border-left: 1px solid var(--line); background: rgba(3,6,11,.95); display: flex; flex-direction: column; }
.chat-head { padding: 18px; border-bottom: 1px solid var(--line); display: flex; justify-content: space-between; gap: 12px; }
.chat-head button { background: transparent; border: 0; color: var(--muted); font-size: 24px; cursor: pointer; }
.quick-actions { padding: 12px; display: flex; flex-wrap: wrap; gap: 8px; border-bottom: 1px solid var(--line); }
.messages { flex: 1; overflow: auto; padding: 16px; display: flex; flex-direction: column; gap: 12px; }
.msg { max-width: 88%; padding: 12px 13px; border-radius: 16px; line-height: 1.42; font-size: 14px; }
.msg.user { align-self: flex-end; background: var(--brand); color: #020814; }
.msg.ai { align-self: flex-start; background: var(--panel-2); color: var(--text); border: 1px solid var(--line); }
.msg small { display: block; color: var(--muted); margin-top: 8px; }
form { display: grid; grid-template-columns: 1fr auto; gap: 8px; padding: 14px; border-top: 1px solid var(--line); }
input { min-width: 0; border: 1px solid var(--line); background: rgba(255,255,255,.06); color: var(--text); border-radius: 14px; padding: 12px; }
form button { border: 0; border-radius: 14px; padding: 0 14px; background: var(--brand); color: #020814; font-weight: 800; }
@media (max-width: 1200px) { .app-shell { grid-template-columns: 230px 1fr; } .chat-widget { grid-column: 1 / -1; height: 560px; position: relative; border-left: 0; border-top: 1px solid var(--line); } .grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 760px) { .app-shell { display: block; width: 100%; overflow-x: hidden; } .sidebar { position: relative; height: auto; width: 100%; } .two-col, .grid-4, .product-grid, .inline-form, .ops-summary { grid-template-columns: minmax(0, 1fr); } .topbar { align-items: flex-start; flex-direction: column; gap: 12px; } main { width: 100%; padding: 18px; overflow-x: hidden; } .panel, .metric-card, .chat-widget { max-width: 100%; } }
.is-hidden { display: none !important; }
.login-overlay { position: fixed; inset: 0; z-index: 1000; display: grid; place-items: center; padding: 20px; background: radial-gradient(circle at top, rgba(192,199,209,.18), rgba(7,16,20,.96) 45%); backdrop-filter: blur(14px); }
.login-card { width: min(680px, 100%); display: grid; gap: 12px; border: 1px solid var(--line); border-radius: 28px; padding: 28px; background: linear-gradient(180deg, rgba(15,27,33,.98), rgba(8,16,20,.98)); box-shadow: var(--shadow); }
.login-card .mark { margin-bottom: 4px; }
.login-card h2 { margin-bottom: 0; }
.login-card input { width: 100%; }
.login-credentials { display: grid; grid-template-columns: minmax(320px, 1.45fr) minmax(240px, 1fr); gap: 14px; align-items: center; }
.login-card .login-user-input { min-height: 56px; font-size: 15px; padding-inline: 16px; }
.login-card .login-password-input { min-height: 56px; font-size: 15px; padding-inline: 16px; }
.security-notice.optional .panel { border-color: rgba(192,199,209,.28); background: linear-gradient(180deg, rgba(192,199,209,.07), rgba(255,255,255,.02)); }
.password-change-form { grid-template-columns: minmax(260px, 1fr) minmax(260px, 1fr) auto; }
.security-helper { display: block; margin-top: 10px; color: var(--muted); line-height: 1.4; }
@media (max-width: 760px) { .login-card { width: min(480px, 100%); } .login-credentials, .password-change-form { grid-template-columns: minmax(0, 1fr); } }

.login-card button { border: 0; border-radius: 14px; padding: 13px; background: var(--brand); color: #020814; font-weight: 900; cursor: pointer; }
.login-card small { color: var(--muted); }
.login-readiness-link { color: var(--brand-2); text-decoration: none; text-align: center; font-size: 13px; border: 1px solid rgba(192,199,209,.22); border-radius: 999px; padding: 9px 10px; background: rgba(192,199,209,.06); }
.login-readiness-link:hover { border-color: var(--brand); }
.login-error { color: var(--danger); background: rgba(255,139,139,.08); border: 1px solid rgba(255,139,139,.22); padding: 10px; border-radius: 12px; font-size: 13px; }
.public-page { min-height: 100vh; background: radial-gradient(circle at top left, rgba(192,199,209,.14), transparent 34rem), var(--bg); }
.public-shell { max-width: 1120px; margin: 0 auto; padding: 32px 20px 56px; }
.public-hero { border: 1px solid var(--line); border-radius: 32px; padding: clamp(26px, 6vw, 58px); background: linear-gradient(135deg, rgba(255,255,255,.07), rgba(192,199,209,.07)); box-shadow: var(--shadow); margin-bottom: 20px; }
.public-hero h1 { max-width: 820px; font-size: clamp(36px, 7vw, 76px); line-height: .96; margin-bottom: 18px; }
.public-lead { max-width: 720px; color: var(--muted); font-size: 18px; line-height: 1.55; }
.public-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 22px; }
.public-actions a { text-decoration: none; display: inline-flex; align-items: center; }
.public-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; margin-bottom: 20px; }
.readiness-public-list { display: grid; gap: 10px; }
.readiness-public-list div { border: 1px solid var(--line); border-radius: 16px; padding: 14px; background: rgba(255,255,255,.035); display: grid; gap: 5px; }
.readiness-public-list b { color: var(--text); }
.readiness-public-list span { color: var(--muted); line-height: 1.45; }
@media (max-width: 760px) { .public-grid { grid-template-columns: 1fr; } .public-shell { padding: 18px 14px 40px; } }

/* 2026-05-02: B2B aligned to BIOLAB main site identity/colors. */

/* 2026-05-02 SAJAR: premium B2B login composition fix. Keep text full-width; no cramped side column. */
.login-card {
  width: min(780px, 100%);
  grid-template-columns: minmax(0, 1fr) !important;
  gap: 18px;
  padding: 34px;
  border-top: 1px solid var(--line);
}
.login-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.login-card-head .eyebrow {
  margin: 0;
  text-align: right;
  max-width: 180px;
}
.login-copy {
  display: grid;
  grid-template-columns: minmax(260px, .9fr) minmax(300px, 1.1fr);
  gap: 24px;
  align-items: end;
}
.login-copy h2 {
  font-size: clamp(32px, 4.5vw, 48px);
  line-height: .95;
  margin: 0;
  letter-spacing: -.045em;
}
.login-copy .note {
  margin: 0;
  max-width: 360px;
  font-size: 15px;
  line-height: 1.55;
  justify-self: end;
}
.login-credentials {
  display: grid;
  grid-template-columns: minmax(330px, 1.5fr) minmax(260px, 1fr) auto;
  gap: 14px;
  align-items: stretch;
}
.login-card .login-user-input,
.login-card .login-password-input {
  min-height: 58px;
  font-size: 15px;
  padding-inline: 18px;
  border-radius: 18px;
}
.login-submit {
  min-height: 58px;
  min-width: 116px;
  align-self: stretch;
}
.login-footer-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(170px, .32fr);
  gap: 14px;
  align-items: center;
}
.login-footer-row small {
  line-height: 1.35;
  max-width: 190px;
}
.login-readiness-link {
  min-height: 56px;
  display: grid;
  place-items: center;
}
@media (max-width: 840px) {
  .login-card { width: min(560px, 100%); padding: 28px; }
  .login-copy,
  .login-credentials,
  .login-footer-row { grid-template-columns: minmax(0, 1fr); }
  .login-card-head .eyebrow,
  .login-copy .note,
  .login-footer-row small { text-align: left; justify-self: start; max-width: none; }
  .login-submit { width: 100%; }
}

/* 2026-05-02 SAJAR: all B2B CTA choice controls bold, uppercase and visually highlighted. */
.btn,
.login-submit,
.login-card button,
.login-readiness-link,
.product-actions button,
.tabs button,
.quick-actions button,
.admin-grid button,
.history-row button,
.training-modules button,
.mini-form button,
.row-actions button,
.private-doc-card button,
form button,
.logout-button {
  text-transform: uppercase !important;
  font-weight: 950 !important;
  letter-spacing: .11em !important;
  border-width: 1.5px !important;
}
.btn,
.login-submit,
.login-card button,
.training-modules button,
.mini-form button,
.private-doc-card button,
form button {
  background: linear-gradient(135deg, #F4F7FB, #B8C7D8 50%, #8FA8C4) !important;
  color: #020814 !important;
  border-color: rgba(216,222,231,.72) !important;
  box-shadow: 0 12px 34px rgba(0,0,0,.28), 0 0 0 1px rgba(216,222,231,.08) inset;
}
.btn.secondary,
.login-readiness-link,
.product-actions button,
.tabs button,
.quick-actions button,
.admin-grid button,
.history-row button,
.row-actions button,
.logout-button {
  background: rgba(184,199,216,.075) !important;
  color: #F4F7FB !important;
  border-color: rgba(184,199,216,.36) !important;
  box-shadow: 0 10px 28px rgba(0,0,0,.22), 0 0 0 1px rgba(216,222,231,.06) inset;
}
.btn:hover,
.login-submit:hover,
.login-readiness-link:hover,
.product-actions button:hover,
.tabs button:hover,
.quick-actions button:hover,
.admin-grid button:hover,
.history-row button:hover,
.training-modules button:hover,
.mini-form button:hover,
.row-actions button:hover,
.private-doc-card button:hover,
form button:hover,
.logout-button:hover {
  border-color: rgba(244,247,251,.78) !important;
  filter: brightness(1.06);
}

/* 2026-05-02 SAJAR correction: B2B titles natural case; action buttons uppercase. */
h1,
h2,
h3,
.panel h2,
.metric-card strong,
.product-card h3,
.public-hero h1,
.login-copy h2 {
  text-transform: none !important;
}
.btn,
.login-submit,
.login-card button,
.login-readiness-link,
.product-actions button,
.tabs button,
.quick-actions button,
.admin-grid button,
.history-row button,
.training-modules button,
.mini-form button,
.row-actions button,
.private-doc-card button,
form button,
.logout-button,
a.btn,
a.login-readiness-link {
  text-transform: uppercase !important;
  font-weight: 950 !important;
  letter-spacing: .11em !important;
}

/* 2026-05-02 live QA fix: B2B public/login background fills viewport; login breathes. */
html, body, #root {
  min-height: 100% !important;
  background: #03060B !important;
}
body {
  background: radial-gradient(circle at 18% 0%,rgba(18,54,96,.28),transparent 28%),radial-gradient(circle at 86% 8%,rgba(192,199,209,.10),transparent 26%),linear-gradient(180deg,#03060B,#03060B 62%,#01030A) !important;
}
.login-overlay {
  min-height: 100vh !important;
  min-height: 100svh !important;
  background: radial-gradient(circle at top, rgba(192,199,209,.18), rgba(3,6,11,.98) 48%), #03060B !important;
  overflow-y: auto !important;
}
.login-card { gap: 20px !important; }
.login-readiness-link {
  font-size: 12px !important;
  letter-spacing: .08em !important;
  opacity: .92;
}

/* 2026-05-02 palette hardening: BIOLAB-only B2B colors. */
:root{
  --brand:#C0C7D1!important;
  --brand-2:#8FA8C4!important;
  --text:#F7FAFF!important;
  --muted:#AEB7C4!important;
  --bg:#03060B!important;
  --panel:#07111F!important;
  --line:rgba(192,199,209,.22)!important;
}
.warn,.warning,.status-pending,.pill.warn,[class*="warn"],[class*="pending"]{
  color:#B8C7D8!important;
  border-color:rgba(184,199,216,.28)!important;
  background:rgba(184,199,216,.075)!important;
}

/* 2026-05-02 mobile QA: B2B login must fit Telegram/mobile viewport; no electric-blue focus. */
.login-overlay,
.login-overlay * { box-sizing: border-box !important; }
.login-card input:focus,
.login-card button:focus,
.login-readiness-link:focus {
  outline: 1.5px solid #8FA8C4 !important;
  box-shadow: 0 0 0 3px rgba(143,168,196,.22) !important;
  border-color: rgba(184,199,216,.62) !important;
}
@media(max-width:760px){
  .login-overlay {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 14px !important;
    overflow-x: hidden !important;
  }
  .login-card {
    width: min(310px, calc(100vw - 28px)) !important;
    max-width: min(310px, calc(100vw - 28px)) !important;
    min-width: 0 !important;
    margin-left: 0 !important;
    margin-right: auto !important;
    padding: 22px 18px !important;
    border-radius: 24px !important;
    overflow: hidden !important;
  }
  .login-card-head,
  .login-copy,
  .login-credentials,
  .login-footer-row {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    grid-template-columns: minmax(0,1fr) !important;
  }
  .login-card-head { align-items: flex-start !important; }
  .login-card-head .eyebrow { max-width: 120px !important; font-size: 9px !important; overflow-wrap: break-word !important; }
  .login-copy h2 { font-size: 32px !important; line-height: 1 !important; }
  .login-copy .note { font-size: 14px !important; line-height: 1.45 !important; }
  .login-card input,
  .login-submit,
  .login-readiness-link {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }
  .login-readiness-link {
    white-space: normal !important;
    overflow-wrap: break-word !important;
    text-align: center !important;
    line-height: 1.25 !important;
    padding: 12px 10px !important;
    font-size: 10.5px !important;
    letter-spacing: .075em !important;
  }
}


/* 2026-05-02 SAJAR: vertical scroll for B2B product grid. */
@media (min-width: 821px) {
  .product-grid {
    max-height: min(70vh, 860px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding-right: 10px !important;
    align-content: start !important;
    overscroll-behavior: contain !important;
    scrollbar-width: thin;
    scrollbar-color: rgba(184,199,216,.62) rgba(255,255,255,.055);
  }
  .product-grid::-webkit-scrollbar { width: 9px; }
  .product-grid::-webkit-scrollbar-track { background: rgba(255,255,255,.045); border-radius: 999px; }
  .product-grid::-webkit-scrollbar-thumb { background: linear-gradient(180deg,rgba(244,247,251,.64),rgba(143,168,196,.46)); border-radius: 999px; border: 2px solid rgba(3,6,11,.92); }
  .product-grid::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg,rgba(255,255,255,.82),rgba(184,199,216,.58)); }
}
@media (max-width: 820px) {
  .product-grid { max-height: none !important; overflow: visible !important; padding-right: 0 !important; }
}


/* 2026-05-02 SAJAR: neutralize color cast cast inside B2B product imagery. */
.product-photo,
.detail-product-photo img,
.product-photo-wrap img,
img[src*="drive-products"],
img[src*="products"] {
  filter: grayscale(100%) contrast(1.08) brightness(.94) !important;
  mix-blend-mode: luminosity;
}
.product-photo-wrap,
.detail-product-photo {
  background: radial-gradient(circle at 50% 18%, rgba(184,199,216,.13), rgba(255,255,255,.035) 44%, rgba(3,6,11,.92) 100%) !important;
}
.product-photo-wrap::after,
.detail-product-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(244,247,251,.045), rgba(143,168,196,.075) 46%, rgba(3,6,11,.12));
  mix-blend-mode: screen;
}
.product-photo-wrap,
.detail-product-photo { position: relative; }


/* 2026-05-02 SAJAR: hard removal of perceived cold accent from B2B UI/product surfaces. */
:root{ --brand:#D8DEE7!important; --brand-2:#8FA8C4!important; --success:#8FA8C4!important; accent-color:#C0C7D1; }
*, *::before, *::after { accent-color:#C0C7D1; }
.product-photo,
.detail-product-photo img,
.product-photo-wrap img,
img[src*="drive-products"],
img[src*="products"]{
  filter: grayscale(1) saturate(0) contrast(1.16) brightness(.88) !important;
  -webkit-filter: grayscale(1) saturate(0) contrast(1.16) brightness(.88) !important;
}
.product-photo-wrap,
.detail-product-photo,
.product-card,
.metric-card,
.compliance-card{
  border-color:rgba(216,222,231,.30)!important;
  background:linear-gradient(135deg,rgba(216,222,231,.07),rgba(255,255,255,.025))!important;
}
.btn,.login-submit,.login-card button,.product-actions button,.tabs button,.quick-actions button,.admin-grid button,.history-row button,.training-modules button,.mini-form button,.row-actions button,.private-doc-card button,form button,.logout-button,a.btn,a.login-readiness-link{
  border-color:rgba(216,222,231,.44)!important;
}


/* 2026-05-02 SAJAR: B2B horizontal scroll guard. Page never scrolls sideways; action rails may scroll on mobile. */
html,
body,
#root {
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: clip !important;
}
@supports not (overflow: clip) {
  html, body, #root { overflow-x: hidden !important; }
}
.app-shell,
.panel,
.login-card,
.product-card,
.product-grid,
.metric-card,
.compliance-card,
.private-doc-card {
  max-width: 100% !important;
  min-width: 0 !important;
}
@media (max-width: 820px) {
  .tabs,
  .quick-actions,
  .product-actions,
  .row-actions,
  .tags,
  .login-footer-row,
  .private-doc-list {
    max-width: 100% !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-inline: contain;
    scrollbar-width: none;
  }
  .tabs::-webkit-scrollbar,
  .quick-actions::-webkit-scrollbar,
  .product-actions::-webkit-scrollbar,
  .row-actions::-webkit-scrollbar,
  .tags::-webkit-scrollbar,
  .login-footer-row::-webkit-scrollbar,
  .private-doc-list::-webkit-scrollbar { display:none; }
  .tabs,
  .quick-actions,
  .product-actions,
  .row-actions,
  .tags { flex-wrap: nowrap !important; justify-content: flex-start !important; }
  .tabs button,
  .quick-actions button,
  .product-actions button,
  .row-actions button,
  .tag { flex: 0 0 auto !important; white-space: nowrap !important; }
}


/* 2026-05-02 SAJAR: remove internal vertical scrollbars from catalog/product grids. Page scroll only. */
.compound-grid,
.product-grid,
.dossier-grid,
.certificate-dossier-grid,
.verification-status-grid,
.product-list,
.public-product-list {
  max-height: none !important;
  height: auto !important;
  overflow-y: visible !important;
  overflow-x: clip !important;
  padding-right: 0 !important;
  overscroll-behavior: auto !important;
}
.compound-grid::-webkit-scrollbar,
.product-grid::-webkit-scrollbar,
.dossier-grid::-webkit-scrollbar,
.certificate-dossier-grid::-webkit-scrollbar,
.verification-status-grid::-webkit-scrollbar,
.product-list::-webkit-scrollbar,
.public-product-list::-webkit-scrollbar { display: none !important; }


/* 2026-05-02 BIOLAB B2B login P0: prevent compressed mobile inputs and keep institutional premium layout. */
.login-form{
  display:grid !important;
  gap:14px !important;
}
.login-card input,
.login-form .primary{
  width:100% !important;
  min-width:0 !important;
  box-sizing:border-box !important;
}
@media (max-width:760px){
  .login-form{
    grid-template-columns:1fr !important;
    gap:12px !important;
  }
  .login-form .primary{
    white-space:normal !important;
    line-height:1.18 !important;
  }
}
@media (min-width:761px){
  .login-form{
    grid-template-columns:minmax(330px,1.5fr) minmax(260px,1fr) !important;
  }
  .login-form .primary{ grid-column:1 / -1 !important; }
}
