/* =========================================
   TURNO DIGITAL - ACTIVE UI STYLESHEET

   Status:
   - This is the only stylesheet loaded by the active application shell.
   - Legacy stylesheets were removed from active static root and archived under:
     backend/static/legacy_css/

   Internal organization:
   1. Active tokens
   2. Turno-specific refinements and page layers
   3. Core shell/components inherited by the active app
   4. Deliberate override layers used by the current premium interface

   Notes:
   - This file still contains historical layering and controlled overrides.
   - When removing selectors, prefer verifying template/HTMX usage first.
   ========================================= */

:root {
    --bg: #f5f7fb;
    --bg-elevated: #eef2f8;
    --card: #ffffff;
    --card-muted: #f8fafd;
    --border: #e6eaf2;
    --border-strong: #d6dce8;
    --card-border: #e7ebf3;
    --text: #111827;
    --text-muted: #667085;
    --text-soft: #98a2b3;
    --info: #356dff;
    --info-soft: rgba(53, 109, 255, 0.1);
    --success: #22a06b;
    --success-soft: rgba(34, 160, 107, 0.12);
    --warning: #d9a441;
    --warning-soft: rgba(217, 164, 65, 0.14);
    --danger: #d9534f;
    --danger-soft: rgba(217, 83, 79, 0.12);
    --sidebar-bg: #0f172a;
    --sidebar-bg-soft: rgba(148, 163, 184, 0.08);
    --sidebar-border: rgba(148, 163, 184, 0.14);
    --sidebar-text: #e2e8f0;
    --sidebar-text-muted: #94a3b8;
    --shadow-light: 0 1px 2px rgba(16, 24, 40, 0.04);
    --shadow-medium: 0 8px 24px rgba(16, 24, 40, 0.06);
    --shadow-premium: 0 18px 40px rgba(16, 24, 40, 0.05);
    --radius-sm: 10px;
    --radius-md: 14px;
    --radius-lg: 18px;
    --radius-pill: 999px;
    --space-1: 4px;
    --space-2: 8px;
    --space-3: 12px;
    --space-4: 16px;
    --space-5: 20px;
    --space-6: 24px;
    --space-7: 28px;
    --space-8: 32px;
    --sidebar-width: 264px;
    --content-max: 1360px;
    --bottom-nav-height: 76px;
    --font-sans: "Segoe UI Variable Display", "Bahnschrift", "Segoe UI", sans-serif;
    --font-display: "Segoe UI Variable Display", "Bahnschrift", "Segoe UI", sans-serif;
    --title-size: 28px;
    --section-title-size: 20px;
    --subtitle-size: 14px;
    --label-size: 11px;
    --value-size: 15px;
}

/* Passagem de Turno - premium core refinement */

.turno-list-page {
    gap: 14px;
}

.turno-list-shell {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
    gap: 14px 18px;
    padding: 16px 18px;
    border-color: rgba(217, 223, 233, 0.92);
    background:
        radial-gradient(circle at top right, rgba(29, 78, 216, 0.05), transparent 28%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(246, 248, 252, 0.98));
    box-shadow:
        0 1px 2px rgba(16, 24, 40, 0.04),
        0 14px 28px rgba(15, 23, 42, 0.05);
}

.turno-list-shell::after {
    background: linear-gradient(120deg, rgba(29, 78, 216, 0.035), transparent 42%);
}

.turno-list-shell-main {
    display: grid;
    gap: 12px;
    min-width: 0;
}

.turno-list-shell-info {
    gap: 10px;
}

.turno-list-shell-copy {
    display: grid;
    gap: 6px;
    max-width: 760px;
}

.turno-list-shell .page-header-title {
    font-size: clamp(28px, 2.2vw, 34px);
    font-weight: 800;
    letter-spacing: -0.055em;
}

.turno-list-shell .page-header-subtitle {
    margin-top: 2px;
    max-width: 58ch;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.45;
    color: #667085;
}

.turno-list-summary-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.turno-list-summary-item {
    display: grid;
    gap: 3px;
    min-width: 112px;
    padding: 10px 12px;
    border-radius: 14px;
    border: 1px solid rgba(223, 228, 236, 0.96);
    background: rgba(248, 250, 252, 0.9);
}

.turno-list-summary-item strong {
    font-family: var(--font-display);
    font-size: 22px;
    line-height: 1;
    font-weight: 800;
    letter-spacing: -0.05em;
    color: #111827;
}

.turno-list-shell-actions {
    align-self: start;
    justify-content: flex-end;
}

.turno-list-shell-actions .btn {
    min-height: 36px;
    padding-inline: 14px;
}

.turno-list-page .turno-filter-card-compact,
.turno-list-page .turno-history-shell {
    border-radius: 18px;
    border-color: rgba(221, 226, 234, 0.94);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.992), rgba(248, 250, 252, 0.985));
    box-shadow:
        0 1px 2px rgba(16, 24, 40, 0.04),
        0 12px 24px rgba(15, 23, 42, 0.05);
}

.turno-list-page .turno-filter-card-compact {
    padding: 14px 16px;
}

.turno-filter-headline {
    margin-bottom: 10px;
    align-items: center;
}

.turno-filter-tools {
    justify-content: flex-end;
}

.turno-list-page .turno-filter-grid-compact {
    gap: 10px 12px;
}

