:root {
    --color-primary: #004354;
    --color-primary-strong: #005c72;
    --color-secondary: #536167;
    --color-secondary-soft: #d6e5ec;
    --color-secondary-text: #58676d;
    --color-surface: #ffffff;
    --color-surface-low: #f3f4f5;
    --color-surface-mid: #edeeef;
    --color-surface-high: #e7e8e9;
    --color-border: #bfc8cc;
    --color-text: #191c1d;
    --color-text-muted: #3f484c;
    --color-nav-text: #6b7280;
    --color-shadow: rgba(0, 67, 84, 0.1);
    --sidebar-width: 16rem;
    --content-max-width: 120rem;
    --radius-sm: 0.125rem;
    --radius-md: 0.25rem;
    --radius-lg: 1rem;
    --radius-xl: 0.75rem;
    --transition: 180ms ease;
    --sidebar-role-line: #004354;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    font-size: 16px;
}

body {
    margin: 0;
    min-height: 100vh;
    background: #f8f9fa;
    color: var(--color-text);
    font-family: "Inter", sans-serif;
}

a {
    color: inherit;
    text-decoration: none;
}

button {
    font: inherit;
}

.material-symbols-outlined {
    font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
}

.app-shell {
    min-height: 100vh;
}

.app-overlay {
    position: fixed;
    inset: 0;
    background: rgba(8, 15, 20, 0.42);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition);
    z-index: 39;
}

.sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    width: var(--sidebar-width);
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 0;
    overflow-y: auto;
    background: #f0f4f8;
    border-right: 1px solid #e2e8f0;
    z-index: 40;
    transition: width var(--transition);
}

.sidebar::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    width: 0.45rem;
    background: var(--sidebar-role-line);
}

.sidebar__brand {
    padding: 2rem 1.5rem;
    transition: padding var(--transition);
}

.sidebar__title,
.dashboard-header__title,
.dashboard-section-title,
.metric__value {
    font-family: "Manrope", sans-serif;
}

.sidebar__title {
    margin: 0;
    color: var(--color-primary);
    font-size: 0.875rem;
    font-weight: 700;
    letter-spacing: -0.01em;
    line-height: 1.15;
    transition: opacity var(--transition), max-width var(--transition);
}

.sidebar__subtitle {
    margin: 0.125rem 0 0;
    color: var(--color-nav-text);
    font-size: 0.625rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    transition: opacity var(--transition), max-width var(--transition);
}

.sidebar__nav,
.sidebar__footer {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.sidebar__nav {
    flex: 1;
}

.sidebar__link {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.5rem;
    color: var(--color-nav-text);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    transition:
        color var(--transition),
        background-color var(--transition),
        padding var(--transition),
        gap var(--transition);
}

.sidebar__link:hover,
.sidebar__link:focus-visible {
    color: var(--color-primary);
    background: rgba(225, 233, 239, 0.5);
    outline: none;
}

.sidebar__link.is-active {
    margin: 0;
    padding-left: 1.5rem;
    border-right: 4px solid var(--color-primary);
    border-radius: 0;
    background: #e1e9ef;
    color: var(--color-primary);
    box-shadow: none;
}

body.role-theme-admin {
    --sidebar-role-line: #4f378b;
}

body.role-theme-planner {
    --sidebar-role-line: #05c9ff;
}

body.role-theme-requestor {
    --sidebar-role-line: #111111;
}

body.role-theme-fabricator {
    --sidebar-role-line: #355e3b;
}

body.role-theme-logistics {
    --sidebar-role-line: #9a6a05;
}

body.role-theme-receiving {
    --sidebar-role-line: #2e7d32;
}

.app-frame {
    margin-left: var(--sidebar-width);
    transition: margin-left var(--transition);
}

.topbar {
    position: sticky;
    top: 0;
    z-index: 30;
    background: #f8fafc;
}

.topbar__content,
.app-main {
    width: min(calc(100% - 3rem), var(--content-max-width));
    margin: 0 auto;
}

.topbar__content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    padding: 0.75rem 0;
}

.topbar__left,
.topbar__mobile-trigger,
.topbar__right,
.topbar__actions,
.section-nav {
    display: flex;
    align-items: center;
}

.topbar__left,
.topbar__mobile-trigger {
    flex: 1;
}

.topbar__right {
    gap: 1.5rem;
}

.topbar__sidebar-toggle {
    display: inline-flex;
}

.topbar__sidebar-toggle .material-symbols-outlined {
    transition: transform var(--transition);
}

body.sidebar-collapsed .sidebar {
    width: 5.5rem;
}

body.sidebar-collapsed .sidebar__brand {
    padding-left: 0.75rem;
    padding-right: 0.75rem;
}

body.sidebar-collapsed .sidebar__title,
body.sidebar-collapsed .sidebar__subtitle {
    max-width: none;
    opacity: 1;
    overflow: visible;
    white-space: normal;
    color: transparent;
    font-size: 0;
}

body.sidebar-collapsed .sidebar__title::after,
body.sidebar-collapsed .sidebar__subtitle::after {
    display: block;
    color: var(--color-primary);
    text-align: center;
}

body.sidebar-collapsed .sidebar__title::after {
    content: attr(data-short);
    font-size: 0.875rem;
    font-weight: 700;
    letter-spacing: -0.01em;
    line-height: 1.15;
}

body.sidebar-collapsed .sidebar__subtitle::after {
    content: attr(data-short);
    font-size: 0.625rem;
    font-weight: 400;
    letter-spacing: 0.2em;
    text-transform: uppercase;
}

body.sidebar-collapsed .sidebar__link span:last-child {
    max-width: 0;
    opacity: 0;
    overflow: hidden;
    white-space: nowrap;
}

body.sidebar-collapsed .sidebar__link {
    justify-content: center;
    gap: 0;
    padding-left: 0.75rem;
    padding-right: 0.75rem;
}

body.sidebar-collapsed .sidebar__link.is-active {
    padding-left: 0.75rem;
    border-right-width: 3px;
}

body.sidebar-collapsed .app-frame {
    margin-left: 5.5rem;
}

body.sidebar-collapsed .topbar__sidebar-toggle .material-symbols-outlined {
    transform: scaleX(-1);
}

.section-nav {
    gap: 2rem;
}

.section-nav__link {
    padding: 0;
    color: var(--color-nav-text);
    border-bottom: 2px solid transparent;
    font-family: "Manrope", sans-serif;
    font-size: 0.875rem;
    font-weight: 500;
    letter-spacing: -0.01em;
    transition:
        color var(--transition),
        background-color var(--transition),
        border-color var(--transition);
}

.section-nav__link:hover,
.section-nav__link:focus-visible {
    color: var(--color-primary);
    outline: none;
}

.section-nav__link.is-active {
    color: var(--color-primary);
    font-weight: 700;
    border-color: var(--color-primary);
}

.topbar__actions {
    gap: 0.75rem;
}

.icon-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--color-nav-text);
    cursor: pointer;
    transition:
        color var(--transition),
        background-color var(--transition),
        transform var(--transition);
}

.icon-button:hover,
.icon-button:focus-visible {
    background: rgba(226, 232, 240, 0.5);
    outline: none;
}

.icon-button:active {
    transform: scale(0.96);
}

.topbar__menu-button {
    display: none;
}

.user-avatar-wrap {
    position: relative;
    display: inline-flex;
}

.user-avatar {
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    overflow: hidden;
    background: var(--color-primary-strong);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    font-weight: 800;
}

.user-avatar img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.user-avatar__fallback {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    font-size: 0.8rem;
    letter-spacing: 0.02em;
}

.user-avatar-wrap::after {
    content: attr(data-tooltip);
    position: absolute;
    right: 0;
    top: calc(100% + 0.5rem);
    transform: translateY(-0.25rem);
    padding: 0.4rem 0.55rem;
    background: rgba(25, 28, 29, 0.92);
    color: #ffffff;
    border-radius: 0.4rem;
    font-size: 0.75rem;
    font-weight: 600;
    line-height: 1.2;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition), transform var(--transition);
    z-index: 50;
}

.user-avatar-wrap:hover::after,
.user-avatar-wrap:focus-within::after {
    opacity: 1;
    transform: translateY(0);
}

.app-main {
    padding: 1.5rem 0 6rem;
}

.dashboard-header {
    display: flex;
    justify-content: space-between;
    gap: 1.5rem;
    margin-bottom: 2.5rem;
}

