:root {
    --bg: #f7f9fc;
    --ink: #081936;
    --muted: #64748b;
    --panel: #ffffff;
    --line: #e1e8f2;
    --line-soft: #edf2f7;
    --accent: #0672d8;
    --accent-dark: #05265c;
    --accent-soft: #e8f3ff;
    --accent-2: #d97706;
    --success: #047857;
    --danger: #b42318;
    --shadow-soft: 0 12px 34px rgba(8, 25, 54, .032);
    --shadow-panel: 0 18px 46px rgba(8, 25, 54, .04);
}

* { box-sizing: border-box; }
body {
    margin: 0;
    background: linear-gradient(180deg, #fbfdff 0%, var(--bg) 260px);
    color: var(--ink);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
a { color: inherit; text-decoration: none; }
.shell { display: flex; min-height: 100vh; }
.sidebar {
    width: 268px;
    flex: 0 0 268px;
    background: linear-gradient(180deg, #041c44 0%, #07275b 56%, #06336c 100%);
    color: #f7fbf8;
    padding: 24px 18px;
    position: sticky;
    top: 0;
    height: 100vh;
    overflow-y: auto;
}
.brand { display: flex; align-items: center; gap: 12px; min-width: 0; font-weight: 800; font-size: 22px; margin-bottom: 32px; }
.brand span {
    overflow: hidden;
    white-space: nowrap;
}
.brand img { width: 42px; height: 42px; object-fit: contain; border-radius: 8px; background: #fff; }
.login-brand img { width: 72px; height: 72px; box-shadow: 0 18px 45px rgba(6, 114, 216, .16); }
.brand-icon {
    width: 38px; height: 38px; border-radius: 8px;
    background: #e9b44c; color: #10251f;
    display: grid; place-items: center;
}
nav { display: grid; gap: 7px; }
nav a { display: flex; align-items: center; gap: 10px; padding: 11px 12px; border-radius: 8px; color: #dce7f7; }
nav a:hover { background: rgba(255,255,255,.1); color: #fff; }
.nav-group {
    display: grid;
    gap: 6px;
}
.nav-group-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 34px;
    gap: 6px;
    align-items: center;
}
.nav-subtoggle {
    width: 34px;
    height: 34px;
    display: grid;
    place-items: center;
    padding: 0;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 8px;
    background: rgba(255,255,255,.08);
    color: #b8d8ff;
    font-size: 18px;
    line-height: 1;
}
.nav-subtoggle:hover {
    background: rgba(255,255,255,.14);
    color: #fff;
}
.settings-nav.is-closed .subnav {
    display: none;
}
.subnav {
    display: grid;
    gap: 4px;
    margin: -2px 0 6px 38px;
    padding-left: 10px;
    border-left: 1px solid rgba(255,255,255,.18);
}
.subnav a {
    padding: 8px 10px;
    color: #b8d8ff;
    font-size: 13px;
}
.subnav-label {
    padding: 4px 10px 2px;
    color: rgba(255,255,255,.58);
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
}
.nav-icon {
    flex: 0 0 30px;
    width: 30px;
    height: 30px;
    border-radius: 7px;
    background: rgba(255,255,255,.12);
    display: grid;
    place-items: center;
    color: #b8d8ff;
    font-size: 16px;
    font-weight: 800;
}
.nav-text {
    min-width: 0;
    overflow: hidden;
    white-space: nowrap;
}
.main { flex: 1; padding: 30px clamp(22px, 3vw, 42px); min-width: 0; }
.topbar { display: flex; justify-content: space-between; align-items: center; gap: 20px; margin-bottom: 26px; }
.topbar h1 { margin: 0; font-size: 28px; font-weight: 800; }
.eyebrow { margin: 0 0 4px; color: var(--muted); font-size: 13px; text-transform: uppercase; letter-spacing: .08em; }
.userbox { display: flex; align-items: center; gap: 12px; }
.grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.card, .panel {
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 8px;
    box-shadow: var(--shadow-soft);
}
.card { padding: 16px; }
.card span { color: var(--muted); }
.card strong { display: block; font-size: 26px; margin-top: 6px; }
.panel { padding: 18px; margin-bottom: 16px; }
.panel.compact { padding: 16px; }
.panel h2 { margin-top: 0; font-size: 19px; }
.toolbar { display: flex; justify-content: space-between; align-items: center; gap: 14px; margin-bottom: 14px; }
.list-toolbar {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) auto auto;
    gap: 10px;
    align-items: center;
    margin-bottom: 14px;
}
.list-count {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    color: var(--muted);
    font-weight: 700;
}
.pagination {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 10px;
    margin-top: 12px;
}
.pagination span {
    color: var(--muted);
    font-weight: 700;
}
.data-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.edit-row {
    display: none;
}
.edit-row:target {
    display: table-row;
}
.edit-row td {
    background: #f8fbff;
}
.button, button {
    border: 0;
    background: var(--accent);
    color: #fff;
    border-radius: 8px;
    padding: 9px 13px;
    font-weight: 700;
    cursor: pointer;
}
.button.big { padding: 12px 16px; font-size: 15px; }
.button:hover, button:hover { filter: brightness(.96); }
.button.secondary { background: var(--accent-2); }
.button.ghost { background: transparent; color: var(--accent); border: 1px solid var(--line); }
.button.danger { background: var(--danger); }
.notice {
    background: #e8f3ff;
    color: var(--accent-dark);
    border: 1px solid #b9d8f6;
    border-radius: 8px;
    padding: 12px 14px;
    margin-bottom: 18px;
    font-weight: 700;
}
.notice.bad { background: #fdecec; color: var(--danger); border-color: #f5c2c0; }
.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; background: var(--panel); border-radius: 8px; overflow: hidden; font-size: 13px; }
th, td { text-align: left; padding: 9px 11px; border-bottom: 1px solid var(--line-soft); vertical-align: top; }
th { font-size: 12px; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; }
tr:last-child td { border-bottom: 0; }
.badge { display: inline-flex; border-radius: 999px; padding: 4px 9px; font-size: 12px; background: #e8f3ff; color: var(--accent); font-weight: 700; }
.badge.warn { background: #fff2df; color: #9a4d16; }
.badge.bad { background: #fdecec; color: var(--danger); }
.badge.muted { background: #edf2f7; color: var(--muted); }
.empty {
    padding: 26px;
    border: 1px dashed #b8c7d9;
    border-radius: 8px;
    background: #f9fbfe;
    color: var(--muted);
}
.empty strong { display: block; color: var(--ink); margin-bottom: 5px; }
form { display: grid; gap: 12px; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.form-grid.triple { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.wide { grid-column: 1 / -1; }
.inline { display: flex; align-items: center; gap: 8px; }
.inline input { width: auto; }
.inline-form { display: flex; align-items: center; gap: 8px; }
.inline-form input { min-width: 180px; }
label { display: grid; gap: 6px; font-weight: 700; }
label small { color: var(--muted); font-weight: 500; }
.permanent-option {
    align-self: end;
    min-height: 43px;
    padding: 10px 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fbfdff;
}
.issue-form {
    align-items: start;
}
.issue-form .return-choice {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: minmax(260px, .9fr) minmax(260px, 1.1fr);
    gap: 12px;
    align-items: end;
}
.issue-form .permanent-option {
    min-height: 43px;
    margin-bottom: 23px;
}
.issue-form button.wide {
    width: 100%;
}
.signature-pad {
    grid-column: 1 / -1;
    display: grid;
    gap: 8px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fbfdff;
}
.inline-form .signature-pad {
    min-width: 260px;
    max-width: 340px;
    padding: 8px;
}
.signature-pad-title {
    color: var(--muted);
    font-size: 13px;
    font-weight: 850;
}
.signature-pad canvas {
    width: 100%;
    height: 150px;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    background: #fff;
    cursor: crosshair;
    touch-action: none;
}
.inline-form .signature-pad canvas {
    height: 92px;
}
.signature-pad-actions {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    align-items: center;
}
input, select, textarea {
    width: 100%;
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 10px 11px;
    font: inherit;
    background: #fff;
}
input:focus, select:focus, textarea:focus {
    outline: 3px solid rgba(6, 114, 216, .14);
    border-color: #8ec5f4;
}
textarea { min-height: 76px; resize: vertical; }
select[multiple] { min-height: 118px; }
.record-list { display: grid; gap: 14px; }
.compact-edit-list {
    gap: 8px;
}
.edit-panel {
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fcfdff;
    overflow: hidden;
}
.edit-panel summary {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) auto auto;
    gap: 12px;
    align-items: center;
    min-height: 48px;
    padding: 10px 13px;
    cursor: pointer;
    list-style: none;
}
.edit-panel summary::-webkit-details-marker {
    display: none;
}
.edit-panel summary span:first-child {
    display: grid;
    gap: 2px;
}
.edit-panel summary strong {
    color: var(--ink);
}
.edit-panel summary small {
    color: var(--muted);
}
.edit-panel[open] summary {
    border-bottom: 1px solid var(--line-soft);
    background: #f8fbff;
}
.edit-panel .split-card {
    border: 0;
    border-radius: 0;
    box-shadow: none;
}
.record-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: end;
    padding: 13px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fcfdff;
}
.row-main {
    display: grid;
    grid-template-columns: 1fr 1fr auto;
    gap: 10px;
    align-items: end;
}
.split-card {
    display: grid;
    grid-template-columns: minmax(0, 1.7fr) minmax(260px, .8fr);
    gap: 14px;
    padding: 16px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fcfdff;
}
.split-card.single-purpose {
    grid-template-columns: minmax(0, 1fr) auto;
}
.key-card { align-items: start; }
.key-side {
    border-left: 4px solid var(--accent);
    padding: 12px 14px;
    background: #f2f7fd;
    border-radius: 8px;
}
.key-side h3 { margin: 0; font-size: 24px; }
.key-side p { margin: 5px 0 12px; color: var(--muted); }
.key-side form, .key-side .button { margin-top: 10px; }
.key-detail-hero {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 18px;
}
.key-detail-hero h2 { margin: 0 0 6px; font-size: 34px; }
.matrix-row {
    display: grid;
    grid-template-columns: minmax(180px, .6fr) minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fbfdff;
}
.matrix-row div { display: grid; gap: 4px; }
.matrix-row span { color: var(--muted); }
.steps {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}
.steps div {
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 14px;
    background: #fbfdff;
}
.steps strong {
    display: grid;
    place-items: center;
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: var(--accent);
    color: #fff;
    margin-bottom: 10px;
}
.settings-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin-top: 18px;
}
.settings-tile {
    display: grid;
    gap: 8px;
    min-height: 112px;
    padding: 17px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background:
        linear-gradient(90deg, rgba(6,114,216,.16), transparent 56%) top left / 100% 3px no-repeat,
        #fcfdff;
    transition: transform .15s ease, border-color .15s ease, background .15s ease;
}
.settings-tile:hover {
    border-color: #9cc8f2;
    background:
        linear-gradient(90deg, rgba(6,114,216,.28), transparent 56%) top left / 100% 3px no-repeat,
        #f5faff;
}
.settings-tile strong { font-size: 18px; }
.settings-tile span { color: var(--muted); }
.page-intro {
    color: var(--muted);
    margin: -4px 0 18px;
}
.quick-issue {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 22px;
    margin-bottom: 16px;
    padding: 20px;
    border: 1px solid #b9d8f6;
    border-radius: 8px;
    background:
        linear-gradient(90deg, rgba(6,114,216,.12), transparent 42%) top left / 100% 4px no-repeat,
        #fff;
    box-shadow: 0 18px 46px rgba(6, 114, 216, .075);
}
.quick-issue-copy {
    display: flex;
    align-items: center;
    gap: 16px;
}
.quick-icon {
    width: 52px;
    height: 52px;
    display: grid;
    place-items: center;
    border-radius: 8px;
    background: var(--accent);
    color: #fff;
    font-size: 27px;
    font-weight: 800;
}
.quick-issue h2 { margin: 0 0 6px; font-size: 28px; }
.quick-issue p { margin: 0; color: var(--muted); }
.quick-issue-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.risk-control-room {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 18px;
}
.risk-control-room a {
    min-height: 118px;
    padding: 15px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    color: var(--ink);
    text-decoration: none;
    box-shadow: 0 14px 34px rgba(8, 25, 54, .035);
}
.risk-control-room a:hover {
    transform: translateY(-1px);
    border-color: #9cc8f2;
}
.risk-control-room span {
    display: block;
    color: var(--muted);
    font-size: 12px;
    font-weight: 850;
    text-transform: uppercase;
}
.risk-control-room strong {
    display: block;
    margin: 8px 0 5px;
    font-size: 34px;
    line-height: 1;
}
.risk-control-room small {
    color: var(--muted);
    line-height: 1.35;
}
.risk-control-room .is-critical {
    border-color: #f2b8b5;
    background: #fff8f8;
}
.risk-control-room .is-critical strong {
    color: var(--danger);
}
.risk-control-room .is-warning {
    border-color: #f1d996;
    background: #fffaf0;
}
.risk-control-room .is-warning strong {
    color: #8a5a00;
}
.risk-control-room .is-muted {
    background: #f8fafc;
}
.barcode {
    display: block;
    width: 100%;
    height: 54px;
    fill: #050b18;
    background: #fff;
}
.scan-entry-panel {
    display: grid;
    gap: 18px;
}
.scan-entry-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: end;
}
.scan-entry-form input {
    min-height: 58px;
    font-size: 24px;
    font-weight: 850;
    letter-spacing: .06em;
    text-transform: uppercase;
}
.scan-help-grid,
.scan-code-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.scan-help-grid div,
.scan-code-card {
    padding: 16px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
}
.scan-help-grid strong,
.scan-code-card strong {
    display: block;
    margin: 8px 0 4px;
    font-size: 18px;
}
.scan-help-grid span,
.scan-code-card span,
.scan-code-card small {
    color: var(--muted);
    line-height: 1.4;
}
.scan-code-card {
    display: grid;
    gap: 8px;
    scroll-margin-top: 18px;
}
.scan-code-card:target {
    border-color: #d8b36f;
    box-shadow: 0 0 0 3px rgba(216,179,111,.28);
}
.scan-code-card a {
    color: #0b7bdc;
    font-weight: 800;
    text-decoration: none;
}
.scan-workbench {
    display: grid;
    gap: 18px;
}
.scan-focus-card {
    display: grid;
    grid-template-columns: minmax(220px, .7fr) minmax(0, 1.3fr);
    gap: 18px;
    align-items: center;
    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
}
.scan-focus-card h3 {
    margin: 0 0 6px;
    font-size: 24px;
}
.scan-focus-card p {
    margin: 0 0 12px;
    color: var(--muted);
}
.scan-meta-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}
.scan-meta-grid > span:not(.badge) {
    padding: 7px 10px;
    border: 1px solid var(--line);
    border-radius: 999px;
    color: var(--muted);
    font-size: 13px;
    font-weight: 800;
}
.scan-action-box {
    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #f8fafc;
}
.scan-action-box h3 {
    margin: 0 0 8px;
}
.scan-action-box p {
    margin: 0 0 14px;
    color: var(--muted);
}
.scan-copy-link {
    color: inherit;
    text-decoration: none;
}
.scan-copy-link:hover {
    border-color: #d8b36f;
    box-shadow: 0 10px 30px rgba(15, 23, 42, .08);
}
.print-label-body {
    margin: 0;
    background: #eef2f7;
    color: #0f172a;
    font-family: Arial, sans-serif;
}
.label-sheet {
    width: min(1120px, calc(100% - 28px));
    margin: 0 auto;
    padding: 24px 0 40px;
}
.label-print-head {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 18px;
    padding: 18px;
    border: 1px solid #d8e1ed;
    border-radius: 8px;
    background: #fff;
}
.label-print-head img {
    width: 58px;
    height: 58px;
    object-fit: contain;
}
.label-print-head h1 {
    margin: 0 0 4px;
    font-size: 28px;
}
.label-print-head p {
    margin: 0;
    color: #64748b;
}
.label-print-head button {
    margin-left: auto;
}
.label-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
}
.key-label {
    min-height: 150px;
    padding: 12px;
    border: 1px dashed #94a3b8;
    border-radius: 6px;
    background: #fff;
    break-inside: avoid;
}
.label-title {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    font-size: 14px;
}
.key-label p {
    min-height: 32px;
    margin: 5px 0 8px;
    color: #334155;
    font-size: 12px;
    line-height: 1.25;
}
.label-code {
    margin-top: 4px;
    font-size: 16px;
    font-weight: 900;
    letter-spacing: .08em;
    text-align: center;
}
.key-label small {
    display: block;
    margin-top: 4px;
    color: #64748b;
    font-size: 11px;
    text-align: center;
}
.search-panel { padding: 12px; }
.search-panel .toolbar { margin: 0; }
.metric-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 16px;
}
.metric-card {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-areas: "icon label" "icon value";
    column-gap: 12px;
    align-items: center;
    padding: 17px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 14px 34px rgba(8, 25, 54, .035);
    transition: transform .15s ease, border-color .15s ease, background .15s ease;
}
.metric-card:hover,
.action-list a:hover,
.settings-tile:hover {
    transform: translateY(-1px);
}
.metric-card.primary { border-color: #9cc8f2; background: #f5fbff; }
.metric-card.alert { border-color: #f2b8b5; background: #fff8f8; }
.metric-icon {
    grid-area: icon;
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border-radius: 8px;
    background: var(--accent-soft);
    color: var(--accent);
    font-weight: 900;
}
.metric-card small { grid-area: label; color: var(--muted); font-weight: 700; }
.metric-card strong { grid-area: value; font-size: 28px; line-height: 1; }
.dashboard-hero {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 22px;
    margin-bottom: 18px;
}
.dashboard-hero h2 {
    margin: 0 0 6px;
    font-size: 28px;
}
.dashboard-hero p {
    margin: 0;
    color: var(--muted);
}
.dashboard-scan {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    margin-bottom: 18px;
}
.scan-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 190px;
    align-items: center;
    gap: 22px;
    min-height: 246px;
    padding: 26px 30px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 18px 46px rgba(8, 25, 54, .035);
}
.scan-copy h3 {
    margin: 0 0 26px;
    font-size: 20px;
}
.legend-list {
    display: grid;
    gap: 12px;
    max-width: 260px;
}
.legend-list span {
    display: grid;
    grid-template-columns: 14px minmax(0, 1fr) auto;
    align-items: center;
    gap: 9px;
    color: var(--muted);
    font-size: 14px;
}
.legend-list strong {
    color: var(--ink);
}
.dot {
    width: 7px;
    height: 7px;
    border-radius: 999px;
    background: var(--muted);
}
.dot.ok { background: #0f766e; }
.dot.warn { background: #d8b36f; }
.dot.bad { background: var(--danger); }
.donut {
    --value: 0;
    --ring: var(--accent);
    width: 178px;
    aspect-ratio: 1;
    display: grid;
    place-items: center;
    position: relative;
    border-radius: 50%;
    background:
        radial-gradient(circle at center, #fff 0 55%, transparent 56%),
        conic-gradient(var(--ring) calc(var(--value) * 1%), #16181d 0 88%, #edf2f7 0);
}
.donut.thin {
    background:
        radial-gradient(circle at center, #fff 0 58%, transparent 59%),
        conic-gradient(var(--ring) calc(var(--value) * 1%), #edf2f7 0);
}
.donut::after {
    content: "";
    position: absolute;
    inset: 13px;
    border-radius: 50%;
    border: 1px solid rgba(8,25,54,.08);
}
.donut strong,
.donut span {
    position: relative;
    z-index: 1;
}
.donut strong {
    align-self: end;
    font-size: 34px;
    line-height: 1;
}
.donut span {
    align-self: start;
    margin-top: 6px;
    color: var(--muted);
}
.dashboard-tabs {
    display: flex;
    align-items: center;
    gap: 26px;
    margin: 8px 0 18px;
    border-bottom: 1px solid var(--line-soft);
}
.dashboard-tabs a {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 0 0 12px;
    color: var(--muted);
    font-size: 14px;
    font-weight: 700;
}
.dashboard-tabs a.is-active {
    color: var(--ink);
}
.dashboard-tabs a.is-active::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -1px;
    height: 3px;
    border-radius: 999px;
    background: #e11d48;
}
.dashboard-tabs span {
    min-width: 22px;
    padding: 2px 7px;
    border-radius: 999px;
    background: #eef2f7;
    color: var(--ink);
    font-size: 12px;
}
.dashboard-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(300px, .65fr);
    gap: 18px;
    margin-bottom: 18px;
}
.inventory-bars {
    display: grid;
    gap: 16px;
}
.inventory-row {
    display: grid;
    grid-template-columns: 105px minmax(0, 1fr) 44px;
    align-items: center;
    gap: 12px;
}
.inventory-row span {
    color: var(--muted);
    font-weight: 700;
}
.inventory-row div {
    height: 9px;
    border-radius: 999px;
    background: #edf2f7;
    overflow: hidden;
}
.inventory-row i {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #0f766e, #d8b36f);
}
.inventory-row strong {
    text-align: right;
}
.action-list.single {
    grid-template-columns: 1fr;
}
.workbench {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(320px, .8fr);
    gap: 16px;
}
.action-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}
.action-list a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fcfdff;
    font-weight: 700;
    transition: transform .15s ease, border-color .15s ease, background .15s ease;
}
.action-list span {
    width: 30px;
    height: 30px;
    display: grid;
    place-items: center;
    border-radius: 8px;
    background: var(--accent-soft);
    color: var(--accent);
}
.mini-stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}
.mini-stats div {
    padding: 12px;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    background: #fcfdff;
}
.mini-stats strong { display: block; font-size: 24px; }
.mini-stats span { color: var(--muted); font-size: 13px; }
.protocol {
    width: min(900px, calc(100% - 40px));
    margin: 30px auto;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 32px;
}
.protocol img { width: 120px; height: 120px; object-fit: contain; }
.protocol .signature-image {
    width: min(360px, 100%);
    height: auto;
    max-height: 120px;
    object-fit: contain;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: #fff;
}
.signature-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 28px;
    margin: 70px 0 28px;
}
.signature-grid span {
    display: block;
    border-bottom: 1px solid var(--ink);
    height: 48px;
}
.signature-grid p { margin: 8px 0 0; color: var(--muted); }
.login-page {
    min-height: 100vh;
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(420px, .9fr);
    padding: 24px;
    background: #f6f9fd;
    gap: 26px;
}
.login-hero {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 28px;
    min-height: calc(100vh - 48px);
    border-radius: 18px;
    color: #fff;
    padding: clamp(28px, 4vw, 48px);
    background:
        linear-gradient(145deg, rgba(4,28,68,.98), rgba(7,39,91,.94));
    overflow: hidden;
}
.login-hero h1 {
    margin: 0;
    max-width: 760px;
    font-size: clamp(34px, 4.4vw, 58px);
    line-height: 1.04;
}
.login-hero p { max-width: 700px; color: #d9eaff; font-size: 17px; line-height: 1.45; }
.login-feature-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    max-width: 880px;
    margin-top: 22px;
}
.login-feature-grid div {
    min-height: 96px;
    padding: 16px;
    border: 1px solid rgba(255,255,255,.16);
    border-radius: 8px;
    background: rgba(255,255,255,.075);
    backdrop-filter: blur(8px);
}
.login-feature-grid strong {
    display: block;
    margin-bottom: 7px;
    color: #fff;
}
.login-feature-grid span {
    color: #c8dcf5;
    line-height: 1.38;
    font-size: 15px;
}
.login-panel {
    display: grid;
    place-items: center;
}
.login-panel .panel {
    width: min(460px, 100%);
    padding: 30px;
    box-shadow: var(--shadow-panel);
}
.login-panel h2 { margin: 0 0 6px; font-size: 30px; }
.login-panel .subline { margin-top: 0; color: var(--muted); }
.login-proof {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 16px 0 18px;
}
.login-proof span {
    padding: 6px 9px;
    border-radius: 999px;
    background: var(--accent-soft);
    color: var(--accent-dark);
    font-size: 12px;
    font-weight: 800;
}
.error { color: var(--danger); font-weight: 700; }

.site-body {
    background: #f7f9fc;
}
.site-body main {
    width: min(1180px, calc(100% - 40px));
    margin: 0 auto;
}
.site-nav {
    position: sticky;
    top: 0;
    z-index: 5;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 22px;
    width: min(1180px, calc(100% - 40px));
    margin: 0 auto;
    padding: 16px 0;
    background: rgba(247,249,252,.9);
    backdrop-filter: blur(14px);
}
.site-nav .brand {
    margin: 0;
    padding: 0;
    border: 0;
    color: var(--ink);
}
.site-nav .brand img {
    width: 40px;
    height: 40px;
}
.site-nav nav {
    display: flex;
    justify-content: center;
    gap: 8px;
}
.site-nav nav a {
    min-height: 36px;
    padding: 8px 11px;
    color: var(--muted);
    font-weight: 750;
}
.site-nav nav a:hover {
    background: #fff;
    color: var(--ink);
}
.site-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(360px, .95fr);
    gap: clamp(28px, 5vw, 62px);
    align-items: center;
    min-height: calc(100vh - 76px);
    padding: 48px 0 72px;
}
.site-hero-copy h1 {
    margin: 0;
    max-width: 760px;
    font-size: clamp(42px, 5vw, 72px);
    line-height: 1.02;
    letter-spacing: 0;
}
.hero-lead {
    max-width: 680px;
    color: var(--muted);
    font-size: 19px;
    line-height: 1.55;
}
.site-actions,
.site-proof {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-top: 22px;
}
.site-proof span {
    padding: 7px 10px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #fff;
    color: var(--accent-dark);
    font-size: 12px;
    font-weight: 850;
}
.product-preview {
    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background:
        linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    box-shadow: 0 30px 70px rgba(8,25,54,.12);
}
.preview-top {
    display: flex;
    gap: 7px;
    margin-bottom: 18px;
}
.preview-top span {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: #cbd5e1;
}
.preview-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 14px;
}
.preview-stat {
    padding: 14px;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    background: #fff;
}
.preview-stat small {
    display: block;
    color: var(--muted);
    font-weight: 800;
}
.preview-stat strong {
    display: block;
    margin-top: 7px;
    font-size: 28px;
}
.preview-stat.alert { border-color: #f4c7c3; background: #fff8f8; }
.preview-stat.ok { border-color: #b8e3d9; background: #f4fffc; }
.preview-list {
    display: grid;
    gap: 8px;
}
.preview-list div {
    display: grid;
    grid-template-columns: 88px minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    min-height: 48px;
    padding: 10px 12px;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    background: #fff;
}
.preview-list span {
    color: var(--muted);
}
.preview-list em {
    padding: 4px 8px;
    border-radius: 999px;
    background: var(--accent-soft);
    color: var(--accent-dark);
    font-size: 12px;
    font-style: normal;
    font-weight: 800;
}
.site-section {
    padding: 70px 0;
    border-top: 1px solid var(--line);
}
.intro-band,
.split-band,
.site-cta {
    display: grid;
    grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
    gap: 34px;
    align-items: center;
}
.site-section h2,
.site-cta h2 {
    margin: 0;
    max-width: 780px;
    font-size: clamp(30px, 3.4vw, 46px);
    line-height: 1.08;
}
.site-section p,
.site-cta p {
    color: var(--muted);
    font-size: 17px;
    line-height: 1.55;
}
.section-head {
    max-width: 820px;
    margin-bottom: 26px;
}
.feature-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.feature-grid div,
.demo-flow div,
.audience-grid a,
.proof-grid div,
.trust-grid div,
.price-card {
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--shadow-soft);
}
.feature-grid div {
    min-height: 168px;
    padding: 20px;
}
.feature-grid.tight {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}
.feature-grid strong {
    display: block;
    margin-bottom: 10px;
    font-size: 19px;
}
.feature-grid span {
    color: var(--muted);
    line-height: 1.45;
}
.split-band {
    padding: 54px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background:
        linear-gradient(90deg, rgba(6,114,216,.09), transparent 52%),
        #fff;
}
.check-list {
    display: grid;
    gap: 10px;
}
.check-list span {
    padding: 13px 14px;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    background: #fcfdff;
    font-weight: 750;
}
.check-list span::before {
    content: "+";
    margin-right: 9px;
    color: var(--success);
    font-weight: 900;
}
.pricing-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}
.price-card {
    display: grid;
    align-content: start;
    gap: 12px;
    min-height: 380px;
    padding: 24px;
}
.price-card.featured {
    border-color: #8ec5f4;
    box-shadow: 0 24px 56px rgba(6,114,216,.12);
}
.price-card h3 {
    margin: 0;
    font-size: 42px;
}
.price-card small {
    color: var(--muted);
    font-weight: 750;
}
.price-card ul {
    display: grid;
    gap: 10px;
    margin: 10px 0 0;
    padding: 0;
    list-style: none;
}
.price-card li {
    color: #243449;
}
.price-card li::before {
    content: "+";
    margin-right: 8px;
    color: var(--success);
    font-weight: 900;
}
.demo-flow {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}
.demo-flow div {
    min-height: 190px;
    padding: 20px;
}
.demo-flow b,
.feature-grid b {
    display: inline-grid;
    place-items: center;
    width: 34px;
    height: 34px;
    margin-bottom: 20px;
    border-radius: 8px;
    background: #e8f3ff;
    color: #05265c;
    font-size: 14px;
}
.demo-flow strong,
.audience-grid strong,
.proof-grid strong,
.trust-grid strong {
    display: block;
    margin-bottom: 9px;
    font-size: 18px;
}
.demo-flow span,
.audience-grid span,
.proof-grid span,
.trust-grid span {
    color: var(--muted);
    line-height: 1.45;
}
.audience-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
}
.audience-grid a {
    min-height: 150px;
    padding: 18px;
    color: var(--ink);
    text-decoration: none;
}
.audience-grid a:hover {
    border-color: #8ec5f4;
    transform: translateY(-1px);
}
.proof-grid,
.trust-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.proof-grid div,
.trust-grid div {
    min-height: 160px;
    padding: 20px;
}
.proof-grid a {
    display: inline-flex;
    margin-top: 16px;
    color: #0b7bdc;
    font-weight: 800;
    text-decoration: none;
}
.site-subhero {
    margin: 22px 0 18px;
    padding: clamp(38px, 6vw, 72px);
    border: 1px solid rgba(255,255,255,.54);
    border-radius: 8px;
    background:
        linear-gradient(90deg, rgba(3,18,43,.95), rgba(5,38,92,.78)),
        url("/public/assets/img/keyora-hero.png") center right / cover no-repeat;
    color: #fff;
    box-shadow: 0 28px 78px rgba(8,25,54,.18);
}
.site-subhero h1 {
    max-width: 860px;
    margin: 0 0 18px;
    color: #fff;
    font-size: clamp(38px, 6vw, 70px);
    line-height: 1.02;
}
.site-subhero p {
    max-width: 760px;
    margin: 0;
    color: #dbeafe;
    font-size: 18px;
    line-height: 1.55;
}
.site-subhero .eyebrow {
    color: #8fd3ff;
}
.comparison-table {
    display: grid;
    border: 1px solid var(--line);
    border-radius: 8px;
    overflow: hidden;
    background: #fff;
    box-shadow: var(--shadow-soft);
}
.comparison-table div {
    display: grid;
    grid-template-columns: 180px 1fr 1fr;
    gap: 14px;
    padding: 18px;
    border-bottom: 1px solid var(--line-soft);
}
.comparison-table div:last-child {
    border-bottom: 0;
}
.comparison-table strong {
    color: var(--ink);
}
.comparison-table span {
    color: var(--muted);
}
.comparison-table span:last-child {
    color: #0f5132;
    font-weight: 750;
}
.price-calculator {
    display: grid;
    grid-template-columns: 1.2fr 1fr auto;
    gap: 18px;
    align-items: end;
    margin-top: 18px;
    padding: 22px;
    border: 1px solid #b9d8f6;
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--shadow-panel);
}
.price-calculator h3 {
    margin: 0 0 8px;
    font-size: 28px;
}
.price-calculator p {
    margin: 0;
}
.calc-controls {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}
.calc-controls label {
    font-size: 12px;
    font-weight: 800;
    color: var(--muted);
    text-transform: uppercase;
}
.calc-controls input {
    margin-top: 7px;
}
.price-calculator output {
    min-width: 190px;
    padding: 14px 16px;
    border-radius: 8px;
    background: #05265c;
    color: #fff;
    font-weight: 900;
    text-align: center;
}
.site-cta {
    margin: 18px 0 70px;
    padding: 34px;
    border: 1px solid #b9d8f6;
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--shadow-panel);
}
.site-cta .button {
    justify-self: end;
}