.turno-list-page .turno-filter-grid-compact .field {
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.turno-list-page .turno-filter-grid-compact .label {
    margin-bottom: 5px;
    font-size: 10px;
    letter-spacing: 0.1em;
}

.turno-list-page .turno-filter-grid-compact .control {
    min-height: 36px;
    padding: 0 12px;
    border-radius: 12px;
    border-color: rgba(209, 217, 228, 0.96);
    background: rgba(255, 255, 255, 0.98);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.turno-list-page .turno-filter-grid-compact .control:focus {
    box-shadow:
        0 0 0 4px rgba(37, 99, 235, 0.08),
        0 8px 18px rgba(37, 99, 235, 0.05);
}

.turno-filter-toolbar-inline {
    justify-content: space-between;
    padding-top: 2px;
}

.turno-filter-toolbar-inline .btn {
    min-height: 34px;
}

.turno-list-page .turno-history-shell {
    padding: 14px 0 0;
}

.turno-history-headline {
    margin: 0 16px 10px;
    align-items: center;
}

.turno-history-body {
    gap: 0;
}

.turno-list-page .turno-history-line-list {
    gap: 0;
}

.turno-list-page .turno-history-row {
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    overflow: visible;
}

.turno-list-page .turno-history-row + .turno-history-row {
    border-top: 1px solid rgba(226, 232, 240, 0.92);
}

.turno-list-page .turno-history-row:hover {
    transform: none;
    border-color: transparent;
    box-shadow: none;
    background: linear-gradient(180deg, rgba(248, 250, 252, 0.82), rgba(255, 255, 255, 0.68));
}

.turno-list-page .turno-status-rail {
    width: 4px;
}

.turno-list-page .turno-history-grid {
    grid-template-columns: minmax(0, 1.8fr) auto minmax(132px, auto) auto;
    gap: 12px 14px;
    padding: 14px 16px;
    align-items: center;
}

.turno-list-page .turno-card-title {
    font-size: 16px;
    font-weight: 700;
    letter-spacing: -0.035em;
}

.turno-list-page .turno-history-subline {
    gap: 4px 10px;
    font-size: 12px;
}

.turno-list-page .turno-history-badges {
    gap: 10px;
}

.turno-list-page .turno-count-badge {
    min-height: auto;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    gap: 1px;
    align-items: flex-start;
}

.turno-list-page .turno-count-badge strong {
    font-size: 16px;
    letter-spacing: -0.04em;
}

.turno-list-page .turno-count-badge small {
    font-size: 9px;
    letter-spacing: 0.1em;
}

.turno-list-page .turno-history-updated {
    min-width: 132px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.turno-list-page .turno-history-updated strong {
    font-size: 14px;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.turno-list-page .turno-history-actions {
    justify-content: flex-end;
    gap: 6px;
}

.turno-list-page .turno-history-actions .btn {
    min-height: 32px;
    padding-inline: 11px;
    border-radius: 11px;
}

.turno-detail-page {
    gap: 14px;
}

.turno-detail-header-shell {
    padding: 16px 18px;
    gap: 12px;
    border-color: rgba(217, 223, 233, 0.92);
    background:
        radial-gradient(circle at top right, rgba(29, 78, 216, 0.05), transparent 28%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.992), rgba(246, 248, 252, 0.985));
    box-shadow:
        0 1px 2px rgba(16, 24, 40, 0.04),
        0 14px 28px rgba(15, 23, 42, 0.05);
}

.turno-detail-header-shell::after {
    background: linear-gradient(120deg, rgba(29, 78, 216, 0.032), transparent 42%);
}

.turno-detail-header-top {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px 18px;
    align-items: start;
}

.turno-detail-header-copy {
    gap: 8px;
}

.turno-detail-page .turno-detail-heading {
    gap: 6px;
}

.turno-detail-page .turno-detail-title {
    font-size: clamp(28px, 2.3vw, 34px);
    font-weight: 800;
    letter-spacing: -0.058em;
}

.turno-detail-page .turno-detail-subtitle {
    max-width: 62ch;
    font-size: 13px;
    line-height: 1.45;
    color: #667085;
}

.turno-detail-page .turno-card-subtitle {
    margin: 0;
    font-size: 12px;
    font-weight: 600;
    color: #475467;
}

.turno-detail-header-status {
    display: flex;
    align-items: flex-start;
    justify-content: flex-end;
}

.turno-detail-meta-strip {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 10px 14px;
    padding-top: 12px;
    border-top: 1px solid rgba(226, 232, 240, 0.9);
}

.turno-detail-meta-item {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.turno-detail-meta-item strong {
    font-size: 14px;
    line-height: 1.35;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: #111827;
}

.turno-detail-page .turno-detail-kpi-strip {
    gap: 10px;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}

.turno-detail-page .turno-detail-kpi-card {
    min-height: 74px;
    padding: 12px 14px;
    gap: 6px;
    border-radius: 14px;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.86),
        0 8px 16px rgba(16, 24, 40, 0.04);
}

.turno-detail-page .turno-detail-kpi-card .turno-summary-label {
    font-size: 9px;
    letter-spacing: 0.12em;
}

.turno-detail-page .turno-detail-kpi-card .turno-summary-value {
    font-size: 24px;
    font-weight: 800;
    letter-spacing: -0.055em;
}

.turno-detail-page .turno-detail-section-card {
    border-radius: 18px;
    box-shadow:
        0 1px 2px rgba(16, 24, 40, 0.04),
        0 10px 22px rgba(15, 23, 42, 0.045);
}

.turno-detail-page .turno-detail-section-card::before {
    width: 3px;
}

.turno-detail-page .turno-detail-section-card > .card-header {
    padding: 14px 16px 10px 18px;
}

.turno-detail-page .turno-detail-section-card > .card-body {
    padding: 12px 16px 16px 18px;
    gap: 12px;
}

.turno-detail-page .turno-detail-section-card .card-title {
    font-size: 17px;
    font-weight: 700;
    letter-spacing: -0.035em;
}

.turno-detail-page .turno-detail-section-card .muted {
    font-size: 12px;
}

.turno-detail-page .turno-section-tools {
    gap: 6px;
}

.turno-section-badge-soft {
    background: transparent;
    border-style: dashed;
    color: #98a2b3;
}

.turno-detail-page .turno-detail-mini-card {
    padding: 12px 14px;
    border-radius: 14px;
    border-color: rgba(225, 230, 238, 0.94);
    background: linear-gradient(180deg, rgba(248, 250, 252, 0.88), rgba(255, 255, 255, 0.92));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.84);
}

.turno-detail-page .turno-detail-card-grid,
.turno-detail-page .turno-detail-card-grid-dense {
    gap: 10px 16px;
}

.turno-detail-page .turno-meta-caption {
    font-size: 9px;
    letter-spacing: 0.12em;
    color: #94a3b8;
}

.turno-detail-page .turno-detail-field-cell strong,
.turno-detail-page .turno-detail-field-card strong {
    font-size: 14px;
    line-height: 1.5;
    font-weight: 600;
}

.turno-detail-page .turno-detail-toolbar {
    padding: 10px 12px;
    border-radius: 16px;
    border-color: rgba(221, 226, 234, 0.94);
    background: rgba(255, 255, 255, 0.95);
    box-shadow:
        0 1px 2px rgba(16, 24, 40, 0.04),
        0 10px 20px rgba(15, 23, 42, 0.05);
}

.turno-detail-page .turno-detail-toolbar .btn {
    min-height: 36px;
    padding-inline: 13px;
}

@media (max-width: 1024px) {
    .turno-list-shell,
    .turno-detail-header-top {
        grid-template-columns: 1fr;
    }

    .turno-list-shell-actions,
    .turno-detail-header-status {
        justify-content: flex-start;
    }

    .turno-list-page .turno-history-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .turno-list-page .turno-history-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 640px) {
    .turno-list-summary-strip,
    .turno-detail-meta-strip {
        display: grid;
        grid-template-columns: 1fr;
    }

    .turno-list-summary-item,
    .turno-detail-meta-item {
        min-width: 0;
    }
}

/* ---------- Legacy Internal Override Layer (Phase: compactacao executiva)
   Historical compaction layer removed from active cascade.
   It duplicated global selectors already governed by the official reset below.
   Page-specific behavior is now maintained by the official page blocks. ---------- */

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

html {
    -webkit-text-size-adjust: 100%;
    font-synthesis-weight: none;
}

body {
    margin: 0;
    min-height: 100vh;
    font-family: var(--font-sans);
    color: var(--text);
    background:
        radial-gradient(circle at top left, rgba(53, 109, 255, 0.035), transparent 24%),
        linear-gradient(180deg, #fbfcfe 0%, var(--bg) 100%);
    line-height: 1.38;
}

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

button,
input,
select,
textarea {
    font: inherit;
}

button {
    cursor: pointer;
}

img,
svg {
    display: block;
    max-width: 100%;
}

[hidden] {
    display: none !important;
}

/* ---------- Legacy Core Foundation (Preserved)
   Merged historical base used across active and less-frequent surfaces.
   This section remains intentionally broad because admin/HTMX screens still
   depend on many of these selectors. The official active look is refined later
   by the reset blocks marked as authoritative. ---------- */

.app-shell {
    display: grid;
    grid-template-columns: var(--sidebar-width) minmax(0, 1fr);
    min-height: 100vh;
}

.sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    width: var(--sidebar-width);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent 24%),
        linear-gradient(180deg, #0f172a 0%, #111827 100%);
    color: var(--sidebar-text);
    border-right: 1px solid var(--sidebar-border);
    display: flex;
    flex-direction: column;
    z-index: 30;
    transition: transform 180ms ease;
}

.sidebar-header {
    padding: 22px 18px 16px;
    border-bottom: 1px solid var(--sidebar-border);
}

.sidebar-brand {
    display: flex;
    align-items: center;
    gap: 12px;
}

.brand-icon,
.page-header-icon,
.section-icon,
.stat-icon-wrapper,
.turno-metric-icon,
.action-icon-wrapper,
.list-item-icon,
.hero-stat-value.success {
    flex-shrink: 0;
}

.brand-icon,
.page-header-icon,
.section-icon,
.stat-icon-wrapper,
.turno-metric-icon,
.action-icon-wrapper,
.list-item-icon {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(180deg, rgba(59, 130, 246, 0.18), rgba(59, 130, 246, 0.08));
    color: var(--info);
    border: 1px solid rgba(59, 130, 246, 0.14);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.page-header-icon {
    width: 36px;
    height: 36px;
    border-radius: 12px;
}

.brand-icon {
    background: linear-gradient(180deg, rgba(59, 130, 246, 0.95), rgba(59, 130, 246, 0.78));
    border-color: rgba(255, 255, 255, 0.18);
    color: #ffffff;
    box-shadow: 0 8px 20px rgba(59, 130, 246, 0.24);
}

.brand-copy {
    display: grid;
    gap: 2px;
}

.brand-copy strong {
    font-size: 17px;
    font-weight: 700;
    letter-spacing: -0.03em;
}

.brand-copy small {
    font-size: 11px;
    color: var(--sidebar-text-muted);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.sidebar-nav {
    flex: 1;
    overflow-y: auto;
    padding: 18px 12px;
    display: grid;
    gap: 18px;
}

.nav-section {
    display: grid;
    gap: 4px;
}

.nav-section-title {
    padding: 0 10px 8px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--sidebar-text-muted);
}

.sidebar-link,
.bottom-link {
    position: relative;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 11px 12px;
    border-radius: 12px;
    color: var(--sidebar-text-muted);
    transition: background-color 140ms ease, color 140ms ease, border-color 140ms ease;
    border: 1px solid transparent;
}

.sidebar-link:hover,
.bottom-link:hover {
    background: var(--sidebar-bg-soft);
    color: var(--sidebar-text);
}

.sidebar-link.active,
.bottom-link.active {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(53, 109, 255, 0.1));
    color: #f8fafc;
    border-color: rgba(255, 255, 255, 0.08);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05), 0 6px 16px rgba(2, 6, 23, 0.18);
}

.sidebar-link.active::before {
    content: "";
    position: absolute;
    left: -12px;
    top: 10px;
    bottom: 10px;
    width: 2px;
    border-radius: 999px;
    background: linear-gradient(180deg, #8fb0ff, var(--info));
}

.sidebar-icon,
.bottom-icon {
    width: 20px;
    height: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.sidebar-label {
    font-size: 14px;
    font-weight: 500;
}

.sidebar-footer {
    padding: 14px 14px 18px;
    border-top: 1px solid var(--sidebar-border);
}

.user-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    border-radius: 14px;
    border: 1px solid var(--sidebar-border);
    background: rgba(255, 255, 255, 0.04);
}

.user-avatar,
.user-initials {
    width: 38px;
    height: 38px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(180deg, #818cf8, #4f46e5);
    color: #ffffff;
    font-weight: 700;
    box-shadow: 0 8px 18px rgba(79, 70, 229, 0.28);
}

.user-info,
.user-chip-info {
    min-width: 0;
    display: grid;
    gap: 2px;
}

.user-info strong,
.user-chip-info strong {
    font-size: 14px;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.user-role {
    font-size: 11px;
    color: var(--sidebar-text-muted);
}

.sidebar-overlay {
    display: none;
}

.sidebar-overlay:not([hidden]) {
    position: fixed;
    inset: 0;
    display: block;
    background: rgba(15, 23, 42, 0.5);
    backdrop-filter: blur(3px);
    z-index: 20;
}

.content-wrapper {
    grid-column: 2;
    min-width: 0;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.topbar {
    position: sticky;
    top: 0;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 12px 22px;
    background: rgba(255, 255, 255, 0.86);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(229, 231, 235, 0.8);
}

.topbar-left,
.topbar-actions {
    display: flex;
    align-items: center;
    gap: 12px;
}

.topbar-title {
    margin: 0;
    font-size: 17px;
    font-weight: 600;
    letter-spacing: -0.03em;
}

.hamburger {
    width: 38px;
    height: 38px;
    display: none;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    border: 1px solid var(--border);
    background: #ffffff;
    color: var(--text);
}

.user-chip {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 7px 12px;
    min-height: 52px;
    border-radius: 14px;
    border: 1px solid var(--border);
    background: linear-gradient(180deg, #ffffff, #f8fafc);
    box-shadow: var(--shadow-light);
}

.logout-form {
    display: contents;
}

.content {
    flex: 1;
    padding: 20px 22px;
    min-width: 0;
}

.content-inner,
.container {
    width: 100%;
    max-width: var(--content-max);
    margin: 0 auto;
    min-width: 0;
}

.content-inner {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.page {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.stack {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.stack-sm {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.muted,
.page-header-subtitle,
.hero-subtitle,
.section-subtitle,
.empty-desc,
.turno-card-subtitle,
.turno-detail-subtitle,
.turno-card-note,
.turno-field-help,
.list-row-meta,
.list-item-time,
.turno-inline-note,
.turno-metric-copy,
.turno-detail-date,
.turno-detail-owner {
    color: var(--text-muted);
    font-size: 13px;
    font-weight: 400;
}

.page-header,
.dashboard-hero,
.turno-detail-hero,
.turno-form-hero,
.turno-premium-hero {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 14px 18px;
    align-items: start;
    padding: 16px 18px;
    border-radius: var(--radius-lg);
    border: 1px solid var(--card-border);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.985), rgba(248, 250, 253, 0.97));
    box-shadow: var(--shadow-light), var(--shadow-medium), var(--shadow-premium);
    overflow: hidden;
}

.page-header::after,
.dashboard-hero::after,
.turno-detail-hero::after,
.turno-form-hero::after,
.turno-premium-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, rgba(53, 109, 255, 0.028), transparent 44%);
    pointer-events: none;
}

.page-header-content,
.page-header-info,
.hero-greeting,
.turno-detail-hero-main,
.turno-detail-hero-copy,
.turno-hero-copy {
    position: relative;
    z-index: 1;
}

.page-header-content,
.turno-detail-hero-main {
    display: contents;
}

.page-header-info,
.hero-greeting,
.turno-detail-hero-copy {
    min-width: 0;
    display: flex;
    align-items: flex-start;
    gap: 12px;
}

.hero-greeting,
.turno-detail-hero-copy {
    flex-direction: column;
    gap: 8px;
}

.page-header-icon svg,
.section-icon svg,
.turno-metric-icon svg,
.stat-icon-wrapper svg,
.action-icon-wrapper svg,
.list-item-icon svg {
    width: 16px;
    height: 16px;
}

.page-header-title,
.hero-title,
.turno-detail-title {
    margin: 0;
    font-size: var(--title-size);
    font-weight: 700;
    line-height: 1.05;
    letter-spacing: -0.04em;
    color: var(--text);
}

.page-header-subtitle,
.hero-subtitle,
.turno-detail-subtitle {
    margin: 4px 0 0;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.35;
}

.turno-detail-kicker,
.page-eyebrow,
.hero-kicker {
    font-size: 11px;
    line-height: 1;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
}

.turno-detail-hero-side,
.turno-form-hero-meta,
.turno-hero-actions-panel,
.hero-stats,
.page-header-side {
    position: relative;
    z-index: 1;
    min-width: 250px;
    display: grid;
    gap: 8px;
    justify-items: end;
}

.page-header-meta-list {
    width: 100%;
    display: grid;
    gap: 8px;
}

.page-header-meta {
    width: 100%;
    display: grid;
    gap: 3px;
    padding: 9px 11px;
    border-radius: 14px;
    border: 1px solid var(--card-border);
    background: rgba(255, 255, 255, 0.92);
    box-shadow: var(--shadow-light), 0 8px 18px rgba(16, 24, 40, 0.04);
}

.page-header-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.hero-stat,
.stat-card,
.turno-metric-card,
.turno-summary-card,
.turno-overview-card {
    position: relative;
    display: grid;
    gap: 6px;
    padding: 12px 14px;
    min-height: 74px;
    border-radius: var(--radius-md);
    border: 1px solid var(--card-border);
    background: linear-gradient(180deg, #ffffff, #fbfdff);
    box-shadow: var(--shadow-light), var(--shadow-medium), var(--shadow-premium);
}

.hero-stat-label,
.stat-label,
.turno-summary-label,
.turno-meta-caption,
.turno-detail-meta-label,
.turno-history-meta-label,
.turno-metric-label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.hero-stat-value,
.stat-value,
.turno-summary-value,
.turno-metric-value {
    font-size: clamp(19px, 1.7vw, 24px);
    line-height: 1;
    font-weight: 700;
    letter-spacing: -0.04em;
    color: var(--text);
}

.turno-summary-value-compact {
    font-size: 24px;
}

.hero-stat-value.success,
.stat-success .stat-value,
.turno-detail-panel-success .turno-summary-value,
.turno-metric-icon-success {
    color: var(--success);
}

.hero-stat-divider {
    display: none;
}

.stat-grid,
.quick-actions,
.turno-metric-grid,
.turno-overview-grid,
.turno-detail-summary-grid,
.turno-template-grid,
.turno-preview-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 14px;
}

.stat-grid-mini {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.stat-card {
    grid-template-columns: auto 1fr auto;
    align-items: center;
    min-height: 72px;
}

.stat-content,
.turno-metric-top {
    display: grid;
    gap: 6px;
}

.stat-trend,
.turno-section-badge,
.turno-summary-line,
.turno-inline-note,
.turno-meta-pill,
.turno-field-chip,
.turno-count-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    min-height: 24px;
    padding: 0 8px;
    border-radius: 12px;
    border: 1px solid var(--card-border);
    background: var(--card-muted);
    color: var(--text-muted);
    font-size: 11px;
    font-weight: 600;
}

.stat-primary,
.card-info,
.turno-detail-panel-primary,
.turno-detail-panel-neutral {
    border-left: 4px solid var(--info);
}

.stat-info {
    border-left: 4px solid var(--info);
}

.stat-success,
.card-success,
.turno-detail-panel-success {
    border-left: 4px solid var(--success);
}

.tenant-plan-card {
    gap: 0;
}

.tenant-plan-card-header {
    align-items: start;
    gap: 16px;
}

.tenant-plan-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.tenant-plan-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
    padding: 0 20px 20px;
}

.tenant-plan-summary-item {
    display: grid;
    gap: 6px;
    padding: 16px 18px;
    border: 1px solid rgba(226, 232, 240, 0.84);
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.96));
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.03);
}

.tenant-plan-form {
    gap: 18px;
}

.tenant-plan-form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 14px;
}

.tenant-plan-card-footer {
    justify-content: space-between;
    gap: 12px;
}

.stat-warning,
.card-warning,
.turno-detail-panel-warning {
    border-left: 4px solid var(--warning);
}

.card-danger,
.turno-detail-panel-danger {
    border-left: 4px solid var(--danger);
}

.quick-action,
.modelo-card,
.turno-template-card,
.turno-preview-item,
.turno-repeat-item,
.item-card,
.turno-model-block-card,
.turno-detail-card,
.turno-detail-field-card,
.turno-detail-panel,
.turno-block-preview-card,
.turno-history-row {
    background: var(--card);
    border: 1px solid var(--card-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-light), var(--shadow-medium), var(--shadow-premium);
}

.card,
.panel,
.filter-section,
.turno-filter-card,
.turno-history-card,
.turno-section-shell,
.glass-card {
    background: var(--card);
    border: 1px solid var(--card-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-light), var(--shadow-medium), var(--shadow-premium);
}

.card,
.panel,
.turno-filter-card,
.turno-history-card,
.turno-section-shell,
.glass-card {
    padding: 16px;
}

.card-narrow {
    max-width: 720px;
    margin: 0 auto;
}

.card-attention {
    border-style: dashed;
    background: linear-gradient(180deg, #ffffff, #fffbeb);
}

.card-header,
.section-heading,
.turno-card-header-tight,
.turno-section-header,
.modal-header,
.filter-header,
.panel-header,
.turno-template-card-head,
.turno-model-field-panel-head,
.turno-model-field-row-head,
.turno-detail-card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
}

.card-header,
.section-heading,
.turno-card-header-tight,
.turno-section-header,
.filter-header,
.panel-header,
.modal-header {
    margin-bottom: 14px;
}

.card-body,
.modal-body {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.card-footer,
.modal-footer,
.filter-actions,
.actions,
.toolbar,
.toolbar-group,
.inline-actions,
.turno-template-card-actions,
.turno-detail-toolbar,
.turno-form-actions,
.turno-select-editor-actions,
.turno-repeat-actions,
.turno-history-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.card-footer,
.modal-footer {
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid var(--border);
    justify-content: space-between;
}

.card-title,
.section-title,
.turno-detail-card-title,
.turno-card-title,
.filter-title {
    margin: 0;
    font-size: var(--section-title-size);
    font-weight: 600;
    line-height: 1.2;
    letter-spacing: -0.03em;
}

.label,
.filter-label,
.field > span:first-child {
    display: inline-block;
    margin-bottom: 6px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.field {
    min-width: 0;
}

.field label.checkbox,
.checkbox {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 500;
    color: var(--text);
}

.checkbox input {
    accent-color: var(--info);
}

.control,
.filter-input,
.filter-select,
.item-input,
.item-order,
.field input,
.field select,
.field textarea {
    width: 100%;
    min-height: 36px;
    padding: 7px 10px;
    border-radius: 12px;
    border: 1px solid var(--border);
    background: #ffffff;
    color: var(--text);
    box-shadow: inset 0 1px 1px rgba(15, 23, 42, 0.02);
    transition: border-color 140ms ease, box-shadow 140ms ease, background-color 140ms ease;
}

.control::placeholder,
.filter-input::placeholder,
.item-input::placeholder,
textarea::placeholder,
input::placeholder {
    color: var(--text-soft);
}

.control:focus,
.filter-input:focus,
.filter-select:focus,
.item-input:focus,
.item-order:focus,
.field input:focus,
.field select:focus,
.field textarea:focus {
    outline: none;
    border-color: rgba(59, 130, 246, 0.45);
    box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.12);
}

textarea.control,
.field textarea,
.item-extras textarea {
    min-height: 92px;
    resize: vertical;
}

.turno-note {
    min-height: 38px;
    padding: 9px 12px;
    border-radius: 12px;
    border: 1px solid var(--border);
    background: var(--card-muted);
    color: var(--text);
}

.is-invalid {
    border-color: rgba(239, 68, 68, 0.42);
    box-shadow: 0 0 0 4px rgba(239, 68, 68, 0.1);
}

.error {
    color: #b91c1c;
    font-size: 12px;
    font-weight: 600;
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 36px;
    padding: 0 12px;
    border-radius: 12px;
    border: 1px solid transparent;
    background: transparent;
    color: var(--text);
    font-size: 12px;
    font-weight: 600;
    line-height: 1;
    transition: background-color 140ms ease, border-color 140ms ease, color 140ms ease, box-shadow 140ms ease;
}

.btn:hover {
    text-decoration: none;
}

.btn-primary {
    background: linear-gradient(180deg, #4f8cff, #3b82f6);
    color: #ffffff;
    box-shadow: 0 6px 18px rgba(59, 130, 246, 0.18);
}

.btn-primary:hover {
    background: linear-gradient(180deg, #4a83f2, #2563eb);
}

.btn-secondary,
.btn-outline {
    background: #ffffff;
    border-color: var(--border);
    color: var(--text);
}

.btn-secondary:hover,
.btn-outline:hover {
    background: var(--card-muted);
    border-color: var(--border-strong);
}

.btn-ghost {
    background: transparent;
    border-color: var(--border);
    color: var(--text-muted);
}

.btn-ghost:hover {
    background: var(--card-muted);
    color: var(--text);
}

.btn-danger {
    background: linear-gradient(180deg, #f87171, #ef4444);
    color: #ffffff;
}

.btn-danger:hover {
    background: linear-gradient(180deg, #ef6464, #dc2626);
}

.btn-sm {
    min-height: 32px;
    padding: 0 10px;
    font-size: 11px;
}

.btn:disabled,
.btn[disabled] {
    opacity: 0.64;
    cursor: not-allowed;
    box-shadow: none;
}

.badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    min-height: 20px;
    padding: 3px 7px;
    border-radius: var(--radius-pill);
    border: 1px solid transparent;
    font-size: 10px;
    line-height: 1;
    font-weight: 600;
    letter-spacing: 0.04em;
}

.badge-info,
.badge-primary {
    background: var(--info-soft);
    color: #1d4ed8;
    border-color: rgba(59, 130, 246, 0.18);
}

.badge-success {
    background: var(--success-soft);
    color: #15803d;
    border-color: rgba(34, 197, 94, 0.18);
}

.badge-warning {
    background: var(--warning-soft);
    color: #b45309;
    border-color: rgba(245, 158, 11, 0.2);
}

.badge-danger {
    background: var(--danger-soft);
    color: #b91c1c;
    border-color: rgba(239, 68, 68, 0.2);
}

.badge-neutral {
    background: rgba(148, 163, 184, 0.14);
    color: #475569;
    border-color: rgba(148, 163, 184, 0.18);
}

.alerts {
    display: grid;
    gap: 10px;
}

.alert {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 14px;
    border-radius: 12px;
    border: 1px solid transparent;
    font-size: 13px;
    box-shadow: var(--shadow-light);
}

.alert a {
    color: inherit;
    text-decoration: underline;
}

.alert-info {
    background: var(--info-soft);
    color: #1d4ed8;
    border-color: rgba(59, 130, 246, 0.18);
}

.alert-success {
    background: var(--success-soft);
    color: #15803d;
    border-color: rgba(34, 197, 94, 0.18);
}

.alert-warning {
    background: var(--warning-soft);
    color: #b45309;
    border-color: rgba(245, 158, 11, 0.18);
}

.alert-danger {
    background: var(--danger-soft);
    color: #b91c1c;
    border-color: rgba(239, 68, 68, 0.18);
}

.grid,
.filter-grid,
.form-grid,
.turno-detail-card-grid,
.turno-detail-card-grid-dense,
.turno-model-grid,
.turno-detail-meta-grid {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 12px 14px;
}

.grid > *,
.filter-grid > *,
.form-grid > *,
.turno-detail-card-grid > *,
.turno-detail-card-grid-dense > *,
.turno-model-grid > * {
    min-width: 0;
}

.grid-auto {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.grid-stack {
    grid-auto-rows: auto;
}

.col-1 { grid-column: span 1; }
.col-2 { grid-column: span 2; }
.col-3 { grid-column: span 3; }
.col-4 { grid-column: span 4; }
.col-5 { grid-column: span 5; }
.col-6 { grid-column: span 6; }
.col-7 { grid-column: span 7; }
.col-8 { grid-column: span 8; }
.col-9 { grid-column: span 9; }
.col-10 { grid-column: span 10; }
.col-11 { grid-column: span 11; }
.col-12 { grid-column: span 12; }
.span-2 { grid-column: span 2; }

.form-inline {
    display: flex;
    gap: 10px;
    align-items: flex-end;
    flex-wrap: wrap;
}

.field-grow {
    flex: 1 1 320px;
}

.list,
.record-list,
.turno-history-line-list,
.turno-detail-list,
.turno-field-chip-list,
.turno-preview-tags,
.turno-template-card-tags,
.turno-hero-chips,
.turno-detail-tags {
    display: grid;
    gap: 10px;
}

.list-row,
.list-item,
.record-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid var(--card-border);
    background: linear-gradient(180deg, #ffffff, #fbfdff);
    box-shadow: var(--shadow-light), 0 10px 20px rgba(16, 24, 40, 0.035);
}

.list-row-main,
.list-item-left,
.list-item-content {
    min-width: 0;
    display: grid;
    gap: 4px;
}

.list-row-actions,
.list-item-right {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.list-row-title,
.list-item-title,
.action-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--text);
}

.list-row-field {
    min-width: min(100%, 320px);
}

.list-item {
    cursor: default;
}

.list-item-left {
    display: flex;
    align-items: center;
    gap: 12px;
}

.quick-actions {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.quick-action {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 12px;
    padding: 16px;
    transition: border-color 140ms ease, transform 140ms ease, box-shadow 140ms ease;
}

.quick-action:hover {
    transform: translateY(-1px);
    border-color: rgba(59, 130, 246, 0.22);
    box-shadow: var(--shadow-medium);
}

.quick-action.primary,
.quick-action.action-primary {
    background:
        radial-gradient(circle at top right, rgba(59, 130, 246, 0.14), transparent 34%),
        linear-gradient(180deg, #ffffff, #f8fbff);
    border-color: rgba(59, 130, 246, 0.18);
}

.action-icon-wrapper.neutral {
    background: rgba(148, 163, 184, 0.12);
    color: #475569;
    border-color: rgba(148, 163, 184, 0.16);
}

.action-icon-wrapper.warning {
    background: var(--warning-soft);
    color: #b45309;
    border-color: rgba(245, 158, 11, 0.18);
}

.action-icon-wrapper.accent {
    background: rgba(34, 197, 94, 0.12);
    color: #15803d;
    border-color: rgba(34, 197, 94, 0.18);
}

.action-content {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.action-desc {
    margin: 0;
    font-size: 13px;
    color: var(--text-muted);
}

.action-arrow {
    color: var(--text-soft);
}

.empty-state {
    display: grid;
    justify-items: center;
    gap: 10px;
    padding: 24px 18px;
    text-align: center;
    border-radius: 14px;
    border: 1px dashed var(--card-border);
    background:
        radial-gradient(circle at top right, rgba(59, 130, 246, 0.06), transparent 32%),
        linear-gradient(180deg, #ffffff, #f8fafc);
}

.empty-state.compact {
    padding: 18px 14px;
}

.empty-icon {
    width: 44px;
    height: 44px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(59, 130, 246, 0.1);
    color: var(--info);
}

.empty-title {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
}

.toolbar-sticky {
    position: sticky;
    bottom: 16px;
    padding: 12px 14px;
    border-radius: 16px;
    border: 1px solid var(--border);
    background: rgba(255, 255, 255, 0.94);
    backdrop-filter: blur(14px);
    box-shadow: var(--shadow-premium);
    justify-content: space-between;
    z-index: 8;
}

.loader {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--text-muted);
    font-size: 12px;
    font-weight: 600;
}

.loader svg {
    width: 16px;
    height: 16px;
    animation: spin 1s linear infinite;
}

.htmx-indicator {
    opacity: 0;
    transition: opacity 140ms ease;
}

.htmx-request .htmx-indicator,
.htmx-request.htmx-indicator {
    opacity: 1;
}

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.page-footer {
    padding: 14px 24px 24px;
    text-align: center;
    font-size: 12px;
    color: var(--text-muted);
}

.bottom-nav {
    display: none;
}

.turno-chip {
    display: inline-flex;
    align-items: center;
    min-height: 20px;
    padding: 0 7px;
    border-radius: var(--radius-pill);
    background: rgba(53, 109, 255, 0.065);
    border: 1px solid rgba(53, 109, 255, 0.12);
    color: #2957d9;
    font-size: 10px;
    font-weight: 600;
}

.turno-chip-soft {
    background: rgba(148, 163, 184, 0.12);
    border-color: rgba(148, 163, 184, 0.16);
    color: #475569;
}

.turno-hero-actions,
.turno-hero-actions-main,
.turno-header-side,
.turno-model-block-switches,
.turno-section-tools,
.turno-model-field-row-switches,
.turno-detail-tags {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.turno-hero-sidecard {
    justify-self: end;
    max-width: 280px;
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid rgba(59, 130, 246, 0.14);
    background: rgba(255, 255, 255, 0.7);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.turno-hero-sidecard strong {
    font-size: 18px;
    line-height: 1.1;
}

.turno-metric-icon-warning {
    color: #b45309;
    background: var(--warning-soft);
    border-color: rgba(245, 158, 11, 0.18);
}

.turno-metric-icon-success {
    color: #15803d;
    background: var(--success-soft);
    border-color: rgba(34, 197, 94, 0.18);
}

.turno-history-row {
    display: grid;
    grid-template-columns: 5px minmax(0, 1fr);
    overflow: hidden;
}

.turno-status-rail {
    display: block;
    width: 100%;
    height: 100%;
}

.turno-status-rail-success {
    background: linear-gradient(180deg, #4ade80, #22c55e);
}

.turno-status-rail-warning {
    background: linear-gradient(180deg, #fbbf24, #f59e0b);
}

.turno-status-rail-danger {
    background: linear-gradient(180deg, #f87171, #ef4444);
}

.turno-history-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) auto auto auto;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
}

.turno-history-primary,
.turno-history-updated {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.turno-history-titleline {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.turno-history-subline {
    display: flex;
    flex-wrap: wrap;
    gap: 4px 10px;
    font-size: 12px;
    color: var(--text-muted);
}

.turno-history-badges {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.turno-count-badge strong {
    color: var(--text);
}

.turno-detail-panel {
    padding: 14px;
}

.turno-detail-page .turno-detail-hero {
    padding: 15px 18px;
    gap: 12px 18px;
}

.turno-detail-page .turno-detail-title {
    font-size: 30px;
    font-weight: 700;
    letter-spacing: -0.05em;
}

.turno-detail-page .turno-detail-subtitle {
    max-width: 58ch;
    font-size: 13px;
}

.turno-detail-page .turno-card-subtitle {
    margin: 2px 0 0;
    font-size: 12px;
    font-weight: 500;
    color: var(--text-muted);
}

.turno-detail-page .page-header-meta {
    padding: 8px 10px;
}

.turno-detail-page .page-header-meta .badge {
    width: fit-content;
}

.turno-detail-page .turno-detail-summary-grid {
    gap: 12px;
}

.turno-detail-page .turno-detail-kpi-card {
    min-height: 68px;
    padding: 12px 14px;
    gap: 4px;
    transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.turno-detail-page .turno-detail-kpi-card:hover {
    transform: translateY(-1px);
    border-color: rgba(53, 109, 255, 0.14);
    box-shadow:
        0 1px 2px rgba(16, 24, 40, 0.04),
        0 10px 26px rgba(16, 24, 40, 0.07),
        0 18px 38px rgba(16, 24, 40, 0.05);
}

.turno-detail-page .turno-detail-kpi-card .turno-summary-label {
    font-size: 10px;
}

.turno-detail-page .turno-detail-kpi-card .turno-summary-value {
    font-size: 23px;
}

.turno-detail-page .turno-detail-section-card {
    position: relative;
    overflow: hidden;
    padding: 0;
    border-left: 0;
    --detail-accent: var(--info);
    --detail-glow: rgba(53, 109, 255, 0.18);
}

.turno-detail-page .turno-detail-section-card::before {
    content: "";
    position: absolute;
    left: 0;
    top: 14px;
    bottom: 14px;
    width: 4px;
    border-radius: 999px;
    background: var(--detail-accent);
    box-shadow: 0 0 0 1px var(--detail-glow), 0 0 18px var(--detail-glow);
}

.turno-detail-page .turno-detail-panel-neutral {
    --detail-accent: var(--info);
    --detail-glow: rgba(53, 109, 255, 0.18);
}

.turno-detail-page .turno-detail-panel-primary {
    --detail-accent: var(--info);
    --detail-glow: rgba(53, 109, 255, 0.18);
}

.turno-detail-page .turno-detail-panel-muted {
    --detail-accent: #98a2b3;
    --detail-glow: rgba(152, 162, 179, 0.18);
}

.turno-detail-page .turno-detail-panel-warning {
    --detail-accent: var(--warning);
    --detail-glow: rgba(217, 164, 65, 0.18);
}

.turno-detail-page .turno-detail-panel-danger {
    --detail-accent: var(--danger);
    --detail-glow: rgba(217, 83, 79, 0.18);
}

.turno-detail-page .turno-detail-panel-success {
    --detail-accent: var(--success);
    --detail-glow: rgba(34, 160, 107, 0.18);
}

.turno-detail-page .turno-detail-section-card > .card-header {
    margin: 0;
    padding: 15px 18px 12px 20px;
    border-bottom: 1px solid rgba(230, 234, 242, 0.9);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(247, 249, 252, 0.94));
}

.turno-detail-page .turno-detail-section-card > .card-body {
    padding: 14px 18px 18px 20px;
    gap: 12px;
}

.turno-detail-page .turno-summary-line {
    display: grid;
    gap: 4px;
    min-height: auto;
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid var(--card-border);
    background: linear-gradient(180deg, #ffffff, #fbfcfe);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.74);
}

.turno-detail-page .turno-detail-mini-card {
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid rgba(230, 234, 242, 0.92);
    background: linear-gradient(180deg, #ffffff, #fbfcfe);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.8),
        0 6px 16px rgba(16, 24, 40, 0.05);
}

.turno-detail-page .turno-detail-card-grid,
.turno-detail-page .turno-detail-card-grid-dense {
    gap: 10px 16px;
}

.turno-detail-page .turno-meta-caption {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.05em;
}

.turno-detail-page .turno-detail-field-cell strong,
.turno-detail-page .turno-detail-field-card strong,
.turno-detail-page .turno-summary-line strong {
    font-size: 14px;
    font-weight: 500;
}

.turno-detail-page .turno-detail-toolbar {
    padding: 10px 12px;
    border-radius: 16px;
}

.turno-detail-page .turno-inline-empty {
    padding: 18px 14px;
    background: linear-gradient(180deg, #ffffff, #fafbfd);
}

.turno-summary-line,
.turno-detail-field-cell,
.turno-detail-field-card,
.turno-detail-field-stack,
.turno-detail-field-stack-tight {
    display: grid;
    gap: 4px;
}

.turno-detail-card,
.turno-detail-field-card {
    padding: 12px 14px;
}

.turno-detail-card-grid,
.turno-detail-card-grid-dense {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.turno-detail-card-span {
    grid-column: 1 / -1;
}

.turno-detail-field-cell strong,
.turno-detail-field-card strong,
.turno-summary-line strong {
    font-size: 14px;
    font-weight: 500;
    color: var(--text);
}

.turno-detail-list,
.turno-model-field-list {
    display: grid;
    gap: 10px;
}

.turno-template-card,
.turno-model-block-card {
    display: grid;
    gap: 14px;
    padding: 16px;
}

.turno-template-card-meta,
.turno-block-preview-meta {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 10px;
}

.turno-meta-pill {
    justify-content: space-between;
    padding: 10px 12px;
    min-height: auto;
}

.turno-meta-pill strong {
    color: var(--text);
}

.turno-preview-item,
.turno-repeat-item,
.item-card,
.turno-model-field-row,
.turno-block-preview-card {
    padding: 14px;
}

.turno-repeat-list,
.turno-preview-list,
.item-list {
    display: grid;
    gap: 12px;
}

.turno-repeat-actions,
.item-row {
    justify-content: space-between;
}

.item-row {
    display: flex;
    align-items: center;
    gap: 10px;
}

.item-compact,
.item-extras-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 10px;
}

.item-input {
    min-height: 40px;
}

.item-order {
    max-width: 96px;
}

.turno-select-option-list {
    display: grid;
    gap: 8px;
}

.turno-select-option-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: 8px;
    align-items: center;
}

.turno-field-chip {
    flex-wrap: wrap;
    align-items: flex-start;
    padding: 10px 12px;
    min-height: auto;
}

.turno-field-chip em {
    font-style: normal;
    color: #1d4ed8;
}

.turno-field-chip small {
    color: var(--text-muted);
}

.turno-section-counter {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-muted);
}

.turno-mode-toggle-panel {
    padding: 10px 12px;
    border-radius: 14px;
    border: 1px solid var(--border);
    background: var(--card-muted);
}

.turno-mode-note {
    margin: 8px 0 0;
    font-size: 12px;
}

.turno-model-field-panel {
    display: grid;
    gap: 12px;
}

.turno-card-status,
.turno-template-card-tags,
.turno-preview-tags {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.filter-title-group {
    display: flex;
    align-items: center;
    gap: 8px;
}

.filter-icon {
    color: var(--info);
}

.filter-form {
    display: grid;
    gap: 12px;
}

.models-section {
    display: grid;
}

#modelos-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 14px;
}

.modelo-card {
    display: grid;
    gap: 12px;
    padding: 16px;
}

.modelo-card .card-header {
    margin-bottom: 0;
}

.detail-grid,
.detail-pairs,
.meta-grid,
.summary-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px 16px;
}

.detail-item,
.detail-pair {
    display: grid;
    gap: 4px;
}

.detail-label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.detail-value {
    font-size: 15px;
    font-weight: 500;
    color: var(--text);
}

.login-page {
    display: grid;
    place-items: center;
    min-height: 100vh;
    padding: 24px;
}

.public-shell {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 24px;
}

.login-panel,
.auth-card,
.panel {
    width: min(100%, 460px);
    padding: 24px;
    border-radius: 20px;
    border: 1px solid var(--border);
    background:
        radial-gradient(circle at top right, rgba(59, 130, 246, 0.08), transparent 32%),
        linear-gradient(180deg, #ffffff, #f8fafc);
    box-shadow: var(--shadow-premium);
}

.login-panel h1,
.panel h2,
.auth-card h1 {
    margin: 0 0 8px;
    font-size: 24px;
    font-weight: 600;
    letter-spacing: -0.04em;
}

.login-panel p,
.auth-card p {
    margin: 0 0 20px;
    color: var(--text-muted);
}

.login-panel form,
.panel form,
.auth-card form {
    display: grid;
    gap: 14px;
}

.modal-root {
    position: fixed;
    inset: 0;
    z-index: 50;
}

.modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.46);
    backdrop-filter: blur(4px);
}

.modal-card {
    position: relative;
    z-index: 1;
    width: min(100% - 24px, 960px);
    max-height: calc(100vh - 32px);
    margin: 16px auto;
    padding: 20px;
    overflow: auto;
    border-radius: 20px;
    border: 1px solid var(--border);
    background: linear-gradient(180deg, #ffffff, #f8fafc);
    box-shadow: var(--shadow-premium);
}

.modal-close {
    width: 34px;
    min-width: 34px;
    padding: 0;
}

.modal-title {
    margin: 0;
    font-size: 20px;
    font-weight: 600;
    letter-spacing: -0.03em;
}

.modal-subtitle {
    margin: 4px 0 0;
    font-size: 13px;
    color: var(--text-muted);
}

.desktop-only {
    display: inline-flex;
}

@media (max-width: 1180px) {
    .turno-history-grid {
        grid-template-columns: minmax(0, 1fr) auto;
    }

    .turno-history-badges,
    .turno-history-updated {
        grid-column: 1 / -1;
    }
}

@media (max-width: 1024px) {
    .app-shell {
        grid-template-columns: 1fr;
    }

    .sidebar {
        transform: translateX(-100%);
    }

    .sidebar.is-open {
        transform: translateX(0);
    }

    .content-wrapper {
        grid-column: 1;
    }

    .hamburger {
        display: inline-flex;
    }

    .desktop-only {
        display: none;
    }

    .bottom-nav {
        position: sticky;
        bottom: 0;
        display: grid;
        grid-template-columns: repeat(5, minmax(0, 1fr));
        gap: 8px;
        padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
        border-top: 1px solid var(--border);
        background: rgba(255, 255, 255, 0.94);
        backdrop-filter: blur(14px);
        z-index: 15;
    }

    .bottom-link {
        flex-direction: column;
        gap: 6px;
        justify-content: center;
        padding: 10px 6px;
        border-radius: 14px;
        border: 1px solid var(--border);
        background: var(--card);
        color: var(--text-muted);
        font-size: 11px;
        font-weight: 600;
    }

    .bottom-link.active {
        color: var(--info);
        background: rgba(59, 130, 246, 0.08);
        border-color: rgba(59, 130, 246, 0.16);
    }

    .content {
        padding-bottom: calc(24px + var(--bottom-nav-height));
    }
}

/* ---------- Active Page Layer: premium refresh for login and turno surfaces ----------
   Shared active-page refinements that predate the official visual reset below.
   Kept because some selectors still support the current core screens. ---------- */

.page-header-title,
.hero-title,
.turno-detail-title,
.login-brand-title,
.login-panel h1,
.login-panel h2,
.auth-card h1 {
    font-family: var(--font-display);
}

.login-page {
    position: relative;
    min-height: 100svh;
    padding: 20px 18px;
    overflow-x: hidden;
    overflow-y: auto;
    background:
        radial-gradient(circle at top left, rgba(30, 64, 175, 0.09), transparent 24%),
        radial-gradient(circle at right 12%, rgba(15, 23, 42, 0.07), transparent 22%),
        linear-gradient(180deg, #f8fafc 0%, #eef3f9 100%);
}

.login-page::before,
.login-page::after {
    content: "";
    position: fixed;
    border-radius: 999px;
    pointer-events: none;
    filter: blur(8px);
}

.login-page::before {
    top: -140px;
    right: -60px;
    width: 420px;
    height: 420px;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.94) 0%, rgba(255, 255, 255, 0.08) 62%, transparent 74%);
}

.login-page::after {
    left: -110px;
    bottom: -120px;
    width: 360px;
    height: 360px;
    background: radial-gradient(circle, rgba(59, 130, 246, 0.12) 0%, rgba(59, 130, 246, 0.02) 60%, transparent 72%);
}

.login-shell {
    position: relative;
    z-index: 1;
    width: min(100%, 1100px);
    display: grid;
    grid-template-columns: minmax(0, 0.96fr) minmax(400px, 470px);
    gap: 24px;
    align-items: stretch;
    margin: 0 auto;
    min-height: calc(100svh - 40px);
}

.login-brand-panel,
.login-panel {
    position: relative;
    overflow: hidden;
    border-radius: 28px;
    border: 1px solid rgba(212, 219, 230, 0.9);
    box-shadow:
        0 1px 2px rgba(16, 24, 40, 0.04),
        0 18px 44px rgba(15, 23, 42, 0.08),
        0 32px 72px rgba(15, 23, 42, 0.06);
}

.login-brand-panel::before,
.login-panel::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.login-brand-panel {
    padding: 34px;
    min-height: 620px;
    background:
        linear-gradient(180deg, rgba(13, 17, 28, 0.035), transparent 28%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(244, 247, 252, 0.96));
}

.login-brand-panel::before {
    background:
        radial-gradient(circle at top left, rgba(59, 130, 246, 0.13), transparent 28%),
        linear-gradient(135deg, rgba(255, 255, 255, 0.8), transparent 54%);
}

.login-panel {
    width: 100%;
    max-width: 470px;
    padding: 28px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 253, 0.96));
    justify-self: end;
}

.login-panel::before {
    background:
        radial-gradient(circle at top right, rgba(59, 130, 246, 0.12), transparent 28%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.7), transparent 34%);
}

.login-brand-stack {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 22px;
    align-content: space-between;
    min-height: 100%;
}

.login-kicker {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #475467;
}

.login-brand-mark {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 16px;
    align-items: start;
}

.login-brand-icon {
    width: 56px;
    height: 56px;
    border-radius: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    background: linear-gradient(180deg, #1f4ed8 0%, #1940ad 100%);
    border: 1px solid rgba(17, 24, 39, 0.08);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.22),
        0 18px 30px rgba(29, 78, 216, 0.24);
}

.login-brand-copy {
    display: grid;
    gap: 10px;
}

.login-brand-label {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #667085;
}

.login-brand-title {
    margin: 0;
    max-width: 12ch;
    font-size: clamp(40px, 4.8vw, 58px);
    line-height: 0.98;
    font-weight: 800;
    letter-spacing: -0.065em;
    color: #0f172a;
}

.login-brand-text {
    margin: 0;
    max-width: 52ch;
    font-size: 15px;
    line-height: 1.6;
    color: #475467;
}

.login-trust-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.login-trust-card {
    position: relative;
    display: grid;
    gap: 10px;
    padding: 18px 18px 20px;
    border-radius: 22px;
    border: 1px solid rgba(221, 227, 236, 0.94);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(245, 248, 252, 0.96));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.92),
        0 16px 28px rgba(15, 23, 42, 0.05);
}

.login-trust-card::after {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 3px;
    border-radius: 22px 0 0 22px;
    background: linear-gradient(180deg, #1d4ed8, #60a5fa);
    opacity: 0.92;
}

.login-trust-label {
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #667085;
}

.login-trust-value {
    font-family: var(--font-display);
    font-size: 18px;
    line-height: 1.1;
    font-weight: 700;
    letter-spacing: -0.04em;
    color: #0f172a;
}

.login-trust-text {
    margin: 0;
    font-size: 13px;
    line-height: 1.55;
    color: #667085;
}

.login-panel-premium {
    display: grid;
    gap: 18px;
    align-content: center;
}

.login-brand-panel {
    order: 1;
}

.login-panel {
    order: 2;
}

.login-panel-head {
    display: grid;
    gap: 8px;
}

.login-mobile-brand {
    display: none;
}

.login-panel h2 {
    margin: 0;
    font-size: 31px;
    line-height: 1.02;
    font-weight: 800;
    letter-spacing: -0.055em;
    color: #101828;
}

.login-panel-head p {
    margin: 0;
    color: #667085;
    font-size: 14px;
    line-height: 1.55;
}

.login-form {
    gap: 16px;
}

.login-field {
    display: grid;
    gap: 8px;
}

.login-panel .control {
    min-height: 48px;
    padding: 12px 14px;
    border-radius: 16px;
    border-color: #d6dde8;
    background: linear-gradient(180deg, #ffffff, #fbfcfe);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.96),
        0 1px 2px rgba(15, 23, 42, 0.02);
}

.login-panel .control:focus {
    border-color: rgba(37, 99, 235, 0.42);
    box-shadow:
        0 0 0 4px rgba(37, 99, 235, 0.12),
        0 14px 26px rgba(30, 64, 175, 0.08);
}

.login-submit {
    min-height: 48px;
    width: 100%;
    justify-content: center;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.01em;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.2),
        0 18px 34px rgba(37, 99, 235, 0.24);
}

.login-benefits-line {
    color: #98a2b3;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.turno-list-page {
    gap: 18px;
}

.turno-list-page .turno-list-hero {
    padding: 20px 22px;
    gap: 16px 22px;
    border-color: rgba(217, 223, 233, 0.96);
    background:
        radial-gradient(circle at top right, rgba(29, 78, 216, 0.08), transparent 26%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.985), rgba(245, 248, 252, 0.97));
    box-shadow:
        0 1px 2px rgba(16, 24, 40, 0.04),
        0 16px 32px rgba(15, 23, 42, 0.05),
        0 28px 56px rgba(15, 23, 42, 0.045);
}

.turno-list-page .turno-list-hero::after {
    background:
        linear-gradient(120deg, rgba(29, 78, 216, 0.045), transparent 42%),
        radial-gradient(circle at top right, rgba(255, 255, 255, 0.5), transparent 26%);
}

.turno-list-page .turno-list-hero-info {
    gap: 14px;
}

.turno-list-page .turno-list-hero-copy {
    display: grid;
    gap: 10px;
    max-width: 780px;
}

.turno-list-page .turno-list-hero .page-header-title {
    font-size: clamp(32px, 2.7vw, 42px);
    font-weight: 800;
    letter-spacing: -0.06em;
}

.turno-list-page .turno-list-hero .page-header-subtitle {
    max-width: 60ch;
    font-size: 14px;
    font-weight: 500;
    color: #667085;
}

.turno-list-hero-tags {
    gap: 8px;
}

.turno-list-page .turno-list-hero-side {
    min-width: 330px;
    gap: 10px;
}

.turno-list-sidecard {
    width: 100%;
    max-width: none;
    padding: 16px 18px;
    border-radius: 18px;
    border-color: rgba(203, 213, 225, 0.82);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(244, 247, 251, 0.92));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.88),
        0 14px 28px rgba(15, 23, 42, 0.06);
}

.turno-list-sidecard strong {
    font-family: var(--font-display);
    font-size: 30px;
    line-height: 1;
    font-weight: 800;
    letter-spacing: -0.06em;
}

.turno-list-page .page-header-meta-list {
    gap: 10px;
}

.turno-list-page .page-header-meta {
    padding: 12px 14px;
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(247, 249, 252, 0.92));
}

.turno-list-page .page-header-actions .btn {
    min-height: 38px;
    padding-inline: 14px;
}

.turno-list-page .turno-metric-card {
    position: relative;
    gap: 10px;
    min-height: 112px;
    padding: 16px 16px 18px;
    overflow: hidden;
    border-radius: 18px;
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.turno-list-page .turno-metric-card::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 4px;
    background: linear-gradient(180deg, #1d4ed8, #60a5fa);
}

.turno-list-page .turno-metric-card:hover {
    transform: translateY(-2px);
    box-shadow:
        0 1px 2px rgba(16, 24, 40, 0.04),
        0 16px 34px rgba(15, 23, 42, 0.08),
        0 30px 60px rgba(15, 23, 42, 0.05);
}

.turno-list-page .turno-metric-card-warning::before {
    background: linear-gradient(180deg, #d9a441, #f3c56f);
}

.turno-list-page .turno-metric-card-success::before {
    background: linear-gradient(180deg, #22a06b, #55c996);
}

.turno-list-page .turno-metric-card .turno-metric-value {
    font-size: clamp(28px, 2.4vw, 38px);
    font-weight: 800;
    letter-spacing: -0.06em;
}

.turno-list-page .turno-filter-card,
.turno-list-page .turno-history-card {
    border-radius: 22px;
    border-color: rgba(219, 225, 234, 0.96);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.985), rgba(247, 249, 252, 0.97));
}

.turno-list-page .turno-filter-card .card-header,
.turno-list-page .turno-history-card .card-header {
    margin-bottom: 16px;
}

.turno-list-page .turno-filter-grid-premium {
    gap: 14px;
}

.turno-list-page .turno-filter-grid-premium .field {
    padding: 14px;
    border-radius: 16px;
    border: 1px solid rgba(225, 230, 238, 0.92);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 253, 0.94));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.94);
}

.turno-list-page .turno-filter-grid-premium .label {
    margin-bottom: 8px;
}

.turno-list-page .turno-filter-grid-premium .control {
    min-height: 40px;
    border-radius: 14px;
    border-color: #d9e0ea;
    background: linear-gradient(180deg, #ffffff, #fbfcfe);
}

.turno-list-page .turno-filter-grid-premium .control:focus {
    box-shadow:
        0 0 0 4px rgba(37, 99, 235, 0.1),
        0 10px 22px rgba(37, 99, 235, 0.05);
}

.turno-list-page .turno-filter-toolbar {
    padding-top: 6px;
}

.turno-list-page .turno-history-line-list {
    gap: 12px;
}

.turno-list-page .turno-history-row {
    border-radius: 20px;
    border-color: rgba(217, 223, 233, 0.96);
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.turno-list-page .turno-history-row:hover {
    transform: translateY(-2px);
    border-color: rgba(59, 130, 246, 0.16);
    box-shadow:
        0 1px 2px rgba(16, 24, 40, 0.04),
        0 16px 34px rgba(15, 23, 42, 0.08),
        0 28px 54px rgba(15, 23, 42, 0.05);
}

.turno-list-page .turno-status-rail {
    width: 6px;
}

.turno-list-page .turno-history-grid {
    grid-template-columns: minmax(0, 1.8fr) auto auto auto;
    gap: 14px;
    padding: 16px 18px;
}

.turno-history-overline {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.turno-history-record-id {
    display: inline-flex;
    align-items: center;
    min-height: 22px;
    padding: 0 8px;
    border-radius: 999px;
    border: 1px solid rgba(203, 213, 225, 0.9);
    background: rgba(248, 250, 252, 0.96);
    color: #667085;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.turno-history-record-id-soft {
    color: #94a3b8;
}

.turno-list-page .turno-card-title {
    font-size: 18px;
    font-weight: 700;
    letter-spacing: -0.04em;
}

.turno-list-page .turno-history-subline {
    gap: 6px 12px;
    font-size: 12px;
}

.turno-list-page .turno-count-badge {
    min-height: 46px;
    padding: 0 12px;
    border-radius: 16px;
    display: grid;
    place-items: center;
    gap: 2px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(245, 248, 251, 0.94));
    border-color: rgba(217, 223, 233, 0.92);
}

.turno-list-page .turno-count-badge strong {
    font-family: var(--font-display);
    font-size: 18px;
    font-weight: 800;
    letter-spacing: -0.05em;
}

.turno-list-page .turno-count-badge small {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #667085;
}

.turno-list-page .turno-history-updated {
    min-width: 170px;
    padding: 12px 14px;
    border-radius: 16px;
    border: 1px solid rgba(217, 223, 233, 0.92);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 249, 252, 0.94));
}

.turno-list-page .turno-history-updated strong {
    font-family: var(--font-display);
    font-size: 16px;
    letter-spacing: -0.03em;
}

.turno-list-page .turno-history-actions form {
    margin: 0;
}

.turno-list-page .turno-history-actions .btn {
    min-height: 34px;
    border-radius: 12px;
}

.turno-detail-page {
    gap: 18px;
}

.turno-detail-page .turno-detail-hero {
    padding: 20px 22px;
    gap: 18px;
    border-color: rgba(217, 223, 233, 0.96);
    background:
        radial-gradient(circle at top right, rgba(29, 78, 216, 0.08), transparent 26%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(245, 248, 252, 0.97));
}

.turno-detail-page .turno-detail-hero-main {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(300px, 360px);
    gap: 20px;
    align-items: start;
}

.turno-detail-page .turno-detail-hero-copy {
    gap: 12px;
}

.turno-detail-page .turno-detail-heading {
    display: grid;
    gap: 8px;
}

.turno-detail-page .turno-detail-title {
    font-size: clamp(34px, 3vw, 46px);
    font-weight: 800;
    letter-spacing: -0.065em;
}

.turno-detail-page .turno-detail-subtitle {
    max-width: 60ch;
    font-size: 14px;
    line-height: 1.55;
    color: #667085;
}

.turno-detail-page .turno-card-subtitle {
    margin: 2px 0 0;
    font-size: 12px;
    font-weight: 600;
    color: #475467;
}

.turno-detail-page .turno-detail-hero-tags {
    gap: 8px;
}

.turno-detail-page .turno-detail-hero-side {
    gap: 10px;
    min-width: 0;
}

.turno-detail-page .turno-detail-hero-sidecard {
    width: 100%;
    max-width: none;
    padding: 16px 18px;
    border-radius: 18px;
    border-color: rgba(203, 213, 225, 0.84);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(244, 247, 251, 0.92));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.86),
        0 16px 30px rgba(15, 23, 42, 0.06);
}

.turno-detail-page .turno-detail-hero-sidecard strong {
    font-family: var(--font-display);
    font-size: 38px;
    font-weight: 800;
    letter-spacing: -0.07em;
}

.turno-detail-page .page-header-meta-list {
    gap: 10px;
}

.turno-detail-page .page-header-meta {
    padding: 12px 14px;
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(247, 249, 252, 0.92));
}

