/* ========================================
   TEMA CLARO (por defecto)
   ======================================== */
:root,
[data-theme="claro"] {
    --color-bg-primary: #f5f6fa;
    --color-bg-secondary: #ffffff;
    --color-bg-tertiary: #eef1f6;
    --color-bg-hover: rgba(0, 0, 0, 0.05);
    --color-bg-card: #ffffff;

    --color-text-primary: #1a1d29;
    --color-text-secondary: #5a5f72;
    --color-text-tertiary: #8b8fa3;
    --color-text-inverse: #ffffff;

    --color-border: #e2e5ec;
    --color-border-light: #eef0f5;

    --color-accent: #4361ee;
    --color-accent-hover: #3a56d4;
    --color-accent-light: rgba(67, 97, 238, 0.1);

    --color-success: #2ecc71;
    --color-success-light: rgba(46, 204, 113, 0.1);
    --color-warning: #f39c12;
    --color-warning-light: rgba(243, 156, 18, 0.1);
    --color-danger: #e74c3c;
    --color-danger-light: rgba(231, 76, 60, 0.1);
    --color-info: #3498db;
    --color-info-light: rgba(52, 152, 219, 0.1);

    --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.08);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.12);

    --radius-sm: 6px;
    --radius-md: 10px;
    --radius-lg: 16px;
}

/* ========================================
   TEMA OSCURO
   ======================================== */
[data-theme="oscuro"] {
    --color-bg-primary: #0f1117;
    --color-bg-secondary: #1a1d29;
    --color-bg-tertiary: #232636;
    --color-bg-hover: rgba(255, 255, 255, 0.06);
    --color-bg-card: #1a1d29;

    --color-text-primary: #e8eaf0;
    --color-text-secondary: #b0b4c4;
    --color-text-tertiary: #8a8ea2;
    --color-text-inverse: #0f1117;

    --color-border: #2a2d3a;
    --color-border-light: #232636;

    --color-accent: #5a7cf7;
    --color-accent-hover: #4d6de6;
    --color-accent-light: rgba(90, 124, 247, 0.15);

    --color-success: #27ae60;
    --color-success-light: rgba(39, 174, 96, 0.15);
    --color-warning: #e67e22;
    --color-warning-light: rgba(230, 126, 34, 0.15);
    --color-danger: #c0392b;
    --color-danger-light: rgba(192, 57, 43, 0.15);
    --color-info: #2980b9;
    --color-info-light: rgba(41, 128, 185, 0.15);

    --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.3);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.4);
    --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.5);
}

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

html, body {
    margin: 0;
    padding: 0;
    font-family: 'Segoe UI', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', Arial, sans-serif;
    font-size: 15px;
    line-height: 1.5;
    color: var(--color-text-primary);
    background-color: var(--color-bg-primary);
    -webkit-font-smoothing: antialiased;
}

html,
[data-theme="claro"] {
    color-scheme: light;
}

[data-theme="oscuro"] {
    color-scheme: dark;
}

h1, h2, h3, h4, h5, h6 {
    margin-top: 0;
    color: var(--color-text-primary);
}

h1 { font-size: 1.75rem; font-weight: 700; }
h2 { font-size: 1.4rem; font-weight: 600; }
h3 { font-size: 1.15rem; font-weight: 600; }

a {
    color: var(--color-accent);
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

h1:focus {
    outline: none;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: 3px solid var(--color-accent);
    outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        scroll-behavior: auto !important;
        transition-duration: 0.01ms !important;
    }
}

/* ========================================
   CARDS
   ======================================== */
.card {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 1.25rem;
    box-shadow: var(--shadow-sm);
    transition: box-shadow 0.2s;
}

.card:hover {
    box-shadow: var(--shadow-md);
}

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

.card-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0;
}

.card-icon {
    font-size: 1.75rem;
}

.card-value {
    font-size: 2rem;
    font-weight: 700;
    color: var(--color-text-primary);
    line-height: 1.2;
}

.card-label {
    font-size: 0.8rem;
    color: var(--color-text-tertiary);
    margin-top: 0.25rem;
}

/* ========================================
   MÓDULO CARDS (colores por módulo)
   ======================================== */
.module-card {
    cursor: pointer;
    transition: transform 0.2s, box-shadow 0.2s;
}

.module-card:hover {
    transform: translateY(-2px);
}

.module-seguridad { border-left: 4px solid var(--color-danger); }
.module-energia { border-left: 4px solid var(--color-warning); }
.module-comodidad { border-left: 4px solid var(--color-info); }
.module-entretenimiento { border-left: 4px solid #9b59b6; }
.module-accesibilidad { border-left: 4px solid var(--color-success); }
.module-automatizacion { border-left: 4px solid var(--color-accent); }

/* ========================================
   GRID LAYOUTS
   ======================================== */
.grid-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.grid-modules {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.grid-2 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

/* ========================================
   BOTONES
   ======================================== */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.6rem 1.25rem;
    font-size: 0.9rem;
    font-weight: 500;
    border: none;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all 0.2s;
    text-decoration: none;
    line-height: 1.4;
}

.btn-primary {
    background-color: var(--color-accent);
    color: #fff;
}

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

.btn-secondary {
    background-color: var(--color-bg-tertiary);
    color: var(--color-text-primary);
    border: 1px solid var(--color-border);
}

.btn-secondary:hover {
    background-color: var(--color-bg-hover);
}

.btn-danger {
    background-color: var(--color-danger);
    color: #fff;
}

.btn-block {
    width: 100%;
}

.btn-sm {
    padding: 0.35rem 0.75rem;
    font-size: 0.8rem;
}

/* ========================================
   FORMULARIOS
   ======================================== */
.form-group {
    margin-bottom: 1rem;
}

.form-group label {
    display: block;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--color-text-secondary);
    margin-bottom: 0.35rem;
}

.form-input {
    width: 100%;
    padding: 0.6rem 0.85rem;
    font-size: 0.9rem;
    color: var(--color-text-primary);
    background-color: var(--color-bg-primary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    transition: border-color 0.2s, box-shadow 0.2s;
}

.form-input:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px var(--color-accent-light);
}

.form-check {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.form-check input[type="checkbox"] {
    accent-color: var(--color-accent);
}

/* ========================================
   ALERTAS
   ======================================== */
.alert {
    padding: 0.75rem 1rem;
    border-radius: var(--radius-sm);
    font-size: 0.85rem;
    margin-bottom: 1rem;
}

.alert-error {
    background-color: var(--color-danger-light);
    color: var(--color-danger);
    border: 1px solid var(--color-danger);
}

.alert-success {
    background-color: var(--color-success-light);
    color: var(--color-success);
    border: 1px solid var(--color-success);
}

.alert-warning {
    background-color: var(--color-warning-light);
    color: var(--color-warning);
    border: 1px solid var(--color-warning);
}

.alert-info {
    background-color: var(--color-info-light);
    color: var(--color-info);
    border: 1px solid var(--color-info);
}

/* ========================================
   BADGES
   ======================================== */
.badge {
    display: inline-flex;
    align-items: center;
    padding: 0.2rem 0.6rem;
    font-size: 0.72rem;
    font-weight: 600;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.badge-success { background: var(--color-success-light); color: var(--color-success); }
.badge-warning { background: var(--color-warning-light); color: var(--color-warning); }
.badge-danger { background: var(--color-danger-light); color: var(--color-danger); }
.badge-info { background: var(--color-info-light); color: var(--color-info); }

/* ========================================
   TABLAS
   ======================================== */
.table-container {
    overflow-x: auto;
}

table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.85rem;
}

thead th {
    text-align: left;
    padding: 0.75rem 1rem;
    font-weight: 600;
    color: var(--color-text-secondary);
    border-bottom: 2px solid var(--color-border);
    white-space: nowrap;
}

tbody td {
    padding: 0.65rem 1rem;
    border-bottom: 1px solid var(--color-border-light);
    color: var(--color-text-primary);
}

tbody tr:hover {
    background-color: var(--color-bg-hover);
}

/* ========================================
   PÁGINA CUENTA (Login / Registro)
   ======================================== */
.account-card {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 2rem;
    box-shadow: var(--shadow-lg);
}

.account-card h2 {
    text-align: center;
    margin-bottom: 1.5rem;
}

.account-links {
    text-align: center;
    margin-top: 1.25rem;
    font-size: 0.85rem;
}

/* ========================================
   ESTADO INDICADORES
   ======================================== */
.status-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-right: 0.4rem;
}

.status-online { background-color: var(--color-success); }
.status-offline { background-color: var(--color-text-tertiary); }
.status-error { background-color: var(--color-danger); }
.status-warning { background-color: var(--color-warning); }

/* ========================================
   SECCIONES DE MÓDULO
   ======================================== */
.module-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
    gap: 1rem;
}

.module-header h1 {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0;
}

.module-description {
    color: var(--color-text-secondary);
    font-size: 0.9rem;
    margin-bottom: 1.5rem;
}

/* ========================================
   LISTA DE ACTIVIDAD
   ======================================== */
.activity-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.activity-item {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--color-border-light);
}

.activity-item:last-child {
    border-bottom: none;
}

.activity-icon {
    font-size: 1.25rem;
    flex-shrink: 0;
    margin-top: 0.1rem;
}

.activity-content {
    flex: 1;
    min-width: 0;
}

.activity-text {
    font-size: 0.85rem;
    color: var(--color-text-primary);
}

.activity-time {
    font-size: 0.75rem;
    color: var(--color-text-tertiary);
    margin-top: 0.15rem;
}

/* ========================================
   VACÍO / EMPTY STATE
   ======================================== */
.empty-state {
    text-align: center;
    padding: 3rem 1.5rem;
    color: var(--color-text-tertiary);
}

.empty-state-icon {
    font-size: 3rem;
    margin-bottom: 1rem;
    display: block;
}

.empty-state h3 {
    color: var(--color-text-secondary);
    margin-bottom: 0.5rem;
}

.empty-state p {
    font-size: 0.9rem;
    max-width: 400px;
    margin: 0 auto;
}

/* ========================================
   VALIDACIONES BLAZOR
   ======================================== */
