html, body {
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
    background: #f3f2ee;
    color: #1f2933;
}

body {
    margin: 0;
}

a, .btn-link {
    color: #006bb7;
}

.btn-primary {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

.content {
    padding-top: 1.1rem;
}

h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
    text-align: start;
}

.project-board {
    display: grid;
    grid-template-columns: repeat(4, minmax(260px, 1fr));
    gap: 1rem;
    align-items: start;
}

.project-summary {
    display: grid;
    grid-template-columns: repeat(4, minmax(180px, 1fr));
    gap: 0.9rem;
    margin-bottom: 1rem;
}

.project-summary__card {
    background: #fcfbf8;
    border: 1px solid rgba(31, 41, 51, 0.09);
    border-radius: 16px;
    padding: 0.95rem 1rem;
}

.project-summary__label {
    margin: 0 0 0.35rem;
    font-size: 0.74rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #6b7280;
    font-weight: 700;
}

.project-summary__value {
    font-size: 1.55rem;
    line-height: 1;
    color: #142536;
}

.project-column {
    background: #ebe7df;
    border: 1px solid rgba(31, 41, 51, 0.08);
    border-radius: 18px;
    min-height: 24rem;
    overflow: hidden;
}

.project-column__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1rem 0.875rem;
    border-bottom: 1px solid rgba(31, 41, 51, 0.08);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.52), rgba(255, 255, 255, 0.12));
}

.project-column__eyebrow {
    margin: 0 0 0.25rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #6b7280;
}

.project-column__title {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
}

.project-column__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2rem;
    height: 2rem;
    padding: 0 0.65rem;
    border-radius: 999px;
    font-size: 0.85rem;
    font-weight: 700;
    border: 1px solid transparent;
}

.project-column__count--planning {
    background: #f8e7b6;
    border-color: #e0bf61;
    color: #7a5600;
}

.project-column__count--progress {
    background: #cfe6dc;
    border-color: #7db39b;
    color: #17533b;
}

.project-column__count--done {
    background: #dde5ec;
    border-color: #9cb1c3;
    color: #304a60;
}

.project-column__count--cancelled {
    background: #efd4d1;
    border-color: #cb8f86;
    color: #7d2f27;
}

.project-column__body {
    display: flex;
    flex-direction: column;
    gap: 0.875rem;
    padding: 1rem;
}

.project-card {
    background: #fcfbf8;
    border: 1px solid rgba(31, 41, 51, 0.1);
    border-radius: 16px;
    padding: 0.95rem;
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

.project-card--empty {
    min-height: 10rem;
    align-items: center;
    justify-content: center;
    color: #6b7280;
    border-style: dashed;
    background: rgba(255, 255, 255, 0.38);
}

.project-card--empty p {
    margin: 0;
}

.project-card__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.project-chip,
.project-flag {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 0.28rem 0.62rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.03em;
}

.project-chip--planning {
    background: #f7e4aa;
    color: #745100;
}

.project-chip--progress {
    background: #cfe7db;
    color: #134f38;
}

.project-chip--done {
    background: #d9e3ec;
    color: #314b61;
}

.project-chip--cancelled {
    background: #efd6d2;
    color: #7b3028;
}

.project-flag--danger {
    background: #8d2f25;
    color: #fff7f5;
}

.project-flag--warning {
    background: #f5ddba;
    color: #7a4e0c;
}

.project-flag--neutral {
    background: #dce4ec;
    color: #355068;
}

.project-card__content {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.project-card__signals {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    min-height: 1.7rem;
}

.project-card__title {
    font-size: 1.02rem;
    font-weight: 700;
    color: #142536;
    text-decoration: none;
}

.project-card__title:hover {
    text-decoration: underline;
}

.project-card__client {
    margin: 0;
    color: #5b6671;
    font-size: 0.92rem;
}

.project-card__metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
    margin: 0;
}

.project-card__metrics div {
    padding: 0.65rem 0.7rem;
    border-radius: 12px;
    background: #f2efe8;
    border: 1px solid rgba(31, 41, 51, 0.08);
}

.project-card__metrics dt {
    margin: 0 0 0.3rem;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #6b7280;
}

.project-card__metrics dd {
    margin: 0;
    font-size: 0.92rem;
    font-weight: 700;
    color: #142536;
}

.project-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.backoffice-shell {
    display: flex;
    flex-direction: column;
    gap: var(--gp-space-6);
}

.backoffice-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
    gap: var(--gp-space-6);
}

.backoffice-empty {
    margin: 0;
    color: var(--gp-text-muted);
}

.backoffice-table tbody tr {
    cursor: pointer;
}

.backoffice-table__row--selected {
    background: rgba(31, 162, 166, 0.08);
}

.backoffice-company {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.backoffice-company span {
    color: var(--gp-text-muted);
    font-size: 0.82rem;
}

.backoffice-detail {
    display: flex;
    flex-direction: column;
    gap: var(--gp-space-4);
}

.backoffice-detail__intro h3 {
    margin: 0;
    font-size: 1.1rem;
}

.backoffice-detail__intro p {
    margin: var(--gp-space-1) 0 0;
    color: var(--gp-text-muted);
}

.backoffice-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--gp-space-3);
    margin: 0;
}

.backoffice-meta div {
    padding: var(--gp-space-3);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    background: var(--gp-surface-soft);
}

.backoffice-meta dt {
    margin: 0 0 var(--gp-space-1);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--gp-text-muted);
}

.backoffice-meta dd {
    margin: 0;
    font-weight: 700;
    color: var(--gp-text);
}

.approval-document {
    gap: var(--gp-space-4);
}

.approval-document__header {
    display: flex;
    justify-content: space-between;
    gap: var(--gp-space-4);
    align-items: flex-start;
    flex-wrap: wrap;
}

.approval-document__eyebrow {
    margin: 0 0 var(--gp-space-2);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--gp-text-muted);
    font-weight: 700;
}

.approval-document__title {
    margin: 0;
}

.approval-document__subtitle {
    margin: var(--gp-space-2) 0 0;
    color: var(--gp-text-muted);
}

.approval-document__meta {
    display: grid;
    gap: var(--gp-space-2);
    min-width: min(420px, 100%);
    padding: var(--gp-space-4);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    background: var(--gp-surface-soft);
}

.approval-document__meta span {
    color: var(--gp-text-secondary);
}

.approval-document__facts {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--gp-space-3);
}

.approval-document__facts article {
    display: flex;
    flex-direction: column;
    gap: var(--gp-space-1);
    padding: var(--gp-space-3);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    background: var(--gp-surface-soft);
}

.approval-document__facts span,
.approval-document__narrative span {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--gp-text-muted);
    font-weight: 700;
}

.approval-document__facts strong {
    font-size: 1rem;
    color: var(--gp-text);
}

.approval-document__narrative {
    display: grid;
    gap: var(--gp-space-3);
}

.approval-document__narrative article {
    padding: var(--gp-space-4);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    background: var(--gp-surface-soft);
}

.approval-document__narrative p {
    margin: var(--gp-space-2) 0 0;
    white-space: pre-wrap;
    color: var(--gp-text);
}

.approval-signature-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--gp-space-4);
}

.approval-signature {
    display: flex;
    flex-direction: column;
    gap: var(--gp-space-2);
    align-items: center;
    text-align: center;
    padding-top: var(--gp-space-4);
}

.approval-signature__line {
    width: 100%;
    border-top: 1px solid var(--gp-border-strong);
}

@media (max-width: 1200px) {
    .project-summary {
        grid-template-columns: repeat(2, minmax(180px, 1fr));
    }

    .project-board {
        grid-template-columns: repeat(2, minmax(280px, 1fr));
    }

    .backoffice-layout {
        grid-template-columns: 1fr;
    }

    .approval-document__meta {
        min-width: 100%;
    }
}

@media (max-width: 768px) {
    .project-summary,
    .project-board {
        grid-template-columns: 1fr;
    }

    .project-card__metrics {
        grid-template-columns: 1fr;
    }

    .backoffice-meta {
        grid-template-columns: 1fr;
    }
}

:root {
    --gp-font-sans: "Inter", "Segoe UI", Arial, sans-serif;
    --gp-font-mono: "JetBrains Mono", "Cascadia Code", Consolas, monospace;
    --gp-bg: #f4f6f8;
    --gp-surface: #ffffff;
    --gp-surface-soft: #f8fafc;
    --gp-border: #d9e0e6;
    --gp-border-strong: #b8c4ce;
    --gp-text: #1a1a1a;
    --gp-text-secondary: #2e3a44;
    --gp-text-muted: #5e6a73;
    --gp-primary: #0b3c5d;
    --gp-primary-hover: #0e4a72;
    --gp-accent: #1fa2a6;
    --gp-accent-active: #18878b;
    --gp-success: #1d7a46;
    --gp-success-soft: #e9f5ee;
    --gp-warning: #a56a00;
    --gp-warning-soft: #faf1df;
    --gp-danger: #a83232;
    --gp-danger-soft: #f9e9e9;
    --gp-info: #0b5fa5;
    --gp-info-soft: #e8f0f9;
    --gp-shadow-sm: 0 1px 2px rgba(11, 60, 93, 0.04);
    --gp-radius-md: 6px;
    --gp-radius-lg: 8px;
    --gp-space-1: 4px;
    --gp-space-2: 8px;
    --gp-space-3: 12px;
    --gp-space-4: 16px;
    --gp-space-5: 20px;
    --gp-space-6: 24px;
    --gp-space-8: 32px;
}

html,
body {
    min-height: 100%;
    margin: 0;
    font-family: var(--gp-font-sans);
    background: var(--gp-bg);
    color: var(--gp-text);
}

a,
.btn-link {
    color: var(--gp-primary);
}

a {
    text-decoration: none;
}

a:hover {
    color: var(--gp-primary-hover);
}

h1,
h2,
h3,
h4,
h5,
h6 {
    color: var(--gp-text);
    letter-spacing: -0.02em;
}

.content {
    padding-top: var(--gp-space-6);
    padding-bottom: var(--gp-space-8);
}

.page-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--gp-space-4);
    margin-bottom: var(--gp-space-6);
    flex-wrap: wrap;
}

.page-header > div {
    min-width: 0;
}

.page-header__eyebrow {
    margin: 0 0 var(--gp-space-1);
    display: block;
    font-size: 0.75rem;
    font-weight: 700;
    line-height: 1.3;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--gp-accent);
}

.page-header__title {
    margin: 0;
    display: block;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.08;
    text-wrap: balance;
}

.page-header__description {
    margin: var(--gp-space-2) 0 0;
    display: block;
    max-width: 42rem;
    line-height: 1.5;
    color: var(--gp-text-muted);
}

.page-header__actions {
    display: flex;
    align-items: center;
    gap: var(--gp-space-2);
    flex-wrap: wrap;
}

.btn {
    border-radius: var(--gp-radius-md);
    font-weight: 600;
    transition: background-color 120ms ease, border-color 120ms ease, color 120ms ease;
}

.btn-primary {
    color: #f4f6f8;
    background-color: var(--gp-primary);
    border-color: var(--gp-primary);
}

.btn-primary:hover,
.btn-primary:focus {
    color: #f4f6f8;
    background-color: var(--gp-primary-hover);
    border-color: var(--gp-primary-hover);
}

.btn-outline-primary {
    color: var(--gp-primary);
    border-color: var(--gp-border-strong);
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
    color: #f4f6f8;
    background-color: var(--gp-primary);
    border-color: var(--gp-primary);
}

.btn-outline-secondary {
    color: var(--gp-text-secondary);
    border-color: var(--gp-border);
}

.btn-outline-secondary:hover,
.btn-outline-secondary:focus {
    color: var(--gp-text);
    background-color: var(--gp-surface-soft);
    border-color: var(--gp-border-strong);
}

.btn-outline-danger {
    color: var(--gp-danger);
    border-color: #d7a5a5;
}

.btn-outline-danger:hover,
.btn-outline-danger:focus {
    color: #fff;
    background-color: var(--gp-danger);
    border-color: var(--gp-danger);
}