.dashboard-header__content {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.dashboard-header__eyebrow,
.metric__label,
.status-card__title {
    margin: 0;
    color: var(--color-secondary);
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.2em;
    text-transform: uppercase;
}

.dashboard-header__title {
    margin: 0;
    color: var(--color-primary);
    font-size: clamp(3rem, 4vw, 3.75rem);
    font-weight: 800;
    letter-spacing: -0.07em;
    line-height: 1;
}

.assembly-receiving__title {
    display: flex;
    align-items: baseline;
    gap: 0.75rem;
}

.assembly-receiving__title-code {
    display: inline-block;
}

.assembly-receiving__title-name {
    display: inline-block;
    font-size: 0.62em;
    font-weight: 700;
    letter-spacing: -0.03em;
}

.dashboard-grid {
    display: grid;
    grid-template-columns: minmax(0, 2fr) minmax(18rem, 1fr);
    gap: 2rem;
    align-items: start;
}

.assembly-selector {
    padding: 0 2rem 2rem;
}

.assembly-selector__panel {
    padding: 2rem;
    background: #ffffff;
    border-radius: 1rem;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.assembly-selector__intro {
    margin-bottom: 1.5rem;
}

.assembly-selector__intro h3 {
    margin: 0 0 0.35rem;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 1.5rem;
    font-weight: 800;
}

.assembly-selector__intro p {
    margin: 0;
    color: var(--color-text-muted);
    line-height: 1.6;
}

.assembly-selector__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
    gap: 1rem;
}

.assembly-selector__card {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 1.25rem;
    background: var(--color-surface-low);
    border: 1px solid rgba(191, 200, 204, 0.55);
    border-radius: 0.85rem;
    color: inherit;
    text-decoration: none;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.assembly-selector__card:hover,
.assembly-selector__card:focus-visible {
    transform: translateY(-1px);
    border-color: rgba(0, 67, 84, 0.2);
    box-shadow: 0 12px 24px rgba(15, 23, 42, 0.08);
    outline: none;
}

.assembly-selector__card.is-active {
    background: rgba(183, 234, 255, 0.18);
    border-color: rgba(0, 67, 84, 0.22);
}

.assembly-selector__card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.assembly-selector__code {
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 1.5rem;
    font-weight: 900;
}

.assembly-selector__badge {
    padding: 0.2rem 0.55rem;
    background: rgba(0, 67, 84, 0.1);
    color: var(--color-primary);
    border-radius: 999px;
    font-size: 0.625rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.assembly-selector__card h4 {
    margin: 0;
    color: var(--color-text);
    font-family: "Manrope", sans-serif;
    font-size: 1.125rem;
    font-weight: 700;
}

.assembly-selector__card p {
    margin: 0;
    color: var(--color-text-muted);
    line-height: 1.5;
}

.assembly-selector__action {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-top: auto;
    color: var(--color-primary);
    font-size: 0.875rem;
    font-weight: 700;
}

.page-assembly .app-main {
    width: 100%;
    min-height: 0;
    padding: 0;
}

.page-assembly .dashboard-header {
    padding: 0 2rem;
}

.assembly-layout {
    display: flex;
    width: 100%;
    min-height: calc(100vh - 14rem);
    background: var(--color-surface-low);
    overflow: hidden;
}

.assembly-pane {
    min-width: 0;
    min-height: 0;
}

.assembly-pane--ribbon {
    width: 22rem;
    flex-shrink: 0;
    background: var(--color-surface-mid);
    border-right: 1px solid rgba(191, 200, 204, 0.18);
}

.assembly-pane--detail {
    flex: 1;
    background: var(--color-surface);
}

.assembly-pane__section {
    height: 100%;
    padding: 1.5rem;
}

.assembly-pane__section--detail {
    padding: 2rem;
}

.assembly-ribbon__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.assembly-ribbon__header h3 {
    margin: 0;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 0.875rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.assembly-ribbon__header span {
    color: var(--color-text-muted);
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.assembly-ribbon__list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    min-height: 0;
    max-height: 100%;
    overflow-y: auto;
}

.assembly-ribbon__empty {
    padding: 1rem;
    color: var(--color-text-muted);
    background: #ffffff;
    border-radius: 0.75rem;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.assembly-ribbon__empty p {
    margin: 0;
    line-height: 1.6;
}

.assembly-ribbon-card {
    width: 100%;
    padding: 1rem;
    border: 1px solid transparent;
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.72);
    text-align: left;
    cursor: pointer;
    transition: border-color var(--transition), box-shadow var(--transition), background-color var(--transition);
}

.assembly-ribbon-card:hover,
.assembly-ribbon-card:focus-visible {
    border-color: rgba(0, 67, 84, 0.2);
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.06);
    outline: none;
}

.assembly-ribbon-card.is-active {
    background: #ffffff;
    border-color: rgba(0, 67, 84, 0.22);
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
}

.assembly-ribbon-card--muted {
    background: rgba(248, 250, 252, 0.85);
}

.assembly-ribbon-card__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
}

.assembly-ribbon-card__label {
    color: var(--color-primary);
    font-size: 0.625rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.assembly-ribbon-card__count {
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.assembly-ribbon-card h4 {
    margin: 0 0 0.25rem;
    color: var(--color-text);
    font-family: "Manrope", sans-serif;
    font-size: 1.1rem;
    font-weight: 800;
}

.assembly-ribbon-card p {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.8125rem;
}

.assembly-detail-empty {
    height: 100%;
    background: #ffffff;
    border-radius: 1rem;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.assembly-detail {
    display: flex;
    flex-direction: column;
    height: 100%;
    gap: 1.5rem;
    padding: 2rem;
    background: #ffffff;
    border-radius: 1rem;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.assembly-detail__header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1.5rem;
}

.assembly-detail__eyebrow {
    margin: 0 0 0.35rem;
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.assembly-detail__header h2 {
    margin: 0;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 2.25rem;
    font-weight: 800;
    letter-spacing: -0.04em;
}

.assembly-detail__summary {
    display: flex;
    gap: 2rem;
}

.assembly-detail__summary span {
    display: block;
    margin-bottom: 0.25rem;
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.assembly-detail__summary strong {
    color: var(--color-primary);
    font-size: 1.125rem;
    font-weight: 800;
}

.assembly-detail__table-shell {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    background: var(--color-surface-low);
    border-radius: 0.85rem;
}

.assembly-detail__table {
    width: 100%;
    border-collapse: collapse;
    text-align: left;
}

.assembly-detail__table thead tr {
    background: rgba(231, 232, 233, 0.5);
}

.assembly-detail__table th {
    padding: 1rem 1.5rem;
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.assembly-detail__table tbody td {
    padding: 1rem 1.5rem;
    border-top: 1px solid rgba(191, 200, 204, 0.32);
}

.assembly-detail__table tbody td:first-child {
    color: var(--color-primary);
    font-weight: 700;
}

.assembly-detail__qty-input {
    width: 100%;
    padding: 0.5rem 0.75rem;
    border: 1px solid rgba(191, 200, 204, 0.55);
    border-radius: 0.5rem;
    background: #ffffff;
    font: inherit;
    outline: none;
}

.assembly-detail__qty-input:focus {
    border-color: rgba(0, 67, 84, 0.35);
    box-shadow: 0 0 0 2px rgba(0, 67, 84, 0.12);
}

.assembly-detail__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.assembly-detail__footer p {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.875rem;
    font-weight: 600;
}

.dashboard-main {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.dashboard-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.dashboard-section-title {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    margin: 0;
    color: var(--color-text);
    font-size: 1.25rem;
    font-weight: 700;
}

.dashboard-section-title .material-symbols-outlined {
    color: var(--color-primary);
}

.filter-chip {
    padding: 0.25rem 0.75rem;
    border: 1px solid transparent;
    border-radius: 999px;
    background: var(--color-surface-high);
    color: var(--color-text-muted);
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: -0.01em;
    text-transform: uppercase;
    cursor: pointer;
    transition:
        background-color var(--transition),
        color var(--transition),
        border-color var(--transition);
}

.filter-chip:hover,
.filter-chip:focus-visible {
    background: var(--color-surface);
    color: var(--color-text);
    outline: none;
}

.receipt-list,
.progress-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.receipt-card {
    position: relative;
    overflow: hidden;
    background: #ffffff;
    border-radius: 0.75rem;
    transition:
        background-color var(--transition),
        box-shadow var(--transition),
        outline-color var(--transition);
}

.receipt-card:hover,
.receipt-card:focus-within {
    background: var(--color-surface);
    box-shadow: inset 0 0 0 1px rgba(0, 67, 84, 0.1);
}

.receipt-card__accent {
    position: absolute;
    inset: 0 auto 0 0;
    width: 0.25rem;
    background: var(--color-primary);
    transition: width var(--transition);
}

.receipt-card--muted .receipt-card__accent {
    background: #94a3b8;
}

.receipt-card:hover .receipt-card__accent,
.receipt-card:focus-within .receipt-card__accent {
    width: 0.55rem;
}

.receipt-card__content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
    padding: 1.5rem;
}

.assembly-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 4rem 2rem;
    background: rgba(255, 255, 255, 0.6);
    border: 1px dashed rgba(191, 200, 204, 0.9);
    border-radius: 1rem;
    text-align: center;
}

.assembly-empty-state__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 4rem;
    height: 4rem;
    margin-bottom: 1rem;
    background: var(--color-surface-low);
    border-radius: 999px;
}

.assembly-empty-state__icon .material-symbols-outlined {
    color: var(--color-text-muted);
    font-size: 2rem;
}

.assembly-empty-state h3 {
    margin: 0 0 0.5rem;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 1.4rem;
    font-weight: 800;
}

.assembly-empty-state p {
    max-width: 24rem;
    margin: 0;
    color: var(--color-text-muted);
    line-height: 1.6;
}

.receipt-card__metrics {
    flex: 1;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 2rem;
    align-items: center;
}

.metric {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    min-width: 0;
}

.metric__label {
    color: var(--color-text-muted);
    display: block;
    margin-bottom: 0.25rem;
    font-size: 0.65rem;
}

.metric__value {
    font-size: 1.125rem;
    font-weight: 700;
    line-height: 1.15;
    word-break: break-word;
}

.metric__value--quantity {
    color: var(--color-primary);
    font-size: 1.5rem;
    font-weight: 900;
}

.metric__value--quantity span {
    color: var(--color-secondary);
    font-family: "Inter", sans-serif;
    font-size: 0.75rem;
    font-weight: 400;
}

.metric__detail {
    color: var(--color-secondary);
    display: block;
    margin-top: 0.125rem;
    font-size: 0.75rem;
}

.bin-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.25rem 1rem;
    border-radius: var(--radius-lg);
    background: var(--color-secondary-soft);
    color: var(--color-secondary-text);
    font-family: "Manrope", sans-serif;
    font-size: 1.125rem;
    font-weight: 800;
}

.action-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.75rem 1.25rem;
    border: 0;
    border-radius: 0.375rem;
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-strong));
    color: #fff;
    font-size: 0.875rem;
    font-weight: 800;
    white-space: nowrap;
    cursor: pointer;
    box-shadow: 0 10px 20px rgba(0, 67, 84, 0.1);
    transition:
        transform var(--transition),
        box-shadow var(--transition),
        opacity var(--transition);
}

.action-button .material-symbols-outlined {
    font-variation-settings: "FILL" 1, "wght" 500, "GRAD" 0, "opsz" 24;
}

.action-button:hover,
.action-button:focus-visible {
    opacity: 0.94;
    box-shadow: 0 14px 28px rgba(0, 67, 84, 0.12);
    outline: none;
}

.action-button:active {
    transform: scale(0.98);
}

.planning-page {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.page-inventory .app-main {
    width: 100%;
    padding: 2rem;
}

.inventory-page {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.inventory-page__header {
    display: flex;
    align-items: flex-end;
    gap: 1.5rem;
}

.inventory-page__eyebrow {
    margin: 0 0 0.35rem;
    color: var(--color-text-muted);
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.inventory-page__header h2 {
    margin: 0;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 2.75rem;
    font-weight: 800;
    letter-spacing: -0.05em;
}

.inventory-page__subtitle {
    max-width: 42rem;
    margin: 0.5rem 0 0;
    color: var(--color-text-muted);
    line-height: 1.6;
}

/* Pipeline flow */
.pipeline-container {
    display: flex;
    flex-direction: column;
}

.pipeline-flow {
    display: flex;
    align-items: stretch;
    background: #ffffff;
    border: 1px solid rgba(191, 200, 204, 0.55);
    border-radius: 1rem;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
    overflow: hidden;
}

.pipeline-flow--has-chips {
    border-radius: 1rem 1rem 0 0;
    border-bottom-color: transparent;
}

.pipeline-stage {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.2rem;
    padding: 1.35rem 1.5rem;
    border: none;
    background: transparent;
    text-align: left;
    cursor: pointer;
    position: relative;
    transition: background var(--transition);
}

.pipeline-stage:hover,
.pipeline-stage:focus-visible {
    background: rgba(0, 67, 84, 0.035);
    outline: none;
}

.pipeline-stage.is-active {
    background: rgba(183, 234, 255, 0.22);
}

.pipeline-stage.is-active::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--color-primary);
    border-radius: 3px 3px 0 0;
}

.pipeline-stage__icon {
    font-size: 1.375rem;
    color: var(--color-border);
    margin-bottom: 0.5rem;
    transition: color var(--transition);
}

.pipeline-stage.is-active .pipeline-stage__icon {
    color: var(--color-primary);
}

.pipeline-stage__label {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.13em;
    text-transform: uppercase;
}

.pipeline-stage.is-active .pipeline-stage__label {
    color: var(--color-primary);
}

.pipeline-stage__qty {
    color: var(--color-text);
    font-family: "Manrope", sans-serif;
    font-size: 2.25rem;
    font-weight: 800;
    letter-spacing: -0.04em;
    line-height: 1.05;
}

.pipeline-stage.is-active .pipeline-stage__qty {
    color: var(--color-primary);
}

.pipeline-stage__meta {
    color: var(--color-text-muted);
    font-size: 0.8rem;
}

.pipeline-arrow {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    padding: 0 0.125rem;
    color: rgba(191, 200, 204, 0.9);
    pointer-events: none;
}

.pipeline-arrow .material-symbols-outlined {
    font-size: 1.25rem;
}

/* Receiving point chips */
.pipeline-receiving-points {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.625rem;
    padding: 0.75rem 1.5rem;
    border: 1px solid rgba(191, 200, 204, 0.55);
    border-top: 1px solid rgba(0, 67, 84, 0.1);
    border-radius: 0 0 1rem 1rem;
    background: rgba(183, 234, 255, 0.1);
}

.pipeline-receiving-points__label {
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    white-space: nowrap;
    margin-right: 0.25rem;
}

.pipeline-receiving-points__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.receiving-point-chip {
    padding: 0.3rem 0.875rem;
    border: 1px solid rgba(191, 200, 204, 0.7);
    border-radius: 100px;
    background: #ffffff;
    color: var(--color-text-muted);
    font-size: 0.8125rem;
    font-weight: 600;
    cursor: pointer;
    transition: border-color var(--transition), background var(--transition), color var(--transition);
}

.receiving-point-chip:hover,
.receiving-point-chip:focus-visible {
    border-color: var(--color-primary);
    color: var(--color-primary);
    outline: none;
}

.receiving-point-chip.is-active {
    border-color: var(--color-primary);
    background: var(--color-primary);
    color: #ffffff;
}

.inventory-page__load-region {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    padding: 0.5rem 0 1.5rem;
}

.inventory-page__status {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.875rem;
    line-height: 1.5;
    text-align: center;
}

.inventory-page__load-sentinel {
    width: 100%;
    height: 1px;
}

.inventory-table-shell {
    background: #ffffff;
    border-radius: 1rem;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
    overflow: visible;
    position: relative;
}

.inventory-table__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.25rem 1.5rem 1rem;
    border-bottom: 1px solid rgba(191, 200, 204, 0.32);
}

.inventory-table__header-text h3 {
    margin: 0 0 0.25rem;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 1.25rem;
    font-weight: 800;
}

.inventory-table__header-text p {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.875rem;
    line-height: 1.5;
}

.inventory-table__count {
    flex-shrink: 0;
    padding: 0.3rem 0.75rem;
    border-radius: 100px;
    background: var(--color-surface-high);
    color: var(--color-text-muted);
    font-size: 0.8125rem;
    font-weight: 700;
}

.inventory-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    text-align: left;
}

.inventory-table thead tr {
    background: rgba(231, 232, 233, 0.5);
}

.inventory-table th {
    padding: 1rem 1.5rem;
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.inventory-table tbody td {
    padding: 1rem 1.5rem;
    border-top: 1px solid rgba(191, 200, 204, 0.32);
}

.inventory-table tbody tr:last-child td:first-child { border-radius: 0 0 0 1rem; }
.inventory-table tbody tr:last-child td:last-child { border-radius: 0 0 1rem 0; }

.inventory-table__part-cell {
    white-space: nowrap;
}

.inventory-part-number {
    color: var(--color-primary);
    font-weight: 700;
}

.inventory-part-rev {
    margin-left: 0.5rem;
    padding: 0.1rem 0.4rem;
    border-radius: 0.25rem;
    background: var(--color-surface-high);
    color: var(--color-text-muted);
    font-size: 0.75rem;
    font-weight: 600;
}

.inventory-table__qty-cell {
    white-space: nowrap;
}

.inventory-table__dest-cell {
    color: var(--color-text-muted);
    font-size: 0.875rem;
    white-space: nowrap;
}

.inventory-qty-badge {
    display: inline-block;
    min-width: 2rem;
    padding: 0.2rem 0.5rem;
    border-radius: 0.35rem;
    background: rgba(0, 67, 84, 0.07);
    color: var(--color-primary);
    font-size: 0.9375rem;
    font-weight: 700;
    text-align: center;
}

.inventory-qty-badge--zero {
    background: rgba(220, 38, 38, 0.08);
    color: #b91c1c;
}

.inventory-unit-label {
    margin-left: 0.4rem;
    color: var(--color-text-muted);
    font-size: 0.8125rem;
}

.inventory-table__actions-head {
    width: 10rem;
    text-align: center;
}

.inventory-table__actions {
    text-align: center;
}

.inventory-table__button {
    padding: 0.5rem 0.85rem;
    border: 1px solid rgba(191, 200, 204, 0.72);
    border-radius: 0.45rem;
    background: #ffffff;
    color: var(--color-text);
    font-size: 0.8125rem;
    font-weight: 700;
    cursor: pointer;
}

.inventory-table__button--primary {
    border-color: transparent;
    background: var(--color-primary);
    color: #ffffff;
}

inventory-record-action-menu {
    display: inline-flex;
    position: relative;
}

.inventory-table__empty {
    padding: 2rem 1.5rem;
    color: var(--color-text-muted);
    border-radius: 0 0 1rem 1rem;
}

/* Inventory history link */
.inventory-history-link {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin-left: auto;
    padding: 0.5rem 1rem;
    border: 1px solid rgba(191, 200, 204, 0.7);
    border-radius: 0.5rem;
    background: #ffffff;
    color: var(--color-text-muted);
    font-size: 0.875rem;
    font-weight: 600;
    white-space: nowrap;
    transition: border-color var(--transition), color var(--transition);
}

.inventory-history-link:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
}

.inventory-history-link .material-symbols-outlined {
    font-size: 1.125rem;
}

@media (max-width: 767px) {
    .page-inventory .app-main {
        padding: 1rem;
        overflow-x: hidden;
    }

    .inventory-page {
        gap: 1rem;
    }

    .inventory-page__header {
        flex-direction: column;
        align-items: stretch;
        gap: 0.9rem;
    }

    .inventory-page__header h2 {
        font-size: 2rem;
    }

    .inventory-page__subtitle {
        max-width: none;
        font-size: 0.95rem;
    }

    .inventory-history-link {
        width: 100%;
        justify-content: center;
        margin-left: 0;
    }

    .pipeline-flow {
        flex-direction: column;
    }

    .pipeline-flow--has-chips {
        border-radius: 1rem 1rem 0 0;
    }

    .pipeline-stage {
        width: 100%;
        padding: 1rem 1.1rem;
    }

    .pipeline-stage__qty {
        font-size: 1.75rem;
    }

    .pipeline-arrow {
        justify-content: center;
        padding: 0.15rem 0;
    }

    .pipeline-arrow .material-symbols-outlined {
        transform: rotate(90deg);
    }

    .pipeline-receiving-points {
        padding: 0.85rem 1rem;
    }

    .pipeline-receiving-points__chips {
        width: 100%;
    }

    .receiving-point-chip {
        flex: 1 1 100%;
        text-align: center;
    }

    .inventory-table-shell {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .inventory-table__header {
        flex-direction: column;
        align-items: flex-start;
        padding: 1rem;
    }

    .inventory-table__count {
        align-self: stretch;
        text-align: center;
    }

    .inventory-table {
        min-width: 44rem;
    }

    .inventory-table th,
    .inventory-table tbody td {
        padding: 0.85rem 1rem;
    }

    .inventory-table__empty {
        padding: 1.25rem 1rem;
    }
}

/* Transfer modal extras */
.modal__static-value {
    padding: 0.625rem 0.75rem;
    border: 1px solid rgba(191, 200, 204, 0.5);
    border-radius: 0.5rem;
    background: var(--color-surface-low);
    color: var(--color-text);
    font-size: 0.9375rem;
}

.modal__select-input {
    width: 100%;
    min-height: 2.75rem;
    padding: 0.625rem 2.5rem 0.625rem 0.75rem;
    border: 1px solid #bfc8cc;
    border-radius: 0.5rem;
    background-color: #ffffff;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%2364758b' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M1 1.25 6 6.25l5-5'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    background-size: 0.875rem auto;
    color: var(--color-text);
    font: inherit;
    outline: none;
    -webkit-appearance: none;
    appearance: none;
}

.modal__select-input:focus {
    border-color: var(--color-primary);
    outline: 2px solid rgba(0, 67, 84, 0.15);
    outline-offset: 0;
}

.modal__textarea-input {
    width: 100%;
    padding: 0.625rem 0.75rem;
    border: 1px solid #bfc8cc;
    border-radius: 0.5rem;
    background: #ffffff;
    color: var(--color-text);
    font: inherit;
    font-size: 0.9375rem;
    line-height: 1.5;
    resize: vertical;
    outline: none;
}

.modal__textarea-input:focus {
    border-color: var(--color-primary);
    outline: 2px solid rgba(0, 67, 84, 0.15);
    outline-offset: 0;
}

.modal__field-optional {
    color: var(--color-text-muted);
    font-size: 0.8125rem;
    font-weight: 400;
}

/* Transaction history page */
.page-inventory-transactions .app-main {
    width: 100%;
    padding: 2rem;
}

.txn-page {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.txn-page__back {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    margin-bottom: 0.75rem;
    color: var(--color-text-muted);
    font-size: 0.875rem;
    font-weight: 600;
    transition: color var(--transition);
}

.txn-page__back:hover {
    color: var(--color-primary);
}

.txn-page__back .material-symbols-outlined {
    font-size: 1rem;
}

.txn-page__eyebrow {
    margin: 0 0 0.35rem;
    color: var(--color-text-muted);
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.txn-page__header h2 {
    margin: 0;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 2.75rem;
    font-weight: 800;
    letter-spacing: -0.05em;
}

.txn-page__subtitle {
    max-width: 42rem;
    margin: 0.5rem 0 0;
    color: var(--color-text-muted);
    line-height: 1.6;
}

.txn-filters {
    display: flex;
    align-items: flex-end;
    gap: 1rem;
    flex-wrap: wrap;
}

.txn-filter-group {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.txn-filter-label {
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.txn-filter-input,
.txn-filter-select {
    min-height: 2.5rem;
    padding: 0.5rem 0.875rem;
    border: 1px solid #bfc8cc;
    border-radius: 0.5rem;
    background: #ffffff;
    color: var(--color-text);
    font: inherit;
    font-size: 0.9375rem;
    outline: none;
    min-width: 14rem;
}

.txn-filter-select {
    padding-right: 2.5rem;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%2364758b' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M1 1.25 6 6.25l5-5'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    background-size: 0.875rem auto;
    -webkit-appearance: none;
    appearance: none;
}

.txn-filter-input:focus,
.txn-filter-select:focus {
    border-color: var(--color-primary);
    outline: 2px solid rgba(0, 67, 84, 0.12);
    outline-offset: 0;
}

.txn-filter-clear {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.5rem 0.875rem;
    border: 1px solid rgba(191, 200, 204, 0.7);
    border-radius: 0.5rem;
    background: transparent;
    color: var(--color-text-muted);
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition);
}

.txn-filter-clear:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
}

.txn-filter-clear .material-symbols-outlined {
    font-size: 1rem;
}

.txn-table-shell {
    background: #ffffff;
    border-radius: 1rem;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
}

.txn-table {
    width: 100%;
    min-width: 78rem;
    border-collapse: collapse;
    text-align: left;
}

.txn-table thead tr {
    background: rgba(231, 232, 233, 0.5);
}

.txn-table th {
    padding: 0.875rem 1.25rem;
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    white-space: nowrap;
}

.txn-table tbody td {
    padding: 0.875rem 1.25rem;
    border-top: 1px solid rgba(191, 200, 204, 0.28);
    vertical-align: middle;
}

.txn-table__part-cell {
    white-space: nowrap;
}

.txn-part-number {
    color: var(--color-primary);
    font-weight: 700;
}

.txn-part-rev {
    margin-left: 0.4rem;
    padding: 0.1rem 0.35rem;
    border-radius: 0.25rem;
    background: var(--color-surface-high);
    color: var(--color-text-muted);
    font-size: 0.75rem;
    font-weight: 600;
}

.txn-table__desc-cell {
    max-width: 18rem;
    color: var(--color-text-muted);
    font-size: 0.875rem;
}

.txn-type-badge {
    display: inline-block;
    padding: 0.2rem 0.6rem;
    border-radius: 100px;
    font-size: 0.75rem;
    font-weight: 700;
    white-space: nowrap;
}

.txn-type-badge--in {
    background: rgba(21, 128, 61, 0.1);
    color: #15803d;
}

.txn-type-badge--out {
    background: rgba(185, 28, 28, 0.08);
    color: #b91c1c;
}

.txn-type-badge--transfer {
    background: rgba(0, 67, 84, 0.08);
    color: var(--color-primary);
}

.txn-location {
    display: inline-flex;
    flex-direction: column;
    gap: 0.1rem;
    font-size: 0.875rem;
}

.txn-location strong {
    color: var(--color-text);
    font-weight: 700;
}

.txn-location span {
    color: var(--color-text-muted);
    font-size: 0.8rem;
}

.txn-location--none {
    color: var(--color-text-muted);
}

.txn-table__qty-cell {
    white-space: nowrap;
}

.txn-qty {
    font-weight: 700;
    color: var(--color-text);
}

.txn-unit {
    margin-left: 0.3rem;
    color: var(--color-text-muted);
    font-size: 0.8125rem;
}

.txn-table__actor-cell {
    color: var(--color-text-muted);
    font-size: 0.875rem;
    white-space: nowrap;
}

.txn-table__date-cell {
    color: var(--color-text-muted);
    font-size: 0.8125rem;
    white-space: nowrap;
}

.txn-table__notes-cell {
    max-width: 14rem;
    color: var(--color-text-muted);
    font-size: 0.875rem;
}

.txn-table__empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    padding: 4rem 2rem;
    color: var(--color-text-muted);
    text-align: center;
}

.txn-table__empty[hidden] {
    display: none;
}

.txn-table__empty .material-symbols-outlined {
    font-size: 2.5rem;
    opacity: 0.4;
}

.txn-table__empty p {
    margin: 0;
    font-size: 1rem;
}

.txn-load-region {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0 1.5rem;
}

.txn-status {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.875rem;
    text-align: center;
}

.page-parts .app-main {
    width: 100%;
    padding: 2rem;
}

.parts-page {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.parts-page__load-region {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    padding: 0.5rem 0 1.5rem;
}

.parts-page__status {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.875rem;
    line-height: 1.5;
    text-align: center;
}

.parts-page__load-sentinel {
    width: 100%;
    height: 1px;
}

.parts-page__header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1.5rem;
}

.parts-page__controls {
    display: flex;
    align-items: flex-end;
    gap: 1rem;
}

.parts-page__eyebrow {
    margin: 0 0 0.35rem;
    color: var(--color-text-muted);
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.parts-page__header h2 {
    margin: 0;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 2.75rem;
    font-weight: 800;
    letter-spacing: -0.05em;
}

.parts-page__subtitle {
    max-width: 42rem;
    margin: 0.5rem 0 0;
    color: var(--color-text-muted);
    line-height: 1.6;
}

.parts-page__filter {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    min-width: 12rem;
}

.parts-page__filter span {
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.parts-page__filter select {
    min-height: 2.75rem;
    padding: 0.75rem 2.75rem 0.75rem 1rem;
    border: 1px solid #bfc8cc;
    border-radius: 0.5rem;
    background-color: #ffffff;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%2364758b' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M1 1.25 6 6.25l5-5'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 0.875rem auto;
    color: var(--color-text);
    font: inherit;
    outline: none;
    -webkit-appearance: none;
    appearance: none;
}

.parts-catalog-table__shell {
    background: #ffffff;
    border-radius: 1rem;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
    overflow-x: auto;
    overflow-y: hidden;
}

.parts-catalog-table {
    width: 100%;
    border-collapse: collapse;
    text-align: left;
}

.parts-catalog-table thead tr {
    background: rgba(231, 232, 233, 0.5);
}

.parts-catalog-table th {
    padding: 1rem 1.5rem;
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.parts-catalog-table tbody td {
    padding: 1rem 1.5rem;
    border-top: 1px solid rgba(191, 200, 204, 0.32);
    vertical-align: middle;
}

.parts-catalog-table__row--editable {
    cursor: pointer;
    transition: background-color var(--transition);
}

.parts-catalog-table__row--editable:hover {
    background: rgba(0, 67, 84, 0.03);
}

.parts-catalog-table tbody td:first-child {
    color: var(--color-primary);
    font-weight: 700;
    white-space: nowrap;
    word-break: keep-all;
    min-width: 10rem;
}

.parts-catalog-table__actions-head,
.parts-catalog-table__actions-cell {
    position: sticky;
    right: 0;
    text-align: center;
    width: 5.5rem;
    min-width: 5.5rem;
    background: #ffffff;
    z-index: 1;
}

.parts-catalog-table__actions-head {
    background: rgba(231, 232, 233, 0.96);
    z-index: 2;
}

.parts-catalog-table__actions-cell--open {
    z-index: 30;
}

.parts-catalog-table__thumb {
    width: 3rem;
    height: 3rem;
    overflow: hidden;
    border-radius: 0.6rem;
    background: var(--color-surface-low);
}

.parts-catalog-table__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.parts-catalog-table__thumb--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(63, 72, 76, 0.45);
}

.parts-catalog-table__link {
    color: var(--color-primary);
    font-weight: 700;
    text-decoration: none;
}

.parts-catalog-table__link--muted {
    color: var(--color-text-muted);
}

parts-record-action-menu {
    display: inline-flex;
    position: relative;
}

.parts-catalog-table__empty {
    padding: 2rem 1.5rem;
    background: #ffffff;
    border-radius: 1rem;
    color: var(--color-text-muted);
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.parts-modal__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.parts-modal__helper {
    margin: 0 0 1rem;
    color: var(--color-text-muted);
    font-size: 0.875rem;
    line-height: 1.5;
}

.parts-modal__helper span {
    color: #b42318;
    font-weight: 800;
}

.parts-modal__feedback {
    margin: 0 0 1rem;
    padding: 0.875rem 1rem;
    border: 1px solid rgba(180, 35, 24, 0.24);
    border-radius: 0.75rem;
    background: rgba(254, 243, 242, 0.95);
    color: #912018;
    font-size: 0.9375rem;
    line-height: 1.5;
}

.parts-modal__feedback--success {
    border-color: rgba(2, 122, 72, 0.18);
    background: rgba(236, 253, 243, 0.98);
    color: #05603a;
}

.parts-modal__field {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.parts-modal__field--wide {
    grid-column: 1 / -1;
}

.parts-modal__field span {
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.parts-modal__field strong {
    color: #b42318;
    font-weight: 800;
}

.parts-modal__field input,
.parts-modal__textarea,
.parts-modal__field select {
    min-height: 2.75rem;
    padding: 0.75rem 2.75rem 0.75rem 1rem;
    border: 1px solid #bfc8cc;
    border-radius: 0.5rem;
    background-color: #ffffff;
    color: var(--color-text);
    font: inherit;
    outline: none;
}

.parts-modal__textarea {
    min-height: 14rem;
    padding: 0.9rem 1rem;
    resize: vertical;
    line-height: 1.5;
    white-space: pre;
}

.parts-modal__field select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%2364758b' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M1 1.25 6 6.25l5-5'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 0.875rem auto;
    -webkit-appearance: none;
    appearance: none;
}

.parts-modal__field.is-invalid span {
    color: #912018;
}

.parts-modal__field.is-invalid input,
.parts-modal__field.is-invalid .parts-modal__textarea,
.parts-modal__field.is-invalid select {
    border-color: #d92d20;
    box-shadow: 0 0 0 3px rgba(217, 45, 32, 0.12);
}

.part-search-dropdown {
    z-index: 9999;
    background: #ffffff;
    border: 1px solid #bfc8cc;
    border-radius: 0.625rem;
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.14), 0 2px 8px rgba(0, 0, 0, 0.08);
    list-style: none;
    margin: 0;
    padding: 0.3rem 0;
    max-height: 18rem;
    overflow-y: auto;
}

.part-search-dropdown__item {
    padding: 0.55rem 1rem;
    cursor: pointer;
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    column-gap: 0.75rem;
    row-gap: 0.1rem;
}

.part-search-dropdown__item:hover,
.part-search-dropdown__item.is-active {
    background: rgba(var(--color-primary-rgb, 30, 100, 210), 0.07);
}

.part-search-dropdown__number {
    font-weight: 700;
    font-size: 0.875rem;
    color: var(--color-text);
    grid-column: 1;
    grid-row: 1;
}

.part-search-dropdown__rev {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--color-text-muted);
    grid-column: 2;
    grid-row: 1;
    align-self: center;
    white-space: nowrap;
}

.part-search-dropdown__desc {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    grid-column: 1 / -1;
    grid-row: 2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.parts-batch-modal__panel {
    width: min(100%, 58rem);
    max-height: min(82vh, 48rem);
    display: flex;
    flex-direction: column;
}

.parts-batch-modal__body {
    flex: 1;
    min-height: 0;
    overflow: auto;
    padding: 1rem 1.25rem;
}

.parts-batch-modal__layout {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.parts-batch-modal__column {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
    min-width: 0;
}

.parts-batch-modal__column--review {
    position: static;
}

.parts-batch-modal__textarea {
    min-height: 8.5rem;
}

.parts-batch-modal__footer {
    border-top: 1px solid rgba(226, 232, 240, 0.9);
    background: rgba(248, 250, 252, 0.98);
}

.parts-batch-modal__body.is-progress-only {
    padding-top: 1.25rem;
}

.parts-batch-modal__body.is-progress-only .parts-batch-modal__column--input,
.parts-batch-modal__body.is-progress-only .parts-batch__summary {
    display: none;
}

.parts-batch-modal__body.is-progress-only .parts-batch-modal__column--review {
    gap: 0;
}

.parts-batch-modal__body.is-progress-only .parts-batch__progress {
    margin: 0;
}

.parts-batch__summary {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    margin: 0;
}

.parts-batch__summary-card {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    padding: 1rem 1.1rem;
    border: 1px solid rgba(191, 200, 204, 0.6);
    border-radius: 0.85rem;
    background: rgba(247, 249, 250, 0.9);
}

.parts-batch__summary-label {
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.parts-batch__summary-card strong {
    color: var(--color-primary);
    font-size: 1rem;
    line-height: 1.4;
}

.parts-batch__progress {
    margin: 0;
    padding: 1rem 1.1rem;
    border: 1px solid rgba(191, 200, 204, 0.6);
    border-radius: 0.85rem;
    background: #ffffff;
}

.parts-batch__progress-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.75rem;
}

.parts-batch__progress-header strong {
    color: var(--color-primary);
    font-size: 0.95rem;
}

.parts-batch__progress-count,
#parts-batch-progress-count {
    color: var(--color-text-muted);
    font-size: 0.875rem;
    font-weight: 700;
}

.parts-batch__progress-bar {
    width: 100%;
    height: 0.65rem;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(191, 200, 204, 0.45);
}

.parts-batch__progress-fill {
    width: 0%;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #004354 0%, #0f766e 100%);
    transition: width 180ms ease;
}

.parts-batch__progress-note {
    margin: 0.75rem 0 0;
    color: var(--color-text-muted);
    font-size: 0.875rem;
    line-height: 1.5;
}

.parts-batch__progress-log {
    display: grid;
    gap: 0.5rem;
    margin-top: 0.9rem;
}

.parts-batch__progress-log-item {
    padding: 0.65rem 0.75rem;
    border-radius: 0.7rem;
    font-size: 0.875rem;
    line-height: 1.5;
}

.parts-batch__progress-log-item--success {
    background: rgba(236, 253, 243, 0.98);
    color: #05603a;
}

.parts-batch__progress-log-item--error {
    background: rgba(254, 243, 242, 0.98);
    color: #912018;
}

.page-planning .app-main {
    width: 100%;
    padding: 2rem;
}

.planning-hero {
    padding: 0;
}

.planning-hero__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.planning-upload-card,
.planning-action-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 15rem;
    padding: 2rem 1.5rem;
    text-align: center;
    border-radius: 0.75rem;
}

.planning-upload-card {
    background: rgba(0, 67, 84, 0.05);
    border: 2px dashed rgba(0, 67, 84, 0.2);
}

.planning-action-card {
    background: #ffffff;
    border: 1px solid rgba(191, 200, 204, 0.9);
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.planning-upload-card__icon,
.planning-action-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    margin-bottom: 1rem;
    background: rgba(0, 67, 84, 0.1);
    color: var(--color-primary);
    border-radius: 999px;
}

.planning-upload-card__icon .material-symbols-outlined,
.planning-action-card__icon .material-symbols-outlined {
    font-size: 1.875rem;
    font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24;
}

.planning-upload-card__title,
.planning-action-card__title {
    margin: 0 0 0.25rem;
    color: var(--color-text);
    font-family: "Manrope", sans-serif;
    font-size: 1.125rem;
    font-weight: 700;
}

.planning-upload-card__description,
.planning-action-card__description {
    margin: 0 0 1rem;
    color: var(--color-text-muted);
    font-size: 0.875rem;
    line-height: 1.6;
}

.planning-upload-input {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.planning-upload-card__button,
.planning-action-card__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.625rem 2rem;
    border: 0;
    border-radius: 0.375rem;
    background: var(--color-primary);
    color: #ffffff;
    font-size: 0.875rem;
    font-weight: 600;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
    cursor: pointer;
}

.planning-action-card__button {
    border: 0;
}

.planning-filters {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    background: #ffffff;
    border-radius: 0.75rem;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.planning-filters__fields {
    display: flex;
    flex: 1;
    gap: 1rem;
    min-width: 18.75rem;
}

.planning-field {
    position: relative;
    flex: 1;
}

.planning-field label {
    position: absolute;
    top: -0.5rem;
    left: 0.75rem;
    padding: 0 0.25rem;
    background: #ffffff;
    color: var(--color-primary);
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
}

.planning-field input {
    width: 100%;
    padding: 0.75rem;
    border: 0;
    border-radius: 0.25rem;
    background: var(--color-surface-low);
    color: var(--color-text);
    font-size: 0.875rem;
    outline: none;
    box-shadow: inset 0 0 0 2px transparent;
}

.planning-field input:focus {
    box-shadow: inset 0 0 0 2px rgba(0, 67, 84, 0.2);
}

.planning-filters__button {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.5rem;
    border: 0;
    border-radius: 0.25rem;
    background: var(--color-surface-high);
    color: var(--color-text-muted);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    cursor: pointer;
}

.planning-table-shell {
    overflow: visible;
    background: #ffffff;
    border-radius: 0.75rem;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.planning-table-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem 2rem;
    text-align: center;
}

.planning-table-empty__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 4rem;
    height: 4rem;
    margin-bottom: 1rem;
    background: var(--color-surface-low);
    border-radius: 999px;
}

.planning-table-empty__icon .material-symbols-outlined {
    color: var(--color-text-muted);
    font-size: 2rem;
}

.planning-table-empty h3 {
    margin: 0 0 0.5rem;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 1.35rem;
    font-weight: 800;
}

.planning-table-empty p {
    max-width: 28rem;
    margin: 0;
    color: var(--color-text-muted);
    line-height: 1.6;
}

.planning-request-modal__panel {
    width: min(100%, 92rem);
    max-height: min(88vh, 56rem);
    display: flex;
    flex-direction: column;
}

.planning-request-modal__body {
    flex: 1;
    min-height: 0;
    overflow: auto;
}

.planning-request-modal__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.planning-request-modal__notes {
    min-height: 7rem;
    white-space: normal;
}

.planning-request-lines {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.planning-request-lines__header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
}

.planning-request-lines__header h4 {
    margin: 0;
    color: var(--color-primary);
    font-size: 1rem;
    font-weight: 800;
}

.planning-request-lines__header p {
    margin: 0.25rem 0 0;
    color: var(--color-text-muted);
    font-size: 0.875rem;
    line-height: 1.5;
}

.planning-request-lines__add {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.7rem 1rem;
    border: 1px solid rgba(191, 200, 204, 0.8);
    border-radius: 0.55rem;
    background: #ffffff;
    color: var(--color-primary);
    font-size: 0.875rem;
    font-weight: 700;
    cursor: pointer;
}

.planning-request-lines__list {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

.planning-request-line {
    display: grid;
    grid-template-columns:
        minmax(0, 1.1fr)
        minmax(0, 0.65fr)
        minmax(0, 1.6fr)
        minmax(0, 1.15fr)
        minmax(0, 1fr)
        minmax(0, 0.65fr)
        auto;
    gap: 1rem;
    align-items: end;
    padding: 1rem;
    border: 1px solid rgba(191, 200, 204, 0.65);
    border-radius: 0.85rem;
    background: rgba(247, 249, 250, 0.92);
    overflow: hidden;
}

.planning-request-line .parts-modal__field {
    min-width: 0;
}

.planning-request-line .parts-modal__field input {
    width: 100%;
    box-sizing: border-box;
}

.planning-request-line .parts-modal__field input[readonly] {
    background: rgba(231, 232, 233, 0.45);
    color: var(--color-text-muted);
}

.planning-request-line__lookup {
    grid-column: 1 / -1;
    margin-top: -0.15rem;
    font-size: 0.75rem;
    line-height: 1.4;
}

.planning-request-line__lookup--muted {
    color: var(--color-text-muted);
}

.planning-request-line__lookup--error {
    color: #ba1a1a;
}

.planning-request-line__lookup--success {
    color: #05603a;
}

.planning-request-line__remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    border: 0;
    border-radius: 0.6rem;
    background: rgba(186, 26, 26, 0.08);
    color: #ba1a1a;
    cursor: pointer;
}

.planning-picklist-modal__panel {
    width: min(100%, 96rem);
    max-height: min(90vh, 60rem);
    display: flex;
    flex-direction: column;
}

.planning-picklist-modal__body {
    flex: 1;
    min-height: 0;
    overflow: auto;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.planning-picklist-modal__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.planning-picklist-modal__notes {
    min-height: 6rem;
    white-space: normal;
}

.planning-picklist-modal__textarea {
    min-height: 14rem;
    white-space: pre;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.875rem;
}

.planning-picklist__summary {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.planning-picklist-preview-shell {
    overflow: auto;
    max-height: 22rem;
    border: 1px solid rgba(191, 200, 204, 0.6);
    border-radius: 0.85rem;
    background: #ffffff;
}

.planning-picklist-preview-table {
    width: 100%;
    min-width: 54rem;
    border-collapse: collapse;
    text-align: left;
}

.planning-picklist-preview-table thead tr {
    background: rgba(231, 232, 233, 0.5);
}

.planning-picklist-preview-table th {
    padding: 0.85rem 1rem;
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    white-space: nowrap;
}

.planning-picklist-preview-table td {
    padding: 0.8rem 1rem;
    border-top: 1px solid rgba(191, 200, 204, 0.32);
    font-size: 0.875rem;
    vertical-align: top;
}

.planning-picklist-preview-table__row--ready td:last-child {
    color: #05603a;
    font-weight: 700;
}

.planning-picklist-preview-table__row--missing td:last-child {
    color: #912018;
    font-weight: 700;
}

.planning-picklist-preview-table__empty {
    color: var(--color-text-muted);
    text-align: center;
}

@media (max-width: 980px) {
    .planning-request-modal__grid {
        grid-template-columns: 1fr;
    }

    .planning-picklist-modal__grid,
    .planning-picklist__summary {
        grid-template-columns: 1fr;
    }

    .planning-request-line {
        grid-template-columns: 1fr;
    }
}

.planning-table {
    width: 100%;
    border-collapse: collapse;
    text-align: left;
}

.planning-table thead {
    background: var(--color-surface-low);
    color: var(--color-text-muted);
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
}

.planning-table th,
.planning-table td {
    padding: 1.25rem 1.5rem;
}

.planning-table tbody {
    font-size: 0.875rem;
}

.planning-table__row {
    background: #ffffff;
    cursor: pointer;
    transition: background-color var(--transition);
}

.planning-table__row:hover {
    background: var(--color-surface-low);
}

.planning-table__row--interactive.is-expanded {
    background: var(--color-surface-low);
}

.planning-table tbody tr + tr td {
    border-top: 1px solid var(--color-surface-mid);
}

.planning-table__job {
    color: var(--color-primary);
    font-weight: 700;
}

.planning-table__date {
    font-weight: 600;
}

.planning-table__center {
    text-align: center;
}

.planning-table__right {
    text-align: right;
}

.planning-progress {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.planning-progress span {
    color: var(--color-text-muted);
    font-size: 0.625rem;
    font-weight: 700;
}

.planning-progress__track {
    width: 6rem;
    height: 0.5rem;
    overflow: hidden;
    background: var(--color-surface-high);
    border-radius: 999px;
}

.planning-progress__fill {
    height: 100%;
    background: var(--color-primary);
}

.planning-table__status {
    font-size: 1.25rem;
}

.planning-table__status--complete,
.planning-table__status--done {
    color: var(--color-primary);
    font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24;
}

.planning-table__status--empty {
    color: #cbd5e1;
}

.planning-table__status--pending {
    color: #f59e0b;
}

.planning-table__status--incomplete {
    color: #94a3b8;
}

.planning-watchers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    gap: 0.3rem;
    color: var(--color-primary);
    font-size: 0.75rem;
    font-weight: 700;
    cursor: default;
}

.planning-watchers .material-symbols-outlined {
    font-size: 1.15rem;
}

.planning-watchers__icons {
    display: inline-flex;
    align-items: center;
    gap: 0.1rem;
}

.planning-watchers__overflow {
    font-size: 0.7rem;
    font-weight: 800;
}

.planning-watchers--empty {
    color: #94a3b8;
}

.planning-watchers__popover {
    position: absolute;
    right: 0;
    top: calc(100% + 0.45rem);
    display: none;
    min-width: 13rem;
    max-width: 18rem;
    padding: 0.75rem 0.85rem;
    border-radius: 0.75rem;
    background: rgba(25, 28, 29, 0.96);
    color: #ffffff;
    box-shadow: 0 14px 28px rgba(15, 23, 42, 0.28);
    z-index: 20;
    text-align: left;
}

.planning-watchers:hover .planning-watchers__popover,
.planning-watchers:focus-within .planning-watchers__popover {
    display: block;
}

.planning-watchers__popover-title {
    display: block;
    margin-bottom: 0.45rem;
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.72);
}

.planning-watchers__popover-list {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.planning-watchers__popover-item {
    font-size: 0.8125rem;
    line-height: 1.4;
    white-space: normal;
    word-break: break-word;
}

.planning-table__expand {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: 0.375rem;
    background: transparent;
    color: var(--color-primary);
    cursor: pointer;
}

.planning-table__expand:hover {
    background: rgba(183, 234, 255, 0.6);
}

.planning-table__row--interactive.is-expanded .planning-table__expand .material-symbols-outlined,
.planning-table__expand[aria-expanded="true"] .material-symbols-outlined {
    transform: rotate(180deg);
}

.planning-table__expand .material-symbols-outlined {
    transition: transform var(--transition);
}

.planning-table__action-button .material-symbols-outlined,
.planning-table__action-button[aria-expanded="true"] .material-symbols-outlined,
.planning-table__row--interactive.is-expanded .planning-table__action-button .material-symbols-outlined {
    transform: none;
}

.planning-table__drilldown-row td {
    padding: 0 1.5rem 1rem;
    background: var(--color-surface-low);
    border-top: 0;
}

.planning-drilldown {
    margin: 0;
    padding: 1.5rem;
    background: #ffffff;
    border-left: 4px solid var(--color-primary);
    border-radius: 0.5rem;
    box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.05);
}

.planning-drilldown__title {
    margin: 0 0 1rem;
    color: var(--color-primary);
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
}

.planning-subtable {
    width: 100%;
    margin-top: 0.75rem;
    border-collapse: collapse;
    table-layout: fixed;
    font-size: 0.75rem;
}

.planning-subtable thead th {
    padding: 0.75rem 0.75rem 0.5rem;
    border-bottom: 1px solid var(--color-surface-mid);
    color: var(--color-text-muted);
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.planning-subtable tbody td {
    padding: 0.75rem;
    border-top: 1px solid var(--color-surface-low);
}

.planning-subtable__mono {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-weight: 700;
}

.planning-subtable__input {
    width: 4rem;
    padding: 0.25rem 0.5rem;
    border: 1px solid var(--color-border);
    border-radius: 0.25rem;
    background: var(--color-surface-low);
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 0.625rem;
    outline: none;
}

.planning-subtable__input:focus {
    box-shadow: 0 0 0 1px var(--color-primary);
}

.planning-subtable__status-wrap {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-weight: 700;
}

.planning-subtable__false {
    color: #94a3b8;
    font-size: 0.625rem;
    font-weight: 700;
    text-transform: uppercase;
}

.planning-table__actions-cell {
    position: relative;
}

planning-job-action-menu {
    display: inline-flex;
    position: relative;
}

.planning-job-action-menu--open {
    z-index: 30;
}

.planning-action-menu {
    position: absolute;
    top: 50%;
    right: 2.75rem;
    z-index: 31;
    min-width: 8.75rem;
    padding: 0.25rem;
    background: #ffffff;
    border: 1px solid var(--color-border);
    border-radius: 0.375rem;
    box-shadow:
        0 4px 20px -2px rgba(0, 0, 0, 0.1),
        0 2px 8px -1px rgba(0, 0, 0, 0.06);
    transform: translateY(-50%);
}

.planning-action-menu[hidden] {
    display: none;
}

.planning-action-menu__item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
    padding: 0.5rem 0.75rem;
    border: 0;
    border-radius: 0.25rem;
    background: transparent;
    color: var(--color-text);
    font-size: 0.75rem;
    font-weight: 600;
    text-align: left;
    cursor: pointer;
}

.planning-action-menu__item:hover {
    background: var(--color-surface-low);
}

.planning-action-menu__item--danger {
    color: #ba1a1a;
}

.planning-action-menu__item--danger:hover {
    background: rgba(186, 26, 26, 0.05);
}

.planning-action-menu__divider {
    height: 1px;
    margin: 0.25rem 0;
    background: var(--color-surface-mid);
}

.planning-confirm-modal__panel {
    width: min(100%, 26rem);
    padding: 0;
    background: #ffffff;
}

.planning-confirm-modal__header,
.planning-confirm-modal__body,
.planning-confirm-modal__actions {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

.planning-confirm-modal__header {
    padding-top: 1.25rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--color-surface-mid);
}

.planning-confirm-modal__header h3 {
    margin: 0;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 1.25rem;
    font-weight: 700;
}

.planning-confirm-modal__body {
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.planning-confirm-modal__body p {
    margin: 0;
    color: var(--color-text);
    line-height: 1.6;
}

.planning-confirm-modal__actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    padding-top: 0.75rem;
    padding-bottom: 1.25rem;
}

.planning-confirm-modal__button {
    min-width: 8rem;
    padding: 0.75rem 1rem;
    border-radius: 0.5rem;
    font-size: 0.875rem;
    font-weight: 700;
    cursor: pointer;
}

.planning-confirm-modal__button--secondary {
    border: 1px solid var(--color-border);
    background: #ffffff;
    color: var(--color-text);
}

.planning-confirm-modal__button--danger {
    border: 0;
    background: #ba1a1a;
    color: #ffffff;
}

.planning-toast {
    position: fixed;
    right: 2rem;
    bottom: 2rem;
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.85rem 1rem;
    background: var(--color-primary);
    color: #ffffff;
    border-radius: 0.75rem;
    box-shadow: 0 12px 28px rgba(0, 67, 84, 0.2);
    font-size: 0.875rem;
    font-weight: 700;
    z-index: 110;
}

/* Fabrication toast — replaces planning-toast for fabrication feedback */
.fabrication-toast {
    position: fixed;
    right: 1.5rem;
    bottom: 1.5rem;
    display: flex;
    align-items: flex-start;
    gap: 0.875rem;
    padding: 1rem 1.25rem;
    background: #ffffff;
    border-radius: 1rem;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.04), 0 12px 32px rgba(0, 0, 0, 0.1);
    min-width: 260px;
    max-width: 360px;
    z-index: 200;
    animation: fabrication-toast-in 0.28s cubic-bezier(0.34, 1.4, 0.64, 1) both;
}

.simple-assembly-toast {
    top: 1.5rem;
    bottom: auto;
}

.simple-fabrication-toast {
    left: 1.5rem;
    right: auto;
}

.fabrication-toast--leaving {
    animation: fabrication-toast-out 0.22s ease-in forwards;
}

.fabrication-toast__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 50%;
    flex-shrink: 0;
    margin-top: 0.05rem;
}

.fabrication-toast--success .fabrication-toast__icon {
    background: #dcfce7;
    color: #16a34a;
}

.fabrication-toast--error .fabrication-toast__icon {
    background: #fee2e2;
    color: #dc2626;
}

.fabrication-toast__body {
    flex: 1;
    min-width: 0;
}

.fabrication-toast__title {
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--color-text);
    line-height: 1.3;
    margin: 0;
}

.fabrication-toast__message {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    margin: 0.2rem 0 0;
    line-height: 1.45;
}

@keyframes fabrication-toast-in {
    from { opacity: 0; transform: translateY(0.75rem) scale(0.96); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes fabrication-toast-out {
    from { opacity: 1; transform: translateY(0) scale(1); }
    to   { opacity: 0; transform: translateY(0.4rem) scale(0.97); }
}

.page-fabrication .app-main {
    display: flex;
    flex: 1;
    width: 100%;
    min-height: 0;
    padding: 0;
    overflow: hidden;
}

work-order-ribbon,
parts-ribbon {
    display: block;
}

work-order-ribbon[variant="fabrication"],
parts-ribbon[variant="fabrication"],
work-order-ribbon[variant="logistics"],
parts-ribbon[variant="logistics"] {
    display: flex;
    flex-direction: column;
    min-height: 0;
    height: 100%;
}

.page-fabrication {
    overflow: hidden;
}

.page-fabrication .app-shell {
    height: 100vh;
    overflow: hidden;
}

.page-fabrication .app-frame {
    display: flex;
    flex-direction: column;
    height: 100vh;
    overflow: hidden;
}

.fabrication-layout {
    display: flex;
    flex: 1 1 auto;
    width: 100%;
    height: 100%;
    min-height: 0;
    overflow: hidden;
}

.fabrication-pane {
    display: flex;
    flex-direction: column;
    min-width: 0;
    min-height: 0;
}

.fabrication-pane--jobs {
    width: 18rem;
    background: var(--color-surface-low);
    border-right: 1px solid transparent;
    overflow: hidden;
}

.fabrication-pane--parts {
    width: 20rem;
    background: var(--color-surface-mid);
    overflow: hidden;
}

.fabrication-pane--entry {
    flex: 1;
    background: var(--color-surface);
    overflow: hidden;
}

.fabrication-pane__section {
    display: flex;
    flex: 1;
    flex-direction: column;
    min-height: 0;
    padding: 1.5rem;
}

.fabrication-pane__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.fabrication-pane__heading {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.2em;
    text-transform: uppercase;
}

.fabrication-pane__meta {
    color: rgba(63, 72, 76, 0.6);
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.fabrication-job-list,
.fabrication-parts-list {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    gap: 0.75rem;
    min-height: 0;
    overflow-y: auto;
}

.fabrication-job-card,
.fabrication-part-card {
    width: 100%;
    border: 0;
    background: transparent;
    text-align: left;
    cursor: pointer;
}

.fabrication-job-card {
    padding: 1rem;
    border-radius: 0.75rem;
    transition: background-color var(--transition);
}

.fabrication-job-card:hover,
.fabrication-job-card:focus-visible {
    background: rgba(255, 255, 255, 0.65);
    outline: none;
}

.fabrication-job-card.is-active {
    background: #ffffff;
    border-left: 4px solid var(--color-primary);
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.fabrication-job-card__top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.25rem;
}

.fabrication-job-card__title {
    color: var(--color-primary);
    font-size: 0.95rem;
    font-weight: 700;
}

.fabrication-job-card__badge {
    padding: 0.125rem 0.5rem;
    background: var(--color-primary-soft, #b7eaff);
    color: #001f28;
    border-radius: 999px;
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.fabrication-job-card__subtitle {
    margin: 0;
    color: rgba(63, 72, 76, 0.8);
    font-size: 0.6875rem;
    line-height: 1.5;
}

.fabrication-job-card__progress {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.75rem;
}

.fabrication-job-card__progress span {
    color: var(--color-primary);
    font-size: 0.625rem;
    font-weight: 700;
}

.fabrication-job-card__track {
    flex: 1;
    height: 0.25rem;
    overflow: hidden;
    background: var(--color-surface-mid);
    border-radius: 999px;
}

.fabrication-job-card__fill {
    height: 100%;
    background: var(--color-primary);
}

.fabrication-part-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.75rem;
    border-radius: 0.75rem;
    transition: background-color var(--transition);
}

.fabrication-part-card:hover,
.fabrication-part-card:focus-visible,
.fabrication-part-card.is-active {
    background: var(--color-surface-low);
    outline: none;
}

.fabrication-part-card[hidden] {
    display: none;
}

.fabrication-part-card__thumb {
    width: 4rem;
    height: 4rem;
    overflow: hidden;
    border-radius: 0.5rem;
    flex-shrink: 0;
    background: var(--color-surface-high);
}

.fabrication-part-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fabrication-part-card__thumb--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(63, 72, 76, 0.5);
}

.fabrication-part-card__content {
    flex: 1;
    min-width: 0;
}

.fabrication-part-card__content h4 {
    margin: 0;
    color: rgba(25, 28, 29, 0.78);
    font-size: 0.9rem;
    font-weight: 700;
    transition: color var(--transition);
}

.fabrication-part-card:hover .fabrication-part-card__content h4,
.fabrication-part-card.is-active .fabrication-part-card__content h4 {
    color: var(--color-primary);
}

.fabrication-part-card__content p {
    margin: 0.25rem 0 0;
    color: rgba(63, 72, 76, 0.6);
    font-size: 0.625rem;
}

.fabrication-part-card__progress {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.5rem;
}

.fabrication-part-card__progress-track {
    flex: 1;
    height: 0.25rem;
    border-radius: 999px;
    background: var(--color-border);
    overflow: hidden;
}

.fabrication-part-card__progress-fill {
    height: 100%;
    border-radius: 999px;
    background: var(--color-primary);
    transition: width 0.3s ease;
}

.fabrication-part-card__status {
    flex-shrink: 0;
    color: var(--color-text-muted);
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.fabrication-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    height: 100%;
    padding: 2rem;
}

.fabrication-empty-state[hidden],
.fabrication-entry[hidden] {
    display: none !important;
}

.fabrication-empty-state__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 12rem;
    height: 12rem;
    margin-bottom: 1.5rem;
    background: var(--color-surface-low);
    border-radius: 999px;
}

.fabrication-empty-state__icon .material-symbols-outlined {
    color: rgba(112, 120, 125, 0.4);
    font-size: 4.5rem;
}

.fabrication-empty-state h2 {
    margin: 0 0 0.75rem;
    color: var(--color-primary);
    font-size: 1.9rem;
    font-weight: 800;
}

.fabrication-empty-state p {
    max-width: 24rem;
    margin: 0;
    color: var(--color-text-muted);
    font-weight: 500;
}

.fabrication-empty-state__bars {
    display: flex;
    gap: 2rem;
    margin-top: 3rem;
    opacity: 0.2;
    filter: grayscale(1);
}

.fabrication-empty-state__bars span {
    width: 6rem;
    height: 0.25rem;
    background: var(--color-border);
    border-radius: 999px;
}

.fabrication-entry {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    height: 100%;
    min-height: 0;
    padding: 2rem;
    overflow: hidden;
}

.fabrication-entry__media-grid {
    display: grid;
    grid-template-columns: 4fr 8fr;
    gap: 2.5rem;
    margin-bottom: 0.5rem;
}

.fabrication-entry__image-card {
    position: relative;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: var(--color-surface-low);
    border-radius: 1rem;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.fabrication-entry__image-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fabrication-entry__model-card {
    position: absolute;
    right: 1rem;
    bottom: 1rem;
    left: 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.75rem;
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(12px);
    border-radius: 0.75rem;
}

.fabrication-entry__model-card p:first-child {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.5625rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.fabrication-entry__model-card p:last-child {
    margin: 0.15rem 0 0;
    color: var(--color-primary);
    font-size: 0.6875rem;
    font-weight: 700;
}

.fabrication-entry__model-card .material-symbols-outlined {
    color: var(--color-primary);
    cursor: pointer;
    transition: transform var(--transition);
}

.fabrication-entry__model-card .material-symbols-outlined:hover {
    transform: scale(1.08);
}

.fabrication-entry__pdf-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
    text-decoration: none;
}

.fabrication-entry__summary {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.fabrication-entry__summary-top {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
}

.fabrication-entry__summary-top h2 {
    margin: 0;
    color: var(--color-primary);
    font-size: 3rem;
    font-weight: 800;
    line-height: 1;
}

.fabrication-entry__pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.3rem 0.75rem;
    background: rgba(183, 234, 255, 0.2);
    color: var(--color-primary);
    border-radius: 999px;
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.fabrication-entry__pill span {
    width: 0.375rem;
    height: 0.375rem;
    border-radius: 999px;
    background: var(--color-primary);
    animation: fabrication-pulse 1.6s infinite;
}

.fabrication-entry__subtitle {
    display: flex;
    gap: 0.4rem;
    margin: 0 0 2rem;
    color: var(--color-text-muted);
    font-size: 1.125rem;
    font-weight: 500;
}

.fabrication-entry__subtitle strong {
    font-weight: 700;
}

.fabrication-entry__stats {
    display: flex;
    gap: 4rem;
    margin-bottom: 2rem;
}

.fabrication-entry__stats p {
    display: block;
    margin: 0 0 0.25rem;
    color: var(--color-text-muted);
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.fabrication-entry__stats span {
    color: var(--color-primary);
    font-size: 3rem;
    font-weight: 700;
    letter-spacing: -0.05em;
}

.fabrication-entry__produced-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.fabrication-entry__produced-row strong {
    padding: 0.3rem 0.75rem;
    background: rgba(183, 234, 255, 0.3);
    color: var(--color-primary);
    border-radius: 999px;
    font-size: 0.875rem;
    font-weight: 700;
}

.fabrication-entry__progress-track {
    width: 100%;
    height: 1rem;
    overflow: hidden;
    background: var(--color-surface-high);
    border-radius: 999px;
    box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.08);
}

.fabrication-entry__progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--color-primary), var(--color-primary-strong));
}

.fabrication-entry__production {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    padding: 2rem;
    background: var(--color-surface-low);
    border-radius: 1rem;
    overflow: hidden;
}

.fabrication-entry__production-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.fabrication-entry__production-header h3 {
    margin: 0 0 0.25rem;
    color: var(--color-primary);
    font-size: 1.25rem;
    font-weight: 700;
}

.fabrication-entry__production-header p {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.875rem;
}

.fabrication-entry__add-lot {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.7rem 1.5rem;
    border: 0;
    border-radius: 0.5rem;
    background: #ffffff;
    color: var(--color-primary);
    font-size: 0.875rem;
    font-weight: 700;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
    cursor: pointer;
}

.fabrication-entry__add-lot[hidden] {
    display: none !important;
}

.fabrication-entry__expected-mobile {
    display: none;
}

.fabrication-entry__table-shell {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    background: #ffffff;
    border-radius: 0.75rem;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.fabrication-entry__table {
    width: 100%;
    border-collapse: collapse;
    text-align: left;
}

.fabrication-entry__table thead tr {
    background: rgba(231, 232, 233, 0.5);
}

.fabrication-entry__table th {
    padding: 1.25rem 2rem;
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.fabrication-entry__table-action-head {
    width: 4.5rem;
}

.fabrication-entry__table tbody {
    border-top: 1px solid var(--color-surface-low);
}

.fabrication-entry__table tbody tr {
    transition: background-color var(--transition);
}

.fabrication-entry__table tbody tr:hover {
    background: rgba(243, 244, 245, 0.3);
}

.fabrication-entry__table tbody td {
    padding: 1rem 2rem;
    border-top: 1px solid var(--color-surface-low);
}

.fabrication-entry__table tbody td:first-child {
    color: var(--color-primary);
    font-size: 0.875rem;
    font-weight: 700;
}

.fabrication-entry__table input {
    width: 100%;
    padding: 0;
    border: 0;
    background: transparent;
    font: inherit;
    outline: none;
}

.fabrication-entry__pallet-input-wrap {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.fabrication-entry__scan-pallet {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    flex-shrink: 0;
    border: 0;
    border-radius: 999px;
    background: rgba(0, 67, 84, 0.08);
    color: var(--color-primary);
    cursor: pointer;
    transition: background-color var(--transition), transform var(--transition);
}

.fabrication-entry__scan-pallet:hover,
.fabrication-entry__scan-pallet:focus-visible {
    background: rgba(0, 67, 84, 0.16);
    transform: scale(1.03);
    outline: none;
}

.fabrication-entry__table-action-cell {
    text-align: right;
}

.fabrication-entry__delete-lot {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: rgba(63, 72, 76, 0.65);
    cursor: pointer;
    transition:
        background-color var(--transition),
        color var(--transition);
}

.fabrication-entry__delete-lot:hover,
.fabrication-entry__delete-lot:focus-visible {
    background: rgba(186, 26, 26, 0.08);
    color: #ba1a1a;
    outline: none;
}

/* =========================================================
   Full-bleed page overrides — fabrication, logistics, assembly
   all use edge-to-edge layouts; remove the global app-main
   centering/max-width constraints for these pages.
   ========================================================= */
.page-fabrication .app-main,
.page-logistics .app-main,
.page-assembly .app-main {
    width: 100%;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
}

/* =========================================================
   Fabrication — collapsible jobs pane & responsive layout
   ========================================================= */

.fabrication-pane--jobs {
    position: relative;
    transition: width 0.25s ease;
}

.fabrication-jobs-toggle {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.375rem;
    min-width: 1.375rem;
    padding: 0;
    border: none;
    border-right: 1px solid rgba(15, 23, 42, 0.08);
    background: var(--color-surface-low);
    color: var(--color-text-muted);
    cursor: pointer;
    transition:
        background-color var(--transition),
        color var(--transition);
}

.fabrication-jobs-toggle:hover {
    background: var(--color-surface-mid);
    color: var(--color-primary);
}

.fabrication-jobs-toggle .material-symbols-outlined {
    font-size: 1.125rem;
    transition: transform 0.25s ease;
}

.fabrication-layout.jobs-collapsed .fabrication-pane--jobs {
    width: 0;
    min-width: 0;
    overflow: hidden;
}

.fabrication-layout.jobs-collapsed .fabrication-jobs-toggle .material-symbols-outlined {
    transform: rotate(180deg);
}

.fabrication-drawer-backdrop {
    display: none;
}

.fabrication-mobile-nav {
    display: none;
}

.fabrication-drawer-close-btn {
    display: none;
}

/* Tablet — slightly narrower columns */
@media (max-width: 1023px) and (min-width: 768px) {
    .fabrication-pane--jobs {
        width: 15rem;
    }

    .fabrication-pane--parts {
        width: 16rem;
    }

    .fabrication-entry {
        padding-bottom: 1rem;
    }

    .fabrication-entry__production {
        padding-bottom: calc(2rem + env(safe-area-inset-bottom));
    }

    .fabrication-entry__footer {
        margin-bottom: calc(1.5rem + env(safe-area-inset-bottom));
    }
}

/* Mobile — both side panels become full overlay drawers */
@media (max-width: 767px) {
    /* Prevent horizontal scroll on the fabrication page */
    .page-fabrication .app-frame,
    .page-fabrication .app-main {
        overflow-x: hidden;
    }

    .fabrication-layout {
        position: relative;
        overflow-x: hidden;
    }

    /* Jobs and parts: fixed-position drawers, hidden by default.
       Using position:fixed avoids the overflow:hidden + transform
       clipping issue in mobile Safari.
       visibility:hidden prevents the box-shadow from bleeding into
       the viewport edge when the panel is translateX(-100%) off-screen. */
    .fabrication-pane--jobs,
    .fabrication-pane--parts {
        position: fixed;
        left: 0;
        top: 0;
        height: 100%;
        z-index: 60;
        width: 88%;
        max-width: 22rem;
        transform: translateX(-100%);
        visibility: hidden;
        transition: transform 0.25s ease, visibility 0s linear 0.25s;
        box-shadow: 0.5rem 0 2rem rgba(15, 23, 42, 0.22);
        overflow-y: auto;
        overflow-x: hidden;
    }

    .fabrication-pane--jobs {
        z-index: 61;
    }

    .fabrication-layout.jobs-open .fabrication-pane--jobs {
        transform: translateX(0);
        visibility: visible;
        transition: transform 0.25s ease, visibility 0s linear 0s;
    }

    .fabrication-layout.parts-open .fabrication-pane--parts {
        transform: translateX(0);
        visibility: visible;
        transition: transform 0.25s ease, visibility 0s linear 0s;
    }

    /* Neutralise the desktop collapse rules on mobile */
    .fabrication-layout.jobs-collapsed .fabrication-pane--jobs {
        width: 88%;
        overflow-y: auto;
        overflow-x: hidden;
    }

    /* Toggle button: not needed on mobile */
    .fabrication-jobs-toggle {
        display: none;
    }

    /* Entry panel fills the whole screen — no horizontal overflow */
    .fabrication-pane--entry {
        flex: 1;
        min-width: 0;
        max-width: 100%;
        overflow-x: hidden;
    }

    /* Dimming backdrop: fixed so it covers the full viewport */
    .fabrication-drawer-backdrop {
        display: block;
        position: fixed;
        inset: 0;
        z-index: 55;
        background: rgba(15, 23, 42, 0.45);
    }

    .fabrication-drawer-backdrop[hidden] {
        display: none;
    }

    /* Drawer close button (top of each overlay panel) */
    .fabrication-drawer-close-btn {
        display: flex;
        align-items: center;
        gap: 0.375rem;
        flex-shrink: 0;
        width: 100%;
        padding: 0.75rem 1rem;
        border: none;
        border-bottom: 1px solid rgba(15, 23, 42, 0.08);
        background: var(--color-surface-low);
        color: var(--color-primary);
        font-size: 0.875rem;
        font-weight: 700;
        cursor: pointer;
        text-align: left;
    }

    .fabrication-drawer-close-btn .material-symbols-outlined {
        font-size: 1.25rem;
    }

    /* Mobile nav bar — sits at the top of the entry panel */
    .fabrication-mobile-nav {
        display: flex;
        align-items: center;
        gap: 0.5rem;
        flex-shrink: 0;
        padding: 0.5rem 0.75rem;
        background: var(--color-surface-low);
        border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    }

    .fabrication-mobile-nav__btn {
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        width: 2.5rem;
        height: 2.5rem;
        padding: 0;
        border: none;
        background: transparent;
        color: var(--color-text-muted);
        cursor: pointer;
        border-radius: 0.5rem;
        transition: background-color var(--transition), color var(--transition);
    }

    .fabrication-mobile-nav__btn:hover,
    .fabrication-mobile-nav__btn:active {
        background: var(--color-surface-mid);
        color: var(--color-primary);
    }

    .fabrication-mobile-nav__btn .material-symbols-outlined {
        font-size: 1.5rem;
    }

    .fabrication-mobile-nav__context {
        display: flex;
        align-items: center;
        gap: 0.375rem;
        flex: 1;
        min-width: 0;
        overflow: hidden;
    }

    .fabrication-mobile-nav__job,
    .fabrication-mobile-nav__part {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        font-size: 0.6875rem;
        font-weight: 700;
        color: var(--color-primary);
    }

    .fabrication-mobile-nav__sep {
        flex-shrink: 0;
        color: var(--color-text-muted);
        font-size: 0.75rem;
    }

    /* Compact entry panel */
    .fabrication-entry {
        padding: 0.75rem;
        gap: 0.75rem;
        overflow-x: hidden;
    }

    .fabrication-entry__media-grid {
        display: none;
    }

    .fabrication-entry__production {
        padding: 1rem;
        padding-bottom: calc(6.5rem + env(safe-area-inset-bottom));
        overflow-x: hidden;
    }

    .fabrication-entry__production-header {
        flex-wrap: wrap;
        align-items: center;
        margin-bottom: 0.75rem;
    }

    .fabrication-entry__production-header h3 {
        font-size: 1rem;
    }

    .fabrication-entry__production-header p {
        font-size: 0.75rem;
    }

    .fabrication-entry__expected-mobile {
        display: inline-flex;
        flex-direction: column;
        align-items: flex-start;
        justify-content: center;
        gap: 0.15rem;
        padding: 0.55rem 0.85rem;
        border-radius: 0.75rem;
        background: rgba(183, 234, 255, 0.24);
        color: var(--color-primary);
        box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
    }

    .fabrication-entry__expected-mobile-label {
        font-size: 0.625rem;
        font-weight: 800;
        letter-spacing: 0.14em;
        text-transform: uppercase;
        color: var(--color-text-muted);
    }

    .fabrication-entry__expected-mobile-value {
        font-family: "Manrope", sans-serif;
        font-size: 1rem;
        font-weight: 800;
        line-height: 1;
    }

    .fabrication-entry__footer {
        gap: 1rem;
        margin-top: 1rem;
        flex-wrap: wrap;
    }

    .fabrication-entry__footer p {
        font-size: 1.25rem;
    }

    .fabrication-entry__table-shell {
        overflow-x: auto;
    }

    .fabrication-entry__table th,
    .fabrication-entry__table td {
        padding: 0.75rem 1rem;
    }

    .fabrication-empty-state__icon {
        width: 6rem;
        height: 6rem;
        margin-bottom: 1rem;
    }

    .fabrication-empty-state h2 {
        font-size: 1.25rem;
    }
}

.fabrication-scan-modal__panel {
    width: min(100%, 34rem);
}

.fabrication-scan-modal__body {
    gap: 1rem;
}

.fabrication-scan-modal__intro {
    margin: 0;
    color: var(--color-text-muted);
    line-height: 1.5;
}

.fabrication-scan-modal__viewport {
    position: relative;
    overflow: hidden;
    aspect-ratio: 4 / 3;
    background: #0f172a;
    border-radius: 0.85rem;
}

.fabrication-scan-modal__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fabrication-scan-modal__reticle {
    position: absolute;
    inset: 18%;
    border: 2px solid rgba(255, 255, 255, 0.9);
    border-radius: 1rem;
    box-shadow: 0 0 0 999px rgba(15, 23, 42, 0.22);
    pointer-events: none;
}

.fabrication-scan-modal__status {
    margin: 0;
    color: var(--color-primary);
    font-size: 0.875rem;
    font-weight: 600;
}

.page-logistics .app-main {
    flex: 1;
    width: 100%;
    min-height: 0;
    padding: 0;
    overflow: hidden;
}

.page-logistics .app-shell {
    height: 100vh;
    overflow: hidden;
}

.page-logistics .app-frame {
    display: flex;
    flex-direction: column;
    height: 100vh;
    overflow: hidden;
}

.logistics-layout {
    display: flex;
    flex: 1 1 auto;
    width: 100%;
    height: 100%;
    min-height: 0;
    background: var(--color-surface-low);
    overflow: hidden;
}

.logistics-pane {
    min-width: 0;
    min-height: 0;
}

.logistics-pane--jobs {
    width: 20rem;
    flex-shrink: 0;
    background: var(--color-surface);
    border-right: 1px solid rgba(191, 200, 204, 0.15);
}

.logistics-pane--ribbon {
    width: 19rem;
    flex-shrink: 0;
    background: var(--color-surface);
    border-right: 1px solid rgba(191, 200, 204, 0.18);
}

.logistics-pane__section {
    height: 100%;
    padding: 1.5rem;
}

.logistics-pane__title {
    margin: 0 0 1rem;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 1.25rem;
    font-weight: 800;
}

.logistics-job-list,
.logistics-ribbon__list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    min-height: 0;
    overflow-y: auto;
}

.logistics-job-card {
    padding: 1rem;
    background: var(--color-surface-low);
    border-radius: 0.5rem;
    transition: background-color var(--transition);
    cursor: pointer;
}

.logistics-job-card:hover {
    background: var(--color-surface-high);
}

.logistics-job-card--active {
    background: var(--color-surface);
    border-left: 4px solid var(--color-primary);
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.logistics-job-card--simple {
    padding-bottom: 1.1rem;
}

.logistics-job-card__top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
}

.logistics-job-card__id {
    color: var(--color-text);
    font-family: "Manrope", sans-serif;
    font-size: 0.875rem;
    font-weight: 700;
}

.logistics-job-card__id--muted {
    color: #64748b;
}

.logistics-job-card__badge {
    padding: 0.125rem 0.5rem;
    background: var(--color-secondary-soft);
    color: var(--color-secondary-text);
    border-radius: 999px;
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.logistics-job-card__client {
    margin: 0 0 0.75rem;
    color: var(--color-text-muted);
    font-size: 0.75rem;
}

.logistics-job-card__client--muted {
    color: rgba(100, 116, 139, 0.9);
    margin-bottom: 0;
}

.logistics-job-card__progress {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.logistics-job-card__progress span {
    color: var(--color-primary);
    font-size: 0.625rem;
    font-weight: 700;
}

.logistics-job-card__progress-text--muted {
    color: #94a3b8 !important;
}

.logistics-job-card__track {
    flex: 1;
    height: 0.25rem;
    overflow: hidden;
    background: var(--color-surface-highest);
    border-radius: 999px;
}

.logistics-job-card__fill {
    height: 100%;
    background: var(--color-primary);
}

.logistics-job-card__fill--muted {
    background: #94a3b8;
}

.logistics-ribbon__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.logistics-ribbon__header h3 {
    margin: 0;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 0.875rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.logistics-ribbon__header span {
    color: var(--color-text-muted);
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.logistics-ribbon-card {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    width: 100%;
    padding: 1rem;
    border: 0;
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.55);
    text-align: left;
    cursor: pointer;
}

.logistics-ribbon-card__thumb {
    width: 3.5rem;
    height: 3.5rem;
    flex-shrink: 0;
    overflow: hidden;
    border-radius: 0.6rem;
    background: var(--color-surface-high);
}

.logistics-ribbon-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.logistics-ribbon-card__thumb--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(63, 72, 76, 0.5);
}

.logistics-ribbon-card__body {
    min-width: 0;
    flex: 1;
}

.logistics-ribbon-card--active {
    background: #ffffff;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.logistics-ribbon-card--locked {
    opacity: 0.6;
    filter: grayscale(1);
}

.logistics-ribbon-card__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}

.logistics-ribbon-card__meta p,
.logistics-ribbon-card__meta span {
    margin: 0;
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.logistics-ribbon-card__meta p {
    color: var(--color-primary);
}

.logistics-ribbon-card__meta span {
    color: var(--color-text-muted);
}

.logistics-ribbon-card h4 {
    margin: 0;
    color: var(--color-text);
    font-family: "Manrope", sans-serif;
    font-size: 1rem;
    font-weight: 700;
}

.logistics-ribbon-card p {
    margin: 0.35rem 0 0;
    color: var(--color-text-muted);
    font-size: 0.75rem;
}

.logistics-ribbon-card strong {
    display: inline-block;
    margin-top: 0.75rem;
    color: var(--color-primary);
    font-size: 0.875rem;
    font-weight: 700;
}

.logistics-ribbon-card__job-info {
    display: flex;
    gap: 0.4rem;
    flex-wrap: wrap;
    margin-top: 0.5rem;
}

.logistics-ribbon-card__job-num,
.logistics-ribbon-card__tag {
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 0.15rem 0.4rem;
    border-radius: 3px;
    white-space: nowrap;
}

.logistics-ribbon-card__job-num {
    background: rgba(var(--color-primary-rgb, 0 84 166), 0.1);
    color: var(--color-primary);
}

.logistics-ribbon-card__tag {
    background: rgba(63, 72, 76, 0.08);
    color: var(--color-text-muted);
}

.logistics-pane--main {
    flex: 1;
    min-width: 0;
    background: var(--color-surface);
    overflow: hidden;
}

.logistics-main {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.logistics-main__content {
    flex: 1;
    overflow-y: auto;
    padding: 2rem;
}

.logistics-main__content > * {
    max-width: 64rem;
    margin-left: auto;
    margin-right: auto;
}

.logistics-main__breadcrumb {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    margin-bottom: 0.5rem;
    color: #94a3b8;
    font-size: 0.75rem;
}

.logistics-main__breadcrumb .material-symbols-outlined {
    font-size: 0.625rem;
}

.logistics-main__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.logistics-main__header h2 {
    margin: 0;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 2.25rem;
    font-weight: 800;
    letter-spacing: -0.03em;
}

.logistics-main__header .material-symbols-outlined {
    color: #94a3b8;
    font-size: 1.875rem;
}

.logistics-main__intro {
    max-width: 40rem;
    margin: 0 0 2rem;
    color: var(--color-text-muted);
    line-height: 1.6;
}

.logistics-lot-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.logistics-lot-card {
    display: block;
    cursor: pointer;
}

.logistics-lot-card__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.5rem;
    background: var(--color-surface-highest);
    border: 2px solid transparent;
    border-radius: 0.75rem;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
    transition: border-color var(--transition);
}

.logistics-lot-card:hover .logistics-lot-card__inner {
    border-color: rgba(0, 67, 84, 0.2);
}

.logistics-lot-card__thumb {
    width: 3.5rem;
    height: 3.5rem;
    flex-shrink: 0;
    overflow: hidden;
    border-radius: 0.6rem;
    background: var(--color-surface-high);
}

.logistics-lot-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.logistics-lot-card__thumb--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(63, 72, 76, 0.5);
}

.logistics-lot-card__left {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex: 1;
}

.logistics-lot-card__lot-id {
    margin: 0 0 0.25rem;
    color: var(--color-primary);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.logistics-lot-card__lot-id--muted {
    color: #64748b;
}

.logistics-lot-card__qty {
    margin: 0;
    color: var(--color-text);
    font-family: "Manrope", sans-serif;
    font-size: 1.75rem;
    font-weight: 800;
}

.logistics-lot-card__sku {
    margin: 0.25rem 0 0;
    color: var(--color-text-muted);
    font-size: 0.875rem;
}

.logistics-lot-card__icon {
    color: #94a3b8;
    font-size: 1.875rem;
}

.logistics-lot-card__remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: #64748b;
    cursor: pointer;
    transition: background-color var(--transition), color var(--transition);
}

.logistics-lot-card__remove:hover,
.logistics-lot-card__remove:focus-visible {
    background: rgba(186, 26, 26, 0.08);
    color: #ba1a1a;
    outline: none;
}

.logistics-lot-card__remove[disabled] {
    cursor: not-allowed;
    background: transparent;
    color: #94a3b8;
}

.logistics-lot-card__remove--static {
    cursor: default;
    background: rgba(15, 23, 42, 0.04);
    color: #64748b;
}

.logistics-lot-card--locked {
    opacity: 0.6;
    filter: grayscale(1);
}

.logistics-main__cta {
    margin-top: 3rem;
    text-align: center;
}

.logistics-main__create {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    width: 100%;
    height: 4rem;
    border: 0;
    border-radius: 0.75rem;
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-strong));
    color: #ffffff;
    font-family: "Manrope", sans-serif;
    font-size: 1.25rem;
    font-weight: 800;
    box-shadow: 0 20px 40px rgba(0, 67, 84, 0.18);
    cursor: pointer;
}

.logistics-main__cta p {
    margin: 1rem 0 0;
    color: #94a3b8;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.logistics-main__cta--readonly {
    margin-top: 2rem;
}

.logistics-main__cta--readonly p {
    margin-top: 0;
}

/* Inline pallet naming form */
.logistics-pallet-naming {
    margin-top: 2rem;
    padding: 1.25rem;
    border: 1px solid #334155;
    border-radius: 0.75rem;
    background: #1e293b;
}

.logistics-pallet-naming__label {
    display: block;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #94a3b8;
    margin-bottom: 0.5rem;
}

.logistics-pallet-name-input {
    display: block;
    width: 100%;
    padding: 0.6rem 0.875rem;
    background: #0f172a;
    border: 1px solid #475569;
    border-radius: 0.5rem;
    color: #f1f5f9;
    font-size: 1rem;
    font-family: inherit;
    box-sizing: border-box;
    outline: none;
    transition: border-color 0.15s;
}

.logistics-pallet-name-input:focus {
    border-color: #3b82f6;
}

.logistics-pallet-naming__field {
    margin-bottom: 1rem;
}

.logistics-pallet-naming__actions {
    display: flex;
    gap: 0.75rem;
    justify-content: flex-end;
}

.logistics-pallet-naming__cancel {
    padding: 0.5rem 1rem;
    border: 1px solid #475569;
    border-radius: 0.5rem;
    background: transparent;
    color: #94a3b8;
    font-size: 0.875rem;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
}

.logistics-pallet-naming__cancel:hover {
    background: #334155;
    color: #e2e8f0;
}

.logistics-pallet-naming__confirm {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.5rem 1.125rem;
    background: #3b82f6;
    border: none;
    border-radius: 0.5rem;
    color: #fff;
    font-size: 0.875rem;
    cursor: pointer;
    transition: background 0.15s;
}

.logistics-pallet-naming__confirm:hover {
    background: #2563eb;
}

.logistics-pallet-naming__confirm .material-symbols-outlined {
    font-size: 1.1rem;
}

.logistics-staged {
    margin-top: 2rem;
}

.logistics-staged__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.85rem;
}

.logistics-staged__header h3 {
    margin: 0;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 0.875rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.logistics-staged__header span {
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.logistics-staged__list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.logistics-staged__card {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(191, 200, 204, 0.55);
    border-radius: 0.75rem;
}

.logistics-staged__card.is-active {
    border-color: rgba(0, 67, 84, 0.22);
    background: #ffffff;
}

.logistics-staged__select {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex: 1;
    padding: 0;
    border: 0;
    background: transparent;
    text-align: left;
    cursor: pointer;
}

.logistics-staged__select p {
    margin: 0 0 0.2rem;
    color: var(--color-primary);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.logistics-staged__select strong {
    color: var(--color-text);
    font-family: "Manrope", sans-serif;
    font-size: 1rem;
    font-weight: 800;
}

.logistics-staged__select span {
    color: var(--color-text-muted);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.logistics-staged__remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: #64748b;
    cursor: pointer;
}

.logistics-staged__remove:hover,
.logistics-staged__remove:focus-visible {
    background: rgba(186, 26, 26, 0.08);
    color: #ba1a1a;
    outline: none;
}

.logistics-dispatch {
    padding: 2rem;
    background: #f1f5f9;
    border-top: 1px solid #e2e8f0;
}

.logistics-dispatch > * {
    max-width: 64rem;
    margin-left: auto;
    margin-right: auto;
}

.logistics-dispatch__header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.logistics-dispatch__header .material-symbols-outlined {
    color: var(--color-tertiary, #5d3300);
}

.logistics-dispatch__header h3 {
    margin: 0;
    color: #475569;
    font-size: 0.875rem;
    font-weight: 700;
}

.logistics-dispatch__body {
    display: flex;
    align-items: stretch;
    gap: 0.75rem;
}

.logistics-dispatch__bays-scroll {
    flex: 1;
    min-width: 0;
    overflow-x: auto;
    overflow-y: hidden;
    cursor: grab;
    scrollbar-width: thin;
    scrollbar-color: rgba(83, 97, 103, 0.45) transparent;
}

.logistics-dispatch__bays-scroll.is-dragging {
    cursor: grabbing;
}

.logistics-dispatch__bays-scroll::-webkit-scrollbar {
    height: 6px;
}

.logistics-dispatch__bays-scroll::-webkit-scrollbar-track {
    background: transparent;
}

.logistics-dispatch__bays-scroll::-webkit-scrollbar-thumb {
    background: rgba(83, 97, 103, 0.35);
    border-radius: 999px;
}

.logistics-dispatch__bays-scroll::-webkit-scrollbar-thumb:hover {
    background: rgba(83, 97, 103, 0.55);
}

.logistics-dispatch__bays {
    display: flex;
    gap: 0.75rem;
    min-width: max-content;
}

.logistics-bay {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 9rem;
    padding: 1.25rem 1rem;
    border: 2px solid transparent;
    border-radius: 0.5rem;
    background: rgba(255, 255, 255, 0.6);
    color: #64748b;
    cursor: pointer;
}

.logistics-bay span {
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.logistics-bay strong {
    margin-top: 0.25rem;
    font-size: 1.25rem;
    font-weight: 700;
}

.logistics-bay--active {
    background: #ffffff;
    border-color: var(--color-primary);
    color: var(--color-primary);
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.logistics-dispatch__button {
    width: 16rem;
    border: 0;
    border-radius: 0.5rem;
    background: var(--color-primary);
    color: #ffffff;
    font-family: "Manrope", sans-serif;
    font-size: 1.125rem;
    font-weight: 800;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    box-shadow: 0 10px 24px rgba(0, 67, 84, 0.16);
    cursor: pointer;
}

.logistics-dispatch__button[disabled] {
    opacity: 0.45;
    cursor: not-allowed;
    box-shadow: none;
}

.logistics-dispatch__button--dispatching .material-symbols-outlined {
    animation: fab-spin 0.9s linear infinite;
}

/* ── Logistics mobile drawer nav ─────────────────────────────────── */
.logistics-mobile-nav {
    display: none;
}

.logistics-drawer-close-btn {
    display: none;
}

@media (max-width: 767px) {
    .page-logistics .app-frame,
    .page-logistics .app-main {
        overflow-x: hidden;
    }

    .logistics-layout {
        position: relative;
        overflow-x: hidden;
    }

    .logistics-pane--ribbon {
        position: fixed;
        left: 0;
        top: 0;
        height: 100%;
        z-index: 61;
        width: 88%;
        max-width: 22rem;
        transform: translateX(-100%);
        visibility: hidden;
        transition: transform 0.25s ease, visibility 0s linear 0.25s;
        box-shadow: 0.5rem 0 2rem rgba(15, 23, 42, 0.22);
        overflow-y: auto;
        overflow-x: hidden;
        background: var(--color-surface);
    }

    .logistics-layout.ribbon-open .logistics-pane--ribbon {
        transform: translateX(0);
        visibility: visible;
        transition: transform 0.25s ease, visibility 0s linear 0s;
    }

    .logistics-pane--main {
        flex: 1;
        width: 100%;
        min-width: 0;
        max-width: 100%;
        overflow-x: hidden;
        display: flex;
        flex-direction: column;
    }

    .logistics-drawer-backdrop {
        display: block;
        position: fixed;
        inset: 0;
        z-index: 55;
        background: rgba(15, 23, 42, 0.45);
    }

    .logistics-drawer-backdrop[hidden] {
        display: none;
    }

    .logistics-drawer-close-btn {
        display: flex;
        align-items: center;
        gap: 0.375rem;
        width: 100%;
        padding: 0.75rem 1rem;
        background: var(--color-surface-low);
        border: none;
        border-bottom: 1px solid rgba(15, 23, 42, 0.08);
        color: var(--color-primary);
        font-size: 0.875rem;
        font-weight: 700;
        cursor: pointer;
        text-align: left;
        flex-shrink: 0;
    }

    .logistics-drawer-close-btn .material-symbols-outlined {
        font-size: 1.25rem;
    }

    .logistics-mobile-nav {
        display: flex;
        align-items: center;
        gap: 0.75rem;
        padding: 0.625rem 1rem;
        background: var(--color-surface);
        border-bottom: 1px solid var(--color-border);
        flex-shrink: 0;
    }

    .logistics-mobile-nav__btn {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 2.5rem;
        height: 2.5rem;
        background: transparent;
        border: 0;
        border-radius: 0.5rem;
        color: var(--color-primary);
        cursor: pointer;
    }

    .logistics-mobile-nav__btn:hover,
    .logistics-mobile-nav__btn:active {
        background: var(--color-surface-mid);
    }

    .logistics-mobile-nav__btn .material-symbols-outlined {
        font-size: 1.5rem;
    }

    .logistics-mobile-nav__title {
        font-size: 0.9rem;
        font-weight: 600;
        color: var(--color-primary);
    }

    .logistics-main {
        flex: 1;
        min-height: 0;
        overflow-y: auto;
        display: flex;
        flex-direction: column;
        padding-bottom: calc(7rem + env(safe-area-inset-bottom));
    }

    .logistics-pane__section {
        padding: 1rem;
        height: auto;
    }

    .logistics-ribbon__header {
        margin-bottom: 0.85rem;
    }

    .logistics-ribbon__list {
        gap: 0.625rem;
    }

    .logistics-ribbon-card {
        padding: 0.875rem;
        border-radius: 0.875rem;
        background: rgba(255, 255, 255, 0.88);
        box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
    }

    .logistics-ribbon-card__meta {
        margin-bottom: 0.4rem;
    }

    .logistics-ribbon-card h4 {
        font-size: 0.95rem;
    }

    .logistics-ribbon-card strong {
        margin-top: 0.55rem;
    }

    .logistics-main__content {
        padding: 1rem;
        padding-bottom: 1rem;
    }

    .logistics-dispatch {
        padding: 1rem;
        padding-bottom: 1rem;
    }

    .logistics-dispatch__body {
        flex-direction: column;
        align-items: stretch;
    }

    .logistics-dispatch__bays-scroll {
        width: 100%;
    }

    .logistics-dispatch__button {
        width: 100%;
        min-height: 3.5rem;
        font-size: 1rem;
    }

    .logistics-pallet-naming {
        margin-top: 1.25rem;
        padding: 1rem;
    }

    .logistics-pallet-naming__actions {
        flex-direction: column-reverse;
        align-items: stretch;
    }

    .logistics-pallet-naming__cancel,
    .logistics-pallet-naming__confirm {
        width: 100%;
        justify-content: center;
    }
}

/* ── Assembly receiving mobile drawer nav ────────────────────────── */
.assembly-mobile-nav {
    display: none;
}

.assembly-drawer-close-btn {
    display: none;
}

@media (max-width: 767px) {
    .page-assembly .app-frame,
    .page-assembly .app-main {
        overflow-x: hidden;
    }

    .assembly-layout {
        position: relative;
        overflow-x: hidden;
    }

    .assembly-pane--ribbon {
        position: fixed;
        left: 0;
        top: 0;
        height: 100%;
        z-index: 61;
        width: 88%;
        max-width: 22rem;
        transform: translateX(-100%);
        visibility: hidden;
        transition: transform 0.25s ease, visibility 0s linear 0.25s;
        box-shadow: 0.5rem 0 2rem rgba(15, 23, 42, 0.22);
        overflow-y: auto;
        overflow-x: hidden;
        background: var(--color-surface);
    }

    .assembly-layout.ribbon-open .assembly-pane--ribbon {
        transform: translateX(0);
        visibility: visible;
        transition: transform 0.25s ease, visibility 0s linear 0s;
    }

    .assembly-pane--detail {
        flex: 1;
        width: 100%;
        min-width: 0;
        max-width: 100%;
        overflow-x: hidden;
        display: flex;
        flex-direction: column;
    }

    .assembly-drawer-backdrop {
        display: block;
        position: fixed;
        inset: 0;
        z-index: 55;
        background: rgba(15, 23, 42, 0.45);
    }

    .assembly-drawer-backdrop[hidden] {
        display: none;
    }

    .assembly-drawer-close-btn {
        display: flex;
        align-items: center;
        gap: 0.5rem;
        width: 100%;
        padding: 1rem 1.25rem;
        background: transparent;
        border: 0;
        border-bottom: 1px solid var(--color-border);
        color: var(--color-primary);
        font-size: 0.9rem;
        font-weight: 600;
        cursor: pointer;
        text-align: left;
        flex-shrink: 0;
    }

    .assembly-mobile-nav {
        display: flex;
        align-items: center;
        gap: 0.75rem;
        padding: 0.625rem 1rem;
        background: var(--color-surface);
        border-bottom: 1px solid var(--color-border);
        flex-shrink: 0;
    }

    .assembly-mobile-nav__btn {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 2.5rem;
        height: 2.5rem;
        background: transparent;
        border: 0;
        border-radius: 0.5rem;
        color: var(--color-primary);
        cursor: pointer;
    }

    .assembly-mobile-nav__btn:hover,
    .assembly-mobile-nav__btn:active {
        background: var(--color-surface-mid);
    }

    .assembly-mobile-nav__btn .material-symbols-outlined {
        font-size: 1.5rem;
    }

    .assembly-mobile-nav__title {
        font-size: 0.9rem;
        font-weight: 600;
        color: var(--color-primary);
        flex: 1;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .assembly-pane__section {
        padding: 0.75rem;
        height: auto;
    }

    .assembly-pane__section--detail {
        padding: 0.75rem;
        flex: 1;
        overflow-y: auto;
    }
}

/* ── Simple Assembly Receiving ─────────────────────────────────────────────── */

.simple-assembly-ribbon {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.simple-assembly-ribbon__header {
    padding: 1rem 1rem 0.5rem;
    border-bottom: 1px solid var(--color-border);
}

.simple-assembly-ribbon__header h3 {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin: 0;
}

.simple-assembly-ribbon__list {
    list-style: none;
    margin: 0;
    padding: 0.5rem 0;
    overflow-y: auto;
    flex: 1;
}

.simple-assembly-ribbon__loading,
.simple-assembly-ribbon__empty {
    padding: 1rem;
    color: var(--color-text-muted);
    font-size: 0.875rem;
}

.simple-assembly-ribbon__item {
    padding: 0.65rem 1rem;
    cursor: pointer;
    border-left: 3px solid transparent;
    transition: background 0.1s ease;
}

.simple-assembly-ribbon__item:hover {
    background: var(--color-surface-container);
}

.simple-assembly-ribbon__item.is-selected {
    background: var(--color-surface-container);
    border-left-color: var(--color-primary);
}

.simple-assembly-ribbon__item-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.simple-assembly-ribbon__lot-number {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-text);
}

.simple-assembly-ribbon__status {
    font-size: 0.72rem;
    font-weight: 600;
    padding: 0.15rem 0.5rem;
    border-radius: 999px;
    white-space: nowrap;
}

.simple-assembly-ribbon__status--open {
    background: color-mix(in srgb, var(--color-warning) 15%, transparent);
    color: var(--color-warning);
}

.simple-assembly-ribbon__status--dispatched {
    background: color-mix(in srgb, var(--color-primary) 15%, transparent);
    color: var(--color-primary);
}

.simple-assembly-ribbon__status--received {
    background: color-mix(in srgb, var(--color-success) 15%, transparent);
    color: var(--color-success);
}

.simple-assembly-ribbon__item-sub {
    font-size: 0.78rem;
    color: var(--color-text-muted);
    margin-top: 0.2rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Detail panel */

.simple-assembly-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem 2rem;
    text-align: center;
    color: var(--color-text-muted);
    gap: 0.75rem;
    height: 100%;
}

.simple-assembly-detail {
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.simple-assembly-detail__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.simple-assembly-detail__eyebrow {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-muted);
    margin: 0 0 0.25rem;
}

.simple-assembly-detail__lot-number {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--color-text);
    margin: 0;
}

.simple-assembly-detail__status-badge {
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0.25rem 0.75rem;
    border-radius: 999px;
    white-space: nowrap;
    margin-top: 0.25rem;
}

.simple-assembly-detail__status-badge--open {
    background: color-mix(in srgb, var(--color-warning) 15%, transparent);
    color: var(--color-warning);
}

.simple-assembly-detail__status-badge--dispatched {
    background: color-mix(in srgb, var(--color-primary) 15%, transparent);
    color: var(--color-primary);
}

.simple-assembly-detail__status-badge--received {
    background: color-mix(in srgb, var(--color-success) 15%, transparent);
    color: var(--color-success);
}

.simple-assembly-detail__meta {
    background: var(--color-surface-container);
    border-radius: 0.5rem;
    overflow: hidden;
}

.simple-assembly-detail__meta-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.6rem 1rem;
    border-bottom: 1px solid var(--color-border);
    gap: 1rem;
}

.simple-assembly-detail__meta-row:last-child {
    border-bottom: none;
}

.simple-assembly-detail__meta-label {
    font-size: 0.78rem;
    color: var(--color-text-muted);
    font-weight: 500;
}

.simple-assembly-detail__meta-value {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-text);
    text-align: right;
}

.simple-assembly-detail__actions {
    display: flex;
    justify-content: flex-end;
}

.simple-assembly-detail__ack-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: var(--color-primary);
    color: #fff;
    border: none;
    border-radius: 0.5rem;
    padding: 0.65rem 1.25rem;
    font-size: 0.9rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s ease, opacity 0.15s ease;
}

.simple-assembly-detail__ack-btn:hover {
    background: var(--color-primary-dark, var(--color-primary));
    opacity: 0.9;
}

.simple-assembly-detail__ack-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.page-data-model .app-main {
    width: 100%;
    padding: 2rem;
}

.data-model-page {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.data-model-page__header {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.data-model-page__eyebrow {
    margin: 0;
    color: var(--color-secondary);
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.2em;
    text-transform: uppercase;
}

.data-model-page__title {
    margin: 0;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 800;
    letter-spacing: -0.04em;
}

.data-model-page__subtitle {
    max-width: 48rem;
    margin: 0;
    color: var(--color-text-muted);
    line-height: 1.6;
}

.data-model-panel {
    padding: 1.5rem;
    background: #ffffff;
    border-radius: 1rem;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.data-model-panel__meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.data-model-panel__label {
    margin: 0 0 0.25rem;
    color: var(--color-text-muted);
    font-size: 0.625rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.data-model-panel__value {
    margin: 0;
    color: var(--color-primary);
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 0.875rem;
    font-weight: 700;
}

.data-model-table__shell {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.data-model-table__count {
    color: var(--color-text-muted);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.data-model-table__scroll {
    overflow: auto;
    border: 1px solid var(--color-surface-mid);
    border-radius: 0.75rem;
}

.data-model-table {
    width: 100%;
    border-collapse: collapse;
    text-align: left;
}

.data-model-table thead {
    background: var(--color-surface-low);
}

.data-model-table th,
.data-model-table td {
    padding: 0.85rem 1rem;
    border-top: 1px solid var(--color-surface-mid);
    vertical-align: top;
}

.data-model-table thead th {
    border-top: 0;
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.data-model-table tbody code {
    white-space: pre-wrap;
    word-break: break-word;
    color: var(--color-text);
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 0.75rem;
}

.data-model-table__empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem 2rem;
    background: rgba(255, 255, 255, 0.6);
    border: 1px dashed rgba(191, 200, 204, 0.9);
    border-radius: 1rem;
    text-align: center;
}

.data-model-table__empty-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 4rem;
    height: 4rem;
    margin-bottom: 1rem;
    background: var(--color-surface-low);
    border-radius: 999px;
}

.data-model-table__empty-icon .material-symbols-outlined {
    color: var(--color-text-muted);
    font-size: 2rem;
}

.data-model-table__empty h3 {
    margin: 0 0 0.5rem;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 1.35rem;
    font-weight: 800;
}

.data-model-table__empty p {
    margin: 0;
    color: var(--color-text-muted);
    line-height: 1.6;
}

.page-feature-flags .app-main {
    width: 100%;
    padding: 2rem;
}

.page-admin .app-main {
    width: 100%;
    height: calc(100vh - 4rem);
    padding: 0;
    overflow: hidden;
}

.admin-layout {
    display: grid;
    grid-template-columns: 11.5rem minmax(0, 1fr);
    gap: 0;
    align-items: stretch;
    min-height: 100%;
    height: 100%;
}

.admin-layout__sidebar {
    height: 100%;
}

.admin-layout__sidebar-inner {
    height: 100%;
    padding: 1rem 0.75rem;
    background: #ffffff;
    border-radius: 0;
    border-right: 1px solid var(--color-surface-mid);
}

.admin-layout__nav {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.admin-layout__link {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.7rem 0.75rem;
    border-radius: 0.45rem;
    color: var(--color-text-muted);
    font-size: 0.8rem;
    font-weight: 700;
    text-decoration: none;
    transition: background-color var(--transition), color var(--transition);
}

.admin-layout__content {
    overflow-y: auto;
    padding: 2rem 2rem 2rem 1.5rem;
}

.admin-layout__link:hover,
.admin-layout__link:focus-visible {
    background: var(--color-surface-low);
    color: var(--color-primary);
    outline: none;
}

.admin-layout__link.is-active {
    background: rgba(0, 67, 84, 0.08);
    color: var(--color-primary);
}

.feature-flags-page {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.feature-flags-page__header {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.feature-flags-page__eyebrow {
    margin: 0;
    color: var(--color-secondary);
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.2em;
    text-transform: uppercase;
}

.feature-flags-page__title {
    margin: 0;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 800;
    letter-spacing: -0.04em;
}

.feature-flags-page__subtitle {
    max-width: 52rem;
    margin: 0;
    color: var(--color-text-muted);
    line-height: 1.6;
}

.feature-flags-form {
    padding: 1.5rem;
    background: #ffffff;
    border-radius: 1rem;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.feature-flags-table__scroll {
    width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
}

.feature-flags-table {
    width: 100%;
    min-width: 68rem;
    border-collapse: collapse;
    text-align: left;
    table-layout: fixed;
}

.feature-flags-table thead {
    background: var(--color-surface-low);
}

.feature-flags-table th,
.feature-flags-table td {
    padding: 0.85rem 1rem;
    border-top: 1px solid var(--color-surface-mid);
    vertical-align: top;
    word-break: break-word;
}

.feature-flags-table thead th {
    border-top: 0;
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.feature-flags-table code {
    color: var(--color-primary);
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 0.75rem;
    font-weight: 700;
}

.feature-flags-table select {
    width: 100%;
    min-width: 0;
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--color-border);
    border-radius: 0.5rem;
    background: #ffffff;
    font: inherit;
}

.feature-flags-table th:nth-child(1),
.feature-flags-table td:nth-child(1) {
    width: 14rem;
}

.feature-flags-table th:nth-child(2),
.feature-flags-table td:nth-child(2) {
    width: 20rem;
}

.feature-flags-table th:nth-child(3),
.feature-flags-table td:nth-child(3),
.feature-flags-table th:nth-child(4),
.feature-flags-table td:nth-child(4),
.feature-flags-table th:nth-child(5),
.feature-flags-table td:nth-child(5),
.feature-flags-table th:nth-child(6),
.feature-flags-table td:nth-child(6) {
    width: 6.5rem;
}

.feature-flags-table th:nth-child(7),
.feature-flags-table td:nth-child(7) {
    width: 10rem;
}

.feature-flags-table th:nth-child(8),
.feature-flags-table td:nth-child(8) {
    width: 9rem;
}

.feature-flags-form__actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    margin-top: 1.5rem;
}

.feature-flags-form__link {
    color: var(--color-primary);
    font-size: 0.875rem;
    font-weight: 700;
    text-decoration: none;
}

.feature-flags-form__submit {
    padding: 0.8rem 1.2rem;
    border: 0;
    border-radius: 0.5rem;
    background: var(--color-primary);
    color: #ffffff;
    font-size: 0.875rem;
    font-weight: 700;
    cursor: pointer;
}

.admin-data-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
    gap: 1rem;
}

.admin-data-card {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 1.25rem;
    background: #ffffff;
    border: 1px solid var(--color-surface-mid);
    border-radius: 0.9rem;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
    color: inherit;
    text-decoration: none;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.admin-data-card:hover,
.admin-data-card:focus-visible {
    transform: translateY(-2px);
    border-color: rgba(0, 67, 84, 0.2);
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
    outline: none;
}

.admin-data-card__eyebrow {
    margin: 0;
    color: var(--color-secondary);
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.admin-data-card__title {
    margin: 0;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 1.15rem;
    font-weight: 800;
}

.admin-data-card__description {
    margin: 0;
    color: var(--color-text-muted);
    line-height: 1.6;
}

.admin-data-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: auto;
    gap: 0.75rem;
}

.admin-data-card__footer code {
    color: var(--color-primary);
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 0.75rem;
    font-weight: 700;
}

.admin-data-card__footer .material-symbols-outlined {
    color: var(--color-primary);
}

.impersonation-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.75rem 1.5rem;
    background: rgba(138, 75, 8, 0.08);
    border-bottom: 1px solid rgba(138, 75, 8, 0.12);
}

.impersonation-banner__content {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    color: #8a4b08;
    font-size: 0.875rem;
    font-weight: 700;
}

.impersonation-banner__button {
    padding: 0.6rem 0.9rem;
    border: 0;
    border-radius: 0.5rem;
    background: #8a4b08;
    color: #ffffff;
    font-size: 0.8125rem;
    font-weight: 700;
    cursor: pointer;
}

.page-login {
    min-height: 100vh;
    background: linear-gradient(180deg, #f8f9fa 0%, #eef2f4 100%);
}

.login-page {
    display: flex;
    min-height: 100vh;
    align-items: center;
    justify-content: center;
    padding: 2rem;
}

.login-card {
    width: min(100%, 28rem);
    padding: 2rem;
    background: #ffffff;
    border-radius: 1rem;
    box-shadow: 0 20px 40px rgba(15, 23, 42, 0.08);
}

.login-card__header {
    margin-bottom: 1.5rem;
}

.login-card__eyebrow {
    margin: 0 0 0.35rem;
    color: var(--color-secondary);
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.2em;
    text-transform: uppercase;
}

.login-card__header h1 {
    margin: 0 0 0.5rem;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 2rem;
    font-weight: 800;
}

.login-card__header p {
    margin: 0;
    color: var(--color-text-muted);
    line-height: 1.6;
}

.login-card__error {
    margin-bottom: 1rem;
    padding: 0.85rem 1rem;
    background: rgba(186, 26, 26, 0.08);
    color: #ba1a1a;
    border-radius: 0.75rem;
    font-size: 0.875rem;
    font-weight: 700;
}

.login-card__field {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    margin-bottom: 1rem;
}

.login-card__field span {
    color: var(--color-text-muted);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.login-card__field input {
    width: 100%;
    padding: 0.85rem 1rem;
    border: 1px solid var(--color-border);
    border-radius: 0.5rem;
    font: inherit;
}

.login-card__submit {
    width: 100%;
    margin-top: 0.5rem;
    padding: 0.9rem 1rem;
    border: 0;
    border-radius: 0.5rem;
    background: var(--color-primary);
    color: #ffffff;
    font-size: 0.875rem;
    font-weight: 700;
    cursor: pointer;
}

.login-card__auth0-button {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    width: 100%;
    padding: 0.9rem 1rem;
    border: 1px solid var(--color-border);
    border-radius: 0.5rem;
    background: var(--color-surface-low);
    color: var(--color-primary);
    font-size: 0.875rem;
    font-weight: 800;
    text-decoration: none;
}

.login-card__auth0-button .material-symbols-outlined {
    font-size: 1.1rem;
}

.login-card__divider {
    position: relative;
    margin: 1rem 0 1rem;
    text-align: center;
}

.login-card__divider::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    height: 1px;
    background: var(--color-border);
}

.login-card__divider span {
    position: relative;
    padding: 0 0.75rem;
    background: #ffffff;
    color: var(--color-text-muted);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.login-card__hint {
    margin-top: 1.25rem;
    padding: 1rem;
    background: var(--color-surface-low);
    border-radius: 0.75rem;
}

.login-card__hint p {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.8125rem;
    line-height: 1.6;
}

.login-card__hint p + p {
    margin-top: 0.35rem;
}

.login-card__credentials {
    margin: 0.5rem 0 0;
    padding: 0.85rem 1rem;
    overflow-x: auto;
    background: #ffffff;
    border: 1px solid var(--color-border);
    border-radius: 0.5rem;
    color: var(--color-primary);
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 0.85rem;
    line-height: 1.7;
    white-space: pre;
}

.users-admin-grid {
    display: grid;
    grid-template-columns: minmax(0, 24rem) minmax(0, 1fr);
    gap: 1.5rem;
}

.users-admin__panel-header {
    margin-bottom: 1rem;
}

.users-admin__panel-header h3 {
    margin: 0;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 1.2rem;
    font-weight: 800;
}

.users-admin__form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.users-admin__field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.users-admin__password-field {
    position: relative;
}

.users-admin__field span,
.users-admin__permissions p {
    color: var(--color-text-muted);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.users-admin__field input,
.users-admin__field select,
.users-admin__active-toggle select {
    width: 100%;
    padding: 0.7rem 0.85rem;
    border: 1px solid var(--color-border);
    border-radius: 0.5rem;
    font: inherit;
    background: #ffffff;
    min-height: 2.75rem;
}

.users-admin__password-field input {
    padding-right: 3rem;
}

.users-admin__password-toggle {
    position: absolute;
    top: 50%;
    right: 0.6rem;
    transform: translateY(-50%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--color-text-muted);
    cursor: pointer;
}

.users-admin__password-toggle:hover,
.users-admin__password-toggle:focus-visible {
    background: rgba(226, 232, 240, 0.5);
    color: var(--color-primary);
    outline: none;
}

.users-admin__roles {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1rem;
}

.users-admin__role-option {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.5rem 0.75rem;
    background: var(--color-surface-low);
    border-radius: 999px;
    font-size: 0.8125rem;
    font-weight: 700;
}

.users-admin__group-option {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.5rem 0.75rem;
    background: #ffffff;
    border: 1px solid var(--color-surface-mid);
    border-radius: 999px;
    font-size: 0.8125rem;
    font-weight: 700;
}

.users-admin__multi-select {
    width: 100%;
    min-height: 11rem;
    padding: 0.35rem;
    border: 1px solid var(--color-border);
    border-radius: 0.5rem;
    background: #ffffff;
    font: inherit;
}

.users-admin__multi-select option {
    padding: 0.55rem 0.65rem;
    border-radius: 0.35rem;
}

.users-admin__role-impersonate {
    padding: 0.55rem 0.85rem;
    border: 1px solid var(--color-border);
    border-radius: 999px;
    background: #ffffff;
    color: var(--color-primary);
    font-size: 0.8125rem;
    font-weight: 700;
    cursor: pointer;
}

.users-admin__role-impersonate.is-active {
    background: rgba(0, 67, 84, 0.08);
    border-color: rgba(0, 67, 84, 0.2);
}

.users-admin__role-impersonate--stop {
    background: rgba(186, 26, 26, 0.08);
    border-color: rgba(186, 26, 26, 0.14);
    color: #ba1a1a;
}

.users-admin__user-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.users-admin__user-shell {
    border: 1px solid rgba(14, 105, 122, 0.1);
    border-radius: 1rem;
    overflow: hidden;
    background:
        radial-gradient(circle at top right, rgba(14, 105, 122, 0.08), transparent 30%),
        linear-gradient(180deg, #ffffff, rgba(247, 250, 252, 0.96));
    box-shadow: 0 14px 28px rgba(15, 23, 42, 0.05);
}

.users-admin__user-card {
    padding: 1rem;
    background: transparent;
    border-radius: 0;
    border: 0;
    box-shadow: none;
}

.users-admin__user-card-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.users-admin__user-card-top h4 {
    margin: 0;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 1rem;
    font-weight: 800;
}

.users-admin__user-card-top p {
    margin: 0.2rem 0 0;
    color: var(--color-text-muted);
    font-size: 0.8rem;
}

.users-admin__meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    margin-bottom: 0.85rem;
}

.users-admin__meta-chip {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: rgba(14, 105, 122, 0.08);
    color: var(--color-primary);
    font-size: 0.75rem;
    font-weight: 700;
}

.users-admin__meta-button {
    padding: 0.45rem 0.8rem;
    border: 1px solid var(--color-border);
    border-radius: 999px;
    background: #ffffff;
    color: var(--color-primary);
    font-size: 0.75rem;
    font-weight: 800;
    cursor: pointer;
}

.users-admin__active-toggle {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    min-width: 6rem;
}

.users-admin__permissions {
    margin-top: 1rem;
}

.users-admin__permissions div {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.5rem;
}

.users-admin__permissions code {
    padding: 0.35rem 0.5rem;
    background: #ffffff;
    border-radius: 0.4rem;
    color: var(--color-primary);
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 0.75rem;
    font-weight: 700;
}

.users-admin__group-flags {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    margin-top: 1rem;
}

.users-admin__field--wide {
    grid-column: 1 / -1;
}

.users-admin__delete-button {
    padding: 0.8rem 1.2rem;
    border: 1px solid rgba(186, 26, 26, 0.18);
    border-radius: 0.5rem;
    background: rgba(186, 26, 26, 0.08);
    color: #ba1a1a;
    font-size: 0.875rem;
    font-weight: 700;
    cursor: pointer;
}

.users-admin__action-panel {
    margin-top: 0;
    padding: 1rem;
    border-top: 1px solid rgba(14, 105, 122, 0.1);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.55), rgba(241, 245, 249, 0.9));
}

.users-admin__action-panel .users-admin__panel-header {
    margin-bottom: 0.75rem;
}

.users-admin__action-panel > form + form,
.users-admin__action-panel > form + .users-admin__danger-actions {
    margin-top: 0.85rem;
    padding-top: 0.85rem;
    border-top: 1px solid rgba(14, 105, 122, 0.08);
}

.users-admin__danger-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    margin-top: 1rem;
}

.users-admin__danger-actions form {
    margin: 0;
}

.users-admin__danger-button {
    width: 100%;
    padding: 0.8rem 1.2rem;
    border: 1px solid rgba(186, 26, 26, 0.18);
    border-radius: 0.5rem;
    background: rgba(186, 26, 26, 0.08);
    color: #ba1a1a;
    font-size: 0.875rem;
    font-weight: 700;
    cursor: pointer;
}

.users-admin__danger-button--secondary {
    border-color: rgba(14, 105, 122, 0.18);
    background: rgba(14, 105, 122, 0.08);
    color: var(--color-primary);
}

.users-admin__danger-button:hover,
.users-admin__danger-button:focus-visible,
.users-admin__meta-button:hover,
.users-admin__meta-button:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 10px 18px rgba(15, 23, 42, 0.08);
}

.users-admin__logs-panel {
    width: min(100%, 48rem);
}

.users-admin__logs-body {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.users-admin__logs-subtitle {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.9rem;
}

.users-admin__logs-state {
    padding: 1rem;
    border: 1px dashed var(--color-border);
    border-radius: 0.85rem;
    color: var(--color-text-muted);
    background: rgba(247, 250, 252, 0.75);
}

.users-admin__logs-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    max-height: 24rem;
    overflow-y: auto;
}

.users-admin__log-item {
    padding: 0.9rem 1rem;
    border: 1px solid var(--color-border);
    border-radius: 0.85rem;
    background: #ffffff;
}

.users-admin__log-item-top {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: baseline;
}

.users-admin__log-item-top strong {
    color: var(--color-primary);
    font-size: 0.95rem;
}

.users-admin__log-item-top span {
    color: var(--color-text-muted);
    font-size: 0.8rem;
    white-space: nowrap;
}

.users-admin__log-item-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin-top: 0.5rem;
    color: var(--color-text-muted);
    font-size: 0.8rem;
}


.fabrication-entry__table-row--draft {
    background: rgba(0, 67, 84, 0.03);
}

.fabrication-entry__table-row--draft td:first-child input {
    color: var(--color-primary);
    font-weight: 700;
}

.fabrication-entry__table-row--staged {
    opacity: 0.55;
    background: rgba(63, 72, 76, 0.04);
    pointer-events: none;
}

.fabrication-entry__table-row--staged td {
    color: var(--color-text-muted);
    font-size: 0.875rem;
}

.fabrication-entry__pallet-staged-value {
    font-weight: 600;
    color: var(--color-text-muted);
    padding: 0 0.25rem;
}

.fabrication-entry__staged-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #2e7d32;
}

.fabrication-entry__staged-badge .material-symbols-outlined {
    font-size: 1rem;
    color: #2e7d32;
}

.fabrication-entry__staged-badge--dispatched {
    color: #1565c0;
}

.fabrication-entry__staged-badge--dispatched .material-symbols-outlined {
    color: #1565c0;
}

.fabrication-entry__staged-badge--received {
    color: #6a1b9a;
}

.fabrication-entry__staged-badge--received .material-symbols-outlined {
    color: #6a1b9a;
}

.fabrication-entry__stage-lot {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border: 1.5px solid var(--color-primary);
    border-radius: 6px;
    background: transparent;
    color: var(--color-primary);
    cursor: pointer;
    transition: background var(--transition), color var(--transition);
    flex-shrink: 0;
}

.fabrication-entry__stage-lot:hover:not(:disabled) {
    background: var(--color-primary);
    color: #ffffff;
}

.fabrication-entry__stage-lot:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.fabrication-entry__stage-lot .material-symbols-outlined {
    font-size: 1.1rem;
}

.fabrication-entry__footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 2rem;
    margin-top: 2rem;
}

.fabrication-entry__footer p {
    margin: 0;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 1.875rem;
    font-weight: 800;
}

.fabrication-entry__stage {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1.25rem 2.5rem;
    border: 2px solid var(--color-primary);
    border-radius: 0.75rem;
    background: transparent;
    color: var(--color-primary);
    font-size: 1.125rem;
    font-weight: 700;
    cursor: pointer;
    transition: background var(--transition), color var(--transition), transform var(--transition);
}

.fabrication-entry__stage:hover:not(:disabled) {
    background: var(--color-primary);
    color: #ffffff;
    transform: scale(1.02);
}

.fabrication-entry__stage:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.fabrication-entry__complete {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1.25rem 3rem;
    border: 0;
    border-radius: 0.75rem;
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-strong));
    color: #ffffff;
    font-size: 1.125rem;
    font-weight: 700;
    box-shadow: 0 18px 36px rgba(0, 67, 84, 0.2);
    cursor: pointer;
    transition: transform var(--transition), box-shadow var(--transition);
}

.fabrication-entry__complete:hover:not(:disabled) {
    transform: scale(1.02);
    box-shadow: 0 22px 40px rgba(0, 67, 84, 0.24);
}

.fabrication-entry__complete--saving {
    opacity: 0.75;
    cursor: not-allowed;
    transform: none !important;
}

.fabrication-entry__complete--saving .material-symbols-outlined {
    animation: fab-spin 0.9s linear infinite;
}

@keyframes fab-spin {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}

@keyframes fabrication-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.4; }
}


.dashboard-aside {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.status-card {
    padding: 2rem;
    background: var(--color-surface-low);
    border: 1px solid rgba(255, 255, 255, 0.4);
    border-radius: 1rem;
    backdrop-filter: blur(12px);
}

.status-card__title {
    margin-bottom: 1.5rem;
    color: var(--color-primary);
}

.progress-card {
    background: transparent;
}

.progress-card__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.5rem;
    color: var(--color-text);
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: uppercase;
}

.progress-card__value {
    color: var(--color-primary);
}

.progress-track {
    overflow: hidden;
    height: 0.75rem;
    background: var(--color-surface-mid);
    border-radius: 999px;
}

.progress-fill {
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--color-primary), var(--color-primary-strong));
}

.mobile-nav {
    position: fixed;
    inset: auto 0 0;
    display: none;
    align-items: center;
    justify-content: space-around;
    gap: 0.5rem;
    padding: 0.8rem 0.9rem calc(0.8rem + env(safe-area-inset-bottom));
    background: rgba(255, 255, 255, 0.96);
    border-top: 1px solid rgba(226, 232, 240, 1);
    z-index: 30;
}

.mobile-nav__item {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 0.2rem;
    color: var(--color-nav-text);
    font-size: 0.68rem;
    font-weight: 700;
}

.mobile-nav__item.is-active {
    color: var(--color-primary);
}

.mobile-nav__item.is-active .material-symbols-outlined {
    font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24;
}

body.modal-open {
    overflow: hidden;
}

.modal {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition);
    z-index: 90;
}

.modal.is-open {
    opacity: 1;
    pointer-events: auto;
}

.modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(25, 28, 29, 0.5);
}

.modal__panel {
    position: relative;
    width: min(100%, 28rem);
    background: #ffffff;
    border-radius: 1rem;
    box-shadow: 0 24px 48px rgba(15, 23, 42, 0.22);
    overflow: hidden;
    transform: scale(0.96);
    transition: transform 200ms ease;
}

.modal__panel.planning-request-modal__panel {
    width: min(100%, 92rem);
    max-height: min(88vh, 56rem);
}

.modal.is-open .modal__panel {
    transform: scale(1);
}

.modal__panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.5rem;
    border-bottom: 1px solid #f1f5f9;
}

.modal__panel-title {
    margin: 0;
    color: var(--color-primary);
    font-family: "Manrope", sans-serif;
    font-size: 1.25rem;
    font-weight: 700;
}

.modal__close-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: #94a3b8;
    cursor: pointer;
    transition: color var(--transition);
}