/* Public website visual layer */
.site-body {
    background:
        linear-gradient(180deg, #eef4fb 0%, #f7f9fc 36%, #ffffff 100%);
}
.site-nav {
    width: min(1220px, calc(100% - 36px));
    padding: 14px 18px;
    margin-top: 12px;
    border: 1px solid rgba(225,232,242,.86);
    border-radius: 8px;
    background: rgba(255,255,255,.88);
    box-shadow: 0 16px 42px rgba(8,25,54,.075);
}
.site-body main {
    width: min(1220px, calc(100% - 36px));
}
.site-hero {
    position: relative;
    min-height: calc(100vh - 168px);
    margin: 18px 0 22px;
    padding: clamp(34px, 5vw, 64px);
    border: 1px solid rgba(255,255,255,.54);
    border-radius: 8px;
    background:
        linear-gradient(90deg, rgba(3,18,43,.94) 0%, rgba(5,38,92,.78) 43%, rgba(5,38,92,.24) 68%, rgba(5,38,92,.08) 100%),
        url("/public/assets/img/keyora-hero.png") center right / cover no-repeat;
    box-shadow: 0 28px 78px rgba(8,25,54,.18);
    overflow: hidden;
}
.site-hero::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 120px;
    background: linear-gradient(180deg, transparent, rgba(3,18,43,.18));
    pointer-events: none;
}
.site-hero-copy {
    position: relative;
    z-index: 1;
    max-width: 660px;
}
.site-hero-copy .eyebrow {
    color: #8fd3ff;
}
.site-hero-copy h1 {
    color: #fff;
    text-shadow: 0 18px 52px rgba(0,0,0,.25);
}
.hero-lead {
    color: #dbeafe;
}
.site-actions .button.ghost {
    border-color: rgba(255,255,255,.36);
    background: rgba(255,255,255,.1);
    color: #fff;
}
.site-proof span {
    border-color: rgba(255,255,255,.24);
    background: rgba(255,255,255,.12);
    color: #ecf7ff;
    backdrop-filter: blur(10px);
}
.product-preview {
    position: relative;
    z-index: 1;
    align-self: end;
    margin-top: 150px;
    border-color: rgba(255,255,255,.24);
    background: rgba(255,255,255,.88);
    backdrop-filter: blur(18px);
    box-shadow: 0 28px 70px rgba(0,0,0,.2);
}
.preview-label {
    position: absolute;
    top: -14px;
    right: 16px;
    padding: 7px 10px;
    border-radius: 999px;
    background: #0f766e;
    color: #fff;
    font-size: 12px;
    font-weight: 850;
    box-shadow: 0 12px 28px rgba(15,118,110,.28);
}
.site-trust {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin: -4px 0 28px;
}
.site-trust div {
    padding: 16px 18px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--shadow-soft);
}
.site-trust strong {
    display: block;
    font-size: 26px;
    color: var(--accent-dark);
}
.site-trust span {
    color: var(--muted);
    font-weight: 750;
}
.intro-band {
    padding: 64px 38px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background:
        linear-gradient(90deg, rgba(6,114,216,.09), transparent 52%),
        #fff;
    box-shadow: var(--shadow-soft);
}
.feature-grid div {
    position: relative;
    overflow: hidden;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.feature-grid div:hover {
    transform: translateY(-3px);
    border-color: #9cc8f2;
    box-shadow: 0 22px 52px rgba(8,25,54,.075);
}
.feature-grid b {
    display: inline-grid;
    place-items: center;
    width: 34px;
    height: 34px;
    margin-bottom: 18px;
    border-radius: 8px;
    background: var(--accent-dark);
    color: #fff;
    font-size: 13px;
}
.split-band {
    background:
        linear-gradient(90deg, rgba(3,18,43,.96), rgba(5,38,92,.92)),
        #05265c;
    color: #fff;
    box-shadow: 0 24px 66px rgba(8,25,54,.16);
}
.split-band .eyebrow,
.split-band p {
    color: #c8dcf5;
}
.check-list span {
    border-color: rgba(255,255,255,.14);
    background: rgba(255,255,255,.08);
    color: #fff;
}
.pricing-grid {
    align-items: stretch;
}
.price-card {
    position: relative;
    overflow: hidden;
}
.price-card.featured {
    transform: translateY(-10px);
    border-color: #0672d8;
    background:
        linear-gradient(180deg, #f8fcff 0%, #ffffff 52%);
}
.plan-badge {
    position: absolute;
    top: 18px;
    right: 18px;
    padding: 6px 10px;
    border-radius: 999px;
    background: var(--accent);
    color: #fff;
    font-size: 12px;
    font-weight: 850;
}
.site-cta {
    background:
        linear-gradient(90deg, #05265c, #075f8f);
    color: #fff;
    border-color: transparent;
}
.site-cta .eyebrow,
.site-cta p {
    color: #d9eaff;
}
.site-cta h2 {
    color: #fff;
}
.site-footer {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
    width: min(1220px, calc(100% - 36px));
    margin: 0 auto;
    padding: 24px 0 34px;
    color: var(--muted);
    font-weight: 750;
}
.site-footer a {
    color: var(--accent-dark);
}
.site-footer a:hover {
    color: var(--accent);
}
.legal-page {
    max-width: 920px;
    margin: 46px auto 70px;
    padding: clamp(24px, 5vw, 54px);
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--shadow-panel);
}
.legal-page h1 {
    margin: 0 0 12px;
    font-size: clamp(38px, 5vw, 58px);
    line-height: 1.05;
}
.legal-page h2 {
    margin: 28px 0 8px;
    font-size: 20px;
}
.legal-page p {
    color: var(--muted);
    font-size: 16px;
    line-height: 1.58;
}
.legal-page a {
    color: var(--accent);
    font-weight: 800;
}
.legal-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin: 26px 0 6px;
}
.legal-grid div {
    padding: 18px;
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    background: #fbfdff;
}
.legal-grid h2 {
    margin-top: 0;
}
.cookie-banner {
    position: fixed;
    left: 50%;
    bottom: 18px;
    z-index: 30;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    align-items: center;
    width: min(760px, calc(100% - 32px));
    padding: 16px;
    border: 1px solid rgba(185,216,246,.86);
    border-radius: 8px;
    background: rgba(255,255,255,.96);
    box-shadow: 0 24px 68px rgba(8,25,54,.22);
    transform: translateX(-50%);
    backdrop-filter: blur(14px);
}
.cookie-banner[hidden] {
    display: none;
}
.cookie-banner strong {
    display: block;
    margin-bottom: 4px;
    color: var(--ink);
}
.cookie-banner p {
    margin: 0;
    color: var(--muted);
    line-height: 1.45;
}
.error-page {
    display: grid;
    grid-template-columns: minmax(0, .9fr) minmax(360px, 1.1fr);
    gap: clamp(24px, 5vw, 58px);
    align-items: center;
    min-height: min(720px, calc(100vh - 170px));
    margin: 46px auto 70px;
    padding: clamp(24px, 5vw, 56px);
    border: 1px solid rgba(185,216,246,.82);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(3,18,43,.97), rgba(5,38,92,.9) 58%, rgba(7,95,143,.78)),
        #05265c;
    color: #fff;
    box-shadow: 0 28px 78px rgba(8,25,54,.2);
    overflow: hidden;
}
.error-copy {
    position: relative;
    z-index: 1;
}
.error-copy .eyebrow {
    color: #8fd3ff;
}
.error-copy h1 {
    margin: 0 0 14px;
    max-width: 660px;
    font-size: clamp(38px, 5vw, 66px);
    line-height: 1.03;
}
.error-copy p {
    max-width: 580px;
    color: #d9eaff;
    font-size: 18px;
    line-height: 1.55;
}
.error-page .button.ghost {
    border-color: rgba(255,255,255,.36);
    background: rgba(255,255,255,.1);
    color: #fff;
}
.error-visual {
    position: relative;
}
.error-visual::before {
    content: "";
    position: absolute;
    inset: 12% -4% -6% 12%;
    border-radius: 999px;
    background: rgba(143,211,255,.16);
    filter: blur(28px);
}
.error-visual img {
    position: relative;
    display: block;
    width: 100%;
    border: 1px solid rgba(255,255,255,.22);
    border-radius: 8px;
    box-shadow: 0 28px 70px rgba(0,0,0,.28);
}
.static-error-main {
    width: min(1220px, calc(100% - 36px));
    margin: 0 auto;
    padding-top: 24px;
}