.btn:focus,
.btn:active:focus,
.btn-link.nav-link:focus,
.form-control:focus,
.form-check-input:focus {
    box-shadow: 0 0 0 0.1rem rgba(255, 255, 255, 0.7), 0 0 0 0.25rem rgba(31, 162, 166, 0.2);
}

.form-control,
.form-select {
    min-height: 40px;
    border-radius: var(--gp-radius-md);
    border-color: var(--gp-border);
    background: var(--gp-surface);
    color: var(--gp-text);
}

.form-control::placeholder {
    color: var(--gp-text-muted);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--gp-accent);
}

.card {
    background: var(--gp-surface);
    border-color: var(--gp-border);
    border-radius: var(--gp-radius-lg);
    box-shadow: var(--gp-shadow-sm);
}

.table {
    color: var(--gp-text);
    --bs-table-bg: transparent;
    --bs-table-striped-bg: #f8fafc;
    --bs-table-striped-color: var(--gp-text);
}

.table > :not(caption) > * > * {
    padding: 12px;
    border-bottom-color: var(--gp-border);
}

.alert {
    border-radius: var(--gp-radius-md);
    border: 1px solid var(--gp-border);
}

.alert-danger {
    color: var(--gp-danger);
    background: var(--gp-danger-soft);
    border-color: #e5c0c0;
}

.alert-info {
    color: var(--gp-info);
    background: var(--gp-info-soft);
    border-color: #c7d8ea;
}

.text-danger {
    color: var(--gp-danger) !important;
}

.text-success {
    color: var(--gp-success) !important;
}

.brand-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: var(--gp-radius-md);
    border: 1px solid rgba(244, 246, 248, 0.12);
    background: linear-gradient(180deg, rgba(31, 162, 166, 0.18), rgba(11, 60, 93, 0.18));
    color: #f4f6f8;
    font-weight: 700;
    letter-spacing: -0.04em;
}

.brand-mark--logo {
    object-fit: contain;
    padding: 0;
    background: transparent;
    border: 0;
    border-radius: 0;
}

.navbar-brand {
    display: inline-flex;
    align-items: center;
    gap: var(--gp-space-3);
    text-decoration: none;
}

.navbar-brand__text {
    display: inline-flex;
    flex-direction: column;
    gap: 0.1rem;
}

.navbar-brand__text strong {
    color: #f4f6f8;
    line-height: 1.1;
}

.navbar-brand__text small {
    color: rgba(244, 246, 248, 0.72);
    line-height: 1.1;
}

.login-layout {
    min-height: 100vh;
    width: 100%;
    display: flex;
    align-items: stretch;
    justify-content: center;
    background: var(--gp-bg);
}

.dashboard-shell {
    display: grid;
    gap: var(--gp-space-6);
}

.metric-grid.dashboard-metric-grid {
    grid-template-columns: repeat(3, minmax(180px, 1fr));
}

.metric-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(180px, 1fr));
    gap: var(--gp-space-4);
}

.metric-card {
    background: var(--gp-surface);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    padding: var(--gp-space-4);
    box-shadow: var(--gp-shadow-sm);
}

.metric-card__label {
    margin: 0 0 var(--gp-space-2);
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--gp-text-muted);
}

.metric-card__value {
    margin: 0;
    font-size: 1.9rem;
    font-weight: 700;
}

.metric-card__tone--accent {
    border-top: 3px solid var(--gp-accent);
}

.metric-card__tone--primary {
    border-top: 3px solid var(--gp-primary);
}

.metric-card__tone--warning {
    border-top: 3px solid var(--gp-warning);
}

.metric-card__tone--success {
    border-top: 3px solid var(--gp-success);
}

.panel {
    background: var(--gp-surface);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    padding: var(--gp-space-5);
    box-shadow: var(--gp-shadow-sm);
}

.panel__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--gp-space-3);
    margin-bottom: var(--gp-space-4);
}

.panel__eyebrow {
    margin: 0 0 var(--gp-space-1);
    color: var(--gp-accent);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 700;
}

.panel__title {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 700;
}

.panel__description {
    margin: var(--gp-space-1) 0 0;
    color: var(--gp-text-muted);
}

.config-panel__actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--gp-space-2);
    flex-wrap: wrap;
}

.config-panel__toggle {
    white-space: nowrap;
}

.config-panel__summary {
    margin: var(--gp-space-3) 0 0;
    color: var(--gp-text-muted);
    font-size: 0.92rem;
}

.workspace-tabs {
    display: flex;
    align-items: center;
    gap: var(--gp-space-2);
    padding: 0.4rem;
    border: 1px solid var(--gp-border);
    border-radius: calc(var(--gp-radius-lg) + 6px);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 250, 252, 0.98));
    box-shadow: var(--gp-shadow-sm);
    overflow-x: auto;
    touch-action: manipulation;
    scrollbar-width: thin;
}

.workspace-tabs__item {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 0.55rem 0.9rem;
    border: 1px solid transparent;
    border-radius: calc(var(--gp-radius-md) + 10px);
    background: transparent;
    color: var(--gp-text-secondary);
    font-size: 0.9rem;
    font-weight: 700;
    line-height: 1.2;
    white-space: nowrap;
    transition:
        background-color 120ms ease,
        border-color 120ms ease,
        box-shadow 120ms ease,
        color 120ms ease,
        transform 120ms ease;
}

.workspace-tabs__item--active {
    color: var(--gp-primary);
    background: var(--gp-surface);
    border-color: rgba(11, 60, 93, 0.12);
    box-shadow:
        0 1px 2px rgba(11, 60, 93, 0.08),
        inset 0 0 0 1px rgba(255, 255, 255, 0.55);
}

.workspace-tabs__item:hover {
    color: var(--gp-primary);
    background: rgba(11, 60, 93, 0.05);
}

.workspace-tabs__item:active {
    transform: translateY(1px);
}

.workspace-tabs__item:focus-visible {
    outline: none;
    color: var(--gp-primary);
    border-color: rgba(31, 162, 166, 0.42);
    background: rgba(31, 162, 166, 0.08);
    box-shadow:
        0 0 0 0.1rem rgba(255, 255, 255, 0.7),
        0 0 0 0.24rem rgba(31, 162, 166, 0.22);
}

.workspace-config-surface {
    padding-top: 0.25rem;
}

.login-screen {
    min-height: 100vh;
    width: 100%;
    display: grid;
    place-items: center;
    padding: var(--gp-space-8) var(--gp-space-4);
    background:
        radial-gradient(circle at top left, rgba(31, 162, 166, 0.16), transparent 28%),
        radial-gradient(circle at bottom right, rgba(11, 60, 93, 0.08), transparent 26%),
        linear-gradient(180deg, #edf2f6 0%, var(--gp-bg) 100%);
}

.login-card {
    width: min(100%, 430px);
    background: var(--gp-surface);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    padding: var(--gp-space-6);
    box-shadow: var(--gp-shadow-sm);
}

.login-card__brand {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--gp-space-3);
    margin-bottom: var(--gp-space-5);
}

.login-card__logo {
    width: min(100%, 10rem);
    height: auto;
    display: block;
}

.login-card__subtitle {
    margin: 0;
    color: var(--gp-text-muted);
    font-size: 0.95rem;
}

.login-card__title {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 700;
}

.login-form {
    display: grid;
    gap: var(--gp-space-4);
}

.export-modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 1050;
    display: grid;
    place-items: center;
    padding: var(--gp-space-4);
    background: rgba(17, 24, 39, 0.38);
}

.export-modal {
    width: min(100%, 34rem);
    margin: 0;
}

.export-modal__options {
    display: grid;
    gap: var(--gp-space-3);
}

.export-option {
    display: flex;
    align-items: flex-start;
    gap: var(--gp-space-3);
    padding: var(--gp-space-3);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-md);
    background: var(--gp-surface-soft);
    cursor: pointer;
}

.export-option input {
    margin-top: 0.2rem;
}

.export-option span {
    display: grid;
    gap: 0.25rem;
}

.export-option small {
    color: var(--gp-text-muted);
}

.export-modal__actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--gp-space-3);
    margin-top: var(--gp-space-5);
}

.export-toggle {
    display: flex;
    align-items: center;
    gap: var(--gp-space-2);
    margin-top: var(--gp-space-4);
    color: var(--gp-text-secondary);
}

.login-form__field label {
    display: inline-block;
    margin-bottom: var(--gp-space-2);
    color: var(--gp-text-secondary);
    font-weight: 600;
}

.project-summary {
    display: grid;
    grid-template-columns: repeat(4, minmax(180px, 1fr));
    align-items: stretch;
    gap: var(--gp-space-4);
    margin-bottom: var(--gp-space-6);
}

.project-summary__card {
    display: grid;
    align-content: start;
    gap: var(--gp-space-2);
    background: var(--gp-surface);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    padding: var(--gp-space-4);
}

.project-summary__label {
    margin: 0 0 var(--gp-space-2);
    color: var(--gp-text-muted);
    line-height: 1.3;
}

.project-summary__value {
    display: block;
    margin: 0;
    font-size: 1.8rem;
    line-height: 1.1;
    color: var(--gp-text);
}

.project-board {
    gap: var(--gp-space-4);
}

.project-column {
    background: var(--gp-surface-soft);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
}

.project-column__header {
    padding: var(--gp-space-4);
    border-bottom: 1px solid var(--gp-border);
    background: rgba(255, 255, 255, 0.7);
}

.project-column__eyebrow {
    color: var(--gp-text-muted);
}

.project-column__count--planning,
.project-chip--planning {
    background: var(--gp-warning-soft);
    border-color: #eadab8;
    color: var(--gp-warning);
}

.project-column__count--progress,
.project-chip--progress {
    background: #e7f4f5;
    border-color: #b7dde0;
    color: var(--gp-accent-active);
}

.project-column__count--done,
.project-chip--done {
    background: var(--gp-info-soft);
    border-color: #c7d8ea;
    color: var(--gp-info);
}

.project-column__count--cancelled,
.project-chip--cancelled {
    background: var(--gp-danger-soft);
    border-color: #e5c0c0;
    color: var(--gp-danger);
}

.project-column__body {
    gap: var(--gp-space-3);
    padding: var(--gp-space-4);
}

.project-card {
    background: var(--gp-surface);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    padding: var(--gp-space-4);
    gap: var(--gp-space-4);
}

.project-card--empty {
    color: var(--gp-text-muted);
    background: transparent;
}

.project-chip,
.project-flag {
    border: 1px solid transparent;
}

.project-flag--danger {
    background: var(--gp-danger-soft);
    color: var(--gp-danger);
    border-color: #e5c0c0;
}

.project-flag--warning {
    background: var(--gp-warning-soft);
    color: var(--gp-warning);
    border-color: #eadab8;
}

.project-flag--neutral {
    background: var(--gp-info-soft);
    color: var(--gp-info);
    border-color: #c7d8ea;
}

.project-card__title {
    color: var(--gp-text);
}

.project-card__title:hover {
    color: var(--gp-primary);
    text-decoration: none;
}

.project-card__client {
    color: var(--gp-text-muted);
}

.project-card__metrics div {
    border-radius: var(--gp-radius-md);
    background: var(--gp-surface-soft);
    border: 1px solid var(--gp-border);
}

.project-card__metrics dt {
    color: var(--gp-text-muted);
}

.project-card__metrics dd {
    color: var(--gp-text);
}

@media (max-width: 1200px) {
    .dashboard-chart-grid,
    .dashboard-metric-grid,
    .metric-grid {
        grid-template-columns: repeat(2, minmax(180px, 1fr));
    }

    .dashboard-alert-row {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .page-header,
    .panel__header {
        flex-direction: column;
        align-items: stretch;
    }

    .dashboard-chart-grid,
    .dashboard-context-strip,
    .dashboard-metric-grid,
    .metric-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-alert-row__meta {
        grid-template-columns: 1fr 1fr;
    }

    .dashboard-donut {
        grid-template-columns: 1fr;
    }

    .workspace-tabs {
        padding-inline: 0.35rem;
        gap: 0.35rem;
    }

    .workspace-tabs__item {
        min-height: 38px;
        padding-inline: 0.8rem;
        font-size: 0.86rem;
    }
}

.project-card__body {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 112px;
    gap: var(--gp-space-3);
    align-items: start;
}

.project-card__main {
    min-width: 0;
}

.project-card__metrics--sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--gp-space-2);
    margin: 0;
}

