:root {
    --bg: #f4f5f1;
    --panel: rgba(255, 255, 255, 0.84);
    --text: #182124;
    --muted: #4f6369;
    --primary: #0b8f7a;
    --primary-2: #08715f;
    --line: #c4d0d2;
    --danger: #a93535;
    --warning: #ba7c17;
    --ok: #138351;
    --info: #4f6369;
    --amber-soft: #ffe5bf;
    --mint-soft: #cef0e0;
    --shadow: 0 16px 38px rgba(17, 53, 48, 0.12);
    --shadow-soft: 0 8px 20px rgba(16, 53, 48, 0.08);
    --radius-card: 20px;
    --radius-control: 12px;
    --radius-pill: 999px;
    --safe-top: env(safe-area-inset-top, 0px);
    --safe-bottom: env(safe-area-inset-bottom, 0px);
}

[data-theme="dark"] {
    --bg: #0f171b;
    --panel: rgba(20, 33, 38, 0.88);
    --text: #eef5f6;
    --muted: #a6bcc1;
    --primary: #3cd0b2;
    --primary-2: #2ca68f;
    --line: #355058;
    --danger: #ff9494;
    --warning: #ffd086;
    --ok: #84e7b4;
    --info: #9ab2b8;
    --amber-soft: #564126;
    --mint-soft: #214a3d;
    --shadow: 0 16px 42px rgba(0, 0, 0, 0.42);
    --shadow-soft: 0 10px 22px rgba(0, 0, 0, 0.3);
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    min-height: 100vh;
    font-family: "Manrope", sans-serif;
    font-size: 16px;
    line-height: 1.45;
    color: var(--text);
    background: radial-gradient(circle at 12% 15%, #d9f2e5 0, transparent 35%),
                radial-gradient(circle at 90% 8%, #ffd9b3 0, transparent 36%),
                var(--bg);
    position: relative;
    overflow-x: hidden;
    padding-bottom: var(--safe-bottom);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overscroll-behavior-y: none;
}

h1, h2, h3, h4 {
    font-family: "Sora", sans-serif;
    margin: 0;
    letter-spacing: 0.01em;
}

.bg-grid {
    position: fixed;
    inset: 0;
    background-image: linear-gradient(to right, rgba(90, 110, 110, 0.045) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(90, 110, 110, 0.045) 1px, transparent 1px);
    background-size: 28px 28px;
    pointer-events: none;
    z-index: -3;
}

.bg-shape {
    position: fixed;
    border-radius: 999px;
    filter: blur(54px);
    z-index: -2;
    opacity: 0.55;
    animation: floaty 9s ease-in-out infinite alternate;
}

@keyframes floaty {
    from {
        transform: translateY(0);
    }
    to {
        transform: translateY(20px);
    }
}

.bg-shape-a {
    width: 240px;
    height: 240px;
    background: #28bca0;
    top: -82px;
    right: -30px;
}

.bg-shape-b {
    width: 300px;
    height: 300px;
    background: #ffae5a;
    bottom: -95px;
    left: -75px;
}

.glass {
    backdrop-filter: blur(18px);
}

.topbar {
    position: sticky;
    top: max(8px, var(--safe-top));
    z-index: 18;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 12px 14px 0;
    padding: 14px 16px;
    border-radius: var(--radius-card);
    border: 1px solid var(--line);
    box-shadow: var(--shadow);
    background: var(--panel);
}

.brand-lockup {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.brand-mark {
    width: 52px;
    height: 52px;
    border-radius: 12px;
    border: 1px solid var(--line);
    overflow: hidden;
    background: color-mix(in srgb, var(--panel-2) 92%, #ffffff);
    box-shadow: 0 10px 20px color-mix(in srgb, #071626 45%, transparent);
    flex-shrink: 0;
}

.brand-mark img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.topbar h1 {
    font-size: clamp(1.18rem, 1.2vw, 1.38rem);
}

.eyebrow {
    margin: 0;
    font-size: 0.7rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--muted);
}

.brand-lockup .eyebrow {
    font-weight: 700;
}

.topbar-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}

.user-badge {
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 7px 12px;
    font-size: 0.78rem;
    color: var(--muted);
}

.layout {
    padding: 12px 14px calc(34px + var(--safe-bottom));
}

.card {
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    box-shadow: var(--shadow);
}

.auth-card {
    max-width: 460px;
    margin: 44px auto;
    padding: 24px;
    transform: translateY(8px);
    animation: rise 0.42s ease forwards;
}

.auth-note {
    margin: 4px 0 8px;
    color: var(--muted);
}

@keyframes rise {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.auth-tabs {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    margin: 14px 0;
}

.password-field {
    position: relative;
}

.password-field input {
    padding-right: 46px;
}

.password-toggle {
    position: absolute;
    top: 50%;
    right: 8px;
    transform: translateY(-50%);
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    border: 1px solid var(--line);
    background: color-mix(in srgb, var(--panel) 84%, transparent);
    color: var(--muted);
    cursor: pointer;
    transition: border-color 0.16s ease, color 0.16s ease;
}

.password-toggle:hover {
    border-color: var(--primary);
    color: var(--primary);
}

.password-toggle[aria-pressed="true"] {
    color: var(--primary);
    border-color: color-mix(in srgb, var(--primary) 65%, var(--line));
}

.auth-error {
    margin: 4px 0 0;
    border: 1px solid color-mix(in srgb, var(--danger) 50%, var(--line));
    background: color-mix(in srgb, var(--danger) 10%, transparent);
    color: var(--danger);
    border-radius: 12px;
    padding: 8px 10px;
    font-size: 0.88rem;
}

.auth-support-link {
    margin-top: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    min-height: 42px;
    border-radius: var(--radius-control);
    border: 1px solid color-mix(in srgb, #25d366 55%, var(--line));
    background: color-mix(in srgb, #25d366 14%, var(--panel));
    color: #147c46;
    text-decoration: none;
    font-family: "Space Grotesk", sans-serif;
    font-weight: 700;
    transition: transform 0.16s ease, border-color 0.16s ease, background 0.16s ease;
}

.auth-support-link:hover {
    transform: translateY(-1px);
    border-color: #25d366;
    background: color-mix(in srgb, #25d366 20%, var(--panel));
}

.auth-support-link:focus-visible {
    outline: 2px solid color-mix(in srgb, #25d366 60%, #ffffff);
    outline-offset: 2px;
}

.tab,
.chip,
.primary-btn,
.ghost-btn,
.danger-btn {
    border-radius: var(--radius-control);
    min-height: 42px;
    padding: 10px 14px;
    font-family: "Space Grotesk", sans-serif;
    font-weight: 700;
    border: 1px solid transparent;
    cursor: pointer;
    transition: all 0.2s ease;
}

.tab,
.chip,
.ghost-btn {
    background: transparent;
    border-color: var(--line);
    color: var(--text);
}

.ghost-btn {
    background: color-mix(in srgb, var(--panel) 72%, transparent);
}

.tab.active,
.chip.active {
    background: var(--primary);
    border-color: var(--primary);
    color: #fff;
}

.primary-btn {
    background: var(--primary);
    color: #fff;
    box-shadow: 0 6px 16px color-mix(in srgb, var(--primary) 26%, transparent);
}

.primary-btn:hover {
    background: var(--primary-2);
    transform: translateY(-1px);
}

.ghost-btn:hover,
.chip:hover,
.tab:hover {
    border-color: var(--primary);
}

.danger-btn {
    background: transparent;
    border-color: color-mix(in srgb, var(--danger) 60%, var(--line));
    color: var(--danger);
}

.danger-btn:hover {
    background: color-mix(in srgb, var(--danger) 14%, transparent);
}

.primary-btn:focus-visible,
.ghost-btn:focus-visible,
.danger-btn:focus-visible,
.tab:focus-visible,
.chip:focus-visible,
.tab-view:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--primary) 70%, #ffffff);
    outline-offset: 2px;
}

.form-grid {
    display: grid;
    gap: 10px;
}

input,
select,
textarea {
    width: 100%;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.25);
    color: var(--text);
    border-radius: var(--radius-control);
    padding: 11px 12px;
    font: inherit;
    transition: border-color 0.16s ease, background 0.16s ease;
}

input:focus,
select:focus,
textarea:focus {
    border-color: color-mix(in srgb, var(--primary) 65%, var(--line));
    background: color-mix(in srgb, var(--panel) 86%, #ffffff);
}

input::placeholder,
textarea::placeholder {
    color: color-mix(in srgb, var(--muted) 86%, var(--text));
    opacity: 1;
}

.field-label {
    margin: 2px 0 -2px;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--muted);
}

.field-help {
    margin: -4px 0 2px;
    font-size: 0.76rem;
    color: var(--muted);
}

.field-help.warn {
    color: var(--danger);
}

input.input-invalid,
select.input-invalid,
textarea.input-invalid {
    border-color: color-mix(in srgb, var(--danger) 72%, var(--line));
    background: color-mix(in srgb, var(--danger) 9%, var(--panel));
}

textarea {
    min-height: 66px;
}

.cobro-access-list {
    margin-top: 6px;
    display: grid;
    gap: 8px;
    max-height: 220px;
    overflow: auto;
    padding-right: 2px;
}

.access-option {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 10px;
    background: rgba(255, 255, 255, 0.18);
}

.access-option input[type="checkbox"] {
    width: 17px;
    height: 17px;
    margin-top: 2px;
    accent-color: var(--primary);
}

.access-option span {
    display: grid;
    gap: 2px;
}

.access-option small {
    font-size: 0.76rem;
}

.app-shell {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 14px;
}

.panel-left {
    padding: 14px;
    min-height: calc(100vh - 145px);
    max-height: calc(100vh - 145px);
    overflow: auto;
}

.panel-left .panel-header .primary-btn {
    min-width: 90px;
}

.panel-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
    gap: 10px;
}

.list {
    display: grid;
    gap: 8px;
    margin-bottom: 12px;
}

.employee-grid {
    display: grid;
    gap: 12px;
    margin-top: 12px;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.admin-users-grid {
    grid-template-columns: repeat(3, minmax(280px, 1fr));
    max-height: calc(100vh - 320px);
    overflow-y: auto;
    padding-right: 4px;
    align-content: start;
}

.admin-user-meta {
    margin: 0;
    font-size: 0.78rem;
    color: var(--muted);
}

.admin-card-block {
    border: 1px solid color-mix(in srgb, var(--line) 85%, transparent);
    border-radius: 12px;
    padding: 10px;
    background: color-mix(in srgb, var(--panel) 70%, transparent);
}

.admin-block-title {
    margin: 0 0 8px;
    font-size: 0.78rem;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: var(--muted);
}

.admin-plan-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.admin-plan-grid label {
    display: grid;
    gap: 4px;
    font-size: 0.78rem;
    color: var(--muted);
}

.admin-plan-grid label:last-child {
    grid-column: 1 / -1;
}

.admin-plan-grid input {
    min-height: 40px;
}

.admin-alert-grid {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: 8px;
    align-items: center;
}

.admin-alert-grid input {
    min-height: 38px;
}

.employees-card {
    padding: 16px;
}

.employees-card .panel-header {
    margin-bottom: 10px;
}

.cobro-group {
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 10px;
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.24), rgba(255, 255, 255, 0.08));
    margin-bottom: 10px;
}

.cobro-group:nth-child(1) {
    border-color: color-mix(in srgb, var(--warning) 50%, var(--line));
}

.cobro-group:nth-child(2) {
    border-color: color-mix(in srgb, var(--ok) 50%, var(--line));
}

.cobro-group-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.cobro-group-head h4 {
    font-size: 0.9rem;
}

.cobro-count {
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 2px 8px;
    font-size: 0.74rem;
    color: var(--muted);
}

.list-item {
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 12px;
    cursor: pointer;
    background: rgba(255, 255, 255, 0.2);
    transition: border-color 0.16s ease, transform 0.16s ease, box-shadow 0.16s ease;
}

.list-item:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-soft);
}

.list-item.active {
    border-color: var(--primary);
    background: color-mix(in srgb, var(--primary) 16%, transparent);
}

.employee-card {
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 16px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--panel) 80%, #ffffff 20%), rgba(255, 255, 255, 0.08));
    box-shadow: var(--shadow-soft);
    display: grid;
    gap: 12px;
}