.valid.modified:not([type=checkbox]) {
    outline: 1px solid var(--color-success);
}

.invalid {
    outline: 1px solid var(--color-danger);
}

.validation-message {
    color: var(--color-danger);
    font-size: 0.8rem;
    margin-top: 0.25rem;
}

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

    .blazor-error-boundary::after {
        content: "Ha ocurrido un error."
    }

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

/* ========================================
   LANDING PAGE
   ======================================== */
.btn-lg {
    padding: 0.8rem 1.45rem;
    font-size: 0.95rem;
}

.landing-page {
    width: 100%;
}

html {
    scroll-behavior: smooth;
}

.landing-hero,
.landing-section[id] {
    scroll-margin-top: 90px;
}

.landing-topbar {
    position: sticky;
    top: 0;
    z-index: 80;
    backdrop-filter: blur(10px);
    background: color-mix(in srgb, var(--color-bg-primary) 80%, transparent 20%);
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 82%, var(--color-accent) 18%);
}

.landing-topbar-shell {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    min-height: 72px;
}

.landing-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    text-decoration: none;
    color: var(--color-text-primary);
    font-weight: 700;
}

.landing-brand-icon {
    width: 2.5rem;
    height: 2.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.9rem;
    background: linear-gradient(135deg, var(--color-accent) 0%, color-mix(in srgb, var(--color-accent) 68%, white 32%) 100%);
    color: white;
    box-shadow: 0 10px 22px color-mix(in srgb, var(--color-accent) 20%, transparent 80%);
}

.landing-brand-text {
    white-space: nowrap;
}

.landing-topnav {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.95rem;
}

.landing-topnav a {
    color: var(--color-text-secondary);
    text-decoration: none;
    font-weight: 600;
    font-size: 0.92rem;
}

.landing-topnav a:hover {
    color: var(--color-text-primary);
}

.landing-topactions {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.landing-home-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.55rem 0.95rem;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--color-accent), var(--color-accent-strong));
    color: #ffffff;
    text-decoration: none;
    font-weight: 800;
    box-shadow: 0 10px 20px rgba(37, 99, 235, 0.22);
    transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

.landing-home-link:hover {
    color: #ffffff;
    filter: brightness(1.04);
    transform: translateY(-1px);
    box-shadow: 0 12px 24px rgba(37, 99, 235, 0.28);
}

html[data-theme="claro"] .landing-home-link {
    background: linear-gradient(135deg, #1d4ed8, #1e40af);
    color: #ffffff;
    border: 1px solid rgba(255, 255, 255, 0.28);
    box-shadow: 0 10px 20px rgba(30, 64, 175, 0.24);
}

html[data-theme="claro"] .landing-home-link:hover {
    color: #ffffff;
    box-shadow: 0 12px 24px rgba(30, 64, 175, 0.3);
}

.landing-summary {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 100%;
    padding: 1.5rem;
}

.landing-shell {
    width: min(1180px, calc(100% - 2rem));
    margin: 0 auto;
}

.landing-section {
    padding: 4rem 0;
}

.landing-section-soft {
    background: linear-gradient(180deg, transparent 0%, var(--color-bg-secondary) 100%);
}

.landing-hero {
    padding: 4.5rem 0 3.5rem;
    background:
        radial-gradient(circle at top left, color-mix(in srgb, var(--color-accent-light) 70%, transparent 30%) 0%, transparent 40%),
        linear-gradient(180deg, var(--color-bg-primary) 0%, var(--color-bg-secondary) 100%);
}

.landing-section-definition {
    background:
        linear-gradient(180deg, rgba(10, 16, 30, 0.76) 0%, rgba(10, 16, 30, 0.68) 100%),
        url('/images/domotica-definicion.jpg') center/cover no-repeat;
}

.landing-image-showcase {
    padding: 1.5rem 0;
    background: linear-gradient(180deg, color-mix(in srgb, var(--color-bg-tertiary) 78%, var(--color-accent-light) 22%) 0%, color-mix(in srgb, var(--color-bg-secondary) 88%, var(--color-accent-light) 12%) 100%);
}

.landing-image-showcase-frame {
    height: clamp(340px, 34vw, 520px);
    border-radius: calc(var(--radius-lg) + 4px);
    border: 1px solid color-mix(in srgb, var(--color-border) 74%, var(--color-accent) 26%);
    box-shadow: var(--shadow-md);
    position: relative;
    overflow: hidden;
}

.landing-image-slide-image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    opacity: 0;
    animation: landing-image-rotate 36s infinite;
    animation-fill-mode: both;
}

.landing-image-showcase-frame::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(7, 12, 24, 0.1) 0%, rgba(7, 12, 24, 0.22) 100%);
    pointer-events: none;
}

.landing-image-slide-image-1 {
    animation-delay: 0s;
}

.landing-image-slide-image-2 {
    animation-delay: 6s;
}

.landing-image-slide-image-3 {
    animation-delay: 12s;
}

.landing-image-slide-image-4 {
    animation-delay: 18s;
}

.landing-image-slide-image-5 {
    animation-delay: 24s;
}

.landing-image-slide-image-6 {
    animation-delay: 30s;
}

@keyframes landing-image-rotate {
    0% { opacity: 0; transform: scale(1.02); }
    4% { opacity: 1; }
    14% { opacity: 1; transform: scale(1.06); }
    18% { opacity: 0; }
    100% { opacity: 0; transform: scale(1.08); }
}

.landing-section-coverage {
    background:
        linear-gradient(180deg, rgba(9, 14, 27, 0.76) 0%, rgba(9, 14, 27, 0.68) 100%),
        url('/images/domotica-cobertura.jpg') center/cover no-repeat;
}

.landing-section-packages {
    background: transparent;
}

.landing-section-cta-contact {
    background:
        linear-gradient(180deg, rgba(7, 12, 24, 0.56) 0%, rgba(7, 12, 24, 0.62) 100%),
        url('/images/domotica-cta-contacto.jpg') center/cover no-repeat;
}

.contact-hero-image {
    background:
        linear-gradient(180deg, rgba(9, 14, 27, 0.76) 0%, rgba(9, 14, 27, 0.7) 100%),
        url('/images/domotica-contacto.jpg') center/cover no-repeat;
}

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

.landing-copy {
    max-width: 100%;
}

.landing-copy-full {
    width: 100%;
}

.landing-kicker,
.landing-section-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    background: var(--color-accent-light);
    color: var(--color-accent);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.landing-copy h1 {
    font-size: clamp(2.2rem, 5vw, 4rem);
    line-height: 1.05;
    margin: 1rem 0 1rem;
}

.landing-lead {
    font-size: 1.05rem;
    color: color-mix(in srgb, var(--color-text-primary) 78%, white 22%);
    max-width: none;
}

.landing-lead-full {
    width: 100%;
}

.landing-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin: 1.5rem 0;
}

.landing-actions-centered {
    justify-content: center;
}

.landing-inline-note {
    padding: 1rem 1.1rem;
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--color-warning-light) 55%, var(--color-bg-card) 45%);
    border: 1px solid color-mix(in srgb, var(--color-warning) 22%, var(--color-border) 78%);
    color: color-mix(in srgb, var(--color-text-primary) 78%, white 22%);
}

.landing-summary-header {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.landing-summary h2 {
    margin-bottom: 1rem;
}

.landing-checklist {
    padding-left: 1.2rem;
    margin: 0 0 1.5rem;
    color: color-mix(in srgb, var(--color-text-primary) 76%, white 24%);
}

.landing-checklist li + li {
    margin-top: 0.65rem;
}

.landing-mini-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.landing-mini-stats-hero {
    max-width: 780px;
}

.landing-mini-stats-section {
    margin-top: 1.5rem;
}

.landing-stat {
    padding: 0.95rem;
    border-radius: var(--radius-md);
    background: var(--color-bg-tertiary);
    border: 1px solid var(--color-border);
    text-align: center;
}

.landing-stat strong {
    display: block;
    font-size: 1.45rem;
    color: var(--color-text-primary);
}

.landing-stat span {
    color: color-mix(in srgb, var(--color-text-primary) 72%, white 28%);
    font-size: 0.82rem;
}

.landing-section-header {
    margin-bottom: 1.5rem;
}

.landing-section-header h2 {
    margin: 0.9rem 0 0.5rem;
    font-size: clamp(1.7rem, 3vw, 2.5rem);
}

.landing-section-header p {
    margin: 0;
    max-width: none;
    color: color-mix(in srgb, var(--color-text-primary) 78%, white 22%);
}

html[data-theme="claro"] .contact-hero-image .contact-copy h1,
html[data-theme="claro"] .contact-hero-image .contact-copy p,
html[data-theme="claro"] .contact-hero-image .contact-highlights h3,
html[data-theme="claro"] .contact-hero-image .contact-highlights p {
    color: #14283f !important;
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.28);
}

html[data-theme="claro"] .landing-section-definition .landing-section-header h2,
html[data-theme="claro"] .landing-section-definition .landing-section-header p,
html[data-theme="claro"] .landing-section-coverage .landing-section-header h2,
html[data-theme="claro"] .landing-section-coverage .landing-section-header p {
    color: #f5f8fe !important;
    text-shadow: 0 1px 12px rgba(0, 0, 0, 0.24);
}

html[data-theme="claro"] .landing-section-definition .landing-card-accent h3,
html[data-theme="claro"] .landing-section-definition .landing-card-accent p,
html[data-theme="claro"] .landing-section-coverage .landing-card-accent h3,
html[data-theme="claro"] .landing-section-coverage .landing-card-accent p {
    color: #102238 !important;
    text-shadow: none;
}

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

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

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

.landing-card-accent,
.landing-package-card,
.landing-plan-card,
.landing-benefit-card,
.landing-compliance-card {
    height: 100%;
}

.landing-card-accent {
    border-top: 4px solid var(--color-accent);
}

.landing-package-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1rem;
}

.landing-package-top h3,
.landing-plan-card h3,
.landing-benefit-card h3 {
    margin-bottom: 0.65rem;
}

.landing-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-bottom: 1rem;
}

.landing-price {
    font-size: 1.7rem;
    font-weight: 800;
    white-space: nowrap;
    color: var(--color-text-primary);
}