.modal__close-button:hover,
.modal__close-button:focus-visible {
    color: #475569;
    outline: none;
}

.modal__panel-body {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    padding: 1.5rem;
}

.modal__part-summary {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    background: #f8fafc;
    border-radius: 0.75rem;
}

.modal__part-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 0.5rem;
    background: rgba(0, 67, 84, 0.1);
    color: var(--color-primary);
}

.modal__summary-label,
.modal__field-label {
    margin: 0;
    color: #64748b;
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.2em;
    text-transform: uppercase;
}

.modal__summary-value {
    margin-top: 0.125rem;
    font-size: 1.125rem;
    font-weight: 700;
}

.modal__form-block {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.modal__warning {
    display: flex;
    gap: 0.75rem;
    padding: 1rem;
    background: #fffbeb;
    border: 1px solid #fde68a;
    border-radius: 0.75rem;
}

.modal__warning .material-symbols-outlined {
    flex-shrink: 0;
    color: #d97706;
}

.modal__warning p {
    margin: 0;
    color: #92400e;
    font-size: 0.75rem;
    font-weight: 500;
    line-height: 1.6;
}

.modal__field-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.modal__quantity-input {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid #bfc8cc;
    border-radius: 0.5rem;
    background: #f8f9fa;
    color: var(--color-text);
    font-size: 1.125rem;
    font-weight: 700;
    outline: none;
    transition:
        border-color var(--transition),
        box-shadow var(--transition);
}

.modal__quantity-input:focus {
    border-color: transparent;
    box-shadow: 0 0 0 2px var(--color-primary);
}

.modal__field-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0 0.25rem;
    color: #64748b;
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.modal__difference {
    color: #d97706;
}

.modal__panel-footer {
    display: flex;
    gap: 0.75rem;
    padding: 1rem 1.5rem;
    background: rgba(248, 250, 252, 0.9);
}

.modal__footer-button {
    flex: 1;
    padding: 0.75rem 1rem;
    border-radius: 0.5rem;
    font-size: 0.95rem;
    font-weight: 700;
    cursor: pointer;
    transition:
        opacity var(--transition),
        background-color var(--transition);
}

.modal__footer-button:hover,
.modal__footer-button:focus-visible {
    opacity: 0.9;
    outline: none;
}

.modal__footer-button--secondary {
    border: 1px solid #e2e8f0;
    background: transparent;
    color: #475569;
}

.modal__footer-button--primary {
    border: 0;
    background: var(--color-primary);
    color: #ffffff;
    box-shadow: 0 10px 25px rgba(0, 67, 84, 0.2);
}

body.nav-open {
    overflow: hidden;
}

body.nav-open .app-overlay {
    opacity: 1;
    pointer-events: auto;
}

@media (max-width: 1199px) {
    .dashboard-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 1023px) {
    .sidebar {
        transform: translateX(-100%);
        transition: transform var(--transition);
    }

    body.nav-open .sidebar {
        transform: translateX(0);
    }

    .app-frame {
        margin-left: 0;
    }

    body.sidebar-collapsed .app-frame {
        margin-left: 0;
    }

    .topbar__menu-button {
        display: inline-flex;
    }

    .topbar__left {
        display: none;
    }

    .topbar__sidebar-toggle {
        display: none;
    }

    .topbar__mobile-trigger {
        justify-content: flex-start;
    }

    .app-main {
        padding-bottom: 7rem;
    }

    .page-planning .app-main {
        padding-left: 1.5rem;
        padding-right: 1.5rem;
    }
}

@media (max-width: 900px) {
    .receipt-card__content {
        flex-direction: column;
        align-items: stretch;
    }

    .receipt-card__metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .action-button {
        width: 100%;
    }
}

@media (max-width: 767px) {
    .topbar__content,
    .app-main {
        width: min(calc(100% - 2rem), var(--content-max-width));
    }

    .page-inventory .app-main,
    .page-fabrication .app-main,
    .page-logistics .app-main,
    .page-assembly .app-main {
        width: 100%;
        max-width: 100%;
        margin-left: 0;
        margin-right: 0;
    }

    .topbar__content {
        padding: 0.85rem 0;
    }

    .section-nav {
        display: none;
    }

    .dashboard-header {
        margin-bottom: 1.5rem;
    }

    .mobile-nav {
        display: flex;
    }

    .planning-hero__grid {
        grid-template-columns: 1fr;
    }

    .planning-filters__fields {
        flex-direction: column;
        min-width: 100%;
    }

    .planning-table-shell {
        overflow-x: auto;
    }

    .planning-table {
        min-width: 54rem;
    }
}

@media (max-width: 640px) {
    .receipt-card__metrics {
        grid-template-columns: 1fr;
    }

    .progress-card__row {
        flex-direction: column;
        align-items: flex-start;
    }

    .modal {
        padding: 1rem;
    }

    .modal__panel {
        width: 100%;
    }

    .modal__field-meta,
    .modal__panel-footer {
        flex-direction: column;
        align-items: stretch;
    }

    .modal__field-meta {
        padding: 0;
    }

    .modal__footer-button {
        width: 100%;
    }
}

/* ─── Pallets Admin ──────────────────────────────────────────────────────── */

.pallets-admin {
    padding: 2rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    min-height: 100%;
}

.pallets-admin__eyebrow {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
    margin: 0 0 0.25rem;
}

.pallets-admin__header h2 {
    margin: 0 0 0.375rem;
    font-size: 1.5rem;
}

.pallets-admin__subtitle {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.875rem;
}

.pallets-admin__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.pallets-admin__toolbar {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.pallets-admin__filters {
    display: flex;
    gap: 0.375rem;
    flex-wrap: wrap;
}

.pallet-filter-chip {
    padding: 0.3rem 0.75rem;
    border-radius: 999px;
    border: 1px solid var(--color-border);
    background: transparent;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--color-text-muted);
    cursor: pointer;
    transition: background 0.12s, color 0.12s, border-color 0.12s;
}

.pallet-filter-chip:hover {
    background: var(--color-bg-hover, rgba(0,0,0,0.04));
    color: var(--color-text);
}

.pallet-filter-chip.is-active {
    background: var(--color-accent, #1a56db);
    border-color: var(--color-accent, #1a56db);
    color: #fff;
}

.pallets-admin__search {
    flex: 1;
    min-width: 200px;
    max-width: 320px;
    padding: 0.4rem 0.75rem;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    font-size: 0.875rem;
    background: var(--color-bg-input, #fff);
    color: var(--color-text);
}

.pallets-admin__table-shell {
    border: 1px solid var(--color-border);
    border-radius: 8px;
    overflow: hidden;
}

.pallets-admin__table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}

.pallets-admin__table thead tr {
    background: var(--color-bg-subtle, #f9fafb);
}

.pallets-admin__table th {
    padding: 0.625rem 0.875rem;
    text-align: left;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-text-muted);
    white-space: nowrap;
    border-bottom: 1px solid var(--color-border);
}

.pallets-admin__table tbody td {
    padding: 0.625rem 0.875rem;
    border-bottom: 1px solid var(--color-border);
    vertical-align: middle;
}

.pallets-admin__row:last-of-type td {
    border-bottom: none;
}

.pallets-admin__row:hover td {
    background: var(--color-bg-hover, rgba(0,0,0,0.02));
}

.pallets-admin__expand-cell {
    width: 2rem;
    padding: 0 0.25rem 0 0.5rem !important;
}

.pallet-expand-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    border: none;
    background: transparent;
    border-radius: 4px;
    cursor: pointer;
    color: var(--color-text-muted);
    transition: color 0.1s;
}

.pallet-expand-btn .material-symbols-outlined {
    font-size: 1.1rem;
    transition: transform 0.15s;
}

.pallet-expand-btn.is-expanded .material-symbols-outlined {
    transform: rotate(90deg);
}

.pallets-admin__pallet-num {
    font-weight: 600;
    font-family: var(--font-mono, monospace);
    font-size: 0.8125rem;
}

.pallets-admin__wo {
    font-family: var(--font-mono, monospace);
    font-size: 0.8125rem;
}

.pallets-admin__lot-count {
    text-align: center;
    font-weight: 600;
}

.pallets-admin__actions {
    white-space: nowrap;
}

/* Status badges */
.pallet-badge {
    display: inline-block;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.pallet-badge--open    { background: #f3f4f6; color: #6b7280; }
.pallet-badge--staged  { background: #dcfce7; color: #166534; }
.pallet-badge--dispatched { background: #dbeafe; color: #1d4ed8; }
.pallet-badge--received { background: #ede9fe; color: #5b21b6; }
.pallet-badge--void    { background: #fee2e2; color: #991b1b; }

/* Release button */
.pallet-release-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.3rem 0.625rem;
    border-radius: 6px;
    border: 1px solid var(--color-border);
    background: transparent;
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--color-text);
    cursor: pointer;
    transition: background 0.1s, border-color 0.1s;
}

.pallet-release-btn:hover {
    background: var(--color-bg-hover, rgba(0,0,0,0.04));
    border-color: var(--color-text-muted);
}

.pallet-release-btn:disabled {
    opacity: 0.5;
    cursor: default;
}

.pallet-release-btn .material-symbols-outlined {
    font-size: 0.95rem;
}

/* Expanded lot detail rows */
.pallets-admin__detail-row td {
    padding: 0 !important;
    border-bottom: 2px solid var(--color-accent, #1a56db) !important;
}

.pallets-admin__detail-cell {
    background: var(--color-bg-subtle, #f9fafb);
    padding: 0 !important;
}

.pallets-admin__lots-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.8125rem;
}

.pallets-admin__lots-table th {
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-text-muted);
    border-bottom: 1px solid var(--color-border);
    text-align: left;
}

.pallets-admin__lots-table th:first-child,
.pallets-admin__lot-row td:first-child {
    padding-left: 1.75rem;
}

.pallets-admin__lot-row td {
    padding: 0.5rem 1.125rem;
    border-bottom: 1px solid var(--color-border);
    vertical-align: middle;
}

.pallets-admin__lot-row:last-child td {
    border-bottom: none;
}

.pallets-admin__lots-table th {
    padding: 0.4rem 1.125rem;
}

.pallets-admin__lot-number {
    font-family: var(--font-mono, monospace);
    font-size: 0.78rem;
    color: var(--color-text-muted);
}

.pallets-admin__lot-desc {
    color: var(--color-text-muted);
    max-width: 260px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.pallets-admin__lot-qty {
    font-weight: 600;
    text-align: right;
}

.pallets-admin__no-lots {
    padding: 0.75rem 1.125rem !important;
    color: var(--color-text-muted);
    font-style: italic;
}

.pallet-lot-status {
    display: inline-block;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    line-height: 1.4;
    white-space: nowrap;
}

.pallet-lot-status--open       { background: #f3f4f6; color: #6b7280; }
.pallet-lot-status--staged     { background: #dcfce7; color: #166534; }
.pallet-lot-status--dispatched { background: #dbeafe; color: #1d4ed8; }
.pallet-lot-status--received   { background: #ede9fe; color: #5b21b6; }
.pallet-lot-status--void       { background: #fee2e2; color: #991b1b; }

.pallet-rev {
    font-size: 0.75rem;
    color: var(--color-text-muted);
}

/* Empty / loading states */
.pallets-admin__empty,
.pallets-admin__loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    padding: 4rem 2rem;
    color: var(--color-text-muted);
    text-align: center;
}

.pallets-admin__empty[hidden],
.pallets-admin__loading[hidden] {
    display: none;
}

.pallets-admin__empty .material-symbols-outlined,
.pallets-admin__loading .material-symbols-outlined {
    font-size: 2.5rem;
    opacity: 0.4;
}

.pallets-admin__empty p,
.pallets-admin__loading p {
    margin: 0;
    font-size: 1rem;
}

.pallets-admin__status {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    text-align: center;
    margin: 0;
    padding-bottom: 1rem;
}

/* ─── Toast messages ─────────────────────────────────────────────────────── */

#toast-rack {
    position: fixed;
    bottom: 1.5rem;
    right: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    z-index: 1000;
    pointer-events: none;
}

.toast {
    padding: 0.75rem 1.125rem;
    border-radius: 8px;
    font-size: 0.875rem;
    font-weight: 500;
    color: #fff;
    background: #1f2937;
    box-shadow: 0 4px 12px rgba(0,0,0,0.18);
    opacity: 0;
    transform: translateY(0.5rem);
    transition: opacity 0.2s, transform 0.2s;
    max-width: 340px;
}

.toast--visible {
    opacity: 1;
    transform: translateY(0);
}

.toast--error {
    background: #dc2626;
}

.toast--success {
    background: #16a34a;
}

/* ─── Confirm modal ──────────────────────────────────────────────────────── */

.confirm-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 900;
    opacity: 0;
    transition: opacity 0.15s;
}

.confirm-modal-overlay--visible {
    opacity: 1;
}

.confirm-modal {
    background: var(--color-bg, #fff);
    border-radius: 10px;
    padding: 1.5rem;
    max-width: 380px;
    width: calc(100% - 2rem);
    box-shadow: 0 8px 32px rgba(0,0,0,0.18);
    transform: translateY(4px);
    transition: transform 0.15s;
}

.confirm-modal-overlay--visible .confirm-modal {
    transform: translateY(0);
}

.confirm-modal__title {
    margin: 0 0 0.5rem;
    font-size: 1rem;
    font-weight: 700;
}

.confirm-modal__body {
    margin: 0 0 1.25rem;
    font-size: 0.875rem;
    color: var(--color-text-muted);
    line-height: 1.5;
}

.confirm-modal__footer {
    display: flex;
    justify-content: flex-end;
    gap: 0.625rem;
}

.confirm-modal__cancel {
    padding: 0.45rem 1rem;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    background: transparent;
    font-size: 0.875rem;
    cursor: pointer;
    color: var(--color-text);
}

.confirm-modal__cancel:hover {
    background: var(--color-bg-hover, rgba(0,0,0,0.04));
}

.confirm-modal__confirm {
    padding: 0.45rem 1rem;
    border: none;
    border-radius: 6px;
    background: var(--color-accent, #1a56db);
    color: #fff;
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
}

.confirm-modal__confirm:hover {
    filter: brightness(1.08);
}

/* Pallet search dropdown (portal, lives on body) */
.pallet-search-dropdown {
    z-index: 9998;
    background: #ffffff;
    border: 1px solid #bfc8cc;
    border-radius: 0.625rem;
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.14), 0 2px 8px rgba(0, 0, 0, 0.08);
    list-style: none;
    margin: 0;
    padding: 0.3rem 0;
    max-height: 14rem;
    overflow-y: auto;
}

.pallet-search-dropdown__item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.875rem;
    cursor: pointer;
    font-size: 0.875rem;
    transition: background 0.08s;
}

.pallet-search-dropdown__item:hover,
.pallet-search-dropdown__item.is-active {
    background: rgba(var(--color-primary-rgb, 30, 100, 210), 0.07);
}

.pallet-search-dropdown__item .material-symbols-outlined {
    font-size: 1rem;
    color: var(--color-text-muted);
    flex-shrink: 0;
}

.pallet-search-dropdown__name {
    font-weight: 600;
    font-size: 0.8125rem;
    font-family: var(--font-mono, monospace);
    color: var(--color-text);
}

.pallet-search-dropdown__empty {
    padding: 0.6rem 0.875rem;
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    font-style: italic;
}

.pallet-search-dropdown__item--create {
    border-top: 1px solid rgba(0, 0, 0, 0.06);
    margin-top: 0.2rem;
    color: var(--color-primary, #1e64d2);
}

.pallet-search-dropdown__item--create .material-symbols-outlined {
    color: var(--color-primary, #1e64d2);
}

.pallet-search-dropdown__item--create .pallet-search-dropdown__name {
    color: var(--color-primary, #1e64d2);
    font-style: italic;
}

/* New Pallet form inside modal */
.new-pallet-form {
    display: flex;
    flex-direction: column;
    gap: 0.875rem;
    margin-bottom: 1.25rem;
}

.new-pallet-form__field {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--color-text);
}

.new-pallet-form__input {
    padding: 0.45rem 0.625rem;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    font-size: 0.875rem;
    background: var(--color-bg-input, #fff);
    color: var(--color-text);
}

.new-pallet-form__textarea {
    min-height: 14rem;
    padding: 0.625rem 0.75rem;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    font: inherit;
    font-size: 0.875rem;
    line-height: 1.5;
    background: var(--color-bg-input, #fff);
    color: var(--color-text);
    resize: vertical;
}

.new-pallet-form__hint {
    margin: 0;
    font-size: 0.78rem;
    color: var(--color-text-muted);
    line-height: 1.45;
}

/* ─────────────────────────────────────────────────────────────────────────────
   Operations Dashboard
   ───────────────────────────────────────────────────────────────────────────── */

.ops-dashboard {
    padding: 2rem 2.5rem 4rem;
    min-height: 100%;
}

.ops-dashboard__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.ops-dashboard__eyebrow {
    margin: 0 0 0.25rem;
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-primary);
    opacity: 0.7;
}

.ops-dashboard__header h2 {
    margin: 0 0 0.375rem;
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--color-text);
}

.ops-dashboard__subtitle {
    margin: 0;
    font-size: 0.875rem;
    color: var(--color-text-muted);
    max-width: 52ch;
}

.ops-dashboard__header-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-shrink: 0;
}

.ops-dashboard__snapshot-time {
    margin: 0;
    font-size: 0.75rem;
    color: var(--color-text-muted);
    white-space: nowrap;
}

.ops-dashboard__loading {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 3rem 0;
    font-size: 0.9375rem;
    color: var(--color-text-muted);
}

.ops-dashboard__loading .material-symbols-outlined {
    font-size: 1.5rem;
    animation: spin 1.2s linear infinite;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* ── Pipeline stat strip ─────────────────────────────────────────────────── */

.ops-dashboard__pipeline {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1.75rem;
    padding: 1.25rem 1.5rem;
    background: var(--color-surface);
    border: 1px solid rgba(191, 200, 204, 0.55);
    border-radius: 1rem;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
    overflow-x: auto;
}

.dash-stat-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    min-width: 0;
}

.dash-stat-group__label {
    margin: 0;
    font-size: 0.625rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-primary);
    opacity: 0.6;
    white-space: nowrap;
}

.dash-stat-group__cards {
    display: flex;
    gap: 0.5rem;
}

.dash-stat-group__arrow {
    flex-shrink: 0;
    color: var(--color-border);
    font-size: 1.25rem;
    padding: 0 0.25rem;
    margin-top: 1.25rem;
}

.dash-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.2rem;
    padding: 0.625rem 1rem;
    border-radius: 0.625rem;
    border: 1px solid transparent;
    min-width: 5.5rem;
    text-align: center;
    background: var(--color-surface-low);
}

.dash-stat__value {
    font-size: 1.625rem;
    font-weight: 800;
    line-height: 1;
    color: var(--color-text);
    letter-spacing: -0.02em;
}

.dash-stat__label {
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    white-space: nowrap;
}

/* Stat colour variants */
.dash-stat--active { background: rgba(0, 67, 84, 0.06); border-color: rgba(0, 67, 84, 0.15); }
.dash-stat--active .dash-stat__value { color: var(--color-primary); }

.dash-stat--fab-staged { background: rgba(9, 105, 218, 0.05); border-color: rgba(9, 105, 218, 0.15); }
.dash-stat--fab-staged .dash-stat__value { color: #0550ae; }

.dash-stat--fab-dispatched { background: rgba(154, 106, 5, 0.06); border-color: rgba(154, 106, 5, 0.15); }
.dash-stat--fab-dispatched .dash-stat__value { color: #7a5500; }

.dash-stat--pallet-transit { background: rgba(154, 106, 5, 0.06); border-color: rgba(154, 106, 5, 0.15); }
.dash-stat--pallet-transit .dash-stat__value { color: #7a5500; }

.dash-stat--pallet-received { background: rgba(26, 127, 55, 0.06); border-color: rgba(26, 127, 55, 0.15); }
.dash-stat--pallet-received .dash-stat__value { color: #1a7f37; }

/* ── Main grid ───────────────────────────────────────────────────────────── */

.ops-dashboard__grid {
    display: grid;
    grid-template-columns: 1fr 22rem;
    gap: 1.25rem;
    margin-bottom: 1.25rem;
    align-items: start;
}

.ops-dashboard__summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.ops-summary-card {
    padding: 1rem 1.25rem;
    background: var(--color-surface);
    border: 1px solid rgba(191, 200, 204, 0.55);
    border-radius: 1rem;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}

.ops-summary-card__label {
    display: block;
    color: var(--color-text-muted);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.ops-summary-card__value {
    display: block;
    margin-top: 0.5rem;
    color: var(--color-primary);
    font-size: 2rem;
    font-weight: 800;
    line-height: 1;
}

.ops-draft-list,
.ops-jobs-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.ops-draft-card {
    padding: 1rem 1.1rem;
    border: 1px solid rgba(191, 200, 204, 0.45);
    border-radius: 0.85rem;
    background: linear-gradient(180deg, #ffffff, rgba(247, 250, 252, 0.9));
}

.ops-draft-card__top {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
}

.ops-draft-card__top strong {
    color: var(--color-primary);
    font-size: 1rem;
}

.ops-draft-card__top p {
    margin: 0.25rem 0 0;
    color: var(--color-text-muted);
    font-size: 0.85rem;
}

.ops-draft-card__badge {
    padding: 0.3rem 0.7rem;
    border-radius: 999px;
    background: rgba(154, 106, 5, 0.1);
    color: #7a5500;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.ops-draft-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 0.85rem;
    color: var(--color-text-muted);
    font-size: 0.82rem;
}

.ops-job-card {
    border: 1px solid rgba(191, 200, 204, 0.45);
    border-radius: 1rem;
    overflow: hidden;
    background: linear-gradient(180deg, #ffffff, rgba(247, 250, 252, 0.92));
}

.ops-job-card__summary {
    width: 100%;
    padding: 1.1rem 1.25rem;
    border: 0;
    background: transparent;
    cursor: pointer;
    text-align: left;
}

.ops-job-card__summary-main {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.ops-job-card__eyebrow {
    color: var(--color-text-muted);
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.ops-job-card__summary h3 {
    margin: 0.2rem 0 0.25rem;
    color: var(--color-primary);
    font-size: 1.15rem;
    font-weight: 800;
}

.ops-job-card__summary p {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.9rem;
}

.ops-job-card__summary-progress {
    min-width: 16rem;
}

.ops-job-card__due {
    margin-top: 0.45rem;
    color: var(--color-text-muted);
    font-size: 0.82rem;
    text-align: right;
}

.ops-job-card__chevron {
    display: block;
    margin-top: 0.5rem;
    color: var(--color-text-muted);
}

.ops-job-card__parts {
    padding: 0 1.25rem 1.25rem;
    border-top: 1px solid rgba(191, 200, 204, 0.35);
    background: rgba(248, 250, 252, 0.75);
}

.ops-job-part {
    padding: 1rem 0;
    border-bottom: 1px solid rgba(191, 200, 204, 0.28);
}

.ops-job-part:last-child {
    border-bottom: 0;
}

.ops-job-part__header {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
}

.ops-job-part__header strong {
    color: var(--color-text);
    font-size: 0.96rem;
}

.ops-job-part__header span {
    display: block;
    margin-top: 0.2rem;
    color: var(--color-text-muted);
    font-size: 0.84rem;
}

.ops-job-part__metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
    margin: 0.85rem 0;
}

.ops-job-part__metrics span {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    padding: 0.7rem 0.8rem;
    background: #ffffff;
    border: 1px solid rgba(191, 200, 204, 0.32);
    border-radius: 0.75rem;
}

.ops-job-part__metrics label {
    color: var(--color-text-muted);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.ops-job-part__metrics strong {
    color: var(--color-primary);
    font-size: 1rem;
    font-weight: 800;
}

.ops-job-part__status {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: rgba(191, 200, 204, 0.2);
    color: var(--color-text-muted);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
}

.ops-job-part__status--fabricated { background: rgba(0, 67, 84, 0.1); color: var(--color-primary); }
.ops-job-part__status--transit { background: rgba(154, 106, 5, 0.12); color: #7a5500; }
.ops-job-part__status--received { background: rgba(9, 105, 218, 0.12); color: #0550ae; }
.ops-job-part__status--complete { background: rgba(26, 127, 55, 0.12); color: #1a7f37; }

@media (max-width: 1100px) {
    .ops-dashboard__summary-grid {
        grid-template-columns: 1fr;
    }

    .ops-job-card__summary-main {
        flex-direction: column;
        align-items: flex-start;
    }

    .ops-job-card__summary-progress {
        min-width: 0;
        width: 100%;
    }

    .ops-job-card__due {
        text-align: left;
    }

    .ops-job-part__metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 1100px) {
    .ops-dashboard__grid {
        grid-template-columns: 1fr;
    }
}

/* ── Panel ───────────────────────────────────────────────────────────────── */

.dash-panel {
    background: var(--color-surface);
    border: 1px solid rgba(191, 200, 204, 0.55);
    border-radius: 1rem;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
    overflow: hidden;
    margin-bottom: 1.25rem;
}

.dash-panel--full {
    margin-bottom: 1.25rem;
}

.dash-panel__header {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    padding: 1rem 1.5rem;
    border-bottom: 1px solid rgba(191, 200, 204, 0.4);
    background: rgba(243, 244, 245, 0.5);
}

.dash-panel__header .material-symbols-outlined {
    font-size: 1.125rem;
    color: var(--color-primary);
    opacity: 0.8;
}

.dash-panel__header h3 {
    margin: 0;
    font-size: 0.8125rem;
    font-weight: 800;
    color: var(--color-text);
    letter-spacing: 0.01em;
    flex: 1;
}

.dash-panel__count {
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--color-text-muted);
    background: var(--color-surface-high);
    border-radius: 999px;
    padding: 0.15rem 0.6rem;
    min-width: 1.5rem;
    text-align: center;
}

.dash-panel__body {
    overflow-x: auto;
}

.dash-panel__empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 3rem 2rem;
    color: var(--color-text-muted);
    text-align: center;
}

.dash-panel__empty[hidden] {
    display: none;
}

.dash-panel__empty .material-symbols-outlined {
    font-size: 2rem;
    opacity: 0.35;
}

.dash-panel__empty p {
    margin: 0;
    font-size: 0.875rem;
}

/* ── Dashboard table ─────────────────────────────────────────────────────── */

.dash-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.8125rem;
}

.dash-table thead tr {
    background: rgba(231, 232, 233, 0.5);
}

.dash-table th {
    padding: 0.625rem 1.25rem;
    font-size: 0.625rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-secondary-text);
    text-align: left;
    white-space: nowrap;
    border-bottom: 1px solid rgba(191, 200, 204, 0.4);
}

.dash-table tbody tr {
    border-bottom: 1px solid rgba(191, 200, 204, 0.28);
    transition: background var(--transition);
}

.dash-table tbody tr:last-child {
    border-bottom: none;
}

.dash-table tbody tr:hover {
    background: rgba(0, 67, 84, 0.025);
}

.dash-table td {
    padding: 0.75rem 1.25rem;
    color: var(--color-text);
    vertical-align: middle;
}

.dash-table td.muted {
    color: var(--color-text-muted);
    font-size: 0.75rem;
}

/* ── Progress bar ────────────────────────────────────────────────────────── */

.dash-progress {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    min-width: 8rem;
}

.dash-progress__bar {
    flex: 1;
    height: 5px;
    background: rgba(0, 67, 84, 0.1);
    border-radius: 3px;
    overflow: hidden;
}

.dash-progress__fill {
    height: 100%;
    background: linear-gradient(90deg, var(--color-primary), var(--color-primary-strong));
    border-radius: 3px;
    transition: width 0.5s ease;
    min-width: 2px;
}

.dash-progress__fill--complete {
    background: linear-gradient(90deg, #1a7f37, #2da44e);
}

.dash-progress__pct {
    font-size: 0.6875rem;
    font-weight: 700;
    color: var(--color-text-muted);
    white-space: nowrap;
    min-width: 2.5rem;
    text-align: right;
}

/* ── Transaction type badge ──────────────────────────────────────────────── */

.dash-txn-badge {
    display: inline-block;
    padding: 0.2rem 0.55rem;
    border-radius: 0.35rem;
    font-size: 0.6875rem;
    font-weight: 700;
    white-space: nowrap;
    background: var(--color-surface-mid);
    color: var(--color-text-muted);
}

.dash-txn-badge--fab_complete_receipt    { background: rgba(0, 67, 84, 0.08);   color: var(--color-primary); }
.dash-txn-badge--move_to_fab_staging     { background: rgba(9, 105, 218, 0.08); color: #0550ae; }
.dash-txn-badge--dispatch_to_transit     { background: rgba(154, 106, 5, 0.1);  color: #7a5500; }
.dash-txn-badge--receive_from_transit    { background: rgba(26, 127, 55, 0.08); color: #1a7f37; }
.dash-txn-badge--issue_to_wip            { background: rgba(207, 34, 46, 0.07); color: #b91c1c; }
.dash-txn-badge--adjustment_gain         { background: rgba(26, 127, 55, 0.08); color: #1a7f37; }
.dash-txn-badge--adjustment_loss         { background: rgba(207, 34, 46, 0.07); color: #b91c1c; }
.dash-txn-badge--transfer_out            { background: rgba(88, 28, 135, 0.07); color: #6b21a8; }

/* ── Pallet number pill ──────────────────────────────────────────────────── */

.dash-pallet-pill {
    display: inline-block;
    padding: 0.15rem 0.55rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    background: rgba(0, 67, 84, 0.07);
    color: var(--color-primary);
    font-family: ui-monospace, monospace;
}