.turno-detail-page .turno-detail-kpi-card {
    min-height: 92px;
    padding: 16px;
    gap: 8px;
}

.turno-detail-page .turno-detail-kpi-card .turno-summary-label {
    font-size: 10px;
    letter-spacing: 0.14em;
}

.turno-detail-page .turno-detail-kpi-card .turno-summary-value {
    font-size: 30px;
    font-weight: 800;
    letter-spacing: -0.06em;
}

.turno-detail-page .turno-detail-section-card > .card-header {
    padding: 18px 20px 14px 22px;
}

.turno-detail-page .turno-detail-section-card > .card-body {
    padding: 16px 20px 20px 22px;
    gap: 14px;
}

.turno-detail-page .turno-section-tools {
    gap: 8px;
    justify-content: flex-end;
}

.turno-detail-page .turno-summary-line {
    gap: 6px;
    padding: 14px 16px;
    border-radius: 16px;
}

.turno-detail-page .turno-detail-mini-card {
    padding: 14px 16px;
    border-radius: 16px;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.8),
        0 10px 22px rgba(16, 24, 40, 0.05);
}

.turno-detail-page .turno-detail-card-grid,
.turno-detail-page .turno-detail-card-grid-dense {
    gap: 12px 18px;
}

.turno-detail-page .turno-meta-caption {
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.14em;
}

.turno-detail-page .turno-detail-field-cell strong,
.turno-detail-page .turno-detail-field-card strong,
.turno-detail-page .turno-summary-line strong {
    font-size: 15px;
    line-height: 1.45;
    font-weight: 600;
}

.turno-detail-page .turno-detail-toolbar {
    padding: 12px 14px;
    border-radius: 18px;
    border-color: rgba(217, 223, 233, 0.96);
    background: rgba(255, 255, 255, 0.94);
    box-shadow:
        0 1px 2px rgba(16, 24, 40, 0.04),
        0 18px 36px rgba(15, 23, 42, 0.08);
}

.turno-detail-page .turno-detail-toolbar .btn {
    min-height: 38px;
    padding-inline: 14px;
}

@media (max-width: 900px) {
    .login-shell,
    .turno-detail-page .turno-detail-hero-main {
        grid-template-columns: 1fr;
    }

    .login-shell {
        min-height: auto;
        gap: 16px;
    }

    .login-brand-panel {
        min-height: auto;
        order: 2;
    }

    .login-panel {
        order: 1;
        max-width: none;
        justify-self: stretch;
    }

    .login-trust-grid {
        grid-template-columns: 1fr;
    }

    .page-header,
    .dashboard-hero,
    .turno-detail-hero,
    .turno-form-hero,
    .turno-premium-hero,
    .turno-history-grid,
    .detail-grid,
    .detail-pairs,
    .meta-grid,
    .summary-grid {
        grid-template-columns: 1fr;
    }

    .page-header-info,
    .turno-detail-hero-copy {
        width: 100%;
    }

    .turno-detail-hero-side,
    .turno-form-hero-meta,
    .turno-hero-actions-panel,
    .hero-stats,
    .page-header-side {
        justify-items: stretch;
        min-width: 0;
    }

    .turno-list-page .turno-list-hero-side,
    .turno-detail-page .turno-detail-hero-side {
        min-width: 0;
    }

    .hero-stats {
        grid-template-columns: 1fr;
    }

    .grid,
    .filter-grid,
    .form-grid,
    .turno-detail-card-grid,
    .turno-detail-card-grid-dense,
    .turno-model-grid,
    .turno-detail-meta-grid {
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }

    .col-7,
    .col-8,
    .col-9,
    .col-10,
    .col-11,
    .col-12 {
        grid-column: span 6;
    }

    .col-6,
    .col-5,
    .col-4,
    .col-3,
    .col-2,
    .col-1 {
        grid-column: span 3;
    }

    .turno-history-actions,
    .toolbar,
    .toolbar-sticky {
        justify-content: flex-start;
    }
}

@media (max-width: 720px) {
    .login-page {
        min-height: auto;
        padding: 12px;
    }

    .login-shell {
        gap: 12px;
        align-items: start;
        min-height: auto;
    }

    .login-brand-panel,
    .login-panel {
        width: 100%;
        border-radius: 22px;
    }

    .login-panel {
        order: 1;
        padding: 18px 18px 16px;
        gap: 16px;
        box-shadow:
            0 1px 2px rgba(16, 24, 40, 0.04),
            0 14px 30px rgba(15, 23, 42, 0.08);
    }

    .login-panel-head {
        gap: 6px;
    }

    .login-mobile-brand {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        gap: 10px;
        align-items: center;
        margin-bottom: 2px;
    }

    .login-mobile-brand-icon {
        width: 42px;
        height: 42px;
        border-radius: 14px;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.22),
            0 12px 22px rgba(29, 78, 216, 0.18);
    }

    .login-mobile-brand-copy {
        display: grid;
        gap: 2px;
        min-width: 0;
    }

    .login-panel h2 {
        font-size: 28px;
        letter-spacing: -0.05em;
    }

    .login-panel-head p {
        font-size: 13px;
        line-height: 1.45;
    }

    .login-form {
        gap: 14px;
    }

    .login-field {
        gap: 7px;
    }

    .login-panel .control {
        min-height: 52px;
        padding: 13px 14px;
        border-radius: 14px;
    }

    .login-submit {
        min-height: 50px;
        border-radius: 14px;
        font-size: 13px;
    }

    .login-benefits-line {
        color: #64748b;
        font-size: 10px;
        letter-spacing: 0.06em;
    }

    .login-brand-panel {
        order: 2;
        min-height: 0;
        padding: 14px 16px;
        border-radius: 18px;
        background:
            linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(246, 249, 252, 0.94));
        box-shadow: 0 8px 18px rgba(15, 23, 42, 0.04);
    }

    .login-brand-stack {
        gap: 12px;
        min-height: 0;
    }

    .login-kicker {
        font-size: 10px;
        letter-spacing: 0.14em;
    }

    .login-brand-mark {
        grid-template-columns: auto minmax(0, 1fr);
        gap: 10px;
        align-items: center;
    }

    .login-brand-icon {
        width: 42px;
        height: 42px;
        border-radius: 14px;
    }

    .login-brand-title {
        max-width: none;
        font-size: 20px;
        line-height: 1.08;
        letter-spacing: -0.04em;
    }

    .login-brand-text {
        font-size: 12px;
        line-height: 1.45;
    }

        .login-trust-grid {
        display: none;
    }

    .content,
    .topbar,
    .page-footer {
        padding-left: 16px;
        padding-right: 16px;
    }

    .page-header,
    .dashboard-hero,
    .turno-detail-hero,
    .turno-form-hero,
    .turno-premium-hero,
    .card,
    .panel,
    .turno-filter-card,
    .turno-history-card,
    .turno-section-shell,
    .glass-card,
    .modal-card,
    .login-panel,
    .auth-card {
        padding: 16px;
        border-radius: 16px;
    }

    .grid,
    .filter-grid,
    .form-grid,
    .turno-detail-card-grid,
    .turno-detail-card-grid-dense,
    .turno-model-grid,
    .turno-detail-meta-grid {
        grid-template-columns: 1fr;
    }

    .col-1,
    .col-2,
    .col-3,
    .col-4,
    .col-5,
    .col-6,
    .col-7,
    .col-8,
    .col-9,
    .col-10,
    .col-11,
    .col-12,
    .span-2 {
        grid-column: span 1;
    }

    .list-row,
    .list-item,
    .quick-action,
    .turno-select-option-row {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .list-row,
    .list-item {
        flex-direction: column;
        align-items: stretch;
    }

    .list-row-actions,
    .list-item-right,
    .card-footer,
    .modal-footer {
        justify-content: flex-start;
    }

    .form-inline {
        align-items: stretch;
    }

    .form-inline > * {
        width: 100%;
    }

    .turno-detail-page .turno-detail-title {
        font-size: 26px;
    }

    .turno-list-page .turno-list-hero,
    .turno-detail-page .turno-detail-hero {
        padding: 18px;
    }

    .turno-list-page .turno-history-grid {
        padding: 14px;
    }
}

/* ---------- Legacy Internal Override Layer (Phase: compressao estrutural executiva)
   Removed from active cascade after consolidation.
   Global shell/components now resolve from the official reset below.
   Current dashboard and turno pages are governed by the official page blocks. ---------- */

/* ---------- Official Active Reset ----------
   Authoritative layer for the active product shell:
   1. tokens / typography
   2. layout shell
   3. global components
   4. dashboard
   5. /turnos
   6. /turnos/{id}

   When a global selector is defined both above and here, this block is the
   official implementation for the active application.

   Sidebar navigation is governed below by the dedicated official shell layer
   so the base shell and component rules here do not re-define it again. ---------- */

:root {
    --sidebar-width: 228px;
    --content-max: 1380px;
    --title-size: 30px;
    --section-title-size: 20px;
    --subtitle-size: 14px;
    --label-size: 11px;
    --value-size: 15px;
}

body {
    background:
        radial-gradient(circle at top left, rgba(53, 109, 255, 0.055), transparent 22%),
        radial-gradient(circle at top right, rgba(15, 23, 42, 0.03), transparent 20%),
        linear-gradient(180deg, #fbfcff 0%, #f2f5fa 100%);
    color: #0f172a;
    line-height: 1.42;
}

.app-shell-premium {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.42), rgba(255, 255, 255, 0)),
        transparent;
}