.project-card__metric {
    min-width: 0;
    padding: 10px 10px 9px;
    border-radius: var(--gp-radius-md);
    background: var(--gp-surface-soft);
    border: 1px solid var(--gp-border);
}

.project-card__metric dt {
    margin: 0 0 3px;
    font-size: 0.66rem;
    line-height: 1.15;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--gp-text-muted);
}

.project-card__metric dd {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.25;
    font-weight: 700;
    color: var(--gp-text);
    word-break: break-word;
}

.project-card__actions {
    gap: var(--gp-space-2);
}

.project-card__actions .btn {
    min-width: 0;
}

@media (max-width: 768px) {
    .project-card__body {
        grid-template-columns: 1fr;
    }

    .project-card__metrics--sidebar {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.metric-card__tone--danger {
    border-top: 3px solid var(--gp-danger);
}

.metric-card__subtitle {
    margin: 6px 0 0;
    font-size: 0.78rem;
    color: var(--gp-text-muted);
}

.dashboard-context-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--gp-space-3);
}

.dashboard-chart-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
    gap: var(--gp-space-4);
}

.dashboard-context-card {
    padding: var(--gp-space-3) var(--gp-space-4);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    background: var(--gp-surface-soft);
}

.dashboard-context-card__label {
    margin: 0 0 var(--gp-space-1);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--gp-text-muted);
}

.dashboard-context-card__value {
    display: block;
    color: var(--gp-text);
    font-size: 1.2rem;
}

.dashboard-donut {
    display: grid;
    grid-template-columns: minmax(180px, 220px) minmax(0, 1fr);
    gap: var(--gp-space-4);
    align-items: center;
}

.dashboard-donut__visual {
    position: relative;
    width: 220px;
    height: 220px;
    margin-inline: auto;
}

.dashboard-donut__svg {
    width: 100%;
    height: 100%;
}

.dashboard-donut__track,
.dashboard-donut__slice {
    fill: none;
    stroke-width: 14;
}

.dashboard-donut__track {
    stroke: var(--gp-surface-soft);
}

.dashboard-donut__slice {
    transform: rotate(-90deg);
    transform-origin: 50% 50%;
    stroke-linecap: butt;
}

.dashboard-donut__slice--planning {
    stroke: var(--gp-warning);
}

.dashboard-donut__slice--progress {
    stroke: var(--gp-accent);
}

.dashboard-donut__slice--done {
    stroke: var(--gp-success);
}

.dashboard-donut__slice--danger {
    stroke: var(--gp-danger);
}

.dashboard-donut__center {
    position: absolute;
    inset: 50%;
    width: 112px;
    height: 112px;
    display: grid;
    place-items: center;
    align-content: center;
    gap: 4px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid var(--gp-border);
    border-radius: 999px;
    transform: translate(-50%, -50%);
    text-align: center;
}

.dashboard-donut__center strong {
    color: var(--gp-text);
    font-size: 1.7rem;
    line-height: 1;
}

.dashboard-donut__center span {
    color: var(--gp-text-muted);
    font-size: 0.72rem;
    line-height: 1.3;
}

.dashboard-donut__legend {
    display: grid;
    gap: var(--gp-space-3);
}

.dashboard-donut__legend-item {
    display: flex;
    align-items: flex-start;
    gap: var(--gp-space-3);
}

.dashboard-donut__legend-item strong,
.dashboard-donut__legend-item span {
    display: block;
}

.dashboard-donut__legend-item strong {
    color: var(--gp-text);
    font-size: 0.95rem;
}

.dashboard-donut__legend-item span {
    margin-top: 4px;
    color: var(--gp-text-muted);
    font-size: 0.84rem;
}

.dashboard-donut__legend-swatch {
    width: 12px;
    height: 12px;
    margin-top: 4px;
    border-radius: 999px;
    flex-shrink: 0;
}

.dashboard-donut__legend-swatch--planning {
    background: var(--gp-warning);
}

.dashboard-donut__legend-swatch--progress {
    background: var(--gp-accent);
}

.dashboard-donut__legend-swatch--done {
    background: var(--gp-success);
}

.dashboard-donut__legend-swatch--danger {
    background: var(--gp-danger);
}

.dashboard-bar-chart {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(92px, 1fr));
    gap: var(--gp-space-3);
    align-items: end;
    min-height: 244px;
}

.dashboard-bar-chart__item {
    display: grid;
    gap: var(--gp-space-2);
    align-items: end;
    justify-items: center;
}

.dashboard-bar-chart__value {
    color: var(--gp-text);
    font-size: 0.82rem;
    font-weight: 700;
}

.dashboard-bar-chart__bar-shell {
    width: 100%;
    max-width: 64px;
    height: 168px;
    display: flex;
    align-items: end;
    padding: 6px;
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    background: linear-gradient(180deg, rgba(248, 250, 252, 0.95), rgba(233, 239, 244, 0.95));
}

.dashboard-bar-chart__bar {
    width: 100%;
    min-height: 18%;
    border-radius: calc(var(--gp-radius-md) - 2px);
    background: linear-gradient(180deg, var(--gp-accent), var(--gp-primary));
    box-shadow: inset 0 -1px 0 rgba(255, 255, 255, 0.28);
}

.dashboard-bar-chart__label {
    max-width: 100%;
    color: var(--gp-text-muted);
    font-size: 0.76rem;
    font-weight: 600;
    line-height: 1.35;
    text-align: center;
    word-break: break-word;
}

.dashboard-alert-list {
    display: grid;
    gap: var(--gp-space-3);
}

.dashboard-alert-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 220px;
    gap: var(--gp-space-4);
    padding: var(--gp-space-4);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.98));
}

.dashboard-alert-row__main {
    min-width: 0;
}

.dashboard-alert-row__heading {
    display: flex;
    align-items: center;
    gap: var(--gp-space-2);
    flex-wrap: wrap;
}

.dashboard-alert-row__title {
    color: var(--gp-text);
    font-size: 1rem;
    font-weight: 700;
}

.dashboard-alert-row__title:hover {
    color: var(--gp-primary);
}

.dashboard-alert-row__client {
    margin: var(--gp-space-1) 0 0;
    color: var(--gp-text-muted);
}

.dashboard-alert-row__signals {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gp-space-2);
    margin-top: var(--gp-space-3);
}

.dashboard-alert-row__meta {
    display: grid;
    gap: var(--gp-space-3);
    margin: 0;
    padding: var(--gp-space-3);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    background: var(--gp-surface-soft);
    align-self: start;
}

.dashboard-alert-row__meta dt {
    margin: 0 0 var(--gp-space-1);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--gp-text-muted);
}

.dashboard-alert-row__meta dd {
    margin: 0;
    color: var(--gp-text);
    font-weight: 700;
}

.dashboard-alert-empty {
    padding: var(--gp-space-5);
    border: 1px dashed var(--gp-border-strong);
    border-radius: var(--gp-radius-lg);
    background: linear-gradient(180deg, rgba(233, 245, 238, 0.72), rgba(255, 255, 255, 0.96));
}

.dashboard-alert-empty strong {
    display: block;
    color: var(--gp-success);
}

.dashboard-alert-empty p {
    margin: var(--gp-space-2) 0 0;
    color: var(--gp-text-muted);
}

.dashboard-exception-list {
    display: grid;
    gap: var(--gp-space-4);
}

.dashboard-exception-card {
    gap: var(--gp-space-3);
}

.dashboard-exception-card__metrics {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gp-space-4);
}

.status-summary {
    display: grid;
    gap: var(--gp-space-3);
}

.status-summary__row {
    display: grid;
    grid-template-columns: 140px minmax(0, 1fr) 36px;
    gap: var(--gp-space-3);
    align-items: center;
}

.status-summary__label,
.status-summary__count {
    font-size: 0.9rem;
    color: var(--gp-text-secondary);
}

.status-summary__count {
    text-align: right;
    font-weight: 700;
}

.status-summary__track {
    height: 10px;
    background: var(--gp-surface-soft);
    border: 1px solid var(--gp-border);
    border-radius: 999px;
    overflow: hidden;
}

.status-summary__fill {
    height: 100%;
    border-radius: 999px;
}

.status-summary__fill--planning {
    background: var(--gp-warning);
}

.status-summary__fill--progress {
    background: var(--gp-accent);
}

.status-summary__fill--done {
    background: var(--gp-success);
}

.status-summary__fill--cancelled {
    background: var(--gp-danger);
}

.toolbar-search {
    display: flex;
    align-items: center;
}

.toolbar-search__field {
    position: relative;
    width: min(100%, 560px);
}

.toolbar-search__icon {
    position: absolute;
    top: 50%;
    left: 12px;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    border-radius: 999px;
    background: var(--gp-surface-soft);
    border: 1px solid var(--gp-border);
    color: var(--gp-text-muted);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    font-family: var(--gp-font-mono);
}

.toolbar-search__field .form-control {
    padding-left: 42px;
}

.operational-pills {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gp-space-2);
    margin-bottom: var(--gp-space-4);
}

.operational-pill {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid var(--gp-border);
    background: var(--gp-surface-soft);
    color: var(--gp-text-secondary);
    font-size: 0.8rem;
    font-weight: 600;
    line-height: 1.2;
}

.section-rail {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gp-space-2);
    margin-bottom: var(--gp-space-4);
    padding-bottom: var(--gp-space-3);
    border-bottom: 1px solid var(--gp-border);
}

.section-rail__link {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid var(--gp-border);
    background: var(--gp-surface);
    color: var(--gp-text-secondary);
    font-size: 0.8rem;
    font-weight: 600;
    text-decoration: none;
    transition: border-color 120ms ease, color 120ms ease, background-color 120ms ease;
}

.section-rail__link:hover {
    color: var(--gp-primary);
    border-color: var(--gp-border-strong);
    background: var(--gp-surface-soft);
}

.status-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gp-space-2);
    margin-bottom: var(--gp-space-6);
    padding-bottom: var(--gp-space-3);
    border-bottom: 1px solid var(--gp-border);
}

.status-tabs__item {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: var(--gp-space-2);
    min-height: 42px;
    padding: 10px 14px;
    border: 0;
    border-bottom: 2px solid transparent;
    background: transparent;
    color: var(--gp-text-muted);
    font-size: 0.92rem;
    font-weight: 600;
}

.status-tabs__item:hover {
    color: var(--gp-text);
}

.status-tabs__item--active {
    color: var(--gp-primary);
    border-bottom-color: var(--gp-primary);
}

.status-tabs__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 24px;
    padding: 0 6px;
    height: 20px;
    border-radius: 999px;
    background: var(--gp-surface-soft);
    border: 1px solid var(--gp-border);
    font-size: 0.72rem;
}

.status-tabs__item > span {
    color: inherit;
    line-height: 1.2;
}

.project-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--gp-space-4);
}

.project-grid-card {
    background: var(--gp-surface);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    padding: var(--gp-space-4);
    display: grid;
    gap: var(--gp-space-4);
    transition: border-color 120ms ease, box-shadow 120ms ease, transform 120ms ease;
}

.project-grid-card:hover {
    border-color: rgba(11, 60, 93, 0.24);
    box-shadow: 0 6px 18px rgba(11, 60, 93, 0.08);
    transform: translateY(-1px);
}

.project-grid-card__top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--gp-space-3);
}

.project-grid-card__top > div {
    min-width: 0;
}