.employee-card-off {
    opacity: 0.75;
    filter: saturate(0.7);
}

.employee-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
}

.employee-head h4 {
    margin: 0;
    font-size: 1.06rem;
}

.employee-main {
    display: grid;
    gap: 4px;
}

.employee-routes {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    align-items: center;
}

.employee-route-chip {
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 5px 10px;
    font-size: 0.74rem;
    background: color-mix(in srgb, var(--panel) 74%, transparent);
}

.employee-route-chip-empty {
    color: var(--muted);
}

.employee-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.employee-actions .ghost-btn,
.employee-actions .danger-btn {
    min-height: 36px;
    padding: 7px 12px;
    font-size: 0.78rem;
}

.employee-toggle-btn {
    border-color: color-mix(in srgb, var(--primary) 42%, var(--line));
    background: color-mix(in srgb, var(--primary) 12%, transparent);
}

.employee-toggle-btn:hover {
    border-color: var(--primary);
}

.main-stack {
    display: grid;
    gap: 12px;
}

.section-tabs {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    align-self: start;
    padding: 6px 0;
    position: sticky;
    top: calc(max(8px, var(--safe-top)) + 84px);
    z-index: 12;
    background: color-mix(in srgb, var(--bg) 84%, transparent);
    border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
    border-radius: 14px;
    padding: 8px;
    backdrop-filter: blur(8px);
}