.content-wrapper-premium {
    position: relative;
}

.topbar,
.topbar-premium {
    padding: 8px 20px;
    gap: 12px;
    background: rgba(250, 252, 255, 0.86);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid rgba(226, 232, 240, 0.8);
}

.topbar .topbar-title,
.topbar-premium .topbar-title {
    font-family: var(--font-display);
    font-size: 15px;
    font-weight: 700;
    letter-spacing: -0.04em;
    color: #0f172a;
}

.topbar-context {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.topbar-eyebrow {
    color: #64748b;
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.topbar-title-row {
    display: flex;
    align-items: baseline;
    gap: 10px;
    min-width: 0;
}

.topbar-page-meta {
    color: #64748b;
    font-size: 12px;
    line-height: 1.35;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.topbar-session-mobile {
    display: none;
    color: #64748b;
    font-size: 11px;
    font-weight: 600;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.topbar .user-chip,
.topbar-premium .user-chip {
    min-height: 38px;
    padding: 5px 9px;
    border-radius: 14px;
    border-color: rgba(214, 220, 232, 0.88);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(247, 249, 252, 0.96));
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.04);
}

.topbar .btn-logout,
.topbar-premium .btn-logout {
    min-height: 34px;
    padding-inline: 10px;
}

.page-footer {
    padding: 10px 28px 14px;
    font-size: 12px;
    color: #94a3b8;
}

.content-premium,
.content {
    padding: 16px 22px 22px;
}

.content-inner,
.page,
.stack {
    gap: 20px;
}

.page-header,
.dashboard-hero,
.turno-detail-hero,
.turno-form-hero,
.turno-premium-hero,
.card,
.panel,
.turno-filter-card,
.turno-history-card,
.turno-section-shell,
.glass-card {
    border-radius: 22px;
}

.page-header,
.dashboard-hero,
.turno-detail-hero,
.turno-form-hero,
.turno-premium-hero {
    gap: 18px 22px;
    padding: 24px 26px;
    background:
        radial-gradient(circle at top right, rgba(59, 130, 246, 0.05), transparent 28%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.985), rgba(246, 249, 252, 0.96));
    border-color: rgba(226, 232, 240, 0.88);
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.04),
        0 16px 36px rgba(15, 23, 42, 0.06);
}

.page-header::after,
.dashboard-hero::after,
.turno-detail-hero::after,
.turno-form-hero::after,
.turno-premium-hero::after {
    background: linear-gradient(120deg, rgba(59, 130, 246, 0.03), transparent 44%);
}

.page-header-icon,
.page-header-icon svg,
.section-icon,
.section-icon svg,
.stat-icon-wrapper,
.action-icon-wrapper {
    width: 42px;
    height: 42px;
}

.page-header-title,
.hero-title,
.turno-detail-title {
    font-family: var(--font-display);
    font-size: clamp(29px, 2.2vw, 34px);
    font-weight: 800;
    line-height: 1.02;
    letter-spacing: -0.06em;
}

.page-header-subtitle,
.hero-subtitle,
.turno-detail-subtitle {
    margin-top: 6px;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.48;
    color: #64748b;
}

.page-eyebrow,
.turno-detail-kicker,
.hero-kicker {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.14em;
    color: #64748b;
}

.muted,
.empty-desc,
.turno-card-subtitle,
.turno-inline-note,
.turno-metric-copy,
.list-row-meta {
    font-size: 13px;
    line-height: 1.45;
    color: #64748b;
}

.card,
.panel,
.turno-filter-card,
.turno-history-card,
.turno-section-shell,
.glass-card {
    padding: 20px 22px;
    border-color: rgba(226, 232, 240, 0.88);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.995), rgba(248, 250, 252, 0.98));
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.04),
        0 12px 30px rgba(15, 23, 42, 0.05);
}

.card-header,
.section-heading,
.turno-card-header-tight,
.turno-section-header,
.filter-header,
.panel-header,
.modal-header {
    margin-bottom: 16px;
    gap: 16px;
}

.card-title,
.section-title,
.turno-detail-card-title,
.turno-card-title,
.filter-title {
    font-family: var(--font-display);
    font-size: 20px;
    font-weight: 700;
    letter-spacing: -0.04em;
}

.label,
.filter-label,
.field > span:first-child,
.detail-label,
.turno-meta-caption,
.turno-history-meta-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.12em;
    color: #64748b;
}

.detail-value {
    font-family: var(--font-display);
    font-size: 24px;
    font-weight: 700;
    letter-spacing: -0.05em;
}

.control,
.input,
.select,
.textarea,
.filter-input,
.filter-select,
.item-input,
.item-order,
.field input,
.field select,
.field textarea {
    min-height: 40px;
    padding: 9px 12px;
    border-radius: 14px;
    border-color: rgba(214, 220, 232, 0.96);
    background: rgba(255, 255, 255, 0.98);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.control:focus,
.input:focus,
.select:focus,
.textarea:focus,
.filter-input:focus,
.filter-select:focus,
.item-input:focus,
.item-order:focus,
.field input:focus,
.field select:focus,
.field textarea:focus {
    border-color: rgba(59, 130, 246, 0.45);
    box-shadow:
        0 0 0 4px rgba(59, 130, 246, 0.1),
        0 10px 20px rgba(59, 130, 246, 0.05);
}

.btn {
    min-height: 40px;
    padding: 0 14px;
    border-radius: 14px;
    font-size: 13px;
    font-weight: 700;
}

.btn-sm {
    min-height: 34px;
    padding: 0 11px;
    border-radius: 12px;
    font-size: 12px;
}

.badge,
.pill {
    min-height: 22px;
    padding: 3px 8px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
}

.dashboard-page .dashboard-stack,
.turno-list-layout,
.turno-detail-document-stack {
    gap: 18px;
}

.dashboard-shell {
    grid-template-columns: minmax(0, 1.5fr) minmax(290px, 0.9fr);
    align-items: stretch;
}

.dashboard-shell .page-header-info {
    gap: 14px;
}

.dashboard-shell-side {
    display: flex;
    align-items: stretch;
}

.dashboard-shell-meta {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    width: 100%;
}

.dashboard-shell .page-header-meta,
.dashboard-shell-meta-card {
    min-height: 100%;
    padding: 14px 15px;
    border-radius: 18px;
    border: 1px solid rgba(224, 229, 238, 0.88);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 250, 252, 0.94));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.dashboard-shell .page-header-meta .detail-value,
.dashboard-shell-meta-card .detail-value {
    margin-top: 8px;
    display: block;
}

.dashboard-stat-grid {
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: 14px;
}

.dashboard-stat-grid .stat-card {
    min-height: 102px;
    padding: 18px 18px 16px;
    gap: 10px;
    border-radius: 18px;
    background: linear-gradient(180deg, #ffffff, #f8fbff);
    border-color: rgba(222, 228, 238, 0.92);
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.04),
        0 14px 30px rgba(15, 23, 42, 0.06);
}

.dashboard-stat-grid .stat-content {
    gap: 8px;
}

.dashboard-stat-grid .stat-label {
    font-size: 10px;
    letter-spacing: 0.12em;
}

.dashboard-stat-grid .stat-value {
    font-family: var(--font-display);
    font-size: 30px;
    font-weight: 800;
    letter-spacing: -0.06em;
}

.dashboard-stat-grid .stat-trend {
    min-height: 26px;
    padding-inline: 10px;
    border-radius: 999px;
}

.dashboard-card {
    padding: 22px 24px;
}

.dashboard-quick-actions {
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 14px;
}

.dashboard-quick-actions .quick-action {
    position: relative;
    overflow: hidden;
}

.dashboard-quick-actions .quick-action::after {
    content: "";
    position: absolute;
    inset: auto 18px 0;
    height: 1px;
    background: linear-gradient(90deg, rgba(226, 232, 240, 0), rgba(203, 213, 225, 0.9), rgba(226, 232, 240, 0));
}

.dashboard-quick-actions .quick-action {
    min-height: 118px;
    padding: 18px 18px 16px;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 249, 252, 0.96));
    border-color: rgba(224, 229, 238, 0.94);
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.04),
        0 14px 28px rgba(15, 23, 42, 0.05);
}

.dashboard-quick-actions .action-title {
    font-family: var(--font-display);
    font-size: 18px;
    letter-spacing: -0.03em;
}

.dashboard-quick-actions .action-desc,
.dashboard-quick-actions .action-arrow {
    font-size: 13px;
}

.dashboard-recent-list {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.dashboard-recent-row {
    min-height: 0;
    padding: 16px 0;
    border-radius: 0;
    border: 0;
    border-top: 1px solid rgba(226, 232, 240, 0.72);
    background: transparent;
    box-shadow: none;
}

.dashboard-recent-list .dashboard-recent-row:first-child {
    border-top: 0;
    padding-top: 4px;
}

.dashboard-recent-row .list-row-title {
    font-family: var(--font-display);
    font-size: 17px;
    font-weight: 700;
    letter-spacing: -0.03em;
}

.dashboard-recent-overline {
    margin-bottom: 5px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #94a3b8;
}

.dashboard-recent-row .list-row-actions,
.dashboard-recent-side {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.dashboard-recent-timestamp {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 152px;
}

.dashboard-recent-timestamp strong {
    font-size: 14px;
    font-weight: 700;
    color: #0f172a;
}

.turno-list-shell-premium {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: stretch;
}

.turno-list-shell-premium .turno-list-shell-main {
    gap: 16px;
}

.turno-list-shell-premium .page-header-info {
    gap: 14px;
}

.turno-list-shell-premium .page-header-title {
    font-size: clamp(30px, 2.2vw, 36px);
}

.turno-list-shell-premium .page-header-subtitle {
    max-width: 58ch;
}

.turno-list-summary-strip {
    gap: 12px;
}

.turno-list-summary-item {
    min-width: 118px;
    padding: 13px 14px;
    border-radius: 16px;
    border: 1px solid rgba(224, 229, 238, 0.92);
    background: rgba(250, 251, 253, 0.96);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

.turno-list-summary-item strong {
    font-family: var(--font-display);
    font-size: 24px;
    font-weight: 800;
    letter-spacing: -0.05em;
}

.turno-list-shell-actions {
    gap: 8px;
    align-self: flex-start;
}

.turno-list-shell-actions .btn {
    min-height: 40px;
}

.turno-filter-shell {
    padding: 18px 20px;
}

.turno-filter-headline {
    margin-bottom: 14px;
}

.turno-filter-grid-compact {
    gap: 12px 14px;
}

.turno-filter-grid-compact .field {
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
}

.turno-filter-toolbar-inline {
    justify-content: space-between;
    padding-top: 6px;
}

.turno-history-shell-premium {
    padding: 16px 0 0;
    overflow: hidden;
}

.turno-history-headline {
    margin: 0 20px 14px;
}

.turno-history-body {
    gap: 0;
}

.turno-history-line-list {
    gap: 0;
}

.turno-history-row-premium {
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.turno-history-row-premium + .turno-history-row-premium {
    border-top: 0;
}

.turno-history-row-premium:hover {
    background: linear-gradient(180deg, rgba(248, 250, 252, 0.88), rgba(255, 255, 255, 0.7));
}

.turno-history-row-premium .turno-status-rail {
    width: 5px;
}

.turno-history-row-premium .turno-history-grid {
    grid-template-columns: minmax(0, 1.9fr) minmax(250px, 0.95fr) auto;
    gap: 18px;
    padding: 18px 20px;
    align-items: center;
}

.turno-history-row-premium .turno-history-overline {
    gap: 8px;
    margin-bottom: 4px;
}

.turno-history-row-premium .turno-history-record-id {
    min-height: 22px;
    padding: 0 9px;
    border-radius: 999px;
    border: 1px solid rgba(224, 229, 238, 0.92);
    background: rgba(248, 250, 252, 0.96);
    font-size: 10px;
    font-weight: 700;
}

.turno-history-row-premium .turno-card-title {
    font-family: var(--font-display);
    font-size: 18px;
    font-weight: 700;
    letter-spacing: -0.04em;
}

.turno-history-row-premium .turno-history-titleline {
    gap: 10px;
}

.turno-history-row-premium .turno-history-subline {
    gap: 6px 12px;
    font-size: 13px;
}

.turno-history-row-premium .turno-history-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.turno-history-secondary {
    display: grid;
    gap: 10px;
    align-items: center;
}

.turno-history-row-premium .turno-count-badge {
    min-height: 34px;
    padding: 6px 10px;
    border-radius: 14px;
    border-color: rgba(224, 229, 238, 0.92);
    background: rgba(248, 250, 252, 0.94);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.turno-history-row-premium .turno-count-badge strong {
    font-family: var(--font-display);
    font-size: 17px;
    font-weight: 700;
}

.turno-history-row-premium .turno-count-badge small {
    font-size: 9px;
    letter-spacing: 0.1em;
}

.turno-history-row-premium .turno-history-updated {
    min-width: 0;
    gap: 4px;
    padding: 10px 12px;
    border-radius: 16px;
    border: 1px solid rgba(224, 229, 238, 0.92);
    background: rgba(250, 251, 253, 0.94);
}

.turno-history-row-premium .turno-history-updated strong {
    font-size: 14px;
    font-weight: 700;
    line-height: 1.35;
}

.turno-history-row-premium .turno-history-actions {
    justify-content: flex-end;
    gap: 6px;
    align-items: center;
    flex-wrap: wrap;
}

.turno-history-row-premium .turno-history-actions .btn {
    min-height: 34px;
}

.turno-detail-header-shell-premium {
    gap: 18px;
}

.turno-detail-header-top {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    align-items: start;
}

.turno-detail-header-shell-premium .turno-detail-header-copy {
    gap: 10px;
}

.turno-detail-header-topline {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.turno-detail-model-badge {
    background: rgba(241, 245, 249, 0.92);
    color: #475467;
    border: 1px solid rgba(224, 229, 238, 0.94);
}

.turno-detail-header-status {
    display: flex;
    align-items: flex-start;
    justify-content: flex-end;
}

.turno-detail-header-shell-premium .turno-detail-title {
    font-size: clamp(30px, 2.2vw, 36px);
}

.turno-detail-header-shell-premium .turno-detail-subtitle {
    max-width: 60ch;
}

.turno-detail-meta-strip {
    grid-template-columns: repeat(auto-fit, minmax(154px, 1fr));
    gap: 14px;
    padding-top: 16px;
}

.turno-detail-meta-item {
    gap: 5px;
    padding: 14px 15px;
    border-radius: 16px;
    border: 1px solid rgba(224, 229, 238, 0.88);
    background: rgba(249, 250, 252, 0.88);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

.turno-detail-meta-item strong {
    font-size: 15px;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.turno-detail-kpi-strip-premium {
    gap: 14px;
    grid-template-columns: repeat(auto-fit, minmax(152px, 1fr));
}

.turno-detail-kpi-card-premium {
    min-height: 92px;
    padding: 16px 18px;
    gap: 8px;
    border-radius: 18px;
}

.turno-detail-kpi-card-premium .turno-summary-label {
    font-size: 10px;
    letter-spacing: 0.12em;
}

.turno-detail-kpi-card-premium .turno-summary-value {
    font-family: var(--font-display);
    font-size: 28px;
    font-weight: 800;
    letter-spacing: -0.06em;
}

.turno-detail-section-card-premium {
    position: relative;
    overflow: hidden;
}

.turno-detail-section-card-premium::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 4px;
    background: currentColor;
    opacity: 0.14;
}

.turno-detail-page .turno-detail-section-card > .card-header {
    padding: 18px 20px 14px 24px;
    align-items: start;
}

.turno-detail-page .turno-detail-section-card > .card-body {
    padding: 0 20px 20px 24px;
    gap: 14px;
}

.turno-section-counter {
    min-height: 26px;
    padding: 0 10px;
    border-radius: 999px;
    border: 1px solid rgba(224, 229, 238, 0.92);
    background: rgba(248, 250, 252, 0.94);
    font-size: 11px;
    font-weight: 700;
    color: #475467;
}

.turno-section-badge {
    min-height: 24px;
    padding: 0 9px;
    border-radius: 999px;
    font-size: 10px;
}

.turno-detail-page .turno-detail-mini-card,
.turno-detail-page .turno-summary-line {
    padding: 14px 16px;
    border-radius: 16px;
    border: 1px solid rgba(224, 229, 238, 0.92);
    background: rgba(249, 250, 252, 0.96);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.turno-detail-page .turno-detail-card-grid,
.turno-detail-page .turno-detail-card-grid-dense {
    gap: 12px 18px;
}

.turno-detail-page .turno-detail-field-cell strong,
.turno-detail-page .turno-detail-field-card strong,
.turno-detail-page .turno-summary-line strong {
    font-size: 15px;
    line-height: 1.45;
    font-weight: 600;
    color: #0f172a;
}

.turno-detail-toolbar-premium {
    padding: 14px 16px;
    border-radius: 18px;
    border-color: rgba(226, 232, 240, 0.9);
    background: rgba(255, 255, 255, 0.94);
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.04),
        0 16px 36px rgba(15, 23, 42, 0.08);
}

@media (max-width: 1200px) {
    :root {
        --content-max: 1280px;
    }

    .content-premium,
    .content {
        padding: 20px 22px 24px;
    }
}

@media (max-width: 1024px) {
    .topbar,
    .topbar-premium {
        padding: 14px 18px;
    }

    .content-premium,
    .content {
        padding: 18px 18px 22px;
    }

    .content-inner,
    .page,
    .stack,
    .dashboard-page .dashboard-stack,
    .turno-list-layout,
    .turno-detail-document-stack {
        gap: 16px;
    }

    .dashboard-shell,
    .turno-list-shell-premium,
    .turno-detail-header-shell-premium,
    .turno-history-row-premium .turno-history-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .dashboard-shell-meta {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .turno-detail-header-top {
        grid-template-columns: minmax(0, 1fr);
    }

    .turno-history-row-premium .turno-history-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 720px) {
    .content-premium,
    .content,
    .topbar,
    .topbar-premium,
    .page-footer {
        padding-left: 16px;
        padding-right: 16px;
    }

    .page-header,
    .dashboard-hero,
    .turno-detail-hero,
    .turno-form-hero,
    .turno-premium-hero,
    .card,
    .panel,
    .turno-filter-card,
    .turno-history-card,
    .turno-section-shell,
    .glass-card {
        padding: 18px;
        border-radius: 18px;
    }

    .page-header-title,
    .hero-title,
    .turno-detail-title,
    .turno-list-shell-premium .page-header-title,
    .turno-detail-header-shell-premium .turno-detail-title {
        font-size: 26px;
    }

    .dashboard-stat-grid,
    .dashboard-quick-actions,
    .turno-detail-kpi-strip-premium {
        grid-template-columns: 1fr;
    }

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

    .turno-history-headline {
        margin: 0 18px 12px;
    }

    .turno-history-row-premium .turno-history-grid {
        padding: 16px 18px;
    }
}

/* ---------- Official Shell Layer ----------
   Dedicated sidebar and user-card implementation for the active shell.
   This layer intentionally owns `.sidebar-link`, `.sidebar-link.active`
   and `.user-card` so they no longer depend on earlier internal overrides. ---------- */

.app-shell-premium {
    --sidebar-width: 248px;
    background:
        radial-gradient(circle at top left, rgba(37, 99, 235, 0.06), transparent 28%),
        radial-gradient(circle at bottom right, rgba(249, 115, 22, 0.06), transparent 24%),
        linear-gradient(180deg, #f8fafc 0%, #f3f6fb 48%, #eef3f8 100%);
}

.sidebar-premium {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.72) 0%, rgba(247, 250, 252, 0.92) 18%, rgba(240, 245, 251, 0.96) 100%);
    color: #111827;
    border-right: 1px solid rgba(217, 225, 236, 0.9);
    box-shadow: 18px 0 34px rgba(15, 23, 42, 0.05);
    backdrop-filter: blur(18px) saturate(110%);
    -webkit-backdrop-filter: blur(18px) saturate(110%);
}

.sidebar-shell {
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 0;
    gap: 12px;
    padding: 14px 14px 12px;
}

.sidebar-header-premium {
    padding: 0;
    border: 1px solid rgba(222, 230, 241, 0.82);
    border-radius: 16px;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.94)),
        linear-gradient(180deg, rgba(37, 99, 235, 0.02), rgba(249, 115, 22, 0.02));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.94),
        0 10px 24px rgba(15, 23, 42, 0.03);
}

.sidebar-brand-premium {
    width: 100%;
    align-items: center;
    gap: 12px;
    padding: 14px 14px 13px;
}

.sidebar-brand-mark {
    width: 34px !important;
    height: 34px !important;
    color: #f97316 !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 12px !important;
    box-shadow: none !important;
    filter: drop-shadow(0 8px 14px rgba(249, 115, 22, 0.16));
}

.sidebar-premium .brand-icon svg {
    width: 24px;
    height: 24px;
}

.sidebar-brand-copy {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.sidebar-brand-kicker {
    color: #64748b;
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.sidebar-brand-text {
    font-family: var(--font-display);
    font-size: 1.16rem;
    font-weight: 800;
    letter-spacing: -0.03em;
    color: #111827;
}

.brand-energy {
    color: #111827;
}

.brand-center {
    color: #f97316;
}

.sidebar-brand-subtitle {
    color: #475569;
    font-size: 0.67rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
}

.sidebar-body {
    flex: 1;
    min-height: 0;
    overflow: auto;
    padding-right: 3px;
}

.sidebar-body::-webkit-scrollbar {
    width: 6px;
}

.sidebar-body::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.45);
}

.sidebar-nav-premium {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 0;
}

.sidebar-nav-premium .nav-section {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.sidebar-nav-premium .nav-section + .nav-section {
    padding-top: 8px;
    border-top: 1px solid rgba(217, 225, 236, 0.72);
}

.sidebar-section-label,
.sidebar-nav-premium .nav-section-title {
    padding: 5px 10px 3px;
    color: #7c8da3;
    font-size: 0.66rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.sidebar-menu {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 0;
}

.menu-item,
.sidebar-premium .sidebar-link {
    position: relative;
    display: grid;
    grid-template-columns: 18px minmax(0, 1fr);
    gap: 11px;
    align-items: center;
    min-height: 42px;
    margin: 0 !important;
    padding: 9px 10px 9px 13px !important;
    border: 0 !important;
    border-radius: 12px !important;
    background: transparent !important;
    color: #243244 !important;
    overflow: hidden;
    box-shadow: none !important;
    transform: none !important;
    transition: background-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

.menu-item::before,
.sidebar-premium .sidebar-link::before {
    content: "";
    position: absolute;
    left: 0;
    top: 8px;
    bottom: 8px;
    width: 3px;
    border-radius: 999px;
    background: transparent;
    transition: background-color 0.18s ease, box-shadow 0.18s ease;
}

.menu-item:hover,
.sidebar-premium .sidebar-link:hover {
    background: rgba(255, 255, 255, 0.68) !important;
    color: #111827 !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82) !important;
}

.menu-item.active,
.sidebar-premium .sidebar-link.active {
    background: linear-gradient(90deg, rgba(37, 99, 235, 0.08), rgba(255, 255, 255, 0.92) 72%) !important;
    color: #0f172a !important;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.96) !important,
        0 10px 18px rgba(15, 23, 42, 0.04) !important;
}

.menu-item.active::before,
.sidebar-premium .sidebar-link.active::before {
    background: #f97316 !important;
    box-shadow: 0 0 0 1px rgba(249, 115, 22, 0.08);
}

.menu-item-icon,
.sidebar-premium .sidebar-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px !important;
    height: 18px !important;
    border-radius: 0;
    border: 0;
    background: transparent;
    color: #64748b;
    opacity: 1;
    transition: color 0.18s ease, transform 0.18s ease;
}

.menu-item-icon svg,
.sidebar-premium .sidebar-icon svg {
    width: 16px;
    height: 16px;
}

.menu-item:hover .menu-item-icon,
.sidebar-premium .sidebar-link:hover .menu-item-icon,
.sidebar-premium .sidebar-link:hover .sidebar-icon {
    color: #1d4ed8;
    transform: translateY(-1px);
}

.menu-item.active .menu-item-icon,
.sidebar-premium .sidebar-link.active .menu-item-icon,
.sidebar-premium .sidebar-link.active .sidebar-icon {
    color: #f97316;
    border-color: transparent;
    background: transparent;
    box-shadow: none;
}

.menu-item-copy {
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
}

.menu-item-title,
.sidebar-premium .sidebar-label {
    font-family: var(--font-display);
    font-size: 0.9rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    color: inherit;
}

.menu-item-subtitle {
    color: #64748b;
    font-size: 0.67rem;
    letter-spacing: 0.02em;
}

.menu-item:hover .menu-item-subtitle,
.menu-item.active .menu-item-subtitle,
.sidebar-premium .sidebar-link:hover .menu-item-subtitle,
.sidebar-premium .sidebar-link.active .menu-item-subtitle {
    color: #667085;
}

.sidebar-footer {
    display: grid;
}

.user-card,
.user-card-minimal {
    gap: 10px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.user-card .user-avatar,
.user-card-minimal .user-avatar {
    width: 32px;
    height: 32px;
    background: linear-gradient(180deg, #7c8cff, #4f46e5);
    color: #ffffff;
    box-shadow: none;
}

.sidebar-footer-label {
    color: #7c8da3;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.16em;
}

.sidebar-footer-title {
    margin-top: 2px;
    color: #111827;
    font-family: var(--font-display);
    font-size: 0.9rem;
    font-weight: 700;
}

.sidebar-footer-meta,
.user-card .user-role,
.user-card-minimal .user-role {
    margin-top: 2px;
    color: #64748b;
    font-size: 0.74rem;
}

.sidebar-footer-context {
    gap: 2px;
    padding: 12px 12px 10px;
    border: 1px solid rgba(220, 228, 239, 0.82);
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.88), rgba(244, 247, 251, 0.94));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

@media (max-width: 1024px) {
    .app-shell-premium {
        --sidebar-width: 100%;
    }

    .sidebar-shell {
        padding: 14px;
    }

    .sidebar-footer {
        display: none;
    }
}

@media (max-width: 720px) {
    .sidebar-shell {
        padding: 14px 12px;
    }

    .sidebar-brand-premium {
        padding: 16px 14px;
    }
}

/* ---------- Official Product Workspace ----------
   Core product pages and model editor composition.
   Uses the official shell/components without introducing new component variants. ---------- */

.login-shell {
    width: min(100%, 1120px);
    grid-template-columns: minmax(0, 1.02fr) minmax(380px, 430px);
    gap: 20px;
    align-items: center;
}

.login-brand-panel {
    min-height: 620px;
    padding: 30px;
}

.login-panel {
    width: min(100%, 430px);
    padding: 26px;
}

.turno-modelos-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 0;
}

.turno-modelos-header-copy {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.turno-modelos-header .page-header-title {
    margin: 0;
}

.turno-modelos-header-meta {
    margin: 0;
    color: var(--text-muted);
    font-size: 13px;
    line-height: 1.45;
}

.turno-modelos-primary-cta {
    min-height: 42px;
    padding: 0 18px;
    border-radius: 12px;
    box-shadow: 0 12px 24px rgba(37, 99, 235, 0.14);
}

.turno-modelos-plan-card {
    display: grid;
    gap: 10px;
    padding: 10px 14px;
    border: 1px solid rgba(226, 232, 240, 0.88);
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.95));
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.03);
}

.turno-modelos-plan-badges {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.turno-modelos-plan-badge {
    padding: 0.34rem 0.72rem;
    font-size: 0.68rem;
}

.turno-modelos-plan-message {
    display: flex;
    align-items: center;
    min-height: 38px;
    padding: 9px 12px;
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(248, 250, 252, 0.94), rgba(241, 245, 249, 0.9));
    color: var(--text-soft);
}

.turno-modelos-plan-message.is-alert {
    background: linear-gradient(180deg, rgba(255, 247, 237, 0.98), rgba(255, 237, 213, 0.86));
}

.turno-modelos-plan-message.is-warning {
    background: linear-gradient(180deg, rgba(254, 252, 232, 0.98), rgba(254, 243, 199, 0.86));
}

.turno-modelos-plan-message.is-business {
    background: linear-gradient(180deg, rgba(239, 246, 255, 0.98), rgba(219, 234, 254, 0.8));
}

.turno-modelos-plan-message p {
    margin: 0;
    font-size: 12.5px;
    line-height: 1.5;
}

.turno-modelos-list-header {
    align-items: center;
}

.turno-modelos-page .turno-template-card {
    border: 1px solid rgba(226, 232, 240, 0.88);
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.96));
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.03);
    padding: 14px;
    display: grid;
    gap: 12px;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.turno-modelos-page .turno-template-card:hover {
    transform: translateY(-1px);
    border-color: rgba(203, 213, 225, 0.92);
    box-shadow: 0 12px 24px rgba(15, 23, 42, 0.06);
}

.turno-modelos-page .turno-template-grid {
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 12px;
}

.turno-modelos-page .turno-template-card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
}

.turno-template-card-title-wrap {
    min-width: 0;
}

.turno-modelos-page .turno-card-title {
    font-size: 15px;
    font-weight: 700;
    line-height: 1.35;
}

.turno-modelos-page .turno-card-status {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.turno-modelos-page .turno-template-card-meta {
    display: flex;
    align-items: stretch;
    gap: 8px;
}

.turno-modelos-page .turno-meta-pill {
    flex: 1 1 0;
    min-width: 0;
    padding: 10px 11px;
    border-radius: 12px;
    background: rgba(248, 250, 252, 0.82);
    border: 1px solid rgba(226, 232, 240, 0.7);
}

.turno-modelos-page .turno-meta-label {
    font-size: 10px;
    letter-spacing: 0.08em;
}

.turno-modelos-page .turno-meta-pill strong {
    display: block;
    margin-top: 4px;
    color: var(--text-strong);
    font-size: 13px;
    line-height: 1.35;
}

.turno-modelos-page .turno-template-card-actions {
    display: grid;
    gap: 8px;
    padding-top: 2px;
}

.turno-template-card-actions-main {
    display: flex;
    align-items: center;
}

.turno-template-card-actions-secondary {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.turno-template-card-actions-secondary form {
    margin: 0;
}

.turno-modelos-inline-action {
    position: relative;
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 2px;
    border: 0;
    background: transparent;
    color: #475569;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.2;
    border-radius: 8px;
    cursor: pointer;
    transition: color 0.18s ease, transform 0.18s ease, background-color 0.18s ease;
}

.turno-modelos-inline-action::after {
    content: "";
    position: absolute;
    left: 2px;
    right: 2px;
    bottom: 2px;
    height: 1px;
    border-radius: 999px;
    background: rgba(37, 99, 235, 0.32);
    transform: scaleX(0.32);
    transform-origin: left center;
    opacity: 0;
    transition: transform 0.18s ease, opacity 0.18s ease, background-color 0.18s ease;
}

.turno-modelos-inline-action:hover {
    color: #0f172a;
    background: rgba(241, 245, 249, 0.78);
    transform: translateY(-1px);
}

.turno-modelos-inline-action:hover::after {
    opacity: 1;
    transform: scaleX(1);
}

.turno-modelos-inline-action:focus-visible {
    outline: none;
    color: #0f172a;
    background: rgba(239, 246, 255, 0.92);
    box-shadow: 0 0 0 1px rgba(147, 197, 253, 0.95), 0 0 0 4px rgba(219, 234, 254, 0.9);
}

.turno-modelos-inline-action:focus-visible::after {
    opacity: 1;
    transform: scaleX(1);
    background: rgba(37, 99, 235, 0.48);
}

.turno-modelos-inline-action:active {
    transform: translateY(0);
}

.turno-modelos-inline-note {
    color: var(--text-muted);
    font-size: 11px;
    line-height: 1.4;
}

.turno-modelos-plan-summary,
.turno-modelos-toolbar-note {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

@media (max-width: 1100px) {
    .turno-modelos-header {
        align-items: flex-start;
        flex-direction: column;
    }
}

@media (max-width: 720px) {
    .tenant-plan-card-footer {
        align-items: stretch;
    }

    .turno-modelos-toolbar-note {
        justify-content: flex-start;
    }

    .turno-modelos-page .turno-template-card-meta {
        flex-direction: column;
    }
}

.turno-modelo-page-stack {
    gap: 18px;
}

.usuarios-page .stack {
    gap: 14px;
}

.usuarios-shell {
    display: grid;
    gap: 12px;
    padding: 16px 18px 18px;
    border: 1px solid rgba(226, 232, 240, 0.88);
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.995), rgba(248, 250, 252, 0.98));
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 16px 34px rgba(15, 23, 42, 0.05);
}

.usuarios-compact-header {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid rgba(226, 232, 240, 0.84);
}

.usuarios-compact-title {
    display: grid;
    gap: 4px;
}

.usuarios-compact-title h1 {
    margin: 0;
    color: #0f172a;
    font-size: 1.9rem;
    line-height: 1;
    letter-spacing: -0.03em;
}

.usuarios-compact-title p {
    margin: 0;
    color: #64748b;
    font-size: 13px;
}

.usuarios-creation-strip {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) auto auto;
    gap: 10px;
    align-items: center;
    padding: 2px 0 4px;
}

.usuarios-strip-input {
    min-height: 38px;
}

.usuarios-strip-checkbox {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    min-height: 38px;
    padding: 0 12px;
    border: 1px solid rgba(226, 232, 240, 0.88);
    border-radius: 11px;
    background: rgba(248, 250, 252, 0.78);
    white-space: nowrap;
}

.usuarios-strip-submit {
    min-height: 38px;
    padding: 0 16px;
    border-radius: 12px;
}

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

.usuarios-panel-shell {
    display: grid;
    gap: 10px;
}

.usuarios-inline-feedback {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 10px 12px;
    border: 1px solid rgba(187, 247, 208, 0.9);
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(240, 253, 244, 0.96), rgba(220, 252, 231, 0.84));
}