.project-grid-card__id {
    margin: 0 0 6px;
    color: var(--gp-text-muted);
    font-family: var(--gp-font-mono);
    font-size: 0.72rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.project-grid-card__title {
    display: inline-block;
    margin-bottom: 4px;
    color: var(--gp-text);
    font-size: 1.05rem;
    font-weight: 700;
    line-height: 1.25;
    word-break: break-word;
}

.project-grid-card__client {
    margin: 0;
    color: var(--gp-text-muted);
    font-size: 0.92rem;
    line-height: 1.4;
}

.project-grid-card__info {
    display: grid;
    gap: var(--gp-space-2);
}

.project-grid-card__info-row {
    display: flex;
    justify-content: space-between;
    gap: var(--gp-space-3);
    color: var(--gp-text-secondary);
    font-size: 0.9rem;
}

.project-grid-card__info-row > span {
    min-width: 0;
}

.project-grid-card__info-row--danger {
    color: var(--gp-danger);
}

.project-grid-card__info-label {
    color: var(--gp-text-muted);
}

.project-grid-card__info-value {
    text-align: right;
    font-weight: 600;
}

.project-grid-card__progress {
    display: grid;
    gap: var(--gp-space-2);
}

.project-grid-card__progress-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: var(--gp-text-secondary);
    font-size: 0.82rem;
    font-weight: 600;
}

.progress-strip {
    height: 8px;
    border-radius: 999px;
    background: var(--gp-surface-soft);
    border: 1px solid var(--gp-border);
    overflow: hidden;
}

.progress-strip__fill {
    height: 100%;
}

.progress-strip__fill--planning {
    background: var(--gp-warning);
}

.progress-strip__fill--progress {
    background: var(--gp-accent);
}

.progress-strip__fill--done {
    background: var(--gp-success);
}

.progress-strip__fill--cancelled {
    background: var(--gp-danger);
}

.project-grid-card__signals {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gp-space-2);
    min-height: 28px;
    align-items: flex-start;
}

.project-grid-card__footer {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: var(--gp-space-3);
    padding-top: var(--gp-space-3);
    border-top: 1px solid var(--gp-border);
}

.project-grid-card__metric {
    display: grid;
    gap: 4px;
}

.project-grid-card__metric-label {
    color: var(--gp-text-muted);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.project-grid-card__metric-value {
    font-weight: 700;
}

.project-grid-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gp-space-2);
    justify-content: flex-end;
}

.icon-action-bar {
    display: inline-flex;
    align-items: center;
    gap: var(--gp-space-2);
    flex-wrap: wrap;
}

.icon-action-bar--end {
    justify-content: flex-end;
}

.status-badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 8px;
    border-radius: 999px;
    border: 1px solid transparent;
    font-size: 0.75rem;
    font-weight: 700;
}

.status-badge--planning {
    color: var(--gp-warning);
    background: var(--gp-warning-soft);
    border-color: #eadab8;
}

.status-badge--progress {
    color: var(--gp-accent-active);
    background: #e7f4f5;
    border-color: #b7dde0;
}

.status-badge--done {
    color: var(--gp-success);
    background: var(--gp-success-soft);
    border-color: #c6dfcf;
}

.status-badge--cancelled {
    color: var(--gp-danger);
    background: var(--gp-danger-soft);
    border-color: #e5c0c0;
}

.status-badge--neutral {
    color: var(--gp-text-muted);
    background: var(--gp-surface-soft);
    border-color: var(--gp-border);
}

.people-summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--gp-space-4);
    margin-bottom: var(--gp-space-4);
}

.people-panel {
    overflow: hidden;
}

.people-table tbody tr {
    transition: background-color 120ms ease;
}

.people-table tbody tr:hover {
    background: rgba(11, 60, 93, 0.03);
}

.people-table {
    margin-bottom: 0;
    table-layout: auto;
}

.people-cell {
    display: flex;
    align-items: center;
    gap: var(--gp-space-3);
    min-width: 0;
}

.people-avatar {
    width: 32px;
    height: 32px;
    border-radius: 999px;
    background: var(--gp-surface-soft);
    border: 1px solid var(--gp-border);
    color: var(--gp-text-secondary);
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.people-name {
    display: block;
    min-width: 0;
    font-weight: 600;
    line-height: 1.35;
    word-break: break-word;
}

.people-cost {
    display: grid;
    gap: 2px;
    justify-items: end;
}

.people-cost span {
    color: var(--gp-text-muted);
    font-size: 0.78rem;
}

.people-footer {
    margin-top: var(--gp-space-3);
    color: var(--gp-text-muted);
    font-size: 0.9rem;
}

.people-table th,
.people-table td {
    vertical-align: middle;
}

.settings-stack {
    display: grid;
    gap: var(--gp-space-4);
}

.settings-callout {
    display: flex;
    align-items: flex-start;
    gap: var(--gp-space-3);
    padding: var(--gp-space-5);
    border-radius: var(--gp-radius-lg);
    border: 1px solid rgba(11, 60, 93, 0.14);
    background: linear-gradient(180deg, rgba(11, 60, 93, 0.05), rgba(31, 162, 166, 0.04));
}

.settings-callout__title {
    margin: 0 0 6px;
    font-size: 1rem;
}

.settings-callout__text {
    margin: 0;
    color: var(--gp-text-muted);
}

.settings-panel {
    max-width: 720px;
}

.settings-panel--wide {
    max-width: none;
}

.settings-list {
    display: grid;
    gap: var(--gp-space-2);
}

.settings-list__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gp-space-3);
    padding: 12px 0;
    border-bottom: 1px solid var(--gp-border);
    color: var(--gp-text-muted);
}

.settings-list__row:last-child {
    border-bottom: 0;
}

.settings-list__row strong {
    color: var(--gp-text);
}

.settings-branding {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(280px, 0.9fr);
    gap: var(--gp-space-5);
    align-items: start;
}

.settings-branding__fields {
    min-width: 0;
}

.settings-form-sections {
    display: grid;
    gap: var(--gp-space-4);
}

.settings-form-section {
    padding: var(--gp-space-4);
    border-radius: var(--gp-radius-lg);
    border: 1px solid var(--gp-border);
    background: var(--gp-surface-soft);
}

.settings-form-section__header {
    margin-bottom: var(--gp-space-3);
}

.settings-form-section__header h3 {
    margin: 0;
    color: var(--gp-text);
    font-size: 1rem;
}

.settings-form-section__eyebrow {
    margin: 0 0 6px;
    color: var(--gp-text-muted);
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.settings-branding__preview {
    display: grid;
    gap: var(--gp-space-3);
}

.settings-branding__preview-eyebrow {
    margin: 0;
    color: var(--gp-text-muted);
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.settings-branding-card {
    overflow: hidden;
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    background: var(--gp-surface-soft);
}

.settings-branding-card__hero {
    display: flex;
    align-items: center;
    gap: var(--gp-space-3);
    padding: var(--gp-space-4);
}

.settings-branding-card__hero strong,
.settings-branding-card__hero span {
    display: block;
}

.settings-branding-card__hero span {
    opacity: 0.8;
    font-size: 0.84rem;
}

.settings-branding-card__logo {
    width: 56px;
    height: 56px;
    object-fit: contain;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.88);
    padding: 8px;
}

.settings-branding-card__body {
    padding: var(--gp-space-4);
}

.settings-color-field {
    display: flex;
    align-items: center;
    gap: var(--gp-space-2);
}

.settings-color-field__text {
    font-family: "IBM Plex Mono", monospace;
    text-transform: uppercase;
}

.settings-color-field__picker {
    width: 56px;
    min-width: 56px;
    padding: 4px;
}

.settings-branding__fields .validation-message,
.settings-branding__fields .validation-message * {
    color: #b42318;
    font-size: 0.9rem;
}

.alert-success {
    color: var(--gp-success);
    background: var(--gp-success-soft);
    border-color: #c6dfcf;
}

.empty-state {
    margin: 0;
    color: var(--gp-text-muted);
    text-align: center;
    padding: var(--gp-space-6) 0;
}

.recovery-page {
    min-height: calc(100vh - 3rem);
    display: grid;
    place-items: center;
    padding: clamp(2rem, 5vw, 4rem) 1.25rem;
}

.recovery-page__shell {
    width: min(100%, 720px);
    display: grid;
    gap: var(--gp-space-4);
    padding: clamp(1.5rem, 4vw, 3rem);
    border: 1px solid var(--gp-border);
    border-radius: calc(var(--gp-radius-lg) + 4px);
    background:
        radial-gradient(circle at top right, rgba(31, 162, 166, 0.12), transparent 32%),
        linear-gradient(180deg, rgba(11, 60, 93, 0.02), rgba(11, 60, 93, 0.05)),
        var(--gp-surface);
    box-shadow: 0 20px 48px rgba(9, 28, 44, 0.08);
}

.recovery-page__status {
    display: inline-flex;
    width: fit-content;
    padding: 0.45rem 0.8rem;
    border-radius: 999px;
    background: rgba(11, 60, 93, 0.08);
    color: var(--gp-primary);
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.08em;
}

.recovery-page__eyebrow {
    margin: 0;
    color: var(--gp-accent);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.recovery-page__title {
    margin: 0;
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1.05;
    letter-spacing: -0.03em;
}

.recovery-page__description,
.recovery-page__body,
.recovery-page__support {
    margin: 0;
    color: var(--gp-text-muted);
    line-height: 1.6;
}

.recovery-page__body code {
    padding: 0.15rem 0.35rem;
    border-radius: 6px;
    background: rgba(11, 60, 93, 0.08);
    color: var(--gp-primary);
    font-family: "IBM Plex Mono", monospace;
    font-size: 0.92em;
}

.recovery-page__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gp-space-2);
    padding-top: var(--gp-space-2);
}

.menu-shell {
    display: grid;
    gap: var(--gp-space-6);
}

.menu-header__signals {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: var(--gp-space-2);
}

.menu-pill,
.menu-counter {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid rgba(11, 60, 93, 0.16);
    background: rgba(11, 60, 93, 0.04);
    color: var(--gp-text);
    font-size: 0.82rem;
    font-weight: 600;
}

.menu-pill--muted {
    background: rgba(31, 162, 166, 0.07);
    color: var(--gp-text-secondary);
}

.menu-overview {
    display: grid;
}

.menu-overview__hero {
    display: grid;
    gap: var(--gp-space-4);
    background:
        linear-gradient(135deg, rgba(11, 60, 93, 0.04), rgba(31, 162, 166, 0.08)),
        var(--gp-surface);
}

.menu-overview__metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--gp-space-3);
}

.menu-metric-card {
    display: grid;
    gap: 8px;
    padding: 16px 18px;
    border: 1px solid rgba(11, 60, 93, 0.12);
    border-radius: var(--gp-radius-md);
    background: rgba(255, 255, 255, 0.66);
}

.menu-metric-card__label,
.menu-metric-card__hint {
    color: var(--gp-text-muted);
    font-size: 0.82rem;
}

.menu-metric-card__value {
    margin: 0;
    color: var(--gp-text);
    font-size: 1.15rem;
    line-height: 1.2;
}

.menu-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.75fr) minmax(280px, 0.9fr);
    gap: var(--gp-space-5);
    align-items: start;
}

.menu-feed,
.menu-admin-grid {
    display: grid;
    gap: var(--gp-space-4);
}

.menu-sidebar {
    display: grid;
    gap: var(--gp-space-4);
}

.menu-post {
    display: grid;
    gap: var(--gp-space-3);
    position: relative;
    overflow: hidden;
    padding: var(--gp-space-4);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(245, 249, 252, 0.94));
}

.menu-post::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 3px;
    background: linear-gradient(180deg, var(--gp-accent), rgba(31, 162, 166, 0.05));
}

.menu-post--featured {
    border-color: rgba(31, 162, 166, 0.24);
    box-shadow: 0 18px 40px rgba(10, 31, 49, 0.06);
}

.menu-post__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gp-space-3);
    padding-left: var(--gp-space-3);
    color: var(--gp-text-muted);
    font-size: 0.82rem;
}

.menu-post__title {
    margin: 0;
    padding-left: var(--gp-space-3);
    font-size: 1.15rem;
}

.menu-post__summary,
.menu-post__content {
    margin: 0;
    padding-left: var(--gp-space-3);
    color: var(--gp-text-secondary);
    line-height: 1.6;
}

.menu-post__summary {
    font-weight: 600;
    color: var(--gp-text);
}

.menu-video-list {
    display: grid;
    gap: var(--gp-space-3);
}

.menu-video-card {
    display: grid;
    grid-template-columns: 112px minmax(0, 1fr);
    gap: var(--gp-space-3);
    align-items: center;
    padding: var(--gp-space-3);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-md);
    background: linear-gradient(180deg, rgba(11, 60, 93, 0.015), rgba(31, 162, 166, 0.03));
    transition: border-color 120ms ease, transform 120ms ease, background-color 120ms ease;
}