.landing-price small {
    font-size: 0.85rem;
    color: var(--color-text-secondary);
    font-weight: 600;
}

.landing-card-accent p,
.landing-benefit-card p,
.landing-plan-card p,
.landing-package-header p,
.landing-tier-subtitle,
.landing-example-list,
.landing-plan-button p {
    color: color-mix(in srgb, var(--color-text-primary) 76%, white 24%);
}

.landing-plan-card {
    border-top: 4px solid var(--color-info);
}

.landing-plan-featured {
    border-top-color: var(--color-accent);
    box-shadow: 0 10px 24px color-mix(in srgb, var(--color-accent) 18%, transparent 82%);
}

.landing-benefit-card {
    background: linear-gradient(180deg, var(--color-bg-card) 0%, color-mix(in srgb, var(--color-bg-card) 85%, var(--color-accent-light) 15%) 100%);
}

.landing-compliance-card {
    padding: 1.6rem;
    border-left: 4px solid var(--color-success);
}

.landing-compliance-card p {
    margin-bottom: 0;
    color: var(--color-text-secondary);
}

@media (max-width: 1080px) {
    .landing-topbar-shell {
        flex-wrap: wrap;
        justify-content: center;
        padding: 0.75rem 0;
    }

    .landing-topnav {
        order: 3;
    }

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

    .landing-grid-3,
    .landing-hero-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .landing-section {
        padding: 3rem 0;
    }

    .landing-shell {
        width: min(100% - 1.25rem, 100%);
    }

    .landing-grid-4,
    .landing-grid-3,
    .landing-mini-stats {
        grid-template-columns: 1fr;
    }

    .landing-topactions,
    .landing-topnav {
        width: 100%;
        justify-content: center;
    }

    .landing-topactions {
        flex-wrap: wrap;
    }

    .landing-home-link {
        width: 100%;
    }

    .landing-package-top {
        flex-direction: column;
    }
}

.landing-tab-list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.landing-tabcontrol-shell {
    border: 1px solid color-mix(in srgb, var(--color-border) 82%, var(--color-accent) 18%);
    border-radius: calc(var(--radius-lg) + 2px);
    background: linear-gradient(180deg, color-mix(in srgb, var(--color-bg-card) 94%, var(--color-accent-light) 6%) 0%, var(--color-bg-card) 100%);
    padding: 0.9rem;
    box-shadow: var(--shadow-md);
}

.landing-tab-input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.landing-tab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    padding: 1rem 1rem 0.95rem;
    border: 1px solid var(--color-border);
    border-radius: 0.95rem 0.95rem 0.35rem 0.35rem;
    background: linear-gradient(180deg, color-mix(in srgb, var(--color-bg-card) 96%, white 4%) 0%, var(--color-bg-tertiary) 100%);
    color: var(--color-text-secondary);
    cursor: pointer;
    font: inherit;
    font-weight: 600;
    transition: transform 0.2s, border-color 0.2s, box-shadow 0.2s, background-color 0.2s, color 0.2s;
    position: relative;
}

.landing-tab:hover {
    transform: translateY(-1px);
    border-color: var(--color-accent);
}

.landing-tab.active,
#tab-hogar:checked ~ .landing-tab-list label[for="tab-hogar"],
#tab-bienestar:checked ~ .landing-tab-list label[for="tab-bienestar"],
#tab-inclusivo:checked ~ .landing-tab-list label[for="tab-inclusivo"],
#tab-empresa:checked ~ .landing-tab-list label[for="tab-empresa"],
#tab-industria:checked ~ .landing-tab-list label[for="tab-industria"],
#tab-premium:checked ~ .landing-tab-list label[for="tab-premium"] {
    background: linear-gradient(135deg, color-mix(in srgb, var(--color-accent) 88%, white 12%) 0%, var(--color-accent) 100%);
    color: #fff;
    border-color: color-mix(in srgb, var(--color-accent) 82%, white 18%);
    box-shadow: 0 12px 28px color-mix(in srgb, var(--color-accent) 24%, transparent 76%);
    transform: translateY(1px);
}

.landing-tab-icon {
    font-size: 1.05rem;
}

.landing-package-header {
    margin-bottom: 1rem;
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    padding: 0 0 1rem;
    border-bottom: 1px solid var(--color-border-light);
}

.landing-tab-panels {
    border: 1px solid color-mix(in srgb, var(--color-border) 84%, var(--color-accent) 16%);
    border-radius: 0 1rem 1rem 1rem;
    background: color-mix(in srgb, var(--color-bg-card) 96%, var(--color-bg-tertiary) 4%);
    padding: 1.1rem;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.landing-package-header p {
    margin-bottom: 0;
    color: var(--color-text-secondary);
}

.landing-tier-card {
    border-top: 4px solid var(--color-border);
}

.landing-tier-zero {
    border-top-color: color-mix(in srgb, var(--color-text-tertiary) 65%, var(--color-border) 35%);
    background: linear-gradient(180deg, color-mix(in srgb, var(--color-bg-card) 92%, var(--color-bg-tertiary) 8%) 0%, var(--color-bg-card) 100%);
}

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

.landing-tab-panels .landing-tab-panel {
    display: none;
}

.landing-tab-panel-visible {
    display: block !important;
}

#tab-hogar:checked ~ .landing-tab-panels .panel-hogar,
#tab-bienestar:checked ~ .landing-tab-panels .panel-bienestar,
#tab-inclusivo:checked ~ .landing-tab-panels .panel-inclusivo,
#tab-empresa:checked ~ .landing-tab-panels .panel-empresa,
#tab-industria:checked ~ .landing-tab-panels .panel-industria,
#tab-premium:checked ~ .landing-tab-panels .panel-premium {
    display: block;
}

.landing-tier-featured {
    border-top-color: var(--color-accent);
    box-shadow: 0 10px 26px color-mix(in srgb, var(--color-accent) 16%, transparent 84%);
}

.landing-tier-zero-band {
    width: 100%;
    margin-bottom: 1rem;
}

.landing-plan-button {
    width: 100%;
    text-align: left;
    border-left: 1px solid var(--color-border);
    border-right: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-bg-card);
    padding: 1.1rem;
    cursor: pointer;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background-color 0.18s ease;
}

.landing-plan-button:hover {
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--color-accent) 30%, var(--color-border) 70%);
    box-shadow: 0 14px 28px color-mix(in srgb, var(--color-accent) 12%, transparent 88%);
}

.landing-plan-card-footer {
    margin-top: 1rem;
    color: var(--color-accent);
    font-weight: 700;
    font-size: 0.88rem;
}

.landing-plan-recommended {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-bottom: 0.65rem;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-accent-light) 70%, transparent 30%);
    color: var(--color-accent);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.landing-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.62);
    backdrop-filter: blur(6px);
    z-index: 250;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.landing-modal {
    width: min(880px, 100%);
    max-height: min(88vh, 920px);
    overflow-y: auto;
    padding: 1.4rem;
}

.landing-modal-media {
    height: 220px;
    margin: -1.4rem -1.4rem 1.2rem;
    border-radius: calc(var(--radius-lg) - 2px) calc(var(--radius-lg) - 2px) 0 0;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    box-shadow: inset 0 -80px 110px rgba(0, 0, 0, 0.28);
}

.landing-modal-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.landing-modal-header p {
    margin: 0.5rem 0 0;
    color: color-mix(in srgb, var(--color-text-primary) 78%, white 22%);
}

.landing-modal-price {
    font-size: 1.9rem;
    font-weight: 800;
    margin-bottom: 1rem;
}

.landing-modal-price small {
    font-size: 0.85rem;
    color: var(--color-text-secondary);
}

.landing-modal-section + .landing-modal-section {
    margin-top: 1rem;
}

.landing-modal-section h3 {
    margin-bottom: 0.75rem;
}

.landing-cta-panel {
    padding: 2rem;
    text-align: center;
    background: color-mix(in srgb, var(--color-bg-card) 82%, transparent 18%);
    backdrop-filter: blur(6px);
    border: 1px solid color-mix(in srgb, var(--color-border) 78%, white 22%);
}

.landing-cta-panel p {
    margin-bottom: 0;
    color: var(--color-text-secondary);
}

.landing-tier-subtitle {
    margin: 0.35rem 0 0;
    color: var(--color-text-secondary);
    font-size: 0.9rem;
}

.landing-example-title {
    margin: 1rem 0 0.55rem;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--color-text-tertiary);
}

.landing-example-list {
    margin-bottom: 0;
}

.contact-hero {
    padding-top: 3.5rem;
}

.contact-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(340px, 0.95fr);
    gap: 1.5rem;
    align-items: start;
}

.contact-form-card {
    padding: 1.5rem;
}

.contact-form-card .landing-actions {
    margin-top: 1rem;
}

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

.contact-textarea {
    min-height: 140px;
    resize: vertical;
}

.contact-highlights {
    margin-top: 1.5rem;
}

@media (max-width: 1080px) {
    .landing-tab-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .landing-package-header,
    .contact-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .landing-tab-list,
    .contact-grid-fields {
        grid-template-columns: 1fr;
    }

    .landing-tab {
        justify-content: flex-start;
    }

    .landing-modal {
        padding: 1rem;
        max-height: 92vh;
    }

    .landing-modal-media {
        height: 170px;
        margin: -1rem -1rem 1rem;
    }

    .landing-modal-header {
        flex-direction: column;
    }

    .landing-image-showcase-frame {
        min-height: 300px;
    }
}

.landing-theme-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    appearance: none;
    border: 1px solid color-mix(in srgb, var(--color-accent) 42%, var(--color-border) 58%);
    background: linear-gradient(135deg, color-mix(in srgb, var(--color-accent-light) 72%, var(--color-bg-card) 28%) 0%, color-mix(in srgb, var(--color-bg-card) 92%, white 8%) 100%);
    color: var(--color-text-primary);
    border-radius: 999px;
    min-height: 2.6rem;
    padding: 0.55rem 0.95rem;
    box-shadow: 0 10px 24px color-mix(in srgb, var(--color-accent) 12%, transparent 88%);
    cursor: pointer;
    transition: transform 0.2s, border-color 0.2s, box-shadow 0.2s;
}