.usuarios-inline-feedback div {
    display: grid;
    gap: 2px;
}

.usuarios-inline-feedback strong {
    color: #166534;
    font-size: 13px;
}

.usuarios-inline-feedback span {
    color: #166534;
    font-size: 11px;
}

.usuarios-inline-feedback a {
    color: #166534;
    font-weight: 700;
    white-space: nowrap;
}

.usuarios-inline-feedback.is-danger {
    border-color: rgba(254, 202, 202, 0.92);
    background: linear-gradient(180deg, rgba(254, 242, 242, 0.98), rgba(254, 226, 226, 0.88));
}

.usuarios-inline-feedback.is-danger strong,
.usuarios-inline-feedback.is-danger span,
.usuarios-inline-feedback.is-danger a {
    color: #b91c1c;
}

.usuarios-list-shell {
    --usuarios-grid: minmax(0, 2fr) minmax(150px, 1fr) minmax(110px, 0.9fr) auto;
    display: grid;
    gap: 6px;
}

.usuarios-list-legend {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
    padding: 0 10px 2px;
    color: #64748b;
    font-size: 11px;
    line-height: 1.4;
}

.usuarios-list-legend strong {
    color: #0f172a;
    font-weight: 600;
}

.usuarios-list-head {
    display: grid;
    grid-template-columns: var(--usuarios-grid);
    gap: 14px;
    align-items: center;
    padding: 0 10px 4px;
    color: #64748b;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.usuarios-list-head-actions {
    text-align: right;
}

.usuarios-list {
    display: grid;
    gap: 6px;
}

.usuarios-row {
    display: grid;
    grid-template-columns: var(--usuarios-grid);
    gap: 14px;
    align-items: center;
    min-height: 54px;
    padding: 8px 10px;
    border: 1px solid rgba(226, 232, 240, 0.8);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.88);
    transition: border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
}

.usuarios-row.is-inactive {
    opacity: 0.68;
    background: rgba(248, 250, 252, 0.92);
}

.usuarios-row:hover {
    border-color: rgba(203, 213, 225, 0.92);
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.04);
}

.usuarios-row-identity {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

.usuarios-row-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 10px;
    border: 1px solid rgba(226, 232, 240, 0.9);
    background: linear-gradient(180deg, rgba(248, 250, 252, 0.98), rgba(241, 245, 249, 0.98));
    color: #0f172a;
    font-size: 12px;
    font-weight: 700;
}

.usuarios-row-copy {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.usuarios-row-title {
    color: #0f172a;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.2;
}

.usuarios-row-meta {
    color: #64748b;
    font-size: 11px;
    line-height: 1.3;
}

.usuarios-row-role {
    display: flex;
    align-items: center;
}

.usuarios-row-status {
    display: flex;
    align-items: center;
}

.usuarios-role-badge {
    padding: 0.2rem 0.5rem;
    font-size: 0.64rem;
}

.usuarios-status-badge {
    padding: 0.2rem 0.5rem;
    font-size: 0.64rem;
    border-radius: 999px;
}

.usuarios-status-badge-active {
    background: #ecfdf3;
    color: #15803d;
    border: 1px solid #bbf7d0;
}

.usuarios-status-badge-inactive {
    background: #f8fafc;
    color: #64748b;
    border: 1px solid #e2e8f0;
}

.usuarios-row-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.usuarios-actions-menu {
    position: relative;
}

.usuarios-actions-menu[open] .usuarios-actions-trigger {
    border-color: rgba(191, 219, 254, 0.92);
    background: rgba(239, 246, 255, 0.9);
}

.usuarios-actions-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 3px;
    width: 32px;
    height: 32px;
    padding: 0;
    border: 1px solid rgba(226, 232, 240, 0.88);
    border-radius: 10px;
    background: rgba(248, 250, 252, 0.85);
    cursor: pointer;
    list-style: none;
}

.usuarios-actions-trigger::-webkit-details-marker {
    display: none;
}

.usuarios-actions-trigger span {
    width: 3px;
    height: 3px;
    border-radius: 999px;
    background: #475569;
}

.usuarios-actions-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    z-index: 10;
    display: grid;
    gap: 6px;
    min-width: 180px;
    padding: 8px;
    border: 1px solid rgba(226, 232, 240, 0.92);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 18px 36px rgba(15, 23, 42, 0.08);
}

.usuarios-actions-dropdown form {
    margin: 0;
}

.usuarios-actions-dropdown .btn.btn-sm {
    width: 100%;
    min-height: 32px;
    justify-content: flex-start;
    padding: 0 10px;
    border-radius: 9px;
}

.usuarios-action-disabled {
    opacity: 0.58;
    cursor: not-allowed;
}

@media (max-width: 1080px) {
    .usuarios-compact-header,
    .usuarios-creation-strip {
        grid-template-columns: 1fr;
        flex-direction: column;
        align-items: stretch;
    }

    .usuarios-list-head {
        display: none;
    }

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

    .usuarios-row-role,
    .usuarios-row-actions {
        justify-content: flex-start;
    }
}

.turno-modelo-hero {
    align-items: start;
}

.turno-modelo-hero-meta {
    min-width: 220px;
}

.turno-modelo-workspace {
    display: grid;
    grid-template-columns: minmax(300px, 340px) minmax(0, 1fr);
    gap: 18px;
    align-items: start;
    min-width: 0;
}

.turno-modelo-sidebar {
    position: sticky;
    top: 90px;
    display: grid;
    gap: 16px;
    align-self: start;
}

.turno-modelo-editor {
    min-width: 0;
}

.turno-modelo-context-card .card-body,
.turno-modelo-summary-card,
.turno-modelo-preview-shell {
    min-width: 0;
}

.turno-modelo-context-grid {
    gap: 12px 14px;
}

.turno-modelo-summary-grid {
    display: grid;
    gap: 12px;
}

.turno-modelo-summary-card .turno-overview-card {
    border: 1px solid rgba(226, 232, 240, 0.9);
    border-radius: 16px;
    background: rgba(249, 250, 252, 0.92);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.turno-modelo-preview-list {
    max-height: min(46vh, 480px);
    overflow: auto;
    padding-right: 4px;
}

.turno-modelo-preview-list::-webkit-scrollbar,
.turno-model-field-list-scroll::-webkit-scrollbar {
    width: 6px;
}

.turno-modelo-preview-list::-webkit-scrollbar-thumb,
.turno-model-field-list-scroll::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.42);
}

.turno-modelo-structure-card {
    overflow: hidden;
    min-width: 0;
}

.turno-modelo-structure-header {
    align-items: start;
    gap: 16px;
}

.turno-model-grid-editor {
    display: grid;
    gap: 14px;
    min-width: 0;
}

.turno-model-block-card-deep {
    gap: 0;
    padding: 0;
    overflow: hidden;
    border: 1px solid rgba(226, 232, 240, 0.9);
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(247, 250, 252, 0.96));
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.04),
        0 10px 24px rgba(15, 23, 42, 0.04);
}

.turno-model-block-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    align-items: start;
    padding: 18px 20px 16px;
    border-bottom: 1px solid rgba(226, 232, 240, 0.86);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(248, 250, 252, 0.94));
}

.turno-model-block-layout {
    display: grid;
    grid-template-columns: minmax(280px, 0.82fr) minmax(360px, 1fr);
    min-width: 0;
}

.turno-model-block-core {
    display: grid;
    gap: 14px;
    min-width: 0;
    padding: 18px 20px 20px;
    border-right: 1px solid rgba(226, 232, 240, 0.86);
}

.turno-model-field-panel-editor {
    display: grid;
    gap: 12px;
    min-width: 0;
    padding: 18px 20px 20px;
    background: linear-gradient(180deg, rgba(249, 251, 253, 0.92), rgba(245, 248, 251, 0.96));
}

.turno-model-field-panel-head {
    gap: 8px;
}

.turno-model-field-list-scroll {
    max-height: min(68vh, 900px);
    overflow: auto;
    padding-right: 4px;
}

.turno-model-field-row {
    border: 1px solid rgba(226, 232, 240, 0.9);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.94);
}

.turno-model-field-row-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 16px;
    align-items: start;
}

.turno-model-field-row-title {
    display: flex;
    align-items: center;
    gap: 6px 8px;
    flex-wrap: wrap;
}

.turno-model-field-row-title strong {
    font-family: var(--font-display);
    font-size: 15px;
    font-weight: 700;
    color: #0f172a;
}

.turno-model-block-switches,
.turno-model-field-row-switches {
    justify-content: flex-end;
}

.turno-block-preview-card {
    border: 1px solid rgba(226, 232, 240, 0.88);
    border-radius: 16px;
    background: rgba(248, 250, 252, 0.86);
}

.turno-select-editor {
    display: grid;
    gap: 10px;
    min-width: 0;
    padding: 12px;
    border: 1px solid rgba(226, 232, 240, 0.88);
    border-radius: 14px;
    background: rgba(248, 250, 252, 0.92);
}

.turno-select-option-row {
    min-width: 0;
    grid-template-columns: minmax(0, 1fr) auto auto;
}

.turno-select-option-row .control {
    min-width: 0;
}

.turno-modelo-page .turno-form-toolbar {
    gap: 12px;
}

@media (max-width: 1280px) {
    .turno-modelo-workspace {
        grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
    }

    .turno-model-block-layout {
        grid-template-columns: minmax(0, 1fr);
    }

    .turno-model-block-core {
        border-right: 0;
        border-bottom: 1px solid rgba(226, 232, 240, 0.86);
    }
}

@media (max-width: 1024px) {
    .login-shell,
    .turno-modelo-workspace {
        grid-template-columns: minmax(0, 1fr);
    }

    .login-brand-panel {
        min-height: 0;
    }

    .turno-modelo-sidebar {
        position: static;
    }

    .turno-model-field-list-scroll,
    .turno-modelo-preview-list {
        max-height: none;
    }
}

@media (max-width: 720px) {
    .turno-model-block-head,
    .turno-model-field-row-head {
        grid-template-columns: minmax(0, 1fr);
    }

    .turno-model-block-switches,
    .turno-model-field-row-switches {
        justify-content: flex-start;
    }

    .turno-model-field-panel-editor,
    .turno-model-block-core {
        padding: 16px;
    }
}

/* ---------- Official Model Editor Workspace ----------
   Purpose-built editor layout for /turnos/modelos/{id}/editar. ---------- */

.turno-modelo-editor-stack {
    gap: 14px;
}

.turno-modelo-editor-shell {
    display: grid;
    gap: 16px;
    min-width: 0;
}

.turno-modelo-editor-shell[data-config-mode="simple"] .turno-advanced-only {
    display: none !important;
}

.editor-topbar {
    position: sticky;
    top: 86px;
    z-index: 14;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 14px 18px;
    border: 1px solid rgba(226, 232, 240, 0.88);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.94);
    backdrop-filter: blur(14px);
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.04),
        0 12px 30px rgba(15, 23, 42, 0.05);
}

.editor-title {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.editor-kicker {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #64748b;
}

.editor-title h1 {
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(24px, 2vw, 30px);
    font-weight: 700;
    letter-spacing: -0.05em;
    color: #0f172a;
}

.editor-title > span:last-child {
    font-size: 13px;
    color: #667085;
}

.editor-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.editor-grid {
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
    gap: 20px;
    align-items: start;
    min-width: 0;
}

.editor-sidebar {
    position: sticky;
    top: 166px;
    display: grid;
    gap: 16px;
    align-self: start;
    padding-right: 4px;
}

.editor-sidebar-section {
    display: grid;
    gap: 12px;
    padding: 0 0 16px;
    border-bottom: 1px solid rgba(226, 232, 240, 0.92);
}

.editor-sidebar-section:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.editor-sidebar-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #94a3b8;
}

.editor-sidebar-block,
.editor-sidebar-stats,
.editor-sidebar-preview {
    display: grid;
    gap: 12px;
}

.editor-sidebar-two-col {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.editor-sidebar-stat {
    display: grid;
    gap: 4px;
    padding-bottom: 10px;
    border-bottom: 1px solid rgba(226, 232, 240, 0.72);
}

.editor-sidebar-stat:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.editor-sidebar-stat span,
.editor-sidebar-preview-item span {
    font-size: 12px;
    color: #667085;
}

.editor-sidebar-stat strong,
.editor-sidebar-preview-item strong {
    font-family: var(--font-display);
    font-size: 15px;
    font-weight: 700;
    color: #0f172a;
}

.editor-sidebar-preview-item {
    display: grid;
    gap: 2px;
    padding-bottom: 10px;
    border-bottom: 1px solid rgba(226, 232, 240, 0.72);
}

.editor-sidebar-preview-item:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.editor-surface {
    display: grid;
    gap: 16px;
    min-width: 0;
    padding: 18px 20px 22px;
    border: 1px solid rgba(226, 232, 240, 0.88);
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(248, 250, 252, 0.97));
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.04),
        0 14px 36px rgba(15, 23, 42, 0.05);
}

.blocos-bar {
    position: sticky;
    top: 154px;
    z-index: 8;
    display: flex;
    align-items: stretch;
    gap: 8px;
    overflow-x: auto;
    padding: 0 0 8px;
    margin: -2px 0 0;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 255, 255, 0.96));
}

.blocos-bar::-webkit-scrollbar {
    height: 6px;
}

.blocos-bar::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.42);
}

.bloco-item {
    flex: 0 0 auto;
    display: grid;
    gap: 3px;
    min-width: 154px;
    padding: 12px 14px;
    border: 1px solid rgba(226, 232, 240, 0.72);
    border-radius: 14px;
    background: rgba(248, 250, 252, 0.86);
    color: #475467;
    text-align: left;
    transition: background-color 0.16s ease, border-color 0.16s ease, color 0.16s ease, transform 0.16s ease;
}

.bloco-item:hover {
    border-color: rgba(203, 213, 225, 0.9);
    background: rgba(255, 255, 255, 0.98);
    color: #0f172a;
}

.bloco-item.active {
    border-color: rgba(37, 99, 235, 0.24);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(239, 246, 255, 0.96));
    color: #0f172a;
    box-shadow: inset 0 -2px 0 #2563eb;
}

.bloco-item-name {
    font-family: var(--font-display);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.bloco-item-meta {
    font-size: 11px;
    color: #667085;
}

.editor-main {
    display: grid;
    min-width: 0;
}

.editor-panel {
    display: grid;
    gap: 18px;
    min-width: 0;
}

.editor-panel[hidden] {
    display: none !important;
}

.editor-panel-header {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 16px;
    padding-bottom: 16px;
    border-bottom: 1px solid rgba(226, 232, 240, 0.88);
}

.editor-panel-kicker {
    display: inline-block;
    margin-bottom: 6px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #64748b;
}

.editor-panel-header h2 {
    margin: 0;
    font-family: var(--font-display);
    font-size: 28px;
    font-weight: 700;
    letter-spacing: -0.05em;
    color: #0f172a;
}

.editor-panel-header p {
    margin: 6px 0 0;
    max-width: 64ch;
    font-size: 14px;
    color: #667085;
}

.editor-section {
    display: grid;
    gap: 14px;
}

.editor-section + .editor-section {
    padding-top: 18px;
    border-top: 1px solid rgba(226, 232, 240, 0.88);
}

.editor-section-head {
    display: grid;
    gap: 4px;
}

.editor-section-head h3 {
    margin: 0;
    font-family: var(--font-display);
    font-size: 18px;
    font-weight: 700;
    letter-spacing: -0.03em;
    color: #0f172a;
}

.editor-section-head p {
    margin: 0;
    font-size: 13px;
    color: #667085;
}

.editor-config-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px 14px;
}

.editor-static-value {
    display: flex;
    align-items: center;
    min-height: 40px;
    padding: 0 12px;
    border: 1px solid rgba(214, 220, 232, 0.96);
    border-radius: 14px;
    background: rgba(248, 250, 252, 0.9);
    color: #0f172a;
    font-weight: 600;
}

.editor-config-flags {
    display: flex;
    align-items: center;
    gap: 10px 14px;
    flex-wrap: wrap;
}