.menu-video-card:hover {
    border-color: var(--gp-border-strong);
    transform: translateY(-1px);
}

.menu-video-card__thumb {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    border-radius: calc(var(--gp-radius-md) - 2px);
    border: 1px solid var(--gp-border);
    background: var(--gp-surface-soft);
}

.menu-video-card__body {
    min-width: 0;
    display: grid;
    gap: 4px;
}

.menu-video-card__body strong {
    color: var(--gp-text);
    line-height: 1.35;
}

.menu-video-card__body span {
    color: var(--gp-text-muted);
    font-size: 0.82rem;
}

.menu-quick-list {
    margin: 0;
    padding-left: 1.1rem;
    color: var(--gp-text-secondary);
    display: grid;
    gap: 10px;
    line-height: 1.55;
}

.menu-admin-shell {
    display: grid;
    gap: var(--gp-space-4);
    padding-top: var(--gp-space-2);
    border-top: 1px solid rgba(11, 60, 93, 0.1);
}

.menu-admin-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.menu-admin-list {
    display: grid;
    gap: var(--gp-space-2);
    margin-bottom: var(--gp-space-4);
}

.menu-admin-list__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gp-space-3);
    padding: 12px 14px;
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-md);
    background: var(--gp-surface-soft);
}

.menu-admin-list__row strong,
.menu-admin-list__row span {
    display: block;
}

.menu-admin-list__row span {
    color: var(--gp-text-muted);
    font-size: 0.82rem;
    line-height: 1.4;
    word-break: break-word;
}

.budget-shell {
    display: grid;
    gap: var(--gp-space-6);
}

.budget-filter-panel {
    display: grid;
    gap: var(--gp-space-4);
}

.budget-filters {
    align-items: end;
}

.budget-layout {
    display: grid;
    grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
    gap: var(--gp-space-5);
    align-items: start;
}

.budget-history {
    position: sticky;
    top: var(--gp-space-5);
}

.budget-history__list,
.budget-editor,
.budget-items,
.budget-items__rows {
    display: grid;
    gap: var(--gp-space-3);
}

.budget-history__item {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gp-space-3);
    padding: 14px;
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-md);
    background: var(--gp-surface-soft);
    color: var(--gp-text);
    text-align: left;
    transition: border-color 120ms ease, background-color 120ms ease, transform 120ms ease;
}

.budget-history__item:hover {
    border-color: var(--gp-border-strong);
    transform: translateY(-1px);
}

.budget-history__item--active {
    border-color: rgba(31, 162, 166, 0.35);
    background: linear-gradient(180deg, rgba(31, 162, 166, 0.08), rgba(31, 162, 166, 0.02));
}

.budget-history__item strong,
.budget-history__item span {
    display: block;
}

.budget-history__item span {
    color: var(--gp-text-muted);
    font-size: 0.84rem;
}

.budget-history__meta {
    display: grid;
    justify-items: end;
    gap: 6px;
}

.budget-summary {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--gp-space-4);
}

.budget-table__main {
    display: grid;
    gap: 2px;
}

.budget-table__main span {
    color: var(--gp-text-muted);
    font-size: 0.82rem;
}

.budget-items__group {
    display: grid;
    gap: var(--gp-space-3);
}

.budget-items__group-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gp-space-3);
    padding-bottom: var(--gp-space-2);
    border-bottom: 1px solid var(--gp-border);
}

.budget-items__group-header h3 {
    margin: 0;
    font-size: 1rem;
}

.budget-item-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gp-space-3);
    padding: 14px;
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-md);
    background: var(--gp-surface-soft);
}

.budget-item-card span {
    display: block;
    margin-top: 4px;
    color: var(--gp-text-muted);
    font-size: 0.82rem;
}

.budget-item-card__actions {
    display: flex;
    align-items: center;
    gap: var(--gp-space-2);
    flex-wrap: wrap;
    justify-content: flex-end;
}

.budget-item-editor {
    margin-top: var(--gp-space-4);
    padding-top: var(--gp-space-4);
    border-top: 1px solid var(--gp-border);
}

.budget-preview-shell {
    display: grid;
    gap: var(--gp-space-5);
}

.budget-preview-toolbar {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--gp-space-4);
}

.budget-preview-toolbar__actions {
    display: flex;
    align-items: center;
    gap: var(--gp-space-2);
}

.budget-preview-document {
    max-width: 1080px;
    margin: 0 auto;
    padding: clamp(24px, 3vw, 40px);
    border: 1px solid rgba(11, 60, 93, 0.12);
    border-radius: 24px;
    background: #fff;
    box-shadow: 0 24px 72px rgba(11, 60, 93, 0.08);
    display: grid;
    gap: var(--gp-space-5);
}

.budget-preview-document__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--gp-space-4);
    padding-bottom: var(--gp-space-4);
    border-bottom: 1px solid var(--gp-border);
}

.budget-preview-document__logo {
    display: block;
    max-width: 180px;
    max-height: 72px;
    margin-bottom: var(--gp-space-3);
    object-fit: contain;
}

.budget-preview-document__eyebrow {
    margin: 0 0 8px;
    color: var(--gp-accent);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.budget-preview-document__title {
    margin: 0;
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    color: #102437;
}

.budget-preview-document__subtitle {
    margin: 10px 0 0;
    color: var(--gp-text-muted);
    max-width: 56ch;
    line-height: 1.6;
}

.budget-preview-document__status {
    min-width: 180px;
    display: grid;
    justify-items: end;
    gap: 10px;
}

.budget-preview-document__status strong {
    font-size: 1.45rem;
    color: #102437;
}

.budget-preview-meta {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--gp-space-3);
}

.budget-preview-meta article {
    padding: 14px 16px;
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-md);
    background: #fbfcfd;
    display: grid;
    align-content: start;
    gap: 6px;
    min-width: 0;
}

.budget-preview-meta span,
.budget-preview-notes span,
.budget-preview-proposal span,
.budget-preview-footer span,
.budget-preview-section__header p {
    margin: 0;
    color: var(--gp-text-muted);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 700;
}

.budget-preview-meta strong,
.budget-preview-section__header strong,
.budget-preview-footer strong {
    color: #102437;
}

.budget-preview-meta p {
    margin: 0;
    color: var(--gp-text-secondary);
    line-height: 1.55;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.budget-preview-meta__field {
    display: grid;
    align-content: start;
    gap: 4px;
    min-width: 0;
}

.budget-preview-meta__field--full {
    width: 100%;
}

.budget-preview-meta__pair,
.budget-preview-meta__triple {
    display: grid;
    align-items: start;
    gap: 12px;
}

.budget-preview-meta__pair {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.budget-preview-meta__triple {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.budget-preview-meta__label {
    display: block;
    font-size: 0.8rem;
    font-weight: 700;
    color: #102437;
}

.budget-preview-meta__title-value {
    display: block;
    font-weight: 700;
    color: #102437;
    font-size: 1.05rem;
}

.budget-preview-section {
    display: grid;
    gap: var(--gp-space-3);
}

.budget-preview-section__header {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: var(--gp-space-3);
}

.budget-preview-table__wrap {
    overflow-x: auto;
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-md);
}

.budget-preview-table {
    width: 100%;
    border-collapse: collapse;
    background: #fff;
}

.budget-preview-table th,
.budget-preview-table td {
    padding: 12px 14px;
    border-bottom: 1px solid var(--gp-border);
    text-align: left;
    vertical-align: top;
}

.budget-preview-table th {
    background: #f8fafc;
    color: var(--gp-text-secondary);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.budget-preview-table tbody tr:last-child td {
    border-bottom: 0;
}

.budget-preview-notes,
.budget-preview-proposal {
    display: grid;
    gap: 8px;
    padding: 16px 18px;
    border-radius: var(--gp-radius-md);
    border: 1px solid var(--gp-border);
    background: #f8fafc;
}

.budget-preview-meta + .budget-preview-proposal,
.budget-preview-meta + .budget-preview-notes {
    margin-top: 6px;
}

.budget-preview-notes p,
.budget-preview-proposal p,
.budget-preview-footer p {
    margin: 0;
    color: var(--gp-text-secondary);
    line-height: 1.7;
}

.budget-preview-footer {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: var(--gp-space-4);
    padding-top: var(--gp-space-4);
    border-top: 1px solid var(--gp-border);
}

.budget-preview-footer__totals {
    min-width: min(100%, 320px);
    display: grid;
    gap: 10px;
}

.budget-preview-total-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gp-space-3);
}

.budget-preview-total-row--grand {
    padding-top: 10px;
    border-top: 1px solid var(--gp-border);
}

.budget-preview-signatures {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--gp-space-3);
}

.budget-preview-signature-card {
    display: grid;
    gap: 10px;
    padding: 18px;
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-md);
    background: #fff;
}

.budget-preview-signature-card span {
    margin: 0;
    color: var(--gp-text-muted);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 700;
}

.budget-preview-signature-card__line {
    min-height: 52px;
    border-bottom: 1px solid rgba(11, 60, 93, 0.22);
}

.budget-preview-signature-card strong {
    color: #102437;
}

.budget-preview-signature-card p {
    margin: 0;
    color: var(--gp-text-secondary);
    line-height: 1.5;
}