.landing-theme-toggle:hover {
    transform: translateY(-1px);
    border-color: var(--color-accent);
    box-shadow: 0 12px 28px color-mix(in srgb, var(--color-accent) 18%, transparent 82%);
}

.landing-theme-toggle-icon {
    font-size: 1rem;
}

.landing-theme-toggle-label {
    font-weight: 700;
}

.landing-image-slide-current {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: none;
}

.landing-image-slide-active.is-forward {
    animation-name: landing-slide-in-forward;
}

.landing-image-slide-active.is-backward {
    animation-name: landing-slide-in-backward;
}

.landing-image-slide-previous.is-forward {
    animation-name: landing-slide-out-forward;
}

.landing-image-slide-previous.is-backward {
    animation-name: landing-slide-out-backward;
}

.landing-image-slide-dots {
    position: absolute;
    left: 50%;
    bottom: 1.8rem;
    transform: translateX(-50%);
    display: flex;
    gap: 0.45rem;
    z-index: 2;
}

.landing-image-slide-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    width: 2.9rem;
    height: 2.9rem;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 999px;
    background: rgba(11, 17, 29, 0.36);
    color: white;
    font-size: 1.2rem;
    cursor: pointer;
    backdrop-filter: blur(8px);
    transition: background-color 0.2s, transform 0.2s;
}

.landing-image-slide-nav:hover {
    background: rgba(11, 17, 29, 0.58);
}

.landing-image-slide-nav-prev {
    left: 1rem;
}

.landing-image-slide-nav-next {
    right: 1rem;
}

.landing-image-slide-progress {
    position: absolute;
    left: 1rem;
    right: 1rem;
    bottom: 0.7rem;
    height: 0.3rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.18);
    overflow: hidden;
    z-index: 2;
}

.landing-image-slide-progress-bar {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, rgba(255, 255, 255, 0.68) 0%, rgba(255, 255, 255, 0.96) 100%);
    transition: width 0.1s linear;
}

.landing-image-slide-dot {
    width: 0.7rem;
    height: 0.7rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.45);
    border: 1px solid rgba(255, 255, 255, 0.28);
    padding: 0;
    cursor: pointer;
}

.landing-image-slide-dot.active {
    background: white;
    box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.12);
}

.landing-section-about {
    background: linear-gradient(180deg, color-mix(in srgb, #4f79aa 58%, var(--color-bg-secondary) 42%) 0%, color-mix(in srgb, #f1f6ff 30%, var(--color-bg-secondary) 70%) 100%);
}

.landing-about-panel {
    padding: 1.25rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 72%, var(--color-accent) 28%);
    background: color-mix(in srgb, var(--color-bg-card) 92%, white 8%);
    box-shadow: var(--shadow-md);
}

.landing-about-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(260px, 0.75fr);
    gap: 1rem;
    align-items: stretch;
}

.landing-about-copy {
    display: flex;
    align-items: center;
}

.landing-about-copy p {
    margin: 0;
    color: color-mix(in srgb, var(--color-text-primary) 78%, white 22%);
    font-size: 1rem;
    line-height: 1.8;
}

.landing-about-photo {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    overflow: hidden;
}

.landing-about-photo img {
    display: block;
    width: 100%;
    max-width: 220px;
    height: auto;
    object-fit: contain;
    border-radius: var(--radius-md);
}

.proposal-page {
    background: linear-gradient(180deg, color-mix(in srgb, var(--color-bg-primary) 92%, var(--color-accent-light) 8%) 0%, var(--color-bg-secondary) 100%);
}

.proposal-page.proposal-page-presentation {
    width: 100%;
    max-width: none;
    margin: 0;
    overflow-x: hidden;
}

.proposal-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    margin: 1rem 0 1.5rem;
}

.proposal-document {
    border: 1px solid color-mix(in srgb, var(--color-border) 78%, var(--color-accent) 22%);
    border-radius: calc(var(--radius-lg) + 2px);
    background: linear-gradient(180deg, color-mix(in srgb, var(--color-bg-card) 97%, white 3%) 0%, var(--color-bg-card) 100%);
    box-shadow: var(--shadow-md);
    overflow: hidden;
}

.proposal-document-header {
    padding: 2rem;
    background: linear-gradient(135deg, color-mix(in srgb, var(--color-accent) 30%, var(--color-bg-secondary) 70%) 0%, color-mix(in srgb, var(--color-bg-secondary) 88%, var(--color-bg-primary) 12%) 100%);
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 80%, var(--color-accent) 20%);
}

.proposal-cover-topline {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    margin-bottom: 1rem;
}

.proposal-logo {
    width: 56px;
    height: 56px;
}

.proposal-brand {
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--color-text-primary);
}

.proposal-document-body {
    padding: 1.75rem;
}

.proposal-meta-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.proposal-meta-card,
.proposal-section-card {
    padding: 1.2rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--color-bg-card) 96%, var(--color-accent-light) 4%);
}

.proposal-section-stack {
    display: grid;
    gap: 1.2rem;
}

.proposal-step-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.proposal-cost-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 0.5rem;
    overflow: hidden;
}

.proposal-cost-table th,
.proposal-cost-table td {
    padding: 0.9rem 0.85rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 82%, var(--color-accent) 18%);
    text-align: left;
}

.proposal-cost-table thead th {
    background: color-mix(in srgb, var(--color-accent-light) 64%, var(--color-bg-card) 36%);
}

.proposal-page-presentation .proposal-document {
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.18);
    transform: scale(1.01);
}

.proposal-page-presentation .proposal-document-header {
    padding: 2.5rem;
}

.proposal-page-presentation .proposal-document-body {
    padding: 2.25rem;
}

.proposal-page-presentation .proposal-section-card,
.proposal-page-presentation .proposal-meta-card {
    background: color-mix(in srgb, white 10%, var(--color-bg-card) 90%);
}

.proposal-presentation-shell {
    min-height: 100vh;
    position: static;
    left: auto;
    width: 100%;
    max-width: none;
    margin-left: 0;
    padding: 0;
    box-sizing: border-box;
    display: grid;
    grid-template-rows: auto 1fr auto;
    gap: 0;
}

.proposal-presentation-topbar {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    flex-wrap: wrap;
    padding: 0.75rem 1.75rem 0.75rem 1rem;
}

.proposal-presentation-slide {
    display: flex;
    align-items: stretch;
    justify-content: stretch;
    width: 100vw;
    max-width: 100vw;
    padding: 1.5rem 2rem;
    border-radius: 0;
    border: 0;
    background: linear-gradient(180deg, color-mix(in srgb, var(--color-bg-card) 98%, white 2%) 0%, var(--color-bg-card) 100%);
    box-shadow: none;
    min-height: calc(100vh - 8rem);
    box-sizing: border-box;
}

.proposal-presentation-slide > div {
    width: 100%;
    max-width: none;
    margin: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.proposal-presentation-slide .landing-grid,
.proposal-presentation-slide .proposal-meta-grid,
.proposal-presentation-slide .proposal-step-grid {
    margin-top: 1.25rem;
}

.proposal-presentation-slide .landing-grid {
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    width: 100%;
}

.proposal-presentation-slide .proposal-meta-grid,
.proposal-presentation-slide .proposal-step-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    width: 100%;
}

.proposal-presentation-nav .btn.disabled,
.proposal-presentation-nav .btn[aria-disabled="True"],
.proposal-presentation-nav .btn[aria-disabled="true"] {
    pointer-events: none;
    opacity: 0.55;
}

.proposal-presentation-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    padding: 0.75rem 1rem 1rem;
}

.proposal-presentation-counter {
    font-weight: 700;
    color: color-mix(in srgb, var(--color-text-primary) 78%, white 22%);
}

@media (max-width: 1080px) {
    .landing-about-grid,
    .proposal-meta-grid,
    .proposal-step-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .landing-image-slide-current {
        height: 100%;
    }

    .landing-image-slide-nav {
        width: 2.45rem;
        height: 2.45rem;
    }

    .landing-about-photo img {
        max-width: 180px;
    }

    .proposal-toolbar {
        flex-direction: column;
    }

    .proposal-presentation-slide {
        width: 100%;
        padding: 1rem;
        min-height: calc(100vh - 8.5rem);
    }

    .proposal-presentation-nav,
    .proposal-presentation-topbar {
        flex-direction: column;
    }
}