.editor-preview-line {
    display: grid;
    gap: 4px;
    padding: 14px 0 0;
    border-top: 1px dashed rgba(203, 213, 225, 0.88);
}

.editor-preview-line strong {
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #64748b;
}

.editor-preview-line span {
    font-size: 14px;
    color: #0f172a;
}

.field-list {
    display: grid;
    gap: 0;
}

.field-row {
    display: grid;
    gap: 12px;
    padding: 18px 0;
    border-top: 1px solid rgba(226, 232, 240, 0.88);
}

.field-list .field-row:first-child {
    padding-top: 0;
    border-top: 0;
}

.field-row-head {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 16px;
}

.field-name {
    font-family: var(--font-display);
    font-size: 15px;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: #0f172a;
}

.field-meta {
    margin-top: 4px;
    font-size: 12px;
    color: #667085;
}

.field-actions {
    display: flex;
    align-items: center;
    gap: 10px 14px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.field-row-body,
.field-select-editor {
    display: grid;
    gap: 12px;
}

.editor-field-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px 14px;
}

.field-select-editor {
    padding-top: 2px;
}

.turno-select-editor {
    display: grid;
    gap: 10px;
    min-width: 0;
    padding: 12px 14px;
    border: 1px solid rgba(226, 232, 240, 0.88);
    border-radius: 14px;
    background: rgba(248, 250, 252, 0.9);
}

.turno-select-option-list {
    display: grid;
    gap: 8px;
}

.turno-select-option-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: 8px;
    align-items: center;
    min-width: 0;
}

.turno-select-option-row .control {
    min-width: 0;
}

.turno-select-editor-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
}

@media (max-width: 1280px) {
    .editor-grid {
        grid-template-columns: 240px minmax(0, 1fr);
    }
}

@media (max-width: 1024px) {
    .editor-topbar {
        top: 78px;
        align-items: start;
        flex-direction: column;
    }

    .editor-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .editor-sidebar,
    .blocos-bar {
        position: static;
    }
}

@media (max-width: 720px) {
    .editor-topbar,
    .editor-surface {
        padding-left: 16px;
        padding-right: 16px;
    }

    .editor-sidebar-two-col,
    .editor-config-grid,
    .editor-field-grid {
        grid-template-columns: 1fr;
    }

    .field-row-head,
    .editor-panel-header {
        flex-direction: column;
        align-items: stretch;
    }

    .field-actions,
    .editor-actions {
        justify-content: flex-start;
    }
}

/* ---------- Official Turno Model Wizard ----------
   Guided editor for /turnos/modelos/{id}/editar. ---------- */

.wizard-shell {
    display: grid;
    gap: 16px;
}

.wizard-topbar {
    position: static;
    top: auto;
    z-index: auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: 18px;
    padding: 16px 20px;
    margin-bottom: 6px;
    border-color: rgba(229, 231, 235, 0.98);
    border-radius: 16px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.992), rgba(248, 250, 252, 0.98));
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.03),
        0 8px 18px rgba(15, 23, 42, 0.035);
}

.wizard-topbar-status {
    display: flex;
    align-items: center;
    justify-content: center;
}

.wizard-status-badge {
    min-height: 30px;
    padding-inline: 12px;
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.wizard-topbar .editor-title {
    gap: 4px;
}

.wizard-topbar .editor-title h1 {
    font-size: clamp(27px, 2vw, 33px);
    letter-spacing: -0.05em;
    line-height: 1.04;
}

.wizard-topbar .editor-title > span:last-child {
    font-size: 13px;
    line-height: 1.45;
    color: #667085;
}

.wizard-topbar .editor-actions {
    gap: 8px;
}

.wizard-layout {
    display: grid;
    grid-template-columns: 268px minmax(0, 1fr) 336px;
    gap: 22px;
    align-items: start;
    min-width: 0;
    padding-top: 4px;
}

.wizard-stepper,
.wizard-preview {
    position: sticky;
    top: 86px;
    display: grid;
    gap: 14px;
    align-self: start;
}

.wizard-stepper {
    padding: 8px 0 0;
}

.wizard-stepper-intro,
.wizard-preview-panel,
.wizard-panel,
.wizard-actions {
    border: 1px solid rgba(226, 232, 240, 0.9);
    border-radius: 14px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.996), rgba(249, 250, 252, 0.985));
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.035),
        0 10px 20px rgba(15, 23, 42, 0.032);
}

.wizard-stepper-intro,
.wizard-preview-panel {
    padding: 16px;
}

.wizard-stepper-intro h2,
.wizard-preview-panel h3,
.wizard-stage-head h2 {
    margin: 0;
    font-family: var(--font-display);
    letter-spacing: -0.04em;
    color: #0f172a;
}

.wizard-stepper-intro h2 {
    font-size: 22px;
    line-height: 1.22;
}

.wizard-stepper-intro p,
.wizard-preview-note,
.wizard-stage-head p {
    margin: 0;
    color: #667085;
    font-size: 13px;
    line-height: 1.5;
}

.wizard-stepper-nav {
    display: grid;
    gap: 10px;
    padding: 6px 0;
    border: 0;
    border-radius: 0;
    background: transparent;
}

.wizard-step {
    display: grid;
    grid-template-columns: 32px minmax(0, 1fr);
    gap: 12px;
    align-items: start;
    width: 100%;
    min-height: 72px;
    padding: 14px 12px;
    border: 1px solid rgba(226, 232, 240, 0.86);
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.92));
    color: #475467;
    text-align: left;
    transition: background-color 0.16s ease, color 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
}

.wizard-step:not(.is-current) {
    opacity: 0.8;
}

.wizard-step:hover {
    background: rgba(248, 250, 252, 0.95);
    border-color: rgba(214, 220, 232, 0.94);
    color: #0f172a;
    transform: translateY(-1px);
}

.wizard-step.is-current {
    background: linear-gradient(180deg, rgba(239, 246, 255, 0.94), rgba(255, 255, 255, 0.99));
    border-color: rgba(191, 219, 254, 0.98);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.95),
        0 4px 12px rgba(37, 99, 235, 0.06);
    color: #0f172a;
    opacity: 1;
}

.wizard-step.is-complete .wizard-step-index {
    background: #eff6ff;
    color: #2563eb;
    border-color: rgba(147, 197, 253, 0.95);
}

.wizard-step.is-current .wizard-step-index {
    background: #2563eb;
    color: #fff;
    border-color: #2563eb;
}

.wizard-step-index {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: 1px solid rgba(203, 213, 225, 0.92);
    border-radius: 999px;
    background: linear-gradient(180deg, #ffffff, #f8fafc);
    font-size: 12px;
    font-weight: 700;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.wizard-step-copy {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.wizard-step-copy strong {
    font-size: 14px;
    letter-spacing: -0.02em;
    color: #0f172a;
}

.wizard-step-copy span {
    font-size: 12px;
    color: #667085;
    line-height: 1.45;
}

.wizard-content {
    display: grid;
    min-width: 0;
}

.wizard-stage {
    display: grid;
    gap: 18px;
}

.wizard-stage-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 14px;
}

.wizard-stage-head h2 {
    font-size: clamp(28px, 2.2vw, 34px);
    line-height: 1.08;
}

.wizard-stage-head h2 [data-current-block-label] {
    display: inline-block;
    color: #2563eb;
    margin-left: 4px;
}

.wizard-stage-head-inline {
    align-items: start;
}

.wizard-stage-inline-actions,
.wizard-block-nav {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: flex-end;
    min-width: 0;
}

.wizard-panel {
    padding: 16px;
}

.wizard-form-grid,
.wizard-review-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.field-span-2 {
    grid-column: span 2;
}

.wizard-inline-group {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid rgba(226, 232, 240, 0.92);
}

.wizard-checkbox-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 14px;
    align-items: start;
    min-height: 74px;
    padding: 14px;
    border: 1px solid rgba(229, 231, 235, 0.96);
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.995), rgba(248, 250, 252, 0.95));
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.wizard-checkbox-card.is-disabled {
    opacity: 0.78;
    background: linear-gradient(180deg, rgba(248, 250, 252, 0.98), rgba(241, 245, 249, 0.94));
}

.wizard-checkbox-card.is-disabled input {
    cursor: not-allowed;
}

.wizard-checkbox-card span,
.wizard-inline-checkbox span {
    display: grid;
    gap: 2px;
}

.wizard-checkbox-card strong {
    color: #0f172a;
    font-size: 15px;
    letter-spacing: -0.02em;
}

.wizard-checkbox-card small {
    color: #667085;
    font-size: 12px;
    line-height: 1.45;
}

.wizard-mode-toggle {
    display: grid;
    gap: 10px;
}

.wizard-inline-help {
    grid-column: 1 / -1;
    margin: -8px 0 0;
    padding: 12px 14px;
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(255, 247, 237, 0.95), rgba(255, 237, 213, 0.82));
    color: #9a3412;
    font-size: 12px;
    line-height: 1.55;
}

.wizard-catalog-shell {
    display: grid;
    gap: 12px;
}

.wizard-catalog-group-head {
    display: grid;
    gap: 4px;
}

.wizard-catalog-group-head h3 {
    margin: 0;
    font-size: 18px;
    letter-spacing: -0.03em;
    color: #0f172a;
}

.wizard-catalog-group-head p {
    margin: 0;
    font-size: 12px;
    line-height: 1.5;
    color: #667085;
}

.wizard-catalog-group-head-optional {
    margin-top: 2px;
    padding-top: 10px;
    border-top: 1px solid rgba(226, 232, 240, 0.9);
}

.wizard-universal-tags {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
}

.wizard-universal-tags .turno-chip {
    justify-content: center;
    min-height: 28px;
    font-size: 11px;
    font-weight: 700;
    border: 1px solid rgba(191, 219, 254, 0.95);
    background: linear-gradient(180deg, rgba(239, 246, 255, 0.92), rgba(255, 255, 255, 0.98));
    color: #1d4ed8;
}

.wizard-catalog-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.wizard-catalog-grid-optional {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.wizard-choice-card {
    display: grid;
    gap: 8px;
    padding: 12px;
    border-radius: 12px;
    border: 1px solid rgba(226, 232, 240, 0.95);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(248, 250, 252, 0.93));
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.wizard-choice-card:hover {
    border-color: rgba(191, 219, 254, 0.9);
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.06);
    transform: translateY(-1px);
}

.wizard-choice-card.is-selected {
    border-color: rgba(59, 130, 246, 0.44);
    background: linear-gradient(180deg, rgba(239, 246, 255, 0.75), rgba(255, 255, 255, 0.98));
}

.wizard-choice-card-alias {
    opacity: 0.78;
    border-style: dashed;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(250, 252, 255, 0.96));
}

.wizard-choice-card-alias.is-selected {
    opacity: 0.94;
}

.wizard-choice-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.wizard-choice-meta .pill:not(.pill-neutral) {
    color: #1d4ed8;
    border-color: rgba(191, 219, 254, 0.96);
    background: linear-gradient(180deg, rgba(239, 246, 255, 0.95), rgba(255, 255, 255, 0.98));
}

.wizard-choice-title {
    color: #0f172a;
    font-size: 15px;
    line-height: 1.35;
    letter-spacing: -0.02em;
}

.wizard-choice-card p,
.wizard-choice-card small {
    margin: 0;
    color: #667085;
    font-size: 12px;
    line-height: 1.5;
}

.wizard-choice-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    flex-wrap: wrap;
    font-size: 12px;
    color: #64748b;
}

.wizard-advanced-shell {
    display: grid;
    gap: 12px;
    padding-top: 12px;
    background: linear-gradient(180deg, rgba(248, 250, 252, 0.9), rgba(255, 255, 255, 0.99));
}

.wizard-advanced-head {
    display: grid;
    gap: 2px;
}

.wizard-advanced-head strong {
    font-size: 13px;
    color: #0f172a;
}

.wizard-advanced-head span {
    font-size: 12px;
    color: #64748b;
}

.wizard-choice-footer strong {
    color: #0f172a;
}

.wizard-structure-list,
.wizard-preview-structure,
.wizard-review-structure,
.wizard-preview-summary,
.wizard-review-list {
    display: grid;
    gap: 10px;
}

.wizard-structure-row,
.wizard-review-item,
.wizard-preview-summary-item,
.wizard-preview-structure-item,
.wizard-review-structure-item,
.wizard-block-preview-field {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 12px;
    align-items: start;
    padding: 10px 0;
    border-top: 1px solid rgba(226, 232, 240, 0.92);
}

.wizard-structure-list > :first-child,
.wizard-review-list > :first-child,
.wizard-preview-summary > :first-child,
.wizard-review-structure > :first-child,
.wizard-preview-structure > :first-child,
.wizard-block-preview-fields > :first-child {
    border-top: 0;
    padding-top: 0;
}

.wizard-structure-order {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 10px;
    background: linear-gradient(180deg, #ffffff, #f8fafc);
    border: 1px solid rgba(229, 231, 235, 0.96);
    font-size: 13px;
    font-weight: 700;
    color: #475467;
}

.wizard-structure-row {
    grid-template-columns: auto minmax(0, 1.2fr) minmax(244px, auto);
    gap: 14px;
    padding-block: 12px;
}

.wizard-structure-copy,
.wizard-preview-summary-item,
.wizard-review-item,
.wizard-preview-structure-item,
.wizard-review-structure-item {
    display: grid;
    gap: 3px;
}

.wizard-structure-copy strong,
.wizard-preview-summary-item strong,
.wizard-review-item strong,
.wizard-preview-structure-item strong,
.wizard-review-structure-item strong,
.wizard-block-preview-field strong {
    color: #0f172a;
    font-size: 15px;
    line-height: 1.35;
    letter-spacing: -0.02em;
}

.wizard-structure-copy p,
.wizard-preview-summary-item span,
.wizard-review-item span,
.wizard-preview-structure-item span,
.wizard-review-structure-item span,
.wizard-block-preview-field span {
    margin: 0;
    color: #667085;
    font-size: 11px;
    line-height: 1.45;
}

.wizard-structure-tools {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.wizard-structure-actions,
.wizard-actions-primary,
.wizard-actions-secondary {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.wizard-order-input,
.wizard-block-select {
    width: 104px;
}

.wizard-block-tabs {
    top: 0;
    gap: 10px;
    padding: 2px 0 10px;
    background: transparent;
}

.wizard-block-tabs .bloco-item {
    min-width: 184px;
    padding: 14px 16px;
    border-radius: 12px;
    border-color: rgba(229, 231, 235, 0.96);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.03);
}

.wizard-block-tabs .bloco-item-name {
    font-size: 15px;
    line-height: 1.35;
}

.wizard-block-tabs .bloco-item-meta {
    font-size: 12px;
    line-height: 1.45;
}

.wizard-block-panels {
    gap: 14px;
}

.wizard-block-header {
    padding-bottom: 12px;
    gap: 12px;
}

.wizard-block-header h3,
.wizard-preview-panel h3 {
    font-size: 24px;
    line-height: 1.12;
}

.wizard-config-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.wizard-toggle-grid {
    gap: 12px;
}

/* ---------- Wizard Block Selection ----------
   Stronger visual feedback for the selected block tab/panel. ---------- */

.wizard-block-tabs .bloco-item {
    position: relative;
    overflow: hidden;
    transition:
        border-color 0.18s ease,
        background-color 0.18s ease,
        box-shadow 0.18s ease,
        color 0.18s ease,
        transform 0.18s ease;
}

.wizard-block-tabs .bloco-item::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(135deg, rgba(37, 99, 235, 0.08), rgba(59, 130, 246, 0.02));
    opacity: 0;
    transition: opacity 0.18s ease;
    pointer-events: none;
}

.wizard-block-tabs .bloco-item::before {
    content: "";
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: 0;
    height: 3px;
    border-radius: 999px;
    background: linear-gradient(90deg, #2563eb, #60a5fa);
    opacity: 0;
    transform: scaleX(0.4);
    transition: opacity 0.18s ease, transform 0.18s ease;
    transform-origin: center;
}

.wizard-block-tabs .bloco-item:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.06);
}

.wizard-block-tabs .bloco-item:hover::after {
    opacity: 0.7;
}

.wizard-block-tabs .bloco-item.active,
.wizard-block-tabs .bloco-item[aria-selected="true"] {
    border-color: rgba(37, 99, 235, 0.24);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(239, 246, 255, 0.98));
    color: #0f172a;
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.04),
        0 12px 28px rgba(37, 99, 235, 0.10);
}

.wizard-block-tabs .bloco-item.active::after,
.wizard-block-tabs .bloco-item[aria-selected="true"]::after {
    opacity: 1;
}

.wizard-block-tabs .bloco-item.active::before,
.wizard-block-tabs .bloco-item[aria-selected="true"]::before {
    opacity: 1;
    transform: scaleX(1);
}

.wizard-block-tabs .bloco-item.active .bloco-item-name,
.wizard-block-tabs .bloco-item[aria-selected="true"] .bloco-item-name {
    color: #0f172a;
}

.wizard-block-tabs .bloco-item.active .bloco-item-meta,
.wizard-block-tabs .bloco-item[aria-selected="true"] .bloco-item-meta {
    color: #365314;
}

.wizard-block-tabs .bloco-item:focus-visible {
    outline: none;
    border-color: rgba(37, 99, 235, 0.36);
    box-shadow:
        0 0 0 1px rgba(37, 99, 235, 0.18),
        0 0 0 4px rgba(37, 99, 235, 0.10);
}

.wizard-block-panel {
    opacity: 0.88;
    transform: translateY(4px);
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.wizard-block-panel.is-active {
    opacity: 1;
    transform: translateY(0);
}

.wizard-inline-checkbox {
    padding: 0;
    border: 0;
    background: transparent;
}

.wizard-shell .field {
    display: grid;
    gap: 10px;
}

.wizard-shell .label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #6b7280;
}

.wizard-shell .control,
.wizard-shell textarea.control,
.wizard-shell select.control {
    min-height: 42px;
    padding: 10px 12px;
    border-radius: 10px;
    border-color: #e5e7eb;
    background: #fff;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.96);
}

.wizard-shell textarea.control {
    min-height: 108px;
    padding-block: 12px;
}

.wizard-inline-note {
    gap: 6px;
}

.wizard-field-row .field-row-body {
    padding: 12px;
    border: 1px solid rgba(229, 231, 235, 0.9);
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(250, 251, 253, 0.8), rgba(255, 255, 255, 0.98));
}

.wizard-field-list {
    gap: 0;
}

.wizard-field-row {
    padding-block: 12px;
}

.wizard-field-grid {
    gap: 12px;
}

.wizard-preview-count {
    display: flex;
    align-items: baseline;
    gap: 8px;
    padding: 6px 0 12px;
}

.wizard-preview-count strong {
    font-family: var(--font-display);
    font-size: 34px;
    line-height: 1;
    color: #0f172a;
}

.wizard-preview-count span {
    color: #667085;
    font-size: 13px;
}

.wizard-block-preview {
    display: grid;
    gap: 16px;
}

.wizard-block-preview[hidden] {
    display: none !important;
}

.wizard-block-preview-note {
    padding: 14px 16px;
    border: 1px solid rgba(219, 234, 254, 0.98);
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(239, 246, 255, 0.82), rgba(255, 255, 255, 0.98));
    color: #1d4ed8;
    font-size: 13px;
    line-height: 1.6;
}

.wizard-block-preview-fields {
    display: grid;
    gap: 0;
    padding-top: 2px;
}

.wizard-actions {
    position: sticky;
    bottom: 12px;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 14px 16px;
    backdrop-filter: blur(14px);
}

.wizard-topbar .btn,
.wizard-actions .btn,
.wizard-structure-actions .btn,
.wizard-block-nav .btn {
    min-height: 40px;
    padding-inline: 16px;
    border-radius: 10px;
    font-weight: 600;
}

.wizard-shell .btn-primary {
    background: #2563eb;
    border-color: #2563eb;
    box-shadow: 0 1px 2px rgba(37, 99, 235, 0.16);
}

.wizard-shell .btn-primary:hover {
    background: #1d4ed8;
    border-color: #1d4ed8;
}

.wizard-shell .btn-secondary {
    background: #f1f5f9;
    border-color: #e2e8f0;
    color: #0f172a;
    box-shadow: none;
}

.wizard-shell .btn-ghost {
    border-color: #e5e7eb;
    background: #fff;
    color: #334155;
}

.wizard-shell .btn:hover {
    transform: translateY(-1px);
}

.wizard-review-grid .wizard-panel {
    min-height: 100%;
}

.wizard-review-list-tight .wizard-review-item {
    padding-block: 14px;
}

.wizard-preview-panel .editor-kicker {
    display: block;
    margin-bottom: 10px;
}

.wizard-preview-panel h3 {
    margin-bottom: 14px;
}

.wizard-preview-summary-item,
.wizard-review-item {
    grid-template-columns: minmax(0, 1fr);
    gap: 4px;
    padding-block: 12px;
}

.wizard-preview-summary-item span,
.wizard-review-item span {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #94a3b8;
}

.wizard-preview-summary-item strong,
.wizard-review-item strong {
    font-size: 16px;
    line-height: 1.35;
}

.wizard-preview-panel {
    background:
        linear-gradient(180deg, rgba(248, 250, 252, 0.96), rgba(255, 255, 255, 0.995));
}

.wizard-review-list-tight {
    gap: 8px;
}

@media (max-width: 1380px) {
    .wizard-layout {
        grid-template-columns: 220px minmax(0, 1fr) 280px;
    }
}

@media (max-width: 1180px) {
    .wizard-layout {
        grid-template-columns: minmax(0, 1fr);
    }

    .wizard-stepper,
    .wizard-preview {
        position: static;
    }

    .wizard-stepper-nav {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 900px) {
    .wizard-topbar {
        top: 78px;
        display: grid;
        grid-template-columns: minmax(0, 1fr);
        align-items: start;
    }

    .wizard-stage-head,
    .wizard-stage-head-inline,
    .wizard-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .wizard-form-grid,
    .wizard-inline-group,
    .wizard-review-grid,
    .wizard-catalog-grid,
    .wizard-catalog-grid-optional,
    .wizard-config-grid,
    .wizard-field-grid {
        grid-template-columns: 1fr;
    }

    .wizard-universal-tags {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .field-span-2 {
        grid-column: auto;
    }

    .wizard-structure-row,
    .wizard-review-item,
    .wizard-preview-summary-item,
    .wizard-preview-structure-item,
    .wizard-review-structure-item,
    .wizard-block-preview-field {
        grid-template-columns: minmax(0, 1fr);
    }

    .wizard-structure-tools,
    .wizard-stage-inline-actions,
    .wizard-block-nav,
    .wizard-actions-primary,
    .wizard-actions-secondary {
        justify-content: flex-start;
    }

    .wizard-order-input,
    .wizard-block-select {
        width: 100%;
    }
}

@media (max-width: 560px) {
    .wizard-universal-tags {
        grid-template-columns: 1fr;
    }
}

/* ---------- Turnos List Compact Refresh ----------
   Compact operational toolbar and line-list layout for /turnos. ---------- */

.turno-list-header-compact {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
    gap: 18px;
    padding: 18px 20px;
}

.turno-list-header-main {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
    gap: 18px;
    min-width: 0;
}

.turno-list-header-copy {
    min-width: 0;
}

.turno-list-header-compact .page-eyebrow {
    margin-bottom: 4px;
}

.turno-list-header-compact .page-header-title {
    margin: 0;
    font-size: 28px;
    line-height: 1.05;
}

.turno-list-header-compact .page-header-subtitle {
    margin-top: 6px;
    max-width: 54ch;
    font-size: 13px;
}

.turno-list-summary-strip-compact {
    gap: 8px;
}

.turno-list-summary-strip-compact .turno-list-summary-item {
    min-width: 94px;
    padding: 10px 12px;
    border-radius: 12px;
}

.turno-list-summary-strip-compact .turno-list-summary-item strong {
    font-size: 20px;
}

.turno-list-shell-actions-compact {
    align-self: center;
    gap: 6px;
}

.turno-list-shell-actions-compact .btn {
    min-height: 36px;
    padding: 0 13px;
}

.turno-filter-shell-inline {
    padding: 10px 12px;
}

.turnos-filtros-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 0;
    scrollbar-width: thin;
}

.turnos-filtros-bar::-webkit-scrollbar {
    height: 8px;
}

.turnos-filtros-bar::-webkit-scrollbar-thumb {
    background: rgba(148, 163, 184, 0.35);
    border-radius: 999px;
}

.filtro-input {
    height: 34px;
    min-width: 126px;
    padding: 0 10px;
    border-radius: 9px;
    font-size: 13px;
    box-shadow: none;
}

.filtro-input::placeholder {
    color: #64748b;
}

.filtro-input-date {
    min-width: 138px;
}

.filtro-input-wide {
    min-width: 160px;
}

.filtro-select {
    min-width: 118px;
}

.filtro-btn-primary,
.filtro-btn-ghost {
    min-height: 34px;
    padding: 0 12px;
    border-radius: 9px;
    flex: 0 0 auto;
}

.turno-filter-inline-summary {
    flex: 0 0 auto;
    margin-left: 4px;
    color: #64748b;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
}

.turno-history-shell-premium {
    padding-top: 10px;
}

.turno-history-headline {
    margin: 0 16px 8px;
}

.turno-history-headline .card-title {
    font-size: 17px;
}

.turno-history-headline .muted {
    font-size: 12px;
}

.turno-row {
    min-height: 0;
}

.turno-row .turno-status-rail {
    width: 4px;
    border-radius: 999px;
}

.turno-row-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.85fr) minmax(320px, 1.15fr) auto;
    align-items: center;
    gap: 14px;
    padding: 12px 16px;
}