@media (max-width: 1200px) {
    .project-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .menu-overview__metrics,
    .menu-layout,
    .menu-admin-grid,
    .budget-layout,
    .budget-preview-meta,
    .budget-preview-signatures {
        grid-template-columns: 1fr;
    }

    .budget-preview-meta__pair,
    .budget-preview-meta__triple {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .status-summary__row,
    .project-grid-card__footer,
    .settings-list__row {
        grid-template-columns: 1fr;
        display: grid;
    }

    .project-grid,
    .people-summary,
    .budget-summary,
    .budget-preview-meta {
        grid-template-columns: 1fr;
    }

    .menu-header__signals {
        justify-content: flex-start;
    }

    .menu-video-card,
    .menu-post__meta,
    .menu-admin-list__row,
    .budget-item-card,
    .budget-history__item,
    .budget-preview-toolbar,
    .budget-preview-document__header,
    .budget-preview-footer {
        grid-template-columns: 1fr;
        display: grid;
    }

    .menu-metric-card {
        padding: 14px 16px;
    }

    .menu-video-card__thumb {
        max-width: 240px;
    }

    .budget-history {
        position: static;
    }

    .settings-branding {
        grid-template-columns: 1fr;
    }

    .project-grid-card__top,
    .project-grid-card__footer {
        align-items: stretch;
    }

    .project-grid-card__actions {
        justify-content: flex-start;
    }
}

@media print {
    html,
    body {
        background: #fff;
    }

    .sidebar,
    .top-row.app-topbar,
    .no-print {
        display: none !important;
    }

    main,
    .content {
        padding: 0 !important;
        margin: 0 !important;
    }

    .budget-preview-shell {
        gap: 0;
    }

    .budget-preview-document {
        display: block;
        max-width: none;
        margin: 0;
        padding: 16px;
        border: 1px solid rgba(11, 60, 93, 0.12);
        border-radius: 18px;
        box-shadow: none;
        print-color-adjust: exact;
        -webkit-print-color-adjust: exact;
    }

    .budget-preview-meta,
    .budget-preview-signatures {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .budget-preview-meta {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .budget-preview-meta__pair {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .budget-preview-meta__triple {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .budget-preview-meta + .budget-preview-proposal,
    .budget-preview-meta + .budget-preview-notes {
        margin-top: 10px;
    }

    .budget-preview-section {
        display: block;
        break-inside: auto;
        page-break-inside: auto;
        margin-top: 18px;
    }

    .budget-preview-section__header,
    .budget-preview-notes,
    .budget-preview-proposal,
    .budget-preview-footer,
    .budget-preview-signatures,
    .budget-preview-signature-card,
    .budget-preview-meta article {
        break-inside: avoid;
        page-break-inside: avoid;
    }

    .budget-preview-table__wrap {
        overflow: visible;
        break-inside: auto;
        page-break-inside: auto;
    }

    .budget-preview-table {
        table-layout: fixed;
    }

    .budget-preview-table thead {
        display: table-header-group;
    }

    .budget-preview-table tr,
    .budget-preview-table td,
    .budget-preview-table th {
        break-inside: avoid;
        page-break-inside: avoid;
    }

    .budget-preview-table th,
    .budget-preview-table td {
        padding: 10px 12px;
        font-size: 0.92rem;
    }
}

.project-detail-code {
    font-family: var(--gp-font-mono);
    color: var(--gp-text-secondary);
}

.project-detail-shell {
    display: grid;
    gap: var(--gp-space-6);
}

.project-phase-list {
    display: grid;
    gap: var(--gp-space-4);
}

.task-board {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(280px, 360px);
    gap: var(--gp-space-4);
    overflow-x: auto;
    align-items: start;
    padding-bottom: var(--gp-space-2);
}

.task-board-column {
    display: flex;
    flex-direction: column;
    min-height: 520px;
    background:
        linear-gradient(180deg, rgba(11, 60, 93, 0.02) 0%, rgba(11, 60, 93, 0) 100%),
        var(--gp-surface);
}

.task-board-column__header {
    display: flex;
    flex-direction: column;
    gap: var(--gp-space-3);
    padding-bottom: var(--gp-space-3);
    border-bottom: 1px solid var(--gp-border);
}

.task-board-column__heading {
    display: grid;
    gap: var(--gp-space-2);
}

.task-board-column__title {
    margin: 0;
    font-size: 1rem;
    font-weight: 800;
}

.task-board-column__description {
    margin: 0;
    color: var(--gp-text-muted);
    font-size: 0.84rem;
    line-height: 1.45;
}

.task-board-column__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gp-space-2);
}

.task-board-column__body {
    display: grid;
    gap: var(--gp-space-3);
    padding-top: var(--gp-space-4);
}

.task-board-add {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--gp-space-2);
    min-height: 42px;
    width: 100%;
    border: 1px dashed rgba(11, 60, 93, 0.22);
    border-radius: var(--gp-radius-lg);
    background: rgba(11, 60, 93, 0.03);
    color: var(--gp-primary);
    font-weight: 700;
}

.task-board-add:hover {
    background: rgba(11, 60, 93, 0.06);
    border-color: rgba(11, 60, 93, 0.34);
}

.task-board-empty {
    display: grid;
    place-items: center;
    min-height: 140px;
    padding: var(--gp-space-4);
    border: 1px dashed var(--gp-border);
    border-radius: var(--gp-radius-lg);
    color: var(--gp-text-muted);
    text-align: center;
    background: var(--gp-surface-soft);
}

.task-board-cards {
    display: grid;
    gap: var(--gp-space-3);
}

.task-board-card {
    display: grid;
    gap: var(--gp-space-3);
    padding: var(--gp-space-4);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    background: var(--gp-surface);
    box-shadow: var(--gp-shadow-sm);
}

.task-board-card__header,
.task-board-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gp-space-2);
}

.task-board-card__badges,
.task-board-card__actions {
    display: flex;
    align-items: center;
    gap: var(--gp-space-2);
    flex-wrap: wrap;
}

.task-board-card__content {
    display: grid;
    gap: 6px;
    padding: 0;
    border: 0;
    background: transparent;
    text-align: left;
}

.task-board-card__content:hover .task-board-card__title {
    color: var(--gp-primary);
}

.task-board-card__title {
    color: var(--gp-text);
    font-size: 0.98rem;
    line-height: 1.35;
}

.task-board-card__subtitle {
    color: var(--gp-text-muted);
    font-size: 0.82rem;
    line-height: 1.45;
}

.task-board-card__meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--gp-space-3);
    margin: 0;
}

.task-board-card__meta div {
    padding: var(--gp-space-3);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-md);
    background: var(--gp-surface-soft);
}

.task-board-card__meta dt {
    margin: 0 0 4px;
    color: var(--gp-text-muted);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.task-board-card__meta dd {
    margin: 0;
    color: var(--gp-text);
    font-size: 0.86rem;
    font-weight: 700;
    line-height: 1.4;
}

.task-view-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gp-space-3);
    margin-top: var(--gp-space-4);
    padding-top: var(--gp-space-4);
    border-top: 1px solid var(--gp-border);
}

.task-view-toolbar--compact {
    margin-top: 0;
    padding-top: 0;
    border-top: 0;
}

.task-view-toggle {
    display: inline-flex;
    align-items: center;
    gap: var(--gp-space-2);
    padding: 4px;
    border: 1px solid var(--gp-border);
    border-radius: 999px;
    background: var(--gp-surface-soft);
}

.task-view-toggle__button {
    display: inline-flex;
    align-items: center;
    gap: var(--gp-space-2);
    min-height: 36px;
    padding: 0 12px;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--gp-text-muted);
    font-size: 0.88rem;
    font-weight: 700;
}

.task-view-toggle__button--active {
    background: var(--gp-surface);
    color: var(--gp-primary);
    box-shadow: var(--gp-shadow-sm);
}

.task-workspace-compact {
    background: var(--gp-surface);
    border: 1px solid var(--gp-border);
    border-radius: 14px;
    padding: 0.9rem 1rem;
    box-shadow: var(--gp-shadow-sm);
}

.task-workspace-compact__bar,
.task-workspace-compact__actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gp-space-3);
    flex-wrap: wrap;
}

.task-workspace-compact__heading {
    display: flex;
    flex-direction: column;
    gap: 0.12rem;
}

.task-workspace-compact__eyebrow {
    margin: 0;
    color: var(--gp-accent);
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 700;
}

.task-workspace-compact__title {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
    color: var(--gp-text);
}

.task-view-icon {
    position: relative;
    display: inline-flex;
    width: 18px;
    height: 18px;
    flex: 0 0 auto;
}

.task-view-icon::before,
.task-view-icon::after {
    content: "";
    position: absolute;
}

.task-view-icon--board::before {
    inset: 1px;
    border: 1px solid var(--gp-border-strong);
    border-radius: 4px;
    box-shadow:
        inset 0 -6px 0 0 var(--gp-surface-soft),
        inset -6px 0 0 0 var(--gp-surface-soft);
}

.task-view-icon--list::before {
    top: 3px;
    left: 1px;
    width: 4px;
    height: 4px;
    border-radius: 1px;
    background: currentcolor;
    box-shadow: 0 5px 0 currentcolor, 0 10px 0 currentcolor;
}

.task-view-icon--list::after {
    top: 4px;
    left: 8px;
    width: 9px;
    height: 2px;
    background: currentcolor;
    box-shadow: 0 5px 0 currentcolor, 0 10px 0 currentcolor;
}

.task-ops-table__name,
.task-ops-table__costs {
    display: grid;
    gap: 2px;
}

.task-ops-table__name span,
.task-ops-table__costs span {
    color: var(--gp-text-muted);
    font-size: 0.83rem;
}

.task-ops-table__details-row > td {
    background: var(--gp-surface-soft);
    border-bottom: 0;
}

.task-ops-table__details {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--gp-space-4);
    padding: var(--gp-space-2) 0;
}

.task-detail-panel {
    background: var(--gp-surface);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    padding: var(--gp-space-4);
}

.task-detail-panel__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--gp-space-3);
    margin-bottom: var(--gp-space-4);
}

.task-detail-panel__title {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
}

.task-list-table {
    min-width: 1280px;
}

.icon-action,
.task-action-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    padding: 0;
    border: 1px solid var(--gp-border);
    border-radius: 999px;
    background: var(--gp-surface);
    color: var(--gp-text-secondary);
    transition: background-color 120ms ease, border-color 120ms ease, color 120ms ease, transform 120ms ease;
    text-decoration: none;
}

.icon-action:hover,
.task-action-button:hover {
    transform: translateY(-1px);
}

.icon-action:disabled,
.task-action-button:disabled {
    opacity: 0.45;
    transform: none;
}

.icon-action svg,
.task-action-button svg {
    width: 16px;
    height: 16px;
}

.icon-action svg {
    fill: none;
    stroke: currentcolor;
}

.task-action-button svg {
    fill: currentcolor;
    stroke: none;
}

.icon-action--neutral:hover,
.task-action-button--neutral:hover {
    background: var(--gp-surface-soft);
    border-color: var(--gp-border-strong);
    color: var(--gp-text);
}

.icon-action--primary,
.task-action-button--primary {
    color: var(--gp-primary);
    border-color: rgba(11, 60, 93, 0.18);
}

.icon-action--primary:hover,
.task-action-button--primary:hover {
    background: rgba(11, 60, 93, 0.08);
    border-color: rgba(11, 60, 93, 0.28);
}

.icon-action--success,
.task-action-button--success {
    color: var(--gp-success);
    border-color: rgba(29, 122, 70, 0.2);
}

.icon-action--success:hover,
.task-action-button--success:hover {
    background: rgba(29, 122, 70, 0.08);
    border-color: rgba(29, 122, 70, 0.32);
}

.icon-action--danger,
.task-action-button--danger {
    color: var(--gp-danger);
    border-color: rgba(168, 50, 50, 0.2);
}

.icon-action--danger:hover,
.task-action-button--danger:hover {
    background: rgba(168, 50, 50, 0.08);
    border-color: rgba(168, 50, 50, 0.32);
}

.icon-action--warning {
    color: var(--gp-warning);
    border-color: rgba(165, 106, 0, 0.22);
}

.icon-action--warning:hover,
.task-action-button--warning:hover {
    background: rgba(165, 106, 0, 0.09);
    border-color: rgba(165, 106, 0, 0.36);
}

.task-action-button--warning {
    color: var(--gp-warning);
    border-color: rgba(165, 106, 0, 0.22);
    font-weight: 800;
    font-size: 1rem;
}

.task-list-phase-label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 32px;
    padding: 0 8px;
    border-radius: 999px;
    border: 1px solid var(--gp-border);
    background: var(--gp-surface-soft);
    color: var(--gp-text-secondary);
    font-weight: 700;
}

.task-list-phase-label-wrap {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: var(--gp-space-2);
}

.task-cell {
    vertical-align: middle;
    white-space: nowrap;
}

.task-cell--editable {
    cursor: pointer;
}

.task-cell--editable:hover {
    background: rgba(11, 60, 93, 0.04);
}

.task-cell--readonly {
    background: rgba(15, 23, 42, 0.02);
}

.task-list-empty {
    padding: var(--gp-space-5);
    color: var(--gp-text-muted);
    text-align: center;
}

.task-inline-row > td {
    background: #fbfdfe;
    box-shadow: inset 0 1px 0 rgba(11, 60, 93, 0.08), inset 0 -1px 0 rgba(11, 60, 93, 0.08);
}

.photo-report-summary__value {
    font-size: 1rem;
    line-height: 1.35;
}

.photo-report-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--gp-space-4);
}

.photo-report-card {
    display: flex;
    flex-direction: column;
    background: var(--gp-surface);
    border: 1px solid var(--gp-border);
    border-radius: var(--gp-radius-lg);
    overflow: hidden;
}

.photo-report-card__image-wrap {
    background: var(--gp-surface-soft);
    aspect-ratio: 4 / 3;
    border-bottom: 1px solid var(--gp-border);
}

.photo-report-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.photo-report-card__body {
    display: flex;
    flex-direction: column;
    gap: var(--gp-space-3);
    padding: var(--gp-space-4);
}

.photo-report-card__meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--gp-space-2);
    flex-wrap: wrap;
    color: var(--gp-text-muted);
    font-size: 0.82rem;
}

.photo-report-card__title {
    color: var(--gp-text);
    font-size: 1rem;
    line-height: 1.35;
}

.photo-report-card__details {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--gp-space-3);
    margin: 0;
}

.photo-report-card__details div {
    padding: var(--gp-space-3);
    border-radius: var(--gp-radius-md);
    background: var(--gp-surface-soft);
    border: 1px solid var(--gp-border);
}

.photo-report-card__details dt {
    margin: 0 0 4px;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--gp-text-muted);
}

.photo-report-card__details dd {
    margin: 0;
    color: var(--gp-text);
    font-weight: 700;
}