@media print {
    /* ── Ocultar elementos no imprimibles ── */
    .proposal-toolbar,
    .proposal-presentation-topbar,
    .proposal-presentation-nav,
    .landing-topbar,
    .public-topbar {
        display: none !important;
    }

    /* ── Base: fondo blanco, textos oscuros, sin fondos decorativos ── */
    *,
    *::before,
    *::after {
        color-scheme: light !important;
        background-image: none !important;
    }

    html, body,
    .proposal-page,
    .proposal-page-presentation {
        background: #fff !important;
        color: #1a1d29 !important;
        font-size: 10pt !important;
        line-height: 1.5 !important;
    }

    /* ── Documento: ocupa todo el ancho sin márgenes internos ── */
    .proposal-document {
        box-shadow: none !important;
        border: none !important;
        max-width: 100% !important;
        width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
        border-radius: 0 !important;
    }

    .proposal-document-body {
        padding: 0 !important;
    }

    .landing-section {
        padding: 0 !important;
    }

    .landing-shell {
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    /* ── Cabecera tipo informe técnico ── */
    .proposal-document-header {
        border-bottom: 2px solid #1a1d29 !important;
        padding-bottom: 0.8rem !important;
        margin-bottom: 0.8rem !important;
        page-break-after: avoid;
        background: none !important;
    }

    .proposal-document-header h1 {
        color: #1a1d29 !important;
        font-size: 16pt !important;
        margin-bottom: 0.3rem !important;
    }

    .proposal-document-header p {
        color: #2d3142 !important;
        font-size: 9.5pt !important;
    }

    .proposal-brand {
        color: #1a1d29 !important;
    }

    .proposal-logo {
        width: 28px !important;
        height: 28px !important;
    }

    .landing-section-kicker {
        color: #2d3142 !important;
        font-size: 9pt !important;
    }

    /* ── Títulos estilo informe ── */
    h1, h2, h3, h4, h5, h6 {
        color: #1a1d29 !important;
        page-break-after: avoid;
    }

    h2 {
        font-size: 12pt !important;
        font-weight: 700 !important;
        border-bottom: 1px solid #1a1d29 !important;
        padding-bottom: 0.2rem !important;
        margin-top: 1rem !important;
        margin-bottom: 0.5rem !important;
    }

    h3 {
        font-size: 10pt !important;
        font-weight: 700 !important;
        color: #1a1d29 !important;
    }

    p, li, td, th, span, div {
        color: #2d3142 !important;
    }

    /* ── Cards: sin fondo, solo borde fino ── */
    .card,
    .proposal-meta-card {
        background: #fff !important;
        border: 1px solid #c0c6d4 !important;
        box-shadow: none !important;
        page-break-inside: avoid;
        border-radius: 4px !important;
    }

    .proposal-section-card {
        background: transparent !important;
        border: none !important;
        box-shadow: none !important;
        padding: 0 !important;
    }

    /* ── Tabla de costos: sin fondo oscuro en encabezado ── */
    .proposal-cost-table {
        border-collapse: collapse !important;
        width: 100% !important;
        font-size: 9pt !important;
    }

    .proposal-cost-table th {
        background: #fff !important;
        color: #1a1d29 !important;
        font-weight: 700 !important;
        font-size: 9pt !important;
        border: 1px solid #1a1d29 !important;
        border-bottom: 2px solid #1a1d29 !important;
    }

    .proposal-cost-table td {
        border: 1px solid #999 !important;
        font-size: 9pt !important;
        color: #2d3142 !important;
        background: #fff !important;
    }

    .proposal-cost-table tr:nth-child(even) td {
        background: #fff !important;
    }

    /* ── Diagrama de arquitectura: sin fondos ── */
    .proposal-arch {
        border: 1px solid #999 !important;
        background: #fff !important;
        padding: 1rem !important;
    }

    .proposal-arch-title {
        color: #1a1d29 !important;
        font-weight: 700 !important;
    }

    .proposal-arch-node {
        border: 1px solid #666 !important;
        background: #fff !important;
    }

    .proposal-arch-node-hub {
        border: 2px solid #1a1d29 !important;
        background: #fff !important;
    }

    .proposal-arch-node-cloud {
        border: 1px solid #666 !important;
        border-style: dashed !important;
        background: #fff !important;
    }

    .proposal-arch-label,
    .proposal-arch-sublabel,
    .proposal-arch-arrow,
    .proposal-arch-group-label {
        color: #1a1d29 !important;
    }

    .proposal-arch-group-label {
        background: #fff !important;
        border: 1px solid #999 !important;
    }

    /* ── Comparación Antes/Después: sin fondos coloreados ── */
    .proposal-compare-col {
        background: #fff !important;
    }

    .proposal-compare-before {
        border-left: 3px solid #1a1d29 !important;
        background: #fff !important;
    }

    .proposal-compare-after {
        border-left: 3px solid #1a1d29 !important;
        border-left-style: double !important;
        background: #fff !important;
    }

    .proposal-compare-col h4,
    .proposal-compare-col li {
        color: #1a1d29 !important;
    }

    /* ── Plano de ubicación: sin fondo ── */
    .proposal-floorplan-zone {
        border: 1px dashed #666 !important;
        background: #fff !important;
    }

    .proposal-floorplan-zone-name,
    .proposal-floorplan-zone-devices {
        color: #1a1d29 !important;
    }

    /* ── KPIs: sin fondo ── */
    .proposal-kpi {
        border: 1px solid #999 !important;
        background: #fff !important;
    }

    .proposal-kpi-value {
        color: #1a1d29 !important;
        font-weight: 800 !important;
    }

    .proposal-kpi-label {
        color: #2d3142 !important;
    }

    /* ── FAQ: sin fondo ── */
    .proposal-faq-item {
        border: 1px solid #c0c6d4 !important;
        background: #fff !important;
    }

    .proposal-faq-q {
        color: #1a1d29 !important;
    }

    .proposal-faq-a {
        color: #2d3142 !important;
    }

    /* ── Checklist ── */
    .landing-checklist li {
        color: #2d3142 !important;
    }

    .landing-checklist li strong {
        color: #1a1d29 !important;
    }

    /* ── Grids: aprovechar ancho completo ── */
    .landing-grid,
    .proposal-meta-grid,
    .proposal-step-grid,
    .proposal-kpi-grid,
    .proposal-compare,
    .proposal-floorplan,
    .proposal-faq {
        page-break-inside: avoid;
    }

    .landing-grid-3 {
        grid-template-columns: repeat(3, 1fr) !important;
    }

    /* ── Modo presentación ── */
    .proposal-presentation-shell {
        padding: 0 !important;
        min-height: auto !important;
    }

    .proposal-presentation-slide {
        background: #fff !important;
        border: none !important;
        box-shadow: none !important;
        min-height: auto !important;
        padding: 0.5rem !important;
    }

    /* ── Página A4 con márgenes estrechos para aprovechar espacio ── */
    @page {
        size: A4;
        margin: 12mm 10mm 14mm 10mm;
    }

    @page :first {
        margin-top: 10mm;
    }
}

/* ========================================
   PROPUESTAS — DIAGRAMA DE ARQUITECTURA
   ======================================== */
.proposal-arch {
    padding: 1.5rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 70%, var(--color-accent) 30%);
    border-radius: var(--radius-lg);
    background: color-mix(in srgb, var(--color-bg-card) 94%, var(--color-accent-light) 6%);
    overflow-x: auto;
}

.proposal-arch-title {
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--color-text-tertiary);
    margin-bottom: 1.25rem;
}

.proposal-arch-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    flex-wrap: wrap;
}

.proposal-arch-node {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.35rem;
    padding: 0.85rem 1rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
    background: var(--color-bg-card);
    min-width: 100px;
    text-align: center;
    box-shadow: var(--shadow-sm);
}

.proposal-arch-node-hub {
    border-color: var(--color-accent);
    background: color-mix(in srgb, var(--color-bg-card) 88%, var(--color-accent-light) 12%);
    box-shadow: 0 6px 18px color-mix(in srgb, var(--color-accent) 14%, transparent 86%);
}

.proposal-arch-node-cloud {
    border-color: var(--color-info);
    background: color-mix(in srgb, var(--color-bg-card) 88%, var(--color-info-light) 12%);
}

.proposal-arch-icon {
    font-size: 1.6rem;
}

.proposal-arch-label {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--color-text-primary);
    line-height: 1.2;
}

.proposal-arch-sublabel {
    font-size: 0.68rem;
    color: var(--color-text-tertiary);
}

.proposal-arch-arrow {
    font-size: 1.1rem;
    color: var(--color-text-tertiary);
    flex-shrink: 0;
    padding: 0 0.15rem;
}

.proposal-arch-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    align-items: center;
}

.proposal-arch-group-label {
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-text-tertiary);
    padding: 0.2rem 0.6rem;
    border-radius: 999px;
    background: var(--color-bg-tertiary);
    border: 1px solid var(--color-border-light);
}

.proposal-arch-stack {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

/* ========================================
   PROPUESTAS — COMPARACIÓN ANTES/DESPUÉS
   ======================================== */
.proposal-compare {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-top: 0.5rem;
}

.proposal-compare-col {
    padding: 1.15rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
}

.proposal-compare-before {
    border-left: 4px solid var(--color-danger);
    background: color-mix(in srgb, var(--color-bg-card) 92%, var(--color-danger-light) 8%);
}

.proposal-compare-after {
    border-left: 4px solid var(--color-success);
    background: color-mix(in srgb, var(--color-bg-card) 92%, var(--color-success-light) 8%);
}

.proposal-compare-col h4 {
    margin: 0 0 0.75rem;
    font-size: 0.92rem;
}

.proposal-compare-col ul {
    margin: 0;
    padding-left: 1.15rem;
    color: var(--color-text-secondary);
    font-size: 0.88rem;
}

.proposal-compare-col li + li {
    margin-top: 0.45rem;
}

/* ========================================
   PROPUESTAS — PLANO DE UBICACIÓN
   ======================================== */
.proposal-floorplan {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 0.75rem;
    margin-top: 0.5rem;
}

.proposal-floorplan-zone {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.35rem;
    padding: 1rem 0.75rem;
    border-radius: var(--radius-md);
    border: 1px dashed var(--color-border);
    background: var(--color-bg-tertiary);
    text-align: center;
}

.proposal-floorplan-zone-icon {
    font-size: 1.8rem;
}

.proposal-floorplan-zone-name {
    font-weight: 600;
    font-size: 0.82rem;
    color: var(--color-text-primary);
}

.proposal-floorplan-zone-devices {
    font-size: 0.72rem;
    color: var(--color-text-tertiary);
    line-height: 1.4;
}

/* ========================================
   PROPUESTAS — INDICADORES KPI
   ======================================== */
.proposal-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 0.75rem;
    margin-top: 0.5rem;
}

.proposal-kpi {
    padding: 1rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
    background: var(--color-bg-card);
    text-align: center;
}

.proposal-kpi-value {
    font-size: 1.55rem;
    font-weight: 800;
    color: var(--color-accent);
    line-height: 1.2;
}

.proposal-kpi-label {
    font-size: 0.75rem;
    color: var(--color-text-tertiary);
    margin-top: 0.2rem;
}

/* ========================================
   PROPUESTAS — FAQ
   ======================================== */
.proposal-faq {
    display: grid;
    gap: 0.65rem;
    margin-top: 0.5rem;
}

.proposal-faq-item {
    padding: 1rem 1.15rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border-light);
    background: var(--color-bg-card);
}

.proposal-faq-q {
    font-weight: 700;
    font-size: 0.9rem;
    color: var(--color-text-primary);
    margin-bottom: 0.35rem;
}

.proposal-faq-a {
    font-size: 0.85rem;
    color: var(--color-text-secondary);
    margin: 0;
    line-height: 1.6;
}

@media (max-width: 640px) {
    .proposal-compare {
        grid-template-columns: 1fr;
    }

    .proposal-arch-row {
        flex-direction: column;
    }

    .proposal-arch-arrow {
        transform: rotate(90deg);
    }
}