.tab-view {
    border-radius: 999px;
    border: 1px solid var(--line);
    background: transparent;
    color: var(--text);
    min-height: 38px;
    padding: 7px 15px;
    font-size: 0.8rem;
    font-family: "Space Grotesk", sans-serif;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.15s, color 0.15s;
}

.tab-view:hover {
    background: color-mix(in srgb, var(--primary) 12%, transparent);
}

.tab-view.active {
    background: var(--primary);
    border-color: var(--primary);
    color: #fff;
}

.view-panel {
    display: grid;
    gap: 12px;
}

.home-summary {
    padding: 18px;
}

.home-summary h3 {
    margin-bottom: 8px;
}

.metrics {
    padding: 14px;
    display: grid;
    grid-template-columns: repeat(4, minmax(150px, 1fr));
    gap: 8px;
}

.analytics-card {
    padding: 14px;
    display: grid;
    gap: 12px;
}

.analytics-filters {
    display: grid;
    grid-template-columns: repeat(4, minmax(190px, 1fr));
    gap: 12px;
    align-items: stretch;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: color-mix(in srgb, var(--panel) 88%, transparent);
}

.analytics-filter-item {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.analytics-filter-item .field-label {
    margin: 0;
    font-size: 0.74rem;
    letter-spacing: 0.02em;
}

.analytics-filter-item select,
.analytics-filter-item input {
    width: 100%;
    min-height: 42px;
    border-radius: 12px;
    background: color-mix(in srgb, var(--panel) 80%, #ffffff);
    border: 1px solid color-mix(in srgb, var(--line) 88%, #ffffff);
}

.analytics-filter-item select {
    appearance: none;
    -webkit-appearance: none;
    background-image: linear-gradient(45deg, transparent 50%, var(--muted) 50%), linear-gradient(135deg, var(--muted) 50%, transparent 50%);
    background-position: calc(100% - 18px) calc(50% - 2px), calc(100% - 12px) calc(50% - 2px);
    background-size: 6px 6px, 6px 6px;
    background-repeat: no-repeat;
    padding-right: 34px;
}

#analyticsMonth {
    padding-right: 12px;
}

.analytics-range {
    grid-column: span 2;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.analytics-metrics {
    grid-template-columns: repeat(4, minmax(180px, 1fr));
}

.analytics-category-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.analytics-category-block {
    border: 1px solid var(--line);
    border-radius: 16px;
    padding: 12px;
    background: rgba(255, 255, 255, 0.2);
    display: grid;
    gap: 10px;
}

#analyticsMercanciaSection .panel-header,
#analyticsPrestamoSection .panel-header {
    justify-content: center;
}

#analyticsMercanciaSection .panel-header h4,
#analyticsPrestamoSection .panel-header h4 {
    text-align: center;
    width: 100%;
    font-size: 1.24rem;
    font-family: "Sora", sans-serif;
    letter-spacing: 0.01em;
}

.analytics-mini-kpis {
    display: grid;
    grid-template-columns: repeat(3, minmax(140px, 1fr));
    gap: 8px;
}

.analytics-mini-kpis .metric {
    min-height: 78px;
}

#analyticsMercanciaSection .analytics-mini-kpis .metric {
    background: color-mix(in srgb, #26b497 18%, var(--panel));
    border-color: color-mix(in srgb, #26b497 42%, var(--line));
}

#analyticsPrestamoSection .analytics-mini-kpis .metric {
    background: color-mix(in srgb, #1f8f7f 14%, var(--panel));
    border-color: color-mix(in srgb, #1f8f7f 36%, var(--line));
}

.analytics-charts-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
}

.analytics-category-charts-grid {
    grid-template-columns: 1fr;
}

.analytics-global-grid {
    grid-template-columns: 1fr;
}

.analytics-chart-card {
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 10px;
    background: rgba(255, 255, 255, 0.2);
}

.analytics-chart-card h5 {
    margin: 0 0 8px;
    font-family: "Space Grotesk", sans-serif;
    font-size: 0.92rem;
}

.chart-card-wide {
    grid-column: span 2;
}

.chart-bars {
    display: grid;
    gap: 8px;
}

.chart-row {
    display: grid;
    gap: 4px;
}

.chart-row-head {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    align-items: center;
    font-size: 0.82rem;
}

.chart-row-head span {
    min-width: 0;
    overflow-wrap: anywhere;
}

.chart-bar-track {
    width: 100%;
    height: 9px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--line) 65%, transparent);
    overflow: hidden;
}