.turno-row-main {
    min-width: 0;
}

.turno-row-titleline {
    gap: 8px;
    align-items: center;
    margin-bottom: 4px;
}

.turno-row .turno-card-title {
    font-size: 15px;
    line-height: 1.2;
    letter-spacing: -0.02em;
}

.turno-row-subline {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 4px 10px;
    color: #64748b;
    font-size: 12px;
    line-height: 1.4;
}

.turno-row-subline span {
    position: relative;
}

.turno-row-subline span + span::before {
    content: "•";
    margin-right: 10px;
    color: #c0cad7;
}

.turno-row-kpi-block {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.turno-kpis {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.turno-row .turno-count-badge {
    min-height: 28px;
    padding: 4px 8px;
    border-radius: 10px;
    gap: 3px;
}

.turno-row .turno-count-badge strong {
    font-size: 13px;
    letter-spacing: -0.02em;
}

.turno-row .turno-count-badge small {
    font-size: 10px;
    letter-spacing: 0.04em;
    text-transform: none;
}

.turno-row-updated {
    min-width: 132px;
    padding: 6px 8px;
    border: 0;
    background: transparent;
    text-align: right;
}

.turno-row-updated .turno-history-meta-label {
    font-size: 10px;
    letter-spacing: 0.1em;
}

.turno-row-updated strong {
    font-size: 12px;
    line-height: 1.35;
}

.turno-row-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 6px;
    flex-wrap: wrap;
}

.turno-row-actions form {
    margin: 0;
}

.turno-row-actions .btn {
    min-height: 28px;
    padding: 0 10px;
    border-radius: 8px;
    font-size: 12px;
}

@media (max-width: 1240px) {
    .turno-list-header-compact,
    .turno-list-header-main,
    .turno-row-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .turno-list-shell-actions-compact {
        justify-content: flex-start;
    }

    .turno-row-kpi-block,
    .turno-row-actions {
        justify-content: flex-start;
    }

    .turno-row-updated {
        text-align: left;
        padding-left: 0;
    }
}

@media (max-width: 720px) {
    .turno-list-header-compact {
        padding: 16px 18px;
    }

    .turno-filter-shell-inline {
        padding: 8px 10px;
    }

    .turno-history-headline {
        margin: 0 14px 8px;
    }

    .turno-row-grid {
        padding: 12px 14px;
    }
}

/* ---------- Turnos Premium Polish ----------
   Final refinement layer for /turnos header and history cards. ---------- */

.turno-list-header-compact {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 22px;
    padding: 20px 22px;
}

.turno-list-header-copy {
    display: grid;
    gap: 7px;
    min-width: 0;
}

.turno-list-header-compact .page-eyebrow {
    color: #64748b;
    letter-spacing: 0.14em;
}

.turno-list-header-compact .page-header-title {
    font-size: clamp(29px, 2vw, 34px);
    font-weight: 800;
    letter-spacing: -0.04em;
}

.turno-list-header-compact .page-header-subtitle {
    max-width: 60ch;
    color: #64748b;
    font-size: 13px;
}

.turno-list-header-side {
    display: grid;
    justify-items: end;
    gap: 12px;
}

.turno-list-summary-strip-compact {
    gap: 10px;
}

.turno-list-summary-strip-compact .turno-list-summary-item {
    min-width: 104px;
    padding: 11px 13px;
    border: 1px solid rgba(226, 232, 240, 0.9);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.98));
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.turno-list-summary-strip-compact .turno-meta-caption {
    color: #64748b;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.turno-list-summary-strip-compact .turno-list-summary-item strong {
    color: #0f172a;
    font-size: 21px;
}

.turno-list-shell-actions-compact {
    gap: 0;
}

.turno-list-cta {
    min-height: 42px;
    padding: 0 18px;
    border-radius: 12px;
    background: linear-gradient(135deg, #2563eb 0%, #3b82f6 100%) !important;
    box-shadow: 0 10px 24px rgba(37, 99, 235, 0.18);
}

.turno-list-cta:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 28px rgba(37, 99, 235, 0.22);
}

.turno-history-shell-premium {
    padding: 14px 10px 10px;
    border: 1px solid rgba(226, 232, 240, 0.88);
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.04);
}

.turno-history-headline {
    margin: 0 12px 12px;
    padding: 0 6px;
    align-items: end;
}

.turno-history-headline .card-title {
    color: #0f172a;
    font-size: 18px;
    font-weight: 800;
    letter-spacing: -0.03em;
}

.turno-history-headline .muted {
    color: #64748b;
    font-size: 12px;
}

.turno-history-count-badge {
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    border-color: rgba(226, 232, 240, 0.9);
    background: rgba(248, 250, 252, 0.9);
    color: #475467;
    font-size: 11px;
    font-weight: 700;
}

.turno-history-line-list {
    gap: 12px;
}

.turno-history-row-premium {
    margin: 0;
    border: 1px solid rgba(226, 232, 240, 0.78);
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 10px 28px rgba(15, 23, 42, 0.04);
    overflow: hidden;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.turno-history-row-premium + .turno-history-row-premium {
    border-top: 1px solid rgba(226, 232, 240, 0.78);
}

.turno-history-row-premium:hover {
    border-color: rgba(203, 213, 225, 0.95);
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 16px 34px rgba(15, 23, 42, 0.08);
    transform: translateY(-1px);
}

.turno-row .turno-status-rail {
    width: 5px;
}

.turno-row-grid {
    grid-template-columns: minmax(0, 1.7fr) minmax(310px, 1fr) auto;
    gap: 16px;
    padding: 16px 18px;
}

.turno-row-titleline {
    margin-bottom: 6px;
}

.turno-row .turno-card-title {
    color: #0f172a;
    font-size: 16px;
    font-weight: 800;
}

.turno-row .badge {
    min-height: 22px;
    padding: 0.2rem 0.56rem;
    border-radius: 999px;
    font-size: 0.66rem;
    font-weight: 700;
    letter-spacing: 0.04em;
}

.turno-row-subline {
    gap: 4px 0;
    color: #667085;
    font-size: 12px;
}

.turno-row-subline span {
    white-space: nowrap;
}

.turno-row-subline span + span {
    margin-left: 10px;
}

.turno-row-subline span + span::before {
    content: "\2022";
    margin-right: 10px;
    color: #c0cad7;
}

.turno-row-kpi-block {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 16px;
}

.turno-kpis {
    gap: 14px;
    flex-wrap: nowrap;
}

.turno-row .turno-count-badge {
    min-width: 50px;
    min-height: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    align-items: flex-start;
}

.turno-row .turno-count-badge strong {
    color: #0f172a;
    font-size: 17px;
    font-weight: 800;
    line-height: 1;
}

.turno-row .turno-count-badge small {
    color: #64748b;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.turno-row-updated {
    min-width: 124px;
    padding: 0;
    background: transparent;
    text-align: right;
}

.turno-row-updated .turno-history-meta-label {
    color: #94a3b8;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.turno-row-updated strong {
    color: #475467;
    font-size: 12px;
    font-weight: 700;
}

.turno-row-actions {
    gap: 8px;
}

.turno-row-actions .btn {
    min-height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
}

.turno-row-actions .btn-secondary {
    background: linear-gradient(180deg, #f8fafc 0%, #eef2f7 100%) !important;
    border-color: rgba(226, 232, 240, 0.92) !important;
    color: #0f172a !important;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.turno-row-actions .btn-secondary:hover {
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%) !important;
    border-color: rgba(203, 213, 225, 0.92) !important;
}

.turno-row-actions .btn-ghost {
    background: rgba(248, 250, 252, 0.7) !important;
    color: #475467 !important;
}

.turno-row-actions .btn-ghost:hover {
    background: rgba(241, 245, 249, 0.95) !important;
    color: #0f172a !important;
}

@media (max-width: 1240px) {
    .turno-list-header-compact {
        grid-template-columns: minmax(0, 1fr);
    }

    .turno-list-header-side {
        justify-items: start;
    }

    .turno-kpis {
        flex-wrap: wrap;
    }
}

/* ---------- Universal Turno Summary ----------
   Generic turn summary for /turnos, independent of specific model blocks. ---------- */

.turno-row-grid {
    grid-template-columns: minmax(0, 1.9fr) minmax(260px, 0.95fr) auto;
}

.turno-row-titleline {
    flex-wrap: wrap;
}

.turno-operacional-tag {
    display: inline-flex;
    align-items: center;
    min-height: 22px;
    padding: 0.18rem 0.56rem;
    border-radius: 999px;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.turno-operacional-estavel {
    background: rgba(236, 253, 243, 0.9);
    color: #15803d;
}

.turno-operacional-atencao {
    background: rgba(255, 247, 237, 0.92);
    color: #b45309;
}

.turno-operacional-critico {
    background: rgba(254, 242, 242, 0.92);
    color: #b91c1c;
}

.turno-row-summary-block {
    gap: 12px;
}

.turno-universal-summary {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px 0;
    color: #667085;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.45;
}

.turno-universal-summary span {
    white-space: nowrap;
}

.turno-universal-summary span strong {
    color: #0f172a;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: -0.02em;
}

.turno-universal-summary span + span {
    margin-left: 10px;
}

.turno-universal-summary span + span::before {
    content: "\2022";
    margin-right: 10px;
    color: #c0cad7;
}

.turno-row-updated {
    min-width: 116px;
}

@media (max-width: 1240px) {
    .turno-universal-summary span {
        white-space: normal;
    }

    .turno-universal-summary span + span {
        margin-left: 0;
    }

    .turno-universal-summary span + span::before {
        display: none;
    }
}

/* ---------- Mobile System ----------
   Unified premium mobile layer for the active shell and core screens.
   Keeps desktop intact while standardizing density, topbar, bottom nav,
   page headers, forms and admin lists across the product. ---------- */

@media (max-width: 1024px) {
    :root {
        --bottom-nav-height: 68px;
    }

    .app-shell-premium {
        --sidebar-width: min(86vw, 320px);
    }

    .sidebar-premium {
        box-shadow: 16px 0 34px rgba(15, 23, 42, 0.1);
    }

    .sidebar-shell {
        gap: 10px;
        padding: 12px 12px calc(12px + env(safe-area-inset-bottom));
    }

    .sidebar-header-premium {
        border-radius: 14px;
    }

    .sidebar-brand-premium {
        gap: 10px;
        padding: 14px 12px;
    }

    .sidebar-brand-kicker,
    .sidebar-brand-subtitle,
    .menu-item-subtitle,
    .sidebar-footer {
        display: none;
    }

    .sidebar-brand-text {
        font-size: 1rem;
    }

    .sidebar-nav-premium .nav-section {
        gap: 6px;
    }

    .sidebar-nav-premium .nav-section + .nav-section {
        padding-top: 8px;
        margin-top: 4px;
    }

    .sidebar-menu {
        gap: 4px;
    }

    .sidebar-premium .sidebar-link {
        min-height: 40px;
        padding: 9px 10px;
        border-radius: 12px;
    }

    .menu-item-title,
    .sidebar-premium .sidebar-label {
        font-size: 0.84rem;
    }

    .topbar,
    .topbar-premium {
        min-height: 56px;
        padding: 10px 14px;
        gap: 10px;
    }

    .topbar-left,
    .topbar-actions {
        gap: 8px;
        min-width: 0;
    }

    .topbar-context {
        min-width: 0;
    }

    .topbar-title {
        max-width: 100%;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .topbar-page-meta {
        display: none;
    }

    .topbar-session-mobile {
        display: block;
        max-width: 100%;
    }

    .hamburger {
        width: 36px;
        height: 36px;
        border-radius: 10px;
    }

    .btn-logout {
        min-height: 36px;
        min-width: 36px;
        padding: 0 10px;
        border-radius: 10px;
    }

    .btn-logout .btn-text {
        display: none;
    }

    .content,
    .content-premium {
        padding: 14px 14px calc(16px + var(--bottom-nav-height));
    }

    .content-inner,
    .page,
    .stack {
        gap: 14px;
    }

    .page-footer {
        display: none;
    }

    .bottom-nav {
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        display: grid;
        grid-auto-flow: column;
        grid-auto-columns: minmax(0, 1fr);
        gap: 6px;
        padding: 8px 10px calc(8px + env(safe-area-inset-bottom));
        border-top: 1px solid rgba(226, 232, 240, 0.9);
        background: rgba(255, 255, 255, 0.94);
        backdrop-filter: blur(18px);
        -webkit-backdrop-filter: blur(18px);
        box-shadow: 0 -8px 22px rgba(15, 23, 42, 0.06);
        z-index: 25;
    }

    .bottom-link {
        gap: 4px;
        justify-content: center;
        min-height: 52px;
        padding: 6px 4px 8px;
        border: 0;
        border-radius: 14px;
        background: transparent;
        font-size: 10px;
        font-weight: 700;
        letter-spacing: 0.01em;
    }

    .bottom-icon {
        width: 18px;
        height: 18px;
    }

    .bottom-link.active {
        border: 0;
        background: linear-gradient(180deg, rgba(239, 246, 255, 0.96), rgba(219, 234, 254, 0.84));
        box-shadow: inset 0 0 0 1px rgba(191, 219, 254, 0.86);
        color: #1d4ed8;
    }

    .bottom-link.active .bottom-icon {
        color: #f97316;
    }
}

@media (max-width: 720px) {
    :root {
        --bottom-nav-height: 64px;
    }

    .content,
    .content-premium {
        padding: 12px 12px calc(14px + var(--bottom-nav-height));
    }

    .container,
    .content-inner {
        max-width: none;
    }

    .topbar,
    .topbar-premium {
        min-height: 52px;
        padding: 8px 12px;
    }

    .topbar-eyebrow,
    .page-header .page-eyebrow,
    .turno-list-header-compact .page-eyebrow,
    .dashboard-shell .page-eyebrow {
        display: none;
    }

    .topbar .topbar-title,
    .topbar-premium .topbar-title {
        font-size: 15px;
    }

    .topbar-context {
        gap: 1px;
    }

    .topbar-session-mobile {
        font-size: 10px;
        color: #667085;
    }

    .page-header,
    .dashboard-hero,
    .turno-detail-hero,
    .turno-form-hero,
    .turno-premium-hero,
    .card,
    .panel,
    .turno-filter-card,
    .turno-history-card,
    .turno-section-shell,
    .glass-card {
        padding: 14px 14px 15px;
        border-radius: 16px;
    }

    .page-header,
    .dashboard-shell,
    .turno-list-header-compact {
        gap: 12px;
    }

    .page-header-info {
        gap: 10px;
        align-items: start;
    }

    .page-header-icon,
    .stat-icon-wrapper,
    .action-icon-wrapper {
        width: 32px;
        height: 32px;
        border-radius: 10px;
    }

    .page-header-title,
    .turno-list-header-compact .page-header-title {
        font-size: 22px;
        line-height: 1.06;
        letter-spacing: -0.04em;
    }

    .page-header-subtitle,
    .turno-list-header-compact .page-header-subtitle,
    .dashboard-shell .page-header-subtitle,
    .card-header .muted {
        font-size: 12px;
        line-height: 1.45;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .detail-pairs {
        width: 100%;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }

    .detail-pair {
        padding: 10px 12px;
        border: 1px solid rgba(226, 232, 240, 0.84);
        border-radius: 12px;
        background: rgba(248, 250, 252, 0.9);
    }

    .card-header,
    .card-footer {
        gap: 10px;
    }

    .card-footer,
    .tenant-plan-card-footer,
    .page-header-actions,
    .turno-list-shell-actions-compact {
        align-items: stretch;
        flex-direction: column;
    }

    .card-footer .btn,
    .tenant-plan-card-footer .btn,
    .page-header-actions .btn,
    .turno-list-shell-actions-compact .btn,
    .usuarios-strip-submit {
        width: 100%;
        justify-content: center;
    }

    .control,
    select.control,
    textarea.control {
        min-height: 44px;
        border-radius: 12px;
    }

    .btn {
        min-height: 42px;
    }

    .dashboard-shell {
        grid-template-columns: minmax(0, 1fr);
        padding: 15px;
    }

    .dashboard-shell-meta {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 8px;
        width: 100%;
    }

    .dashboard-shell-meta-card {
        min-width: 0;
        padding: 10px 11px;
        border-radius: 12px;
    }

    .dashboard-shell-meta-card .detail-label {
        font-size: 10px;
    }

    .dashboard-shell-meta-card .detail-value {
        font-size: 16px;
    }

    .dashboard-stat-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .dashboard-stat-grid .stat-card {
        min-height: 0;
        padding: 12px;
        border-radius: 14px;
    }

    .dashboard-stat-grid .stat-icon-wrapper {
        width: 30px;
        height: 30px;
    }

    .dashboard-stat-grid .stat-label {
        font-size: 11px;
    }

    .dashboard-stat-grid .stat-value {
        font-size: 22px;
    }

    .dashboard-stat-grid .stat-trend {
        display: none;
    }

    .dashboard-quick-actions {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .dashboard-quick-actions .quick-action {
        min-height: 0;
        padding: 12px;
        gap: 10px;
        align-items: start;
    }

    .dashboard-quick-actions .action-icon-wrapper {
        width: 34px;
        height: 34px;
        border-radius: 10px;
    }

    .dashboard-quick-actions .action-title {
        font-size: 13px;
        line-height: 1.35;
    }

    .dashboard-quick-actions .action-desc,
    .dashboard-quick-actions .action-arrow {
        display: none;
    }

    .dashboard-recent-row {
        gap: 10px;
        padding: 12px 0;
    }

    .dashboard-recent-overline {
        font-size: 10px;
        letter-spacing: 0.08em;
    }

    .dashboard-recent-side {
        align-items: flex-start;
        gap: 8px;
    }

    .dashboard-recent-timestamp {
        align-items: flex-start;
    }

    .turno-list-header-compact {
        grid-template-columns: minmax(0, 1fr);
        gap: 12px;
        padding: 14px;
    }

    .turno-list-header-side {
        justify-items: stretch;
        gap: 10px;
    }

    .turno-list-summary-strip-compact {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 8px;
        width: 100%;
    }

    .turno-list-summary-strip-compact .turno-list-summary-item {
        min-width: 0;
        padding: 10px;
    }

    .turno-list-summary-strip-compact .turno-list-summary-item strong {
        font-size: 18px;
    }

    .turno-list-cta {
        min-height: 40px;
    }

    .turno-filter-shell-inline {
        padding: 8px 10px;
        border-radius: 14px;
    }

    .turnos-filtros-bar {
        gap: 6px;
        padding: 0;
        flex-wrap: nowrap;
        overflow-x: auto;
    }

    .filtro-input {
        min-width: 124px;
        height: 36px;
        font-size: 12px;
    }

    .filtro-input-date {
        min-width: 138px;
    }

    .filtro-input-wide {
        min-width: 156px;
    }

    .filtro-btn-primary,
    .filtro-btn-ghost {
        min-height: 36px;
        white-space: nowrap;
    }

    .turno-filter-inline-summary {
        display: none;
    }

    .turno-history-shell-premium {
        padding: 10px 8px 8px;
        border-radius: 16px;
    }

    .turno-history-headline {
        margin: 0 8px 8px;
        padding: 0 4px;
        gap: 8px;
        align-items: flex-start;
    }

    .turno-history-headline .muted {
        display: none;
    }

    .turno-history-line-list {
        gap: 8px;
    }

    .turno-row-grid {
        padding: 12px;
        gap: 10px;
    }

    .turno-history-titleline {
        gap: 6px;
        align-items: flex-start;
        flex-wrap: wrap;
    }

    .turno-card-title {
        font-size: 15px;
    }

    .turno-history-subline {
        gap: 4px 8px;
        font-size: 11px;
        line-height: 1.4;
    }

    .turno-row-summary-block {
        gap: 8px;
    }

    .turno-universal-summary {
        gap: 4px 10px;
        font-size: 11px;
    }

    .turno-universal-summary span strong {
        font-size: 13px;
    }

    .turno-row-updated {
        min-width: 0;
        padding: 0;
    }

    .turno-row-updated .turno-history-meta-label {
        font-size: 9px;
    }

    .turno-row-updated strong {
        font-size: 11px;
    }

    .turno-row-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 6px;
        width: 100%;
    }

    .turno-row-actions form {
        width: 100%;
    }

    .turno-row-actions .btn {
        width: 100%;
        min-height: 34px;
    }

    .card-narrow {
        max-width: none;
    }

    .tenant-plan-card {
        padding: 14px 14px 0;
    }

    .tenant-plan-card-header {
        flex-direction: column;
        gap: 12px;
    }

    .tenant-plan-summary-grid {
        grid-template-columns: 1fr;
        gap: 8px;
        padding: 0 0 14px;
    }

    .tenant-plan-summary-item {
        gap: 4px;
        padding: 12px;
        border-radius: 12px;
    }

    .tenant-plan-form {
        gap: 14px;
    }

    .tenant-plan-form-grid {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .tenant-plan-card-footer .muted {
        margin: 0;
    }

    .usuarios-page .stack {
        gap: 10px;
    }

    .usuarios-shell {
        gap: 10px;
        padding: 14px;
        border-radius: 16px;
    }

    .usuarios-compact-header {
        padding-bottom: 8px;
    }

    .usuarios-compact-title {
        gap: 2px;
    }

    .usuarios-compact-title h1 {
        font-size: 1.35rem;
    }

    .usuarios-compact-title p {
        font-size: 12px;
    }

    .usuarios-creation-strip {
        grid-template-columns: 1fr;
        gap: 8px;
        padding: 0;
        border: 0;
        background: transparent;
        box-shadow: none;
    }

    .usuarios-strip-input,
    .usuarios-strip-submit {
        width: 100%;
    }

    .usuarios-strip-checkbox {
        min-height: 40px;
        justify-content: flex-start;
        padding: 0 12px;
    }

    .usuarios-list-legend {
        display: none;
    }

    .usuarios-list-shell {
        gap: 8px;
    }

    .usuarios-row {
        grid-template-columns: minmax(0, 1fr) auto;
        grid-template-areas:
            "identity actions"
            "role status";
        gap: 8px 10px;
        min-height: 0;
        padding: 10px 12px;
        border-radius: 14px;
    }

    .usuarios-row-identity {
        grid-area: identity;
    }

    .usuarios-row-role {
        grid-area: role;
    }

    .usuarios-row-status {
        grid-area: status;
        justify-content: flex-end;
    }

    .usuarios-row-actions {
        grid-area: actions;
        justify-content: flex-end;
        align-self: start;
    }

    .usuarios-row-avatar {
        width: 30px;
        height: 30px;
        border-radius: 9px;
    }

    .usuarios-row-title {
        font-size: 13px;
    }

    .usuarios-row-meta {
        display: none;
    }

    .usuarios-role-badge,
    .usuarios-status-badge {
        padding: 0.16rem 0.46rem;
        font-size: 0.62rem;
    }

    .usuarios-actions-trigger {
        width: 30px;
        height: 30px;
        border-radius: 9px;
    }

    .usuarios-actions-dropdown {
        min-width: 168px;
    }
}

@media (max-width: 420px) {
    .dashboard-stat-grid,
    .dashboard-quick-actions {
        grid-template-columns: 1fr;
    }

    .dashboard-shell-meta,
    .detail-pairs,
    .turno-list-summary-strip-compact,
    .turno-row-actions {
        grid-template-columns: 1fr;
    }

    .usuarios-row {
        grid-template-columns: 1fr;
        grid-template-areas:
            "identity"
            "role"
            "status"
            "actions";
    }

    .usuarios-row-status,
    .usuarios-row-actions {
        justify-content: flex-start;
    }
}

/* ---------- Mobile Navigation Refinement ----------
   Final mobile-only pass for bottom nav alignment and sidebar redundancy. ---------- */

@media (max-width: 1024px) {
    .hamburger {
        display: none;
    }

    .hamburger.has-mobile-secondary {
        display: inline-flex;
    }

    .sidebar-link-mobile-primary,
    .nav-section-account,
    .nav-section-admin {
        display: none !important;
    }

    .nav-section-operation {
        gap: 8px;
    }

    .nav-section-operation .nav-section-title {
        padding: 4px 8px 2px;
    }

    .bottom-nav {
        align-items: center;
        justify-items: center;
        min-height: 66px;
        gap: 0;
        padding: 7px 8px calc(7px + env(safe-area-inset-bottom));
        border-top: 1px solid rgba(226, 232, 240, 0.9);
        background: rgba(255, 255, 255, 0.97);
        backdrop-filter: blur(10px);
    }

    .bottom-nav.bottom-nav--four {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .bottom-nav.bottom-nav--three {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .bottom-link {
        position: relative;
        display: grid;
        grid-template-rows: auto auto;
        align-content: center;
        justify-items: center;
        min-height: 54px;
        width: 100%;
        gap: 4px;
        padding: 8px 4px 6px;
        border-radius: 12px;
        color: #64748b;
        font-size: 10.5px;
    }

    .bottom-link span:last-child {
        line-height: 1.15;
        text-align: center;
        font-weight: 600;
    }

    .bottom-link:hover {
        background: rgba(241, 245, 249, 0.88);
        color: #334155;
    }

    .bottom-link.active {
        background: linear-gradient(180deg, rgba(37, 99, 235, 0.1), rgba(37, 99, 235, 0.05));
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
        color: #0f172a;
    }

    .bottom-link.active::before {
        content: "";
        position: absolute;
        top: 2px;
        left: 50%;
        width: 18px;
        height: 3px;
        border-radius: 999px;
        transform: translateX(-50%);
        background: linear-gradient(90deg, #2563eb, #1d4ed8);
        opacity: 0.96;
    }

    .bottom-link.active .bottom-icon {
        color: #1e40af;
        transform: translateY(-0.5px);
    }

    .bottom-link.active span:last-child {
        color: #0f172a;
    }

    .bottom-icon {
        width: 18px;
        height: 18px;
    }

    .bottom-icon svg {
        width: 18px;
        height: 18px;
    }
}

@media (max-width: 720px) {
    .bottom-nav {
        min-height: 64px;
        padding: 6px 6px calc(6px + env(safe-area-inset-bottom));
    }

    .bottom-link {
        min-height: 52px;
        gap: 3px;
        padding: 7px 4px 6px;
        font-size: 10px;
    }

    .bottom-icon {
        width: 18px;
        height: 18px;
    }

    .bottom-link span:last-child {
        font-size: 9.6px;
    }
}

/* ---------- Operacoes Hub ---------- */

.operacoes-stack {
    gap: 12px;
}

.operacoes-header {
    display: block;
    grid-template-columns: 1fr;
    padding: 16px 18px;
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.96));
    box-shadow: 0 12px 26px rgba(15, 23, 42, 0.05);
}

.operacoes-hero-copy {
    max-width: 680px;
    display: grid;
    gap: 5px;
    justify-items: start;
    text-align: left;
}

.operacoes-hero-label {
    margin: 0;
    font-size: 11px;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #94a3b8;
}

.operacoes-hero-title {
    margin: 0;
    font-size: clamp(27px, 2.1vw, 31px);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.03em;
    color: #0f172a;
}

.operacoes-hero-subtitle {
    margin: 0;
    font-size: 14px;
    line-height: 1.42;
    color: #64748b;
    max-width: 44ch;
}

.operacoes-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.operacao-card {
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: 15px;
    background: #fff;
    padding: 14px;
    display: grid;
    gap: 10px;
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.05);
}

.operacao-card-head {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.operacao-card-head strong {
    font-size: 1.08rem;
    font-weight: 700;
    color: #0f172a;
}

.operacao-card-desc {
    margin: 0;
    color: #475569;
    font-size: 0.9rem;
    line-height: 1.48;
}

.operacao-card-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.operacao-metric {
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: 10px;
    background: rgba(248, 250, 252, 0.82);
    padding: 8px 10px;
    display: grid;
    gap: 1px;
}

.operacao-metric span {
    font-size: 0.72rem;
    color: #64748b;
}

.operacao-metric strong {
    font-size: 0.98rem;
    color: #0f172a;
}

.operacao-card-actions {
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
}

.operacao-card-actions .btn {
    flex: 1 1 0;
    min-height: 38px;
    justify-content: center;
}

.operacoes-presets-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.operacao-preset-card {
    border: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: 14px;
    padding: 14px;
    background: #fff;
    display: grid;
    gap: 10px;
}

.operacao-preset-card strong {
    font-size: 0.98rem;
    color: #0f172a;
}

.operacao-preset-card p {
    margin: 0;
    color: #475569;
    font-size: 0.88rem;
    line-height: 1.42;
}

.operacao-preset-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.operacoes-outros-list {
    display: grid;
    gap: 8px;
}

.operacoes-outro-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: 12px;
    padding: 10px 12px;
    color: #0f172a;
    text-decoration: none;
    background: #fff;
}

.operacoes-outro-item span {
    color: #64748b;
    font-size: 0.82rem;
}

.operacoes-admin-note .card-body {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.operacoes-admin-note {
    border: 1px solid rgba(148, 163, 184, 0.2);
    background: linear-gradient(180deg, rgba(248, 250, 252, 0.95), rgba(255, 255, 255, 0.96));
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.04);
}

.operacoes-admin-copy {
    display: grid;
    gap: 2px;
}

.operacoes-admin-kicker {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #94a3b8;
}

.operacoes-admin-note p {
    margin: 4px 0 0;
}

@media (max-width: 960px) {
    .operacoes-grid,
    .operacoes-presets-grid {
        grid-template-columns: 1fr;
    }

    .operacoes-header {
        padding: 14px 16px;
    }

    .operacoes-hero-copy {
        max-width: 100%;
        gap: 4px;
    }

    .operacoes-hero-title {
        font-size: clamp(24px, 6.5vw, 28px);
        line-height: 1.12;
    }

    .operacoes-hero-subtitle {
        font-size: 13px;
        max-width: 33ch;
    }

    .operacao-card {
        padding: 13px;
        gap: 9px;
    }

    .operacao-card-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }

    .operacao-card-actions .btn {
        width: 100%;
        min-height: 40px;
        padding: 9px 10px;
    }

    .operacoes-admin-note .btn {
        width: 100%;
        justify-content: center;
    }

    .operacoes-admin-note .card-body {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 380px) {
    .operacao-card-actions {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 360px) {
    .operacoes-stack {
        gap: 10px;
    }

    .operacoes-header {
        padding: 12px 12px;
        border-radius: 14px;
    }

    .operacoes-hero-label {
        font-size: 10px;
    }

    .operacoes-hero-title {
        font-size: 23px;
        line-height: 1.14;
        letter-spacing: -0.02em;
    }

    .operacoes-hero-subtitle {
        max-width: 30ch;
        font-size: 12.5px;
        line-height: 1.4;
    }

    .operacao-card {
        padding: 12px;
        gap: 8px;
        border-radius: 13px;
    }

    .operacao-card-head {
        gap: 5px;
    }

    .operacao-card-head strong {
        font-size: 1rem;
    }

    .operacao-card-desc {
        font-size: 0.84rem;
        line-height: 1.42;
    }

    .operacao-card-metrics {
        gap: 6px;
    }

    .operacao-metric {
        padding: 7px 8px;
        border-radius: 9px;
    }

    .operacao-metric span {
        font-size: 0.68rem;
    }

    .operacao-metric strong {
        font-size: 0.92rem;
    }

    .operacao-card-actions .btn {
        min-height: 38px;
        padding: 8px 9px;
        font-size: 12.5px;
    }

    .operacoes-admin-note {
        border-radius: 13px;
    }

    .operacoes-admin-note .card-body {
        gap: 8px;
    }

    .operacoes-admin-kicker {
        font-size: 9.5px;
    }

    .operacoes-admin-copy strong {
        font-size: 0.95rem;
    }

    .operacoes-admin-note p {
        margin-top: 2px;
        font-size: 12px;
        line-height: 1.4;
    }

    .bottom-nav {
        min-height: 62px;
        padding: 5px 5px calc(5px + env(safe-area-inset-bottom));
    }

    .bottom-link {
        min-height: 50px;
        gap: 2px;
        padding: 6px 3px 5px;
    }

    .bottom-link span:last-child {
        font-size: 9.2px;
        line-height: 1.1;
    }

    .bottom-icon,
    .bottom-icon svg {
        width: 17px;
        height: 17px;
    }
}

/* ---------- Operacoes Segment Pages ---------- */

.operacoes-segment-page {
    gap: 12px;
}

.operacoes-segment-stack {
    gap: 12px;
}

.operacoes-segment-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px 12px;
    padding: 14px 16px;
    border: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(248, 250, 252, 0.96));
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.05);
}

.operacoes-segment-header-copy {
    display: grid;
    gap: 4px;
}

.operacoes-segment-kicker {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #94a3b8;
}

.operacoes-segment-title {
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(25px, 2.1vw, 31px);
    line-height: 1.1;
    letter-spacing: -0.03em;
    color: #0f172a;
}

.operacoes-segment-subtitle {
    margin: 0;
    color: #64748b;
    font-size: 13.5px;
    line-height: 1.42;
    max-width: 64ch;
}

.operacoes-segment-top-actions {
    display: flex;
    align-items: flex-start;
    justify-content: flex-end;
    gap: 8px;
}

.operacoes-segment-meta-grid {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.operacoes-segment-meta-item {
    display: grid;
    gap: 2px;
    padding: 9px 10px;
    border: 1px solid rgba(226, 232, 240, 0.94);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.92);
}

.operacoes-segment-meta-item span {
    font-size: 10px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-weight: 700;
    color: #94a3b8;
}

.operacoes-segment-meta-item strong {
    font-size: 14px;
    color: #0f172a;
    line-height: 1.35;
}

.operacoes-segment-section {
    border: 1px solid rgba(226, 232, 240, 0.92);
    border-radius: 16px;
    box-shadow: 0 10px 20px rgba(15, 23, 42, 0.05);
}

.operacoes-segment-section-primary {
    border-color: rgba(191, 219, 254, 0.95);
    background: linear-gradient(180deg, rgba(239, 246, 255, 0.56), rgba(255, 255, 255, 0.98));
}

.operacoes-segment-section-soft {
    background: linear-gradient(180deg, rgba(248, 250, 252, 0.8), rgba(255, 255, 255, 0.98));
}

.operacoes-segment-section-head {
    margin-bottom: 10px;
}

.operacoes-segment-section-head .card-title {
    font-size: 20px;
}

.operacoes-segment-section-kicker {
    display: inline-block;
    margin-bottom: 3px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    color: #94a3b8;
}

.operacoes-segment-preset-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.operacoes-segment-preset-card,
.operacoes-segment-modelo-card {
    display: grid;
    gap: 9px;
    padding: 12px;
    border: 1px solid rgba(226, 232, 240, 0.95);
    border-radius: 13px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.995), rgba(248, 250, 252, 0.94));
    box-shadow: 0 6px 14px rgba(15, 23, 42, 0.04);
}

.operacoes-segment-preset-head,
.operacoes-segment-modelo-head {
    display: grid;
    gap: 4px;
}

.operacoes-segment-pill {
    display: inline-flex;
    width: fit-content;
    min-height: 22px;
    align-items: center;
    padding: 0 8px;
    border-radius: 999px;
    border: 1px solid rgba(147, 197, 253, 0.9);
    background: rgba(239, 246, 255, 0.86);
    color: #1d4ed8;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.operacoes-segment-preset-head strong {
    font-size: 17px;
    line-height: 1.2;
    letter-spacing: -0.02em;
    color: #0f172a;
}

.operacoes-segment-preset-head p {
    margin: 0;
    color: #475569;
    font-size: 13px;
    line-height: 1.45;
}

.operacoes-segment-points {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.operacoes-segment-preset-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.operacoes-segment-preset-actions,
.operacoes-segment-modelo-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.operacoes-segment-preset-actions .btn,
.operacoes-segment-modelo-actions .btn {
    min-height: 36px;
}

.operacoes-segment-note {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    padding: 0 10px;
    border-radius: 10px;
    border: 1px dashed rgba(148, 163, 184, 0.48);
    color: #64748b;
    font-size: 12px;
    background: rgba(248, 250, 252, 0.82);
}

.operacoes-segment-modelos-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.operacoes-segment-modelo-head {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 8px;
}

.operacoes-segment-modelo-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.operacoes-segment-modelo-actions form {
    margin: 0;
}

.operacoes-segment-admin-card {
    border: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(248, 250, 252, 0.9), rgba(255, 255, 255, 0.98));
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.04);
}

