﻿/* Variables de colores base - Paleta moderna y profesional */
/* =============================================================
Paleta: Navy #011d7d (primario) + Cyan #0891b2 (acento)
Modo claro | Modo oscuro | data-theme light | data-theme dark
============================================================= */
:root {
/* Primarios - Navy profundo #011d7d */
--checkbox-color: #93FF63;
--primary-color: #011d7d;
--primary-light: #2d4fa6;
--primary-dark: #010e47;
--primary-hover: #0a2592;
--primary-foreground: #ffffff;
/* Secundarios - Slate neutro */
--secondary-color: #475569;
--secondary-light: #64748b;
--secondary-dark: #334155;
--secondary-foreground: #ffffff;
/* Acentos - Cyan/Teal  ← familia completamente diferente al azul anterior */
--accent-color: #0891b2;
--accent-light: #06b6d4;
--accent-dark: #0e7490;
--accent-foreground: #ffffff;
/* Estados - Colores semánticos modernos */
--success-color: #10b981;
--success-background: #d1fae5;
--success-foreground: #065f46;
--success-light: #34d399;
--success-dark: #059669;
--warning-color: #f59e0b;
--warning-background: #fef3c7;
--warning-foreground: #78350f;
--warning-light: #fbbf24;
--warning-dark: #d97706;
--danger-color: #ef4444;
--danger-background: #fee2e2;
--danger-foreground: #991b1b;
--danger-light: #f87171;
--danger-dark: #dc2626;
--info-color: #3b82f6;
--info-background: #dbeafe;
--info-foreground: #1e40af;
--info-light: #60a5fa;
--info-dark: #2563eb;
/* Texto - Mayor contraste y legibilidad */
--text-color: #0f172a;
--text-light: #ffffff;
--text-muted: #64748b;
--text-secondary: #475569;
--error-text: #dc2626;
--success-text: #059669;
/* Fondos - Más limpios y modernos */
--background-color: #f8fafc;
--secondary-background: #f1f5f9;
--surface-color: #ffffff;
--surface-alt-color: #f8fafc;
--card-bg-color: #ffffff;
--card-category-bg-color: #f1f5f9;
--card-category-selected-color: #011d7d;
--card-aditional-bg-color: #f8fafc;
--selected-aditional-color: #011d7d;
--overlay-color: rgba(1, 8, 40, 0.6);
/* Bordes y divisores - Más sutiles */
--border-color: #e2e8f0;
--border-light: #f1f5f9;
--divider-color: #e2e8f0;
--focus-color: #011d7d;
--focus-ring: rgba(8, 145, 178, 0.3);
/* Estados interactivos */
--highlight-color: #011d7d;
--hover-color: #0e7490;
--hover-background-color: #ecfeff;
--selected-color: #011d7d;
--active-color: #010e47;
/* Deshabilitado */
--disabled-color: #94a3b8;
--disabled-background: #f1f5f9;
/* Sombras */
--shadow-xs: 0 1px 2px 0 rgba(1, 14, 71, 0.05);
--shadow-sm: 0 1px 3px 0 rgba(1, 14, 71, 0.1), 0 1px 2px -1px rgba(1, 14, 71, 0.1);
--shadow-md: 0 4px 6px -1px rgba(1, 14, 71, 0.12), 0 2px 4px -2px rgba(1, 14, 71, 0.1);
--shadow-lg: 0 10px 15px -3px rgba(1, 14, 71, 0.12), 0 4px 6px -4px rgba(1, 14, 71, 0.1);
--shadow-xl: 0 20px 25px -5px rgba(1, 14, 71, 0.14), 0 8px 10px -6px rgba(1, 14, 71, 0.1);
--shadow-color: rgba(1, 14, 71, 0.1);
/* Links — usan el acento cyan para diferenciarse visualmente del primario */
--link-color: #0891b2;
--link-hover-color: #0e7490;
--link-hover-text-color: #0e7490;
--badge-color: #ffffff;
--badge-bg: #011d7d;
--badge-overlay-bg: rgba(1, 8, 40, 0.85);
--badge-overlay-border: rgba(255, 255, 255, 0.1);
/* Tablas */
--table-header-bg: #f0f9ff;
--table-header-text: #011d7d;
--table-row-hover: #ecfeff;
--table-border: #e2e8f0;
/* Eventos */
--events-pill-bg: rgba(255, 255, 255, 0.92);
--events-pill-border: rgba(6, 182, 212, 0.25);
--events-pill-shadow: 0 2px 16px rgba(1, 8, 40, 0.10), 0 1px 4px rgba(8, 145, 178, 0.07);
--events-card-accent: var(--accent-color);
--events-card-image-bg: var(--surface-alt-color);
/* Glassmorphism */
--glass-bg: rgba(255, 255, 255, 0.75);
--glass-border: rgba(6, 182, 212, 0.2);
--glass-blur: 16px;
--gradient-primary: linear-gradient(135deg, var(--primary-color) 0%, var(--accent-color) 100%);
--gradient-accent: linear-gradient(135deg, var(--accent-color) 0%, var(--accent-light) 100%);
--gradient-surface: linear-gradient(180deg, var(--surface-color) 0%, var(--surface-alt-color) 100%);
/* TopBar */
--topbar-bg: rgba(255, 255, 255, 0.82);
--topbar-border: rgba(6, 182, 212, 0.2);
--topbar-shadow: 0 1px 3px rgba(1, 8, 40, 0.06), 0 4px 16px rgba(1, 8, 40, 0.04);
--topbar-accent-gradient: linear-gradient(90deg, var(--primary-color) 0%, var(--accent-color) 100%);
--topbar-nav-bg: #f0f9ff;
--topbar-nav-border: #e0f2fe;
--topbar-nav-link-hover-bg: #ecfeff;
--topbar-nav-link-hover-border: #a5f3fc;
--topbar-dropdown-hover-bg: #ecfeff;
/* Sidebar */
--sidebar-header-bg: #f0f9ff;
--sidebar-active-bg: rgba(8, 145, 178, 0.08);
--sidebar-active-border: var(--accent-color);
/* Card */
--card-hover-border: rgba(8, 145, 178, 0.3);
--card-accent-gradient: linear-gradient(135deg, var(--primary-color) 0%, var(--accent-color) 100%);
/* Loader */
--loader-dot-color: #011d7d;
--loader-bg: #0f172a;
}
/* Modo oscuro automático - sigue preferencia del SO */
@media (prefers-color-scheme: dark) {
:root:not([data-theme='light']) {
/* Primarios - Navy brightened para fondos oscuros */
--primary-color: #4d73d6;
--primary-light: #6b8fe0;
--primary-dark: #011d7d;
--primary-hover: #6b8fe0;
--primary-foreground: #ffffff;
/* Secundarios - Slate */
--secondary-color: #94a3b8;
--secondary-light: #cbd5e1;
--secondary-dark: #64748b;
--secondary-foreground: #0f172a;
/* Acentos - Cyan vibrante para dark ← muy distinto del azul anterior */
--accent-color: #22d3ee;
--accent-light: #67e8f9;
--accent-dark: #06b6d4;
--accent-foreground: #011d7d;
/* Estados - Colores semánticos para dark */
--success-color: #34d399;
--success-background: #064e3b;
--success-foreground: #d1fae5;
--success-light: #6ee7b7;
--success-dark: #10b981;
--warning-color: #fbbf24;
--warning-background: #78350f;
--warning-foreground: #fef3c7;
--warning-light: #fcd34d;
--warning-dark: #f59e0b;
--danger-color: #f87171;
--danger-background: #7f1d1d;
--danger-foreground: #fee2e2;
--danger-light: #fca5a5;
--danger-dark: #ef4444;
--info-color: #60a5fa;
--info-background: #1e3a8a;
--info-foreground: #dbeafe;
--info-light: #93c5fd;
--info-dark: #3b82f6;
/* Texto - Alto contraste */
--text-color: #f1f5f9;
--text-light: #ffffff;
--text-muted: #94a3b8;
--text-secondary: #cbd5e1;
--error-text: #fca5a5;
--success-text: #6ee7b7;
/* Fondos - Grises oscuros modernos */
--background-color: #0f172a;
--secondary-background: #1e293b;
--surface-color: #1e293b;
--surface-alt-color: #0f172a;
--card-bg-color: #1e293b;
--card-category-bg-color: #334155;
--card-category-selected-color: #5580e0;
--card-aditional-bg-color: #1e293b;
--selected-aditional-color: #5580e0;
--overlay-color: rgba(0, 0, 0, 0.8);
/* Bordes y divisores */
--border-color: #334155;
--border-light: #1e293b;
--divider-color: #334155;
--focus-color: #22d3ee;
--focus-ring: rgba(34, 211, 238, 0.4);
/* Estados interactivos */
--highlight-color: #22d3ee;
--hover-color: #67e8f9;
--hover-background-color: rgba(34, 211, 238, 0.1);
--selected-color: #22d3ee;
--active-color: #011d7d;
/* Deshabilitado */
--disabled-color: #64748b;
--disabled-background: #334155;
/* Sombras */
--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.4);
--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, 0.5), 0 1px 2px -1px rgba(0, 0, 0, 0.5);
--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.5), 0 2px 4px -2px rgba(0, 0, 0, 0.5);
--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.5), 0 4px 6px -4px rgba(0, 0, 0, 0.5);
--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.6), 0 8px 10px -6px rgba(0, 0, 0, 0.6);
--shadow-color: rgba(0, 0, 0, 0.5);
/* Links — cyan vibrante en dark */
--link-color: #22d3ee;
--link-hover-color: #67e8f9;
--link-hover-text-color: #67e8f9;
--badge-color: #011d7d;
--badge-bg: #22d3ee;
--badge-overlay-bg: rgba(0, 0, 0, 0.9);
--badge-overlay-border: rgba(34, 211, 238, 0.2);
/* Tablas */
--table-header-bg: #0c1a3a;
--table-header-text: #22d3ee;
--table-row-hover: rgba(34, 211, 238, 0.06);
--table-border: #334155;
/* Eventos */
--events-pill-bg: rgba(12, 26, 58, 0.95);
--events-pill-border: rgba(34, 211, 238, 0.2);
--events-pill-shadow: 0 2px 16px rgba(0, 0, 0, 0.35), 0 1px 4px rgba(34, 211, 238, 0.1);
--events-card-accent: var(--accent-color);
--events-card-image-bg: var(--surface-alt-color);
/* Glassmorphism */
--glass-bg: rgba(12, 26, 58, 0.75);
--glass-border: rgba(34, 211, 238, 0.2);
--glass-blur: 16px;
--gradient-primary: linear-gradient(135deg, var(--primary-color) 0%, var(--accent-color) 100%);
--gradient-accent: linear-gradient(135deg, var(--accent-color) 0%, var(--accent-light) 100%);
--gradient-surface: linear-gradient(180deg, var(--surface-color) 0%, var(--surface-alt-color) 100%);
/* TopBar */
--topbar-bg: rgba(1, 5, 25, 0.95);
--topbar-border: rgba(34, 211, 238, 0.15);
--topbar-shadow: 0 1px 3px rgba(0, 0, 0, 0.25), 0 4px 16px rgba(34, 211, 238, 0.06);
--topbar-accent-gradient: linear-gradient(90deg, var(--primary-color), var(--accent-color), var(--accent-light));
--topbar-nav-bg: rgba(1, 5, 25, 0.6);
--topbar-nav-border: rgba(34, 211, 238, 0.12);
--topbar-nav-link-hover-bg: rgba(34, 211, 238, 0.08);
--topbar-nav-link-hover-border: rgba(34, 211, 238, 0.2);
--topbar-dropdown-hover-bg: rgba(34, 211, 238, 0.08);
/* Sidebar */
--sidebar-header-bg: #0c1a3a;
--sidebar-active-bg: rgba(34, 211, 238, 0.1);
--sidebar-active-border: var(--accent-color);
/* Card */
--card-hover-border: rgba(34, 211, 238, 0.3);
--card-accent-gradient: linear-gradient(135deg, var(--primary-color) 0%, var(--accent-color) 100%);
/* Loader */
--loader-dot-color: #22d3ee;
--loader-bg: #f8fafc;
}
}
/* Override explícito para tema dark cuando se use data-theme */
:root[data-theme='dark'] {
--primary-color: #4d73d6;
--primary-light: #6b8fe0;
--primary-dark: #011d7d;
--primary-hover: #6b8fe0;
--primary-foreground: #ffffff;
--secondary-color: #94a3b8;
--secondary-light: #cbd5e1;
--secondary-dark: #64748b;
--secondary-foreground: #0f172a;
/* Acentos - Cyan vibrante ← familia completamente diferente al azul anterior */
--accent-color: #22d3ee;
--accent-light: #67e8f9;
--accent-dark: #06b6d4;
--accent-foreground: #011d7d;
--success-color: #34d399;
--success-background: #064e3b;
--success-foreground: #d1fae5;
--success-light: #6ee7b7;
--success-dark: #10b981;
--warning-color: #fbbf24;
--warning-background: #78350f;
--warning-foreground: #fef3c7;
--warning-light: #fcd34d;
--warning-dark: #f59e0b;
--danger-color: #f87171;
--danger-background: #7f1d1d;
--danger-foreground: #fee2e2;
--danger-light: #fca5a5;
--danger-dark: #ef4444;
--info-color: #60a5fa;
--info-background: #1e3a8a;
--info-foreground: #dbeafe;
--info-light: #93c5fd;
--info-dark: #3b82f6;
--text-color: #f1f5f9;
--text-light: #ffffff;
--text-muted: #94a3b8;
--text-secondary: #cbd5e1;
--error-text: #fca5a5;
--success-text: #6ee7b7;
--background-color: #0f172a;
--secondary-background: #1e293b;
--surface-color: #1e293b;
--surface-alt-color: #0f172a;
--card-bg-color: #1e293b;
--card-category-bg-color: #334155;
--card-category-selected-color: #5580e0;
--card-aditional-bg-color: #1e293b;
--selected-aditional-color: #5580e0;
--overlay-color: rgba(0, 0, 0, 0.8);
--border-color: #334155;
--border-light: #1e293b;
--divider-color: #334155;
--focus-color: #22d3ee;
--focus-ring: rgba(34, 211, 238, 0.4);
--highlight-color: #22d3ee;
--hover-color: #67e8f9;
--hover-background-color: rgba(34, 211, 238, 0.1);
--selected-color: #22d3ee;
--active-color: #011d7d;
--disabled-color: #64748b;
--disabled-background: #334155;
--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.4);
--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, 0.5), 0 1px 2px -1px rgba(0, 0, 0, 0.5);
--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.5), 0 2px 4px -2px rgba(0, 0, 0, 0.5);
--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.5), 0 4px 6px -4px rgba(0, 0, 0, 0.5);
--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.6), 0 8px 10px -6px rgba(0, 0, 0, 0.6);
--shadow-color: rgba(0, 0, 0, 0.5);
--link-color: #22d3ee;
--link-hover-color: #67e8f9;
--link-hover-text-color: #67e8f9;
--badge-color: #011d7d;
--badge-bg: #22d3ee;
--badge-overlay-bg: rgba(0, 0, 0, 0.9);
--badge-overlay-border: rgba(34, 211, 238, 0.2);
--table-header-bg: #0c1a3a;
--table-header-text: #22d3ee;
--table-row-hover: rgba(34, 211, 238, 0.06);
--table-border: #334155;
--events-pill-bg: rgba(12, 26, 58, 0.95);
--events-pill-border: rgba(34, 211, 238, 0.2);
--events-pill-shadow: 0 2px 16px rgba(0, 0, 0, 0.35), 0 1px 4px rgba(34, 211, 238, 0.1);
--events-card-accent: var(--accent-color);
--events-card-image-bg: var(--surface-alt-color);
--glass-bg: rgba(12, 26, 58, 0.75);
--glass-border: rgba(34, 211, 238, 0.2);
--glass-blur: 16px;
--gradient-primary: linear-gradient(135deg, var(--primary-color) 0%, var(--accent-color) 100%);
--gradient-accent: linear-gradient(135deg, var(--accent-color) 0%, var(--accent-light) 100%);
--gradient-surface: linear-gradient(180deg, var(--surface-color) 0%, var(--surface-alt-color) 100%);
--topbar-bg: rgba(1, 5, 25, 0.95);
--topbar-border: rgba(34, 211, 238, 0.15);
--topbar-shadow: 0 1px 3px rgba(0, 0, 0, 0.25), 0 4px 16px rgba(34, 211, 238, 0.06);
--topbar-accent-gradient: linear-gradient(90deg, var(--primary-color), var(--accent-color), var(--accent-light));
--topbar-nav-bg: rgba(1, 5, 25, 0.6);
--topbar-nav-border: rgba(34, 211, 238, 0.12);
--topbar-nav-link-hover-bg: rgba(34, 211, 238, 0.08);
--topbar-nav-link-hover-border: rgba(34, 211, 238, 0.2);
--topbar-dropdown-hover-bg: rgba(34, 211, 238, 0.08);
/* Sidebar */
--sidebar-header-bg: #0c1a3a;
--sidebar-active-bg: rgba(34, 211, 238, 0.1);
--sidebar-active-border: var(--accent-color);
/* Card */
--card-hover-border: rgba(34, 211, 238, 0.3);
--card-accent-gradient: linear-gradient(135deg, var(--primary-color) 0%, var(--accent-color) 100%);
/* Loader */
--loader-dot-color: #22d3ee;
--loader-bg:        #0f172a;
}
/* Override explícito para tema light — necesario cuando SO es dark pero usuario elige light */
:root[data-theme='light'] {
--primary-color: #011d7d;
--primary-light: #2d4fa6;
--primary-dark: #010e47;
--primary-hover: #0a2592;
--primary-foreground: #ffffff;
--secondary-color: #475569;
--secondary-light: #64748b;
--secondary-dark: #334155;
--secondary-foreground: #ffffff;
/* Acentos - Cyan/Teal ← familia completamente diferente al azul anterior */
--accent-color: #0891b2;
--accent-light: #06b6d4;
--accent-dark: #0e7490;
--accent-foreground: #ffffff;
--success-color: #10b981;
--success-background: #d1fae5;
--success-foreground: #065f46;
--success-light: #34d399;
--success-dark: #059669;
--warning-color: #f59e0b;
--warning-background: #fef3c7;
--warning-foreground: #78350f;
--warning-light: #fbbf24;
--warning-dark: #d97706;
--danger-color: #ef4444;
--danger-background: #fee2e2;
--danger-foreground: #991b1b;
--danger-light: #f87171;
--danger-dark: #dc2626;
--info-color: #3b82f6;
--info-background: #dbeafe;
--info-foreground: #1e40af;
--info-light: #60a5fa;
--info-dark: #2563eb;
--text-color: #0f172a;
--text-light: #ffffff;
--text-muted: #64748b;
--text-secondary: #475569;
--error-text: #dc2626;
--success-text: #059669;
--background-color: #f8fafc;
--secondary-background: #f1f5f9;
--surface-color: #ffffff;
--surface-alt-color: #f8fafc;
--card-bg-color: #ffffff;
--card-category-bg-color: #f1f5f9;
--card-category-selected-color: #011d7d;
--card-aditional-bg-color: #f8fafc;
--selected-aditional-color: #011d7d;
--overlay-color: rgba(1, 8, 40, 0.6);
--border-color: #e2e8f0;
--border-light: #f1f5f9;
--divider-color: #e2e8f0;
--focus-color: #011d7d;
--focus-ring: rgba(8, 145, 178, 0.3);
--highlight-color: #011d7d;
--hover-color: #0e7490;
--hover-background-color: #ecfeff;
--selected-color: #011d7d;
--active-color: #010e47;
--disabled-color: #94a3b8;
--disabled-background: #f1f5f9;
--shadow-xs: 0 1px 2px 0 rgba(1, 14, 71, 0.05);
--shadow-sm: 0 1px 3px 0 rgba(1, 14, 71, 0.1), 0 1px 2px -1px rgba(1, 14, 71, 0.1);
--shadow-md: 0 4px 6px -1px rgba(1, 14, 71, 0.12), 0 2px 4px -2px rgba(1, 14, 71, 0.1);
--shadow-lg: 0 10px 15px -3px rgba(1, 14, 71, 0.12), 0 4px 6px -4px rgba(1, 14, 71, 0.1);
--shadow-xl: 0 20px 25px -5px rgba(1, 14, 71, 0.14), 0 8px 10px -6px rgba(1, 14, 71, 0.1);
--shadow-color: rgba(1, 14, 71, 0.1);
--link-color: #0891b2;
--link-hover-color: #0e7490;
--link-hover-text-color: #0e7490;
--badge-color: #ffffff;
--badge-bg: #011d7d;
--badge-overlay-bg: rgba(1, 8, 40, 0.85);
--badge-overlay-border: rgba(255, 255, 255, 0.1);
--table-header-bg: #f0f9ff;
--table-header-text: #011d7d;
--table-row-hover: #ecfeff;
--table-border: #e2e8f0;
--events-pill-bg: rgba(255, 255, 255, 0.92);
--events-pill-border: rgba(6, 182, 212, 0.25);
--events-pill-shadow: 0 2px 16px rgba(1, 8, 40, 0.10), 0 1px 4px rgba(8, 145, 178, 0.07);
--events-card-accent: var(--accent-color);
--events-card-image-bg: var(--surface-alt-color);
--glass-bg: rgba(255, 255, 255, 0.75);
--glass-border: rgba(6, 182, 212, 0.2);
--glass-blur: 16px;
--gradient-primary: linear-gradient(135deg, var(--primary-color) 0%, var(--accent-color) 100%);
--gradient-accent: linear-gradient(135deg, var(--accent-color) 0%, var(--accent-light) 100%);
--gradient-surface: linear-gradient(180deg, var(--surface-color) 0%, var(--surface-alt-color) 100%);
--topbar-bg: rgba(255, 255, 255, 0.82);
--topbar-border: rgba(6, 182, 212, 0.2);
--topbar-shadow: 0 1px 3px rgba(1, 8, 40, 0.06), 0 4px 16px rgba(1, 8, 40, 0.04);
--topbar-accent-gradient: linear-gradient(90deg, var(--primary-color) 0%, var(--accent-color) 100%);
--topbar-nav-bg: #f0f9ff;
--topbar-nav-border: #e0f2fe;
--topbar-nav-link-hover-bg: #ecfeff;
--topbar-nav-link-hover-border: #a5f3fc;
--topbar-dropdown-hover-bg: #ecfeff;
/* Sidebar */
--sidebar-header-bg: #f0f9ff;
--sidebar-active-bg: rgba(8, 145, 178, 0.08);
--sidebar-active-border: var(--accent-color);
--card-hover-border: rgba(8, 145, 178, 0.3);
--card-accent-gradient: linear-gradient(135deg, var(--primary-color) 0%, var(--accent-color) 100%);
/* Loader */
--loader-dot-color: #011d7d;
--loader-bg:        #f8fafc;
}
/* ==============================================
GENERAL - Estilos base modernos
============================================== */
/* === BASE === */
body {
margin: 0;
padding: 0;
font-family: 'Inter', 'Roboto', 'Segoe UI', -apple-system, BlinkMacSystemFont, sans-serif;
font-size: 16px;
line-height: 1.6;
background-color: var(--background-color);
color: var(--text-color);
min-height: 100vh;
transition: background 0.3s ease, color 0.3s ease;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
h1, h2, h3, h4, h5, h6 {
margin: 0 0 1rem 0;
font-weight: 600;
color: var(--text-color);
line-height: 1.3;
letter-spacing: -0.02em;
}
h1 {
font-size: 2.25rem;
font-weight: 700;
}
h2 {
font-size: 1.875rem;
}
h3 {
font-size: 1.5rem;
}
h4 {
font-size: 1.25rem;
}
h5 {
font-size: 1.125rem;
}
h6 {
font-size: 1rem;
}
p {
margin: 0 0 1rem 0;
line-height: 1.6;
color: var(--text-color);
}
a {
color: var(--link-color);
text-decoration: none;
transition: color 0.2s ease;
font-weight: 500;
}
a:hover {
color: var(--link-hover-color);
text-decoration: underline;
}
a:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
border-radius: 0.25rem;
}
hr, .divider {
border: none;
border-top: 1px solid var(--divider-color);
margin: 1.5rem 0;
}
/* === LAYOUT === */
.container {
max-width: 1280px;
margin: 0 auto;
padding: 0 1.5rem;
width: 100%;
}
.container--narrow {
max-width: 960px;
}
.container--wide {
max-width: 1536px;
}
.main-layout {
display: flex;
flex-direction: column;
min-height: 100vh;
background-color: var(--background-color);
}
.content-area {
flex: 1;
padding: 2rem 1rem;
overflow-y: auto;
background-color: var(--background-color);
padding-top: 80px;
}
/* === CARDS === */
.card {
background-color: var(--card-bg-color);
border: 1px solid var(--border-color);
border-radius: 0.875rem;
box-shadow: var(--shadow-sm);
padding: 1.5rem;
margin: 1rem 0;
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.card:hover {
box-shadow: var(--shadow-md);
transform: translateY(-2px);
border-color: var(--card-hover-border);
}
.card--flat {
box-shadow: none;
}
.card--elevated {
box-shadow: var(--shadow-md);
}
/* === BOTONES GEN�RICOS (usar AppButton cuando sea posible) === */
/* Estos estilos son para botones HTML nativos sin componente */
button:not([class*="app-"]):not([class*="btn-"]):not([class*="adr"]):not([class*="theme-"]),
.btn {
background-color: var(--primary-color);
color: var(--primary-foreground);
border: 1px solid transparent;
border-radius: 0.5rem;
padding: 0.625rem 1.25rem;
font-size: 0.9375rem;
font-weight: 600;
cursor: pointer;
transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
box-shadow: var(--shadow-sm);
outline: none;
display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.5rem;
text-decoration: none;
min-height: 2.5rem;
}
button:not([class*="app-"]):not([class*="btn-"]):not([class*="adr"]):not([class*="theme-"]):hover,
.btn:hover {
background-color: var(--primary-hover);
color: var(--primary-foreground);
box-shadow: var(--shadow-md);
transform: translateY(-1px);
}
button:not([class*="app-"]):not([class*="btn-"]):not([class*="adr"]):not([class*="theme-"]):active,
.btn:active {
transform: translateY(0);
box-shadow: var(--shadow-sm);
}
button:not([class*="app-"]):not([class*="btn-"]):not([class*="adr"]):not([class*="theme-"]):focus-visible,
.btn:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
box-shadow: var(--shadow-md), 0 0 0 3px var(--focus-ring);
}
button:not([class*="app-"]):not([class*="btn-"]):not([class*="adr"]):not([class*="theme-"]):disabled,
.btn:disabled {
background-color: var(--disabled-background);
color: var(--disabled-color);
cursor: not-allowed;
opacity: 0.6;
box-shadow: none;
transform: none;
}
/* Botones secundarios y de estado */
.btn-secondary {
background-color: var(--secondary-color);
color: var(--secondary-foreground);
}
.btn-secondary:hover {
background-color: var(--secondary-dark);
color: var(--secondary-foreground);
}
.btn-success {
background-color: var(--success-color);
color: var(--success-foreground);
}
.btn-success:hover {
background-color: var(--success-light);
color: var(--success-foreground);
}
.btn-danger {
background-color: var(--danger-color);
color: var(--danger-foreground);
}
.btn-danger:hover {
background-color: var(--danger-light);
color: var,--danger-foreground;
}
.btn-warning {
background-color: var(--warning-color);
color: var(--warning-foreground);
}
.btn-warning:hover {
background-color: var(--warning-light);
color: var(--warning-foreground);
}
.btn-outline {
background: transparent;
color: var(--primary-color);
border: 1px solid var(--primary-color);
box-shadow: none;
}
.btn-outline:hover {
background: var(--primary-color);
color: var(--primary-foreground);
box-shadow: var(--shadow-sm);
}
.btn-ghost {
background: transparent;
color: var(--text-color);
border: 1px solid var(--border-color);
box-shadow: none;
}
.btn-ghost:hover {
background: var(--hover-background-color);
color: var(--text-color);
box-shadow: none;
}
/* === FORMULARIOS === */
input:not([class*="app-"]),
select:not([class*="app-"]),
textarea:not([class*="app-"]) {
width: 100%;
padding: 0.625rem 1rem;
border: 1px solid var(--border-color);
border-radius: 0.5rem;
background-color: var(--surface-color);
color: var(--text-color);
font-size: 0.9375rem;
font-family: inherit;
margin: 0.5rem 0;
transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
box-shadow: var(--shadow-xs);
}
input:not([class*="app-"]):focus,
select:not([class*="app-"]):focus,
textarea:not([class*="app-"]):focus {
border-color: var(--focus-color);
outline: none;
box-shadow: 0 0 0 3px var(--focus-ring), var(--shadow-sm);
transform: translateY(-1px);
}
input:not([class*="app-"]):hover:not(:disabled):not(:focus),
select:not([class*="app-"]):hover:not(:disabled):not(:focus),
textarea:not([class*="app-"]):hover:not(:disabled):not(:focus) {
border-color: var(--highlight-color);
box-shadow: var(--shadow-sm);
}
input:not([class*="app-"]):disabled,
select:not([class*="app-"]):disabled,
textarea:not([class*="app-"]):disabled {
background-color: var(--disabled-background);
color: var(--disabled-color);
cursor: not-allowed;
opacity: 0.6;
}
label:not([class*="app-"]) {
display: block;
margin-bottom: 0.375rem;
font-weight: 500;
color: var(--text-color);
font-size: 0.875rem;
letter-spacing: 0.01em;
}
/* === TABLAS GEN�RICAS (usar AppTable cuando sea posible) === */
/* REMOVIDOS los estilos de tabla gen�ricos que causaban conflictos */
/* Las tablas ahora deben usar el componente AppTable */
/* === ALERTAS Y MENSAJES === */
.alert {
padding: 1rem 1.25rem;
margin: 1rem 0;
border-radius: 0.5rem;
font-weight: 500;
border: 1px solid transparent;
display: flex;
align-items: center;
gap: 0.75rem;
box-shadow: var(--shadow-sm);
}
.alert-success {
background-color: var(--success-background);
color: var(--success-text);
border-color: var(--success-color);
}
.alert-error {
background-color: var(--danger-background);
color: var(--error-text);
border-color: var(--danger-color);
}
.alert-warning {
background-color: var(--warning-background);
color: var(--warning-color);
border-color: var(--warning-color);
}
.alert-info {
background-color: var(--info-background);
color: var(--info-color);
border-color: var(--info-color);
}
/* === UTILIDADES DE FONDO === */
.bg-error { background-color: var(--danger-background) !important; }
.bg-warning { background-color: var(--warning-background) !important; }
.bg-success { background-color: var(--success-background) !important; }
.bg-info { background-color: var(--info-background) !important; }
/* === UTILIDADES DE TEXTO === */
.text-small { font-size: 0.8125rem !important; }
.text-medium { font-size: 0.9375rem !important; }
.text-large { font-size: 1.125rem !important; }
.text-xlarge { font-size: 1.5rem !important; }
.text-xxlarge { font-size: 2rem !important; }
.text-bold { font-weight: 700 !important; }
.text-semibold { font-weight: 600 !important; }
.text-medium-weight { font-weight: 500 !important; }
.text-italic { font-style: italic !important; }
.text-center { text-align: center !important; }
.text-right { text-align: right !important; }
.text-left { text-align: left !important; }
.text-justify { text-align: justify !important; }
.text-primary { color: var(--primary-color) !important; }
.text-secondary { color: var(--secondary-color) !important; }
.text-success { color: var(--success-color) !important; }
.text-danger { color: var(--danger-color) !important; }
.text-warning { color: var(--warning-color) !important; }
.text-info { color: var(--info-color) !important; }
.text-light { color: var(--text-light) !important; }
.text-dark { color: var(--text-color) !important; }
.text-muted { color: var(--text-muted) !important; }
/* === UTILIDADES DE ESPACIADO === */
.p-0 { padding: 0 !important; }
.p-4 { padding: 0.25rem !important; }
.p-8 { padding: 0.5rem !important; }
.p-12 { padding: 0.75rem !important; }
.p-15 { padding: 0.9375rem !important; }
.p-16 { padding: 1rem !important; }
.p-24 { padding: 1.5rem !important; }
.p-32 { padding: 2rem !important; }
.pt-15 { padding-top: 0.9375rem !important; }
.pb-15 { padding-bottom: 0.9375rem !important; }
.pl-15 { padding-left: 0.9375rem !important; }
.pr-15 { padding-right: 0.9375rem !important; }
.m-0 { margin: 0 !important; }
.m-4 { margin: 0.25rem !important; }
.m-8 { margin: 0.5rem !important; }
.m-10 { margin: 0.625rem !important; }
.m-16 { margin: 1rem !important; }
.m-24 { margin: 1.5rem !important; }
.mt-10 { margin-top: 0.625rem !important; }
.mb-10 { margin-bottom: 0.625rem !important; }
.mb-30 { margin-bottom: 1.875rem !important; }
/* === SCROLLBAR === */
::-webkit-scrollbar {
width: 6px;
height: 6px;
background: transparent;
}
::-webkit-scrollbar-track {
background: transparent;
border-radius: 3px;
}
::-webkit-scrollbar-thumb {
background: var(--border-color);
border-radius: 3px;
transition: background 0.2s;
}
::-webkit-scrollbar-thumb:hover {
background: var(--text-muted);
}
/* === ALINEACIONES FLEX === */
.align-center { display: flex !important; justify-content: center !important; align-items: center !important; }
.align-left { display: flex !important; justify-content: flex-start !important; align-items: center !important; }
.align-right { display: flex !important; justify-content: flex-end !important; align-items: center !important; }
.align-top { display: flex !important; justify-content: center !important; align-items: flex-start !important; }
.align-bottom { display: flex !important; justify-content: center !important; align-items: flex-end !important; }
.align-space-between { display: flex !important; justify-content: space-between !important; align-items: center !important; }
.align-space-around { display: flex !important; justify-content: space-around !important; align-items: center !important; }
.align-space-evenly { display: flex !important; justify-content: space-evenly !important; align-items: center !important; }
.justify-start { justify-content: flex-start !important; }
.justify-center { justify-content: center !important; }
.justify-end { justify-content: flex-end !important; }
.justify-between { justify-content: space-between !important; }
.justify-around { justify-content: space-around !important; }
.justify-evenly { justify-content: space-evenly !important; }
.items-start { align-items: flex-start !important; }
.items-center { align-items: center !important; }
.items-end { align-items: flex-end !important; }
.items-stretch { align-items: stretch !important; }
.self-start { align-self: flex-start !important; }
.self-center { align-self: center !important; }
.self-end { align-self: flex-end !important; }
.self-stretch { align-self: stretch !important; }
.flex-row { display: flex !important; flex-direction: row !important; }
.flex-column { display: flex !important; flex-direction: column !important; }
.flex-wrap { flex-wrap: wrap !important; }
.flex-nowrap { flex-wrap: nowrap !important; }
.flex-1 { flex: 1 1 0% !important; }
.flex-auto { flex: 1 1 auto !important; }
.flex-none { flex: none !important; }
.gap-4 { gap: 0.25rem !important; }
.gap-8 { gap: 0.5rem !important; }
.gap-12 { gap: 0.75rem !important; }
.gap-15 { gap: 0.9375rem !important; }
.gap-16 { gap: 1rem !important; }
.gap-24 { gap: 1.5rem !important; }
/* === HELPERS === */
.absolute-center {
position: absolute !important;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
.w-full { width: 100% !important; }
.h-full { height: 100% !important; }
.hidden { display: none !important; }
.invisible { visibility: hidden !important; }
.rounded { border-radius: 0.5rem !important; }
.rounded-sm { border-radius: 0.25rem !important; }
.rounded-lg { border-radius: 0.75rem !important; }
.rounded-full { border-radius: 9999px !important; }
.shadow-sm { box-shadow: var(--shadow-sm) !important; }
.shadow-md { box-shadow: var(--shadow-md) !important; }
.shadow-lg { box-shadow: var(--shadow-lg) !important; }
.shadow-none { box-shadow: none !important; }
/* === MAUI SAFE AREA === */
/*
* Aplica padding usando las safe area insets del dispositivo.
* Requiere viewport-fit=cover en el meta viewport (ya configurado en AbstractBP.Maui/wwwroot/index.html).
* Compatible con Android (barra de estado y navegaci�n) e iOS (notch, Dynamic Island, home indicator).
*/
.maui-safe-area {
padding-top: env(safe-area-inset-top, 0px);
padding-bottom: env(safe-area-inset-bottom, 0px);
padding-left: env(safe-area-inset-left, 0px);
padding-right: env(safe-area-inset-right, 0px);
box-sizing: border-box;
}
/* === RESPONSIVIDAD === */
@media (max-width: 768px) {
body { font-size: 14px; }
h1 { font-size: 1.875rem; }
h2 { font-size: 1.5rem; }
h3 { font-size: 1.25rem; }
h4 { font-size: 1.125rem; }
h5, h6 { font-size: 1rem; }
.card { padding: 1rem; }
.container { padding: 0 1rem; }
.content-area { padding: 1.5rem 0.75rem; padding-top: 70px; }
}
/* === AJUSTES MODO OSCURO === */
@media (prefers-color-scheme: dark) {
:root:not([data-theme='light']) a:hover {
color: var(--primary-light);
}
}
:root[data-theme='dark'] a:hover {
color: var(--primary-light);
}
/* === ANIMACI�N DE CARGA === */
.loading-progress {
stroke: var(--primary-color);
}
.loading-progress-text {
font-weight: 700;
fill: var(--primary-color);
}
/* === INTERFAZ DE ERROR === */
#blazor-error-ui {
background-color: var(--danger-color);
color: var(--text-light);
padding: 1rem 1.5rem;
border-radius: 0.5rem 0.5rem 0 0;
position: fixed;
bottom: 0;
left: 0;
right: 0;
box-shadow: var(--shadow-lg);
display: none;
z-index: 10000;
}
#blazor-error-ui a.reload {
color: var(--text-light);
text-decoration: underline;
cursor: pointer;
font-weight: 600;
}
#blazor-error-ui .dismiss {
color: var(--text-light);
cursor: pointer;
font-weight: 600;
opacity: 0.9;
}
#blazor-error-ui .dismiss:hover {
opacity: 1;
}
/* === SPINNER DE INICIO === */
.init-spinner {
position: fixed;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
z-index: 9999;
}
/* Reset moderno */
*, *::before, *::after {
box-sizing: border-box;
margin: 0;
padding: 0;
}
html, body {
height: 100%;
font-family: 'Segoe UI', 'Roboto', Arial, sans-serif;
background: var(--background-color, #f5f6fa);
color: var(--text-color, #222);
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
img, picture, video, canvas, svg {
display: block;
max-width: 100%;
}
button, input, select, textarea {
font: inherit;
}
a {
text-decoration: none;
}
ul, ol {
list-style: none;
}
h1, h2, h3, h4, h5, h6 {
font-family: 'Segoe UI', 'Roboto', Arial, sans-serif;
font-weight: 600;
color: var(--text-color);
margin-bottom: 0.5em;
line-height: 1.2;
}
h1 {
font-size: 2.5rem;
}
h2 {
font-size: 2rem;
}
h3 {
font-size: 1.5rem;
}
h4 {
font-size: 1.25rem;
}
h5 {
font-size: 1rem;
}
h6 {
font-size: 0.875rem;
}
/* Solo aplicar a elementos que NO estén dentro de componentes */
p:not([class*="app-"]):not([class*="btn-"]):not([class*="modal-"]),
li:not([class*="app-"]):not([class*="btn-"]):not([class*="modal-"]),
label:not([class*="app-"]):not([class*="btn-"]):not([class*="modal-"]),
span:not([class*="app-"]):not([class*="btn-"]):not([class*="modal-"]) {
color: var(--text-color);
font-size: 1rem;
line-height: 1.6;
}
/* NO aplicar a spans dentro de botones o componentes */
button span,
.app-button span,
.app-button__text,
.app-button__icon,
[class*="app-"] span,
[class*="btn-"] span {
color: inherit;
}
small, .text-muted {
color: var(--text-muted);
font-size: 0.875rem;
}
/* AdminEventPaymentKeys - Componente de administraci�n de claves de pago */
.admin-event-payment-keys {
width: 100%;
height: 100%;
display: flex;
flex-direction: column;
gap: 1.5rem;
}
/* Header */
.admin-event-payment-keys__header {
display: flex;
justify-content: space-between;
align-items: center;
gap: 1rem;
flex-wrap: wrap;
}
.admin-event-payment-keys__title {
font-size: 1.5rem;
font-weight: 600;
color: var(--text-color);
margin: 0;
}
/* Estados */
.admin-event-payment-keys__loading {
display: flex;
align-items: center;
justify-content: center;
gap: 1rem;
padding: 2rem;
color: var(--text-muted);
}
.admin-event-payment-keys__error {
padding: 1rem;
background: var(--danger-background);
color: var(--danger-color);
border-radius: 0.5rem;
border: 1px solid var(--danger-color);
}
.admin-event-payment-keys__empty {
padding: 2rem;
text-align: center;
color: var(--text-muted);
background: var(--surface-color);
border: 1px dashed var(--border-color);
border-radius: 0.5rem;
}
/* Tabla */
.admin-event-payment-keys__table-wrapper {
width: 100%;
overflow-x: auto;
background: var(--surface-color);
border-radius: 0.5rem;
border: 1px solid var(--border-color);
}
.admin-event-payment-keys__th-center {
text-align: center !important;
}
/* Badges */
.admin-event-payment-keys__badge {
display: inline-block;
padding: 0.25rem 0.75rem;
border-radius: 1rem;
font-size: 0.875rem;
font-weight: 500;
white-space: nowrap;
}
.admin-event-payment-keys__badge--prod {
background: var(--warning-background);
color: var(--warning-color);
}
.admin-event-payment-keys__badge--test {
background: var(--info-background);
color: var(--info-color);
}
.admin-event-payment-keys__badge--active {
background: var(--success-background);
color: var(--success-color);
}
.admin-event-payment-keys__badge--inactive {
background: var(--disabled-background);
color: var(--disabled-color);
}
/* Acciones */
.admin-event-payment-keys__actions-cell {
text-align: center;
}
.admin-event-payment-keys__actions {
display: flex;
justify-content: center;
align-items: center;
gap: 0.5rem;
}
/* Botones de acci�n con mayor especificidad para evitar sobrescritura */
button.admin-event-payment-keys__action-btn {
display: inline-flex !important;
align-items: center !important;
justify-content: center !important;
width: 2rem !important;
height: 2rem !important;
min-height: auto !important;
padding: 0 !important;
margin: 0 !important;
border-radius: 0.375rem !important;
background: transparent !important;
color: var(--text-color) !important;
border: 1px solid var(--border-color) !important;
cursor: pointer !important;
transition: all 0.2s ease !important;
box-shadow: none !important;
font-size: 1rem !important;
font-weight: 400 !important;
text-decoration: none !important;
transform: none !important;
}
/* Estilos para los SVG dentro de los botones */
button.admin-event-payment-keys__action-btn svg {
width: 18px !important;
height: 18px !important;
stroke: currentColor !important;
fill: none !important;
stroke-width: 2 !important;
stroke-linecap: round !important;
stroke-linejoin: round !important;
display: block !important;
}
button.admin-event-payment-keys__action-btn:hover {
background: var(--hover-background-color) !important;
color: var(--primary-color) !important;
border-color: var(--primary-color) !important;
transform: translateY(-1px) !important;
box-shadow: var(--shadow-sm) !important;
}
button.admin-event-payment-keys__action-btn:active {
transform: translateY(0) !important;
box-shadow: none !important;
}
button.admin-event-payment-keys__action-btn:focus-visible {
outline: 2px solid var(--primary-color) !important;
outline-offset: 2px !important;
}
button.admin-event-payment-keys__action-btn.admin-event-payment-keys__action-btn--danger:hover {
background: var(--danger-background) !important;
color: var(--danger-color) !important;
border-color: var(--danger-color) !important;
}
button.admin-event-payment-keys__action-btn.admin-event-payment-keys__action-btn--danger:focus-visible {
outline-color: var(--danger-color) !important;
}
button.admin-event-payment-keys__action-btn.admin-event-payment-keys__action-btn--success:hover {
background: var(--success-background) !important;
color: var(--success-color) !important;
border-color: var(--success-color) !important;
}
button.admin-event-payment-keys__action-btn.admin-event-payment-keys__action-btn--success:focus-visible {
outline-color: var(--success-color) !important;
}
/* Paginaci�n */
.admin-event-payment-keys__pagination {
display: flex;
justify-content: center;
padding: 1rem 0;
}
/* Modal - Detalle */
.admin-event-payment-keys__detail {
display: flex;
flex-direction: column;
gap: 1rem;
}
.admin-event-payment-keys__detail-row {
display: grid;
grid-template-columns: 140px 1fr;
gap: 1rem;
padding: 0.75rem;
background: var(--surface-alt-color);
border-radius: 0.375rem;
}
.admin-event-payment-keys__detail-label {
font-weight: 600;
color: var(--text-secondary);
}
.admin-event-payment-keys__detail-value {
color: var(--text-color);
word-break: break-word;
}
.admin-event-payment-keys__detail-value--code {
font-family: 'Courier New', monospace;
font-size: 0.875rem;
background: var(--background-color);
padding: 0.5rem;
border-radius: 0.25rem;
border: 1px solid var(--border-color);
}
/* Modal - Form */
.admin-event-payment-keys__form {
display: flex;
flex-direction: column;
gap: 1.25rem;
}
.admin-event-payment-keys__row {
display: grid;
gap: 1rem;
}
.admin-event-payment-keys__row--2 {
grid-template-columns: 1fr 1fr;
}
/* Modal Actions */
.admin-event-payment-keys__modal-actions {
display: flex;
justify-content: flex-end;
gap: 0.75rem;
margin-top: 1.5rem;
padding-top: 1.5rem;
border-top: 1px solid var(--border-color);
}
/* Responsive - Tablets */
@media (max-width: 768px) {
.admin-event-payment-keys__header {
flex-direction: column;
align-items: stretch;
}
.admin-event-payment-keys__title {
font-size: 1.25rem;
}
.admin-event-payment-keys__row--2 {
grid-template-columns: 1fr;
}
.admin-event-payment-keys__detail-row {
grid-template-columns: 1fr;
gap: 0.5rem;
}
.admin-event-payment-keys__modal-actions {
flex-direction: column;
}
}
/* Responsive - M�viles */
@media (max-width: 480px) {
.admin-event-payment-keys {
gap: 1rem;
}
.admin-event-payment-keys__title {
font-size: 1.125rem;
}
.admin-event-payment-keys__actions {
flex-wrap: wrap;
}
button.admin-event-payment-keys__action-btn {
width: 1.75rem !important;
height: 1.75rem !important;
}
button.admin-event-payment-keys__action-btn svg {
width: 16px !important;
height: 16px !important;
}
.admin-event-payment-keys__badge {
font-size: 0.75rem;
padding: 0.2rem 0.5rem;
}
}
/* AppAdminToolbar - Barra superior para p�ginas administrativas */
.app-admin-toolbar {
display: flex;
flex-direction: column;
gap: var(--spacing-md, 1rem);
padding: var(--spacing-md, 1rem);
background-color: var(--surface-color);
border-bottom: 1px solid var(--border-color);
position: sticky;
top: 0;
z-index: 10;
}
.app-admin-toolbar__actions {
display: flex;
flex-wrap: wrap;
gap: var(--spacing-sm, 0.5rem);
align-items: center;
}
.app-admin-toolbar__btn {
display: inline-flex;
align-items: center;
gap: var(--spacing-xs, 0.25rem);
padding: var(--spacing-sm, 0.5rem) var(--spacing-md, 1rem);
font-size: var(--font-size-sm, 0.875rem);
font-weight: 500;
border: 1px solid transparent;
border-radius: var(--border-radius-md, 0.375rem);
cursor: pointer;
transition: all 0.2s ease;
white-space: nowrap;
}
.app-admin-toolbar__btn:disabled {
opacity: 0.5;
cursor: not-allowed;
}
.app-admin-toolbar__btn--primary {
background-color: var(--primary-color);
color: var(--primary-foreground);
border-color: var(--primary-color);
}
.app-admin-toolbar__btn--primary:hover:not(:disabled) {
background-color: var(--primary-hover);
border-color: var(--primary-hover);
color: var(--primary-foreground);
}
.app-admin-toolbar__btn--success {
background-color: var(--success-color);
color: var(--success-foreground);
border-color: var(--success-color);
}
.app-admin-toolbar__btn--success:hover:not(:disabled) {
background-color: var(--success-dark);
border-color: var(--success-dark);
color: var(--success-foreground);
}
.app-admin-toolbar__btn--ghost {
background-color: transparent;
color: var(--text-color);
border-color: var(--border-color);
}
.app-admin-toolbar__btn--ghost:hover:not(:disabled) {
background-color: var(--hover-background-color);
border-color: var(--primary-color);
color: var(--primary-color);
}
.app-admin-toolbar__icon {
width: 1.125rem;
height: 1.125rem;
flex-shrink: 0;
}
.app-admin-toolbar__label {
display: none;
}
.app-admin-toolbar__info {
display: flex;
flex-wrap: wrap;
gap: var(--spacing-md, 1rem);
align-items: center;
justify-content: space-between;
font-size: var(--font-size-sm, 0.875rem);
color: var(--text-muted);
}
.app-admin-toolbar__summary {
font-weight: 500;
color: var(--text-color);
}
.app-admin-toolbar__pagination {
display: flex;
align-items: center;
gap: var(--spacing-sm, 0.5rem);
}
.app-admin-toolbar__page-btn {
display: inline-flex;
align-items: center;
justify-content: center;
width: 2rem;
height: 2rem;
padding: 0;
background-color: transparent;
color: var(--text-color);
border: 1px solid var(--border-color);
border-radius: var(--border-radius-md, 0.375rem);
cursor: pointer;
transition: all 0.2s ease;
}
.app-admin-toolbar__page-btn:hover:not(:disabled) {
background-color: var(--hover-background-color);
border-color: var(--primary-color);
color: var(--primary-color);
}
.app-admin-toolbar__page-btn:disabled {
opacity: 0.3;
cursor: not-allowed;
}
.app-admin-toolbar__page-btn svg {
width: 1rem;
height: 1rem;
}
.app-admin-toolbar__page-info {
min-width: 4rem;
text-align: center;
font-weight: 500;
color: var(--text-color);
}
.app-admin-toolbar__filters {
display: flex;
flex-wrap: wrap;
gap: var(--spacing-xs, 0.25rem);
align-items: center;
padding: var(--spacing-sm, 0.5rem);
background-color: var(--background-color);
border-radius: var(--border-radius-md, 0.375rem);
border: 1px solid var(--border-color);
min-height: 2rem;
}
.app-admin-toolbar__filters:empty {
display: none;
}
/* Responsive */
@media (min-width: 640px) {
.app-admin-toolbar {
flex-direction: row;
flex-wrap: wrap;
align-items: center;
}
.app-admin-toolbar__actions {
flex: 1;
}
.app-admin-toolbar__info {
flex: 0 0 auto;
}
.app-admin-toolbar__filters {
flex-basis: 100%;
}
.app-admin-toolbar__label {
display: inline;
}
}
@media (min-width: 1024px) {
.app-admin-toolbar {
gap: var(--spacing-lg, 1.5rem);
}
}
/* AppFilterBadge - Badge para filtros activos */
.app-filter-badge {
display: inline-flex;
align-items: center;
gap: var(--spacing-xs, 0.25rem);
padding: 0.188rem 0.5rem;
font-size: var(--font-size-xs, 0.75rem);
background-color: var(--info-background);
color: var(--primary-color);
border: 1px solid var(--primary-color);
border-radius: var(--border-radius-full, 9999px);
white-space: nowrap;
transition: all 0.2s ease;
animation: badgeFadeIn 0.2s ease;
}
@keyframes badgeFadeIn {
from {
opacity: 0;
transform: scale(0.95);
}
to {
opacity: 1;
transform: scale(1);
}
}
.app-filter-badge:hover {
box-shadow: var(--shadow-sm);
}
.app-filter-badge__label {
font-weight: 600;
color: var(--primary-color);
}
.app-filter-badge__value {
font-weight: 500;
color: var(--primary-color);
max-width: 120px;
overflow: hidden;
text-overflow: ellipsis;
}
.app-filter-badge__remove {
display: inline-flex;
align-items: center;
justify-content: center;
width: 0.875rem;
height: 0.875rem;
padding: 0;
margin-left: var(--spacing-xs, 0.25rem);
background-color: transparent;
border: none;
border-radius: var(--border-radius-full, 9999px);
cursor: pointer;
transition: all 0.15s ease;
color: var(--primary-color);
}
.app-filter-badge__remove:hover {
background-color: var(--primary-color);
color: var(--primary-foreground);
transform: scale(1.1);
}
.app-filter-badge__remove svg {
width: 0.625rem;
height: 0.625rem;
}
/* AppFilterPanel - Panel lateral derecho para filtros */
.app-filter-panel {
position: fixed;
top: 0;
right: 0;
bottom: 0;
left: 0;
z-index: 50;
pointer-events: none;
}
.app-filter-panel--open {
pointer-events: auto;
}
.app-filter-panel__overlay {
position: absolute;
inset: 0;
background-color: var(--overlay-color);
opacity: 0;
transition: opacity 0.15s ease;
}
.app-filter-panel--open .app-filter-panel__overlay {
opacity: 1;
}
.app-filter-panel__panel {
position: absolute;
top: 0;
right: 0;
bottom: 0;
width: 100%;
max-width: 28rem;
display: flex;
flex-direction: column;
background-color: var(--surface-color);
box-shadow: var(--shadow-xl);
transform: translateX(100%);
transition: transform 0.2s ease;
}
.app-filter-panel--open .app-filter-panel__panel {
transform: translateX(0);
}
.app-filter-panel__header {
display: flex;
align-items: center;
justify-content: space-between;
padding: var(--spacing-lg, 1.5rem);
border-bottom: 1px solid var(--border-color);
background-color: var(--surface-color);
}
.app-filter-panel__title {
margin: 0;
font-size: var(--font-size-lg, 1.125rem);
font-weight: 600;
color: var(--text-color);
}
.app-filter-panel__close {
display: inline-flex;
align-items: center;
justify-content: center;
width: 2rem;
height: 2rem;
padding: 0;
background-color: transparent;
border: none;
border-radius: var(--border-radius-md, 0.375rem);
cursor: pointer;
transition: background-color 0.2s ease;
color: var(--text-muted);
}
.app-filter-panel__close:hover {
background-color: var(--hover-background-color);
color: var(--text-color);
}
.app-filter-panel__close svg {
width: 1.25rem;
height: 1.25rem;
}
.app-filter-panel__body {
flex: 1;
overflow-y: auto;
padding: var(--spacing-lg, 1.5rem);
background-color: var(--background-color);
}
.app-filter-panel__footer {
display: flex;
gap: var(--spacing-sm, 0.5rem);
padding: var(--spacing-lg, 1.5rem);
border-top: 1px solid var(--border-color);
background-color: var(--surface-color);
}
.app-filter-panel__btn {
flex: 1;
padding: var(--spacing-sm, 0.5rem) var(--spacing-md, 1rem);
font-size: var(--font-size-sm, 0.875rem);
font-weight: 500;
border: 1px solid transparent;
border-radius: var(--border-radius-md, 0.375rem);
cursor: pointer;
transition: all 0.2s ease;
}
.app-filter-panel__btn--primary {
background-color: var(--primary-color);
color: var(--primary-foreground);
border-color: var(--primary-color);
}
.app-filter-panel__btn--primary:hover {
background-color: var(--primary-hover);
border-color: var(--primary-hover);
color: var(--primary-foreground);
}
/* Asegurarse que los spans dentro hereden el color */
.app-filter-panel__btn--primary span {
color: var(--primary-foreground) !important;
}
.app-filter-panel__btn--ghost {
background-color: transparent;
color: var(--text-color);
border-color: var(--border-color);
}
.app-filter-panel__btn--ghost:hover {
background-color: var(--hover-background-color);
border-color: var(--border-color);
color: var(--text-color);
}
.app-filter-panel__btn--ghost span {
color: inherit !important;
}
/* Responsive */
@media (max-width: 639px) {
.app-filter-panel__panel {
max-width: 100%;
}
}
/* ============================================
CancelCfdiModal Component Styles (BEM)
Modal para cancelaci�n de CFDI
============================================ */
.cancelCfdiModal {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
/* ============= Error Message ============= */
.cancelCfdiModal__error {
display: flex;
align-items: center;
gap: 0.75rem;
padding: 1rem;
background: var(--danger-background);
border-left: 4px solid var(--danger-color);
border-radius: var(--border-radius);
color: var(--danger-color);
font-size: 0.875rem;
}
.cancelCfdiModal__error-icon {
font-size: 1.5rem;
flex-shrink: 0;
}
/* ============= Info Section ============= */
.cancelCfdiModal__info {
background: var(--info-background);
border: 1px solid var(--info-color);
border-radius: var(--border-radius);
padding: 1rem;
}
.cancelCfdiModal__info-title {
margin: 0 0 0.75rem 0;
font-size: 1rem;
font-weight: 600;
color: var(--text-color);
}
.cancelCfdiModal__info-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: 0.75rem;
}
.cancelCfdiModal__info-item {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.cancelCfdiModal__info-label {
font-size: 0.75rem;
font-weight: 600;
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: 0.5px;
}
.cancelCfdiModal__info-value {
font-size: 0.875rem;
color: var(--text-color);
font-weight: 500;
}
.cancelCfdiModal__info-value--mono {
font-family: 'Courier New', Courier, monospace;
font-size: 0.8125rem;
}
/* ============= Form ============= */
.cancelCfdiModal__form {
display: flex;
flex-direction: column;
gap: 1rem;
}
.cancelCfdiModal__help-text {
display: block;
margin-top: 0.25rem;
color: var(--text-muted);
font-style: italic;
}
/* ============= Replacement Section ============= */
.cancelCfdiModal__replacement-section {
padding: var(--spacing-md);
background: var(--secondary-background);
border-radius: var(--border-radius);
border: 1px solid var(--border-color);
display: flex;
flex-direction: column;
gap: var(--spacing-md);
}
.cancelCfdiModal__replacement-info {
display: flex;
gap: var(--spacing-sm);
margin-top: var(--spacing-md);
padding: var(--spacing-md);
background: var(--info-background);
border-radius: var(--border-radius);
border: 1px solid var(--info-color);
}
.cancelCfdiModal__replacement-icon {
font-size: 1.5rem;
flex-shrink: 0;
}
.cancelCfdiModal__replacement-info div {
flex: 1;
}
.cancelCfdiModal__replacement-info strong {
display: block;
margin-bottom: 0.5rem;
color: var(--info-color);
font-size: 0.875rem;
}
.cancelCfdiModal__replacement-info ul {
margin: 0;
padding-left: 1.25rem;
font-size: 0.8125rem;
color: var(--text-color);
}
.cancelCfdiModal__replacement-info li {
margin-bottom: 0.25rem;
}
.cancelCfdiModal__checkbox-container {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.cancelCfdiModal__checkbox-label {
display: flex;
align-items: center;
gap: 0.5rem;
cursor: pointer;
user-select: none;
}
.cancelCfdiModal__checkbox-input {
width: 1.25rem;
height: 1.25rem;
cursor: pointer;
accent-color: var(--primary-color);
}
.cancelCfdiModal__checkbox-text {
font-size: 0.875rem;
font-weight: 500;
color: var(--text-color);
}
.cancelCfdiModal__checkbox-help {
display: block;
margin-left: 1.75rem;
color: var(--text-muted);
font-size: 0.75rem;
font-style: italic;
}
/* ============= Warning Section ============= */
.cancelCfdiModal__warning {
display: flex;
gap: 0.75rem;
padding: 1rem;
background: var(--warning-background);
border-left: 4px solid var(--warning-color);
border-radius: var(--border-radius);
}
.cancelCfdiModal__warning-icon {
font-size: 1.5rem;
flex-shrink: 0;
color: var(--warning-color);
}
.cancelCfdiModal__warning-content {
flex: 1;
color: var(--text-color);
}
.cancelCfdiModal__warning-content strong {
display: block;
margin-bottom: 0.5rem;
font-size: 0.875rem;
color: var(--warning-color);
}
.cancelCfdiModal__warning-content ul {
margin: 0;
padding-left: 1.25rem;
font-size: 0.8125rem;
}
.cancelCfdiModal__warning-content li {
margin-bottom: 0.25rem;
}
/* ============= Responsive ============= */
@media (max-width: 640px) {
.cancelCfdiModal__info-grid {
grid-template-columns: 1fr;
}
.cancelCfdiModal__warning,
.cancelCfdiModal__replacement-info {
flex-direction: column;
}
.cancelCfdiModal__warning-icon,
.cancelCfdiModal__replacement-icon {
font-size: 2rem;
}
}
/* Dark mode handled by CSS variables */
/* ============================================
CfdiHistoryTimeline Component Styles (BEM)
Timeline visual para historial de CFDIs
============================================ */
.cfdiHistoryTimeline {
width: 100%;
padding: 0;
}
/* ============= Empty State ============= */
.cfdiHistoryTimeline__empty {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
padding: 3rem 1rem;
text-align: center;
color: var(--text-muted);
}
.cfdiHistoryTimeline__empty-icon {
font-size: 3rem;
margin-bottom: 1rem;
opacity: 0.5;
}
.cfdiHistoryTimeline__empty p {
margin: 0;
font-size: 1rem;
}
/* ============= Timeline Container ============= */
.cfdiHistoryTimeline__container {
position: relative;
padding-left: 2.5rem;
}
/* L�nea vertical del timeline */
.cfdiHistoryTimeline__container::before {
content: '';
position: absolute;
left: 1.25rem;
top: 0;
bottom: 0;
width: 2px;
background: var(--border-color);
}
/* ============= Timeline Item ============= */
.cfdiHistoryTimeline__item {
position: relative;
margin-bottom: 2rem;
}
.cfdiHistoryTimeline__item:last-child {
margin-bottom: 0;
}
/* ============= Marker (c�rculo con icono) ============= */
.cfdiHistoryTimeline__marker {
position: absolute;
left: -2.5rem;
top: 0.5rem;
width: 2.5rem;
height: 2.5rem;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
font-size: 1.25rem;
background: var(--surface-color);
border: 2px solid var(--border-color);
z-index: 1;
}
/* Colores seg�n estado */
.cfdiHistoryTimeline__item--active .cfdiHistoryTimeline__marker {
background: var(--success-bg);
border-color: var(--success);
}
.cfdiHistoryTimeline__item--cancelled .cfdiHistoryTimeline__marker {
background: var(--danger-bg);
border-color: var(--danger);
}
.cfdiHistoryTimeline__item--replaced .cfdiHistoryTimeline__marker {
background: var(--warning-bg);
border-color: var(--warning);
}
.cfdiHistoryTimeline__marker-icon {
line-height: 1;
}
/* ============= Content Card ============= */
.cfdiHistoryTimeline__content {
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 0.5rem;
padding: 1rem;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
transition: box-shadow 0.2s ease;
}
.cfdiHistoryTimeline__content:hover {
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}
/* ============= Header ============= */
.cfdiHistoryTimeline__header {
display: flex;
justify-content: space-between;
align-items: flex-start;
margin-bottom: 0.75rem;
gap: 1rem;
}
.cfdiHistoryTimeline__title-group {
display: flex;
align-items: center;
gap: 0.75rem;
flex-wrap: wrap;
}
.cfdiHistoryTimeline__title {
margin: 0;
font-size: 1.125rem;
font-weight: 600;
color: var(--text-primary);
}
.cfdiHistoryTimeline__badge {
display: inline-flex;
align-items: center;
padding: 0.25rem 0.75rem;
border-radius: 1rem;
font-size: 0.75rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.cfdiHistoryTimeline__badge--active {
background: var(--success-bg);
color: var(--success);
}
.cfdiHistoryTimeline__badge--cancelled {
background: var(--danger-bg);
color: var(--danger);
}
.cfdiHistoryTimeline__badge--replaced {
background: var(--warning-bg);
color: var(--warning);
}
.cfdiHistoryTimeline__date {
font-size: 0.875rem;
color: var(--text-muted);
white-space: nowrap;
}
/* ============= Details ============= */
.cfdiHistoryTimeline__details {
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.cfdiHistoryTimeline__detail-row {
display: flex;
gap: 0.5rem;
font-size: 0.875rem;
}
.cfdiHistoryTimeline__detail-label {
font-weight: 500;
color: var(--text-muted);
min-width: 100px;
}
.cfdiHistoryTimeline__detail-value {
color: var(--text-primary);
word-break: break-word;
}
/* ============= Replacement Info ============= */
.cfdiHistoryTimeline__replacement {
display: flex;
align-items: center;
gap: 0.5rem;
padding: 0.75rem;
margin-top: 0.5rem;
background: var(--warning-bg);
border-left: 3px solid var(--warning);
border-radius: 0.25rem;
font-size: 0.875rem;
color: var(--warning-dark);
}
.cfdiHistoryTimeline__replacement-icon {
font-size: 1.25rem;
}
/* ============= Actions ============= */
.cfdiHistoryTimeline__actions {
display: flex;
gap: 0.5rem;
margin-top: 1rem;
padding-top: 1rem;
border-top: 1px solid var(--border-color);
}
.cfdiHistoryTimeline__action-btn {
display: inline-flex;
align-items: center;
justify-content: center;
padding: 0.5rem 1rem;
border: 1px solid var(--border-color);
border-radius: 0.25rem;
background: var(--surface-color);
color: var(--text-primary);
font-size: 0.875rem;
font-weight: 500;
cursor: pointer;
transition: all 0.2s ease;
}
.cfdiHistoryTimeline__action-btn:hover {
background: var(--hover-bg);
border-color: var(--primary);
color: var(--primary);
}
.cfdiHistoryTimeline__action-btn--primary {
background: var(--primary-bg);
color: var(--primary);
border-color: var(--primary);
}
.cfdiHistoryTimeline__action-btn--primary:hover {
background: var(--primary);
color: var(--white);
}
.cfdiHistoryTimeline__action-btn--secondary {
background: var(--surface-color);
color: var(--text-secondary);
}
.cfdiHistoryTimeline__action-btn--secondary:hover {
background: var(--hover-bg);
color: var(--text-primary);
}
/* ============= Responsive ============= */
@media (max-width: 768px) {
.cfdiHistoryTimeline__container {
padding-left: 2rem;
}
.cfdiHistoryTimeline__container::before {
left: 1rem;
}
.cfdiHistoryTimeline__marker {
left: -2rem;
width: 2rem;
height: 2rem;
font-size: 1rem;
}
.cfdiHistoryTimeline__header {
flex-direction: column;
align-items: flex-start;
}
.cfdiHistoryTimeline__detail-label {
min-width: 80px;
}
.cfdiHistoryTimeline__actions {
flex-direction: column;
}
.cfdiHistoryTimeline__action-btn {
width: 100%;
}
}
@media (max-width: 480px) {
.cfdiHistoryTimeline__detail-row {
flex-direction: column;
gap: 0.25rem;
}
.cfdiHistoryTimeline__detail-label {
min-width: auto;
}
}
/* ============================================
CfdiRelationStatusBadge Component (BEM)
Badge para estado de relaci�n CFDI
============================================ */
.cfdiRelationBadge {
display: inline-flex;
align-items: center;
gap: 0.375rem;
padding: 0.25rem 0.75rem;
border-radius: 1rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
white-space: nowrap;
}
/* ============= Sizes ============= */
.cfdiRelationBadge--sm {
font-size: 0.625rem;
padding: 0.125rem 0.5rem;
gap: 0.25rem;
}
.cfdiRelationBadge--md {
font-size: 0.75rem;
padding: 0.25rem 0.75rem;
gap: 0.375rem;
}
.cfdiRelationBadge--lg {
font-size: 0.875rem;
padding: 0.375rem 1rem;
gap: 0.5rem;
}
/* ============= Icon ============= */
.cfdiRelationBadge__icon {
font-size: 1em;
line-height: 1;
}
.cfdiRelationBadge__text {
line-height: 1;
}
/* ============= Status Colors ============= */
/* Active - Verde */
.cfdiRelationBadge--active {
background: var(--success-bg);
color: var(--success);
}
/* Cancelled - Rojo */
.cfdiRelationBadge--cancelled {
background: var(--danger-bg);
color: var(--danger);
}
/* Replaced - Amarillo/Naranja */
.cfdiRelationBadge--replaced {
background: var(--warning-bg);
color: var(--warning-dark);
}
/* Unknown - Gris */
.cfdiRelationBadge--unknown {
background: var(--muted-bg);
color: var(--text-muted);
}
/* ==========================================================================
CFDI STATUS BADGE - Component Styles
========================================================================== */
.cfdi-status-badge {
display: inline-flex;
align-items: center;
gap: 0.375rem;
padding: 0.375rem 0.75rem;
border-radius: 12px;
font-size: 0.875rem;
font-weight: 600;
cursor: help;
transition: all 0.2s ease;
border: 1px solid transparent;
}
.cfdi-status-badge__icon {
font-size: 1rem;
line-height: 1;
}
.cfdi-status-badge__label {
line-height: 1;
}
/* Status: Pending (Warning) */
.cfdi-status-badge--pending {
background: var(--warning-background);
color: var(--warning-color);
border-color: var(--warning-color);
}
.cfdi-status-badge--pending:hover {
background: var(--warning-color);
color: var(--warning-foreground);
transform: translateY(-1px);
box-shadow: var(--shadow-sm);
}
/* Status: Valid (Success) */
.cfdi-status-badge--valid {
background: var(--success-background);
color: var(--success-color);
border-color: var(--success-color);
}
.cfdi-status-badge--valid:hover {
background: var(--success-color);
color: var(--success-foreground);
transform: translateY(-1px);
box-shadow: var(--shadow-sm);
}
/* Status: Cancelled (Danger) */
.cfdi-status-badge--cancelled {
background: var(--danger-background);
color: var(--danger-color);
border-color: var(--danger-color);
}
.cfdi-status-badge--cancelled:hover {
background: var(--danger-color);
color: var(--danger-foreground);
transform: translateY(-1px);
box-shadow: var(--shadow-sm);
}
/* Status: Draft (Secondary) */
.cfdi-status-badge--draft {
background: var(--secondary-background);
color: var(--text-secondary);
border-color: var(--border-color);
}
.cfdi-status-badge--draft:hover {
background: var(--secondary-color);
color: var(--secondary-foreground);
transform: translateY(-1px);
box-shadow: var(--shadow-sm);
}
/* Status: Failed (Error) */
.cfdi-status-badge--failed {
background: var(--danger-background);
color: var(--danger-color);
border-color: var(--danger-color);
}
.cfdi-status-badge--failed:hover {
background: var(--danger-color);
color: var(--danger-foreground);
transform: translateY(-1px);
box-shadow: var(--shadow-sm);
}
/* Status: Error (Danger) */
.cfdi-status-badge--error {
background: var(--danger-background);
color: var(--danger-color);
border-color: var(--danger-color);
}
.cfdi-status-badge--error:hover {
background: var(--danger-color);
color: var(--danger-foreground);
transform: translateY(-1px);
box-shadow: var(--shadow-sm);
}
/* Status: Unknown (Default) */
.cfdi-status-badge--unknown {
background: var(--secondary-background);
color: var(--text-muted);
border-color: var(--border-color);
}
/* Responsive */
@media (max-width: 767px) {
.cfdi-status-badge {
font-size: 0.8125rem;
padding: 0.3rem 0.6rem;
}
.cfdi-status-badge__icon {
font-size: 0.9rem;
}
}
/* AppActionsMenu - Botón trigger con soporte Dark/Light Mode */
.app-actions-menu {
position: relative;
display: inline-flex;
}
.app-actions-menu__trigger {
display: inline-flex;
align-items: center;
justify-content: center;
width: 32px;
height: 32px;
padding: 4px;
background: transparent;
border: 1px solid var(--border-color);
border-radius: 4px;
cursor: pointer;
transition: all 0.2s ease;
color: var(--text-secondary);
flex-shrink: 0;
}
.app-actions-menu__trigger:hover {
background: var(--hover-background-color);
border-color: var(--primary-color);
color: var(--primary-color);
}
.app-actions-menu__trigger:active {
transform: scale(0.95);
}
.app-actions-menu__trigger svg {
width: 18px;
height: 18px;
min-width: 18px;
min-height: 18px;
max-width: 18px;
max-height: 18px;
display: block;
flex-shrink: 0;
}
/* Backdrop para cerrar al hacer clic fuera */
.app-actions-menu__backdrop {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
z-index: 9998;
background: transparent;
}
/* Dropdown del menú - POSICIONAMIENTO ABSOLUTO RELATIVO AL CONTENEDOR */
.app-actions-menu__dropdown {
position: absolute;
top: calc(100% + 4px);
right: 0;
z-index: 9999;
min-width: 200px;
max-width: 280px;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 8px;
box-shadow: var(--shadow-md);
padding: 4px 0;
animation: menuSlideDown 0.15s ease;
transform-origin: top right;
}
@keyframes menuSlideDown {
from {
opacity: 0;
transform: translateY(-8px) scale(0.95);
}
to {
opacity: 1;
transform: translateY(0) scale(1);
}
}
/* Ajuste para que no se salga de la pantalla */
@media (max-width: 768px) {
.app-actions-menu__dropdown {
right: auto;
left: 50%;
transform: translateX(-50%);
max-width: 90vw;
}
}
.app-actions-menu__list {
list-style: none;
margin: 0;
padding: 0;
}
.app-actions-menu__item {
margin: 0;
padding: 0;
}
.app-actions-menu__btn {
width: 100%;
display: flex;
align-items: center;
gap: 12px;
padding: 10px 16px;
background: transparent;
border: none;
cursor: pointer;
text-align: left;
font-size: 14px;
color: var(--text-color);
transition: all 0.15s ease;
white-space: nowrap;
}
.app-actions-menu__btn:hover:not(:disabled) {
background: var(--hover-background-color);
color: var(--primary-color);
}
.app-actions-menu__btn:active:not(:disabled) {
background: var(--secondary-background);
}
.app-actions-menu__btn:disabled {
opacity: 0.5;
cursor: not-allowed;
}
.app-actions-menu__btn--disabled {
opacity: 0.5;
cursor: not-allowed;
pointer-events: none;
}
.app-actions-menu__btn--danger {
color: var(--danger-color);
}
.app-actions-menu__btn--danger:hover:not(:disabled) {
background: var(--danger-background);
color: var(--danger-dark);
}
.app-actions-menu__btn--success {
color: var(--success-color);
}
.app-actions-menu__btn--success:hover:not(:disabled) {
background: var(--success-background);
color: var(--success-dark);
}
.app-actions-menu__icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 18px;
height: 18px;
flex-shrink: 0;
}
.app-actions-menu__icon svg {
width: 18px;
height: 18px;
display: block;
}
.app-actions-menu__text {
flex: 1;
line-height: 1.4;
}
.app-actions-menu__separator {
height: 1px;
background: var(--border-color);
margin: 4px 8px;
}
/* Ajuste para tablas: alinear a la derecha automáticamente */
td .app-actions-menu {
justify-content: flex-end;
}
/* AppActionsModal - Modal con soporte Dark/Light Mode */
.app-actions-modal {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
z-index: 10000;
display: flex;
align-items: center;
justify-content: center;
padding: 20px;
animation: fadeIn 0.2s ease;
}
@keyframes fadeIn {
from { opacity: 0; }
to { opacity: 1; }
}
.app-actions-modal__backdrop {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: var(--overlay-color);
cursor: pointer;
}
.app-actions-modal__content {
position: relative;
background: var(--surface-color);
border-radius: 12px;
box-shadow: var(--shadow-xl);
max-width: 400px;
width: 100%;
max-height: 80vh;
overflow: hidden;
animation: slideUp 0.3s ease;
border: 1px solid var(--border-color);
}
@keyframes slideUp {
from {
opacity: 0;
transform: translateY(20px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
.app-actions-modal__header {
display: flex;
flex-direction: column;
gap: 8px;
padding: 16px 20px;
border-bottom: 1px solid var(--border-color);
}
.app-actions-modal__header-top {
display: flex;
align-items: center;
justify-content: space-between;
}
.app-actions-modal__title {
margin: 0;
font-size: 18px;
font-weight: 600;
color: var(--text-color);
}
.app-actions-modal__subtitle {
font-size: 14px;
color: var(--text-secondary);
margin: 0;
font-weight: 400;
}
.app-actions-modal__close {
display: inline-flex;
align-items: center;
justify-content: center;
width: 32px;
height: 32px;
padding: 0;
background: transparent;
border: none;
border-radius: 6px;
cursor: pointer;
color: var(--text-secondary);
transition: all 0.2s ease;
flex-shrink: 0;
}
.app-actions-modal__close:hover {
background: var(--hover-background-color);
color: var(--text-color);
}
.app-actions-modal__body {
padding: 8px 0;
max-height: calc(80vh - 85px);
overflow-y: auto;
}
.app-actions-modal__list {
list-style: none;
margin: 0;
padding: 0;
}
.app-actions-modal__item {
margin: 0;
padding: 0;
}
.app-actions-modal__btn {
width: 100%;
display: flex;
align-items: center;
gap: 12px;
padding: 14px 20px;
background: transparent;
border: none;
cursor: pointer;
text-align: left;
font-size: 15px;
color: var(--text-color);
transition: all 0.15s ease;
}
.app-actions-modal__btn:hover:not(:disabled) {
background: var(--hover-background-color);
}
.app-actions-modal__btn:active:not(:disabled) {
background: var(--secondary-background);
}
.app-actions-modal__btn:disabled {
opacity: 0.5;
cursor: not-allowed;
}
.app-actions-modal__btn--disabled {
opacity: 0.5;
cursor: not-allowed;
pointer-events: none;
}
.app-actions-modal__btn--danger {
color: var(--danger-color);
}
.app-actions-modal__btn--danger:hover:not(:disabled) {
background: var(--danger-background);
}
.app-actions-modal__btn--success {
color: var(--success-color);
}
.app-actions-modal__btn--success:hover:not(:disabled) {
background: var(--success-background);
}
.app-actions-modal__icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 20px;
height: 20px;
flex-shrink: 0;
}
.app-actions-modal__icon svg {
width: 20px;
height: 20px;
display: block;
}
.app-actions-modal__text {
flex: 1;
line-height: 1.4;
}
.app-actions-modal__separator {
height: 1px;
background: var(--border-color);
margin: 8px 20px;
}
/* Scrollbar styling */
.app-actions-modal__body::-webkit-scrollbar {
width: 8px;
}
.app-actions-modal__body::-webkit-scrollbar-track {
background: transparent;
}
.app-actions-modal__body::-webkit-scrollbar-thumb {
background: var(--disabled-color);
border-radius: 4px;
}
.app-actions-modal__body::-webkit-scrollbar-thumb:hover {
background: var(--text-muted);
}
/* Responsive */
@media (max-width: 480px) {
.app-actions-modal {
padding: 10px;
align-items: flex-end;
}
.app-actions-modal__content {
max-width: 100%;
border-bottom-left-radius: 0;
border-bottom-right-radius: 0;
}
.app-actions-modal__btn {
padding: 16px 20px;
font-size: 16px;
}
}
/* ==============================================
AppButton - Componente de botón moderno y profesional
============================================== */
/* Base del botón */
.app-button {
font-family: inherit;
font-size: 0.875rem;
font-weight: 600;
line-height: 1.25rem;
padding: 0.625rem 1.25rem;
border-radius: 0.5rem;
border: 1px solid transparent;
cursor: pointer;
transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
outline: none;
display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.5rem;
min-height: 2.5rem;
text-align: center;
white-space: nowrap;
user-select: none;
position: relative;
overflow: hidden;
}
.app-button::before {
content: '';
position: absolute;
top: 50%;
left: 50%;
width: 0;
height: 0;
border-radius: 50%;
background: var(--primary-foreground);
opacity: 0.2;
transform: translate(-50%, -50%);
transition: width 0.6s, height 0.6s;
}
.app-button:active::before {
width: 300px;
height: 300px;
}
.app-button__icon {
display: inline-flex;
align-items: center;
justify-content: center;
font-size: 1.125rem;
line-height: 1;
}
.app-button__text {
display: inline;
font: inherit;
font-weight: inherit;
line-height: inherit;
}
/* ============================================== */
/* Variantes de botón */
/* ============================================== */
/* Primary - Botón principal */
.app-button--primary {
background: var(--primary-color);
color: var(--primary-foreground);
border-color: var(--primary-color);
box-shadow: var(--shadow-sm);
}
.app-button--primary:hover {
background: var(--primary-hover);
color: var(--primary-foreground);
border-color: var(--primary-hover);
box-shadow: var(--shadow-md);
transform: translateY(-1px);
}
.app-button--primary:active {
background: var(--primary-dark);
color: var(--primary-foreground);
border-color: var(--primary-dark);
box-shadow: var(--shadow-sm);
transform: translateY(0);
}
.app-button--primary:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
box-shadow: var(--shadow-md), 0 0 0 3px var(--focus-ring);
}
/* Secondary - Botón secundario */
.app-button--secondary {
background: var(--secondary-color);
color: var(--secondary-foreground);
border-color: var(--secondary-color);
box-shadow: var(--shadow-sm);
}
.app-button--secondary:hover {
background: var(--secondary-dark);
color: var(--secondary-foreground);
border-color: var(--secondary-dark);
box-shadow: var(--shadow-md);
transform: translateY(-1px);
}
.app-button--secondary:active {
background: var(--secondary-dark);
color: var,--secondary-foreground);
box-shadow: var(--shadow-sm);
transform: translateY(0);
}
.app-button--secondary:focus-visible {
outline: 2px solid var(--secondary-color);
outline-offset: 2px;
box-shadow: var(--shadow-md), 0 0 0 3px var(--focus-ring);
}
/* Ghost - Botón sin fondo */
.app-button--ghost {
background: transparent;
color: var(--text-color);
border-color: var(--border-color);
}
.app-button--ghost:hover {
background: var(--hover-background-color);
color: var(--text-color);
border-color: var(--border-color);
}
.app-button--ghost:active {
background: var(--hover-background-color);
color: var(--text-color);
}
.app-button--ghost:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
/* Outline - Botón con borde */
.app-button--outline {
background: transparent;
color: var(--primary-color);
border-color: var(--primary-color);
}
.app-button--outline:hover {
background: var(--primary-color);
color: var(--primary-foreground);
border-color: var(--primary-color);
box-shadow: var(--shadow-sm);
}
.app-button--outline:active {
background: var(--primary-dark);
color: var(--primary-foreground);
border-color: var(--primary-dark);
}
.app-button--outline:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
/* Danger - Botón de acción destructiva */
.app-button--danger {
background: var(--danger-color);
color: var(--danger-foreground);
border-color: var(--danger-color);
box-shadow: var(--shadow-sm);
}
.app-button--danger:hover {
background: var(--danger-light);
color: var(--danger-foreground);
border-color: var(--danger-light);
box-shadow: var(--shadow-md);
transform: translateY(-1px);
}
.app-button--danger:active {
background: var(--danger-dark);
color: var(--danger-foreground);
border-color: var(--danger-dark);
box-shadow: var(--shadow-sm);
transform: translateY(0);
}
.app-button--danger:focus-visible {
outline: 2px solid var(--danger-color);
outline-offset: 2px;
box-shadow: var(--shadow-md), 0 0 0 3px var(--focus-ring);
}
/* Success - Botón de acción exitosa */
.app-button--success {
background: var(--success-color);
color: var(--success-foreground);
border-color: var(--success-color);
box-shadow: var(--shadow-sm);
}
.app-button--success:hover {
background: var(--success-light);
color: var(--success-foreground);
border-color: var(--success-light);
box-shadow: var(--shadow-md);
transform: translateY(-1px);
}
.app-button--success:active {
background: var(--success-dark);
color: var(--success-foreground);
border-color: var(--success-dark);
box-shadow: var(--shadow-sm);
transform: translateY(0);
}
.app-button--success:focus-visible {
outline: 2px solid var(--success-color);
outline-offset: 2px;
box-shadow: var(--shadow-md), 0 0 0 3px var(--focus-ring);
}
/* Warning - Botón de advertencia */
.app-button--warning {
background: var(--warning-color);
color: var(--warning-foreground);
border-color: var(--warning-color);
box-shadow: var(--shadow-sm);
}
.app-button--warning:hover {
background: var(--warning-light);
color: var(--warning-foreground);
border-color: var(--warning-light);
box-shadow: var(--shadow-md);
transform: translateY(-1px);
}
.app-button--warning:active {
background: var(--warning-dark);
color: var(--warning-foreground);
border-color: var(--warning-dark);
box-shadow: var(--shadow-sm);
transform: translateY(0);
}
.app-button--warning:focus-visible {
outline: 2px solid var(--warning-color);
outline-offset: 2px;
box-shadow: var(--shadow-md), 0 0 0 3px var(--focus-ring);
}
/* Info - Botón informativo */
.app-button--info {
background: var(--info-color);
color: var(--info-foreground);
border-color: var(--info-color);
box-shadow: var(--shadow-sm);
}
.app-button--info:hover {
background: var(--info-light);
color: var(--info-foreground);
border-color: var(--info-light);
box-shadow: var(--shadow-md);
transform: translateY(-1px);
}
.app-button--info:active {
background: var(--info-dark);
color: var(--info-foreground);
border-color: var(--info-dark);
box-shadow: var(--shadow-sm);
transform: translateY(0);
}
.app-button--info:focus-visible {
outline: 2px solid var(--info-color);
outline-offset: 2px;
box-shadow: var(--shadow-md), 0 0 0 3px var(--focus-ring);
}
/* Accent - Botón de acento */
.app-button--accent {
background: var(--accent-color);
color: var(--accent-foreground);
border-color: var(--accent-color);
box-shadow: var(--shadow-sm);
}
.app-button--accent:hover {
background: var(--accent-light);
color: var(--accent-foreground);
border-color: var(--accent-light);
box-shadow: var(--shadow-md);
transform: translateY(-1px);
}
.app-button--accent:active {
background: var(--accent-dark);
color: var(--accent-foreground);
border-color: var(--accent-dark);
box-shadow: var(--shadow-sm);
transform: translateY(0);
}
.app-button--accent:focus-visible {
outline: 2px solid var(--accent-color);
outline-offset: 2px;
box-shadow: var(--shadow-md), 0 0 0 3px var(--focus-ring);
}
/* Light - Botón claro */
.app-button--light {
background: var(--surface-color);
color: var(--text-color);
border-color: var(--border-color);
box-shadow: var(--shadow-sm);
}
.app-button--light:hover {
background: var(--secondary-background);
color: var(--text-color);
border-color: var(--border-color);
box-shadow: var(--shadow-md);
}
.app-button--light:active {
background: var(--secondary-background);
color: var(--text-color);
box-shadow: var(--shadow-sm);
}
.app-button--light:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
/* Dark - Botón oscuro (útil en fondos claros) */
.app-button--dark {
background: var(--text-color);
color: var(--text-light);
border-color: var(--text-color);
box-shadow: var(--shadow-sm);
}
.app-button--dark:hover {
background: var(--text-secondary);
color: var(--text-light);
border-color: var(--text-secondary);
box-shadow: var(--shadow-md);
transform: translateY(-1px);
}
.app-button--dark:active {
background: var(--text-color);
color: var(--text-light);
box-shadow: var(--shadow-sm);
transform: translateY(0);
}
.app-button--dark:focus-visible {
outline: 2px solid var(--text-color);
outline-offset: 2px;
}
/* Outline variants adicionales */
.app-button--outline-secondary {
background: transparent;
color: var(--secondary-color);
border-color: var(--secondary-color);
}
.app-button--outline-secondary:hover {
background: var(--secondary-color);
color: var(--secondary-foreground);
border-color: var(--secondary-color);
}
.app-button--outline-danger {
background: transparent;
color: var(--danger-color);
border-color: var(--danger-color);
}
.app-button--outline-danger:hover {
background: var(--danger-color);
color: var(--danger-foreground);
border-color: var(--danger-color);
}
.app-button--outline-success {
background: transparent;
color: var(--success-color);
border-color: var(--success-color);
}
.app-button--outline-success:hover {
background: var(--success-color);
color: var(--success-foreground);
border-color: var(--success-color);
}
/* Link - Botón estilo enlace */
.app-button--link {
background: transparent;
color: var(--link-color);
border: none;
padding: 0.25rem 0.5rem;
min-width: 0;
min-height: 0;
box-shadow: none;
font-weight: 500;
}
.app-button--link:hover {
color: var(--link-hover-color);
text-decoration: underline;
background: transparent;
transform: none;
box-shadow: none;
}
.app-button--link:active {
color: var(--link-hover-color);
background: transparent;
transform: none;
}
.app-button--link:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
box-shadow: none;
}
/* Link Header - Variante ultra discreta para headers de tabla */
.app-button--link-header {
all: unset;
display: inline-flex;
align-items: center;
gap: 0.25rem;
cursor: pointer;
color: var(--table-header-text);
font-size: 0.8125rem;
font-weight: 600;
letter-spacing: 0.05em;
text-transform: uppercase;
transition: color 0.2s ease;
padding: 0;
background: transparent;
}
.app-button--link-header:hover {
color: var(--primary-color);
}
.app-button--link-header:active {
color: var(--primary-dark);
}
.app-button--link-header:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
border-radius: 0.125rem;
}
/* Asegurarse que spans dentro heredan */
.app-button--link-header span,
.app-button--link-header .app-button__text {
color: inherit !important;
font-size: inherit;
font-weight: inherit;
letter-spacing: inherit;
text-transform: inherit;
}
/* Iconos en link-header más pequeños */
.app-button--link-header .app-button__icon,
.app-button--link-header svg {
width: 0.75rem;
height: 0.75rem;
}
/* ============================================== */
/* Estados */
/* ============================================== */
/* Disabled - Estado deshabilitado */
.app-button--disabled,
.app-button:disabled {
background: var(--disabled-background);
color: var(--disabled-color);
border-color: var(--disabled-background);
cursor: not-allowed;
opacity: 0.6;
box-shadow: none;
transform: none;
}
.app-button--disabled:hover,
.app-button:disabled:hover {
background: var(--disabled-background);
color: var(--disabled-color);
border-color: var(--disabled-background);
box-shadow: none;
transform: none;
}
/* Ghost y outline disabled */
.app-button--ghost:disabled,
.app-button--outline:disabled,
.app-button--outline-secondary:disabled,
.app-button--outline-danger:disabled,
.app-button--outline-success:disabled {
background: transparent;
color: var(--disabled-color);
border-color: var(--disabled-color);
}
/* Full width */
.app-button--fullwidth {
width: 100%;
}
/* ============================================== */
/* Tamaños */
/* ============================================== */
.app-button--xs {
font-size: 0.75rem;
padding: 0.375rem 0.75rem;
min-height: 1.75rem;
}
.app-button--sm {
font-size: 0.8125rem;
padding: 0.5rem 1rem;
min-height: 2rem;
}
.app-button--lg {
font-size: 1rem;
padding: 0.75rem 1.5rem;
min-height: 3rem;
}
.app-button--xl {
font-size: 1.125rem;
padding: 1rem 2rem;
min-height: 3.5rem;
}
/* ============================================== */
/* Grupos de botones */
/* ============================================== */
.app-button-group {
display: inline-flex;
gap: 0;
}
.app-button-group .app-button {
border-radius: 0;
}
.app-button-group .app-button:first-child {
border-top-left-radius: 0.5rem;
border-bottom-left-radius: 0.5rem;
}
.app-button-group .app-button:last-child {
border-top-right-radius: 0.5rem;
border-bottom-right-radius: 0.5rem;
}
.app-button-group .app-button:not(:last-child) {
border-right-width: 0;
}
/* ============================================== */
/* Loading state */
/* ============================================== */
.app-button--loading {
pointer-events: none;
position: relative;
color: transparent;
}
.app-button--loading .app-button__icon,
.app-button--loading .app-button__text {
opacity: 0;
}
.app-button--loading::after {
content: '';
position: absolute;
width: 1rem;
height: 1rem;
top: 50%;
left: 50%;
margin-left: -0.5rem;
margin-top: -0.5rem;
border: 2px solid currentColor;
border-top-color: transparent;
border-radius: 50%;
animation: app-button-spin 0.6s linear infinite;
opacity: 1;
}
@keyframes app-button-spin {
to {
transform: rotate(360deg);
}
}
/* ============================================== */
/* Ajustes para modo oscuro */
/* ============================================== */
.app-button__text,
.app-button__icon,
.app-button span {
color: inherit !important;
}
/* ==============================================
AppInput - Componente de entrada moderno
============================================== */
/* Bloque: app-input */
.app-input__control {
display: block;
width: 100%;
max-width: 100%;
box-sizing: border-box;
padding: 0.625rem 1rem;
font-size: 0.9375rem;
line-height: 1.5;
font-weight: 400;
color: var(--text-color);
background-color: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 0.5rem;
transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
outline: none;
box-shadow: var(--shadow-xs);
}
/* Estado focus - Más prominente */
.app-input__control:focus {
border-color: var(--focus-color);
background-color: var(--surface-color);
box-shadow: 0 0 0 3px var(--focus-ring), var(--shadow-sm);
transform: translateY(-1px);
}
/* Estado hover */
.app-input__control:hover:not(:disabled):not([readonly]):not(.app-input__control--invalid) {
border-color: var(--highlight-color);
box-shadow: var(--shadow-sm);
}
/* Estados disabled y readonly */
.app-input__control:disabled,
.app-input__control[readonly] {
background-color: var(--disabled-background);
color: var(--disabled-color);
border-color: var(--border-color);
cursor: not-allowed;
opacity: 0.6;
box-shadow: none;
}
.app-input__control[readonly] {
cursor: default;
}
/* Estado de error - Más visible */
.app-input__control--invalid {
border-color: var(--danger-color);
background-color: var(--surface-color);
color: var(--text-color);
box-shadow: 0 0 0 3px var(--danger-background);
}
.app-input__control--invalid:focus {
border-color: var(--danger-color);
box-shadow: 0 0 0 3px var(--focus-ring), var(--shadow-sm);
}
/* Estado de éxito */
.app-input__control--valid {
border-color: var(--success-color);
background-color: var(--surface-color);
}
.app-input__control--valid:focus {
border-color: var(--success-color);
box-shadow: 0 0 0 3px var(--success-background), var(--shadow-sm);
}
/* Placeholder mejorado */
.app-input__control::placeholder {
color: var(--text-muted);
opacity: 0.7;
font-weight: 400;
}
.app-input__control:focus::placeholder {
opacity: 0.5;
}
/* Tamaños */
.app-input__control--sm {
padding: 0.5rem 0.875rem;
font-size: 0.875rem;
}
.app-input__control--lg {
padding: 0.75rem 1.25rem;
font-size: 1rem;
}
/* ============================================== */
/* Input con iconos */
/* ============================================== */
.app-input__wrapper {
position: relative;
display: flex;
align-items: center;
}
.app-input__wrapper .app-input__control {
padding-right: 2.5rem;
}
.app-input__icon {
position: absolute;
right: 0.75rem;
color: var(--text-muted);
pointer-events: none;
display: flex;
align-items: center;
justify-content: center;
}
.app-input__control:focus ~ .app-input__icon {
color: var(--focus-color);
}
.app-input__control--invalid ~ .app-input__icon {
color: var(--danger-color);
}
/* ============================================== */
/* Responsive */
/* ============================================== */
@media (max-width: 768px) {
.app-input__control {
font-size: 0.875rem;
padding: 0.5rem 0.875rem;
}
.app-input__control--lg {
padding: 0.625rem 1rem;
font-size: 0.9375rem;
}
}
/* ============================================== */
/* Modo oscuro */
/* ============================================== */
@media (prefers-color-scheme: dark) {
.app-input__control {
background-color: var(--surface-color);
border-color: var(--border-color);
box-shadow: var(--shadow-xs);
}
.app-input__control:hover:not(:disabled):not([readonly]):not(.app-input__control--invalid) {
border-color: var(--primary-light);
box-shadow: var(--shadow-sm);
}
.app-input__control:focus {
background-color: var(--surface-alt-color);
border-color: var(--focus-color);
box-shadow: 0 0 0 1px var(--focus-color), 0 0 0 4px var(--focus-ring), var(--shadow-sm);
}
/* Estados de error y éxito más visibles */
.app-input__control--invalid {
border-color: var(--danger-color);
box-shadow: 0 0 0 3px var(--danger-background);
}
.app-input__control--invalid:focus {
box-shadow: 0 0 0 1px var(--danger-color), 0 0 0 4px var(--focus-ring), var(--shadow-sm);
}
.app-input__control--valid {
border-color: var(--success-color);
box-shadow: 0 0 0 3px var(--success-background);
}
.app-input__control--valid:focus {
box-shadow: 0 0 0 1px var(--success-color), 0 0 0 4px var(--success-background), var(--shadow-sm);
}
.app-input__control::placeholder {
color: var(--text-muted);
opacity: 0.6;
}
.app-input__control:disabled,
.app-input__control[readonly] {
background-color: var(--disabled-background);
border-color: var(--border-color);
box-shadow: none;
}
}
/* Override explícito para data-theme dark */
:root[data-theme='dark'] .app-input__control {
background-color: var(--surface-color);
border-color: var(--border-color);
box-shadow: var(--shadow-xs);
}
:root[data-theme='dark'] .app-input__control:hover:not(:disabled):not([readonly]):not(.app-input__control--invalid) {
border-color: var(--primary-light);
box-shadow: var(--shadow-sm);
}
:root[data-theme='dark'] .app-input__control:focus {
background-color: var(--surface-alt-color);
border-color: var(--focus-color);
box-shadow: 0 0 0 1px var(--focus-color), 0 0 0 4px var(--focus-ring), var(--shadow-sm);
}
.app-input-field {
margin-bottom: 1rem; /* unified with select field */
width: 100%;
display: flex;
flex-direction: column;
}
.app-input-field__label-container {
margin-bottom: 0.25rem;
display: flex;
align-items: center;
gap: 0.3rem;
}
/* Unify vertical rhythm: do not reserve extra space when there's no error */
.app-input-field__error {
color: var(--danger-color);
font-size: 0.95rem;
margin-top: 0.2rem; /* slightly tighter */
font-weight: 500;
min-height: 0; /* remove reserved height to align with selects */
}
/* Responsive */
@media (max-width: 600px) {
.app-input-field {
margin-bottom: 0.85rem;
}
.app-input-field__error {
font-size: 0.9rem;
}
}
/* ==============================================
AppLabel - Componente de etiqueta moderno
============================================== */
.app-label {
font-weight: 500;
color: var(--text-color);
font-size: 0.875rem;
margin-bottom: 0.375rem;
display: inline-block;
cursor: pointer;
transition: color 0.2s cubic-bezier(0.4, 0, 0.2, 1);
line-height: 1.5;
letter-spacing: 0.01em;
}
/* Estado de error */
.app-label--error {
color: var(--danger-color);
font-weight: 600;
}
/* Label requerido */
.app-label--required::after {
content: '*';
color: var(--danger-color);
margin-left: 0.25rem;
font-weight: 600;
}
/* Label con tooltip */
.app-label__wrapper {
position: relative;
display: inline-flex;
align-items: center;
gap: 0.375rem;
vertical-align: middle;
}
.app-label__tooltip-icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 1rem;
height: 1rem;
color: var(--text-muted);
cursor: help;
transition: color 0.2s;
}
.app-label__tooltip-icon:hover {
color: var(--primary-color);
}
/* Hover effect */
.app-label:hover {
color: var(--primary-color);
}
.app-label--error:hover {
color: var(--danger-light);
}
/* Tamaños */
.app-label--sm {
font-size: 0.8125rem;
margin-bottom: 0.25rem;
}
.app-label--lg {
font-size: 1rem;
margin-bottom: 0.5rem;
}
/* Estado disabled */
.app-label--disabled {
color: var(--disabled-color);
cursor: not-allowed;
opacity: 0.6;
}
.app-label--disabled:hover {
color: var(--disabled-color);
}
/* ============================================
AppLazySelect - Componente de selección con carga bajo demanda
Nomenclatura BEM: app-lazy-select
Estilo: Botones dentro del input (similar a DateRange)
============================================ */
/* Variables CSS locales */
:root {
--als-spacing-xs: 0.25rem;
--als-spacing-sm: 0.5rem;
--als-spacing-md: 0.75rem;
--als-spacing-lg: 1rem;
--als-spacing-xl: 1.5rem;
--als-radius-sm: 0.375rem;
--als-radius-md: 0.5rem;
--als-transition: all 0.2s ease;
--als-dropdown-max-height: 400px;
}
/* ============================================
BLOQUE: app-lazy-select
============================================ */
.app-lazy-select {
width: 100%;
margin-bottom: 1rem;
display: flex;
flex-direction: column;
position: relative;
}
/* ============================================
ELEMENTO: label-container
============================================ */
.app-lazy-select__label-container {
margin-bottom: var(--als-spacing-xs);
display: flex;
align-items: center;
gap: 0.3rem;
}
/* ============================================
ELEMENTO: input-wrapper (contiene input + botones)
============================================ */
.app-lazy-select__input-wrapper {
position: relative;
width: 100%;
display: flex;
align-items: center;
}
/* ============================================
ELEMENTO: input
============================================ */
.app-lazy-select__input {
flex: 1;
width: 100%;
padding: var(--als-spacing-md) var(--als-spacing-lg);
padding-right: 5rem; /* Espacio para los botones */
border: 1px solid var(--border-color);
border-radius: var(--als-radius-md);
background-color: var(--surface-color);
color: var(--text-color);
font-size: 1rem;
transition: var(--als-transition);
outline: none;
}
.app-lazy-select__input::placeholder {
color: var(--text-muted);
}
.app-lazy-select__input:focus {
border-color: var(--focus-color);
box-shadow: 0 0 0 3px var(--focus-ring);
}
.app-lazy-select__input:hover:not(:disabled):not(:read-only) {
border-color: var(--hover-color);
}
/* MODIFICADOR: invalid */
.app-lazy-select__input--invalid {
border-color: var(--danger-color);
}
.app-lazy-select__input--invalid:focus {
border-color: var(--danger-color);
box-shadow: 0 0 0 3px var(--focus-ring);
}
/* MODIFICADOR: disabled */
.app-lazy-select__input--disabled {
background-color: var(--disabled-background);
color: var(--disabled-color);
cursor: not-allowed;
}
.app-lazy-select__input:read-only {
background-color: var(--secondary-background);
cursor: default;
}
/* ============================================
ELEMENTO: actions (contenedor de botones)
============================================ */
.app-lazy-select__actions {
position: absolute;
right: 0.375rem;
top: 50%;
transform: translateY(-50%);
display: flex;
align-items: center;
gap: 0.25rem;
pointer-events: none;
}
.app-lazy-select__actions > * {
pointer-events: auto;
}
/* ============================================
ELEMENTO: action-btn (botones dentro del input)
============================================ */
.app-lazy-select__action-btn {
width: 2rem;
height: 2rem;
border: none;
border-radius: var(--als-radius-sm);
background-color: transparent;
color: var(--text-muted);
cursor: pointer;
display: inline-flex;
align-items: center;
justify-content: center;
transition: var(--als-transition);
flex-shrink: 0;
}
.app-lazy-select__action-btn:hover:not(:disabled) {
background-color: var(--hover-background-color);
color: var(--text-color);
}
.app-lazy-select__action-btn:active:not(:disabled) {
transform: scale(0.95);
}
.app-lazy-select__action-btn:disabled {
opacity: 0.4;
cursor: not-allowed;
}
.app-lazy-select__action-btn svg {
width: 1.125rem;
height: 1.125rem;
flex-shrink: 0;
}
/* MODIFICADOR: search-btn */
.app-lazy-select__search-btn {
color: var(--primary-color);
}
.app-lazy-select__search-btn:hover:not(:disabled) {
background-color: var(--info-background);
color: var(--primary-color);
}
/* MODIFICADOR: clear-btn */
.app-lazy-select__clear-btn {
color: var(--danger-color);
}
.app-lazy-select__clear-btn:hover:not(:disabled) {
background-color: var(--danger-background);
color: var(--danger-color);
}
/* ============================================
ELEMENTO: spinner (dentro del botón buscar)
============================================ */
.app-lazy-select__spinner {
width: 1.125rem;
height: 1.125rem;
border: 2px solid var(--border-light);
border-top-color: var(--primary-color);
border-radius: 50%;
animation: app-lazy-select-spin 0.8s linear infinite;
}
@keyframes app-lazy-select-spin {
to {
transform: rotate(360deg);
}
}
/* ============================================
ELEMENTO: dropdown
============================================ */
.app-lazy-select__dropdown {
position: absolute;
top: calc(100% + var(--als-spacing-xs));
left: 0;
right: 0;
z-index: 1000;
background-color: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: var(--als-radius-md);
box-shadow: var(--shadow-lg);
max-height: var(--als-dropdown-max-height);
display: flex;
flex-direction: column;
overflow: hidden;
}
/* ============================================
ELEMENTO: empty
============================================ */
.app-lazy-select__empty {
padding: var(--als-spacing-xl);
text-align: center;
}
.app-lazy-select__empty-text {
color: var(--text-muted);
font-size: 0.95rem;
}
/* ============================================
ELEMENTO: list
============================================ */
.app-lazy-select__list {
list-style: none;
margin: 0;
padding: 0;
overflow-y: auto;
max-height: 300px;
}
/* ============================================
ELEMENTO: item
============================================ */
.app-lazy-select__item {
padding: var(--als-spacing-md) var(--als-spacing-lg);
cursor: pointer;
color: var(--text-color);
font-size: 1rem;
transition: var(--als-transition);
border-bottom: 1px solid var(--border-light);
}
.app-lazy-select__item:last-child {
border-bottom: none;
}
.app-lazy-select__item:hover {
background-color: var(--hover-background-color);
}
.app-lazy-select__item:focus {
outline: none;
background-color: var(--hover-background-color);
border-left: 3px solid var(--focus-color);
}
/* MODIFICADOR: selected */
.app-lazy-select__item--selected {
background-color: var(--primary-color);
color: var(--primary-foreground);
font-weight: 600;
}
.app-lazy-select__item--selected:hover {
background-color: var(--primary-hover);
}
/* ============================================
ELEMENTO: pagination
============================================ */
.app-lazy-select__pagination {
padding: var(--als-spacing-md);
border-top: 1px solid var(--border-color);
background-color: var(--surface-alt-color);
}
/* ============================================
ELEMENTO: error
============================================ */
.app-lazy-select__error {
color: var(--danger-color);
font-size: 0.95rem;
margin-top: var(--als-spacing-xs);
font-weight: 500;
}
/* ============================================
RESPONSIVE: Tablet (max-width: 768px)
============================================ */
@media (max-width: 768px) {
.app-lazy-select__input {
padding: var(--als-spacing-sm) var(--als-spacing-md);
padding-right: 5rem;
font-size: 0.95rem;
}
.app-lazy-select__dropdown {
max-height: 350px;
}
.app-lazy-select__list {
max-height: 250px;
}
}
/* ============================================
RESPONSIVE: Mobile (max-width: 640px)
============================================ */
@media (max-width: 640px) {
.app-lazy-select {
margin-bottom: 0.85rem;
}
.app-lazy-select__input {
padding: var(--als-spacing-sm) var(--als-spacing-md);
padding-right: 4.5rem;
font-size: 0.9rem;
}
.app-lazy-select__action-btn {
width: 1.75rem;
height: 1.75rem;
}
.app-lazy-select__action-btn svg {
width: 1rem;
height: 1rem;
}
.app-lazy-select__dropdown {
max-height: 300px;
}
.app-lazy-select__list {
max-height: 200px;
}
.app-lazy-select__item {
padding: var(--als-spacing-sm) var(--als-spacing-md);
font-size: 0.95rem;
}
.app-lazy-select__error {
font-size: 0.9rem;
}
}
/* ============================================
DARK MODE (Media Query)
============================================ */
@media (prefers-color-scheme: dark) {
.app-lazy-select__input {
background-color: var(--surface-color);
color: var(--text-color);
border-color: var(--border-color);
}
.app-lazy-select__dropdown {
background-color: var(--surface-color);
border-color: var(--border-color);
box-shadow: var(--shadow-lg);
}
.app-lazy-select__item {
color: var(--text-color);
border-bottom-color: var(--border-light);
}
.app-lazy-select__item:hover {
background-color: var(--hover-background-color);
}
}
/* ============================================
DARK MODE (Data Attribute)
============================================ */
:root[data-theme='dark'] .app-lazy-select__input {
background-color: var(--surface-color);
color: var(--text-color);
border-color: var(--border-color);
}
:root[data-theme='dark'] .app-lazy-select__dropdown {
background-color: var(--surface-color);
border-color: var(--border-color);
}
:root[data-theme='dark'] .app-lazy-select__item {
color: var(--text-color);
border-bottom-color: var(--border-light);
}
:root[data-theme='dark'] .app-lazy-select__item:hover {
background-color: var(--hover-background-color);
}
/* ============================================
ACCESSIBILITY: Focus visible
============================================ */
.app-lazy-select__input:focus-visible,
.app-lazy-select__item:focus-visible,
.app-lazy-select__action-btn:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
/* ============================================
ACCESSIBILITY: Prefers reduced motion
============================================ */
@media (prefers-reduced-motion: reduce) {
.app-lazy-select__input,
.app-lazy-select__item,
.app-lazy-select__action-btn,
.app-lazy-select__spinner {
transition: none;
animation: none;
}
}
/* ============================================
PRINT: Optimización para impresión
============================================ */
@media print {
.app-lazy-select__dropdown {
display: none;
}
.app-lazy-select__actions {
display: none;
}
}
.app-password-field {
margin-bottom: 1.5rem;
width: 100%;
display: flex;
flex-direction: column;
}
.app-password-field__label-container {
margin-bottom: 0.25rem;
display: flex;
align-items: center;
gap: 0.3rem;
}
.app-password-field__input-wrapper {
position: relative;
display: flex;
align-items: center;
}
.app-password-field__toggle {
position: absolute;
right: 0.75rem;
top: 50%;
transform: translateY(-50%);
background: transparent;
border: none;
cursor: pointer;
color: var(--text-muted);
font-size: 1.2em;
padding: 0 0.25em;
display: flex;
align-items: center;
transition: color 0.2s;
}
.app-password-field__toggle:hover,
.app-password-field__toggle:focus-visible {
color: var(--primary-color);
outline: none;
}
.app-password-field__error {
color: var(--danger-color);
font-size: 0.95rem;
margin-top: 0.3rem;
font-weight: 500;
min-height: 1.2em;
}
/* Responsive */
@media (max-width: 600px) {
.app-password-field {
margin-bottom: 1rem;
}
.app-password-field__error {
font-size: 0.9rem;
}
}
/* ==============================================
AppSelect - Componente de selección moderno
============================================== */
.app-select {
position: relative;
width: 100%;
min-width: 0;
font-family: inherit;
box-sizing: border-box;
display: flex;
flex-direction: column;
max-width: 100%;
margin-bottom: 1rem;
}
/* Control principal */
.app-select__control {
display: flex;
align-items: center;
justify-content: space-between;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 0.5rem;
padding: 0.625rem 1rem;
cursor: pointer;
min-height: 44px;
transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
color: var(--text-color);
width: 100%;
min-width: 0;
box-sizing: border-box;
box-shadow: var(--shadow-xs);
}
.app-select__control:hover {
border-color: var(--highlight-color);
box-shadow: var(--shadow-sm);
}
.app-select__control:focus,
.app-select__control--open {
border-color: var(--focus-color);
box-shadow: 0 0 0 3px var(--focus-ring), var(--shadow-sm);
outline: none;
}
/* Estado de error - aplicado al componente */
.app-select--invalid .app-select__control {
border-color: var(--danger-color);
background: var(--surface-color);
color: var(--text-color);
box-shadow: 0 0 0 3px var(--danger-background);
}
.app-select--invalid .app-select__control:focus,
.app-select--invalid .app-select__control--open {
box-shadow: 0 0 0 3px var(--focus-ring), var(--shadow-sm);
}
/* Mensaje de error */
.app-select__error {
color: var(--danger-color);
font-size: 0.875rem;
margin-top: 0.375rem;
display: flex;
align-items: flex-start;
gap: 0.25rem;
animation: app-select-error-slide-in 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes app-select-error-slide-in {
from {
opacity: 0;
transform: translateY(-4px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
/* Estado de error (legacy) */
.app-select__control--error {
border-color: var(--danger-color);
background: var(--surface-color);
color: var(--text-color);
box-shadow: 0 0 0 3px var(--danger-background);
}
.app-select__control--error:focus,
.app-select__control--error.app-select__control--open {
box-shadow: 0 0 0 3px var(--focus-ring), var(--shadow-sm);
}
/* Placeholder */
.app-select__placeholder {
color: var(--text-muted);
font-style: normal;
opacity: 0.7;
}
/* Texto seleccionado */
.app-select__selected-text {
color: var(--text-color);
font-weight: 500;
}
/* Flecha indicadora */
.app-select__arrow {
margin-left: 0.5rem;
font-size: 1.1em;
color: var(--text-muted);
transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.app-select__control--open .app-select__arrow {
transform: rotate(180deg);
color: var(--focus-color);
}
/* Dropdown */
.app-select__dropdown {
position: absolute;
top: calc(100% + 4px);
left: 0;
right: 0;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 0.5rem;
box-shadow: var(--shadow-lg);
z-index: 100;
padding: 0.5rem 0;
margin-top: 0.25rem;
animation: app-select-dropdown-fade-in 0.2s cubic-bezier(0.4, 0, 0.2, 1);
width: 100%;
min-width: 0;
box-sizing: border-box;
max-width: 100%;
overflow: hidden;
}
@keyframes app-select-dropdown-fade-in {
from {
opacity: 0;
transform: translateY(-8px) scale(0.95);
}
to {
opacity: 1;
transform: translateY(0) scale(1);
}
}
/* Campo de búsqueda */
.app-select__search {
width: calc(100% - 1rem);
margin: 0.5rem 0.5rem;
display: block;
padding: 0.5rem 0.875rem;
border: 1px solid var(--border-color);
border-radius: 0.5rem;
font-size: 0.9375rem;
background: var(--surface-alt-color);
color: var(--text-color);
transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
box-sizing: border-box;
outline: none;
}
.app-select__search:focus {
border-color: var(--focus-color);
box-shadow: 0 0 0 2px var(--focus-ring);
background: var(--surface-color);
}
.app-select__search::placeholder {
color: var(--text-muted);
opacity: 0.7;
}
/* Lista de opciones */
.app-select__list {
list-style: none;
margin: 0;
padding: 0.25rem 0.5rem;
max-height: 240px;
overflow-y: auto;
width: 100%;
min-width: 0;
box-sizing: border-box;
}
/* Scrollbar personalizado */
.app-select__list::-webkit-scrollbar {
width: 6px;
}
.app-select__list::-webkit-scrollbar-track {
background: transparent;
}
.app-select__list::-webkit-scrollbar-thumb {
background: var(--border-color);
border-radius: 3px;
}
.app-select__list::-webkit-scrollbar-thumb:hover {
background: var(--text-muted);
}
/* Ítems de la lista */
.app-select__item {
padding: 0.625rem 0.875rem;
cursor: pointer;
color: var(--text-color);
border-radius: 0.375rem;
transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
width: 100%;
box-sizing: border-box;
font-size: 0.9375rem;
}
.app-select__item:hover,
.app-select__item:focus {
background: var(--hover-background-color);
color: var(--primary-color);
outline: none;
font-weight: 500;
}
.app-select__item--selected {
background: var(--primary-color);
color: var(--text-light);
font-weight: 600;
}
.app-select__item--selected:hover {
background: var(--primary-hover);
color: var(--text-light);
}
/* Estado disabled */
.app-select--disabled .app-select__control {
background: var(--disabled-background);
border-color: var(--border-color);
color: var(--disabled-color);
cursor: not-allowed;
opacity: 0.6;
}
.app-select--disabled .app-select__control:hover {
border-color: var(--border-color);
box-shadow: none;
}
/* ============================================== */
/* Responsive */
/* ============================================== */
@media (max-width: 768px) {
.app-select {
max-width: 100%;
margin-bottom: 0.85rem;
}
.app-select__control {
padding: 0.5rem 0.875rem;
font-size: 0.875rem;
}
.app-select__dropdown {
left: 0;
right: 0;
min-width: 180px;
}
.app-select__list {
max-height: 200px;
}
.app-select__item {
padding: 0.5rem 0.75rem;
font-size: 0.875rem;
}
.app-select__error {
font-size: 0.8125rem;
}
}
/* ============================================== */
/* Modo oscuro */
/* ============================================== */
@media (prefers-color-scheme: dark) {
.app-select__control {
background: var(--surface-color);
border-color: var(--border-color);
box-shadow: var(--shadow-xs);
}
.app-select__control:hover {
border-color: var(--primary-light);
box-shadow: var(--shadow-sm);
}
.app-select__control:focus,
.app-select__control--open {
border-color: var(--focus-color);
box-shadow: 0 0 0 1px var(--focus-color), 0 0 0 4px var(--focus-ring), var(--shadow-sm);
}
.app-select__dropdown {
background: var(--surface-color);
border-color: var(--border-color);
box-shadow: var(--shadow-lg);
}
.app-select__search {
background: var(--surface-alt-color);
border-color: var(--border-color);
box-shadow: var(--shadow-xs);
}
.app-select__search:focus {
border-color: var(--focus-color);
box-shadow: 0 0 0 1px var(--focus-color), 0 0 0 3px var(--focus-ring);
}
.app-select__item:hover,
.app-select__item:focus {
background: var(--hover-background-color);
color: var(--primary-light);
}
.app-select__item--selected {
background: var(--primary-color);
color: var(--text-light);
}
.app-select__item--selected:hover {
background: var(--primary-light);
}
.app-select--invalid .app-select__control {
border-color: var(--danger-color);
box-shadow: 0 0 0 3px var(--danger-background);
}
.app-select__control--error {
border-color: var(--danger-color);
box-shadow: 0 0 0 3px var(--danger-background);
}
}
/* Override explícito para data-theme dark */
:root[data-theme='dark'] .app-select__control {
background: var(--surface-color);
border-color: var(--border-color);
box-shadow: var(--shadow-xs);
}
:root[data-theme='dark'] .app-select__control:hover {
border-color: var(--primary-light);
box-shadow: var(--shadow-sm);
}
:root[data-theme='dark'] .app-select__dropdown {
border-color: var(--border-color);
box-shadow: var(--shadow-lg);
}
:root[data-theme='dark'] .app-select__item:hover,
:root[data-theme='dark'] .app-select__item:focus {
color: var(--primary-light);
}
:root[data-theme='dark'] .app-select--invalid .app-select__control {
border-color: var(--danger-color);
box-shadow: 0 0 0 3px var(--danger-background);
}
.app-select-field { display: block; margin-bottom: 1rem; } /* unify with input field */
.app-select-field__control { margin-top: .25rem; }
.app-select-field--invalid .app-select-field__select { border-color: var(--danger-color); }
:root{
--sw-track: var(--secondary-color);
--sw-thumb: var(--text-light);
--sw-on: var(--success-color);
--sw-bg: var(--background-color);
--sw-fg: var(--text-color);
--sw-focus: var(--focus-color);
}
@media (prefers-color-scheme: light){
:root{
--sw-track: var(--border-color);
--sw-thumb: var(--text-color);
--sw-on: var(--success-color);
--sw-bg: var(--background-color);
--sw-fg: var(--text-color);
--sw-focus: var(--primary-color);
}
}
.app-switch-bool{ display:inline-flex; align-items:center; gap:.5rem; cursor:pointer; color:var(--sw-fg); outline:0; margin-bottom: 1rem; }
.app-switch-bool--disabled{ opacity:.6; cursor:not-allowed; pointer-events:none; }
.app-switch-bool__track{ position:relative; width:2.5rem; height:1.35rem; background:var(--sw-track); border-radius:999px; transition:background .2s ease; }
.app-switch-bool__track--on{ background:var(--sw-on); }
.app-switch-bool__thumb{ position:absolute; top:2px; left:2px; width:1rem; height:1rem; border-radius:999px; background:var(--sw-thumb); transition:transform .2s ease; transform:translateX(0); }
.app-switch-bool__track--on .app-switch-bool__thumb{ transform:translateX(1.15rem); }
.app-switch-bool__label{ font-size:.9rem; }
.app-switch-bool:focus-visible .app-switch-bool__track{ box-shadow:0 0 0 3px var(--focus-ring); }
/* size variants */
.app-switch-bool--sm .app-switch-bool__track{ width:2rem; height:1.1rem; }
.app-switch-bool--sm .app-switch-bool__thumb{ width:.8rem; height:.8rem; top:.15rem; left:.15rem; }
.app-switch-bool--sm .app-switch-bool__track--on .app-switch-bool__thumb{ transform:translateX(.9rem); }
@media (max-width: 640px){ .app-switch-bool__label{ font-size:.85rem; } }
@media (max-width: 600px){ .app-switch-bool{ margin-bottom: .85rem; } }
/* ============================================
CreateComplementModal - Modal de Complemento de Pago
============================================ */
.createComplementModal {
width: 100%;
}
/* ==================== LOADING ==================== */
.createComplementModal__loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: var(--spacing-md);
padding: var(--spacing-xl);
text-align: center;
}
.createComplementModal__loading p {
color: var(--text-color);
font-weight: 500;
}
.createComplementModal__loading small {
color: var(--text-muted);
}
/* ==================== ERROR ==================== */
.createComplementModal__error {
padding: var(--spacing-lg);
background: var(--danger-background);
border: 2px solid var(--danger-color);
border-radius: var(--border-radius);
display: flex;
gap: var(--spacing-md);
}
.createComplementModal__error-icon {
font-size: 2rem;
flex-shrink: 0;
}
.createComplementModal__error-content {
flex: 1;
}
.createComplementModal__error-content h4 {
color: var(--danger-color);
margin-bottom: var(--spacing-sm);
}
.createComplementModal__error-list {
list-style: none;
padding: 0;
margin: var(--spacing-sm) 0;
}
.createComplementModal__error-list li {
padding: var(--spacing-xs) var(--spacing-sm);
background: var(--surface-color);
border-left: 3px solid var(--danger-color);
margin-bottom: var(--spacing-xs);
border-radius: var(--border-radius);
}
/* ==================== SUCCESS ==================== */
.createComplementModal__success {
padding: var(--spacing-lg);
background: var(--success-background);
border: 2px solid var(--success-color);
border-radius: var(--border-radius);
display: flex;
gap: var(--spacing-md);
}
.createComplementModal__success-icon {
font-size: 2.5rem;
flex-shrink: 0;
}
.createComplementModal__success-content {
flex: 1;
}
.createComplementModal__success-content h4 {
color: var(--success-color);
margin-bottom: var(--spacing-md);
font-size: 1.25rem;
}
.createComplementModal__result-details {
background: var(--surface-color);
padding: var(--spacing-md);
border-radius: var(--border-radius);
margin-bottom: var(--spacing-md);
}
.createComplementModal__result-item {
display: flex;
justify-content: space-between;
padding: var(--spacing-xs) 0;
border-bottom: 1px solid var(--border-color);
}
.createComplementModal__result-item:last-child {
border-bottom: none;
}
.createComplementModal__result-item--highlight {
background: var(--success-background);
padding: var(--spacing-sm);
border-radius: var(--border-radius);
margin-top: var(--spacing-sm);
font-size: 1.125rem;
}
.createComplementModal__result-item span:first-child {
font-weight: 500;
color: var(--text-muted);
}
.createComplementModal__result-value {
color: var(--text-color);
font-weight: 600;
}
.createComplementModal__result-value--balance {
color: var(--success-color);
font-size: 1.25rem;
}
/* ==================== PREVIEW CONTAINER ==================== */
.createComplementModal__preview-container {
display: flex;
flex-direction: column;
gap: var(--spacing-lg);
}
/* ==================== SECTIONS ==================== */
.createComplementModal__section {
padding: var(--spacing-md);
background: var(--surface-color);
border-radius: var(--border-radius);
border: 1px solid var(--border-color);
}
.createComplementModal__section--ppd {
background: var(--primary-background);
border-color: var(--primary-color);
}
.createComplementModal__section--balance {
background: var(--info-background);
border-color: var(--info-color);
}
.createComplementModal__section-title {
font-size: 1rem;
font-weight: 600;
color: var(--text-color);
margin-bottom: var(--spacing-md);
padding-bottom: var(--spacing-sm);
border-bottom: 2px solid var(--border-color);
}
/* ==================== PPD INFO ==================== */
.createComplementModal__ppd-info {
display: flex;
flex-direction: column;
gap: var(--spacing-sm);
}
.createComplementModal__ppd-item {
display: flex;
justify-content: space-between;
align-items: center;
}
.createComplementModal__ppd-item span:first-child {
color: var(--text-muted);
font-size: 0.875rem;
}
.createComplementModal__ppd-item strong {
color: var(--primary-color);
font-weight: 600;
}
.createComplementModal__uuid {
font-family: 'Courier New', monospace;
font-size: 0.75rem;
color: var(--text-muted);
}
/* ==================== PAYMENT INFO ==================== */
.createComplementModal__payment-info {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
gap: var(--spacing-md);
}
.createComplementModal__payment-item {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.createComplementModal__payment-item span:first-child {
font-size: 0.75rem;
color: var(--text-muted);
text-transform: uppercase;
}
.createComplementModal__parcialidad {
font-size: 1.5rem;
font-weight: 700;
color: var(--primary-color);
}
.createComplementModal__amount {
font-size: 1.25rem;
font-weight: 600;
color: var(--success-color);
}
/* ==================== BALANCE FLOW ==================== */
.createComplementModal__balance-flow {
display: flex;
align-items: center;
justify-content: space-between;
gap: var(--spacing-md);
padding: var(--spacing-md);
background: var(--surface-color);
border-radius: var(--border-radius);
}
.createComplementModal__balance-item {
display: flex;
flex-direction: column;
gap: 0.25rem;
flex: 1;
}
.createComplementModal__balance-item--final {
background: var(--success-background);
padding: var(--spacing-sm);
border-radius: var(--border-radius);
}
.createComplementModal__balance-label {
font-size: 0.75rem;
color: var(--text-muted);
text-transform: uppercase;
}
.createComplementModal__balance-value {
font-size: 1.125rem;
font-weight: 600;
color: var(--text-color);
}
.createComplementModal__balance-value--success {
color: var(--success-color);
}
.createComplementModal__balance-value--final {
font-size: 1.5rem;
color: var(--success-color);
}
.createComplementModal__balance-separator {
font-size: 1.5rem;
font-weight: 700;
color: var(--text-muted);
flex-shrink: 0;
}
/* ==================== PAID BADGE ==================== */
.createComplementModal__paid-badge {
margin-top: var(--spacing-md);
padding: var(--spacing-sm);
background: var(--success-color);
color: var(--success-foreground);
text-align: center;
border-radius: var(--border-radius);
font-weight: 600;
font-size: 1.125rem;
}
/* ==================== RECEIVER INFO ==================== */
.createComplementModal__receiver-info {
display: flex;
flex-direction: column;
gap: var(--spacing-sm);
}
.createComplementModal__receiver-item {
display: flex;
justify-content: space-between;
}
.createComplementModal__receiver-item span:first-child {
color: var(--text-muted);
font-size: 0.875rem;
}
.createComplementModal__rfc {
font-family: 'Courier New', monospace;
font-weight: 600;
color: var(--text-color);
}
/* ==================== RESPONSIVE ==================== */
@media (max-width: 767px) {
.createComplementModal__balance-flow {
flex-direction: column;
align-items: stretch;
}
.createComplementModal__balance-separator {
text-align: center;
padding: var(--spacing-xs) 0;
}
.createComplementModal__payment-info {
grid-template-columns: 1fr;
}
.createComplementModal__error,
.createComplementModal__success {
flex-direction: column;
text-align: center;
}
.createComplementModal__error-icon,
.createComplementModal__success-icon {
align-self: center;
}
}
/* Dark mode handled by CSS variables */
/* ================================================== */
/* CREATE DIRECT PPD MODAL                            */
/* Modal gen�rico para crear factura PPD directa      */
/* ================================================== */
.createDirectPpdModal {
width: 100%;
}
/* ==================== LOADING STATE ==================== */
.createDirectPpdModal__loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
padding: 3rem;
gap: 1rem;
color: var(--text-secondary);
}
/* ==================== PROGRESS STEPS ==================== */
.createDirectPpdModal__steps {
display: flex;
justify-content: space-between;
margin-bottom: 2rem;
padding: 0 1rem;
position: relative;
}
.createDirectPpdModal__steps::before {
content: '';
position: absolute;
top: 20px;
left: 0;
right: 0;
height: 2px;
background: var(--border-color);
z-index: 0;
}
.createDirectPpdModal__step {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.5rem;
flex: 1;
position: relative;
z-index: 1;
}
.createDirectPpdModal__step-number {
width: 40px;
height: 40px;
border-radius: 50%;
background: var(--surface-color);
border: 2px solid var(--border-color);
display: flex;
align-items: center;
justify-content: center;
font-weight: 600;
color: var(--text-secondary);
transition: all 0.3s;
}
.createDirectPpdModal__step.active .createDirectPpdModal__step-number {
background: var(--primary-color);
border-color: var(--primary-color);
color: var(--primary-foreground);
}
.createDirectPpdModal__step.completed .createDirectPpdModal__step-number {
background: var(--success-color);
border-color: var(--success-color);
color: white;
}
.createDirectPpdModal__step-label {
font-size: 0.875rem;
color: var(--text-secondary);
text-align: center;
font-weight: 500;
}
.createDirectPpdModal__step.active .createDirectPpdModal__step-label {
color: var(--text-color);
font-weight: 600;
}
/* ==================== ERROR MESSAGE ==================== */
.createDirectPpdModal__error {
display: flex;
align-items: flex-start;
gap: 0.75rem;
padding: 1rem;
background: var(--danger-background, rgba(239, 68, 68, 0.1));
border: 1px solid var(--danger-color, #ef4444);
border-radius: 8px;
margin-bottom: 1.5rem;
}
.createDirectPpdModal__error-icon {
font-size: 1.25rem;
flex-shrink: 0;
}
.createDirectPpdModal__error-content {
flex: 1;
}
.createDirectPpdModal__error-content strong {
color: var(--danger-color, #ef4444);
display: block;
margin-bottom: 0.25rem;
}
.createDirectPpdModal__error-content p {
margin: 0;
color: var(--text-color);
}
/* ==================== SECTIONS ==================== */
.createDirectPpdModal__section {
margin-bottom: 1.5rem;
}
.createDirectPpdModal__section-title {
font-size: 1.125rem;
font-weight: 600;
color: var(--text-color);
margin-bottom: 1.25rem;
padding-bottom: 0.75rem;
border-bottom: 2px solid var(--border-color);
}
/* ==================== GRID LAYOUT ==================== */
.createDirectPpdModal__row {
display: flex;
gap: 1rem;
margin-bottom: 1rem;
flex-wrap: wrap;
}
.createDirectPpdModal__col {
flex: 1;
min-width: 0;
}
.createDirectPpdModal__col--3 {
flex: 0 0 calc(25% - 0.75rem);
min-width: 150px;
}
.createDirectPpdModal__col--4 {
flex: 0 0 calc(33.333% - 0.67rem);
min-width: 180px;
}
.createDirectPpdModal__col--6 {
flex: 0 0 calc(50% - 0.5rem);
min-width: 200px;
}
.createDirectPpdModal__col--12 {
flex: 0 0 100%;
}
/* ==================== VALIDATION ERRORS ==================== */
.createDirectPpdModal__validation-error {
background: var(--danger-background, rgba(239, 68, 68, 0.1));
color: var(--danger-color, #ef4444);
padding: 0.75rem 1rem;
border-radius: 6px;
margin-bottom: 1rem;
font-size: 0.875rem;
border-left: 4px solid var(--danger-color, #ef4444);
}
/* ==================== ITEMS LIST ==================== */
.createDirectPpdModal__items {
display: flex;
flex-direction: column;
gap: 1.5rem;
margin-bottom: 1.5rem;
}
.createDirectPpdModal__item {
background: var(--background-color);
border: 1px solid var(--border-color);
border-radius: 8px;
padding: 1.25rem;
}
.createDirectPpdModal__item-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 1rem;
padding-bottom: 0.75rem;
border-bottom: 1px solid var(--border-color);
}
.createDirectPpdModal__item-number {
font-weight: 600;
color: var(--text-color);
font-size: 1rem;
}
.createDirectPpdModal__item-remove {
background: transparent;
border: 1px solid var(--danger-color, #ef4444);
color: var(--danger-color, #ef4444);
padding: 0.375rem 0.75rem;
border-radius: 6px;
cursor: pointer;
font-size: 0.875rem;
transition: all 0.2s;
}
.createDirectPpdModal__item-remove:hover {
background: var(--danger-color, #ef4444);
color: white;
}
.createDirectPpdModal__item-total {
display: flex;
justify-content: flex-end;
align-items: center;
gap: 1rem;
margin-top: 1rem;
padding-top: 1rem;
border-top: 1px solid var(--border-color);
}
.createDirectPpdModal__item-total-label {
font-weight: 500;
color: var(--text-secondary);
}
.createDirectPpdModal__item-total-value {
font-size: 1.25rem;
font-weight: 700;
color: var(--primary-color);
}
/* ==================== SUMMARY (STEP 3) ==================== */
.createDirectPpdModal__summary {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
.createDirectPpdModal__summary-section {
background: var(--background-color);
border: 1px solid var(--border-color);
border-radius: 8px;
padding: 1.25rem;
}
.createDirectPpdModal__summary-section h5 {
font-size: 1rem;
font-weight: 600;
color: var(--text-color);
margin-bottom: 1rem;
padding-bottom: 0.5rem;
border-bottom: 1px solid var(--border-color);
}
.createDirectPpdModal__summary-list {
display: grid;
grid-template-columns: auto 1fr;
gap: 0.5rem 1rem;
}
.createDirectPpdModal__summary-list dt {
font-weight: 500;
color: var(--text-secondary);
}
.createDirectPpdModal__summary-list dd {
margin: 0;
color: var(--text-color);
font-weight: 500;
}
.createDirectPpdModal__summary-item {
display: flex;
justify-content: space-between;
align-items: center;
padding: 0.75rem 0;
border-bottom: 1px solid var(--border-color);
}
.createDirectPpdModal__summary-item:last-child {
border-bottom: none;
}
.createDirectPpdModal__summary-item-desc {
flex: 1;
color: var(--text-color);
}
.createDirectPpdModal__summary-item-amount {
font-weight: 600;
color: var(--text-color);
}
.createDirectPpdModal__summary-totals {
background: var(--surface-color);
padding: 1.25rem;
border-radius: 8px;
}
.createDirectPpdModal__summary-total-row {
display: flex;
justify-content: space-between;
align-items: center;
padding: 0.5rem 0;
font-size: 0.9375rem;
}
.createDirectPpdModal__summary-total-row--grand {
margin-top: 0.75rem;
padding-top: 0.75rem;
border-top: 2px solid var(--border-color);
font-size: 1.25rem;
font-weight: 700;
color: var(--primary-color);
}
/* ==================== RESPONSIVE ==================== */
@media (max-width: 768px) {
.createDirectPpdModal__steps {
padding: 0;
}
.createDirectPpdModal__step-label {
font-size: 0.75rem;
}
.createDirectPpdModal__step-number {
width: 35px;
height: 35px;
font-size: 0.875rem;
}
.createDirectPpdModal__row {
flex-direction: column;
}
.createDirectPpdModal__col,
.createDirectPpdModal__col--3,
.createDirectPpdModal__col--4,
.createDirectPpdModal__col--6 {
flex: 0 0 100%;
min-width: 0;
}
.createDirectPpdModal__item-header {
flex-direction: column;
align-items: flex-start;
gap: 0.75rem;
}
.createDirectPpdModal__summary-list {
grid-template-columns: 1fr;
gap: 0.25rem;
}
}
/* ==================== DARK MODE ==================== */
@media (prefers-color-scheme: dark) {
.createDirectPpdModal__steps::before {
background: var(--border-color-dark, #374151);
}
.createDirectPpdModal__error {
background: rgba(239, 68, 68, 0.15);
border-color: rgba(239, 68, 68, 0.5);
}
.createDirectPpdModal__item {
background: var(--background-color-dark, #1f2937);
border-color: var(--border-color-dark, #374151);
}
.createDirectPpdModal__summary-section {
background: var(--background-color-dark, #1f2937);
border-color: var(--border-color-dark, #374151);
}
.createDirectPpdModal__summary-totals {
background: var(--surface-color-dark, #111827);
}
}
/* ============================================
CreatePpdModal - Modal de Creaci�n PPD
============================================
Reutiliza estilos de StampPaymentModal
============================================ */
.createPpdModal {
width: 100%;
}
/* ==================== LOADING ==================== */
.createPpdModal__loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: var(--spacing-md);
padding: var(--spacing-xl);
text-align: center;
}
.createPpdModal__loading p {
color: var(--text-color);
font-weight: 500;
}
.createPpdModal__loading small {
color: var(--text-muted);
}
/* ==================== ERROR ==================== */
.createPpdModal__error {
padding: var(--spacing-lg);
background: var(--danger-background);
border: 2px solid var(--danger-color);
border-radius: var(--border-radius);
display: flex;
gap: var(--spacing-md);
}
.createPpdModal__error-icon {
font-size: 2rem;
flex-shrink: 0;
}
.createPpdModal__error-content {
flex: 1;
}
.createPpdModal__error-content h4 {
color: var(--danger-color);
margin-bottom: var(--spacing-sm);
}
.createPpdModal__error-content p {
color: var(--text-color);
}
.createPpdModal__error-list {
list-style: none;
padding: 0;
margin: var(--spacing-sm) 0;
}
.createPpdModal__error-list li {
padding: var(--spacing-xs) var(--spacing-sm);
background: var(--surface-color);
border-left: 3px solid var(--danger-color);
margin-bottom: var(--spacing-xs);
border-radius: var(--border-radius);
}
/* ==================== SUCCESS ==================== */
.createPpdModal__success {
padding: var(--spacing-lg);
background: var(--success-background);
border: 2px solid var(--success-color);
border-radius: var(--border-radius);
display: flex;
gap: var(--spacing-md);
}
.createPpdModal__success-icon {
font-size: 2.5rem;
flex-shrink: 0;
}
.createPpdModal__success-content {
flex: 1;
}
.createPpdModal__success-content h4 {
color: var(--success-color);
margin-bottom: var(--spacing-md);
font-size: 1.25rem;
}
.createPpdModal__result-details {
background: var(--surface-color);
padding: var(--spacing-md);
border-radius: var(--border-radius);
margin-bottom: var(--spacing-md);
}
.createPpdModal__result-item {
display: flex;
justify-content: space-between;
padding: var(--spacing-xs) 0;
border-bottom: 1px solid var(--border-color);
}
.createPpdModal__result-item:last-child {
border-bottom: none;
}
.createPpdModal__result-item span:first-child {
font-weight: 500;
color: var(--text-muted);
}
.createPpdModal__result-value {
color: var(--text-color);
font-weight: 600;
}
.createPpdModal__next-steps {
margin-top: var(--spacing-md);
padding: var(--spacing-md);
background: var(--info-background);
border-radius: var(--border-radius);
}
.createPpdModal__next-steps h5 {
color: var(--info-color);
margin-bottom: var(--spacing-sm);
}
.createPpdModal__next-steps ol {
padding-left: var(--spacing-md);
margin: 0;
}
.createPpdModal__next-steps li {
color: var(--text-color);
margin-bottom: 0.25rem;
}
/* ==================== FORM CONTAINER ==================== */
.createPpdModal__form-container {
display: flex;
flex-direction: column;
gap: var(--spacing-lg);
}
/* ==================== SECTIONS ==================== */
.createPpdModal__section {
padding: var(--spacing-md);
background: var(--surface-color);
border-radius: var(--border-radius);
border: 1px solid var(--border-color);
}
.createPpdModal__section-title {
font-size: 1rem;
font-weight: 600;
color: var(--text-color);
margin-bottom: var(--spacing-md);
padding-bottom: var(--spacing-sm);
border-bottom: 2px solid var(--border-color);
}
/* ==================== INFO GRID ==================== */
.createPpdModal__info-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: var(--spacing-sm);
}
.createPpdModal__info-item {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.createPpdModal__info-label {
font-size: 0.75rem;
font-weight: 500;
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: 0.05em;
}
.createPpdModal__info-value {
font-weight: 600;
color: var(--text-color);
}
/* ==================== FORM ==================== */
.createPpdModal__form {
display: flex;
flex-direction: column;
gap: var(--spacing-md);
}
/* ==================== INFO BOX ==================== */
.createPpdModal__info-box {
padding: var(--spacing-md);
background: var(--info-background);
border: 1px solid var(--info-color);
border-radius: var(--border-radius);
display: flex;
gap: var(--spacing-md);
}
.createPpdModal__info-box-icon {
font-size: 1.5rem;
flex-shrink: 0;
}
.createPpdModal__info-box-content {
flex: 1;
}
.createPpdModal__info-box-content strong {
color: var(--info-color);
display: block;
margin-bottom: var(--spacing-xs);
}
.createPpdModal__info-box-content ul {
list-style: disc;
padding-left: var(--spacing-md);
margin: var(--spacing-xs) 0;
}
.createPpdModal__info-box-content li {
color: var(--text-color);
margin-bottom: 0.25rem;
}
/* ==================== RESPONSIVE ==================== */
@media (max-width: 767px) {
.createPpdModal__info-grid {
grid-template-columns: 1fr;
}
.createPpdModal__error,
.createPpdModal__success {
flex-direction: column;
text-align: center;
}
.createPpdModal__error-icon,
.createPpdModal__success-icon {
align-self: center;
}
.createPpdModal__info-box {
flex-direction: column;
text-align: center;
}
.createPpdModal__info-box-icon {
align-self: center;
}
}
/* Dark mode handled by CSS variables */
/* ===== FISCALS COMPONENT ===== */
.fiscals {
width: 100%;
}
/* ===== HEADER ===== */
.fiscals__header {
display: flex;
flex-direction: column;
gap: 0.5rem;
margin-bottom: 1rem;
}
.fiscals__actions {
display: flex;
justify-content: space-between;
align-items: center;
gap: 1rem;
width: 100%;
}
.fiscals__actions-left {
display: flex;
align-items: center;
gap: 0.5rem;
}
.fiscals__actions-right {
display: flex;
align-items: center;
gap: 0.5rem;
margin-left: auto;
}
.fiscals__search-group {
display: flex;
align-items: center;
gap: 0.3rem;
}
.fiscals__actions-cell {
display: flex;
gap: 0.25rem;
flex-wrap: wrap;
}
/* ===== SELECTOR MODE ===== */
.fiscals__selector {
display: flex;
flex-direction: column;
gap: 0.5rem;
width: 100%;
}
.fiscals__selector-group {
display: flex;
align-items: center;
gap: 0.5rem;
width: 100%;
}
.fiscals__select {
flex: 1;
padding: 0.5rem 0.75rem;
border: 1px solid var(--border-color);
border-radius: 6px;
background: var(--surface-color);
color: var(--text-color);
font-size: 0.875rem;
cursor: pointer;
transition: border-color 0.2s ease;
}
.fiscals__select:hover {
border-color: var(--primary-color);
}
.fiscals__select:focus {
outline: none;
border-color: var(--primary-color);
box-shadow: 0 0 0 2px var(--focus-ring);
}
.fiscals__empty {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;
padding: 0.75rem 1rem;
background: var(--info-background);
border: 1px solid var(--info-color);
border-radius: 6px;
color: var(--info-foreground);
}
.fiscals__warning {
padding: 0.5rem 0.75rem;
background: var(--warning-background);
border: 1px solid var(--warning-color);
border-radius: 6px;
color: var(--warning-foreground);
}
/* ===== BADGES ===== */
.fiscals__badge {
display: inline-flex;
align-items: center;
justify-content: center;
padding: 0.125rem 0.375rem;
margin-left: 0.5rem;
border-radius: 4px;
font-size: 0.75rem;
}
.fiscals__badge--default {
background: var(--success-background);
color: var(--success-foreground);
}
/* ===== FORM ===== */
.fiscals__form {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 1rem 1.5rem;
width: 100%;
box-sizing: border-box;
}
.fiscals__form-full {
grid-column: 1 / -1;
}
.fiscals__form-divider {
grid-column: 1 / -1;
display: flex;
align-items: center;
gap: 1rem;
margin: 0.5rem 0;
color: var(--text-secondary);
font-size: 0.75rem;
text-transform: uppercase;
letter-spacing: 0.05em;
}
.fiscals__form-divider::before,
.fiscals__form-divider::after {
content: "";
flex: 1;
height: 1px;
background: var(--border-color);
}
.fiscals__form-actions {
display: flex;
justify-content: flex-end;
gap: 0.75rem;
margin-top: 1.25rem;
padding-top: 1rem;
border-top: 1px solid var(--border-color);
}
/* ===== TABS DEL FORMULARIO FISCAL ===== */
.fiscals__tabs .app-tabs__list {
justify-content: flex-start;
gap: 0.25rem;
padding-bottom: 0.75rem;
border-bottom: 1px solid var(--border-color);
margin-bottom: 0.25rem;
}
.fiscals__tabs .app-tabs__panels {
margin-top: 1.25rem;
}
/* ===== DISCLAIMER ===== */
.fiscals__disclaimer {
grid-column: 1 / -1;
background: var(--warning-background);
border: 1px solid var(--warning-color);
padding: 0.75rem 1rem;
border-radius: 6px;
font-size: 0.75rem;
line-height: 1.4;
color: var(--warning-foreground);
}
/* ===== SELECTED STATE ===== */
.fiscals__row--selected {
background: var(--hover-background-color);
border-left: 4px solid var(--primary-color);
}
/* ===== SELECT BUTTON ===== */
.fiscals__select-btn {
font-size: 0.8rem;
padding: 0.3rem 0.75rem;
border-radius: 6px;
white-space: nowrap;
min-width: auto;
}
/* ===== RESPONSIVE ===== */
@media (max-width: 768px) {
.fiscals__form {
grid-template-columns: 1fr;
gap: 1rem;
}
.fiscals__actions {
flex-direction: column;
align-items: stretch;
}
.fiscals__actions-right {
margin-left: 0;
}
.fiscals__search-group {
width: 100%;
}
.fiscals__selector-group {
flex-direction: column;
}
.fiscals__select {
width: 100%;
}
.fiscals__empty {
flex-direction: column;
text-align: center;
}
}
@media (max-width: 480px) {
.fiscals__form {
gap: 0.75rem;
}
.fiscals__actions-cell {
flex-direction: column;
gap: 0.5rem;
}
}
/* ============================================
PaymentHistoryTimeline - Timeline de Complementos
============================================ */
.paymentHistoryTimeline {
width: 100%;
}
/* ==================== LOADING ==================== */
.paymentHistoryTimeline__loading {
display: flex;
flex-direction: column;
align-items: center;
gap: var(--spacing-sm);
padding: var(--spacing-xl);
color: var(--text-muted);
}
/* ==================== ERROR ==================== */
.paymentHistoryTimeline__error {
padding: var(--spacing-md);
background: var(--danger-background);
border: 1px solid var(--danger-color);
border-radius: var(--border-radius);
color: var(--danger-color);
text-align: center;
}
/* ==================== EMPTY ==================== */
.paymentHistoryTimeline__empty {
display: flex;
flex-direction: column;
align-items: center;
gap: var(--spacing-sm);
padding: var(--spacing-xl);
text-align: center;
color: var(--text-muted);
}
.paymentHistoryTimeline__empty-icon {
font-size: 3rem;
opacity: 0.5;
}
.paymentHistoryTimeline__empty p {
margin: 0;
font-weight: 500;
color: var(--text-color);
}
.paymentHistoryTimeline__empty small {
font-size: 0.875rem;
}
/* ==================== HEADER ==================== */
.paymentHistoryTimeline__header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: var(--spacing-lg);
padding-bottom: var(--spacing-md);
border-bottom: 2px solid var(--border-color);
}
.paymentHistoryTimeline__title {
font-size: 1.125rem;
font-weight: 600;
color: var(--text-color);
margin: 0;
}
.paymentHistoryTimeline__count {
font-size: 0.875rem;
color: var(--text-muted);
background: var(--secondary-background);
padding: 0.25rem 0.5rem;
border-radius: var(--border-radius);
}
/* ==================== LIST ==================== */
.paymentHistoryTimeline__list {
position: relative;
display: flex;
flex-direction: column;
gap: var(--spacing-lg);
}
/* ==================== ITEM ==================== */
.paymentHistoryTimeline__item {
position: relative;
display: flex;
gap: var(--spacing-md);
padding-left: var(--spacing-md);
}
.paymentHistoryTimeline__item::before {
content: '';
position: absolute;
left: 1.125rem;
top: 2.5rem;
bottom: -1.5rem;
width: 2px;
background: var(--border-color);
}
.paymentHistoryTimeline__item:last-child::before {
display: none;
}
/* ==================== MARKER ==================== */
.paymentHistoryTimeline__marker {
flex-shrink: 0;
width: 2.5rem;
height: 2.5rem;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
background: var(--surface-color);
border: 2px solid var(--border-color);
font-size: 1.25rem;
z-index: 1;
}
.paymentHistoryTimeline__item--valid .paymentHistoryTimeline__marker {
background: var(--success-background);
border-color: var(--success-color);
}
.paymentHistoryTimeline__item--cancelled .paymentHistoryTimeline__marker {
background: var(--danger-background);
border-color: var(--danger-color);
}
.paymentHistoryTimeline__item--failed .paymentHistoryTimeline__marker {
background: var(--warning-background);
border-color: var(--warning-color);
}
.paymentHistoryTimeline__marker-icon {
display: block;
}
/* ==================== CONTENT ==================== */
.paymentHistoryTimeline__content {
flex: 1;
padding: var(--spacing-md);
background: var(--surface-color);
border-radius: var(--border-radius);
border: 1px solid var(--border-color);
box-shadow: var(--shadow-xs);
}
.paymentHistoryTimeline__item--valid .paymentHistoryTimeline__content {
border-left: 3px solid var(--success-color);
}
.paymentHistoryTimeline__item--cancelled .paymentHistoryTimeline__content {
border-left: 3px solid var(--danger-color);
opacity: 0.7;
}
.paymentHistoryTimeline__item--failed .paymentHistoryTimeline__content {
border-left: 3px solid var(--warning-color);
}
.paymentHistoryTimeline__content-header {
display: flex;
justify-content: space-between;
align-items: flex-start;
margin-bottom: var(--spacing-md);
}
.paymentHistoryTimeline__content-title {
display: flex;
align-items: center;
gap: var(--spacing-sm);
flex-wrap: wrap;
}
.paymentHistoryTimeline__content-title strong {
color: var(--text-color);
font-size: 1rem;
}
.paymentHistoryTimeline__date {
font-size: 0.75rem;
color: var(--text-muted);
white-space: nowrap;
}
/* ==================== STATUS BADGE ==================== */
.paymentHistoryTimeline__status-badge {
padding: 0.25rem 0.5rem;
border-radius: var(--border-radius);
font-size: 0.75rem;
font-weight: 600;
text-transform: uppercase;
}
.paymentHistoryTimeline__status-badge--valid {
background: var(--success-background);
color: var(--success-color);
}
.paymentHistoryTimeline__status-badge--cancelled {
background: var(--danger-background);
color: var(--danger-color);
}
.paymentHistoryTimeline__status-badge--failed {
background: var(--warning-background);
color: var(--warning-color);
}
.paymentHistoryTimeline__status-badge--default {
background: var(--secondary-background);
color: var(--text-muted);
}
/* ==================== DETAILS ==================== */
.paymentHistoryTimeline__details {
display: flex;
flex-direction: column;
gap: var(--spacing-sm);
}
.paymentHistoryTimeline__detail-row {
display: flex;
justify-content: space-between;
align-items: center;
padding: var(--spacing-xs) 0;
}
.paymentHistoryTimeline__detail-label {
font-size: 0.875rem;
color: var(--text-muted);
font-weight: 500;
}
.paymentHistoryTimeline__detail-value {
font-size: 0.875rem;
color: var(--text-color);
font-weight: 600;
}
.paymentHistoryTimeline__detail-value--uuid {
font-family: 'Courier New', monospace;
font-size: 0.75rem;
}
.paymentHistoryTimeline__detail-value--amount {
color: var(--success-color);
font-size: 1rem;
}
/* ==================== BALANCE CHANGE ==================== */
.paymentHistoryTimeline__balance-change {
display: flex;
align-items: center;
gap: var(--spacing-sm);
padding: var(--spacing-sm);
background: var(--secondary-background);
border-radius: var(--border-radius);
margin-top: var(--spacing-sm);
flex-wrap: wrap;
}
.paymentHistoryTimeline__balance-item {
font-size: 0.875rem;
color: var(--text-muted);
}
.paymentHistoryTimeline__balance-item strong {
color: var(--text-color);
}
.paymentHistoryTimeline__balance-item--new strong {
color: var(--success-color);
font-size: 1rem;
}
.paymentHistoryTimeline__balance-arrow {
color: var(--text-muted);
font-weight: bold;
}
/* ==================== PAID BADGE ==================== */
.paymentHistoryTimeline__paid-badge {
margin-top: var(--spacing-sm);
padding: var(--spacing-sm);
background: var(--success-color);
color: var(--success-foreground);
text-align: center;
border-radius: var(--border-radius);
font-weight: 600;
}
/* ==================== ACTIONS ==================== */
.paymentHistoryTimeline__actions {
display: flex;
gap: var(--spacing-sm);
margin-top: var(--spacing-md);
padding-top: var(--spacing-md);
border-top: 1px solid var(--border-color);
}
/* ==================== RESPONSIVE ==================== */
@media (max-width: 767px) {
.paymentHistoryTimeline__item {
padding-left: 0;
}
.paymentHistoryTimeline__item::before {
left: 1rem;
}
.paymentHistoryTimeline__marker {
width: 2rem;
height: 2rem;
font-size: 1rem;
}
.paymentHistoryTimeline__content-header {
flex-direction: column;
gap: var(--spacing-xs);
}
.paymentHistoryTimeline__date {
align-self: flex-start;
}
.paymentHistoryTimeline__detail-row {
flex-direction: column;
align-items: flex-start;
gap: 0.25rem;
}
.paymentHistoryTimeline__balance-change {
flex-direction: column;
align-items: flex-start;
}
.paymentHistoryTimeline__balance-arrow {
transform: rotate(90deg);
}
.paymentHistoryTimeline__actions {
flex-direction: column;
}
}
/* Dark mode handled by CSS variables */
/* ============================================
PaymentStatusBadge Component
Badge visual para estado de pago de facturas
============================================ */
/* ============= Base Badge ============= */
.payment-status-badge {
display: inline-flex;
align-items: center;
gap: 0.375rem;
padding: 0.375rem 0.75rem;
border-radius: 9999px;
font-size: 0.875rem;
font-weight: 500;
line-height: 1.25rem;
white-space: nowrap;
transition: all 0.2s ease;
cursor: help;
}
.payment-status-badge__icon {
font-size: 1rem;
line-height: 1;
}
.payment-status-badge__text {
font-weight: 600;
}
/* ============= Status Colors ============= */
/* Unpaid - Rojo */
.payment-status-badge--unpaid {
background-color: var(--danger-background);
color: var(--danger-color);
border: 1px solid var(--danger-color);
}
/* Partially Paid - Amarillo */
.payment-status-badge--partial {
background-color: var(--warning-background);
color: var(--warning-color);
border: 1px solid var(--warning-color);
}
/* Fully Paid - Verde */
.payment-status-badge--paid {
background-color: var(--success-background);
color: var(--success-color);
border: 1px solid var(--success-color);
}
/* ============= Sizes ============= */
.payment-status-badge--sm {
padding: 0.25rem 0.5rem;
font-size: 0.75rem;
gap: 0.25rem;
}
.payment-status-badge--sm .payment-status-badge__icon {
font-size: 0.875rem;
}
.payment-status-badge--md {
padding: 0.375rem 0.75rem;
font-size: 0.875rem;
gap: 0.375rem;
}
.payment-status-badge--md .payment-status-badge__icon {
font-size: 1rem;
}
.payment-status-badge--lg {
padding: 0.5rem 1rem;
font-size: 1rem;
gap: 0.5rem;
}
.payment-status-badge--lg .payment-status-badge__icon {
font-size: 1.25rem;
}
/* ============= Hover Effects ============= */
.payment-status-badge:hover {
transform: translateY(-1px);
box-shadow: var(--shadow-sm);
}
/* ============= Responsive ============= */
@media (max-width: 640px) {
.payment-status-badge {
font-size: 0.8125rem;
padding: 0.3125rem 0.625rem;
}
.payment-status-badge--lg {
font-size: 0.875rem;
padding: 0.4375rem 0.875rem;
}
}
/* Payment Modal Styles */
.payment-modal__container {
padding: 1rem;
min-height: 200px;
}
/* Estado: Error */
.payment-modal__error {
display: flex;
flex-direction: column;
align-items: center;
gap: 1.5rem;
padding: 2rem;
text-align: center;
}
.payment-modal__error-icon {
width: 64px;
height: 64px;
color: var(--danger-color);
}
.payment-modal__error-text {
color: var(--text-color);
font-size: 1rem;
margin: 0;
}
/* Estado: Success */
.payment-modal__success {
display: flex;
flex-direction: column;
align-items: center;
gap: 1.5rem;
padding: 2rem;
text-align: center;
}
.payment-modal__success-icon {
width: 64px;
height: 64px;
color: var(--success-color);
}
.payment-modal__success-title {
color: var(--text-color);
font-size: 1.5rem;
font-weight: 700;
margin: 0;
}
.payment-modal__success-text {
color: var(--text-color);
font-size: 1rem;
margin: 0;
}
.payment-modal__redirecting {
color: var(--text-muted);
font-size: 0.875rem;
margin: 0;
}
/* Estado: Opening */
.payment-modal__opening {
display: flex;
flex-direction: column;
align-items: center;
gap: 1rem;
padding: 2rem;
}
.payment-modal__opening-text {
color: var(--text-muted);
margin: 0;
}
/* Estado: Waiting Payment */
.payment-modal__waiting-payment {
display: flex;
flex-direction: column;
gap: 1.5rem;
padding: 1.5rem;
}
.payment-modal__info-icon {
width: 48px;
height: 48px;
color: var(--primary-color);
margin: 0 auto;
flex-shrink: 0;
}
.payment-modal__waiting-title {
color: var(--text-color);
font-size: 1.25rem;
font-weight: 600;
margin: 0;
text-align: center;
}
.payment-modal__waiting-text {
color: var(--text-muted);
margin: 0;
text-align: center;
line-height: 1.6;
}
.payment-modal__instructions {
background: var(--surface-color);
border-left: 4px solid var(--primary-color);
border-radius: 8px;
padding: 1rem 1.5rem;
}
.payment-modal__instructions p {
color: var(--text-color);
font-weight: 600;
margin: 0 0 0.75rem 0;
}
.payment-modal__instructions ol {
margin: 0;
padding-left: 1.5rem;
color: var(--text-color);
}
.payment-modal__instructions li {
margin-bottom: 0.5rem;
line-height: 1.5;
}
/* Estado: Checking Status */
.payment-modal__verifying,
.payment-modal__checking,
.payment-modal__verifying-manual,
.payment-modal__confirming {
display: flex;
flex-direction: column;
align-items: center;
gap: 1.5rem;
padding: 2rem;
text-align: center;
}
.payment-modal__verifying-title,
.payment-modal__checking-title,
.payment-modal__confirming-title {
color: var(--text-color);
font-size: 1.125rem;
font-weight: 600;
margin: 0;
}
.payment-modal__verifying-text,
.payment-modal__checking-text,
.payment-modal__confirming-text {
color: var(--text-muted);
margin: 0;
line-height: 1.6;
}
.payment-modal__attempts {
color: var(--text-muted);
font-size: 0.875rem;
margin: 0;
}
/* Estado: Waiting Confirm (Manual) */
.payment-modal__manual-confirm {
display: flex;
flex-direction: column;
gap: 1.5rem;
padding: 1.5rem;
}
.payment-modal__question-icon {
width: 48px;
height: 48px;
color: var(--warning-color);
margin: 0 auto;
flex-shrink: 0;
}
.payment-modal__manual-title {
color: var(--text-color);
font-size: 1.25rem;
font-weight: 600;
margin: 0;
text-align: center;
}
.payment-modal__manual-text {
color: var(--text-muted);
margin: 0;
text-align: center;
line-height: 1.6;
}
.payment-modal__manual-info {
background: var(--surface-color);
border-radius: 8px;
padding: 1rem 1.5rem;
line-height: 1.6;
}
.payment-modal__manual-info p {
margin: 0 0 0.75rem 0;
color: var(--text-color);
}
.payment-modal__manual-info p:last-child {
margin-bottom: 0;
}
.payment-modal__manual-error {
display: flex;
align-items: center;
gap: 0.75rem;
padding: 1rem;
background: var(--danger-background);
border: 1px solid var(--danger-color);
border-radius: 8px;
color: var(--danger-color);
font-size: 0.875rem;
}
.payment-modal__error-icon-small {
width: 20px;
height: 20px;
flex-shrink: 0;
}
/* Timer compartido */
.payment-modal__timer {
text-align: center;
color: var(--text-muted);
font-size: 0.875rem;
margin: 0;
padding: 0.75rem;
background: var(--surface-color);
border-radius: 8px;
}
.payment-modal__timer strong {
color: var(--primary-color);
font-weight: 600;
}
/* Actions compartidas */
.payment-modal__actions {
display: flex;
gap: 1rem;
justify-content: center;
flex-wrap: wrap;
}
.payment-modal__actions button {
min-width: 180px;
}
/* Responsive */
@media (max-width: 640px) {
.payment-modal__container {
padding: 0.5rem;
}
.payment-modal__waiting-payment,
.payment-modal__manual-confirm {
padding: 1rem;
}
.payment-modal__actions button {
min-width: 100%;
}
}
/* ============================================
PpdStatusCard - Tarjeta de Estado PPD
============================================ */
.ppdStatusCard {
width: 100%;
padding: var(--spacing-lg);
background: var(--surface-color);
border-radius: var(--border-radius);
border: 1px solid var(--border-color);
box-shadow: var(--shadow-sm);
}
/* ==================== LOADING ==================== */
.ppdStatusCard__loading {
display: flex;
flex-direction: column;
align-items: center;
gap: var(--spacing-sm);
padding: var(--spacing-xl);
color: var(--text-muted);
}
/* ==================== ERROR ==================== */
.ppdStatusCard__error {
padding: var(--spacing-md);
background: var(--danger-background);
border: 1px solid var(--danger-color);
border-radius: var(--border-radius);
display: flex;
align-items: center;
gap: var(--spacing-sm);
color: var(--danger-color);
}
.ppdStatusCard__error-icon {
font-size: 1.25rem;
}
/* ==================== EMPTY ==================== */
.ppdStatusCard__empty {
padding: var(--spacing-lg);
text-align: center;
color: var(--text-muted);
}
/* ==================== HEADER ==================== */
.ppdStatusCard__header {
display: flex;
justify-content: space-between;
align-items: flex-start;
margin-bottom: var(--spacing-md);
padding-bottom: var(--spacing-md);
border-bottom: 2px solid var(--border-color);
}
.ppdStatusCard__header-info {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.ppdStatusCard__title {
font-size: 1.25rem;
font-weight: 700;
color: var(--text-color);
margin: 0;
}
.ppdStatusCard__folio {
font-size: 0.875rem;
color: var(--text-muted);
font-family: 'Courier New', monospace;
}
/* ==================== BADGE ==================== */
.ppdStatusCard__badge {
padding: 0.375rem 0.75rem;
border-radius: var(--border-radius);
font-size: 0.875rem;
font-weight: 600;
white-space: nowrap;
}
.ppdStatusCard__badge--paid {
background: var(--success-background);
color: var(--success-color);
}
.ppdStatusCard__badge--pending {
background: var(--warning-background);
color: var(--warning-color);
}
/* ==================== UUID ==================== */
.ppdStatusCard__uuid-section {
display: flex;
flex-direction: column;
gap: 0.25rem;
padding: var(--spacing-sm);
background: var(--secondary-background);
border-radius: var(--border-radius);
margin-bottom: var(--spacing-md);
}
.ppdStatusCard__label {
font-size: 0.75rem;
color: var(--text-muted);
text-transform: uppercase;
font-weight: 600;
}
.ppdStatusCard__uuid {
font-size: 0.75rem;
font-family: 'Courier New', monospace;
color: var(--text-color);
word-break: break-all;
}
/* ==================== PROGRESS ==================== */
.ppdStatusCard__progress-section {
margin-bottom: var(--spacing-lg);
}
.ppdStatusCard__progress-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: var(--spacing-sm);
}
.ppdStatusCard__progress-label {
font-size: 0.875rem;
font-weight: 600;
color: var(--text-color);
}
.ppdStatusCard__progress-percentage {
font-size: 1.125rem;
font-weight: 700;
color: var(--primary-color);
}
.ppdStatusCard__progress-bar {
width: 100%;
height: 1.5rem;
background: var(--secondary-background);
border-radius: var(--border-radius);
overflow: hidden;
position: relative;
box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.1);
}
.ppdStatusCard__progress-fill {
height: 100%;
background: linear-gradient(90deg, var(--success-color), var(--primary-color));
border-radius: var(--border-radius);
transition: width 0.3s ease;
position: relative;
}
.ppdStatusCard__progress-fill::after {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: linear-gradient(
90deg,
rgba(255, 255, 255, 0) 0%,
rgba(255, 255, 255, 0.3) 50%,
rgba(255, 255, 255, 0) 100%
);
animation: shimmer 2s infinite;
}
@keyframes shimmer {
0% { transform: translateX(-100%); }
100% { transform: translateX(100%); }
}
/* ==================== AMOUNTS ==================== */
.ppdStatusCard__amounts {
display: flex;
flex-direction: column;
gap: var(--spacing-sm);
margin-bottom: var(--spacing-lg);
}
.ppdStatusCard__amount-item {
display: flex;
justify-content: space-between;
align-items: center;
padding: var(--spacing-sm);
background: var(--secondary-background);
border-radius: var(--border-radius);
}
.ppdStatusCard__amount-item--success {
background: var(--success-background);
border: 1px solid var(--success-color);
}
.ppdStatusCard__amount-item--pending {
background: var(--warning-background);
border: 1px solid var(--warning-color);
}
.ppdStatusCard__amount-label {
font-size: 0.875rem;
color: var(--text-muted);
font-weight: 500;
}
.ppdStatusCard__amount-value {
font-size: 1.125rem;
font-weight: 700;
color: var(--text-color);
}
.ppdStatusCard__amount-item--success .ppdStatusCard__amount-value {
color: var(--success-color);
}
.ppdStatusCard__amount-item--pending .ppdStatusCard__amount-value {
color: var(--warning-color);
}
/* ==================== STATS ==================== */
.ppdStatusCard__stats {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: var(--spacing-md);
margin-bottom: var(--spacing-lg);
}
.ppdStatusCard__stat {
display: flex;
flex-direction: column;
align-items: center;
padding: var(--spacing-md);
background: var(--primary-background);
border-radius: var(--border-radius);
border: 1px solid var(--primary-color);
}
.ppdStatusCard__stat-value {
font-size: 2rem;
font-weight: 700;
color: var(--primary-color);
line-height: 1;
}
.ppdStatusCard__stat-label {
font-size: 0.75rem;
color: var(--text-muted);
text-align: center;
margin-top: 0.25rem;
}
/* ==================== ACTIONS ==================== */
.ppdStatusCard__actions {
display: flex;
gap: var(--spacing-sm);
flex-wrap: wrap;
padding-top: var(--spacing-md);
border-top: 1px solid var(--border-color);
}
/* ==================== RESPONSIVE ==================== */
@media (max-width: 767px) {
.ppdStatusCard {
padding: var(--spacing-md);
}
.ppdStatusCard__header {
flex-direction: column;
gap: var(--spacing-sm);
}
.ppdStatusCard__badge {
align-self: flex-start;
}
.ppdStatusCard__stats {
grid-template-columns: 1fr;
}
.ppdStatusCard__actions {
flex-direction: column;
}
}
/* Dark mode handled by CSS variables */
/* ==============================================
AuthComponent - Estilos para componente de autenticación
============================================== */
/* Enlace para volver */
.auth__back-link {
margin-top: 0.75rem;
text-align: center;
}
.auth__back-link span {
color: var(--link-color);
font-size: 0.875rem;
font-weight: 500;
text-decoration: underline;
cursor: pointer;
transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
padding: 0.25rem 0.5rem;
border-radius: 0.25rem;
display: inline-block;
}
.auth__back-link span:hover,
.auth__back-link span:focus {
color: var(--primary-color);
background: var(--hover-background-color);
text-decoration: underline;
}
/* Descripción informativa */
.auth__description {
color: var(--text-muted);
font-size: 0.875rem;
line-height: 1.5;
margin-bottom: 1.25rem;
padding: 0.75rem;
background: var(--surface-alt-color);
border-radius: 0.5rem;
border-left: 3px solid var(--primary-color);
}
/* Enlace para reenviar código */
.auth__resend-link {
margin-top: 1rem;
text-align: right;
}
.auth__resend-link--active {
color: var(--link-color);
cursor: pointer;
text-decoration: underline;
font-size: 0.875rem;
font-weight: 500;
transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
padding: 0.25rem 0.5rem;
border-radius: 0.25rem;
display: inline-block;
}
.auth__resend-link--active:hover,
.auth__resend-link--active:focus {
color: var(--primary-color);
background: var(--hover-background-color);
text-decoration: underline;
}
.auth__resend-link--disabled {
color: var(--text-muted);
font-size: 0.875rem;
opacity: 0.7;
}
/* ============================================== */
/* Layout Responsivo para Formulario de Registro */
/* ============================================== */
/* Grid responsivo para formularios */
.register__form-grid {
display: grid;
grid-template-columns: 1fr;
gap: 0.875rem;
width: 100%;
box-sizing: border-box;
min-height: 340px;
}
/* Campo inline para selects pequeños (título, código de país) */
.register__inline-field {
display: flex;
flex-direction: column;
gap: 0.5rem;
width: 100%;
box-sizing: border-box;
}
/* Grupo de teléfono (código + número) */
.register__phone-group {
display: grid;
grid-template-columns: 1fr;
gap: 0.875rem;
width: 100%;
box-sizing: border-box;
}
@media (min-width: 420px) and (max-width: 479px) {
.register__form-grid {
gap: 0.75rem;
}
.register__phone-group {
gap: 0.75rem;
}
.auth__description {
padding: 0.625rem;
font-size: 0.8125rem;
}
}
/* ============================================== */
/* Móvil pequeño (480px - 639px)                 */
/* ============================================== */
@media (min-width: 480px) and (max-width: 639px) {
.register__form-grid {
gap: 0.875rem;
}
.register__phone-group {
gap: 0.875rem;
}
}
/* ============================================== */
/* Tablet y superior (640px+) - 2 columnas       */
/* ============================================== */
@media (min-width: 640px) {
.register__form-grid {
grid-template-columns: repeat(2, 1fr);
gap: 1rem;
}
/* Grupo de teléfono: código (pequeño) + número */
.register__phone-group {
grid-template-columns: 140px 1fr;
gap: 0.75rem;
}
/* Clase para campos que ocupan toda la fila */
.register__field--full {
grid-column: 1 / -1;
}
/* Clase para campos de media fila */
.register__field--half {
grid-column: span 1;
}
}
/* ============================================== */
/* Desktop grande (1024px+) - 3 columnas         */
/* ============================================== */
@media (min-width: 1024px) {
.register__form-grid {
grid-template-columns: repeat(3, 1fr);
gap: 1.25rem;
}
/* Campos que ocupan 2 de 3 columnas */
.register__field--two-thirds {
grid-column: span 2;
}
/* Grupo de teléfono en 3 columnas */
.register__phone-group {
grid-template-columns: 130px 1fr;
}
}
/* ============================================== */
/* Ajustes generales para pantallas pequeñas     */
/* ============================================== */
@media (max-width: 639px) {
/* Asegurar que todos los campos no se desborden */
.register__form-grid > *,
.register__phone-group > *,
.register__inline-field > * {
min-width: 0;
max-width: 100%;
}
/* Reducir padding en descripción para pantallas pequeñas */
.auth__description {
padding: 0.625rem;
font-size: 0.8125rem;
margin-bottom: 1rem;
}
/* Ajustar enlaces en móvil */
.auth__resend-link,
.auth__back-link {
font-size: 0.8125rem;
}
.auth__resend-link--active,
.auth__back-link span {
padding: 0.25rem 0.375rem;
font-size: 0.8125rem;
}
}
/* ============================================== */
/* Ajustes específicos para móviles muy pequeños */
/* ============================================== */
@media (max-width: 420px) {
.register__form-grid {
gap: 0.625rem;
}
.register__phone-group {
gap: 0.625rem;
}
.auth__description {
padding: 0.5rem;
font-size: 0.75rem;
margin-bottom: 0.875rem;
line-height: 1.4;
}
.auth__resend-link,
.auth__back-link {
margin-top: 0.625rem;
}
.auth__resend-link--active,
.auth__back-link span,
.auth__resend-link--disabled {
font-size: 0.75rem;
padding: 0.25rem;
}
}
/* ============================================== */
/* Bloque de campos opcionales del registro      */
/* (Reemplazado por AppTabs — estilos eliminados)*/
/* ============================================== */
/* Tabs del formulario de registro: alineados a la izquierda */
.register__tabs .app-tabs__list {
justify-content: flex-start;
gap: 0.25rem;
padding-bottom: 0.75rem;
border-bottom: 1px solid var(--border-color);
margin-bottom: 0.25rem;
}
.register__tabs .app-tabs__panels {
margin-top: 1.25rem;
}
/* ============================================================
auth-email  —  Paso 1 (correo): ícono + input + botón en fila
Usa exclusivamente variables de colors.css
============================================================ */
/* Contenedor del paso email */
.auth-email {
width: 100%;
padding: 0.25rem 0;
}
/* ── Fila única horizontal: ícono | input | botón ─────────── */
.auth-email__row {
display: flex;
align-items: center;
gap: 0.75rem;
width: 100%;
}
/* ── Ícono de sobre ───────────────────────────────────────── */
.auth-email__icon {
flex-shrink: 0;
width: 2.5rem;
height: 2.5rem;
border-radius: 0.6rem;
background: var(--secondary-background);
border: 1.5px solid var(--border-color);
display: flex;
align-items: center;
justify-content: center;
margin-top: -0.5rem;
color: var(--primary-color);
transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.auth-email__icon svg {
width: 18px;
height: 18px;
}
.auth-email__input-wrap {
flex: 1;
min-width: 0;
}
.auth-email__btn-wrap {
margin-top: -0.7rem;
flex-shrink: 0;
}
/* ── Focus en el input: resalta el ícono también ─────────── */
.auth-email__row:focus-within .auth-email__icon {
border-color: var(--focus-color);
color: var(--accent-color);
background: var(--hover-background-color);
}
/* ── Modo oscuro (variables lo gestionan automáticamente) ─── */
:root[data-theme='dark'] .auth-email__icon {
color: var(--accent-color);
}
/* ── Responsivo ───────────────────────────────────────────── */
@media (max-width: 480px) {
.auth-email__icon {
display: none;          /* el ícono se oculta en pantallas muy pequeñas */
}
.auth-email__row {
gap: 0.5rem;
}
.auth-email__btn-wrap .app-button {
padding-inline: 0.875rem;
}
}
/* ============================================
StampPaymentModal - Modal de Timbrado PUE
============================================ */
.stampPaymentModal {
width: 100%;
}
/* ==================== LOADING ==================== */
.stampPaymentModal__loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: var(--spacing-md);
padding: var(--spacing-xl);
text-align: center;
}
.stampPaymentModal__loading p {
color: var(--text-color);
font-weight: 500;
}
.stampPaymentModal__loading small {
color: var(--text-muted);
}
/* ==================== ERROR ==================== */
.stampPaymentModal__error {
padding: var(--spacing-lg);
background: var(--danger-background);
border: 2px solid var(--danger-color);
border-radius: var(--border-radius);
display: flex;
gap: var(--spacing-md);
}
.stampPaymentModal__error-icon {
font-size: 2rem;
flex-shrink: 0;
}
.stampPaymentModal__error-content {
flex: 1;
}
.stampPaymentModal__error-content h4 {
color: var(--danger-color);
margin-bottom: var(--spacing-sm);
font-size: 1.125rem;
}
.stampPaymentModal__error-content p {
color: var(--text-color);
margin-bottom: var(--spacing-sm);
}
.stampPaymentModal__error-list {
list-style: none;
padding: 0;
margin: var(--spacing-sm) 0;
}
.stampPaymentModal__error-list li {
padding: var(--spacing-xs) var(--spacing-sm);
background: var(--surface-color);
border-left: 3px solid var(--danger-color);
margin-bottom: var(--spacing-xs);
border-radius: var(--border-radius);
}
.stampPaymentModal__warnings {
margin-top: var(--spacing-md);
padding: var(--spacing-md);
background: var(--warning-background);
border: 1px solid var(--warning-color);
border-radius: var(--border-radius);
}
.stampPaymentModal__warnings h5 {
color: var(--warning-color);
margin-bottom: var(--spacing-sm);
}
.stampPaymentModal__warnings ul {
list-style: disc;
padding-left: var(--spacing-md);
}
.stampPaymentModal__error-actions {
margin-top: var(--spacing-md);
}
/* ==================== SUCCESS ==================== */
.stampPaymentModal__success {
padding: var(--spacing-lg);
background: var(--success-background);
border: 2px solid var(--success-color);
border-radius: var(--border-radius);
display: flex;
gap: var(--spacing-md);
}
.stampPaymentModal__success-icon {
font-size: 2.5rem;
flex-shrink: 0;
}
.stampPaymentModal__success-content {
flex: 1;
}
.stampPaymentModal__success-content h4 {
color: var(--success-color);
margin-bottom: var(--spacing-md);
font-size: 1.25rem;
}
.stampPaymentModal__result-details {
background: var(--surface-color);
padding: var(--spacing-md);
border-radius: var(--border-radius);
margin-bottom: var(--spacing-md);
}
.stampPaymentModal__result-item {
display: flex;
justify-content: space-between;
padding: var(--spacing-xs) 0;
border-bottom: 1px solid var(--border-color);
}
.stampPaymentModal__result-item:last-child {
border-bottom: none;
}
.stampPaymentModal__result-item span:first-child {
font-weight: 500;
color: var(--text-muted);
}
.stampPaymentModal__result-value {
color: var(--text-color);
font-weight: 600;
}
.stampPaymentModal__download-links {
margin-top: var(--spacing-md);
}
.stampPaymentModal__download-links p {
margin-bottom: var(--spacing-sm);
color: var(--text-color);
}
.stampPaymentModal__download-buttons {
display: flex;
gap: var(--spacing-sm);
flex-wrap: wrap;
}
/* ==================== PREVIEW ==================== */
.stampPaymentModal__preview {
display: flex;
flex-direction: column;
gap: var(--spacing-lg);
}
/* ==================== SECTIONS ==================== */
.stampPaymentModal__section {
padding: var(--spacing-md);
background: var(--surface-color);
border-radius: var(--border-radius);
border: 1px solid var(--border-color);
}
.stampPaymentModal__section-title {
font-size: 1rem;
font-weight: 600;
color: var(--text-color);
margin-bottom: var(--spacing-md);
padding-bottom: var(--spacing-sm);
border-bottom: 2px solid var(--border-color);
}
/* ==================== INFO GRID ==================== */
.stampPaymentModal__info-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: var(--spacing-sm);
}
.stampPaymentModal__info-item {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.stampPaymentModal__info-label {
font-size: 0.75rem;
font-weight: 500;
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: 0.05em;
}
.stampPaymentModal__info-value {
font-weight: 600;
color: var(--text-color);
}
.stampPaymentModal__info-value--mono {
font-family: 'Courier New', monospace;
font-size: 0.875rem;
}
/* ==================== CONCEPTS ==================== */
.stampPaymentModal__concepts {
display: flex;
flex-direction: column;
gap: var(--spacing-md);
}
.stampPaymentModal__concept-card {
padding: var(--spacing-md);
background: var(--secondary-background);
border-radius: var(--border-radius);
border: 1px solid var(--border-color);
}
.stampPaymentModal__concept-header {
margin-bottom: var(--spacing-sm);
color: var(--text-color);
}
.stampPaymentModal__concept-details {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.stampPaymentModal__concept-row {
display: flex;
justify-content: space-between;
align-items: center;
padding: 0.25rem 0;
font-size: 0.875rem;
}
.stampPaymentModal__concept-row span:first-child {
color: var(--text-muted);
}
.stampPaymentModal__concept-row span:last-child {
color: var(--text-color);
font-weight: 500;
}
.stampPaymentModal__concept-row--total {
margin-top: 0.5rem;
padding-top: 0.5rem;
border-top: 2px solid var(--border-color);
font-weight: 600;
}
.stampPaymentModal__concept-row--total span {
color: var(--success-color);
}
.stampPaymentModal__concept-codes {
margin-top: var(--spacing-sm);
padding-top: var(--spacing-sm);
border-top: 1px solid var(--border-color);
display: flex;
gap: var(--spacing-md);
}
.stampPaymentModal__concept-codes small {
font-size: 0.75rem;
color: var(--text-muted);
font-family: 'Courier New', monospace;
}
/* ==================== TOTALS ==================== */
.stampPaymentModal__totals {
display: flex;
flex-direction: column;
gap: var(--spacing-xs);
}
.stampPaymentModal__total-row {
display: flex;
justify-content: space-between;
align-items: center;
padding: var(--spacing-xs) 0;
font-size: 1rem;
}
.stampPaymentModal__total-row span:first-child {
color: var(--text-muted);
font-weight: 500;
}
.stampPaymentModal__total-row span:last-child {
color: var(--text-color);
font-weight: 600;
}
.stampPaymentModal__total-row--final {
margin-top: var(--spacing-sm);
padding-top: var(--spacing-sm);
border-top: 2px solid var(--border-color);
font-size: 1.25rem;
}
.stampPaymentModal__total-row--final span {
color: var(--success-color);
font-weight: 700;
}
/* ==================== FORM ==================== */
.stampPaymentModal__form {
display: flex;
flex-direction: column;
gap: var(--spacing-md);
}
/* ==================== WARNING ==================== */
.stampPaymentModal__warning {
padding: var(--spacing-md);
background: var(--warning-background);
border: 1px solid var(--warning-color);
border-radius: var(--border-radius);
display: flex;
gap: var(--spacing-md);
}
.stampPaymentModal__warning-icon {
font-size: 1.5rem;
flex-shrink: 0;
}
.stampPaymentModal__warning-content {
flex: 1;
}
.stampPaymentModal__warning-content strong {
color: var(--warning-color);
display: block;
margin-bottom: var(--spacing-xs);
}
.stampPaymentModal__warning-content ul {
list-style: disc;
padding-left: var(--spacing-md);
margin: var(--spacing-xs) 0;
}
.stampPaymentModal__warning-content li {
color: var(--text-color);
margin-bottom: 0.25rem;
}
/* ==================== RESPONSIVE ==================== */
@media (max-width: 767px) {
.stampPaymentModal__info-grid {
grid-template-columns: 1fr;
}
.stampPaymentModal__download-buttons {
flex-direction: column;
}
.stampPaymentModal__error,
.stampPaymentModal__success {
flex-direction: column;
text-align: center;
}
.stampPaymentModal__error-icon,
.stampPaymentModal__success-icon {
align-self: center;
}
}
/* Dark mode handled by CSS variables */
.aditional-category {
background: var(--card-aditional-bg-color);
border-radius: 12px;
border: 2px solid var(--border-color);
margin-bottom: 0.5rem;
box-shadow: var(--shadow-sm);
padding: 0.65rem 1rem;
transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
position: relative;
}
.aditional-category:hover {
border-color: var(--primary-light);
box-shadow: var(--shadow-md);
background: var(--hover-background-color);
}
.aditional-category--disabled {
opacity: 0.6;
pointer-events: none;
filter: grayscale(0.2);
background: var(--disabled-background);
border: 2px dashed var(--disabled-color);
}
.aditional-category__header {
display: flex;
justify-content: space-between;
align-items: flex-start;
gap: 0.75rem;
}
.aditional-category__info {
flex: 1 1 auto;
}
.aditional-category__name {
font-size: 1.05rem;
font-weight: 700;
color: var(--text-color);
}
.aditional-category__desc {
font-size: 0.8rem;
color: var(--text-muted);
margin-top: 0.1rem;
}
.aditional-category__not-available {
color: var(--danger-color);
font-size: 0.85rem;
margin-top: 0.3rem;
font-weight: 600;
}
.aditional-category__fees {
min-width: 160px;
text-align: right;
flex-shrink: 0;
}
.aditional-category__fee--active {
display: flex;
align-items: baseline;
flex-wrap: nowrap;
gap: 0.35rem;
font-size: 1rem;
font-weight: 800;
color: var(--success-color);
border: none;
border-radius: 0;
padding: 0;
margin-bottom: 0.12rem;
white-space: nowrap;
}
.aditional-category__fee--active .aditional-category__fee-amount {
font-size: 1.3rem !important;
font-weight: 800;
color: var(--success-color) !important;
white-space: nowrap;
}
/* fecha del fee ACTIVO — en verde con ligera opacidad */
.aditional-category__fee--active .aditional-category__fee-dates {
font-size: 0.8rem;
color: var(--success-color) !important;
font-weight: 500;
margin-left: 0.25rem;
white-space: nowrap;
opacity: 0.85;
}
/* monto genérico (fees futuros) */
.aditional-category__fee-amount {
font-size: 0.85rem;
font-weight: 600;
color: var(--text-muted);
white-space: nowrap;
}
/* fecha genérica (fees futuros) — en muted */
.aditional-category__fee-dates {
font-size: 0.78rem;
color: var(--text-muted);
font-weight: 400;
margin-left: 0.25rem;
white-space: nowrap;
opacity: 1;
}
.aditional-category__fee-list {
margin-top: 0.25rem;
padding-top: 0.2rem;
display: flex;
flex-direction: column;
gap: 0.05rem;
}
.aditional-category__fee--future {
display: flex;
align-items: baseline;
flex-wrap: nowrap;
justify-content: flex-end;
gap: 0.25rem;
white-space: nowrap;
}
.aditional-category__fee--future .aditional-category__fee-amount {
font-size: 0.85rem;
color: var(--text-muted);
font-weight: 600;
white-space: nowrap;
}
.aditional-category__fee--future .aditional-category__fee-dates {
font-size: 0.78rem;
color: var(--text-muted);
font-weight: 400;
margin-left: 0.2rem;
white-space: nowrap;
opacity: 1;
}
/* Separador visual entre header y controles */
.aditional-category__actions {
margin-top: 0.4rem;
padding-top: 0.4rem;
border-top: 1px solid var(--border-color);
}
.aditional-category__quantity-label {
display: flex !important;
align-items: center;
gap: 0.5rem;
font-size: 0.88rem;
font-weight: 500;
color: var(--text-secondary);
}
.aditional-category__quantity {
width: 2.8rem;
padding: 0.2rem 0.3rem;
border-radius: 6px;
border: 1px solid var(--border-color);
font-size: 0.9rem;
font-weight: 600;
text-align: center;
background: var(--surface-color);
color: var(--text-color);
-moz-appearance: textfield;
}
.aditional-category__quantity::-webkit-inner-spin-button,
.aditional-category__quantity::-webkit-outer-spin-button {
-webkit-appearance: none;
margin: 0;
}
/* Botones +/- de cantidad */
.aditional-category__quantity-btn {
background: var(--surface-color);
border: 2px solid var(--primary-color);
color: var(--primary-color);
border-radius: 50%;
width: 1.8rem;
height: 1.8rem;
font-size: 1.1rem;
font-weight: bold;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: background 0.15s, border-color 0.15s, color 0.15s;
padding: 0;
line-height: 1;
flex-shrink: 0;
}
.aditional-category__quantity-btn span,
.aditional-category__quantity-btn svg {
color: inherit !important;
fill: currentColor !important;
transition: color 0.15s, fill 0.15s;
}
.aditional-category__quantity-btn:hover:not(:disabled),
.aditional-category__quantity-btn:focus-visible:not(:disabled) {
background: var(--primary-color);
color: var(--primary-foreground);
border-color: var(--primary-color);
}
.aditional-category__quantity-btn:hover:not(:disabled) span,
.aditional-category__quantity-btn:focus-visible:not(:disabled) span,
.aditional-category__quantity-btn:hover:not(:disabled) svg,
.aditional-category__quantity-btn:focus-visible:not(:disabled) svg {
color: var(--primary-foreground) !important;
fill: var(--primary-foreground) !important;
}
.aditional-category__quantity-btn:disabled {
opacity: 0.4;
cursor: not-allowed;
background: var(--disabled-background);
border-color: var(--disabled-color);
color: var(--disabled-color);
}
/* Inputs de nombre por boleto (RequiredName) */
.aditional-category__names {
display: flex;
flex-direction: column;
gap: 0.4rem;
margin-top: 0.5rem;
padding-top: 0.4rem;
border-top: 1px solid var(--border-color);
}
.aditional-category__name-row {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 0.5rem;
}
.aditional-category__name-input {
width: 100%;
padding: 0.35rem 0.6rem;
border-radius: 6px;
border: 1px solid var(--border-color);
background: var(--surface-color);
color: var(--text-color);
font-size: 0.88rem;
transition: border-color 0.15s, box-shadow 0.15s;
outline: none;
}
.aditional-category__name-input:focus {
border-color: var(--primary-color);
box-shadow: 0 0 0 2px var(--focus-ring);
}
.aditional-category__name-input.is-required {
border-color: var(--danger-color);
}
.aditional-category__name-input::placeholder {
color: var(--text-muted);
opacity: 0.8;
}
@media (max-width: 700px) {
.aditional-category__header {
flex-direction: column;
gap: 0.5rem;
}
.aditional-category__fees {
min-width: unset;
text-align: left;
}
}
@media (max-width: 600px) {
.aditional-category {
padding: 0.6rem 0.8rem;
}
.aditional-category__fee--active,
.aditional-category__fee--future {
display: flex;
flex-direction: column;
align-items: center;
text-align: center;
gap: 0.15rem;
}
.aditional-category__fee-dates,
.aditional-category__fee--future .aditional-category__fee-dates {
margin-left: 0;
white-space: normal;
line-height: 1.15;
}
.aditional-category__fees {
width: 100%;
text-align: center;
}
.aditional-category__header {
align-items: center;
}
.aditional-category__info {
text-align: center;
}
.aditional-category__quantity-label {
justify-content: center;
}
.aditional-category__fee-active-dot {
display: none;
}
.aditional-category__name-row {
grid-template-columns: 1fr;
}
}
/* App Badge Preview Component (BEM) */
.app-badge-preview {
position: relative;
display: flex;
width: 100%;
/* Use aspect-ratio to force desired proportion. 420x510 ≈ 14/17 */
aspect-ratio: 14 / 17;
/* limit overall size so it doesn't dominate layout */
max-width: 420px;
max-height: 510px;
min-height: 130px; /* asegura tamaño mínimo cuando el contenedor no define altura */
border-radius: .75rem;
overflow: hidden;
background: var(--surface-alt-color);
box-shadow: var(--shadow-sm);
isolation: isolate;
font-family: inherit;
user-select: none;
/* badge-specific variables so fallback and text can be forced independently of global surface vars */
--badge-fallback-start: var(--surface-color);
--badge-fallback-end: var(--secondary-background);
--badge-text-color: var(--text-color);
}
/* Orientation modifier: fuerza formato vertical típico de credencial */
.app-badge-preview--vertical { aspect-ratio: 54 / 86; }
.app-badge-preview--vertical .app-badge-preview__image { object-fit: cover; object-position: center top; }
/* Para imágenes muy horizontales, se prioriza altura completa sin distorsión, recortando laterales */
.app-badge-preview--vertical .app-badge-preview__image-wrapper { background-color: var(--text-color); }
.app-badge-preview--editing { outline: 2px solid var(--primary-color); outline-offset: 2px; }
/* Toolbar */
.app-badge-preview__toolbar {
position: absolute;
top: .4rem;
right: .4rem;
display: flex;
gap: .35rem;
z-index: 5;
}
.app-badge-preview__btn {
appearance: none;
border: 1.5px solid var(--primary-color);
background: color-mix(in oklab, var(--primary-color) 12%, var(--surface-color));
opacity: 1;
color: var(--badge-text-color);
width: 2.55rem;
height: 2.55rem;
display: inline-flex;
align-items: center;
justify-content: center;
border-radius: .65rem;
font-size: 1.2rem;
cursor: pointer;
transition: background .15s, transform .12s, box-shadow .15s;
box-shadow: 0 2px 8px color-mix(in oklab, var(--primary-color) 25%, transparent);
animation: abpBtnPulse 2.4s ease-in-out infinite;
}
.app-badge-preview__btn:hover { background: color-mix(in oklab, var(--primary-color) 22%, var(--surface-color)); box-shadow: 0 3px 12px color-mix(in oklab, var(--primary-color) 35%, transparent); animation: none; }
.app-badge-preview__btn:active { transform: scale(.94); }
.app-badge-preview__btn:disabled { opacity: .35; cursor: not-allowed; animation: none; }
.app-badge-preview__btn--save { border-color: var(--success-color); background: color-mix(in oklab, var(--success-color) 12%, var(--surface-color)); box-shadow: 0 2px 8px color-mix(in oklab, var(--success-color) 25%, transparent); animation: none; }
.app-badge-preview__btn--cancel { border-color: var(--danger-color); background: color-mix(in oklab, var(--danger-color) 10%, var(--surface-color)); box-shadow: 0 2px 8px color-mix(in oklab, var(--danger-color) 20%, transparent); animation: none; }
@keyframes abpBtnPulse { 0%,100% { box-shadow: 0 2px 8px color-mix(in oklab, var(--primary-color) 25%, transparent); } 50% { box-shadow: 0 3px 14px color-mix(in oklab, var(--primary-color) 45%, transparent); } }
/* Tamaños (modifier): ahora considerablemente más grandes */
/* medium (default) se define en las clases base */
.app-badge-preview--size-small .app-badge-preview__name { font-size: clamp(.9rem, 3vw, 1.25rem); }
.app-badge-preview--size-small .app-badge-preview__lastname { font-size: clamp(.8rem, 2.7vw, 1.1rem); }
.app-badge-preview--size-large .app-badge-preview__name { font-size: clamp(1.8rem, 4vw, 3rem); }
.app-badge-preview--size-large .app-badge-preview__lastname { font-size: clamp(1.55rem, 3.5vw, 2.4rem); }
/* Imagen */
.app-badge-preview__image-wrapper {
/* keep full-bleed wrapper but ensure clipping and that inner content respects container aspect-ratio */
position: absolute;
inset: 0;
width: 100%;
height: 100%;
pointer-events: none;
background: var(--surface-alt-color);
overflow: hidden; /* ensure nothing can overflow the badge area */
display: block;
}
.app-badge-preview__image {
/* Fill the container and preserve the set proportion via aspect-ratio on the parent */
position: absolute;
inset: 0;
width: 100%;
height: 100%;
object-fit: cover; /* cover ensures the image fills without distortion and will be clipped inside */
object-position: center;
filter: brightness(0.95) saturate(1.05);
transition: transform .6s ease, filter .4s ease;
}
/* Fallback cuando no hay imagen */
.app-badge-preview__image-fallback {
position: absolute;
inset: 0;
/* Use badge-specific variables so fallback remains light by default even in dark themes */
background: linear-gradient(135deg, var(--badge-fallback-start), var(--badge-fallback-end));
display: flex;
align-items: center;
justify-content: center;
padding: 0; /* removed extra padding so SVG can fill entirely; spacing can be handled inside the SVG if needed */
}
/* Make placeholder SVG fill the wrapper and respect preserveAspectRatio set in the SVG */
.app-badge-preview__image-fallback svg,
.app-badge-preview__placeholder-svg {
width: 100%;
height: 100%;
max-width: 100%;
max-height: 100%;
display: block;
opacity: .95;
filter: none; /* remove drop-shadow to keep crisp on light backgrounds */
}
/* Estilos internos del SVG */
.abp-pl-outline { fill: var(--surface-color); stroke: var(--border-light); stroke-width: 2; }
.abp-pl-band { fill: url(#abpGradient); }
.abp-pl-avatar { fill: var(--border-color); }
.abp-pl-line { fill: var(--text-muted); }
.abp-pl-line--short { fill: var(--border-color); }
.abp-pl-code { fill: var(--border-color); }
/* Overlay para texto (centrado) */
.app-badge-preview__overlay {
position: absolute;
inset: 0;
display: flex;
align-items: center; /* centro vertical */
justify-content: center; /* centro horizontal */
padding: 1rem;
text-align: center;
/* Removed dark semi-opaque background so underlying image is visible */
background: transparent;
/* Reduce or remove backdrop-filter to avoid darkening the image */
backdrop-filter: none;
pointer-events: none; /* avoid blocking input click events when editing inputs are visually on top */
}
.app-badge-preview__text {
width: 100%;
line-height: 1.1;
font-weight: 600;
letter-spacing: .5px;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
gap: .4rem;
pointer-events: auto; /* allow interactions with text when editing is active */
}
/* Tamaños base (default: medium) */
.app-badge-preview__name {
display: block;
width: 100%;
/* Use badge-text-color so it can be forced to dark even in dark mode */
color: var(--badge-text-color);
/* Subtle light text shadow to help readability over busy images */
text-shadow: 0 1px 2px var(--surface-color);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
font-weight: 700;
font-size: clamp(1.35rem, 3.2vw, 2.2rem);
}
.app-badge-preview__lastname {
display: block;
width: 100%;
color: var(--badge-text-color);
text-shadow: 0 1px 2px var(--surface-color);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
font-weight: 500;
font-size: clamp(1.15rem, 2.8vw, 1.8rem);
}
/* Editing form */
.app-badge-preview__form {
width: 100%;
max-width: 100%;
display: flex;
flex-direction: column;
gap: .5rem;
pointer-events: auto; /* allow form interactions */
}
.app-badge-preview__field { width: 100%; }
.app-badge-preview__input {
width: 100%;
background: var(--surface-color);
border: 1px solid var(--border-color);
color: var(--badge-text-color);
padding: .55rem .7rem;
border-radius: .55rem;
font-size: 1rem;
font-weight: 600;
letter-spacing: .5px;
outline: none;
transition: border-color .25s, background .25s;
}
.app-badge-preview__input::placeholder {
color: var(--text-muted);
font-weight: 400;
}
.app-badge-preview__input:focus {
border-color: var(--primary-color);
background: var(--surface-color);
}
.app-badge-preview__input:disabled { opacity: .6; cursor: not-allowed; }
.app-badge-preview__input--error { border-color: var(--danger-color) !important; background: var(--danger-background); }
/* Status / hint */
.app-badge-preview__hint {
min-height: 1.1rem;
display: flex;
align-items: center;
justify-content: center;
font-size: .8rem;
font-weight: 500;
letter-spacing: .4px;
}
.app-badge-preview__status {
display: inline-flex;
align-items: center;
gap: .35rem;
padding: .2rem .55rem;
border-radius: .5rem;
line-height: 1;
}
.app-badge-preview__status--pending {
background: var(--disabled-background);
color: var(--badge-text-color);
animation: abpPulse 1.2s ease-in-out infinite;
}
.app-badge-preview__status--success { background: var(--success-background); color: var(--success-dark); }
.app-badge-preview__status--error { background: var(--danger-background); color: var(--danger-dark); }
@keyframes abpPulse { 0%,100% { opacity: .55; } 50% { opacity: 1; } }
/* Interacciones suaves (aunque sea solo preview) */
.app-badge-preview:hover .app-badge-preview__image {
transform: scale(1.04);
filter: brightness(1) saturate(1.1);
}
/* Dark mode */
@media (prefers-color-scheme: dark) {
.app-badge-preview {
background: var(--surface-color);
box-shadow: var(--shadow-md);
}
.app-badge-preview__image { filter: brightness(.9) saturate(1.05); }
.app-badge-preview:hover .app-badge-preview__image { filter: brightness(.95) saturate(1.12); }
.app-badge-preview__overlay { background: transparent !important; }
.app-badge-preview__image-fallback { background: linear-gradient(135deg, var(--badge-fallback-start), var(--badge-fallback-end)); }
.abp-pl-outline { fill: var(--border-light); stroke: var(--border-color); }
.abp-pl-avatar { fill: var(--disabled-color); }
.abp-pl-line { fill: var(--text-muted); }
.abp-pl-line--short { fill: var(--disabled-color); }
.abp-pl-code { fill: var(--disabled-color); }
}
/* Compacidad en layouts muy pequeños */
@media (max-width: 420px) {
.app-badge-preview { min-height: 130px; max-width: 320px; max-height: 420px; }
.app-badge-preview__overlay { padding: .8rem; }
/* Ajustes responsive para que no se desborde */
.app-badge-preview__name { font-size: clamp(1.1rem, 6vw, 1.7rem); }
.app-badge-preview__lastname { font-size: clamp(.95rem, 5.2vw, 1.4rem); }
.app-badge-preview--size-small .app-badge-preview__name { font-size: clamp(.85rem, 5vw, 1.1rem); }
.app-badge-preview--size-small .app-badge-preview__lastname { font-size: clamp(.75rem, 4.5vw, 1rem); }
.app-badge-preview--size-large .app-badge-preview__name { font-size: clamp(1.4rem, 7vw, 2.2rem); }
.app-badge-preview--size-large .app-badge-preview__lastname { font-size: clamp(1.2rem, 6.3vw, 1.9rem); }
}
/* Utilitario ratio credencial (54x86 mm => ~1:1.59) */
.app-badge-preview--ratio-id { aspect-ratio: 54 / 86; }
/* Clase opcional (ya no necesaria para centrar, se mantiene por compatibilidad) */
.app-badge-preview--vcenter .app-badge-preview__overlay { align-items: center; justify-content: center; }
/* Add / extend error state styles for inputs and error messages */
.app-badge-preview__error { display:inline-block; margin-top:.25rem; font-size:.7rem; font-weight:600; letter-spacing:.5px; color: var(--danger-dark); text-shadow:none; }
/* OpenPay Form - BEM Naming with Modern Design */
.appform-openpay {
display: block;
position: relative;
}
.appform-openpay--processing {
pointer-events: none;
opacity: 0.7;
}
/* Rows */
.appform-openpay__row {
margin-bottom: 1rem;
}
.appform-openpay__row--exp {
display: flex;
gap: 0.75rem;
align-items: flex-start;
}
/* Columns for expiration/CVV */
.appform-openpay__col {
flex: 1 1 0;
min-width: 0;
}
.appform-openpay__col--exp-input {
flex: 2;
}
.appform-openpay__col--cvv {
flex: 1;
}
/* Card Number Input with Icon */
.appform-openpay__card-input {
position: relative;
}
.appform-openpay__card-icon {
position: absolute;
right: 12px;
top: 50%;
transform: translateY(-50%);
margin-top: 8px; /* Adjust for label */
width: 48px;
height: 32px;
pointer-events: none;
z-index: 10;
transition: opacity 0.2s ease;
}
.card-icon {
width: 100%;
height: 100%;
filter: drop-shadow(0 1px 2px var(--shadow-color));
}
/* Card type specific animations */
.appform-openpay__card-icon--visa,
.appform-openpay__card-icon--mastercard,
.appform-openpay__card-icon--amex {
animation: fadeInScale 0.3s ease;
}
@keyframes fadeInScale {
from {
opacity: 0;
transform: translateY(-50%) scale(0.8);
}
to {
opacity: 1;
transform: translateY(-50%) scale(1);
}
}
/* CVV Input with Visual Help */
.appform-openpay__cvv-input {
position: relative;
}
.appform-openpay__cvv-icon {
position: absolute;
right: 12px;
top: 50%;
transform: translateY(-50%);
margin-top: 8px;
width: 48px;
height: 32px;
pointer-events: none;
z-index: 10;
opacity: 0.6;
transition: opacity 0.2s ease;
}
.appform-openpay__cvv-input:hover .appform-openpay__cvv-icon {
opacity: 1;
}
.cvv-icon {
width: 100%;
height: 100%;
filter: drop-shadow(0 1px 2px var(--shadow-color));
}
/* Actions (Button area) */
.appform-openpay__actions {
margin-top: 1.5rem;
}
.appform-openpay__actions button {
width: 100%;
}
/* Security Indicator */
.appform-openpay__security {
display: flex;
align-items: center;
justify-content: center;
gap: 0.4rem;
margin-top: 0.75rem;
padding: 0.5rem 0.75rem;
background-color: transparent;
border-radius: var(--border-radius-md, 8px);
color: var(--text-muted);
font-size: 0.8125rem;
line-height: 1.2;
}
.appform-openpay__security-icon {
width: 16px;
height: 16px;
color: var(--success-color);
flex-shrink: 0;
}
.appform-openpay__security-text {
font-weight: var(--font-weight-normal, 400);
}
/* Responsive */
@media (max-width: 640px) {
.appform-openpay__row--exp {
flex-wrap: wrap;
}
.appform-openpay__col--exp-input {
flex: 1 1 100%;
}
.appform-openpay__col--cvv {
flex: 1 1 100%;
}
.appform-openpay__card-icon,
.appform-openpay__cvv-icon {
width: 40px;
height: 28px;
}
}
/* Loading state */
.appform-openpay--processing::after {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: var(--overlay-color);
backdrop-filter: blur(2px);
border-radius: var(--border-radius-lg, 12px);
z-index: 100;
}
.appform-openpay--processing .appform-openpay__actions button {
cursor: wait;
}
/* Focus states enhancement */
.appform-openpay input:focus ~ .appform-openpay__card-icon,
.appform-openpay input:focus ~ .appform-openpay__cvv-icon {
opacity: 1;
}
/* Error states */
.appform-openpay input[aria-invalid="true"] ~ .appform-openpay__card-icon {
opacity: 0.5;
}
/* MercadoPago mounts - estilos claros/oscuro y clickeables */
.app-payment-form__form--mp .app-payment-form__mount {
position: relative;
display: block;
width: 100%;
min-height: 46px;
border: 1px solid var(--border-color);
border-radius: 6px;
padding: 10px 12px;
background: var(--surface-color);
color: var(--text-color);
}
/* iFrame de MP ocupa el contenedor */
.app-payment-form__form--mp .app-payment-form__mount iframe {
position: relative !important;
display: block !important;
width: 100% !important;
height: 100% !important;
min-height: 24px !important;
border: none !important;
background: transparent !important;
z-index: 2;
pointer-events: auto !important;
}
.app-payment-form__form--mp .app-payment-form__label { color: var(--text-secondary); }
/* separación */
.app-payment-form__form--mp .app-payment-form__row + .app-payment-form__row { margin-top: 12px; }
/* Block: app-payment-form (BEM) */
.app-payment-form {
border: 2px solid var(--primary-color);
border-radius: 10px;
background: var(--surface-color);
box-shadow: var(--shadow-md);
padding: 16px;
display: grid;
gap: 16px;
color: var(--text-color);
width: 100%;
position: relative;
}
@media (prefers-color-scheme: dark) {
.app-payment-form {
border-color: var(--primary-light);
box-shadow: var(--shadow-lg);
}
}
.app-payment-form__engine-selector {
display: flex;
gap: 8px;
flex-wrap: wrap;
}
.app-payment-form__engine-btn {
border: 1px solid var(--border-color);
background: var(--surface-color);
color: var(--text-color);
border-radius: 999px;
padding: 6px 12px;
cursor: pointer;
transition: border-color .15s ease,color .15s ease,background-color .15s ease;
}
.app-payment-form__engine-btn:hover {
border-color: var(--highlight-color);
}
.app-payment-form__engine-btn.is-active {
border-color: var(--primary-color);
color: var(--primary-color);
font-weight: 600;
}
.app-payment-form__header {
display: flex;
align-items: baseline;
justify-content: space-between;
padding-bottom: 6px;
border-bottom: 1px dashed var(--divider-color);
}
.app-payment-form__title {
font-weight: 700;
font-size: 1.05rem;
}
.app-payment-form__amount {
opacity: .8;
}
.app-payment-form__content {
display: grid;
gap: 12px;
}
.app-payment-form__form {
display: grid;
gap: 12px;
}
/* Filas y proporciones */
.app-payment-form__row {
display: grid;
gap: 12px;
}
.app-payment-form__row--two {
grid-template-columns: 1fr 1fr;
}
/* Primera fila del formulario: 2fr 1fr (Número + Titular) */
.app-payment-form__form .app-payment-form__row--two:first-of-type {
grid-template-columns: 2fr 1fr;
}
@media(max-width:640px) {
.app-payment-form__row--two {
grid-template-columns: 1fr;
}
}
.app-payment-form__field {
display: grid;
gap: 6px;
}
.app-payment-form__label {
font-weight: 600;
color: var(--text-color);
}
.app-payment-form__input,
.app-payment-form__select {
border: 1px solid var(--border-color);
border-radius: 6px;
padding: 10px 12px;
background: var(--surface-color);
color: var(--text-color);
outline: none;
transition: border-color .15s ease, box-shadow .15s ease;
}
.app-payment-form__input:focus,
.app-payment-form__select:focus {
border-color: var(--focus-color);
box-shadow: 0 0 0 3px var(--focus-ring);
}
/* Monturas de SDK: foco y puntero correctos (evita bloqueo) */
.app-payment-form__mount {
min-height: 44px;
border: 1px solid var(--border-color);
border-radius: 6px;
background: var(--surface-color);
padding: 8px 10px;
display: flex;
align-items: center;
position: relative;
overflow: hidden;
isolation: isolate;
z-index: 1000;
pointer-events: auto;
width: 100%;
}
.app-payment-form__mount iframe,
.app-payment-form__mount > div {
width: 100%;
}
.app-payment-form__mount--paypal {
padding: 12px;
justify-content: center;
}
.app-payment-form__hint {
font-size: .85rem;
color: var(--text-muted);
}
.app-payment-form__actions {
display: flex;
justify-content: flex-end;
align-items: center;
gap: 12px;
position: relative;
z-index: 1;
}
.app-payment-form__note {
color: var(--text-muted);
}
.app-payment-form__pay-btn {
background: var(--primary-color);
color: var(--primary-foreground);
border: none;
border-radius: 8px;
padding: 10px 16px;
cursor: pointer;
transition: filter .15s ease, opacity .15s ease;
}
.app-payment-form__pay-btn:hover {
filter: brightness(1.05);
}
.app-payment-form__pay-btn[disabled] {
opacity: .6;
cursor: not-allowed;
}
/* --- Principal Category Styles --- */
.principal-category {
width: 100%;
background: var(--card-category-bg-color);
border-radius: 12px;
border: 2px solid transparent;
box-shadow: var(--shadow-sm);
margin-bottom: 0.5rem;
cursor: pointer;
transition: border-color 0.2s, box-shadow 0.2s, background 0.2s, transform 0.15s;
outline: none;
padding: 0;
position: relative;
}
.principal-category:focus-visible {
border-color: var(--focus-color);
box-shadow: 0 0 0 3px var(--focus-ring);
}
.principal-category--selected {
border-color: var(--primary-color);
border-width: 4px;
background: var(--secondary-background);
box-shadow: var(--shadow-lg), 0 0 0 4px var(--focus-ring);
transform: scale(1.025);
transition: border-color 0.2s, box-shadow 0.2s, background 0.2s, transform 0.2s, border-width 0.2s;
z-index: 1;
}
.principal-category:hover {
background: var(--hover-background-color);
box-shadow: var(--shadow-xl);
border-color: var(--primary-color);
transform: scale(1.015);
}
.principal-category__selected-icon {
position: absolute;
top: 0.7rem;
right: 0.9rem;
background: var(--primary-color);
color: var(--primary-foreground);
border-radius: 50%;
width: 2.1rem;
height: 2.1rem;
display: flex;
align-items: center;
justify-content: center;
font-size: 1.3rem;
font-weight: bold;
box-shadow: var(--shadow-md);
z-index: 2;
border: 3px solid var(--surface-color);
transition: all 0.2s;
animation: popSelected 0.18s cubic-bezier(.4,1.3,.6,1);
}
@keyframes popSelected {
0% { transform: scale(0.8); }
60% { transform: scale(1.15); }
100% { transform: scale(1); }
}
.principal-category__grid {
display: grid;
grid-template-columns: 2fr 1.2fr;
gap: 0.75rem;
align-items: center;
padding: 0.65rem 1rem 0.65rem 1.2rem;
}
.principal-category__info {
display: flex;
flex-direction: column;
gap: 0.1rem;
}
.principal-category__name {
font-size: 1.05rem;
font-weight: 700;
color: var(--text-color);
}
.principal-category__desc {
font-size: 0.8rem;
color: var(--text-muted);
}
.principal-category__fees {
display: flex;
flex-direction: column;
align-items: flex-end;
gap: 0.05rem;
width: 100%;
}
.principal-category__fee--active {
display: flex;
align-items: baseline;
flex-wrap: nowrap;
gap: 0.35rem;
font-size: 1rem;
font-weight: 800;
color: var(--success-color);
background: none;
border: none;
border-radius: 0;
padding: 0;
margin-bottom: 0.12rem;
white-space: nowrap;
}
.principal-category__fee--active .principal-category__fee-amount {
font-size: 1.3rem !important;
font-weight: 800;
color: var(--success-color) !important;
white-space: nowrap;
}
.principal-category__fee--active .principal-category__fee-dates {
font-size: 0.8rem;
color: var(--success-color) !important;
font-weight: 500;
margin-left: 0.25rem;
white-space: nowrap;
opacity: 0.85;
}
.principal-category__fee-active-dot {
display: none;
}
.principal-category__fee-amount {
font-size: 1rem;
font-weight: 800;
color: var(--success-color);
white-space: nowrap;
}
.principal-category__fee-dates {
font-size: 0.78rem;
color: var(--text-muted);
font-weight: 400;
margin-left: 0.25rem;
white-space: nowrap;
}
.principal-category__fee-list {
width: 100%;
display: flex;
flex-direction: column;
gap: 0.05rem;
margin-top: 0.25rem;
padding-top: 0.2rem;
}
.principal-category__fee--future {
display: flex;
align-items: baseline;
flex-wrap: nowrap;
justify-content: flex-end;
gap: 0.25rem;
font-size: 0.85rem;
color: var(--secondary-color);
font-weight: 600;
margin-top: 0.03rem;
white-space: nowrap;
}
.principal-category__fee--future .principal-category__fee-amount {
font-size: 0.85rem;
color: var(--secondary-color);
font-weight: 600;
white-space: nowrap;
}
.principal-category__fee--future .principal-category__fee-dates {
font-size: 0.78rem;
color: var(--text-muted);
font-weight: 400;
margin-left: 0.2rem;
white-space: nowrap;
}
.principal-category--selected .principal-category__name,
.principal-category--selected .principal-category__desc {
color: var(--text-color);
}
.principal-category--selected .principal-category__fee--future .principal-category__fee-amount {
color: var(--secondary-color);
}
.principal-category--selected .principal-category__fee--future .principal-category__fee-dates {
color: var(--text-muted);
}
.principal-category--selected .principal-category__selected-icon {
background: var(--primary-color);
color: var(--primary-foreground);
border: 3px solid var(--surface-color);
}
.principal-category--disabled {
opacity: 0.6;
pointer-events: none;
filter: grayscale(0.2);
background: var(--disabled-background);
border: 2px dashed var(--disabled-color);
box-shadow: none;
cursor: not-allowed;
}
.principal-category__not-available {
color: var(--danger-color);
font-size: 0.85rem;
margin-top: 0.3rem;
font-weight: 600;
}
/* Ajustes para pantallas pequeñas (ahora <=600px) */
@media (max-width: 600px) {
.principal-category__grid {
grid-template-columns: 1fr;
padding: 0.6rem 0.8rem;
gap: 0.5rem;
justify-items: center;
}
.principal-category__info {
align-items: center;
text-align: center;
display: flex;
flex-direction: column;
}
.principal-category__fees {
align-items: center;
text-align: center;
}
.principal-category__fee--active,
.principal-category__fee--future {
flex-direction: column;
align-items: center;
text-align: center;
gap: 0.15rem;
}
.principal-category__fee--active .principal-category__fee-dates,
.principal-category__fee--future .principal-category__fee-dates,
.principal-category__fee-dates {
margin-left: 0;
white-space: normal;
line-height: 1.15;
}
.principal-category__fee-active-dot {
display: none;
}
}
/* AppPrivacy Component (BEM) */
.app-privacy {
box-sizing: border-box;
display: flex;
flex-direction: column;
width: 100%;
height: 100%; /* To fit any modal/container */
overflow: hidden; /* Hide overflow from inner scroll container */
background: var(--surface-color);
color: var(--text-color);
font-size: var(--font-size-base, 0.95rem);
}
.app-privacy__inner {
box-sizing: border-box;
flex: 1;
display: flex;
flex-direction: column;
gap: 1rem;
padding: 1.25rem 1.25rem 2rem;
overflow-y: auto; /* Scroll only content */
scrollbar-width: thin;
}
.app-privacy__inner::-webkit-scrollbar {
width: 8px;
}
.app-privacy__inner::-webkit-scrollbar-track {
background: transparent;
}
.app-privacy__inner::-webkit-scrollbar-thumb {
background: var(--text-muted);
border-radius: 4px;
}
.app-privacy__header {
border-bottom: 1px solid var(--border-color);
padding-bottom: .75rem;
margin-bottom: .25rem;
}
.app-privacy__title {
margin: 0 0 .25rem 0;
font-size: 1.25rem;
font-weight: 600;
color: var(--text-color);
}
.app-privacy__last-updated {
margin: 0;
font-size: .7rem;
letter-spacing: .5px;
text-transform: uppercase;
color: var(--text-muted);
}
.app-privacy__content {
line-height: 1.55;
display: flex;
flex-direction: column;
gap: 1.25rem;
}
.app-privacy__section {
display: flex;
flex-direction: column;
gap: .5rem;
}
.app-privacy__section-title {
margin: 0;
font-size: 1.05rem;
font-weight: 600;
color: var(--primary-color);
}
.app-privacy__paragraph {
margin: 0;
text-align: justify;
}
.app-privacy__paragraph + .app-privacy__paragraph {
margin-top: .75rem;
}
.app-privacy__extra {
margin-top: .5rem;
padding-top: .75rem;
border-top: 1px dashed var(--border-light);
font-size: .85rem;
}
/* Responsive */
@media (min-width: 768px) {
.app-privacy__title { font-size: 1.4rem; }
.app-privacy__section-title { font-size: 1.15rem; }
}
/* Optional transitions for smooth theme change */
.app-privacy, .app-privacy * { transition: background-color .25s, color .25s, border-color .25s; }
/* Componente AppQr */
.app-qr {
position: relative;
display: inline-flex;
width: 100%;
height: 100%;
align-items: center;
justify-content: center;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: var(--radius-md, 8px);
padding: var(--space-sm, 0.5rem);
box-sizing: border-box;
overflow: hidden;
aspect-ratio: 1 / 1;
}
/* Estado sin botón de descarga */
.app-qr--no-download .app-qr__download-btn { display: none; }
.app-qr__image {
max-width: 100%;
max-height: 100%;
width: 100%;
height: 100%;
object-fit: contain;
image-rendering: pixelated;
border-radius: var(--radius-xs, 4px);
user-select: none;
-webkit-user-drag: none;
}
.app-qr__placeholder {
width: 100%;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
font-size: clamp(0.75rem, 2vw, 1rem);
color: var(--text-secondary);
background: repeating-conic-gradient(var(--border-color) 0% 25%, transparent 0% 50%) 50% / 20px 20px;
border-radius: var(--radius-xs, 4px);
letter-spacing: 1px;
font-weight: 600;
}
.app-qr__placeholder-text { opacity: 0.6; }
.app-qr__download-btn {
position: absolute;
top: 4px;
right: 4px;
width: 28px;
height: 28px;
display: inline-flex;
align-items: center;
justify-content: center;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: var(--radius-sm, 6px);
text-decoration: none;
color: var(--text-color);
backdrop-filter: blur(4px);
opacity: 0.0;
transform: translateY(-4px);
transition: opacity .25s ease, transform .25s ease, background .25s, border-color .25s;
}
.app-qr:hover .app-qr__download-btn,
.app-qr:focus-within .app-qr__download-btn {
opacity: 1;
transform: translateY(0);
}
.app-qr__download-btn:hover,
.app-qr__download-btn:focus-visible {
background: var(--primary-color);
border-color: var(--primary-color);
color: var(--primary-foreground);
}
.app-qr__download-icon {
width: 16px;
height: 16px;
fill: currentColor;
pointer-events: none;
}
/* Reducción de movimiento */
@media (prefers-reduced-motion: reduce) {
.app-qr__download-btn { transition: none; }
}
/* ------------------------------------------------------------------ */
/* Estilos para el código de confirmación / etiqueta (solo visual, sin cambio de comportamiento) */
/* Centra y enfatiza el código de confirmación cuando se coloca junto o debajo del componente QR.
Apunta a .inscription-page__qr común envolvente y también patrones de hermanos adyacentes. */
.inscription-page__qr {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 0.5rem;
}
/* Cuando el código de confirmación se representa como un hermano justo después del elemento .app-qr */
.app-qr + .inscription-page__code,
/* Cuando está dentro de un contenedor como .inscription-page__qr */
.inscription-page__qr .inscription-page__code {
text-align: center;
font-weight: 700;
font-size: clamp(1rem, 2.6vw, 1.40rem); /* receptivo, más grande en pantallas más anchas */
color: var(--text-color);
letter-spacing: 0.02em;
line-height: 1;
margin: 0;
}
/* Ligera separación y separación visual del cuadro QR */
.app-qr + .inscription-page__code { margin-top: 0.25rem; }
/* Asegurar que los códigos largos se ajusten bien (si los hay) */
.inscription-page__code { word-break: break-word; max-width: 100%; }
/* AppSideBar (BEM)
Visual polish + alignment with base/colors.css variables
*/
.app-sidebar { position: relative; z-index:1000; }
/* Overlay for small screens */
.app-sidebar__overlay { position: fixed; inset:0; background: var(--overlay-color); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); z-index:1090; }
/* Panel */
.app-sidebar__panel {
position: fixed;
top:0; left:0;
height:100dvh;
width: min(320px,90vw);
background: var(--surface-color);
color: var(--text-color);
border-right:1px solid var(--border-color);
box-shadow: var(--shadow-xl);
transform: translateX(-100%);
transition: transform .28s cubic-bezier(0.4, 0, 0.2, 1);
display: flex; flex-direction: column;
z-index:1100;
}
.app-sidebar--open .app-sidebar__panel { transform: translateX(0); }
/* Header - Premium style */
.app-sidebar__header {
display: flex; align-items: center; justify-content: space-between; gap: .5rem;
padding: 1rem 1.25rem;
border-bottom:1px solid var(--border-color);
background: var(--sidebar-header-bg);
color: var(--text-color);
position: relative;
}
/* Línea de acento en el header del sidebar */
.app-sidebar__header::after {
content: '';
position: absolute;
bottom: 0;
left: 0;
right: 0;
height: 2px;
background: var(--topbar-accent-gradient);
opacity: 0.6;
}
.app-sidebar__title { font-weight:700; letter-spacing: -0.01em; font-size: 1.0625rem; }
.app-sidebar__close {
position: relative; display: inline-flex; align-items: center; justify-content: center;
width:36px; height:36px; border-radius:10px;
border:1.5px solid var(--border-color);
background: transparent; color: var(--text-muted);
cursor: pointer; transition: all .25s cubic-bezier(0.4, 0, 0.2, 1);
box-shadow: none;
}
.app-sidebar__close:hover { background: var(--hover-background-color); border-color: var(--primary-color); color: var(--primary-color) }
/* close button visual X */
.app-sidebar__close::before, .app-sidebar__close::after {
content: ""; position: absolute; top:50%; left:50%; width:14px; height:2px;
background-color: currentColor; transform-origin: center; border-radius:1px;
}
.app-sidebar__close::before { transform: translate(-50%, -50%) rotate(45deg); }
.app-sidebar__close::after { transform: translate(-50%, -50%) rotate(-45deg); }
/* Nav */
.app-sidebar__nav { padding: .5rem .75rem 1rem .75rem; overflow: auto; flex: 1; }
.app-sidebar__group { padding: .5rem 0; }
.app-sidebar__group + .app-sidebar__group { border-top:1px solid var(--border-light); }
.app-sidebar__group-title {
padding: .375rem .75rem;
margin: 0 0 .25rem 0;
font-size: .75rem;
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: .08em;
font-weight: 600;
}
.app-sidebar__list { list-style: none; padding:0; margin:0; }
/* Links - Premium hover */
.app-sidebar__link {
display: flex; align-items: center; gap: .625rem;
padding: .5rem .75rem; margin:2px 0; border-radius:10px;
color: var(--text-color); text-decoration: none;
transition: all .2s cubic-bezier(0.4, 0, 0.2, 1);
border-left: 3px solid transparent;
font-size: 0.9375rem;
font-weight: 500;
}
.app-sidebar__link:hover {
background: var(--hover-background-color);
color: var(--primary-color);
border-left-color: var(--primary-color);
transform: translateX(2px);
}
.app-sidebar__link--active {
background: var(--sidebar-active-bg);
color: var(--primary-color);
border-left-color: var(--sidebar-active-border);
font-weight: 600;
}
/* Uniform icons for groups and items */
.app-sidebar__item-icon {
width:22px; height:22px;
display: inline-flex; align-items: center; justify-content: center;
color: var(--text-muted);
border-radius:6px;
transition: color .2s ease;
}
.app-sidebar__item-icon > svg { width:18px; height:18px; display: block; }
/* Hover/active icon color */
.app-sidebar__link:hover .app-sidebar__item-icon { color: var(--primary-color); }
.app-sidebar__link--active .app-sidebar__item-icon { color: var(--primary-color); }
/* Group toggle */
.app-sidebar__group-toggle {
width:100%; display: flex; align-items: center; justify-content: space-between; gap: .5rem;
padding: .5rem .75rem; border:0; background: transparent; color: inherit;
border-radius:10px; cursor: pointer;
transition: all .2s ease;
font-weight: 600;
font-size: 0.9375rem;
}
.app-sidebar__group-toggle:hover { background: var(--hover-background-color); }
/* Caret indicator */
.app-sidebar__group-caret { width:16px; height:16px; position: relative; color: var(--text-muted); transition: color .2s ease; }
.app-sidebar__group-caret::before, .app-sidebar__group-caret::after { content: ""; position: absolute; left:50%; top:50%; width:9px; height:2px; background: currentColor; border-radius:1px; transform-origin: center; transition: transform .2s ease; }
.app-sidebar__group-caret::before { transform: translate(-50%, -50%) rotate(45deg); }
.app-sidebar__group-caret::after { transform: translate(-50%, -50%) rotate(-45deg); }
.app-sidebar__group--closed .app-sidebar__group-caret { color: var(--text-muted); }
.app-sidebar__group--closed .app-sidebar__group-caret::before { transform: translate(-50%, -50%) rotate(135deg); }
.app-sidebar__group--closed .app-sidebar__group-caret::after { transform: translate(-50%, -50%) rotate(45deg); }
.app-sidebar__group-toggle:hover .app-sidebar__group-caret { color: var(--primary-color); }
/* Rail variant (optional) */
.app-sidebar--rail .app-sidebar__panel { width:72px; }
.app-sidebar--rail .app-sidebar__title { display: none; }
.app-sidebar--rail .app-sidebar__group-title { display: none; }
.app-sidebar--rail .app-sidebar__list { display: none; }
.app-sidebar--rail .app-sidebar__group-toggle { justify-content: center; }
.app-sidebar--rail .app-sidebar__item-label { display: none; }
.app-summary {
background: var(--card-bg-color);
border-radius: 14px;
box-shadow: 0 2px 12px var(--shadow-color);
padding: 1rem 1rem 0.75rem 1rem;
margin-bottom: 2rem;
font-size: 1rem;
color: var(--text-color);
}
.app-summary__section {
margin-bottom: 1.2rem;
}
.app-summary__item {
display: flex;
align-items: center;
gap: 1rem;
padding: 0.3rem 0;
}
.app-summary__item--empty {
color: var(--text-muted);
font-style: italic;
}
/* Table like layout */
.app-summary__table {
width: 100%;
margin-bottom: 1rem;
border-radius: 8px;
background: var(--surface-color);
box-shadow: 0 2px 8px var(--shadow-color);
overflow: hidden;
font-size: 0.98rem;
}
.app-summary__table-header,
.app-summary__table-row,
.app-summary__table-footer {
display: grid;
grid-template-columns: 1fr 2.5fr 1.5fr;
align-items: center;
padding: 0.5rem 1rem;
border-bottom: 1px solid var(--divider-color);
}
.app-summary__table-header {
background: var(--divider-color);
font-weight: 700;
color: var(--primary-color);
}
.app-summary__table-row--principal {
background: var(--surface-alt-color);
font-weight: 700;
}
.app-summary__table-footer {
background: var(--surface-color);
font-weight: 600;
color: var(--text-color);
border-bottom: none;
}
.app-summary__table-footer--total {
background: var(--divider-color);
font-size: 1.08rem;
font-weight: 800;
color: var(--primary-color);
border-top: 2px solid var(--warning-color);
}
.app-summary__table--taxes {
margin-top: 0.5rem;
margin-bottom: 0.5rem;
background: var(--surface-color);
border-radius: 8px;
box-shadow: 0 2px 8px var(--shadow-color);
}
.app-summary__table--total {
margin-top: 0.5rem;
background: var(--divider-color);
border-radius: 8px;
box-shadow: 0 2px 8px var(--shadow-color);
}
/* Fiscal card */
.app-summary__fiscal-card {
background: var(--surface-color);
border-radius: 10px;
box-shadow: 0 2px 8px var(--shadow-color);
padding: 1rem 1.2rem;
margin-top: 1.2rem;
margin-bottom: 0.5rem;
}
.app-summary__fiscal-fields {
display: flex;
flex-direction: column;
gap: 0.3rem;
font-size: 1rem;
color: var(--primary-color);
}
/* Currency warning */
.app-summary__currency-warning {
font-size: 0.92rem;
color: var(--warning-color);
background: var(--warning-background);
border-radius: 8px;
padding: 0.6rem 1rem;
margin-bottom: 1.1rem;
margin-top: 0.2rem;
text-align: left;
display: flex;
align-items: center;
gap: 0.5rem;
box-shadow: 0 2px 8px var(--shadow-color);
}
/* Headings */
.app-summary h3,
.app-summary h4 {
color: var(--text-color);
margin: 0 0 0.6rem;
}
/* Event name section */
.app-summary__event-name {
display: flex;
align-items: center;
gap: 0.5rem;
padding: 0.75rem 1rem;
margin-bottom: 1rem;
background: var(--primary-background);
border: 1px solid var(--primary-color);
border-radius: 8px;
color: var(--primary-color);
font-weight: 600;
font-size: 1rem;
box-shadow: 0 2px 8px var(--shadow-color);
}
.app-summary__event-name span {
flex: 1;
}
.app-summary__icon {
margin-right: 0.25rem;
font-size: 0.95em;
}
.app-summary__icon--event {
font-size: 1.1em;
color: var(--primary-color);
}
.app-summary__icon--flag {
color: var(--warning-color);
}
.app-summary__icon--tag {
color: var(--success-color);
}
.app-summary__icon--info {
color: var(--warning-color);
font-size: 1.1em;
}
@media (max-width: 700px) {
.app-summary {
padding: .75rem .5rem;
}
.app-summary__table-header,
.app-summary__table-row,
.app-summary__table-footer {
grid-template-columns: .8fr 2fr 1.2fr;
}
}
/* Estilo para la etiqueta de descuentos */
.app-summary__discount-label {
display: flex;
align-items: center;
font-weight: 600;
color: var(--success-color);
margin-top: 0.5rem;
margin-bottom: 0.25rem;
font-size: 1rem;
}
/* Tabla de descuentos con borde success */
.app-summary__table--discounts {
border: 2px solid var(--success-color);
border-radius: 8px;
margin-top: 0.5rem;
margin-bottom: 1rem;
background: var(--surface-color);
box-shadow: var(--shadow-sm);
}
/* Fila de descuento: texto success */
.app-summary__table-row--discount {
color: var(--success-color);
font-weight: 600;
display: grid;
grid-template-columns: 1fr 2.5fr 1.5fr;
align-items: center;
padding: 0.5rem 1rem;
border-bottom: 1px solid var(--divider-color);
background: inherit;
}
.app-summary__table-row--discount span {
text-align: left;
padding: 0.15rem 0.25rem;
}
.app-terms {
width: 100%;
min-height: 0;
display: flex;
align-items: center;
justify-content: center;
background: transparent;
padding: 0;
box-sizing: border-box;
}
.app-terms__container {
background: var(--surface-color);
border-radius: 18px;
box-shadow: var(--shadow-md);
padding: 2.5rem 2.5rem 2rem 2.5rem;
width: 100%;
margin: 0;
box-sizing: border-box;
transition: background 0.3s;
}
.app-terms__title {
font-size: 2.1rem;
font-weight: 800;
color: var(--primary-color);
margin-bottom: 1.2rem;
text-align: center;
letter-spacing: 0.01em;
}
.app-terms__subtitle {
font-size: 1.25rem;
font-weight: 700;
color: var(--primary-color);
margin-bottom: 1.5rem;
text-align: center;
letter-spacing: 0.01em;
}
.app-terms__list {
list-style: none;
padding: 0;
margin: 0;
display: flex;
flex-direction: column;
gap: 1.2rem;
}
.app-terms__item {
display: flex;
align-items: flex-start;
gap: 1rem;
font-size: 1.15rem;
color: var(--text-color);
background: var(--surface-alt-color);
border-radius: 12px;
padding: 1.2rem 1.5rem;
box-shadow: var(--shadow-sm);
font-weight: 500;
position: relative;
transition: background 0.3s, color 0.3s;
}
.app-terms__item::before {
content: '';
display: inline-block;
width: 1.1em;
height: 1.1em;
margin-top: 0.2em;
margin-right: 0.5em;
background: var(--accent-color);
mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><circle cx="12" cy="12" r="8"/></svg>') no-repeat center / contain;
-webkit-mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><circle cx="12" cy="12" r="8"/></svg>') no-repeat center / contain;
}
.app-terms__item strong {
color: var(--accent-color);
font-weight: 700;
transition: color 0.3s;
}
.app-terms__item:hover {
background: var(--hover-background-color);
color: var(--primary-color);
}
@media (max-width: 700px) {
.app-terms__container {
padding: 1.2rem 0.5rem 1rem 0.5rem;
}
.app-terms__title {
font-size: 1.3rem;
}
.app-terms__subtitle {
font-size: 1.05rem;
}
.app-terms__item {
font-size: 1rem;
padding: 0.8rem 0.7rem;
}
.app-terms__item::before {
width: 0.9em;
height: 0.9em;
margin-right: 0.4em;
}
}
/* ================================================
AppTicketMessage — Chat bubble component
All colors use variables from colors.css
================================================ */
.ticket-message {
display: flex;
margin: 0.375rem 0;
}
.ticket-message__bubble {
max-width: 70%;
padding: 0.625rem 0.75rem;
border-radius: 0.75rem;
line-height: 1.45;
font-size: 0.9375rem;
box-shadow: var(--shadow-xs);
}
/* Staff message — left-aligned */
.ticket-message--staff {
justify-content: flex-start;
}
.ticket-message--staff .ticket-message__bubble {
background: var(--info-background);
color: var(--info-foreground);
border: 1px solid var(--info-color);
border-top-left-radius: 0.25rem;
}
/* Client message — right-aligned */
.ticket-message--client {
justify-content: flex-end;
}
.ticket-message--client .ticket-message__bubble {
background: var(--success-background);
color: var(--success-foreground);
border: 1px solid var(--success-color);
border-top-right-radius: 0.25rem;
}
/* Meta: sender + date */
.ticket-message__meta {
margin-top: 0.25rem;
font-size: 0.6875rem;
opacity: 0.7;
}
body
{
}
.app-user-data-form{width:100%;display:block}
.app-user-data-form__grid{display:grid;grid-template-columns:1fr;gap:1rem}
.app-user-data-form__field{width:100%}
.app-user-data-form__field--full{grid-column:1/-1}
.app-user-data-form__inline-field{display:flex;flex-direction:column;gap:.5rem}
.app-user-data-form__actions{display:flex;justify-content:flex-end}
@media (min-width: 640px){
.app-user-data-form__grid{grid-template-columns:repeat(2,1fr)}
}
@media (min-width: 1024px){
.app-user-data-form__grid{grid-template-columns:repeat(3,1fr)}
}
/* Theme-aware colors rely on existing CSS variables defined globally */
.app-user-data-form, .app-user-data-form *{box-sizing:border-box}
body
{
}
body
{
}
.app-user-photo-upload {
position: relative;
display: block;
}
/* Card */
.app-user-photo-upload__card {
position: relative;
display: flex;
flex-direction: column;
gap: .5rem;
border: 1px dashed var(--border-color);
border-radius: 12px;
overflow: hidden;
background: var(--surface-color);
transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}
.app-user-photo-upload__card:hover {
border-color: var(--primary-light);
}
.app-user-photo-upload__card--dragover,
.app-user-photo-upload__card:focus-within {
border-color: var(--primary-color);
box-shadow: 0 0 0 3px var(--focus-ring);
}
/* Top image area */
.app-user-photo-upload__image {
width: 100%;
aspect-ratio: 1.6/1;
background: var(--disabled-background);
display: flex;
align-items: center;
justify-content: center;
}
.app-user-photo-upload__img {
max-width: 100%;
max-height: 100%;
object-fit: cover;
display: block;
width: 100%;
height: 100%;
}
.app-user-photo-upload__placeholder {
color: var(--text-muted);
display: flex;
align-items: center;
justify-content: center;
width: 100%;
height: 100%;
}
/* Bottom area */
.app-user-photo-upload__bottom {
display: flex;
align-items: center;
justify-content: space-between;
gap: .75rem;
padding: .75rem .9rem;
background: var(--surface-color);
}
.app-user-photo-upload__texts {
min-width: 0;
color: var(--text-color);
}
.app-user-photo-upload__title {
font-weight: 600;
font-size: .95rem;
line-height: 1.2;
}
.app-user-photo-upload__hint {
font-size: .8rem;
color: var(--text-muted);
}
.app-user-photo-upload__action {
color: var(--primary-color);
cursor: pointer;
font-weight: 600;
white-space: nowrap;
}
.app-user-photo-upload__action:hover,
.app-user-photo-upload__action:focus {
text-decoration: underline;
}
/* Full overlay input capturing clicks and drops */
.app-user-photo-upload__input {
position: absolute;
inset: 0;
opacity: 0;
width: 100%;
height: 100%;
cursor: pointer;
z-index: 2;
pointer-events: auto;
}
/* Error message */
.app-user-photo-upload__error {
color: var(--danger-color);
font-size: .85rem;
margin-top: .5rem;
}
/* Save / Update action */
.app-user-photo-upload__actions {
display: flex;
justify-content: flex-end;
margin-top: .75rem;
}
.app-user-photo-upload__btn {
display: inline-flex;
align-items: center;
gap: .4rem;
padding: .5rem 1.25rem;
border: none;
border-radius: 8px;
font-size: .9rem;
font-weight: 600;
cursor: pointer;
background-color: var(--primary-color);
color: var(--primary-foreground);
transition: background-color .2s ease, box-shadow .2s ease;
}
.app-user-photo-upload__btn:hover {
background-color: var(--primary-hover);
box-shadow: var(--shadow-sm);
}
.app-user-photo-upload__btn:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
.app-user-photo-upload__card {
transition: none;
}
}
body
{
}
.app-user-summary{width:100%;display:block}
.app-user-summary__grid{display:grid;grid-template-columns:1fr;gap:.5rem}
.app-user-summary__row{display:flex;justify-content:space-between;gap:.75rem;padding:.25rem 0;border-bottom:1px dashed var(--border-color)}
.app-user-summary__value{color:var(--text-color)}
@media (min-width:768px){
.app-user-summary__grid{grid-template-columns:1fr 1fr}
}
.app-user-view{width:100%;display:block}
.app-user-view__actions{display:flex;align-items:center;gap:.5rem}
.app-user-view__spacer{flex:1}
.app-user-view__loading,.app-user-view__error,.app-user-view__empty{width:100%;display:flex;align-items:center;justify-content:center;min-height:120px;color:var(--text-secondary)}
/* Mobile first: tabs stacked */
.app-user-view__mobile{display:block}
.app-user-view__desktop{display:none}
/* Panels (left column) */
.app-user-view__layout{display:grid;grid-template-columns:1fr;gap:1rem}
.app-user-view__left{display:flex;flex-direction:column;gap:1rem}
.app-user-view__right{min-width:0}
.app-user-view__panel{background:var(--surface-color);border:1px solid var(--border-color);border-radius:8px;padding:1rem}
.app-user-view__panel-title{margin:0 0 .5rem 0;color:var(--text-color);font-size:1rem}
/* Nueva clase para centrar el contenido de privacidad debajo de la foto */
.app-user-view__left { display:flex; flex-direction:column; align-items:center; }
.app-user-view__panel { width:100%; max-width:280px; text-align:center; }
.app-user-view__panel-title { margin-bottom:.6rem }
.app-user-view__privacy { margin-top:1rem; text-align:center; }
.app-user-view__privacy-text { font-size:.9rem; color:var(--text-muted); margin-bottom:.4rem }
.app-user-view__privacy-action { display:flex; justify-content:center }
.app-user-view__privacy-action .app-button--link { font-weight:600 }
/* Privacy mobile styles (dentro de tabs) */
.app-user-view__privacy-mobile { padding:1rem; text-align:center; }
.app-user-view__privacy-mobile .app-user-view__privacy-text { font-size:.9rem; color:var(--text-muted); margin-bottom:1rem; line-height:1.5; }
.app-user-view__privacy-mobile .app-user-view__privacy-action { display:flex; justify-content:center; }
.app-user-view__privacy-mobile .app-button--link { font-weight:600; }
/* >= md: two columns */
@media (min-width:768px){
.app-user-view__mobile{display:none}
.app-user-view__desktop{display:block}
.app-user-view__layout{grid-template-columns:minmax(220px,30%) 1fr}
}
/* >= lg: wider left column cap */
@media (min-width:1024px){
.app-user-view__layout{grid-template-columns:minmax(260px,28%) 1fr}
}
/* Styles for AppEventCsd component - BEM: app-event-csd
Responsive, uses CSS variables from global palette
*/
.app-event-csd {
box-sizing: border-box;
width:100%;
display: flex;
flex-direction: column;
gap:0.75rem;
font-family: var(--app-font-family, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial);
color: var(--text-color);
}
/* modifier to ensure full container sizing when required */
.app-event-csd--full {
width:100%;
height:100%;
}
/* Card container alignment (AppCard wrapper keeps padding) */
.app-event-csd .app-card {
width:100%;
}
/* Assigned CSD block */
.app-event-csd__assigned {
padding:1rem;
border-radius:8px;
background: var(--card-bg-color);
border:1px solid var(--border-color);
display: flex;
flex-direction: column;
gap:0.75rem;
}
.app-event-csd__assigned h3 {
margin:0;
font-size:1rem;
color: var(--primary-color);
}
.app-event-csd__assigned-row {
display: flex;
flex-wrap: wrap;
gap:1rem;
align-items: center;
}
.app-event-csd__assigned-row > div {
min-width:160px;
font-size:0.95rem;
color: var(--text-color);
}
.app-event-csd__assigned-actions {
display: flex;
gap:0.5rem;
}
/* List & search area */
.app-event-csd__list {
display: flex;
flex-direction: column;
gap:0.75rem;
}
.app-event-csd__search {
display: flex;
gap:0.5rem;
align-items: end;
flex-wrap: wrap;
}
.app-event-csd__search .app-input-field,
.app-event-csd__search .app-button {
vertical-align: middle;
}
/* ensure spinner aligns center */
.app-event-csd app-spinner,
.app-event-csd .app-spinner {
display: block;
margin:1rem auto;
}
/* Table responsiveness - keep consistent with base table styles */
.app-event-csd table.app-table {
width:100%;
border-collapse: collapse;
}
.app-event-csd__pagination {
display: flex;
justify-content: center;
margin-top:0.5rem;
}
/* Modal actions */
.app-event-csd__modal-actions {
display: flex;
gap:0.5rem;
justify-content: flex-end;
margin-top:0.75rem;
}
/* Error box inside modal/form */
.app-event-csd__error {
color: var(--danger-color);
background: var(--danger-background);
padding:0.5rem 0.75rem;
border-radius:6px;
font-size:0.95rem;
}
/* small utilities */
.app-event-csd__small {
font-size:0.875rem;
color: var(--text-muted);
}
/* Responsive breakpoints */
@media (max-width:767px) {
.app-event-csd__search {
flex-direction: column;
align-items: stretch;
}
.app-event-csd__assigned-row {
flex-direction: column;
gap:0.5rem;
}
.app-event-csd__assigned-row > div { min-width: auto; }
.app-event-csd__modal-actions { flex-direction: column-reverse; align-items: stretch; }
}
/* Theme Toggle Component */
.theme-toggle {
position: relative;
}
.theme-toggle__button {
display: flex;
align-items: center;
justify-content: center;
width: 36px;
height: 36px;
padding: 0;
background: transparent;
border: 1.5px solid var(--border-color);
border-radius: 9px;
color: var(--text-muted);
cursor: pointer;
transition: all 0.2s ease;
box-shadow: none;
}
.theme-toggle__button:hover {
background: var(--hover-background-color);
border-color: var(--primary-color);
color: var(--primary-color);
transform: translateY(-1px);
}
.theme-toggle__button:active {
transform: translateY(0);
}
.theme-toggle__button:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
.theme-toggle__icon {
width: 18px;
height: 18px;
flex-shrink: 0;
color: currentColor;
transition: transform 0.2s ease;
}
.theme-toggle__button:hover .theme-toggle__icon {
transform: scale(1.08);
}
/* Dropdown */
.theme-toggle__dropdown {
position: absolute;
top: calc(100% + 8px);
right: 0;
background-color: var(--surface-color);
color: var(--text-color);
min-width: 180px;
border-radius: 12px;
box-shadow: var(--shadow-xl);
border: 1px solid var(--border-color);
padding: 0.25rem;
display: none;
z-index: 1050;
animation: themeDropFadeIn 0.15s ease;
isolation: isolate;
backdrop-filter: none;
-webkit-backdrop-filter: none;
}
.theme-toggle.open .theme-toggle__dropdown {
display: block;
}
@keyframes themeDropFadeIn {
from {
opacity: 0;
transform: translateY(-6px) scale(0.98);
}
to {
opacity: 1;
transform: translateY(0) scale(1);
}
}
.theme-toggle__dropdown .theme-toggle__option {
width: 100%;
text-align: left;
background-color: transparent;
border: 0;
padding: 0.5rem 0.75rem;
border-radius: 8px;
cursor: pointer;
color: var(--text-color);
text-decoration: none;
display: flex;
align-items: center;
gap: 0.625rem;
font-size: 0.875rem;
font-weight: 500;
line-height: 1.4;
transition: background-color 0.15s ease, color 0.15s ease;
box-shadow: none;
outline: none;
min-height: auto;
transform: none;
}
.theme-toggle__dropdown .theme-toggle__option:hover {
background-color: var(--topbar-dropdown-hover-bg);
color: var(--primary-color);
box-shadow: none;
transform: none;
}
.theme-toggle__dropdown .theme-toggle__option:active {
opacity: 0.8;
transform: none;
box-shadow: none;
}
.theme-toggle__dropdown .theme-toggle__option:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
.theme-toggle__dropdown .theme-toggle__option--active {
background-color: var(--topbar-dropdown-hover-bg);
color: var(--primary-color);
font-weight: 600;
}
.theme-toggle__option {
width: 100%;
text-align: left;
background: transparent;
border: 0;
padding: 0.5rem 0.75rem;
border-radius: 8px;
cursor: pointer;
color: var(--text-color);
text-decoration: none;
display: flex;
align-items: center;
gap: 0.625rem;
font-size: 0.875rem;
font-weight: 500;
line-height: 1.4;
transition: all 0.15s ease;
}
.theme-toggle__option:hover {
background-color: var(--topbar-dropdown-hover-bg);
color: var(--primary-color);
}
.theme-toggle__option:active {
opacity: 0.8;
}
.theme-toggle__option:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
.theme-toggle__option--active {
background-color: var(--topbar-dropdown-hover-bg);
color: var(--primary-color);
font-weight: 600;
}
.theme-toggle__option svg:first-of-type {
width: 18px;
height: 18px;
flex-shrink: 0;
}
.theme-toggle__option span {
flex: 1;
}
.theme-toggle__check {
width: 14px;
height: 14px;
flex-shrink: 0;
color: var(--primary-color);
}
/* Responsive */
@media (max-width: 640px) {
.theme-toggle__dropdown {
right: -0.5rem;
min-width: 160px;
}
.theme-toggle__button {
width: 34px;
height: 34px;
}
.theme-toggle__icon {
width: 16px;
height: 16px;
}
}
/* Backdrop */
.theme-toggle__backdrop {
position: fixed;
inset: 0;
z-index: 1040;
background: transparent;
}
.app-topbar {
position: sticky;
top: 0;
left: 0;
right: 0;
z-index: 980;
width: 100%;
background: var(--topbar-bg);
color: var(--text-color);
box-shadow: var(--topbar-shadow);
border-bottom: none;
backdrop-filter: blur(var(--glass-blur)) saturate(180%);
-webkit-backdrop-filter: blur(var(--glass-blur)) saturate(180%);
transition: box-shadow 0.3s ease, background 0.3s ease;
}
.app-custom__topbar__logo-mark{
width: 44px;
height: 44px;
}
.app-topbar::after {
content: '';
position: absolute;
bottom: 0;
left: 0;
right: 0;
height: 2px;
background: var(--topbar-accent-gradient);
background-size: 200% 100%;
animation: topbar-accent-shimmer 6s ease infinite;
opacity: 0.7;
}
@keyframes topbar-accent-shimmer {
0%, 100% { background-position: 0% 50%; }
50% { background-position: 100% 50%; }
}
.app-topbar__inner {
height: 60px;
display: grid;
grid-template-columns: minmax(160px, 20%) minmax(0, 60%) minmax(160px, 20%);
align-items: center;
gap: 1rem;
padding: 0 1.5rem;
width: 100%;
max-width: 1400px;
margin: 0 auto;
box-sizing: border-box;
}
.app-topbar__left, .app-topbar__center, .app-topbar__right {
min-width: 0;
}
.app-topbar__left {
display: flex;
align-items: center;
gap: 0.75rem;
justify-content: flex-start;
}
.app-topbar__logo {
display: inline-flex;
align-items: center;
justify-content: center;
width: 40px;
height: 40px;
border-radius: 10px;
background: var(--surface-color);
border: 1px solid var(--border-color);
overflow: hidden;
transition: all 0.2s ease;
flex-shrink: 0;
}
.app-topbar__logo:hover {
transform: translateY(-1px);
box-shadow: var(--shadow-sm);
border-color: var(--primary-color);
}
.app-topbar__logo img {
width: 30px;
height: 30px;
object-fit: contain;
display: block;
}
.app-topbar__brand {
color: var(--text-color);
text-decoration: none;
transition: color 0.2s ease;
}
.app-topbar__brand:hover {
color: var(--primary-color);
text-decoration: none;
}
.app-topbar__brand-name {
font-size: 1.125rem;
font-weight: 700;
letter-spacing: -0.02em;
white-space: nowrap;
max-width: 180px;
overflow: hidden;
text-overflow: ellipsis;
display: inline-block;
color: inherit;
line-height: 1.2;
}
.app-topbar__center {
display: flex;
align-items: center;
justify-content: center;
overflow: hidden;
}
.app-topbar__nav {
display: flex;
gap: 2px;
align-items: center;
flex-wrap: nowrap;
max-width: 100%;
overflow: hidden;
padding: 3px;
border-radius: 10px;
background: var(--topbar-nav-bg);
border: 1px solid var(--topbar-nav-border);
}
.app-topbar__nav-link {
color: var(--text-secondary);
text-decoration: none;
padding: 0.4375rem 1rem;
border-radius: 7px;
transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
white-space: nowrap;
font-size: 0.8125rem;
font-weight: 600;
line-height: 1.3;
border: 1px solid transparent;
background: transparent;
}
.app-topbar__nav-link:hover {
color: var(--text-color);
background: var(--topbar-nav-link-hover-bg);
border-color: var(--topbar-nav-link-hover-border);
text-decoration: none;
}
.app-topbar__nav-link:focus-visible {
color: var(--primary-color);
background: var(--topbar-nav-link-hover-bg);
outline: 2px solid var(--focus-color);
outline-offset: 1px;
}
.app-topbar__nav-link:active {
transform: scale(0.97);
}
/* Link activo */
.app-topbar__nav-link--active {
color: var(--primary-foreground);
background: var(--primary-color);
border-color: var(--primary-color);
box-shadow: var(--shadow-xs);
}
.app-topbar__nav-link--active:hover {
color: var(--primary-foreground);
background: var(--primary-hover);
border-color: var(--primary-hover);
}
.app-topbar__right {
display: flex;
align-items: center;
justify-content: flex-end;
gap: 0.375rem;
flex: 0 0 auto;
flex-wrap: nowrap;
}
/* Botón Admin */
.app-topbar__admin {
display: flex;
align-items: center;
}
.app-topbar__admin-btn {
background: transparent;
border: 1.5px solid var(--primary-color);
color: var(--primary-color);
border-radius: 9px;
height: 36px;
padding: 0 0.75rem;
display: inline-flex;
align-items: center;
gap: 0.4rem;
cursor: pointer;
font-weight: 600;
font-size: 0.8125rem;
line-height: 1;
transition: all 0.2s ease;
box-shadow: none;
}
.app-topbar__admin-btn:hover {
background: var(--primary-color);
color: var(--primary-foreground);
box-shadow: var(--shadow-sm);
transform: translateY(-1px);
}
.app-topbar__admin-btn:active {
transform: translateY(0);
box-shadow: none;
}
.app-topbar__admin-btn svg {
width: 16px;
height: 16px;
color: currentColor;
fill: currentColor;
}
.app-topbar__admin-label {
font-size: 0.8125rem;
}
/* Icon buttons — theme, lang, avatar */
.app-topbar__dropdowns {
display: flex;
align-items: center;
gap: 0.25rem;
}
.app-topbar__language,
.app-topbar__avatar {
position: relative;
display: inline-flex;
align-items: center;
justify-content: center;
width: 36px;
height: 36px;
border-radius: 9px;
cursor: pointer;
flex: 0 0 auto;
background: transparent;
border: 1.5px solid var(--border-color);
color: var(--text-muted);
box-shadow: none;
transition: all 0.2s ease;
}
.app-topbar__language:hover,
.app-topbar__avatar:hover {
background: var(--hover-background-color);
border-color: var(--primary-color);
color: var(--primary-color);
transform: translateY(-1px);
}
.app-topbar__language:active,
.app-topbar__avatar:active {
transform: translateY(0);
}
.app-topbar__language:focus-visible,
.app-topbar__avatar:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
.app-topbar__language svg,
.app-topbar__avatar svg {
width: 18px;
height: 18px;
color: currentColor;
transition: transform 0.2s ease;
}
.app-topbar__language:hover svg,
.app-topbar__avatar:hover svg {
transform: scale(1.08);
}
/* Dropdown menus */
.app-topbar__dropdown-menu {
position: absolute;
right: 0;
top: calc(100% + 8px);
background-color: var(--surface-color);
color: var(--text-color);
min-width: 200px;
border-radius: 12px;
box-shadow: var(--shadow-xl);
border: 1px solid var(--border-color);
padding: 0.25rem;
display: none;
z-index: 1050;
animation: dropdownFadeIn 0.15s ease;
/* Ensure fully opaque — prevent topbar backdrop-filter bleed-through */
isolation: isolate;
backdrop-filter: none;
-webkit-backdrop-filter: none;
}
@keyframes dropdownFadeIn {
from {
opacity: 0;
transform: translateY(-6px) scale(0.98);
}
to {
opacity: 1;
transform: translateY(0) scale(1);
}
}
.app-topbar__language.open .app-topbar__dropdown-menu,
.app-topbar__avatar.open .app-topbar__dropdown-menu {
display: block;
}
.app-topbar__dropdown-menu .app-topbar__dropdown-item {
width: 100%;
text-align: left;
background-color: transparent;
border: 0;
padding: 0.5rem 0.75rem;
border-radius: 8px;
cursor: pointer;
color: var(--text-color);
text-decoration: none;
display: flex;
align-items: center;
font-size: 0.875rem;
font-weight: 500;
line-height: 1.4;
transition: background-color 0.15s ease, color 0.15s ease;
gap: 0.5rem;
box-shadow: none;
outline: none;
min-height: auto;
transform: none;
}
.app-topbar__dropdown-menu .app-topbar__dropdown-item:hover {
background-color: var(--topbar-dropdown-hover-bg);
color: var(--primary-color);
text-decoration: none;
box-shadow: none;
transform: none;
}
.app-topbar__dropdown-menu .app-topbar__dropdown-item:active {
opacity: 0.8;
transform: none;
box-shadow: none;
}
.app-topbar__dropdown-menu .app-topbar__dropdown-item:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
/* Divider */
.app-topbar__dropdown-divider {
height: 1px;
background: var(--divider-color);
margin: 0.25rem 0.5rem;
}
/* ========================================== */
/*  Hamburguesa (móvil)                      */
/* ========================================== */
.app-topbar__hamburger {
display: none;
}
.app-topbar__menu-toggle {
background: transparent;
color: var(--text-color);
border: 1.5px solid var(--border-color);
border-radius: 9px;
padding: 0;
cursor: pointer;
transition: all 0.2s ease;
display: inline-flex;
align-items: center;
justify-content: center;
width: 36px;
height: 36px;
}
.app-topbar__menu-toggle:hover {
background: var(--hover-background-color);
border-color: var(--primary-color);
color: var(--primary-color);
}
.app-topbar__menu-toggle svg {
width: 20px;
height: 20px;
}
/* ========================================== */
/*  Responsive                               */
/* ========================================== */
@media (max-width: 900px) {
.app-topbar__inner {
grid-template-columns: auto 1fr auto;
padding: 0 1rem;
gap: 0.75rem;
height: 56px;
}
.app-topbar__brand-name {
display: none;
}
.app-topbar__hamburger {
display: block;
}
.app-topbar__center {
justify-content: flex-end;
}
.app-topbar__nav {
display: none;
background: transparent;
border: none;
padding: 0;
}
.app-topbar__nav--open {
display: flex;
position: absolute;
left: 0;
right: 0;
top: 56px;
background: var(--surface-color);
padding: 0.5rem 1rem;
flex-direction: column;
gap: 2px;
border-bottom: 2px solid var(--primary-color);
z-index: 1040;
box-shadow: var(--shadow-md);
animation: menuSlideDown 0.2s ease;
}
@keyframes menuSlideDown {
from { opacity: 0; transform: translateY(-8px); }
to { opacity: 1; transform: translateY(0); }
}
.app-topbar__nav--open .app-topbar__nav-link {
width: 100%;
padding: 0.625rem 0.875rem;
text-align: left;
font-size: 0.875rem;
border-radius: 8px;
}
.app-topbar__admin-label {
display: none;
}
.app-topbar__admin-btn {
padding: 0 0.5rem;
}
.app-topbar__dropdown-menu {
right: 0;
left: auto;
}
}
@media (max-width: 640px) {
.app-topbar__inner {
padding: 0 0.75rem;
gap: 0.25rem;
height: 52px;
}
.app-topbar__right {
gap: 0.25rem;
}
.app-topbar__language,
.app-topbar__avatar,
.app-topbar__menu-toggle {
width: 34px;
height: 34px;
}
.app-topbar__language svg,
.app-topbar__avatar svg {
width: 16px;
height: 16px;
}
.app-topbar__admin-btn {
height: 34px;
}
.app-topbar__dropdown-menu {
min-width: 180px;
}
.app-topbar__logo {
width: 36px;
height: 36px;
}
.app-topbar__logo img {
width: 28px;
height: 28px;
}
.app-topbar__nav--open {
top: 52px;
}
}
/* ========================================== */
/*  Focus accesible                          */
/* ========================================== */
.app-topbar__nav-link:focus-visible,
.app-topbar__admin-btn:focus-visible,
.app-topbar__menu-toggle:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
.home-coauthors__accordion {
border: 1px solid var(--border-color);
border-radius: 0.875rem;
overflow: hidden;
background: var(--surface-color);
transition: border-color 0.2s, box-shadow 0.2s;
}
.home-coauthors__accordion--open {
border-color: var(--primary-color);
box-shadow: 0 0 0 3px rgba(1, 29, 125, 0.10);
}
.home-coauthors__accordion-header {
display: flex;
flex-direction: row;
align-items: center;
gap: 0.6rem;
padding: 0.65rem 1rem;
background: var(--secondary-background);
border-bottom: 1px solid transparent;
cursor: pointer;
user-select: none;
transition: background 0.15s;
min-height: 3rem;
}
.home-coauthors__accordion--open .home-coauthors__accordion-header {
border-bottom-color: var(--border-color);
}
.home-coauthors__accordion-header:hover {
background: var(--surface-alt-color);
}
.home-coauthors__accordion-chevron {
flex-shrink: 0;
color: var(--primary-color);
opacity: 0.7;
transition: transform 0.22s ease, opacity 0.15s;
}
.home-coauthors__accordion--open .home-coauthors__accordion-chevron {
transform: rotate(180deg);
opacity: 1;
}
.home-coauthors__accordion-title {
flex: 1 1 0;
display: flex;
flex-direction: column;
justify-content: center;
gap: 0.1rem;
min-width: 0;
overflow: hidden;
}
.home-coauthors__item-label {
display: inline-flex;
flex-direction: row;
align-items: center;
gap: 0.35rem;
font-size: 0.875rem;
font-weight: 600;
color: var(--text-color);
white-space: nowrap;
}
.home-coauthors__accordion-summary {
font-size: 0.75rem;
color: var(--text-muted);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.home-coauthors__complete-icon {
flex-shrink: 0;
color: var(--success-color, #10b981);
}
.home-coauthors__incomplete-badge {
font-size: 0.67rem;
font-weight: 500;
line-height: 1.5;
color: #92400e;
background: #fef3c7;
border: 1px solid #fde68a;
border-radius: 999px;
padding: 0.05rem 0.55rem;
}
.home-coauthors__accordion-actions {
display: flex;
flex-direction: row;
align-items: center;
gap: 0.25rem;
flex-shrink: 0;
margin-left: auto;
}
.home-coauthors__remove-btn {
display: flex;
align-items: center;
justify-content: center;
width: 1.75rem;
height: 1.75rem;
padding: 0;
background: none;
border: none;
border-radius: 0.4rem;
cursor: pointer;
color: var(--danger-color);
transition: background 0.15s, color 0.15s;
line-height: 0;
}
.home-coauthors__remove-btn:hover {
background: var(--danger-background);
color: var(--danger-dark);
}
.home-coauthors__accordion-body {
animation: accordion-in 0.16s ease;
}
@keyframes accordion-in {
from { opacity: 0; transform: translateY(-4px); }
to   { opacity: 1; transform: translateY(0); }
}
.home-coauthors__item-form {
padding: 1rem 1.1rem;
display: flex;
flex-direction: column;
gap: 1rem;
}
.home-coauthors__item-row {
display: flex;
flex-direction: row;
gap: 1rem;
}
@media (max-width: 640px) {
.home-coauthors__item-row {
flex-direction: column;
}
}
.app-accordion__item {
border-bottom: 1px solid var(--border-color);
background: var(--surface-color);
}
.app-accordion__header {
width: 100%;
background: var(--surface-color);
border: none;
padding: 1rem;
text-align: left;
font-size: 1.08rem;
font-weight: 500;
display: flex;
align-items: center;
justify-content: space-between;
cursor: pointer;
color: var(--primary-color);
transition: background 0.2s, color 0.2s;
}
.app-accordion__header:hover {
background: var(--hover-background-color);
color: var(--hover-color);
}
.app-accordion__icon {
font-size: 1.1em;
margin-left: 0.5em;
color: var(--primary-color);
}
.app-accordion__content {
padding: 1rem;
background: var(--surface-alt-color);
color: var(--text-color);
font-size: 1rem;
animation: accordion-fadein 0.2s;
}
.app-accordion__content, .app-accordion__content * {
color: var(--text-color);
}
@keyframes accordion-fadein {
from {
opacity: 0;
}
to {
opacity: 1;
}
}
/* ============================================================
app-alert  —  Componente de alerta contextual  (BEM)
Variantes: info | success | warning | danger
Usa exclusivamente variables de colors.css
============================================================ */
/* ── Contenedor base ─────────────────────────────────────── */
.app-alert {
display: flex;
align-items: center;
margin-bottom: 2rem;
gap: 0.75rem;
padding: 0.875rem 1rem;
border-radius: 0.6rem;
border: 1px solid var(--border-color);
background: var(--surface-color);
width: 100%;
box-sizing: border-box;
flex-wrap: wrap;
border-left-width: 3px;
border-left-style: solid;
}
.app-alert__select-wrap{
width: 50%;
order: 2;
}
/* ── Variantes ───────────────────────────────────────────── */
/* Info */
.app-alert--info {
border-left-color: var(--info-dark);
background: var(--info-background);
border-color: var(--info-light);
border-left-color: var(--info-dark);
}
/* Success */
.app-alert--success {
border-left-color: var(--success-dark);
background: var(--success-background);
border-color: var(--success-light);
border-left-color: var(--success-dark);
}
/* Warning */
.app-alert--warning {
border-left-color: var(--warning-dark);
background: var(--warning-background);
border-color: var(--warning-light);
border-left-color: var(--warning-dark);
}
/* Danger */
.app-alert--danger {
border-left-color: var(--danger-dark);
background: var(--danger-background);
border-color: var(--danger-light);
border-left-color: var(--danger-dark);
}
/* ── Ícono ───────────────────────────────────────────────── */
.app-alert__icon {
flex-shrink: 0;
width: 20px;
height: 20px;
display: flex;
align-items: center;
justify-content: center;
}
.app-alert__icon svg,
.app-alert__icon img {
width: 20px;
height: 20px;
display: block;
}
/* Color de relleno del SVG por variante */
.app-alert--info    .app-alert__icon svg { fill: var(--info-foreground);    color: var(--info-foreground); }
.app-alert--success .app-alert__icon svg { fill: var(--success-foreground); color: var(--success-foreground); }
.app-alert--warning .app-alert__icon svg { fill: var(--warning-foreground); color: var(--warning-foreground); }
.app-alert--danger  .app-alert__icon svg { fill: var(--danger-foreground);  color: var(--danger-foreground); }
/* ── Cuerpo ──────────────────────────────────────────────── */
.app-alert__body {
flex: 1;
min-width: 0;
}
/* Título */
.app-alert__title {
font-size: 0.875rem;
font-weight: 600;
margin: 0 0 0.125rem;
line-height: 1.4;
}
.app-alert--info    .app-alert__title { color: var(--info-foreground); }
.app-alert--success .app-alert__title { color: var(--success-foreground); }
.app-alert--warning .app-alert__title { color: var(--warning-foreground); }
.app-alert--danger  .app-alert__title { color: var(--danger-foreground); }
/* Mensaje */
.app-alert__text {
font-size: 0.8125rem;
margin: 0;
line-height: 1.5;
}
.app-alert--info    .app-alert__text { color: var(--info-foreground); }
.app-alert--success .app-alert__text { color: var(--success-foreground); }
.app-alert--warning .app-alert__text { color: var(--warning-foreground); }
.app-alert--danger  .app-alert__text { color: var(--danger-foreground); }
/* ── Control opcional (select / input / botón) ───────────── */
.app-alert__control {
flex-shrink: 0;
order: -1;              /* se muestra antes del ícono y el cuerpo */
}
/* Estilos base para un <select> nativo dentro del control */
.app-alert__control select {
font-size: 0.8125rem;
padding: 0.375rem 0.625rem;
border-radius: 0.4rem;
border: 1px solid var(--border-color);
background: var(--surface-color);
color: var(--text-color);
cursor: pointer;
min-width: 7.5rem;
transition: border-color 0.2s, box-shadow 0.2s;
}
.app-alert__control select:focus {
outline: none;
border-color: var(--focus-color);
box-shadow: 0 0 0 3px var(--focus-ring);
}
/* Colores del select por variante */
.app-alert--info    .app-alert__control select { border-color: var(--info-light);    color: var(--info-foreground); }
.app-alert--success .app-alert__control select { border-color: var(--success-light); color: var(--success-foreground); }
.app-alert--warning .app-alert__control select { border-color: var(--warning-light); color: var(--warning-foreground); }
.app-alert--danger  .app-alert__control select { border-color: var(--danger-light);  color: var(--danger-foreground); }
/* ── Modo oscuro ─────────────────────────────────────────── */
/* Las variables de colors.css ya cambian en dark mode,
por lo que no es necesario sobrescribir reglas adicionales. */
/* ── Responsivo ──────────────────────────────────────────── */
@media (max-width: 480px) {
.app-alert {
gap: 0.625rem;
}
.app-alert__control {
order: 0;
width: 100%;
}
.app-alert__control select {
width: 100%;
min-width: unset;
}
.app-alert__icon {
align-self: flex-start;
margin-top: 2px;
}
}
/* ==============================================
AppCard - Componente de tarjeta moderno
============================================== */
.app-card {
background-color: var(--card-bg-color);
border: 1px solid var(--border-color);
border-radius: 0.875rem;
box-shadow: var(--shadow-sm);
padding: 1.5rem;
margin: 1rem 0;
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
display: flex;
flex-direction: column;
min-width: 0;
position: relative;
overflow: hidden;
}
/* Header del card */
.app-card-header {
margin-bottom: 1.25rem;
padding-bottom: 0.75rem;
border-bottom: 1px solid var(--divider-color);
}
.app-card-header h3 {
margin: 0;
font-size: 1.25rem;
font-weight: 600;
color: var(--text-color);
line-height: 1.5;
}
/* Body del card */
.app-card-body {
flex: 1 1 auto;
color: var(--text-color);
line-height: 1.6;
}
/* Footer del card */
.app-card-footer {
margin-top: 1.25rem;
padding-top: 0.75rem;
border-top: 1px solid var(--divider-color);
display: flex;
gap: 0.75rem;
align-items: center;
flex-wrap: wrap;
}
/* Hover effect - Elevación con borde sutil */
.app-card:hover {
box-shadow: var(--shadow-md);
border-color: var(--card-hover-border);
transform: translateY(-2px);
}
/* ============================================== */
/* Variantes del card */
/* ============================================== */
/* Card interactivo (clickeable) */
.app-card--interactive {
cursor: pointer;
}
.app-card--interactive:hover {
box-shadow: var(--shadow-lg);
border-color: var(--primary-color);
transform: translateY(-4px);
}
.app-card--interactive:active {
transform: translateY(-1px);
box-shadow: var(--shadow-md);
}
/* Card elevado */
.app-card--elevated {
box-shadow: var(--shadow-md);
}
.app-card--elevated:hover {
box-shadow: var(--shadow-lg);
}
/* Card plano */
.app-card--flat {
box-shadow: none;
border: 1px solid var(--border-color);
}
.app-card--flat:hover {
box-shadow: var(--shadow-sm);
}
/* Card con acento superior gradiente */
.app-card--accent-top::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
height: 3px;
background: var(--card-accent-gradient);
border-radius: 0.875rem 0.875rem 0 0;
}
/* Card con acento lateral gradiente */
.app-card--accent-left::before {
content: '';
position: absolute;
top: 0;
left: 0;
bottom: 0;
width: 3px;
background: var(--card-accent-gradient);
border-radius: 0.875rem 0 0 0.875rem;
}
/* ============================================== */
/* Tamaños */
/* ============================================== */
.app-card--compact {
padding: 1rem;
}
.app-card--spacious {
padding: 2rem;
}
/* ============================================== */
/* Estados */
/* ============================================== */
/* Card con foco */
.app-card:focus-within {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
box-shadow: var(--shadow-md), 0 0 0 3px var(--focus-ring);
}
/* Card deshabilitado */
.app-card--disabled {
opacity: 0.6;
pointer-events: none;
background-color: var(--disabled-background);
}
/* ============================================== */
/* Responsive */
/* ============================================== */
@media (max-width: 768px) {
.app-card {
padding: 1rem;
border-radius: 0.75rem;
}
.app-card-header {
margin-bottom: 1rem;
padding-bottom: 0.5rem;
}
.app-card-header h3 {
font-size: 1.125rem;
}
.app-card-footer {
margin-top: 1rem;
padding-top: 0.5rem;
gap: 0.5rem;
}
.app-card--spacious {
padding: 1.25rem;
}
}
.app-carousel {
width: 100%;
max-width: 480px;
margin: 0 auto;
position: relative;
background: var(--surface-color);
border-radius: 0.7rem;
box-shadow: var(--shadow-sm);
overflow: hidden;
}
.app-carousel__viewport {
width: 100%;
min-height: 220px;
display: flex;
align-items: center;
justify-content: center;
}
.app-carousel__slide {
width: 100%;
display: flex;
flex-direction: column;
align-items: center;
}
.app-carousel__image-link, .app-carousel__image {
display: block;
width: 100%;
max-height: 220px;
object-fit: cover;
border-radius: 0.7rem 0.7rem 0 0;
}
.app-carousel__text {
margin-top: 0.7rem;
font-size: 1rem;
color: var(--text-color);
text-align: center;
padding: 0 1rem;
}
.app-carousel__button {
margin-top: 0.6rem;
padding: 0.5rem 1.2rem;
background: var(--primary-color);
color: var(--primary-foreground);
border: none;
border-radius: 0.4rem;
text-decoration: none;
font-size: 1rem;
cursor: pointer;
transition: background 0.2s;
display: inline-block;
}
.app-carousel__button:hover {
background: var(--primary-hover);
}
.app-carousel__controls {
display: flex;
align-items: center;
justify-content: center;
gap: 1.2rem;
padding: 0.5rem 0;
}
.app-carousel__nav {
background: none;
border: none;
font-size: 1.6rem;
color: var(--primary-color);
cursor: pointer;
padding: 0.2rem 0.7rem;
border-radius: 50%;
transition: background 0.2s;
}
.app-carousel__nav:hover {
background: var(--hover-background-color);
}
.app-carousel__indicator {
font-size: 1rem;
color: var(--text-secondary);
}
.app-color-picker { display:flex; flex-direction:column; gap:.4rem; color:var(--text-color); }
.app-color-picker__label{ font-size:.85rem; opacity:.9; }
.app-color-picker__control{ display:flex; align-items:center; gap:.4rem; }
.app-color-picker__input{ flex:1 1 auto; min-width:8rem; padding:.45rem .6rem; border:1px solid var(--border-color); border-radius:.5rem; background:var(--surface-color); color:var(--text-color); outline:none; transition:border-color .2s, box-shadow .2s; }
.app-color-picker__input:focus{ border-color:var(--focus-color); box-shadow:0 0 0 3px var(--focus-ring); }
.app-color-picker__native{ width:2.4rem; height:2.4rem; border:none; background:transparent; padding:0; cursor:pointer; }
.app-color-picker__swatch{ width:2.4rem; height:2.4rem; border:1px solid var(--border-color); border-radius:.4rem; }
.app-color-picker__error{ color:var(--danger-color); font-size:.8rem; }
.app-color-picker--disabled{ opacity:.6; pointer-events:none; }
.app-coordinates-input{ display:flex; flex-direction:column; gap:.5rem; color:var(--text-color); }
.app-coordinates-input__label{ font-size:.9rem; font-weight:600; color:var(--text-muted); }
.app-coordinates-input__grid{ display:grid; grid-template-columns: 1fr 1fr; gap:.6rem; }
.app-coordinates-input__item{ min-width:0; }
.app-coordinates-input--disabled{ opacity:.6; pointer-events:none; }
@media (max-width: 640px){
.app-coordinates-input__grid{ grid-template-columns: 1fr; }
}
/* ========================================================================
AppDateRange Component - Compact Date Range Picker
BEM Prefix: adr
======================================================================== */
/* ========================================================================
Base Container
======================================================================== */
.adr {
position: relative;
width: 100%;
font-family: inherit;
font-size: 0.875rem;
}
.adr--open {
z-index: 1000;
}
/* ========================================================================
Label
======================================================================== */
.adr__label-wrapper {
margin-bottom: 0.375rem;
}
/* ========================================================================
Layout Modes
======================================================================== */
.adr__single {
display: flex;
flex-direction: column;
gap: 0.375rem;
width: 100%;
}
.adr__dual {
display: flex;
flex-direction: column;
gap: 0.625rem;
width: 100%;
}
.adr__field {
display: flex;
flex-direction: column;
gap: 0.375rem;
min-width: 0;
}
/* ========================================================================
Trigger (Input Display)
======================================================================== */
.adr__trigger {
display: flex;
align-items: center;
justify-content: space-between;
gap: 0.5rem;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 0.375rem;
padding: 0.625rem 0.75rem;
cursor: pointer;
transition: all 0.2s ease;
min-height: 2.5rem;
}
.adr__trigger:hover {
border-color: var(--primary-color);
background: var(--hover-background-color);
}
.adr__trigger:focus-within {
border-color: var(--focus-color);
box-shadow: 0 0 0 3px var(--focus-ring);
outline: none;
}
.adr--error .adr__trigger {
border-color: var(--danger-color);
}
.adr--error .adr__trigger:focus-within {
box-shadow: 0 0 0 3px var(--danger-background);
}
.adr__trigger-text {
flex: 1;
min-width: 0;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
color: var(--text-color);
font-size: 0.875rem;
}
.adr__trigger-text:empty::before {
content: attr(data-placeholder);
color: var(--text-muted);
}
.adr__trigger-actions {
display: flex;
align-items: center;
gap: 0.375rem;
flex-shrink: 0;
}
/* ========================================================================
SVG Icons
======================================================================== */
.adr__svg-icon {
width: 1.125rem;
height: 1.125rem;
flex-shrink: 0;
stroke-linecap: round;
stroke-linejoin: round;
}
.adr__icon {
display: flex;
align-items: center;
justify-content: center;
color: var(--text-secondary);
}
/* ========================================================================
Buttons
======================================================================== */
.adr__btn {
display: inline-flex;
align-items: center;
justify-content: center;
border: none;
border-radius: 0.25rem;
font-family: inherit;
font-size: 0.8125rem;
font-weight: 500;
cursor: pointer;
transition: all 0.2s ease;
white-space: nowrap;
user-select: none;
padding: 0.375rem 0.625rem;
line-height: 1.2;
gap: 0.25rem;
}
.adr__btn:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
.adr__btn:disabled {
opacity: 0.5;
cursor: not-allowed;
pointer-events: none;
}
.adr__btn--clear {
background: transparent;
color: var(--danger-color);
padding: 0.25rem 0.375rem;
}
.adr__btn--clear:hover {
background: var(--danger-background);
}
.adr__btn--clear .adr__svg-icon {
width: 1rem;
height: 1rem;
}
.adr__btn--ghost {
background: transparent;
color: var(--text-secondary);
border: 1px solid var(--border-color);
}
.adr__btn--ghost:hover {
background: var(--hover-background-color);
border-color: var(--text-muted);
}
.adr__btn--primary {
background: var(--primary-color);
color: var(--text-light);
}
.adr__btn--primary:hover {
background: var(--primary-hover);
}
/* ========================================================================
Error Messages
======================================================================== */
.adr__error {
margin-top: 0.375rem;
font-size: 0.75rem;
color: var(--danger-color);
line-height: 1.4;
}
/* ========================================================================
Backdrop & Panel - CENTRADO EN PANTALLA
======================================================================== */
.adr__backdrop {
position: fixed;
inset: 0;
background: var(--overlay-color);
backdrop-filter: blur(2px);
z-index: 999;
animation: adr-fade-in 0.2s ease-out;
display: flex;
align-items: center;
justify-content: center;
padding: 1rem;
}
.adr__panel {
position: relative;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 0.5rem;
box-shadow: var(--shadow-xl);
padding: 1rem;
z-index: 1000;
min-width: 280px;
max-width: min(600px, 100%);
max-height: calc(100vh - 2rem);
overflow-y: auto;
animation: adr-scale-in 0.2s ease-out;
}
@keyframes adr-fade-in {
from { opacity: 0; }
to { opacity: 1; }
}
@keyframes adr-scale-in {
from {
opacity: 0;
transform: scale(0.95);
}
to {
opacity: 1;
transform: scale(1);
}
}
/* ========================================================================
Panel Header
======================================================================== */
.adr__header {
display: flex;
justify-content: space-between;
align-items: center;
gap: 0.625rem;
margin-bottom: 0.875rem;
padding-bottom: 0.625rem;
border-bottom: 1px solid var(--border-color);
flex-wrap: wrap;
}
.adr__nav {
display: flex;
gap: 0.375rem;
flex-shrink: 0;
}
.adr__nav-btn {
display: inline-flex;
align-items: center;
justify-content: center;
width: 2rem;
height: 2rem;
border: 1px solid var(--border-color);
border-radius: 0.25rem;
background: var(--surface-alt-color);
color: var(--text-color);
cursor: pointer;
transition: all 0.2s ease;
}
.adr__nav-btn:hover {
background: var(--primary-color);
color: var(--text-light);
border-color: var(--primary-color);
}
.adr__nav-btn .adr__svg-icon {
width: 1rem;
height: 1rem;
}
.adr__actions {
display: flex;
gap: 0.375rem;
flex-shrink: 0;
}
/* ========================================================================
Calendars Layout
======================================================================== */
.adr__calendars {
display: flex;
gap: 0.875rem;
flex-wrap: wrap;
justify-content: center;
}
.adr__calendar {
display: flex;
flex-direction: column;
gap: 0.5rem;
flex: 0 0 auto;
min-width: 240px;
}
.adr__month {
font-size: 0.875rem;
font-weight: 600;
color: var(--primary-color);
text-align: center;
text-transform: capitalize;
padding: 0.25rem 0;
}
/* ========================================================================
Calendar Grid
======================================================================== */
.adr__grid {
display: grid;
grid-template-columns: repeat(7, 1fr);
gap: 2px;
}
.adr__weekday {
display: flex;
align-items: center;
justify-content: center;
padding: 0.375rem 0.25rem;
font-size: 0.6875rem;
font-weight: 600;
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: 0.03em;
}
/* ========================================================================
Day Cells
======================================================================== */
.adr__day {
display: flex;
align-items: center;
justify-content: center;
min-height: 2rem;
aspect-ratio: 1;
border: none;
border-radius: 0.25rem;
background: transparent;
color: var(--text-color);
font-size: 0.8125rem;
font-weight: 500;
cursor: pointer;
transition: all 0.15s ease;
user-select: none;
padding: 0.25rem;
}
.adr__day:not(.adr__day--disabled):not(.adr__day--empty):hover {
background: var(--hover-background-color);
color: var(--primary-color);
font-weight: 600;
transform: scale(1.05);
}
.adr__day--empty {
cursor: default;
pointer-events: none;
}
.adr__day--disabled {
opacity: 0.3;
cursor: not-allowed;
pointer-events: none;
}
.adr__day--today {
font-weight: 700;
box-shadow: inset 0 0 0 2px var(--info-color);
}
.adr__day--start,
.adr__day--end {
background: var(--primary-color);
color: var(--text-light);
font-weight: 600;
}
.adr__day--start:hover,
.adr__day--end:hover {
background: var(--primary-hover);
color: var(--text-light);
}
.adr__day--in-range {
background: var(--primary-light);
color: var(--text-light);
opacity: 0.7;
}
.adr__day--hover {
background: var(--primary-light);
color: var(--text-light);
opacity: 0.5;
}
/* ========================================================================
Panel Error
======================================================================== */
.adr__panel-error {
display: flex;
align-items: center;
gap: 0.5rem;
margin-top: 0.625rem;
padding: 0.625rem 0.75rem;
background: var(--danger-background);
border: 1px solid var(--danger-color);
border-radius: 0.375rem;
color: var(--danger-color);
font-size: 0.8125rem;
line-height: 1.4;
}
.adr__panel-error .adr__svg-icon {
width: 1.125rem;
height: 1.125rem;
flex-shrink: 0;
}
/* ========================================================================
Responsive - Tablet
======================================================================== */
@media (max-width: 768px) {
.adr__calendars {
flex-direction: column;
gap: 0.875rem;
}
.adr__calendar {
min-width: 100%;
}
.adr__header {
flex-direction: column;
align-items: stretch;
}
.adr__nav {
justify-content: center;
}
.adr__actions {
width: 100%;
}
.adr__actions .adr__btn {
flex: 1;
}
}
/* ========================================================================
Responsive - Mobile
======================================================================== */
@media (max-width: 640px) {
.adr__backdrop {
padding: 0.75rem;
}
.adr__panel {
padding: 0.875rem;
max-height: calc(100vh - 1.5rem);
}
.adr__calendars {
flex-direction: column;
}
.adr__calendar {
min-width: 100%;
}
.adr__day {
min-height: 2.25rem;
font-size: 0.875rem;
}
.adr__weekday {
font-size: 0.6875rem;
padding: 0.375rem 0.25rem;
}
}
/* ========================================================================
Print Styles
======================================================================== */
@media print {
.adr__backdrop,
.adr__panel {
display: none;
}
}
/* ========================================================================
Accessibility
======================================================================== */
.adr__btn:focus-visible,
.adr__day:focus-visible,
.adr__nav-btn:focus-visible,
.adr__trigger:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
@media (prefers-reduced-motion: reduce) {
.adr__btn,
.adr__day,
.adr__trigger,
.adr__nav-btn,
.adr__backdrop,
.adr__panel {
animation: none;
transition: none;
}
}
@media (prefers-contrast: high) {
.adr__trigger {
border-width: 2px;
}
.adr__day--start,
.adr__day--end {
outline: 2px solid currentColor;
outline-offset: -2px;
}
}
/* ========================================================================
Scrollbar personalizado para el panel
======================================================================== */
.adr__panel::-webkit-scrollbar {
width: 6px;
}
.adr__panel::-webkit-scrollbar-track {
background: var(--surface-alt-color);
border-radius: 3px;
}
.adr__panel::-webkit-scrollbar-thumb {
background: var(--border-color);
border-radius: 3px;
}
.adr__panel::-webkit-scrollbar-thumb:hover {
background: var(--text-muted);
}
.app-event-cats{ padding:1rem; }
.app-event-cats__header{ display:flex; align-items:center; justify-content:space-between; }
.app-event-cats__actions{ margin:.5rem 0; }
.app-event-cats__list{ display:flex; flex-direction:column; gap:1rem; }
.app-event-cats__item{ border:1px solid var(--border-color); border-radius:.5rem; padding:.75rem; }
.cat-form{ display:grid; grid-template-columns: repeat(6, minmax(0,1fr)); gap:.5rem; }
.cat-actions{ display:flex; gap:.5rem; align-items:center; }
.input{ width:100%; padding:.35rem .5rem; border:1px solid var(--border-color); border-radius:.35rem; }
.fees{ margin-top:.75rem; }
.fees__new{ margin:.5rem 0; }
.fee-form{ display:grid; grid-template-columns: repeat(5, minmax(0,1fr)); gap:.5rem; }
.fees-table{ width:100%; border-collapse:collapse; }
.fees-table th,.fees-table td{ border:1px solid var(--border-color); padding:.35rem .5rem; text-align:left; }
.btn{ padding:.35rem .6rem; border:1px solid var(--border-color); background:var(--surface-color); border-radius:.35rem; cursor:pointer; }
.btn--primary{ background:var(--primary-color);color:var(--primary-foreground);border-color:var(--primary-dark); }
.btn--danger{ background:var(--danger-color);color:var(--danger-foreground);border-color:var(--danger-dark); }
.btn--ghost{ background:transparent; }
.error{ color:var(--danger-color); }
.app-event-images-editor{ padding:1rem; }
.app-event-images-editor__header{ display:flex; align-items:center; justify-content:space-between; margin-bottom:1rem; }
.app-event-images-editor__close{ border:1px solid var(--border-color); background:transparent; border-radius:.4rem; width:2rem; height:2rem; cursor:pointer; }
.app-event-images-editor__grid{ display:grid; grid-template-columns: 1fr 1fr; gap:1rem; }
.app-event-images-editor__block{ border:1px dashed var(--border-color); border-radius:.5rem; padding:1rem; }
.app-event-images-editor__preview{ width:100%; aspect-ratio: 1920 / 480; background:var(--surface-alt-color); border:1px solid var(--border-color); border-radius:.5rem; display:grid; place-items:center; overflow:hidden; }
.app-event-images-editor__preview--poster{ aspect-ratio: 612 / 900; }
.app-event-images-editor__preview img{ width:100%; height:100%; object-fit:cover; display:block; }
.app-event-images-editor__placeholder{ color:var(--text-muted); font-size:.9rem; }
.app-event-images-editor__actions{ margin-top:.5rem; display:flex; gap:.5rem; }
.btn{ padding:.45rem .75rem; border:1px solid var(--border-color); background:var(--surface-color); border-radius:.4rem; cursor:pointer; }
.btn--primary{ background:var(--primary-color); color:var(--primary-foreground); border-color:var(--primary-dark); }
.app-event-images-editor__error{ margin-top:.35rem; color:var(--danger-color); font-size:.85rem; }
@media (max-width: 760px){
.app-event-images-editor__grid{ grid-template-columns: 1fr; }
}
/* ==============================================
AppListado — Componente de listado genérico
Metodología BEM
============================================== */
.app-listado {
width: 100%;
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.app-listado__content {
display: flex;
flex-direction: column;
gap: 0.5rem;
width: 100%;
animation: listado-fade-in 0.25s ease-out both;
}
.app-listado__state {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 0.875rem;
padding: 3.5rem 1.5rem;
width: 100%;
border-radius: 0.875rem;
background-color: var(--card-bg-color);
text-align: center;
animation: listado-fade-in 0.3s ease-out both;
}
.app-listado__state--empty {
border: 1.5px dashed var(--border-color);
}
.app-listado__state--loading {
border: 1.5px solid var(--border-color);
box-shadow: var(--shadow-sm);
}
.app-listado__pagination {
display: flex;
justify-content: flex-start;
align-items: flex-start;
padding-left: .7rem;
}
.app-listado__state-icon {
display: flex;
align-items: center;
justify-content: center;
width: 3.5rem;
height: 3.5rem;
border-radius: 50%;
font-size: 1.75rem;
line-height: 1;
background-color: var(--bg-secondary, rgba(0, 0, 0, 0.04));
color: var(--text-muted, #9ca3af);
flex-shrink: 0;
transition: background-color 0.3s ease;
}
.app-listado__state--empty .app-listado__state-icon {
background-color: var(--warning-bg, rgba(251, 191, 36, 0.12));
color: var(--warning-color, #f59e0b);
}
.app-listado__state--loading .app-listado__state-icon {
background-color: var(--primary-bg, rgba(99, 102, 241, 0.1));
color: var(--primary-color, #6366f1);
animation: listado-pulse 1.4s ease-in-out infinite;
}
.app-listado__state-text {
margin: 0;
font-size: 0.9375rem;
font-weight: 500;
color: var(--text-muted, #6b7280);
line-height: 1.5;
}
@keyframes listado-fade-in {
from {
opacity: 0;
transform: translateY(6px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
@keyframes listado-pulse {
0%, 100% {
opacity: 1;
transform: scale(1);
}
50% {
opacity: 0.6;
transform: scale(0.92);
}
}
@media (prefers-reduced-motion: reduce) {
.app-listado__content,
.app-listado__state {
animation: none;
}
.app-listado__state--loading .app-listado__state-icon {
animation: none;
}
}
/* ==============================================
AppModal - Componente de modal moderno y responsivo
============================================== */
.app-modal {
position: fixed;
inset: 0;
z-index: 1000;
display: flex;
align-items: center;
justify-content: center;
padding: 0.5rem;
animation: app-modal-fade-in 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes app-modal-fade-in {
from {
opacity: 0;
}
to {
opacity: 1;
}
}
/* Overlay con blur moderno */
.app-modal__overlay {
position: absolute;
inset: 0;
background: var(--overlay-color);
backdrop-filter: blur(8px) saturate(180%);
-webkit-backdrop-filter: blur(8px) saturate(180%);
animation: app-modal-overlay-fade-in 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes app-modal-overlay-fade-in {
from {
opacity: 0;
backdrop-filter: blur(0);
}
to {
opacity: 1;
backdrop-filter: blur(8px);
}
}
/* Dialog principal - Responsivo por defecto */
.app-modal__dialog {
position: relative;
background: var(--surface-color);
color: var(--text-color);
border-radius: 1.125rem;
border: 1px solid var(--border-color);
width: 100%;
max-width: 500px;
max-height: 90vh;
overflow: hidden;
display: flex;
flex-direction: column;
box-shadow: var(--shadow-xl);
animation: app-modal-dialog-scale-in 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes app-modal-dialog-scale-in {
from {
opacity: 0;
transform: scale(0.95) translateY(20px);
}
to {
opacity: 1;
transform: scale(1) translateY(0);
}
}
/* Variantes de ancho - Responsivas */
.app-modal__dialog--wide {
max-width: 920px;
}
.app-modal__dialog--narrow {
max-width: 420px;
}
.app-modal__dialog--full {
max-width: 1280px;
}
/* ✅ Nueva variante xlarge para vista previa de PDF */
.app-modal__dialog--xlarge {
max-width: 1600px;
width: 95vw;
}
/* Header */
.app-modal__header {
position: sticky;
top: 0;
background: var(--surface-color);
z-index: 10;
display: flex;
align-items: center;
justify-content: space-between;
gap: 0.75rem;
padding: 1rem 1.25rem;
border-bottom: 1px solid var(--divider-color);
flex-shrink: 0;
}
.app-modal__title {
margin: 0;
font-size: 1.25rem;
font-weight: 600;
color: var(--text-color);
line-height: 1.4;
word-break: break-word;
}
/* Botón de cerrar */
.app-modal__close-btn,
.app-modal__close {
background: transparent;
border: none;
color: var(--text-muted);
width: 2.5rem;
height: 2.5rem;
min-width: 2.5rem;
border-radius: 0.5rem;
display: inline-flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
flex-shrink: 0;
}
.app-modal__close-icon {
width: 1.25rem;
height: 1.25rem;
fill: currentColor;
color: inherit;
}
.app-modal__close-icon path {
fill: currentColor;
}
.app-modal__close-btn:hover,
.app-modal__close:hover {
background: var(--hover-background-color);
color: var(--text-color);
}
.app-modal__close-btn:focus,
.app-modal__close:focus {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
box-shadow: 0 0 0 3px var(--focus-ring);
color: var(--text-color);
}
.app-modal__close-btn:active,
.app-modal__close:active {
transform: scale(0.95);
background: var(--secondary-background);
}
/* Content */
.app-modal__content {
padding: 1.25rem;
flex: 1 1 auto;
overflow-y: auto;
overflow-x: hidden;
color: var(--text-color);
line-height: 1.6;
}
/* Scrollbar personalizado para el contenido */
.app-modal__content::-webkit-scrollbar {
width: 8px;
}
.app-modal__content::-webkit-scrollbar-track {
background: transparent;
}
.app-modal__content::-webkit-scrollbar-thumb {
background: var(--border-color);
border-radius: 4px;
}
.app-modal__content::-webkit-scrollbar-thumb:hover {
background: var(--text-muted);
}
/* Footer */
.app-modal__footer {
position: sticky;
bottom: 0;
background: var(--surface-color);
display: flex;
justify-content: flex-end;
align-items: center;
gap: 0.75rem;
padding: 1rem 1.25rem;
border-top: 1px solid var(--divider-color);
flex-shrink: 0;
}
.app-modal__footer--start {
justify-content: flex-start;
}
.app-modal__footer--center {
justify-content: center;
}
.app-modal__footer--space-between {
justify-content: space-between;
}
/* ============================================== */
/* Responsive - Móvil muy pequeño (420px-479px)  */
/* ============================================== */
@media (min-width: 420px) and (max-width: 479px) {
.app-modal {
padding: 0.375rem;
}
.app-modal__dialog {
max-width: 100%;
max-height: 92vh;
border-radius: 0.75rem;
}
.app-modal__dialog--wide,
.app-modal__dialog--full {
max-width: 100%;
}
.app-modal__header {
padding: 0.875rem 1rem;
gap: 0.5rem;
}
.app-modal__title {
font-size: 1rem;
}
.app-modal__close-btn,
.app-modal__close {
width: 2.25rem;
height: 2.25rem;
min-width: 2.25rem;
}
.app-modal__content {
padding: 1rem;
}
.app-modal__footer {
padding: 0.875rem 1rem;
gap: 0.5rem;
}
}
/* ============================================== */
/* Responsive - Móvil pequeño (480px-639px)      */
/* ============================================== */
@media (min-width: 480px) and (max-width: 639px) {
.app-modal {
padding: 0.5rem;
}
.app-modal__dialog {
max-width: 100%;
max-height: 92vh;
border-radius: 0.75rem;
}
.app-modal__dialog--wide,
.app-modal__dialog--full {
max-width: 100%;
}
.app-modal__header {
padding: 0.875rem 1rem;
}
.app-modal__title {
font-size: 1.0625rem;
}
.app-modal__content {
padding: 1rem;
}
.app-modal__footer {
padding: 0.875rem 1rem;
gap: 0.5rem;
}
}
/* ============================================== */
/* Responsive - Tablet (640px - 1024px)          */
/* ============================================== */
@media (min-width: 640px) and (max-width: 1024px) {
.app-modal {
padding: 0.75rem;
}
.app-modal__dialog {
max-width: 680px;
}
.app-modal__dialog--wide {
max-width: 85vw;
}
.app-modal__dialog--full,
.app-modal__dialog--xlarge {
max-width: 92vw;
width: 92vw;
}
.app-modal__header {
padding: 1rem 1.25rem;
}
.app-modal__title {
font-size: 1.125rem;
}
.app-modal__content {
padding: 1.25rem;
}
.app-modal__footer {
padding: 1rem 1.25rem;
}
}
/* ============================================== */
/* Responsive - Desktop (1025px+)                */
/* ============================================== */
@media (min-width: 1025px) {
.app-modal {
padding: 1rem;
}
.app-modal__dialog {
max-width: 580px;
}
.app-modal__dialog--wide {
max-width: min(920px, 85vw);
}
.app-modal__dialog--full {
max-width: min(1280px, 90vw);
}
/* ✅ xlarge para pantallas grandes */
.app-modal__dialog--xlarge {
max-width: min(1600px, 95vw);
width: 95vw;
}
.app-modal__content {
padding: 1.5rem;
}
.app-modal__header {
padding: 1.25rem 1.5rem;
}
.app-modal__title {
font-size: 1.375rem;
}
.app-modal__footer {
padding: 1.25rem 1.5rem;
}
}
/* ============================================== */
/* Responsive - Pantallas muy pequeñas (<420px)  */
/* ============================================== */
@media (max-width: 419px) {
.app-modal {
padding: 0;
}
.app-modal__dialog {
width: 100vw;
max-width: 100vw;
max-height: 100vh;
border-radius: 0;
border: none;
border-left: none;
border-right: none;
}
.app-modal__dialog--wide,
.app-modal__dialog--narrow,
.app-modal__dialog--full {
width: 100vw;
max-width: 100vw;
}
.app-modal__header {
padding: 0.75rem;
gap: 0.5rem;
}
.app-modal__title {
font-size: 0.9375rem;
line-height: 1.3;
}
.app-modal__close-btn,
.app-modal__close {
width: 2rem;
height: 2rem;
min-width: 2rem;
}
.app-modal__close-icon {
width: 1rem;
height: 1rem;
}
.app-modal__content {
padding: 0.75rem;
}
.app-modal__footer {
padding: 0.75rem;
flex-wrap: wrap;
gap: 0.5rem;
}
}
/* ==============================================
AppPagination - Componente de paginación moderno
============================================== */
.app-pagination {
display: flex;
align-items: center;
gap: 0.5rem;
justify-content: center;
margin: 1.5rem 0 1rem 0;
flex-wrap: wrap;
}
/* Botones de navegación */
.app-pagination__nav-button {
background: var(--surface-color);
color: var(--primary-color);
border: 1px solid var(--border-color);
border-radius: 0.5rem;
padding: 0.5rem 1rem;
font-size: 0.9375rem;
font-weight: 500;
cursor: pointer;
transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
min-width: 2.5rem;
min-height: 2.5rem;
display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.375rem;
box-shadow: var(--shadow-xs);
}
.app-pagination__nav-button:hover:not(:disabled) {
background: var(--primary-color);
color: var(--text-light);
border-color: var(--primary-color);
box-shadow: var(--shadow-sm);
transform: translateY(-1px);
}
.app-pagination__nav-button:active:not(:disabled) {
transform: translateY(0);
box-shadow: var(--shadow-xs);
}
.app-pagination__nav-button:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
box-shadow: 0 0 0 3px var(--focus-ring);
}
.app-pagination__nav-button:disabled {
background: var(--disabled-background);
color: var(--disabled-color);
border-color: var(--border-color);
cursor: not-allowed;
opacity: 0.5;
box-shadow: none;
}
/* Información de página actual */
.app-pagination__page-info {
font-weight: 600;
color: var(--text-color);
min-width: 4rem;
text-align: center;
padding: 0 0.5rem;
font-size: 0.9375rem;
}
.app-pagination__page-info .app-pagination__current-page {
color: var(--primary-color);
font-weight: 700;
font-size: 1.125rem;
}
/* Resumen de paginación */
.app-pagination__summary {
text-align: center;
color: var(--text-muted);
font-size: 0.875rem;
margin-top: 0.5rem;
width: 100%;
line-height: 1.5;
}
/* ============================================== */
/* Variante con números de página */
/* ============================================== */
.app-pagination--numbered {
gap: 0.375rem;
}
.app-pagination__page-button {
background: var(--surface-color);
color: var(--text-color);
border: 1px solid var(--border-color);
border-radius: 0.5rem;
padding: 0.5rem 0.75rem;
font-size: 0.9375rem;
font-weight: 500;
cursor: pointer;
transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
min-width: 2.5rem;
min-height: 2.5rem;
display: inline-flex;
align-items: center;
justify-content: center;
box-shadow: var(--shadow-xs);
}
.app-pagination__page-button:hover:not(.app-pagination__page-button--active) {
background: var(--hover-background-color);
border-color: var(--primary-color);
color: var(--primary-color);
box-shadow: var(--shadow-sm);
}
.app-pagination__page-button--active {
background: var(--primary-color);
color: var(--text-light);
border-color: var(--primary-color);
font-weight: 700;
box-shadow: var(--shadow-sm);
pointer-events: none;
}
.app-pagination__page-button--dots {
pointer-events: none;
border: none;
box-shadow: none;
background: transparent;
color: var(--text-muted);
}
/* ============================================== */
/* Tamaños */
/* ============================================== */
.app-pagination--sm .app-pagination__nav-button,
.app-pagination--sm .app-pagination__page-button {
padding: 0.375rem 0.625rem;
font-size: 0.875rem;
min-width: 2rem;
min-height: 2rem;
}
.app-pagination--lg .app-pagination__nav-button,
.app-pagination--lg .app-pagination__page-button {
padding: 0.625rem 1.25rem;
font-size: 1rem;
min-width: 3rem;
min-height: 3rem;
}
/* ============================================== */
/* Responsive */
/* ============================================== */
@media (max-width: 768px) {
.app-pagination {
font-size: 0.875rem;
gap: 0.375rem;
margin: 1rem 0 0.75rem 0;
}
.app-pagination__nav-button,
.app-pagination__page-button {
padding: 0.4rem 0.75rem;
font-size: 0.875rem;
min-width: 2.25rem;
min-height: 2.25rem;
}
.app-pagination__page-info {
font-size: 0.875rem;
min-width: 3rem;
}
.app-pagination__summary {
font-size: 0.8125rem;
margin-top: 0.375rem;
}
}
@media (max-width: 480px) {
.app-pagination__nav-button,
.app-pagination__page-button {
padding: 0.375rem 0.625rem;
min-width: 2rem;
min-height: 2rem;
}
/* Ocultar números intermedios en móviles */
.app-pagination__page-button:not(.app-pagination__page-button--active):not(:first-of-type):not(:last-of-type) {
display: none;
}
}
/* Componente de Resultado de Pago con Animaci�n */
.app-payment-result {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
z-index: 10000;
display: flex;
align-items: center;
justify-content: center;
opacity: 0;
visibility: hidden;
transition: opacity 0.3s ease, visibility 0.3s ease;
}
.app-payment-result--visible {
opacity: 1;
visibility: visible;
}
.app-payment-result__overlay {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: var(--overlay-color);
backdrop-filter: blur(4px);
}
.app-payment-result__card {
position: relative;
z-index: 1;
background: var(--card-bg-color);
border-radius: 16px;
padding: 3rem;
box-shadow: var(--shadow-xl);
animation: scaleIn 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
display: flex;
flex-direction: column;
align-items: center;
gap: 1.5rem;
max-width: 480px;
}
@keyframes scaleIn {
from {
transform: scale(0.5);
opacity: 0;
}
to {
transform: scale(1);
opacity: 1;
}
}
.app-payment-result__icon {
width: 120px;
height: 120px;
margin: 0 auto;
flex-shrink: 0;
}
/* Textos del resultado */
.app-payment-result__title {
font-size: 1.75rem;
font-weight: 700;
color: var(--text-color);
text-align: center;
margin: 0;
line-height: 1.3;
}
.app-payment-result__message {
font-size: 1.125rem;
font-weight: 400;
color: var(--text-muted);
text-align: center;
margin: 0;
line-height: 1.5;
}
/* Animaci�n de �xito (Checkmark) */
.app-payment-result__checkmark {
width: 120px;
height: 120px;
border-radius: 50%;
display: block;
stroke-width: 2;
stroke: var(--success-color);
stroke-miterlimit: 10;
}
.app-payment-result__checkmark-circle {
stroke-dasharray: 166;
stroke-dashoffset: 166;
stroke-width: 2;
stroke-miterlimit: 10;
stroke: var(--success-color);
fill: none;
animation: stroke 0.6s cubic-bezier(0.65, 0, 0.45, 1) forwards;
}
.app-payment-result__checkmark-check {
transform-origin: 50% 50%;
stroke-dasharray: 48;
stroke-dashoffset: 48;
animation: stroke 0.3s cubic-bezier(0.65, 0, 0.45, 1) 0.6s forwards;
}
@keyframes stroke {
100% {
stroke-dashoffset: 0;
}
}
/* Animaci�n de Error (Cross) */
.app-payment-result__cross {
width: 120px;
height: 120px;
border-radius: 50%;
display: block;
stroke-width: 2;
stroke: var(--danger-color);
stroke-miterlimit: 10;
}
.app-payment-result__cross-circle {
stroke-dasharray: 166;
stroke-dashoffset: 166;
stroke-width: 2;
stroke-miterlimit: 10;
stroke: var(--danger-color);
fill: none;
animation: stroke 0.6s cubic-bezier(0.65, 0, 0.45, 1) forwards;
}
.app-payment-result__cross-line {
stroke-dasharray: 28;
stroke-dashoffset: 28;
animation: stroke 0.3s cubic-bezier(0.65, 0, 0.45, 1) 0.6s forwards;
}
/* Responsive */
@media (max-width: 640px) {
.app-payment-result__card {
padding: 2rem;
max-width: 90vw;
}
.app-payment-result__icon {
width: 100px;
height: 100px;
}
.app-payment-result__checkmark,
.app-payment-result__cross {
width: 100px;
height: 100px;
}
.app-payment-result__title {
font-size: 1.5rem;
}
.app-payment-result__message {
font-size: 1rem;
}
}
.payment-selector__list {
display: flex;
gap: 1.5rem;
flex-wrap: wrap;
margin-bottom: 1.5rem;
justify-content: center;
}
.payment-selector__card {
background: var(--surface-color);
border: 2px solid var(--border-color);
border-radius: 12px;
box-shadow: var(--shadow-sm);
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 0.7rem;
padding: 1.2rem 1.2rem;
cursor: pointer;
transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
min-width: 220px;
max-width: 260px;
width: 100%;
position: relative;
height: 220px;
}
.payment-selector__card--selected {
border-color: var(--primary-color);
background: var(--hover-background-color);
box-shadow: var(--shadow-md);
}
.payment-selector__logo {
width: 48px;
height: 48px;
object-fit: contain;
margin-bottom: 0.5rem;
}
.payment-selector__info {
text-align: center;
}
.payment-selector__name {
font-size: 1.1rem;
font-weight: 700;
color: var(--primary-color);
}
.payment-selector__desc {
font-size: 0.98rem;
color: var(--text-muted);
}
.payment-selector__badge {
position: absolute;
top: 10px;
right: 14px;
background: var(--primary-color);
color: var(--primary-foreground);
font-size: 1.2rem;
border-radius: 50%;
padding: 0.2rem 0.5rem;
font-weight: bold;
box-shadow: var(--shadow-sm);
}
.payment-selector__not-available {
position: absolute;
top: 8px;
left: 12px;
background: var(--danger-color);
color: var(--danger-foreground);
font-size: 0.9rem;
padding: 0.2rem 0.6rem;
border-radius: 6px;
font-weight: 600;
}
.payment-selector__confirmation {
margin: 1rem 0 0.5rem 0;
font-size: 1.05rem;
color: var(--primary-color);
text-align: center;
}
.payment-selector__summary {
margin: 1.2rem 0;
padding: 0.8rem 1.2rem;
background: var(--surface-alt-color);
border-radius: 8px;
box-shadow: var(--shadow-sm);
}
.payment-selector__summary-details {
display: flex;
flex-direction: column;
gap: 0.3rem;
font-size: 1rem;
color: var(--primary-color);
}
.payment-selector__total {
font-size: 1.15rem;
color: var(--success-color);
font-weight: bold;
}
.payment-selector__continue {
text-align: right;
margin-top: 1.2rem;
}
@media (max-width: 700px) {
.payment-selector__list {
flex-direction: column;
gap: 1rem;
}
.payment-selector__card {
min-width: unset;
max-width: unset;
width: 100%;
height: 180px;
}
}
.app-progress-bar {
width: 100%;
max-width: 400px;
margin: 0.5rem 0;
}
.app-progress-bar__track {
width: 100%;
height: 1.2rem;
background: var(--surface-alt-color);
border-radius: 0.6rem;
overflow: hidden;
box-shadow: var(--shadow-xs);
position: relative;
}
.app-progress-bar__fill {
height: 100%;
background: var(--primary-color);
border-radius: 0.6rem 0 0 0.6rem;
transition: width 0.4s cubic-bezier(.4,1,.7,1);
}
/* Clases de anchura en múltiplos de 5% */
.app-progress-bar__fill--w0 { width: 0%; }
.app-progress-bar__fill--w5 { width: 5%; }
.app-progress-bar__fill--w10 { width: 10%; }
.app-progress-bar__fill--w15 { width: 15%; }
.app-progress-bar__fill--w20 { width: 20%; }
.app-progress-bar__fill--w25 { width: 25%; }
.app-progress-bar__fill--w30 { width: 30%; }
.app-progress-bar__fill--w35 { width: 35%; }
.app-progress-bar__fill--w40 { width: 40%; }
.app-progress-bar__fill--w45 { width: 45%; }
.app-progress-bar__fill--w50 { width: 50%; }
.app-progress-bar__fill--w55 { width: 55%; }
.app-progress-bar__fill--w60 { width: 60%; }
.app-progress-bar__fill--w65 { width: 65%; }
.app-progress-bar__fill--w70 { width: 70%; }
.app-progress-bar__fill--w75 { width: 75%; }
.app-progress-bar__fill--w80 { width: 80%; }
.app-progress-bar__fill--w85 { width: 85%; }
.app-progress-bar__fill--w90 { width: 90%; }
.app-progress-bar__fill--w95 { width: 95%; }
.app-progress-bar__fill--w100 { width: 100%; }
.app-progress-bar__fill--animated {
position: absolute;
left: 0;
top: 0;
height: 100%;
width: 30%;
min-width: 60px;
max-width: 100%;
background: var(--primary-color);
border-radius: 0.6rem;
animation: app-progress-bar-animated 1.2s infinite linear;
}
@keyframes app-progress-bar-animated {
0% {
left: -30%;
width: 30%;
}
50% {
left: 35%;
width: 40%;
}
100% {
left: 100%;
width: 30%;
}
}
.app-progress-bar__label {
margin-top: 0.3rem;
font-size: 0.98rem;
color: var(--text-color);
text-align: right;
font-weight: 500;
}
.app-spinner {
display: flex;
align-items: center;
justify-content: center;
width: 100%;
height: 100%;
}
.loader {
display: inline-flex;
align-items: center;
justify-content: center;
}
.loader--lg {
gap: 14px;
}
.loader--md {
gap: 10px;
}
.loader__dot {
border-radius: 50%;
background: var(--loader-dot-color, var(--primary-color));
animation: loader-pulse 1.2s ease-in-out infinite;
}
.loader--lg .loader__dot {
width: 16px;
height: 16px;
}
.loader--md .loader__dot {
width: 10px;
height: 10px;
}
.loader__dot--1 { animation-delay: 0s;   }
.loader__dot--2 { animation-delay: 0.2s; }
.loader__dot--3 { animation-delay: 0.4s; }
@media (prefers-reduced-motion: reduce) {
.loader__dot { animation-duration: 3s; }
}
@keyframes loader-pulse {
0%, 80%, 100% {
transform: scale(0.55);
opacity: 0.35;
}
40% {
transform: scale(1);
opacity: 1;
}
}
.app-steps {
position: relative;
display: flex;
align-items: flex-start;
justify-content: space-between;
width: 100%;
padding: 0.25rem 0 1.5rem;
box-sizing: border-box;
overflow-x: auto;
scrollbar-width: none;
}
.app-steps::-webkit-scrollbar { display: none; }
.app-steps__track {
position: absolute;
top: 1.125rem;
left:  2rem;
right: 2rem;
height: 3px;
background: var(--border-color);
border-radius: 999px;
overflow: hidden;
z-index: 0;
}
/* Relleno animado del track */
.app-steps__track-fill {
height: 100%;
background: linear-gradient(90deg, var(--primary-color), var(--accent-color));
border-radius: 999px;
transition: width 0.45s cubic-bezier(0.4, 0, 0.2, 1);
}
/* ── Item (paso individual) ───────────────────────────────── */
.app-steps__item {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.5rem;
flex: 1;
min-width: 0;
position: relative;
z-index: 1;
cursor: default;
}
/* ── Burbuja ──────────────────────────────────────────────── */
.app-steps__bubble {
width: 2.25rem;
height: 2.25rem;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
font-weight: 700;
font-size: 0.9rem;
transition:
background   0.3s ease,
border-color 0.3s ease,
color        0.3s ease,
box-shadow   0.3s ease,
transform    0.25s cubic-bezier(0.4, 1.4, 0.6, 1);
/* estado pendiente (default) */
background:    var(--surface-color);
border:        2px solid var(--border-color);
color:         var(--text-muted);
box-shadow:    none;
}
/* ── Estados ──────────────────────────────────────────────── */
/* Completado */
.app-steps__item--completed .app-steps__bubble {
background:    var(--success-color);
border-color:  var(--success-color);
color:         #ffffff;
box-shadow:    0 0 0 4px var(--success-background);
transform:     scale(1.05);
}
/* Activo */
.app-steps__item--active .app-steps__bubble {
background:    var(--primary-color);
border-color:  var(--primary-color);
color:         var(--primary-foreground);
box-shadow:    0 0 0 4px rgba(var(--primary-color), 0.15),
var(--shadow-md);
transform:     scale(1.12);
animation:     app-steps-pulse 2.2s ease-in-out infinite;
}
/* Pendiente: sin cambios sobre el default */
.app-steps__item--pending .app-steps__bubble {
background:    var(--surface-color);
border-color:  var(--border-color);
color:         var(--text-muted);
}
/* ── Icono check (SVG inline) ─────────────────────────────── */
.app-steps__icon {
width: 1rem;
height: 1rem;
stroke-width: 2.5;
}
/* ── Número ───────────────────────────────────────────────── */
.app-steps__number {
line-height: 1;
user-select: none;
}
/* ── Meta (tag + label) ───────────────────────────────────── */
.app-steps__meta {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.1rem;
text-align: center;
min-width: 0;
}
/* "Paso N" en gris pequeño */
.app-steps__step-tag {
font-size: 0.68rem;
font-weight: 500;
text-transform: uppercase;
letter-spacing: 0.06em;
color: var(--text-muted);
line-height: 1;
transition: color 0.3s;
}
/* Nombre del paso */
.app-steps__label {
font-size: 0.82rem;
font-weight: 600;
color: var(--text-secondary);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
max-width: 90px;
line-height: 1.2;
transition: color 0.3s;
}
/* Label en paso activo */
.app-steps__item--active .app-steps__label {
color: var(--primary-color);
font-weight: 700;
}
.app-steps__item--active .app-steps__step-tag {
color: var(--primary-color);
}
/* Label en paso completado */
.app-steps__item--completed .app-steps__label {
color: var(--success-color);
}
.app-steps__item--completed .app-steps__step-tag {
color: var(--success-color);
}
/* ── Animación pulso (paso activo) ────────────────────────── */
@keyframes app-steps-pulse {
0%, 100% { box-shadow: 0 0 0 4px color-mix(in srgb, var(--primary-color) 20%, transparent), var(--shadow-sm); }
50%       { box-shadow: 0 0 0 8px color-mix(in srgb, var(--primary-color) 10%, transparent), var(--shadow-md); }
}
/* ── Modo oscuro ──────────────────────────────────────────── */
.app-steps__item--pending .app-steps__bubble {
background: var(--surface-color);
}
/* ── Responsivo ───────────────────────────────────────────── */
@media (max-width: 640px) {
.app-steps {
gap: 0;
padding-bottom: 1rem;
}
.app-steps__label {
display: none;
}
.app-steps__step-tag {
font-size: 0.62rem;
}
.app-steps__bubble {
width: 2rem;
height: 2rem;
font-size: 0.8rem;
}
.app-steps__track {
top: 1rem;
}
}
/* ==============================================
AppTable - Componente de tabla moderno y profesional
============================================== */
.app-table__wrapper {
width: 100%;
overflow-x: auto;
margin-bottom: 1.5rem;
border-radius: 0.5rem;
box-shadow: var(--shadow-sm);
}
.app-table {
width: 100%;
border-collapse: separate;
border-spacing: 0;
background: var(--surface-color);
color: var(--text-color);
font-size: 0.9375rem;
border-radius: 0.5rem;
overflow: hidden;
border: 1px solid var(--table-border);
}
/* Header de la tabla - Diseño profesional y limpio */
.app-table__head {
position: sticky;
top: 0;
z-index: 10;
background-color: var(--table-header-bg);
}
.app-table__head th {
background-color: var(--table-header-bg);
color: var(--table-header-text);
font-weight: 600;
padding: 1rem 1.25rem;
border-bottom: 2px solid var(--table-border);
text-align: left;
white-space: nowrap;
font-size: 0.8125rem;
letter-spacing: 0.05em;
text-transform: uppercase;
transition: all 0.2s ease;
cursor: pointer;
user-select: none;
}
.app-table__head th:hover {
background-color: var(--hover-background-color);
color: var(--primary-color);
}
.app-table__head th:first-child {
border-top-left-radius: 0.5rem;
padding-left: 1.5rem;
}
.app-table__head th:last-child {
border-top-right-radius: 0.5rem;
padding-right: 1.5rem;
cursor: default;
}
.app-table__head th:last-child:hover {
background-color: var(--table-header-bg);
color: var(--table-header-text);
}
/* Botones en header - ya no se usan, pero por compatibilidad */
.app-table__head th button {
all: unset;
display: inline;
cursor: pointer;
color: inherit;
font: inherit;
}
/* Los spans dentro del header heredan */
.app-table__head th span {
color: inherit !important;
}
/* Cuerpo de la tabla */
.app-table__body .app-table__row {
transition: background-color 0.2s ease, box-shadow 0.2s ease;
background: var(--surface-color);
border-bottom: 1px solid var(--table-border);
}
.app-table__body .app-table__row:nth-child(even) {
background: var(--surface-alt-color);
}
.app-table__body .app-table__row:hover {
background: var(--table-row-hover);
box-shadow: inset 3px 0 0 var(--primary-color);
}
/* Filas con menú contextual */
.app-table__body .app-table__row[data-has-context-menu] {
cursor: context-menu;
position: relative;
}
.app-table__body .app-table__row[data-has-context-menu]::after {
content: '⋮';
position: absolute;
right: 0.75rem;
top: 50%;
transform: translateY(-50%);
opacity: 0;
color: var(--text-muted);
font-size: 1.25rem;
font-weight: bold;
pointer-events: none;
transition: opacity 0.2s ease;
}
.app-table__body .app-table__row[data-has-context-menu]:hover::after {
opacity: 0.5;
}
/* Celdas */
.app-table__cell,
.app-table__body td,
.app-table__head th {
padding: 0.875rem 1.25rem;
vertical-align: middle;
}
.app-table__body td {
line-height: 1.5;
color: var(--text-color);
font-size: 0.875rem;
border-bottom: none;
}
.app-table__body td:first-child {
padding-left: 1.5rem;
}
.app-table__body td:last-child {
padding-right: 1.5rem;
}
/* Última fila sin borde inferior */
.app-table__row:last-child {
border-bottom: none;
}
/* Fila vacía */
.app-table__row--empty .app-table__cell--empty {
text-align: center;
color: var(--text-muted);
font-style: italic;
background: var(--surface-alt-color);
border-bottom: none;
padding: 3rem 1rem;
font-size: 0.9375rem;
}
/* Celda con alineación */
.app-table__cell--center,
.app-table__body td[data-align="center"] {
text-align: center;
}
.app-table__cell--right,
.app-table__body td[data-align="right"] {
text-align: right;
}
/* Celda con acciones */
.app-table__cell--actions {
display: flex;
gap: 0.5rem;
justify-content: flex-end;
align-items: center;
flex-wrap: wrap;
}
/* Estados de fila */
.app-table__row--selected {
background: var(--hover-background-color);
box-shadow: inset 3px 0 0 var(--primary-color);
}
.app-table__row--disabled {
opacity: 0.5;
pointer-events: none;
}
/* ============================================== */
/* Header sorteable */
/* ============================================== */
.app-table__head th[data-sortable="true"] {
cursor: pointer;
user-select: none;
position: relative;
padding-right: 2.5rem;
}
.app-table__head th[data-sortable="true"]:hover {
background-color: var(--hover-background-color);
}
.app-table__head th[data-sortable="true"]::after {
content: '⇅';
position: absolute;
right: 0.75rem;
opacity: 0.4;
font-size: 0.75rem;
transition: opacity 0.2s ease;
}
.app-table__head th[data-sortable="true"]:hover::after {
opacity: 0.7;
}
.app-table__head th[data-sort="asc"]::after {
content: '↑';
opacity: 1;
color: var(--primary-color);
}
.app-table__head th[data-sort="desc"]::after {
content: '↓';
opacity: 1;
color: var(--primary-color);
}
/* ============================================== */
/* Responsive - Cards en móvil < 750px */
/* ============================================== */
@media (max-width: 750px) {
.app-table__wrapper {
margin-bottom: 1rem;
border-radius: 0;
box-shadow: none;
background: transparent;
overflow-x: visible;
}
.app-table {
border: none;
background: transparent;
}
/* Ocultar header en móvil */
.app-table__head {
display: none;
}
/* Convertir filas en cards */
.app-table__body {
display: flex;
flex-direction: column;
gap: 1rem;
}
.app-table__body .app-table__row {
display: flex;
flex-direction: column;
background-color: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 0.75rem;
padding: 1rem;
box-shadow: var(--shadow-sm);
margin-bottom: 0;
transition: all 0.2s ease;
}
.app-table__body .app-table__row:hover {
box-shadow: var(--shadow-md);
transform: translateY(-2px);
border-color: var(--primary-color);
}
.app-table__body .app-table__row:nth-child(even) {
background: var(--surface-color);
}
/* Cada celda como fila con label */
.app-table__body td {
display: flex;
justify-content: space-between;
align-items: center;
padding: 0.75rem 0;
border-bottom: 1px solid var(--border-color);
font-size: 0.875rem;
}
.app-table__body td:first-child {
padding-left: 0;
padding-top: 0;
}
.app-table__body td:last-child {
padding-right: 0;
padding-bottom: 0;
border-bottom: none;
}
/* Label antes del valor */
.app-table__body td::before {
content: attr(data-label);
font-weight: 600;
color: var(--text-secondary);
font-size: 0.75rem;
text-transform: uppercase;
letter-spacing: 0.05em;
margin-right: 0.5rem;
}
/* Valor a la derecha */
.app-table__body td > * {
text-align: right;
}
/* Celda de acciones - centrada */
.app-table__cell--actions {
justify-content: flex-end;
margin-top: 0.5rem;
padding-top: 1rem;
border-top: 1px solid var(--border-color);
}
/* Menú contextual en cards */
.app-table__body .app-table__row[data-has-context-menu]::after {
display: none;
}
}
@media (max-width: 768px) and (min-width: 751px) {
.app-table__wrapper {
margin-bottom: 1rem;
border-radius: 0.375rem;
}
.app-table__head th,
.app-table__cell,
.app-table__body td {
padding: 0.75rem 1rem;
font-size: 0.8125rem;
}
.app-table__head th {
font-size: 0.75rem;
}
.app-table__head th:first-child,
.app-table__body td:first-child {
padding-left: 1rem;
}
.app-table__head th:last-child,
.app-table__body td:last-child {
padding-right: 1rem;
}
.app-table__cell--actions {
gap: 0.375rem;
}
.app-table__body .app-table__row[data-has-context-menu]::after {
right: 0.5rem;
}
}
.app-tabs{width:100%;--tab-gap:.5rem;--tab-radius:8px;--tab-padding:.55rem .95rem;
/* tokens mapeados a variables del sitio */
--tab-fg:var(--text-color);
--tab-bg:var(--surface-color);
--tab-border:var(--border-color);
--tab-hover-bg:var(--hover-background-color);
--tab-active-bg:var(--primary-color);
--tab-active-border:var(--primary-color);
--tab-active-fg:var(--primary-foreground); /* Cambiado a primary-foreground para mejor contraste */
--tab-shadow:01px2px var(--shadow-color);
}
.app-tabs__list{display:flex;gap:var(--tab-gap);flex-wrap:wrap}
.app-tabs--scroll .app-tabs__list{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:thin}
.app-tabs--fill .app-tabs__list{justify-content:space-between}
.app-tabs__tab{appearance:none;background:var(--tab-bg);color:var(--tab-fg);border:1px solid var(--tab-border);padding:var(--tab-padding);border-radius:var(--tab-radius);cursor:pointer;font:inherit;display:inline-flex;align-items:center;gap:.45rem;white-space:nowrap;transition:.15s background,.15s border-color,.15s color,.15s box-shadow;box-shadow:none}
.app-tabs__tab:hover{background:var(--tab-hover-bg);color:var(--tab-fg)}
.app-tabs__tab:focus-visible{outline:2px solid var(--focus-color);outline-offset:2px}
.app-tabs__tab.is-active{background:var(--tab-active-bg);color:var(--tab-active-fg);border-color:var(--tab-active-border);box-shadow:var(--tab-shadow)}
.app-tabs__tab.is-disabled{opacity:.5;cursor:not-allowed}
.app-tabs__icon{display:inline-flex;align-items:center;color:currentColor}
.app-tabs__panels{margin-top:1rem}
.app-tabs__panel{animation:fade .18s ease}
.app-tabs__panel.is-hidden{display:none}
/* Variant underline */
.app-tabs--variant-underline .app-tabs__tab{background:transparent;border:none;border-bottom:3px solid transparent;border-radius:0;padding:.65rem .9rem;color:var(--text-color)}
.app-tabs--variant-underline .app-tabs__tab:hover{background:var(--hover-background-color)}
.app-tabs--variant-underline .app-tabs__tab.is-active{border-color:var(--primary-color);color:var(--primary-color)}
/* Variant pills */
.app-tabs--variant-pills .app-tabs__tab{border:1px solid var(--border-color);background:var(--secondary-background);color:var(--text-color)}
.app-tabs--variant-pills .app-tabs__tab:hover{background:var(--hover-background-color);color:var(--text-color)}
.app-tabs--variant-pills .app-tabs__tab.is-active{background:var(--primary-color);color:var(--primary-foreground);border-color:var(--primary-color)}
@media (max-width:767px){
.app-tabs__list{gap:.35rem}
.app-tabs__tab{padding:.5rem .8rem}
}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.app-toast__container {
position: fixed;
top: 1.2rem;
right: 1.2rem;
z-index: 10000;
}
.app-toast {
min-width: 260px;
max-width: 340px;
padding: 1.1rem 1.5rem 1.1rem 1.1rem;
border-radius: 0.5rem;
box-shadow: var(--shadow-sm);
position: relative;
background: var(--surface-color);
display: flex;
flex-direction: column;
gap: 0.3rem;
font-family: var(--font-family-base);
font-size: 1rem;
animation: app-toast-fadein 0.3s;
opacity: 1;
transition: opacity 0.5s;
}
.app-toast--closing {
opacity: 0;
}
.app-toast--info {
background: var(--info-background);
color: var(--info-foreground);
}
.app-toast--success {
background: var(--success-background);
color: var(--success-foreground);
}
.app-toast--warning {
background: var(--warning-background);
color: var(--warning-foreground);
}
.app-toast--error {
background: var(--danger-background);
color: var(--danger-foreground);
}
.app-toast__close {
position: absolute;
top: 0.5rem;
right: 0.7rem;
background: none;
border: none;
color: inherit;
font-size: 1rem;
font-weight: normal;
cursor: pointer;
opacity: 0.6;
transition: opacity 0.2s, color 0.2s;
z-index: 1;
line-height: 1;
padding: 0;
width: 1.5em;
height: 1.5em;
display: flex;
align-items: center;
justify-content: center;
}
.app-toast__close:hover {
opacity: 1;
color: var(--primary-color);
}
.app-toast__title {
font-weight: 600;
font-size: 1.08em;
margin-bottom: 0.15em;
line-height: 1.2;
word-break: break-word;
}
.app-toast__content {
font-size: 0.98em;
margin-bottom: 0.1em;
line-height: 1.4;
word-break: break-word;
}
.app-toast__link {
display: inline-block;
margin-top: 0.15em;
font-size: 0.95em;
color: var(--primary-color);
text-decoration: underline;
word-break: break-all;
transition: color 0.2s;
}
.app-toast__link:hover {
color: var(--primary-dark);
}
@keyframes app-toast-fadein {
from {
opacity: 0;
right: 0;
}
to {
opacity: 1;
right: 1.2rem;
}
}
.app-tooltip__content {
position: absolute;
bottom: 100%;
left: 50%;
transform: translateX(-50%);
background-color: var(--primary-color);
color: var(--text-light);
font-size: 0.95rem;
border: 1px solid var(--border-color);
border-radius: 0.5rem;
padding: 0.5rem 1rem;
white-space: nowrap;
z-index: 1000;
margin-bottom: 0.5rem;
box-shadow: var(--shadow-sm);
opacity: 0.98;
pointer-events: none;
transition: opacity 0.15s;
text-align: center;
}
/* Flecha del tooltip */
.app-tooltip__content::after {
content: "";
position: absolute;
top: 100%;
left: 50%;
transform: translateX(-50%);
border-width: 6px;
border-style: solid;
border-color: var(--primary-color) transparent transparent transparent;
}
/* ============================================================
abstract-details — BEM
Usa variables de colors.css para soporte light / dark mode
============================================================ */
/* Bloque raíz */
.abstract-details {
max-width: 960px;
margin: 2rem auto;
padding: 0 1rem 3rem;
color: var(--text-color);
}
/* Header */
.abstract-details__header {
display: flex;
align-items: flex-start;
justify-content: space-between;
gap: 1rem;
padding-bottom: 1.25rem;
border-bottom: 2px solid var(--primary-color);
margin-bottom: 1.5rem;
}
.abstract-details__header_md {
display: flex;
align-items: flex-start;
justify-content: flex-end;
gap: 1rem;
padding-bottom: 1.25rem;
margin-bottom: 1.5rem;
}
.abstract-details__header-actions {
display: flex;
gap: 1.3rem;
}
.abstract-details__title {
font-size: 1.6rem;
font-weight: 700;
line-height: 1.3;
color: var(--primary-color);
margin: 0;
}
/* Badge de estado activo / inactivo */
.abstract-details__badge {
display: inline-flex;
align-items: center;
padding: 0.3rem 0.8rem;
border-radius: 999px;
font-size: 0.75rem;
font-weight: 600;
white-space: nowrap;
flex-shrink: 0;
}
.abstract-details__badge--active {
background-color: var(--success-background);
color: var(--success-foreground);
}
.abstract-details__badge--inactive {
background-color: var(--danger-background);
color: var(--danger-foreground);
}
/* Metadatos */
.abstract-details__meta {
display: flex;
flex-wrap: wrap;
gap: 0.75rem 2rem;
margin-bottom: 2rem;
padding: 1rem 1.25rem;
background-color: var(--card-bg-color);
border: 1px solid var(--border-color);
border-radius: 0.75rem;
box-shadow: var(--shadow-sm);
}
.abstract-details__meta-item {
display: flex;
flex-direction: column;
gap: 0.2rem;
}
.abstract-details__meta-label {
font-size: 0.7rem !important;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.07em;
color: var(--text-muted) !important;
}
.abstract-details__meta-value {
font-size: 0.9rem !important;
font-weight: 500;
color: var(--text-color) !important;
}
/* Media: imagen del trabajo o uploader */
.abstract-details__media {
margin-bottom: 2rem;
}
.abstract-details__media-preview {
border-radius: 0.75rem;
overflow: hidden;
border: 1px solid var(--border-color);
box-shadow: var(--shadow-sm);
background-color: var(--card-bg-color);
}
.abstract-details__media-img {
display: block;
width: 100%;
max-height: 320px;
object-fit: cover;
}
.abstract-details__media-upload {
background-color: var(--card-bg-color);
border: 1px dashed var(--border-color);
border-radius: 0.75rem;
padding: 1.25rem;
}
.abstract-details__media-label {
font-size: 0.7rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.07em;
color: var(--text-muted);
margin: 0 0 0.75rem;
}
/* Estado del poster */
.abstract-details__poster-status {
display: flex;
align-items: center;
gap: 0.85rem;
padding: 0.85rem 1.25rem;
border-radius: 0.75rem;
border: 1px solid var(--border-color);
margin-bottom: 1.5rem;
background-color: var(--card-bg-color);
box-shadow: var(--shadow-xs);
}
.abstract-details__poster-status--uploaded {
border-color: var(--success-foreground);
background-color: var(--success-background);
}
.abstract-details__poster-status--pending {
border-color: var(--danger-foreground);
background-color: var(--danger-background);
}
.abstract-details__poster-status-icon {
display: flex;
align-items: center;
flex-shrink: 0;
color: var(--success-foreground);
}
.abstract-details__poster-status--pending .abstract-details__poster-status-icon {
color: var(--danger-foreground);
}
.abstract-details__poster-status-info {
display: flex;
flex-direction: column;
gap: 0.15rem;
}
.abstract-details__poster-status-title {
font-size: 0.82rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.06em;
color: var(--success-foreground);
}
.abstract-details__poster-status--pending .abstract-details__poster-status-title {
color: var(--danger-foreground);
}
.abstract-details__poster-status-desc {
font-size: 0.85rem;
color: var(--text-secondary);
}
/* Contenedor de secciones */
.abstract-details__content {
display: flex;
flex-direction: column;
gap: 0.5rem;
}
/* Acordeón — bloque */
.abstract-details__accordion {
border: 1px solid var(--border-color);
border-radius: 0.75rem;
overflow: hidden;
background-color: var(--card-bg-color);
box-shadow: var(--shadow-xs);
transition: box-shadow 0.2s ease;
}
.abstract-details__accordion:hover {
box-shadow: var(--shadow-sm);
}
/* Header del acordeón — trigger */
.abstract-details__accordion-header {
width: 100%;
display: flex;
align-items: center;
justify-content: space-between;
padding: 0.9rem 1.25rem;
background: none;
border: none;
cursor: pointer;
text-align: left;
gap: 0.75rem;
color: var(--text-color);
background: none !important;
border-left: 4px solid var(--accent-color);
transition: background-color 0.15s ease, border-left-color 0.2s ease;
}
.abstract-details__accordion-header:hover {
border-left-color: var(--primary-color);
}
.abstract-details__accordion--open .abstract-details__accordion-header {
border-left-color: var(--primary-color);
background-color: var(--secondary-background);
}
/* Título dentro del header */
.abstract-details__accordion-title {
font-size: 0.8rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.08em;
color: var(--accent-dark);
flex: 1;
}
.abstract-details__accordion--open .abstract-details__accordion-title {
color: var(--primary-color);
}
/* Ícono chevron con rotación animada */
.abstract-details__accordion-icon {
display: flex;
align-items: center;
color: var(--text-muted);
transition: transform 0.25s ease, color 0.2s ease;
flex-shrink: 0;
}
.abstract-details__accordion--open .abstract-details__accordion-icon {
transform: rotate(180deg);
color: var(--primary-color);
}
/* Cuerpo del acordeón — colapsado por defecto */
.abstract-details__accordion-body {
display: grid;
grid-template-rows: 0fr;
transition: grid-template-rows 0.3s ease;
}
.abstract-details__accordion--open .abstract-details__accordion-body {
grid-template-rows: 1fr;
}
.abstract-details__accordion-body > div {
overflow: hidden;
}
/* Texto del cuerpo */
.abstract-details__section-body {
font-size: 0.95rem;
line-height: 1.7;
color: var(--text-secondary);
margin: 0;
padding: 1rem 1.25rem 1.25rem;
white-space: pre-line;
}
/* Responsive */
@media (max-width: 600px) {
.abstract-details__header {
flex-direction: column;
align-items: flex-start;
}
.abstract-details__title {
font-size: 1.25rem;
}
.abstract-details__meta {
flex-direction: column;
gap: 0.75rem;
}
}
/* ============================================================
MyAbstract Page — BEM
Bloque: my-abstracts-page
============================================================ */
/* === Bloque === */
.my-abstracts-page {
display: flex;
flex-direction: column;
gap: 1.5rem;
padding: 1.5rem;
min-height: 100%;
}
/* === Header === */
.my-abstracts-page__header {
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: 1rem;
}
.my-abstracts-page__header-text {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.my-abstracts-page__title {
margin: 0;
font-size: 1.5rem;
font-weight: 700;
color: var(--text-color);
line-height: 1.2;
}
.my-abstracts-page__subtitle {
margin: 0;
font-size: 0.875rem;
color: var(--text-muted);
}
.my-abstracts-page__header-actions {
display: flex;
align-items: center;
gap: 0.5rem;
}
/* === Botones === */
.my-abstracts-page__btn {
display: inline-flex;
align-items: center;
gap: 0.375rem;
padding: 0.5rem 1.125rem;
border: none;
border-radius: 0.5rem;
font-size: 0.875rem;
font-weight: 500;
cursor: pointer;
transition: background-color 0.15s ease, box-shadow 0.15s ease;
text-decoration: none;
}
.my-abstracts-page__btn--primary {
background-color: var(--primary-color);
color: var(--primary-foreground);
}
.my-abstracts-page__btn--primary:hover {
background-color: var(--primary-hover);
box-shadow: var(--shadow-sm);
}
/* === Body === */
.my-abstracts-page__body {
display: flex;
flex-direction: column;
gap: 1rem;
padding: 1rem;
background-color: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 0.75rem;
box-shadow: var(--shadow-md);
overflow: hidden;
}
/* === Encabezados de tabla === */
.my-abstracts-page__th {
padding: 0.75rem 1rem;
text-align: left;
font-size: 0.7rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.06em;
color: var(--table-header-text);
background-color: var(--table-header-bg);
white-space: nowrap;
}
/* === Celdas de tabla === */
.my-abstracts-page__td {
padding: 0.875rem 1rem;
font-size: 0.875rem;
color: var(--text-color);
border-bottom: 1px solid var(--table-border);
vertical-align: middle;
}
.my-abstracts-page__td--title {
font-weight: 500;
max-width: 240px;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
/* === Badge de estado === */
.my-abstracts-page__badge {
display: inline-flex;
align-items: center;
padding: 0.2rem 0.625rem;
border-radius: 9999px;
font-size: 0.72rem;
font-weight: 600;
letter-spacing: 0.03em;
white-space: nowrap;
}
.my-abstracts-page__badge--active {
background-color: var(--success-background);
color: var(--success-foreground);
}
.my-abstracts-page__badge--inactive {
background-color: var(--danger-background);
color: var(--danger-foreground);
}
/* === Responsive === */
@media (max-width: 768px) {
.my-abstracts-page {
padding: 1rem;
}
.my-abstracts-page__header {
flex-direction: column;
align-items: flex-start;
}
.my-abstracts-page__title {
font-size: 1.25rem;
}
}
/* ============================================
CfdiListPage - Filter Styles
Estilos para panel de filtros
============================================ */
/* ============= Filter Groups ============= */
.cfdiListPage__filter-group {
margin-bottom: 1.5rem;
}
.cfdiListPage__filter-section-title {
margin: 0 0 1rem 0;
font-size: 0.875rem;
font-weight: 600;
color: var(--text-secondary);
text-transform: uppercase;
letter-spacing: 0.5px;
display: flex;
align-items: center;
gap: 0.5rem;
}
.cfdiListPage__filter-divider {
height: 1px;
background: var(--border-color);
margin: 1.5rem 0;
}
/* ============= Responsive ============= */
@media (max-width: 640px) {
.cfdiListPage__filter-group {
margin-bottom: 1.25rem;
}
.cfdiListPage__filter-section-title {
font-size: 0.8125rem;
}
.cfdiListPage__filter-divider {
margin: 1.25rem 0;
}
}
/* ============================================
CfdiPpdListPage - Cuentas por Cobrar
P�gina de facturas PPD con estado de pago
============================================ */
/* ============= Container ============= */
.cfdiPpdListPage {
width: 100%;
max-width: 1400px;
margin: 0 auto;
padding: 1.5rem;
}
/* ============= Header ============= */
.cfdiPpdListPage__title {
font-size: 1.75rem;
font-weight: 600;
color: var(--text-color);
margin-bottom: 1.5rem;
}
/* ============= Estad�sticas ============= */
.cfdiPpdListPage__stats {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: 1rem;
margin-bottom: 2rem;
}
.cfdiPpdListPage__stat-card {
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 8px;
padding: 1.25rem;
display: flex;
flex-direction: column;
align-items: center;
text-align: center;
transition: transform 0.2s, box-shadow 0.2s;
}
.cfdiPpdListPage__stat-card:hover {
transform: translateY(-2px);
box-shadow: var(--shadow-md);
}
.cfdiPpdListPage__stat-value {
font-size: 2rem;
font-weight: 700;
color: var(--primary-color);
margin-bottom: 0.5rem;
}
.cfdiPpdListPage__stat-label {
font-size: 0.875rem;
color: var(--text-secondary);
font-weight: 500;
}
.cfdiPpdListPage__stat-card--danger .cfdiPpdListPage__stat-value {
color: var(--danger-color);
}
.cfdiPpdListPage__stat-card--warning .cfdiPpdListPage__stat-value {
color: var(--warning-color);
}
.cfdiPpdListPage__stat-card--success .cfdiPpdListPage__stat-value {
color: var(--success-color);
}
.cfdiPpdListPage__stat-card--primary .cfdiPpdListPage__stat-value {
color: var(--primary-color);
}
/* ============= Filtros ============= */
.cfdiPpdListPage__filters {
display: flex;
flex-wrap: wrap;
gap: 1.5rem;
align-items: flex-end;
background: var(--surface-color);
padding: 1.25rem;
border-radius: 8px;
border: 1px solid var(--border-color);
margin-bottom: 1.5rem;
}
.cfdiPpdListPage__filter-group {
flex: 1;
min-width: 200px;
}
.cfdiPpdListPage__filter-label {
display: block;
font-size: 0.875rem;
font-weight: 500;
color: var(--text-secondary);
margin-bottom: 0.5rem;
}
.cfdiPpdListPage__filter-buttons {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
}
.cfdiPpdListPage__filter-btn {
padding: 0.5rem 1rem;
border: 1px solid var(--border-color);
background: var(--background-color);
color: var(--text-color);
border-radius: 6px;
font-size: 0.875rem;
font-weight: 500;
cursor: pointer;
transition: all 0.2s;
}
.cfdiPpdListPage__filter-btn:hover {
background: var(--hover-background-color);
border-color: var(--primary-color);
}
.cfdiPpdListPage__filter-btn.active {
background: var(--primary-color);
color: var(--primary-foreground);
border-color: var(--primary-color);
}
/* ============= Tabla ============= */
.cfdiPpdListPage__table-wrapper {
background: var(--surface-color);
border-radius: 8px;
border: 1px solid var(--border-color);
overflow: hidden;
}
.cfdiPpdListPage__th-center {
text-align: center;
}
.cfdiPpdListPage__client-col {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.cfdiPpdListPage__client-col strong {
color: var(--text-color);
}
.cfdiPpdListPage__client-col small {
color: var(--text-secondary);
font-size: 0.8125rem;
}
.cfdiPpdListPage__status-cell {
text-align: center;
}
.cfdiPpdListPage__payments-count {
display: block;
margin-top: 0.25rem;
color: var(--text-secondary);
font-size: 0.75rem;
}
.cfdiPpdListPage__actions-cell {
text-align: center;
}
.text-danger {
color: var(--danger-color);
font-weight: 600;
}
.text-success {
color: var(--success-color);
font-weight: 600;
}
/* ============= Badges ============= */
.badge {
display: inline-block;
padding: 0.25rem 0.75rem;
border-radius: 12px;
font-size: 0.75rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.badge--success {
background: rgba(34, 197, 94, 0.1);
color: #22c55e;
}
.badge--warning {
background: rgba(251, 191, 36, 0.1);
color: #fbbf24;
}
.badge--danger {
background: rgba(239, 68, 68, 0.1);
color: #ef4444;
}
.badge--primary {
background: rgba(59, 130, 246, 0.1);
color: #3b82f6;
}
/* ============= Estados ============= */
.cfdiPpdListPage__loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
padding: 3rem;
gap: 1rem;
}
.cfdiPpdListPage__loading span {
color: var(--text-secondary);
}
.cfdiPpdListPage__error {
background: rgba(239, 68, 68, 0.1);
color: #ef4444;
padding: 1rem;
border-radius: 6px;
border-left: 4px solid #ef4444;
}
.cfdiPpdListPage__empty {
text-align: center;
padding: 3rem;
color: var(--text-secondary);
}
.cfdiPpdListPage__empty p {
margin-bottom: 1rem;
}
/* ============= Modales ============= */
.cfdiPpdListPage__modal-loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
padding: 2rem;
gap: 1rem;
}
.cfdiPpdListPage__modal-empty {
text-align: center;
padding: 2rem;
color: var(--text-secondary);
}
/* ============= Lista de Complementos ============= */
.cfdiPpdListPage__complements-list {
display: flex;
flex-direction: column;
gap: 1rem;
}
.cfdiPpdListPage__complement-card {
background: var(--background-color);
border: 1px solid var(--border-color);
border-radius: 8px;
padding: 1rem;
}
.cfdiPpdListPage__complement-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 1rem;
padding-bottom: 0.75rem;
border-bottom: 1px solid var(--border-color);
}
.cfdiPpdListPage__complement-header h4 {
margin: 0;
font-size: 1rem;
color: var(--text-color);
}
.cfdiPpdListPage__complement-body {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: 0.75rem;
margin-bottom: 1rem;
}
.cfdiPpdListPage__complement-row {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.cfdiPpdListPage__complement-row .label {
font-size: 0.75rem;
color: var(--text-secondary);
font-weight: 500;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.cfdiPpdListPage__complement-row .value {
font-size: 0.875rem;
color: var(--text-color);
}
.cfdiPpdListPage__complement-row .value--mono {
font-family: 'Courier New', monospace;
font-size: 0.8125rem;
}
.cfdiPpdListPage__complement-row .value--amount {
font-weight: 600;
font-size: 1rem;
color: #22c55e;
}
.cfdiPpdListPage__complement-actions {
display: flex;
gap: 0.75rem;
padding-top: 0.75rem;
border-top: 1px solid var(--border-color);
}
/* ============= Responsive ============= */
@media (max-width: 768px) {
.cfdiPpdListPage {
padding: 1rem;
}
.cfdiPpdListPage__title {
font-size: 1.5rem;
}
.cfdiPpdListPage__stats {
grid-template-columns: repeat(2, 1fr);
}
.cfdiPpdListPage__filters {
flex-direction: column;
align-items: stretch;
}
.cfdiPpdListPage__filter-group {
width: 100%;
}
.cfdiPpdListPage__filter-buttons {
flex-direction: column;
}
.cfdiPpdListPage__filter-btn {
width: 100%;
}
.cfdiPpdListPage__complement-body {
grid-template-columns: 1fr;
}
.cfdiPpdListPage__complement-actions {
flex-direction: column;
}
}
@media (max-width: 480px) {
.cfdiPpdListPage__stats {
grid-template-columns: 1fr;
}
.cfdiPpdListPage__stat-value {
font-size: 1.5rem;
}
}
/* ============= Dark Mode ============= */
@media (prefers-color-scheme: dark) {
.badge--success {
background: rgba(34, 197, 94, 0.2);
}
.badge--warning {
background: rgba(251, 191, 36, 0.2);
}
.badge--danger {
background: rgba(239, 68, 68, 0.2);
}
.badge--primary {
background: rgba(59, 130, 246, 0.2);
}
}
/* CFDI List Page Styles (BEM) - Updated with Global Colors */
.cfdiListPage__card {
margin-bottom: 1.5rem;
background-color: var(--surface-color);
border: 1px solid var(--border-color);
}
.cfdiListPage__search-form { width: 100%; }
.cfdiListPage__search-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: 1rem;
align-items: end;
}
.cfdiListPage__search-input { min-width: 0; }
.cfdiListPage__search-actions {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
align-items: center;
}
.cfdiListPage__table-card {
overflow-x: auto;
background-color: var(--surface-color);
border: 1px solid var(--border-color);
}
.cfdiListPage__error,
.cfdiListPage__info,
.cfdiListPage__empty {
padding: 1.5rem;
text-align: center;
border-radius: 0.375rem;
margin: 1rem 0;
}
.cfdiListPage__error {
background-color: var(--danger-background);
color: var(--error-text);
border: 1px solid var(--danger-color);
}
.cfdiListPage__info {
background-color: var(--info-background);
color: var(--info-color);
border: 1px solid var(--info-color);
}
.cfdiListPage__empty {
background-color: var(--secondary-background);
color: var(--text-muted);
}
.cfdiListPage__cell-uuid {
font-family: 'Courier New', monospace;
font-weight: 600;
color: var(--primary-color);
font-size: 0.875rem;
}
.cfdiListPage__cell-folio {
font-weight: 600;
color: var(--text-color);
}
.cfdiListPage__cell-receiver {
font-weight: 500;
color: var(--text-color);
}
.cfdiListPage__cell-rfc {
font-family: 'Courier New', monospace;
font-size: 0.875rem;
color: var(--text-secondary);
}
.cfdiListPage__cell-date {
font-size: 0.875rem;
color: var(--text-secondary);
}
.cfdiListPage__cell-total {
font-weight: 600;
color: var(--text-color);
text-align: right;
font-family: 'Courier New', monospace;
}
.cfdiListPage__cell-status {}
.cfdiListPage__cell-actions {
display: flex;
gap: 0.25rem;
justify-content: flex-end;
flex-wrap: wrap;
}
/* ⚙️ Estilos para AppActionsMenu */
.cfdiListPage__th-center {
text-align: center !important;
}
.cfdiListPage__actions-cell {
text-align: center;
vertical-align: middle;
}
.cfdiListPage__status {
display: inline-flex;
align-items: center;
padding: 0.375rem 0.75rem;
border-radius: 0.375rem;
font-size: 0.875rem;
font-weight: 500;
}
.cfdiListPage__status--valid {
background-color: var(--success-background);
color: var(--success-dark);
}
.cfdiListPage__status--cancelled {
background-color: var(--danger-background);
color: var(--danger-dark);
}
.cfdiListPage__status--pending {
background-color: var(--warning-background);
color: var(--warning-dark);
}
.cfdiListPage__status--draft {
background-color: var(--secondary-background);
color: var(--text-secondary);
}
.cfdiListPage__pagination { margin-top: 1.5rem; }
/* Details */
.cfdiListPage__detail-grid,
.cfdiListPage__details-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
gap: 1rem;
margin: 1rem 0;
}
.cfdiListPage__detail-section {
padding: 1rem;
background-color: var(--secondary-background);
border-radius: 0.5rem;
border: 1px solid var(--border-color);
}
.cfdiListPage__detail-section h4 {
font-size: 0.875rem;
font-weight: 700;
text-transform: uppercase;
color: var(--text-muted);
margin: 0 0 1rem 0;
padding-bottom: 0.5rem;
border-bottom: 2px solid var(--border-color);
}
.cfdiListPage__detail-item {
display: flex;
justify-content: space-between;
padding: 0.5rem 0;
border-bottom: 1px solid var(--border-light);
}
.cfdiListPage__detail-item:last-child {
border-bottom: none;
}
.cfdiListPage__detail-label {
font-size: 0.875rem;
font-weight: 600;
color: var(--text-muted);
}
.cfdiListPage__detail-value {
font-size: 0.875rem;
color: var(--text-color);
font-weight: 500;
text-align: right;
}
.cfdiListPage__detail-value--mono {
font-family: 'Courier New', monospace;
color: var(--primary-color);
}
.cfdiListPage__detail-value--total {
font-size: 1.125rem;
font-weight: 700;
color: var(--primary-color);
}
/* Actions */
.cfdiListPage__actions-section {
margin-top: 1.5rem;
padding-top: 1.5rem;
border-top: 2px solid var(--border-color);
}
.cfdiListPage__actions-section h4 {
font-size: 0.875rem;
font-weight: 700;
text-transform: uppercase;
color: var(--text-muted);
margin-bottom: 1rem;
}
.cfdiListPage__actions-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: 0.75rem;
}
.cfdiListPage__detail-actions {
margin-top: 1.5rem;
padding-top: 1.5rem;
border-top: 2px solid var(--border-color);
display: flex;
flex-direction: column;
gap: 1rem;
}
.cfdiListPage__info-message {
display: flex;
align-items: center;
gap: 0.75rem;
padding: 1rem 1.25rem;
background: var(--info-background);
border: 2px solid var(--info-color);
border-radius: 0.5rem;
color: var(--text-color);
font-size: 0.875rem;
line-height: 1.5;
}
.cfdiListPage__info-message--success {
background: var(--success-background);
border-color: var(--success-color);
}
.cfdiListPage__info-message--warning {
background: var(--warning-background);
border-color: var(--warning-color);
}
.cfdiListPage__info-message--info {
background: var(--info-background);
border-color: var(--info-color);
}
.cfdiListPage__info-icon {
font-size: 1.25rem;
flex-shrink: 0;
}
/* Cancel Form */
.cfdiListPage__cancel-form {
display: flex;
flex-direction: column;
gap: 1rem;
}
.cfdiListPage__form-row {
display: grid;
gap: 1rem;
}
.cfdiListPage__form-row--2 { grid-template-columns: repeat(2, 1fr); }
.cfdiListPage__checkbox-container {
margin: 1rem 0;
padding: 0.75rem;
background-color: var(--secondary-background);
border-radius: 0.375rem;
}
.cfdiListPage__checkbox-container label {
display: flex;
align-items: center;
gap: 0.5rem;
cursor: pointer;
user-select: none;
}
.cfdiListPage__checkbox-container input[type="checkbox"] {
width: 1.25rem;
height: 1.25rem;
cursor: pointer;
}
.cfdiListPage__checkbox-container span {
font-size: 0.875rem;
color: var(--text-color);
font-weight: 500;
}
.cfdiListPage__modal-actions {
display: flex;
gap: 0.75rem;
justify-content: flex-end;
margin-top: 1.5rem;
}
.cfdiListPage__warning {
padding: 1rem;
background-color: var(--warning-background);
border: 2px solid var(--warning-color);
border-radius: 0.375rem;
margin-bottom: 1rem;
color: var(--text-color);
}
.cfdiListPage__warning p {
margin: 0.5rem 0;
color: var(--text-color);
}
.cfdiListPage__warning strong {
color: var(--warning-color);
font-weight: 700;
}
.cfdiListPage__warning-text {
color: var(--text-color);
font-size: 0.875rem;
}
/* ==========================================================================
ESTILOS PARA MODALES DE CANCELACIÓN - BEM con alta especificidad
========================================================================== */
/* Modal Overlay - Fondo oscuro semi-transparente */
.cfdiListPage__modal-overlay,
.modal-overlay {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: var(--overlay-color);
display: flex;
align-items: center;
justify-content: center;
z-index: 9999;
padding: 1rem;
}
/* Modal Content - Contenedor principal */
.cfdiListPage__modal-content,
.modal-content {
background: var(--surface-color);
border-radius: 0.75rem;
box-shadow: var(--shadow-xl);
max-width: 600px;
width: 100%;
max-height: 90vh;
overflow-y: auto;
border: 1px solid var(--border-color);
}
/* Modal Header */
.cfdiListPage__modal-header,
.modal-header {
display: flex;
justify-content: space-between;
align-items: center;
padding: 1.5rem;
border-bottom: 2px solid var(--border-color);
background: var(--secondary-background);
}
.cfdiListPage__modal-header h3,
.modal-header h3 {
margin: 0;
font-size: 1.25rem;
font-weight: 700;
color: var(--text-color) !important;
}
.cfdiListPage__modal-close-btn,
.close-btn {
background: transparent;
border: none;
font-size: 1.75rem;
line-height: 1;
color: var(--text-muted);
cursor: pointer;
padding: 0;
width: 2rem;
height: 2rem;
display: flex;
align-items: center;
justify-content: center;
border-radius: 0.375rem;
transition: all 0.2s ease;
}
.cfdiListPage__modal-close-btn:hover,
.close-btn:hover {
background: var(--hover-background-color);
color: var(--text-color);
}
/* Modal Body */
.cfdiListPage__modal-body,
.modal-body {
padding: 1.5rem;
}
/* Modal Footer */
.cfdiListPage__modal-footer,
.modal-footer {
display: flex;
gap: 0.75rem;
justify-content: flex-end;
padding: 1.5rem;
border-top: 2px solid var(--border-color);
background: var(--secondary-background);
}
/* ✅ CFDI Info Section - BEM con especificidad alta */
.cfdiListPage__cfdi-info,
.cfdi-info {
padding: 1.25rem;
background: var(--secondary-background) !important;
border: 1px solid var(--border-color);
border-radius: 0.5rem;
margin-bottom: 1.5rem;
}
/* ✅ Forzar colores en párrafos dentro de cfdi-info */
.cfdiListPage__cfdi-info p,
.cfdi-info p {
margin: 0.5rem 0 !important;
color: var(--text-color) !important;
font-size: 0.875rem;
line-height: 1.6;
}
.cfdiListPage__cfdi-info strong,
.cfdi-info strong {
color: var(--text-color) !important;
font-weight: 700;
}
/* Form Group */
.cfdiListPage__form-group,
.form-group {
margin-bottom: 1.25rem;
}
.cfdiListPage__form-group label,
.form-group label {
display: block;
font-weight: 600;
color: var(--text-color) !important;
margin-bottom: 0.5rem;
font-size: 0.875rem;
}
.cfdiListPage__form-group .required,
.form-group .required {
color: var(--danger-color) !important;
font-weight: 700;
}
/* Form Control (Inputs, Selects) */
.cfdiListPage__form-control,
.form-control {
width: 100%;
padding: 0.625rem 0.875rem;
font-size: 0.875rem;
line-height: 1.5;
color: var(--text-color) !important;
background-color: var(--surface-color);
border: 2px solid var(--border-color);
border-radius: 0.375rem;
transition: all 0.2s ease;
font-family: inherit;
}
.cfdiListPage__form-control:focus,
.form-control:focus {
outline: none;
border-color: var(--primary-color);
box-shadow: 0 0 0 3px var(--focus-ring);
}
.cfdiListPage__form-control::placeholder,
.form-control::placeholder {
color: var(--text-muted) !important;
}
.cfdiListPage__form-text,
.form-text {
display: block;
margin-top: 0.375rem;
font-size: 0.75rem;
color: var(--text-muted) !important;
line-height: 1.4;
}
/* Form Check (Checkboxes) */
.cfdiListPage__form-check,
.form-check {
display: flex;
align-items: center;
gap: 0.75rem;
padding: 0.875rem;
background: var(--secondary-background);
border: 1px solid var(--border-color);
border-radius: 0.375rem;
margin: 1rem 0;
}
.cfdiListPage__form-check-input,
.form-check-input {
width: 1.25rem;
height: 1.25rem;
cursor: pointer;
accent-color: var(--primary-color);
}
.cfdiListPage__form-check-label,
.form-check-label {
cursor: pointer;
user-select: none;
color: var(--text-color) !important;
font-size: 0.875rem;
font-weight: 500;
margin: 0;
}
/* ✅ Alert Boxes - BEM con especificidad alta */
.cfdiListPage__alert,
.alert {
padding: 1rem 1.25rem;
border-radius: 0.5rem;
margin-bottom: 1.25rem;
border: 2px solid;
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.cfdiListPage__alert i,
.alert i {
font-size: 1.25rem;
}
.cfdiListPage__alert strong,
.alert strong {
font-weight: 700 !important;
display: block;
margin-bottom: 0.5rem;
}
/* ✅ Forzar colores en párrafos y listas dentro de alertas */
.cfdiListPage__alert p,
.alert p {
margin: 0.375rem 0 !important;
line-height: 1.6;
color: inherit !important;
}
.cfdiListPage__alert ul,
.alert ul {
margin: 0.5rem 0 0 0;
padding-left: 1.5rem;
color: inherit !important;
}
.cfdiListPage__alert li,
.alert li {
margin-bottom: 0.375rem;
line-height: 1.6;
color: inherit !important;
}
/* ✅ Alert Info */
.cfdiListPage__alert--info,
.alert-info {
background: var(--info-background) !important;
border-color: var(--info-color) !important;
color: var(--text-color) !important;
}
.cfdiListPage__alert--info i,
.alert-info i,
.cfdiListPage__alert--info strong,
.alert-info strong {
color: var(--info-color) !important;
}
.cfdiListPage__alert--info p,
.alert-info p,
.cfdiListPage__alert--info li,
.alert-info li,
.cfdiListPage__alert--info ul,
.alert-info ul {
color: var(--text-color) !important;
}
/* ✅ Alert Warning */
.cfdiListPage__alert--warning,
.alert-warning {
background: var(--warning-background) !important;
border-color: var(--warning-color) !important;
color: var(--text-color) !important;
}
.cfdiListPage__alert--warning i,
.alert-warning i,
.cfdiListPage__alert--warning strong,
.alert-warning strong {
color: var(--warning-color) !important;
}
.cfdiListPage__alert--warning p,
.alert-warning p,
.cfdiListPage__alert--warning li,
.alert-warning li,
.cfdiListPage__alert--warning ul,
.alert-warning ul {
color: var(--text-color) !important;
}
/* ✅ Alert Danger */
.cfdiListPage__alert--danger,
.alert-danger {
background: var(--danger-background) !important;
border-color: var(--danger-color) !important;
color: var(--text-color) !important;
}
.cfdiListPage__alert--danger i,
.alert-danger i,
.cfdiListPage__alert--danger strong,
.alert-danger strong {
color: var(--danger-color) !important;
}
.cfdiListPage__alert--danger p,
.alert-danger p,
.cfdiListPage__alert--danger li,
.alert-danger li,
.cfdiListPage__alert--danger ul,
.alert-danger ul {
color: var(--text-color) !important;
}
/* Buttons */
.cfdiListPage__btn,
.btn {
display: inline-flex;
align-items: center;
gap: 0.5rem;
padding: 0.625rem 1.25rem;
font-size: 0.875rem;
font-weight: 600;
line-height: 1.5;
border-radius: 0.375rem;
border: 2px solid transparent;
cursor: pointer;
transition: all 0.2s ease;
text-decoration: none;
font-family: inherit;
}
.cfdiListPage__btn:disabled,
.btn:disabled {
opacity: 0.6;
cursor: not-allowed;
background: var(--disabled-background);
color: var(--disabled-color) !important;
}
.cfdiListPage__btn--primary,
.btn-primary {
background: var(--primary-color);
color: var(--primary-foreground) !important;
border-color: var(--primary-color);
}
.cfdiListPage__btn--primary:hover:not(:disabled),
.btn-primary:hover:not(:disabled) {
background: var(--primary-hover);
border-color: var(--primary-hover);
transform: translateY(-1px);
box-shadow: var(--shadow-md);
}
.cfdiListPage__btn--secondary,
.btn-secondary {
background: var(--secondary-background);
color: var(--text-color) !important;
border-color: var(--border-color);
}
.cfdiListPage__btn--secondary:hover:not(:disabled),
.btn-secondary:hover:not(:disabled) {
background: var(--hover-background-color);
border-color: var(--primary-color);
color: var(--primary-color) !important;
}
.cfdiListPage__btn--danger,
.btn-danger {
background: var(--danger-color);
color: var(--danger-foreground) !important;
border-color: var(--danger-color);
}
.cfdiListPage__btn--danger:hover:not(:disabled),
.btn-danger:hover:not(:disabled) {
background: var(--danger-dark);
border-color: var(--danger-dark);
transform: translateY(-1px);
box-shadow: var(--shadow-md);
}
.cfdiListPage__btn--success,
.btn-success {
background: var(--success-color);
color: var(--success-foreground) !important;
border-color: var(--success-color);
}
.cfdiListPage__btn--success:hover:not(:disabled),
.btn-success:hover:not(:disabled) {
background: var(--success-dark);
border-color: var(--success-dark);
transform: translateY(-1px);
box-shadow: var(--shadow-md);
}
/* ==========================================================================
RESPONSIVE
========================================================================== */
@media (max-width: 768px) {
.cfdiListPage__search-grid {
grid-template-columns: 1fr;
}
.cfdiListPage__detail-grid,
.cfdiListPage__details-grid {
grid-template-columns: 1fr;
}
.cfdiListPage__actions-grid {
grid-template-columns: 1fr;
}
.cfdiListPage__form-row--2 {
grid-template-columns: 1fr;
}
.cfdiListPage__modal-actions,
.cfdiListPage__modal-footer,
.modal-footer {
flex-direction: column;
}
.cfdiListPage__modal-actions > *,
.cfdiListPage__modal-footer > *,
.modal-footer > * {
width: 100%;
}
.cfdiListPage__modal-content,
.modal-content {
margin: 0;
max-height: 100vh;
border-radius: 0;
}
.cfdiListPage__modal-overlay,
.modal-overlay {
padding: 0;
}
}
/* CFDI Series Page Styles (BEM) - Updated with Global Colors */
.cfdiSeriesPage__card {
margin-bottom: 1.5rem;
background-color: var(--surface-color);
border: 1px solid var(--border-color);
}
.cfdiSeriesPage__search-form { width: 100%; }
.cfdiSeriesPage__search-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: 1rem;
align-items: end;
}
.cfdiSeriesPage__search-input { min-width: 0; }
.cfdiSeriesPage__search-actions {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
align-items: center;
}
.cfdiSeriesPage__table-card {
overflow-x: auto;
background-color: var(--surface-color);
border: 1px solid var(--border-color);
}
.cfdiSeriesPage__error, .cfdiSeriesPage__info, .cfdiSeriesPage__empty {
padding: 1.5rem;
text-align: center;
border-radius: 0.375rem;
margin: 1rem 0;
}
.cfdiSeriesPage__error {
background-color: var(--danger-background);
color: var(--error-text);
border: 1px solid var(--danger-color);
}
.cfdiSeriesPage__info {
background-color: var(--info-background);
color: var(--info-color);
border: 1px solid var(--info-color);
}
.cfdiSeriesPage__empty {
background-color: var(--secondary-background);
color: var(--text-muted);
}
.cfdiSeriesPage__cell-code {
font-family: 'Courier New', monospace;
font-weight: 600;
color: var(--primary-color);
}
.cfdiSeriesPage__cell-name {
font-weight: 500;
color: var(--text-color);
}
.cfdiSeriesPage__cell-type { }
.cfdiSeriesPage__cell-csd, .cfdiSeriesPage__cell-pac, .cfdiSeriesPage__cell-folio {
font-size: 0.875rem;
color: var(--text-secondary);
}
.cfdiSeriesPage__cell-status { }
.cfdiSeriesPage__cell-actions {
display: flex;
gap: 0.25rem;
justify-content: flex-end;
flex-wrap: wrap;
}
.cfdiSeriesPage__badge {
display: inline-flex;
align-items: center;
padding: 0.375rem 0.75rem;
border-radius: 0.375rem;
font-size: 0.875rem;
font-weight: 500;
background-color: var(--secondary-background);
color: var(--text-secondary);
}
.cfdiSeriesPage__badge--inscription {
background-color: var(--info-background);
color: var(--info-dark);
}
.cfdiSeriesPage__badge--exhibitor {
background-color: var(--warning-background);
color: var(--warning-dark);
}
.cfdiSeriesPage__badge--reservation {
background-color: var(--success-background);
color: var(--success-dark);
}
.cfdiSeriesPage__badge--sponsorship {
background: var(--accent-background);
color: var(--accent-color);
}
.cfdiSeriesPage__badge--manual {
background-color: var(--secondary-background);
color: var(--text-secondary);
}
.cfdiSeriesPage__status {
display: inline-flex;
align-items: center;
padding: 0.375rem 0.75rem;
border-radius: 0.375rem;
font-size: 0.875rem;
font-weight: 500;
}
.cfdiSeriesPage__status--active {
background-color: var(--success-background);
color: var(--success-dark);
}
.cfdiSeriesPage__status--inactive {
background-color: var(--danger-background);
color: var(--danger-dark);
}
.cfdiSeriesPage__pagination { margin-top: 1.5rem; }
/* Form */
.cfdiSeriesPage__form-grid {
display: flex;
flex-direction: column;
gap: 1rem;
}
.cfdiSeriesPage__form-row {
display: grid;
gap: 1rem;
}
.cfdiSeriesPage__form-row--2 { grid-template-columns: repeat(2, 1fr); }
.cfdiSeriesPage__form-row--3 { grid-template-columns: repeat(3, 1fr); }
.cfdiSeriesPage__folio-preview {
padding: 1rem;
background-color: var(--info-background);
border: 1px solid var(--info-color);
border-radius: 0.375rem;
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.cfdiSeriesPage__folio-preview label {
font-size: 0.875rem;
color: var(--text-muted);
font-weight: 500;
}
.cfdiSeriesPage__folio-preview strong {
font-size: 1.125rem;
color: var(--info-dark);
font-family: 'Courier New', monospace;
}
.cfdiSeriesPage__form-actions {
display: flex;
gap: 0.75rem;
justify-content: flex-end;
margin-top: 1.5rem;
padding-top: 1.5rem;
border-top: 2px solid var(--border-color);
}
/* Stats */
.cfdiSeriesPage__stats-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: 1rem;
margin: 1rem 0;
}
.cfdiSeriesPage__stat-card {
padding: 1.5rem;
background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-dark) 100%);
border-radius: 0.5rem;
color: var(--primary-foreground);
text-align: center;
}
.cfdiSeriesPage__stat-label {
font-size: 0.875rem;
opacity: 0.9;
margin-bottom: 0.5rem;
}
.cfdiSeriesPage__stat-value {
font-size: 2rem;
font-weight: 700;
}
/* Warning boxes */
.cfdiSeriesPage__warning {
padding: 1rem;
background-color: var(--warning-background);
border: 2px solid var(--warning-color);
border-radius: 0.375rem;
margin-bottom: 1rem;
color: var(--warning-foreground);
}
.cfdiSeriesPage__warning p {
margin: 0.5rem 0;
}
.cfdiSeriesPage__warning strong {
color: var(--warning-dark);
}
.cfdiSeriesPage__warning-text {
color: var(--warning-dark);
font-size: 0.875rem;
}
.cfdiSeriesPage__checkbox-container {
margin: 1rem 0;
padding: 0.75rem;
background-color: var(--secondary-background);
border-radius: 0.375rem;
}
.cfdiSeriesPage__checkbox-container label {
display: flex;
align-items: center;
gap: 0.5rem;
cursor: pointer;
user-select: none;
}
.cfdiSeriesPage__checkbox-container input[type="checkbox"] {
width: 1.25rem;
height: 1.25rem;
cursor: pointer;
}
.cfdiSeriesPage__checkbox-container span {
font-size: 0.875rem;
color: var(--text-color);
font-weight: 500;
}
.cfdiSeriesPage__modal-actions {
display: flex;
gap: 0.75rem;
justify-content: flex-end;
margin-top: 1.5rem;
}
.cfdiSeriesPage__divider {
height: 1px;
background-color: var(--divider-color);
margin: 1.5rem 0;
}
@media (max-width: 768px) {
.cfdiSeriesPage__search-grid { grid-template-columns: 1fr; }
.cfdiSeriesPage__form-row--2,
.cfdiSeriesPage__form-row--3 { grid-template-columns: 1fr; }
.cfdiSeriesPage__stats-grid { grid-template-columns: 1fr; }
.cfdiSeriesPage__form-actions,
.cfdiSeriesPage__modal-actions {
flex-direction: column;
}
.cfdiSeriesPage__form-actions > *,
.cfdiSeriesPage__modal-actions > * {
width: 100%;
}
}
/* Create CFDI Page Styles (BEM) - Updated with Global Colors */
/* ? Card principal m�s ancho */
.createCfdiPage__card {
margin-bottom: 1.5rem;
background-color: var(--surface-color);
border: 1px solid var(--border-color);
max-width: 1400px; /* Aumentado de 1200px (default) a 1400px */
width: 100%;
margin-left: auto;
margin-right: auto;
}
.createCfdiPage__error,
.createCfdiPage__info {
padding: 1.5rem;
text-align: center;
border-radius: 0.375rem;
margin: 1rem 0;
}
.createCfdiPage__error {
background-color: var(--danger-background);
color: var(--error-text);
border: 1px solid var(--danger-color);
}
.createCfdiPage__info {
background-color: var(--info-background);
color: var(--info-color);
border: 1px solid var(--info-color);
}
.createCfdiPage__steps {
display: flex;
justify-content: space-between;
align-items: center;
margin: 2rem 0;
padding: 1.5rem;
background-color: var(--secondary-background);
border-radius: 0.5rem;
border: 1px solid var(--border-color);
}
.createCfdiPage__step {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.5rem;
flex: 1;
position: relative;
}
.createCfdiPage__step::after {
content: '';
position: absolute;
top: 1.5rem;
left: 50%;
width: 100%;
height: 2px;
background-color: var(--border-color);
z-index: 0;
}
.createCfdiPage__step:last-child::after {
display: none;
}
.createCfdiPage__step-number {
width: 3rem;
height: 3rem;
border-radius: 50%;
background-color: var(--surface-color);
border: 2px solid var(--border-color);
display: flex;
align-items: center;
justify-content: center;
font-weight: 700;
font-size: 1.25rem;
color: var(--text-muted);
z-index: 1;
transition: all 0.3s ease;
}
.createCfdiPage__step--active .createCfdiPage__step-number {
background-color: var(--primary-color);
border-color: var(--primary-color);
color: var(--primary-foreground);
box-shadow: 0 0 0 4px var(--focus-ring);
}
.createCfdiPage__step--completed .createCfdiPage__step-number {
background-color: var(--success-color);
border-color: var(--success-color);
color: var(--success-foreground);
}
.createCfdiPage__step-label {
font-size: 0.875rem;
font-weight: 600;
color: var(--text-muted);
text-align: center;
}
.createCfdiPage__step--active .createCfdiPage__step-label {
color: var(--primary-color);
}
.createCfdiPage__step--completed .createCfdiPage__step-label {
color: var(--success-color);
}
.createCfdiPage__form-grid {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
.createCfdiPage__form-row {
display: grid;
gap: 1rem;
}
.createCfdiPage__form-row--2 { grid-template-columns: repeat(2, 1fr); }
.createCfdiPage__form-row--3 { grid-template-columns: repeat(3, 1fr); }
/* ? Nueva fila de 4 columnas para Cantidad, Precio, Descuento, Checkbox IVA */
.createCfdiPage__form-row--4 { grid-template-columns: repeat(4, 1fr); }
.createCfdiPage__section {
padding: 1.5rem;
background-color: var(--secondary-background);
border-radius: 0.5rem;
border: 1px solid var(--border-color);
}
.createCfdiPage__section-title {
font-size: 1.125rem;
font-weight: 700;
color: var(--text-color);
margin: 0 0 1rem 0;
padding-bottom: 0.75rem;
border-bottom: 2px solid var(--border-color);
}
.createCfdiPage__payment-card {
padding: 1rem;
background-color: var(--surface-color);
border: 2px solid var(--primary-color);
border-radius: 0.5rem;
margin: 1rem 0;
}
.createCfdiPage__payment-card.createCfdiPage__payment-card--selected {
background-color: var(--hover-background-color);
box-shadow: var(--shadow-md);
}
.createCfdiPage__payment-card h4 {
font-size: 1rem;
font-weight: 700;
color: var(--text-color);
margin: 0 0 0.5rem 0;
}
.createCfdiPage__payment-card p {
margin: 0.25rem 0;
font-size: 0.875rem;
color: var(--text-secondary);
}
.createCfdiPage__payment-card p strong {
color: var(--text-color);
}
.createCfdiPage__series-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
gap: 1rem;
}
.createCfdiPage__serie-card {
padding: 1rem;
background-color: var(--surface-color);
border: 2px solid var(--border-color);
border-radius: 0.5rem;
cursor: pointer;
transition: all 0.2s ease;
}
.createCfdiPage__serie-card:hover {
border-color: var(--primary-color);
background-color: var(--hover-background-color);
}
.createCfdiPage__serie-card.createCfdiPage__serie-card--selected {
border-color: var(--primary-color);
background-color: var(--hover-background-color);
box-shadow: var(--shadow-md);
}
.createCfdiPage__serie-card h4 {
font-size: 1rem;
font-weight: 700;
color: var(--primary-color);
margin: 0 0 0.5rem 0;
}
.createCfdiPage__serie-card p {
margin: 0.25rem 0;
font-size: 0.875rem;
color: var(--text-secondary);
}
.createCfdiPage__summary-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
gap: 1rem;
margin: 1rem 0;
}
.createCfdiPage__summary-item {
padding: 0.75rem;
background-color: var(--surface-color);
border-radius: 0.375rem;
border: 1px solid var(--border-color);
}
.createCfdiPage__summary-label {
font-size: 0.75rem;
font-weight: 600;
text-transform: uppercase;
color: var(--text-muted);
margin-bottom: 0.25rem;
}
.createCfdiPage__summary-value {
font-size: 1rem;
color: var(--text-color);
font-weight: 500;
}
.createCfdiPage__summary-value--mono {
font-family: 'Courier New', monospace;
color: var(--primary-color);
}
.createCfdiPage__summary-value--total {
font-size: 1.5rem;
font-weight: 700;
color: var(--primary-color);
}
.createCfdiPage__calculated {
padding: 1.5rem;
background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-dark) 100%);
border-radius: 0.5rem;
color: var(--primary-foreground);
margin: 1rem 0;
}
.createCfdiPage__calculated h4 {
font-size: 1rem;
font-weight: 700;
margin: 0 0 1rem 0;
opacity: 0.9;
}
.createCfdiPage__calculated-row {
display: flex;
justify-content: space-between;
padding: 0.5rem 0;
border-bottom: 1px solid var(--border-light);
}
.createCfdiPage__calculated-row:last-child {
border-bottom: none;
padding-top: 1rem;
margin-top: 0.5rem;
border-top: 2px solid var(--border-light);
}
.createCfdiPage__calculated-label {
font-size: 0.875rem;
opacity: 0.9;
}
.createCfdiPage__calculated-value {
font-weight: 700;
font-size: 1rem;
}
.createCfdiPage__calculated-row:last-child .createCfdiPage__calculated-label,
.createCfdiPage__calculated-row:last-child .createCfdiPage__calculated-value {
font-size: 1.25rem;
font-weight: 700;
}
.createCfdiPage__form-actions {
display: flex;
gap: 0.75rem;
justify-content: flex-end;
margin-top: 2rem;
padding-top: 1.5rem;
border-top: 2px solid var(--border-color);
}
.createCfdiPage__success {
padding: 2rem;
text-align: center;
background-color: var(--success-background);
border: 2px solid var(--success-color);
border-radius: 0.5rem;
}
.createCfdiPage__success h3 {
font-size: 1.5rem;
font-weight: 700;
color: var(--success-dark);
margin: 0 0 1rem 0;
}
.createCfdiPage__success p {
font-size: 1rem;
color: var(--success-dark);
margin: 0.5rem 0;
}
/* ? Estilos para el modal de preview PDF - M�S ANCHO */
.createCfdiPage__preview-modal {
width: 100%;
height: 80vh;
display: flex;
flex-direction: column;
}
.createCfdiPage__preview-alert {
margin-bottom: 1rem;
}
.createCfdiPage__preview-iframe-container {
flex: 1;
width: 100%;
border: 1px solid var(--border-color);
border-radius: 0.5rem;
overflow: hidden;
}
.createCfdiPage__preview-iframe {
width: 100%;
height: 100%;
border: none;
}
.createCfdiPage__preview-loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
height: 400px;
gap: 1rem;
}
@media (max-width: 768px) {
.createCfdiPage__steps {
flex-direction: column;
gap: 1rem;
}
.createCfdiPage__step::after {
display: none;
}
.createCfdiPage__form-row--2,
.createCfdiPage__form-row--3,
.createCfdiPage__form-row--4 {
grid-template-columns: 1fr;
}
.createCfdiPage__series-grid {
grid-template-columns: 1fr;
}
.createCfdiPage__summary-grid {
grid-template-columns: 1fr;
}
.createCfdiPage__form-actions {
flex-direction: column;
}
.createCfdiPage__form-actions > * {
width: 100%;
}
/* ? Modal de preview responsivo en m�vil */
.createCfdiPage__preview-modal {
height: 60vh;
}
}
/* ==========================================================================
CREATE CFDI PAGE V2 - MODERN RESPONSIVE STYLES
========================================================================== */
.createCfdiPage {
max-width: 1400px;
margin: 0 auto;
padding: 2rem;
font-family: var(--font-primary);
}
.createCfdiPage__header {
text-align: center;
margin-bottom: 2.5rem;
}
.createCfdiPage__title {
font-size: 2rem;
font-weight: 700;
color: var(--primary-color);
margin-bottom: 0.5rem;
}
.createCfdiPage__subtitle {
font-size: 1.1rem;
color: var(--text-muted);
}
/* ==========================================================================
PROGRESS INDICATOR
========================================================================== */
.createCfdiPage__progress {
display: flex;
align-items: center;
justify-content: center;
margin-bottom: 2.5rem;
padding: 2rem 1.5rem;
background: var(--surface-color);
border-radius: 12px;
border: 1px solid var(--border-color);
box-shadow: var(--shadow-sm);
}
.createCfdiPage__progress-step {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.75rem;
}
.createCfdiPage__progress-number {
width: 48px;
height: 48px;
border-radius: 50%;
background: var(--secondary-background);
color: var(--text-muted);
display: flex;
align-items: center;
justify-content: center;
font-weight: 700;
font-size: 1.2rem;
border: 2px solid var(--border-color);
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.createCfdiPage__progress-step.active .createCfdiPage__progress-number {
background: var(--primary-color);
color: var(--primary-foreground);
border-color: var(--primary-color);
transform: scale(1.1);
box-shadow: 0 0 0 4px var(--hover-background-color);
}
.createCfdiPage__progress-step.completed .createCfdiPage__progress-number {
background: var(--success-color);
color: var(--success-foreground);
border-color: var(--success-color);
}
.createCfdiPage__progress-label {
font-size: 0.875rem;
font-weight: 600;
color: var(--text-muted);
transition: color 0.3s ease;
}
.createCfdiPage__progress-step.active .createCfdiPage__progress-label {
color: var(--primary-color);
}
.createCfdiPage__progress-step.completed .createCfdiPage__progress-label {
color: var(--success-color);
}
.createCfdiPage__progress-line {
flex: 1;
height: 3px;
background: var(--border-color);
margin: 0 1.5rem;
position: relative;
top: -15px;
border-radius: 2px;
transition: background 0.3s ease;
}
.createCfdiPage__progress-line.completed {
background: var(--success-color);
}
/* ==========================================================================
CARD & CONTENT
========================================================================== */
.createCfdiPage__card {
margin-bottom: 2rem;
}
.createCfdiPage__step {
padding: 1.5rem 0;
}
.createCfdiPage__step-description {
font-size: 1rem;
color: var(--text-secondary);
margin-bottom: 2rem;
padding: 1rem 1.25rem;
background: var(--info-background);
border-left: 4px solid var(--info-color);
border-radius: 8px;
line-height: 1.6;
}
.createCfdiPage__error-banner {
display: flex;
align-items: flex-start;
gap: 1rem;
padding: 1rem 1.5rem;
background: var(--danger-background);
border: 1px solid var(--danger-color);
border-radius: 8px;
margin-bottom: 2rem;
color: var(--error-text);
}
.createCfdiPage__error-icon {
font-size: 1.5rem;
line-height: 1;
}
/* ==========================================================================
PAYMENT SELECTOR
========================================================================== */
.createCfdiPage__payment-selector {
padding: 1.5rem;
background: var(--surface-color);
border-radius: 12px;
border: 1px solid var(--border-color);
}
.createCfdiPage__payment-preview {
margin: 1.5rem 0;
padding: 1.5rem;
background: var(--success-background);
border: 2px solid var(--success-color);
border-radius: 12px;
box-shadow: var(--shadow-sm);
}
.createCfdiPage__payment-preview-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 1.5rem;
padding-bottom: 1rem;
border-bottom: 1px solid var(--success-color);
}
.createCfdiPage__payment-preview-header h4 {
font-size: 1.15rem;
font-weight: 700;
color: var(--success-color);
margin: 0;
}
.createCfdiPage__switch-link {
margin-top: 1.5rem;
padding: 1rem;
background: var(--hover-background-color);
border-radius: 8px;
text-align: center;
}
.createCfdiPage__switch-link p {
margin: 0;
color: var(--text-secondary);
}
.createCfdiPage__switch-link a {
color: var(--link-color);
font-weight: 600;
cursor: pointer;
text-decoration: underline;
transition: color 0.2s ease;
}
.createCfdiPage__switch-link a:hover {
color: var(--link-hover-color);
}
/* ==========================================================================
FORM GRID - RESPONSIVE
========================================================================== */
.createCfdiPage__form-grid {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
.createCfdiPage__form-row {
display: grid;
gap: 1.25rem;
align-items: start;
}
.createCfdiPage__form-row--2 {
grid-template-columns: 1fr;
}
.createCfdiPage__form-row--3 {
grid-template-columns: 1fr;
}
.createCfdiPage__form-row--4 {
grid-template-columns: 1fr;
}
.createCfdiPage__section-title {
font-size: 1.25rem;
font-weight: 700;
color: var(--primary-color);
margin: 2.5rem 0 1.25rem 0;
padding-bottom: 0.75rem;
border-bottom: 2px solid var(--primary-color);
position: relative;
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: 1rem;
}
.createCfdiPage__section-title::after {
content: '';
position: absolute;
bottom: -2px;
left: 0;
width: 60px;
height: 2px;
background: var(--accent-color);
}
.createCfdiPage__section-title .float-end {
margin-left: auto;
}
.createCfdiPage__field {
margin-bottom: 1.5rem;
}
/* ==========================================================================
PREVIEWS (Payment, CSD, Serie)
========================================================================== */
.createCfdiPage__csd-preview,
.createCfdiPage__serie-preview {
margin: 2rem 0;
padding: 1.5rem;
background: var(--info-background);
border: 2px solid var(--info-color);
border-radius: 12px;
box-shadow: var(--shadow-sm);
}
.createCfdiPage__csd-preview h4,
.createCfdiPage__serie-preview h4 {
font-size: 1.15rem;
font-weight: 700;
color: var(--info-color);
margin-bottom: 1.25rem;
padding-bottom: 0.75rem;
border-bottom: 1px solid var(--info-color);
}
.createCfdiPage__payment-details,
.createCfdiPage__csd-details,
.createCfdiPage__serie-details {
display: grid;
grid-template-columns: 1fr;
gap: 1rem;
}
.createCfdiPage__detail-row {
display: flex;
justify-content: space-between;
align-items: center;
padding: 0.75rem;
background: var(--surface-color);
border-radius: 6px;
border-left: 3px solid var(--border-color);
transition: all 0.2s ease;
}
.createCfdiPage__detail-row:hover {
background: var(--hover-background-color);
border-left-color: var(--primary-color);
}
.createCfdiPage__detail-row .label {
font-weight: 600;
color: var(--text-muted);
font-size: 0.9rem;
}
.createCfdiPage__detail-row .value {
font-weight: 600;
color: var(--text-color);
text-align: right;
}
/* ==========================================================================
TOTALS SUMMARY
========================================================================== */
.createCfdiPage__totals-summary {
margin: 2.5rem 0;
padding: 2rem;
background: var(--surface-color);
border-radius: 12px;
border: 2px solid var(--primary-color);
box-shadow: var(--shadow-md);
}
.createCfdiPage__totals-summary h4 {
font-size: 1.3rem;
font-weight: 700;
color: var(--primary-color);
margin-bottom: 1.5rem;
display: flex;
align-items: center;
gap: 0.5rem;
}
.createCfdiPage__totals-summary h4::before {
content: '??';
font-size: 1.5rem;
}
.createCfdiPage__totals-grid {
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.createCfdiPage__total-row {
display: flex;
justify-content: space-between;
align-items: center;
padding: 1rem 1.25rem;
background: var(--secondary-background);
border-radius: 8px;
font-size: 1rem;
transition: all 0.2s ease;
}
.createCfdiPage__total-row:hover {
background: var(--hover-background-color);
transform: translateX(4px);
}
.createCfdiPage__total-row .label {
font-weight: 600;
color: var(--text-secondary);
}
.createCfdiPage__total-row .value {
font-weight: 700;
color: var(--text-color);
font-size: 1.1rem;
}
.createCfdiPage__total-row .value.discount {
color: var(--warning-color);
}
.createCfdiPage__total-row.total {
background: var(--primary-color);
margin-top: 0.5rem;
padding: 1.25rem;
font-size: 1.2rem;
box-shadow: var(--shadow-md);
}
.createCfdiPage__total-row.total:hover {
transform: translateX(0);
background: var(--primary-hover);
}
.createCfdiPage__total-row.total .label,
.createCfdiPage__total-row.total .value {
color: var(--primary-foreground);
font-weight: 700;
}
.createCfdiPage__total-row.total .value {
font-size: 1.5rem;
}
.createCfdiPage__total-row.validation {
background: var(--surface-color);
border: 2px solid var(--border-color);
flex-wrap: wrap;
gap: 0.5rem;
}
.createCfdiPage__total-row.validation .validation-error {
display: flex;
align-items: center;
gap: 0.5rem;
color: var(--danger-color);
font-weight: 700;
font-size: 0.95rem;
width: 100%;
justify-content: flex-end;
}
.createCfdiPage__total-row.validation .validation-success {
display: flex;
align-items: center;
gap: 0.5rem;
color: var(--success-color);
font-weight: 700;
font-size: 0.95rem;
width: 100%;
justify-content: flex-end;
}
/* ==========================================================================
FINAL WARNING
========================================================================== */
.createCfdiPage__final-warning {
display: flex;
gap: 1.25rem;
padding: 1.75rem;
background: var(--warning-background);
border: 2px solid var(--warning-color);
border-radius: 12px;
margin: 2rem 0;
box-shadow: var(--shadow-sm);
}
.createCfdiPage__warning-icon {
font-size: 2rem;
line-height: 1;
flex-shrink: 0;
}
.createCfdiPage__final-warning > div {
flex: 1;
}
.createCfdiPage__final-warning p {
margin: 0.5rem 0;
color: var(--text-color);
line-height: 1.6;
}
.createCfdiPage__final-warning strong {
color: var(--warning-color);
font-weight: 700;
}
/* ==========================================================================
ACTIONS (Navigation Buttons)
========================================================================== */
.createCfdiPage__actions {
display: flex;
gap: 1rem;
justify-content: center;
flex-wrap: wrap;
margin-top: 2.5rem;
padding-top: 2rem;
border-top: 2px solid var(--border-color);
}
.createCfdiPage__actions > * {
min-width: 160px;
}
/* ==========================================================================
CONCEPTOS LIST
========================================================================== */
.createCfdiPage__conceptos-list {
display: flex;
flex-direction: column;
gap: 1.5rem;
margin-top: 1rem;
}
.createCfdiPage__concepto-card {
background: var(--surface-color);
border: 2px solid var(--border-color);
border-radius: 12px;
padding: 1.5rem;
box-shadow: var(--shadow-sm);
transition: all 0.3s ease;
}
.createCfdiPage__concepto-card:hover {
border-color: var(--primary-color);
box-shadow: var(--shadow-md);
}
.createCfdiPage__concepto-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 1.5rem;
padding-bottom: 1rem;
border-bottom: 2px solid var(--border-color);
}
.createCfdiPage__concepto-header h4 {
margin: 0;
font-size: 1.1rem;
color: var(--text-color);
display: flex;
align-items: center;
gap: 0.5rem;
}
.createCfdiPage__concepto-header h4 i {
color: var(--primary-color);
}
.createCfdiPage__concepto-body {
display: flex;
flex-direction: column;
gap: 1rem;
}
.createCfdiPage__concepto-fields {
display: grid;
grid-template-columns: 1fr;
gap: 1rem;
}
.createCfdiPage__concepto-descripcion {
grid-column: 1 / -1;
}
.createCfdiPage__concepto-summary {
background: var(--secondary-background);
border: 1px solid var(--border-color);
border-radius: 8px;
padding: 1rem;
margin-top: 1rem;
}
.createCfdiPage__concepto-summary-row {
display: flex;
justify-content: space-between;
align-items: center;
padding: 0.5rem 0;
border-bottom: 1px dashed var(--border-color);
}
.createCfdiPage__concepto-summary-row:last-child {
border-bottom: none;
}
.createCfdiPage__concepto-summary-row.total {
border-top: 2px solid var(--border-color);
margin-top: 0.5rem;
padding-top: 0.75rem;
font-weight: 600;
font-size: 1.05rem;
color: var(--primary-color);
}
.createCfdiPage__concepto-summary-row span:first-child {
color: var(--text-secondary);
font-size: 0.9rem;
}
.createCfdiPage__concepto-summary-row span:last-child {
font-weight: 500;
color: var(--text-color);
}
.createCfdiPage__concepto-summary-row .text-danger {
color: var(--danger-color);
}
/* ==========================================================================
PASO 3: CSD + SERIE (Responsive Grid)
========================================================================== */
.createCfdiPage__step3-grid {
display: grid;
grid-template-columns: 1fr;
gap: 2rem;
margin-top: 2rem;
}
.createCfdiPage__selector-section {
background: var(--surface-color);
border: 2px solid var(--border-color);
border-radius: 0.75rem;
padding: 1.5rem;
box-shadow: var(--shadow-sm);
transition: all 0.3s ease;
height: fit-content;
}
.createCfdiPage__selector-section:hover {
border-color: var(--primary-color);
box-shadow: var(--shadow-md);
}
.createCfdiPage__selector-title {
font-size: 1.25rem;
font-weight: 700;
color: var(--primary-color);
margin-bottom: 1rem;
padding-bottom: 0.75rem;
border-bottom: 2px solid var(--border-color);
display: flex;
align-items: center;
gap: 0.5rem;
}
.createCfdiPage__selected-preview {
margin-top: 1.5rem;
padding: 1rem;
background: var(--success-background);
border: 1px solid var(--success-color);
border-radius: 0.5rem;
max-height: 400px;
overflow-y: auto;
}
.createCfdiPage__selected-preview h4 {
color: var(--success-dark, var(--success-color));
font-size: 1rem;
margin-bottom: 0.75rem;
display: flex;
align-items: center;
gap: 0.5rem;
}
.createCfdiPage__selected-preview h4::before {
content: "✓";
display: inline-flex;
align-items: center;
justify-content: center;
width: 1.5rem;
height: 1.5rem;
background: var(--success-color);
color: var(--success-foreground, white);
border-radius: 50%;
font-weight: 700;
font-size: 0.875rem;
}
.createCfdiPage__preview-grid {
display: grid;
grid-template-columns: 1fr;
gap: 0.5rem;
}
.createCfdiPage__preview-item {
display: flex;
flex-direction: column;
gap: 0.25rem;
padding: 0.5rem;
background: var(--surface-color);
border-radius: 0.375rem;
}
.createCfdiPage__preview-item .label {
font-size: 0.75rem;
text-transform: uppercase;
font-weight: 600;
color: var(--text-muted);
}
.createCfdiPage__preview-item .value {
font-size: 0.875rem;
font-weight: 500;
color: var(--text-color);
word-break: break-word;
}
.createCfdiPage__preview-item .value.mono {
font-family: 'Courier New', monospace;
color: var(--primary-color);
}
/* ==========================================================================
PASO 2: FISCAL + CONCEPTOS (Responsive Grid)
========================================================================== */
.createCfdiPage__step2-grid {
display: grid;
grid-template-columns: 1fr;
gap: 2rem;
margin-top: 2rem;
}
.createCfdiPage__fiscal-data {
background: var(--surface-color);
border: 2px solid var(--border-color);
border-radius: 0.75rem;
padding: 1.5rem;
box-shadow: var(--shadow-sm);
height: fit-content;
}
.createCfdiPage__conceptos-section {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
/* ==========================================================================
MODALS
========================================================================== */
.createCfdiPage__error-modal,
.createCfdiPage__warning-modal,
.createCfdiPage__preview-modal {
padding: 1rem;
}
.createCfdiPage__error-modal-message {
padding: 1.25rem;
background: var(--danger-background);
border-left: 4px solid var(--danger-color);
border-radius: 8px;
margin-bottom: 1.5rem;
}
.createCfdiPage__error-modal-message p {
margin: 0;
font-size: 1.05rem;
color: var(--error-text);
line-height: 1.6;
}
.createCfdiPage__error-modal-details {
padding: 1.25rem;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 8px;
margin-bottom: 1.5rem;
}
.createCfdiPage__error-modal-details h4 {
font-size: 1rem;
font-weight: 700;
color: var(--text-color);
margin: 0 0 1rem 0;
}
.createCfdiPage__error-modal-details-content {
padding: 1rem;
background: var(--secondary-background);
border-radius: 6px;
font-family: 'Courier New', monospace;
font-size: 0.9rem;
color: var(--text-color);
line-height: 1.6;
word-break: break-word;
max-height: 300px;
overflow-y: auto;
}
.createCfdiPage__error-modal-help {
padding: 1.25rem;
background: var(--info-background);
border-left: 4px solid var(--info-color);
border-radius: 8px;
}
.createCfdiPage__error-modal-help p {
margin: 0 0 0.75rem 0;
font-weight: 700;
color: var(--text-color);
}
.createCfdiPage__error-modal-help ul {
margin: 0.5rem 0 0 0;
padding-left: 1.5rem;
color: var(--text-secondary);
line-height: 1.8;
}
.createCfdiPage__error-modal-help li {
margin-bottom: 0.5rem;
}
.createCfdiPage__retry-info {
padding: 1.25rem;
background: var(--warning-background);
border: 1px solid var(--warning-color);
border-radius: 8px;
margin-bottom: 1.5rem;
}
.createCfdiPage__retry-info h5 {
font-size: 1rem;
font-weight: 700;
color: var(--warning-color);
margin: 0 0 1rem 0;
display: flex;
align-items: center;
gap: 0.5rem;
}
.createCfdiPage__retry-info ul {
margin: 0;
padding-left: 1.5rem;
color: var(--text-color);
line-height: 1.8;
}
.createCfdiPage__retry-info li {
margin-bottom: 0.75rem;
}
.createCfdiPage__warning-icon-large {
text-align: center;
font-size: 4rem;
color: var(--warning-color);
margin-bottom: 1.5rem;
}
.createCfdiPage__warning-message {
padding: 1.5rem;
background: var(--warning-background);
border-radius: 8px;
margin-bottom: 1.5rem;
}
.createCfdiPage__warning-message h4 {
font-size: 1.2rem;
font-weight: 700;
color: var(--warning-color);
margin: 0 0 1rem 0;
}
.createCfdiPage__warning-message p {
margin: 0.75rem 0;
color: var(--text-color);
line-height: 1.6;
}
.createCfdiPage__warning-message ul {
margin: 1rem 0;
padding-left: 1.5rem;
color: var(--text-color);
}
.createCfdiPage__warning-message li {
margin-bottom: 0.75rem;
line-height: 1.6;
}
.createCfdiPage__warning-exception {
padding: 1.25rem;
background: var(--info-background);
border-left: 4px solid var(--info-color);
border-radius: 8px;
margin-bottom: 1.5rem;
}
.createCfdiPage__warning-exception h5 {
font-size: 1rem;
font-weight: 700;
color: var(--info-color);
margin: 0 0 0.75rem 0;
}
.createCfdiPage__warning-exception p {
margin: 0;
color: var(--text-color);
line-height: 1.6;
}
.createCfdiPage__warning-totals {
padding: 1.25rem;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 8px;
}
.createCfdiPage__warning-totals h5 {
font-size: 1rem;
font-weight: 700;
color: var(--text-color);
margin: 0 0 1rem 0;
}
.totals-summary-compact {
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.totals-summary-compact .total-row {
display: flex;
justify-content: space-between;
padding: 0.75rem;
background: var(--secondary-background);
border-radius: 6px;
}
.totals-summary-compact .total-row.total {
background: var(--primary-color);
color: var(--primary-foreground);
font-weight: 700;
font-size: 1.1rem;
}
.createCfdiPage__preview-alert {
margin-bottom: 1.5rem;
}
.createCfdiPage__preview-iframe-container {
width: 100%;
height: 70vh;
min-height: 500px;
border: 2px solid var(--border-color);
border-radius: 8px;
overflow: hidden;
background: var(--surface-color);
}
.createCfdiPage__preview-iframe {
width: 100%;
height: 100%;
border: none;
}
.createCfdiPage__preview-loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
padding: 4rem 2rem;
gap: 1.5rem;
}
.createCfdiPage__preview-loading p {
font-size: 1.1rem;
color: var(--text-secondary);
margin: 0;
}
/* ==========================================================================
ERROR & LOADING STATES
========================================================================== */
.createCfdiPage__error {
padding: 2rem;
text-align: center;
color: var(--error-text);
background: var(--danger-background);
border-radius: 8px;
border: 1px solid var(--danger-color);
}
.createCfdiPage__step > .appSpinner {
margin: 3rem 0;
}
/* ==========================================================================
UTILITY CLASSES
========================================================================== */
.text-muted {
color: var(--text-muted) !important;
}
.text-danger {
color: var(--danger-color) !important;
}
.text-success {
color: var(--success-color) !important;
}
.text-warning {
color: var(--warning-color) !important;
}
.text-info {
color: var(--info-color) !important;
}
.float-end {
float: right !important;
}
/* ==========================================================================
RESPONSIVE BREAKPOINTS
========================================================================== */
/* Tablets (768px+): 2 columnas */
@media (min-width: 768px) {
.createCfdiPage__form-row--2,
.createCfdiPage__form-row--3,
.createCfdiPage__form-row--4 {
grid-template-columns: repeat(2, 1fr);
}
.createCfdiPage__step3-grid {
grid-template-columns: 1fr 1fr;
gap: 2.5rem;
}
.createCfdiPage__payment-details,
.createCfdiPage__csd-details,
.createCfdiPage__serie-details {
grid-template-columns: repeat(2, 1fr);
}
.createCfdiPage__concepto-fields {
grid-template-columns: repeat(2, 1fr);
}
}
/* Tablets grandes (968px+): Fiscal sidebar */
@media (min-width: 968px) {
.createCfdiPage__step2-grid {
grid-template-columns: 380px 1fr;
gap: 2.5rem;
align-items: start;
}
.createCfdiPage__fiscal-data {
position: sticky;
top: 2rem;
max-height: calc(100vh - 4rem);
overflow-y: auto;
}
}
/* Desktop (1200px+): 3 columnas, grids optimizados */
@media (min-width: 1200px) {
.createCfdiPage__form-row--3,
.createCfdiPage__form-row--4 {
grid-template-columns: repeat(3, 1fr);
}
.createCfdiPage__step3-grid {
gap: 3rem;
max-width: 1400px;
margin: 2rem auto 0;
}
.createCfdiPage__concepto-fields {
grid-template-columns: repeat(3, 1fr);
}
}
/* Desktop XL (1400px+): 4 columnas, preview grid 2 cols */
@media (min-width: 1400px) {
.createCfdiPage__form-row--4 {
grid-template-columns: repeat(4, 1fr);
}
.createCfdiPage__step2-grid {
grid-template-columns: 420px 1fr;
gap: 3rem;
max-width: 1600px;
margin: 2rem auto 0;
}
.createCfdiPage__preview-grid {
grid-template-columns: repeat(2, 1fr);
gap: 0.75rem;
}
}
/* Mobile (<768px): Todo en 1 columna, ajustes de padding */
@media (max-width: 767px) {
.createCfdiPage {
padding: 1rem;
}
.createCfdiPage__title {
font-size: 1.5rem;
}
.createCfdiPage__subtitle {
font-size: 1rem;
}
.createCfdiPage__progress {
flex-direction: column;
gap: 1rem;
padding: 1.5rem 1rem;
}
.createCfdiPage__progress-line {
width: 3px;
height: 40px;
margin: 0;
top: 0;
}
.createCfdiPage__actions {
flex-direction: column;
}
.createCfdiPage__actions > * {
width: 100%;
min-width: unset;
}
.createCfdiPage__total-row {
padding: 0.875rem 1rem;
font-size: 0.95rem;
}
.createCfdiPage__total-row.total {
font-size: 1.1rem;
}
.createCfdiPage__total-row.total .value {
font-size: 1.3rem;
}
.createCfdiPage__section-title {
flex-direction: column;
align-items: flex-start;
}
.createCfdiPage__concepto-card {
padding: 1rem;
}
.createCfdiPage__concepto-header {
flex-direction: column;
align-items: flex-start;
gap: 1rem;
}
.createCfdiPage__selector-section,
.createCfdiPage__fiscal-data {
padding: 1rem;
}
.createCfdiPage__selected-preview {
max-height: 300px;
}
}
/* Print */
@media print {
.createCfdiPage__progress,
.createCfdiPage__actions {
display: none;
}
}
.csdPage__card {
margin-bottom:1.5rem;
padding:1.5rem;
}
.csdPage__filters {
display: flex;
flex-wrap: wrap;
gap:1rem;
align-items: end;
}
.csdPage__filters > * {
min-width:180px;
}
.csdPage__table-card {
margin-bottom:1rem;
padding:1.5rem;
}
.csdPage__table {
width:100%;
border-collapse: collapse;
}
.csdPage__row--active {
background: var(--color-bg-table-row-active, #e8f5e9);
}
.csdPage__row--inactive {
background: var(--color-bg-table-row-inactive, #fbe9e7);
}
.csdPage__status {
padding:0.25em 0.75em;
border-radius:1em;
font-size:0.95em;
font-weight:600;
display: inline-block;
}
.csdPage__status--active {
background: var(--color-success-bg, #c8e6c9);
color: var(--color-success-text, #256029);
}
.csdPage__status--inactive {
background: var(--color-danger-bg, #ffcdd2);
color: var(--color-danger-text, #b71c1c);
}
.csdPage__empty {
text-align: center;
color: var(--color-text-muted, #888);
font-style: italic;
}
.csdPage__error {
color: var(--color-danger-text, #b71c1c);
margin-bottom:1rem;
}
.csdPage__info {
color: var(--color-info-text, #1976d2);
margin-bottom:1rem;
}
.csdPage__pagination {
margin-top:1.5rem;
display: flex;
justify-content: center;
}
.csdPage__modal {
position: fixed;
top:50%;
left:50%;
min-width:320px;
max-width:90vw;
background: var(--color-bg-modal, #fff);
color: var(--color-text, #222);
border-radius:1rem;
box-shadow:0 2px 24px 0 rgba(0,0,0,0.18);
padding:2rem;
z-index:1000;
transform: translate(-50%, -50%);
display: flex;
flex-direction: column;
gap:1.5rem;
align-items: center;
}
.csdPage__form-grid {
display: grid;
grid-template-columns:1fr 1fr;
gap:1rem 2rem;
}
.csdPage__form-error {
color: var(--color-danger-text, #b71c1c);
font-size:0.95em;
margin-bottom:0.5rem;
min-height:1.2em;
}
.csdPage__form-actions {
display: flex;
gap:1rem;
margin-top:2rem;
justify-content: flex-end;
}
.csdPage__modal-form {
max-width:700px;
width:95vw;
margin:0 auto;
}
/* Styles for CSD page search panel */
.csdPage__card { }
.csdPage__search-form { }
/* Desktop:3 columns for inputs + actions area */
.csdPage__search-grid {
display: grid;
grid-template-columns:1fr 1fr 1fr auto;
gap:1rem;
align-items: end;
}
.csdPage__search-input {
min-width:0;
}
.csdPage__search-actions {
display:flex;
gap:0.5rem;
align-items:center;
justify-self:end;
}
/* Responsive: small screens stack inputs and put actions in their own row; actions inline */
@media (max-width:767px) {
.csdPage__search-grid {
grid-template-columns:1fr;
gap:0.75rem;
}
.csdPage__search-actions {
justify-self:start;
display:flex;
gap:0.5rem;
}
}
@media (max-width:900px) {
.csdPage__filters {
flex-direction: column;
align-items: stretch;
}
.csdPage__table-card, .csdPage__card {
padding:1rem;
}
.csdPage__form-grid {
grid-template-columns:1fr;
}
.csdPage__modal-form {
max-width:99vw;
padding:0.5rem;
}
}
@media (max-width:600px) {
.csdPage__table {
font-size:0.95em;
}
.csdPage__modal {
min-width:90vw;
padding:1rem;
}
}
/* Modo oscuro */
@media (prefers-color-scheme: dark) {
.csdPage__card, .csdPage__table-card {
background: var(--color-bg-card-dark, #23272f);
color: var(--color-text-dark, #f1f1f1);
}
.csdPage__modal {
background: var(--color-bg-modal-dark, #23272f);
color: var(--color-text-dark, #f1f1f1);
}
.csdPage__row--active {
background: var(--color-bg-table-row-active-dark, #294034);
}
.csdPage__row--inactive {
background: var(--color-bg-table-row-inactive-dark, #402929);
}
.csdPage__status--active {
background: var(--color-success-bg-dark, #2e7d32);
color: var(--color-success-text-dark, #b9f6ca);
}
.csdPage__status--inactive {
background: var(--color-danger-bg-dark, #b71c1c);
color: var(--color-danger-text-dark, #ffcdd2);
}
}
/* ============================================
Admin Discounts List Page
Página de administración de descuentos
============================================ */
.admin-discounts {
width: 100%;
max-width: 100%;
padding: var(--spacing-md);
box-sizing: border-box;
}
/* Header */
.admin-discounts__header {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: var(--spacing-lg);
padding-bottom: var(--spacing-md);
border-bottom: 2px solid var(--primary-color);
}
.admin-discounts__title {
font-size: var(--font-size-3xl, 2rem);
font-weight: var(--font-weight-bold, 700);
color: var(--text-primary, var(--text-color));
margin: 0;
letter-spacing: -0.02em;
background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-dark) 100%);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
/* Content */
.admin-discounts__content {
width: 100%;
margin-top: var(--spacing-md);
}
.admin-discounts__loading {
display: flex;
align-items: center;
justify-content: center;
padding: var(--spacing-xl);
}
.admin-discounts__error {
padding: var(--spacing-md);
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: var(--border-radius-md, 8px);
margin: var(--spacing-md) 0;
}
.admin-discounts__empty {
text-align: center;
padding: var(--spacing-xl);
color: var(--text-secondary);
font-size: var(--font-size-lg, 1.125rem);
}
/* Table */
.admin-discounts__table-wrapper {
width: 100%;
overflow-x: auto;
margin-top: var(--spacing-md);
}
.admin-discounts__th {
text-align: left;
white-space: nowrap;
font-size: var(--font-size-sm, 0.875rem);
color: var(--table-header-text);
padding: var(--spacing-sm) var(--spacing-md);
}
.admin-discounts__th--sortable {
cursor: pointer;
user-select: none;
}
.admin-discounts__th--sortable:hover {
color: var(--primary-color);
}
.admin-discounts__td {
padding: var(--spacing-sm) var(--spacing-md);
font-size: var(--font-size-sm, 0.875rem);
vertical-align: middle;
color: var(--text-color);
}
.admin-discounts__td--center {
text-align: center;
}
.admin-discounts__th--actions,
.admin-discounts__td--actions {
width: 50px;
text-align: center;
}
/* Requester */
.admin-discounts__requester {
display: flex;
flex-direction: column;
gap: 2px;
}
.admin-discounts__requester-name {
font-weight: 500;
color: var(--text-color);
}
.admin-discounts__requester-email {
font-size: var(--font-size-xs, 0.75rem);
color: var(--text-muted);
}
/* Badges */
.admin-discounts__badge {
display: inline-block;
padding: 2px 10px;
border-radius: 999px;
font-size: var(--font-size-xs, 0.75rem);
font-weight: 600;
text-transform: capitalize;
}
.admin-discounts__badge--courtesy {
background: var(--info-background);
color: var(--info-foreground);
}
.admin-discounts__badge--sponsor {
background: var(--warning-background);
color: var(--warning-foreground);
}
.admin-discounts__badge--purchase {
background: var(--success-background);
color: var(--success-foreground);
}
/* Status */
.admin-discounts__status {
display: inline-block;
padding: 2px 10px;
border-radius: 999px;
font-size: var(--font-size-xs, 0.75rem);
font-weight: 600;
}
.admin-discounts__status--active {
background: var(--success-background);
color: var(--success-foreground);
}
.admin-discounts__status--inactive {
background: var(--danger-background);
color: var(--danger-foreground);
}
/* Code Status */
.admin-discounts__code-status {
display: inline-block;
padding: 2px 10px;
border-radius: 999px;
font-size: var(--font-size-xs, 0.75rem);
font-weight: 600;
}
.admin-discounts__code-status--available {
background: var(--success-background);
color: var(--success-foreground);
}
.admin-discounts__code-status--redeemed {
background: var(--warning-background);
color: var(--warning-foreground);
}
.admin-discounts__code-status--inactive {
background: var(--danger-background);
color: var(--danger-foreground);
}
/* Code Text */
.admin-discounts__code-text {
font-family: 'Courier New', Courier, monospace;
font-size: var(--font-size-sm, 0.875rem);
font-weight: 700;
letter-spacing: 0.08em;
background: var(--secondary-background);
padding: 2px 8px;
border-radius: var(--border-radius-sm, 4px);
color: var(--text-color);
}
/* Item badge */
.admin-discounts__item-badge {
display: inline-block;
padding: 1px 8px;
border-radius: 999px;
font-size: var(--font-size-xs, 0.75rem);
background: var(--info-background);
color: var(--info-foreground);
margin: 1px 2px;
}
.admin-discounts__date-small {
display: block;
font-size: var(--font-size-xs, 0.75rem);
color: var(--text-muted);
}
/* Filters */
.admin-discounts__filter-group {
margin-bottom: var(--spacing-md);
}
.admin-discounts__filter-divider {
border-top: 1px solid var(--divider-color);
margin: var(--spacing-md) 0;
}
.admin-discounts__label {
display: block;
font-size: var(--font-size-sm, 0.875rem);
font-weight: 500;
color: var(--text-secondary);
margin-bottom: var(--spacing-xs, 4px);
}
/* Stats button */
.admin-discounts__stats-btn {
font-size: var(--font-size-sm, 0.875rem);
}
/* Grant form */
.admin-discounts__grant-form {
display: flex;
flex-direction: column;
gap: var(--spacing-md);
}
.admin-discounts__field {
margin-bottom: var(--spacing-sm);
}
.admin-discounts__item-row {
display: flex;
align-items: center;
gap: var(--spacing-sm);
margin-bottom: var(--spacing-sm);
padding: var(--spacing-sm);
background: var(--secondary-background);
border-radius: var(--border-radius-md, 8px);
}
.admin-discounts__item-row-fields {
display: flex;
gap: var(--spacing-sm);
flex: 1;
flex-wrap: wrap;
}
.admin-discounts__select-mini,
.admin-discounts__input-mini {
padding: 6px 10px;
border: 1px solid var(--border-color);
border-radius: var(--border-radius-sm, 4px);
font-size: var(--font-size-sm, 0.875rem);
background: var(--surface-color);
color: var(--text-color);
min-width: 120px;
}
.admin-discounts__select-mini:focus,
.admin-discounts__input-mini:focus {
outline: none;
border-color: var(--focus-color);
box-shadow: 0 0 0 3px var(--focus-ring);
}
.admin-discounts__btn-remove-item {
display: flex;
align-items: center;
justify-content: center;
background: none;
border: 1px solid transparent;
cursor: pointer;
color: var(--danger-color);
padding: 6px;
border-radius: var(--border-radius-sm, 4px);
flex-shrink: 0;
min-width: 32px;
min-height: 32px;
transition: background 0.15s, border-color 0.15s;
}
.admin-discounts__btn-remove-item:hover {
background: var(--danger-background);
border-color: var(--danger-color);
}
.admin-discounts__btn-add-item {
font-size: var(--font-size-sm, 0.875rem);
align-self: flex-start;
}
/* Grant form grid */
.admin-discounts__grant-form {
display: flex;
flex-direction: column;
gap: var(--spacing-md);
}
.admin-discounts__grant-row {
display: grid;
grid-template-columns: 1fr 1fr;
gap: var(--spacing-md);
}
.admin-discounts__grant-row--3 {
grid-template-columns: 1fr 1fr 1fr;
}
.admin-discounts__grant-col {
display: flex;
flex-direction: column;
gap: var(--spacing-xs, 4px);
min-width: 0;
}
/* Item rows */
.admin-discounts__item-row {
display: flex;
align-items: flex-end;
gap: var(--spacing-sm);
margin-bottom: var(--spacing-sm);
}
.admin-discounts__item-row-fields {
display: flex;
flex: 1;
gap: var(--spacing-sm);
flex-wrap: wrap;
}
.admin-discounts__item-field {
display: flex;
flex-direction: column;
gap: 2px;
min-width: 100px;
flex: 1;
}
.admin-discounts__item-field--category {
flex: 2;
min-width: 160px;
}
.admin-discounts__item-field-label {
font-size: var(--font-size-xs, 0.75rem);
color: var(--text-muted);
font-weight: 500;
}
/* Loading inline */
.admin-discounts__loading-inline {
display: flex;
align-items: center;
gap: var(--spacing-sm);
font-size: var(--font-size-sm, 0.875rem);
color: var(--text-muted);
padding: var(--spacing-sm) 0;
}
/* PPD banner */
.admin-discounts__payment-ppd {
display: flex;
align-items: flex-start;
gap: var(--spacing-sm);
padding: var(--spacing-md);
background: var(--warning-background);
color: var(--warning-foreground);
border-radius: var(--border-radius-md, 8px);
border: 1px solid var(--warning-color);
}
.admin-discounts__payment-ppd p {
margin: 4px 0 0;
font-size: var(--font-size-sm, 0.875rem);
font-weight: 400;
}
.admin-discounts__payment-ppd-text {
opacity: 0.85;
}
/* Add item inline button */
.admin-discounts__btn-add-item-inline {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 8px 14px;
border: 1px dashed var(--primary-color);
border-radius: var(--border-radius-sm, 4px);
background: transparent;
color: var(--primary-color);
font-size: var(--font-size-sm, 0.875rem);
font-weight: 600;
cursor: pointer;
transition: background 0.15s, color 0.15s;
}
.admin-discounts__btn-add-item-inline:hover {
background: var(--primary-color);
color: var(--primary-foreground, #fff);
}
.admin-discounts__btn-add-item-inline svg {
flex-shrink: 0;
}
/* Payment Info */
.admin-discounts__payment-info {
padding: var(--spacing-md);
background: var(--surface-alt-color);
border-radius: var(--border-radius-md, 8px);
border: 1px solid var(--border-color);
}
.admin-discounts__payment-info-title {
display: flex;
align-items: center;
gap: var(--spacing-sm);
margin: 0 0 var(--spacing-md) 0;
color: var(--text-secondary);
font-size: var(--font-size-md, 1rem);
font-weight: 600;
}
/* Grant result */
.admin-discounts__grant-result {
text-align: center;
padding: var(--spacing-lg);
}
.admin-discounts__grant-result-icon {
width: 60px;
height: 60px;
display: flex;
align-items: center;
justify-content: center;
border-radius: 50%;
background: var(--success-background);
color: var(--success-foreground);
margin: 0 auto var(--spacing-md);
}
.admin-discounts__grant-result-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: var(--spacing-sm);
text-align: left;
max-width: 400px;
margin: var(--spacing-md) auto 0;
font-size: var(--font-size-sm, 0.875rem);
}
/* Confirm */
.admin-discounts__confirm-text {
font-size: var(--font-size-md, 1rem);
color: var(--text-color);
}
/* Stats */
.admin-discounts__stats-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: var(--spacing-md);
margin-top: var(--spacing-lg);
}
.admin-discounts__stat-card {
display: flex;
flex-direction: column;
align-items: center;
padding: var(--spacing-md);
background: var(--surface-alt-color);
border-radius: var(--border-radius-md, 8px);
border: 1px solid var(--border-color);
}
.admin-discounts__stat-value {
font-size: var(--font-size-3xl, 2rem);
font-weight: 700;
color: var(--primary-color);
}
.admin-discounts__stat-label {
font-size: var(--font-size-sm, 0.875rem);
color: var(--text-secondary);
margin-top: var(--spacing-xs, 4px);
}
.admin-discounts__stats-breakdown {
margin-top: var(--spacing-lg);
}
.admin-discounts__stats-row {
display: flex;
justify-content: space-between;
align-items: center;
padding: var(--spacing-sm) 0;
border-bottom: 1px solid var(--divider-color);
}
/* Buttons */
.admin-discounts__btn-primary {
background: var(--primary-color);
color: var(--primary-foreground);
}
.admin-discounts__btn-secondary {
background: var(--secondary-background);
color: var(--text-color);
}
.admin-discounts__btn-danger {
background: var(--danger-color);
color: #fff;
}
.admin-discounts__btn-danger-sm {
font-size: var(--font-size-xs, 0.75rem);
padding: 2px 8px;
background: var(--danger-background);
color: var(--danger-foreground);
border: 1px solid var(--danger-color);
}
/* Codes table wrapper */
.admin-discounts__codes-table-wrapper {
width: 100%;
overflow-x: auto;
}
/* Codes summary header */
.admin-discounts__codes-summary {
display: flex;
flex-wrap: wrap;
gap: var(--spacing-md);
padding: var(--spacing-md);
background: var(--surface-alt-color);
border-radius: var(--border-radius-md, 8px);
border: 1px solid var(--border-color);
margin-bottom: var(--spacing-md);
}
.admin-discounts__codes-summary-item {
display: flex;
flex-direction: column;
gap: 2px;
min-width: 100px;
}
.admin-discounts__codes-summary-label {
font-size: var(--font-size-xs, 0.75rem);
color: var(--text-muted);
font-weight: 500;
text-transform: uppercase;
letter-spacing: 0.03em;
}
.admin-discounts__codes-summary-value {
font-size: var(--font-size-md, 1rem);
font-weight: 600;
color: var(--text-color);
}
/* Codes toolbar (filter + pagination) */
.admin-discounts__codes-toolbar {
display: flex;
justify-content: space-between;
align-items: center;
gap: var(--spacing-md);
padding: var(--spacing-sm) 0;
margin-bottom: var(--spacing-sm);
}
.admin-discounts__codes-toolbar-left {
display: flex;
align-items: center;
gap: var(--spacing-sm);
}
.admin-discounts__codes-toolbar-count {
font-size: var(--font-size-sm, 0.875rem);
color: var(--text-muted);
}
.admin-discounts__codes-toolbar-right {
display: flex;
align-items: center;
gap: var(--spacing-xs, 4px);
}
/* Page buttons */
.admin-discounts__codes-page-btn {
display: inline-flex;
align-items: center;
gap: 4px;
padding: 6px 10px;
border: 1px solid var(--border-color);
border-radius: var(--border-radius-sm, 4px);
background: var(--surface-color);
color: var(--text-color);
font-size: var(--font-size-sm, 0.875rem);
cursor: pointer;
transition: background 0.15s, border-color 0.15s;
}
.admin-discounts__codes-page-btn:hover:not(:disabled) {
background: var(--primary-background);
border-color: var(--primary-color);
color: var(--primary-color);
}
.admin-discounts__codes-page-btn:disabled {
opacity: 0.4;
cursor: not-allowed;
}
.admin-discounts__codes-page-info {
font-size: var(--font-size-sm, 0.875rem);
color: var(--text-secondary);
padding: 0 var(--spacing-xs, 4px);
white-space: nowrap;
}
/* Bottom pagination */
.admin-discounts__codes-pagination-bottom {
display: flex;
justify-content: center;
align-items: center;
gap: var(--spacing-md);
padding: var(--spacing-md) 0 0;
border-top: 1px solid var(--divider-color);
margin-top: var(--spacing-md);
}
/* Code action button (small) */
.admin-discounts__btn-action-sm {
display: inline-flex;
align-items: center;
gap: 4px;
padding: 4px 10px;
border: 1px solid var(--border-color);
border-radius: var(--border-radius-sm, 4px);
background: transparent;
font-size: var(--font-size-xs, 0.75rem);
font-weight: 500;
cursor: pointer;
transition: background 0.15s, border-color 0.15s;
white-space: nowrap;
}
.admin-discounts__btn-action-sm--danger {
color: var(--danger-color);
border-color: var(--danger-color);
}
.admin-discounts__btn-action-sm--danger:hover {
background: var(--danger-background);
}
/* Redeemer info */
.admin-discounts__redeemer-info {
display: flex;
flex-direction: column;
gap: 1px;
}
.admin-discounts__text-muted {
color: var(--text-muted);
}
/* ============================================
Responsive
============================================ */
@media (max-width: 768px) {
.admin-discounts {
padding: var(--spacing-sm);
}
.admin-discounts__title {
font-size: var(--font-size-xl, 1.5rem);
}
.admin-discounts__stats-grid {
grid-template-columns: 1fr;
}
.admin-discounts__grant-result-grid {
grid-template-columns: 1fr;
}
.admin-discounts__grant-row,
.admin-discounts__grant-row--3 {
grid-template-columns: 1fr;
}
.admin-discounts__item-row-fields {
flex-direction: column;
}
.admin-discounts__item-field {
min-width: unset;
}
.admin-discounts__select-mini,
.admin-discounts__input-mini {
width: 100%;
min-width: unset;
}
.admin-discounts__codes-summary {
gap: var(--spacing-sm);
}
.admin-discounts__codes-toolbar {
flex-direction: column;
align-items: flex-start;
}
.admin-discounts__codes-pagination-bottom {
flex-direction: column;
gap: var(--spacing-sm);
}
}
@media (max-width: 480px) {
.admin-discounts__header {
flex-direction: column;
align-items: flex-start;
gap: var(--spacing-sm);
}
}
/* ============================================
Dark mode overrides
============================================ */
[data-theme="dark"] .admin-discounts__code-text {
background: var(--secondary-background);
color: var(--text-color);
}
[data-theme="dark"] .admin-discounts__select-mini,
[data-theme="dark"] .admin-discounts__input-mini {
background: var(--surface-color);
color: var(--text-color);
border-color: var(--border-color);
}
/* ============================================
Buy Discounts Page (User)
============================================ */
.buy-discounts {
width: 100%;
max-width: 700px;
margin: 0 auto;
padding: var(--spacing-md);
box-sizing: border-box;
}
.buy-discounts__loading {
display: flex;
justify-content: center;
padding: var(--spacing-xl);
}
.buy-discounts__error {
padding: var(--spacing-md);
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: var(--border-radius-md, 8px);
margin-bottom: var(--spacing-md);
}
/* Header */
.buy-discounts__header {
margin-bottom: var(--spacing-lg);
text-align: center;
}
.buy-discounts__title {
font-size: var(--font-size-2xl, 1.75rem);
font-weight: 700;
color: var(--text-color);
margin: 0;
}
.buy-discounts__subtitle {
font-size: var(--font-size-sm, 0.875rem);
color: var(--text-secondary);
margin: 4px 0 0;
}
/* Form */
.buy-discounts__form {
display: flex;
flex-direction: column;
gap: var(--spacing-lg);
}
.buy-discounts__field {
display: flex;
flex-direction: column;
gap: var(--spacing-xs, 4px);
}
.buy-discounts__label {
font-size: var(--font-size-sm, 0.875rem);
font-weight: 600;
color: var(--text-secondary);
}
.buy-discounts__hint {
font-size: var(--font-size-xs, 0.75rem);
color: var(--text-muted);
}
.buy-discounts__input,
.buy-discounts__select {
padding: 8px 12px;
border: 1px solid var(--border-color);
border-radius: var(--border-radius-sm, 4px);
font-size: var(--font-size-sm, 0.875rem);
background: var(--surface-color);
color: var(--text-color);
max-width: 200px;
}
.buy-discounts__input:focus,
.buy-discounts__select:focus {
outline: none;
border-color: var(--focus-color);
box-shadow: 0 0 0 3px var(--focus-ring);
}
/* Item rows */
.buy-discounts__item-row {
display: flex;
align-items: flex-end;
gap: var(--spacing-sm);
padding: var(--spacing-md);
background: var(--surface-alt-color);
border: 1px solid var(--border-color);
border-radius: var(--border-radius-md, 8px);
margin-bottom: var(--spacing-sm);
}
.buy-discounts__item-fields {
display: flex;
gap: var(--spacing-md);
flex: 1;
flex-wrap: wrap;
}
.buy-discounts__item-field {
display: flex;
flex-direction: column;
gap: 2px;
min-width: 120px;
flex: 1;
}
.buy-discounts__item-field .buy-discounts__select,
.buy-discounts__item-field .buy-discounts__input {
max-width: none;
width: 100%;
}
.buy-discounts__item-label {
font-size: var(--font-size-xs, 0.75rem);
color: var(--text-muted);
font-weight: 500;
}
.buy-discounts__item-price {
font-size: var(--font-size-lg, 1.125rem);
font-weight: 700;
color: var(--primary-color);
padding-top: 6px;
}
.buy-discounts__btn-remove {
background: none;
border: none;
cursor: pointer;
color: var(--danger-color);
font-size: 1.2rem;
padding: 4px 8px;
border-radius: var(--border-radius-sm, 4px);
align-self: center;
}
.buy-discounts__btn-remove:hover {
background: var(--danger-background);
}
.buy-discounts__btn-add {
font-size: var(--font-size-sm, 0.875rem);
align-self: flex-start;
}
/* Summary */
.buy-discounts__summary {
background: var(--surface-alt-color);
border: 1px solid var(--border-color);
border-radius: var(--border-radius-md, 8px);
padding: var(--spacing-md);
}
.buy-discounts__summary-row {
display: flex;
justify-content: space-between;
padding: var(--spacing-xs, 4px) 0;
font-size: var(--font-size-sm, 0.875rem);
color: var(--text-secondary);
}
.buy-discounts__summary-row--total {
border-top: 2px solid var(--primary-color);
margin-top: var(--spacing-sm);
padding-top: var(--spacing-sm);
}
.buy-discounts__summary-value {
font-weight: 600;
color: var(--text-color);
}
.buy-discounts__summary-total {
font-size: var(--font-size-xl, 1.5rem);
font-weight: 700;
color: var(--primary-color);
}
/* Actions */
.buy-discounts__actions {
display: flex;
justify-content: flex-end;
gap: var(--spacing-md);
}
.buy-discounts__btn-primary {
background: var(--primary-color);
color: var(--primary-foreground);
}
.buy-discounts__btn-secondary {
background: var(--secondary-background);
color: var(--text-color);
}
/* Result */
.buy-discounts__result {
text-align: center;
padding: var(--spacing-lg);
}
.buy-discounts__result-icon {
width: 60px;
height: 60px;
line-height: 60px;
border-radius: 50%;
background: var(--success-background);
color: var(--success-foreground);
font-size: 2rem;
font-weight: 700;
margin: 0 auto var(--spacing-md);
}
.buy-discounts__result-details {
display: grid;
grid-template-columns: 1fr 1fr;
gap: var(--spacing-sm);
text-align: left;
max-width: 400px;
margin: var(--spacing-md) auto;
font-size: var(--font-size-sm, 0.875rem);
}
.buy-discounts__result-message {
color: var(--text-secondary);
font-size: var(--font-size-sm, 0.875rem);
}
.buy-discounts__result-actions {
display: flex;
justify-content: center;
gap: var(--spacing-md);
margin-top: var(--spacing-lg);
}
/* Responsive */
@media (max-width: 600px) {
.buy-discounts__item-fields {
flex-direction: column;
}
.buy-discounts__item-field {
min-width: unset;
}
.buy-discounts__result-details {
grid-template-columns: 1fr;
}
.buy-discounts__actions {
flex-direction: column;
}
}
/* ============================================
My Discounts Page (User)
============================================ */
.my-discounts {
width: 100%;
max-width: 800px;
margin: 0 auto;
padding: var(--spacing-md);
box-sizing: border-box;
}
.my-discounts__loading {
display: flex;
justify-content: center;
padding: var(--spacing-xl);
}
.my-discounts__error {
padding: var(--spacing-md);
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: var(--border-radius-md, 8px);
}
.my-discounts__empty {
text-align: center;
padding: var(--spacing-xl);
color: var(--text-secondary);
}
/* Header */
.my-discounts__header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: var(--spacing-lg);
flex-wrap: wrap;
gap: var(--spacing-sm);
}
.my-discounts__title {
font-size: var(--font-size-2xl, 1.75rem);
font-weight: 700;
color: var(--text-color);
margin: 0;
}
.my-discounts__subtitle {
font-size: var(--font-size-sm, 0.875rem);
color: var(--text-secondary);
margin: 4px 0 0;
}
.my-discounts__buy-btn {
background: var(--primary-color);
color: var(--primary-foreground);
}
/* Batch list */
.my-discounts__batch-list {
display: grid;
gap: var(--spacing-md);
}
.my-discounts__batch-card {
background: var(--card-bg-color);
border: 1px solid var(--border-color);
border-radius: var(--border-radius-md, 8px);
padding: var(--spacing-md);
cursor: pointer;
transition: box-shadow 0.2s, border-color 0.2s;
}
.my-discounts__batch-card:hover {
border-color: var(--primary-color);
box-shadow: var(--shadow-md);
}
.my-discounts__batch-card-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: var(--spacing-sm);
}
.my-discounts__batch-type {
font-weight: 600;
color: var(--primary-color);
text-transform: capitalize;
}
.my-discounts__batch-status {
font-size: var(--font-size-xs, 0.75rem);
padding: 2px 10px;
border-radius: 999px;
font-weight: 600;
}
.my-discounts__batch-status--active {
background: var(--success-background);
color: var(--success-foreground);
}
.my-discounts__batch-status--inactive {
background: var(--danger-background);
color: var(--danger-foreground);
}
.my-discounts__batch-card-body {
display: flex;
gap: var(--spacing-lg);
margin-bottom: var(--spacing-sm);
}
.my-discounts__batch-stat {
display: flex;
flex-direction: column;
align-items: center;
}
.my-discounts__batch-stat-value {
font-size: var(--font-size-2xl, 1.75rem);
font-weight: 700;
color: var(--primary-color);
}
.my-discounts__batch-stat-label {
font-size: var(--font-size-xs, 0.75rem);
color: var(--text-muted);
}
.my-discounts__batch-card-footer {
display: flex;
justify-content: space-between;
align-items: center;
border-top: 1px solid var(--divider-color);
padding-top: var(--spacing-sm);
}
.my-discounts__batch-date {
font-size: var(--font-size-xs, 0.75rem);
color: var(--text-muted);
}
.my-discounts__batch-view {
font-size: var(--font-size-sm, 0.875rem);
color: var(--link-color);
font-weight: 500;
}
/* Codes grid */
.my-discounts__codes-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
gap: var(--spacing-md);
}
.my-discounts__code-card {
background: var(--surface-alt-color);
border: 1px solid var(--border-color);
border-radius: var(--border-radius-md, 8px);
padding: var(--spacing-md);
}
.my-discounts__code-card-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: var(--spacing-sm);
}
.my-discounts__code-text {
font-family: 'Courier New', Courier, monospace;
font-size: var(--font-size-lg, 1.125rem);
font-weight: 700;
letter-spacing: 0.1em;
color: var(--text-color);
}
.my-discounts__code-badge {
font-size: var(--font-size-xs, 0.75rem);
padding: 2px 8px;
border-radius: 999px;
font-weight: 600;
}
.my-discounts__code-badge--available {
background: var(--success-background);
color: var(--success-foreground);
}
.my-discounts__code-badge--redeemed {
background: var(--warning-background);
color: var(--warning-foreground);
}
.my-discounts__code-badge--inactive {
background: var(--danger-background);
color: var(--danger-foreground);
}
.my-discounts__code-items {
display: flex;
flex-wrap: wrap;
gap: 4px;
margin-bottom: var(--spacing-sm);
}
.my-discounts__item-tag {
font-size: var(--font-size-xs, 0.75rem);
padding: 2px 8px;
background: var(--info-background);
color: var(--info-foreground);
border-radius: 999px;
}
.my-discounts__code-redeemed {
font-size: var(--font-size-xs, 0.75rem);
color: var(--text-muted);
border-top: 1px solid var(--divider-color);
padding-top: var(--spacing-xs, 4px);
}
.my-discounts__code-date {
display: block;
color: var(--text-muted);
}
/* Responsive */
@media (max-width: 600px) {
.my-discounts__header {
flex-direction: column;
align-items: flex-start;
}
.my-discounts__codes-grid {
grid-template-columns: 1fr;
}
}
/* EventsListPage - Página de administración de eventos */
.events-list-page {
display: flex;
flex-direction: column;
min-height: 100vh;
background-color: var(--background-color);
}
.events-list-page__title {
margin: 0;
padding: var(--spacing-lg, 1.5rem) var(--spacing-lg, 1.5rem) var(--spacing-md, 1rem);
font-size: var(--font-size-2xl, 1.5rem);
font-weight: 700;
color: var(--text-color);
}
/* Contenido principal */
.events-list-page__content {
flex: 1;
padding: var(--spacing-md, 1rem);
}
/* Estados de carga y vacío */
.events-list-page__loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: var(--spacing-md, 1rem);
padding: var(--spacing-3xl, 3rem);
color: var(--text-muted);
}
.events-list-page__empty {
padding: var(--spacing-3xl, 3rem);
text-align: center;
color: var(--text-muted);
font-size: var(--font-size-lg, 1.125rem);
}
.events-list-page__error {
padding: var(--spacing-md, 1rem);
margin: var(--spacing-md, 1rem);
background-color: var(--danger-background);
color: var(--danger-color);
border: 1px solid var(--danger-color);
border-radius: var(--border-radius-md, 0.375rem);
}
/* Tabla - Solo estilos específicos de esta página */
.events-list-page__table-wrapper {
overflow-x: auto;
background-color: var(--surface-color);
border-radius: var(--border-radius-lg, 0.5rem);
box-shadow: var(--shadow-sm);
border: 1px solid var(--table-border);
}
.events-list-page__th-center {
text-align: center !important;
}
.events-list-page__actions-cell {
text-align: center !important;
}
/* Responsive para tabla en móvil */
@media (max-width: 750px) {
.events-list-page__table-wrapper {
background-color: transparent;
border: none;
box-shadow: none;
border-radius: 0;
}
.events-list-page__content {
padding: var(--spacing-sm, 0.5rem);
}
}
/* Filtros dentro del panel */
.events-list-page__filter-group {
margin-bottom: var(--spacing-lg, 1.5rem);
}
.events-list-page__label {
display: block;
margin-bottom: var(--spacing-xs, 0.25rem);
font-size: var(--font-size-sm, 0.875rem);
font-weight: 500;
color: var(--text-color);
}
/* Formulario de edición/creación */
.events-list-page__form {
display: flex;
flex-direction: column;
gap: var(--spacing-md, 1rem);
}
.events-list-page__row {
display: grid;
gap: var(--spacing-md, 1rem);
grid-template-columns: 1fr;
}
.events-list-page__row--2 {
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}
.events-list-page__row--3 {
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}
.events-list-page__field-inline {
display: flex;
flex-direction: column;
}
.events-list-page__divider {
height: 1px;
margin: var(--spacing-lg, 1.5rem) 0;
background-color: var(--border-color);
}
.events-list-page__actions {
display: flex;
gap: var(--spacing-sm, 0.5rem);
margin-bottom: var(--spacing-md, 1rem);
}
/* Categorías y cuotas */
.events-list-page__categories {
display: flex;
flex-direction: column;
gap: var(--spacing-lg, 1.5rem);
}
/* Categoría colapsable */
.events-list-page__category-collapsible {
background-color: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: var(--border-radius-lg, 0.5rem);
overflow: hidden;
transition: all 0.2s ease;
}
.events-list-page__category-collapsible[open] {
border-color: var(--primary-color);
}
.events-list-page__category-collapsible:hover {
box-shadow: var(--shadow-sm);
}
/* Summary (encabezado colapsable) */
.events-list-page__category-summary {
display: flex;
justify-content: space-between;
align-items: center;
padding: var(--spacing-md, 1rem) var(--spacing-lg, 1.5rem);
background-color: var(--card-category-bg-color);
cursor: pointer;
user-select: none;
list-style: none;
transition: background-color 0.2s ease;
}
.events-list-page__category-summary::-webkit-details-marker {
display: none;
}
.events-list-page__category-summary::marker {
display: none;
}
.events-list-page__category-summary:hover {
background-color: var(--hover-background);
}
.events-list-page__category-collapsible[open] .events-list-page__category-summary {
background-color: var(--primary-color-light, rgba(59, 130, 246, 0.1));
border-bottom: 1px solid var(--border-color);
}
.events-list-page__category-summary-content {
display: flex;
flex-direction: column;
gap: var(--spacing-xs, 0.25rem);
flex: 1;
min-width: 0;
}
.events-list-page__category-summary-content strong {
font-size: var(--font-size-lg, 1.125rem);
font-weight: 600;
color: var(--text-color);
}
.events-list-page__category-summary-info {
display: flex;
gap: var(--spacing-md, 1rem);
flex-wrap: wrap;
font-size: var(--font-size-sm, 0.875rem);
color: var(--text-muted);
}
.events-list-page__category-summary-info .category-name {
font-weight: 500;
color: var(--text-color);
}
.events-list-page__category-summary-info .category-type {
padding: var("--spacing-xs", 0.25rem) var("--spacing-sm", 0.5rem);
background-color: var(--secondary-background);
border-radius: var(--border-radius-sm, 0.25rem);
font-size: var(--font-size-xs, 0.75rem);
}
.events-list-page__category-summary-info .category-fees-count {
padding: var("--spacing-xs", 0.25rem) var("--spacing-sm", 0.5rem);
background-color: var(--info-background);
color: var(--info-color);
border-radius: var(--border-radius-sm, 0.25rem);
font-size: var(--font-size-xs, 0.75rem);
font-weight: 500;
}
.events-list-page__category-summary-actions {
display: flex;
gap: var(--spacing-xs, 0.25rem);
margin-left: var(--spacing-md, 1rem);
}
/* Ícono de expansión personalizado */
.events-list-page__category-summary::before {
content: '▶';
display: inline-block;
margin-right: var(--spacing-sm, 0.5rem);
font-size: var(--font-size-sm, 0.875rem);
color: var(--text-muted);
transition: transform 0.2s ease;
}
.events-list-page__category-collapsible[open] .events-list-page__category-summary::before {
transform: rotate(90deg);
}
/* Contenido de la categoría */
.events-list-page__category-card {
padding: var(--spacing-lg, 1.5rem);
background-color: var(--background-color);
}
.events-list-page__category-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: var(--spacing-md, 1rem);
padding-bottom: var(--spacing-sm, 0.5rem);
border-bottom: 1px solid var(--border-color);
color: var(--text-color);
}
/* Modal actions */
.events-list-page__modal-actions {
display: flex;
gap: var(--spacing-sm, 0.5rem);
margin-top: var(--spacing-lg, 1.5rem);
padding-top: var(--spacing-lg, 1.5rem);
border-top: 1px solid var(--border-color);
}
/* Modal de detalle */
.events-list-page__detail {
display: flex;
flex-direction: column;
gap: var(--spacing-md, 1rem);
}
.events-card__title {
margin: 0 0 var(--spacing-sm, 0.5rem);
font-size: var(--font-size-lg, 1.125rem);
font-weight: 600;
color: var(--text-color);
}
.events-card__meta {
display: flex;
flex-direction: column;
gap: var(--spacing-xs, 0.25rem);
padding: var(--spacing-md, 1rem);
background-color: var(--secondary-background);
border: 1px solid var(--border-color);
border-radius: var(--border-radius-md, 0.375rem);
}
.events-card__meta span {
font-size: var(--font-size-sm, 0.875rem);
color: var(--text-color);
}
.events-card__meta b {
color: var(--text-color);
}
/* Badges */
.badge {
display: inline-block;
padding: var(--spacing-xs, 0.25rem) var(--spacing-sm, 0.5rem);
font-size: var(--font-size-xs, 0.75rem);
font-weight: 600;
border-radius: var(--border-radius-full, 9999px);
}
.badge--success {
background-color: var(--success-background);
color: var(--success-color);
border: 1px solid var(--success-color);
}
.badge--danger {
background-color: var(--danger-background);
color: var(--danger-color);
border: 1px solid var(--danger-color);
}
/* Switch readonly */
.switch-readonly {
pointer-events: none;
opacity: 0.8;
}
/* Input select dentro del formulario */
.events-list-page__form .input {
width: 100%;
padding: var(--spacing-sm, 0.5rem) var(--spacing-md, 1rem);
font-size: var(--font-size-sm, 0.875rem);
background-color: var(--surface-color);
color: var(--text-color);
border: 1px solid var(--border-color);
border-radius: var(--border-radius-md, 0.375rem);
transition: border-color 0.2s ease;
}
.events-list-page__form .input:focus {
outline: none;
border-color: var(--focus-color);
box-shadow: 0 0 0 3px var(--focus-ring);
}
/* Subheader de sección (Cuotas, CFDI) */
.events-list-page__subheader {
display: flex;
justify-content: space-between;
align-items: center;
padding: var(--spacing-sm, 0.5rem) 0;
border-bottom: 1px solid var(--border-color);
margin-bottom: var(--spacing-sm, 0.5rem);
color: var(--text-color);
font-size: var(--font-size-sm, 0.875rem);
}
/* Filas de cuota */
.events-list-page__fee-row {
display: grid;
gap: var(--spacing-sm, 0.5rem);
grid-template-columns: 1fr;
padding: var(--spacing-sm, 0.5rem) 0;
border-bottom: 1px dashed var(--border-color);
align-items: start;
}
.events-list-page__fee-col {
display: flex;
flex-direction: column;
}
.events-list-page__fee-flags {
display: flex;
gap: var(--spacing-sm, 0.5rem);
flex-wrap: wrap;
align-items: center;
}
@media (min-width: 1024px) {
.events-list-page__fee-row {
grid-template-columns: 2fr 1fr 1fr 2fr 1.5fr auto;
align-items: end;
}
.events-list-page__fee-col--range {
grid-column: span 1;
}
}
/* Sección CFDI SAT dentro de cada categoría */
.events-list-page__cfdi-section {
margin-top: var(--spacing-md, 1rem);
padding: var(--spacing-md, 1rem);
background-color: var(--secondary-background);
border: 1px solid var(--border-color);
border-radius: var(--border-radius-md, 0.375rem);
display: flex;
flex-direction: column;
gap: var(--spacing-md, 1rem);
}
.events-list-page__cfdi-badge {
display: inline-block;
padding: var(--spacing-xs, 0.25rem) var(--spacing-sm, 0.5rem);
font-size: var(--font-size-xs, 0.75rem);
font-weight: 600;
border-radius: var(--border-radius-full, 9999px);
}
.events-list-page__cfdi-badge--required {
background-color: var(--warning-background, #fffbeb);
color: var(--warning-color, #b45309);
border: 1px solid var(--warning-color, #b45309);
}
.events-list-page__cfdi-badge--free {
background-color: var(--info-background, #eff6ff);
color: var(--info-color, #1d4ed8);
border: 1px solid var(--info-color, #1d4ed8);
}
.events-list-page__cfdi-auto-info {
display: flex;
flex-wrap: wrap;
gap: var(--spacing-md, 1rem);
font-size: var(--font-size-sm, 0.875rem);
color: var(--text-muted);
}
.events-list-page__cfdi-auto-info span {
padding: var(--spacing-xs, 0.25rem) var(--spacing-sm, 0.5rem);
background-color: var(--surface-color);
border: 1px dashed var(--border-color);
border-radius: var(--border-radius-sm, 0.25rem);
}
.events-list-page__cfdi-auto-info b {
color: var(--text-color);
}
/* Responsive */
@media (min-width: 640px) {
.events-list-page__content {
padding: var(--spacing-lg, 1.5rem);
}
.events-list-page__fee-row {
grid-template-columns: 2fr 1fr 1fr 2fr auto auto;
}
.events-list-page__fee-col--range {
grid-column: span 2;
}
.events-list-page__fee-col--desc {
grid-column: span 1;
}
.events-list-page__fee-col--flags {
grid-column: span 1;
}
}
@media (min-width: 768px) {
.events-list-page__title {
font-size: var(--font-size-3xl, 1.875rem);
padding: var(--spacing-xl, 2rem) var(--spacing-xl, 2rem) var(--spacing-lg, 1.5rem);
}
}
@media (min-width: 1024px) {
.events-list-page__row--2 {
grid-template-columns: repeat(2, 1fr);
}
.events-list-page__row--3 {
grid-template-columns: repeat(3, 1fr);
}
.events-list-page__fee-row {
grid-template-columns: 2fr 1fr 1fr 2fr 1.5fr auto;
}
}
/* Fee colapsable */
.events-list-page__fee-collapsible {
border: 1px solid var(--border-color);
border-radius: var(--border-radius-md, 0.375rem);
overflow: hidden;
transition: border-color 0.2s ease;
}
.events-list-page__fee-collapsible[open] {
border-color: var(--secondary-color);
}
.events-list-page__fee-summary {
display: flex;
justify-content: space-between;
align-items: center;
padding: var(--spacing-sm, 0.5rem) var(--spacing-md, 1rem);
background-color: var(--card-category-bg-color);
cursor: pointer;
user-select: none;
list-style: none;
transition: background-color 0.2s ease;
gap: var(--spacing-sm, 0.5rem);
}
.events-list-page__fee-summary::-webkit-details-marker {
display: none;
}
.events-list-page__fee-summary::marker {
display: none;
}
.events-list-page__fee-summary:hover {
background-color: var(--hover-background-color);
}
.events-list-page__fee-collapsible[open] .events-list-page__fee-summary {
border-bottom: 1px solid var(--border-color);
}
.events-list-page__fee-summary::before {
content: '▶';
display: inline-block;
margin-right: var(--spacing-sm, 0.5rem);
font-size: var(--font-size-xs, 0.75rem);
color: var(--text-muted);
transition: transform 0.2s ease;
flex-shrink: 0;
}
.events-list-page__fee-collapsible[open] .events-list-page__fee-summary::before {
transform: rotate(90deg);
}
.events-list-page__fee-summary-content {
display: flex;
align-items: center;
gap: var(--spacing-md, 1rem);
flex: 1;
min-width: 0;
flex-wrap: wrap;
}
.events-list-page__fee-summary-index {
font-size: var(--font-size-sm, 0.875rem);
font-weight: 600;
color: var(--text-color);
white-space: nowrap;
}
.events-list-page__fee-summary-info {
display: flex;
align-items: center;
gap: var(--spacing-sm, 0.5rem);
font-size: var(--font-size-sm, 0.875rem);
color: var(--text-muted);
flex-wrap: wrap;
}
.events-list-page__fee-summary-amount {
font-weight: 600;
color: var(--success-color);
}
.events-list-page__fee-summary-actions {
display: flex;
gap: var(--spacing-xs, 0.25rem);
flex-shrink: 0;
}
.events-list-page__fee-body {
padding: var(--spacing-md, 1rem);
background-color: var(--background-color);
display: flex;
flex-direction: column;
gap: var(--spacing-md, 1rem);
}
/* ============================================
Admin Inscriptions List Page
Página de administración de inscripciones
============================================ */
.admin-inscriptions-list-page {
width: 100%;
max-width: 100%;
padding: var(--spacing-md);
box-sizing: border-box;
}
/* ============================================
Header y Título
============================================ */
.admin-inscriptions-list-page__header {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: var(--spacing-lg);
padding-bottom: var(--spacing-md);
border-bottom: 2px solid var(--primary-color, #0066cc);
}
.admin-inscriptions-list-page__title {
font-size: var(--font-size-3xl, 2rem);
font-weight: var(--font-weight-bold, 700);
color: var(--text-primary, #1a1a1a);
margin: 0;
letter-spacing: -0.02em;
background: linear-gradient(135deg, var(--primary-color, #0066cc) 0%, var(--primary-dark, #004d99) 100%);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
/* ============================================
Contenido Principal
============================================ */
.admin-inscriptions-list-page__content {
width: 100%;
margin-top: var(--spacing-md);
}
.admin-inscriptions-list-page__loading {
display: flex;
align-items: center;
justify-content: center;
gap: var(--spacing-sm);
padding: var(--spacing-xl);
color: var(--text-secondary);
}
.admin-inscriptions-list-page__error {
padding: var(--spacing-md);
background: var(--error-bg, #fee);
color: var(--error-text, #c00);
border-radius: var(--border-radius-md);
margin: var(--spacing-md) 0;
}
.admin-inscriptions-list-page__empty {
text-align: center;
padding: var(--spacing-xl);
color: var(--text-secondary);
font-size: var(--font-size-lg);
}
/* ============================================
Tabla
============================================ */
.admin-inscriptions-list-page__table-wrapper {
width: 100%;
overflow-x: auto;
margin-top: var(--spacing-md);
}
.admin-inscriptions-list-page__th-center {
text-align: center !important;
}
.admin-inscriptions-list-page__actions-cell {
text-align: center;
}
.admin-inscriptions-list-page__attendance-cell {
text-align: center;
padding: var(--spacing-sm) !important;
}
.admin-inscriptions-list-page__sub-text {
font-size: var(--font-size-xs, 0.75rem);
color: var(--text-secondary, #666);
margin-top: var(--spacing-xs, 0.25rem);
}
/* ============================================
Badges
============================================ */
.admin-inscriptions-list-page__badge {
display: inline-block;
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--border-radius-sm);
font-size: var(--font-size-sm);
font-weight: var(--font-weight-medium);
}
.admin-inscriptions-list-page__badge--success {
background: var(--success-bg, #d4edda);
color: var(--success-text, #155724);
}
.admin-inscriptions-list-page__badge--warning {
background: var(--warning-bg, #fff3cd);
color: var(--warning-text, #856404);
}
.admin-inscriptions-list-page__badge--danger {
background: var(--error-bg, #f8d7da);
color: var(--error-text, #721c24);
}
/* ============================================
Filtros
============================================ */
.admin-inscriptions-list-page__filter-group {
margin-bottom: var(--spacing-md);
}
.admin-inscriptions-list-page__filter-divider {
height: 1px;
background: var(--border-color, #e0e0e0);
margin: var(--spacing-lg) 0;
}
.admin-inscriptions-list-page__label {
display: block;
font-size: var(--font-size-sm);
font-weight: var(--font-weight-medium);
color: var(--text-primary);
margin-bottom: var(--spacing-xs);
display: flex;
align-items: center;
gap: var(--spacing-xs);
}
/* ============================================
Modal Detalle con Adicionales
============================================ */
.admin-inscriptions-list-page__detail {
width: 100%;
}
.admin-inscriptions-list-page__detail-loading {
display: flex;
align-items: center;
justify-content: center;
gap: var(--spacing-sm);
padding: var(--spacing-xl);
color: var(--text-secondary);
}
.admin-inscriptions-list-page__detail-section {
margin-bottom: var(--spacing-lg);
padding: var(--spacing-md);
background: var(--surface-color, #f9f9f9);
border-radius: var(--border-radius-md);
border: 1px solid var(--border-color, #e0e0e0);
}
.admin-inscriptions-list-page__detail-section h3 {
margin: 0 0 var(--spacing-md) 0;
font-size: var(--font-size-lg);
font-weight: var(--font-weight-semibold);
color: var(--primary-color, #0066cc);
border-bottom: 1px solid var(--border-color, #e0e0e0);
padding-bottom: var(--spacing-sm);
}
.admin-inscriptions-list-page__detail-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: var(--spacing-sm);
}
.admin-inscriptions-list-page__detail-row {
padding: var(--spacing-xs) 0;
}
.admin-inscriptions-list-page__detail-row strong {
display: inline-block;
min-width: 120px;
color: var(--text-secondary, #666);
font-weight: var(--font-weight-medium);
}
/* ============================================
Adicionales
============================================ */
.admin-inscriptions-list-page__additionals {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
gap: var(--spacing-md);
}
.admin-inscriptions-list-page__additional-card {
padding: var(--spacing-md);
background: white;
border: 1px solid var(--border-color, #e0e0e0);
border-radius: var(--border-radius-md);
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}
.admin-inscriptions-list-page__additional-header {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: var(--spacing-sm);
font-size: var(--font-size-md);
font-weight: var(--font-weight-semibold);
}
.admin-inscriptions-list-page__additional-info {
font-size: var(--font-size-sm);
color: var(--text-secondary, #666);
}
.admin-inscriptions-list-page__modal-actions {
display: flex;
gap: var(--spacing-sm);
justify-content: flex-end;
margin-top: var(--spacing-lg);
padding-top: var(--spacing-md);
border-top: 1px solid var(--border-color, #e0e0e0);
}
/* ============================================
Switch Readonly
============================================ */
.switch-readonly {
pointer-events: none;
opacity: 0.7;
}
/* ============================================
Responsive
============================================ */
@media (max-width: 768px) {
.admin-inscriptions-list-page {
padding: var(--spacing-sm);
}
.admin-inscriptions-list-page__title {
font-size: var(--font-size-2xl, 1.5rem);
}
.admin-inscriptions-list-page__detail-grid {
grid-template-columns: 1fr;
}
.admin-inscriptions-list-page__additionals {
grid-template-columns: 1fr;
}
.admin-inscriptions-list-page__modal-actions {
flex-direction: column;
}
}
@media (max-width: 480px) {
.admin-inscriptions-list-page__title {
font-size: var(--font-size-xl, 1.25rem);
}
.admin-inscriptions-list-page__attendance-toggle {
width: 32px;
height: 32px;
}
}
/* ============================================
Modo Oscuro
============================================ */
@media (prefers-color-scheme: dark) {
.admin-inscriptions-list-page__title {
color: var(--text-primary-dark, #fff);
}
.admin-inscriptions-list-page__label {
color: var(--text-primary-dark, #fff);
}
.admin-inscriptions-list-page__sub-text {
color: var(--text-secondary-dark, #aaa);
}
.admin-inscriptions-list-page__error {
background: var(--error-bg-dark, #5a1a1a);
color: var(--error-text-dark, #ff9999);
}
.admin-inscriptions-list-page__loading {
color: var(--text-secondary-dark, #bbb);
}
.admin-inscriptions-list-page__empty {
color: var(--text-secondary-dark, #bbb);
}
.admin-inscriptions-list-page__detail-section {
background: var(--surface-color-dark, #2a2a2a);
border-color: var(--border-color-dark, #444);
}
.admin-inscriptions-list-page__detail-section h3 {
color: var(--primary-light, #4d9fff);
border-bottom-color: var(--border-color-dark, #444);
}
.admin-inscriptions-list-page__additional-card {
background: var(--surface-color-dark, #2a2a2a);
border-color: var(--border-color-dark, #444);
}
.admin-inscriptions-list-page__filter-divider {
background: var(--border-color-dark, #444);
}
.admin-inscriptions-list-page__modal-actions {
border-top-color: var(--border-color-dark, #444);
}
.admin-inscriptions-list-page__attendance-toggle--inactive {
background: var(--surface-color-dark, #333);
}
}
.admin-inscriptions-list-page__loading-indicator {
font-size: var(--font-size-xs, 0.75rem);
color: var(--primary-color);
font-weight: normal;
font-style: italic;
}
/* ===============================================
InscriptionListPage
=============================================== */
.inscription-list-page {
display: flex;
flex-direction: column;
gap: 1.25rem;
padding: 1.25rem 1rem;
min-height: 80vh;
background: var(--background-color);
}
/* -----------------------------------------------
Toolbar: título | pill | counter — 1 sola fila
----------------------------------------------- */
.inscription-list-page__toolbar {
display: grid;
grid-template-columns: auto 1fr auto;
align-items: center;
gap: 1rem;
}
.inscription-list-page__title {
margin: 0;
color: var(--text-color);
font-size: 1.5rem;
font-weight: 700;
line-height: 1.2;
white-space: nowrap;
}
.inscription-list-page__counter {
display: flex;
align-items: center;
gap: 0.4rem;
font-size: 0.875rem;
color: var(--text-muted);
white-space: nowrap;
}
/* -----------------------------------------------
Pill de filtros dentro del toolbar
----------------------------------------------- */
.inscription-list-page__filters-form {
display: flex;
flex-direction: row;
align-items: center;
gap: 0;
background: var(--events-pill-bg);
border: 1px solid var(--events-pill-border);
border-radius: 9999px;
box-shadow: var(--events-pill-shadow);
padding: 0.3rem 0.3rem 0.3rem 1rem;
width: 100%;
backdrop-filter: blur(8px);
-webkit-backdrop-filter: blur(8px);
transition: box-shadow 0.2s, border-color 0.2s;
}
.inscription-list-page__filters-form:focus-within {
border-color: var(--focus-color);
box-shadow: var(--events-pill-shadow), 0 0 0 3px var(--focus-ring);
}
/* Divisores visuales */
.inscription-list-page__filters-divider {
width: 1px;
height: 1.5rem;
background: var(--border-color);
flex-shrink: 0;
margin: 0 0.5rem;
}
/* AppInput transparente dentro de la pill */
.inscription-list-page__filters-form .app-input,
.inscription-list-page__filters-form .app-input__control {
border: none;
background: transparent;
box-shadow: none;
outline: none;
padding: 0.4rem 0.5rem 0.4rem 0;
margin: 0;
min-height: unset;
width: 100%;
color: var(--text-color);
font-size: 0.9375rem;
}
.inscription-list-page__filters-form .app-input__control:focus {
border: none;
box-shadow: none;
outline: none;
}
/* AppSelect transparente dentro de la pill */
.inscription-list-page__filters-form .app-select {
margin-bottom: 0;
width: auto;
max-width: 9.5rem;
flex-shrink: 0;
}
.inscription-list-page__filters-form .app-select__control {
border: none;
background: transparent;
box-shadow: none;
padding: 0.4rem 0.75rem;
min-height: unset;
color: var(--text-color);
}
.inscription-list-page__filters-form .app-select__control:hover,
.inscription-list-page__filters-form .app-select__control:focus,
.inscription-list-page__filters-form .app-select__control--open {
border: none;
box-shadow: none;
background: transparent;
}
.inscription-list-page__filters-form .app-select__dropdown {
z-index: 200;
}
/* Botón limpiar (X) circular ghost */
.inscription-list-page__filters-clear {
flex-shrink: 0;
width: 30px;
height: 30px;
min-width: 30px;
padding: 0;
display: flex;
align-items: center;
justify-content: center;
border-radius: 9999px;
background: transparent;
border: none;
color: var(--text-muted);
margin-right: 0.25rem;
transition: color 0.2s, background 0.2s;
box-shadow: none;
}
.inscription-list-page__filters-clear:hover {
color: var(--danger-color);
background: var(--danger-background);
box-shadow: none;
transform: none;
}
.inscription-list-page__filters-clear svg {
color: currentColor;
stroke: currentColor;
display: block;
}
/* Botón buscar circular primario */
.inscription-list-page__filters-button {
flex-shrink: 0;
width: 38px;
height: 38px;
min-width: 38px;
padding: 0;
display: flex;
align-items: center;
justify-content: center;
border-radius: 9999px;
background: var(--primary-color);
border: none;
box-shadow: none;
transition: background 0.2s, transform 0.15s;
}
.inscription-list-page__filters-button:hover {
background: var(--primary-hover);
transform: scale(1.07);
box-shadow: none;
}
.inscription-list-page__filters-button svg {
display: block;
fill: var(--primary-foreground);
color: var(--primary-foreground);
}
/* -----------------------------------------------
Messages
----------------------------------------------- */
.inscription-list-page__error {
padding: 0.75rem 1rem;
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: 0.5rem;
}
.inscription-list-page__info {
padding: 0.75rem 1rem;
background: var(--info-background);
color: var(--info-foreground);
border-radius: 0.5rem;
}
/* -----------------------------------------------
Content / estados
----------------------------------------------- */
.inscription-list-page__loading {
display: flex;
align-items: center;
gap: 0.75rem;
justify-content: center;
padding: 3rem;
color: var(--text-muted);
}
.inscription-list-page__empty {
text-align: center;
padding: 3rem 1rem;
color: var(--text-muted);
font-size: 1.05rem;
}
/* -----------------------------------------------
Cards grid
----------------------------------------------- */
.inscription-list-page__cards {
display: grid;
grid-template-columns: 1fr;
gap: 1rem;
}
.inscription-list-page__cards .app-card {
margin: 0;
padding: 0;
overflow: hidden;
}
.inscription-list-page__pagination {
display: flex;
justify-content: center;
margin-top: 0.5rem;
}
/* -----------------------------------------------
Inscription card — layout horizontal
[poster | body ]
[poster | acciones]
----------------------------------------------- */
.inscription-card {
display: grid;
grid-template-columns: 7rem 1fr;
grid-template-rows: 1fr auto;
min-height: 10rem;
}
.inscription-card__media {
grid-column: 1 / 2;
grid-row: 1 / 3;
position: relative;
overflow: hidden;
background: var(--surface-alt-color);
}
.inscription-card__media img {
width: 100%;
height: 100%;
display: block;
object-fit: cover;
object-position: center top;
}
.inscription-card__badge-dates {
position: absolute;
bottom: 0.4rem;
left: 50%;
transform: translateX(-50%);
background: var(--badge-overlay-bg);
color: var(--text-light);
padding: 0.2rem 0.5rem;
border-radius: 0.35rem;
font-size: 0.7rem;
font-weight: 700;
backdrop-filter: blur(8px);
box-shadow: var(--shadow-md);
border: 1px solid var(--badge-overlay-border);
white-space: nowrap;
width: max-content;
max-width: calc(100% - 0.5rem);
text-align: center;
}
.inscription-card__body {
grid-column: 2 / 3;
grid-row: 1 / 2;
display: flex;
flex-direction: column;
gap: 0.35rem;
padding: 0.875rem 1rem 0.5rem 1rem;
min-width: 0;
}
.inscription-card__title {
font-size: 0.9375rem;
font-weight: 700;
line-height: 1.25;
color: var(--text-color);
display: -webkit-box;
-webkit-line-clamp: 3;
-webkit-box-orient: vertical;
overflow: hidden;
}
.inscription-card__subtitle {
font-size: 0.8125rem;
color: var(--text-muted);
line-height: 1.3;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.inscription-card__code {
display: flex;
align-items: center;
gap: 0.4rem;
flex-wrap: wrap;
margin-top: auto;
padding-top: 0.4rem;
}
.inscription-card__code-label {
font-size: 0.75rem;
color: var(--text-muted);
}
.inscription-card__code-value {
font-size: 0.8125rem;
font-weight: 800;
letter-spacing: 0.04em;
padding: 0.1rem 0.4rem;
border-radius: 0.3rem;
background: var(--primary-light);
color: var(--primary-foreground);
border: 1px solid var(--primary-color);
}
.inscription-card__actions {
grid-column: 2 / 3;
grid-row: 2 / 3;
display: flex;
padding: 0 1rem 0.875rem 1rem;
}
.inscription-card__actions .app-button {
width: 100%;
justify-content: center;
}
/* -----------------------------------------------
Breakpoints
----------------------------------------------- */
@media (min-width: 768px) {
.inscription-list-page__cards {
grid-template-columns: repeat(2, 1fr);
}
.inscription-card {
grid-template-columns: 9rem 1fr;
}
}
@media (min-width: 1200px) {
.inscription-list-page__cards {
grid-template-columns: repeat(3, 1fr);
}
.inscription-card {
grid-template-columns: 10rem 1fr;
min-height: 12rem;
}
}
/* Tablet: título puede reducirse un poco */
@media (max-width: 900px) {
.inscription-list-page__title {
font-size: 1.25rem;
}
}
/* Móvil: toolbar en 2 filas (título + pill), counter oculto */
@media (max-width: 600px) {
.inscription-list-page__toolbar {
grid-template-columns: 1fr;
grid-template-rows: auto auto;
gap: 0.75rem;
}
.inscription-list-page__counter {
display: none;
}
.inscription-list-page__filters-form {
padding: 0.25rem 0.25rem 0.25rem 0.875rem;
}
.inscription-list-page__filters-divider,
.inscription-list-page__filters-form .app-select {
display: none;
}
.inscription-list-page__title {
font-size: 1.25rem;
}
}
/* Inscription details page (BEM) */
.inscription-page { padding: 1rem; display: grid; gap: 1rem; justify-items: center; }
.inscription-page__loading { display: flex; align-items: center; gap: .5rem; min-height: 3rem; }
.inscription-page__error { color: var(--danger-color); }
.inscription-page__header { text-align: center; display: grid; gap: .35rem; width: 100%; }
.inscription-page__title { font-size: clamp(1.35rem, 2.5vw, 2rem); font-weight: 800; color: var(--text-color); }
.inscription-page__meta { display: grid; gap: .15rem; color: var(--text-muted); }
.inscription-page__dates { font-weight: 600; }
.inscription-page__venue { opacity: .95; }
/* Main area: stacked by default (mobile) */
.inscription-page__main { display: grid; grid-template-columns: 1fr; gap: 1rem; width: 100%; max-width: 1400px; }
.inscription-page__col { min-width: 0; }
/* QR box: constrain size so it never grows too large */
.inscription-page__qr { display: grid; place-items: center; gap: .5rem; }
.inscription-page__qr > * { max-width: 320px; max-height: 320px; width: 100%; height: auto; }
.inscription-page__code { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-weight: 900; font-size: 1.4rem; letter-spacing: .04em; background: color-mix(in oklab, var(--primary-color) 10%, transparent); border: 1px dashed color-mix(in oklab, var(--primary-color) 40%, var(--border-color)); padding: .35rem .6rem; border-radius: .35rem; }
/* Badge preview: center and limit its width so it doesn't stretch too wide */
.inscription-page__badge { display: grid; place-items: center; gap: .65rem; }
.inscription-page__badge > * { max-width: 420px; width: 100%; }
/* Badge edit hint – prominent info banner */
.inscription-page__badge-hint {
display: flex;
align-items: flex-start;
gap: .55rem;
max-width: 420px;
width: 100%;
padding: .65rem .85rem;
border-radius: .55rem;
border-left: 3.5px solid var(--primary-color);
background: color-mix(in oklab, var(--primary-color) 8%, var(--surface-color));
color: var(--text-color);
font-size: .85rem;
font-weight: 500;
line-height: 1.45;
letter-spacing: .015em;
}
.inscription-page__badge-hint-icon {
flex-shrink: 0;
font-size: 1.15rem;
line-height: 1.3;
}
.inscription-page__includes { width: 100%; }
.inscription-page__includes-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .35rem; }
.inscription-page__include-item { padding: .5rem .75rem; border: 1px solid var(--border-color); border-radius: .5rem; background: var(--surface-alt-color); }
/* On very small screens reduce QR and badge max width */
@media (max-width: 480px) {
.inscription-page__qr > * { max-width: 220px; max-height: 220px; }
.inscription-page__badge > * { max-width: 320px; }
}
/* On medium screens (>=700px) show QR and Badge side-by-side; includes stay below (span full width) */
@media (min-width: 700px) and (max-width: 1099px) {
.inscription-page__main {
grid-template-columns: minmax(0, 360px) minmax(0, 460px);
gap: 1.25rem;
align-items: start;
}
.inscription-page__qr > * { max-width: 360px; max-height: 360px; }
.inscription-page__badge > * { max-width: 460px; }
/* make the includes block span both columns and appear below */
.inscription-page__col--includes { grid-column: 1 / -1; }
}
/* On larger screens (>=1100px) show QR, Badge and Includes side-by-side (three columns) */
@media (min-width: 1100px) and (max-width: 1399px) {
.inscription-page__main {
grid-template-columns: minmax(0, 360px) minmax(0, 460px) 1fr;
gap: 1.25rem;
align-items: start;
}
.inscription-page__qr > * { max-width: 360px; max-height: 360px; }
.inscription-page__badge > * { max-width: 460px; }
.inscription-page__includes { max-width: none; }
}
/* On very large screens allow slightly bigger QR and badge */
@media (min-width: 1400px) {
.inscription-page__main { grid-template-columns: minmax(0, 420px) minmax(0, 520px) 1fr; }
.inscription-page__qr > * { max-width: 420px; max-height: 420px; }
.inscription-page__badge > * { max-width: 520px; }
}
/* ============================================
PaymentGenericListPage - CFDI Extensions
Estilos adicionales para gesti�n de CFDI
============================================ */
/* ============= CFDI History Modal ============= */
.paymentGenericPage__cfdi-history {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
.paymentGenericPage__history-info {
display: flex;
flex-wrap: wrap;
gap: 1rem;
padding: 1rem;
background: var(--info-bg);
border-left: 4px solid var(--info);
border-radius: 0.25rem;
}
.paymentGenericPage__history-info p {
margin: 0;
font-size: 0.875rem;
color: var(--info-dark);
}
.paymentGenericPage__history-info strong {
font-weight: 600;
margin-right: 0.5rem;
}
/* ============= Loading State ============= */
.paymentGenericPage__loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 1rem;
padding: 3rem 1rem;
color: var(--text-muted);
}
.paymentGenericPage__loading span {
font-size: 0.875rem;
}
/* ============= Empty State ============= */
.paymentGenericPage__empty {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 1rem;
padding: 3rem 1rem;
text-align: center;
}
.paymentGenericPage__empty-icon {
font-size: 3rem;
opacity: 0.5;
}
.paymentGenericPage__empty p {
margin: 0;
color: var(--text-muted);
font-size: 1rem;
}
/* ============= CFDI Indicator in Table ============= */
.paymentGenericPage__cfdi-indicator {
display: inline-flex;
align-items: center;
gap: 0.25rem;
margin-top: 0.25rem;
padding: 0.125rem 0.5rem;
background: var(--success-bg);
color: var(--success);
border-radius: 0.25rem;
font-size: 0.75rem;
font-weight: 500;
}
.paymentGenericPage__cfdi-indicator i {
font-size: 0.875rem;
}
/* ============= Status Badges ============= */
.paymentGenericPage__badge {
display: inline-flex;
align-items: center;
justify-content: center;
padding: 0.25rem 0.75rem;
border-radius: 1rem;
font-size: 0.75rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
white-space: nowrap;
}
.paymentGenericPage__badge--pending {
background: var(--warning-bg);
color: var(--warning-dark);
}
.paymentGenericPage__badge--stamped {
background: var(--success-bg);
color: var(--success);
}
.paymentGenericPage__badge--cancelled {
background: var(--danger-bg);
color: var(--danger);
}
/* ============= Warning Text ============= */
.paymentGenericPage__warning-text {
color: var(--danger);
font-weight: 500;
margin: 0.5rem 0;
}
/* ============= Modal Actions ============= */
.paymentGenericPage__modal-actions {
display: flex;
gap: 0.75rem;
margin-top: 1.5rem;
justify-content: flex-end;
}
/* ============= Responsive ============= */
@media (max-width: 768px) {
.paymentGenericPage__history-info {
flex-direction: column;
gap: 0.5rem;
}
.paymentGenericPage__modal-actions {
flex-direction: column-reverse;
}
.paymentGenericPage__modal-actions button {
width: 100%;
}
}
@media (max-width: 480px) {
.paymentGenericPage__empty {
padding: 2rem 1rem;
}
.paymentGenericPage__empty-icon {
font-size: 2rem;
}
}
/* ============================================
PaymentListPage - Lista de Pagos (Admin)
============================================ */
.paymentListPage {
width: 100%;
height: 100%;
padding: var(--spacing-md);
}
/* ==================== HEADER ==================== */
.paymentListPage__title {
font-size: 2rem;
font-weight: 700;
color: var(--text-color);
margin-bottom: var(--spacing-md);
}
/* ==================== LOADING / ERROR / EMPTY ==================== */
.paymentListPage__loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: var(--spacing-sm);
padding: var(--spacing-xl);
color: var(--text-muted);
}
.paymentListPage__error {
padding: var(--spacing-md);
background: var(--danger-background);
border: 1px solid var(--danger-color);
border-radius: var(--border-radius);
color: var(--danger-color);
font-weight: 500;
}
.paymentListPage__empty {
padding: var(--spacing-xl);
text-align: center;
background: var(--surface-color);
border-radius: var(--border-radius);
color: var(--text-muted);
}
.paymentListPage__empty p {
margin-bottom: var(--spacing-md);
}
/* ==================== FILTER PANEL ==================== */
.paymentListPage__filter-group {
margin-bottom: var(--spacing-md);
}
.paymentListPage__filter-section-title {
font-size: 0.875rem;
font-weight: 600;
color: var(--text-color);
margin-bottom: var(--spacing-sm);
text-transform: uppercase;
letter-spacing: 0.05em;
}
.paymentListPage__filter-divider {
height: 1px;
background: var(--border-color);
margin: var(--spacing-md) 0;
}
/* ==================== TABLE ==================== */
.paymentListPage__table-wrapper {
background: var(--surface-color);
border-radius: var(--border-radius);
overflow: hidden;
box-shadow: var(--shadow-sm);
}
.paymentListPage__th-center {
text-align: center;
}
.paymentListPage__actions-cell {
text-align: center;
width: 80px;
}
/* ==================== TABLE - CUSTOM COLUMNS ==================== */
.paymentListPage__date-col {
display: flex;
flex-direction: column;
gap: 0.125rem;
}
.paymentListPage__date {
font-weight: 500;
color: var(--text-color);
}
.paymentListPage__time {
font-size: 0.75rem;
color: var(--text-muted);
}
.paymentListPage__payer-col,
.paymentListPage__event-col,
.paymentListPage__cfdi-col {
display: flex;
flex-direction: column;
gap: 0.125rem;
}
.paymentListPage__payer-col strong,
.paymentListPage__event-col strong {
color: var(--text-color);
}
.paymentListPage__payer-col small,
.paymentListPage__event-col small,
.paymentListPage__cfdi-status {
font-size: 0.75rem;
color: var(--text-muted);
}
.paymentListPage__engine-col {
display: flex;
flex-direction: column;
gap: 0.125rem;
}
.paymentListPage__engine {
font-weight: 500;
color: var(--text-color);
}
.paymentListPage__txn,
.paymentListPage__card {
font-size: 0.75rem;
color: var(--text-muted);
font-family: 'Courier New', monospace;
}
.paymentListPage__total-col {
display: flex;
flex-direction: column;
gap: 0.125rem;
}
.paymentListPage__amount {
color: var(--success-color);
font-weight: 600;
}
.paymentListPage__currency {
font-size: 0.75rem;
color: var(--text-muted);
}
/* Celdas de �conos de estado */
.paymentListPage__status-cell,
.paymentListPage__cfdi-cell {
text-align: center;
vertical-align: middle;
}
/* �conos visuales */
.paymentListPage__icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 1.75rem;
height: 1.75rem;
border-radius: 50%;
font-size: 1rem;
font-weight: bold;
cursor: help;
transition: transform 0.2s ease;
}
.paymentListPage__icon:hover {
transform: scale(1.15);
}
.paymentListPage__icon--success {
background: var(--success-background);
color: var(--success-color);
}
.paymentListPage__icon--pending {
background: var(--warning-background);
color: var(--warning-color);
}
.paymentListPage__icon--warning {
background: var(--warning-background);
color: var(--warning-color);
}
.paymentListPage__icon--cancelled {
background: var(--danger-background);
color: var(--danger-color);
}
.paymentListPage__icon--none {
background: var(--secondary-background);
color: var(--text-muted);
font-size: 1.25rem;
}
/* Contador de CFDIs adicionales */
.paymentListPage__cfdi-count {
display: inline-block;
margin-left: 0.25rem;
padding: 0.125rem 0.375rem;
background: var(--info-background);
color: var(--info-color);
border-radius: var(--border-radius);
font-size: 0.625rem;
font-weight: 600;
vertical-align: middle;
}
.paymentListPage__text-muted {
color: var(--text-muted);
}
.paymentListPage__empty-icon {
font-size: 4rem;
opacity: 0.3;
}
/* ==================== BADGES ==================== */
.paymentListPage__badge {
display: inline-block;
padding: 0.25rem 0.5rem;
border-radius: var(--border-radius);
font-size: 0.75rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.05em;
}
.paymentListPage__badge--success {
background: var(--success-background);
color: var(--success-foreground);
}
.paymentListPage__badge--warning {
background: var(--warning-background);
color: var(--warning-foreground);
}
.paymentListPage__badge--danger {
background: var(--danger-background);
color: var(--danger-foreground);
}
.paymentListPage__badge--info {
background: var(--info-background);
color: var(--info-foreground);
}
.paymentListPage__badge--muted {
background: var(--secondary-background);
color: var(--text-muted);
}
.paymentListPage__badge--engine {
background: var(--primary-color);
color: var(--primary-foreground);
}
.paymentListPage__badge--primary {
background: var(--primary-color);
color: var(--primary-foreground);
}
/* Badges de marcas de tarjetas - Mantienen sus colores corporativos */
.paymentListPage__badge--visa {
background: linear-gradient(135deg, #1A1F71, #0066B2);
color: var(--text-light);
}
.paymentListPage__badge--mastercard {
background: linear-gradient(135deg, #EB001B, #FF5F00);
color: var(--text-light);
}
.paymentListPage__badge--amex {
background: linear-gradient(135deg, #006FCF, #00ACED);
color: var(--text-light);
}
/* ==================== MODAL DE DETALLES ==================== */
.paymentListPage__modal-loading {
display: flex;
flex-direction: column;
align-items: center;
gap: 1rem;
padding: 3rem;
color: var(--text-secondary);
}
/* Wrapper principal con 2 columnas */
.paymentListPage__details-wrapper {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 1.5rem;
padding: 0.5rem;
}
.paymentListPage__details-column {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
.paymentListPage__detail-section {
background: var(--surface-color);
border-radius: var(--border-radius);
padding: 1.25rem;
border: 1px solid var(--border-color);
}
.paymentListPage__detail-section--highlight {
background: var(--info-background);
border-color: var(--info-color);
}
.paymentListPage__detail-section--footer {
background: var(--secondary-background);
border-style: dashed;
border-color: var(--border-color);
}
.paymentListPage__detail-section-title {
font-size: 1rem;
font-weight: 600;
margin: 0 0 1rem 0;
padding-bottom: 0.75rem;
border-bottom: 2px solid var(--border-color);
color: var(--text-color);
}
/* Grupos de campos (filas dentro de secciones) */
.paymentListPage__detail-group {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 1rem;
margin-bottom: 0.75rem;
}
.paymentListPage__detail-group:last-child {
margin-bottom: 0;
}
.paymentListPage__detail-item {
display: flex;
flex-direction: column;
gap: 0.25rem;
min-width: 0;
}
.paymentListPage__detail-item--full {
grid-column: 1 / -1;
}
.paymentListPage__detail-label {
font-size: 0.8125rem;
font-weight: 600;
color: var(--text-secondary);
text-transform: uppercase;
letter-spacing: 0.5px;
}
.paymentListPage__detail-value {
font-size: 0.9375rem;
color: var(--text-color);
word-break: break-word;
display: flex;
align-items: center;
gap: 0.5rem;
flex-wrap: wrap;
}
.paymentListPage__detail-value strong {
color: var(--primary-color);
}
.paymentListPage__detail-value--mono {
font-family: 'Courier New', monospace;
background: var(--secondary-background);
padding: 0.25rem 0.5rem;
border-radius: var(--border-radius);
font-size: 0.875rem;
display: inline-block;
}
.paymentListPage__detail-value--total {
font-size: 1.375rem;
color: var(--success-color);
}
.paymentListPage__detail-value--success {
color: var(--success-color);
font-weight: 500;
}
.paymentListPage__detail-value--danger {
color: var(--danger-color);
font-weight: 500;
}
.paymentListPage__observations {
margin: 0;
padding: 1rem;
background: var(--secondary-background);
border-left: 4px solid var(--primary-color);
border-radius: var(--border-radius);
font-size: 0.875rem;
line-height: 1.6;
color: var(--text-secondary);
white-space: pre-wrap;
word-break: break-word;
}
/* ==================== TOOLBAR ==================== */
.paymentListPage__toolbar {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;
margin-bottom: 1.5rem;
flex-wrap: wrap;
}
.paymentListPage__toolbar-actions {
display: flex;
gap: 0.75rem;
align-items: center;
}
/* Responsive para modal de detalles */
@media (max-width: 1200px) {
.paymentListPage__details-wrapper {
grid-template-columns: 1fr;
gap: 1rem;
}
}
@media (max-width: 768px) {
.paymentListPage__detail-group {
grid-template-columns: 1fr;
gap: 0.75rem;
}
.paymentListPage__detail-section {
padding: 1rem;
}
.paymentListPage__detail-section-title {
font-size: 0.9375rem;
}
.paymentListPage__detail-value {
font-size: 0.875rem;
}
.paymentListPage__detail-value--total {
font-size: 1.125rem;
}
.paymentListPage__details-wrapper {
padding: 0;
}
}
/* P�gina de confirmaci�n de pago exitoso */
.payment-success {
display: flex;
align-items: center;
justify-content: center;
min-height: 100vh;
background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-dark) 100%);
padding: 2rem;
}
.payment-success__card {
background: var(--surface-color);
border-radius: 16px;
padding: 3rem 2rem;
text-align: center;
max-width: 400px;
box-shadow: var(--shadow-2xl);
animation: slideUp 0.4s ease-out;
}
@keyframes slideUp {
from {
opacity: 0;
transform: translateY(30px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
.payment-success__icon {
width: 80px;
height: 80px;
margin: 0 auto 1.5rem;
color: var(--success-color);
}
.payment-success__circle {
stroke-dasharray: 188;
stroke-dashoffset: 188;
animation: drawCircle 0.6s ease-out forwards;
}
@keyframes drawCircle {
to {
stroke-dashoffset: 0;
}
}
.payment-success__check {
stroke-dasharray: 40;
stroke-dashoffset: 40;
animation: drawCheck 0.3s ease-out 0.6s forwards;
}
@keyframes drawCheck {
to {
stroke-dashoffset: 0;
}
}
.payment-success__title {
font-size: 1.75rem;
font-weight: 700;
color: var(--text-color);
margin: 0 0 0.75rem 0;
}
.payment-success__message {
font-size: 1rem;
color: var(--text-muted);
margin: 0 0 2rem 0;
}
.payment-success__loader {
display: flex;
justify-content: center;
}
.payment-success__spinner {
width: 32px;
height: 32px;
border: 3px solid var(--border-color);
border-top-color: var(--primary-color);
border-radius: 50%;
animation: spin 0.8s linear infinite;
}
@keyframes spin {
to {
transform: rotate(360deg);
}
}
/* ================================================== */
/* RECEIPT LIST PAGE                                  */
/* Listado de Receipts con filtros                   */
/* ================================================== */
.receiptListPage {
width: 100%;
max-width: 100%;
padding: var(--spacing-md, 1rem);
box-sizing: border-box;
}
/* ==================== HEADER ==================== */
.receiptListPage__header {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: var(--spacing-lg, 1.5rem);
padding-bottom: var(--spacing-md, 1rem);
border-bottom: 2px solid var(--primary-color, #0066cc);
}
.receiptListPage__title {
font-size: var(--font-size-3xl, 2rem);
font-weight: var(--font-weight-bold, 700);
color: var(--text-primary, #1a1a1a);
margin: 0;
letter-spacing: -0.02em;
background: linear-gradient(135deg, var(--primary-color, #0066cc) 0%, var(--primary-dark, #004d99) 100%);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
/* ==================== TOOLBAR ==================== */
.receiptListPage__toolbar {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;
margin-bottom: 1.5rem;
flex-wrap: wrap;
}
.receiptListPage__toolbar-actions {
display: flex;
gap: 0.75rem;
align-items: center;
}
/* ==================== CONTENT ==================== */
.receiptListPage__content {
width: 100%;
margin-top: var(--spacing-md, 1rem);
}
/* ==================== LOADING ==================== */
.receiptListPage__loading {
display: flex;
align-items: center;
justify-content: center;
padding: 4rem 2rem;
gap: 1rem;
color: var(--text-secondary);
}
/* ==================== ERROR ==================== */
.receiptListPage__error {
background: var(--danger-background);
color: var(--danger-color);
padding: 1.5rem;
border-radius: 8px;
margin: 2rem 0;
text-align: center;
border: 1px solid var(--danger-color);
}
/* ==================== EMPTY STATE ==================== */
.receiptListPage__empty {
text-align: center;
padding: 4rem 2rem;
color: var(--text-secondary);
}
.receiptListPage__empty p {
margin-bottom: 1.5rem;
font-size: 1.125rem;
}
/* ==================== FILTER PANEL ==================== */
.receiptListPage__filter-group {
margin-bottom: var(--spacing-md, 1rem);
}
.receiptListPage__filter-section-title {
font-size: 0.9375rem;
font-weight: 600;
color: var(--text-color);
margin-bottom: 0.75rem;
}
.receiptListPage__filter-divider {
height: 1px;
background: var(--border-color);
margin: 1.5rem 0;
}
.receiptListPage__label {
display: block;
font-size: var(--font-size-sm);
font-weight: var(--font-weight-medium);
color: var(--text-primary);
margin-bottom: var(--spacing-xs);
display: flex;
align-items: center;
gap: var(--spacing-xs);
}
/* ==================== TABLE ==================== */
.receiptListPage__table-wrapper {
width: 100%;
overflow-x: auto;
margin-top: 1rem;
}
.receiptListPage__th-center {
text-align: center !important;
}
/* Estilos para columnas ordenables */
.receiptListPage__sortable {
cursor: pointer;
user-select: none;
position: relative;
padding-right: 1.5rem !important;
}
.receiptListPage__sortable:hover {
background-color: var(--hover-background-color, rgba(0, 0, 0, 0.05));
}
/* Iconos de ordenamiento usando pseudoelementos */
.receiptListPage__sortable::after {
content: '';
position: absolute;
right: 0.5rem;
top: 50%;
transform: translateY(-50%);
width: 0;
height: 0;
border-left: 4px solid transparent;
border-right: 4px solid transparent;
opacity: 0.3;
}
/* Icono cuando est� ordenado ascendente */
.receiptListPage__sortable--asc::after {
border-bottom: 6px solid currentColor;
opacity: 1;
}
/* Icono cuando est� ordenado descendente */
.receiptListPage__sortable--desc::after {
border-top: 6px solid currentColor;
opacity: 1;
}
/* Eliminar estilos antiguos de svg */
thead th svg {
display: none;
}
/* ==================== TABLE CELLS ==================== */
.receiptListPage__folio {
font-family: 'Courier New', monospace;
font-weight: 600;
color: var(--primary-color);
}
.receiptListPage__text-muted {
color: var(--text-muted);
}
.receiptListPage__event-info {
display: flex;
align-items: center;
gap: 0.5rem;
}
.receiptListPage__user-info {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.receiptListPage__user-info small {
font-size: var(--font-size-xs, 0.75rem);
color: var(--text-secondary, #666);
}
.receiptListPage__origin-col {
text-align: center;
}
.receiptListPage__origin-badge {
display: inline-flex;
align-items: center;
padding: 0.25rem 0.625rem;
border-radius: 12px;
font-size: 0.75rem;
font-weight: 600;
white-space: nowrap;
background: var(--secondary-background);
color: var(--text-secondary);
}
.receiptListPage__date-col {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.receiptListPage__date {
font-weight: 500;
color: var(--text-color);
}
.receiptListPage__time {
font-size: 0.875rem;
color: var(--text-secondary);
}
.receiptListPage__total-col {
display: flex;
align-items: baseline;
gap: 0.375rem;
}
.receiptListPage__amount {
font-size: 1.125rem;
font-weight: 700;
color: var(--text-color);
}
.receiptListPage__amount--warning {
color: var(--warning-color);
}
.receiptListPage__currency {
font-size: 0.75rem;
color: var(--text-secondary);
text-transform: uppercase;
}
.receiptListPage__balance-cell {
text-align: center;
}
.receiptListPage__balance-col {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.25rem;
}
.receiptListPage__status-cell {
text-align: center;
padding: 0.5rem;
}
.receiptListPage__status-badges {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.375rem;
}
.receiptListPage__actions-cell {
text-align: center;
}
/* ==================== BADGES ==================== */
.receiptListPage__badge {
display: inline-flex;
align-items: center;
gap: 0.375rem;
padding: 0.25rem 0.625rem;
border-radius: 12px;
font-size: 0.75rem;
font-weight: 600;
white-space: nowrap;
line-height: 1.4;
}
.receiptListPage__badge--compact {
padding: 0.2rem 0.5rem;
font-size: 0.6875rem;
gap: 0.25rem;
border-radius: 10px;
}
.receiptListPage__badge--compact .receiptListPage__badge-icon svg {
width: 12px;
height: 12px;
}
.receiptListPage__badge--icon-only {
padding: 0.375rem;
gap: 0;
}
.receiptListPage__badge--icon-only svg {
width: 16px;
height: 16px;
}
.receiptListPage__badge-icon {
display: inline-flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
}
.receiptListPage__badge-icon svg {
width: 14px;
height: 14px;
}
.receiptListPage__badge--success {
background: var(--success-background);
color: var(--success-color);
}
.receiptListPage__badge--success-sm {
background: var(--success-background);
color: var(--success-color);
padding: 0.375rem;
}
.receiptListPage__badge--success-sm svg {
width: 16px;
height: 16px;
}
.receiptListPage__badge--warning {
background: var(--warning-background);
color: var(--warning-color);
}
.receiptListPage__badge--danger {
background: var(--danger-background);
color: var(--danger-color);
}
.receiptListPage__badge--info {
background: var(--info-background);
color: var(--info-color);
}
.receiptListPage__badge--event {
background: var(--info-background);
color: var(--info-color);
}
.receiptListPage__badge--neutral {
background: var(--secondary-background);
color: var(--text-secondary);
}
.receiptListPage__badge--muted {
background: var(--secondary-background);
color: var(--text-secondary);
}
/* ==================== MODAL DETAILS ==================== */
.receiptListPage__modal-loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
padding: 3rem;
gap: 1rem;
color: var(--text-secondary);
}
.receiptListPage__details-wrapper {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
.receiptListPage__detail-section {
margin-bottom: var(--spacing-lg, 1.5rem);
padding: var(--spacing-md, 1rem);
background: var(--surface-color, #f9f9f9);
border-radius: var(--border-radius-md, 8px);
border: 1px solid var(--border-color, #e0e0e0);
}
.receiptListPage__detail-section:last-child {
margin-bottom: 0;
}
.receiptListPage__detail-section--highlight {
background: var(--secondary-background);
}
.receiptListPage__detail-section h3 {
margin: 0 0 var(--spacing-md, 1rem) 0;
font-size: var(--font-size-lg, 1.125rem);
font-weight: var(--font-weight-semibold, 600);
color: var(--primary-color, #0066cc);
border-bottom: 1px solid var(--border-color, #e0e0e0);
padding-bottom: var(--spacing-sm, 0.5rem);
}
.receiptListPage__detail-section-title {
font-size: 1rem;
font-weight: 600;
color: var(--text-color);
margin-bottom: 1rem;
padding-bottom: 0.75rem;
border-bottom: 2px solid var(--border-color);
display: flex;
align-items: center;
gap: 0.5rem;
}
.receiptListPage__section-icon {
display: inline-flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
color: var(--primary-color);
}
.receiptListPage__section-icon svg {
width: 20px;
height: 20px;
}
.receiptListPage__detail-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: var(--spacing-sm, 0.5rem);
}
.receiptListPage__detail-row {
padding: var(--spacing-xs, 0.25rem) 0;
}
.receiptListPage__detail-row strong {
display: inline-block;
min-width: 120px;
color: var(--text-secondary, #666);
font-weight: var(--font-weight-medium, 500);
}
.receiptListPage__detail-group {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 1rem;
margin-bottom: 1rem;
}
.receiptListPage__detail-group:last-child {
margin-bottom: 0;
}
.receiptListPage__detail-item {
display: flex;
flex-direction: column;
gap: 0.375rem;
}
.receiptListPage__detail-item--full {
grid-column: 1 / -1;
}
.receiptListPage__detail-label {
font-size: 0.875rem;
font-weight: 500;
color: var(--text-secondary);
}
.receiptListPage__detail-value {
font-size: 1rem;
color: var(--text-color);
font-weight: 500;
}
.receiptListPage__detail-value--success {
color: var(--success-color);
}
.receiptListPage__detail-value--warning {
color: var(--warning-color);
}
.receiptListPage__detail-value--total {
font-size: 1.5rem;
font-weight: 700;
color: var(--primary-color);
}
.receiptListPage__detail-value--mono {
font-family: 'Courier New', monospace;
}
.receiptListPage__detail-divider {
height: 1px;
background: var(--border-color);
margin: 1rem 0;
}
.receiptListPage__modal-actions {
display: flex;
gap: var(--spacing-sm, 0.5rem);
justify-content: flex-end;
margin-top: var(--spacing-lg, 1.5rem);
padding-top: var(--spacing-md, 1rem);
border-top: 1px solid var(--border-color, #e0e0e0);
}
/* ==================== ITEMS TABLE ==================== */
.receiptListPage__items-table {
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.receiptListPage__item-row {
display: flex;
justify-content: space-between;
align-items: flex-start;
padding: 0.75rem;
background: var(--background-color);
border: 1px solid var(--border-color);
border-radius: 6px;
gap: 1rem;
}
.receiptListPage__item-desc {
flex: 1;
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.receiptListPage__item-desc strong {
color: var(--text-color);
font-weight: 600;
}
.receiptListPage__item-desc small {
color: var(--text-muted);
font-size: 0.875rem;
}
.receiptListPage__item-amounts {
display: flex;
flex-direction: column;
align-items: flex-end;
gap: 0.25rem;
white-space: nowrap;
}
.receiptListPage__item-amounts span {
color: var(--text-secondary);
font-size: 0.875rem;
}
.receiptListPage__item-amounts strong {
color: var(--primary-color);
font-size: 1rem;
font-weight: 700;
}
/* ==================== OLD ITEMS LIST (deprecated) ==================== */
.receiptListPage__items-list {
display: flex;
flex-direction: column;
gap: 1rem;
}
.receiptListPage__item-card {
background: var(--background-color);
border: 1px solid var(--border-color);
border-radius: 8px;
padding: 1rem;
transition: all 0.2s ease;
}
.receiptListPage__item-card:hover {
background: var(--hover-background-color);
box-shadow: var(--shadow-sm);
}
.receiptListPage__item-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 0.5rem;
}
.receiptListPage__item-name {
font-weight: 600;
color: var(--text-color);
}
.receiptListPage__item-amount {
font-size: 1.125rem;
font-weight: 700;
color: var(--primary-color);
}
.receiptListPage__item-description {
font-size: 0.875rem;
color: var(--text-secondary);
margin-bottom: 0.75rem;
}
.receiptListPage__item-details {
display: flex;
gap: 1.5rem;
font-size: 0.875rem;
color: var(--text-secondary);
}
.receiptListPage__item-details span {
display: flex;
align-items: center;
gap: 0.25rem;
}
/* ==================== RESPONSIVE ==================== */
@media (max-width: 768px) {
.receiptListPage {
padding: var(--spacing-sm, 0.5rem);
}
.receiptListPage__title {
font-size: var(--font-size-2xl, 1.5rem);
}
.receiptListPage__toolbar {
flex-direction: column;
align-items: stretch;
}
.receiptListPage__toolbar-actions {
width: 100%;
}
.receiptListPage__detail-group,
.receiptListPage__detail-grid {
grid-template-columns: 1fr;
}
.receiptListPage__item-header {
flex-direction: column;
align-items: flex-start;
gap: 0.5rem;
}
.receiptListPage__item-details {
flex-direction: column;
gap: 0.5rem;
}
.receiptListPage__item-row {
flex-direction: column;
align-items: stretch;
}
.receiptListPage__item-amounts {
align-items: flex-start;
}
.receiptListPage__status-badges {
align-items: flex-start;
}
.receiptListPage__modal-actions {
flex-direction: column;
}
}
@media (max-width: 480px) {
.receiptListPage__title {
font-size: var(--font-size-xl, 1.25rem);
}
}
/* ==================== DARK MODE ==================== */
@media (prefers-color-scheme: dark) {
.receiptListPage__title {
color: var(--text-primary-dark, #fff);
}
.receiptListPage__label {
color: var(--text-primary-dark, #fff);
}
.receiptListPage__detail-section {
background: var(--surface-color-dark, #2a2a2a);
border-color: var(--border-color-dark, #444);
}
.receiptListPage__detail-section h3 {
color: var(--primary-light, #4d9fff);
border-bottom-color: var(--border-color-dark, #444);
}
.receiptListPage__detail-section--highlight {
background: var(--background-color-dark, #111827);
}
.receiptListPage__item-card,
.receiptListPage__item-row {
background: var(--background-color-dark, #111827);
border-color: var(--border-color-dark, #374151);
}
.receiptListPage__item-card:hover {
background: var(--surface-color-dark, #1f2937);
}
.receiptListPage__error {
background: rgba(239, 68, 68, 0.15);
border-color: rgba(239, 68, 68, 0.5);
}
.receiptListPage__loading {
color: var(--text-secondary-dark, #bbb);
}
.receiptListPage__empty {
color: var(--text-secondary-dark, #bbb);
}
.receiptListPage__badge--success,
.receiptListPage__badge--success-sm {
background: rgba(34, 197, 94, 0.15);
}
.receiptListPage__badge--warning {
background: rgba(251, 146, 60, 0.15);
}
.receiptListPage__badge--danger {
background: rgba(239, 68, 68, 0.15);
}
.receiptListPage__badge--info,
.receiptListPage__badge--event {
background: rgba(59, 130, 246, 0.15);
}
.receiptListPage__badge--neutral {
background: rgba(156, 163, 175, 0.15);
}
.receiptListPage__filter-divider {
background: var(--border-color-dark, #444);
}
.receiptListPage__modal-actions {
border-top-color: var(--border-color-dark, #444);
}
}
/* Receipt Status Page - Layout estilo Register con 2 columnas */
.receipt-page {
min-height: 100vh;
background: var(--background-color);
padding: 2rem 1rem;
}
/* Loading */
.receipt-page__loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
min-height: 60vh;
gap: 1rem;
}
.receipt-page__loading-text {
color: var(--text-color);
font-size: 1.125rem;
}
/* Error */
.receipt-page__error {
max-width: 600px;
margin: 0 auto;
}
.receipt-page__error-content {
display: flex;
flex-direction: column;
align-items: center;
gap: 1.5rem;
padding: 2rem;
text-align: center;
}
.receipt-page__error-icon {
width: 80px;
height: 80px;
stroke: var(--danger-color);
stroke-width: 2;
fill: none;
}
.receipt-page__error-title {
color: var(--danger-color);
font-size: 1.5rem;
margin: 0;
}
.receipt-page__error-message {
color: var(--text-muted);
margin: 0;
}
/* Success View (Recibo Pagado) */
.receipt-page__success {
max-width: 800px;
margin: 0 auto;
}
.receipt-page__success-content {
display: flex;
flex-direction: column;
align-items: center;
gap: 1.5rem;
padding: 2rem;
text-align: center;
}
.receipt-page__success-icon {
width: 100px;
height: 100px;
stroke: var(--success-color);
stroke-width: 2;
fill: none;
animation: checkmarkPop 0.5s ease;
}
@keyframes checkmarkPop {
0% {
transform: scale(0);
opacity: 0;
}
50% {
transform: scale(1.1);
}
100% {
transform: scale(1);
opacity: 1;
}
}
.receipt-page__success-title {
color: var(--success-color);
font-size: 1.75rem;
margin: 0;
}
.receipt-page__success-message {
color: var(--text-color);
font-size: 1.125rem;
margin: 0;
}
.receipt-page__details {
width: 100%;
background: var(--surface-color);
border-radius: 12px;
padding: 1.5rem;
display: flex;
flex-direction: column;
gap: 1rem;
}
.receipt-page__detail-row {
display: flex;
justify-content: space-between;
align-items: center;
padding: 0.5rem 0;
border-bottom: 1px solid var(--divider-color);
}
.receipt-page__detail-row:last-child {
border-bottom: none;
}
.receipt-page__detail-label {
color: var(--text-muted);
font-weight: 500;
}
.receipt-page__detail-value {
color: var(--primary-color);
font-weight: 600;
}
.receipt-page__actions {
display: flex;
gap: 1rem;
width: 100%;
flex-wrap: wrap;
}
.receipt-page__actions button {
flex: 1;
min-width: 200px;
}
/* Pending View (Layout 2 columnas como Register) */
.receipt-page__pending {
max-width: 1400px;
margin: 0 auto;
display: grid;
grid-template-columns: 1fr 400px;
gap: 2rem;
align-items: start;
}
/* Columna Principal (izquierda) */
.receipt-page__main {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
.receipt-page__header {
background: var(--card-bg-color);
border-radius: 12px;
padding: 1.5rem;
box-shadow: 0 2px 8px var(--shadow-color);
}
.receipt-page__title {
color: var(--primary-color);
font-size: 1.75rem;
margin: 0 0 0.5rem 0;
}
.receipt-page__subtitle {
color: var(--text-muted);
font-size: 1rem;
margin: 0;
}
.receipt-page__payment-error {
background: var(--error-background);
border: 1px solid var(--error-color);
border-radius: 8px;
padding: 1rem;
display: flex;
align-items: center;
gap: 0.75rem;
}
.receipt-page__payment-error-icon {
width: 24px;
height: 24px;
stroke: var(--error-color);
stroke-width: 2;
fill: none;
flex-shrink: 0;
}
.receipt-page__payment-error-text {
color: var(--error-color);
margin: 0;
font-weight: 500;
}
.receipt-page__content {
background: var(--card-bg-color);
border-radius: 12px;
padding: 2rem;
box-shadow: 0 2px 8px var(--shadow-color);
}
.receipt-page__section-title {
color: var(--text-color);
font-size: 1.25rem;
margin: 0 0 1.5rem 0;
}
/* Grid de opciones de pago */
.receipt-page__payment-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: 1rem;
}
/* Estilos base de las tarjetas de pago */
.receipt-page__payment-options .receipt-page__payment-grid .receipt-page__payment-card,
button.receipt-page__payment-card {
all: unset;
box-sizing: border-box;
background: #ffffff !important;
border: 2px solid #e5e7eb !important;
border-radius: 16px;
padding: 1.5rem;
display: flex !important;
flex-direction: column;
align-items: center;
gap: 0.75rem;
cursor: pointer;
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
text-align: center;
width: 100%;
position: relative;
overflow: hidden;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}
/* Efecto de brillo sutil en el fondo */
.receipt-page__payment-options .receipt-page__payment-grid .receipt-page__payment-card::before,
button.receipt-page__payment-card::before {
content: '';
position: absolute;
top: -50%;
left: -50%;
width: 200%;
height: 200%;
background: radial-gradient(circle, rgba(255, 255, 255, 0.1) 0%, transparent 70%);
opacity: 0;
transition: opacity 0.3s ease;
pointer-events: none;
}
.receipt-page__payment-options .receipt-page__payment-grid .receipt-page__payment-card:hover::before,
button.receipt-page__payment-card:hover::before {
opacity: 1;
}
/* Hover general */
.receipt-page__payment-options .receipt-page__payment-grid .receipt-page__payment-card:hover,
button.receipt-page__payment-card:hover {
background: #ffffff !important;
transform: translateY(-4px) scale(1.02);
box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}
/* Active state */
.receipt-page__payment-options .receipt-page__payment-grid .receipt-page__payment-card:active,
button.receipt-page__payment-card:active {
transform: translateY(-2px) scale(1);
}
/* Estilos espec�ficos por motor de pago con bordes de color */
/* OpenPay - Cian */
.receipt-page__payment-card--openpay {
border-color: rgba(0, 217, 255, 0.3) !important;
}
.receipt-page__payment-card--openpay:hover {
border-color: #00D9FF !important;
box-shadow: 0 8px 24px rgba(0, 217, 255, 0.25), 0 0 0 1px rgba(0, 217, 255, 0.1) !important;
}
/* MercadoPago - Azul */
.receipt-page__payment-card--mercadopago {
border-color: rgba(0, 158, 227, 0.3) !important;
}
.receipt-page__payment-card--mercadopago:hover {
border-color: #009EE3 !important;
box-shadow: 0 8px 24px rgba(0, 158, 227, 0.25), 0 0 0 1px rgba(0, 158, 227, 0.1) !important;
}
/* Stripe - Violeta */
.receipt-page__payment-card--stripe {
border-color: rgba(99, 91, 255, 0.3) !important;
}
.receipt-page__payment-card--stripe:hover {
border-color: #635BFF !important;
box-shadow: 0 8px 24px rgba(99, 91, 255, 0.25), 0 0 0 1px rgba(99, 91, 255, 0.1) !important;
}
/* PayPal - Azul oscuro */
.receipt-page__payment-card--paypal {
border-color: rgba(0, 112, 186, 0.3) !important;
}
.receipt-page__payment-card--paypal:hover {
border-color: #0070BA !important;
box-shadow: 0 8px 24px rgba(0, 112, 186, 0.25), 0 0 0 1px rgba(0, 112, 186, 0.1) !important;
}
/* Icono con animaci�n */
.receipt-page__payment-icon {
width: 64px;
height: 48px;
transition: transform 0.3s ease;
}
.receipt-page__payment-card:hover .receipt-page__payment-icon {
transform: scale(1.1);
}
.receipt-page__payment-icon svg {
width: 100%;
height: 100%;
filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.1));
transition: filter 0.3s ease;
}
.receipt-page__payment-card:hover .receipt-page__payment-icon svg {
filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.15));
}
/* Asegurar que el texto del SVG siempre sea blanco */
.receipt-page__payment-icon svg text {
fill: white !important;
}
/* Textos de las tarjetas con animaci�n */
.receipt-page__payment-card > .receipt-page__payment-name,
button.receipt-page__payment-card > .receipt-page__payment-name,
.receipt-page__payment-options .receipt-page__payment-card .receipt-page__payment-name {
color: #1f2937 !important;
font-weight: 600 !important;
font-size: 1rem !important;
margin: 0;
padding: 0;
transition: color 0.2s ease;
}
.receipt-page__payment-card:hover > .receipt-page__payment-name {
color: #111827 !important;
}
.receipt-page__payment-card > .receipt-page__payment-desc,
button.receipt-page__payment-card > .receipt-page__payment-desc,
.receipt-page__payment-options .receipt-page__payment-card .receipt-page__payment-desc {
color: #6b7280 !important;
font-size: 0.875rem !important;
margin: 0;
padding: 0;
transition: color 0.2s ease;
}
.receipt-page__payment-card:hover > .receipt-page__payment-desc {
color: #4b5563 !important;
}
/* Dark mode con efectos mejorados */
@media (prefers-color-scheme: dark) {
.receipt-page__payment-options .receipt-page__payment-grid .receipt-page__payment-card,
button.receipt-page__payment-card {
background: #1f2937 !important;
border-color: #374151 !important;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}
.receipt-page__payment-options .receipt-page__payment-grid .receipt-page__payment-card::before,
button.receipt-page__payment-card::before {
background: radial-gradient(circle, rgba(255, 255, 255, 0.05) 0%, transparent 70%);
}
.receipt-page__payment-options .receipt-page__payment-grid .receipt-page__payment-card:hover,
button.receipt-page__payment-card:hover {
background: #1f2937 !important;
box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}
/* OpenPay - Cian en dark */
.receipt-page__payment-card--openpay {
border-color: rgba(0, 217, 255, 0.4) !important;
}
.receipt-page__payment-card--openpay:hover {
border-color: #00D9FF !important;
box-shadow: 0 8px 24px rgba(0, 217, 255, 0.3), 0 0 0 1px rgba(0, 217, 255, 0.2) !important;
}
/* MercadoPago - Azul en dark */
.receipt-page__payment-card--mercadopago {
border-color: rgba(0, 158, 227, 0.4) !important;
}
.receipt-page__payment-card--mercadopago:hover {
border-color: #009EE3 !important;
box-shadow: 0 8px 24px rgba(0, 158, 227, 0.3), 0 0 0 1px rgba(0, 158, 227, 0.2) !important;
}
/* Stripe - Violeta en dark */
.receipt-page__payment-card--stripe {
border-color: rgba(99, 91, 255, 0.4) !important;
}
.receipt-page__payment-card--stripe:hover {
border-color: #635BFF !important;
box-shadow: 0 8px 24px rgba(99, 91, 255, 0.3), 0 0 0 1px rgba(99, 91, 255, 0.2) !important;
}
/* PayPal - Azul oscuro en dark */
.receipt-page__payment-card--paypal {
border-color: rgba(0, 112, 186, 0.4) !important;
}
.receipt-page__payment-card--paypal:hover {
border-color: #0070BA !important;
box-shadow: 0 8px 24px rgba(0, 112, 186, 0.3), 0 0 0 1px rgba(0, 112, 186, 0.2) !important;
}
.receipt-page__payment-card > .receipt-page__payment-name,
button.receipt-page__payment-card > .receipt-page__payment-name,
.receipt-page__payment-options .receipt-page__payment-card .receipt-page__payment-name {
color: #f9fafb !important;
}
.receipt-page__payment-card:hover > .receipt-page__payment-name {
color: #ffffff !important;
}
.receipt-page__payment-card > .receipt-page__payment-desc,
button.receipt-page__payment-card > .receipt-page__payment-desc,
.receipt-page__payment-options .receipt-page__payment-card .receipt-page__payment-desc {
color: #9ca3af !important;
}
.receipt-page__payment-card:hover > .receipt-page__payment-desc {
color: #d1d5db !important;
}
}
/* Animaci�n de entrada para las tarjetas */
@keyframes fadeInUp {
from {
opacity: 0;
transform: translateY(20px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
.receipt-page__payment-card {
animation: fadeInUp 0.4s ease-out backwards;
}
.receipt-page__payment-card:nth-child(1) { animation-delay: 0.05s; }
.receipt-page__payment-card:nth-child(2) { animation-delay: 0.1s; }
.receipt-page__payment-card:nth-child(3) { animation-delay: 0.15s; }
.receipt-page__payment-card:nth-child(4) { animation-delay: 0.2s; }
/* Columna del Resumen (derecha) */
.receipt-page__summary {
position: sticky;
top: 2rem;
}
.receipt-page__summary-card {
background: var(--card-bg-color);
border-radius: 14px;
box-shadow: 0 2px 12px var(--shadow-color);
padding: 1.5rem;
}
.receipt-page__summary-title {
color: var(--text-color);
font-size: 1.25rem;
font-weight: 600;
margin: 0 0 1rem 0;
}
.receipt-page__summary-event {
display: flex;
align-items: center;
gap: 0.5rem;
padding: 0.75rem;
margin-bottom: 1rem;
background: var(--primary-background);
border: 1px solid var(--primary-color);
border-radius: 8px;
color: var(--primary-color);
font-weight: 600;
}
.receipt-page__summary-items {
display: flex;
flex-direction: column;
gap: 0.75rem;
margin-bottom: 1rem;
}
.receipt-page__summary-item {
display: flex;
justify-content: space-between;
align-items: flex-start;
padding: 0.75rem;
background: var(--surface-color);
border-radius: 8px;
}
.receipt-page__summary-item-info {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.receipt-page__summary-item-name {
color: var(--text-color);
font-weight: 500;
}
.receipt-page__summary-item-qty {
color: var(--text-muted);
font-size: 0.875rem;
}
.receipt-page__summary-item-amount {
color: var(--primary-color);
font-weight: 600;
}
.receipt-page__summary-totals {
display: flex;
flex-direction: column;
gap: 0.5rem;
padding-top: 1rem;
border-top: 2px solid var(--divider-color);
}
.receipt-page__summary-row {
display: flex;
justify-content: space-between;
align-items: center;
color: var(--text-muted);
}
.receipt-page__summary-discount {
color: var(--success-color);
}
.receipt-page__summary-total {
font-size: 1.125rem;
font-weight: 700;
color: var(--primary-color);
padding-top: 0.5rem;
border-top: 1px solid var(--divider-color);
}
/* Modal de motor de pago */
.receipt-page__engine-modal {
display: flex;
flex-direction: column;
gap: 1.5rem;
padding: 1rem;
}
.receipt-page__engine-icon {
display: flex;
justify-content: center;
}
.receipt-page__engine-icon svg {
width: 96px;
height: 64px;
filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.15));
}
.receipt-page__engine-terms h4 {
color: var(--text-color);
font-size: 1rem;
margin: 0 0 0.75rem 0;
}
.receipt-page__engine-terms-content {
color: var(--text-muted);
line-height: 1.6;
}
.receipt-page__engine-terms-content ul {
margin: 0;
padding-left: 1.5rem;
}
.receipt-page__engine-terms-content li {
margin-bottom: 0.5rem;
}
.receipt-page__engine-amount {
display: flex;
justify-content: space-between;
align-items: center;
padding: 1rem;
background: var(--surface-color);
border-radius: 8px;
font-size: 1.125rem;
}
.receipt-page__engine-amount strong {
color: var(--primary-color);
font-size: 1.25rem;
}
.receipt-page__engine-actions {
display: flex;
gap: 1rem;
justify-content: flex-end;
}
.receipt-page__engine-actions button {
min-width: 120px;
}
/* Alerta de pago pendiente */
.receipt-page__payment-pending-alert {
grid-column: 1 / -1;
background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
border: 2px solid #f59e0b;
border-radius: 12px;
padding: 1.5rem;
display: flex;
gap: 1rem;
align-items: flex-start;
margin-bottom: 1.5rem;
box-shadow: 0 4px 12px rgba(245, 158, 11, 0.15);
}
.receipt-page__alert-icon {
width: 32px;
height: 32px;
color: #d97706;
flex-shrink: 0;
}
.receipt-page__alert-content {
flex: 1;
}
.receipt-page__alert-title {
color: #92400e;
font-size: 1.125rem;
font-weight: 700;
margin: 0 0 0.5rem 0;
}
.receipt-page__alert-text {
color: #78350f;
margin: 0 0 0.5rem 0;
line-height: 1.6;
}
.receipt-page__alert-subtext {
color: #92400e;
font-size: 0.875rem;
margin: 0 0 1rem 0;
}
@media (prefers-color-scheme: dark) {
.receipt-page__payment-pending-alert {
background: linear-gradient(135deg, #422006 0%, #78350f 100%);
border-color: #f59e0b;
}
.receipt-page__alert-icon {
color: #fbbf24;
}
.receipt-page__alert-title {
color: #fde68a;
}
.receipt-page__alert-text {
color: #fcd34d;
}
.receipt-page__alert-subtext {
color: #fbbf24;
}
}
/* Responsive */
@media (max-width: 1024px) {
.receipt-page__pending {
grid-template-columns: 1fr;
}
.receipt-page__summary {
position: static;
order: -1; /* Mostrar resumen arriba en m�vil */
}
}
@media (max-width: 640px) {
.receipt-page {
padding: 1rem 0.5rem;
}
.receipt-page__payment-grid {
grid-template-columns: 1fr;
}
.receipt-page__actions {
flex-direction: column;
}
.receipt-page__actions button {
min-width: 100%;
}
}
/* Dark mode */
@media (prefers-color-scheme: dark) {
.receipt-page__payment-card {
background: var(--surface-color-dark);
border-color: var(--divider-color-dark);
}
.receipt-page__payment-card:hover {
border-color: var(--primary-color);
}
}
/* Nota: Los colores de marca de OpenPay (#00D9FF), MercadoPago (#009EE3),
Stripe (#635BFF) y PayPal (#0070BA) se mantienen ya que son parte de
las gu�as de marca de esas plataformas y no pueden cambiarse */
/* ============================================================
Pantalla de pago en progreso
============================================================ */
.receipt-page__payment-progress {
display: flex;
flex-direction: column;
align-items: center;
gap: 1.25rem;
padding: 2.5rem 1.5rem;
text-align: center;
}
.receipt-page__progress-icon {
width: 64px;
height: 64px;
color: var(--primary-color);
animation: progressPulse 2s ease-in-out infinite;
}
.receipt-page__progress-svg {
width: 100%;
height: 100%;
}
@keyframes progressPulse {
0%, 100% { opacity: 1; transform: scale(1); }
50%       { opacity: 0.7; transform: scale(1.08); }
}
.receipt-page__progress-title {
color: var(--text-color);
font-size: 1.25rem;
font-weight: 700;
margin: 0;
}
.receipt-page__progress-desc {
color: var(--text-muted);
font-size: 0.9375rem;
max-width: 400px;
line-height: 1.6;
margin: 0;
}
.receipt-page__progress-actions {
display: flex;
flex-direction: column;
gap: 0.75rem;
width: 100%;
max-width: 360px;
margin-top: 0.5rem;
}
.receipt-page__progress-btn {
all: unset;
box-sizing: border-box;
display: flex;
align-items: center;
justify-content: center;
gap: 0.625rem;
width: 100%;
padding: 0.875rem 1.5rem;
border-radius: 10px;
font-size: 0.9375rem;
font-weight: 600;
cursor: pointer;
transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}
.receipt-page__progress-btn svg {
width: 20px;
height: 20px;
flex-shrink: 0;
}
.receipt-page__progress-btn:active {
transform: scale(0.97);
}
/* Bot�n "He completado mi pago" */
.receipt-page__progress-btn--success {
background: var(--success-color);
color: var(--success-foreground);
box-shadow: var(--shadow-md);
}
.receipt-page__progress-btn--success:hover {
background: var(--success-dark);
box-shadow: var(--shadow-lg);
transform: translateY(-2px);
}
/* Bot�n "No he logrado mi pago" */
.receipt-page__progress-btn--retry {
background: transparent;
color: var(--text-muted);
border: 2px solid var(--border-color);
}
.receipt-page__progress-btn--retry:hover {
border-color: var(--primary-color);
color: var(--primary-color);
background: var(--hover-background-color);
transform: translateY(-2px);
}
@media (max-width: 480px) {
.receipt-page__progress-actions {
max-width: 100%;
}
}
/* Mensaje de inscripci�n existente en Register */
.register-already-inscribed {
display: flex;
gap: 0.75rem;
padding: 0.875rem 1rem;
background: var(--info-background);
border: 1px solid var(--info-color);
border-radius: 0.5rem;
margin-bottom: 1rem;
}
.register-already-inscribed__icon {
flex-shrink: 0;
width: 1.75rem;
height: 1.75rem;
display: flex;
align-items: center;
justify-content: center;
background: var(--info-color);
color: var(--info-foreground);
border-radius: 50%;
}
.register-already-inscribed__icon svg {
width: 1.125rem;
height: 1.125rem;
}
.register-already-inscribed__content {
flex: 1;
}
.register-already-inscribed__title {
margin: 0 0 0.25rem 0;
font-size: 0.9375rem;
font-weight: 600;
color: var(--info-color);
line-height: 1.3;
}
.register-already-inscribed__message {
margin: 0 0 0.5rem 0;
font-size: 0.875rem;
color: var(--text-secondary);
line-height: 1.4;
}
.register-already-inscribed__additionals-note {
margin: 0;
padding: 0.5rem 0.625rem;
background: var(--success-background);
border-left: 2px solid var(--success-color);
border-radius: 0.25rem;
color: var(--success-color);
font-weight: 500;
font-size: 0.8125rem;
line-height: 1.4;
}
/* Responsive */
@media (max-width: 640px) {
.register-already-inscribed {
gap: 0.625rem;
padding: 0.75rem 0.875rem;
}
.register-already-inscribed__icon {
width: 1.5rem;
height: 1.5rem;
}
.register-already-inscribed__icon svg {
width: 1rem;
height: 1rem;
}
.register-already-inscribed__title {
font-size: 0.875rem;
}
.register-already-inscribed__message {
font-size: 0.8125rem;
}
.register-already-inscribed__additionals-note {
font-size: 0.75rem;
padding: 0.4375rem 0.5rem;
}
}
/* Event Register - Página de registro de eventos */
.event-register {
display: grid;
grid-template-columns: 2fr 1fr;
gap: 2rem;
margin: 2rem 0;
width: 100%;
box-sizing: border-box;
}
.event-register__main {
display: flex;
flex-direction: column;
min-width: 0;
background: var(--surface-color);
border-radius: 12px;
box-shadow: var(--shadow-sm);
padding: 2rem 2rem 1.5rem 2rem;
box-sizing: border-box;
gap: 1.5rem;
}
.event-register__summary {
background: var(--card-bg-color);
color: var(--primary-color);
border-radius: 12px;
box-shadow: var(--shadow-sm);
padding: 2rem 1.5rem;
min-width: 250px;
max-width: 400px;
box-sizing: border-box;
align-self: flex-start;
}
.event-register__header {
width: 100%;
margin-bottom: 0.5rem;
display: flex;
align-items: center;
justify-content: space-between;
padding: 0.5rem 0 0.2rem 0;
}
.event-register__title-small {
font-size: 1.18rem;
font-weight: 700;
color: var(--primary-color);
margin-bottom: 0.05rem;
letter-spacing: 0.01em;
max-width: none;
white-space: normal;
overflow: visible;
text-overflow: unset;
}
.event-register__subtitle-small {
font-size: 0.85rem;
font-weight: 400;
color: var(--text-color);
margin-bottom: 0.05rem;
letter-spacing: 0.01em;
}
.currency-select-mini {
font-size: 0.92rem;
padding: 2px 8px;
border-radius: 4px;
border: 1px solid var(--border-color);
background: var(--surface-alt-color);
min-width: 54px;
max-width: 90px;
margin-left: 1rem;
height: 28px;
color: var(--text-color);
}
.dashboard {
display: flex;
flex-direction: column;
gap: 2rem;
padding: 2rem;
background: var(--surface-color);
border-radius: 8px;
box-shadow: var(--shadow-md);
}
.dashboard__header {
display: flex;
justify-content: space-between;
align-items: center;
}
.dashboard__title {
font-size: 1.8rem;
font-weight: 700;
color: var(--primary-color);
}
.dashboard__actions {
display: flex;
gap: 1rem;
}
.dashboard__button {
padding: 0.6rem 1.2rem;
font-size: 0.9rem;
font-weight: 500;
color: var(--primary-foreground);
background: var(--primary-color);
border: none;
border-radius: 4px;
cursor: pointer;
transition: background 0.3s;
}
.dashboard__button:hover {
background: var(--primary-hover);
}
.dashboard__content {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
.dashboard__card {
background: var(--card-bg-color);
border-radius: 8px;
padding: 1.5rem;
box-shadow: var(--shadow-sm);
}
.dashboard__card-title {
font-size: 1.2rem;
font-weight: 600;
color: var(--primary-color);
margin-bottom: 1rem;
}
.dashboard__card-content {
font-size: 1rem;
color: var(--text-color);
}
.principal-category__fee-badge {
display: inline-block;
background: var(--surface-alt-color);
color: var(--primary-color);
font-size: 0.78rem;
font-weight: 600;
border-radius: 8px;
padding: 1px 8px;
margin-left: 0.5rem;
letter-spacing: 0.02em;
box-shadow: none;
vertical-align: middle;
border: 1px solid var(--primary-color);
}
.principal-category__fee-amount {
font-size: 1.05rem;
font-weight: 700;
color: var(--primary-color);
border-radius: 6px;
padding: 2px 10px;
margin-left: 0.7rem;
letter-spacing: 0.01em;
display: inline-block;
background: none;
box-shadow: none;
}
.principal-category__fee--highlight {
border: 2px solid var(--primary-color);
border-radius: 10px;
box-shadow: var(--shadow-sm);
background: var(--hover-background-color);
padding: 4px 12px;
}
.register-payment-view {
display: flex;
flex-direction: column;
gap: 1.2rem;
padding-bottom: 5rem;
position: relative;
}
.register-payment-summary-mobile {
display: none;
}
.register__terms-block {
display: flex;
flex-direction: column;
align-items: center;
width: 100%;
margin-bottom: 0.5em;
background: none;
border: none;
box-shadow: none;
padding: 0;
}
.register__terms-checkbox-row {
display: flex;
flex-direction: row;
align-items: center;
justify-content: center;
gap: 0.8rem;
width: 100%;
margin-bottom: 0;
background: none;
border: none;
box-shadow: none;
padding: 0.5rem 0;
flex-wrap: nowrap;
}
.register__terms-checkbox-large {
appearance: none;
-webkit-appearance: none;
width: 1.8rem !important;
height: 1.8rem !important;
min-width: 1.8rem;
min-height: 1.8rem;
max-width: 1.8rem;
border: 1.5px solid var(--text-color) !important;
border-radius: 6px;
background: var(--surface-color);
cursor: pointer;
margin: 0;
padding: 0;
flex-shrink: 0;
transition:
border-color 0.2s,
background 0.2s,
box-shadow 0.2s;
box-shadow: 0 0 0 3px var(--focus-ring), var(--shadow-md);
position: relative;
vertical-align: middle;
display: inline-block;
}
.register__terms-checkbox-large:hover {
border-color: var(--text-color) !important;
box-shadow: 0 0 0 4px var(--focus-ring), var(--shadow-md);
}
.register__terms-checkbox-large:focus-visible {
outline: none;
border-color: var(--text-color) !important;
box-shadow: 0 0 0 4px var(--focus-ring), var(--shadow-md);
}
.register__terms-checkbox-large:checked {
background: var(--primary-color);
border-color: var(--primary-color) !important;
box-shadow: 0 0 0 3px var(--focus-ring), var(--shadow-md);
}
.register__terms-checkbox-large:checked::after {
content: '';
position: absolute;
top: 50%;
left: 50%;
width: 0.38rem;
height: 0.7rem;
border: 2.5px solid var(--primary-foreground);
border-top: none;
border-left: none;
transform: translate(-50%, -60%) rotate(45deg);
}
.register__terms-label {
font-size: 1.08rem;
font-weight: 500;
color: var(--primary-color);
vertical-align: middle;
white-space: nowrap;
}
.register__terms-label a {
color: var(--link-color);
text-decoration: underline;
font-weight: 500;
cursor: pointer;
transition: color 0.2s;
}
.register__terms-label a:hover {
color: var(--link-hover-color);
}
.register__back-btn {
position: absolute;
left: 0.5rem;
bottom: 0.5rem;
font-size: 0.92rem;
padding: 0.3rem 1.1rem;
border-radius: 6px;
z-index: 2;
min-width: 90px;
}
.register-payment-card {
max-width: 90%;
min-width: 90%;
margin: 2.5rem auto 0 auto;
background: var(--card-bg-color);
border-radius: 16px;
box-shadow: var(--shadow-md);
border: 1px solid var(--border-color);
padding: 2rem 2rem 1.5rem 2rem;
display: flex;
flex-direction: column;
align-items: center;
gap: 1.2rem;
}
.register-payment-card__content {
width: 100%;
display: flex;
flex-direction: column;
gap: 1.2rem;
align-items: center;
}
.register-payment-card__actions {
width: 100%;
display: flex;
flex-direction: column;
gap: 1.2rem;
align-items: center;
}
.register-payment-card__button {
width: 100%;
max-width: 220px;
margin-top: 0.5rem;
font-size: 1.08rem;
font-weight: 600;
border-radius: 8px;
padding: 0.7rem 0;
}
.register-payment-card__url {
margin-top: 1.2rem;
font-size: 0.98rem;
color: var(--primary-color);
word-break: break-all;
text-align: center;
}
.register-payment-card__message {
margin-top: 1rem;
color: var(--warning-foreground);
font-size: 1.02rem;
text-align: center;
}
.register-payment-card__button-row {
display: flex;
justify-content: center;
width: 100%;
}
.register-payment-back-btn {
position: absolute;
left: 2rem;
bottom: 2rem;
min-width: 70px;
font-size: 0.88rem;
padding: 0.28rem 0.7rem;
border-radius: 7px;
z-index: 10;
}
.register-step-card {
width: 100%;
max-width: 700px;
margin: 0.5rem auto 0 auto;
background: var(--card-bg-color);
border-radius: 16px;
box-shadow: var(--shadow-md);
padding: 2rem 2rem 1.5rem 2rem;
display: flex;
flex-direction: column;
gap: 1.2rem;
align-items: stretch;
}
.register-aditional-categories-row {
width: 100%;
display: flex;
flex-direction: column;
gap: 1.2rem;
}
.app-aditional-category {
width: 100%;
box-sizing: border-box;
margin-bottom: 0.5rem;
border-radius: 12px;
background: var(--card-bg-color);
box-shadow: var(--shadow-sm);
padding: 1.2rem 1.2rem 1rem 1.2rem;
position: relative;
transition: box-shadow 0.2s, border 0.2s;
}
.app-aditional-category--selected {
border: 2.5px solid var(--primary-color);
border-width: 2px;
box-shadow: var(--shadow-md);
}
.app-aditional-category__actions {
display: flex;
align-items: center;
gap: 1.2rem;
margin-top: 0.7rem;
}
.app-aditional-category__qty-btn {
font-size: 1.5rem;
padding: 0.35rem 1.2rem;
border-radius: 8px;
min-width: 44px;
min-height: 44px;
font-weight: 700;
background: var(--secondary-background);
color: var(--primary-color);
border: 2px solid var(--primary-color);
transition: background 0.2s, color 0.2s;
}
.app-aditional-category__qty-btn:active {
background: var(--primary-color);
color: var(--primary-foreground);
}
.app-aditional-category__check {
position: absolute;
top: 1rem;
right: 1rem;
font-size: 1.7rem;
color: var(--primary-color);
background: var(--secondary-background);
border-radius: 50%;
padding: 0.2rem 0.4rem;
box-shadow: var(--shadow-sm);
}
.aditional-category__quantity-btn {
background: var(--surface-color);
border: 2px solid var(--primary-color);
color: var(--primary-color);
border-radius: 50%;
width: 2.6rem;
height: 2.6rem;
font-size: 1.5rem;
font-weight: bold;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: background 0.15s, border-color 0.15s, color 0.15s;
margin: 0 0.15rem;
padding: 0;
}
.aditional-category__quantity-btn:hover:not(:disabled),
.aditional-category__quantity-btn:focus-visible:not(:disabled) {
background: var(--primary-color);
color: var(--primary-foreground);
border-color: var(--primary-color);
}
.aditional-category--selected {
border-color: var(--primary-color);
border-width: 2px;
background: var(--secondary-background);
box-shadow: var(--shadow-md);
transition: border-color 0.2s, background 0.2s, box-shadow 0.2s, border-width 0.2s;
}
.aditional-category__selected-mark {
position: absolute;
top: 12px;
right: 18px;
font-size: 2rem;
color: var(--primary-color);
background: var(--surface-color);
border-radius: 50%;
box-shadow: var(--shadow-sm);
padding: 0.15rem 0.4rem;
z-index: 2;
}
.register-step-actions-row {
display: flex;
justify-content: space-between;
align-items: center;
width: 100%;
margin-top: 1rem;
gap: 1rem;
}
.register-step-actions-left, .register-step-actions-right { flex: 1; }
.register-step-actions-right { text-align: right; }
/* Discount section wrapper */
.register-discount-section {
width: 100%;
background: var(--secondary-background);
border: 1px solid var(--primary-color);
border-left: 4px solid var(--primary-color);
border-radius: 12px;
padding: 1.1rem 1.2rem;
box-shadow: 0 0 12px rgba(var(--primary-color-rgb, 99, 102, 241), 0.08);
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.register-discount-section__header {
display: flex;
align-items: center;
gap: 0.5rem;
}
.register-discount-section__icon {
color: var(--primary-color);
flex-shrink: 0;
}
.register-discount-section__title {
font-size: 0.95rem;
font-weight: 600;
color: var(--text-color);
}
/* Discount code block (inside section) */
.register-discount, #divDiscount {
width: 100%;
}
.register-discount__row, #divDiscount .discount-row {
display: flex;
align-items: flex-end;
gap: 0.6rem;
}
.register-discount .app-input-field, #divDiscount .app-input-field {
flex: 1 1 auto;
min-width: 0;
}
.register-discount .app-input__control, #divDiscount .app-input__control {
width: 100%;
height: 42px;
padding: 0.55rem 0.9rem;
border-radius: 8px;
border: 1px solid var(--border-color);
background: var(--surface-color);
color: var(--text-color);
box-shadow: var(--shadow-xs);
}
.register-discount .app-input__control::placeholder, #divDiscount .app-input__control::placeholder {
color: var(--text-muted);
opacity: 1;
}
.register-discount .app-input__control:focus, #divDiscount .app-input__control:focus {
outline: none;
border-color: var(--primary-color);
box-shadow: 0 0 0 3px var(--focus-ring);
}
.register-discount .app-button, #divDiscount .app-button {
height: 42px;
padding: 0 1rem;
border-radius: 8px;
white-space: nowrap;
}
.register-discount__applied, #divDiscount .discount-applied {
margin-top: 0.35rem;
font-size: 0.92rem;
color: var(--success-color);
}
.register-discount__error, #divDiscount .discount-error {
margin-top: 0.35rem;
font-size: 0.92rem;
color: var(--danger-color);
}
.register-discount__benefits {
display: flex;
flex-wrap: wrap;
gap: 6px;
margin-top: 0.5rem;
}
.register-discount__benefit-tag {
display: inline-block;
padding: 2px 10px;
border-radius: 999px;
font-size: 0.8rem;
font-weight: 600;
background: var(--info-background);
color: var(--info-foreground);
}
.register-buy-for-others {
display: flex;
align-items: center;
gap: 0.5rem;
flex-wrap: wrap;
padding: 0.6rem 0.8rem;
background: var(--surface-alt-color);
border: 1px dashed var(--primary-color);
border-radius: 8px;
}
.register-buy-for-others__icon {
color: var(--primary-color);
flex-shrink: 0;
}
.register-buy-for-others__text {
font-size: 0.88rem;
color: var(--text-secondary);
}
.register-buy-for-others__link {
font-size: 0.88rem;
font-weight: 600;
color: var(--primary-color);
text-decoration: none;
}
.register-buy-for-others__link:hover {
text-decoration: underline;
}
@media (max-width: 480px) {
.register-discount-section {
padding: 0.9rem;
}
.register-discount__row, #divDiscount .discount-row {
flex-wrap: wrap;
}
.register-discount .app-button, #divDiscount .app-button {
width: 100%;
height: 44px;
}
.register-buy-for-others {
flex-direction: column;
align-items: flex-start;
}
}
@media (max-width: 1024px) {
.event-register {
grid-template-columns: 1fr;
}
.event-register__summary {
width: 100%;
max-width: none;
justify-self: stretch;
margin-top: 1rem;
}
}
@media (max-width: 1024px) {
.register-payment-summary-mobile { display: block; }
:root:has(.register-payment-summary-mobile) .event-register__summary { display: none; }
}
/* Payment styles */
.register-payment-card__button-row {
display: grid;
grid-template-columns: 1fr;
gap: 12px;
}
.register-payment-card__button-row .app-payment-form {
width: 100%;
}
.register-payment-card__alt-row {
margin-top: 8px;
}
.app-payment-form__alt-link {
color: var(--link-color);
text-decoration: underline;
}
.app-payment-form__alt-link:hover {
color: var(--link-hover-color);
}
.register__info-message {
text-align: center;
margin: 0.5rem 0;
font-size: 1rem;
color: var(--text-color);
}
.register-result-card {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 1rem;
padding: 2rem;
border-radius: 12px;
background: var(--surface-color);
box-shadow: var(--shadow-md);
text-align: center;
max-width: 520px;
margin: 1rem auto;
}
.register-result-card__title {
font-size: 1.25rem;
font-weight: 700;
color: var(--text-color);
}
.register-result-card__icon {
width: 84px;
height: 84px;
stroke-width: 2.5;
}
.register-result-card__icon--success {
stroke: var(--success-color);
}
.register-result-card__icon--error {
stroke: var(--danger-color);
}
.register-engine-error {
display: flex;
align-items: center;
justify-content: center;
gap: .5rem;
margin: .5rem 0;
}
.register-engine-error__icon {
width: 22px;
height: 22px;
stroke: var(--danger-color);
stroke-width: 2.5;
}
.register-payment-card__engine-selector {
display: flex;
gap: .5rem;
flex-wrap: wrap;
justify-content: center;
}
.register-payment-card__alt-row { text-align: center; }
.event-register__header { }
.register-content-card {
width: 100%;
max-width: 580px;
margin: 0.5rem auto 0 auto;
background: var(--card-bg-color);
border-radius: 16px;
box-shadow: var(--shadow-md);
border: 1px solid var(--border-color);
padding: 1.5rem;
display: flex;
flex-direction: column;
gap: 1.2rem;
box-sizing: border-box;
}
.register-content-card .register-aditional-categories-row,
.register-content-card .register-fiscal-table-fullwidth,
.register-content-card .fiscal-summary__card {
width: 100%;
}
.event-register__step-container + .register-step-actions-row,
.register-content-card + .register-step-actions-row {
margin-top: 1rem;
}
/* ============================================== */
/* Responsive Breakpoints for register-content-card */
/* ============================================== */
@media (max-width: 419px) {
.register-content-card {
max-width: 100%;
width: 100%;
margin: 0;
padding: 0.875rem;
border-radius: 0.75rem;
gap: 1rem;
}
}
@media (min-width: 420px) and (max-width: 639px) {
.register-content-card {
max-width: 100%;
width: 100%;
padding: 1rem;
gap: 1rem;
}
}
@media (min-width: 640px) and (max-width: 1023px) {
.register-content-card {
max-width: 90%;
padding: 1.25rem;
}
}
@media (min-width: 1024px) {
.register-content-card {
max-width: 680px;
padding: 1.75rem;
}
}
@media (min-width: 1280px) {
.register-content-card {
max-width: 700px;
padding: 2rem;
}
}
/* ============================================== */
/* Fiscal selection hint message */
/* ============================================== */
.register-fiscal-hint {
display: flex;
align-items: flex-start;
gap: 0.75rem;
background: var(--info-background);
border: 1px solid var(--info-color);
border-radius: 10px;
padding: 0.85rem 1rem;
margin-bottom: 0.5rem;
}
.register-fiscal-hint__icon {
width: 22px;
height: 22px;
min-width: 22px;
color: var(--info-foreground);
flex-shrink: 0;
margin-top: 0.1rem;
}
.register-fiscal-hint__text {
color: var(--info-foreground);
font-size: 0.92rem;
line-height: 1.5;
margin: 0;
}
@media (max-width: 640px) {
.register-fiscal-hint {
padding: 0.75rem;
}
}
/* ============================================== */
/* No deseo factura fiscal - Sección y Modal */
/* ============================================== */
.register-no-invoice {
background: var(--warning-background);
border: 2px solid var(--warning-color);
border-radius: 12px;
padding: 1.25rem;
margin-bottom: 1.5rem;
text-align: center;
}
.register-no-invoice__text {
color: var(--warning-foreground);
font-size: 0.95rem;
margin: 0 0 1rem 0;
line-height: 1.5;
}
.register-no-invoice__button {
min-width: 220px;
}
.register-no-invoice-confirmed {
display: flex;
align-items: flex-start;
gap: 1rem;
background: var(--info-background);
border: 2px solid var(--info-color);
border-radius: 12px;
padding: 1.25rem;
margin-bottom: 1.5rem;
}
.register-no-invoice-confirmed__icon {
width: 32px;
height: 32px;
color: var(--info-foreground);
flex-shrink: 0;
}
.register-no-invoice-confirmed__content {
flex: 1;
}
.register-no-invoice-confirmed__text {
color: var(--info-foreground);
font-size: 0.95rem;
margin: 0 0 0.75rem 0;
line-height: 1.6;
}
.register-no-invoice-confirmed__text strong {
font-weight: 700;
color: var(--info-foreground);
}
.register-no-invoice-modal {
display: flex;
flex-direction: column;
align-items: center;
gap: 1rem;
padding: 1rem;
text-align: center;
}
.register-no-invoice-modal__icon {
width: 64px;
height: 64px;
color: var(--warning-color);
margin-bottom: 0.5rem;
}
.register-no-invoice-modal__text {
color: var(--text-color);
font-size: 1rem;
line-height: 1.6;
margin: 0;
}
.register-no-invoice-modal__text strong {
color: var(--danger-color);
font-weight: 700;
}
.register-no-invoice-modal__question {
color: var(--primary-color);
font-size: 1.05rem;
font-weight: 600;
margin: 0.5rem 0 0 0;
}
@media (max-width: 640px) {
.register-no-invoice,
.register-no-invoice-confirmed {
padding: 1rem;
}
.register-no-invoice__button {
min-width: 100%;
}
.register-no-invoice-modal__icon {
width: 48px;
height: 48px;
}
}
/* ============================================
Admin Users List Page
============================================ */
.admin-users {
width: 100%;
max-width: 100%;
padding: var(--spacing-md);
box-sizing: border-box;
}
.admin-users__header {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: var(--spacing-lg);
padding-bottom: var(--spacing-md);
border-bottom: 2px solid var(--primary-color);
}
.admin-users__title {
font-size: var(--font-size-3xl, 2rem);
font-weight: var(--font-weight-bold, 700);
color: var(--text-primary, var(--text-color));
margin: 0;
letter-spacing: -0.02em;
background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-dark) 100%);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.admin-users__content {
width: 100%;
margin-top: var(--spacing-md);
}
.admin-users__loading {
display: flex;
align-items: center;
justify-content: center;
padding: var(--spacing-xl);
}
.admin-users__error {
padding: var(--spacing-md);
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: var(--border-radius-md, 8px);
margin: var(--spacing-md) 0;
}
.admin-users__empty {
text-align: center;
padding: var(--spacing-xl);
color: var(--text-secondary);
font-size: var(--font-size-lg, 1.125rem);
}
/* Table */
.admin-users__table-wrapper {
width: 100%;
overflow-x: auto;
margin-top: var(--spacing-md);
}
.admin-users__th {
text-align: left;
white-space: nowrap;
font-size: var(--font-size-sm, 0.875rem);
color: var(--table-header-text);
padding: var(--spacing-sm) var(--spacing-md);
}
.admin-users__th--sortable {
cursor: pointer;
user-select: none;
}
.admin-users__th--sortable:hover {
color: var(--primary-color);
}
.admin-users__td {
padding: var(--spacing-sm) var(--spacing-md);
font-size: var(--font-size-sm, 0.875rem);
vertical-align: middle;
color: var(--text-color);
}
.admin-users__td--email {
max-width: 220px;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.admin-users__th--actions,
.admin-users__td--actions {
width: 50px;
text-align: center;
}
/* User cell */
.admin-users__user-cell {
display: flex;
align-items: center;
gap: var(--spacing-sm);
}
.admin-users__avatar {
width: 36px;
height: 36px;
border-radius: 50%;
object-fit: cover;
flex-shrink: 0;
}
.admin-users__avatar-initials {
width: 36px;
height: 36px;
border-radius: 50%;
background: var(--primary-color);
color: var(--primary-foreground, #fff);
display: flex;
align-items: center;
justify-content: center;
font-size: var(--font-size-sm, 0.875rem);
font-weight: 700;
flex-shrink: 0;
}
.admin-users__user-info {
display: flex;
flex-direction: column;
gap: 1px;
}
.admin-users__user-name {
font-weight: 500;
color: var(--text-color);
}
.admin-users__user-title {
font-size: var(--font-size-xs, 0.75rem);
color: var(--text-muted);
}
/* Filters */
.admin-users__filter-group {
margin-bottom: var(--spacing-md);
}
.admin-users__filter-divider {
border-top: 1px solid var(--divider-color);
margin: var(--spacing-md) 0;
}
.admin-users__label {
display: block;
font-size: var(--font-size-sm, 0.875rem);
font-weight: 500;
color: var(--text-secondary);
margin-bottom: var(--spacing-xs, 4px);
}
/* Status */
.admin-users__status {
display: inline-block;
padding: 2px 10px;
border-radius: 999px;
font-size: var(--font-size-xs, 0.75rem);
font-weight: 600;
}
.admin-users__status--active {
background: var(--success-background);
color: var(--success-foreground);
}
.admin-users__status--inactive {
background: var(--danger-background);
color: var(--danger-foreground);
}
/* Detail Modal */
.admin-users__detail {
display: flex;
flex-direction: column;
gap: var(--spacing-lg);
}
.admin-users__detail-header {
display: flex;
align-items: center;
gap: var(--spacing-md);
}
.admin-users__detail-avatar {
width: 64px;
height: 64px;
border-radius: 50%;
object-fit: cover;
flex-shrink: 0;
}
.admin-users__detail-avatar-initials {
width: 64px;
height: 64px;
border-radius: 50%;
background: var(--primary-color);
color: var(--primary-foreground, #fff);
display: flex;
align-items: center;
justify-content: center;
font-size: var(--font-size-xl, 1.5rem);
font-weight: 700;
flex-shrink: 0;
}
.admin-users__detail-name {
margin: 0;
font-size: var(--font-size-lg, 1.125rem);
font-weight: 600;
color: var(--text-color);
}
.admin-users__detail-email {
margin: 2px 0 6px;
font-size: var(--font-size-sm, 0.875rem);
color: var(--text-muted);
}
.admin-users__detail-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: var(--spacing-md);
}
.admin-users__detail-field {
display: flex;
flex-direction: column;
gap: 2px;
}
.admin-users__detail-label {
font-size: var(--font-size-xs, 0.75rem);
font-weight: 600;
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: 0.04em;
}
/* Confirm */
.admin-users__confirm-text {
font-size: var(--font-size-md, 1rem);
color: var(--text-color);
}
/* Buttons */
.admin-users__btn-primary {
background: var(--primary-color);
color: var(--primary-foreground);
}
.admin-users__btn-secondary {
background: var(--secondary-background);
color: var(--text-color);
}
.admin-users__btn-danger {
background: var(--danger-color);
color: #fff;
}
/* Responsive */
@media (max-width: 768px) {
.admin-users {
padding: var(--spacing-sm);
}
.admin-users__title {
font-size: var(--font-size-xl, 1.5rem);
}
.admin-users__detail-grid {
grid-template-columns: 1fr;
}
}
@media (max-width: 480px) {
.admin-users__header {
flex-direction: column;
align-items: flex-start;
gap: var(--spacing-sm);
}
.admin-users__detail-header {
flex-direction: column;
align-items: center;
text-align: center;
}
}
.user-profile{width:100%}
.user-profile__header{max-width:1000px;margin:0 auto;padding:1rem 1.25rem}
.user-profile__title{margin:0 0 .25rem;font-size:1.5rem;font-weight:700}
.user-profile__subtitle{margin:0;color:var(--text-muted)}
.user-profile__content{max-width:1000px;margin:0 auto;padding:0 1.25rem 2rem}
.user-profile__grid{display:grid;grid-template-columns:1fr;gap:1.25rem}
.user-profile__photo{background:transparent}
.user-profile__form{background:transparent}
.user-profile__status{font-size:.875rem;color:var(--text-muted);margin-top:.5rem}
@media (min-width: 768px){
.user-profile__grid{grid-template-columns:320px 1fr}
}
/* Webhook Admin Page Styles - Compatible con WASM/MAUI */
.webhook-page {
padding: 2rem;
max-width: 800px;
margin: 0 auto;
}
.webhook-page__header {
margin-bottom: 2rem;
}
.webhook-page__title {
color: var(--text-color);
font-size: 1.75rem;
font-weight: 700;
margin: 0 0 0.5rem 0;
}
.webhook-page__subtitle {
color: var(--text-muted);
font-size: 0.875rem;
margin: 0;
line-height: 1.6;
}
/* Alertas */
.webhook-page__alert {
padding: 1rem 1.25rem;
border-radius: 8px;
margin-bottom: 1.5rem;
display: flex;
align-items: flex-start;
gap: 0.75rem;
}
.webhook-page__alert--error {
background: var(--danger-background);
border: 1px solid var(--danger-color);
color: var(--danger-color);
}
.webhook-page__alert--success {
background: var(--success-background);
border: 1px solid var(--success-color);
color: var(--success-color);
}
.webhook-page__alert--warning {
background: var(--warning-background);
border: 1px solid var(--warning-color);
color: var(--warning-color);
}
.webhook-page__alert-icon {
flex-shrink: 0;
width: 20px;
height: 20px;
}
.webhook-page__alert-text {
flex: 1;
margin: 0;
line-height: 1.5;
}
/* Formulario */
.webhook-form {
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 12px;
padding: 2rem;
box-shadow: var(--shadow-sm);
}
.webhook-form__section {
margin-bottom: 2rem;
}
.webhook-form__section:last-child {
margin-bottom: 0;
}
.webhook-form__section-title {
color: var(--text-color);
font-size: 1rem;
font-weight: 600;
margin: 0 0 1rem 0;
}
.webhook-form__section-description {
color: var(--text-muted);
font-size: 0.875rem;
margin: 0 0 1rem 0;
line-height: 1.5;
}
.webhook-form__section-description code {
background: var(--secondary-background);
color: var(--primary-color);
padding: 0.125rem 0.375rem;
border-radius: 4px;
font-size: 0.8125rem;
font-family: 'Courier New', monospace;
}
/* Campo de input */
.webhook-form__field {
margin-bottom: 1.5rem;
}
.webhook-form__label {
display: block;
color: var(--text-color);
font-size: 0.875rem;
font-weight: 500;
margin-bottom: 0.5rem;
}
.webhook-form__label-required {
color: var(--danger-color);
margin-left: 0.25rem;
}
.webhook-form__input {
width: 100%;
padding: 0.75rem 1rem;
font-size: 0.875rem;
color: var(--text-color);
background: var(--background-color);
border: 1px solid var(--border-color);
border-radius: 8px;
transition: border-color 0.2s, box-shadow 0.2s;
}
.webhook-form__input:focus {
outline: none;
border-color: var(--primary-color);
box-shadow: 0 0 0 3px var(--focus-ring);
}
.webhook-form__input::placeholder {
color: var(--text-muted);
}
.webhook-form__input--error {
border-color: var(--danger-color);
}
.webhook-form__hint {
color: var(--text-muted);
font-size: 0.75rem;
margin-top: 0.5rem;
display: block;
}
/* Checkboxes */
.webhook-form__checkbox-group {
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.webhook-form__checkbox-group-title {
color: var(--text-color);
font-size: 0.9375rem;
font-weight: 600;
margin: 1.5rem 0 0.75rem 0;
padding-bottom: 0.5rem;
border-bottom: 1px solid var(--border-light);
}
.webhook-form__checkbox-group-title:first-child {
margin-top: 0;
}
.webhook-form__checkbox-item {
display: flex;
align-items: center;
gap: 0.5rem;
}
.webhook-form__checkbox {
width: 18px;
height: 18px;
cursor: pointer;
accent-color: var(--primary-color);
}
.webhook-form__checkbox-label {
color: var(--text-color);
font-size: 0.875rem;
cursor: pointer;
user-select: none;
}
.webhook-form__checkbox-description {
color: var(--text-muted);
font-size: 0.75rem;
margin-left: 1.75rem;
}
/* Botones */
.webhook-form__actions {
display: flex;
gap: 1rem;
flex-wrap: wrap;
}
.webhook-form__button {
padding: 0.75rem 1.5rem;
font-size: 0.875rem;
font-weight: 500;
border: none;
border-radius: 8px;
cursor: pointer;
transition: background-color 0.2s, transform 0.1s;
display: inline-flex;
align-items: center;
gap: 0.5rem;
}
.webhook-form__button:hover:not(:disabled) {
transform: translateY(-1px);
}
.webhook-form__button:active:not(:disabled) {
transform: translateY(0);
}
.webhook-form__button:disabled {
opacity: 0.6;
cursor: not-allowed;
}
.webhook-form__button--primary {
background: var(--primary-color);
color: var(--primary-foreground);
}
.webhook-form__button--primary:hover:not(:disabled) {
background: var(--primary-hover);
}
.webhook-form__button--secondary {
background: var(--secondary-background);
color: var(--text-color);
border: 1px solid var(--border-color);
}
.webhook-form__button--secondary:hover:not(:disabled) {
background: var(--hover-background-color);
}
.webhook-form__button-icon {
width: 16px;
height: 16px;
}
/* Spinner de carga */
.webhook-form__spinner {
border: 2px solid var(--border-color);
border-top-color: var(--primary-foreground);
border-radius: 50%;
width: 16px;
height: 16px;
animation: spin 0.6s linear infinite;
}
@keyframes spin {
to { transform: rotate(360deg); }
}
/* Resultado */
.webhook-result {
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 12px;
padding: 1.5rem;
margin-top: 1.5rem;
}
.webhook-result__title {
color: var(--text-color);
font-size: 1rem;
font-weight: 600;
margin: 0 0 1rem 0;
}
.webhook-result__row {
display: flex;
justify-content: space-between;
align-items: flex-start;
padding: 0.75rem 0;
border-bottom: 1px solid var(--border-light);
gap: 1rem;
}
.webhook-result__row:last-child {
border-bottom: none;
}
.webhook-result__label {
color: var(--text-muted);
font-size: 0.875rem;
font-weight: 500;
flex-shrink: 0;
}
.webhook-result__value {
color: var(--text-color);
font-size: 0.875rem;
font-family: 'Courier New', monospace;
word-break: break-all;
text-align: right;
}
.webhook-result__value--verified {
color: var(--success-color);
}
.webhook-result__value--unverified {
color: var(--warning-color);
}
.webhook-result__events {
display: flex;
flex-wrap: wrap;
gap: 0.5rem;
justify-content: flex-end;
}
.webhook-result__event-badge {
background: var(--primary-color);
color: var(--primary-foreground);
padding: 0.25rem 0.75rem;
border-radius: 12px;
font-size: 0.75rem;
font-weight: 500;
}
/* Responsive */
@media (max-width: 640px) {
.webhook-page {
padding: 1rem;
}
.webhook-form {
padding: 1.5rem;
}
.webhook-form__actions {
flex-direction: column;
}
.webhook-form__button {
width: 100%;
justify-content: center;
}
.webhook-result__row {
flex-direction: column;
gap: 0.5rem;
}
.webhook-result__value {
text-align: left;
}
.webhook-result__events {
justify-content: flex-start;
}
}
.not-found {
min-height: 80vh;
display: flex;
align-items: center;
justify-content: center;
background: var(--background-color);
}
.not-found__card {
text-align: center;
background: var(--surface-color);
border-radius: 2rem;
box-shadow: var(--shadow-xl);
padding: 3.5rem 2.5rem;
max-width: 420px;
width: 100%;
margin: 0 auto;
display: flex;
flex-direction: column;
align-items: center;
}
.not-found__icon {
margin-bottom: 1.5rem;
}
.not-found__title {
font-size: 2.5rem;
color: var(--danger-color);
margin-bottom: 1rem;
font-weight: 800;
letter-spacing: 1px;
}
.not-found__message {
color: var(--text-color);
margin-bottom: 2.5rem;
font-size: 1.15rem;
line-height: 1.6;
}
.not-found__button {
min-width: 180px;
font-size: 1.1rem;
padding: 0.75rem 1.5rem;
}
/* Estructura y estilos base para EventDetail */
.event-detail {
display: flex;
flex-direction: column;
gap: 2rem;
padding: 2rem 1rem;
background: var(--background-color);
min-height: 80vh;
}
.event-detail__header {
text-align: center;
margin-bottom: 2rem;
}
.event-detail__title {
font-size: 2.2rem;
font-weight: 700;
color: var(--primary-color);
margin-bottom: 0.5rem;
}
.event-detail__dates {
font-size: 1.1rem;
color: var(--accent-color);
margin-bottom: 0.25rem;
}
.event-detail__venue {
font-size: 1rem;
color: var(--text-color);
margin-bottom: 0.5rem;
}
.event-detail__main {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
gap: 2rem;
width: 100%;
justify-items: center;
}
@media (max-width: 900px) {
.event-detail__main {
grid-template-columns: 1fr;
}
}
/* Events Page - BEM Methodology */
.events {
display: flex;
flex-direction: column;
gap: 2rem;
padding: 2rem 1rem;
min-height: 80vh;
background: var(--background-color);
}
/* ── FILTROS: Search pill compacta ─────────────────────────────── */
.events__filters {
display: flex;
justify-content: center;
align-items: center;
width: 100%;
margin: 0 0 0.5rem;
position: relative;
z-index: 100;
}
.events__filters-form {
display: flex;
flex-direction: row;
align-items: center;
gap: 0;
background: var(--events-pill-bg);
border: 1px solid var(--events-pill-border);
border-radius: 9999px;
box-shadow: var(--events-pill-shadow);
padding: 0.3rem 0.3rem 0.3rem 1.1rem;
width: 100%;
max-width: 560px;
backdrop-filter: blur(8px);
-webkit-backdrop-filter: blur(8px);
transition: box-shadow 0.2s, border-color 0.2s;
}
.events__filters-form:focus-within {
border-color: var(--focus-color);
box-shadow: var(--events-pill-shadow), 0 0 0 3px var(--focus-ring);
}
/* Divisor visual entre secciones de la pill */
.events__filters-divider {
width: 1px;
height: 1.5rem;
background: var(--border-color);
flex-shrink: 0;
margin: 0 0.25rem;
}
.events__filters-search {
flex: 1 1 0;
min-width: 0;
border: none !important;
background: transparent !important;
box-shadow: none !important;
outline: none !important;
padding: 0.4rem 0.5rem 0.4rem 0 !important;
margin: 0 !important;
font-size: 0.9375rem;
color: var(--text-color);
transform: none !important;
}
.events__filters-year,
.events__filters-month {
border: none !important;
background: transparent !important;
box-shadow: none !important;
outline: none !important;
padding: 0.4rem 0.5rem !important;
margin: 0 !important;
font-size: 0.875rem;
color: var(--text-muted);
min-width: 0;
max-width: 7rem;
cursor: pointer;
transform: none !important;
}
.events__filters-button {
flex-shrink: 0;
width: 38px;
height: 38px;
min-width: 38px;
padding: 0;
display: flex;
align-items: center;
justify-content: center;
border-radius: 9999px;
background: var(--primary-color);
border: none;
box-shadow: none;
transition: background 0.2s, transform 0.15s;
}
.events__filters-button:hover {
background: var(--primary-hover) !important;
transform: scale(1.07);
box-shadow: none !important;
}
.events__filters-button svg {
display: block;
color: var(--primary-foreground);
fill: var(--primary-foreground);
}
.events__filters-clear {
flex-shrink: 0;
width: 30px;
height: 30px;
min-width: 30px;
padding: 0;
display: flex;
align-items: center;
justify-content: center;
border-radius: 9999px;
background: transparent;
border: none;
color: var(--text-muted);
margin-right: 0.25rem;
transition: color 0.2s, background 0.2s;
box-shadow: none;
}
.events__filters-clear:hover {
color: var(--danger-color) !important;
background: var(--danger-background) !important;
box-shadow: none !important;
transform: none !important;
}
.events__filters-clear svg {
color: currentColor;
fill: currentColor;
stroke: currentColor;
width: 16px;
height: 16px;
display: block;
}
/* Anular estilos de app-select cuando vive dentro de la pill */
.events__filters-form .app-select {
margin-bottom: 0;
width: auto;
}
.events__filters-form .app-select__control {
border: none;
background: transparent;
box-shadow: none;
padding: 0.4rem 0.5rem;
min-height: unset;
}
.events__filters-form .app-select__control:hover,
.events__filters-form .app-select__control:focus {
border: none;
box-shadow: none;
background: transparent;
}
.events__filters-form .app-select__dropdown {
z-index: 200;
}
/* ── GRID DE CARDS ──────────────────────────────────────────────── */
.events__list {
display: grid;
grid-template-columns: 1fr;        /* móvil: 1 card */
gap: 1.5rem;
width: 100%;
}
.events__card {
display: grid;
grid-template-columns: 1fr 1fr;
grid-template-rows: 1fr auto;
border-radius: 1.25rem;
overflow: hidden;
cursor: pointer;
box-shadow: var(--shadow-md);
border: 1px solid var(--border-color);
background: var(--surface-color);
min-height: 20rem;
transition: box-shadow 0.25s cubic-bezier(.25,.8,.25,1),
border-color 0.25s cubic-bezier(.25,.8,.25,1),
transform 0.25s cubic-bezier(.25,.8,.25,1);
z-index: 1;
}
.events__card:hover {
box-shadow: var(--shadow-xl);
transform: translateY(-3px);
border-color: var(--events-card-accent);
z-index: 2;
}
/* Poster: ocupa toda la altura del card */
.events__card-image-wrapper {
grid-column: 1 / 2;
grid-row: 1 / 3;
overflow: hidden;
background: var(--surface-alt-color);
display: flex;
align-items: center;
justify-content: center;
}
.events__card-image {
width: 100%;
height: 100%;
object-fit: contain;
object-position: center center;
display: block;
transition: transform 0.35s cubic-bezier(.25,.8,.25,1);
}
.events__card:hover .events__card-image {
transform: scale(1.02);
}
/* Body: columna derecha */
.events__card-body {
grid-column: 2 / 3;
grid-row: 1 / 3;
display: flex;
flex-direction: column;
min-width: 0;
border-left: 2px solid transparent;
background-image: linear-gradient(var(--surface-color), var(--surface-color)),
linear-gradient(to bottom, transparent 8%, var(--events-card-accent) 35%, var(--events-card-accent) 65%, transparent 92%);
background-origin: border-box;
background-clip: padding-box, border-box;
}
/* Modo claro: separador más suave */
@media (prefers-color-scheme: light) {
.events__card-body {
background-image: linear-gradient(var(--surface-color), var(--surface-color)),
linear-gradient(to bottom, transparent 8%, var(--border-color) 35%, var(--border-color) 65%, transparent 92%);
}
}
/* Content */
.events__card-content {
flex: 1 1 auto;
display: flex;
flex-direction: column;
gap: 0.75rem;
padding: 1.5rem 1.5rem 1rem 1.5rem;
min-width: 0;
justify-content: flex-start;
}
.events__card-title {
font-size: 1.15rem;
font-weight: 700;
color: var(--text-color);
margin: 0;
line-height: 1.35;
display: -webkit-box;
-webkit-line-clamp: 3;
-webkit-box-orient: vertical;
overflow: hidden;
}
.events__card-dates {
font-size: 1.1rem;
font-weight: 700;
color: var(--text-color);
}
.events__card-venue {
font-size: 1rem;
color: var(--primary-color);
font-weight: 500;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
/* Acciones: ancladas al fondo */
.events__card-actions {
padding: 0 1.5rem 1.5rem 1.5rem;
flex-shrink: 0;
}
.events__card-button {
width: 100%;
justify-content: center;
}
/* ── ESTADOS ────────────────────────────────────────────────────── */
.events__loading,
.events__empty {
text-align: center;
color: var(--text-muted);
font-size: 1.2rem;
margin: 2rem 0;
grid-column: 1 / -1;
}
.events__pagination {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.5rem;
margin-top: 2rem;
}
.events__pagination-summary {
margin-top: 0.5rem;
font-size: 1.05rem;
color: var(--text-color);
text-align: center;
}
/* ── RESPONSIVO ─────────────────────────────────────────────────── */
/* Tablet (≥768px): 2 columnas — cards anchos, poster generoso */
@media (min-width: 768px) {
.events__list {
grid-template-columns: repeat(2, 1fr);
}
.events__card {
min-height: 24rem;
}
}
/* Desktop grande (≥1400px): 3 columnas — pantallas con espacio de sobra */
@media (min-width: 1400px) {
.events__list {
grid-template-columns: repeat(3, 1fr);
}
.events__card {
min-height: 26rem;
}
}
/* Móvil (≤600px) */
@media (max-width: 600px) {
.events__filters-form {
max-width: 100%;
padding: 0.25rem 0.25rem 0.25rem 0.875rem;
}
.events__filters-year,
.events__filters-month,
.events__filters-divider {
display: none;
}
.events__card {
min-height: 13rem;
}
.events__card-content {
padding: 1rem 1rem 0.75rem 1rem;
gap: 0.5rem;
}
.events__card-title {
font-size: 0.9rem;
-webkit-line-clamp: 3;
}
.events__card-dates {
font-size: 0.875rem;
}
.events__card-venue {
font-size: 0.8rem;
}
.events__card-actions {
padding: 0 1rem 1rem 1rem;
}
}
/* Help page (BEM) - Hero Minimalista Moderno */
.help {
display: flex;
flex-direction: column;
min-height: 100vh;
}
/* Hero - Diseño Minimalista y Profesional */
.help__hero {
position: relative;
background: var(--surface-color);
border-bottom: 1px solid var(--border-color);
padding: 1.5rem 1.5rem 1rem;
}
.help__hero::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
height: 4px;
background: linear-gradient(90deg, var(--primary-color) 0%, var(--accent-color) 100%);
}
.help__hero-inner {
max-width: 860px;
margin: 0 auto;
text-align: center;
}
.help__title {
margin: 0 0 0.375rem;
font-size: 1.75rem;
font-weight: 700;
color: var(--text-color) !important;
letter-spacing: -0.02em;
display: inline-flex;
align-items: center;
gap: 0.75rem;
}
.help__title::before {
content: '💬';
font-size: 1.5rem;
opacity: 0.8;
}
.help__subtitle {
margin: 0 auto !important;
max-width: 720px;
color: var(--text-muted) !important;
font-size: 0.938rem !important;
line-height: 1.5;
font-weight: 400;
}
/* Form Section */
.help__form-section {
padding: 2rem 1.5rem 3rem;
}
.help__form-container {
max-width: 720px;
margin: 0 auto;
display: grid;
gap: 1rem;
}
.help__select {
width: 100%;
}
.help__actions {
margin-top: 0.5rem;
display: flex;
justify-content: flex-end;
gap: 0.75rem;
}
/* Textarea */
.help__textarea {
width: 100%;
min-height: 160px;
padding: 0.75rem 0.85rem;
border-radius: 0.5rem;
border: 1px solid var(--border-color);
background: var(--surface-color);
color: var(--text-color);
font: inherit;
resize: vertical;
transition: border-color 0.2s, box-shadow 0.2s;
}
.help__textarea:focus {
outline: none;
border-color: var(--primary-color);
box-shadow: 0 0 0 3px var(--focus-ring);
}
.help__textarea--invalid {
border-color: var(--danger-color);
}
.help__error {
color: var(--danger-color);
font-size: 0.875rem;
margin-top: 0.25rem;
}
/* Open Ticket Card */
.help__open-ticket {
margin-top: 1rem;
}
/* Overlay */
.help__overlay {
position: fixed;
inset: 0;
background: var(--overlay-color);
display: flex;
align-items: center;
justify-content: center;
padding: 1rem;
z-index: 1000;
animation: fadeIn 0.2s ease;
}
@keyframes fadeIn {
from { opacity: 0; }
to { opacity: 1; }
}
.help__overlay-card {
width: min(680px, 100%);
animation: slideUp 0.3s ease;
}
@keyframes slideUp {
from {
opacity: 0;
transform: translateY(20px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
/* Responsive - Tablets */
@media (max-width: 768px) {
.help__hero {
padding: 1.25rem 1rem 0.875rem;
}
.help__title {
font-size: 1.5rem;
}
.help__title::before {
font-size: 1.25rem;
}
.help__subtitle {
font-size: 0.875rem !important;
}
.help__form-section {
padding: 1.75rem 1rem 2.5rem;
}
.help__actions {
flex-direction: column;
}
}
/* Responsive - Móviles */
@media (max-width: 480px) {
.help__title {
font-size: 1.375rem;
}
.help__textarea {
min-height: 140px;
}
}
.home-hero {
display: flex;
align-items: center;
justify-content: space-between;
padding: 3rem 2rem 2rem 2rem;
background: linear-gradient(135deg, var(--surface-alt-color) 0%, var(--surface-color) 100%);
border-radius: 1.5rem;
box-shadow: var(--shadow-xl);
margin-bottom: 2.5rem;
gap: 2rem;
flex-wrap: wrap;
}
.home-hero__content {
flex: 1 1 320px;
min-width: 280px;
}
.home-hero__title {
font-size: 2.5rem;
font-weight: 800;
color: var(--primary-color);
margin-bottom: 0.5rem;
}
.home-hero__subtitle {
font-size: 1.25rem;
color: var(--text-muted);
margin-bottom: 2rem;
}
.home-hero__image img {
max-width: 340px;
width: 100%;
border-radius: 1rem;
box-shadow: var(--shadow-lg);
}
.home-services {
text-align: center;
margin-bottom: 2rem;
}
.home-services__title {
font-size: 1.7rem;
font-weight: 700;
color: var(--primary-color);
margin-bottom: 2rem;
}
.home-services__list {
display: flex;
flex-wrap: wrap;
gap: 2rem;
justify-content: center;
}
.home-service {
background: var(--surface-color);
border-radius: 1rem;
box-shadow: var(--shadow-sm);
padding: 1.5rem 1.2rem;
width: 260px;
min-width: 220px;
max-width: 100%;
display: flex;
flex-direction: column;
align-items: center;
transition: box-shadow 0.2s, transform 0.2s;
}
.home-service:hover {
box-shadow: var(--shadow-xl);
transform: translateY(-4px) scale(1.03);
}
.home-service__icon {
font-size: 2.2rem;
margin-bottom: 0.7rem;
color: var(--primary-color);
}
.home-service__name {
font-size: 1.15rem;
font-weight: 600;
margin-bottom: 0.5rem;
color: var(--primary-color);
}
.home-service__desc {
color: var(--text-muted);
font-size: 1rem;
margin-bottom: 0;
}
@media (max-width: 900px) {
.home-hero {
flex-direction: column;
align-items: flex-start;
padding: 2rem 1rem;
}
.home-hero__image {
align-self: center;
margin-top: 1.5rem;
}
.home-services__list {
gap: 1.2rem;
}
}
/* ============================================================
home-order — Página de envío de trabajos (BEM)
============================================================ */
/* Block */
.home-order {
max-width: 860px;
margin: 0 auto;
padding: 2rem 1.25rem 4rem;
}
/* Header */
.home-order__header {
text-align: center;
margin-bottom: 2rem;
}
.home-order__title {
font-size: 2rem;
font-weight: 800;
color: var(--primary-color);
margin-bottom: 0.4rem;
}
.home-order__subtitle {
font-size: 1rem;
color: var(--text-muted);
}
/* Steps bar */
.home-order__steps {
margin-bottom: 2.5rem;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 1rem;
padding: 1.25rem 1.75rem 0.75rem;
box-shadow: var(--shadow-sm);
}
/* Content card */
.home-order__content {
display: flex;
justify-content: center;
}
.home-order__card {
width: 100%;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 1.25rem;
box-shadow: var(--shadow-md);
padding: 2rem 2.25rem;
}
/* Wrapper centrado para el auth step */
.home-order__auth-wrap {
display: flex;
flex-direction: column;
justify-content: center;
width: 100%;
}
.home-order__auth-wrap > * {
width: 100%;
/*/max-width: 560px;*/
}
.home-order__auth-wrap__login{
max-width: 560px;
}
/* Generic step section */
.home-order__step-section {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
.home-order__step-header {
border-bottom: 1px solid var(--border-light);
}
.home-order__step-title {
font-size: 1.35rem;
font-weight: 700;
color: var(--text-color);
margin-bottom: 0.25rem;
}
.home-order__step-description {
font-size: 0.9rem;
color: var(--text-muted);
}
/* Success state */
.home-order__success {
display: flex;
flex-direction: column;
align-items: center;
gap: 1.25rem;
padding: 2rem 0;
text-align: center;
}
.home-order__success-icon {
width: 72px;
height: 72px;
border-radius: 50%;
background: var(--success-background);
display: flex;
align-items: center;
justify-content: center;
color: var(--success-color);
}
.home-order__success-icon svg {
width: 40px;
height: 40px;
}
.home-order__success-title {
font-size: 1.6rem;
font-weight: 700;
color: var(--success-color);
}
.home-order__success-message {
font-size: 1rem;
color: var(--text-muted);
max-width: 440px;
}
.home-authores-step__header {
border-bottom: 1px solid var(--border-light);
margin-bottom: 0.8rem;
}
.home-authores-step__title {
font-size: 1.35rem;
font-weight: 700;
color: var(--text-color);
margin-bottom: 0.25rem;
}
.home-authores-step__description {
font-size: 0.9rem;
color: var(--text-muted);
}
.home-authores-step__form {
display: flex;
flex-direction: column;
gap: 1.25rem;
margin-bottom: 2rem;
}
.home-authores-step__row {
display: grid;
/*grid-template-columns: 1fr 1fr;*/
gap: 1.25rem;
}
.home-authores-step__actions {
display: flex;
justify-content: flex-end;
gap: 0.75rem;
border-top: 1px solid var(--border-light);
padding-top: 1.25rem;
}
.home-abstract-step__header {
border-bottom: 1px solid var(--border-light);
padding-bottom: 1rem;
margin-bottom: 1.5rem;
}
.home-abstract-step__title {
font-size: 1.35rem;
font-weight: 700;
color: var(--text-color);
margin-bottom: 0.25rem;
}
.home-abstract-step__description {
font-size: 0.9rem;
color: var(--text-muted);
}
.home-abstract-step__form {
display: flex;
flex-direction: column;
gap: 1.25rem;
margin-bottom: 2rem;
}
.home-abstract-step__row {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 1.25rem;
}
.home-abstract-step__field--full {
display: flex;
flex-direction: column;
gap: 0.4rem;
grid-column: 1 / -1;
}
/* label genérico para textareas */
.home-abstract-step__label {
font-size: 0.875rem;
font-weight: 600;
color: var(--text-color);
display: block;
margin-bottom: 0.25rem;
}
.home-abstract-step__textarea-label {
font-size: 0.875rem;
font-weight: 600;
color: var(--text-color);
}
.home-abstract-step__required {
color: var(--danger-color);
}
.home-abstract-step__textarea {
width: 100%;
padding: 0.75rem 1rem;
border: 1.5px solid var(--border-color);
border-radius: 0.6rem;
font-size: 0.95rem;
color: var(--text-color);
background: var(--surface-color);
resize: vertical;
transition: border-color 0.2s, box-shadow 0.2s;
font-family: inherit;
line-height: 1.6;
box-sizing: border-box;
}
.home-abstract-step__textarea:focus {
outline: none;
border-color: var(--focus-color);
box-shadow: 0 0 0 3px var(--focus-ring);
}
.home-abstract-step__textarea--invalid {
border-color: var(--danger-color);
}
/* contador de palabras */
.home-abstract-step__word-count {
align-self: flex-end;
font-size: 0.78rem;
color: var(--text-muted);
user-select: none;
}
.home-abstract-step__word-count--limit {
color: var(--danger-color);
font-weight: 600;
}
.home-abstract-step__char-count {
align-self: flex-end;
font-size: 0.78rem;
color: var(--text-muted);
}
.home-abstract-step__error {
font-size: 0.8rem;
color: var(--error-text);
}
.home-abstract-step__actions {
display: flex;
justify-content: flex-end;
gap: 0.75rem;
border-top: 1px solid var(--border-light);
padding-top: 1.25rem;
}
/* ============================================================
home-summary-step (BEM)
============================================================ */
.home-summary-step__header {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.5rem;
text-align: center;
border-bottom: 1px solid var(--border-light);
padding-bottom: 1.5rem;
margin-bottom: 1.75rem;
}
.home-summary-step__icon {
width: 56px;
height: 56px;
border-radius: 50%;
background: var(--info-background);
display: flex;
align-items: center;
justify-content: center;
color: var(--primary-color);
}
.home-summary-step__icon svg {
width: 30px;
height: 30px;
}
.home-summary-step__title {
font-size: 1.35rem;
font-weight: 700;
color: var(--text-color);
margin: 0;
}
.home-summary-step__description {
font-size: 0.9rem;
color: var(--text-muted);
margin: 0;
}
.home-summary-step__cards {
display: flex;
flex-direction: column;
gap: 1.25rem;
margin-bottom: 2rem;
}
.home-summary-step__card {
background: var(--surface-alt-color);
border: 1px solid var(--border-color);
border-radius: 0.875rem;
overflow: hidden;
}
.home-summary-step__card-header {
display: flex;
align-items: center;
gap: 0.6rem;
padding: 0.9rem 1.25rem;
background: var(--secondary-background);
border-bottom: 1px solid var(--border-color);
}
.home-summary-step__card-icon {
width: 20px;
height: 20px;
color: var(--primary-color);
flex-shrink: 0;
}
.home-summary-step__card-title {
font-size: 1rem;
font-weight: 700;
color: var(--text-color);
margin: 0;
}
.home-summary-step__card-body {
padding: 1.1rem 1.25rem;
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.home-summary-step__field {
display: flex;
align-items: flex-start;
gap: 0.5rem;
font-size: 0.9rem;
}
.home-summary-step__field--block {
flex-direction: column;
gap: 0.35rem;
}
.home-summary-step__field-label {
font-weight: 600;
color: var(--text-secondary);
min-width: 130px;
flex-shrink: 0;
}
.home-summary-step__field-value {
color: var(--text-color);
word-break: break-word;
}
.home-summary-step__abstract-text {
color: var(--text-color);
font-size: 0.88rem;
line-height: 1.65;
margin: 0;
white-space: pre-wrap;
word-break: break-word;
}
.home-summary-step__actions {
display: flex;
justify-content: flex-end;
gap: 0.75rem;
border-top: 1px solid var(--border-light);
padding-top: 1.25rem;
}
/* ============================================================
Responsive
============================================================ */
@media (max-width: 640px) {
.home-order__card {
padding: 1.25rem 1rem;
}
.home-authores-step__row,
.home-abstract-step__row {
grid-template-columns: 1fr;
}
.home-summary-step__field {
flex-direction: column;
gap: 0.2rem;
}
.home-summary-step__field-label {
min-width: unset;
}
}
/* ============================================================
home-coauthors (BEM)
============================================================ */
.home-coauthors {
margin-top: 1.5rem;
}
.home-coauthors__header {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 1.25rem;
gap: 1rem;
flex-wrap: wrap;
}
.home-coauthors__title-group {
display: flex;
align-items: center;
gap: 0.6rem;
}
.home-coauthors__title {
font-size: 1.1rem;
font-weight: 700;
color: var(--text-color);
margin: 0;
}
.home-coauthors__counter {
font-size: 0.8rem;
font-weight: 600;
color: var(--text-muted);
background: var(--secondary-background);
border: 1px solid var(--border-color);
border-radius: 999px;
padding: 0.15rem 0.6rem;
}
.home-coauthors__empty {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.6rem;
padding: 2rem 1rem;
background: var(--surface-alt-color);
border: 1.5px dashed var(--border-color);
border-radius: 0.75rem;
text-align: center;
}
.home-coauthors__empty-icon {
width: 40px;
height: 40px;
color: var(--disabled-color);
}
.home-coauthors__empty-text {
font-size: 0.88rem;
color: var(--text-muted);
margin: 0;
}
.home-coauthors__list {
display: flex;
flex-direction: column;
gap: 1rem;
}
.home-coauthors__item {
background: var(--surface-alt-color);
border: 1px solid var(--border-color);
border-radius: 0.875rem;
overflow: hidden;
}
.home-coauthors__item-header {
display: flex;
align-items: center;
justify-content: space-between;
padding: 0.7rem 1.1rem;
background: var(--secondary-background);
border-bottom: 1px solid var(--border-color);
}
.home-coauthors__item-label {
font-size: 0.875rem;
font-weight: 600;
color: var(--primary-color);
}
.home-coauthors__remove-btn {
display: flex;
align-items: center;
justify-content: center;
background: none;
border: none;
cursor: pointer;
color: var(--danger-color);
padding: 0.25rem;
border-radius: 0.375rem;
transition: background 0.15s, color 0.15s;
line-height: 0;
}
.home-coauthors__remove-btn:hover {
background: var(--danger-background);
color: var(--danger-dark);
}
.home-coauthors__item-form {
padding: 1rem 1.1rem;
display: flex;
flex-direction: column;
gap: 1rem;
}
.home-coauthors__item-row {
display: flex;
/*grid-template-columns: 1fr 1fr;*/
gap: 1rem;
}
/* Summary coauthors */
.home-summary-step__coauthors {
display: flex;
flex-direction: column;
gap: 0.5rem;
margin-top: 0.25rem;
}
.home-summary-step__coauthors-list {
list-style: none;
padding: 0;
margin: 0;
display: flex;
flex-direction: column;
gap: 0.4rem;
}
.home-summary-step__coauthor-item {
display: flex;
flex-direction: column;
padding: 0.5rem 0.75rem;
background: var(--secondary-background);
border-radius: 0.5rem;
border: 1px solid var(--border-light);
}
.home-summary-step__coauthor-name {
font-size: 0.9rem;
font-weight: 600;
color: var(--text-color);
}
.home-summary-step__coauthor-email {
font-size: 0.8rem;
color: var(--text-muted);
}
@media (max-width: 640px) {
.home-coauthors__item-row {
grid-template-columns: 1fr;
}
}
/* ============================================================
home-coauthors — Roles (Presenter / Ponent)
============================================================ */
/* Name row: prefix narrow + first + last equal */
.home-coauthors__item-row--name {
display: grid;
grid-template-columns: 120px 1fr 1fr;
gap: 1rem;
}
/* ── Roles section wrapper ─────────────────────────────── */
.home-coauthors__roles-section {
display: flex;
flex-direction: column;
gap: 0.65rem;
padding: 0.9rem 1rem;
background: var(--secondary-background);
border: 1px solid var(--border-color);
border-radius: 0.75rem;
}
.home-coauthors__roles-header {
display: flex;
align-items: flex-start;
gap: 0.4rem;
font-size: 0.8rem;
color: var(--text-muted);
line-height: 1.45;
}
.home-coauthors__roles-header svg {
flex-shrink: 0;
margin-top: 0.05rem;
color: var(--primary-light);
}
/* ── Role cards row ────────────────────────────────────── */
.home-coauthors__roles {
display: flex;
flex-direction: row;
gap: 0.75rem;
flex-wrap: wrap;
}
/* ── Single role card ──────────────────────────────────── */
.home-coauthors__role-card {
display: flex;
flex-direction: row;
align-items: center;
gap: 0.6rem;
flex: 1 1 180px;
padding: 0.7rem 0.9rem;
border: 1.5px solid var(--border-color);
border-radius: 0.6rem;
cursor: pointer;
user-select: none;
background: var(--surface-color);
transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;
position: relative;
}
.home-coauthors__role-card:hover {
border-color: var(--primary-light);
background: var(--surface-alt-color);
}
.home-coauthors__role-card--active {
border-color: var(--primary-color);
background: var(--info-background, #eff6ff);
box-shadow: 0 0 0 3px rgba(1, 29, 125, 0.09);
}
/* hide native checkbox */
.home-coauthors__role-checkbox {
position: absolute;
opacity: 0;
width: 0;
height: 0;
pointer-events: none;
}
/* custom checkbox indicator box */
.home-coauthors__role-indicator {
flex-shrink: 0;
width: 1.1rem;
height: 1.1rem;
border: 1.5px solid var(--border-color);
border-radius: 0.25rem;
background: var(--surface-color);
display: flex;
align-items: center;
justify-content: center;
transition: border-color 0.15s, background 0.15s;
}
.home-coauthors__role-card--active .home-coauthors__role-indicator {
border-color: var(--success-color);
background: var(--success-color);
color: #fff;
font-weight: 500;
}
/* icon + text side by side */
.home-coauthors__role-body {
display: flex;
align-items: center;
gap: 0.5rem;
min-width: 0;
}
.home-coauthors__role-icon {
flex-shrink: 0;
color: var(--text-muted);
display: flex;
align-items: center;
}
.home-coauthors__role-card--active .home-coauthors__role-icon {
color: var(--primary-color);
}
/* text stack */
.home-coauthors__role-text {
display: flex;
flex-direction: column;
gap: 0.05rem;
min-width: 0;
}
.home-coauthors__role-name {
font-size: 0.85rem;
font-weight: 600;
color: var(--text-color);
line-height: 1.2;
}
.home-coauthors__role-card--active .home-coauthors__role-name {
color: var(--primary-color);
}
.home-coauthors__role-desc {
font-size: 0.7rem !important;
color: var(--text-muted);
line-height: 1.3;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
@media (max-width: 640px) {
.home-coauthors__item-row--name {
grid-template-columns: 1fr;
}
.home-coauthors__roles {
flex-direction: column;
}
.home-coauthors__role-card {
flex: 1 1 auto;
}
}
/* ============================================================
home-format-picker (BEM)
============================================================ */
.home-format-picker {
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.home-format-picker__header {
display: flex;
align-items: baseline;
gap: 0.6rem;
flex-wrap: wrap;
}
.home-format-picker__title {
font-size: 0.9rem;
font-weight: 700;
color: var(--text-color);
}
.home-format-picker__hint {
font-size: 0.78rem;
color: var(--text-muted);
}
.home-format-picker__options {
display: flex;
flex-direction: row;
gap: 0.85rem;
flex-wrap: wrap;
}
.home-format-picker__icons {
display: flex;
gap: 1rem;
margin-top: 0.5rem;
}
/* Card */
.home-format-picker__card {
display: flex;
align-items: center;
gap: 0.65rem;
flex: 1 1 150px;
padding: 0.75rem 1rem;
border: 1.5px solid var(--border-color);
border-radius: 0.7rem;
cursor: pointer;
user-select: none;
background: var(--surface-color);
transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;
position: relative;
}
.home-format-picker__card:hover {
border-color: var(--primary-light);
background: var(--surface-alt-color);
}
.home-format-picker__card--active {
border-color: var(--success-color);
background: var(--info-background, #eff6ff);
box-shadow: 0 0 0 5px rgba(1, 29, 125, 0.08);
}
/* Hide native checkbox */
.home-format-picker__checkbox {
position: absolute;
opacity: 0;
width: 0;
height: 0;
pointer-events: none;
}
/* Custom indicator */
.home-format-picker__indicator {
flex-shrink: 0;
width: 1.1rem;
height: 1.1rem;
border: 1.5px solid var(--border-color);
border-radius: 0.25rem;
background: var(--surface-color);
display: flex;
align-items: center;
justify-content: center;
transition: border-color 0.15s, background 0.15s;
}
.home-format-picker__card--active .home-format-picker__indicator {
border-color: var(--success-color);
background: var(--success-color);
color: #fff;
}
/* Icon */
.home-format-picker__icon {
flex-shrink: 0;
display: flex;
align-items: center;
color: var(--text-muted);
transition: color 0.15s;
}
.home-format-picker__card--active .home-format-picker__icon {
color: var(--primary-color);
}
/* Label */
.home-format-picker__label {
font-size: 0.875rem;
font-weight: 600;
color: var(--text-color);
transition: color 0.15s;
}
.home-format-picker__card--active .home-format-picker__label {
color: var(--primary-color);
}
@media (max-width: 640px) {
.home-format-picker__options {
flex-direction: column;
}
.home-format-picker__card {
flex: 1 1 auto;
}
}
:host, .login-page, .auth-container {
height: 75dvh;
box-sizing: border-box;
overflow-y: auto;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
}
.login-page__card {
background: var(--surface-color);
border-radius: 1.2rem;
box-shadow: var(--shadow-xl);
padding: 2.5rem 2rem 2rem 2rem;
max-width: 600px;
width: 95vw;
min-width: 320px;
margin: 0 auto;
display: flex;
flex-direction: column;
align-items: stretch;
border: 1px solid var(--border-color);
margin-bottom: 2rem;
}
.login-page__header {
text-align: center;
margin-bottom: 2rem;
}
.login-page__logo {
width: 64px;
height: 64px;
margin-bottom: 1rem;
filter: drop-shadow(0 2px 8px var(--shadow-color));
}
.login-page__title {
margin: 0 0 0.5rem 0;
font-weight: 700;
color: var(--primary-color);
letter-spacing: 0.01em;
}
.login-page__subtitle {
color: var(--text-muted);
font-size: 1rem;
margin-bottom: 0;
}
.login-page__form {
width: 100%;
}
@media (max-width: 600px) {
:host, .login-page, .auth-container {
padding-bottom: 55vh;
padding-top: 2vh;
}
.login-page__card {
padding: 1.2rem 0.5rem;
max-width: 98vw;
margin-bottom: 1.5rem;
}
.login-page__logo {
width: 48px;
height: 48px;
}
}
/* Privacy Page - Hero Minimalista Moderno */
.privacy-page {
width: 100%;
min-height: 100vh;
display: flex;
flex-direction: column;
background: var(--background-color);
}
/* Hero - Diseño Minimalista y Profesional */
.privacy-page__hero {
position: relative;
width: 100%;
background: var(--surface-color);
border-bottom: 1px solid var(--border-color);
padding: 1.5rem 1.5rem 1rem;
}
.privacy-page__hero::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
height: 4px;
background: linear-gradient(90deg, var(--primary-color) 0%, var(--accent-color) 100%);
}
.privacy-page__hero-content {
max-width: 1200px;
margin: 0 auto;
text-align: center;
}
.privacy-page__hero-title {
font-size: 1.75rem;
font-weight: 700;
color: var(--text-color) !important;
margin: 0 0 0.375rem 0;
letter-spacing: -0.02em;
display: inline-flex;
align-items: center;
gap: 0.75rem;
}
.privacy-page__hero-title::before {
content: '🔒';
font-size: 1.5rem;
opacity: 0.8;
}
.privacy-page__hero-subtitle {
font-size: 0.938rem !important;
color: var(--text-muted) !important;
margin: 0 auto !important;
max-width: 720px;
font-weight: 400;
line-height: 1.5;
}
/* Container */
.privacy-page__container {
flex: 1;
width: 100%;
max-width: 1200px;
margin: 0 auto;
padding: 2rem 1.5rem 3rem;
}
/* Card */
.privacy-page__card {
background: var(--surface-color);
border-radius: 0.75rem;
box-shadow: var(--shadow-md);
overflow: hidden;
border: 1px solid var(--border-color);
min-height: 500px;
}
/* Responsive - Tablets */
@media (max-width: 768px) {
.privacy-page__hero {
padding: 1.25rem 1rem 0.875rem;
}
.privacy-page__hero-title {
font-size: 1.5rem;
}
.privacy-page__hero-title::before {
font-size: 1.25rem;
}
.privacy-page__hero-subtitle {
font-size: 0.875rem !important;
}
.privacy-page__container {
padding: 1.75rem 1rem 2.5rem;
}
.privacy-page__card {
border-radius: 0.625rem;
}
}
/* Responsive - Móviles */
@media (max-width: 480px) {
.privacy-page__hero {
padding: 1.125rem 1rem 0.75rem;
}
.privacy-page__hero-title {
font-size: 1.375rem;
}
.privacy-page__hero-subtitle {
font-size: 0.813rem !important;
}
.privacy-page__container {
padding: 1.5rem 0.75rem 2rem;
}
.privacy-page__card {
border-radius: 0.5rem;
box-shadow: var(--shadow-sm);
}
}
/* Servicios (BEM) - Hero Minimalista Moderno */
.services {
display: flex;
flex-direction: column;
min-height: 100vh;
}
/* Hero - Diseño Minimalista y Profesional */
.services__hero {
position: relative;
background: var(--surface-color);
border-bottom: 1px solid var(--border-color);
padding: 1.5rem 1.5rem 1rem;
}
.services__hero::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
height: 4px;
background: linear-gradient(90deg, var(--primary-color) 0%, var(--accent-color) 100%);
}
.services__hero-inner {
max-width: 1100px;
margin: 0 auto;
text-align: center;
}
.services__title {
font-size: 1.75rem;
line-height: 1.2;
margin: 0 0 0.375rem;
font-weight: 700;
color: var(--text-color) !important;
letter-spacing: -0.02em;
display: inline-flex;
align-items: center;
gap: 0.75rem;
}
.services__title::before {
content: '⚡';
font-size: 1.5rem;
opacity: 0.8;
}
.services__subtitle {
font-size: 0.938rem !important;
margin: 0 auto !important;
max-width: 680px;
color: var(--text-muted) !important;
line-height: 1.5;
font-weight: 400;
}
/* Grid */
.services__grid {
max-width: 1100px;
margin: 0 auto;
padding: 2rem 1.5rem 1rem;
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 1.25rem;
}
.services__grid-item {}
/* Card content inside AppCard */
.services__card {
display: grid;
grid-template-columns: 48px 1fr;
gap: 0.75rem;
align-items: start;
}
.services__card-icon {
width: 48px;
height: 48px;
border-radius: 0.625rem;
display: grid;
place-items: center;
background: linear-gradient(135deg, var(--primary-color) 0%, var(--accent-color) 100%);
color: var(--primary-foreground);
font-size: 1.5rem;
box-shadow: var(--shadow-sm);
}
.services__card-desc {
margin: 0.25rem 0 0;
color: var(--text-color);
line-height: 1.55;
font-size: 0.938rem;
}
/* Empty state */
.services__empty {
grid-column: 1 / -1;
text-align: center;
color: var(--text-muted);
padding: 2rem;
}
/* CTA */
.services__cta {
padding: 1rem 1.5rem 3rem;
}
.services__cta-inner {
max-width: 980px;
margin: 0 auto;
background: linear-gradient(135deg, var(--primary-color) 0%, var(--accent-color) 100%);
color: var(--primary-foreground);
border-radius: 1rem;
padding: 2.5rem 2rem;
text-align: center;
box-shadow: var(--shadow-lg);
position: relative;
overflow: hidden;
}
.services__cta-inner::before {
content: '';
position: absolute;
top: -50%;
right: -10%;
width: 300px;
height: 300px;
background: var(--surface-color);
opacity: 0.1;
border-radius: 50%;
pointer-events: none;
}
.services__cta-title {
margin: 0 0 0.75rem;
font-size: 1.5rem;
font-weight: 600;
color: var(--primary-foreground) !important;
}
.services__cta-text {
margin: 0 0 1.5rem;
color: var(--primary-foreground) !important;
opacity: 0.95;
max-width: 600px;
margin-left: auto;
margin-right: auto;
}
/* Responsive */
@media (max-width: 1024px) {
.services__grid {
grid-template-columns: repeat(2, 1fr);
}
}
@media (max-width: 768px) {
.services__hero {
padding: 1.25rem 1rem 0.875rem;
}
.services__title {
font-size: 1.5rem;
}
.services__title::before {
font-size: 1.25rem;
}
.services__subtitle {
font-size: 0.875rem !important;
}
.services__cta-inner {
padding: 2rem 1.5rem;
}
}
@media (max-width: 640px) {
.services__title {
font-size: 1.375rem;
}
.services__grid {
grid-template-columns: 1fr;
padding: 1.5rem 1rem 1rem;
}
.services__card {
grid-template-columns: 40px 1fr;
}
.services__card-icon {
width: 40px;
height: 40px;
font-size: 1.25rem;
}
.services__cta-inner {
border-radius: 0.75rem;
padding: 1.75rem 1rem;
}
.services__cta-title {
font-size: 1.25rem;
}
}
/* ================================================
SUPPORT PAGE — Ticket detail & chat
All colors use variables from colors.css
================================================ */
/* Layout base */
.support {
max-width: 1200px;
margin: 0 auto;
padding: 1rem;
color: var(--text-color);
background: var(--background-color);
}
/* Loading */
.support__loading {
display: flex;
gap: 0.5rem;
align-items: center;
justify-content: center;
padding: 3rem 1rem;
}
.support__loading-text {
color: var(--text-muted);
font-size: 0.9375rem;
}
/* Error */
.support__error {
background: var(--danger-background);
color: var(--danger-color);
padding: 0.875rem 1rem;
border-radius: 0.5rem;
margin: 0.5rem 0;
border-left: 4px solid var(--danger-color);
}
/* ========================
Grid principal
======================== */
.support__grid {
display: grid;
grid-template-columns: 340px 1fr;
gap: 1rem;
align-items: start;
}
.support__col {
background: var(--surface-color);
color: var(--text-color);
border: 1px solid var(--border-color);
border-radius: 0.75rem;
padding: 1rem;
box-shadow: var(--shadow-sm);
}
.support__col--info {
position: sticky;
top: 0.75rem;
align-self: start;
display: flex;
flex-direction: column;
gap: 0.75rem;
}
/* ========================
Title
======================== */
.support__title {
margin: 0;
font-size: 1.25rem;
font-weight: 700;
color: var(--text-color);
letter-spacing: -0.01em;
}
/* ========================
Badges (staff / user / closed)
======================== */
.support__badge {
display: flex;
align-items: center;
gap: 0.5rem;
padding: 0.5rem 0.75rem;
border-radius: 0.5rem;
font-size: 0.8125rem;
font-weight: 600;
box-shadow: var(--shadow-xs);
}
.support__badge-icon {
font-size: 1rem;
line-height: 1;
flex-shrink: 0;
}
.support__badge--staff {
background: var(--info-background);
color: var(--info-foreground);
border: 1px solid var(--info-color);
}
.support__badge--user {
background: var(--success-background);
color: var(--success-foreground);
border: 1px solid var(--success-color);
}
.support__badge--closed {
background: var(--secondary-background);
color: var(--text-muted);
border: 1px solid var(--border-color);
}
/* ========================
Meta — ticket info
======================== */
.support__meta {
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.support__meta-item {
display: flex;
flex-direction: column;
gap: 0.125rem;
padding: 0.375rem 0;
border-bottom: 1px solid var(--border-light);
}
.support__meta-item:last-child {
border-bottom: none;
}
.support__meta-label {
font-size: 0.6875rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.04em;
color: var(--text-muted);
}
.support__meta-value {
font-size: 0.9375rem;
color: var(--text-color);
word-break: break-word;
}
.support__meta-value--muted {
color: var(--text-muted);
font-style: italic;
}
.support__meta-value--status {
font-weight: 600;
font-size: 0.8125rem;
display: inline-flex;
align-items: center;
gap: 0.375rem;
padding: 0.125rem 0.5rem;
border-radius: 1rem;
width: fit-content;
}
.support__meta-value--open {
background: var(--success-background);
color: var(--success-foreground);
}
.support__meta-value--closed {
background: var(--secondary-background);
color: var(--text-muted);
}
/* ========================
Rating — readonly display
======================== */
.support__rate-display {
display: flex;
align-items: center;
gap: 0.5rem;
}
.support__rate-stars {
color: var(--warning-color);
font-size: 1.125rem;
letter-spacing: 0.05em;
line-height: 1;
}
.support__rate-score {
font-size: 0.8125rem;
color: var(--text-muted);
font-weight: 500;
}
/* ========================
Rating — interactive section
======================== */
.support__rate-section {
display: flex;
flex-direction: column;
gap: 0.375rem;
padding: 0.75rem;
background: var(--surface-alt-color);
border: 1px solid var(--border-color);
border-radius: 0.5rem;
width: 100%;
}
.support__rate-title {
font-size: 0.8125rem;
font-weight: 600;
color: var(--text-color);
}
.support__rate-interactive {
display: flex;
gap: 0.25rem;
}
.support__rate-btn {
background: transparent;
border: none;
font-size: 1.5rem;
line-height: 1;
cursor: pointer;
color: var(--border-color);
padding: 0.25rem;
border-radius: 0.25rem;
transition: color 0.15s ease, transform 0.15s ease;
}
.support__rate-btn:hover {
transform: scale(1.2);
}
.support__rate-btn--filled {
color: var(--warning-color);
}
.support__rate-btn:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
.support__rate-label {
font-size: 0.8125rem;
font-weight: 600;
color: var(--warning-dark);
min-height: 1.25rem;
}
.support__rate-label--hint {
font-weight: 400;
color: var(--text-muted);
}
/* ========================
Actions
======================== */
.support__actions {
display: flex;
flex-direction: column;
gap: 0.75rem;
margin-top: 0.25rem;
}
.support__close-section {
display: flex;
flex-direction: column;
gap: 0.375rem;
}
.support__close-hint {
font-size: 0.75rem;
color: var(--warning-color);
background: var(--warning-background);
padding: 0.375rem 0.625rem;
border-radius: 0.375rem;
border-left: 3px solid var(--warning-color);
}
/* ========================
Messages column
======================== */
.support__col--messages {
display: grid;
grid-template-rows: auto 1fr auto;
min-height: 70vh;
}
.support__messages-header {
padding-bottom: 0.5rem;
border-bottom: 1px solid var(--border-color);
}
.support__messages-wrapper {
height: 420px;
overflow-y: auto;
overflow-x: hidden;
-webkit-overflow-scrolling: touch;
scroll-behavior: smooth;
}
.support__messages {
display: flex;
flex-direction: column;
gap: 0.375rem;
padding: 0.5rem 0.25rem;
min-height: 100%;
}
.support__messages-empty {
color: var(--text-muted);
font-style: italic;
text-align: center;
padding: 2rem 1rem;
}
/* ========================
Composer
======================== */
.support__composer {
position: sticky;
bottom: 0;
background: var(--surface-color);
padding-top: 0.5rem;
border-top: 1px solid var(--border-color);
display: grid;
gap: 0.5rem;
}
.support__composer-label {
font-size: 0.875rem;
font-weight: 600;
color: var(--text-color);
}
.support__composer-input {
min-height: 100px;
max-height: 30vh;
resize: vertical;
padding: 0.625rem;
border: 1px solid var(--border-color);
border-radius: 0.5rem;
font: inherit;
font-size: 0.9375rem;
color: var(--text-color);
background: var(--surface-color);
transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.support__composer-input:focus {
border-color: var(--focus-color);
outline: none;
box-shadow: 0 0 0 3px var(--focus-ring);
}
.support__composer-input:disabled {
background: var(--disabled-background);
color: var(--disabled-color);
cursor: not-allowed;
}
.support__composer-hint {
background: var(--warning-background);
color: var(--warning-color);
padding: 0.5rem 0.75rem;
border-radius: 0.375rem;
font-size: 0.8125rem;
border-left: 4px solid var(--warning-color);
}
.support__composer-hint--closed {
background: var(--danger-background);
color: var(--danger-color);
border-left-color: var(--danger-color);
}
.support__composer-actions {
display: flex;
justify-content: flex-end;
}
/* ========================
Responsive
======================== */
@media (max-width: 768px) {
.support__grid {
grid-template-columns: 1fr;
}
.support__col--info {
position: static;
order: 1;
}
.support__col--messages {
order: 2;
min-height: 50vh;
}
.support__messages-wrapper {
height: 300px;
}
.support__title {
font-size: 1.125rem;
}
}
@media (max-width: 480px) {
.support {
padding: 0.5rem;
}
.support__col {
padding: 0.75rem;
}
.support__rate-btn {
font-size: 1.75rem;
padding: 0.375rem;
}
.support__composer-input {
min-height: 80px;
}
}
.terms {
width: 100%;
min-height: 60vh;
display: flex;
align-items: center;
justify-content: center;
background: var(--surface-alt-color);
padding: 3rem 0;
}
.terms__container {
width: 100%;
max-width: 600px;
margin: 0 1rem;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
background: transparent;
box-shadow: none;
border-radius: 0;
padding: 0;
}
@media (max-width: 700px) {
.terms {
padding: 1.2rem 0;
}
.terms__container {
max-width: 100%;
margin: 0;
}
}
/*:root {
--loader-dot-color: #011d7d;
--loader-bg:        #f8fafc;
}
@media (prefers-color-scheme: dark) {
:root:not([data-theme='light']) {
--loader-dot-color: #22d3ee;
--loader-bg:        #0f172a;
}
}
:root[data-theme='dark'] {
--loader-dot-color: #22d3ee;
--loader-bg:        #0f172a;
}
:root[data-theme='light'] {
--loader-dot-color: #011d7d;
--loader-bg:        #f8fafc;
}
*/
.loader-splash {
display: flex;
align-items: center;
justify-content: center;
height: 100vh;
background-color: var(--loader-bg);
transition: background-color 0.2s ease;
}
.loader {
display: inline-flex;
align-items: center;
justify-content: center;
}
.loader--lg { gap: 14px; }
.loader--md { gap: 10px; }
.loader__dot {
border-radius: 50%;
background: var(--loader-dot-color);
animation: loader-pulse 1.2s ease-in-out infinite;
}
.loader--lg .loader__dot { width: 16px; height: 16px; }
.loader--md .loader__dot { width: 10px; height: 10px; }
.loader__dot--1 { animation-delay: 0s;   }
.loader__dot--2 { animation-delay: 0.2s; }
.loader__dot--3 { animation-delay: 0.4s; }
@media (prefers-reduced-motion: reduce) {
.loader__dot { animation-duration: 3s; }
}
@keyframes loader-pulse {
0%, 80%, 100% {
transform: scale(0.55);
opacity: 0.35;
}
40% {
transform: scale(1);
opacity: 1;
}
}
/* MainLayout adjustments for AppSideBar */
:root {
--layout-content-padding: clamp(12px, 2vw, 20px);
--layout-topbar-height: var(--topbar-height, 56px);
--layout-sidebar-width: min(320px, 90vw);
/* Altura global del TopBar para coordinar layout */
--layout-topbar-height: 64px; /* ajustable desde el componente si fuera necesario */
}
/* El TopBar es sticky: no necesitamos reservar espacio extra en el contenido */
.main-layout > main.content-area {
padding-top: 0 !important;
margin-top: 0 !important;
}
.main-layout {
position: relative;
min-height: 100dvh;
display: flex;
flex-direction: column;
background: var(--gradient-surface);
}
/* content area spacing below topbar */
.content-area {
padding: var(--layout-content-padding);
padding-top: calc(var(--layout-content-padding) + var(--layout-topbar-height));
transition: margin-left .28s cubic-bezier(0.4, 0, 0.2, 1);
display: block;
}
/* Asegura espacio bajo el TopBar para el contenido principal */
main.content-area {
padding-top: var(--layout-topbar-height);
min-height: calc(100dvh - var(--layout-topbar-height));
}
/* Shift when sidebar open on large screens */
@media (min-width: 1024px) {
.content-area--shifted {
margin-left: var(--layout-sidebar-width);
}
}