.chart-bar-fill {
    display: block;
    height: 100%;
    border-radius: 999px;
    background: linear-gradient(90deg, color-mix(in srgb, var(--primary) 75%, #fff), var(--primary));
}

.chart-donut {
    min-height: 220px;
    display: grid;
    align-items: center;
    overflow: hidden;
}

.donut-wrap {
    display: grid;
    grid-template-columns: 110px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
}

.donut-plot {
    width: 110px;
    height: 110px;
    border-radius: 50%;
    position: relative;
    justify-self: center;
}

.donut-plot::after {
    content: "";
    position: absolute;
    inset: 22px;
    border-radius: 50%;
    background: var(--panel);
    border: 1px solid var(--line);
}

.donut-legend {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 6px;
    font-size: 0.82rem;
}

.donut-legend li {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
    overflow-wrap: anywhere;
    line-height: 1.25;
}

.donut-legend span {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    display: inline-block;
}

.chart-trend {
    min-height: 170px;
}

.trend-grid {
    min-height: 170px;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(96px, 1fr));
    gap: 6px;
    align-items: end;
}

.trend-col {
    display: grid;
    gap: 4px;
    justify-items: center;
    text-align: center;
}

.trend-col strong {
    font-size: 0.73rem;
    color: var(--text);
    line-height: 1;
}

.trend-col-fill {
    width: 100%;
    min-height: 8px;
    border-radius: 8px 8px 4px 4px;
    background: linear-gradient(180deg, color-mix(in srgb, var(--primary) 70%, #fff), var(--primary-2));
}

.trend-col small {
    color: var(--muted);
    font-size: 0.68rem;
}

.metric {
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 12px;
    background: rgba(255, 255, 255, 0.18);
    min-height: 86px;
    display: grid;
    align-content: start;
    gap: 4px;
}

.metric p {
    margin: 0;
    font-size: 0.79rem;
    color: var(--muted);
}

.metric strong {
    font-size: 1.22rem;
}

.route-board,
.actions-grid,
.history-card,
.focus-card,
.detail-header {
    padding: 14px;
}

.cobro-insights {
    padding: 14px;
}

.insights-toggle {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    border: none;
    background: transparent;
    color: var(--text);
    padding: 0;
    text-align: left;
    cursor: pointer;
}

.insights-toggle strong {
    display: block;
    margin-bottom: 2px;
    font-family: "Sora", sans-serif;
}

.insights-arrow {
    font-size: 1.1rem;
    transition: transform 0.2s ease;
}

.cobro-insights:not(.collapsed) .insights-arrow {
    transform: rotate(180deg);
}

.insights-body {
    margin-top: 12px;
}

.insights-grid {
    margin-top: 10px;
    display: grid;
    grid-template-columns: repeat(3, minmax(120px, 1fr));
    gap: 8px;
}

.detail-header-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.route-toolbar {
    display: grid;
    gap: 8px;
    margin-bottom: 8px;
}

.filter-group {
    display: flex;
    gap: 6px;
}

.chip {
    padding: 8px 10px;
    font-size: 0.78rem;
}

.route-list {
    display: grid;
    gap: 8px;
}

.route-card {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 10px;
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 12px;
    cursor: grab;
    background: rgba(255, 255, 255, 0.28);
    align-items: center;
}

.route-card:hover {
    box-shadow: var(--shadow-soft);
}

.route-card.active {
    border-color: var(--primary);
}

.route-card.dragging {
    opacity: 0.45;
}

.route-card.drop-target {
    border-color: color-mix(in srgb, var(--primary) 76%, var(--line));
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--primary) 24%, transparent);
}

.route-index {
    width: 30px;
    height: 30px;
    display: grid;
    place-items: center;
    border-radius: 10px;
    border: 1px solid var(--line);
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--muted);
    cursor: grab;
    user-select: none;
    -webkit-user-select: none;
}