/* ========================================
   PROPUESTAS — DOCUMENTACIÓN TÉCNICA
   ======================================== */
.proposal-code {
    display: block;
    padding: 1rem 1.15rem;
    margin: 0.5rem 0;
    border-radius: var(--radius-md);
    background: var(--color-bg-tertiary);
    border: 1px solid var(--color-border);
    color: var(--color-text-primary);
    font-family: 'Cascadia Code', 'Fira Code', 'Consolas', 'Courier New', monospace;
    font-size: 0.8rem;
    line-height: 1.65;
    overflow-x: auto;
    white-space: pre;
    tab-size: 2;
}

.proposal-code-title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--color-text-tertiary);
    margin-bottom: 0.25rem;
}

.proposal-step-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.65rem;
    height: 1.65rem;
    border-radius: 50%;
    background: var(--color-accent);
    color: #fff;
    font-size: 0.78rem;
    font-weight: 800;
    flex-shrink: 0;
}

.proposal-tech-table {
    width: 100%;
    border-collapse: collapse;
    margin: 0.5rem 0;
    font-size: 0.85rem;
}

.proposal-tech-table th,
.proposal-tech-table td {
    padding: 0.6rem 0.75rem;
    border: 1px solid var(--color-border);
    text-align: left;
}

.proposal-tech-table thead th {
    background: color-mix(in srgb, var(--color-accent-light) 50%, var(--color-bg-card) 50%);
    font-weight: 700;
    font-size: 0.82rem;
}

.proposal-tech-note {
    padding: 0.85rem 1rem;
    border-radius: var(--radius-md);
    border-left: 4px solid var(--color-warning);
    background: color-mix(in srgb, var(--color-bg-card) 90%, var(--color-warning-light) 10%);
    font-size: 0.85rem;
    color: var(--color-text-secondary);
    margin: 0.5rem 0;
}

.proposal-tech-note strong {
    color: var(--color-text-primary);
}

.proposal-wiring-diagram {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.5rem 1rem;
    margin: 0.5rem 0;
    font-size: 0.85rem;
    padding: 1rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-bg-card);
}

.proposal-wiring-pin {
    font-family: 'Cascadia Code', 'Consolas', monospace;
    font-weight: 700;
    color: var(--color-accent);
    white-space: nowrap;
}

.proposal-wiring-desc {
    color: var(--color-text-secondary);
}

@media print {
    .proposal-code {
        background: #fff !important;
        border: 1px solid #999 !important;
        font-size: 7.5pt !important;
        color: #1a1d29 !important;
        page-break-inside: avoid;
    }

    .proposal-tech-table th {
        background: #fff !important;
        border-bottom: 2px solid #1a1d29 !important;
    }

    .proposal-tech-note {
        background: #fff !important;
        border-left: 3px solid #666 !important;
    }

    .proposal-wiring-diagram {
        background: #fff !important;
    }

    .proposal-wiring-pin {
        color: #1a1d29 !important;
    }
}

/* ========================================
   PIN GATE (protección de documentos)
   ======================================== */
.pin-gate-overlay {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 2rem 1rem;
    background: var(--color-bg-primary);
    z-index: 200;
}

.pin-gate-card {
    width: min(420px, 100%);
    padding: 2.5rem 2rem;
    border-radius: var(--radius-lg);
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-lg);
    text-align: center;
}

.pin-gate-icon {
    font-size: 3rem;
    margin-bottom: 0.75rem;
}

.pin-gate-card h2 {
    margin-bottom: 0.5rem;
}

.pin-gate-card > p {
    color: var(--color-text-secondary);
    font-size: 0.9rem;
    margin-bottom: 1.5rem;
}

.pin-gate-form {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.pin-gate-input {
    width: 100%;
    padding: 0.85rem 1rem;
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 0.6em;
    text-align: center;
    color: var(--color-text-primary);
    background: var(--color-bg-primary);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-md);
    transition: border-color 0.2s, box-shadow 0.2s;
}

.pin-gate-input:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 4px var(--color-accent-light);
}

.pin-gate-input-error {
    border-color: var(--color-danger);
}

.pin-gate-input-error:focus {
    box-shadow: 0 0 0 4px var(--color-danger-light);
}

.pin-gate-error {
    color: var(--color-danger);
    font-size: 0.85rem;
    font-weight: 600;
    margin-top: 0.25rem;
}

.pin-gate-footer {
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--color-border-light);
}

/* ========================================
   LANDING HOGAR INTELIGENTE
   ======================================== */

/* Problema / Solución cards (2-col grid) */
.landing-grid-2 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

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

.lh-problem-card,
.lh-solution-card {
    display: flex;
    gap: 0.75rem;
    align-items: flex-start;
}

.lh-problem-icon {
    font-size: 1.5rem;
    flex-shrink: 0;
    line-height: 1;
    margin-top: 0.1rem;
}

.lh-problem-card h3 {
    color: var(--color-danger);
}

.lh-solution-card h3 {
    color: var(--color-success);
}

/* FAQ list */
.lh-faq-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.lh-faq-item h3 {
    margin-bottom: 0.35rem;
    font-size: 1rem;
    color: var(--color-accent);
}

.lh-faq-item p {
    margin: 0;
    line-height: 1.6;
}

.landing-section-lh-que-es {
    background:
        linear-gradient(180deg, rgba(10, 16, 30, 0.76) 0%, rgba(10, 16, 30, 0.68) 100%),
        url('/images/hogar-que-es.jpg') center/cover no-repeat;
}

html[data-theme="claro"] .landing-section-lh-que-es .landing-section-header h2,
html[data-theme="claro"] .landing-section-lh-que-es .landing-section-header p,
html[data-theme="claro"] .landing-section-lh-que-es .landing-section-header span {
    color: #ffffff;
}

html[data-theme="claro"] .landing-section-lh-que-es .landing-card-accent {
    background: rgba(255, 255, 255, 0.95);
}

.landing-section-lh-que-instala {
    background:
        linear-gradient(180deg, rgba(10, 16, 30, 0.8) 0%, rgba(10, 16, 30, 0.72) 100%),
        url('/images/hogar-que-instala.jpg') center/cover no-repeat;
}

html[data-theme="claro"] .landing-section-lh-que-instala .landing-section-header h2,
html[data-theme="claro"] .landing-section-lh-que-instala .landing-section-header p,
html[data-theme="claro"] .landing-section-lh-que-instala .landing-section-header span {
    color: #ffffff;
}

html[data-theme="claro"] .landing-section-lh-que-instala .landing-card-accent {
    background: rgba(255, 255, 255, 0.95);
}

.landing-section-lh-faq {
    background-color: var(--color-bg-secondary);
}

html[data-theme="claro"] .landing-section-lh-faq {
    background-color: color-mix(in srgb, var(--color-bg-secondary) 85%, var(--color-accent-light) 15%);
}

.landing-hero-home-solutions {
    background:
        linear-gradient(180deg, rgba(10, 16, 30, 0.84) 0%, rgba(10, 16, 30, 0.72) 100%),
        url('/images/hogar-que-instala.jpg') center/cover no-repeat;
}

.landing-section-home-solutions-intro,
.landing-section-home-solutions-list {
    background: transparent;
}

.landing-section-home-solutions-intro {
    padding-bottom: 1.35rem;
}

.landing-section-home-solutions-list {
    padding-top: 1.1rem;
}

.home-solution-list {
    display: grid;
    gap: 1rem;
}

.home-solution-card {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: start;
    gap: 1rem;
    padding: 1.1rem 1.15rem;
    border: 1px solid color-mix(in srgb, var(--color-border) 82%, var(--color-accent) 18%);
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--color-bg-secondary) 96%, white 4%) 0%, color-mix(in srgb, var(--color-bg-secondary) 88%, var(--color-accent-light) 12%) 100%);
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.12);
}

.home-solution-icon {
    width: 3.2rem;
    height: 3.2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
    background: color-mix(in srgb, var(--color-accent-light) 30%, transparent 70%);
    color: var(--color-accent);
    font-size: 1.6rem;
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-accent) 14%, transparent 86%);
}

.home-solution-body {
    display: grid;
    gap: 0.45rem;
    min-width: 0;
}

.home-solution-headline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.home-solution-headline h3 {
    margin: 0;
    color: var(--color-accent);
    font-size: 1.14rem;
}

.home-solution-body p {
    margin: 0;
    line-height: 1.65;
    color: var(--color-text-secondary);
}


.home-solution-summary-card h3 {
    color: var(--color-accent);
}

.home-solution-summary-card p {
    margin: 0;
    line-height: 1.65;
}

html[data-theme="claro"] .home-solution-card {
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    border-color: color-mix(in srgb, var(--color-accent) 18%, #cbd5e1 82%);
}

html[data-theme="claro"] .home-solution-body p,
html[data-theme="claro"] .home-solution-summary-card p {
    color: #334155;
}

@media (max-width: 720px) {
    .home-solution-card {
        grid-template-columns: auto 1fr;
    }

    .home-solution-icon {
        width: 2.9rem;
        height: 2.9rem;
        font-size: 1.45rem;
    }

    .home-solution-headline {
        align-items: flex-start;
        flex-direction: column;
    }
}

/* ========================================
   ADMIN HUB
   ======================================== */
.admin-hub-page {
    min-height: 100vh;
    display: flex;
    justify-content: center;
    background:
        radial-gradient(circle at top left, var(--color-accent-light), transparent 34rem),
        var(--color-bg-primary);
    padding: 2rem 1rem 3rem;
}

.admin-hub-shell {
    width: 1320px;
    max-width: calc(100vw - 2rem);
    margin: 0 auto;
}

.admin-hub-header,
.admin-hub-nav,
.admin-hub-content > * {
    width: 100%;
    max-width: 1320px;
    margin-left: auto;
    margin-right: auto;
}

.admin-auth-card {
    width: 560px;
    max-width: min(560px, calc(100vw - 2rem));
    margin: 8vh auto 0;
    text-align: center;
}

.admin-auth-card .pin-gate-form,
.admin-auth-card .pin-gate-footer,
.admin-auth-card .pin-gate-error,
.admin-auth-card .alert {
    width: 100%;
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
}

.admin-auth-card .pin-gate-input,
.admin-auth-card .btn-block {
    width: 100%;
}

.admin-auth-icon {
    font-size: 3rem;
    margin-bottom: 0.75rem;
}

.admin-auth-hint,
.admin-muted {
    color: var(--color-text-secondary);
    margin: 0.75rem 0 0;
}

.admin-pin-form {
    margin-top: 1rem;
}

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

.admin-hub-header h1,
.admin-hub-header p {
    margin-bottom: 0;
}

.admin-hub-header p {
    color: var(--color-text-secondary);
    max-width: 760px;
}

.admin-hub-header-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.admin-hub-nav {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
    margin: 0 auto 1.25rem;
}

.admin-hub-nav-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 180px;
    padding: 0.65rem 1rem;
    border: 1px solid var(--color-border);
    border-radius: 999px;
    background: var(--color-bg-card);
    color: var(--color-text-primary);
    box-shadow: var(--shadow-sm);
}