.operacoes-segment-admin-body {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.operacoes-segment-admin-copy {
    display: grid;
    gap: 2px;
}

.operacoes-segment-admin-kicker {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #94a3b8;
}

.operacoes-segment-admin-copy strong {
    color: #0f172a;
}

.operacoes-segment-admin-copy p {
    margin: 0;
    color: #64748b;
    font-size: 12.5px;
    line-height: 1.42;
}

@media (max-width: 980px) {
    .operacoes-segment-header {
        grid-template-columns: 1fr;
        gap: 9px;
        padding: 13px 14px;
    }

    .operacoes-segment-top-actions {
        justify-content: flex-start;
        flex-wrap: wrap;
    }

    .operacoes-segment-meta-grid,
    .operacoes-segment-preset-grid,
    .operacoes-segment-modelos-grid {
        grid-template-columns: 1fr;
    }

    .operacoes-segment-section-head .card-title {
        font-size: 18px;
    }

    .operacoes-segment-title {
        font-size: clamp(23px, 6.3vw, 28px);
    }

    .operacoes-segment-subtitle {
        font-size: 12.8px;
        max-width: 36ch;
    }
}

@media (max-width: 720px) {
    .operacoes-segment-page {
        gap: 10px;
    }

    .operacoes-segment-stack {
        gap: 10px;
    }

    .operacoes-segment-header,
    .operacoes-segment-section,
    .operacoes-segment-preset-card,
    .operacoes-segment-modelo-card,
    .operacoes-segment-admin-card {
        border-radius: 13px;
    }

    .operacoes-segment-header {
        padding: 12px;
    }

    .operacoes-segment-meta-item {
        min-height: 54px;
    }

    .operacoes-segment-preset-head strong {
        font-size: 16px;
    }

    .operacoes-segment-preset-head p,
    .operacoes-segment-admin-copy p {
        font-size: 12px;
    }

    .operacoes-segment-modelo-meta {
        grid-template-columns: 1fr;
    }

    .operacoes-segment-preset-actions,
    .operacoes-segment-modelo-actions {
        display: grid;
        grid-template-columns: 1fr;
    }

    .operacoes-segment-preset-actions .btn,
    .operacoes-segment-modelo-actions .btn,
    .operacoes-segment-modelo-actions form .btn {
        width: 100%;
        justify-content: center;
    }

    .operacoes-segment-admin-body {
        flex-direction: column;
        align-items: flex-start;
    }

    .operacoes-segment-admin-body .btn {
        width: 100%;
        justify-content: center;
    }
}

/* ---------- Turno Novo Flow ---------- */

.turno-new-page {
    gap: 14px;
}

.turno-new-context {
    display: grid;
    gap: 4px;
    padding: 14px 16px;
    border: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(248, 250, 252, 0.96));
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.05);
}

.turno-new-context-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #94a3b8;
}

.turno-new-context-title {
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(24px, 2vw, 30px);
    font-weight: 700;
    line-height: 1.08;
    letter-spacing: -0.03em;
    color: #0f172a;
}

.turno-new-context-subinfo {
    margin: 0;
    font-size: 13px;
    line-height: 1.4;
    color: #64748b;
}

.turno-new-main-card,
.turno-new-block {
    border-radius: 16px;
    border-color: rgba(226, 232, 240, 0.92);
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.04);
}

.turno-new-main-head,
.turno-new-block-head {
    margin-bottom: 12px;
}

.turno-new-main-head .card-title,
.turno-new-block-head .card-title {
    font-size: 18px;
}

.turno-new-block-head .muted {
    max-width: 58ch;
}

.turno-new-fields-grid {
    gap: 12px;
}

.turno-new-field .control {
    min-height: 38px;
    padding: 8px 11px;
    border-radius: 12px;
}

.turno-new-field textarea.control {
    min-height: 88px;
}

.turno-new-field.turno-field-compact .control {
    min-height: 36px;
}

.turno-new-repeat-list {
    gap: 10px;
}

.turno-new-repeat-item {
    border-radius: 14px;
    border-color: rgba(226, 232, 240, 0.9);
    box-shadow: 0 4px 10px rgba(15, 23, 42, 0.03);
}

.turno-new-repeat-actions {
    margin-bottom: 10px;
}

.turno-new-repeat-actions strong {
    font-size: 13px;
    letter-spacing: -0.01em;
}

.turno-new-sticky-actions {
    border: 1px solid rgba(226, 232, 240, 0.92);
    background: rgba(255, 255, 255, 0.95);
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

.turno-new-actions-group {
    width: 100%;
    justify-content: flex-end;
}

.turno-new-actions-group .btn {
    min-width: 170px;
}

.turno-new-mobile-actions {
    display: none;
}

@media (max-width: 960px) {
    .turno-new-page {
        gap: 12px;
    }

    .turno-new-page-create .container.stack {
        padding-bottom: 96px;
    }

    .turno-new-context {
        padding: 12px 14px;
        border-radius: 14px;
    }

    .turno-new-context-title {
        font-size: clamp(22px, 6.4vw, 27px);
        line-height: 1.12;
    }

    .turno-new-context-subinfo {
        font-size: 12.5px;
        max-width: 34ch;
    }

    .turno-new-main-card,
    .turno-new-block {
        border-radius: 14px;
    }

    .turno-new-main-head .card-title,
    .turno-new-block-head .card-title {
        font-size: 16px;
    }

    .turno-new-fields-grid {
        gap: 10px;
    }

    .turno-new-field .control {
        min-height: 36px;
        padding: 7px 10px;
    }

    .turno-new-field textarea.control {
        min-height: 82px;
    }

    .turno-new-sticky-actions-create {
        display: none;
    }

    .turno-new-mobile-actions {
        position: fixed;
        left: 14px;
        right: 14px;
        bottom: calc(72px + env(safe-area-inset-bottom));
        z-index: 42;
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 8px;
        padding: 10px;
        border: 1px solid rgba(226, 232, 240, 0.92);
        border-radius: 14px;
        background: rgba(255, 255, 255, 0.96);
        box-shadow: 0 12px 24px rgba(15, 23, 42, 0.12);
        backdrop-filter: blur(8px);
    }

    .turno-new-mobile-actions .btn {
        min-height: 40px;
        justify-content: center;
    }
}

@media (max-width: 360px) {
    .turno-new-page-create .container.stack {
        padding-bottom: 92px;
    }

    .turno-new-context {
        padding: 11px 12px;
    }

    .turno-new-context-title {
        font-size: 21px;
    }

    .turno-new-context-subinfo {
        font-size: 12px;
    }

    .turno-new-mobile-actions {
        left: 10px;
        right: 10px;
        bottom: calc(68px + env(safe-area-inset-bottom));
        padding: 8px;
        gap: 7px;
    }

    .turno-new-mobile-actions .btn {
        min-height: 38px;
        font-size: 12px;
        padding-inline: 8px;
    }
}

/* ---------- Turno Detail Executive ---------- */

.turno-detail-exec-page {
    gap: 12px;
}

.turno-exec-stack {
    gap: 12px;
}

.turno-exec-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px 14px;
    padding: 14px 16px;
    border: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.995), rgba(248, 250, 252, 0.96));
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

.turno-exec-header-main {
    display: grid;
    gap: 4px;
}

.turno-exec-kicker {
    margin: 0;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #94a3b8;
}

.turno-exec-title {
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(25px, 2.1vw, 31px);
    line-height: 1.08;
    letter-spacing: -0.03em;
    color: #0f172a;
}

.turno-exec-subtitle {
    margin: 0;
    font-size: 13px;
    line-height: 1.42;
    color: #64748b;
    max-width: 58ch;
}

.turno-exec-header-side {
    display: flex;
    align-items: flex-start;
    justify-content: flex-end;
}

.turno-exec-meta-grid {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
}

.turno-exec-meta-item {
    display: grid;
    gap: 3px;
    padding: 9px 10px;
    border: 1px solid rgba(226, 232, 240, 0.95);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.9);
}

.turno-exec-meta-label {
    margin: 0;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #94a3b8;
}

.turno-exec-meta-item strong,
.turno-exec-resumo-item strong,
.turno-exec-detail-cell strong,
.turno-exec-mini-card strong {
    margin: 0;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.45;
    color: #0f172a;
}

.turno-exec-kpi-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 8px;
}

.turno-exec-kpi-card {
    display: grid;
    gap: 2px;
    padding: 10px 11px;
    border: 1px solid rgba(226, 232, 240, 0.96);
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(248, 250, 252, 0.9));
    box-shadow: 0 8px 16px rgba(15, 23, 42, 0.04);
}

.turno-exec-kpi-label {
    margin: 0;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #94a3b8;
}

.turno-exec-kpi-value {
    margin: 0;
    font-size: 26px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.03em;
    color: #0f172a;
}

.turno-exec-section {
    position: relative;
    border: 1px solid rgba(226, 232, 240, 0.95);
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

.turno-exec-section::before {
    content: "";
    position: absolute;
    top: 14px;
    bottom: 14px;
    left: 0;
    width: 3px;
    border-radius: 0 999px 999px 0;
    opacity: 0.9;
}

.turno-exec-section-primary::before {
    background: rgba(37, 99, 235, 0.5);
}

.turno-exec-section-muted::before {
    background: rgba(100, 116, 139, 0.48);
}

.turno-exec-section-warning::before {
    background: rgba(245, 158, 11, 0.56);
}

.turno-exec-section-danger::before {
    background: rgba(239, 68, 68, 0.52);
}

.turno-exec-section-success::before {
    background: rgba(34, 197, 94, 0.5);
}

.turno-exec-section-neutral::before {
    background: rgba(148, 163, 184, 0.45);
}

.turno-exec-section-header {
    margin-bottom: 10px;
}

.turno-exec-section .card-title {
    font-size: 18px;
}

.turno-exec-section .muted {
    max-width: 60ch;
    font-size: 12.5px;
}

.turno-exec-resumo-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
}

.turno-exec-resumo-item {
    display: grid;
    gap: 3px;
    padding: 10px;
    border: 1px solid rgba(226, 232, 240, 0.9);
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(248, 250, 252, 0.88));
}

.turno-exec-inline-cards,
.turno-exec-detail-list {
    display: grid;
    gap: 8px;
}

.turno-exec-mini-card {
    padding: 10px;
    border: 1px solid rgba(226, 232, 240, 0.92);
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.995), rgba(248, 250, 252, 0.92));
    box-shadow: 0 4px 12px rgba(15, 23, 42, 0.04);
}

.turno-exec-inline-cards {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.turno-exec-mini-card strong {
    font-size: 14px;
    line-height: 1.55;
}

.turno-exec-detail-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 9px;
}

.turno-exec-detail-cell {
    display: grid;
    gap: 3px;
}

.turno-exec-detail-cell-span {
    grid-column: span 3;
}

.turno-exec-toolbar {
    border: 1px solid rgba(226, 232, 240, 0.92);
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
}

.turno-exec-btn {
    min-height: 38px;
}

.turno-exec-btn-secondary {
    border-color: rgba(148, 163, 184, 0.38);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(248, 250, 252, 0.9));
    color: #334155;
}

.turno-exec-btn-primary {
    box-shadow: 0 8px 18px rgba(37, 99, 235, 0.25);
}

@media (max-width: 1080px) {
    .turno-exec-meta-grid,
    .turno-exec-resumo-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .turno-exec-kpi-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .turno-exec-detail-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .turno-exec-detail-cell-span {
        grid-column: span 2;
    }
}

@media (max-width: 960px) {
    .turno-exec-stack {
        gap: 10px;
    }

    .turno-exec-header {
        grid-template-columns: 1fr;
        gap: 10px;
        padding: 12px 13px;
        border-radius: 14px;
    }

    .turno-exec-header-side {
        justify-content: flex-start;
    }

    .turno-exec-title {
        font-size: clamp(22px, 6.1vw, 27px);
        line-height: 1.12;
    }

    .turno-exec-subtitle {
        font-size: 12.5px;
        max-width: 36ch;
    }

    .turno-exec-kpi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .turno-exec-kpi-card {
        padding: 9px 10px;
    }

    .turno-exec-kpi-value {
        font-size: 24px;
    }

    .turno-exec-section,
    .turno-exec-mini-card,
    .turno-exec-resumo-item {
        border-radius: 13px;
    }

    .turno-exec-section .card-title {
        font-size: 16px;
    }

    .turno-exec-toolbar {
        gap: 8px;
    }

    .turno-exec-toolbar .toolbar-group {
        width: 100%;
        justify-content: space-between;
        flex-wrap: wrap;
        gap: 8px;
    }

    .turno-exec-toolbar .toolbar-group .btn,
    .turno-exec-toolbar .toolbar-group form {
        flex: 1 1 180px;
    }

    .turno-exec-toolbar .toolbar-group form .btn {
        width: 100%;
    }
}

@media (max-width: 560px) {
    .turno-exec-meta-grid,
    .turno-exec-kpi-grid,
    .turno-exec-resumo-grid,
    .turno-exec-detail-grid,
    .turno-exec-inline-cards {
        grid-template-columns: 1fr;
    }

    .turno-exec-detail-cell-span {
        grid-column: auto;
    }

    .turno-exec-toolbar {
        padding: 10px;
    }

    .turno-exec-btn {
        min-height: 40px;
    }
}