.route-main {
    min-width: 0;
}

.route-actions {
    margin-top: 8px;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.route-btn {
    min-height: 34px;
    padding: 6px 12px;
    font-size: 0.78rem;
}

.route-head {
    display: flex;
    gap: 8px;
    align-items: center;
    justify-content: space-between;
}

.route-menu-wrap {
    position: relative;
    margin-left: auto;
}

.route-menu-toggle {
    min-height: 34px;
    min-width: 34px;
    padding: 0;
    display: none;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    font-size: 1.1rem;
    line-height: 1;
}

.route-menu {
    position: absolute;
    right: 0;
    top: calc(100% + 6px);
    min-width: 148px;
    display: none;
    gap: 6px;
    padding: 8px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: color-mix(in srgb, var(--panel) 92%, #ffffff);
    box-shadow: var(--shadow-soft);
    z-index: 25;
}

.route-menu.open {
    display: grid;
}

.route-menu-item {
    width: 100%;
    justify-content: center;
}

.client-avatar {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    object-fit: cover;
    border: 1px solid var(--line);
}

.client-avatar-empty {
    display: grid;
    place-items: center;
    font-size: 0.58rem;
    color: var(--muted);
    background: rgba(255, 255, 255, 0.35);
}

.route-main strong,
.route-head p {
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.route-main strong {
    font-size: 1rem;
}

.route-main .route-reason {
    margin-top: 6px;
    white-space: normal;
    overflow: hidden;
    display: -webkit-box;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.status-pill {
    display: inline-block;
    font-size: 0.73rem;
    border-radius: 999px;
    padding: 5px 9px;
    margin-top: 5px;
}

.status-ok {
    color: var(--ok);
    border: 1px solid color-mix(in srgb, var(--ok) 60%, transparent);
    background: color-mix(in srgb, var(--ok) 14%, transparent);
}

.status-warning {
    color: var(--warning);
    border: 1px solid color-mix(in srgb, var(--warning) 60%, transparent);
    background: color-mix(in srgb, var(--warning) 20%, transparent);
}

.status-danger {
    color: var(--danger);
    border: 1px solid color-mix(in srgb, var(--danger) 60%, transparent);
    background: color-mix(in srgb, var(--danger) 14%, transparent);
}

.status-cancelado {
    color: var(--info);
    border: 1px solid color-mix(in srgb, var(--info) 60%, transparent);
    background: color-mix(in srgb, var(--info) 14%, transparent);
}

/* Payment status indicators - based on payment schedule */
.payment-ok {
    color: var(--ok);
    border: 1px solid color-mix(in srgb, var(--ok) 60%, transparent);
    background: color-mix(in srgb, var(--ok) 14%, transparent);
}

.payment-warning {
    color: var(--warning);
    border: 1px solid color-mix(in srgb, var(--warning) 60%, transparent);
    background: color-mix(in srgb, var(--warning) 20%, transparent);
}

.payment-danger {
    color: var(--danger);
    border: 1px solid color-mix(in srgb, var(--danger) 60%, transparent);
    background: color-mix(in srgb, var(--danger) 14%, transparent);
}

.amount-pill {
    border-radius: var(--radius-pill);
    padding: 5px 9px;
    font-size: 0.76rem;
    background: color-mix(in srgb, var(--text) 8%, transparent);
    color: var(--text);
}

.focus-content {
    border: 1px dashed var(--line);
    border-radius: 12px;
    padding: 14px;
    display: grid;
    gap: 8px;
}

.focus-name {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
}

.focus-name-group {
    display: flex;
    align-items: center;
    gap: 10px;
}

.focus-photo {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    object-fit: cover;
    border: 1px solid var(--line);
}

.focus-photo-clickable {
    cursor: zoom-in;
    transition: opacity 0.15s;
}

.focus-photo-clickable:hover {
    opacity: 0.82;
}

.focus-photo-empty {
    display: grid;
    place-items: center;
    font-size: 0.66rem;
    color: var(--muted);
    background: rgba(255, 255, 255, 0.35);
}

.foto-preview-img {
    display: block;
    width: 64px;
    height: 64px;
    border-radius: 8px;
    object-fit: cover;
    border: 1px solid var(--line);
    margin-top: 4px;
}

.foto-preview-img.hidden {
    display: none;
}

.photo-lightbox {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.88);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
}

.photo-lightbox.hidden {
    display: none;
}

.lightbox-img {
    max-width: 90vw;
    max-height: 90vh;
    border-radius: 10px;
    object-fit: contain;
    box-shadow: 0 8px 40px rgba(0, 0, 0, 0.6);
}

.lightbox-close {
    position: absolute;
    top: 18px;
    right: 22px;
    background: rgba(255, 255, 255, 0.15);
    border: none;
    color: #fff;
    font-size: 1.4rem;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    cursor: pointer;
    display: grid;
    place-items: center;
    line-height: 1;
}

.lightbox-close:hover {
    background: rgba(255, 255, 255, 0.3);
}

.edit-cliente-btn {
    font-size: 0.8rem;
    min-height: 32px;
    padding: 6px 10px;
}

.focus-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
}

.focus-kpi {
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 10px;
    background: rgba(255, 255, 255, 0.2);
}

.focus-kpi p {
    margin: 0;
    color: var(--muted);
    font-size: 0.78rem;
}

.focus-kpi strong {
    font-size: 1.05rem;
}

.status-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}

.actions-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}