/* Enterprise refinement layer */
body {
    font-size: 14px;
}
.sidebar {
    background:
        linear-gradient(180deg, rgba(255,255,255,.035), transparent 26%),
        linear-gradient(180deg, #031a3e 0%, #062451 52%, #073264 100%);
    border-right: 1px solid rgba(255,255,255,.08);
    box-shadow: 18px 0 46px rgba(8,25,54,.08);
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,.28) transparent;
}
.brand {
    padding-bottom: 18px;
    border-bottom: 1px solid rgba(255,255,255,.12);
}
nav a {
    min-height: 42px;
    font-size: 14px;
    font-weight: 650;
}
nav a:hover,
.nav-group-head:hover > a {
    background: rgba(255,255,255,.105);
}
.nav-icon {
    width: 28px;
    height: 28px;
    flex-basis: 28px;
    background: rgba(255,255,255,.105);
}
.subnav {
    margin-left: 34px;
}
.subnav a {
    min-height: 30px;
    padding-top: 6px;
    padding-bottom: 6px;
    font-size: 12.5px;
    color: #c5dcf7;
}
.subnav-label {
    padding-top: 8px;
}
.main {
    max-width: 1680px;
    padding-top: 26px;
}
.topbar {
    min-height: 72px;
    padding: 4px 0 18px;
    border-bottom: 1px solid rgba(219,228,239,.8);
}
.topbar h1 {
    letter-spacing: 0;
}
.userbox {
    padding: 8px 10px 8px 14px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(255,255,255,.78);
    box-shadow: 0 10px 26px rgba(8,25,54,.028);
}
.account-link {
    color: #0f213d;
    font-weight: 750;
    text-decoration: none;
}
.account-link:hover {
    color: var(--accent);
}
.panel,
.card,
.metric-card,
.scan-card,
.settings-tile,
.split-card,
.record-row,
.matrix-row {
    border-color: rgba(197,210,226,.72);
}
.panel {
    position: relative;
    overflow: hidden;
}
.panel::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, rgba(6,114,216,.45), rgba(15,118,110,.18), transparent 52%);
    pointer-events: none;
}
.panel h2,
.toolbar h2 {
    margin-bottom: 0;
    letter-spacing: 0;
}
.toolbar {
    min-height: 38px;
}
.button,
button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    border: 1px solid transparent;
    box-shadow: 0 8px 18px rgba(6,114,216,.12);
    transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease, background .12s ease;
}
.button:hover,
button:hover {
    filter: none;
    transform: translateY(-1px);
    box-shadow: 0 12px 24px rgba(6,114,216,.16);
}
.button.ghost {
    background: #fff;
    box-shadow: none;
}
.button.ghost:hover {
    border-color: #9cc8f2;
    background: #f5fbff;
}
.button.danger {
    box-shadow: 0 8px 18px rgba(180,35,24,.12);
}
input,
select,
textarea {
    min-height: 39px;
    border-color: #d7e1ee;
    background: #fbfdff;
    font-size: 13.5px;
}
textarea {
    line-height: 1.45;
}
label {
    align-content: start;
    color: #172946;
    font-size: 13px;
}
table {
    border: 1px solid var(--line-soft);
    box-shadow: none;
}
th {
    background: #f8fafc;
    color: #718197;
    font-size: 11px;
    font-weight: 800;
}
td {
    color: #1c2d47;
}
tr:hover td {
    background: #fbfdff;
}
.badge {
    border: 1px solid rgba(6,114,216,.16);
}
.badge.warn {
    border-color: rgba(217,119,6,.22);
}
.badge.bad {
    border-color: rgba(180,35,24,.22);
}
.empty {
    background:
        linear-gradient(90deg, rgba(6,114,216,.08), transparent 45%) top left / 100% 2px no-repeat,
        #fbfdff;
}
.settings-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.settings-tile {
    min-height: 104px;
    align-content: start;
    box-shadow: 0 10px 26px rgba(8,25,54,.026);
}
.settings-tile strong {
    font-size: 16px;
}
.settings-tile span {
    font-size: 13px;
}
.record-row,
.split-card,
.matrix-row {
    box-shadow: 0 8px 22px rgba(8,25,54,.022);
}
.split-card:hover,
.record-row:hover,
.matrix-row:hover,
.settings-tile:hover {
    border-color: #b7cbe1;
}
.key-side {
    border-left: 0;
    border-top: 3px solid var(--accent);
    background:
        linear-gradient(180deg, #f7fbff 0%, #eef6ff 100%);
}
.key-side h3 {
    font-size: 22px;
}
.panel > form.form-grid,
.panel > form.form-grid.triple {
    padding: 4px 0 2px;
}
.panel > form.form-grid button,
.panel > form.form-grid.triple button {
    align-self: end;
}
.form-grid.triple label.wide {
    grid-column: span 2;
}
.form-grid.triple label.wide textarea {
    min-height: 58px;
}
.record-list .split-card {
    align-items: stretch;
}
.record-list .split-card .form-grid {
    gap: 10px;
}
.key-detail-hero {
    background:
        linear-gradient(90deg, rgba(6,114,216,.08), transparent 48%),
        #fff;
}
.quick-issue,
.dashboard-hero {
    background:
        linear-gradient(90deg, rgba(6,114,216,.08), transparent 54%),
        #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 18px;
    box-shadow: var(--shadow-soft);
}
.dashboard-hero h2 {
    font-size: 26px;
}
.scan-card {
    min-height: 226px;
    box-shadow: var(--shadow-soft);
}
.donut {
    width: 164px;
}
.dashboard-tabs {
    background: rgba(255,255,255,.72);
    border: 1px solid var(--line-soft);
    border-radius: 8px;
    padding: 0 14px;
    box-shadow: 0 8px 22px rgba(8,25,54,.022);
}
.dashboard-tabs a {
    padding-top: 13px;
}
.inventory-row div {
    height: 8px;
}
.login-page {
    background:
        linear-gradient(180deg, #f8fbff 0%, #eef4fb 100%);
}
.login-hero {
    box-shadow: 0 24px 60px rgba(4,28,68,.18);
}
.login-feature-grid div {
    box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}
.login-panel .panel::before {
    background: linear-gradient(90deg, var(--accent), #0f766e);
}

/* Fine-grained workspace layer */
:root {
    --workspace: #f4f6f9;
    --workspace-2: #eef2f6;
    --surface: rgba(255,255,255,.88);
    --surface-solid: #ffffff;
    --surface-subtle: #f8fafc;
    --surface-hover: #f3f7fb;
    --text-strong: #101827;
    --text-soft: #5f6c7d;
    --focus-ring: rgba(47, 128, 237, .18);
    --nav-bg: #111827;
    --nav-bg-2: #171d28;
    --nav-text: #c4cad5;
    --nav-muted: #858d9c;
    --nav-active: #2f80ed;
    --donut-hole: #ffffff;
    --donut-track: #e7edf5;
    --action-bg: #ffffff;
    --danger-soft: #fdecec;
    --warn-soft: #fff2df;
    --ok-soft: #e7f7f1;
}

body.theme-dark,
body.theme-system {
    color-scheme: light;
}

@media (prefers-color-scheme: dark) {
    body.theme-system {
        color-scheme: dark;
        --bg: #1f2024;
        --workspace: #202124;
        --workspace-2: #18191d;
        --ink: #f2f5f8;
        --muted: #a8b0bd;
        --panel: #24262b;
        --line: #363942;
        --line-soft: #30333b;
        --surface: rgba(37,39,44,.92);
        --surface-solid: #24262b;
        --surface-subtle: #1d1f23;
        --surface-hover: #2b2e35;
        --text-strong: #f4f7fb;
        --text-soft: #a8b0bd;
        --accent: #4a92ff;
        --accent-dark: #d8e7ff;
        --accent-soft: #163052;
        --nav-bg: #15161a;
        --nav-bg-2: #202228;
        --nav-text: #c9ced8;
        --nav-muted: #8f97a6;
        --donut-hole: #24262b;
        --donut-track: #363942;
        --action-bg: #202329;
        --danger-soft: #3a2023;
        --warn-soft: #352b1d;
        --ok-soft: #1d3029;
        --shadow-soft: 0 10px 28px rgba(0,0,0,.16);
        --shadow-panel: 0 16px 42px rgba(0,0,0,.2);
    }
}

body.theme-dark {
    color-scheme: dark;
    --bg: #1f2024;
    --workspace: #202124;
    --workspace-2: #18191d;
    --ink: #f2f5f8;
    --muted: #a8b0bd;
    --panel: #24262b;
    --line: #363942;
    --line-soft: #30333b;
    --surface: rgba(37,39,44,.92);
    --surface-solid: #24262b;
    --surface-subtle: #1d1f23;
    --surface-hover: #2b2e35;
    --text-strong: #f4f7fb;
    --text-soft: #a8b0bd;
    --accent: #4a92ff;
    --accent-dark: #d8e7ff;
    --accent-soft: #163052;
    --nav-bg: #15161a;
    --nav-bg-2: #202228;
    --nav-text: #c9ced8;
    --nav-muted: #8f97a6;
    --donut-hole: #24262b;
    --donut-track: #363942;
    --action-bg: #202329;
    --danger-soft: #3a2023;
    --warn-soft: #352b1d;
    --ok-soft: #1d3029;
    --shadow-soft: 0 10px 28px rgba(0,0,0,.16);
    --shadow-panel: 0 16px 42px rgba(0,0,0,.2);
}

body.theme-light {
    color-scheme: light;
}

body {
    background: linear-gradient(180deg, var(--workspace) 0%, var(--workspace-2) 100%);
}

.shell {
    background: transparent;
}

.sidebar {
    width: 252px;
    flex-basis: 252px;
    background: linear-gradient(180deg, var(--nav-bg) 0%, var(--nav-bg-2) 100%);
    color: var(--nav-text);
    padding: 14px 10px;
    box-shadow: none;
}

.brand {
    min-height: 44px;
    margin: 0 4px 18px;
    padding: 0 8px 14px;
    font-size: 17px;
    font-weight: 760;
}

.brand img {
    width: 30px;
    height: 30px;
    border-radius: 6px;
}

nav {
    gap: 2px;
}

nav a,
.subnav a {
    position: relative;
    min-height: 34px;
    border-radius: 7px;
    color: var(--nav-text);
    font-size: 13px;
    font-weight: 560;
}

nav a:hover,
.nav-group-head:hover > a,
.subnav a:hover {
    background: rgba(255,255,255,.055);
    color: #fff;
}

nav a.is-active,
.subnav a.is-active,
.account-link.is-active {
    color: #fff;
    background: rgba(47,128,237,.17);
}

nav a.is-active::before,
.subnav a.is-active::before {
    content: "";
    position: absolute;
    left: 0;
    top: 9px;
    bottom: 9px;
    width: 2px;
    border-radius: 999px;
    background: var(--nav-active);
}

.nav-icon {
    width: 24px;
    height: 24px;
    flex-basis: 24px;
    border-radius: 6px;
    background: rgba(255,255,255,.07);
    color: var(--nav-text);
    font-size: 13px;
}

.nav-subtoggle {
    width: 30px;
    height: 30px;
    border-radius: 7px;
    background: rgba(255,255,255,.045);
    color: var(--nav-muted);
}

.subnav {
    margin: 0 0 4px 28px;
    padding-left: 8px;
    border-color: rgba(255,255,255,.09);
}

.subnav a {
    min-height: 28px;
    padding: 5px 9px;
    font-size: 12px;
}

.subnav-label {
    color: var(--nav-muted);
    font-size: 10px;
    letter-spacing: .06em;
}

.main {
    max-width: none;
    padding: 18px 22px 28px;
}

.topbar {
    position: sticky;
    top: 0;
    z-index: 10;
    min-height: 58px;
    margin: -18px -22px 18px;
    padding: 12px 22px;
    border-bottom: 1px solid var(--line);
    background: color-mix(in srgb, var(--workspace) 88%, transparent);
    backdrop-filter: blur(14px);
}

.topbar h1 {
    font-size: 18px;
    font-weight: 760;
    color: var(--text-strong);
}

.eyebrow {
    color: var(--text-soft);
    font-size: 10.5px;
    letter-spacing: .06em;
}

.context-line {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 5px;
}

.context-line span {
    display: inline-flex;
    align-items: center;
    min-height: 20px;
    padding: 2px 7px;
    border: 1px solid var(--line);
    border-radius: 999px;
    color: var(--text-soft);
    background: var(--surface);
    font-size: 11px;
    font-weight: 650;
}

.userbox {
    padding: 4px;
    gap: 6px;
    border-color: var(--line);
    background: var(--surface);
    box-shadow: none;
}

.account-link {
    min-height: 30px;
    padding: 6px 9px;
    border-radius: 7px;
    color: var(--text-strong);
    font-size: 13px;
    font-weight: 680;
}

.panel,
.card,
.metric-card,
.scan-card,
.settings-tile,
.record-row,
.split-card,
.matrix-row,
.edit-panel {
    background: var(--surface-solid);
    border-color: var(--line);
    box-shadow: none;
}

.panel {
    padding: 14px;
    margin-bottom: 10px;
}

.panel::before {
    display: none;
}

.panel h2,
.toolbar h2 {
    font-size: 15px;
    font-weight: 760;
    color: var(--text-strong);
}

.page-intro {
    margin: 2px 0 14px;
    font-size: 13px;
    color: var(--text-soft);
}

.toolbar {
    min-height: 30px;
    margin-bottom: 10px;
}

.button,
button {
    min-height: 31px;
    border-radius: 7px;
    padding: 6px 10px;
    box-shadow: none;
    font-size: 12.5px;
    font-weight: 720;
}

.button:hover,
button:hover {
    transform: none;
    box-shadow: none;
}

.button.ghost {
    background: var(--surface-solid);
    color: var(--accent);
    border-color: var(--line);
}

.button.ghost:hover,
button.ghost:hover {
    background: var(--surface-hover);
}

.permanent-option,
.edit-row td,
.key-side,
.steps div,
.mini-stats div,
.metric-card,
.metric-card.primary,
.metric-card.alert,
.preview-card,
.preview-stat,
.preview-stat.alert,
.preview-stat.ok,
.search-panel,
.workbench,
.data-actions,
.login-proof span {
    background: var(--surface-subtle);
    border-color: var(--line);
    color: var(--text-strong);
}

.key-side {
    border-top-color: var(--accent);
}

.permanent-option {
    color: var(--text-soft);
}

.permanent-option input[type="checkbox"],
.inline input[type="checkbox"] {
    accent-color: var(--accent);
}

input,
select,
textarea {
    min-height: 33px;
    border-color: var(--line);
    border-radius: 7px;
    background: var(--surface-subtle);
    color: var(--text-strong);
    font-size: 13px;
}

input:focus,
select:focus,
textarea:focus {
    outline: 2px solid var(--focus-ring);
    border-color: var(--accent);
}

label {
    color: var(--text-strong);
    font-size: 12.5px;
    font-weight: 680;
}

table {
    border: 0;
    border-radius: 7px;
    background: var(--surface-solid);
    font-size: 13px;
}

th,
td {
    padding: 8px 10px;
    border-color: var(--line-soft);
}

th {
    background: var(--surface-subtle);
    color: var(--text-soft);
    font-size: 10.5px;
    font-weight: 780;
}

td {
    color: var(--text-strong);
}

tr:nth-child(even) td {
    background: color-mix(in srgb, var(--surface-subtle) 58%, transparent);
}

tr:hover td {
    background: var(--surface-hover);
}

.badge {
    padding: 2px 7px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 720;
    background: var(--accent-soft);
}

.badge.warn {
    background: var(--warn-soft);
    color: #d8b36f;
    border-color: color-mix(in srgb, #d8b36f 32%, transparent);
}

.badge.bad,
.notice.bad {
    background: var(--danger-soft);
    color: #ff8f86;
    border-color: color-mix(in srgb, #ff8f86 32%, transparent);
}

.badge.muted {
    background: var(--surface-subtle);
    color: var(--text-soft);
    border-color: var(--line);
}

.notice {
    display: flex;
    align-items: center;
    min-height: 38px;
    border-radius: 7px;
    padding: 9px 11px;
    font-size: 13px;
    box-shadow: none;
}

.notice::before {
    content: "";
    width: 7px;
    height: 7px;
    margin-right: 9px;
    border-radius: 999px;
    background: currentColor;
}

.notice:not(.bad) {
    background: var(--ok-soft);
    color: color-mix(in srgb, var(--success) 72%, var(--text-strong));
    border-color: color-mix(in srgb, var(--success) 28%, var(--line));
}

.empty {
    padding: 18px;
    border-radius: 7px;
    background: var(--surface-subtle);
    color: var(--text-soft);
}

.empty strong {
    color: var(--text-strong);
}

.settings-tile {
    min-height: 82px;
    padding: 13px;
    background: var(--surface-solid);
}

.settings-tile:hover,
.split-card:hover,
.record-row:hover,
.matrix-row:hover {
    background: var(--surface-hover);
    border-color: color-mix(in srgb, var(--accent) 34%, var(--line));
}

.dashboard-hero,
.quick-issue {
    padding: 15px;
    background: var(--surface-solid);
    border-color: var(--line);
    box-shadow: none;
}

.dashboard-hero h2 {
    font-size: 20px;
}

.dashboard-tabs {
    background: var(--surface);
    border-color: var(--line);
    box-shadow: none;
}

.dashboard-tabs a.is-active {
    color: var(--accent);
    border-bottom-color: var(--accent);
}

.scan-card {
    background: var(--surface-solid);
}

.legend-list strong,
.inventory-row strong,
.donut strong {
    color: var(--text-strong);
}

.donut,
.donut.thin {
    background:
        radial-gradient(circle at center, var(--donut-hole) 0 58%, transparent 59%),
        conic-gradient(var(--ring) calc(var(--value) * 1%), var(--donut-track) 0);
}

.donut::after {
    border-color: color-mix(in srgb, var(--line) 72%, transparent);
}

.donut span {
    color: var(--text-soft);
}

.inventory-row div {
    background: var(--donut-track);
}

.action-list a,
.mini-stats div {
    background: var(--action-bg);
    border-color: var(--line);
    color: var(--text-strong);
}

.action-list a:hover {
    background: var(--surface-hover);
}

.action-list span {
    background: var(--accent-soft);
    color: var(--accent);
}

form.is-submitting button[type="submit"],
form.is-submitting button:not([type]) {
    opacity: .72;
    cursor: progress;
}

body.theme-dark .login-page,
body.theme-system .login-page {
    background: var(--workspace);
}

body.theme-dark .key-detail-hero,
body.theme-dark .quick-issue,
body.theme-dark .dashboard-hero,
body.theme-system .key-detail-hero,
body.theme-system .quick-issue,
body.theme-system .dashboard-hero {
    background: var(--surface-solid);
}

@media (max-width: 900px) {
    .shell { display: block; }
    .sidebar {
        position: relative;
        width: 100%;
        height: auto;
        min-height: 0;
        padding: 16px;
    }
    .brand { margin-bottom: 14px; }
    .dashboard-hero,
    .dashboard-scan,
    .dashboard-grid,
    .risk-control-room { display: grid; grid-template-columns: 1fr; }
    .scan-entry-form,
    .scan-focus-card,
    .scan-help-grid,
    .scan-code-grid,
    .label-grid {
        grid-template-columns: 1fr;
    }
    .scan-card { grid-template-columns: 1fr; justify-items: center; padding: 22px; }
    .scan-copy { width: 100%; }
    .dashboard-tabs { gap: 16px; overflow-x: auto; }
    .grid, .form-grid, .metric-grid, .workbench, .action-list, .issue-form .return-choice { grid-template-columns: 1fr; }
    .signature-pad-actions { grid-template-columns: 1fr; }
    .inline-form .signature-pad { max-width: none; width: 100%; }
    .list-toolbar { grid-template-columns: 1fr; }
    .pagination { justify-content: flex-start; flex-wrap: wrap; }
    .edit-panel summary { grid-template-columns: 1fr; }
    .form-grid.triple, .steps, .settings-grid, .split-card, .signature-grid, .matrix-row { grid-template-columns: 1fr; }
    .quick-issue, .quick-issue-copy { display: grid; }
    .key-detail-hero { display: grid; }
    .record-row { grid-template-columns: 1fr; }
    .topbar { align-items: flex-start; flex-direction: column; }
    .site-body main,
    .site-nav {
        width: min(100% - 28px, 1180px);
    }
    .site-nav {
        position: relative;
        grid-template-columns: 1fr auto;
    }
    .site-nav nav {
        grid-column: 1 / -1;
        justify-content: flex-start;
        overflow-x: auto;
    }
    .site-hero,
    .intro-band,
    .split-band,
    .pricing-grid,
    .site-cta {
        grid-template-columns: 1fr;
    }
    .site-hero {
        min-height: auto;
        padding: 28px 0 44px;
        margin-top: 14px;
        padding: 28px 20px;
        background:
            linear-gradient(180deg, rgba(3,18,43,.96) 0%, rgba(5,38,92,.84) 58%, rgba(5,38,92,.34) 100%),
            url("/public/assets/img/keyora-hero.png") center right / cover no-repeat;
    }
    .site-hero-copy h1 {
        font-size: 40px;
    }
    .product-preview {
        margin-top: 20px;
    }
    .site-trust {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .product-preview {
        min-width: 0;
    }
    .preview-grid,
    .feature-grid,
    .feature-grid.tight,
    .demo-flow,
    .audience-grid,
    .proof-grid,
    .trust-grid,
    .price-calculator,
    .calc-controls {
        grid-template-columns: 1fr;
    }
    .comparison-table div {
        grid-template-columns: 1fr;
    }
    .price-calculator output {
        min-width: 0;
        width: 100%;
    }
    .preview-list div {
        grid-template-columns: 1fr;
    }
    .site-section {
        padding: 44px 0;
    }
    .split-band,
    .site-cta {
        padding: 22px;
    }
    .site-cta .button {
        justify-self: start;
    }
    .legal-grid,
    .cookie-banner,
    .error-page {
        grid-template-columns: 1fr;
    }
    .error-page {
        min-height: auto;
        margin: 28px auto 44px;
        padding: 24px;
    }
    .cookie-banner {
        align-items: stretch;
    }
    .login-page { display: block; padding: 14px; }
    .login-hero { min-height: auto; margin-bottom: 14px; padding: 24px; }
    .login-feature-grid { grid-template-columns: 1fr; }
    .issue-form .permanent-option { margin-bottom: 0; }
}
@media print {
    body { background: #fff; }
    .print-label-body { background: #fff; }
    .label-sheet { width: 100%; padding: 0; }
    .label-print-head { display: none; }
    .label-grid { grid-template-columns: repeat(3, 1fr); gap: 0; }
    .key-label {
        min-height: 38mm;
        border: 1px dashed #888;
        border-radius: 0;
        box-shadow: none;
        page-break-inside: avoid;
    }
    .protocol { border: 0; margin: 0; width: 100%; box-shadow: none; }
    .protocol button { display: none; }
}