.photo-report-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gp-space-2);
}

@media (max-width: 768px) {
    .task-ops-table__details {
        grid-template-columns: 1fr;
    }

    .task-board {
        grid-auto-columns: minmax(260px, 88vw);
    }

    .task-view-toolbar {
        display: grid;
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .task-workspace-compact__bar,
    .task-workspace-compact__actions {
        align-items: stretch;
    }

    .task-board-card__meta {
        grid-template-columns: 1fr;
    }

    .task-detail-panel__header {
        flex-direction: column;
    }

    .photo-report-card__details {
        grid-template-columns: 1fr;
    }
}

.marketing-shell {
    min-height: 100vh;
    background:
        radial-gradient(circle at top right, rgba(20, 63, 96, 0.08), transparent 28%),
        linear-gradient(180deg, #f7f5ef 0%, #f2efe7 100%);
}

.marketing-skip-link {
    position: absolute;
    top: 1rem;
    left: 1rem;
    z-index: 40;
    padding: 0.8rem 1rem;
    border-radius: 999px;
    background: #123d62;
    color: #f7fbff;
    text-decoration: none;
    transform: translateY(-220%);
    transition: transform 0.2s ease;
}

.marketing-skip-link:focus-visible {
    transform: translateY(0);
}

.marketing-topbar {
    position: sticky;
    top: 0;
    z-index: 20;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 2rem;
    border-bottom: 1px solid rgba(20, 37, 54, 0.08);
    background: rgba(247, 245, 239, 0.92);
    backdrop-filter: blur(14px);
}

.marketing-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.85rem;
    color: inherit;
    text-decoration: none;
}

.marketing-brand__logo {
    width: 2.5rem;
    height: 2.5rem;
}

.marketing-brand__copy {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}

.marketing-brand__name {
    font-size: 1rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #0f2435;
}

.marketing-brand__tagline {
    font-size: 0.72rem;
    color: #5c6975;
}

.marketing-nav {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
}

.marketing-nav a {
    color: #1f2933;
    text-decoration: none;
    font-weight: 600;
}

.marketing-nav a:hover,
.marketing-nav a:focus-visible {
    color: #123d62;
}

.marketing-nav__login {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.75rem;
    padding: 0 1rem;
    border: 1px solid rgba(20, 37, 54, 0.14);
    border-radius: 999px;
    background: #ffffff;
}

.marketing-main {
    width: min(1180px, calc(100vw - 2rem));
    margin: 0 auto;
    padding: 2.2rem 0 4rem;
}

.landing-hero,
.plans-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(320px, 0.9fr);
    gap: 1.5rem;
    align-items: stretch;
}

.plans-hero {
    grid-template-columns: 1fr;
    margin-bottom: 1.5rem;
}

.landing-hero__copy,
.plans-hero > div {
    padding: 1rem 0 0.5rem;
}

.landing-eyebrow {
    margin: 0 0 0.9rem;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: #54738b;
    font-weight: 800;
}

.landing-hero h1,
.plans-hero h1 {
    margin: 0 0 1rem;
    max-width: 12ch;
    font-size: clamp(2.6rem, 4vw, 4.6rem);
    line-height: 0.98;
    letter-spacing: -0.04em;
    color: #10293d;
    text-wrap: balance;
}

.landing-lead {
    max-width: 48rem;
    margin: 0;
    font-size: 1.08rem;
    line-height: 1.75;
    color: #44525f;
}

.landing-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    margin-top: 1.8rem;
}

.landing-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 3.2rem;
    padding: 0 1.3rem;
    border-radius: 999px;
    text-decoration: none;
    font-weight: 700;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.landing-button:hover {
    transform: translateY(-1px);
}

.landing-button--primary {
    color: #f6fbff;
    background: #123d62;
    box-shadow: 0 14px 32px rgba(18, 61, 98, 0.18);
}

.landing-button--secondary {
    color: #17314a;
    background: rgba(255, 255, 255, 0.86);
    border: 1px solid rgba(18, 61, 98, 0.15);
}

.landing-button:focus-visible,
.marketing-brand:focus-visible,
.marketing-nav a:focus-visible,
.landing-carousel__arrow:focus-visible,
.landing-carousel__dot:focus-visible {
    outline: 3px solid rgba(18, 112, 181, 0.28);
    outline-offset: 4px;
    box-shadow: 0 0 0 6px rgba(18, 112, 181, 0.12);
}

.landing-proof {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-top: 1.45rem;
}

.landing-proof span,
.plan-card__trial {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0.2rem 0.75rem;
    border-radius: 999px;
    border: 1px solid rgba(18, 61, 98, 0.1);
    background: rgba(255, 255, 255, 0.72);
    color: #4f6476;
    font-size: 0.84rem;
    font-weight: 700;
}

.marketing-panel,
.landing-card,
.plan-card,
.landing-cta {
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(20, 37, 54, 0.08);
    border-radius: 28px;
    box-shadow: 0 18px 48px rgba(16, 41, 61, 0.08);
}

.marketing-panel {
    height: 100%;
    padding: 1.6rem;
}

.marketing-panel--hero {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(237, 245, 250, 0.86)),
        rgba(255, 255, 255, 0.82);
}

.marketing-panel__eyebrow {
    margin: 0 0 0.8rem;
    color: #54738b;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-size: 0.78rem;
    font-weight: 800;
}

.marketing-panel h2 {
    margin: 0 0 1rem;
    font-size: 1.55rem;
    line-height: 1.15;
    color: #10293d;
}

.marketing-panel__list {
    margin: 0;
    padding-left: 1.1rem;
    display: grid;
    gap: 0.85rem;
    color: #465a6d;
}

.landing-hero__signals,
.landing-faq {
    display: grid;
    gap: 0.8rem;
}

.landing-signal-card {
    padding: 1rem 1.05rem;
    border-radius: 22px;
    background: rgba(245, 250, 253, 0.92);
    border: 1px solid rgba(18, 61, 98, 0.08);
}

.landing-signal-card strong {
    display: block;
    margin-bottom: 0.45rem;
    color: #10293d;
}

.landing-signal-card p {
    margin: 0;
    color: #50606d;
    line-height: 1.65;
}

.landing-band,
.landing-grid,
.plans-grid,
.plans-notes,
.landing-steps {
    display: grid;
    gap: 1rem;
}

.landing-band {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 2.3rem 0;
    padding: 1rem 0;
}

.landing-band article {
    padding: 1.15rem 1.2rem;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.62);
    border: 1px solid rgba(20, 37, 54, 0.07);
}

.landing-band strong {
    display: block;
    margin-bottom: 0.55rem;
    color: #10293d;
    font-size: 1rem;
}

.landing-band p,
.landing-card p,
.landing-step p,
.landing-cta p,
.plan-card li {
    color: #50606d;
    line-height: 1.7;
}

.landing-section {
    padding: 1.2rem 0 0.7rem;
}

.landing-section__intro {
    margin-bottom: 1.35rem;
}

.landing-section__intro h2,
.landing-cta h2 {
    margin: 0;
    max-width: 18ch;
    font-size: clamp(1.8rem, 3vw, 2.7rem);
    line-height: 1.1;
    color: #10293d;
    text-wrap: balance;
}

.landing-grid,
.plans-notes {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.landing-grid--modules {
    align-items: stretch;
}

.landing-grid--story,
.landing-faq {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.landing-card {
    padding: 1.4rem;
}

.landing-card--story,
.landing-card--faq {
    background: rgba(255, 255, 255, 0.9);
}

.landing-section--narrative .landing-card {
    background: linear-gradient(180deg, rgba(18, 61, 98, 0.04), rgba(255, 255, 255, 0.9));
}

.landing-card h3,
.landing-step h3,
.plan-card h2 {
    margin: 0 0 0.75rem;
    color: #10293d;
}

#produto,
#faq {
    scroll-margin-top: 6.5rem;
}

.landing-steps {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.landing-carousel {
    display: grid;
    gap: 1rem;
}

.landing-carousel__stage {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 1rem;
}

.landing-carousel__arrow {
    width: 3rem;
    height: 3rem;
    border: 1px solid rgba(18, 61, 98, 0.12);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.86);
    color: #123d62;
    font-size: 1.8rem;
    line-height: 1;
    transition: transform 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
}

.landing-carousel__arrow:hover {
    transform: translateY(-1px);
    background: rgba(255, 255, 255, 0.98);
    border-color: rgba(18, 61, 98, 0.24);
}

.landing-carousel__card {
    display: grid;
    grid-template-columns: minmax(0, 1.3fr) minmax(280px, 0.7fr);
    gap: 1rem;
    padding: 1rem;
    min-height: 30rem;
    background: rgba(255, 255, 255, 0.84);
    border: 1px solid rgba(20, 37, 54, 0.08);
    border-radius: 28px;
    box-shadow: 0 18px 48px rgba(16, 41, 61, 0.08);
}

.landing-carousel__card > * {
    min-width: 0;
}

.landing-carousel__media {
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    min-height: 24rem;
    height: 100%;
    aspect-ratio: 16 / 10;
    border-radius: 20px;
    border: 1px solid rgba(20, 37, 54, 0.08);
    background: #edf2f5;
}

.landing-carousel__media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
    padding: 0.75rem;
    background: #f7fafc;
}

.landing-carousel__content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.7rem;
    padding: 1rem 1.1rem;
    min-height: 100%;
    min-width: 0;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.82);
}

.landing-carousel__content h3 {
    margin: 0;
    font-size: 1.55rem;
    color: #10293d;
}

.landing-carousel__content p:last-child {
    margin: 0;
    color: #50606d;
    line-height: 1.75;
}

.landing-carousel__dots {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.landing-carousel__dot {
    width: 0.8rem;
    height: 0.8rem;
    border: 0;
    border-radius: 999px;
    background: rgba(18, 61, 98, 0.22);
    cursor: pointer;
    transition: width 0.2s ease, background-color 0.2s ease, transform 0.2s ease;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
}

.landing-carousel__dot:hover {
    transform: translateY(-1px);
    background: rgba(18, 61, 98, 0.38);
}

.landing-carousel__dot--active {
    width: 2rem;
    background: #123d62;
}

.landing-step {
    padding: 1.5rem;
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(18, 61, 98, 0.08), rgba(255, 255, 255, 0.86));
    border: 1px solid rgba(18, 61, 98, 0.1);
}

.landing-step span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    margin-bottom: 1rem;
    border-radius: 999px;
    background: #123d62;
    color: #f3f7fb;
    font-weight: 800;
}

.landing-cta {
    margin-top: 2rem;
    padding: 1.6rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.landing-cta__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    justify-content: flex-end;
}

.plans-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-bottom: 1.2rem;
}

.purchase-grid {
    display: grid;
    grid-template-columns: minmax(280px, 0.95fr) minmax(0, 1.15fr);
    gap: 1rem;
}

.plan-card {
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.plan-card ul {
    margin: 0;
    padding-left: 1.1rem;
    display: grid;
    gap: 0.7rem;
    flex: 1;
}

.plan-card .landing-button {
    margin-top: auto;
}

.purchase-card {
    padding: 1.5rem;
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(20, 37, 54, 0.08);
    box-shadow: 0 18px 48px rgba(16, 41, 61, 0.08);
}

.purchase-form {
    display: grid;
    gap: 1rem;
}

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

.purchase-alert__link {
    font-weight: 700;
    color: #163754;
    white-space: nowrap;
}

.purchase-next-step ul {
    margin: 0;
    padding-left: 1.1rem;
    display: grid;
    gap: 0.55rem;
}

.purchase-form__field {
    display: grid;
    gap: 0.45rem;
}

.purchase-form__field label {
    color: #17314a;
    font-weight: 700;
}

.purchase-form__submit {
    width: 100%;
    border: 0;
}

.purchase-form__field .validation-message,
.purchase-form__field .validation-errors,
.purchase-form__field .validation-message *,
.purchase-form__field .validation-errors * {
    color: #b42318;
    font-size: 0.92rem;
}

.purchase-existing-account {
    margin: 0;
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    color: #395166;
    font-size: 0.96rem;
}

.purchase-existing-account a {
    font-weight: 700;
    color: #163754;
}

.purchase-success-card {
    display: grid;
    align-content: center;
    gap: 1.5rem;
}

.purchase-success-card__body {
    margin: 0;
    color: #31465a;
    font-size: 1rem;
    line-height: 1.7;
}

.purchase-success-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
}