#interestField.hidden {
    display: none;
}

.history-list {
    max-height: 320px;
    overflow: auto;
    display: grid;
    gap: 8px;
}

.detail-history-list {
    max-height: 220px;
}

.history-item {
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 12px;
    font-size: 0.9rem;
    background: rgba(255, 255, 255, 0.2);
}

::-webkit-scrollbar {
    width: 9px;
    height: 9px;
}

::-webkit-scrollbar-track {
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background: color-mix(in srgb, var(--line) 80%, var(--text));
    border-radius: 10px;
}

::-webkit-scrollbar-thumb:hover {
    background: color-mix(in srgb, var(--primary) 65%, var(--line));
}

.history-row {
    display: flex;
    justify-content: space-between;
    gap: 10px;
}

.muted {
    color: var(--muted);
    margin: 0;
}

.hidden {
    display: none !important;
}

#toast {
    position: fixed;
    bottom: 18px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--text);
    color: var(--bg);
    border-radius: 999px;
    padding: 8px 14px;
    opacity: 0;
    transition: opacity 0.24s;
    z-index: 40;
}

#toast.show {
    opacity: 1;
}

.floating-overlay {
    position: fixed;
    inset: 0;
    background: rgba(8, 15, 16, 0.45);
    backdrop-filter: blur(3px);
    z-index: 39;
}

.alert-overlay {
    z-index: 61;
    background: rgba(4, 13, 15, 0.56);
}

.alert-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 62;
    width: min(520px, calc(100vw - 24px));
    padding: 18px;
    border-radius: 18px;
    border: 1px solid color-mix(in srgb, var(--line) 80%, var(--primary));
    box-shadow: 0 24px 55px rgba(2, 20, 24, 0.42);
    display: grid;
    gap: 10px;
}

.alert-modal-head {
    display: flex;
    justify-content: flex-start;
}

.alert-modal h4 {
    font-size: 1.12rem;
}

.alert-modal-actions {
    margin-top: 4px;
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    flex-wrap: wrap;
}

.cliente-floating {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: min(640px, calc(100vw - 30px));
    max-height: calc(100vh - 40px);
    overflow: auto;
    padding: 16px;
    z-index: 41;
}