.admin-hub-nav-link.active,
.admin-hub-nav-link:hover {
    background: var(--color-accent);
    color: #ffffff;
    text-decoration: none;
}

.admin-hub-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.25rem;
}

.admin-stats-grid,
.admin-grid-2,
.admin-proposal-grid {
    display: grid;
    gap: 1rem;
}

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

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

.admin-stat-card {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.admin-stat-card span {
    font-size: 1.8rem;
}

.admin-stat-card strong {
    font-size: 2rem;
    line-height: 1;
}

.admin-stat-card p {
    margin: 0;
    color: var(--color-text-secondary);
}

.admin-panel-card h2,
.admin-proposal-section h2 {
    margin-bottom: 0.75rem;
}

.admin-action-list,
.admin-contact-mini-list,
.admin-contact-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.admin-action-link {
    display: flex;
    gap: 0.75rem;
    align-items: flex-start;
    padding: 0.85rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-bg-secondary);
    color: var(--color-text-primary);
}

.admin-action-link:hover {
    border-color: var(--color-accent);
    text-decoration: none;
}

.admin-action-link span {
    font-size: 1.4rem;
}

.admin-action-link small,
.admin-contact-mini-list small,
.admin-proposal-card small {
    display: block;
    color: var(--color-text-secondary);
}

.admin-contact-mini-list > div {
    border-bottom: 1px solid var(--color-border-light);
    padding-bottom: 0.75rem;
}

.admin-proposal-section {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

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

.admin-section-heading span {
    color: var(--color-text-secondary);
    font-size: 0.9rem;
}

.admin-proposal-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: stretch;
    width: 100%;
}

.admin-proposal-card {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
    min-height: 100%;
    overflow: hidden;
}

.admin-proposal-card p {
    margin: 0;
}

.admin-proposal-summary {
    color: var(--color-text-secondary);
    line-height: 1.6;
}

.admin-proposal-card-header {
    display: flex;
    gap: 0.75rem;
    align-items: flex-start;
}

.admin-proposal-card-header > span {
    font-size: 2rem;
}

.admin-proposal-card-header h3 {
    margin-bottom: 0.15rem;
}

.admin-proposal-highlight-box {
    display: grid;
    gap: 0.25rem;
    padding: 0.85rem;
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--color-accent-light) 38%, var(--color-bg-secondary) 62%);
}

.admin-proposal-highlight-box span {
    color: var(--color-text-secondary);
    line-height: 1.5;
}

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

.admin-proposal-meta div,
.admin-contact-grid div,
.admin-system-list div,
.admin-flyer-details div {
    display: grid;
    gap: 0.15rem;
}

.admin-proposal-meta dt,
.admin-contact-grid strong,
.admin-system-list dt,
.admin-flyer-details strong {
    color: var(--color-text-secondary);
    font-size: 0.82rem;
}

.admin-proposal-meta dd,
.admin-system-list dd {
    margin: 0;
}

.admin-proposal-bullets {
    display: grid;
    gap: 0.45rem;
    padding-left: 1.1rem;
    margin: 0;
}

.admin-proposal-bullets li {
    color: var(--color-text-secondary);
}

.admin-link-row {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-top: auto;
}

.admin-link-row-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: stretch;
}

.admin-link-row-grid .btn:last-child,
.admin-link-row-grid .btn:nth-last-child(2) {
    grid-column: span 1;
}

.admin-link-row-grid .btn {
    width: 100%;
}

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

    .admin-proposal-meta,
    .admin-link-row-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

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

@media (max-width: 640px) {
    .admin-section-heading {
        align-items: flex-start;
        flex-direction: column;
    }

    .admin-proposals-toolbar {
        align-items: flex-start;
        flex-direction: column;
    }

    .admin-proposal-meta,
    .admin-link-row-grid {
        grid-template-columns: 1fr;
    }
}

.admin-print-toolbar,
.admin-table-header,
.admin-proposals-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.admin-print-toolbar p,
.admin-table-header p,
.admin-proposals-toolbar p {
    color: var(--color-text-secondary);
    margin: 0;
}

.admin-contact-card {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-bg-secondary);
    padding: 1rem;
}

.admin-contact-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.admin-contact-card-header h3,
.admin-contact-message p {
    margin-bottom: 0;
}

.admin-contact-card-header span,
.admin-contact-message {
    color: var(--color-text-secondary);
}

.admin-status-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 0.25rem 0.65rem;
    background: var(--color-success-light);
    color: var(--color-success);
    font-weight: 700;
    white-space: nowrap;
}

.admin-status-pill-reviewed {
    background: var(--color-info-light);
    color: var(--color-info);
}

.btn-danger {
    background-color: var(--color-danger);
    color: #ffffff;
}

.btn-danger:hover {
    background-color: color-mix(in srgb, var(--color-danger) 88%, #000000 12%);
}

.admin-contact-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.admin-contact-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    padding-top: 0.85rem;
    border-top: 1px solid var(--color-border-light);
    margin-top: 0.25rem;
}

.admin-contact-check {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    color: var(--color-text-secondary);
}

.admin-contact-delete-confirm {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.admin-contact-message {
    padding-top: 0.75rem;
    border-top: 1px solid var(--color-border-light);
}

.admin-system-list,
.admin-check-list {
    display: grid;
    gap: 0.75rem;
    margin: 0;
}

.admin-check-list {
    padding-left: 1.1rem;
}

.admin-flyer-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 360px));
    justify-content: center;
    gap: 1.25rem;
}

.admin-flyer-single {
    display: flex;
    justify-content: center;
    width: 100%;
}

.admin-flyer-a5 {
    display: flex;
    flex-direction: column;
    min-height: 595px;
    aspect-ratio: 148 / 210;
    box-sizing: border-box;
    padding: 1.15rem;
    border-radius: 18px;
    border: 1px solid #93c5fd;
    color: #0f172a;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    box-shadow: 0 14px 32px rgba(37, 99, 235, 0.14);
    overflow: hidden;
    page-break-inside: avoid;
    break-inside: avoid;
    scroll-margin-top: 1.5rem;
}

.admin-flyer-topline {
    font-size: 0.9rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #475569;
    font-weight: 700;
}

.admin-flyer-header {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.85rem;
    align-items: start;
    margin: 0.9rem 0 0.3rem;
}

.admin-flyer-icon {
    font-size: 2.85rem;
    line-height: 1;
}

.admin-flyer-a5 h2 {
    color: #1d4ed8;
    font-size: 2rem;
    line-height: 1.08;
    margin-bottom: 0.25rem;
    font-weight: 800;
}

.admin-flyer-a5 h3 {
    color: #7c3aed;
    font-size: 0.95rem;
    line-height: 1.45;
    margin-bottom: 0;
    font-weight: 700;
}

.admin-flyer-lead,
.admin-flyer-a5 li,
.admin-flyer-details span,
.admin-flyer-cta-box span {
    color: #0f172a;
    font-size: 0.92rem;
}

.admin-flyer-lead {
    margin: 0.7rem 0 0;
    line-height: 1.6;
    font-size: 0.95rem;
}

.admin-flyer-highlight {
    margin: 0.85rem 0;
    padding: 0.7rem 0.8rem;
    border-radius: 12px;
    background: #eff6ff;
    border-left: 4px solid #2563eb;
    color: #1e3a8a;
    font-weight: 700;
    line-height: 1.5;
}

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

.admin-flyer-columns section {
    min-width: 0;
    padding: 0.75rem;
    border-radius: 14px;
    border: 1px solid #d8e2f0;
    background: #f8fafc;
}

.admin-flyer-columns h4 {
    margin: 0 0 0.45rem;
    color: #0f172a;
    font-size: 0.95rem;
    font-weight: 800;
}

.admin-flyer-a5 ul {
    display: grid;
    gap: 0.38rem;
    margin: 0;
    padding-left: 1rem;
}

.admin-flyer-kpis {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
    margin-top: 0.9rem;
}

.admin-flyer-kpi {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    min-height: 3rem;
    padding: 0.45rem;
    border-radius: 12px;
    background: #eef2ff;
    border: 1px solid #c7d2fe;
    color: #312e81;
    font-size: 0.9rem;
    font-weight: 700;
}

.admin-flyer-details {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.65rem;
    margin-top: 0.9rem;
}

.admin-flyer-cta-box {
    display: grid;
    gap: 0.3rem;
    margin-top: 0.9rem;
    padding: 0.8rem;
    border-radius: 14px;
    background: #fff7ed;
    border: 1px solid #fdba74;
    color: #9a3412;
}

.admin-flyer-actions {
    margin-top: auto;
    padding-top: 0.9rem;
    border-top: 1px solid rgba(255, 255, 255, 0.2);
}

.admin-flyer-actions span,
.admin-flyer-actions strong {
    display: block;
}

.admin-flyer-actions span {
    color: #475569;
    font-size: 0.9rem;
    font-weight: 700;
}

.admin-flyer-actions strong {
    color: #1d4ed8;
    word-break: break-word;
    line-height: 1.4;
    font-size: 0.95rem;
}

.admin-flyer-home {
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    border-color: #93c5fd;
    box-shadow: 0 14px 32px rgba(37, 99, 235, 0.14);
}