.landing-hero--visual {
    grid-template-columns: 1fr;
    gap: 2.4rem;
    justify-items: center;
    padding-top: 1.4rem;
}

.landing-hero__intro {
    display: grid;
    justify-items: center;
    max-width: 46rem;
    text-align: center;
}

.landing-hero__stage {
    position: relative;
    width: min(100%, 72rem);
    padding-inline: 1.5rem;
}

.landing-hero__intro .landing-lead {
    max-width: 40rem;
    font-size: 1.08rem;
}

.landing-device {
    position: relative;
    padding: 1.2rem;
    border-radius: 32px;
    background:
        radial-gradient(circle at top left, rgba(65, 152, 214, 0.18), transparent 32%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(235, 242, 246, 0.88));
    border: 1px solid rgba(18, 61, 98, 0.1);
    box-shadow: 0 28px 60px rgba(12, 37, 58, 0.12);
    overflow: visible;
}

.landing-device__frame,
.landing-shot {
    overflow: hidden;
    border-radius: 24px;
    border: 1px solid rgba(20, 37, 54, 0.08);
    background: linear-gradient(180deg, #f7fafc 0%, #edf3f7 100%);
    box-shadow: 0 18px 42px rgba(12, 37, 58, 0.09);
}

.landing-device__frame img,
.landing-shot img {
    display: block;
    width: 100%;
    height: auto;
}

.landing-device__float {
    position: absolute;
    display: grid;
    gap: 0.3rem;
    width: min(14rem, 46%);
    padding: 0.95rem 1rem;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(18, 61, 98, 0.08);
    box-shadow: 0 18px 42px rgba(12, 37, 58, 0.14);
}

.landing-device__float strong,
.landing-strip__card strong,
.landing-metric-card strong {
    color: #10293d;
    font-size: 0.98rem;
}

.landing-device__float span {
    color: #50606d;
    line-height: 1.55;
    font-size: 0.9rem;
}

.landing-device__float--top {
    top: 1.2rem;
    right: -0.6rem;
}

.landing-device__float--left {
    top: 22%;
    left: -1.2rem;
}

.landing-device__float--right {
    top: 34%;
    right: -1.2rem;
}

.landing-device__float--bottom {
    left: 50%;
    bottom: -1rem;
    transform: translateX(-50%);
    width: min(18rem, 72%);
}

.landing-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin: 2.2rem 0 0.8rem;
}

.landing-strip__card {
    display: grid;
    gap: 0.55rem;
    padding: 1.35rem;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(20, 37, 54, 0.07);
}

.landing-strip__card span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    border-radius: 18px;
    font-weight: 800;
}

.landing-strip__icon {
    font-size: 0.78rem;
}

.landing-strip__icon svg {
    width: 1.45rem;
    height: 1.45rem;
}

.landing-strip__card--cyan .landing-strip__icon {
    background: rgba(70, 197, 216, 0.22);
    color: #0f8ba6;
}

.landing-strip__card--blue .landing-strip__icon {
    background: rgba(18, 94, 214, 0.18);
    color: #1d5cd8;
}

.landing-strip__card--emerald .landing-strip__icon {
    background: rgba(60, 209, 156, 0.18);
    color: #0a9d73;
}

.landing-strip__card p {
    margin: 0;
    color: #50606d;
    line-height: 1.6;
}

.landing-section--feature {
    padding-top: 1.8rem;
}

.landing-feature {
    display: grid;
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
    gap: 1.5rem;
    align-items: center;
}

.landing-feature--reverse {
    grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
}

.landing-feature--stacked {
    grid-template-columns: 1fr;
    justify-items: center;
}

.landing-feature--stacked .landing-feature__copy {
    justify-items: center;
    text-align: center;
}

.landing-feature--visual-flow .landing-grid--mini-centered {
    grid-column: 1 / -1;
    margin-top: -0.25rem;
}

.landing-feature__copy {
    display: grid;
    gap: 1rem;
}

.landing-feature__copy h2 {
    margin: 0;
    max-width: 14ch;
    font-size: clamp(2rem, 3vw, 3rem);
    line-height: 1;
    color: #10293d;
    text-wrap: balance;
}

.landing-feature__copy > p {
    margin: 0;
    color: #50606d;
    max-width: 34rem;
    line-height: 1.65;
}

.landing-bullets {
    margin: 0;
    padding-left: 1.1rem;
    display: grid;
    gap: 0.55rem;
    color: #50606d;
}

.landing-shot {
    position: relative;
    transition: transform 0.24s ease, box-shadow 0.24s ease;
}

.landing-shot:hover {
    transform: translateY(-4px);
    box-shadow: 0 24px 54px rgba(12, 37, 58, 0.14);
}

.landing-shot img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: contain;
    background: #f8fbfd;
}

.landing-shot--feature {
    width: 100%;
    max-width: 48rem;
}

.landing-grid--mini {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.landing-grid--mini-centered {
    width: 100%;
    max-width: 40rem;
    margin: -0.5rem auto 0;
}

.landing-card--compact {
    padding: 1.15rem;
}

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

.landing-metric-card {
    padding: 1.1rem 1.15rem;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(20, 37, 54, 0.08);
}

.landing-metric-card p {
    margin: 0.45rem 0 0;
    color: #50606d;
    line-height: 1.6;
}

.landing-metric-row--panels {
    margin-top: 1.4rem;
    align-items: start;
}

.landing-metric-panel {
    display: grid;
    gap: 0.9rem;
    padding: 1.6rem;
    border-radius: 28px;
    border: 1px solid rgba(18, 94, 214, 0.18);
    box-shadow: 0 18px 48px rgba(16, 41, 61, 0.08);
}

.landing-metric-panel--rdo {
    background: linear-gradient(180deg, rgba(233, 245, 255, 0.92), rgba(240, 250, 255, 0.9));
}

.landing-metric-panel--bm {
    background: linear-gradient(180deg, rgba(235, 255, 245, 0.92), rgba(242, 255, 249, 0.9));
    border-color: rgba(47, 177, 126, 0.18);
}

.landing-metric-panel__eyebrow {
    color: #0f5fd8;
    font-size: 0.95rem;
    font-weight: 500;
}

.landing-metric-panel--bm .landing-metric-panel__eyebrow {
    color: #0f8b63;
}

.landing-metric-panel h3 {
    margin: 0;
    font-size: 1.25rem;
    color: #10293d;
}

.landing-metric-panel p {
    margin: 0;
    color: #32485c;
    line-height: 1.65;
}

.landing-metric-panel__media {
    overflow: hidden;
    border-radius: 22px;
    border: 1px solid rgba(20, 37, 54, 0.08);
    background: #f8fbfd;
    box-shadow: 0 14px 36px rgba(12, 37, 58, 0.12);
}

.landing-metric-panel__media img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: contain;
    background: #f8fbfd;
}

.landing-section--modules .landing-section__intro h2,
.landing-section--faq .landing-section__intro h2,
.landing-section--steps .landing-section__intro h2 {
    max-width: 17ch;
}

.landing-section--modules-dark {
    margin-top: 1rem;
    padding: 2.1rem;
    border-radius: 34px;
    background: linear-gradient(180deg, #10293d 0%, #0a1b29 100%);
    box-shadow: 0 26px 60px rgba(10, 27, 41, 0.18);
}

.landing-section--modules-dark .landing-section__intro {
    text-align: center;
}

.landing-section--modules-dark .landing-eyebrow {
    color: #7fd0ea;
}

.landing-section--modules-dark .landing-section__intro h2 {
    margin-inline: auto;
    color: #f3f7fb;
}

.landing-modules {
    display: grid;
    gap: 1rem;
}

.landing-modules--top {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-bottom: 1rem;
}

.landing-modules--bottom {
    grid-template-columns: minmax(0, 1fr) minmax(0, 2fr);
}

.landing-card--module {
    min-height: 12rem;
    background: rgba(16, 41, 61, 0.82);
    border-color: rgba(127, 208, 234, 0.12);
    color: #f3f7fb;
}

.landing-card--module h3 {
    color: #f3f7fb;
}

.landing-card--module p {
    color: rgba(243, 247, 251, 0.78);
}

.landing-card--module:hover {
    border-color: rgba(127, 208, 234, 0.35);
    box-shadow: 0 22px 48px rgba(5, 18, 28, 0.24);
}

.landing-module__link {
    margin-top: auto;
    color: #7fd0ea;
    font-size: 0.92rem;
    font-weight: 700;
}

.landing-card--people {
    display: grid;
    grid-template-columns: minmax(16rem, 0.95fr) minmax(0, 1.35fr);
    gap: 1rem;
    align-items: start;
}

.landing-card--people__copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.landing-card--people__media {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 0.35rem;
    border-radius: 24px;
    background: rgba(8, 22, 34, 0.42);
    border: 1px solid rgba(127, 208, 234, 0.12);
    align-self: start;
}

.landing-card--people__media img {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
    object-fit: contain;
    border-radius: 20px;
    background: #f8fbfd;
}

.landing-cta--final {
    margin-top: 2.6rem;
    background:
        radial-gradient(circle at top right, rgba(65, 152, 214, 0.18), transparent 34%),
        rgba(255, 255, 255, 0.88);
}

.landing-cta--centered {
    flex-direction: column;
    text-align: center;
}

.landing-cta__content {
    max-width: 42rem;
    margin: 0 auto;
    display: grid;
    justify-items: center;
}

.landing-cta__content p {
    margin-inline: auto;
}

.landing-cta__content h2 {
    margin-inline: auto;
}

.landing-cta--centered .landing-cta__actions {
    justify-content: center;
}

.landing-section--steps .landing-section__intro,
.landing-section--faq .landing-section__intro {
    text-align: center;
}

.landing-section--steps .landing-section__intro h2,
.landing-section--faq .landing-section__intro h2 {
    margin-inline: auto;
}

.landing-section--steps .landing-steps {
    text-align: center;
}

.landing-section--faq .landing-faq {
    text-align: center;
}

@media (max-width: 960px) {
    .landing-hero,
    .landing-band,
    .landing-strip,
    .landing-grid,
    .landing-faq,
    .landing-steps,
    .landing-feature,
    .landing-feature--reverse,
    .landing-grid--mini,
    .landing-metric-row,
    .landing-modules,
    .plans-grid,
    .purchase-grid,
    .plans-notes,
    .landing-cta {
        grid-template-columns: 1fr;
    }

    .landing-cta {
        display: grid;
    }

    .landing-card--people {
        grid-template-columns: 1fr;
    }

    .purchase-alert,
    .purchase-existing-account {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 768px) {
    .marketing-topbar {
        padding: 0.9rem 1rem;
        flex-direction: column;
        align-items: stretch;
    }

    .marketing-nav {
        justify-content: space-between;
        flex-wrap: wrap;
    }

    .marketing-main {
        width: min(100vw - 1rem, 1180px);
        padding-top: 1.2rem;
    }

    .landing-hero h1,
    .plans-hero h1,
    .landing-section__intro h2,
    .landing-cta h2,
    .landing-feature__copy h2 {
        max-width: none;
    }

    .landing-hero__stage {
        width: 100%;
        padding-inline: 0;
    }

    .landing-actions {
        display: grid;
    }

    .landing-cta__actions {
        display: grid;
    }

    .landing-device__float {
        position: static;
        width: 100%;
        margin-top: 0.85rem;
        transform: none;
    }

    .landing-carousel__stage {
        grid-template-columns: 1fr;
    }

    .landing-carousel__card {
        min-height: auto;
    }

    .landing-carousel__media {
        min-height: 18rem;
    }

    .landing-carousel__arrow {
        display: none;
    }

    .landing-button {
        width: 100%;
    }
}

@media (prefers-reduced-motion: reduce) {
    .marketing-skip-link,
    .landing-button,
    .landing-carousel__arrow,
    .landing-carousel__dot {
        transition: none;
    }
}
