:root {
    --bg-main: #f4f6fb;
    --bg-card: #ffffff;
    --bg-sidebar: #0f172a;
    --bg-sidebar-soft: #16213a;
    --primary: #1e40af;
    --primary-soft: #dbeafe;
    --accent: #0f766e;
    --text-main: #111827;
    --text-muted: #64748b;
    --border: #d8e0ec;
    --danger: #dc2626;
    --success: #16a34a;
    --warning: #d97706;
    --shadow: 0 14px 35px rgba(15, 23, 42, 0.08);
}

* {
    box-sizing: border-box;
}

html,
body {
    min-height: 100%;
}

body {
    margin: 0;
    background: var(--bg-main);
    color: var(--text-main);
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.btn,
.card,
.form-control,
.form-select,
.modal-content,
.dropdown-menu,
.alert,
.table,
.input-group-text,
.badge {
    border-radius: 0 !important;
}

.btn {
    font-weight: 700;
    min-height: 38px;
    border-width: 1px;
}

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

.btn-primary:hover {
    background: #172554;
    border-color: #172554;
}

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

.btn-outline-primary:hover {
    background: var(--primary);
    border-color: var(--primary);
}

.form-control,
.form-select {
    border: 1px solid var(--border);
    min-height: 40px;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(30, 64, 175, 0.12);
}

.auth-body {
    min-height: 100vh;
    background:
        radial-gradient(circle at 14% 10%, rgba(20, 184, 166, 0.12), transparent 30%),
        radial-gradient(circle at 86% 6%, rgba(30, 64, 175, 0.14), transparent 34%),
        linear-gradient(135deg, #f8fafc 0%, #eef4f8 54%, #f7fafc 100%);
}

.auth-wrapper {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 28px;
}

.auth-shell {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.auth-shell-centered {
    max-width: 520px;
}

.auth-form-panel {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.auth-card {
    width: 100%;
    max-width: 460px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: 0 24px 70px rgba(15, 23, 42, 0.12);
    padding: 34px;
}

.auth-login-card {
    text-align: left;
}

.auth-card.compact {
    text-align: center;
}

.auth-logo-area {
    display: flex;
    justify-content: center;
    margin-bottom: 22px;
}

.auth-form-logo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 178px;
    min-height: 74px;
    padding: 12px 18px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: #ffffff;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08);
    text-decoration: none;
}

.auth-form-logo img {
    display: block;
    max-width: 100%;
    max-height: 48px;
    object-fit: contain;
}

.auth-card-header {
    text-align: center;
    margin-bottom: 24px;
}

.auth-card-header span {
    display: inline-block;
    color: var(--primary);
    font-size: 0.76rem;
    font-weight: 900;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    margin-bottom: 8px;
}

.auth-card-header h1 {
    margin: 0;
    color: var(--text);
    font-size: clamp(1.65rem, 4vw, 2.2rem);
    font-weight: 900;
    letter-spacing: -0.04em;
}

.auth-card-header p {
    margin: 10px 0 0;
    color: var(--text-muted);
}

.auth-control {
    min-height: 46px;
    background: #f8fafc;
    border-color: rgba(15, 23, 42, 0.12);
}

.auth-submit {
    min-height: 48px;
    border: 0;
    font-weight: 900;
    background: var(--primary);
    box-shadow: 0 14px 28px rgba(15, 118, 110, 0.18);
}

.auth-submit:hover,
.auth-submit:focus {
    background: #0f766e;
}

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

.brand-box h1 {
    margin: 0;
    font-size: 1.35rem;
    font-weight: 800;
}

.brand-box p {
    margin: 2px 0 0;
    color: var(--text-muted);
}

.brand-mark {
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
    background: var(--primary);
    color: #ffffff;
    font-weight: 900;
    letter-spacing: -0.05em;
    border: 1px solid rgba(255,255,255,0.3);
}

.hp-field {
    position: absolute !important;
    left: -10000px !important;
    top: auto !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

.auth-link-row {
    text-align: center;
}

.auth-link-row a {
    color: var(--primary);
    font-weight: 800;
    text-decoration: none;
}

.auth-link-row a:hover {
    text-decoration: underline;
}

@media (max-width: 576px) {
    .auth-wrapper {
        padding: 18px;
    }

    .auth-card {
        padding: 26px 20px;
    }

    .auth-form-logo {
        width: 156px;
        min-height: 66px;
    }
}

.demo-access {
    background: #f8fafc;
    border: 1px solid var(--border);
    padding: 12px;
    color: var(--text-muted);
    font-size: 0.85rem;
}

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

.sidebar {
    width: 258px;
    min-height: 100vh;
    background: var(--bg-sidebar);
    color: #ffffff;
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 30;
    border-right: 1px solid rgba(255,255,255,0.08);
}

.sidebar-brand {
    height: 70px;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 0 18px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.sidebar-brand strong {
    display: block;
    line-height: 1.1;
}

.sidebar-brand small {
    display: block;
    color: #94a3b8;
    margin-top: 3px;
}

.sidebar-menu {
    padding: 14px 10px;
}

.menu-link {
    display: flex;
    align-items: center;
    min-height: 42px;
    color: #cbd5e1;
    text-decoration: none;
    padding: 10px 12px;
    margin-bottom: 4px;
    border-left: 3px solid transparent;
    font-weight: 650;
}

.menu-link:hover,
.menu-link.active {
    color: #ffffff;
    background: var(--bg-sidebar-soft);
    border-left-color: #60a5fa;
}

.app-main {
    flex: 1;
    margin-left: 258px;
    min-width: 0;
}

.topbar {
    height: 70px;
    background: #ffffff;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 0 22px;
    position: sticky;
    top: 0;
    z-index: 20;
}

.btn-menu {
    display: none;
}

.topbar-search {
    flex: 1;
    max-width: 520px;
}

.topbar-user {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 12px;
    color: var(--text-muted);
    font-weight: 650;
}

.content-area {
    padding: 22px;
}

.page-head {
    background: #ffffff;
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    padding: 16px;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.compact-head h1 {
    margin: 0;
    font-size: 1.35rem;
    font-weight: 850;
}

.compact-head p {
    margin: 4px 0 0;
    color: var(--text-muted);
}

.head-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

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

.stat-card,
.panel-card,
.module-tile,
.quick-action {
    background: var(--bg-card);
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
}

.stat-card {
    padding: 18px;
    min-height: 112px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.stat-card span {
    color: var(--text-muted);
    font-weight: 700;
    font-size: 0.86rem;
}

.stat-card strong {
    font-size: 1.7rem;
    letter-spacing: -0.04em;
}

.panel-card {
    padding: 16px;
}

.panel-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}

.panel-card-head h2 {
    margin: 0;
    font-size: 1rem;
    font-weight: 800;
}

.table {
    color: var(--text-main);
}

.table thead th {
    background: #f8fafc;
    color: #334155;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-bottom: 1px solid var(--border);
}

.table td,
.table th {
    padding: 12px;
    border-color: var(--border);
}

.status-badge {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 3px 9px;
    font-size: 0.76rem;
    font-weight: 800;
    border: 1px solid var(--border);
    text-transform: capitalize;
}

.status-activo {
    background: #dcfce7;
    color: #166534;
    border-color: #bbf7d0;
}

.status-pendiente {
    background: #fef3c7;
    color: #92400e;
    border-color: #fde68a;
}

.status-suspendido,
.status-cancelado {
    background: #fee2e2;
    color: #991b1b;
    border-color: #fecaca;
}

.quick-actions,
.module-grid {
    display: grid;
    gap: 10px;
}

.quick-action,
.module-tile {
    display: block;
    text-decoration: none;
    color: var(--text-main);
    padding: 14px;
    border-left: 4px solid var(--primary);
}

.quick-action:hover,
.module-tile:hover {
    background: #f8fafc;
    color: var(--primary);
}

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

.module-tile strong,
.module-tile span {
    display: block;
}

.module-tile span {
    color: var(--text-muted);
    margin-top: 4px;
}

.business-state {
    display: grid;
    gap: 12px;
}

.business-state div {
    padding: 12px;
    border: 1px solid var(--border);
    background: #f8fafc;
}

.business-state span,
.business-state strong {
    display: block;
}

.business-state span {
    color: var(--text-muted);
    font-size: 0.85rem;
    font-weight: 700;
}

.business-state strong {
    margin-top: 3px;
}

@media (max-width: 991.98px) {
    .sidebar {
        transform: translateX(-100%);
        transition: transform 0.2s ease;
    }

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

    .app-main {
        margin-left: 0;
    }

    .btn-menu {
        display: inline-flex;
    }

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

@media (max-width: 575.98px) {
    .content-area {
        padding: 14px;
    }

    .page-head {
        align-items: stretch;
        flex-direction: column;
    }

    .head-actions .btn {
        width: 100%;
    }

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

    .topbar {
        padding: 0 14px;
    }

    .topbar-user span {
        display: none;
    }
}

.app-table-wrap {
    border: 1px solid var(--border);
}

.product-cell {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 240px;
}

.product-thumb {
    width: 48px;
    height: 48px;
    flex: 0 0 48px;
    border: 1px solid var(--border);
    background: #f8fafc;
    display: grid;
    place-items: center;
    overflow: hidden;
    font-weight: 850;
    color: var(--primary);
}

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

.product-cell strong,
.product-cell small {
    display: block;
}

.product-cell small {
    color: var(--text-muted);
    margin-top: 3px;
    max-width: 360px;
}

.action-group {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

.pagination-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding-top: 14px;
    color: var(--text-muted);
    font-weight: 700;
}

.product-form-card {
    padding: 16px;
}

.form-section {
    border: 1px solid var(--border);
    background: #ffffff;
    padding: 16px;
}

.form-section h2 {
    margin: 0 0 14px;
    font-size: 1rem;
    font-weight: 850;
}

.check-panel {
    min-height: 40px;
    border: 1px solid var(--border);
    background: #f8fafc;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 12px;
    font-weight: 700;
}

.check-panel input {
    width: 16px;
    height: 16px;
}

.image-preview-box {
    min-height: 210px;
    border: 1px solid var(--border);
    background: #f8fafc;
    display: grid;
    place-items: center;
    color: var(--text-muted);
    font-weight: 750;
    overflow: hidden;
}

.image-preview-box img {
    width: 100%;
    height: 210px;
    object-fit: contain;
    background: #ffffff;
}

.help-text {
    margin: 8px 0 0;
    color: var(--text-muted);
    font-size: 0.85rem;
}

.form-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    border-top: 1px solid var(--border);
    margin-top: 16px;
    padding-top: 16px;
}

@media (max-width: 575.98px) {
    .pagination-bar,
    .form-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .form-actions .btn,
    .pagination-bar .btn {
        width: 100%;
    }
}

.client-cell {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 260px;
}

.client-mark {
    width: 46px;
    height: 46px;
    flex: 0 0 46px;
    border: 1px solid var(--border);
    background: #eff6ff;
    color: var(--primary);
    display: grid;
    place-items: center;
    font-weight: 900;
}

.client-cell strong,
.client-cell small,
.client-meta strong,
.client-meta span {
    display: block;
}

.client-cell small,
.client-meta span {
    color: var(--text-muted);
    margin-top: 3px;
}

.client-meta {
    min-width: 190px;
}

.muted-check {
    background: #f1f5f9;
    color: var(--text-muted);
}

.pos-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 390px;
    gap: 16px;
    align-items: start;
}

.pos-products-panel,
.pos-cart-panel {
    min-width: 0;
}

.pos-cart-panel {
    position: sticky;
    top: 86px;
}

.pos-product-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.pos-product-card {
    background: #ffffff;
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    padding: 12px;
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr) 42px;
    gap: 10px;
    align-items: center;
}

.pos-product-card .btn:not(.btn-icon-only) {
    grid-column: 1 / -1;
}

.pos-product-card.is-disabled {
    opacity: 0.62;
}

.pos-product-thumb {
    width: 72px;
    height: 72px;
    border: 1px solid var(--border);
    background: #f8fafc;
    display: grid;
    place-items: center;
    overflow: hidden;
    font-size: 1.25rem;
    font-weight: 900;
    color: var(--primary);
}

.pos-product-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.pos-product-info {
    min-width: 0;
}

.pos-product-info strong,
.pos-product-info small {
    display: block;
}

.pos-product-info strong {
    font-size: 0.95rem;
    line-height: 1.2;
}

.pos-product-info small {
    color: var(--text-muted);
    margin-top: 4px;
}

.pos-product-meta {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    margin-top: 8px;
    font-size: 0.82rem;
    font-weight: 800;
}

.pos-product-meta span:first-child {
    color: var(--primary);
}

.pos-product-meta span:last-child {
    color: var(--text-muted);
}

.pos-cart-card {
    padding: 14px;
}

.pos-cart-lines {
    display: grid;
    gap: 8px;
    max-height: 360px;
    overflow: auto;
    padding-right: 2px;
}

.empty-cart {
    border: 1px dashed var(--border);
    background: #f8fafc;
    color: var(--text-muted);
    font-weight: 750;
    text-align: center;
    padding: 18px;
}

.pos-cart-line {
    border: 1px solid var(--border);
    background: #ffffff;
    padding: 10px;
    display: grid;
    gap: 8px;
}

.pos-cart-line-info strong,
.pos-cart-line-info small {
    display: block;
}

.pos-cart-line-info small {
    color: var(--text-muted);
    margin-top: 3px;
}

.pos-cart-line-actions {
    display: grid;
    grid-template-columns: 38px minmax(70px, 1fr) 38px auto;
    gap: 6px;
    align-items: center;
}

.pos-cart-line-actions .btn,
.pos-cart-line-actions .form-control {
    min-height: 34px;
}

.pos-totals {
    display: grid;
    gap: 8px;
    border-top: 1px solid var(--border);
    margin-top: 12px;
    padding-top: 12px;
}

.pos-totals > div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.pos-totals span {
    color: var(--text-muted);
    font-weight: 750;
}

.pos-totals strong {
    font-size: 1rem;
}

.pos-totals input {
    max-width: 150px;
    text-align: right;
}

.pos-totals .total-row {
    border-top: 1px solid var(--border);
    padding-top: 10px;
}

.pos-totals .total-row strong {
    font-size: 1.5rem;
    color: var(--primary);
}

.ticket-shell {
    display: flex;
    justify-content: center;
}

.ticket-card {
    width: 100%;
    max-width: 520px;
    background: #ffffff;
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    padding: 18px;
}

.ticket-head {
    text-align: center;
    border-bottom: 1px solid var(--border);
    padding-bottom: 12px;
    margin-bottom: 12px;
}

.ticket-head strong,
.ticket-head span {
    display: block;
}

.ticket-head strong {
    font-size: 1.1rem;
}

.ticket-head span {
    color: var(--text-muted);
    margin-top: 2px;
}

.ticket-info {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 12px;
}

.ticket-info div {
    border: 1px solid var(--border);
    background: #f8fafc;
    padding: 9px;
}

.ticket-info span,
.ticket-info strong {
    display: block;
}

.ticket-info span {
    color: var(--text-muted);
    font-size: 0.78rem;
    font-weight: 800;
}

.ticket-info strong {
    margin-top: 3px;
    font-size: 0.9rem;
}

.ticket-table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 12px;
}

.ticket-table th,
.ticket-table td {
    border-bottom: 1px solid var(--border);
    padding: 8px 4px;
    vertical-align: top;
}

.ticket-table th {
    color: #334155;
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.ticket-totals {
    display: grid;
    gap: 6px;
    margin-top: 12px;
}

.ticket-totals div {
    display: flex;
    justify-content: space-between;
    gap: 10px;
}

.ticket-total {
    border-top: 1px solid var(--border);
    padding-top: 8px;
    font-size: 1.2rem;
}

.ticket-footer {
    margin-top: 14px;
    border-top: 1px solid var(--border);
    padding-top: 12px;
    color: var(--text-muted);
    text-align: center;
    font-weight: 700;
}

@media (max-width: 1199.98px) {
    .pos-layout {
        grid-template-columns: 1fr;
    }

    .pos-cart-panel {
        position: static;
    }
}

@media (max-width: 767.98px) {
    .pos-product-grid {
        grid-template-columns: 1fr;
    }

    .pos-cart-line-actions {
        grid-template-columns: 36px minmax(60px, 1fr) 36px;
    }

    .pos-cart-line-actions [data-pos-remove] {
        grid-column: 1 / -1;
    }

    .ticket-info {
        grid-template-columns: 1fr;
    }
}

@media (min-width: 768px) and (max-width: 1399.98px) {
    .pos-product-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media print {
    body {
        background: #ffffff;
    }

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

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

    .ticket-card {
        box-shadow: none;
        border: none;
        max-width: 80mm;
        padding: 0;
        font-size: 12px;
    }
}

.logo-preview-box {
    min-height: 82px;
    border: 1px dashed var(--border);
    background: #f8fafc;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px;
}

.logo-preview-box img {
    max-width: 180px;
    max-height: 72px;
    object-fit: contain;
}

.logo-preview-box span {
    color: var(--text-muted);
    font-weight: 700;
}

.square-color {
    width: 100%;
    height: 42px;
    padding: 4px;
}

.settings-checks {
    display: grid;
    gap: 8px;
    border: 1px solid var(--border);
    background: #f8fafc;
    padding: 10px;
}

.settings-checks label,
.switch-line {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin: 0;
    color: #334155;
    font-weight: 700;
    font-size: 0.88rem;
}

.switch-line.compact {
    white-space: nowrap;
}

.payment-inline-form {
    display: grid;
    grid-template-columns: minmax(180px, 1fr) auto auto;
    gap: 8px;
    align-items: center;
}

.status-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 82px;
    padding: 5px 9px;
    border: 1px solid transparent;
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.status-badge.ok {
    color: #166534;
    background: #dcfce7;
    border-color: #bbf7d0;
}

.status-badge.off {
    color: #64748b;
    background: #f1f5f9;
    border-color: #e2e8f0;
}

@media (max-width: 767.98px) {
    .payment-inline-form {
        grid-template-columns: 1fr;
    }
}

.topbar-profile {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--text-main);
    text-decoration: none;
    font-weight: 750;
}

.topbar-profile:hover {
    color: var(--primary);
}

.topbar-avatar {
    width: 34px;
    height: 34px;
    flex: 0 0 34px;
    border: 1px solid var(--border);
    background: #eff6ff;
    color: var(--primary);
    display: grid;
    place-items: center;
    font-weight: 900;
    overflow: hidden;
}

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

.profile-summary {
    display: grid;
    justify-items: center;
    text-align: center;
    gap: 8px;
}

.profile-summary strong,
.profile-summary span {
    display: block;
}

.profile-summary strong {
    font-size: 1.08rem;
    font-weight: 850;
}

.profile-summary span {
    color: var(--text-muted);
    font-weight: 700;
    word-break: break-word;
}

.profile-avatar-lg {
    width: 104px;
    height: 104px;
    border: 1px solid var(--border);
    background: #eff6ff;
    color: var(--primary);
    display: grid;
    place-items: center;
    overflow: hidden;
    font-size: 2.2rem;
    font-weight: 950;
}

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

@media (max-width: 575.98px) {
    .topbar-profile > span:last-child {
        display: none;
    }
}

.module-store-summary {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.module-store-head p {
    margin: 4px 0 0;
    color: var(--text-muted);
    font-weight: 650;
    font-size: 0.9rem;
}

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

.store-module-card {
    border: 1px solid var(--border);
    background: #fff;
    padding: 15px;
    display: grid;
    gap: 14px;
    min-height: 245px;
}

.store-module-top,
.store-module-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.store-module-icon {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    background: #eff6ff;
    color: var(--primary);
    border: 1px solid #dbeafe;
    font-weight: 950;
    font-size: 1rem;
}

.store-module-body h3 {
    margin: 0 0 7px;
    font-size: 1.04rem;
    font-weight: 850;
    color: var(--text-main);
}

.store-module-body p {
    margin: 0;
    color: var(--text-muted);
    font-size: 0.9rem;
    line-height: 1.45;
    min-height: 58px;
}

.store-module-meta {
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    padding: 10px 0;
    display: grid;
    gap: 2px;
}

.store-module-meta span {
    font-weight: 900;
    color: var(--text-main);
}

.store-module-meta small {
    color: var(--text-muted);
    font-weight: 700;
}

.status-badge.warning {
    color: #92400e;
    background: #fef3c7;
    border-color: #fde68a;
}

.status-badge.danger {
    color: #991b1b;
    background: #fee2e2;
    border-color: #fecaca;
}

.empty-state.compact-empty {
    padding: 24px;
    border: 1px dashed var(--border);
    background: #f8fafc;
    display: grid;
    gap: 4px;
}

.empty-state.compact-empty strong {
    color: var(--text-main);
    font-weight: 850;
}

.empty-state.compact-empty span {
    color: var(--text-muted);
    font-weight: 650;
}

.state-link {
    color: var(--primary);
    font-weight: 850;
    text-decoration: none;
}

.state-link:hover {
    text-decoration: underline;
}

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

@media (max-width: 767.98px) {
    .module-store-summary,
    .module-store-grid {
        grid-template-columns: 1fr;
    }

    .store-module-body p {
        min-height: auto;
    }
}

.fe-admin-summary .stat-card {
    min-height: 96px;
}

.fe-status-strip {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
}

.fe-status-strip article {
    background: #fff;
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    padding: 14px;
    display: grid;
    gap: 6px;
}

.fe-status-strip span {
    color: var(--text-muted);
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.fe-status-strip strong {
    font-size: 1rem;
    font-weight: 900;
    word-break: break-word;
}

.fe-admin-form .form-label {
    font-weight: 800;
    color: #334155;
    font-size: 0.84rem;
}

.fe-checks {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.action-buttons {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 7px;
}

@media (max-width: 1199.98px) {
    .fe-status-strip {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .fe-status-strip,
    .fe-admin-summary {
        grid-template-columns: 1fr;
    }
}

.fiscal-email-form .form-control,
.fiscal-email-form .btn {
    min-height: 36px;
}

@media print {
    .fiscal-email-form {
        display: none !important;
    }
}

.fiscal-mini-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    width: max-content;
    max-width: 100%;
    padding: 3px 7px;
    border: 1px solid var(--border);
    background: #f8fafc;
    font-size: 0.68rem;
    font-weight: 900;
    line-height: 1.1;
    white-space: nowrap;
}

.fiscal-mini-badge .fiscal-mini-icon {
    width: 16px;
    height: 16px;
    display: inline-grid;
    place-items: center;
    font-size: 0.66rem;
    font-weight: 950;
    line-height: 1;
}

.fiscal-mini-badge.ok {
    border-color: rgba(22, 163, 74, 0.24);
    background: rgba(22, 163, 74, 0.07);
    color: #166534;
}

.fiscal-mini-badge.warn {
    border-color: rgba(217, 119, 6, 0.28);
    background: rgba(217, 119, 6, 0.08);
    color: #92400e;
}

.fiscal-mini-badge.rx {
    border-color: rgba(29, 78, 216, 0.24);
    background: rgba(29, 78, 216, 0.08);
    color: #1e3a8a;
}

.pos-product-card {
    position: relative;
}

.pos-product-card .fiscal-mini-badge {
    position: absolute;
    top: 6px;
    left: 6px;
    margin: 0;
    z-index: 2;
    box-shadow: 0 4px 14px rgba(15, 23, 42, 0.08);
}

.pos-picker-item .fiscal-mini-badge {
    margin-top: 5px;
}

.alert.app-alert-hiding {
    opacity: 0;
    transform: translateY(-4px);
    transition: opacity .24s ease, transform .24s ease;
}

.pos-fiscal-warning {
    margin-top: 8px;
    padding: 8px 10px;
    border: 1px solid var(--border);
    font-size: 0.82rem;
    font-weight: 700;
    line-height: 1.35;
}

.pos-fiscal-warning.is-ok {
    border-color: rgba(22, 163, 74, 0.28);
    background: rgba(22, 163, 74, 0.08);
    color: #166534;
}

.pos-fiscal-warning.is-warning {
    border-color: rgba(217, 119, 6, 0.3);
    background: rgba(217, 119, 6, 0.09);
    color: #92400e;
}

.module-row-title strong,
.module-row-title small {
    display: block;
}

.module-row-title small {
    color: var(--text-muted);
    margin-top: 2px;
    font-size: 0.78rem;
}

.action-inline {
    display: inline-flex;
    justify-content: flex-end;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

.action-inline form {
    margin: 0;
}

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

.square-check {
    border: 1px solid var(--border);
    background: #f8fafc;
    padding: 10px 12px 10px 38px;
    margin: 0;
}

.plan-box {
    border: 1px solid var(--border);
    padding: 12px;
    background: #ffffff;
}

.plan-box .square-check + .square-check {
    margin-top: 8px;
}

.sticky-card {
    position: sticky;
    top: 88px;
}

@media (max-width: 1199.98px) {
    .sticky-card {
        position: static;
    }
}

.detail-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.detail-grid div {
    border: 1px solid var(--border);
    background: #f8fafc;
    padding: 12px;
    min-width: 0;
}

.detail-grid span,
.note-box span {
    display: block;
    color: var(--text-muted);
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 4px;
}

.detail-grid strong {
    display: block;
    font-size: 0.94rem;
    word-break: break-word;
}

.compact-detail-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.included-modules {
    display: grid;
    gap: 8px;
}

.included-modules h3 {
    margin: 0 0 2px;
    font-size: 0.9rem;
    font-weight: 850;
}

.included-module-item {
    border: 1px solid var(--border);
    background: #ffffff;
    padding: 10px 12px;
    display: flex;
    justify-content: space-between;
    gap: 10px;
}

.included-module-item strong {
    font-size: 0.9rem;
}

.included-module-item span {
    color: var(--text-muted);
    font-size: 0.78rem;
    font-weight: 800;
}

.note-box {
    border: 1px solid var(--border);
    background: #f8fafc;
    padding: 12px;
}

.note-box p {
    margin: 0;
    color: var(--text-main);
    line-height: 1.45;
}

.reject-box {
    border-top: 1px solid var(--border);
    padding-top: 14px;
}

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

@media (max-width: 767.98px) {
    .detail-grid,
    .compact-detail-grid {
        grid-template-columns: 1fr;
    }

    .included-module-item {
        display: grid;
    }
}

.section-mini-title {
    margin: 4px 0 0;
    padding: 10px 0 4px;
    font-size: 0.92rem;
    font-weight: 850;
    color: var(--text-main);
    border-bottom: 1px solid var(--border);
}

.fiscal-results {
    display: grid;
    gap: 6px;
}

.fiscal-result-item {
    width: 100%;
    display: block;
    text-align: left;
    background: #ffffff;
    border: 1px solid var(--border);
    padding: 9px 10px;
    color: var(--text-main);
}

.fiscal-result-item:hover {
    border-color: var(--primary);
    background: #f8fafc;
}

.fiscal-result-item strong,
.fiscal-result-item span {
    display: block;
}

.fiscal-result-item span,
.fiscal-result-item.muted {
    color: var(--text-muted);
    font-size: 0.86rem;
}

.sales-summary-panel {
    background: #ffffff;
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    padding: 14px;
    display: grid;
    grid-template-columns: minmax(220px, 0.95fr) minmax(280px, 1fr) minmax(360px, 1.35fr);
    gap: 12px;
    align-items: stretch;
}

.sales-summary-total,
.sales-summary-statuses article,
.sales-summary-kpis article {
    border: 1px solid var(--border);
    background: #f8fafc;
    padding: 12px;
    min-width: 0;
}

.sales-summary-total {
    background: #ffffff;
    display: grid;
    align-content: center;
    gap: 4px;
}

.sales-summary-total span,
.sales-summary-statuses span,
.sales-summary-kpis span {
    color: var(--text-muted);
    font-size: 0.78rem;
    font-weight: 850;
    display: block;
    line-height: 1.25;
}

.sales-summary-total strong {
    display: block;
    font-size: clamp(1.45rem, 2.2vw, 2rem);
    letter-spacing: -0.05em;
    line-height: 1.05;
    white-space: nowrap;
}

.sales-summary-total small {
    color: var(--text-muted);
    font-size: 0.78rem;
    font-weight: 750;
}

.sales-summary-statuses,
.sales-summary-kpis {
    display: grid;
    gap: 8px;
}

.sales-summary-statuses {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.sales-summary-kpis {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.sales-summary-kpis.with-fe {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.sales-summary-statuses article,
.sales-summary-kpis article {
    display: grid;
    align-content: center;
    gap: 6px;
    min-height: 66px;
}

.sales-summary-statuses strong,
.sales-summary-kpis strong {
    font-size: clamp(1.05rem, 1.35vw, 1.35rem);
    letter-spacing: -0.04em;
    line-height: 1.1;
    white-space: nowrap;
}

.pos-toolbar-panel {
    background: #ffffff;
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    padding: 14px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 14px;
    align-items: end;
}

.pos-sale-controls {
    display: grid;
    grid-template-columns: minmax(230px, 1.25fr) minmax(190px, 1fr) minmax(160px, 0.7fr) minmax(150px, 0.7fr);
    gap: 12px;
    align-items: end;
}

.pos-toolbar-actions {
    align-self: end;
    justify-content: flex-end;
}

.pos-discount-box {
    border: 1px solid var(--border);
    background: #f8fafc;
    padding: 10px;
}

.pos-discount-grid {
    display: grid;
    grid-template-columns: minmax(105px, 0.7fr) minmax(0, 1fr);
    gap: 8px;
}

.pos-pay-modal[hidden] {
    display: none;
}

.pos-pay-modal {
    position: fixed;
    inset: 0;
    z-index: 1080;
    display: grid;
    place-items: center;
    padding: 18px;
}

.pos-pay-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.48);
}

.pos-pay-card {
    position: relative;
    width: min(860px, 100%);
    max-height: 92vh;
    overflow: auto;
    background: #ffffff;
    border: 1px solid var(--border);
    box-shadow: 0 24px 80px rgba(15, 23, 42, 0.24);
    padding: 18px;
}

.pos-pay-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border);
}

.pos-pay-head h2 {
    margin: 0 0 4px;
    font-size: 1.2rem;
    font-weight: 850;
}

.pos-pay-head span {
    color: var(--text-muted);
    font-weight: 750;
}

.pos-pay-rows {
    display: grid;
    gap: 10px;
    margin-top: 14px;
}

.pos-pay-row {
    display: grid;
    grid-template-columns: minmax(180px, 1.1fr) minmax(130px, 0.7fr) minmax(130px, 0.7fr) minmax(160px, 0.9fr) auto;
    gap: 10px;
    align-items: end;
    border: 1px solid var(--border);
    background: #f8fafc;
    padding: 12px;
}

.pos-pay-row-action {
    display: grid;
}

.pos-pay-summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.pos-pay-summary div {
    background: #f8fafc;
    border: 1px solid var(--border);
    padding: 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.pos-pay-summary span {
    color: var(--text-muted);
    font-weight: 800;
}

.pos-pay-summary strong {
    font-size: 1.1rem;
}

@media (max-width: 1199.98px) {
    .sales-summary-panel,
    .pos-toolbar-panel,
    .pos-sale-controls {
        grid-template-columns: 1fr 1fr;
    }

    .sales-summary-total {
        grid-column: 1 / -1;
    }

    .sales-summary-kpis {
        grid-column: 1 / -1;
    }
}

@media (max-width: 767.98px) {
    .sales-summary-panel,
    .sales-summary-statuses,
    .sales-summary-kpis,
    .sales-summary-kpis.with-fe,
    .pos-toolbar-panel,
    .pos-sale-controls,
    .pos-pay-summary,
    .pos-pay-row {
        grid-template-columns: 1fr;
    }

    .pos-toolbar-actions {
        justify-content: stretch;
    }

    .pos-toolbar-actions .btn {
        flex: 1 1 auto;
    }
}

@media (max-width: 575.98px) {
    .sales-summary-total strong,
    .sales-summary-statuses strong,
    .sales-summary-kpis strong {
        white-space: normal;
    }
}


.break-code {
    display: block;
    max-width: 100%;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
    line-height: 1.35;
}

.app-modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 1080;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 18px;
    background: rgba(15, 23, 42, 0.46);
}

.app-modal-backdrop.is-open {
    display: flex;
}

.app-modal-card {
    width: min(100%, 430px);
    background: #fff;
    border: 1px solid var(--border);
    box-shadow: 0 24px 70px rgba(15, 23, 42, 0.24);
}

.app-modal-head,
.app-modal-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 16px 18px;
}

.app-modal-head {
    border-bottom: 1px solid var(--border);
}

.app-modal-head h2 {
    margin: 0;
    font-size: 1rem;
    font-weight: 900;
}

.app-modal-close {
    border: 1px solid var(--border);
    background: #fff;
    width: 34px;
    height: 34px;
    font-size: 1.25rem;
    line-height: 1;
}

.app-modal-body {
    padding: 18px;
}

.app-modal-body p {
    margin: 0;
    color: var(--text-muted);
    font-weight: 700;
}

.app-modal-actions {
    border-top: 1px solid var(--border);
    justify-content: flex-end;
}

.payment-total-box {
    display: grid;
    gap: 2px;
    padding: 12px 14px;
    border: 1px solid var(--border);
    background: #f8fafc;
}

.payment-total-box span,
.payment-total-box small {
    color: var(--text-muted);
    font-weight: 700;
}

.payment-total-box strong {
    color: var(--text-main);
    font-size: 1.25rem;
    font-weight: 900;
}

.caja-summary .stat-card strong {
    font-size: 1.15rem;
}

.caja-current-box {
    display: grid;
    gap: .4rem;
    padding: 1rem;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 16px;
    background: #f8fafc;
}

.caja-current-box strong {
    font-size: 1.05rem;
}

.caja-current-box span {
    color: #64748b;
    font-size: .92rem;
}

.caja-totals-list {
    display: grid;
    gap: .55rem;
}

.caja-totals-list > div,
.caja-pos-line {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    flex-wrap: wrap;
}

.caja-totals-list > div {
    padding: .55rem 0;
    border-bottom: 1px solid rgba(15, 23, 42, .08);
}

.caja-totals-list span,
.caja-pos-line span {
    color: #64748b;
}

.caja-totals-list strong {
    color: #0f172a;
}

.caja-totals-list .total-row {
    border-bottom: 0;
    padding-top: .8rem;
}

.caja-pos-card .panel-card-head {
    margin-bottom: .5rem;
}

.caja-pos-line {
    padding-top: .25rem;
}


.report-bar {
    display: block;
    width: 100%;
    height: 7px;
    margin-top: 7px;
    background: #e2e8f0;
    border: 1px solid #d8e0ec;
    overflow: hidden;
}

.report-bar span {
    display: block;
    height: 100%;
    background: var(--primary);
}

@media (max-width: 767.98px) {
    .table td,
    .table th {
        white-space: nowrap;
    }
}

.report-tabs-card {
    padding: 0;
    overflow: hidden;
}

.report-nav-tabs {
    gap: .35rem;
    padding: 1rem 1rem 0;
    border-bottom: 1px solid rgba(15, 23, 42, .08);
    background: #f8fafc;
}

.report-nav-tabs .nav-link {
    border: 1px solid transparent;
    border-radius: 12px 12px 0 0;
    color: #475569;
    font-weight: 800;
}

.report-nav-tabs .nav-link.active {
    color: #0f172a;
    background: #fff;
    border-color: rgba(15, 23, 42, .1) rgba(15, 23, 42, .1) #fff;
}

.report-tab-content {
    padding: 1rem;
}

.report-table-card {
    border: 1px solid rgba(15, 23, 42, .08);
    background: #fff;
    border-radius: 16px;
    padding: 1rem;
    margin-bottom: 1rem;
}

.report-table-head,
.report-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    flex-wrap: wrap;
}

.report-table-head {
    margin-bottom: .8rem;
}

.report-table-head h3 {
    margin: 0;
    color: #0f172a;
    font-size: 1rem;
    font-weight: 900;
}

.report-table-head span,
.report-pagination span {
    color: #64748b;
    font-size: .86rem;
    font-weight: 700;
}

.report-tools {
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 14px;
    background: #f8fafc;
    padding: .75rem .9rem;
    margin-bottom: .9rem;
}

.report-tools summary {
    color: #334155;
    cursor: pointer;
    font-weight: 900;
}

.report-tools-grid {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) 180px;
    gap: .75rem;
    margin-top: .75rem;
}

.report-table-wrap {
    max-height: 620px;
}

.report-table-wrap thead th {
    position: sticky;
    top: 0;
    z-index: 2;
    background: #f1f5f9;
}

.report-pagination {
    padding-top: .85rem;
}

@media (max-width: 767.98px) {
    .report-tab-content,
    .report-nav-tabs {
        padding-left: .75rem;
        padding-right: .75rem;
    }

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

.inline-details{position:relative;display:inline-block;text-align:left}.inline-details>summary{list-style:none;cursor:pointer}.inline-details>summary::-webkit-details-marker{display:none}.inventory-mini-form{position:absolute;right:0;top:34px;z-index:20;width:320px;max-width:calc(100vw - 32px);padding:14px;background:#fff;border:1px solid rgba(15,23,42,.12);border-radius:18px;box-shadow:0 18px 45px rgba(15,23,42,.18)}.inventory-mini-form label{font-size:.78rem;font-weight:700;color:#475569;margin-top:8px}.nested-card{box-shadow:none;border:1px solid rgba(15,23,42,.08)}.inventory-tabs-card .tab-pane{padding-top:18px}@media(max-width:768px){.inventory-mini-form{position:fixed;left:12px;right:12px;top:80px;width:auto;max-height:80vh;overflow:auto}}

.inline-details[open] .inventory-mini-form{
    position:fixed;
    top:96px;
    right:24px;
    z-index:1085;
    max-height:calc(100vh - 124px);
    overflow:auto;
}
.inline-details[open] summary{position:relative;z-index:1086}.inventory-tabs-card{overflow:visible}.inventory-tabs-card .app-table-wrap{overflow-x:auto;overflow-y:visible}.inventory-mini-form::before{content:'Ajuste de producto';display:block;font-weight:800;color:#0f172a;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid rgba(15,23,42,.08)}
@media(max-width:768px){.inline-details[open] .inventory-mini-form{left:12px;right:12px;top:76px;width:auto;max-height:calc(100vh - 96px)}}

.inventory-detail-box{
    min-width:280px;
    max-width:420px;
    padding:12px;
    margin-top:8px;
    border:1px solid rgba(15,23,42,.10);
    border-radius:14px;
    background:#fff;
    box-shadow:0 16px 35px rgba(15,23,42,.14);
}
.inventory-detail-box strong{
    display:block;
    color:#0f172a;
    font-size:.78rem;
    font-weight:900;
    margin-top:6px;
}
.inventory-detail-box p{
    margin:2px 0 6px;
    color:#475569;
    font-size:.84rem;
}

/* Hotelería */
.hotel-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:16px;align-items:start}.hotel-main-card,.hotel-side-card{min-width:0}.hotel-head-actions{align-items:flex-start;gap:14px}.hotel-filter-form{display:grid;grid-template-columns:minmax(160px,1fr) 150px 170px auto;gap:8px;align-items:end}.hotel-room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.hotel-room-card{background:#fff;border:1px solid var(--border);padding:14px;box-shadow:0 8px 22px rgba(15,23,42,.05);border-left:5px solid var(--border)}.hotel-room-card.status-disponible{border-left-color:#16a34a}.hotel-room-card.status-ocupada{border-left-color:#d97706}.hotel-room-card.status-reservada{border-left-color:#2563eb}.hotel-room-card.status-mantenimiento,.hotel-room-card.status-bloqueada{border-left-color:#64748b}.hotel-room-top{display:flex;justify-content:space-between;gap:10px;align-items:start}.hotel-room-top span,.hotel-room-card p,.hotel-room-card small,.hotel-calendar-list small{color:var(--text-muted)}.hotel-room-top strong{font-size:1.55rem;display:block;line-height:1}.hotel-room-card h3{font-size:1rem;margin:12px 0 4px}.hotel-inline-status{display:grid;grid-template-columns:1fr auto;gap:8px}.hotel-calendar-list{display:grid;gap:10px}.hotel-calendar-list article{border:1px solid var(--border);background:#f8fafc;padding:10px}.hotel-calendar-list span{font-weight:800;color:var(--primary);font-size:.82rem}.hotel-calendar-list strong{display:block;margin-top:2px}.hotel-actions-cell{white-space:nowrap}.hotel-modal{position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:200;display:none;align-items:flex-start;justify-content:center;padding:24px;overflow:auto}.hotel-modal.open{display:flex}.hotel-modal-box{position:relative;background:#fff;border:1px solid var(--border);box-shadow:0 24px 60px rgba(15,23,42,.28);width:min(760px,100%);padding:20px}.hotel-modal-lg{width:min(980px,100%)}.hotel-modal-box h3{margin:0 0 16px;font-size:1.2rem;font-weight:900}.hotel-modal-close{position:absolute;top:10px;right:10px;width:34px;height:34px;border:1px solid var(--border);background:#fff;font-weight:900}.grid-span-2{grid-column:1/-1}.status-badge.info{background:#dbeafe;color:#1d4ed8}.status-badge.muted{background:#e2e8f0;color:#334155}@media(max-width:1100px){.hotel-layout{grid-template-columns:1fr}.hotel-filter-form{grid-template-columns:1fr 1fr}}@media(max-width:700px){.hotel-filter-form{grid-template-columns:1fr}.hotel-modal{padding:10px}.hotel-actions-cell{white-space:normal}.hotel-inline-status{grid-template-columns:1fr}}

/* Hotelería ajustes profesionales */
.hotel-modal-xl{width:min(1180px,100%)}
.hotel-form-pro{display:grid;gap:14px}
.hotel-form-section{border:1px solid var(--border);background:#f8fafc;padding:14px;margin:0}
.hotel-form-section legend{float:none;width:auto;margin:0 0 10px;padding:0 6px;font-size:.86rem;font-weight:900;color:var(--text-main)}
.hotel-form-actions{display:flex;justify-content:flex-end;gap:8px}
.hotel-check{display:flex;align-items:center;min-height:38px;margin-top:26px}
.hotel-search-results{display:grid;gap:6px;margin-top:8px;max-height:190px;overflow:auto}
.hotel-search-item{width:100%;border:1px solid var(--border);background:#fff;text-align:left;padding:8px 10px;font-weight:700;color:var(--text-main)}
.hotel-search-item:hover{background:#eef6ff;border-color:var(--primary)}
.hotel-room-image{height:128px;margin:-14px -14px 12px;overflow:hidden;border-bottom:1px solid var(--border);background:#f1f5f9}
.hotel-room-image img{width:100%;height:100%;object-fit:cover;display:block}
.hotel-block-note{display:block;margin-top:6px;font-weight:800;color:#92400e!important}
.hotel-inline-status{grid-template-columns:1fr 1fr 1fr auto}
.hotel-inline-status .form-control-sm,.hotel-inline-status .form-select-sm{min-width:0}
@media(max-width:900px){.hotel-inline-status{grid-template-columns:1fr}.hotel-form-actions{justify-content:stretch}.hotel-form-actions .btn{width:100%}.hotel-check{margin-top:0}}

/* Hotelería ajuste visual v30 */
.hotel-layout-wide{grid-template-columns:1fr}
.hotel-room-grid{grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:16px}
.hotel-room-card{padding:16px;min-height:260px}
.hotel-room-image{height:150px;margin:-16px -16px 14px}
.hotel-room-meta{display:grid;grid-template-columns:1fr 1fr;gap:8px 10px;margin-top:10px;padding:10px;background:#f8fafc;border:1px solid var(--border)}
.hotel-room-meta span{display:block;color:var(--text-muted);font-size:.82rem;line-height:1.25}
.hotel-room-meta b{display:block;color:var(--text-main);font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}
.hotel-inline-status{grid-template-columns:1fr 1fr;gap:10px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.hotel-mini-field{display:grid;gap:4px;margin:0;min-width:0}
.hotel-mini-field span{font-size:.72rem;font-weight:900;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}
.hotel-mini-field-wide{grid-column:1/-1}
.hotel-inline-status .btn{grid-column:1/-1;width:100%}
.hotel-form-pro .form-grid-compact{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px 12px;align-items:start}
.hotel-form-pro .grid-span-2{grid-column:span 2}
.hotel-form-pro .grid-span-full{grid-column:1/-1}
.hotel-form-pro .form-label{font-size:.8rem;font-weight:800;color:var(--text-main);margin-bottom:4px}
.hotel-form-pro .form-control,.hotel-form-pro .form-select{min-height:38px}
.hotel-form-section{padding:12px 14px}
.hotel-form-section legend{margin-bottom:8px}
.hotel-modal-box{max-height:calc(100vh - 48px);overflow:auto}
.hotel-modal-xl{width:min(1120px,100%)}
.hotel-calendar-panel{padding:0;overflow:hidden}
.hotel-calendar-summary{display:flex;justify-content:space-between;align-items:center;gap:12px;cursor:pointer;padding:16px 18px;border-bottom:1px solid var(--border);font-weight:900;color:var(--text-main)}
.hotel-calendar-summary strong{color:var(--primary);font-size:.9rem}
.hotel-month-calendar{padding:16px 18px;background:#fff}
.hotel-weekdays,.hotel-calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}
.hotel-weekdays{margin-bottom:8px}
.hotel-weekdays span{font-size:.76rem;font-weight:900;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;text-align:center}
.hotel-calendar-day{min-height:118px;border:1px solid var(--border);background:#f8fafc;padding:8px;display:grid;grid-template-rows:auto 1fr;gap:6px;min-width:0}
.hotel-calendar-day.is-empty{background:transparent;border-color:transparent}
.hotel-calendar-date{font-weight:900;color:var(--text-main);font-size:.86rem}
.hotel-calendar-tags{display:grid;gap:5px;align-content:start;overflow:auto;max-height:86px}
.hotel-calendar-tag{border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;text-align:left;font-size:.72rem;font-weight:900;line-height:1.15;padding:5px 6px;white-space:normal}
.hotel-calendar-tag.status-checkin{border-color:#fde68a;background:#fffbeb;color:#92400e}
.hotel-calendar-tag:hover{filter:brightness(.97)}
.hotel-calendar-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.hotel-calendar-detail-grid div{border:1px solid var(--border);background:#f8fafc;padding:10px}
.hotel-calendar-detail-grid span{display:block;color:var(--text-muted);font-size:.75rem;font-weight:900;text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}
.hotel-calendar-detail-grid strong{display:block;color:var(--text-main);font-size:.92rem}
@media(max-width:1100px){.hotel-form-pro .form-grid-compact{grid-template-columns:repeat(2,minmax(0,1fr))}.hotel-weekdays,.hotel-calendar-grid{gap:6px}.hotel-calendar-day{min-height:105px}}
@media(max-width:700px){.hotel-room-grid{grid-template-columns:1fr}.hotel-room-meta{grid-template-columns:1fr}.hotel-form-pro .form-grid-compact{grid-template-columns:1fr}.hotel-form-pro .grid-span-2{grid-column:1/-1}.hotel-weekdays{display:none}.hotel-calendar-grid{grid-template-columns:1fr}.hotel-calendar-day.is-empty{display:none}.hotel-calendar-day{min-height:auto}.hotel-calendar-tags{max-height:none}.hotel-calendar-detail-grid{grid-template-columns:1fr}}

/* Hotelería reserva estado v35 */
.hotel-radio-group{display:flex;flex-wrap:wrap;gap:8px 14px;align-items:center;border:1px solid var(--border);background:#fff;padding:9px 11px;min-height:38px}
.hotel-radio-group label{display:inline-flex;align-items:center;gap:6px;margin:0;font-size:.84rem;font-weight:800;color:var(--text-main)}
.hotel-radio-group input{margin:0}
.hotel-room-select-notice{font-weight:800;color:#92400e!important}

/* Hotelería UI v36 */
.hotel-layout-wide{grid-template-columns:1fr!important}.hotel-main-card{overflow:visible}.hotel-room-grid{display:flex!important;flex-wrap:wrap;gap:16px;align-items:flex-start;justify-content:flex-start}.hotel-room-card{width:290px!important;max-width:100%;min-height:auto!important;padding:14px!important;border:1px solid var(--border);border-left-width:5px;background:#fff}.hotel-room-image{height:118px;margin:-14px -14px 12px}.hotel-room-top strong{font-size:1.45rem}.hotel-room-card h3{margin:10px 0 0;font-size:.96rem;line-height:1.25}.hotel-room-details{margin-top:10px;border-top:1px solid var(--border);padding-top:8px}.hotel-room-details summary{cursor:pointer;font-size:.78rem;font-weight:900;color:var(--primary);list-style:none}.hotel-room-details summary::-webkit-details-marker{display:none}.hotel-room-details summary::after{content:'+';float:right;font-size:1rem}.hotel-room-details[open] summary::after{content:'−'}.hotel-room-meta{grid-template-columns:1fr!important;margin-top:8px;padding:8px}.hotel-inline-status{grid-template-columns:1fr!important;gap:8px!important;margin-top:8px!important;padding-top:8px!important}.hotel-inline-status .btn{width:100%}.hotel-reservations-card{overflow:visible}.hotel-filter-accordion{border:1px solid var(--border);background:#f8fafc;padding:0}.hotel-filter-accordion>summary{cursor:pointer;padding:10px 12px;font-size:.86rem;font-weight:900;color:var(--text-main);list-style:none}.hotel-filter-accordion>summary::-webkit-details-marker{display:none}.hotel-filter-accordion>summary::after{content:'+';float:right}.hotel-filter-accordion[open]>summary::after{content:'−'}.hotel-reservation-filter-grid{display:grid;grid-template-columns:minmax(220px,1fr) 180px auto;gap:10px;align-items:end;padding:0 12px 12px}.hotel-filter-buttons{display:flex;gap:8px;flex-wrap:wrap}.hotel-count-pill{display:inline-flex;align-items:center;padding:6px 10px;border:1px solid var(--border);background:#f8fafc;font-size:.8rem;font-weight:900;color:var(--text-muted)}.hotel-reservations-table{max-height:none}.hotel-actions-cell{white-space:normal!important;min-width:240px}.hotel-actions-grid{display:grid;grid-template-columns:repeat(2,minmax(92px,1fr));gap:6px;justify-content:end}.hotel-actions-grid .btn,.hotel-actions-grid form{width:100%}.hotel-actions-grid .btn{display:block;width:100%;white-space:nowrap}.hotel-pagination{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;padding-top:10px;border-top:1px solid var(--border)}.hotel-pagination span{font-size:.84rem;font-weight:800;color:var(--text-muted)}.hotel-pagination div{display:flex;gap:8px}.hotel-calendar-panel{padding:0;overflow:hidden}.hotel-calendar-summary{border-bottom:1px solid var(--border)}.hotel-calendar-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;padding:12px 18px;background:#f8fafc;border-bottom:1px solid var(--border)}.hotel-calendar-month-form{display:flex;align-items:center;gap:8px}.hotel-calendar-month-form label{font-size:.78rem;font-weight:900;color:var(--text-muted);margin:0}.hotel-calendar-month-form select{height:32px;border:1px solid var(--border);background:#fff;padding:0 8px}.hotel-calendar-empty{border:1px dashed var(--border);background:#f8fafc;padding:12px;margin-bottom:12px;color:var(--text-muted);font-weight:800}.hotel-charge-form{display:block}.hotel-mini-pos{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:12px}.hotel-mini-pos-products{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px;max-height:320px;overflow:auto;padding-right:4px}.hotel-pos-product{border:1px solid var(--border);background:#fff;text-align:left;padding:10px;display:grid;gap:3px}.hotel-pos-product strong{font-size:.82rem;color:var(--text-main);line-height:1.2}.hotel-pos-product span{font-size:.78rem;color:var(--primary);font-weight:900}.hotel-pos-product:hover{background:#eef6ff;border-color:var(--primary)}.hotel-mini-pos-cart{border:1px solid var(--border);background:#fff;padding:10px}.hotel-mini-pos-head{display:flex;justify-content:space-between;gap:8px;align-items:center;margin-bottom:8px}.hotel-pos-lines{display:grid;gap:8px;max-height:300px;overflow:auto}.hotel-pos-line{display:grid;grid-template-columns:minmax(0,1fr) 80px 74px auto;gap:6px;align-items:center;border:1px solid var(--border);background:#f8fafc;padding:8px}.hotel-pos-line strong{font-size:.8rem;line-height:1.2}.hotel-pos-line span{font-size:.78rem;font-weight:900;color:var(--primary)}.hotel-pos-line:has(select){grid-template-columns:minmax(120px,1.2fr) 100px 76px 92px auto}@media(max-width:1000px){.hotel-reservation-filter-grid{grid-template-columns:1fr 1fr}.hotel-filter-buttons{grid-column:1/-1}.hotel-mini-pos{grid-template-columns:1fr}.hotel-mini-pos-cart{order:-1}}@media(max-width:700px){.hotel-room-card{width:100%!important}.hotel-room-grid{display:grid!important;grid-template-columns:1fr}.hotel-actions-grid{grid-template-columns:1fr}.hotel-reservation-filter-grid{grid-template-columns:1fr}.hotel-calendar-toolbar{align-items:stretch}.hotel-calendar-toolbar .btn,.hotel-calendar-month-form,.hotel-calendar-month-form select{width:100%}.hotel-pos-line,.hotel-pos-line:has(select){grid-template-columns:1fr}.hotel-pos-line .btn{width:100%}}

/* Hotelería v37 - cargo por mini POS agregado al hospedaje */
.hotel-mini-pos-main{
  grid-template-columns:minmax(0,1fr) 360px!important;
  align-items:start;
}
.hotel-mini-pos-products-panel,
.hotel-mini-pos-cart{
  border:1px solid var(--border);
  background:#fff;
  padding:12px;
}
.hotel-mini-pos-head-stack{
  align-items:stretch!important;
  flex-direction:column;
}
.hotel-mini-pos-head small{display:block;color:var(--text-muted);font-size:.75rem;font-weight:700;margin-top:2px}
.hotel-mini-pos-products{
  grid-template-columns:repeat(auto-fill,minmax(170px,1fr))!important;
  gap:10px!important;
  max-height:390px!important;
}
.hotel-pos-product{
  min-height:92px;
  border:1px solid var(--border)!important;
  background:#fff!important;
  padding:12px!important;
  display:flex!important;
  flex-direction:column;
  justify-content:space-between;
  transition:.15s ease;
}
.hotel-pos-product:hover{transform:translateY(-1px);box-shadow:0 10px 20px rgba(15,23,42,.08);background:#f8fbff!important}
.hotel-pos-product-title{font-size:.84rem;font-weight:900;color:var(--text-main);line-height:1.25}
.hotel-pos-product strong{font-size:.92rem;color:var(--primary)}
.hotel-pos-product small{font-size:.72rem;color:var(--text-muted);font-weight:800;text-transform:uppercase;letter-spacing:.03em}
.hotel-mini-pos-cart{position:sticky;top:10px}
.hotel-pos-empty{border:1px dashed var(--border);background:#f8fafc;padding:16px;text-align:center;color:var(--text-muted);font-size:.82rem;font-weight:800}
.hotel-pos-lines{gap:10px!important;max-height:360px!important}
.hotel-pos-line{
  grid-template-columns:minmax(0,1fr) 82px 88px auto!important;
  background:#f8fafc!important;
  border:1px solid var(--border)!important;
  padding:10px!important;
}
.hotel-pos-line:has(select){grid-template-columns:minmax(0,1.3fr) 96px 74px 92px auto!important}
.hotel-pos-line-info{min-width:0;display:grid;gap:3px}
.hotel-pos-line-info strong{font-size:.84rem;line-height:1.2;color:var(--text-main)}
.hotel-pos-line-info small{font-size:.76rem;font-weight:900;color:var(--primary)}
.hotel-pos-line label{display:grid;gap:3px;margin:0}
.hotel-pos-line label span{font-size:.68rem;font-weight:900;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}
.hotel-pos-line-total{font-size:.8rem;font-weight:900;color:var(--primary);text-align:right}
.hotel-pos-cart-actions{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.hotel-pos-cart-actions strong{font-size:1rem;color:var(--primary)}
@media(max-width:1000px){.hotel-mini-pos-main{grid-template-columns:1fr!important}.hotel-mini-pos-cart{position:static;order:-1}}
@media(max-width:700px){.hotel-pos-line,.hotel-pos-line:has(select){grid-template-columns:1fr!important}.hotel-pos-line-total{text-align:left}.hotel-mini-pos-products{grid-template-columns:1fr!important}}

/* Hotelería v38: mini POS de cargos */
.hotel-mini-pos-head small{max-width:520px}
.hotel-pos-line.hotel-pos-manual-line{grid-template-columns:minmax(180px,1.4fr) 84px 104px 96px auto!important}
.hotel-pos-line.hotel-pos-manual-line .hotel-pos-line-info{gap:6px}
.hotel-pos-line.hotel-pos-manual-line .hotel-pos-line-info strong{color:var(--text-main);font-size:.78rem;text-transform:uppercase;letter-spacing:.03em}
.hotel-pos-line.hotel-pos-manual-line input[name="manual_descripcion[]"]{min-width:180px}
.hotel-pos-line.hotel-pos-manual-line .hotel-pos-line-total{align-self:end;padding-bottom:8px}
.hotel-pos-product small{color:var(--text-muted);font-weight:800}
@media(max-width:700px){.hotel-pos-line.hotel-pos-manual-line{grid-template-columns:1fr!important}.hotel-pos-line.hotel-pos-manual-line .hotel-pos-line-total{align-self:auto;padding-bottom:0;text-align:left}}


/* POS cantidades por unidad */
.pos-cart-line-actions input[data-pos-qty]{min-width:82px;text-align:center;font-weight:800}

/* Salón */
.salon-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:16px;align-items:start}.salon-main-card,.salon-calendar-card{overflow:visible}.salon-month-form{display:flex;gap:8px;align-items:center}.salon-service-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.salon-service-card{border:1px solid var(--border);background:#fff;padding:14px;display:grid;gap:4px}.salon-service-card strong{font-size:.98rem}.salon-service-card span,.salon-service-card small{color:var(--text-muted);font-size:.82rem}.salon-service-card b{color:var(--primary)}.salon-inline-form{display:grid;grid-template-columns:minmax(110px,1fr) auto;gap:6px}.salon-action-cell{min-width:230px}.salon-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.salon-cal-head{font-size:.75rem;font-weight:900;color:var(--text-muted);text-align:center}.salon-cal-day{min-height:76px;border:1px solid var(--border);background:#fff;padding:5px;display:grid;align-content:start;gap:4px}.salon-cal-day.muted{background:#f8fafc}.salon-cal-day strong{font-size:.8rem}.salon-cal-event{border:1px solid rgba(29,78,216,.22);background:#eef6ff;color:var(--primary);font-size:.72rem;font-weight:900;padding:3px 4px;text-align:left}.salon-modal{position:fixed;inset:0;z-index:2000;background:rgba(15,23,42,.58);display:flex;align-items:flex-start;justify-content:center;padding:24px;overflow:auto}.salon-modal[hidden]{display:none}.salon-modal-card{background:#fff;border:1px solid var(--border);box-shadow:0 20px 60px rgba(15,23,42,.24);width:min(760px,100%);padding:18px;position:relative}.salon-modal-card.wide{width:min(1040px,100%)}.salon-modal-card h2{font-size:1.1rem;margin-bottom:14px}.salon-product-picker{display:grid;grid-template-columns:minmax(0,1fr) 110px auto;gap:8px;align-items:end}.salon-products-list{display:grid;gap:6px;margin-top:10px}.salon-line{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:8px;align-items:center;border:1px solid var(--border);background:#f8fafc;padding:8px}.salon-line strong{font-size:.86rem}.salon-line span{font-size:.78rem;color:var(--text-muted);font-weight:800}@media(max-width:1100px){.salon-layout{grid-template-columns:1fr}.salon-calendar-card{order:2}}@media(max-width:720px){.salon-product-picker,.salon-line,.salon-inline-form{grid-template-columns:1fr}.salon-calendar-grid{grid-template-columns:repeat(2,1fr)}.salon-cal-head{display:none}.salon-modal{padding:10px}.salon-action-cell{min-width:170px}}


/* POS ajustes v42 */
.pos-scale-control small{display:block;margin-top:3px;color:var(--text-muted);font-size:.74rem;font-weight:700}.pos-qty-input{text-align:center;min-width:82px}.pos-cart-line-actions{align-items:center}.pos-cart-line-actions .btn{min-width:34px}.caja-pos-card{display:none!important}
@media(max-width:720px){.pos-qty-input{min-width:100%}.pos-cart-line-actions{grid-template-columns:auto minmax(82px,1fr) auto auto}}

/* Salón UI v42 */
.salon-head{border:1px solid var(--border);background:linear-gradient(135deg,#fff 0%,#f8fbff 100%);box-shadow:0 12px 28px rgba(15,23,42,.05)}
.salon-kpis{grid-template-columns:repeat(4,minmax(160px,1fr));gap:14px}.salon-kpis .stat-card{border-left:4px solid var(--primary);box-shadow:0 10px 28px rgba(15,23,42,.055)}
.salon-workspace{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);gap:16px;align-items:start}.salon-soft-card,.salon-main-card{border:1px solid var(--border);box-shadow:0 14px 34px rgba(15,23,42,.06);background:#fff}.salon-main-card .panel-card-head,.salon-soft-card .panel-card-head{border-bottom:1px solid var(--border);padding-bottom:12px}.salon-main-card .panel-table th{font-size:.74rem;letter-spacing:.06em;color:#334155}.salon-main-card .panel-table td{vertical-align:middle}.salon-month-form{background:#f8fafc;border:1px solid var(--border);padding:6px;display:flex;gap:6px}.salon-action-cell{min-width:250px}.salon-inline-form{display:grid;grid-template-columns:minmax(115px,1fr) auto;gap:6px;align-items:center}.salon-service-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.salon-service-card{border:1px solid var(--border);background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);padding:14px;display:grid;gap:6px;border-left:4px solid var(--primary);box-shadow:0 10px 24px rgba(15,23,42,.05)}.salon-service-card strong{font-size:1rem}.salon-service-card span,.salon-service-card small{color:var(--text-muted);font-size:.82rem}.salon-service-card b{color:var(--primary);font-size:1.05rem}.salon-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}.salon-cal-head{font-size:.72rem;font-weight:900;color:var(--text-muted);text-align:center;text-transform:uppercase}.salon-cal-day{min-height:84px;border:1px solid var(--border);background:#fff;padding:6px;display:grid;align-content:start;gap:4px}.salon-cal-day.muted{background:#f8fafc}.salon-cal-day strong{font-size:.8rem}.salon-cal-event{border:1px solid rgba(29,78,216,.22);background:#eef6ff;color:var(--primary);font-size:.72rem;font-weight:900;padding:4px 5px;text-align:left}.salon-modal{position:fixed;inset:0;z-index:2000;background:rgba(15,23,42,.58);display:flex;align-items:flex-start;justify-content:center;padding:24px;overflow:auto}.salon-modal[hidden]{display:none}.salon-modal-card{background:#fff;border:1px solid var(--border);box-shadow:0 24px 70px rgba(15,23,42,.26);width:min(780px,100%);padding:20px;position:relative}.salon-modal-card.wide{width:min(1080px,100%)}.salon-modal-card h2{font-size:1.15rem;margin:0}.salon-modal-subtitle{margin:4px 0 16px;color:var(--text-muted);font-size:.88rem}.salon-form-section{border:1px solid var(--border);background:#fbfdff;padding:14px;margin-bottom:12px}.salon-form-section h3{font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:#334155;margin:0 0 12px}.salon-product-picker{display:grid;grid-template-columns:minmax(0,1fr) 110px auto;gap:8px;align-items:end}.salon-products-list{display:grid;gap:7px;margin-top:10px}.salon-line{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:8px;align-items:center;border:1px solid var(--border);background:#fff;padding:9px}.salon-line strong{font-size:.88rem}.salon-line span{font-size:.78rem;color:var(--text-muted);font-weight:800}
@media(max-width:1100px){.salon-workspace{grid-template-columns:1fr}.salon-calendar-card{order:2}.salon-kpis{grid-template-columns:repeat(2,minmax(160px,1fr))}}
@media(max-width:720px){.salon-kpis{grid-template-columns:1fr}.salon-product-picker,.salon-line,.salon-inline-form{grid-template-columns:1fr}.salon-calendar-grid{grid-template-columns:repeat(2,1fr)}.salon-cal-head{display:none}.salon-modal{padding:10px}.salon-action-cell{min-width:180px}.salon-form-section{padding:10px}}

/* Salón v45 · formularios compactos y modales pulidos */
.salon-modal{z-index:2600;background:rgba(15,23,42,.62);padding:18px;align-items:flex-start;}
.salon-modal-card{width:min(780px,calc(100vw - 36px));max-height:calc(100vh - 36px);overflow:auto;padding:0!important;background:#fff;border:1px solid #cbd5e1;box-shadow:0 26px 80px rgba(15,23,42,.32);}
.salon-modal-card.wide{width:min(1040px,calc(100vw - 36px));}
.salon-modal-card>.modal-close{position:absolute;top:14px;right:14px;z-index:3;width:36px;height:36px;display:grid;place-items:center;border:1px solid #cbd5e1;background:#fff;color:#0f172a;font-size:1.15rem;line-height:1;font-weight:900;cursor:pointer;box-shadow:0 8px 20px rgba(15,23,42,.08);}
.salon-modal-card>.modal-close:hover{background:#eff6ff;border-color:#1e40af;color:#1e40af;}
.salon-modal-card>h2{margin:0!important;padding:18px 64px 4px 20px;font-size:1.15rem;font-weight:900;color:#0f172a;background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);}
.salon-modal-card>.salon-modal-subtitle{margin:0!important;padding:0 64px 16px 20px;color:#64748b;font-size:.88rem;background:#f8fafc;border-bottom:1px solid #d8e0ec;}
.salon-modal-card>form{padding:16px 20px 20px;display:grid;gap:12px;background:#fff;}
.salon-modal-card .salon-form-section{margin:0!important;padding:14px!important;border:1px solid #d8e0ec;background:#fbfdff;box-shadow:0 8px 20px rgba(15,23,42,.035);}
.salon-modal-card .salon-form-section h3{margin:0 0 12px!important;padding-bottom:8px;border-bottom:1px dashed #cbd5e1;font-size:.78rem;text-transform:uppercase;letter-spacing:.07em;color:#334155;font-weight:900;}
.salon-modal-card .row{display:grid!important;grid-template-columns:repeat(12,minmax(0,1fr));gap:12px;margin:0!important;}
.salon-modal-card .row>[class*="col"]{padding:0!important;width:auto!important;max-width:none!important;min-width:0;}
.salon-modal-card .col-md-2{grid-column:span 2;}.salon-modal-card .col-md-3{grid-column:span 3;}.salon-modal-card .col-md-4{grid-column:span 4;}.salon-modal-card .col-md-5{grid-column:span 5;}.salon-modal-card .col-md-6{grid-column:span 6;}.salon-modal-card .col-md-7{grid-column:span 7;}.salon-modal-card .col-12{grid-column:1/-1;}
.salon-modal-card .form-label{display:block;margin:0 0 6px!important;font-size:.78rem;color:#334155;font-weight:800;}
.salon-modal-card .form-control,.salon-modal-card .form-select{width:100%;min-height:40px;height:40px;border:1px solid #d8e0ec;background:#fff;color:#0f172a;font-size:.92rem;padding:.47rem .7rem;}
.salon-modal-card input[type="datetime-local"].form-control{padding-right:.45rem;}
.salon-modal-card .form-control:focus,.salon-modal-card .form-select:focus{border-color:#1e40af;box-shadow:0 0 0 3px rgba(30,64,175,.12);outline:0;}
.salon-modal-card .check-panel{min-height:40px;display:flex;align-items:center;gap:8px;border:1px solid #d8e0ec;background:#fff;padding:8px 10px;font-weight:800;color:#334155;}
.salon-modal-card .d-grid{display:grid!important;}
.salon-modal-card>form>.d-grid{margin-top:0!important;}
.salon-modal-card>form>.d-grid .btn{min-height:42px;font-weight:900;}
.salon-product-picker{display:grid!important;grid-template-columns:minmax(0,1fr) 110px auto;gap:8px;align-items:end;margin-top:0!important;}
.salon-products-list{border:1px dashed #cbd5e1;background:#fff;padding:10px;min-height:44px;}
.salon-line{border:1px solid #d8e0ec;background:#f8fafc;padding:9px 10px;box-shadow:none;}
.salon-line+.salon-line{margin-top:6px;}
.salon-line strong{color:#0f172a;}.salon-line span{color:#64748b;}
.salon-main-card,.salon-soft-card,.salon-calendar-card{border:1px solid #d8e0ec;box-shadow:0 12px 30px rgba(15,23,42,.055);}
.salon-service-card{min-height:118px;}
.salon-action-cell .btn,.salon-action-cell .form-select{width:100%;}
@media(max-width:900px){.salon-modal-card .col-md-2,.salon-modal-card .col-md-3,.salon-modal-card .col-md-4,.salon-modal-card .col-md-5,.salon-modal-card .col-md-6,.salon-modal-card .col-md-7{grid-column:span 6}.salon-product-picker{grid-template-columns:1fr 110px}.salon-product-picker .btn{grid-column:1/-1}}
@media(max-width:640px){.salon-modal{padding:8px}.salon-modal-card,.salon-modal-card.wide{width:100%;max-height:calc(100vh - 16px)}.salon-modal-card>h2{padding:16px 54px 4px 14px}.salon-modal-card>.salon-modal-subtitle{padding:0 54px 14px 14px}.salon-modal-card>form{padding:12px}.salon-modal-card .row{grid-template-columns:1fr}.salon-modal-card .col-md-2,.salon-modal-card .col-md-3,.salon-modal-card .col-md-4,.salon-modal-card .col-md-5,.salon-modal-card .col-md-6,.salon-modal-card .col-md-7,.salon-modal-card .col-12{grid-column:1/-1}.salon-product-picker{grid-template-columns:1fr}}


/* POS lector de código */
.pos-sale-controls{grid-template-columns:minmax(210px,1.25fr) minmax(170px,.9fr) minmax(140px,.65fr) minmax(130px,.6fr) minmax(150px,.65fr)}
.pos-scanner-panel{overflow:visible}.pos-scanner-entry{display:grid;grid-template-columns:minmax(220px,1fr) auto auto;gap:10px;align-items:end}.pos-scan-status{min-height:22px;margin-top:8px;font-size:.82rem;font-weight:850;color:var(--text-muted)}.pos-scan-status.is-ok{color:#047857}.pos-scan-status.is-warning{color:#b91c1c}.pos-camera-box{margin-top:10px;border:1px solid var(--border);background:#0f172a;padding:8px}.pos-camera-box video{display:block;width:100%;max-height:260px;object-fit:contain;background:#0f172a}.pos-scanner-layout{display:grid;grid-template-columns:minmax(0,1fr) 270px;gap:12px;margin-top:12px;align-items:start}.pos-scanner-table-wrap{overflow:auto;border:1px solid var(--border);background:#fff}.pos-scanner-table{margin:0;min-width:760px}.pos-scanner-table td strong,.pos-scanner-table td small{display:block}.pos-scanner-table td small{font-size:.74rem;color:var(--text-muted);font-weight:750;margin-top:2px}.pos-scanner-qty{display:grid;grid-template-columns:34px minmax(70px,90px) 34px;gap:5px;justify-content:center}.pos-scanner-qty .form-control{text-align:center;font-weight:850}.pos-bestsellers-panel{border:1px solid var(--border);background:#f8fafc;padding:10px}.pos-bestsellers-panel>strong{display:block;margin-bottom:8px;font-size:.84rem;color:var(--text-main)}.pos-bestsellers-list{display:grid;gap:7px}.pos-bestseller-button{border:1px solid var(--border);background:#fff;text-align:left;padding:9px;display:grid;gap:2px;width:100%;cursor:pointer}.pos-bestseller-button:hover{border-color:var(--primary);background:#eef6ff}.pos-bestseller-button.is-disabled{opacity:.55;cursor:not-allowed}.pos-bestseller-button span{font-size:.82rem;font-weight:900;color:var(--text-main);line-height:1.2}.pos-bestseller-button small{font-size:.72rem;color:var(--primary);font-weight:850}.d-none{display:none!important}@media(max-width:1199.98px){.pos-sale-controls{grid-template-columns:1fr 1fr}.pos-scanner-layout{grid-template-columns:1fr}.pos-bestsellers-panel{order:-1}}@media(max-width:767.98px){.pos-scanner-entry,.pos-sale-controls{grid-template-columns:1fr}.pos-scanner-entry .btn{width:100%}.pos-scanner-table{min-width:690px}}

.pos-sale-controls{grid-template-columns:minmax(190px,1.15fr) minmax(175px,1fr) minmax(140px,.75fr) minmax(140px,.75fr) minmax(150px,.75fr)}
.btn-icon-only{display:inline-flex;align-items:center;justify-content:center;gap:0;min-width:42px;min-height:38px;padding:.48rem .72rem;line-height:1}
.btn-icon-only .pos-btn-icon{width:18px;height:18px;display:block;fill:currentColor;pointer-events:none}
.pos-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}
.pos-toolbar-actions .btn-icon-only{width:46px;height:38px;padding:0;flex:0 0 46px}
.pos-product-card .btn-icon-only{width:100%;min-height:38px}
.pos-scanner-head{align-items:flex-start;gap:12px;flex-wrap:wrap}
.pos-scanner-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.pos-scanner-entry{grid-template-columns:minmax(220px,1fr) auto auto}
.pos-scanner-layout{display:block!important;margin-top:12px;width:100%}
.pos-scanner-table-wrap{width:100%;max-width:100%;overflow-x:auto;border:1px solid var(--border);background:#fff}
.pos-scanner-table{width:100%;min-width:860px;margin:0}
.pos-picker-modal[hidden]{display:none!important}
.pos-picker-modal{position:fixed;inset:0;z-index:2600;display:flex;align-items:flex-start;justify-content:center;padding:18px;overflow:auto;background:rgba(15,23,42,.58)}
.pos-picker-backdrop{position:fixed;inset:0}
.pos-picker-card{position:relative;z-index:1;width:min(1040px,calc(100vw - 36px));max-height:calc(100vh - 36px);overflow:auto;background:#fff;border:1px solid var(--border);box-shadow:0 26px 80px rgba(15,23,42,.28)}
.pos-picker-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;padding:16px 18px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#fff 0%,#f8fafc 100%)}
.pos-picker-head h2{font-size:1.08rem;font-weight:900;margin:0;color:var(--text-main)}
.pos-picker-head span{display:block;margin-top:3px;font-size:.82rem;color:var(--text-muted);font-weight:800}
.pos-picker-search{padding:12px 18px;border-bottom:1px solid var(--border);background:#fff}
.pos-picker-list{display:grid;gap:8px;padding:14px 18px 18px;background:#fff}
.pos-picker-item{display:grid;grid-template-columns:minmax(220px,1.35fr) 135px 95px 120px auto;gap:10px;align-items:center;border:1px solid var(--border);background:#fbfdff;padding:10px;min-width:0}
.pos-picker-item:hover{border-color:var(--primary);background:#f8fbff}
.pos-picker-item.is-disabled{opacity:.58}
.pos-picker-item strong{display:block;font-size:.9rem;color:var(--text-main);line-height:1.25}
.pos-picker-item span{display:block;margin-top:2px;font-size:.76rem;color:var(--text-muted);font-weight:800}
.pos-picker-item small{display:block;font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:900;margin-bottom:2px}
.pos-picker-item b{font-size:.84rem;color:var(--text-main);font-weight:900;word-break:break-word}
.pos-picker-item .btn-icon-only{justify-self:end;width:42px;height:38px;padding:0}
@media(max-width:1199.98px){.pos-sale-controls{grid-template-columns:1fr 1fr}.pos-scanner-head{align-items:stretch}.pos-scanner-actions{justify-content:flex-start}.pos-picker-item{grid-template-columns:minmax(220px,1fr) 120px 90px 110px auto}}
@media(max-width:767.98px){.pos-sale-controls,.pos-scanner-entry{grid-template-columns:1fr}.pos-scanner-entry .btn{width:100%}.pos-scanner-table{min-width:720px}.pos-picker-modal{padding:8px}.pos-picker-card{width:100%;max-height:calc(100vh - 16px)}.pos-picker-head{padding:14px}.pos-picker-search{padding:10px 14px}.pos-picker-list{padding:12px 14px}.pos-picker-item{grid-template-columns:1fr}.pos-picker-item .btn-icon-only{justify-self:stretch;width:100%}.pos-toolbar-actions .btn-icon-only{width:42px;flex-basis:42px}}

.pos-product-card .btn.btn-icon-only{
    grid-column:3;
    grid-row:1;
    justify-self:end;
    align-self:start;
    width:42px;
    height:38px;
    min-width:42px;
    min-height:38px;
    padding:0;
}

.pos-product-card .btn.btn-icon-only .pos-btn-icon{
    width:18px;
    height:18px;
    min-width:18px;
    min-height:18px;
}

.pos-alert-modal[hidden]{display:none!important}
.pos-alert-modal{position:fixed;inset:0;z-index:2700;display:flex;align-items:center;justify-content:center;padding:18px;background:rgba(15,23,42,.55)}
.pos-alert-backdrop{position:fixed;inset:0}
.pos-alert-card{position:relative;z-index:1;width:min(420px,calc(100vw - 36px));background:#fff;border:1px solid var(--border);box-shadow:0 24px 70px rgba(15,23,42,.28);padding:18px}
.pos-alert-card h2{margin:0 0 8px;font-size:1.05rem;font-weight:900;color:var(--text-main)}
.pos-alert-card p{margin:0 0 16px;color:var(--text-muted);font-weight:800}

@media(max-width:767.98px){
    .pos-product-card{grid-template-columns:72px minmax(0,1fr) 42px}
    .pos-product-card .btn.btn-icon-only{justify-self:end;width:42px}
}

.sidebar {
    display: flex;
    flex-direction: column;
    transition: transform 0.22s ease, width 0.22s ease;
}

.sidebar-tools {
    padding: 12px 12px 8px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.sidebar-search-input {
    background: rgba(255,255,255,0.06);
    color: #ffffff;
    border-color: rgba(255,255,255,0.12);
    min-height: 36px;
    font-size: 0.88rem;
}

.sidebar-search-input::placeholder {
    color: #94a3b8;
}

.sidebar-search-input:focus {
    background: #ffffff;
    color: var(--text-main);
}

.sidebar-menu {
    flex: 1;
    overflow-y: auto;
    padding: 10px;
}

.sidebar-section + .sidebar-section {
    margin-top: 12px;
}

.sidebar-section-title {
    padding: 8px 12px 6px;
    color: #93c5fd;
    font-size: 0.72rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.sidebar-footer {
    border-top: 1px solid rgba(255,255,255,0.08);
    padding: 12px 16px;
    display: grid;
    gap: 2px;
    color: #cbd5e1;
    font-size: 0.78rem;
}

.sidebar-footer strong {
    color: #ffffff;
    font-size: 0.86rem;
}

.sidebar-footer span {
    color: #94a3b8;
}

.btn-menu {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    min-width: 40px;
    padding: 0;
    font-size: 1.08rem;
    border: 1px solid var(--border);
}

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

body.sidebar-collapsed .app-main {
    margin-left: 0;
}

.sidebar-backdrop {
    display: none;
}

.custom-module-card {
    border: 1px solid var(--border);
    background: linear-gradient(135deg, #ffffff, #f8fafc);
    padding: 18px;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 16px;
    margin-bottom: 16px;
}

.custom-module-icon {
    width: 68px;
    height: 68px;
    display: grid;
    place-items: center;
    border: 1px solid #bfdbfe;
    background: #eff6ff;
    color: var(--primary);
    font-size: 2.2rem;
    font-weight: 950;
    line-height: 1;
}

.custom-module-card h2 {
    margin: 0 0 4px;
    font-size: 1.08rem;
    font-weight: 900;
}

.custom-module-card p {
    margin: 0;
    color: var(--text-muted);
    font-weight: 650;
}

.basic-editor-toolbar {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    padding: 8px;
    border: 1px solid var(--border);
    border-bottom: 0;
    background: #f8fafc;
}

.editor-tool-btn {
    width: 34px;
    height: 34px;
    border: 1px solid var(--border);
    background: #ffffff;
    color: var(--text);
    display: inline-grid;
    place-items: center;
    font-size: 1rem;
    line-height: 1;
    transition: .18s ease;
}

.editor-tool-btn:hover,
.editor-tool-btn:focus {
    border-color: var(--primary);
    color: var(--primary);
    box-shadow: 0 0 0 3px rgba(30, 64, 175, .1);
    outline: none;
}

.basic-editor-box {
    min-height: 150px;
    border: 1px solid var(--border);
    background: #ffffff;
    padding: 12px;
    line-height: 1.5;
    overflow-y: auto;
}

.basic-editor-box h3 {
    margin: 0 0 8px;
    font-size: 1.05rem;
    font-weight: 900;
}

.basic-editor-box p {
    margin: 0 0 8px;
}

.basic-editor-box ul,
.basic-editor-box ol {
    margin: 0 0 8px 18px;
    padding: 0;
}

.basic-editor-box:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(30, 64, 175, 0.12);
}

.custom-request-body {
    border: 1px solid var(--border);
    background: #ffffff;
    padding: 14px;
    line-height: 1.55;
}

.custom-request-body p:last-child,
.custom-request-body ul:last-child,
.custom-request-body ol:last-child {
    margin-bottom: 0;
}

.attachment-list {
    display: grid;
    gap: 8px;
}

.attachment-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 10px 12px;
    border: 1px solid var(--border);
    background: #f8fafc;
}

.attachment-item strong {
    font-size: 0.9rem;
    word-break: break-word;
}

@media (max-width: 991.98px) {
    body.sidebar-collapsed .sidebar {
        transform: translateX(-100%);
    }

    .sidebar.open + .sidebar-backdrop,
    .sidebar.open ~ .sidebar-backdrop {
        display: block;
        position: fixed;
        inset: 0;
        background: rgba(15, 23, 42, 0.45);
        z-index: 25;
    }

    .sidebar {
        z-index: 35;
    }
}

@media (max-width: 767.98px) {
    .custom-module-card {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .custom-module-card .btn {
        width: 100%;
    }

    .attachment-item {
        align-items: stretch;
        display: grid;
    }
}

.app-modal-card.app-modal-lg {
    width: min(100%, 840px);
}

.app-modal-card.app-modal-lg .app-modal-body {
    max-height: min(72vh, 720px);
    overflow-y: auto;
}

/* Taller técnico · ajustes de formularios, filtros y mapas */
.repair-details {
    padding: 0;
    overflow: hidden;
}
.repair-details > summary,
.repair-order-details > summary {
    cursor: pointer;
    list-style: none;
}
.repair-details > summary::-webkit-details-marker,
.repair-order-details > summary::-webkit-details-marker {
    display: none;
}
.repair-summary-title {
    align-items: center;
    background: #ffffff;
    border-bottom: 1px solid rgba(15, 23, 42, .08);
    color: #0f172a;
    display: flex;
    font-size: .96rem;
    font-weight: 800;
    gap: .65rem;
    justify-content: space-between;
    padding: 1rem 1.1rem;
}
.repair-summary-title::after,
.repair-order-details > summary::after {
    content: "+";
    border: 1px solid rgba(15, 23, 42, .12);
    border-radius: 8px;
    color: #0f172a;
    display: inline-grid;
    height: 26px;
    place-items: center;
    width: 26px;
}
.repair-details[open] > .repair-summary-title::after,
.repair-order-details[open] > summary::after {
    content: "−";
}
.repair-form-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 1rem;
}
.repair-form-section {
    background: #f8fafc;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 16px;
    padding: 1rem;
}
.repair-form-section h2,
.repair-box-form h4,
.repair-items-table h4,
.repair-events h4 {
    color: #0f172a;
    font-size: .94rem;
    font-weight: 800;
    margin: 0 0 .75rem;
}
.repair-full {
    grid-column: 1 / -1;
}
.repair-device-map,
.repair-map-read {
    display: grid;
    gap: .75rem;
    grid-template-columns: repeat(5, minmax(0, 1fr));
}
.repair-map-zone,
.repair-map-read > div,
.repair-mini-card,
.repair-box-form,
.repair-map-print-card {
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, .1);
    border-radius: 14px;
    padding: .75rem;
}
.repair-map-zone span,
.repair-map-read span,
.repair-mini-card span,
.repair-order-total span {
    color: #64748b;
    display: block;
    font-size: .78rem;
    font-weight: 700;
    margin-bottom: .3rem;
}
.repair-map-zone textarea {
    resize: vertical;
}
.repair-map-preview {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .1);
    border-radius: 16px;
    min-height: 220px;
    padding: .75rem;
}
.repair-map-preview-image {
    display: none;
    margin: 0;
}
.repair-map-preview-image.is-active {
    display: block;
}
.repair-map-preview-image img,
.repair-map-order figure img,
.repair-slip-map-visual img {
    border: 1px solid rgba(15, 23, 42, .1);
    border-radius: 12px;
    display: block;
    height: auto;
    max-width: 100%;
    object-fit: contain;
    width: 100%;
}
.repair-map-preview-image figcaption,
.repair-map-order figcaption,
.repair-slip-map-title span {
    color: #475569;
    font-size: .82rem;
    font-weight: 700;
    margin-top: .35rem;
    text-align: center;
}
.form-hint {
    color: #64748b;
    display: block;
    font-size: .78rem;
    margin-top: .35rem;
}
.repair-tech-list {
    display: grid;
    gap: .5rem;
}
.repair-tech-list > div {
    background: #f8fafc;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 12px;
    padding: .65rem;
}
.repair-tech-list small {
    color: #64748b;
    display: block;
}
.repair-head-actions {
    align-items: flex-start;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
}
.repair-count-pill {
    background: #ecfeff;
    border: 1px solid #bae6fd;
    border-radius: 10px;
    color: #0369a1;
    font-size: .82rem;
    font-weight: 800;
    padding: .45rem .65rem;
    white-space: nowrap;
}
.repair-filter-grid {
    display: grid;
    gap: .75rem;
    grid-template-columns: minmax(220px, 1.5fr) repeat(4, minmax(140px, 1fr)) repeat(2, minmax(130px, .85fr)) auto auto;
}
.repair-order-list {
    display: grid;
    gap: .9rem;
}
.repair-order-card {
    margin-bottom: 0;
    padding: 1rem;
}
.repair-order-main,
.repair-code-line,
.repair-actions-bar {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: .6rem;
}
.repair-order-main {
    justify-content: space-between;
}
.repair-order-main h3 {
    color: #0f172a;
    font-size: 1.05rem;
    margin: .35rem 0 .1rem;
}
.repair-order-main p {
    color: #64748b;
    margin: 0;
}
.repair-order-total {
    background: #f8fafc;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 14px;
    min-width: 170px;
    padding: .75rem;
    text-align: right;
}
.repair-order-total strong {
    color: #0f172a;
    display: block;
    font-size: 1.1rem;
}
.repair-order-total small,
.repair-mini-card small {
    color: #64748b;
    display: block;
}
.repair-order-details {
    margin-top: .85rem;
    padding: 0;
}
.repair-order-details > summary {
    align-items: center;
    color: #0f172a;
    display: flex;
    font-size: .9rem;
    font-weight: 800;
    justify-content: space-between;
    padding: .85rem;
}
.repair-detail-grid,
.repair-management-grid {
    display: grid;
    gap: .75rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    padding: 0 .85rem;
}
.repair-management-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}
.repair-two-columns,
.repair-map-order {
    display: grid;
    gap: .75rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 0 .85rem;
}
.repair-two-columns > div {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .1);
    border-radius: 14px;
    padding: .75rem;
}
.repair-two-columns h4 {
    color: #0f172a;
    font-size: .88rem;
    font-weight: 800;
    margin: 0 0 .45rem;
}
.repair-two-columns p,
.repair-map-read p {
    color: #475569;
    font-size: .9rem;
    margin: 0;
}
.repair-map-order figure {
    margin: 0;
}
.repair-map-order .repair-map-read {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.repair-actions-bar {
    padding: 0 .85rem;
}
.repair-items-table,
.repair-events {
    padding: 0 .85rem .85rem;
}
.repair-events > div {
    background: #fff;
    border-left: 3px solid #0ea5e9;
    margin-bottom: .45rem;
    padding: .45rem .65rem;
}
.repair-events span {
    color: #64748b;
    font-size: .76rem;
    font-weight: 700;
}
.repair-events p {
    margin: .1rem 0 0;
}
.repair-slip-map-visual,
.repair-slip-map-notes,
.repair-slip-note {
    border: 1px solid rgba(15, 23, 42, .12);
    border-radius: 12px;
    margin-bottom: .85rem;
    padding: .75rem;
}
.repair-slip-map-title {
    align-items: center;
    display: flex;
    gap: .75rem;
    justify-content: space-between;
    margin-bottom: .65rem;
}
.repair-slip-map-visual img {
    margin: 0 auto;
    max-height: 720px;
    width: auto;
}
.repair-slip-note {
    background: #f8fafc;
    color: #334155;
    font-size: .86rem;
}
@media (max-width: 1399.98px) {
    .repair-filter-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
    .repair-management-grid,
    .repair-detail-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 991.98px) {
    .repair-form-grid,
    .repair-two-columns,
    .repair-map-order {
        grid-template-columns: 1fr;
    }
    .repair-device-map,
    .repair-map-read,
    .repair-map-order .repair-map-read,
    .repair-map-print-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .repair-filter-grid,
    .repair-management-grid,
    .repair-detail-grid {
        grid-template-columns: 1fr;
    }
    .repair-order-total {
        text-align: left;
        width: 100%;
    }
}
@media (max-width: 575.98px) {
    .repair-device-map,
    .repair-map-read,
    .repair-map-order .repair-map-read,
    .repair-map-print-grid {
        grid-template-columns: 1fr;
    }
}
@media print {
    .repair-slip-map-sheet {
        font-size: 11px;
    }
    .repair-slip-map-visual img {
        max-height: 640px;
    }
    .repair-slip-grid,
    .repair-slip-grid.two-cols {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .repair-map-print-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
    .repair-slip-footer,
    .repair-slip-signatures {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.repair-top-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: .55rem;
}
.repair-order-shell {
    border: 1px solid rgba(14, 165, 233, .16);
    box-shadow: 0 18px 45px rgba(15, 23, 42, .06);
}
.repair-new-head {
    border-bottom: 1px solid rgba(15, 23, 42, .08);
    margin: -1rem -1rem 1rem;
    padding: 1rem;
}
.repair-head-badges {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
}
.repair-head-badges span {
    background: #f1f5f9;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 10px;
    color: #334155;
    font-size: .78rem;
    font-weight: 800;
    padding: .4rem .6rem;
}
.repair-form-grid-expanded {
    padding: 0;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.repair-form-grid-expanded .repair-form-section {
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    border-color: rgba(15, 23, 42, .09);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7);
}
.repair-form-grid-expanded .repair-form-section h2,
.repair-management-title h4 {
    align-items: center;
    display: flex;
    gap: .45rem;
}
.repair-form-grid-expanded .repair-form-section h2::before,
.repair-management-title h4::before {
    background: #0f172a;
    border-radius: 999px;
    content: "";
    height: .5rem;
    width: .5rem;
}
.repair-map-preview {
    display: grid;
    place-items: center;
}
.repair-map-preview-image img {
    max-height: 360px;
}
.repair-order-card {
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    border: 1px solid rgba(15, 23, 42, .09);
    border-radius: 18px;
    box-shadow: 0 14px 34px rgba(15, 23, 42, .06);
}
.repair-order-details {
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 14px;
}
.repair-management-title {
    align-items: center;
    background: #f8fafc;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 14px;
    display: flex;
    justify-content: space-between;
    margin-inline: .85rem;
    padding: .75rem .85rem;
}
.repair-management-title h4 {
    color: #0f172a;
    font-size: .92rem;
    font-weight: 900;
    margin: 0;
}
.repair-management-title span {
    color: #64748b;
    font-size: .78rem;
    font-weight: 700;
}
.repair-box-form {
    background: #ffffff;
    box-shadow: 0 8px 18px rgba(15, 23, 42, .04);
}
.repair-box-form h4 {
    border-bottom: 1px solid rgba(15, 23, 42, .08);
    margin: -.15rem -.15rem .75rem;
    padding-bottom: .55rem;
}
.repair-product-hint {
    color: #64748b;
    display: block;
    font-size: .76rem;
    font-weight: 700;
    margin-bottom: .45rem;
}
.repair-product-hint.is-danger {
    color: #b91c1c;
}
.repair-mini-card {
    background: linear-gradient(180deg, #ffffff, #f8fafc);
}
.repair-two-columns > div,
.repair-map-read > div,
.repair-items-table,
.repair-events {
    background: #ffffff;
}
.repair-actions-bar .btn {
    border-radius: 10px;
    font-weight: 800;
}
.app-modal-card.app-modal-lg {
    width: min(100%, 1040px);
}
.repair-tech-list-modal {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
@media (max-width: 991.98px) {
    .repair-form-grid-expanded,
    .repair-tech-list-modal {
        grid-template-columns: 1fr;
    }
    .repair-management-title {
        align-items: flex-start;
        flex-direction: column;
    }
}


.repair-create-accordion {
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, .1);
    border-radius: 18px;
    overflow: hidden;
}
.repair-create-summary {
    align-items: center;
    cursor: pointer;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    list-style: none;
    padding: 1rem;
}
.repair-create-summary::-webkit-details-marker {
    display: none;
}
.repair-create-summary strong {
    color: #0f172a;
    display: block;
    font-size: 1rem;
    font-weight: 900;
}
.repair-create-summary span {
    color: #64748b;
    display: block;
    font-size: .84rem;
    font-weight: 700;
    margin-top: .12rem;
}
.repair-create-summary em {
    background: #0f172a;
    border-radius: 12px;
    color: #ffffff;
    font-style: normal;
    font-weight: 900;
    padding: .65rem .9rem;
    white-space: nowrap;
}
.repair-create-summary::after {
    border: 1px solid rgba(15, 23, 42, .16);
    border-radius: 12px;
    color: #0f172a;
    content: "+";
    display: grid;
    font-size: 1.1rem;
    font-weight: 900;
    height: 36px;
    place-items: center;
    width: 36px;
}
.repair-create-accordion[open] .repair-create-summary {
    background: linear-gradient(180deg, #ffffff, #f8fafc);
    border-bottom: 1px solid rgba(15, 23, 42, .08);
}
.repair-create-accordion[open] .repair-create-summary::after {
    content: "−";
}
.repair-order-form {
    padding: 1rem;
}
.repair-form-stack {
    display: grid;
    gap: .85rem;
}
.repair-form-section {
    background: linear-gradient(180deg, #ffffff, #f8fafc);
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 16px;
    padding: 1rem;
}
.repair-section-title {
    align-items: center;
    display: flex;
    gap: .75rem;
    margin-bottom: .85rem;
}
.repair-section-title > span {
    align-items: center;
    background: #0f172a;
    border-radius: 10px;
    color: #ffffff;
    display: inline-flex;
    font-size: .82rem;
    font-weight: 900;
    height: 32px;
    justify-content: center;
    min-width: 32px;
}
.repair-section-title strong {
    color: #0f172a;
    display: block;
    font-size: .98rem;
    font-weight: 900;
}
.repair-section-title small {
    color: #64748b;
    display: block;
    font-size: .78rem;
    font-weight: 700;
}
.repair-submit-bar {
    align-items: center;
    background: #f8fafc;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 16px;
    display: flex;
    justify-content: flex-end;
    margin-top: 1rem;
    padding: .85rem;
}
@media (max-width: 575.98px) {
    .repair-create-summary {
        align-items: stretch;
        flex-direction: column;
    }
    .repair-create-summary em,
    .repair-submit-bar .btn {
        text-align: center;
        width: 100%;
    }
    .repair-create-summary::after {
        display: none;
    }
    .repair-submit-bar {
        align-items: stretch;
        flex-direction: column;
    }
}

/* Taller técnico · ajustes de órdenes y boleta */
.repair-orders-panel {
    overflow: hidden;
}
.repair-filter-grid {
    align-items: end;
    display: grid;
    gap: .75rem;
    grid-template-columns: repeat(auto-fit, minmax(155px, 1fr));
    max-width: 100%;
    overflow: hidden;
}
.repair-filter-grid > * {
    min-width: 0;
}
.repair-filter-search {
    grid-column: span 2;
}
.repair-orders-table-wrap {
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 16px;
    overflow-x: auto;
}
.repair-orders-table th {
    background: #f8fafc;
    color: #334155;
    font-size: .78rem;
    letter-spacing: .02em;
    text-transform: uppercase;
    white-space: nowrap;
}
.repair-orders-table td {
    vertical-align: top;
}
.repair-orders-table td strong,
.repair-orders-table td small {
    display: block;
}
.repair-orders-table td small {
    color: #64748b;
    font-size: .78rem;
    margin-top: .2rem;
}
.repair-table-actions {
    align-items: center;
    display: inline-flex;
    flex-wrap: wrap;
    gap: .35rem;
    justify-content: flex-end;
}
.repair-table-actions form {
    display: inline-flex;
    margin: 0;
}
.repair-order-detail-row > td {
    background: #f8fafc;
    padding: 0 !important;
}
.repair-detail-panel {
    border-top: 1px solid rgba(15, 23, 42, .08);
    padding: 1rem;
}
.app-modal-xl {
    max-width: min(1180px, calc(100vw - 1.5rem));
}
.compact-edit-stack {
    gap: .85rem;
}
.repair-slip-toolbar {
    align-items: center;
    display: flex;
    justify-content: space-between;
    gap: .75rem;
    margin-bottom: 1rem;
}
.repair-slip-toolbar > div {
    display: flex;
    gap: .5rem;
}
.repair-slip-polished {
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, .12);
    border-radius: 18px;
    box-shadow: 0 20px 50px rgba(15, 23, 42, .08);
    padding: 1.25rem;
}
.repair-slip-polished .repair-slip-head {
    background: linear-gradient(135deg, #0f172a, #1e293b);
    border-radius: 16px;
    color: #fff;
    margin-bottom: 1rem;
    padding: 1rem 1.1rem;
}
.repair-slip-polished .repair-slip-head span,
.repair-slip-polished .repair-slip-head p {
    color: rgba(255, 255, 255, .78);
}
.repair-slip-polished .repair-slip-head h1 {
    color: #fff;
    margin: .15rem 0;
}
.repair-slip-summary-grid {
    display: grid;
    gap: .75rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-bottom: 1rem;
}
.repair-slip-summary-grid article,
.repair-slip-section,
.repair-slip-grid article {
    background: #f8fafc;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 14px;
    padding: .85rem;
}
.repair-slip-summary-grid span,
.repair-slip-footer span {
    color: #64748b;
    display: block;
    font-size: .76rem;
    font-weight: 800;
    margin-bottom: .25rem;
    text-transform: uppercase;
}
.repair-slip-summary-grid strong,
.repair-slip-summary-grid small {
    display: block;
}
.repair-slip-summary-grid small {
    color: #64748b;
    font-size: .8rem;
    margin-top: .15rem;
}
.repair-slip-section {
    margin-bottom: 1rem;
}
.repair-slip-section-title {
    align-items: center;
    border-bottom: 1px solid rgba(15, 23, 42, .08);
    display: flex;
    gap: .75rem;
    justify-content: space-between;
    margin-bottom: .85rem;
    padding-bottom: .65rem;
}
.repair-slip-section-title h2 {
    color: #0f172a;
    font-size: 1rem;
    font-weight: 900;
    margin: 0;
}
.repair-slip-section-title span {
    color: #64748b;
    font-weight: 800;
}
.repair-slip-map-section .repair-slip-map-visual {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 14px;
    margin-bottom: .85rem;
    padding: .75rem;
    text-align: center;
}
.repair-slip-map-section .repair-slip-map-visual img {
    border: 0;
    border-radius: 10px;
    height: auto;
    margin: 0 auto;
    max-height: none;
    max-width: 100%;
    width: auto;
}
@media (max-width: 991.98px) {
    .repair-filter-search {
        grid-column: span 1;
    }
    .repair-slip-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .repair-slip-toolbar {
        align-items: stretch;
        flex-direction: column;
    }
    .repair-slip-toolbar > div {
        flex-wrap: wrap;
    }
}
@media (max-width: 575.98px) {
    .repair-slip-summary-grid {
        grid-template-columns: 1fr;
    }
    .repair-table-actions {
        justify-content: flex-start;
    }
}
@media print {
    .repair-slip-polished {
        border: 0;
        box-shadow: none;
        padding: 0;
    }
    .repair-slip-polished .repair-slip-head {
        border-radius: 0;
    }
    .repair-slip-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Taller técnico: edición ordenada y boleta optimizada */
.app-modal-card.app-modal-xl.repair-edit-modal {
    width: min(1180px, calc(100vw - 1.5rem));
    max-height: calc(100vh - 1.5rem);
    border-radius: 18px;
    overflow: hidden;
}
.repair-edit-modal .app-modal-head {
    flex: 0 0 auto;
    border-bottom: 1px solid #e5e7eb;
}
.repair-edit-modal .repair-edit-body {
    max-height: calc(100vh - 96px);
    overflow-y: auto;
    padding: 0;
    background: #f8fafc;
}
.repair-edit-form {
    display: flex;
    flex-direction: column;
    min-height: 0;
}
.repair-edit-stack {
    display: grid;
    gap: 1rem;
    padding: 1rem;
}
.repair-edit-stack .repair-form-section {
    margin: 0;
    border: 1px solid #e5e7eb;
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 10px 26px rgba(15, 23, 42, .055);
}
.repair-edit-stack .repair-section-title {
    align-items: center;
    border-bottom: 1px solid #eef2f7;
    margin: -1rem -1rem 1rem;
    padding: .9rem 1rem;
}
.repair-edit-stack .repair-section-title span {
    flex: 0 0 auto;
}
.repair-edit-stack .form-control,
.repair-edit-stack .form-select {
    min-height: 42px;
}
.repair-edit-stack textarea.form-control {
    min-height: 92px;
}
.repair-edit-modal .repair-submit-bar {
    position: sticky;
    bottom: 0;
    z-index: 4;
    margin: 0;
    border-top: 1px solid #e5e7eb;
    border-radius: 0;
    background: rgba(255, 255, 255, .97);
    box-shadow: 0 -10px 25px rgba(15, 23, 42, .08);
}
.repair-slip-map-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(280px, .75fr);
    gap: 1rem;
    align-items: start;
}
.repair-slip-map-layout .repair-slip-map-visual {
    margin: 0;
    min-height: 100%;
}
.repair-slip-map-layout .repair-slip-map-visual img {
    display: block;
    max-height: 640px;
    margin: 0 auto;
    object-fit: contain;
}
.repair-slip-map-notes-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: .65rem;
    align-content: start;
}
.repair-slip-map-notes-grid .repair-map-print-card {
    margin: 0;
    min-height: auto;
}
.repair-slip-diagnostic-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .75rem;
}
.repair-slip-diagnostic-grid article {
    min-height: 0;
}
@media (max-width: 991.98px) {
    .repair-slip-map-layout,
    .repair-slip-diagnostic-grid {
        grid-template-columns: 1fr;
    }
    .repair-edit-modal .repair-edit-body {
        max-height: calc(100vh - 86px);
    }
}
@media (max-width: 575.98px) {
    .app-modal-card.app-modal-xl.repair-edit-modal {
        width: calc(100vw - .75rem);
        max-height: calc(100vh - .75rem);
        border-radius: 14px;
    }
    .repair-edit-stack {
        padding: .75rem;
    }
    .repair-edit-stack .repair-form-section {
        border-radius: 14px;
        padding: .85rem;
    }
    .repair-edit-stack .repair-section-title {
        margin: -.85rem -.85rem .85rem;
        padding: .8rem .85rem;
    }
}
@media print {
    .repair-slip-map-layout,
    .repair-slip-diagnostic-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .repair-slip-map-notes-grid {
        gap: .45rem;
    }
}

.renew-addon-box {
    display: grid;
    gap: 8px;
    border: 1px solid var(--border);
    background: #f8fafc;
    padding: 12px;
}
.renew-addon-box > strong {
    font-size: .92rem;
    font-weight: 900;
    color: var(--text);
}
.renew-addon-box > small {
    color: var(--text-muted);
    font-weight: 700;
}
.renew-addon-row {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 10px;
    margin: 0;
    padding: 8px 0;
    border-top: 1px solid rgba(148, 163, 184, .22);
    font-size: .88rem;
}
.renew-addon-row strong {
    font-size: .84rem;
}

.repair-attachments-modal {
    width: min(920px, calc(100vw - 1.5rem));
}
.repair-attachments-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 14px;
}
.repair-attachment-card {
    display: grid;
    gap: 8px;
    border: 1px solid #e5e7eb;
    background: #f8fafc;
    padding: 10px;
}
.repair-attachment-card img {
    width: 100%;
    height: 150px;
    object-fit: cover;
    border: 1px solid #e5e7eb;
    background: #fff;
}
.repair-attachment-card strong {
    overflow-wrap: anywhere;
    font-size: .86rem;
}
.repair-attachment-file {
    height: 150px;
    display: grid;
    place-items: center;
    border: 1px solid #e5e7eb;
    background: #fff;
    font-weight: 900;
    color: var(--primary);
}

.brand-mark img{
    width:100%;
    height:100%;
    object-fit:contain;
    display:block;
    background:#ffffff;
}
.current-logo-preview{
    display:inline-flex;
    align-items:center;
    gap:10px;
    border:1px solid var(--border);
    background:#f8fafc;
    padding:8px 10px;
    min-height:54px;
}
.current-logo-preview img{
    width:72px;
    height:38px;
    object-fit:contain;
    background:#ffffff;
    border:1px solid rgba(15,23,42,.08);
}
.current-logo-preview span{
    color:var(--text-muted);
    font-weight:800;
    font-size:.84rem;
}
.business-filter-form{
    display:grid;
    grid-template-columns:150px minmax(220px,1fr) auto;
    gap:10px;
    align-items:end;
    width:min(620px,100%);
}
.business-detail-grid.compact-detail-grid{
    grid-template-columns:repeat(5,minmax(0,1fr));
}
.plan-actions-cell{
    white-space:nowrap;
}
.updates-timeline{
    display:grid;
    gap:12px;
}
.updates-timeline.compact{
    gap:10px;
}
.update-item,
.updates-timeline article{
    border:1px solid var(--border);
    background:#ffffff;
    padding:14px;
}
.update-meta{
    display:flex;
    align-items:center;
    gap:8px;
    flex-wrap:wrap;
    margin-bottom:8px;
}
.update-meta span{
    display:inline-flex;
    align-items:center;
    min-height:24px;
    padding:4px 8px;
    background:#f1f5f9;
    color:#475569;
    font-size:.75rem;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.04em;
}
.update-body h3{
    font-size:1rem;
    font-weight:900;
    color:var(--text-main);
    margin:0 0 6px;
}
.update-body p,
.updates-timeline article p{
    color:var(--text-muted);
    margin:0;
    line-height:1.55;
}
.updates-timeline article>span{
    color:var(--text-muted);
    font-size:.76rem;
    font-weight:900;
    display:block;
    margin-bottom:4px;
}
.updates-timeline article>strong{
    display:block;
    color:var(--text-main);
    font-size:.9rem;
    margin-bottom:4px;
}
.update-actions{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
    align-items:center;
    margin-top:10px;
}
@media(max-width:1100px){
    .business-detail-grid.compact-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media(max-width:760px){
    .business-filter-form{grid-template-columns:1fr;width:100%;}
    .business-detail-grid.compact-detail-grid{grid-template-columns:1fr;}
    .plan-actions-cell{white-space:normal;}
    .plan-actions-cell .btn,.plan-actions-cell form{width:100%;margin-top:6px;}
}

.plans-table-expanded table{
    min-width: 980px;
}
.plan-modal-card{
    width: min(960px, calc(100vw - 36px));
    max-height: calc(100vh - 36px);
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.plan-modal-card .app-modal-head{
    align-items: flex-start;
}
.plan-modal-card .app-modal-body{
    max-height: min(70vh, 680px);
    overflow-y: auto;
}
.plan-modal-form{
    display: flex;
    flex-direction: column;
    min-height: 0;
}
.plan-modal-body{
    display: grid;
    gap: 14px;
}
.plan-form-section{
    border: 1px solid var(--border);
    background: #fbfdff;
    padding: 14px;
}
.plan-form-section h3{
    margin: 0 0 12px;
    font-size: .8rem;
    color: #334155;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .06em;
}
.plan-section-head{
    display: flex;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 12px;
    border-bottom: 1px dashed rgba(148, 163, 184, .55);
    padding-bottom: 10px;
}
.plan-section-head h3{
    margin: 0;
}
.plan-section-head span{
    color: var(--text-muted);
    font-weight: 800;
    font-size: .82rem;
}
.plan-status-switch{
    min-height: 42px;
    border: 1px solid var(--border);
    background: #fff;
    padding: 8px 10px;
    margin: 0;
}
.plan-modules-grid{
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
    gap: 8px;
}
.plan-module-option{
    margin: 0;
    padding: 10px 12px;
    border: 1px solid var(--border);
    background: #fff;
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 44px;
}
.plan-module-option .form-check-input{
    margin: 0;
    flex: 0 0 auto;
}
.plan-module-option .form-check-label{
    font-weight: 800;
    color: var(--text-main);
}
@media(max-width:760px){
    .head-actions{width:100%;}
    .head-actions .btn{width:100%;}
    .plan-modal-card{width:100%;max-height:calc(100vh - 18px);}
    .plan-modal-card .app-modal-body{max-height:calc(100vh - 174px);}
    .plan-form-section{padding:12px;}
    .plan-modules-grid{grid-template-columns:1fr;}
}

.invoice-lines-text {
    display: block;
    max-width: 340px;
    white-space: normal;
    line-height: 1.35;
}

.invoice-status-form {
    min-width: 260px;
}

.renew-addon-box,
.fiscal-results {
    border-radius: 14px;
}

.app-modal-card.app-modal-xl {
    width: min(100%, 1120px);
}

.app-modal-card.app-modal-xl .app-modal-body {
    max-height: min(74vh, 760px);
    overflow-y: auto;
}

.role-modal-body {
    background: #f8fafc;
}

.permissions-toolbar {
    align-items: center;
    background: #fff;
    border: 1px solid var(--border);
    display: flex;
    gap: 12px;
    justify-content: space-between;
    margin-bottom: 14px;
    padding: 12px 14px;
}

.permissions-toolbar strong {
    color: var(--text-main);
    display: block;
    font-size: .92rem;
    font-weight: 900;
    margin-bottom: 3px;
}

.permission-count-pill {
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    color: #1d4ed8;
    display: inline-flex;
    font-size: .78rem;
    font-weight: 900;
    line-height: 1;
    padding: 6px 9px;
}

.permissions-toolbar-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}

.permissions-toolbar-actions .form-control {
    min-width: 220px;
}

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

.role-permission-group {
    background: #fff;
    border: 1px solid var(--border);
    box-shadow: 0 12px 30px rgba(15, 23, 42, .06);
    min-width: 0;
    overflow: hidden;
}

.role-permission-group-head {
    align-items: center;
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    border-bottom: 1px solid var(--border);
    display: flex;
    justify-content: space-between;
    padding: 11px 12px;
}

.role-permission-group-head strong {
    color: #0f172a;
    font-size: .84rem;
    font-weight: 900;
    letter-spacing: .03em;
    text-transform: uppercase;
}

.role-permission-group-head span {
    background: #f1f5f9;
    color: #475569;
    font-size: .72rem;
    font-weight: 900;
    min-width: 28px;
    padding: 5px 8px;
    text-align: center;
}

.role-permission-list {
    display: grid;
    gap: 8px;
    padding: 10px;
}

.team-permission-check {
    align-items: flex-start;
    background: #fff;
    border: 1px solid #e2e8f0;
    display: flex;
    gap: 10px;
    margin: 0;
    min-height: 50px;
    padding: 10px;
    transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}

.team-permission-check:hover {
    border-color: #93c5fd;
    box-shadow: 0 8px 18px rgba(37, 99, 235, .08);
}

.team-permission-check.is-checked {
    background: #eff6ff;
    border-color: #60a5fa;
}

.team-permission-check .form-check-input {
    flex: 0 0 auto;
    margin: 2px 0 0;
}

.team-permission-check .form-check-label {
    display: grid;
    gap: 2px;
    line-height: 1.2;
}

.team-permission-check .form-check-label strong {
    color: #0f172a;
    font-size: .86rem;
    font-weight: 900;
}

.team-permission-check .form-check-label small {
    color: #64748b;
    font-size: .72rem;
    font-weight: 800;
    word-break: break-word;
}

@media (max-width: 760px) {
    .app-modal-card.app-modal-xl {
        width: 100%;
        max-height: calc(100vh - 18px);
    }

    .app-modal-card.app-modal-xl .app-modal-body {
        max-height: calc(100vh - 174px);
    }

    .permissions-toolbar {
        align-items: stretch;
        display: grid;
    }

    .permissions-toolbar-actions {
        display: grid;
        justify-content: stretch;
    }

    .permissions-toolbar-actions .form-control,
    .permissions-toolbar-actions .btn {
        width: 100%;
    }

    .role-permissions-grid {
        grid-template-columns: 1fr;
    }
}

.module-row-with-media {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
}

.module-table-thumb {
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
    border: 1px solid var(--border);
    background: #f8fafc;
    overflow: hidden;
}

.module-table-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.module-table-thumb i {
    color: var(--primary);
    font-size: 1.25rem;
}

.module-form-modal {
    width: min(1180px, 100%);
    max-height: calc(100vh - 34px);
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.module-form-modal form {
    min-height: 0;
    display: flex;
    flex-direction: column;
}

.module-modal-body {
    overflow: auto;
}

.module-modal-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 16px;
    align-items: start;
}

.module-modal-main,
.module-modal-side,
.module-side-box {
    min-width: 0;
}

.module-modal-side {
    display: grid;
    gap: 12px;
}

.module-side-box {
    border: 1px solid var(--border);
    background: #f8fafc;
    padding: 12px;
}

.module-icon-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
}

.module-icon-choice {
    min-height: 68px;
    border: 1px solid var(--border);
    background: #fff;
    color: var(--text);
    display: grid;
    gap: 4px;
    place-items: center;
    padding: 8px 4px;
    font-size: .72rem;
    font-weight: 800;
    text-align: center;
}

.module-icon-choice i {
    font-size: 1.16rem;
    color: var(--primary);
}

.module-icon-choice.is-selected {
    border-color: var(--primary);
    background: rgba(30, 64, 175, .08);
    box-shadow: 0 0 0 3px rgba(30, 64, 175, .1);
}

.module-image-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-top: 10px;
}

.module-image-item {
    position: relative;
    display: grid;
    gap: 6px;
    border: 1px solid var(--border);
    background: #fff;
    padding: 7px;
    cursor: pointer;
}

.module-image-item img {
    width: 100%;
    height: 88px;
    object-fit: cover;
    background: #eef2f7;
}

.module-image-item span {
    color: var(--text-muted);
    font-size: .72rem;
    font-weight: 800;
}

.module-image-item input:not(:checked) + span {
    color: #b91c1c;
}

.module-image-empty {
    grid-column: 1 / -1;
    border: 1px dashed var(--border);
    background: #fff;
    color: var(--text-muted);
    font-size: .82rem;
    font-weight: 800;
    padding: 12px;
}

.module-plan-list {
    display: grid;
    gap: 4px;
    max-height: 170px;
    overflow: auto;
}

@media (max-width: 1100px) {
    .module-modal-grid {
        grid-template-columns: 1fr;
    }

    .module-icon-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (max-width: 680px) {
    .module-icon-grid,
    .module-image-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .module-form-modal {
        max-height: calc(100vh - 18px);
    }
}

.module-tags-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.module-mini-tag {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 5px 9px;
    background: #eef7f5;
    color: #007e6c;
    border: 1px solid #cdece5;
    font-size: 12px;
    font-weight: 800;
}