.admin-flyer-a4 {
    min-height: 420px;
    aspect-ratio: 297 / 210;
    padding: 1.1rem 1.2rem;
}

.admin-flyer-columns-landscape {
    grid-template-columns: 1.15fr 1fr;
}

.admin-flyer-a4 .admin-flyer-header {
    margin: 0.55rem 0 0.2rem;
}

.admin-flyer-a4 .admin-flyer-highlight-img {
    height: 150px;
}

.admin-flyer-a4 .admin-flyer-kpis,
.admin-flyer-a4 .admin-flyer-details {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.admin-flyer-single-landscape {
    max-width: 297mm;
}

.admin-flyer-home-badge {
    align-self: flex-start;
    position: relative;
    z-index: 1;
    margin-top: 0.2rem;
    margin-bottom: 0.45rem;
    padding: 0.5rem 1.05rem;
    border-radius: 999px;
    background: linear-gradient(135deg, #fde047, #fb923c);
    color: #111827;
    font-size: 1rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    box-shadow: 0 8px 16px rgba(17, 24, 39, 0.18);
    border: 1px solid rgba(255, 255, 255, 0.5);
}

.admin-flyer-home-intro {
    display: grid;
    gap: 0.35rem;
    position: relative;
    z-index: 2;
    margin-top: 0.7rem;
    padding: 0.8rem 0.85rem;
    border-radius: 12px;
    background: linear-gradient(135deg, #eff6ff, #f5f3ff);
    border: 1px solid #c4b5fd;
    box-shadow: 0 8px 20px rgba(59, 130, 246, 0.12);
}

.admin-flyer-home-intro strong {
    color: #1d4ed8;
    font-size: 1rem;
}

.admin-flyer-home-intro span {
    color: #334155;
    font-size: 0.92rem;
    line-height: 1.55;
}

.admin-flyer-highlight-img {
    margin: 0.6rem 0 0.7rem;
    border-radius: 16px;
    overflow: hidden;
    height: 168px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255, 255, 255, 0.24);
    box-shadow: 0 14px 30px rgba(15, 23, 42, 0.28);
}

.admin-flyer-highlight-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Flyer A5 Components & Printing adjustments */

.admin-flyer-home-vectors {
    display: flex;
    justify-content: space-around;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.75rem;
    padding: 0.7rem;
    background: linear-gradient(135deg, rgba(255,255,255,0.18), rgba(255,255,255,0.05));
    border-radius: 12px;
}

.admin-flyer-vector {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.4rem;
    color: #334155;
}

.admin-flyer-vector svg {
    width: 2.2rem;
    height: 2.2rem;
    color: #f97316;
}

.admin-flyer-vector span {
    font-size: 0.9rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.admin-flyer-columns {
    gap: 0.7rem;
    margin-top: 0.75rem;
}

.admin-flyer-columns h4 {
    margin-bottom: 0.35rem;
}

.admin-flyer-a5 li {
    margin-bottom: 0.22rem;
}

.admin-flyer-qr {
    width: 84px;
    height: 84px;
    flex: 0 0 84px;
    border-radius: 6px;
    border: 3px solid white;
    box-shadow: 0 4px 6px rgba(0,0,0,0.15);
    background: white;
}

.admin-flyer-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: auto;
    padding-top: 0.7rem;
    border-top: 2px solid #dbeafe;
}

.admin-flyer-actions-text {
    display: flex;
    flex-direction: column;
}

@media (max-width: 640px) {
    .admin-flyer-columns,
    .admin-flyer-kpis,
    .admin-flyer-details,
    .admin-flyer-home-vectors,
    .admin-flyer-columns-landscape {
        grid-template-columns: 1fr;
        flex-direction: column;
    }
}

@media (max-width: 720px) {
    .admin-hub-header,
    .admin-print-toolbar,
    .admin-table-header {
        align-items: stretch;
        flex-direction: column;
    }

    .admin-hub-header-actions {
        justify-content: flex-start;
    }
}

@media print {
    @page {
        size: A5 portrait;
        margin: 0;
    }

    @page flyer-landscape {
        size: A4 landscape;
        margin: 0;
    }

    html,
    body {
        width: 148mm;
        height: 210mm;
        min-width: 148mm;
        max-width: 148mm;
        min-height: 210mm;
        max-height: 210mm;
        margin: 0 !important;
        padding: 0 !important;
        overflow: hidden !important;
        background: #ffffff !important;
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
    }

    html.admin-print-landscape,
    body.admin-print-landscape {
        width: 297mm !important;
        height: 210mm !important;
        min-width: 297mm !important;
        max-width: 297mm !important;
        min-height: 210mm !important;
        max-height: 210mm !important;
        overflow: hidden !important;
    }

    body {
        background: #ffffff !important;
    }

    .proposal-toolbar,
    .topbar,
    .public-topbar,
    .admin-hub-header,
    .admin-hub-nav,
    .admin-print-toolbar,
    .admin-proposal-section {
        display: none !important;
    }

    .landing-page,
    .landing-section,
    .landing-shell,
    .admin-flyer-single,
    .admin-hub-page,
    .admin-hub-shell,
    .admin-hub-content,
    .admin-flyer-list {
        display: block;
        margin: 0 !important;
        padding: 0 !important;
        width: 148mm !important;
        min-width: 148mm !important;
        max-width: 148mm !important;
        overflow: hidden !important;
        background: #ffffff !important;
    }

    .admin-flyer-single-landscape {
        width: 297mm !important;
        min-width: 297mm !important;
        max-width: 297mm !important;
        height: 210mm !important;
        min-height: 210mm !important;
        max-height: 210mm !important;
        margin: 0 !important;
        overflow: hidden !important;
    }

    body.admin-print-landscape .landing-page,
    body.admin-print-landscape .landing-section,
    body.admin-print-landscape .landing-shell,
    body.admin-print-landscape .admin-flyer-single,
    body.admin-print-landscape .admin-hub-page,
    body.admin-print-landscape .admin-hub-shell,
    body.admin-print-landscape .admin-hub-content,
    body.admin-print-landscape .admin-flyer-list {
        width: 297mm !important;
        min-width: 297mm !important;
        max-width: 297mm !important;
        height: 210mm !important;
        min-height: 210mm !important;
        max-height: 210mm !important;
        overflow: hidden !important;
    }

    .admin-flyer-a5 {
        width: 148mm;
        height: 210mm;
        min-height: 210mm;
        max-height: 210mm;
        aspect-ratio: auto;
        border: 1px solid #cbd5e1;
        border-radius: 0;
        box-shadow: none;
        page-break-after: auto;
        break-after: auto;
        page-break-inside: avoid;
        break-inside: avoid;
        margin: 0 !important;
        padding: 5mm 5mm 4mm !important;
        overflow: hidden;
        background: #ffffff !important;
        color: #0f172a !important;
    }

    .admin-flyer-topline {
        font-size: 0.9rem;
    }

    .admin-flyer-a4 {
        page: flyer-landscape;
        display: flex !important;
        flex-direction: column !important;
        width: 297mm !important;
        min-width: 297mm !important;
        max-width: 297mm !important;
        height: 210mm !important;
        min-height: 210mm !important;
        max-height: 210mm !important;
        aspect-ratio: auto;
        box-sizing: border-box !important;
        margin: 0 !important;
        padding: 6mm 8mm 5mm !important;
        page-break-before: avoid !important;
        break-before: avoid !important;
        page-break-after: avoid !important;
        break-after: avoid !important;
        page-break-inside: avoid !important;
        break-inside: avoid !important;
        overflow: hidden !important;
    }

    .admin-flyer-header {
        margin: 0.55rem 0 0.2rem;
        gap: 0.7rem;
    }

    .admin-flyer-icon {
        font-size: 2.5rem;
    }

    .admin-flyer-a5 h2 {
        font-size: 1.78rem;
    }

    .admin-flyer-a5 h3 {
        font-size: 0.95rem;
        line-height: 1.35;
    }

    .admin-flyer-lead,
    .admin-flyer-a5 li,
    .admin-flyer-details span,
    .admin-flyer-actions span,
    .admin-flyer-actions strong,
    .admin-flyer-home-intro span,
    .admin-flyer-vector span,
    .admin-flyer-columns h4,
    .admin-flyer-kpi,
    .admin-flyer-cta-box span {
        font-size: 0.9rem;
        line-height: 1.35;
    }

    .admin-flyer-home-intro {
        margin-top: 0.35rem;
        padding: 0.65rem 0.75rem;
    }

    .admin-flyer-home-vectors {
        margin-top: 0.55rem;
        padding: 0.55rem 0.6rem;
    }

    .admin-flyer-vector svg {
        width: 1.9rem;
        height: 1.9rem;
    }

    .admin-flyer-vector span {
        font-size: 0.66rem;
    }

    .admin-flyer-highlight-img {
        height: 185px;
        margin: 0.55rem 0 0.55rem;
    }

    .admin-flyer-columns {
        gap: 0.55rem;
        margin-top: 0.55rem;
    }

    .admin-flyer-columns section {
        padding: 0.7rem;
    }

    .admin-flyer-cta-box {
        margin-top: 0.55rem;
        padding: 0.65rem 0.7rem;
    }

    .admin-flyer-actions {
        margin-top: auto;
        padding-top: 0.5rem;
        gap: 0.7rem;
    }

    .admin-flyer-qr {
        width: 78px;
        height: 78px;
        flex-basis: 78px;
    }

    .admin-flyer-a4 .admin-flyer-header {
        margin: 0.25rem 0 0.15rem;
        gap: 0.6rem;
    }

    .admin-flyer-a4 .admin-flyer-a5 h2,
    .admin-flyer-a4 h2 {
        font-size: 1.7rem;
    }

    .admin-flyer-a4 .admin-flyer-highlight-img {
        height: 125px;
        margin: 0.45rem 0 0.45rem;
    }

    .admin-flyer-a4 .admin-flyer-columns,
    .admin-flyer-a4 .admin-flyer-kpis,
    .admin-flyer-a4 .admin-flyer-details {
        gap: 0.45rem;
        margin-top: 0.45rem;
    }
}