.action-floating {
    width: min(520px, calc(100vw - 30px));
}

.floating-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
}

.detail-mov-item {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 9px;
    background: rgba(255, 255, 255, 0.2);
}

.detail-mov-main {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.detail-mov-main strong {
    font-size: 0.9rem;
    color: var(--text);
}

.detail-mov-main p {
    margin: 0;
    font-size: 0.85rem;
}

.detail-mov-main .muted {
    font-size: 0.75rem;
}

@media (max-width: 1024px) {
    .metrics {
        grid-template-columns: repeat(2, 1fr);
    }

    .insights-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .focus-grid {
        grid-template-columns: 1fr;
    }

    .analytics-filters {
        grid-template-columns: repeat(2, minmax(170px, 1fr));
    }

    .analytics-range {
        grid-column: span 2;
    }

    .analytics-category-grid,
    .analytics-global-grid {
        grid-template-columns: 1fr;
    }

    .analytics-category-charts-grid {
        grid-template-columns: 1fr;
    }

    .chart-card-wide {
        grid-column: auto;
    }

    .admin-users-grid {
        grid-template-columns: repeat(2, minmax(260px, 1fr));
        max-height: none;
        overflow: visible;
    }

    .admin-alert-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 900px) {
    .app-shell {
        grid-template-columns: 1fr;
    }

    .admin-users-grid {
        grid-template-columns: 1fr;
    }

    .app-shell.screen-cobro .panel-left {
        display: none;
    }

    .panel-left {
        min-height: auto;
        max-height: none;
        overflow: visible;
    }
}

@media (max-width: 720px) {
    .topbar {
        position: static;
        top: auto;
        border-radius: 16px;
        margin: 10px 10px 0;
        padding: 10px 12px;
        gap: 10px;
        align-items: center;
        flex-direction: row;
    }

    .brand-lockup {
        width: auto;
    }

    .brand-mark {
        width: 44px;
        height: 44px;
        border-radius: 10px;
    }

    .topbar-actions {
        width: auto;
        justify-content: flex-end;
        flex-wrap: nowrap;
        margin-left: auto;
    }

    .topbar-actions .ghost-btn,
    .topbar-actions .user-badge {
        min-height: 36px;
    }

    .layout {
        padding: 8px 10px 16px;
    }

    .tab,
    .chip,
    .primary-btn,
    .ghost-btn,
    .danger-btn,
    .tab-view,
    input,
    select,
    textarea {
        min-height: 44px;
        font-size: 16px;
    }

    .metrics {
        grid-template-columns: 1fr;
    }

    .insights-grid {
        grid-template-columns: 1fr;
    }

    .actions-grid {
        grid-template-columns: 1fr;
    }

    .detail-header-actions {
        width: 100%;
        justify-content: flex-start;
        align-items: flex-start;
    }

    .route-card {
        grid-template-columns: auto 1fr;
        align-items: start;
    }

    .route-card > .amount-pill {
        grid-column: 2;
        justify-self: start;
        margin-top: 6px;
    }

    .section-tabs {
        position: static;
        overflow: auto;
        justify-content: center;
        padding: 8px;
        top: auto;
        margin-top: -2px;
        scrollbar-width: thin;
    }

    .tab-view {
        font-size: 0.83rem;
        flex: 0 0 auto;
    }

    .route-actions {
        gap: 6px;
    }

    .route-actions {
        display: none;
    }

    .route-menu-toggle {
        display: inline-flex;
    }

    .route-toolbar {
        position: sticky;
        top: 0;
        z-index: 6;
        padding: 8px;
        margin: -2px -2px 8px;
        border-radius: 12px;
        border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
        background: color-mix(in srgb, var(--panel) 92%, #ffffff);
        backdrop-filter: blur(8px);
    }

    .filter-group {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }

    .app-shell,
    .main-stack,
    .view-panel,
    .route-board,
    .focus-card,
    .history-card,
    .employees-card,
    .analytics-card,
    .home-summary,
    .detail-header,
    .cobro-insights,
    .metrics,
    .panel-left {
        width: min(100%, 860px);
        margin-inline: auto;
    }

    .panel-header {
        justify-content: space-between;
        align-items: flex-start;
        text-align: left;
        flex-direction: row;
        flex-wrap: wrap;
    }

    .panel-header > div {
        text-align: left;
    }

    .focus-content,
    .history-item,
    .list-item,
    .employee-card,
    .metric,
    .analytics-chart-card,
    .analytics-category-block,
    .home-summary,
    .detail-mov-item {
        text-align: left;
    }

    .route-head,
    .focus-name,
    .focus-name-group,
    .employee-head,
    .history-row,
    .chart-row-head {
        justify-content: space-between;
    }

    .route-actions,
    .employee-actions,
    .status-actions,
    .alert-modal-actions,
    .detail-header-actions {
        justify-content: flex-start;
    }

    .muted {
        text-align: left;
    }

    .filter-group .chip {
        width: 100%;
    }

    .panel-left,
    .route-board,
    .focus-card,
    .detail-header,
    .cobro-insights,
    .history-card,
    .employees-card,
    .analytics-card,
    .home-summary,
    .metrics {
        padding: 12px;
    }

    .analytics-filters,
    .analytics-metrics,
    .analytics-mini-kpis {
        grid-template-columns: 1fr;
    }

    .analytics-filter-item select,
    .analytics-filter-item input {
        min-height: 40px;
    }

    .analytics-range {
        grid-column: auto;
        grid-template-columns: 1fr;
    }

    .donut-wrap {
        grid-template-columns: 1fr;
        justify-items: start;
    }

    .cliente-floating {
        width: min(700px, calc(100vw - 14px));
        max-height: calc(100vh - 12px - var(--safe-bottom));
        padding: 14px 12px calc(14px + var(--safe-bottom));
        border-radius: 16px;
    }
}

@media (max-width: 560px) {
    .eyebrow {
        font-size: 0.66rem;
    }

    .topbar h1 {
        font-size: 1.2rem;
    }

    .detail-header-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .detail-header-actions .primary-btn,
    .detail-header-actions .ghost-btn {
        width: 100%;
        max-width: 340px;
    }

    .route-actions .route-btn {
        flex: 1 1 100%;
        max-width: 340px;
        justify-content: center;
    }

    .status-actions .ghost-btn,
    .status-actions .danger-btn {
        flex: 1 1 100%;
        max-width: 340px;
    }

    .user-badge {
        display: none;
    }

    .employee-actions .ghost-btn,
    .employee-actions .danger-btn {
        width: 100%;
        max-width: 340px;
        margin-inline: auto;
    }

    .user-badge {
        max-width: 100%;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        margin-inline: 0;
    }
}

@media (max-width: 420px) {
    .alert-modal {
        width: calc(100vw - 14px);
        padding: 14px;
        border-radius: 14px;
    }
}

@media (max-width: 412px) {
    .topbar {
        margin: 8px 8px 0;
        padding: 10px;
    }

    .layout {
        padding: 8px 8px 16px;
    }

    .section-tabs {
        gap: 6px;
        border-radius: 12px;
    }

    .tab-view {
        padding: 7px 12px;
        font-size: 0.8rem;
    }

    .panel-left,
    .route-board,
    .focus-card,
    .detail-header,
    .cobro-insights,
    .history-card,
    .employees-card,
    .analytics-card,
    .home-summary,
    .metrics {
        padding: 10px;
        border-radius: 16px;
    }

    .cliente-floating {
        width: calc(100vw - 10px);
        max-height: calc(100vh - 10px - var(--safe-bottom));
        padding: 12px 10px calc(12px + var(--safe-bottom));
        border-radius: 14px;
    }
}

@media (max-width: 390px) {
    .brand-lockup {
        gap: 9px;
    }

    .brand-mark {
        width: 38px;
        height: 38px;
        border-radius: 9px;
    }

    .topbar h1 {
        font-size: 1.08rem;
    }

    .eyebrow {
        letter-spacing: 0.12em;
    }

    .section-tabs {
        padding: 7px;
    }

    .filter-group {
        grid-template-columns: 1fr;
    }

    .chip {
        padding: 8px;
        font-size: 0.76rem;
    }

    .route-card {
        padding: 10px;
        gap: 8px;
    }

    .route-menu {
        right: -2px;
        min-width: 136px;
    }

    .route-main strong {
        font-size: 0.93rem;
    }

    .focus-content {
        padding: 10px;
    }

    .status-pill,
    .amount-pill {
        font-size: 0.71rem;
        padding: 4px 8px;
    }
}

@media (max-width: 360px) {
    .topbar {
        margin: 6px 6px 0;
        padding: 9px;
        border-radius: 14px;
    }

    .layout {
        padding: 7px 6px 14px;
    }

    .section-tabs {
        padding: 6px;
        gap: 5px;
    }

    .tab-view {
        min-height: 42px;
        padding: 7px 10px;
        font-size: 0.76rem;
    }

    .topbar-actions {
        gap: 6px;
    }

    .topbar-actions .ghost-btn,
    .topbar-actions .user-badge {
        min-height: 34px;
        padding: 7px 10px;
        font-size: 0.74rem;
    }

    .auth-card {
        margin: 22px auto;
        padding: 14px;
        border-radius: 16px;
    }

    .history-item,
    .list-item,
    .employee-card,
    .metric {
        padding: 10px;
    }

    .panel-header {
        gap: 6px;
        margin-bottom: 10px;
    }

    .detail-header-actions .primary-btn,
    .detail-header-actions .ghost-btn,
    .route-actions .route-btn,
    .status-actions .ghost-btn,
    .status-actions .danger-btn,
    .employee-actions .ghost-btn,
    .employee-actions .danger-btn {
        min-height: 42px;
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation: none !important;
        transition: none !important;
        scroll-behavior: auto !important;
    }
}
