:root {
  color-scheme: light;
  --bg: #f3f5f8;
  --surface: #ffffff;
  --surface-subtle: #f7f9fc;
  --ink: #182230;
  --muted: #697586;
  --line: #d9e0ea;
  --line-strong: #b8c2d0;
  --accent: #2563eb;
  --accent-dark: #1d4ed8;
  --success: #047857;
  --warning: #b45309;
  --danger: #b91c1c;
  --sidebar: #0f172a;
  --sidebar-active: #1e293b;
  --sidebar-muted: #94a3b8;
  --focus: #38bdf8;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
body { margin: 0; background: var(--bg); color: var(--ink); }
body.auth-only { background: var(--surface-subtle); }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
button:disabled { cursor: not-allowed; opacity: .52; }
button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible { outline: 2px solid var(--focus); outline-offset: 2px; }

.auth-screen { min-height: 100vh; display: none; place-items: center; padding: 28px; }
.auth-screen.active { display: grid; }
.app-shell[hidden] { display: none !important; }
.shell { min-height: 100vh; display: grid; grid-template-columns: 248px minmax(0, 1fr); }
.sidebar { background: var(--sidebar); color: #fff; display: flex; flex-direction: column; padding: 18px 12px; box-shadow: inset -1px 0 0 rgba(255,255,255,.06); }
.brand { display: flex; align-items: center; gap: 12px; padding: 4px 8px 18px; border-bottom: 1px solid rgba(255,255,255,.1); }
.brand-mark { width: 38px; height: 38px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.18); border-radius: 6px; font-size: 12px; font-weight: 800; color: #dbeafe; background: rgba(37,99,235,.16); }
.brand h1 { margin: 0; font-size: 15px; letter-spacing: 0; }
.brand p, .sidebar-footer span { margin: 0; color: var(--sidebar-muted); font-size: 12px; }
nav { display: grid; gap: 4px; margin-top: 18px; }
.nav-item { height: 38px; border: 0; border-radius: 6px; background: transparent; color: #cbd5e1; text-align: left; padding: 0 12px; font-weight: 650; }
.nav-item:hover { background: rgba(255,255,255,.07); color: #fff; }
.nav-item.active { background: var(--sidebar-active); color: #fff; box-shadow: inset 3px 0 0 var(--focus); }
.sidebar-footer { margin-top: auto; border-top: 1px solid rgba(255,255,255,.12); padding: 14px 6px 2px; display: grid; grid-template-columns: 34px minmax(0, 1fr); gap: 10px; align-items: center; }
.identity-avatar { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 999px; border: 1px solid rgba(255,255,255,.18); background: rgba(56,189,248,.14); color: #e0f2fe; font-size: 12px; font-weight: 850; }
.identity-copy { min-width: 0; display: grid; gap: 2px; }
.identity-copy strong { font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.identity-copy small { color: var(--sidebar-muted); font-size: 11px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sidebar-logout { grid-column: 1 / -1; margin-top: 2px; min-height: 32px; border: 1px solid rgba(255,255,255,.18); border-radius: 6px; background: rgba(255,255,255,.06); color: #e2e8f0; font-weight: 750; }
.sidebar-logout:hover:not(:disabled) { background: rgba(255,255,255,.12); color: #fff; }
.sidebar-logout:disabled { cursor: not-allowed; opacity: .45; }

.workspace { min-width: 0; display: flex; flex-direction: column; }
.topbar { min-height: 74px; display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 14px 28px; background: rgba(255,255,255,.92); border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 5; backdrop-filter: blur(10px); }
.topbar h2 { margin: 0; font-size: 20px; letter-spacing: 0; }
.topbar p { margin: 4px 0 0; color: var(--muted); font-size: 13px; }
.topbar-actions { display: flex; align-items: center; gap: 12px; }
.timestamp, .count { color: var(--muted); font-size: 12px; }
main { padding: 22px 28px 34px; }
.view { display: none; }
.view.active { display: grid; gap: 18px; }

.primary, .ghost, .danger { min-height: 34px; border-radius: 6px; padding: 0 14px; font-weight: 700; }
.primary { border: 1px solid var(--accent-dark); background: var(--accent); color: #fff; }
.primary:hover { background: var(--accent-dark); }
.ghost { border: 1px solid var(--line-strong); background: #fff; color: #344054; }
.ghost:hover { background: var(--surface-subtle); }
.danger { border: 1px solid #912018; background: var(--danger); color: #fff; }
.danger:hover { background: #912018; }
.link { border: 0; padding: 0; background: transparent; color: var(--accent); font-weight: 700; text-align: left; }
.link:hover { color: var(--accent-dark); text-decoration: underline; }

.metrics { display: grid; grid-template-columns: repeat(4, minmax(150px, 1fr)); gap: 12px; }
.metric, .panel { background: var(--surface); border: 1px solid var(--line); border-radius: 6px; box-shadow: 0 1px 2px rgba(15,23,42,.04); }
.metric { padding: 14px 16px; min-height: 86px; }
.metric .label { color: var(--muted); font-size: 12px; font-weight: 650; }
.metric .value { margin-top: 8px; font-size: 24px; font-weight: 800; letter-spacing: 0; color: #0f172a; }
.metric .hint { margin-top: 2px; color: var(--muted); font-size: 12px; }
.grid.two { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(380px, .85fr); gap: 18px; align-items: start; }
.pod-layout { grid-template-columns: minmax(0, 1fr) minmax(420px, .8fr); align-items: start; }
.panel { padding: 15px; min-width: 0; overflow: hidden; }
.panel-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.panel-head h3 { margin: 0; font-size: 14px; letter-spacing: 0; }

.filters { display: grid; grid-template-columns: minmax(220px, 1.4fr) repeat(5, minmax(130px, 1fr)); gap: 12px; align-items: end; }
.jobs-workspace { display: grid; gap: 12px; }
.jobs-head { margin-bottom: 0; }
.jobs-head > div:first-child { display: grid; gap: 2px; }
.selected-job-pill { min-height: 28px; display: inline-flex; align-items: center; gap: 6px; border: 1px solid var(--line); border-radius: 999px; padding: 0 10px; background: var(--surface-subtle); color: var(--muted); font-size: 12px; font-weight: 700; max-width: 360px; }
.selected-job-pill strong { color: var(--ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.jobs-toolbar { display: grid; grid-template-columns: minmax(0, 1fr) minmax(520px, .66fr); gap: 12px; align-items: end; border: 1px solid var(--line); border-radius: 6px; padding: 12px; background: var(--surface-subtle); }
.jobs-filters { display: grid; grid-template-columns: minmax(220px, 1.4fr) repeat(5, minmax(112px, 1fr)); gap: 10px; align-items: end; }
.jobs-actions { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 14px; align-items: end; }
.job-priority-controls { display: grid; grid-template-columns: minmax(148px, 1fr) 96px auto; gap: 8px; align-items: end; }
.job-lifecycle-actions { display: flex; align-items: end; justify-content: flex-end; gap: 8px; padding-left: 14px; border-left: 1px solid var(--line); }
.action-panel { display: grid; gap: 12px; }
.form-grid { display: grid; gap: 12px; align-items: end; }
.job-action-grid { grid-template-columns: minmax(260px, 1.4fr) minmax(150px, .7fr) minmax(120px, .5fr) auto; }
.queue-form { grid-template-columns: repeat(4, minmax(120px, 1fr)) minmax(260px, 1.4fr) auto; }
.quota-form { grid-template-columns: repeat(6, minmax(110px, 1fr)) auto; }
.button-row { display: flex; gap: 6px; align-items: end; flex-wrap: wrap; }
.compact-action { min-height: 30px; padding: 0 10px; font-size: 12px; border-radius: 5px; white-space: nowrap; }
.priority-action { min-width: 58px; color: #344054; }
.priority-action:hover:not(:disabled) { background: #f2f4f7; border-color: #98a2b3; }
.jobs-actions .danger { border-color: #fda29b; background: #fff; color: var(--danger); }
.jobs-actions .danger:hover:not(:disabled) { background: #fef3f2; border-color: #f97066; }
.jobs-actions .ghost { background: #fff; color: #475467; }
.jobs-actions .primary { background: #175cd3; border-color: #175cd3; }
.jobs-actions .primary:hover:not(:disabled) { background: #1849a9; }
label { display: grid; gap: 6px; color: var(--muted); font-size: 12px; font-weight: 700; }
input, select, textarea { border: 1px solid var(--line-strong); border-radius: 6px; background: #fff; color: var(--ink); }
input, select { height: 34px; padding: 0 10px; }
textarea { width: 100%; min-height: 430px; resize: vertical; padding: 12px; font: 13px/1.5 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }
.queue-form textarea { min-height: 72px; }

table { width: 100%; border-collapse: collapse; table-layout: fixed; font-size: 13px; }
th, td { border-bottom: 1px solid var(--line); padding: 9px 8px; text-align: left; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; vertical-align: middle; }
th { color: #475467; font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .02em; background: #f1f5f9; }
tbody tr:hover { background: #f8fafc; }
tbody tr.selected { background: #eff6ff; box-shadow: inset 3px 0 0 var(--accent); }
tbody tr[data-job-name], tbody tr[data-cluster-name] { cursor: pointer; }
tbody tr[data-job-name]:hover, tbody tr[data-cluster-name]:hover { background: #eef4ff; }
tr:last-child td { border-bottom: 0; }
.jobs-table th:nth-child(1) { width: 18%; }
.jobs-table th:nth-child(2) { width: 17%; }
.jobs-table th:nth-child(3) { width: 16%; }
.jobs-table th:nth-child(7) { width: 13%; }
.jobs-table th:nth-child(10) { width: 13%; }
.table-pagination { min-height: 42px; display: flex; align-items: center; justify-content: space-between; gap: 12px; border-top: 1px solid var(--line); padding-top: 10px; }
.pagination-controls { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.pagination-controls label { display: flex; align-items: center; gap: 6px; }
.pagination-controls select { width: 78px; height: 30px; }
.page-button { min-height: 30px; padding: 0 10px; font-size: 12px; border-radius: 5px; }
.page-index { color: var(--muted); font-size: 12px; font-weight: 700; min-width: 86px; text-align: center; }
.schedule-table th:nth-child(1) { width: 42px; }
.schedule-table th:nth-child(2) { width: 16%; }
.schedule-table th:nth-child(5) { width: 18%; }
.subtle { color: var(--muted); font-size: 12px; }
.mono { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }

.phase { display: inline-flex; height: 22px; align-items: center; padding: 0 8px; border-radius: 999px; background: #eff6ff; color: var(--accent-dark); font-weight: 800; font-size: 11px; }
.phase.Queued, .phase.Requeue { background: #fffaeb; color: var(--warning); }
.phase.Running, .phase.Dispatched { background: #ecfdf3; color: var(--success); }
.phase.Failed, .phase.RetryDispatch { background: #fef3f2; color: var(--danger); }
.phase.Succeeded { background: #f0fdf4; color: #15803d; }
.phase.Cancelled { background: #f1f5f9; color: #475569; }

.priority-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 12px; }
.priority-card { border: 1px solid var(--line); border-radius: 6px; padding: 12px; background: var(--surface-subtle); }
.priority-card h4 { margin: 0 0 10px; font-size: 13px; }
.kv-row { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 12px; padding: 6px 0; font-size: 13px; }
.kv-row span { color: var(--muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pod-detail h4 { margin: 16px 0 8px; font-size: 12px; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); }
.detail-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.detail-grid div { border: 1px solid var(--line); border-radius: 6px; padding: 9px 10px; background: var(--surface-subtle); min-width: 0; }
.detail-grid span { display: block; color: var(--muted); font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .02em; }
.detail-grid strong { display: block; margin-top: 4px; font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.tag-grid { display: flex; flex-wrap: wrap; gap: 6px; }
.tag { display: inline-flex; max-width: 100%; height: 24px; align-items: center; border: 1px solid var(--line); border-radius: 999px; padding: 0 8px; background: var(--surface-subtle); color: #344054; font-size: 12px; font-weight: 650; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.container-grid { display: grid; gap: 8px; }
.container-pill { display: grid; grid-template-columns: minmax(80px, .6fr) minmax(0, 1fr) auto; gap: 10px; align-items: center; border: 1px solid var(--line); border-radius: 6px; padding: 9px 10px; background: var(--surface-subtle); font-size: 12px; }
.container-pill span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--muted); }
.container-pill em { font-style: normal; color: var(--success); font-weight: 800; }
.yaml-view { max-height: 460px; overflow: auto; border: 1px solid var(--line); border-radius: 6px; background: #0b1220; color: #d6e4ff; padding: 12px; font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size: 12px; line-height: 1.5; }
.json-view { max-height: 420px; overflow: auto; border: 1px solid var(--line); border-radius: 6px; background: #0b1220; color: #d6e4ff; padding: 12px; font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size: 12px; line-height: 1.5; white-space: pre; }
pre { min-height: 42px; margin: 12px 0 0; white-space: pre-wrap; color: var(--muted); font-size: 13px; }
.inline-result { min-height: 0; margin: 0; border-top: 1px solid var(--line); padding-top: 10px; }

@media (max-width: 1100px) {
  .shell { grid-template-columns: 1fr; }
  .sidebar { position: static; }
  nav { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .sidebar-footer { grid-template-columns: 34px minmax(0, 1fr) auto; align-items: center; padding: 12px 6px 2px; }
  .sidebar-logout { grid-column: 3; grid-row: 1; margin-top: 0; padding: 0 12px; }
  .metrics, .grid.two, .filters, .jobs-toolbar, .jobs-filters, .jobs-actions, .job-priority-controls, .job-action-grid, .queue-form, .quota-form { grid-template-columns: 1fr; }
  .job-lifecycle-actions { justify-content: flex-start; padding-left: 0; padding-top: 10px; border-left: 0; border-top: 1px solid var(--line); }
  .table-pagination { align-items: stretch; flex-direction: column; }
  .pagination-controls { justify-content: space-between; }
  .topbar { height: auto; padding: 16px; align-items: flex-start; }
  main { padding: 16px; }
  .detail-grid { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
  nav { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .topbar { flex-direction: column; align-items: stretch; }
  .topbar-actions { justify-content: space-between; }
  .metrics { grid-template-columns: 1fr; }
  th, td { padding: 8px 6px; }
}

.auth-chip { min-height: 28px; display: inline-flex; align-items: center; border: 1px solid var(--line); border-radius: 999px; padding: 0 10px; background: #eef6ff; color: #175cd3; font-size: 12px; font-weight: 800; }
.resources-grid { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(360px, .65fr); gap: 18px; align-items: start; }
.namespace-grid { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(440px, .8fr); gap: 18px; align-items: start; }
.primary-panel { min-height: 260px; }
.compact-filters { margin-bottom: 12px; grid-template-columns: minmax(220px, 1.4fr) repeat(4, minmax(130px, 1fr)); }
.cluster-grid, .namespace-list { display: grid; gap: 12px; }
.cluster-grid-full { grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); }
.cluster-card, .namespace-card { border: 1px solid var(--line); border-radius: 6px; background: var(--surface-subtle); padding: 13px; display: grid; gap: 10px; }
.cluster-card-expanded { background: #fff; }
.cluster-card-head, .namespace-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.cluster-card h4, .namespace-card h4 { margin: 0; font-size: 14px; color: #101828; }
.cluster-card span, .namespace-head span { color: var(--muted); font-size: 12px; }
.status-dot { border-radius: 999px; padding: 3px 8px; background: #ecfdf3; color: var(--success); font-size: 11px; text-transform: uppercase; }
.resource-line { min-height: 34px; display: grid; grid-template-columns: minmax(0, 1fr) auto auto; gap: 10px; align-items: center; border-top: 1px solid var(--line); padding-top: 9px; font-size: 12px; }
.resource-line:first-child { border-top: 0; padding-top: 0; }
.resource-line span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: #344054; }
.resource-line strong { color: #101828; }
.resource-line em { font-style: normal; color: var(--muted); }
.namespace-columns { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.namespace-form { grid-template-columns: repeat(4, minmax(110px, 1fr)); }
.namespace-form label:nth-child(5) { grid-column: 1 / -1; }
.clusters-head-panel { display: grid; gap: 12px; }
.cluster-table-frame table { min-width: 920px; }
.cluster-form-panel { display: grid; gap: 12px; }
.cluster-form-grid { grid-template-columns: repeat(4, minmax(140px, 1fr)); }
.cluster-form-grid label:nth-child(7), .cluster-form-grid label:nth-child(8) { grid-column: span 2; }
.cluster-form-grid label:nth-child(9) { grid-column: 1 / -1; }
.cluster-form-grid textarea { min-height: 96px; }
.cluster-actions { justify-content: flex-end; }
.cluster-labels { border-top: 1px solid var(--line); padding-top: 10px; }
.cluster-row.selected { background: #eff6ff; box-shadow: inset 3px 0 0 var(--accent); }
.cluster-detail-panel { width: min(1180px, 100%); }
.cluster-detail-panel h4 { margin: 16px 0 8px; font-size: 12px; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); }
.cluster-detail-summary { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.cluster-node-layout { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 16px; margin-top: 14px; }
.cluster-node-list, .cluster-pod-list { display: grid; gap: 10px; }
.mini-card { display: grid; gap: 8px; border: 1px solid var(--line); border-radius: 6px; background: var(--surface-subtle); padding: 11px; min-width: 0; }
.mini-card > div:first-child { display: grid; gap: 3px; min-width: 0; }
.mini-card strong, .mini-card span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mini-card span { color: var(--muted); font-size: 12px; }
.modal-backdrop { position: fixed; inset: 0; z-index: 20; display: grid; place-items: center; padding: 24px; background: rgba(15, 23, 42, .38); }
.modal-backdrop[hidden] { display: none !important; }
.modal-panel { width: min(980px, 100%); max-height: calc(100vh - 48px); overflow: auto; border: 1px solid var(--line); border-radius: 6px; background: var(--surface); padding: 16px; box-shadow: 0 24px 80px rgba(15,23,42,.22); }
.job-detail-panel { width: min(1180px, 100%); display: grid; gap: 14px; }
.job-detail-panel h4 { margin: 4px 0 0; font-size: 12px; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); }
.job-detail-summary { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.pod-bubble-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 10px; }
.pod-bubble { display: grid; gap: 8px; border: 1px solid var(--line); border-radius: 999px; background: #f8fafc; padding: 12px 16px; min-width: 0; }
.pod-bubble > div:first-child { display: flex; align-items: center; justify-content: space-between; gap: 10px; min-width: 0; }
.pod-bubble strong { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pod-bubble p { display: grid; grid-template-columns: 56px minmax(0, 1fr); gap: 8px; margin: 0; font-size: 12px; }
.pod-bubble p span { color: var(--muted); font-weight: 800; }
.pod-bubble-labels { display: flex; flex-wrap: wrap; gap: 5px; }
.pod-bubble-labels span { max-width: 100%; border: 1px solid var(--line); border-radius: 999px; background: #fff; padding: 2px 7px; color: #475467; font-size: 11px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.legacy-hidden { display: none !important; }

@media (max-width: 1100px) {
  .resources-grid, .namespace-grid, .compact-filters, .namespace-form, .namespace-columns, .cluster-form-grid, .cluster-node-layout, .job-detail-summary, .cluster-detail-summary { grid-template-columns: 1fr; }
  .cluster-form-grid label:nth-child(7), .cluster-form-grid label:nth-child(8), .cluster-form-grid label:nth-child(9) { grid-column: auto; }
}

.login-panel { min-height: 430px; display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(360px, .95fr); gap: 24px; align-items: stretch; border: 1px solid var(--line); border-radius: 6px; background: var(--surface); padding: 22px; box-shadow: 0 1px 2px rgba(15,23,42,.04); }
.login-copy { display: flex; flex-direction: column; justify-content: center; border-right: 1px solid var(--line); padding-right: 24px; }
.login-copy .eyebrow { color: var(--accent-dark); font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; }
.login-copy h3 { margin: 12px 0 8px; font-size: 28px; line-height: 1.15; letter-spacing: 0; color: #101828; }
.login-copy p { max-width: 560px; margin: 0; color: var(--muted); font-size: 14px; line-height: 1.6; }
.login-actions { display: grid; align-content: center; gap: 14px; }
.microsoft-login { min-height: 42px; justify-self: start; padding: 0 18px; }
.login-status { color: var(--muted); font-size: 13px; font-weight: 750; }
.identity-summary { border: 1px solid var(--line); border-radius: 6px; background: var(--surface-subtle); padding: 14px; display: grid; gap: 6px; }
.identity-summary span { color: var(--muted); font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .03em; }
.identity-summary strong { font-size: 15px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.integrated-toolbar { border-bottom-left-radius: 0; border-bottom-right-radius: 0; margin-bottom: -12px; border-bottom-color: transparent; }
.table-frame { border: 1px solid var(--line); border-radius: 0 0 6px 6px; overflow: auto; background: var(--surface); }
.table-frame table { min-width: 980px; }
.jobs-workspace .inline-result { border-top: 0; margin-top: 0; padding-top: 0; }

@media (max-width: 900px) {
  .login-panel { grid-template-columns: 1fr; }
  .login-copy { border-right: 0; border-bottom: 1px solid var(--line); padding: 0 0 20px; }
}
