﻿/* =================================================================
boot-loader.css — Pantalla de inicio "Armando el evento"
Gafete siendo construido pieza a pieza.
CSS variables from colors.css — compatible WASM/MAUI.
================================================================= */
/* ── Contenedor ── */
#boot-loader {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
height: 100vh;
gap: 1.25rem;
background-color: var(--background-color);
font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}
/* ── SVG del gafete ── */
.bl-svg {
width: 100px;
height: 140px;
overflow: visible;
/* rebote de "gafete listo" → luego flota suavemente */
animation:
bl-badge-snap 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) 2.35s both,
bl-float      3.8s ease-in-out 3.1s infinite;
}
@keyframes bl-badge-snap {
0%   { transform: scale(1);    }
45%  { transform: scale(1.06); }
100% { transform: scale(1);    }
}
@keyframes bl-float {
0%, 100% { transform: translateY(0);    }
50%      { transform: translateY(-9px); }
}
/* ── Cuerda / lanyard ── */
.bl-cord {
stroke: var(--border-color);
stroke-width: 2;
stroke-linecap: round;
stroke-dasharray: 10;
stroke-dashoffset: 10;
animation: bl-draw-line 0.25s ease-out 0.05s forwards;
}
/* ── Perforación ── */
.bl-hole {
fill: var(--background-color);
stroke: var(--border-color);
stroke-width: 1.5;
opacity: 0;
animation: bl-fade 0.2s ease-out 0.25s forwards;
}
/* ── Borde del gafete (se traza solo, como pluma recorriendo el contorno) ── */
.bl-outline {
fill: none;
stroke: var(--primary-color);
stroke-width: 2;
stroke-linecap: round;
stroke-linejoin: round;
stroke-dasharray: 355;
stroke-dashoffset: 355;
animation: bl-draw-outline 0.82s cubic-bezier(0.4, 0, 0.2, 1) 0.3s forwards;
}
@keyframes bl-draw-outline {
to { stroke-dashoffset: 0; }
}
/* ── Fondo del gafete ── */
.bl-bg {
fill: var(--surface-color);
opacity: 0;
animation: bl-fade 0.22s ease 1.0s forwards;
}
/* ── Header band ── */
.bl-head {
fill: var(--primary-color);
transform-box: fill-box;
transform-origin: 50% 0%;
transform: scaleY(0);
animation: bl-scale-y 0.35s ease-out 1.05s forwards;
}
/* ── Avatar (círculo + iniciales como grupo) ── */
.bl-avatar-grp {
transform-box: fill-box;
transform-origin: center;
opacity: 0;
transform: scale(0);
animation: bl-pop 0.38s cubic-bezier(0.34, 1.56, 0.64, 1) 1.25s forwards;
}
.bl-avatar-grp circle {
fill: var(--surface-color);
}
.bl-avatar-grp text {
fill: var(--primary-color);
}
/* ── Líneas de nombre ── */
.bl-line {
fill: var(--border-color);
transform-box: fill-box;
transform-origin: 0% 50%;
transform: scaleX(0);
opacity: 0;
}
.bl-line-1 { animation: bl-sweep-x 0.38s ease-out 1.45s forwards; }
.bl-line-2 { animation: bl-sweep-x 0.32s ease-out 1.60s forwards; }
/* ── Categoría (píldora de color, barre desde la izquierda) ── */
.bl-cat {
fill: var(--accent-color);
transform-box: fill-box;
transform-origin: 0% 50%;
opacity: 0;
transform: scaleX(0);
animation: bl-sweep-x 0.38s ease-out 1.75s forwards;
}
/* ── Divisor ── */
.bl-divider {
stroke: var(--divider-color);
stroke-width: 1;
stroke-dasharray: 64;
stroke-dashoffset: 64;
animation: bl-draw-line 0.3s ease-out 1.90s forwards;
}
/* ── Barras de código de barras (suben desde abajo, desfasadas) ── */
.bl-bc {
fill: var(--text-color);
transform-box: fill-box;
transform-origin: 50% 100%;
transform: scaleY(0);
}
.bl-bc-1 { animation: bl-bc-up 0.18s ease-out 2.00s forwards; }
.bl-bc-2 { animation: bl-bc-up 0.18s ease-out 2.04s forwards; }
.bl-bc-3 { animation: bl-bc-up 0.18s ease-out 2.07s forwards; }
.bl-bc-4 { animation: bl-bc-up 0.18s ease-out 2.11s forwards; }
.bl-bc-5 { animation: bl-bc-up 0.18s ease-out 2.03s forwards; }
.bl-bc-6 { animation: bl-bc-up 0.18s ease-out 2.08s forwards; }
.bl-bc-7 { animation: bl-bc-up 0.18s ease-out 2.13s forwards; }
.bl-bc-8 { animation: bl-bc-up 0.18s ease-out 2.06s forwards; }
.bl-bc-9 { animation: bl-bc-up 0.18s ease-out 2.10s forwards; }
/* ── Estrella de completado ── */
.bl-star {
fill: var(--warning-color);
opacity: 0;
transform-box: fill-box;
transform-origin: center;
transform: scale(0) rotate(-30deg);
animation: bl-star-pop 0.42s cubic-bezier(0.34, 1.56, 0.64, 1) 2.28s forwards;
}
/* ── Brillo holográfico ── */
/* Primera vez: al completarse el gafete. Luego cada ~5 s indefinidamente. */
.bl-shine {
fill: var(--primary-foreground);
opacity: 0;
animation: bl-shine-cycle 5s ease-in-out 2.5s infinite;
}
@keyframes bl-shine-cycle {
/* barre en el primer 12% del ciclo (~0.6s), luego invisible el resto */
0%    { opacity: 0;    transform: skewX(-20deg) translateX(-30px); }
4%    { opacity: 0.38; }
12%   { opacity: 0;    transform: skewX(-20deg) translateX(130px); }
12.1% { opacity: 0;    transform: skewX(-20deg) translateX(-30px); } /* salto instantáneo */
100%  { opacity: 0;    transform: skewX(-20deg) translateX(-30px); }
}
/* ── Nombre de marca ── */
/* Las letras "se abren" desde comprimidas — sensación de revelado */
.boot-loader__brand {
font-size: 1.3rem;
font-weight: 300;
color: var(--text-color);
letter-spacing: 0.17em;
text-transform: uppercase;
margin: 0;
opacity: 0;
animation:
bl-brand-expand 0.65s cubic-bezier(0.34, 1.1, 0.64, 1) 2.48s forwards,
bl-brand-glow   3.5s ease-in-out 3.3s infinite;
}
.boot-loader__brand strong {
font-weight: 800;
color: var(--primary-color);
}
@keyframes bl-brand-expand {
from { opacity: 0; letter-spacing: 0.02em; transform: translateY(4px); }
to   { opacity: 1; letter-spacing: 0.17em; transform: translateY(0);   }
}
@keyframes bl-brand-glow {
0%, 100% { text-shadow: none; }
50%      { text-shadow: 0 0 18px var(--focus-ring), 0 0 32px rgba(124, 58, 237, 0.2); }
}
/* ── Keyframes compartidos ── */
@keyframes bl-draw-line  { to { stroke-dashoffset: 0; }                              }
@keyframes bl-fade       { to { opacity: 1; }                                        }
@keyframes bl-scale-y    { to { transform: scaleY(1); }                              }
@keyframes bl-pop        { to { opacity: 1; transform: scale(1); }                   }
@keyframes bl-sweep-x    { to { transform: scaleX(1); opacity: 1; }                  }
@keyframes bl-bc-up      { to { transform: scaleY(1); }                              }
@keyframes bl-star-pop   { to { opacity: 1; transform: scale(1) rotate(0deg); }      }
/* ── Accesibilidad: sin movimiento ── */
@media (prefers-reduced-motion: reduce) {
#boot-loader *,
.bl-svg {
animation: none !important;
opacity: 1 !important;
transform: none !important;
}
.bl-outline { stroke-dashoffset: 0; }
.bl-cord    { stroke-dashoffset: 0; }
.bl-divider { stroke-dashoffset: 0; }
}
/* =======================================================================
OmniaBP Design System — colors.css
Paleta ORIGINAL: Electric Cobalt · Ocean Jade · Plasma Orange
Complementa el logo azul de OmniaBP.
Ninguno de estos tres tonos exactos existe en Bootstrap, Material,
Tailwind, Ant Design ni ningún otro sistema conocido.
Compatible Dark/Light, WASM/MAUI.
======================================================================= */
:root {
/* ── Primario: Electric Cobalt — azul profundo y vibrante ── */
--primary-color: #1d44cc;
--primary-light: #4d6fe0;
--primary-dark: #122d99;
--primary-hover: #1a3dbf;
--primary-foreground: #ffffff;
/* ── Secundario: Slate azulado neutro ── */
--secondary-color: #5a6880;
--secondary-light: #8292a8;
--secondary-dark: #3d4d64;
--secondary-foreground: #ffffff;
/* ── Acento: Ocean Jade — entre teal y verde, exclusivo ── */
--accent-color: #00d4a0;
--accent-light: #33ddb5;
--accent-dark: #00a87e;
--accent-foreground: #ffffff;
/* ── Energia: Plasma Orange — complementario del azul ── */
--highlight-energy: #ff7a18;
--highlight-energy-light: #ff9645;
--highlight-energy-dark: #e05f00;
/* ── Estados semanticos ── */
--success-color: #22c55e;
--success-background: #dcfce7;
--success-foreground: #14532d;
--success-light: #4ade80;
--success-dark: #16a34a;
--warning-color: #ff7a18;
--warning-background: #fff0e0;
--warning-foreground: #7a2e00;
--warning-light: #ff9645;
--warning-dark: #e05f00;
--danger-color: #ef4444;
--danger-background: #fee2e2;
--danger-foreground: #991b1b;
--danger-light: #f87171;
--danger-dark: #dc2626;
--info-color: #00d4a0;
--info-background: #d0faf1;
--info-foreground: #064e3b;
--info-light: #33ddb5;
--info-dark: #00a87e;
/* ── Texto ── */
--text-color: #0c111a;
--text-light: #ffffff;
--text-muted: #64748b;
--text-secondary: #475569;
--error-text: #dc2626;
--success-text: #16a34a;
/* ── Fondos: Slate coolWarm — no es blanco frio ── */
--background-color: #f7f8fb;
--secondary-background: #eef1f7;
--surface-color: #ffffff;
--surface-alt-color: #f7f8fb;
--card-bg-color: #ffffff;
--card-category-bg-color: #eef1f7;
--card-category-selected-color: #1d44cc;
--card-aditional-bg-color: #f7f8fb;
--selected-aditional-color: #1d44cc;
--overlay-color: rgba(8, 12, 24, 0.62);
/* ── Bordes ── */
--border-color: #dde3f0;
--border-light: #eef1f7;
--divider-color: #dde3f0;
--focus-color: #1d44cc;
--focus-ring: rgba(29, 68, 204, 0.22);
/* ── Interactivos ── */
--highlight-color: #1d44cc;
--hover-color: #1a3dbf;
--hover-background-color: rgba(29, 68, 204, 0.06);
--selected-color: #1d44cc;
--active-color: #122d99;
/* ── Deshabilitado ── */
--disabled-color: #94a3b8;
--disabled-background: #f1f5f9;
/* ── Sombras con tinte cobalt ── */
--shadow-xs: 0 1px 2px 0 rgba(12, 17, 26, 0.05);
--shadow-sm: 0 1px 4px 0 rgba(12, 17, 26, 0.08), 0 1px 2px -1px rgba(12, 17, 26, 0.05);
--shadow-md: 0 4px 12px -1px rgba(12, 17, 26, 0.10), 0 2px 6px -2px rgba(12, 17, 26, 0.06);
--shadow-lg: 0 10px 28px -3px rgba(12, 17, 26, 0.12), 0 4px 12px -4px rgba(12, 17, 26, 0.08);
--shadow-xl: 0 20px 48px -5px rgba(12, 17, 26, 0.14), 0 8px 20px -6px rgba(12, 17, 26, 0.10);
--shadow-color: rgba(12, 17, 26, 0.10);
--shadow-glow: 0 0 18px rgba(29, 68, 204, 0.30), 0 0 36px rgba(29, 68, 204, 0.12);
--shadow-glow-accent: 0 0 16px rgba(0, 212, 160, 0.38), 0 0 32px rgba(0, 212, 160, 0.14);
--shadow-glow-energy: 0 0 16px rgba(255, 122, 24, 0.40), 0 0 32px rgba(255, 122, 24, 0.14);
/* ── Links ── */
--link-color: #1d44cc;
--link-hover-color: #122d99;
--link-hover-text-color: #122d99;
/* ── Badge ── */
--badge-color: #ffffff;
--badge-bg: #1d44cc;
--badge-overlay-bg: rgba(8, 12, 24, 0.90);
--badge-overlay-border: rgba(29, 68, 204, 0.22);
/* ── Tablas ── */
--table-header-bg: #f7f8fb;
--table-header-text: #0c111a;
--table-row-hover: #eef1f7;
--table-border: #dde3f0;
/* ── Eventos ── */
--events-pill-bg: rgba(255, 255, 255, 0.95);
--events-pill-border: rgba(221, 227, 240, 0.9);
--events-pill-shadow: 0 2px 16px rgba(12, 17, 26, 0.10), 0 1px 4px rgba(12, 17, 26, 0.06);
--events-card-accent: var(--primary-color);
--events-card-image-bg: var(--surface-alt-color);
/* ── Glassmorphism ── */
--glass-bg: rgba(255, 255, 255, 0.82);
--glass-border: rgba(29, 68, 204, 0.16);
--glass-blur: 18px;
/* ── Gradientes OmniaBP ── */
--gradient-primary: linear-gradient(135deg, #1d44cc 0%, #4d6fe0 100%);
--gradient-accent: linear-gradient(135deg, #00d4a0 0%, #33ddb5 100%);
--gradient-energy: linear-gradient(135deg, #1d44cc 0%, #ff7a18 100%);
--gradient-tricolor: linear-gradient(135deg, #1d44cc 0%, #00d4a0 50%, #ff7a18 100%);
--gradient-surface: linear-gradient(180deg, var(--surface-color) 0%, var(--surface-alt-color) 100%);
--gradient-hero: linear-gradient(135deg, #06091a 0%, #0a1633 50%, #041210 100%);
--gradient-border: linear-gradient(135deg, #1d44cc, #00d4a0, #ff7a18);
/* ── TopBar ── */
--topbar-bg: rgba(255, 255, 255, 0.92);
--topbar-border: rgba(221, 227, 240, 0.8);
--topbar-shadow: 0 1px 3px rgba(12, 17, 26, 0.06), 0 4px 16px rgba(12, 17, 26, 0.04);
--topbar-accent-gradient: linear-gradient(90deg, #1d44cc 0%, #00d4a0 50%, #ff7a18 100%);
--topbar-nav-bg: #f7f8fb;
--topbar-nav-border: #dde3f0;
--topbar-nav-link-hover-bg: #ffffff;
--topbar-nav-link-hover-border: #dde3f0;
--topbar-dropdown-hover-bg: #eef1f7;
/* ── Sidebar ── */
--sidebar-header-bg: var(--surface-alt-color);
--sidebar-active-bg: rgba(29, 68, 204, 0.08);
--sidebar-active-border: var(--primary-color);
/* ── Card ── */
--card-hover-border: rgba(29, 68, 204, 0.25);
--card-accent-gradient: linear-gradient(135deg, #1d44cc 0%, #00d4a0 100%);
/* ── Tokens globales ── */
--transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
--transition-base: 220ms cubic-bezier(0.4, 0, 0.2, 1);
--transition-slow: 350ms cubic-bezier(0.4, 0, 0.2, 1);
--transition-spring: 400ms cubic-bezier(0.34, 1.56, 0.64, 1);
--radius-sm: 0.5rem;
--radius-md: 0.875rem;
--radius-lg: 1.25rem;
--radius-xl: 1.75rem;
--radius-pill: 9999px;
/* ── Escala global de z-index ─────────────────────────────
Regla: UI base < tooltips/pickers < modales < notificaciones
─────────────────────────────────────────────────────── */
--z-topbar:        100;   /* TopBar sticky */
--z-topbar-popup:  200;   /* Dropdowns y menú móvil del TopBar */
--z-sidebar:       300;   /* Sidebar lateral */
--z-tooltip:       400;   /* Tooltips, date-pickers, lazy-select */
--z-modal:        1000;   /* AppModal — siempre sobre todo lo anterior */
--z-modal-nested: 1050;   /* Modales dentro de modales */
--z-notification: 1100;   /* AppToast, AppPaymentResult */
--z-critical:     9999;   /* Loaders de pantalla completa, spinner global */
}
/* ═══════════════════════════════════════════════════════════════════════
DARK MODE — Deep Space Blue-Black
═══════════════════════════════════════════════════════════════════════ */
@media (prefers-color-scheme: dark) {
:root:not([data-theme='light']) {
--primary-color: #5b84f0;
--primary-light: #7fa0f5;
--primary-dark: #1d44cc;
--primary-hover: #7295f2;
--primary-foreground: #ffffff;
--secondary-color: #8292a8;
--secondary-light: #a8b8cc;
--secondary-dark: #5a6880;
--secondary-foreground: #0c1020;
--accent-color: #00e8b5;
--accent-light: #33eec5;
--accent-dark: #00d4a0;
--accent-foreground: #041a12;
--highlight-energy: #ff8f3a;
--highlight-energy-light: #ffaa64;
--highlight-energy-dark: #ff7a18;
--success-color: #4ade80;
--success-background: #052e16;
--success-foreground: #bbf7d0;
--success-light: #86efac;
--success-dark: #22c55e;
--warning-color: #ff8f3a;
--warning-background: #1a0e00;
--warning-foreground: #fed7aa;
--warning-light: #ffaa64;
--warning-dark: #ff7a18;
--danger-color: #f87171;
--danger-background: #1f0808;
--danger-foreground: #fecaca;
--danger-light: #fca5a5;
--danger-dark: #ef4444;
--info-color: #00e8b5;
--info-background: #021a12;
--info-foreground: #a7f3d0;
--info-light: #33eec5;
--info-dark: #00d4a0;
--text-color: #edf0f8;
--text-light: #ffffff;
--text-muted: #7a8ba6;
--text-secondary: #a8bace;
--error-text: #fca5a5;
--success-text: #86efac;
/* Deep Space Blue-Black */
--background-color: #060810;
--secondary-background: #0d1020;
--surface-color: #0f1428;
--surface-alt-color: #060810;
--card-bg-color: #0f1428;
--card-category-bg-color: #182040;
--card-category-selected-color: #5b84f0;
--card-aditional-bg-color: #0f1428;
--selected-aditional-color: #5b84f0;
--overlay-color: rgba(0, 0, 6, 0.84);
--border-color: #1a2340;
--border-light: #0f1428;
--divider-color: #1a2340;
--focus-color: #5b84f0;
--focus-ring: rgba(91, 132, 240, 0.28);
--highlight-color: #5b84f0;
--hover-color: #7fa0f5;
--hover-background-color: rgba(91, 132, 240, 0.10);
--selected-color: #5b84f0;
--active-color: #1d44cc;
--disabled-color: #3a4a6a;
--disabled-background: #182040;
--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.55);
--shadow-sm: 0 1px 4px 0 rgba(0, 0, 0, 0.70), 0 1px 2px -1px rgba(0, 0, 0, 0.55);
--shadow-md: 0 4px 12px -1px rgba(0, 0, 0, 0.75), 0 2px 6px -2px rgba(0, 0, 0, 0.60);
--shadow-lg: 0 10px 28px -3px rgba(0, 0, 0, 0.82), 0 4px 12px -4px rgba(0, 0, 0, 0.65);
--shadow-xl: 0 20px 48px -5px rgba(0, 0, 0, 0.88), 0 8px 20px -6px rgba(0, 0, 0, 0.72);
--shadow-color: rgba(0, 0, 0, 0.70);
--shadow-glow: 0 0 20px rgba(91, 132, 240, 0.45), 0 0 42px rgba(91, 132, 240, 0.18);
--shadow-glow-accent: 0 0 18px rgba(0, 232, 181, 0.50), 0 0 36px rgba(0, 232, 181, 0.18);
--shadow-glow-energy: 0 0 18px rgba(255, 143, 58, 0.50), 0 0 36px rgba(255, 143, 58, 0.18);
--link-color: #5b84f0;
--link-hover-color: #7fa0f5;
--link-hover-text-color: #7fa0f5;
--badge-color: #ffffff;
--badge-bg: #5b84f0;
--badge-overlay-bg: rgba(3, 4, 12, 0.93);
--badge-overlay-border: rgba(91, 132, 240, 0.22);
--table-header-bg: #0d1020;
--table-header-text: #edf0f8;
--table-row-hover: #182040;
--table-border: #1a2340;
--events-pill-bg: rgba(15, 20, 40, 0.97);
--events-pill-border: rgba(26, 35, 64, 0.9);
--events-pill-shadow: 0 2px 16px rgba(0, 0, 0, 0.52), 0 1px 4px rgba(0, 0, 0, 0.40);
--events-card-accent: var(--primary-color);
--events-card-image-bg: var(--surface-alt-color);
--glass-bg: rgba(15, 20, 40, 0.82);
--glass-border: rgba(91, 132, 240, 0.18);
--glass-blur: 20px;
--gradient-primary: linear-gradient(135deg, #5b84f0 0%, #7fa0f5 100%);
--gradient-accent: linear-gradient(135deg, #00e8b5 0%, #33eec5 100%);
--gradient-energy: linear-gradient(135deg, #5b84f0 0%, #ff8f3a 100%);
--gradient-tricolor: linear-gradient(135deg, #5b84f0 0%, #00e8b5 50%, #ff8f3a 100%);
--gradient-surface: linear-gradient(180deg, var(--surface-color) 0%, var(--surface-alt-color) 100%);
--gradient-hero: linear-gradient(135deg, #060810 0%, #0d1a40 50%, #051015 100%);
--gradient-border: linear-gradient(135deg, #5b84f0, #00e8b5, #ff8f3a);
--topbar-bg: rgba(6, 8, 16, 0.95);
--topbar-border: rgba(26, 35, 64, 0.80);
--topbar-shadow: 0 1px 3px rgba(0, 0, 0, 0.40), 0 4px 16px rgba(0, 0, 0, 0.30);
--topbar-accent-gradient: linear-gradient(90deg, #5b84f0 0%, #00e8b5 50%, #ff8f3a 100%);
--topbar-nav-bg: rgba(6, 8, 16, 0.60);
--topbar-nav-border: rgba(26, 35, 64, 0.80);
--topbar-nav-link-hover-bg: rgba(26, 35, 64, 0.70);
--topbar-nav-link-hover-border: rgba(26, 35, 64, 0.90);
--topbar-dropdown-hover-bg: #182040;
--sidebar-header-bg: var(--surface-alt-color);
--sidebar-active-bg: rgba(91, 132, 240, 0.14);
--sidebar-active-border: var(--primary-color);
--card-hover-border: rgba(91, 132, 240, 0.32);
--card-accent-gradient: linear-gradient(135deg, #5b84f0 0%, #00e8b5 100%);
}
}
/* ═══════════════════════════════════════════════════════════════════════
DARK OVERRIDE — data-theme="dark"
═══════════════════════════════════════════════════════════════════════ */
:root[data-theme='dark'] {
--primary-color: #5b84f0;
--primary-light: #7fa0f5;
--primary-dark: #1d44cc;
--primary-hover: #7295f2;
--primary-foreground: #ffffff;
--secondary-color: #8292a8;
--secondary-light: #a8b8cc;
--secondary-dark: #5a6880;
--secondary-foreground: #0c1020;
--accent-color: #00e8b5;
--accent-light: #33eec5;
--accent-dark: #00d4a0;
--accent-foreground: #041a12;
--highlight-energy: #ff8f3a;
--highlight-energy-light: #ffaa64;
--highlight-energy-dark: #ff7a18;
--success-color: #4ade80;
--success-background: #052e16;
--success-foreground: #bbf7d0;
--success-light: #86efac;
--success-dark: #22c55e;
--warning-color: #ff8f3a;
--warning-background: #1a0e00;
--warning-foreground: #fed7aa;
--warning-light: #ffaa64;
--warning-dark: #ff7a18;
--danger-color: #f87171;
--danger-background: #1f0808;
--danger-foreground: #fecaca;
--danger-light: #fca5a5;
--danger-dark: #ef4444;
--info-color: #00e8b5;
--info-background: #021a12;
--info-foreground: #a7f3d0;
--info-light: #33eec5;
--info-dark: #00d4a0;
--text-color: #edf0f8;
--text-light: #ffffff;
--text-muted: #7a8ba6;
--text-secondary: #a8bace;
--error-text: #fca5a5;
--success-text: #86efac;
--background-color: #060810;
--secondary-background: #0d1020;
--surface-color: #0f1428;
--surface-alt-color: #060810;
--card-bg-color: #0f1428;
--card-category-bg-color: #182040;
--card-category-selected-color: #5b84f0;
--card-aditional-bg-color: #0f1428;
--selected-aditional-color: #5b84f0;
--overlay-color: rgba(0, 0, 6, 0.84);
--border-color: #1a2340;
--border-light: #0f1428;
--divider-color: #1a2340;
--focus-color: #5b84f0;
--focus-ring: rgba(91, 132, 240, 0.28);
--highlight-color: #5b84f0;
--hover-color: #7fa0f5;
--hover-background-color: rgba(91, 132, 240, 0.10);
--selected-color: #5b84f0;
--active-color: #1d44cc;
--disabled-color: #3a4a6a;
--disabled-background: #182040;
--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.55);
--shadow-sm: 0 1px 4px 0 rgba(0, 0, 0, 0.70), 0 1px 2px -1px rgba(0, 0, 0, 0.55);
--shadow-md: 0 4px 12px -1px rgba(0, 0, 0, 0.75), 0 2px 6px -2px rgba(0, 0, 0, 0.60);
--shadow-lg: 0 10px 28px -3px rgba(0, 0, 0, 0.82), 0 4px 12px -4px rgba(0, 0, 0, 0.65);
--shadow-xl: 0 20px 48px -5px rgba(0, 0, 0, 0.88), 0 8px 20px -6px rgba(0, 0, 0, 0.72);
--shadow-color: rgba(0, 0, 0, 0.70);
--shadow-glow: 0 0 20px rgba(91, 132, 240, 0.45), 0 0 42px rgba(91, 132, 240, 0.18);
--shadow-glow-accent: 0 0 18px rgba(0, 232, 181, 0.50), 0 0 36px rgba(0, 232, 181, 0.18);
--shadow-glow-energy: 0 0 18px rgba(255, 143, 58, 0.50), 0 0 36px rgba(255, 143, 58, 0.18);
--link-color: #5b84f0;
--link-hover-color: #7fa0f5;
--link-hover-text-color: #7fa0f5;
--badge-color: #ffffff;
--badge-bg: #5b84f0;
--badge-overlay-bg: rgba(3, 4, 12, 0.93);
--badge-overlay-border: rgba(91, 132, 240, 0.22);
--table-header-bg: #0d1020;
--table-header-text: #edf0f8;
--table-row-hover: #182040;
--table-border: #1a2340;
--events-pill-bg: rgba(15, 20, 40, 0.97);
--events-pill-border: rgba(26, 35, 64, 0.9);
--events-pill-shadow: 0 2px 16px rgba(0, 0, 0, 0.52), 0 1px 4px rgba(0, 0, 0, 0.40);
--events-card-accent: var(--primary-color);
--events-card-image-bg: var(--surface-alt-color);
--glass-bg: rgba(15, 20, 40, 0.82);
--glass-border: rgba(91, 132, 240, 0.18);
--glass-blur: 20px;
--gradient-primary: linear-gradient(135deg, #5b84f0 0%, #7fa0f5 100%);
--gradient-accent: linear-gradient(135deg, #00e8b5 0%, #33eec5 100%);
--gradient-energy: linear-gradient(135deg, #5b84f0 0%, #ff8f3a 100%);
--gradient-tricolor: linear-gradient(135deg, #5b84f0 0%, #00e8b5 50%, #ff8f3a 100%);
--gradient-surface: linear-gradient(180deg, var(--surface-color) 0%, var(--surface-alt-color) 100%);
--gradient-hero: linear-gradient(135deg, #060810 0%, #0d1a40 50%, #051015 100%);
--gradient-border: linear-gradient(135deg, #5b84f0, #00e8b5, #ff8f3a);
--topbar-bg: rgba(6, 8, 16, 0.95);
--topbar-border: rgba(26, 35, 64, 0.80);
--topbar-shadow: 0 1px 3px rgba(0, 0, 0, 0.40), 0 4px 16px rgba(0, 0, 0, 0.30);
--topbar-accent-gradient: linear-gradient(90deg, #5b84f0 0%, #00e8b5 50%, #ff8f3a 100%);
--topbar-nav-bg: rgba(6, 8, 16, 0.60);
--topbar-nav-border: rgba(26, 35, 64, 0.80);
--topbar-nav-link-hover-bg: rgba(26, 35, 64, 0.70);
--topbar-nav-link-hover-border: rgba(26, 35, 64, 0.90);
--topbar-dropdown-hover-bg: #182040;
--sidebar-header-bg: var(--surface-alt-color);
--sidebar-active-bg: rgba(91, 132, 240, 0.14);
--sidebar-active-border: var(--primary-color);
--card-hover-border: rgba(91, 132, 240, 0.32);
--card-accent-gradient: linear-gradient(135deg, #5b84f0 0%, #00e8b5 100%);
--transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
--transition-base: 220ms cubic-bezier(0.4, 0, 0.2, 1);
--transition-slow: 350ms cubic-bezier(0.4, 0, 0.2, 1);
--transition-spring: 400ms cubic-bezier(0.34, 1.56, 0.64, 1);
--radius-sm: 0.5rem;
--radius-md: 0.875rem;
--radius-lg: 1.25rem;
--radius-xl: 1.75rem;
--radius-pill: 9999px;
}
/* ═══════════════════════════════════════════════════════════════════════
LIGHT OVERRIDE — data-theme="light"
═══════════════════════════════════════════════════════════════════════ */
:root[data-theme='light'] {
--primary-color: #1d44cc;
--primary-light: #4d6fe0;
--primary-dark: #122d99;
--primary-hover: #1a3dbf;
--primary-foreground: #ffffff;
--secondary-color: #5a6880;
--secondary-light: #8292a8;
--secondary-dark: #3d4d64;
--secondary-foreground: #ffffff;
--accent-color: #00d4a0;
--accent-light: #33ddb5;
--accent-dark: #00a87e;
--accent-foreground: #ffffff;
--highlight-energy: #ff7a18;
--highlight-energy-light: #ff9645;
--highlight-energy-dark: #e05f00;
--success-color: #22c55e;
--success-background: #dcfce7;
--success-foreground: #14532d;
--success-light: #4ade80;
--success-dark: #16a34a;
--warning-color: #ff7a18;
--warning-background: #fff0e0;
--warning-foreground: #7a2e00;
--warning-light: #ff9645;
--warning-dark: #e05f00;
--danger-color: #ef4444;
--danger-background: #fee2e2;
--danger-foreground: #991b1b;
--danger-light: #f87171;
--danger-dark: #dc2626;
--info-color: #00d4a0;
--info-background: #d0faf1;
--info-foreground: #064e3b;
--info-light: #33ddb5;
--info-dark: #00a87e;
--text-color: #0c111a;
--text-light: #ffffff;
--text-muted: #64748b;
--text-secondary: #475569;
--error-text: #dc2626;
--success-text: #16a34a;
--background-color: #f7f8fb;
--secondary-background: #eef1f7;
--surface-color: #ffffff;
--surface-alt-color: #f7f8fb;
--card-bg-color: #ffffff;
--card-category-bg-color: #eef1f7;
--card-category-selected-color: #1d44cc;
--card-aditional-bg-color: #f7f8fb;
--selected-aditional-color: #1d44cc;
--overlay-color: rgba(8, 12, 24, 0.62);
--border-color: #dde3f0;
--border-light: #eef1f7;
--divider-color: #dde3f0;
--focus-color: #1d44cc;
--focus-ring: rgba(29, 68, 204, 0.22);
--highlight-color: #1d44cc;
--hover-color: #1a3dbf;
--hover-background-color: rgba(29, 68, 204, 0.06);
--selected-color: #1d44cc;
--active-color: #122d99;
--disabled-color: #94a3b8;
--disabled-background: #f1f5f9;
--shadow-xs: 0 1px 2px 0 rgba(12, 17, 26, 0.05);
--shadow-sm: 0 1px 4px 0 rgba(12, 17, 26, 0.08), 0 1px 2px -1px rgba(12, 17, 26, 0.05);
--shadow-md: 0 4px 12px -1px rgba(12, 17, 26, 0.10), 0 2px 6px -2px rgba(12, 17, 26, 0.06);
--shadow-lg: 0 10px 28px -3px rgba(12, 17, 26, 0.12), 0 4px 12px -4px rgba(12, 17, 26, 0.08);
--shadow-xl: 0 20px 48px -5px rgba(12, 17, 26, 0.14), 0 8px 20px -6px rgba(12, 17, 26, 0.10);
--shadow-color: rgba(12, 17, 26, 0.10);
--shadow-glow: 0 0 18px rgba(29, 68, 204, 0.30), 0 0 36px rgba(29, 68, 204, 0.12);
--shadow-glow-accent: 0 0 16px rgba(0, 212, 160, 0.38), 0 0 32px rgba(0, 212, 160, 0.14);
--shadow-glow-energy: 0 0 16px rgba(255, 122, 24, 0.40), 0 0 32px rgba(255, 122, 24, 0.14);
--link-color: #1d44cc;
--link-hover-color: #122d99;
--link-hover-text-color: #122d99;
--badge-color: #ffffff;
--badge-bg: #1d44cc;
--badge-overlay-bg: rgba(8, 12, 24, 0.90);
--badge-overlay-border: rgba(29, 68, 204, 0.22);
--table-header-bg: #f7f8fb;
--table-header-text: #0c111a;
--table-row-hover: #eef1f7;
--table-border: #dde3f0;
--events-pill-bg: rgba(255, 255, 255, 0.95);
--events-pill-border: rgba(221, 227, 240, 0.9);
--events-pill-shadow: 0 2px 16px rgba(12, 17, 26, 0.10), 0 1px 4px rgba(12, 17, 26, 0.06);
--events-card-accent: var(--primary-color);
--events-card-image-bg: var(--surface-alt-color);
--glass-bg: rgba(255, 255, 255, 0.82);
--glass-border: rgba(29, 68, 204, 0.16);
--glass-blur: 18px;
--gradient-primary: linear-gradient(135deg, #1d44cc 0%, #4d6fe0 100%);
--gradient-accent: linear-gradient(135deg, #00d4a0 0%, #33ddb5 100%);
--gradient-energy: linear-gradient(135deg, #1d44cc 0%, #ff7a18 100%);
--gradient-tricolor: linear-gradient(135deg, #1d44cc 0%, #00d4a0 50%, #ff7a18 100%);
--gradient-surface: linear-gradient(180deg, var(--surface-color) 0%, var(--surface-alt-color) 100%);
--gradient-hero: linear-gradient(135deg, #06091a 0%, #0a1633 50%, #041210 100%);
--gradient-border: linear-gradient(135deg, #1d44cc, #00d4a0, #ff7a18);
--topbar-bg: rgba(255, 255, 255, 0.92);
--topbar-border: rgba(221, 227, 240, 0.8);
--topbar-shadow: 0 1px 3px rgba(12, 17, 26, 0.06), 0 4px 16px rgba(12, 17, 26, 0.04);
--topbar-accent-gradient: linear-gradient(90deg, #1d44cc 0%, #00d4a0 50%, #ff7a18 100%);
--topbar-nav-bg: #f7f8fb;
--topbar-nav-border: #dde3f0;
--topbar-nav-link-hover-bg: #ffffff;
--topbar-nav-link-hover-border: #dde3f0;
--topbar-dropdown-hover-bg: #eef1f7;
--sidebar-header-bg: var(--surface-alt-color);
--sidebar-active-bg: rgba(29, 68, 204, 0.08);
--sidebar-active-border: var(--primary-color);
--card-hover-border: rgba(29, 68, 204, 0.25);
--card-accent-gradient: linear-gradient(135deg, #1d44cc 0%, #00d4a0 100%);
--transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
--transition-base: 220ms cubic-bezier(0.4, 0, 0.2, 1);
--transition-slow: 350ms cubic-bezier(0.4, 0, 0.2, 1);
--transition-spring: 400ms cubic-bezier(0.34, 1.56, 0.64, 1);
--radius-sm: 0.5rem;
--radius-md: 0.875rem;
--radius-lg: 1.25rem;
--radius-xl: 1.75rem;
--radius-pill: 9999px;
}
/* =======================================================================
NexEvent Design System — general.css
Base global, layout, utilidades, scrollbar, helpers
======================================================================= */
/* === BASE === */
body {
margin: 0;
padding: 0;
font-family: 'Inter', 'Segoe UI', -apple-system, BlinkMacSystemFont, sans-serif;
font-size: 16px;
line-height: 1.6;
background-color: var(--background-color);
background-image:
radial-gradient(ellipse 80% 50% at 20% -10%, rgba(124, 58, 237, 0.10) 0%, transparent 60%),
radial-gradient(ellipse 60% 40% at 80% 10%, rgba(6, 182, 212, 0.07) 0%, transparent 55%);
color: var(--text-color);
min-height: 100vh;
overflow-x: hidden;
scroll-behavior: smooth;
transition: background-color var(--transition-slow), color var(--transition-slow);
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
::selection {
background: var(--primary-color);
color: var(--primary-foreground);
}
h1, h2, h3, h4, h5, h6 {
margin: 0 0 1rem 0;
font-weight: 700;
color: var(--text-color);
line-height: 1.2;
letter-spacing: -0.025em;
}
h1 { font-size: 2.5rem; letter-spacing: -0.04em; }
h2 { font-size: 2rem; letter-spacing: -0.03em; }
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.65;
color: var(--text-color);
}
a {
color: var(--link-color);
text-decoration: none;
transition: color var(--transition-fast);
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: 1440px;
margin: 0 auto;
padding: 0 clamp(1rem, 2vw, 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: transparent;
}
.content-area {
flex: 1;
padding: 2rem 1rem;
overflow-y: auto;
background: transparent;
padding-top: 80px;
}
/* === CARDS GENERICAS === */
.card {
background: var(--card-bg-color);
border: 1px solid var(--border-color);
border-radius: var(--radius-lg);
box-shadow: var(--shadow-sm);
padding: 1.5rem;
margin: 1rem 0;
transition: all var(--transition-base);
position: relative;
overflow: hidden;
}
.card::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
background: var(--card-accent-gradient);
opacity: 0;
transition: opacity var(--transition-base);
}
.card:hover {
box-shadow: var(--shadow-lg);
transform: translateY(-3px);
border-color: var(--card-hover-border);
}
.card:hover::before { opacity: 1; }
.card--flat { box-shadow: none; }
.card--elevated { box-shadow: var(--shadow-md); }
/* === BOTONES GENERICOS === */
button:not([class*="app-"]):not([class*="btn-"]):not([class*="adr"]):not([class*="theme-"]):not([class*="art-"]),
.btn {
background: var(--gradient-primary);
color: var(--primary-foreground);
border: 1px solid transparent;
border-radius: var(--radius-md);
padding: 0.625rem 1.25rem;
font-size: 0.9375rem;
font-weight: 600;
cursor: pointer;
transition: all var(--transition-base);
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.75rem;
letter-spacing: 0.01em;
}
button:not([class*="app-"]):not([class*="btn-"]):not([class*="adr"]):not([class*="theme-"]):not([class*="art-"]):hover,
.btn:hover {
box-shadow: var(--shadow-md), var(--shadow-glow);
transform: translateY(-2px);
}
button:not([class*="app-"]):not([class*="btn-"]):not([class*="adr"]):not([class*="theme-"]):not([class*="art-"]):active,
.btn:active {
transform: translateY(0);
box-shadow: var(--shadow-sm);
}
button:not([class*="app-"]):not([class*="btn-"]):not([class*="adr"]):not([class*="theme-"]):not([class*="art-"]):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-"]):not([class*="art-"]):disabled,
.btn:disabled {
background: var(--disabled-background);
color: var(--disabled-color);
cursor: not-allowed;
opacity: 0.6;
box-shadow: none;
transform: none;
}
.btn-secondary { background: var(--secondary-color); color: var(--secondary-foreground); }
.btn-secondary:hover { background: var(--secondary-dark); color: var(--secondary-foreground); }
.btn-success { background: var(--success-color); color: var(--success-foreground); }
.btn-success:hover { background: var(--success-dark); color: var(--success-foreground); }
.btn-danger { background: var(--danger-color); color: var(--danger-foreground); }
.btn-danger:hover { background: var(--danger-dark); color: var(--danger-foreground); }
.btn-warning { background: var(--warning-color); color: var(--warning-foreground); }
.btn-warning:hover { background: var(--warning-dark); color: var(--warning-foreground); }
.btn-outline {
background: transparent;
color: var(--primary-color);
border: 1.5px solid var(--primary-color);
box-shadow: none;
}
.btn-outline:hover {
background: var(--primary-color);
color: var(--primary-foreground);
box-shadow: var(--shadow-glow);
}
.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);
border-color: var(--primary-color);
color: var(--primary-color);
}
/* === FORMULARIOS GENERICOS === */
input:not([class*="app-"]),
select:not([class*="app-"]),
textarea:not([class*="app-"]) {
width: 100%;
padding: 0.625rem 1rem;
border: 1.5px solid var(--border-color);
border-radius: var(--radius-md);
background-color: var(--surface-color);
color: var(--text-color);
font-size: 0.9375rem;
font-family: inherit;
margin: 0.5rem 0;
transition: all var(--transition-base);
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);
}
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(--primary-color);
}
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: 600;
color: var(--text-color);
font-size: 0.8125rem;
letter-spacing: 0.04em;
text-transform: uppercase;
}
/* === ALERTAS === */
.alert {
padding: 1rem 1.25rem;
margin: 1rem 0;
border-radius: var(--radius-md);
font-weight: 500;
border: 1px solid transparent;
display: flex;
align-items: center;
gap: 0.75rem;
box-shadow: var(--shadow-sm);
position: relative;
overflow: hidden;
}
.alert::before {
content: '';
position: absolute;
left: 0; top: 0; bottom: 0;
width: 3px;
}
.alert-success { background: var(--success-background); color: var(--success-foreground); border-color: var(--success-color); }
.alert-success::before { background: var(--success-color); }
.alert-error { background: var(--danger-background); color: var(--error-text); border-color: var(--danger-color); }
.alert-error::before { background: var(--danger-color); }
.alert-warning { background: var(--warning-background); color: var(--warning-foreground); border-color: var(--warning-color); }
.alert-warning::before { background: var(--warning-color); }
.alert-info { background: var(--info-background); color: var(--info-foreground); border-color: var(--info-color); }
.alert-info::before { background: var(--info-color); }
/* === SCROLLBAR === */
::-webkit-scrollbar { width: 5px; height: 5px; background: transparent; }
::-webkit-scrollbar-track { background: transparent; border-radius: 3px; }
::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 3px; transition: background var(--transition-fast); }
::-webkit-scrollbar-thumb:hover { background: var(--primary-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; }
/* === FLEXBOX UTILS === */
.align-center { display: flex !important; justify-content: center !important; align-items: center !important; }
/* === MAUI SAFE AREA ===
--sat / --sab se inyectan vía JS desde MainPage.xaml.cs con los insets reales del sistema.
env(safe-area-inset-*) actúa como fallback para iOS y Web.
*/
:root {
--sat: env(safe-area-inset-top, 0px);
--sab: env(safe-area-inset-bottom, 0px);
}
.maui-safe-area {
padding-top: var(--sat);
padding-bottom: var(--sab);
padding-left: env(safe-area-inset-left, 0px);
padding-right: env(safe-area-inset-right, 0px);
box-sizing: border-box;
min-height: 100dvh;
}
.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; }
/* Reset moderno */
*, *::before, *::after {
box-sizing: border-box;
margin: 0;
padding: 0;
}
html, body {
height: 100%;
font-family: 'Inter', 'Segoe UI', 'Roboto', -apple-system, BlinkMacSystemFont, sans-serif;
background: var(--background-color, #f5f3ff);
color: var(--text-color, #0f0f1a);
-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;
}
/* =======================================================================
NexEvent Design System — typography.css
Jerarquia tipografica tech-events premium
======================================================================= */
h1, h2, h3, h4, h5, h6 {
font-family: 'Inter', 'Segoe UI', -apple-system, BlinkMacSystemFont, sans-serif;
font-weight: 700;
color: var(--text-color);
margin-bottom: 0.5em;
line-height: 1.15;
}
h1 { font-size: 2.5rem; letter-spacing: -0.04em; }
h2 { font-size: 2rem; letter-spacing: -0.03em; }
h3 { font-size: 1.5rem; letter-spacing: -0.02em; }
h4 { font-size: 1.25rem; letter-spacing: -0.01em; }
h5 { font-size: 1rem; letter-spacing: 0; }
h6 { font-size: 0.875rem; letter-spacing: 0.02em; text-transform: uppercase; }
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.65;
}
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;
}
/* Utility classes de tipografia NexEvent */
.nx-label {
font-size: 0.6875rem;
font-weight: 700;
letter-spacing: 0.1em;
text-transform: uppercase;
color: var(--text-muted);
}
.nx-eyebrow {
font-size: 0.75rem;
font-weight: 700;
letter-spacing: 0.12em;
text-transform: uppercase;
color: var(--primary-color);
}
.nx-display {
font-size: clamp(2.5rem, 5vw, 4.5rem);
font-weight: 800;
letter-spacing: -0.05em;
line-height: 1.0;
color: var(--text-color);
}
.nx-mono {
font-family: 'Fira Code', 'Cascadia Code', 'Consolas', monospace;
font-size: 0.875rem;
letter-spacing: 0.02em;
}
/* 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: var(--radius-sm);
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: var(--radius-sm);
}
/* Tabla */
.admin-event-payment-keys__table-wrapper {
width: 100%;
overflow-x: auto;
background: var(--surface-color);
border-radius: var(--radius-sm);
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: var(--radius-lg);
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: var(--radius-sm) !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: var(--radius-sm);
}
.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;
}
}
/* =======================================================================
NexEvent — AppAdminToolbar
Barra admin sticky con identidad tech, acento gradiente superior
======================================================================= */
.app-admin-toolbar {
display: flex;
flex-direction: column;
gap: 0.875rem;
padding: 1rem 1.25rem;
background: var(--surface-color);
border-bottom: 1px solid var(--border-color);
position: sticky;
top: 0;
z-index: 10;
position: relative;
}
.app-admin-toolbar::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
background: var(--card-accent-gradient);
}
.app-admin-toolbar__actions {
display: flex;
flex-wrap: wrap;
gap: 0.5rem;
align-items: center;
}
.app-admin-toolbar__btn {
display: inline-flex;
align-items: center;
gap: 0.4rem;
padding: 0.5rem 1rem;
font-size: 0.8125rem;
font-weight: 600;
border: 1.5px solid transparent;
border-radius: var(--radius-md);
cursor: pointer;
transition: all var(--transition-base);
white-space: nowrap;
letter-spacing: 0.01em;
}
.app-admin-toolbar__btn:disabled { opacity: 0.5; cursor: not-allowed; }
.app-admin-toolbar__btn--primary {
background: var(--gradient-primary);
color: #ffffff;
border-color: transparent;
}
.app-admin-toolbar__btn--primary:hover:not(:disabled) {
box-shadow: var(--shadow-sm), var(--shadow-glow);
transform: translateY(-1px);
}
.app-admin-toolbar__btn--success {
background: var(--success-color);
color: var(--success-foreground);
border-color: var(--success-color);
}
.app-admin-toolbar__btn--success:hover:not(:disabled) {
background: var(--success-dark);
box-shadow: var(--shadow-sm), 0 0 12px rgba(16,185,129,0.3);
transform: translateY(-1px);
}
.app-admin-toolbar__btn--ghost {
background: transparent;
color: var(--text-color);
border-color: var(--border-color);
}
.app-admin-toolbar__btn--ghost:hover:not(:disabled) {
background: var(--hover-background-color);
border-color: var(--primary-color);
color: var(--primary-color);
}
.app-admin-toolbar__icon { width: 1rem; height: 1rem; flex-shrink: 0; }
.app-admin-toolbar__label { display: none; }
@media (min-width: 640px) {
.app-admin-toolbar__label { display: inline; }
}
/* Título de página inline en la toolbar */
.app-admin-toolbar__page-title {
font-size: 0.75rem;
font-weight: 700;
letter-spacing: 0.06em;
text-transform: uppercase;
color: var(--primary-color);
white-space: nowrap;
line-height: 1;
display: none;
}
@media (min-width: 640px) {
.app-admin-toolbar__page-title { display: inline; }
}
.app-admin-toolbar__title-divider {
display: none;
width: 1px;
height: 1.125rem;
background: var(--border-color);
flex-shrink: 0;
}
@media (min-width: 640px) {
.app-admin-toolbar__title-divider { display: inline-block; }
}
.app-admin-toolbar__info {
display: flex;
flex-wrap: wrap;
gap: 0.875rem;
align-items: center;
justify-content: space-between;
font-size: 0.8125rem;
color: var(--text-muted);
letter-spacing: 0.02em;
}
.app-admin-toolbar__summary {
font-weight: 600;
color: var(--text-color);
}
/* =======================================================================
NexEvent — AppFilterBadge
Chips de filtro activos con estilo pill neón
======================================================================= */
.app-filter-badge {
display: inline-flex;
align-items: center;
gap: 0.3rem;
padding: 0.2rem 0.65rem;
font-size: 0.75rem;
background: var(--hover-background-color);
color: var(--primary-color);
border: 1.5px solid var(--primary-color);
border-radius: var(--radius-pill);
white-space: nowrap;
transition: all var(--transition-base);
animation: badge-fade-in 0.18s cubic-bezier(0.4, 0, 0.2, 1);
font-weight: 600;
letter-spacing: 0.02em;
}
@keyframes badge-fade-in {
from { opacity: 0; transform: scale(0.9); }
to { opacity: 1; transform: scale(1); }
}
.app-filter-badge:hover { box-shadow: var(--shadow-sm), var(--shadow-glow); }
.app-filter-badge__label { font-weight: 700; 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.9rem;
height: 0.9rem;
margin-left: 0.1rem;
background: transparent;
border: none;
border-radius: 50%;
cursor: pointer;
transition: all var(--transition-fast);
color: var(--primary-color);
padding: 0;
}
.app-filter-badge__remove:hover {
background: var(--primary-color);
color: var(--primary-foreground);
transform: scale(1.15);
}
.app-filter-badge__remove svg { width: 0.6rem; height: 0.6rem; }
/* =======================================================================
NexEvent — AppFilterPanel
Panel lateral de filtros con slide-in y glassmorphism
======================================================================= */
.app-filter-panel {
position: fixed;
inset: 0;
z-index: var(--z-sidebar);
pointer-events: none;
}
.app-filter-panel--open { pointer-events: auto; }
.app-filter-panel__overlay {
position: absolute;
inset: 0;
background: var(--overlay-color);
opacity: 0;
transition: opacity var(--transition-base);
backdrop-filter: blur(4px);
-webkit-backdrop-filter: blur(4px);
}
.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: var(--surface-color);
border-left: 1.5px solid var(--border-color);
box-shadow: var(--shadow-xl), var(--shadow-glow);
transform: translateX(100%);
transition: transform var(--transition-slow);
}
.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: 1.25rem 1.5rem;
border-bottom: 1px solid var(--border-color);
background: var(--surface-color);
position: relative;
}
.app-filter-panel__header::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
background: var(--card-accent-gradient);
}
.app-filter-panel__title {
margin: 0;
font-size: 1rem;
font-weight: 700;
color: var(--text-color);
letter-spacing: -0.01em;
}
.app-filter-panel__close {
display: inline-flex;
align-items: center;
justify-content: center;
width: 2.25rem;
height: 2.25rem;
padding: 0;
background: transparent;
border: 1.5px solid transparent;
border-radius: var(--radius-sm);
cursor: pointer;
transition: all var(--transition-base);
color: var(--text-muted);
}
.app-filter-panel__close:hover {
background: var(--hover-background-color);
border-color: var(--border-color);
color: var(--primary-color);
}
.app-filter-panel__close svg { width: 1.25rem; height: 1.25rem; }
.app-filter-panel__body {
flex: 1;
overflow-y: auto;
padding: 1.25rem 1.5rem;
background: var(--background-color);
}
.app-filter-panel__footer {
display: flex;
gap: 0.5rem;
padding: 1rem 1.5rem;
border-top: 1px solid var(--border-color);
background: var(--surface-color);
flex-shrink: 0;
}
/* ── Botones del footer ── */
.app-filter-panel__btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.4rem;
padding: 0.5rem 1.125rem;
border-radius: var(--radius-sm);
font-size: 0.875rem;
font-weight: 600;
line-height: 1;
cursor: pointer;
transition: all var(--transition-base);
border: 1.5px solid transparent;
white-space: nowrap;
}
.app-filter-panel__btn:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
.app-filter-panel__btn:active {
transform: scale(0.96);
}
/* Variante primaria */
.app-filter-panel__btn--primary {
background: var(--primary-color);
color: var(--primary-foreground, #fff);
border-color: var(--primary-color);
flex: 1;
}
.app-filter-panel__btn--primary:hover {
background: var(--primary-hover, var(--primary-color));
box-shadow: 0 0 0 3px var(--focus-ring);
}
/* Variante ghost */
.app-filter-panel__btn--ghost {
background: transparent;
color: var(--text-muted);
border-color: var(--border-color);
}
.app-filter-panel__btn--ghost:hover {
background: var(--hover-background-color);
border-color: var(--primary-color);
color: var(--primary-color);
}
/* ================================================
admin-activate-stand — BEM
Wizard de activación de stand (3 pasos)
================================================ */
.admin-activate-stand__overlay {
position: fixed;
inset: 0;
background: rgba(0, 0, 0, 0.5);
z-index: 1200;
}
.admin-activate-stand__panel {
position: fixed;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
width: 95%;
max-width: 640px;
max-height: 92vh;
background: var(--surface-background);
border-radius: 0.75rem;
display: flex;
flex-direction: column;
z-index: 1201;
box-shadow: 0 8px 40px rgba(0, 0, 0, 0.22);
overflow: hidden;
}
/* Header */
.admin-activate-stand__header {
display: flex;
align-items: center;
justify-content: space-between;
padding: 1rem 1.25rem;
border-bottom: 1px solid var(--border-color);
background: var(--surface-secondary-background);
flex-shrink: 0;
}
.admin-activate-stand__title {
font-size: 1rem;
font-weight: 700;
color: var(--text-primary);
}
.admin-activate-stand__subtitle {
font-size: 0.82rem;
color: var(--text-secondary);
margin-left: 0.5rem;
}
.admin-activate-stand__close {
background: none;
border: none;
cursor: pointer;
color: var(--text-secondary);
padding: 0.25rem;
border-radius: 0.3rem;
display: flex;
align-items: center;
transition: background 0.15s;
}
.admin-activate-stand__close:hover {
background: var(--hover-background);
color: var(--text-primary);
}
.admin-activate-stand__close svg {
width: 20px;
height: 20px;
}
/* Stepper */
.admin-activate-stand__stepper {
padding: 0.75rem 1.25rem;
border-bottom: 1px solid var(--border-color);
flex-shrink: 0;
}
/* Body */
.admin-activate-stand__body {
flex: 1;
overflow-y: auto;
padding: 1.25rem;
}
.admin-activate-stand__step-title {
font-size: 0.95rem;
font-weight: 700;
color: var(--text-primary);
margin: 0 0 1rem 0;
}
.admin-activate-stand__section-title {
font-size: 0.85rem;
font-weight: 600;
color: var(--text-secondary);
text-transform: uppercase;
letter-spacing: 0.05em;
margin: 0.75rem 0 0.5rem;
}
.admin-activate-stand__divider {
height: 1px;
background: var(--border-color);
margin: 1rem 0;
}
/* Form */
.admin-activate-stand__form-group {
display: flex;
flex-direction: column;
gap: 0.3rem;
margin-bottom: 0.75rem;
}
.admin-activate-stand__form-row {
display: grid;
grid-template-columns: 1fr 1fr 1fr;
gap: 0.75rem;
}
.admin-activate-stand__label {
font-size: 0.8rem;
font-weight: 600;
color: var(--text-secondary);
}
/* Items */
.admin-activate-stand__item-card {
border: 1px solid var(--border-color);
border-radius: 0.5rem;
padding: 0.85rem;
margin-bottom: 0.75rem;
background: var(--surface-secondary-background);
}
.admin-activate-stand__item-header {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 0.5rem;
}
.admin-activate-stand__item-num {
font-size: 0.8rem;
font-weight: 700;
color: var(--accent-color);
text-transform: uppercase;
}
.admin-activate-stand__add-item {
margin-top: 0.25rem;
margin-bottom: 1rem;
}
/* Totales */
.admin-activate-stand__totals {
display: flex;
flex-direction: column;
gap: 0.3rem;
padding: 0.75rem;
background: var(--surface-secondary-background);
border-radius: 0.5rem;
border: 1px solid var(--border-color);
font-size: 0.9rem;
color: var(--text-primary);
}
/* Error */
.admin-activate-stand__error {
color: var(--danger-foreground);
background: var(--danger-background);
padding: 0.6rem 0.85rem;
border-radius: 0.4rem;
font-size: 0.85rem;
margin-top: 0.5rem;
}
/* Footer */
.admin-activate-stand__footer {
display: flex;
align-items: center;
justify-content: flex-end;
gap: 0.5rem;
padding: 0.85rem 1.25rem;
border-top: 1px solid var(--border-color);
background: var(--surface-secondary-background);
flex-shrink: 0;
}
/* Responsivo */
@media (max-width: 640px) {
.admin-activate-stand__panel {
max-height: 100vh;
border-radius: 0;
}
.admin-activate-stand__form-row {
grid-template-columns: 1fr 1fr;
}
}
@media (max-width: 400px) {
.admin-activate-stand__form-row {
grid-template-columns: 1fr;
}
}
/* ── AdminMarkPaidModal ──────────────────────────────────────────────────── */
.admin-mark-paid__overlay {
position: fixed;
inset: 0;
background: rgba(0, 0, 0, 0.55);
z-index: 500;
}
.admin-mark-paid__panel {
position: fixed;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
z-index: 501;
width: min(580px, 95vw);
max-height: 90vh;
overflow-y: auto;
background: var(--card-background);
border: 1px solid var(--border-color);
border-radius: 12px;
display: flex;
flex-direction: column;
}
/* ── Header ── */
.admin-mark-paid__header {
display: flex;
align-items: flex-start;
gap: 0.5rem;
padding: 1.25rem 1.5rem 1rem;
border-bottom: 1px solid var(--border-color);
}
.admin-mark-paid__title {
font-size: 1.1rem;
font-weight: 700;
color: var(--text-primary);
flex: 1;
}
.admin-mark-paid__subtitle {
font-size: 0.82rem;
color: var(--text-secondary);
margin-top: 0.15rem;
flex: 1;
align-self: center;
}
.admin-mark-paid__close {
background: none;
border: none;
cursor: pointer;
color: var(--text-secondary);
padding: 0.25rem;
display: flex;
align-items: center;
}
.admin-mark-paid__close svg {
width: 1.1rem;
height: 1.1rem;
}
.admin-mark-paid__close:hover {
color: var(--danger-foreground);
}
/* ── Body ── */
.admin-mark-paid__body {
padding: 1.25rem 1.5rem;
display: flex;
flex-direction: column;
gap: 1.25rem;
flex: 1;
}
/* ── Section ── */
.admin-mark-paid__section {
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.admin-mark-paid__section-title {
font-size: 0.9rem;
font-weight: 700;
color: var(--text-primary);
margin: 0;
padding-bottom: 0.4rem;
border-bottom: 1px solid var(--border-color);
}
.admin-mark-paid__form-group {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.admin-mark-paid__label {
font-size: 0.82rem;
font-weight: 500;
color: var(--text-secondary);
}
/* ── Error ── */
.admin-mark-paid__error {
font-size: 0.85rem;
padding: 0.6rem 0.875rem;
border-radius: 6px;
background: var(--danger-background);
color: var(--danger-foreground);
border: 1px solid var(--danger-border, transparent);
}
/* ── Footer ── */
.admin-mark-paid__footer {
display: flex;
justify-content: flex-end;
gap: 0.75rem;
padding: 1rem 1.5rem;
border-top: 1px solid var(--border-color);
}
/* ── Responsive ── */
@media (max-width: 600px) {
.admin-mark-paid__panel {
width: 100vw;
height: 100dvh;
max-height: 100dvh;
border-radius: 0;
top: 0;
left: 0;
transform: none;
}
.admin-mark-paid__footer {
flex-direction: column;
}
}
/* ── AdminStandFiscalModal ─────────────────────────────────────────────── */
.admin-stand-fiscal__overlay {
position: fixed;
inset: 0;
background: rgba(0, 0, 0, 0.55);
z-index: 500;
}
.admin-stand-fiscal__panel {
position: fixed;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
z-index: 501;
width: min(620px, 95vw);
max-height: 90vh;
overflow-y: auto;
background: var(--card-background);
border: 1px solid var(--border-color);
border-radius: 12px;
display: flex;
flex-direction: column;
gap: 0;
}
/* ── Header ── */
.admin-stand-fiscal__header {
display: flex;
align-items: flex-start;
gap: 0.5rem;
padding: 1.25rem 1.5rem 1rem;
border-bottom: 1px solid var(--border-color);
position: relative;
}
.admin-stand-fiscal__title {
font-size: 1.1rem;
font-weight: 700;
color: var(--text-primary);
flex: 1;
}
.admin-stand-fiscal__subtitle {
font-size: 0.82rem;
color: var(--text-secondary);
margin-top: 0.15rem;
flex: 1;
align-self: center;
}
.admin-stand-fiscal__close {
background: none;
border: none;
cursor: pointer;
color: var(--text-secondary);
padding: 0.25rem;
display: flex;
align-items: center;
}
.admin-stand-fiscal__close svg {
width: 1.1rem;
height: 1.1rem;
}
.admin-stand-fiscal__close:hover {
color: var(--danger-foreground);
}
/* ── Body ── */
.admin-stand-fiscal__body {
padding: 1.25rem 1.5rem 1.5rem;
display: flex;
flex-direction: column;
gap: 1.25rem;
}
/* ── Loading / Empty ── */
.admin-stand-fiscal__loading,
.admin-stand-fiscal__empty {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.75rem;
padding: 2rem 0;
color: var(--text-secondary);
font-size: 0.9rem;
}
/* ── Summary ── */
.admin-stand-fiscal__summary {
background: var(--surface-background);
border: 1px solid var(--border-color);
border-radius: 8px;
padding: 0.875rem 1rem;
display: flex;
flex-direction: column;
gap: 0.35rem;
}
.admin-stand-fiscal__summary-row {
display: flex;
justify-content: space-between;
font-size: 0.85rem;
}
.admin-stand-fiscal__summary-label {
color: var(--text-secondary);
}
.admin-stand-fiscal__summary-value {
color: var(--text-primary);
font-weight: 500;
}
/* ── Sección ── */
.admin-stand-fiscal__section {
display: flex;
flex-direction: column;
gap: 1rem;
}
.admin-stand-fiscal__section-title {
font-size: 0.95rem;
font-weight: 700;
color: var(--text-primary);
margin: 0;
padding-bottom: 0.5rem;
border-bottom: 1px solid var(--border-color);
}
/* ── Card de acción ── */
.admin-stand-fiscal__card {
background: var(--surface-background);
border: 1px solid var(--border-color);
border-radius: 8px;
padding: 1rem;
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.admin-stand-fiscal__card--email {
border-color: var(--accent-border, var(--border-color));
}
.admin-stand-fiscal__card-header {
display: flex;
flex-direction: column;
gap: 0.15rem;
}
.admin-stand-fiscal__card-title {
font-size: 0.9rem;
font-weight: 600;
color: var(--text-primary);
}
.admin-stand-fiscal__card-desc {
font-size: 0.78rem;
color: var(--text-secondary);
}
.admin-stand-fiscal__form-row {
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.admin-stand-fiscal__card-actions {
display: flex;
align-items: center;
gap: 0.75rem;
flex-wrap: wrap;
}
/* ── Links PDF/XML ── */
.admin-stand-fiscal__link {
font-size: 0.82rem;
font-weight: 600;
color: var(--accent-foreground, var(--text-primary));
text-decoration: underline;
cursor: pointer;
}
.admin-stand-fiscal__link:hover {
color: var(--primary-foreground);
}
/* ── Mensajes ── */
.admin-stand-fiscal__message {
font-size: 0.85rem;
padding: 0.6rem 0.875rem;
border-radius: 6px;
border: 1px solid transparent;
}
.admin-stand-fiscal__message--success {
background: var(--success-background);
color: var(--success-foreground);
border-color: var(--success-border, transparent);
}
.admin-stand-fiscal__message--error {
background: var(--danger-background);
color: var(--danger-foreground);
border-color: var(--danger-border, transparent);
}
/* ── Fila de confirmación ── */
.admin-stand-fiscal__confirmation-row {
display: flex;
justify-content: flex-end;
padding-top: 0.5rem;
border-top: 1px solid var(--border-color);
}
/* ── Responsive ── */
@media (max-width: 600px) {
.admin-stand-fiscal__panel {
width: 100vw;
height: 100dvh;
max-height: 100dvh;
border-radius: 0;
top: 0;
left: 0;
transform: none;
}
.admin-stand-fiscal__header {
flex-wrap: wrap;
}
}
/* ================================================
admin-stand-detail — BEM
================================================ */
.admin-stand-detail__overlay {
position: fixed;
inset: 0;
background: rgba(0, 0, 0, 0.45);
z-index: 1200;
}
.admin-stand-detail__panel {
position: fixed;
top: 0;
right: 0;
bottom: 0;
width: 100%;
max-width: 500px;
background: var(--surface-background);
display: flex;
flex-direction: column;
z-index: 1201;
box-shadow: -4px 0 32px rgba(0, 0, 0, 0.18);
overflow: hidden;
}
.admin-stand-detail__header {
display: flex;
align-items: center;
justify-content: space-between;
padding: 1rem 1.25rem;
border-bottom: 1px solid var(--border-color);
background: var(--surface-secondary-background);
flex-shrink: 0;
}
.admin-stand-detail__title {
font-size: 1rem;
font-weight: 700;
color: var(--text-primary);
}
.admin-stand-detail__close {
background: none;
border: none;
cursor: pointer;
color: var(--text-secondary);
padding: 0.25rem;
border-radius: 0.3rem;
display: flex;
align-items: center;
transition: background 0.15s;
}
.admin-stand-detail__close:hover {
background: var(--hover-background);
color: var(--text-primary);
}
.admin-stand-detail__close svg {
width: 20px;
height: 20px;
}
.admin-stand-detail__body {
flex: 1;
overflow-y: auto;
padding: 1.25rem;
display: flex;
flex-direction: column;
gap: 1rem;
}
.admin-stand-detail__section {
border: 1px solid var(--border-color);
border-radius: 0.5rem;
padding: 0.85rem;
background: var(--surface-secondary-background);
}
.admin-stand-detail__section-title {
font-size: 0.78rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.06em;
color: var(--accent-color);
margin: 0 0 0.75rem;
}
.admin-stand-detail__dl {
display: grid;
grid-template-columns: auto 1fr;
gap: 0.3rem 0.75rem;
margin: 0;
font-size: 0.85rem;
}
.admin-stand-detail__dl dt {
color: var(--text-secondary);
font-weight: 600;
white-space: nowrap;
}
.admin-stand-detail__dl dd {
color: var(--text-primary);
margin: 0;
word-break: break-word;
}
.admin-stand-detail__badge {
display: inline-block;
padding: 0.15em 0.5em;
border-radius: 0.3rem;
font-size: 0.72rem;
font-weight: 700;
text-transform: uppercase;
}
.admin-stand-detail__badge--pending_approval { background: var(--warning-background); color: var(--warning-foreground); }
.admin-stand-detail__badge--active { background: var(--success-background); color: var(--success-foreground); }
.admin-stand-detail__badge--inactive { background: var(--muted-background); color: var(--muted-foreground); }
.admin-stand-detail__badge--cancelled { background: var(--danger-background); color: var(--danger-foreground); }
.admin-stand-detail__footer {
display: flex;
align-items: center;
justify-content: flex-end;
gap: 0.5rem;
flex-wrap: wrap;
padding: 0.85rem 1.25rem;
border-top: 1px solid var(--border-color);
background: var(--surface-secondary-background);
flex-shrink: 0;
}
/* ================================================
admin-inactivate-stand — BEM
================================================ */
.admin-inactivate-stand__overlay {
position: fixed;
inset: 0;
background: rgba(0, 0, 0, 0.5);
z-index: 1200;
}
.admin-inactivate-stand__panel {
position: fixed;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
width: 95%;
max-width: 480px;
background: var(--surface-background);
border-radius: 0.75rem;
display: flex;
flex-direction: column;
z-index: 1201;
box-shadow: 0 8px 40px rgba(0, 0, 0, 0.22);
overflow: hidden;
}
.admin-inactivate-stand__header {
display: flex;
align-items: center;
justify-content: space-between;
padding: 1rem 1.25rem;
border-bottom: 1px solid var(--border-color);
background: var(--surface-secondary-background);
flex-shrink: 0;
}
.admin-inactivate-stand__title {
font-size: 1rem;
font-weight: 700;
color: var(--text-primary);
}
.admin-inactivate-stand__close {
background: none;
border: none;
cursor: pointer;
color: var(--text-secondary);
padding: 0.25rem;
border-radius: 0.3rem;
display: flex;
align-items: center;
transition: background 0.15s;
}
.admin-inactivate-stand__close:hover {
background: var(--hover-background);
color: var(--text-primary);
}
.admin-inactivate-stand__close svg {
width: 20px;
height: 20px;
}
.admin-inactivate-stand__body {
padding: 1.25rem;
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.admin-inactivate-stand__warning {
font-size: 0.9rem;
color: var(--text-primary);
background: var(--warning-background);
color: var(--warning-foreground);
padding: 0.65rem 0.85rem;
border-radius: 0.4rem;
}
.admin-inactivate-stand__form-group {
display: flex;
flex-direction: column;
gap: 0.3rem;
}
.admin-inactivate-stand__label {
font-size: 0.8rem;
font-weight: 600;
color: var(--text-secondary);
}
.admin-inactivate-stand__error {
color: var(--danger-foreground);
background: var(--danger-background);
padding: 0.5rem 0.75rem;
border-radius: 0.4rem;
font-size: 0.85rem;
}
.admin-inactivate-stand__footer {
display: flex;
align-items: center;
justify-content: flex-end;
gap: 0.5rem;
padding: 0.85rem 1.25rem;
border-top: 1px solid var(--border-color);
background: var(--surface-secondary-background);
flex-shrink: 0;
}
@media (max-width: 500px) {
.admin-inactivate-stand__panel {
width: 100%;
max-height: 100vh;
border-radius: 0;
}
}
/* ================================================
app-stand-badges — BEM
Panel lateral modal autónomo de gafetes de stand
================================================ */
.app-stand-badges__overlay {
position: fixed;
inset: 0;
background: rgba(0, 0, 0, 0.45);
z-index: 1100;
}
.app-stand-badges__panel {
position: fixed;
top: 0;
right: 0;
bottom: 0;
width: 100%;
max-width: 860px;
background: var(--surface-background);
display: flex;
flex-direction: column;
z-index: 1101;
box-shadow: -4px 0 32px rgba(0, 0, 0, 0.18);
overflow: hidden;
}
/* Header */
.app-stand-badges__header {
display: flex;
align-items: center;
justify-content: space-between;
padding: 1rem 1.25rem;
border-bottom: 1px solid var(--border-color);
background: var(--surface-secondary-background);
flex-shrink: 0;
}
.app-stand-badges__header-info {
display: flex;
flex-direction: column;
gap: 0.15rem;
}
.app-stand-badges__title {
font-size: 1.05rem;
font-weight: 700;
color: var(--text-primary);
}
.app-stand-badges__subtitle {
font-size: 0.82rem;
color: var(--text-secondary);
}
.app-stand-badges__close {
background: none;
border: none;
cursor: pointer;
color: var(--text-secondary);
padding: 0.25rem;
border-radius: 0.3rem;
display: flex;
align-items: center;
justify-content: center;
transition: background 0.15s;
}
.app-stand-badges__close:hover {
background: var(--hover-background);
color: var(--text-primary);
}
.app-stand-badges__close svg {
width: 20px;
height: 20px;
}
/* Body */
.app-stand-badges__body {
flex: 1;
overflow-y: auto;
padding: 1rem 1.25rem;
display: flex;
flex-direction: column;
gap: 1rem;
}
/* Toolbar */
.app-stand-badges__toolbar {
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: 0.5rem;
}
.app-stand-badges__toolbar-left {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
}
.app-stand-badges__count {
font-size: 0.82rem;
color: var(--text-secondary);
}
/* Empty */
.app-stand-badges__empty {
text-align: center;
padding: 2rem;
color: var(--text-secondary);
font-size: 0.9rem;
}
/* Status badges */
.app-stand-badges__badge {
display: inline-block;
padding: 0.18em 0.6em;
border-radius: 0.35rem;
font-size: 0.72rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.03em;
}
.app-stand-badges__badge--active {
background: var(--success-background);
color: var(--success-foreground);
}
.app-stand-badges__badge--cancelled {
background: var(--danger-background);
color: var(--danger-foreground);
}
.app-stand-badges__printed {
font-size: 0.72rem;
color: var(--success-foreground);
margin-left: 0.35rem;
}
/* Row actions */
.app-stand-badges__row-actions {
display: flex;
gap: 0.25rem;
align-items: center;
}
/* Modal forms */
.app-stand-badges__modal-text {
font-size: 0.9rem;
color: var(--text-primary);
margin-bottom: 0.75rem;
}
.app-stand-badges__form-group {
display: flex;
flex-direction: column;
gap: 0.3rem;
margin-bottom: 0.75rem;
}
.app-stand-badges__form-row {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 0.75rem;
}
.app-stand-badges__label {
font-size: 0.8rem;
font-weight: 600;
color: var(--text-secondary);
}
.app-stand-badges__select {
width: 100%;
padding: 0.45rem 0.65rem;
border: 1px solid var(--border-color);
border-radius: 0.4rem;
background: var(--input-background);
color: var(--text-primary);
font-size: 0.88rem;
outline: none;
transition: border-color 0.15s;
}
.app-stand-badges__select:focus {
border-color: var(--accent-color);
}
/* Responsivo */
@media (max-width: 900px) {
.app-stand-badges__panel {
max-width: 100%;
}
}
@media (max-width: 480px) {
.app-stand-badges__form-row {
grid-template-columns: 1fr;
}
}
/* ============================================================
AppCategoryDynamicFields â€” BEM namespace: cat-dyn-fields
Campos dinÃ¡micos adicionales por categorÃ­a en el registro.
============================================================ */
.cat-dyn-fields {
margin-top: 1.25rem;
border: 1px solid var(--border-color);
border-radius: 10px;
overflow: hidden;
background: var(--card-background);
}
/* Header */
.cat-dyn-fields__header {
display: flex;
align-items: center;
gap: 0.6rem;
padding: 0.75rem 1rem;
background: var(--accent-background);
border-bottom: 1px solid var(--border-color);
}
.cat-dyn-fields__header-icon {
color: var(--accent-foreground);
flex-shrink: 0;
}
.cat-dyn-fields__header-title {
font-size: 0.875rem;
font-weight: 600;
color: var(--accent-foreground);
}
/* Fields container */
.cat-dyn-fields__fields {
display: flex;
flex-direction: column;
gap: 1rem;
padding: 1rem;
}
/* Individual field */
.cat-dyn-fields__field {
display: flex;
flex-direction: column;
gap: 0.35rem;
}
/* Label */
.cat-dyn-fields__label {
font-size: 0.85rem;
font-weight: 500;
color: var(--foreground);
}
.cat-dyn-fields__required {
color: var(--danger-foreground);
margin-left: 0.2rem;
}
/* Inputs */
.cat-dyn-fields__input {
width: 100%;
padding: 0.5rem 0.75rem;
border: 1px solid var(--border-color);
border-radius: 6px;
background: var(--input-background);
color: var(--foreground);
font-size: 0.9rem;
transition: border-color 0.15s ease, box-shadow 0.15s ease;
box-sizing: border-box;
}
.cat-dyn-fields__input:focus {
outline: none;
border-color: var(--primary-color);
box-shadow: 0 0 0 2px var(--primary-shadow);
}
.cat-dyn-fields__input--select {
cursor: pointer;
}
.cat-dyn-fields__input--invalid {
border-color: var(--danger-foreground);
}
.cat-dyn-fields__input--invalid:focus {
border-color: var(--danger-foreground);
box-shadow: 0 0 0 2px var(--danger-shadow);
}
/* Error message */
.cat-dyn-fields__error-msg {
font-size: 0.78rem;
color: var(--danger-foreground);
}
/* Field in error state */
.cat-dyn-fields__field--error .cat-dyn-fields__label {
color: var(--danger-foreground);
}
/* Responsive */
@media (min-width: 640px) {
.cat-dyn-fields__fields {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 1rem;
}
/* Campos de tipo textarea o que ocupen ancho completo */
.cat-dyn-fields__field--full {
grid-column: 1 / -1;
}
}
@media (min-width: 1024px) {
.cat-dyn-fields__fields {
grid-template-columns: repeat(3, 1fr);
}
}
/* ============================================================
AppCategoryFieldsEditor â€” BEM namespace: cat-fields-editor
Editor admin de campos dinÃ¡micos por categorÃ­a.
============================================================ */
.cat-fields-editor {
border: 1px solid var(--border-color);
border-radius: 8px;
overflow: hidden;
background: var(--card-background);
margin-top: 0.75rem;
}
/* Header */
.cat-fields-editor__header {
display: flex;
align-items: center;
justify-content: space-between;
gap: 0.75rem;
padding: 0.6rem 0.85rem;
background: var(--surface-background);
border-bottom: 1px solid var(--border-color);
}
.cat-fields-editor__title {
font-size: 0.82rem;
font-weight: 600;
color: var(--foreground);
text-transform: uppercase;
letter-spacing: 0.04em;
}
.cat-fields-editor__header-actions {
display: flex;
gap: 0.4rem;
align-items: center;
}
.cat-fields-editor__btn-refresh {
font-size: 1rem;
padding: 0.2rem 0.5rem;
}
/* Estados vacÃ­os / error */
.cat-fields-editor__empty,
.cat-fields-editor__no-perm,
.cat-fields-editor__error {
padding: 0.75rem 1rem;
font-size: 0.85rem;
color: var(--muted-foreground);
}
.cat-fields-editor__error {
color: var(--danger-foreground);
}
.cat-fields-editor__spinner {
padding: 1rem;
display: flex;
justify-content: center;
}
/* Lista de campos */
.cat-fields-editor__list {
display: flex;
flex-direction: column;
gap: 0;
}
/* Item */
.cat-fields-editor__item {
display: flex;
align-items: center;
justify-content: space-between;
gap: 0.75rem;
padding: 0.6rem 0.85rem;
border-bottom: 1px solid var(--border-color);
transition: background 0.12s;
}
.cat-fields-editor__item:last-child {
border-bottom: none;
}
.cat-fields-editor__item:hover {
background: var(--hover-background);
}
.cat-fields-editor__item--inactive {
opacity: 0.55;
}
.cat-fields-editor__item-info {
display: flex;
flex-direction: column;
gap: 0.15rem;
min-width: 0;
}
.cat-fields-editor__item-top {
display: flex;
align-items: center;
gap: 0.4rem;
flex-wrap: wrap;
}
.cat-fields-editor__item-label {
font-size: 0.9rem;
font-weight: 500;
color: var(--foreground);
}
.cat-fields-editor__item-slug {
font-size: 0.75rem;
color: var(--muted-foreground);
font-family: monospace;
}
/* Badges */
.cat-fields-editor__badge {
font-size: 0.68rem;
font-weight: 600;
padding: 0.1rem 0.45rem;
border-radius: var(--radius-pill);
background: var(--surface-background);
color: var(--muted-foreground);
border: 1px solid var(--border-color);
white-space: nowrap;
}
.cat-fields-editor__badge--required {
background: var(--warning-background);
color: var(--warning-foreground);
border-color: var(--warning-foreground);
}
.cat-fields-editor__badge--inactive {
background: var(--danger-background);
color: var(--danger-foreground);
border-color: var(--danger-foreground);
}
/* Acciones del item */
.cat-fields-editor__item-actions {
display: flex;
align-items: center;
gap: 0.35rem;
flex-shrink: 0;
}
.cat-fields-editor__btn-order {
padding: 0.2rem 0.45rem;
font-size: 0.85rem;
min-width: 2rem;
}
/* ==================== FORMULARIO (modal) ==================== */
.cat-fields-editor__form {
display: flex;
flex-direction: column;
gap: 0.85rem;
padding: 0.25rem 0;
}
.cat-fields-editor__form-error {
padding: 0.6rem 0.85rem;
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: 6px;
font-size: 0.85rem;
}
.cat-fields-editor__form-row {
display: flex;
flex-direction: column;
gap: 0.75rem;
}
@media (min-width: 540px) {
.cat-fields-editor__form-row--2col {
flex-direction: row;
}
.cat-fields-editor__form-row--3col {
flex-direction: row;
}
.cat-fields-editor__form-row--2col > * {
flex: 1;
}
.cat-fields-editor__form-row--3col > * {
flex: 1;
}
}
.cat-fields-editor__form-field {
display: flex;
flex-direction: column;
gap: 0.3rem;
}
.cat-fields-editor__form-label {
font-size: 0.82rem;
font-weight: 500;
color: var(--foreground);
}
.cat-fields-editor__hint {
font-size: 0.75rem;
font-weight: 400;
color: var(--muted-foreground);
margin-left: 0.35rem;
}
.cat-fields-editor__req {
color: var(--danger-foreground);
margin-left: 0.15rem;
}
.cat-fields-editor__input {
width: 100%;
padding: 0.45rem 0.65rem;
border: 1px solid var(--border-color);
border-radius: 6px;
background: var(--input-background);
color: var(--foreground);
font-size: 0.88rem;
box-sizing: border-box;
transition: border-color 0.15s;
}
.cat-fields-editor__input:focus {
outline: none;
border-color: var(--primary-color);
box-shadow: 0 0 0 2px var(--primary-shadow);
}
.cat-fields-editor__input--mono {
font-family: monospace;
font-size: 0.82rem;
}
.cat-fields-editor__textarea {
resize: vertical;
min-height: 5rem;
}
/* Checkboxes */
.cat-fields-editor__form-checks {
display: flex;
gap: 1.25rem;
flex-wrap: wrap;
}
.cat-fields-editor__check-label {
display: flex;
align-items: center;
gap: 0.45rem;
font-size: 0.88rem;
cursor: pointer;
color: var(--foreground);
user-select: none;
}
/* ConfirmaciÃ³n */
.cat-fields-editor__confirm-text {
font-size: 0.9rem;
color: var(--foreground);
line-height: 1.5;
}
/* ============================================================
AppContentCard — BEM: cnt-card
Tarjeta de ítem del programa: session / break / label.
Los colores BgColor/TextColor/Color son data-driven (del evento),
se aplican como style="" según las reglas del proyecto.
============================================================ */
/* ── label (título de sección / separador) ── */
.cnt-card--label {
padding: 0.5rem 1rem;
border-radius: 6px;
font-size: 0.8rem;
font-weight: 700;
letter-spacing: 0.07em;
text-transform: uppercase;
margin-bottom: 0.25rem;
}
.cnt-card__label-text {
display: block;
}
/* ── break (receso, café, comida) ── */
.cnt-card--break {
display: flex;
align-items: center;
gap: 0.6rem;
padding: 0.55rem 1rem;
border-radius: 6px;
font-size: 0.82rem;
opacity: 0.85;
margin: 0.1rem 0;
}
.cnt-card__break-icon {
font-size: 1rem;
flex-shrink: 0;
}
.cnt-card__break-title {
font-weight: 500;
flex: 1;
}
.cnt-card__break-duration {
font-size: 0.75rem;
opacity: 0.75;
white-space: nowrap;
}
/* ── session (ponencia) ── */
.cnt-card--session {
display: flex;
gap: 0.75rem;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-left: 4px solid var(--primary-color); /* color data-driven override */
border-radius: 0 8px 8px 0;
padding: 0.9rem 1rem;
margin: 0.35rem 0;
box-shadow: var(--shadow-xs);
transition: box-shadow 0.15s;
}
.cnt-card--session:hover {
box-shadow: var(--shadow-sm);
}
/* Franja de hora (lateral izquierdo) */
.cnt-card__time {
display: flex;
flex-direction: column;
align-items: center;
justify-content: flex-start;
min-width: 52px;
flex-shrink: 0;
gap: 0.1rem;
padding-top: 0.1rem;
}
.cnt-card__time-start {
font-size: 0.95rem;
font-weight: 700;
color: var(--primary-color);
letter-spacing: -0.01em;
}
.cnt-card__time-duration {
font-size: 0.65rem;
color: var(--text-muted);
white-space: nowrap;
}
/* Cuerpo de la tarjeta */
.cnt-card__body {
display: flex;
flex-direction: column;
gap: 0.45rem;
flex: 1;
min-width: 0;
}
.cnt-card__img {
width: 100%;
max-height: 140px;
object-fit: cover;
border-radius: 6px;
margin-bottom: 0.25rem;
}
.cnt-card__title {
font-size: 1rem;
font-weight: 600;
color: var(--text-color);
margin: 0;
line-height: 1.35;
}
.cnt-card__desc {
font-size: 0.83rem;
color: var(--text-secondary);
margin: 0;
line-height: 1.5;
display: -webkit-box;
-webkit-line-clamp: 3;
-webkit-box-orient: vertical;
overflow: hidden;
}
.cnt-card__speakers {
display: flex;
flex-wrap: wrap;
gap: 0.6rem;
margin-top: 0.1rem;
}
.cnt-card__video-badge {
display: inline-flex;
align-items: center;
gap: 0.3rem;
font-size: 0.7rem;
font-weight: 600;
color: var(--success-foreground);
background: var(--success-background);
border: 1px solid var(--success-color);
border-radius: 999px;
padding: 0.15rem 0.6rem;
width: fit-content;
}
/* ── Responsive ── */
@media (max-width: 540px) {
.cnt-card--session {
flex-direction: column;
gap: 0.5rem;
}
.cnt-card__time {
flex-direction: row;
min-width: unset;
gap: 0.4rem;
}
}
/* AppEventLive — BEM namespace: app-event-live */
/* ── Contenedor raíz del player ───────────────────────────────────────────── */
.app-event-live {
position: relative;
width: 100%;
background: #000;
border-radius: var(--radius-md);
overflow: hidden;
/* Borde superior acento degradado */
box-shadow:
inset 0 1px 0 color-mix(in srgb, var(--primary-color) 40%, transparent),
0 0 0 1px color-mix(in srgb, var(--primary-color) 15%, transparent),
var(--shadow-md);
}
/* Línea de acento superior (futurista) */
.app-event-live::before {
content: '';
position: absolute;
inset: 0 0 auto 0;
height: 2px;
background: var(--gradient-tricolor);
z-index: 1;
opacity: 0.85;
}
/* ── Aspect-ratio 16:9 para iframe y video ───────────────────────────────── */
.app-event-live__iframe,
.app-event-live__video {
display: block;
width: 100%;
aspect-ratio: 16 / 9;
border: none;
background: #000;
border-radius: var(--radius-md);
}
/* Safari fallback — aspect-ratio no soportado en versiones antiguas */
@supports not (aspect-ratio: 16 / 9) {
.app-event-live {
padding-top: 56.25%; /* 9/16 */
}
.app-event-live__iframe,
.app-event-live__video {
position: absolute;
inset: 0;
height: 100%;
}
}
/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 640px) {
.app-event-live {
border-radius: 0;
}
.app-event-live::before {
display: none;
}
.app-event-live__iframe,
.app-event-live__video {
border-radius: 0;
}
}
/* ============================================================
AppEventProgram â€” BEM: evt-prog
Programa acadÃ©mico pÃºblico. Incluye estilos de impresiÃ³n.
============================================================ */
.evt-prog {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
/* â”€â”€ Cabecera â”€â”€ */
.evt-prog__header {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;
flex-wrap: wrap;
}
.evt-prog__meta {
font-size: 0.8rem;
color: var(--text-muted);
}
.evt-prog__header-actions {
display: flex;
gap: 0.5rem;
align-items: center;
}
.evt-prog__btn-print {
font-size: 0.82rem;
gap: 0.35rem;
}
.evt-prog__btn-refresh {
font-size: 1.1rem;
padding: 0.2rem 0.5rem;
}
/* â”€â”€ Estados â”€â”€ */
.evt-prog__loading {
display: flex;
justify-content: center;
padding: 2rem;
}
.evt-prog__error {
display: flex;
flex-direction: column;
align-items: flex-start;
gap: 0.75rem;
padding: 1rem;
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: 8px;
font-size: 0.88rem;
}
.evt-prog__empty {
text-align: center;
padding: 2.5rem 1rem;
color: var(--text-muted);
font-size: 0.9rem;
}
/* â”€â”€ DÃ­as â”€â”€ */
.evt-prog__day {
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.evt-prog__day-label {
font-size: 1.05rem;
font-weight: 700;
color: var(--text-color);
text-transform: capitalize;
padding: 0.4rem 0;
border-bottom: 2px solid var(--primary-color);
margin: 0 0 0.5rem;
}
.evt-prog__day-label--undated {
color: var(--text-muted);
border-bottom-color: var(--border-color);
font-style: italic;
font-weight: 400;
}
.evt-prog__items {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
/* â”€â”€ Cabecera solo para impresiÃ³n â”€â”€ */
.evt-prog__print-header {
display: none;
}
/* ================================================================
ESTILOS DE IMPRESIÃ“N (@media print)
DiseÃ±o limpio tipo agenda para guardar como PDF.
================================================================ */
@media print {
/* Mostrar solo el programa */
body > * {
display: none !important;
}
.evt-prog {
display: block !important;
}
/* Cabecera de impresiÃ³n visible */
.evt-prog__print-header {
display: block;
text-align: center;
margin-bottom: 1.5rem;
padding-bottom: 0.75rem;
border-bottom: 2px solid #1945a8;
}
.evt-prog__print-title {
font-size: 1.4rem;
font-weight: 800;
color: #1945a8;
margin: 0;
letter-spacing: 0.05em;
}
/* Ocultar controles UI */
.evt-prog__header,
.evt-prog__loading,
.evt-prog__error {
display: none !important;
}
/* DÃ­as */
.evt-prog__day {
page-break-inside: avoid;
margin-bottom: 1.2rem;
}
.evt-prog__day-label {
font-size: 1rem;
font-weight: 700;
color: #1945a8;
border-bottom: 1.5px solid #1945a8;
padding-bottom: 0.25rem;
margin-bottom: 0.5rem;
text-transform: capitalize;
}
/* Tarjetas en impresiÃ³n */
.cnt-card--session {
border: none;
border-left: 3px solid #1945a8;
box-shadow: none;
padding: 0.5rem 0.75rem;
margin: 0.2rem 0;
page-break-inside: avoid;
}
.cnt-card--label {
background: #1945a8 !important;
color: #ffffff !important;
padding: 0.3rem 0.6rem;
font-size: 0.72rem;
}
.cnt-card--break {
opacity: 0.65;
font-size: 0.76rem;
padding: 0.25rem 0.6rem;
}
.cnt-card__img {
display: none;
}
.cnt-card__desc {
-webkit-line-clamp: 2;
}
.cnt-card__title {
font-size: 0.9rem;
}
.cnt-card__time-start {
color: #1945a8;
}
.spk-chip__photo,
.spk-chip__avatar {
display: none;
}
.spk-chip__name {
font-size: 0.72rem;
}
}
/* ================================================================
TABS DE DÃA
================================================================ */
.evt-prog__day-tabs {
display: flex;
gap: 0;
overflow-x: auto;
border-bottom: 2px solid var(--border-color);
scrollbar-width: none;
-ms-overflow-style: none;
}
.evt-prog__day-tabs::-webkit-scrollbar { display: none; }
.evt-prog__day-tab {
flex-shrink: 0;
padding: 0.5rem 1rem;
font-size: 0.8rem;
font-weight: 500;
color: var(--text-muted);
background: none;
border: none;
border-bottom: 2px solid transparent;
margin-bottom: -2px;
cursor: pointer;
transition: color 0.15s, border-color 0.15s;
white-space: nowrap;
text-transform: capitalize;
}
.evt-prog__day-tab:hover { color: var(--primary-color); }
.evt-prog__day-tab--active {
color: var(--primary-color);
border-bottom-color: var(--primary-color);
font-weight: 700;
}
/* ================================================================
CHIPS DE BUNDLE / TRACK
================================================================ */
.evt-prog__bundle-bar {
display: flex;
gap: 0.4rem;
overflow-x: auto;
flex-wrap: nowrap;
padding-bottom: 0.25rem;
scrollbar-width: none;
-ms-overflow-style: none;
}
.evt-prog__bundle-bar::-webkit-scrollbar { display: none; }
.evt-prog__bundle-chip {
display: inline-flex;
align-items: center;
gap: 0.35rem;
flex-shrink: 0;
padding: 0.3rem 0.75rem;
font-size: 0.78rem;
font-weight: 500;
color: var(--text-muted);
background: var(--secondary-background);
border: 1.5px solid var(--border-color);
border-radius: var(--radius-pill);
cursor: pointer;
transition: background 0.15s, color 0.15s, border-color 0.15s;
white-space: nowrap;
}
.evt-prog__bundle-chip:hover {
background: var(--hover-background-color);
color: var(--text-color);
border-color: var(--primary-color);
}
.evt-prog__bundle-chip--active {
background: var(--primary-color);
color: var(--primary-foreground, #fff);
border-color: var(--primary-color);
font-weight: 700;
}
.evt-prog__bundle-count {
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 18px;
height: 18px;
padding: 0 4px;
font-size: 0.68rem;
font-weight: 700;
background: rgba(0, 0, 0, 0.15);
border-radius: var(--radius-pill);
}
.evt-prog__bundle-chip--active .evt-prog__bundle-count {
background: rgba(255, 255, 255, 0.25);
}
/* ================================================================
PANEL DE VIDEOS â€” overlay + panel
================================================================ */
.evt-prog__video-overlay {
position: fixed;
inset: 0;
background: rgba(0, 0, 0, 0.55);
display: flex;
align-items: flex-end;
justify-content: center;
z-index: 1200;
padding: 0;
backdrop-filter: blur(2px);
}
@media (min-width: 640px) {
.evt-prog__video-overlay {
align-items: center;
}
}
.evt-prog__video-panel {
background: var(--card-background-color, var(--surface-color));
border-radius: 16px 16px 0 0;
width: 100%;
max-width: 700px;
max-height: 90vh;
overflow-y: auto;
padding: 1.25rem;
display: flex;
flex-direction: column;
gap: 1rem;
box-shadow: 0 -4px 32px rgba(0, 0, 0, 0.2);
}
@media (min-width: 640px) {
.evt-prog__video-panel {
border-radius: 16px;
max-height: 80vh;
}
}
.evt-prog__video-panel-header {
display: flex;
align-items: flex-start;
justify-content: space-between;
gap: 0.75rem;
}
.evt-prog__video-panel-title {
font-size: 0.95rem;
font-weight: 700;
color: var(--text-color);
line-height: 1.3;
flex: 1;
}
.evt-prog__video-panel-close {
flex-shrink: 0;
width: 28px;
height: 28px;
border-radius: 50%;
border: none;
background: var(--secondary-background);
color: var(--text-muted);
font-size: 0.85rem;
cursor: pointer;
display: flex;
align-items: center;
justify-content: center;
transition: background 0.15s, color 0.15s;
}
.evt-prog__video-panel-close:hover {
background: var(--danger-background);
color: var(--danger-foreground);
}
.evt-prog__video-empty {
font-size: 0.84rem;
color: var(--text-muted);
margin: 0;
text-align: center;
padding: 1rem 0;
}
.evt-prog__video-list {
list-style: none;
padding: 0;
margin: 0;
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.evt-prog__video-item {
display: flex;
flex-direction: column;
gap: 0.3rem;
}
.evt-prog__video-player {
width: 100%;
border-radius: 8px;
background: #000;
max-height: 320px;
}
.evt-prog__video-label {
font-size: 0.75rem;
color: var(--text-muted);
text-align: center;
}
.evt-prog__video-link {
display: inline-flex;
align-items: center;
gap: 0.5rem;
padding: 0.65rem 1rem;
background: var(--secondary-background);
border: 1.5px solid var(--border-color);
border-radius: 8px;
color: var(--primary-color);
font-size: 0.85rem;
font-weight: 600;
text-decoration: none;
transition: background 0.15s, border-color 0.15s;
}
.evt-prog__video-link:hover {
background: var(--hover-background-color);
border-color: var(--primary-color);
}
.evt-prog__video-icon {
font-size: 1rem;
}
/* Ocultar overlay en impresiÃ³n */
@media print {
.evt-prog__video-overlay,
.evt-prog__day-tabs,
.evt-prog__bundle-bar { display: none !important; }
}
/* ============================================================
AppSpeakerChip â€” BEM: spk-chip
Chip compacto de ponente: foto/avatar + nombre + rol + org.
============================================================ */
.spk-chip {
display: flex;
align-items: center;
gap: 0.5rem;
}
/* TamaÃ±o md (default) */
.spk-chip--md .spk-chip__photo,
.spk-chip--md .spk-chip__avatar {
width: 36px;
height: 36px;
font-size: 0.9rem;
}
/* TamaÃ±o sm */
.spk-chip--sm .spk-chip__photo,
.spk-chip--sm .spk-chip__avatar {
width: 28px;
height: 28px;
font-size: 0.75rem;
}
.spk-chip__photo {
border-radius: 50%;
object-fit: cover;
flex-shrink: 0;
border: 2px solid var(--border-color);
background: var(--card-category-bg-color);
}
.spk-chip__avatar {
border-radius: 50%;
flex-shrink: 0;
background: var(--primary-color);
color: var(--primary-foreground);
display: flex;
align-items: center;
justify-content: center;
font-weight: 700;
border: 2px solid var(--border-color);
}
.spk-chip__info {
display: flex;
flex-direction: column;
gap: 0.05rem;
min-width: 0;
}
.spk-chip__name {
font-size: 0.82rem;
font-weight: 600;
color: var(--text-color);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.spk-chip--sm .spk-chip__name {
font-size: 0.76rem;
}
.spk-chip__role {
font-size: 0.7rem;
color: var(--text-muted);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.spk-chip__org {
font-size: 0.68rem;
color: var(--text-secondary);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
/* ============================================
CfdiReissueWizard — BEM: cfdiReissueWizard
Wizard multi-paso para re-emisión de CFDI fallido
============================================ */
.cfdiReissueWizard {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
/* ==================== INDICADOR DE PASOS ==================== */
.cfdiReissueWizard__steps {
display: flex;
align-items: center;
gap: 0;
overflow-x: auto;
padding-bottom: 0.25rem;
}
.cfdiReissueWizard__step {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.3rem;
min-width: 80px;
}
.cfdiReissueWizard__step-num {
width: 2rem;
height: 2rem;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
font-size: 0.8rem;
font-weight: 700;
background: var(--border-color);
color: var(--text-muted);
transition: background 0.2s, color 0.2s;
}
.cfdiReissueWizard__step--active .cfdiReissueWizard__step-num {
background: var(--primary-color);
color: var(--primary-foreground, #fff);
}
.cfdiReissueWizard__step--done .cfdiReissueWizard__step-num {
background: var(--success-color);
color: #fff;
}
.cfdiReissueWizard__step-label {
font-size: 0.72rem;
color: var(--text-muted);
text-align: center;
white-space: nowrap;
}
.cfdiReissueWizard__step--active .cfdiReissueWizard__step-label {
color: var(--primary-color);
font-weight: 600;
}
.cfdiReissueWizard__step--done .cfdiReissueWizard__step-label {
color: var(--success-color);
}
.cfdiReissueWizard__step-connector {
flex: 1;
height: 2px;
background: var(--border-color);
margin-bottom: 1.4rem;
min-width: 16px;
transition: background 0.2s;
}
.cfdiReissueWizard__step-connector--done {
background: var(--success-color);
}
/* ==================== LOADING ==================== */
.cfdiReissueWizard__loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 0.75rem;
padding: 2.5rem 1rem;
text-align: center;
color: var(--text-muted);
min-height: 140px;
}
/* ==================== SECCIÓN ==================== */
.cfdiReissueWizard__section {
display: flex;
flex-direction: column;
gap: 1rem;
}
.cfdiReissueWizard__section-hint {
font-size: 0.875rem;
color: var(--text-muted);
margin: 0;
}
/* ==================== ITEM CARD ==================== */
.cfdiReissueWizard__item-card {
border: 1px solid var(--border-color);
border-radius: var(--border-radius);
padding: 1rem;
background: var(--surface-color);
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.cfdiReissueWizard__item-header {
display: flex;
justify-content: space-between;
align-items: baseline;
gap: 0.5rem;
}
.cfdiReissueWizard__item-desc {
font-weight: 600;
color: var(--text-color);
font-size: 0.9rem;
}
.cfdiReissueWizard__item-price {
font-weight: 700;
color: var(--primary-color);
font-size: 0.9rem;
white-space: nowrap;
}
.cfdiReissueWizard__item-fields {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 0.75rem;
}
@media (max-width: 540px) {
.cfdiReissueWizard__item-fields {
grid-template-columns: 1fr;
}
}
/* ==================== REISSUE FORM ==================== */
.cfdiReissueWizard__reissue-form {
max-width: 360px;
}
/* ==================== ÉXITO ==================== */
.cfdiReissueWizard__success {
padding: 1.25rem;
background: var(--success-background);
border-left: 4px solid var(--success-color);
border-radius: var(--border-radius);
display: flex;
flex-direction: column;
gap: 0.6rem;
}
.cfdiReissueWizard__success-title {
font-weight: 700;
color: var(--success-color);
font-size: 1rem;
margin: 0;
}
.cfdiReissueWizard__success-hint {
font-size: 0.875rem;
color: var(--text-color);
margin: 0.25rem 0 0;
}
.cfdiReissueWizard__result-row {
display: flex;
gap: 0.5rem;
font-size: 0.85rem;
}
.cfdiReissueWizard__result-label {
color: var(--text-muted);
font-weight: 600;
min-width: 50px;
}
.cfdiReissueWizard__result-value {
color: var(--text-color);
font-family: 'Courier New', monospace;
word-break: break-all;
}
.cfdiReissueWizard__success-actions {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
margin-top: 0.5rem;
}
.cfdiReissueWizard__email-sent {
font-size: 0.82rem;
color: var(--success-color);
font-weight: 600;
margin: 0;
}
/* ==================== ERROR ==================== */
.cfdiReissueWizard__error {
padding: 0.6rem 0.875rem;
background: var(--danger-background);
border-left: 3px solid var(--danger-color);
border-radius: var(--border-radius);
color: var(--danger-color);
font-size: 0.82rem;
margin: 0;
}
.cfdiReissueWizard__error-block {
padding: 1rem;
background: var(--danger-background);
border-left: 4px solid var(--danger-color);
border-radius: var(--border-radius);
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.cfdiReissueWizard__error-title {
font-weight: 700;
color: var(--danger-color);
margin: 0;
}
.cfdiReissueWizard__error-msg {
color: var(--text-color);
font-size: 0.875rem;
margin: 0;
}
/* ============================================
CreatePpdWizard — BEM: createPpdWizard
Wizard multi-paso para crear Factura PPD
============================================ */
.createPpdWizard {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
/* ==================== INDICADOR DE PASOS ==================== */
.createPpdWizard__steps {
display: flex;
align-items: center;
overflow-x: auto;
padding-bottom: 0.25rem;
gap: 0;
}
.createPpdWizard__step {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.3rem;
min-width: 90px;
flex-shrink: 0;
}
.createPpdWizard__step-num {
width: 2rem;
height: 2rem;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
font-size: 0.8rem;
font-weight: 700;
background: var(--border-color);
color: var(--text-muted);
transition: background 0.2s, color 0.2s;
}
.createPpdWizard__step--active .createPpdWizard__step-num {
background: var(--primary-color);
color: var(--primary-foreground, #fff);
}
.createPpdWizard__step--done .createPpdWizard__step-num {
background: var(--success-color);
color: #fff;
}
.createPpdWizard__step-label {
font-size: 0.72rem;
color: var(--text-muted);
text-align: center;
white-space: nowrap;
}
.createPpdWizard__step--active .createPpdWizard__step-label { color: var(--primary-color); font-weight: 600; }
.createPpdWizard__step--done  .createPpdWizard__step-label  { color: var(--success-color); }
.createPpdWizard__step-connector {
flex: 1;
height: 2px;
background: var(--border-color);
margin-bottom: 1.4rem;
min-width: 12px;
transition: background 0.2s;
}
.createPpdWizard__step-connector--done { background: var(--success-color); }
/* ==================== SECCIONES ==================== */
.createPpdWizard__section {
display: flex;
flex-direction: column;
gap: 1.25rem;
}
.createPpdWizard__section-hint {
font-size: 0.875rem;
color: var(--text-muted);
margin: 0;
}
.createPpdWizard__field-group {
display: flex;
flex-direction: column;
gap: 0.6rem;
}
.createPpdWizard__group-title {
font-size: 0.82rem;
font-weight: 700;
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: 0.5px;
margin: 0;
}
/* ==================== GRIDS ==================== */
.createPpdWizard__grid-2 {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 0.875rem;
}
@media (max-width: 600px) {
.createPpdWizard__grid-2 { grid-template-columns: 1fr; }
}
/* ==================== DIVISOR ==================== */
.createPpdWizard__divider {
display: flex;
align-items: center;
gap: 0.75rem;
color: var(--text-muted);
font-size: 0.78rem;
}
.createPpdWizard__divider::before,
.createPpdWizard__divider::after {
content: '';
flex: 1;
height: 1px;
background: var(--border-color);
}
/* ==================== ITEMS ==================== */
.createPpdWizard__items-header {
display: flex;
justify-content: space-between;
align-items: center;
}
.createPpdWizard__items-empty {
padding: 2rem;
text-align: center;
color: var(--text-muted);
border: 1px dashed var(--border-color);
border-radius: var(--border-radius);
font-size: 0.875rem;
}
.createPpdWizard__item-card {
border: 1px solid var(--border-color);
border-radius: var(--border-radius);
padding: 1rem;
background: var(--surface-color);
display: flex;
flex-direction: column;
gap: 0.875rem;
}
.createPpdWizard__item-card-header {
display: flex;
justify-content: space-between;
align-items: center;
}
.createPpdWizard__item-num {
font-size: 0.8rem;
font-weight: 700;
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: 0.4px;
}
.createPpdWizard__item-remove {
background: none;
border: none;
cursor: pointer;
color: var(--danger-color);
padding: 0.2rem;
display: flex;
align-items: center;
opacity: 0.7;
transition: opacity 0.15s;
}
.createPpdWizard__item-remove:hover { opacity: 1; }
.createPpdWizard__item-remove svg { width: 14px; height: 14px; }
.createPpdWizard__item-totals {
display: flex;
justify-content: flex-end;
gap: 0.5rem;
font-size: 0.85rem;
padding-top: 0.5rem;
border-top: 1px solid var(--border-color);
}
.createPpdWizard__item-total-label { color: var(--text-muted); font-weight: 600; }
.createPpdWizard__item-total-value { color: var(--text-color); font-weight: 700; }
.createPpdWizard__grand-total {
display: flex;
justify-content: flex-end;
gap: 0.75rem;
font-size: 1rem;
font-weight: 700;
padding: 0.75rem 1rem;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: var(--border-radius);
}
.createPpdWizard__grand-total-label { color: var(--text-muted); }
.createPpdWizard__grand-total-value { color: var(--primary-color); }
/* ==================== RESUMEN ==================== */
.createPpdWizard__summary {
display: flex;
flex-direction: column;
gap: 1rem;
}
.createPpdWizard__summary-block {
padding: 1rem;
border: 1px solid var(--border-color);
border-radius: var(--border-radius);
background: var(--surface-color);
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.createPpdWizard__summary-title {
font-size: 0.8rem;
font-weight: 700;
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: 0.4px;
margin: 0 0 0.25rem;
}
.createPpdWizard__summary-row {
display: flex;
gap: 0.5rem;
font-size: 0.85rem;
align-items: baseline;
}
.createPpdWizard__summary-row--total {
font-weight: 700;
font-size: 0.95rem;
margin-top: 0.25rem;
padding-top: 0.5rem;
border-top: 1px solid var(--border-color);
}
.createPpdWizard__summary-label {
color: var(--text-muted);
font-weight: 600;
min-width: 90px;
white-space: nowrap;
}
.createPpdWizard__summary-value { color: var(--text-color); word-break: break-word; }
.createPpdWizard__summary-item {
display: flex;
justify-content: space-between;
gap: 0.5rem;
font-size: 0.85rem;
padding: 0.25rem 0;
border-bottom: 1px solid var(--border-color);
}
.createPpdWizard__summary-item-desc { color: var(--text-color); }
.createPpdWizard__summary-item-price { color: var(--text-muted); white-space: nowrap; }
/* ==================== LOADING ==================== */
.createPpdWizard__loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 0.75rem;
padding: 3rem 1rem;
text-align: center;
color: var(--text-muted);
min-height: 180px;
}
.createPpdWizard__loading small { font-size: 0.78rem; }
/* ==================== RESULTADO ==================== */
.createPpdWizard__result-success {
padding: 1.25rem;
background: var(--success-background);
border-left: 4px solid var(--success-color);
border-radius: var(--border-radius);
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.createPpdWizard__result-title {
font-weight: 700;
color: var(--success-color);
font-size: 1rem;
margin: 0;
}
.createPpdWizard__result-grid {
display: flex;
flex-direction: column;
gap: 0.4rem;
}
.createPpdWizard__result-row {
display: flex;
gap: 0.5rem;
font-size: 0.875rem;
align-items: baseline;
}
.createPpdWizard__result-label {
color: var(--text-muted);
font-weight: 600;
min-width: 80px;
}
.createPpdWizard__result-value { color: var(--text-color); font-weight: 500; }
.createPpdWizard__result-uuid {
color: var(--text-color);
font-family: 'Courier New', monospace;
font-size: 0.78rem;
word-break: break-all;
}
.createPpdWizard__result-hint {
font-size: 0.875rem;
color: var(--text-muted);
margin: 0;
}
.createPpdWizard__result-email-sent {
font-weight: 700;
color: var(--success-color);
font-size: 0.85rem;
margin: 0;
}
.createPpdWizard__result-send-email { display: flex; }
.createPpdWizard__result-error {
padding: 1.25rem;
background: var(--danger-background);
border-left: 4px solid var(--danger-color);
border-radius: var(--border-radius);
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.createPpdWizard__result-error-title {
font-weight: 700;
color: var(--danger-color);
font-size: 1rem;
margin: 0;
}
.createPpdWizard__result-error-msg {
color: var(--text-color);
font-size: 0.875rem;
margin: 0;
}
/* ==================== ERROR INLINE ==================== */
.createPpdWizard__error {
padding: 0.6rem 0.875rem;
background: var(--danger-background);
border-left: 3px solid var(--danger-color);
border-radius: var(--border-radius);
color: var(--danger-color);
font-size: 0.82rem;
margin: 0;
}
/* ============================================
SendEmailCfdiModal — BEM: sendEmailCfdiModal
Modal para envío de CFDI por email
============================================ */
.sendEmailCfdiModal {
display: flex;
flex-direction: column;
gap: 1rem;
min-height: 100px;
}
/* ==================== LOADING ==================== */
.sendEmailCfdiModal__loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 0.75rem;
padding: 2rem 1rem;
text-align: center;
color: var(--text-muted);
}
/* ==================== ÉXITO ==================== */
.sendEmailCfdiModal__success {
padding: 1rem;
background: var(--success-background);
border-left: 3px solid var(--success-color);
border-radius: var(--border-radius);
display: flex;
flex-direction: column;
gap: 0.4rem;
}
.sendEmailCfdiModal__success-title {
font-weight: 700;
color: var(--success-color);
margin: 0;
}
.sendEmailCfdiModal__success-to {
color: var(--text-color);
font-size: 0.875rem;
margin: 0;
}
/* ==================== FORM ==================== */
.sendEmailCfdiModal__form {
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.sendEmailCfdiModal__info {
font-size: 0.875rem;
color: var(--text-muted);
margin: 0;
}
.sendEmailCfdiModal__error {
padding: 0.6rem 0.875rem;
background: var(--danger-background);
border-left: 3px solid var(--danger-color);
border-radius: var(--border-radius);
color: var(--danger-color);
font-size: 0.82rem;
margin: 0;
}
/* 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: var(--radius-sm);
cursor: pointer;
transition: all var(--transition-fast);
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: var(--z-modal-nested);
background: transparent;
}
/* Dropdown del menú - POSICIONAMIENTO ABSOLUTO RELATIVO AL CONTENEDOR */
.app-actions-menu__dropdown {
position: absolute;
top: calc(100% + 4px);
right: 0;
z-index: var(--z-modal-nested);
min-width: 200px;
max-width: 280px;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: var(--radius-md);
box-shadow: var(--shadow-lg), var(--shadow-glow);
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: var(--z-modal);
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: var(--radius-xl);
box-shadow: var(--shadow-xl), var(--shadow-glow);
max-width: 400px;
width: 100%;
max-height: 80vh;
overflow: hidden;
animation: slideUp 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
border: 1.5px 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: 1.125rem;
font-weight: 700;
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;
}
}
/* =======================================================================
NexEvent — AppButton
Botones con identidad tech-events: glow, gradiente, microanimaciones
======================================================================= */
.app-button {
font-family: inherit;
font-size: 0.875rem;
font-weight: 600;
line-height: 1.25rem;
padding: 0.65rem 1.35rem;
border-radius: var(--radius-md);
border: 1.5px solid transparent;
cursor: pointer;
transition: all var(--transition-base);
outline: none;
display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.5rem;
min-height: 2.75rem;
text-align: center;
white-space: nowrap;
user-select: none;
position: relative;
overflow: hidden;
letter-spacing: 0.01em;
isolation: isolate;
}
.app-button::after {
content: '';
position: absolute;
inset: 0;
background: linear-gradient(180deg, rgba(255,255,255,0.12) 0%, transparent 60%);
border-radius: inherit;
pointer-events: none;
opacity: 1;
transition: opacity var(--transition-base);
}
.app-button:hover::after { opacity: 0.7; }
.app-button:active { transform: scale(0.97); }
.app-button__icon {
display: inline-flex;
align-items: center;
justify-content: center;
font-size: 1.125rem;
line-height: 1;
flex-shrink: 0;
}
.app-button__text {
display: inline;
font: inherit;
font-weight: inherit;
line-height: inherit;
}
/* Primary */
.app-button--primary {
background: var(--gradient-primary);
color: #ffffff;
border-color: transparent;
box-shadow: var(--shadow-sm);
}
.app-button--primary:hover {
box-shadow: var(--shadow-md), var(--shadow-glow);
transform: translateY(-2px);
}
.app-button--primary:active {
transform: scale(0.97) translateY(0);
box-shadow: var(--shadow-sm);
}
.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 */
.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);
border-color: var(--secondary-dark);
box-shadow: var(--shadow-md);
transform: translateY(-1px);
}
.app-button--secondary:active {
transform: scale(0.97);
box-shadow: var(--shadow-sm);
}
.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 */
.app-button--ghost {
background: transparent;
color: var(--text-color);
border-color: var(--border-color);
box-shadow: none;
}
.app-button--ghost:hover {
background: var(--hover-background-color);
border-color: var(--primary-color);
color: var(--primary-color);
}
.app-button--ghost:active { transform: scale(0.97); }
.app-button--ghost:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
/* Outline */
.app-button--outline {
background: transparent;
color: var(--primary-color);
border-color: var(--primary-color);
box-shadow: none;
}
.app-button--outline:hover {
background: var(--primary-color);
color: var(--primary-foreground);
box-shadow: var(--shadow-glow);
transform: translateY(-1px);
}
.app-button--outline:active { transform: scale(0.97); }
.app-button--outline:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
/* Danger */
.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-dark);
border-color: var(--danger-dark);
box-shadow: var(--shadow-md), 0 0 16px rgba(239,68,68,0.35);
transform: translateY(-1px);
}
.app-button--danger:active { transform: scale(0.97); box-shadow: var(--shadow-sm); }
.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 */
.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-dark);
border-color: var(--success-dark);
box-shadow: var(--shadow-md), 0 0 16px rgba(16,185,129,0.35);
transform: translateY(-1px);
}
.app-button--success:active { transform: scale(0.97); box-shadow: var(--shadow-sm); }
.app-button--success:focus-visible {
outline: 2px solid var(--success-color);
outline-offset: 2px;
}
/* Warning */
.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-dark);
border-color: var(--warning-dark);
box-shadow: var(--shadow-md), var(--shadow-glow-energy);
transform: translateY(-1px);
}
.app-button--warning:active { transform: scale(0.97); box-shadow: var(--shadow-sm); }
.app-button--warning:focus-visible {
outline: 2px solid var(--warning-color);
outline-offset: 2px;
}
/* Info */
.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-dark);
border-color: var(--info-dark);
box-shadow: var(--shadow-md), var(--shadow-glow-accent);
transform: translateY(-1px);
}
.app-button--info:active { transform: scale(0.97); box-shadow: var(--shadow-sm); }
.app-button--info:focus-visible {
outline: 2px solid var(--info-color);
outline-offset: 2px;
}
/* Accent */
.app-button--accent {
background: var(--gradient-accent);
color: var(--accent-foreground);
border-color: transparent;
box-shadow: var(--shadow-sm);
}
.app-button--accent:hover {
box-shadow: var(--shadow-md), var(--shadow-glow-accent);
transform: translateY(-2px);
}
.app-button--accent:active { transform: scale(0.97); }
.app-button--accent:focus-visible {
outline: 2px solid var(--accent-color);
outline-offset: 2px;
}
/* Light */
.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);
border-color: var(--primary-color);
color: var(--primary-color);
box-shadow: var(--shadow-md);
}
.app-button--light:active { transform: scale(0.97); }
.app-button--light:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
/* Disabled */
.app-button:disabled,
.app-button--disabled {
background: var(--disabled-background) !important;
color: var(--disabled-color) !important;
border-color: var(--disabled-background) !important;
cursor: not-allowed !important;
opacity: 0.6 !important;
box-shadow: none !important;
transform: none !important;
}
/* Tamaños */
.app-button--sm {
font-size: 0.8125rem;
padding: 0.45rem 0.9rem;
min-height: 2.25rem;
border-radius: var(--radius-sm);
}
.app-button--lg {
font-size: 1rem;
padding: 0.85rem 1.75rem;
min-height: 3.25rem;
border-radius: var(--radius-lg);
}
.app-button--xl {
font-size: 1.125rem;
padding: 1rem 2.25rem;
min-height: 3.75rem;
border-radius: var(--radius-lg);
letter-spacing: 0.02em;
}
/* Full width */
.app-button--block { width: 100%; }
/* Icon only */
.app-button--icon-only {
padding: 0.65rem;
min-height: 2.75rem;
min-width: 2.75rem;
border-radius: var(--radius-md);
}
.app-button--icon-only.app-button--sm {
padding: 0.45rem;
min-height: 2.25rem;
min-width: 2.25rem;
}
/* Loading */
.app-button--loading {
pointer-events: none;
opacity: 0.8;
}
/* Responsive */
@media (max-width: 480px) {
.app-button {
font-size: 0.8125rem;
padding: 0.6rem 1rem;
min-height: 2.5rem;
}
}
/* =======================================================================
NexEvent — AppInput
Inputs elegantes con glow en focus, estilos tech-events
======================================================================= */
.app-input__control {
display: block;
width: 100%;
max-width: 100%;
box-sizing: border-box;
padding: 0.65rem 1rem;
font-size: 0.9375rem;
line-height: 1.5;
font-weight: 400;
color: var(--text-color);
background-color: var(--surface-color);
border: 1.5px solid var(--border-color);
border-radius: var(--radius-md);
transition: all var(--transition-base);
outline: none;
box-shadow: var(--shadow-xs);
}
.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);
}
.app-input__control:hover:not(:disabled):not([readonly]):not(.app-input__control--invalid) {
border-color: var(--primary-color);
}
.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; }
.app-input__control--invalid {
border-color: var(--danger-color);
box-shadow: 0 0 0 3px rgba(239,68,68,0.15);
}
.app-input__control--invalid:focus {
border-color: var(--danger-color);
box-shadow: 0 0 0 3px rgba(239,68,68,0.25), var(--shadow-sm);
}
.app-input__control--valid {
border-color: var(--success-color);
}
.app-input__control--valid:focus {
border-color: var(--success-color);
box-shadow: 0 0 0 3px rgba(16,185,129,0.2), var(--shadow-sm);
}
.app-input__control::placeholder {
color: var(--text-muted);
opacity: 0.65;
font-weight: 400;
}
.app-input__control:focus::placeholder { opacity: 0.45; }
.app-input__control--sm {
padding: 0.45rem 0.875rem;
font-size: 0.875rem;
border-radius: var(--radius-sm);
}
.app-input__control--lg {
padding: 0.85rem 1.25rem;
font-size: 1rem;
border-radius: var(--radius-lg);
}
/* Con iconos */
.app-input__wrapper {
position: relative;
display: flex;
align-items: center;
}
.app-input__wrapper .app-input__control {
padding-right: 2.75rem;
}
.app-input__icon {
position: absolute;
right: 0.875rem;
color: var(--text-muted);
pointer-events: none;
display: flex;
align-items: center;
justify-content: center;
transition: color var(--transition-fast);
}
.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.9375rem;
padding: 0.6rem 0.875rem;
}
}
/* NexEvent — AppInputField */
.app-input-field {
margin-bottom: 1rem;
width: 100%;
display: flex;
flex-direction: column;
}
.app-input-field__label-container {
margin-bottom: 0.3rem;
display: flex;
align-items: center;
gap: 0.3rem;
}
.app-input-field__error {
color: var(--danger-color);
font-size: 0.8rem;
margin-top: 0.25rem;
font-weight: 500;
min-height: 0;
letter-spacing: 0.02em;
animation: app-input-field-error-in 0.18s ease;
}
@keyframes app-input-field-error-in {
from { opacity: 0; transform: translateY(-3px); }
to { opacity: 1; transform: translateY(0); }
}
@media (max-width: 600px) {
.app-input-field { margin-bottom: 0.85rem; }
.app-input-field__error { font-size: 0.775rem; }
}
/* =======================================================================
NexEvent — AppLabel
Etiquetas con identidad tech, tracking elevado
======================================================================= */
.app-label {
font-weight: 600;
color: var(--text-color);
font-size: 0.8rem;
margin-bottom: 0.375rem;
display: inline-block;
cursor: pointer;
transition: color var(--transition-fast);
line-height: 1.5;
letter-spacing: 0.06em;
text-transform: uppercase;
}
.app-label--error {
color: var(--danger-color);
font-weight: 700;
}
.app-label--required::after {
content: '*';
color: var(--danger-color);
margin-left: 0.25rem;
font-weight: 700;
}
.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 var(--transition-fast);
}
.app-label__tooltip-icon:hover { color: var(--primary-color); }
.app-label:hover { color: var(--primary-color); }
.app-label--error:hover { color: var(--danger-light); }
.app-label--sm { font-size: 0.7rem; margin-bottom: 0.25rem; }
.app-label--lg { font-size: 0.875rem; margin-bottom: 0.5rem; letter-spacing: 0.04em; }
.app-label--disabled { color: var(--disabled-color); cursor: not-allowed; opacity: 0.6; }
/* ============================================
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: var(--radius-sm);
--als-radius-md: var(--radius-md);
--als-transition: all var(--transition-base);
--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: 1.5px 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), var(--shadow-sm);
}
.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), var(--shadow-sm);
}
/* 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: var(--z-modal);
background-color: var(--surface-color);
border: 1.5px 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;
}
}
/* NexEvent — AppPasswordField */
.app-password-field {
margin-bottom: 1.25rem;
width: 100%;
display: flex;
flex-direction: column;
}
.app-password-field__label-container {
margin-bottom: 0.3rem;
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.15em;
padding: 0.25em;
display: flex;
align-items: center;
border-radius: var(--radius-sm);
transition: color var(--transition-fast), background var(--transition-fast);
}
.app-password-field__toggle:hover,
.app-password-field__toggle:focus-visible {
color: var(--primary-color);
background: var(--hover-background-color);
outline: none;
}
.app-password-field__error {
color: var(--danger-color);
font-size: 0.8rem;
margin-top: 0.25rem;
font-weight: 500;
letter-spacing: 0.02em;
}
@media (max-width: 600px) {
.app-password-field { margin-bottom: 1rem; }
.app-password-field__error { font-size: 0.775rem; }
}
/* =======================================================================
NexEvent — AppSelect
Selector con dropdown estilizado, glow en focus
======================================================================= */
.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;
}
.app-select__control {
display: flex;
align-items: center;
justify-content: space-between;
background: var(--surface-color);
border: 1.5px solid var(--border-color);
border-radius: var(--radius-md);
padding: 0.65rem 1rem;
cursor: pointer;
min-height: 44px;
transition: all var(--transition-base);
color: var(--text-color);
width: 100%;
box-sizing: border-box;
box-shadow: var(--shadow-xs);
}
.app-select__control:hover {
border-color: var(--primary-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;
}
.app-select--invalid .app-select__control {
border-color: var(--danger-color);
box-shadow: 0 0 0 3px rgba(239,68,68,0.15);
}
.app-select__control--error {
border-color: var(--danger-color);
box-shadow: 0 0 0 3px rgba(239,68,68,0.15);
}
.app-select__error {
color: var(--danger-color);
font-size: 0.8rem;
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);
letter-spacing: 0.02em;
}
@keyframes app-select-error-slide-in {
from { opacity: 0; transform: translateY(-4px); }
to { opacity: 1; transform: translateY(0); }
}
.app-select__placeholder { color: var(--text-muted); opacity: 0.7; }
.app-select__selected-text { color: var(--text-color); font-weight: 500; }
.app-select__arrow {
margin-left: 0.5rem;
font-size: 1.1em;
color: var(--text-muted);
transition: transform var(--transition-base);
flex-shrink: 0;
}
.app-select__control--open .app-select__arrow {
transform: rotate(180deg);
color: var(--focus-color);
}
.app-select__dropdown {
position: absolute;
top: calc(100% + 4px);
left: 0;
right: 0;
background: var(--surface-color);
border: 1.5px solid var(--border-color);
border-radius: var(--radius-md);
box-shadow: var(--shadow-lg);
z-index: 100;
padding: 0.5rem 0;
margin-top: 0.25rem;
animation: app-select-dropdown-fade-in 0.18s cubic-bezier(0.4, 0, 0.2, 1);
width: 100%;
box-sizing: border-box;
overflow: hidden;
}
@keyframes app-select-dropdown-fade-in {
from { opacity: 0; transform: translateY(-8px) scale(0.97); }
to { opacity: 1; transform: translateY(0) scale(1); }
}
.app-select__search {
width: calc(100% - 1rem);
margin: 0.5rem;
display: block;
padding: 0.5rem 0.875rem;
border: 1.5px solid var(--border-color);
border-radius: var(--radius-sm);
font-size: 0.9375rem;
background: var(--surface-alt-color);
color: var(--text-color);
transition: all var(--transition-base);
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; }
.app-select__list {
list-style: none;
margin: 0;
padding: 0.25rem 0.5rem;
max-height: 240px;
overflow-y: auto;
box-sizing: border-box;
}
.app-select__list::-webkit-scrollbar { width: 5px; }
.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(--primary-color); }
.app-select__item {
padding: 0.6rem 0.875rem;
cursor: pointer;
color: var(--text-color);
border-radius: var(--radius-sm);
transition: all var(--transition-fast);
font-size: 0.9375rem;
box-sizing: border-box;
}
.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(--gradient-primary);
color: #ffffff;
font-weight: 600;
}
.app-select__item--selected:hover {
background: var(--gradient-primary);
opacity: 0.9;
color: #ffffff;
}
.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;
}
@media (max-width: 768px) {
.app-select { margin-bottom: 0.85rem; }
.app-select__control { padding: 0.55rem 0.875rem; font-size: 0.9375rem; }
.app-select__list { max-height: 200px; }
.app-select__item { padding: 0.5rem 0.75rem; font-size: 0.875rem; }
}
.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; } }
/* =======================================================================
NexEvent — AppTextAreaField
Campo de texto multilínea. Hereda la apariencia visual de AppInput
y agrega comportamiento específico de textarea: resize, min-height,
contador de caracteres y ajuste por número de filas.
======================================================================= */
.app-textarea-field {
margin-bottom: 1rem;
width: 100%;
display: flex;
flex-direction: column;
}
/* ── Label container (idéntico a AppInputField) ── */
.app-textarea-field__label-container {
margin-bottom: 0.3rem;
display: flex;
align-items: center;
gap: 0.3rem;
}
/* ── Control: hereda todos los estilos base de app-input__control ── */
.app-textarea-field__control {
display: block;
width: 100%;
max-width: 100%;
box-sizing: border-box;
padding: 0.65rem 1rem;
font-size: 0.9375rem;
line-height: 1.6;
font-weight: 400;
font-family: inherit;
color: var(--text-color);
background-color: var(--surface-color);
border: 1.5px solid var(--border-color);
border-radius: var(--radius-md);
transition: all var(--transition-base);
outline: none;
box-shadow: var(--shadow-xs);
resize: vertical;
min-height: 5rem;
}
.app-textarea-field__control:focus {
border-color: var(--focus-color);
background-color: var(--surface-color);
box-shadow: 0 0 0 3px var(--focus-ring), var(--shadow-sm);
}
.app-textarea-field__control:hover:not(:disabled):not([readonly]):not(.app-textarea-field__control--invalid) {
border-color: var(--primary-color);
}
.app-textarea-field__control:disabled,
.app-textarea-field__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;
resize: none;
}
.app-textarea-field__control[readonly] { cursor: default; }
.app-textarea-field__control--invalid {
border-color: var(--danger-color);
box-shadow: 0 0 0 3px rgba(239,68,68,0.15);
}
.app-textarea-field__control--invalid:focus {
border-color: var(--danger-color);
box-shadow: 0 0 0 3px rgba(239,68,68,0.25), var(--shadow-sm);
}
.app-textarea-field__control::placeholder {
color: var(--text-muted);
opacity: 0.65;
font-weight: 400;
}
.app-textarea-field__control:focus::placeholder { opacity: 0.45; }
/* ── Contador de caracteres ── */
.app-textarea-field__char-count {
margin-top: 0.25rem;
font-size: 0.775rem;
color: var(--text-muted);
text-align: right;
letter-spacing: 0.02em;
transition: color var(--transition-base);
}
.app-textarea-field__char-count--limit {
color: var(--danger-color);
font-weight: 600;
}
/* ── Mensaje de error (idéntico a AppInputField) ── */
.app-textarea-field__error {
color: var(--danger-color);
font-size: 0.8rem;
margin-top: 0.25rem;
font-weight: 500;
min-height: 0;
letter-spacing: 0.02em;
animation: app-textarea-field-error-in 0.18s ease;
}
@keyframes app-textarea-field-error-in {
from { opacity: 0; transform: translateY(-3px); }
to   { opacity: 1; transform: translateY(0); }
}
/* ── Responsive ── */
@media (max-width: 600px) {
.app-textarea-field          { margin-bottom: 0.85rem; }
.app-textarea-field__error   { font-size: 0.775rem; }
.app-textarea-field__control { font-size: 0.9rem; }
}
/* ============================================
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 */
/* ==================== NUEVAS CLASES v3 (Phase 5) ==================== */
/* Títulos de error y mensajes */
.createComplementModal__error-title {
font-weight: 700;
color: var(--danger-color);
margin: 0 0 0.5rem 0;
font-size: 0.95rem;
}
.createComplementModal__error-message {
color: var(--text-color);
font-size: 0.875rem;
margin: 0;
}
/* Contenedor de preview (PPD info + form) */
.createComplementModal__preview-container {
display: flex;
flex-direction: column;
gap: 1.25rem;
}
.createComplementModal__preview-section,
.createComplementModal__form-section {
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.createComplementModal__section-title {
font-size: 0.875rem;
font-weight: 700;
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: 0.5px;
margin: 0;
padding-bottom: 0.4rem;
border-bottom: 1px solid var(--border-color);
}
/* Filas de info (UUID, folio, total del PPD) */
.createComplementModal__info-row {
display: flex;
align-items: baseline;
gap: 0.5rem;
font-size: 0.875rem;
}
.createComplementModal__info-label {
color: var(--text-muted);
font-size: 0.775rem;
font-weight: 600;
white-space: nowrap;
min-width: 60px;
}
.createComplementModal__info-value {
color: var(--text-color);
font-weight: 500;
font-family: 'Courier New', monospace;
font-size: 0.825rem;
word-break: break-all;
}
/* Error de campo (forma de pago no seleccionada) */
.createComplementModal__field-error {
color: var(--danger-color);
font-size: 0.8rem;
margin: 0.25rem 0 0 0;
}
/* Success */
.createComplementModal__success {
padding: 1rem;
background: var(--success-background);
border: 1px solid var(--success-color);
border-radius: var(--border-radius);
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.createComplementModal__success-title {
font-weight: 700;
color: var(--success-color);
margin: 0 0 0.5rem 0;
font-size: 0.95rem;
}
/* ================================================== */
/* 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);
}
}
/* ==================== NUEVAS CLASES v3 (Phase 5) ==================== */
/* Info rows — UUID, folio, PAC en success */
.createDirectPpdModal__info-row {
display: flex;
align-items: baseline;
gap: 0.5rem;
padding: 0.3rem 0;
border-bottom: 1px solid var(--border-color);
font-size: 0.875rem;
}
.createDirectPpdModal__info-row:last-child { border-bottom: none; }
.createDirectPpdModal__info-label {
color: var(--text-muted);
font-size: 0.775rem;
font-weight: 600;
min-width: 56px;
}
.createDirectPpdModal__info-value {
color: var(--text-color);
font-weight: 500;
font-family: 'Courier New', monospace;
font-size: 0.825rem;
word-break: break-all;
}
/* Success */
.createDirectPpdModal__success {
display: flex;
flex-direction: column;
gap: 0.5rem;
padding: 1rem;
background: var(--success-background);
border: 1px solid var(--success-color);
border-radius: var(--border-radius);
}
.createDirectPpdModal__success-title {
font-weight: 700;
color: var(--success-color);
margin: 0 0 0.5rem 0;
font-size: 0.95rem;
}
.createDirectPpdModal__success-hint {
color: var(--text-muted);
font-size: 0.8rem;
margin: 0.25rem 0 0 0;
}
/* Confirm */
.createDirectPpdModal__confirm {
display: flex;
flex-direction: column;
gap: 0.875rem;
}
.createDirectPpdModal__confirm-text {
color: var(--text-color);
font-size: 0.9rem;
margin: 0;
line-height: 1.5;
}
.createDirectPpdModal__details {
list-style: none;
padding: 0.875rem 1rem;
margin: 0;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: var(--border-radius);
display: flex;
flex-direction: column;
gap: 0.4rem;
font-size: 0.85rem;
color: var(--text-color);
}
.createDirectPpdModal__details li::before {
content: "• ";
color: var(--primary-color);
}
/* Error */
.createDirectPpdModal__error {
padding: 0.75rem 1rem;
background: var(--danger-background);
border-left: 3px solid var(--danger-color);
border-radius: var(--border-radius);
color: var(--danger-color);
font-size: 0.875rem;
margin-top: 0.25rem;
}
/* ============================================
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 */
/* ==================== NUEVAS CLASES v3 (Phase 7) ==================== */
/* Info rows */
.createPpdModal__info-row {
display: flex;
align-items: baseline;
gap: 0.5rem;
padding: 0.3rem 0;
border-bottom: 1px solid var(--border-color);
font-size: 0.875rem;
}
.createPpdModal__info-row:last-child { border-bottom: none; }
.createPpdModal__info-label {
color: var(--text-muted);
font-size: 0.775rem;
font-weight: 600;
min-width: 56px;
}
.createPpdModal__info-value {
color: var(--text-color);
font-weight: 500;
font-family: 'Courier New', monospace;
font-size: 0.825rem;
word-break: break-all;
}
/* Success */
.createPpdModal__success {
display: flex;
flex-direction: column;
gap: 0.5rem;
padding: 1rem;
background: var(--success-background);
border: 1px solid var(--success-color);
border-radius: var(--border-radius);
}
.createPpdModal__success-title {
font-weight: 700;
color: var(--success-color);
margin: 0 0 0.5rem 0;
font-size: 0.95rem;
}
.createPpdModal__success-hint {
color: var(--text-muted);
font-size: 0.8rem;
margin: 0.25rem 0 0 0;
}
/* Confirm */
.createPpdModal__confirm {
display: flex;
flex-direction: column;
gap: 0.875rem;
}
.createPpdModal__confirm-text {
color: var(--text-color);
font-size: 0.9rem;
margin: 0;
line-height: 1.5;
}
.createPpdModal__details {
list-style: none;
padding: 0.875rem 1rem;
margin: 0;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: var(--border-radius);
display: flex;
flex-direction: column;
gap: 0.4rem;
font-size: 0.85rem;
color: var(--text-color);
}
.createPpdModal__details li::before {
content: "• ";
color: var(--primary-color);
}
/* Error */
.createPpdModal__error {
padding: 0.75rem 1rem;
background: var(--danger-background);
border-left: 3px solid var(--danger-color);
border-radius: var(--border-radius);
color: var(--danger-color);
font-size: 0.875rem;
}
/* Loading */
.createPpdModal__loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 1rem;
padding: 2.5rem 1rem;
text-align: center;
color: var(--text-muted);
}
/* ===== 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;
}
}
/* ============================================================
idChip — chip clicable para mostrar un ID y abrir quick-view
BEM namespace: idChip
============================================================ */
.idChip {
display: inline-flex;
align-items: center;
gap: 3px;
background: color-mix(in srgb, var(--primary-color) 10%, transparent);
color: var(--primary-dark);
border: 1px solid color-mix(in srgb, var(--primary-color) 25%, transparent);
border-radius: 999px;
padding: 0.08rem 0.42rem;
font-size: 0.65rem;
font-weight: 600;
cursor: pointer;
transition: background 0.15s, color 0.15s, border-color 0.15s;
white-space: nowrap;
text-decoration: none;
line-height: 1.4;
letter-spacing: 0.01em;
user-select: none;
}
.idChip:hover {
background: color-mix(in srgb, var(--primary-color) 20%, transparent);
border-color: color-mix(in srgb, var(--primary-color) 45%, transparent);
}
.idChip:active {
transform: scale(0.97);
}
.idChip--receipt {
background: color-mix(in srgb, var(--secondary-color) 8%, transparent);
color: var(--text-muted);
border-color: color-mix(in srgb, var(--secondary-color) 20%, transparent);
font-weight: 500;
}
.idChip--receipt:hover {
background: color-mix(in srgb, var(--secondary-color) 16%, transparent);
border-color: color-mix(in srgb, var(--secondary-color) 35%, transparent);
}
.idChip--payment {
background: color-mix(in srgb, var(--primary-color) 10%, transparent);
color: var(--primary-dark);
border-color: color-mix(in srgb, var(--primary-color) 25%, transparent);
}
.idChip--payment:hover {
background: color-mix(in srgb, var(--primary-color) 20%, transparent);
border-color: color-mix(in srgb, var(--primary-color) 45%, transparent);
}
.idChip__icon {
width: 11px;
height: 11px;
opacity: 0.75;
flex-shrink: 0;
}
.idChip:hover .idChip__icon {
opacity: 1;
}
/* ===================================================
OnSiteCategorySelector — BEM: on-site-category-selector
=================================================== */
.on-site-category-selector { width: 100%; display: flex; flex-direction: column; gap: 1.5rem; }
.on-site-category-selector__loading {
display: flex; align-items: center; gap: 0.75rem;
padding: 1.5rem; color: var(--text-muted);
}
.on-site-category-selector__error {
padding: 0.75rem 1rem; background: var(--danger-background);
border-left: 3px solid var(--danger-color); border-radius: var(--border-radius);
color: var(--danger-color); font-size: 0.875rem;
}
.on-site-category-selector__empty { color: var(--text-muted); font-size: 0.875rem; margin: 0; }
.on-site-category-selector__section { display: flex; flex-direction: column; gap: 0.75rem; }
.on-site-category-selector__section--additionals { padding-top: 1rem; border-top: 1px solid var(--border-color); }
.on-site-category-selector__section-title {
font-size: 0.875rem; font-weight: 700; color: var(--text-color);
text-transform: uppercase; letter-spacing: 0.4px; margin: 0;
}
/* Grid de tarjetas */
.on-site-category-selector__grid {
display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 0.75rem;
}
.on-site-category-selector__card {
position: relative; padding: 1rem; border-radius: var(--border-radius);
border: 2px solid var(--border-color); background: var(--surface-color);
cursor: pointer; text-align: left; transition: border-color .15s, background .15s;
display: flex; flex-direction: column; gap: 0.35rem;
}
.on-site-category-selector__card:hover:not(:disabled) {
border-color: var(--primary-color); background: var(--hover-background-color);
}
.on-site-category-selector__card--selected {
border-color: var(--primary-color); background: var(--info-background);
}
.on-site-category-selector__card--additional { border-style: dashed; }
.on-site-category-selector__card--unavailable {
opacity: .5; cursor: not-allowed;
}
.on-site-category-selector__card-name {
font-weight: 600; font-size: 0.95rem; color: var(--text-color);
}
.on-site-category-selector__card-price {
font-size: 1.1rem; font-weight: 700; color: var(--primary-color);
}
.on-site-category-selector__card-unavailable {
font-size: 0.78rem; color: var(--danger-color);
}
.on-site-category-selector__card-check {
position: absolute; top: 0.5rem; right: 0.5rem;
color: var(--primary-color); font-size: 1rem; font-weight: 700;
}
/* Total */
.on-site-category-selector__total {
display: flex; align-items: center; justify-content: flex-end;
gap: 1rem; padding: 0.75rem 1rem;
background: var(--primary-color); border-radius: var(--border-radius);
}
.on-site-category-selector__total-label {
font-size: 0.9rem; color: var(--primary-foreground); font-weight: 500;
}
.on-site-category-selector__total-amount {
font-size: 1.3rem; font-weight: 800; color: var(--primary-foreground);
}
@media (max-width: 480px) {
.on-site-category-selector__grid { grid-template-columns: 1fr; }
}
/* ===================================================
OnSiteEventSelector — BEM: on-site-event-selector
=================================================== */
.on-site-event-selector {
width: 100%;
border-radius: var(--border-radius);
overflow: hidden;
}
.on-site-event-selector__loading {
padding: 1rem;
display: flex;
justify-content: center;
}
/* Evento activo */
.on-site-event-selector__active {
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: 0.75rem;
padding: 0.75rem 1rem;
background: var(--info-background);
border: 1px solid var(--info-color);
border-radius: var(--border-radius);
}
.on-site-event-selector__event-info {
display: flex;
align-items: center;
gap: 0.5rem;
flex-wrap: wrap;
}
.on-site-event-selector__label {
font-size: 0.78rem;
color: var(--text-muted);
font-weight: 600;
text-transform: uppercase;
}
.on-site-event-selector__name {
font-weight: 700;
color: var(--text-color);
font-size: 0.95rem;
}
.on-site-event-selector__short {
font-size: 0.8rem;
color: var(--info-color);
font-family: monospace;
}
.on-site-event-selector__actions {
display: flex;
gap: 0.5rem;
}
/* Sin evento */
.on-site-event-selector__empty {
padding: 1.5rem;
text-align: center;
background: var(--secondary-background);
border: 2px dashed var(--border-color);
border-radius: var(--border-radius);
display: flex;
flex-direction: column;
align-items: center;
gap: 1rem;
}
.on-site-event-selector__empty-text {
color: var(--text-muted);
margin: 0;
font-size: 0.9rem;
}
/* Modal */
.on-site-event-selector__modal-body {
display: flex;
flex-direction: column;
gap: 1rem;
}
.on-site-event-selector__modal-hint {
color: var(--text-muted);
font-size: 0.875rem;
margin: 0;
}
.on-site-event-selector__error {
padding: 0.75rem 1rem;
background: var(--danger-background);
border-left: 3px solid var(--danger-color);
border-radius: var(--border-radius);
color: var(--danger-color);
font-size: 0.875rem;
}
.on-site-event-selector__found {
padding: 1rem;
background: var(--success-background);
border: 1px solid var(--success-color);
border-radius: var(--border-radius);
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.on-site-event-selector__found-label {
font-size: 0.75rem;
color: var(--success-color);
font-weight: 600;
text-transform: uppercase;
}
.on-site-event-selector__found-name {
font-size: 1rem;
color: var(--text-color);
}
.on-site-event-selector__found-date {
font-size: 0.8rem;
color: var(--text-muted);
}
@media (max-width: 600px) {
.on-site-event-selector__active { flex-direction: column; align-items: flex-start; }
}
/* ===================================================
OnSiteFiscalSelector — BEM: on-site-fiscal-selector
=================================================== */
.on-site-fiscal-selector { width: 100%; display: flex; flex-direction: column; gap: 1rem; }
.on-site-fiscal-selector__header { display: flex; flex-direction: column; gap: 0.25rem; }
.on-site-fiscal-selector__title { margin: 0; font-size: 1rem; font-weight: 700; color: var(--text-color); }
.on-site-fiscal-selector__subtitle { margin: 0; font-size: 0.825rem; color: var(--text-muted); }
.on-site-fiscal-selector__loading {
display: flex; align-items: center; gap: 0.75rem; padding: 1rem; color: var(--text-muted);
}
/* Tabs */
.on-site-fiscal-selector__tabs {
display: flex; gap: 0; border-bottom: 2px solid var(--border-color);
}
.on-site-fiscal-selector__tab {
padding: 0.6rem 1rem; border: none; background: transparent;
font-size: 0.85rem; font-weight: 600; color: var(--text-muted);
cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -2px;
transition: color .15s, border-color .15s;
}
.on-site-fiscal-selector__tab:hover { color: var(--primary-color); }
.on-site-fiscal-selector__tab--active {
color: var(--primary-color); border-bottom-color: var(--primary-color);
}
.on-site-fiscal-selector__tab--skip:hover,
.on-site-fiscal-selector__tab--skip.on-site-fiscal-selector__tab--active {
color: var(--warning-color); border-bottom-color: var(--warning-color);
}
.on-site-fiscal-selector__tab-content { display: flex; flex-direction: column; gap: 0.75rem; padding-top: 0.75rem; }
/* Tarjetas de fiscal existente */
.on-site-fiscal-selector__fiscal-card {
position: relative; padding: 0.875rem 1rem;
border: 2px solid var(--border-color); border-radius: var(--border-radius);
background: var(--surface-color); cursor: pointer; text-align: left;
display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
transition: border-color .15s, background .15s;
}
.on-site-fiscal-selector__fiscal-card:hover { border-color: var(--primary-color); background: var(--hover-background-color); }
.on-site-fiscal-selector__fiscal-card--selected { border-color: var(--primary-color); background: var(--info-background); }
.on-site-fiscal-selector__fiscal-rfc {
font-family: monospace; font-weight: 700; color: var(--primary-color); font-size: 0.9rem;
}
.on-site-fiscal-selector__fiscal-name { font-weight: 600; color: var(--text-color); font-size: 0.875rem; flex: 1; }
.on-site-fiscal-selector__fiscal-cp { font-size: 0.8rem; color: var(--text-muted); }
.on-site-fiscal-selector__fiscal-check { margin-left: auto; color: var(--primary-color); font-weight: 700; }
/* Form grid */
.on-site-fiscal-selector__form-grid {
display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem;
}
/* Skip warning */
.on-site-fiscal-selector__skip-warning {
padding: 1rem; background: var(--warning-background);
border: 1px solid var(--warning-color); border-radius: var(--border-radius);
}
.on-site-fiscal-selector__skip-text { margin: 0; font-size: 0.875rem; color: var(--text-color); line-height: 1.6; }
@media (max-width: 600px) {
.on-site-fiscal-selector__form-grid { grid-template-columns: 1fr; }
.on-site-fiscal-selector__tabs { flex-wrap: wrap; }
}
/* ===================================================
OnSiteInactivityTimer — BEM: on-site-inactivity-timer
=================================================== */
.on-site-inactivity-timer {
width: 100%;
height: 100%;
display: contents; /* Transparente al layout */
}
.on-site-inactivity-timer__warning {
padding: 0.5rem 0;
text-align: center;
}
.on-site-inactivity-timer__warning-text {
color: var(--text-color);
font-size: 1rem;
margin: 0;
line-height: 1.6;
}
.on-site-inactivity-timer__countdown {
font-size: 1.75rem;
color: var(--danger-color);
display: block;
margin-top: 0.5rem;
}
/* ===================================================
OnSitePaymentForm — BEM: on-site-payment-form
=================================================== */
.on-site-payment-form { width: 100%; display: flex; flex-direction: column; gap: 1rem; }
.on-site-payment-form__title { font-size: 1rem; font-weight: 700; color: var(--text-color); margin: 0; }
.on-site-payment-form__grid {
display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem;
}
.on-site-payment-form__field-error { color: var(--danger-color); font-size: 0.8rem; margin: 0; }
.on-site-payment-form__total {
display: flex; align-items: center; justify-content: space-between;
padding: 0.875rem 1rem; background: var(--success-background);
border: 1px solid var(--success-color); border-radius: var(--border-radius);
}
.on-site-payment-form__total-label { font-size: 0.875rem; color: var(--text-color); font-weight: 600; }
.on-site-payment-form__total-amount { font-size: 1.4rem; font-weight: 800; color: var(--success-color); }
@media (max-width: 600px) { .on-site-payment-form__grid { grid-template-columns: 1fr; } }
/* ===================================================
OnSiteQrResult — BEM: on-site-qr-result
=================================================== */
.on-site-qr-result {
width: 100%; display: flex; flex-direction: column;
align-items: center; gap: 1.5rem; padding: 1.5rem 1rem;
}
.on-site-qr-result__success-badge {
display: flex; align-items: center; gap: 0.75rem;
padding: 0.75rem 1.5rem; background: var(--success-background);
border: 2px solid var(--success-color); border-radius: 999px;
}
.on-site-qr-result__check-icon { font-size: 1.5rem; color: var(--success-color); }
.on-site-qr-result__success-text { font-weight: 700; font-size: 1rem; color: var(--success-color); }
/* Caja del recibo */
.on-site-qr-result__receipt-box {
width: 100%; max-width: 360px;
padding: 1.5rem; background: var(--surface-color);
border: 2px solid var(--border-color); border-radius: var(--border-radius);
display: flex; flex-direction: column; align-items: center; gap: 0.5rem;
box-shadow: var(--shadow-md);
}
.on-site-qr-result__receipt-label,
.on-site-qr-result__code-label,
.on-site-qr-result__total-label {
font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.5px;
color: var(--text-muted); font-weight: 600; margin: 0.5rem 0 0;
}
.on-site-qr-result__receipt-id {
font-size: 3.5rem; font-weight: 900; color: var(--primary-color);
line-height: 1; margin: 0; font-variant-numeric: tabular-nums;
}
.on-site-qr-result__code-confirm {
font-size: 1.2rem; font-weight: 700; font-family: monospace;
color: var(--text-color); letter-spacing: 2px; margin: 0;
}
.on-site-qr-result__total-amount {
font-size: 1.6rem; font-weight: 800; color: var(--success-color); margin: 0;
}
.on-site-qr-result__message {
font-size: 0.825rem; color: var(--text-muted); text-align: center; margin: 0.5rem 0 0;
}
.on-site-qr-result__qr-wrapper {
margin-top: 0.5rem; padding: 0.75rem;
border: 1px solid var(--border-color); border-radius: 8px;
background: #fff;
}
.on-site-qr-result__actions { display: flex; gap: 0.75rem; flex-wrap: wrap; justify-content: center; }
/* ===================================================
OnSiteUserLookup — BEM: on-site-user-lookup
=================================================== */
.on-site-user-lookup { width: 100%; display: flex; flex-direction: column; gap: 1.25rem; }
.on-site-user-lookup__section-title {
font-size: 1rem; font-weight: 700; color: var(--text-color); margin: 0;
}
.on-site-user-lookup__hint {
color: var(--text-muted); font-size: 0.875rem; margin: 0;
}
.on-site-user-lookup__error {
padding: 0.75rem 1rem;
background: var(--danger-background);
border-left: 3px solid var(--danger-color);
border-radius: var(--border-radius);
color: var(--danger-color); font-size: 0.875rem;
}
.on-site-user-lookup__email-row {
display: flex; gap: 0.75rem; align-items: flex-end; flex-wrap: wrap;
}
.on-site-user-lookup__email-row > :first-child { flex: 1; min-width: 200px; }
/* Found user badge */
.on-site-user-lookup__found {
display: flex; align-items: center; justify-content: space-between;
flex-wrap: wrap; gap: 0.75rem;
padding: 1rem; background: var(--success-background);
border: 1px solid var(--success-color); border-radius: var(--border-radius);
}
.on-site-user-lookup__found-badge {
display: flex; align-items: center; gap: 0.75rem;
}
.on-site-user-lookup__found-icon {
font-size: 1.5rem; color: var(--success-color); font-weight: 700;
}
.on-site-user-lookup__found-info { display: flex; flex-direction: column; gap: 0.15rem; }
.on-site-user-lookup__found-title {
font-size: 0.75rem; font-weight: 600; color: var(--success-color); text-transform: uppercase;
}
.on-site-user-lookup__found-name { font-weight: 700; color: var(--text-color); }
.on-site-user-lookup__found-email { font-size: 0.8rem; color: var(--text-muted); }
/* New user form */
.on-site-user-lookup__new-user {
display: flex; flex-direction: column; gap: 1rem;
padding: 1rem; background: var(--warning-background);
border: 1px solid var(--warning-color); border-radius: var(--border-radius);
}
.on-site-user-lookup__new-user-badge {
padding: 0.5rem 0.75rem; background: var(--warning-color);
color: var(--warning-foreground); border-radius: 4px;
font-size: 0.825rem; font-weight: 600;
}
.on-site-user-lookup__form-grid {
display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem;
}
.on-site-user-lookup__send-email-row { font-size: 0.85rem; color: var(--text-color); }
.on-site-user-lookup__check-label {
display: flex; align-items: center; gap: 0.5rem; cursor: pointer;
}
.on-site-user-lookup__form-actions { display: flex; gap: 0.75rem; flex-wrap: wrap; }
@media (max-width: 600px) {
.on-site-user-lookup__form-grid { grid-template-columns: 1fr; }
.on-site-user-lookup__email-row { flex-direction: column; }
}
/* ============================================
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 */
/* ==================== NUEVAS CLASES v3 (Phase 7) ==================== */
/* Badges de estado del complemento */
.paymentHistoryTimeline__badge {
display: inline-block;
padding: 0.15rem 0.5rem;
border-radius: 999px;
font-size: 0.7rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.4px;
}
.paymentHistoryTimeline__badge--valid     { background: var(--success-background); color: var(--success-color); }
.paymentHistoryTimeline__badge--cancelled { background: var(--warning-background); color: var(--warning-color); }
.paymentHistoryTimeline__badge--failed    { background: var(--danger-background);  color: var(--danger-color);  }
/* Valor monospace (UUID) */
.paymentHistoryTimeline__detail-mono {
font-family: 'Courier New', monospace;
font-size: 0.775rem;
word-break: break-all;
}
/* ============================================
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%;
}
}
/* ============================================
PreviewCfdiModal — BEM: previewCfdiModal
"CFDIs del Pago" — historial de CFDIs
============================================ */
.previewCfdiModal {
width: 100%;
display: flex;
flex-direction: column;
gap: 1rem;
}
/* ==================== ESTADOS ==================== */
.previewCfdiModal__loading,
.previewCfdiModal__empty {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 0.75rem;
padding: 2.5rem 1rem;
text-align: center;
color: var(--text-muted);
}
.previewCfdiModal__error {
padding: 0.875rem 1rem;
background: var(--danger-background);
border-left: 3px solid var(--danger-color);
border-radius: var(--border-radius);
color: var(--danger-color);
font-size: 0.875rem;
}
/* ==================== LISTA ==================== */
.previewCfdiModal__list {
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.previewCfdiModal__item {
padding: 1rem;
border: 1px solid var(--border-color);
border-radius: var(--border-radius);
background: var(--surface-color);
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.previewCfdiModal__item-header {
display: flex;
align-items: center;
flex-wrap: wrap;
gap: 0.5rem;
}
.previewCfdiModal__folio {
font-weight: 700;
font-size: 0.95rem;
color: var(--text-color);
font-family: 'Courier New', monospace;
}
/* Badges de estado */
.previewCfdiModal__badge {
display: inline-block;
padding: 0.2rem 0.55rem;
border-radius: 999px;
font-size: 0.72rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.4px;
}
.previewCfdiModal__badge--valid {
background: var(--success-background);
color: var(--success-color);
}
.previewCfdiModal__badge--failed {
background: var(--danger-background);
color: var(--danger-color);
}
.previewCfdiModal__badge--cancelled {
background: var(--warning-background);
color: var(--warning-color);
}
.previewCfdiModal__type,
.previewCfdiModal__method {
font-size: 0.78rem;
padding: 0.2rem 0.5rem;
border-radius: 4px;
background: var(--border-color);
color: var(--text-muted);
font-weight: 600;
}
/* UUID */
.previewCfdiModal__uuid {
font-family: 'Courier New', monospace;
font-size: 0.775rem;
color: var(--text-muted);
word-break: break-all;
}
/* Filas de detalle */
.previewCfdiModal__item-row {
display: flex;
align-items: baseline;
gap: 0.5rem;
font-size: 0.85rem;
}
.previewCfdiModal__label {
color: var(--text-muted);
font-size: 0.78rem;
font-weight: 600;
white-space: nowrap;
min-width: 80px;
}
.previewCfdiModal__value {
color: var(--text-color);
font-weight: 500;
}
.previewCfdiModal__item-actions {
display: flex;
gap: 8px;
flex-wrap: wrap;
padding-top: 10px;
margin-top: 10px;
border-top: 1px solid var(--border-color);
}
/* ==================== EMAIL PERSONALIZADO ==================== */
.previewCfdiModal__custom-email {
display: flex;
flex-direction: column;
gap: 0.5rem;
padding: 0.75rem;
margin-top: 0.5rem;
background: var(--surface-alt-color, var(--surface-color));
border: 1px solid var(--border-color);
border-radius: var(--border-radius);
}
.previewCfdiModal__custom-email-actions {
display: flex;
gap: 0.5rem;
justify-content: flex-end;
}
/* ============================================
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 */
/* ==================== NUEVAS CLASES v3 (Phase 7) ==================== */
/* Receptor */
.ppdStatusCard__receiver-section {
display: flex;
flex-direction: column;
gap: 0.2rem;
padding: 0.75rem;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: var(--border-radius);
}
.ppdStatusCard__receiver-name {
font-weight: 600;
color: var(--text-color);
font-size: 0.9rem;
}
.ppdStatusCard__receiver-rfc {
font-size: 0.775rem;
color: var(--text-muted);
font-family: 'Courier New', monospace;
}
/* Badges de estado */
.ppdStatusCard__badge--valid     { background: var(--success-background); color: var(--success-color); }
.ppdStatusCard__badge--failed    { background: var(--danger-background);  color: var(--danger-color);  }
.ppdStatusCard__badge--cancelled { background: var(--warning-background); color: var(--warning-color); }
/* ──────────────────────────────────────────────────────────────────────────
app-realtime-connection.css
Banner de solicitud de permiso de notificaciones del SO.
BEM: omnia-conn-notif-banner
Posición: esquina superior izquierda, compacto y elegante.
Colores: usa variables del sistema de colores para soporte light/dark.
Todos los selectores internos usan !important para ganarle a las reglas
globales del sistema (svg, button, etc.) que traen sus propios !important.
────────────────────────────────────────────────────────────────────────── */
.omnia-conn-notif-banner {
position: fixed !important;
top: 4.5rem !important;
left: 1rem !important;
z-index: 9999 !important;
display: flex !important;
align-items: center !important;
gap: 0.5rem !important;
padding: 0.45rem 0.65rem 0.45rem 0.75rem !important;
background: var(--card-bg-color) !important;
border: 1px solid var(--border-color) !important;
border-radius: 2rem !important;
box-shadow: 0 2px 12px rgba(0, 0, 0, 0.10) !important;
max-width: min(22rem, calc(100vw - 2rem)) !important;
animation: omnia-conn-banner-in 0.2s ease !important;
}
@keyframes omnia-conn-banner-in {
from { opacity: 0; transform: translateY(-0.4rem); }
to   { opacity: 1; transform: translateY(0); }
}
/* ── Ícono campana ───────────────────────────────────────────────────────── */
.omnia-conn-notif-banner__icon {
flex-shrink: 0 !important;
width: 1.1rem !important;
height: 1.1rem !important;
min-width: 1.1rem !important;
min-height: 1.1rem !important;
max-width: 1.1rem !important;
max-height: 1.1rem !important;
color: var(--accent-color) !important;
stroke: currentColor !important;
fill: none !important;
stroke-width: 2 !important;
stroke-linecap: round !important;
stroke-linejoin: round !important;
display: block !important;
animation: none !important;
opacity: 1 !important;
transform: none !important;
}
/* ── Texto ───────────────────────────────────────────────────────────────── */
.omnia-conn-notif-banner__text {
font-size: 0.78rem !important;
color: var(--text-muted) !important;
flex: 1 !important;
white-space: nowrap !important;
overflow: hidden !important;
text-overflow: ellipsis !important;
line-height: 1.3 !important;
}
/* ── Botón Activar ───────────────────────────────────────────────────────── */
.omnia-conn-notif-banner__btn {
flex-shrink: 0 !important;
padding: 0.25rem 0.6rem !important;
font-size: 0.75rem !important;
font-weight: 600 !important;
border-radius: 1rem !important;
border: none !important;
cursor: pointer !important;
background: var(--accent-color) !important;
color: var(--accent-foreground) !important;
transition: opacity 0.15s !important;
white-space: nowrap !important;
line-height: 1.4 !important;
display: inline-flex !important;
align-items: center !important;
}
.omnia-conn-notif-banner__btn:hover {
opacity: 0.85 !important;
}
/* ── Botón cerrar ────────────────────────────────────────────────────────── */
.omnia-conn-notif-banner__dismiss {
flex-shrink: 0 !important;
background: none !important;
border: none !important;
cursor: pointer !important;
color: var(--text-muted) !important;
display: flex !important;
align-items: center !important;
justify-content: center !important;
width: 1.4rem !important;
height: 1.4rem !important;
min-width: 1.4rem !important;
min-height: 1.4rem !important;
border-radius: 50% !important;
padding: 0 !important;
transition: background 0.15s, color 0.15s !important;
}
.omnia-conn-notif-banner__dismiss:hover {
background: var(--surface-alt-color) !important;
color: var(--text-color) !important;
}
/* ── SVG del ícono X del dismiss ─────────────────────────────────────────── */
.omnia-conn-notif-banner__dismiss svg {
width: 0.65rem !important;
height: 0.65rem !important;
min-width: 0.65rem !important;
min-height: 0.65rem !important;
max-width: 0.65rem !important;
max-height: 0.65rem !important;
stroke: currentColor !important;
fill: none !important;
stroke-width: 2.5 !important;
stroke-linecap: round !important;
display: block !important;
animation: none !important;
opacity: 1 !important;
transform: none !important;
}
/* Dark mode — data-theme="dark" explícito */
:root[data-theme='dark'] .omnia-conn-notif-banner {
box-shadow: 0 2px 16px rgba(0, 0, 0, 0.35) !important;
}
/* Dark mode — preferencia del sistema cuando no hay tema explícito */
@media (prefers-color-scheme: dark) {
:root:not([data-theme='light']) .omnia-conn-notif-banner {
box-shadow: 0 2px 16px rgba(0, 0, 0, 0.35) !important;
}
}
/* ── Banner de cookies de terceros ───────────────────────────────────────── */
/* Se apila debajo del banner de notificaciones cuando ambos están visibles. */
.omnia-conn-notif-banner--cookie {
top: 8.5rem !important;
border-color: var(--warning-border, var(--border-color)) !important;
}
.omnia-conn-notif-banner--cookie .omnia-conn-notif-banner__icon {
color: var(--warning-foreground, var(--accent-color)) !important;
}
/* app-realtime-event-announcements.css — BEM: app-realtime-event-announcements */
.app-realtime-event-announcements {
width: 100%;
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.app-realtime-event-announcements__item {
display: flex;
align-items: flex-start;
gap: 0.75rem;
padding: 0.875rem 1rem;
border-radius: 0.5rem;
border-left: 4px solid transparent;
background-color: var(--card-background);
border-color: var(--border-color);
}
/* Severidades */
.app-realtime-event-announcements__item--success {
border-left-color: var(--success-foreground);
background-color: var(--success-background);
}
.app-realtime-event-announcements__item--warning {
border-left-color: var(--warning-foreground);
background-color: var(--warning-background);
}
.app-realtime-event-announcements__item--error {
border-left-color: var(--error-foreground);
background-color: var(--error-background);
}
.app-realtime-event-announcements__item--info {
border-left-color: var(--info-foreground);
background-color: var(--info-background);
}
/* Icono */
.app-realtime-event-announcements__icon {
width: 1.25rem;
height: 1.25rem;
flex-shrink: 0;
margin-top: 0.1rem;
color: inherit;
opacity: 0.75;
}
/* Cuerpo */
.app-realtime-event-announcements__body {
flex: 1;
min-width: 0;
}
.app-realtime-event-announcements__title {
display: block;
font-size: 0.875rem;
font-weight: 600;
color: var(--foreground-color);
margin-bottom: 0.25rem;
}
.app-realtime-event-announcements__message {
margin: 0;
font-size: 0.8125rem;
color: var(--muted-foreground);
line-height: 1.5;
word-break: break-word;
}
/* =======================================================================
app-realtime-event-chat.css
BEM namespace: omnia-evtchat  (único, no colisiona con ningún otro CSS)
Diseño: feed tipo Slack — avatar+iniciales | nombre+hora | texto limpio
burbuja compacta solo para mensajes propios
Paleta: 100% variables del sistema. Resets explícitos contra globales.
======================================================================= */
/* ── Raíz ── */
.omnia-evtchat {
display: flex;
flex-direction: column;
width: 100%;
height: 100%;
min-height: 20rem;
background-color: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: var(--radius-md);
overflow: hidden;
}
/* ── Header ── */
.omnia-evtchat__header {
display: flex;
align-items: center;
gap: 0.5rem;
padding: 0.625rem 0.875rem;
background: var(--surface-alt-color);
border-bottom: 1px solid var(--border-color);
flex-shrink: 0;
}
.omnia-evtchat__live-dot {
width: 0.45rem;
height: 0.45rem;
border-radius: 50%;
background-color: var(--danger-color);
animation: omnia-evtchat-pulse 1.4s ease-in-out infinite;
flex-shrink: 0;
}
.omnia-evtchat__title {
flex: 1;
font-size: 0.8125rem !important;
font-weight: 700;
color: var(--text-color) !important;
line-height: 1.2 !important;
letter-spacing: 0.01em;
}
.omnia-evtchat__spinner {
width: 0.875rem;
height: 0.875rem;
border: 2px solid var(--border-color);
border-top-color: var(--primary-color);
border-radius: 50%;
animation: omnia-evtchat-spin 0.7s linear infinite;
flex-shrink: 0;
}
/* ── Cargar más (dentro del scroll, al inicio) ── */
.omnia-evtchat__load-more {
display: flex;
justify-content: center;
padding: 0.5rem 0.75rem 0.25rem;
flex-shrink: 0;
}
.omnia-evtchat__load-more-btn {
/* reset global button */
min-height: unset !important;
line-height: 1.4 !important;
letter-spacing: normal !important;
white-space: normal !important;
overflow: visible !important;
/* estilo link discreto */
display: inline-flex;
align-items: center;
gap: 0.3rem;
font-size: 0.6875rem;
font-weight: 500;
color: var(--text-muted) !important;
background: none !important;
border: none !important;
box-shadow: none !important;
cursor: pointer;
padding: 0.2rem 0.4rem;
border-radius: var(--radius-sm);
opacity: 0.55;
transition: opacity 150ms ease, color 150ms ease;
text-decoration: none;
}
.omnia-evtchat__load-more-btn:hover {
opacity: 1;
color: var(--primary-color) !important;
text-decoration: underline;
}
.omnia-evtchat__load-more-icon {
width: 10px;
height: 10px;
flex-shrink: 0;
}
/* ── Área de mensajes ── */
.omnia-evtchat__messages {
flex: 1;
overflow-y: auto;
padding: 0.25rem 0;
display: flex;
flex-direction: column;
gap: 0;
scrollbar-width: thin;
scrollbar-color: var(--border-color) transparent;
}
.omnia-evtchat__messages::-webkit-scrollbar      { width: 3px; }
.omnia-evtchat__messages::-webkit-scrollbar-track { background: transparent; }
.omnia-evtchat__messages::-webkit-scrollbar-thumb {
background: var(--border-color);
border-radius: 99px;
}
/* ── Estado vacío ── */
.omnia-evtchat__empty {
margin: auto;
padding: 2rem 1rem;
font-size: 0.75rem !important;
color: var(--text-muted) !important;
text-align: center;
opacity: 0.6;
line-height: 1.5 !important;
}
/* =======================================================================
FILAS DE MENSAJE
======================================================================= */
.omnia-evtchat__row {
display: flex;
align-items: flex-start;
padding: 0.3rem 0.75rem;
gap: 0.6rem;
transition: background-color 120ms ease;
}
.omnia-evtchat__row:hover {
background-color: var(--hover-background-color);
}
/* Propio: derecha, sin avatar */
.omnia-evtchat__row--own {
justify-content: flex-end;
padding-left: 3rem;
}
/* Ajeno: izquierda, con avatar */
.omnia-evtchat__row--other {
justify-content: flex-start;
padding-right: 3rem;
}
/* =======================================================================
AVATAR CON INICIALES
======================================================================= */
.omnia-evtchat__avatar {
width: 2rem;
height: 2rem;
min-width: 2rem;
border-radius: 50%;
background: var(--primary-color);
color: var(--primary-foreground, #fff);
font-size: 0.6rem;
font-weight: 800;
letter-spacing: 0.03em;
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
margin-top: 0.1rem;
user-select: none;
}
/* =======================================================================
CUERPO — MENSAJES AJENOS (feed style)
======================================================================= */
.omnia-evtchat__body {
display: flex;
flex-direction: column;
gap: 0.15rem;
min-width: 0;
flex: 1;
}
/* Fila meta: strip + nombre + hora */
.omnia-evtchat__meta {
display: flex;
align-items: baseline;
gap: 0.375rem;
flex-wrap: wrap;
line-height: 1;
}
.omnia-evtchat__strip {
display: inline-block;
font-size: 0.5625rem;
font-weight: 700;
padding: 0.1rem 0.35rem;
border-radius: 99px;
color: #fff;
text-transform: uppercase;
letter-spacing: 0.05em;
line-height: 1.4;
flex-shrink: 0;
}
/* Nombre como span (solo lectura) */
.omnia-evtchat__sender-name {
font-size: 0.8125rem !important;
font-weight: 700;
color: var(--text-color) !important;
line-height: 1.2 !important;
}
/* Nombre como botón (click → direct chat) — reset total de estilos globales */
.omnia-evtchat__sender-name--link {
/* reset botón global */
min-height: unset !important;
padding: 0 !important;
margin: 0 !important;
background: none !important;
border: none !important;
box-shadow: none !important;
border-radius: 0 !important;
letter-spacing: normal !important;
white-space: normal !important;
overflow: visible !important;
/* propios */
display: inline;
cursor: pointer;
font-size: 0.8125rem;
font-weight: 700;
color: var(--text-color);
line-height: 1.2;
transition: color 120ms ease;
text-decoration: none;
}
.omnia-evtchat__sender-name--link:hover {
color: var(--primary-color);
text-decoration: underline;
}
.omnia-evtchat__meta-time {
font-size: 0.6875rem !important;
color: var(--text-muted) !important;
font-variant-numeric: tabular-nums;
line-height: 1.2 !important;
flex-shrink: 0;
}
/* Texto del mensaje ajeno — limpio, sin burbuja */
.omnia-evtchat__text {
margin: 0 !important;
font-size: 0.875rem !important;
line-height: 1.5 !important;
color: var(--text-color) !important;
word-break: break-word;
}
/* =======================================================================
MENSAJE PROPIO — burbuja compacta
======================================================================= */
.omnia-evtchat__own-bubble {
display: flex;
flex-direction: column;
align-items: flex-end;
gap: 0.15rem;
max-width: 100%;
}
.omnia-evtchat__own-text {
margin: 0;
font-size: 0.875rem;
line-height: 1.5;
word-break: break-word;
padding: 0.45rem 0.75rem;
background: var(--primary-color) !important;
color: var(--primary-foreground, #fff) !important;
border-radius: 1rem 1rem 0.25rem 1rem;
max-width: 100%;
}
.omnia-evtchat__own-time {
font-size: 0.625rem !important;
color: var(--text-muted) !important;
font-variant-numeric: tabular-nums;
line-height: 1 !important;
padding-right: 0.125rem;
opacity: 0.75;
}
/* =======================================================================
INPUT ROW
======================================================================= */
.omnia-evtchat__input-row {
display: flex;
align-items: center;
gap: 0.375rem;
padding: 0.5rem 0.625rem;
border-top: 1px solid var(--border-color);
background: var(--surface-alt-color);
flex-shrink: 0;
}
/* Reset contra input:not([class*="app-"]) del sistema */
.omnia-evtchat__input {
margin: 0 !important;
width: auto !important;
box-shadow: none !important;
min-height: unset !important;
resize: none;
/* propios */
flex: 1;
min-width: 0;
font-size: 0.8125rem !important;
line-height: 1.45 !important;
padding: 0.45rem 0.75rem;
border: 1px solid var(--border-color);
border-radius: var(--radius-md);
background-color: var(--surface-color);
color: var(--text-color) !important;
outline: none;
font-family: inherit;
transition: border-color 150ms ease, box-shadow 150ms ease;
}
.omnia-evtchat__input::placeholder { color: var(--text-muted); opacity: 1; }
.omnia-evtchat__input:focus {
border-color: var(--primary-color);
box-shadow: 0 0 0 2px color-mix(in srgb, var(--primary-color) 20%, transparent) !important;
}
.omnia-evtchat__input:disabled { opacity: 0.5; cursor: not-allowed; }
/* =======================================================================
BOTÓN ENVIAR — reset total contra estilos globales
======================================================================= */
.omnia-evtchat__send-btn {
/* reset global button */
min-height: unset !important;
padding: 0 !important;
line-height: 1 !important;
letter-spacing: normal !important;
font-size: inherit !important;
font-weight: normal !important;
white-space: normal !important;
overflow: visible !important;
/* propios */
display: flex !important;
align-items: center !important;
justify-content: center !important;
width: 2rem !important;
height: 2rem !important;
flex-shrink: 0;
background: var(--primary-color) !important;
border: none !important;
border-radius: 50% !important;
color: var(--primary-foreground, #fff) !important;
cursor: pointer;
transition: opacity 150ms ease, transform 150ms ease;
}
/* Reset contra img,picture,video,canvas,svg { display:block; max-width:100% } */
.omnia-evtchat__send-btn svg {
display: inline-flex !important;
max-width: none !important;
width: 0.9rem !important;
height: 0.9rem !important;
flex-shrink: 0;
pointer-events: none;
stroke: var(--primary-foreground, #fff) !important;
color: var(--primary-foreground, #fff) !important;
}
.omnia-evtchat__send-btn:hover:not(:disabled) {
opacity: 0.85;
transform: scale(1.06);
}
.omnia-evtchat__send-btn:active:not(:disabled) {
transform: scale(0.93);
}
.omnia-evtchat__send-btn:disabled {
background: var(--disabled-background) !important;
cursor: not-allowed;
opacity: 0.5;
}
.omnia-evtchat__send-btn:disabled svg {
stroke: var(--disabled-color) !important;
color: var(--disabled-color) !important;
}
/* =======================================================================
ANIMACIONES (nombres únicos con prefijo omnia-evtchat)
======================================================================= */
@keyframes omnia-evtchat-pulse {
0%, 100% { opacity: 1;   transform: scale(1); }
50%       { opacity: 0.3; transform: scale(0.7); }
}
@keyframes omnia-evtchat-spin {
to { transform: rotate(360deg); }
}
/* =======================================================================
RESPONSIVE
======================================================================= */
@media (max-width: 480px) {
.omnia-evtchat__row--own   { padding-left: 1.5rem; }
.omnia-evtchat__row--other { padding-right: 1.5rem; }
.omnia-evtchat__text,
.omnia-evtchat__own-text { font-size: 0.8125rem !important; }
}
/* =======================================================================
SEPARADOR DE FECHA
======================================================================= */
.omnia-evtchat__date-sep {
display: flex;
align-items: center;
gap: 0.5rem;
margin: 0.75rem 0.25rem;
}
.omnia-evtchat__date-sep::before,
.omnia-evtchat__date-sep::after {
content: "";
flex: 1;
height: 1px;
background-color: var(--border-color);
opacity: 0.5;
}
.omnia-evtchat__date-sep-label {
flex-shrink: 0;
font-size: 0.6875rem !important;
font-weight: 600;
color: var(--text-muted) !important;
text-transform: uppercase;
letter-spacing: 0.04em;
white-space: nowrap;
}
/* =======================================================================
MODAL CONFIRMACIÓN CHAT 1:1
======================================================================= */
.omnia-evtchat__confirm-text {
font-size: 0.9375rem !important;
color: var(--text-color) !important;
line-height: 1.5;
margin: 0 !important;
}
/* app-realtime-event-interactivity.css — BEM: art-interactivity */
/* ── Contenedor principal ── */
.art-interactivity {
display: flex;
flex-direction: column;
gap: 1.25rem;
padding: 0.25rem 0;
}
/* ── Countdown ── */
.art-interactivity__countdown-row {
display: flex;
align-items: center;
gap: 0.75rem;
}
.art-interactivity__countdown {
position: relative;
width: 2.75rem;
height: 2.75rem;
flex-shrink: 0;
}
.art-interactivity__countdown-ring {
width: 100%;
height: 100%;
transform: rotate(-90deg);
}
.art-interactivity__countdown-ring-track {
fill: none;
stroke: var(--border-color);
stroke-width: 3.5;
}
.art-interactivity__countdown-ring-progress {
fill: none;
stroke-width: 3.5;
stroke-linecap: round;
transition: stroke-dashoffset 0.9s linear, stroke 0.3s ease;
}
.art-interactivity__countdown--normal .art-interactivity__countdown-ring-progress {
stroke: var(--accent-color);
}
.art-interactivity__countdown--urgent .art-interactivity__countdown-ring-progress {
stroke: var(--error-foreground);
}
.art-interactivity__countdown-number {
position: absolute;
inset: 0;
display: flex;
align-items: center;
justify-content: center;
font-size: 0.8125rem;
font-weight: 700;
color: var(--foreground-color);
line-height: 1;
transition: color 0.3s ease;
}
.art-interactivity__countdown--urgent .art-interactivity__countdown-number {
color: var(--error-foreground);
}
.art-interactivity__countdown-label {
font-size: 0.8125rem;
color: var(--muted-foreground);
line-height: 1.4;
}
/* ── Imagen opcional de la pregunta ── */
.art-interactivity__image {
width: 100%;
max-height: 12rem;
object-fit: cover;
border-radius: var(--radius-sm);
margin-bottom: 0.25rem;
}
/* ── Pregunta ── */
.art-interactivity__question {
margin: 0;
font-size: 1rem;
font-weight: 600;
color: var(--foreground-color);
line-height: 1.5;
}
/* ── Opciones ── */
.art-interactivity__options {
display: flex;
flex-direction: column;
gap: 0.625rem;
}
.art-interactivity__option {
display: flex;
align-items: center;
gap: 0.75rem;
padding: 0.75rem 1rem;
background-color: var(--section-background);
border: 2px solid var(--border-color);
border-radius: 0.625rem;
cursor: pointer;
text-align: left;
width: 100%;
transition: border-color 0.15s ease, background-color 0.15s ease, transform 0.1s ease;
}
.art-interactivity__option:hover:not(:disabled) {
border-color: var(--accent-color);
background-color: var(--hover-background);
}
.art-interactivity__option:active:not(:disabled) {
transform: scale(0.99);
}
.art-interactivity__option:disabled {
opacity: 0.55;
cursor: not-allowed;
}
.art-interactivity__option--selected {
border-color: var(--accent-color);
background-color: var(--info-background);
}
/* Radio visual */
.art-interactivity__option-radio {
width: 1.125rem;
height: 1.125rem;
border-radius: 50%;
border: 2px solid var(--border-color);
flex-shrink: 0;
transition: border-color 0.15s ease, background-color 0.15s ease;
position: relative;
}
.art-interactivity__option--selected .art-interactivity__option-radio {
border-color: var(--accent-color);
background-color: var(--accent-color);
}
.art-interactivity__option--selected .art-interactivity__option-radio::after {
content: '';
position: absolute;
inset: 0.2rem;
background-color: var(--accent-foreground, #fff);
border-radius: 50%;
}
.art-interactivity__option-text {
font-size: 0.9375rem;
color: var(--foreground-color);
line-height: 1.4;
flex: 1;
}
/* ── Error ── */
.art-interactivity__error {
margin: 0;
font-size: 0.8125rem;
color: var(--error-foreground);
padding: 0.5rem 0.75rem;
background-color: var(--error-background);
border-radius: 0.375rem;
}
/* ── Footer ── */
.art-interactivity__answered-badge {
display: flex;
align-items: center;
gap: 0.375rem;
font-size: 0.9375rem;
font-weight: 600;
color: var(--success-foreground);
}
.art-interactivity__answered-badge svg {
width: 1.125rem;
height: 1.125rem;
}
.art-interactivity__cancel-btn {
padding: 0.5rem 1.25rem;
background: none;
border: 1px solid var(--border-color);
border-radius: 0.5rem;
color: var(--muted-foreground);
font-size: 0.875rem;
cursor: pointer;
transition: background-color 0.15s ease;
}
.art-interactivity__cancel-btn:hover:not(:disabled) {
background-color: var(--hover-background);
}
.art-interactivity__submit-btn {
display: flex;
align-items: center;
gap: 0.5rem;
padding: 0.5rem 1.5rem;
background-color: var(--accent-color);
border: none;
border-radius: 0.5rem;
color: var(--accent-foreground, #fff);
font-size: 0.875rem;
font-weight: 600;
cursor: pointer;
transition: opacity 0.15s ease, transform 0.1s ease;
}
.art-interactivity__submit-btn:hover:not(:disabled) {
opacity: 0.88;
}
.art-interactivity__submit-btn:active:not(:disabled) {
transform: scale(0.98);
}
.art-interactivity__submit-btn:disabled {
opacity: 0.45;
cursor: not-allowed;
}
/* Spinner en el botón */
.art-interactivity__btn-spinner {
width: 0.9rem;
height: 0.9rem;
border: 2px solid rgba(255, 255, 255, 0.4);
border-top-color: #fff;
border-radius: 50%;
animation: art-interactivity-spin 0.7s linear infinite;
}
/* ── Animaciones ── */
@keyframes art-interactivity-spin {
to { transform: rotate(360deg); }
}
/* ── Responsive ── */
@media (max-width: 480px) {
.art-interactivity__question {
font-size: 0.9375rem;
}
.art-interactivity__option {
padding: 0.625rem 0.75rem;
}
.art-interactivity__option-text {
font-size: 0.875rem;
}
}
/* app-realtime-event-news.css — BEM: app-realtime-event-news */
.app-realtime-event-news {
width: 100%;
background-color: var(--card-background);
border: 1px solid var(--border-color);
border-radius: 0.5rem;
overflow: hidden;
}
/* Header */
.app-realtime-event-news__header {
display: flex;
align-items: center;
gap: 0.5rem;
padding: 0.625rem 1rem;
background-color: var(--section-background);
border-bottom: 1px solid var(--border-color);
}
.app-realtime-event-news__live-dot {
width: 0.5rem;
height: 0.5rem;
background-color: var(--error-foreground);
border-radius: 50%;
animation: realtime-pulse 1.4s ease-in-out infinite;
flex-shrink: 0;
}
.app-realtime-event-news__live-label {
font-size: 0.6875rem;
font-weight: 700;
letter-spacing: 0.05em;
color: var(--error-foreground);
text-transform: uppercase;
}
.app-realtime-event-news__title {
font-size: 0.8125rem;
font-weight: 600;
color: var(--foreground-color);
}
/* Lista */
.app-realtime-event-news__list {
list-style: none;
margin: 0;
padding: 0;
max-height: 20rem;
overflow-y: auto;
}
.app-realtime-event-news__item {
padding: 0.75rem 1rem;
border-bottom: 1px solid var(--border-color);
transition: background-color 0.15s ease;
}
.app-realtime-event-news__item:last-child { border-bottom: none; }
.app-realtime-event-news__item:hover { background-color: var(--hover-background); }
.app-realtime-event-news__item-header {
display: flex;
justify-content: space-between;
align-items: baseline;
gap: 0.5rem;
margin-bottom: 0.25rem;
}
.app-realtime-event-news__item-title {
font-size: 0.8125rem;
font-weight: 600;
color: var(--foreground-color);
line-height: 1.3;
}
.app-realtime-event-news__item-time {
font-size: 0.6875rem;
color: var(--muted-foreground);
white-space: nowrap;
flex-shrink: 0;
}
.app-realtime-event-news__item-message {
margin: 0;
font-size: 0.8125rem;
color: var(--muted-foreground);
line-height: 1.5;
}
/* Animación dot */
@keyframes realtime-pulse {
0%, 100% { opacity: 1; }
50%       { opacity: 0.3; }
}
/* Responsive */
@media (max-width: 640px) {
.app-realtime-event-news__list { max-height: 15rem; }
}
/* app-realtime-user-chats.css — BEM: art-user-chats */
/* ── FAB globo ── */
.art-user-chats__fab {
position: fixed;
bottom: 1.5rem;
right: 1.5rem;
z-index: 999;
display: flex;
align-items: center;
justify-content: center;
width: 3.25rem;
height: 3.25rem;
background-color: var(--accent-color);
border: none;
border-radius: 50%;
color: var(--accent-foreground, #fff);
cursor: pointer;
transition: opacity 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
}
.art-user-chats__fab svg { width: 1.5rem; height: 1.5rem; }
.art-user-chats__fab:hover { opacity: 0.9; transform: scale(1.05); }
.art-user-chats__fab--unread { animation: art-uc-fab-bounce 2.5s ease-in-out infinite; }
.art-user-chats__fab-badge {
position: absolute;
top: -0.2rem;
right: -0.2rem;
background-color: var(--danger-color);
color: #fff;
font-size: 0.625rem;
font-weight: 700;
min-width: 1.125rem;
height: 1.125rem;
border-radius: 1rem;
display: flex;
align-items: center;
justify-content: center;
padding: 0 0.25rem;
border: 2px solid var(--card-bg-color);
line-height: 1;
}
/* ── Backdrop ── */
.art-user-chats__backdrop {
position: fixed;
inset: 0;
background-color: rgba(0, 0, 0, 0.45);
z-index: 1000;
animation: art-uc-fade-in 0.2s ease;
}
/* ── Panel principal ── */
.art-user-chats__panel {
position: fixed;
bottom: 1rem;
right: 1rem;
width: min(52rem, calc(100vw - 2rem));
height: min(40rem, calc(100vh - 2rem));
background-color: var(--card-bg-color);
border: 1px solid var(--border-color);
border-radius: 0.75rem;
box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
z-index: 1001;
display: flex;
overflow: hidden;
animation: art-uc-slide-up 0.2s ease;
}
/* ── Sidebar ── */
.art-user-chats__sidebar {
width: 16rem;
flex-shrink: 0;
border-right: 1px solid var(--border-color);
display: flex;
flex-direction: column;
background-color: var(--surface-alt-color);
transition: transform 0.2s ease;
}
.art-user-chats__sidebar-header {
display: flex;
align-items: center;
justify-content: space-between;
padding: 0.875rem 1rem;
border-bottom: 1px solid var(--border-color);
flex-shrink: 0;
}
.art-user-chats__sidebar-title {
font-size: 0.9375rem;
font-weight: 700;
color: var(--text-color);
}
.art-user-chats__close-btn {
display: flex;
align-items: center;
justify-content: center;
width: 1.75rem;
height: 1.75rem;
background: none;
border: none;
border-radius: 50%;
color: var(--text-muted);
cursor: pointer;
transition: background-color 0.15s ease;
}
.art-user-chats__close-btn svg { width: 1rem; height: 1rem; }
.art-user-chats__close-btn:hover { background-color: var(--hover-background-color); }
.art-user-chats__sidebar-empty {
padding: 1.5rem 1rem;
font-size: 0.8125rem;
color: var(--text-muted);
text-align: center;
}
.art-user-chats__sidebar-loading {
display: flex;
justify-content: center;
align-items: center;
padding: 1.25rem;
flex-shrink: 0;
}
/* Lista de conversaciones */
.art-user-chats__conv-list {
flex: 1;
overflow-y: auto;
list-style: none;
margin: 0;
padding: 0;
}
.art-user-chats__conv-item {
display: flex;
align-items: center;
gap: 0.75rem;
padding: 0.75rem 1rem;
cursor: pointer;
border-bottom: 1px solid var(--border-color);
transition: background-color 0.15s ease;
user-select: none;
}
.art-user-chats__conv-item:last-child { border-bottom: none; }
.art-user-chats__conv-item:hover { background-color: var(--hover-background-color); }
.art-user-chats__conv-item--active { background-color: var(--sidebar-active-bg); }
.art-user-chats__conv-avatar {
width: 2.5rem;
height: 2.5rem;
border-radius: 50%;
background-color: var(--accent-color);
color: var(--accent-foreground, #fff);
font-size: 1rem;
font-weight: 700;
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
position: relative;
transition: box-shadow 0.2s ease;
}
/* Indicador de mensaje nuevo en el avatar del peer */
.art-user-chats__conv-avatar--unread::after {
content: '';
position: absolute;
top: -0.125rem;
right: -0.125rem;
width: 0.6rem;
height: 0.6rem;
border-radius: 50%;
background-color: var(--danger-color, #e53e3e);
border: 2px solid var(--surface-alt-color, var(--card-bg-color));
}
.art-user-chats__conv-info {
flex: 1;
min-width: 0;
display: flex;
flex-direction: column;
gap: 0.125rem;
}
/* Prefijo "Tú:" en el preview */
.art-user-chats__conv-preview-you {
font-weight: 600;
color: var(--text-color);
margin-right: 0.1rem;
}
.art-user-chats__conv-name {
font-size: 0.875rem;
font-weight: 600;
color: var(--text-color);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.art-user-chats__conv-preview {
font-size: 0.75rem;
color: var(--text-muted);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.art-user-chats__conv-badge {
background-color: var(--accent-color);
color: var(--accent-foreground, #fff);
font-size: 0.625rem;
font-weight: 700;
min-width: 1.125rem;
height: 1.125rem;
border-radius: 1rem;
display: flex;
align-items: center;
justify-content: center;
padding: 0 0.25rem;
flex-shrink: 0;
line-height: 1;
}
/* ── Ventana de chat activo ── */
.art-user-chats__window {
flex: 1;
display: flex;
flex-direction: column;
min-width: 0;
}
.art-user-chats__window-header {
display: flex;
align-items: center;
gap: 0.625rem;
padding: 0.75rem 1rem;
border-bottom: 1px solid var(--border-color);
background-color: var(--surface-alt-color);
flex-shrink: 0;
}
.art-user-chats__back-btn {
display: none; /* visible solo en mobile */
align-items: center;
justify-content: center;
width: 1.75rem;
height: 1.75rem;
background: none;
border: none;
border-radius: 50%;
color: var(--text-muted);
cursor: pointer;
transition: background-color 0.15s ease;
}
.art-user-chats__back-btn svg { width: 1.125rem; height: 1.125rem; }
.art-user-chats__back-btn:hover { background-color: var(--hover-background-color); }
.art-user-chats__window-avatar {
width: 2rem;
height: 2rem;
border-radius: 50%;
background-color: var(--accent-color);
color: var(--accent-foreground, #fff);
font-size: 0.875rem;
font-weight: 700;
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
}
.art-user-chats__window-peer-name {
font-size: 0.9375rem;
font-weight: 600;
color: var(--text-color);
flex: 1;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
/* Cargar más mensajes — sticky al inicio del contenedor de mensajes */
.art-user-chats__load-more-msgs {
display: flex;
justify-content: center;
padding: 0.25rem;
flex-shrink: 0;
position: sticky;
top: 0;
z-index: 1;
background-color: var(--card-bg-color);
}
.art-user-chats__loading-msgs {
display: flex;
justify-content: center;
padding: 0.5rem;
flex-shrink: 0;
}
/* Cargar más */
.art-user-chats__load-more {
display: flex;
justify-content: center;
padding: 0.375rem;
border-bottom: 1px solid var(--border-color);
flex-shrink: 0;
}
.art-user-chats__load-more-btn {
font-size: 0.75rem;
color: var(--accent-color);
background: none;
border: none;
cursor: pointer;
padding: 0.25rem 0.75rem;
border-radius: 1rem;
transition: background-color 0.15s ease;
}
.art-user-chats__load-more-btn:hover { background-color: var(--hover-background-color); }
.art-user-chats__loading-msgs {
display: flex;
justify-content: center;
padding: 0.5rem;
flex-shrink: 0;
}
.art-user-chats__spinner {
width: 1rem;
height: 1rem;
border: 2px solid var(--border-color);
border-top-color: var(--accent-color);
border-radius: 50%;
animation: art-uc-spin 0.7s linear infinite;
}
/* Mensajes */
.art-user-chats__messages {
flex: 1;
overflow-y: auto;
padding: 0.75rem;
display: flex;
flex-direction: column;
gap: 0.5rem;
scroll-behavior: smooth;
}
.art-user-chats__messages-empty {
margin: auto;
font-size: 0.8125rem;
color: var(--text-muted);
text-align: center;
}
/* Burbujas */
.art-user-chats__bubble {
max-width: 72%;
display: flex;
flex-direction: column;
gap: 0.2rem;
}
.art-user-chats__bubble--own { align-self: flex-end; align-items: flex-end; }
.art-user-chats__bubble--other { align-self: flex-start; align-items: flex-start; }
/* ── Variables de contraste para burbujas de chat (independientes del accent global) ── */
:root {
--art-bubble-own-bg:   #1d44cc;
--art-bubble-own-text: #ffffff;
--art-bubble-other-bg: #e4e6eb;
--art-bubble-other-text: #111827;
}
[data-theme="dark"], :root[data-theme='dark'] {
--art-bubble-own-bg:   #2d55e0;
--art-bubble-own-text: #ffffff;
--art-bubble-other-bg: #2a2d36;
--art-bubble-other-text: #e8eaf0;
}
@media (prefers-color-scheme: dark) {
:root:not([data-theme='light']) {
--art-bubble-own-bg:   #2d55e0;
--art-bubble-own-text: #ffffff;
--art-bubble-other-bg: #2a2d36;
--art-bubble-other-text: #e8eaf0;
}
}
.art-user-chats__bubble-text {
margin: 0 !important;
font-size: 0.875rem !important;
line-height: 1.5 !important;
word-break: break-word !important;
padding: 0.5rem 0.875rem !important;
border-radius: 1rem !important;
color: var(--text-color) !important;
}
.art-user-chats__bubble--own .art-user-chats__bubble-text {
background-color: var(--art-bubble-own-bg) !important;
color: var(--art-bubble-own-text) !important;
border-bottom-right-radius: 0.25rem !important;
}
.art-user-chats__bubble--other .art-user-chats__bubble-text {
background-color: var(--art-bubble-other-bg) !important;
color: var(--art-bubble-other-text) !important;
border-bottom-left-radius: 0.25rem !important;
}
.art-user-chats__bubble-time {
font-size: 0.6875rem;
color: var(--text-muted);
padding: 0 0.25rem;
}
/* Ventana vacía */
.art-user-chats__window-empty {
flex: 1;
display: flex;
align-items: center;
justify-content: center;
padding: 2rem;
}
.art-user-chats__window-empty p {
font-size: 0.875rem;
color: var(--text-muted);
text-align: center;
}
/* Input */
.art-user-chats__input-row {
display: flex;
align-items: center;
gap: 0.5rem;
padding: 0.625rem 0.75rem;
border-top: 1px solid var(--border-color);
background-color: var(--surface-alt-color);
flex-shrink: 0;
}
.art-user-chats__input {
flex: 1;
padding: 0.5rem 0.875rem;
border: 1px solid var(--border-color);
border-radius: 1.5rem;
background-color: var(--surface-color);
color: var(--text-color);
font-size: 0.875rem;
outline: none;
transition: border-color 0.15s ease;
min-width: 0;
}
.art-user-chats__input:focus { border-color: var(--accent-color); }
.art-user-chats__input:disabled { opacity: 0.6; cursor: not-allowed; }
.art-user-chats__send-btn {
display: flex;
align-items: center;
justify-content: center;
width: 2.25rem;
height: 2.25rem;
background-color: var(--accent-color);
border: none;
border-radius: 50%;
color: var(--accent-foreground, #fff);
cursor: pointer;
transition: opacity 0.15s ease, transform 0.1s ease;
flex-shrink: 0;
}
.art-user-chats__send-btn svg { width: 1rem; height: 1rem; }
.art-user-chats__send-btn:hover:not(:disabled) { opacity: 0.85; transform: scale(1.05); }
.art-user-chats__send-btn:disabled { opacity: 0.4; cursor: not-allowed; }
/* ── Animaciones ── */
@keyframes art-uc-fab-bounce {
0%, 100% { transform: scale(1); }
50%       { transform: scale(1.08); }
}
@keyframes art-uc-fade-in {
from { opacity: 0; }
to   { opacity: 1; }
}
@keyframes art-uc-slide-up {
from { opacity: 0; transform: translateY(1rem); }
to   { opacity: 1; transform: translateY(0); }
}
@keyframes art-uc-spin {
to { transform: rotate(360deg); }
}
/* ── Responsive ── */
@media (max-width: 640px) {
.art-user-chats__panel {
bottom: 0;
right: 0;
width: 100vw;
height: 100dvh;
border-radius: 0;
}
/* En mobile: el sidebar ocupa toda la pantalla */
.art-user-chats__sidebar {
width: 100%;
border-right: none;
}
/* Cuando hay conversación activa, ocultar sidebar y mostrar window */
.art-user-chats__sidebar--hidden-mobile {
display: none;
}
.art-user-chats__window {
width: 100%;
}
.art-user-chats__back-btn {
display: flex;
}
.art-user-chats__bubble { max-width: 88%; }
}
@media (min-width: 641px) {
.art-user-chats__window--visible {
display: flex;
}
}
/* ==============================================
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.8rem;
line-height: 1.4;
margin-bottom: 0.75rem;
padding: 0.4rem 0.65rem;
background: var(--surface-alt-color);
border-radius: 0.4rem;
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;
}
/* ============================================== */
/* Móvil muy pequeño (420px - 479px)             */
/* ============================================== */
@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;
}
/* ============================================
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 */
/* ==================== NUEVAS CLASES v3 (Phase 5) ==================== */
/* Warning Ã¢â‚¬â€ cuando ya existe un CFDI vÃƒÂ¡lido */
.stampPaymentModal__warning {
padding: var(--spacing-md);
background: var(--warning-background);
border: 1px solid var(--warning-color);
border-radius: var(--border-radius);
display: flex;
flex-direction: column;
gap: var(--spacing-sm);
}
.stampPaymentModal__warning-title {
font-weight: 700;
color: var(--warning-color);
margin: 0;
font-size: 0.95rem;
}
.stampPaymentModal__warning-hint {
color: var(--text-color);
font-size: 0.85rem;
margin: 0;
}
/* Form Ã¢â‚¬â€ selecciÃƒÂ³n de FormaPago */
.stampPaymentModal__form {
display: flex;
flex-direction: column;
gap: var(--spacing-md);
}
.stampPaymentModal__form-hint {
color: var(--text-muted);
font-size: 0.825rem;
margin: 0;
line-height: 1.5;
}
/* Info rows Ã¢â‚¬â€ para mostrar UUID, folio, PAC */
.stampPaymentModal__info-row {
display: flex;
align-items: baseline;
gap: 0.5rem;
padding: 0.35rem 0;
border-bottom: 1px solid var(--border-color);
font-size: 0.875rem;
}
.stampPaymentModal__info-row:last-child { border-bottom: none; }
.stampPaymentModal__info-label {
color: var(--text-muted);
font-size: 0.775rem;
font-weight: 600;
white-space: nowrap;
min-width: 60px;
}
.stampPaymentModal__info-value {
color: var(--text-color);
font-weight: 500;
font-family: 'Courier New', monospace;
font-size: 0.825rem;
word-break: break-all;
}
/* Success state */
.stampPaymentModal__success {
padding: var(--spacing-lg);
background: var(--success-background);
border: 1px solid var(--success-color);
border-radius: var(--border-radius);
display: flex;
flex-direction: column;
gap: var(--spacing-sm);
}
.stampPaymentModal__success-title {
font-weight: 700;
color: var(--success-color);
margin: 0 0 var(--spacing-sm) 0;
font-size: 1rem;
}
.stampPaymentModal__success-hint {
color: var(--text-muted);
font-size: 0.825rem;
margin: 0;
}
/* Error state (simplified) */
.stampPaymentModal__error-title {
font-weight: 700;
color: var(--danger-color);
margin: 0 0 var(--spacing-sm) 0;
}
.stampPaymentModal__error-message {
color: var(--text-color);
font-size: 0.875rem;
margin: 0;
}
.stampPaymentModal__error-hint {
color: var(--text-muted);
font-size: 0.8rem;
margin: var(--spacing-sm) 0 0 0;
}
/* -- AcordeÃ³n de datos fiscales (step Configure) ---------------------- */
.stampPaymentModal__fiscal-accordion {
margin-top: var(--spacing-lg);
border: 1px solid var(--border-color);
border-radius: var(--border-radius);
overflow: hidden;
}
.stampPaymentModal__fiscal-toggle {
display: flex;
align-items: center;
justify-content: space-between;
width: 100%;
padding: var(--spacing-sm) var(--spacing-md);
background: var(--surface-alt);
border: none;
cursor: pointer;
font-size: 0.82rem;
font-weight: 600;
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: 0.04em;
transition: background 0.15s, color 0.15s;
}
.stampPaymentModal__fiscal-toggle:hover {
background: color-mix(in srgb, var(--primary-color) 8%, var(--surface-alt));
color: var(--primary-color);
}
.stampPaymentModal__fiscal-chevron {
width: 1rem;
height: 1rem;
flex-shrink: 0;
transition: transform 0.2s ease;
}
.stampPaymentModal__fiscal-accordion--open .stampPaymentModal__fiscal-chevron {
transform: rotate(180deg);
}
.stampPaymentModal__fiscal-body {
padding: var(--spacing-md);
border-top: 1px solid var(--border-color);
background: var(--surface);
}
.stampPaymentModal__fiscal-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: var(--spacing-md);
}
@media (max-width: 540px) {
.stampPaymentModal__fiscal-grid {
grid-template-columns: 1fr;
}
}
.stampPaymentModal__fiscal-actions {
display: flex;
justify-content: flex-end;
margin-top: var(--spacing-md);
}
.stampPaymentModal__error-inline {
margin-top: var(--spacing-md);
padding: var(--spacing-sm) var(--spacing-md);
background: var(--danger-background);
color: var(--danger-foreground);
border: 1px solid color-mix(in srgb, var(--danger-color) 35%, transparent);
border-radius: var(--border-radius);
font-size: 0.85rem;
}
.stampPaymentModal__loading--inline {
flex-direction: row;
padding: var(--spacing-sm) 0;
gap: var(--spacing-sm);
justify-content: flex-start;
}
.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; }
/* ================================================================
AppEventFloorPlan — BEM: app-floor-plan
CSS en SHARED/wwwroot/css/components/ui/appEventFloorPlan.css
================================================================ */
.app-floor-plan {
display: flex;
flex-direction: column;
gap: 1rem;
width: 100%;
}
/* ── Estados globales ───────────────────────────────────── */
.app-floor-plan__loading,
.app-floor-plan__loading-detail {
display: flex;
justify-content: center;
padding: 2rem;
}
.app-floor-plan__error {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.75rem;
padding: 1.5rem;
color: var(--danger-foreground);
background: var(--danger-background);
border-radius: 8px;
font-size: 0.9rem;
text-align: center;
}
.app-floor-plan__empty {
padding: 2rem;
text-align: center;
color: var(--text-secondary);
font-size: 0.9rem;
}
/* ── Título cuando hay una sola sala ────────────────────── */
.app-floor-plan__room-title {
font-size: 1rem;
font-weight: 600;
color: var(--text-primary);
}
/* ── Tabs de selección de sala ──────────────────────────── */
.app-floor-plan__tabs {
display: flex;
flex-wrap: wrap;
gap: 0.5rem;
}
.app-floor-plan__tab {
padding: 0.4rem 1rem;
border-radius: 20px;
border: 1.5px solid var(--border-color);
background: transparent;
color: var(--text-secondary);
font-size: 0.875rem;
font-weight: 500;
cursor: pointer;
transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.app-floor-plan__tab:hover {
background: var(--hover-background);
color: var(--text-primary);
}
.app-floor-plan__tab--active {
background: var(--color-primary);
border-color: var(--color-primary);
color: var(--card-background);
}
.app-floor-plan__tab--active:hover {
background: var(--color-primary);
color: var(--card-background);
}
/* ── Resumen del slot seleccionado ──────────────────────── */
.app-floor-plan__slot-summary {
display: flex;
flex-wrap: wrap;
align-items: center;
gap: 0.4rem 0.75rem;
padding: 0.6rem 1rem;
border-radius: 8px;
background: var(--success-background);
color: var(--success-foreground);
font-size: 0.875rem;
}
.app-floor-plan__slot-summary-label {
font-weight: 600;
}
/* ── Responsivo ─────────────────────────────────────────── */
@media (max-width: 600px) {
.app-floor-plan__tabs {
gap: 0.4rem;
}
.app-floor-plan__tab {
font-size: 0.8rem;
padding: 0.35rem 0.75rem;
}
.app-floor-plan__slot-summary {
font-size: 0.8rem;
padding: 0.5rem 0.75rem;
}
}
/* =======================================================================
AppEventSeries — Panel de series CFDI por línea de negocio
BEM namespace: appEventSeries
======================================================================= */
/* ── CONTENEDOR ──────────────────────────────────────────────────────── */
.appEventSeries {
display: flex;
flex-direction: column;
gap: 1.25rem;
}
.appEventSeries__header {
padding-bottom: 0.75rem;
border-bottom: 1px solid var(--border-color);
}
.appEventSeries__hint {
font-size: 0.875rem;
color: var(--text-secondary);
margin: 0;
line-height: 1.5;
}
/* ── ESTADOS ─────────────────────────────────────────────────────────── */
.appEventSeries__loading,
.appEventSeries__modal-loading {
display: flex;
align-items: center;
justify-content: center;
gap: 0.75rem;
padding: 2.5rem 1rem;
color: var(--text-secondary);
}
.appEventSeries__loading-inline {
display: flex;
justify-content: center;
padding: 1rem;
}
.appEventSeries__error {
background: var(--danger-background);
color: var(--danger-color);
border: 1px solid var(--danger-color);
border-radius: var(--radius-md);
padding: 0.875rem 1rem;
font-size: 0.875rem;
}
.appEventSeries__empty-hint {
color: var(--text-muted);
font-size: 0.875rem;
font-style: italic;
text-align: center;
padding: 1rem 0;
}
/* ── GRILLA DE LÍNEAS ────────────────────────────────────────────────── */
.appEventSeries__grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
gap: 0.875rem;
}
.appEventSeries__line {
display: flex;
flex-direction: column;
gap: 0.625rem;
padding: 1rem;
border-radius: var(--radius-md);
border: 1.5px solid var(--border-color);
background: var(--surface-color);
transition: border-color var(--transition-base), box-shadow var(--transition-base);
}
.appEventSeries__line--assigned {
border-color: var(--success-color);
background: var(--surface-color);
box-shadow: 0 0 0 1px rgba(34, 197, 94, 0.12);
}
.appEventSeries__line--empty {
border-color: var(--border-color);
border-style: dashed;
opacity: 0.85;
}
/* ── CABECERA DE LÍNEA ───────────────────────────────────────────────── */
.appEventSeries__line-header {
display: flex;
align-items: center;
justify-content: space-between;
gap: 0.5rem;
}
.appEventSeries__line-name {
font-size: 0.9375rem;
font-weight: 600;
color: var(--text-color);
}
/* Acciones por línea */
.appEventSeries__line-actions {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
margin-top: auto;
padding-top: 0.5rem;
}
/* ── BADGES ──────────────────────────────────────────────────────────── */
.appEventSeries__badge {
display: inline-flex;
align-items: center;
padding: 0.2rem 0.5rem;
border-radius: var(--radius-pill);
font-size: 0.6875rem;
font-weight: 600;
letter-spacing: 0.02em;
flex-shrink: 0;
}
.appEventSeries__badge--success {
background: var(--success-background);
color: var(--success-color);
}
.appEventSeries__badge--warning {
background: var(--warning-background);
color: var(--warning-color);
}
/* ── FORMULARIO MODAL ────────────────────────────────────────────────── */
.appEventSeries__assign-form {
display: flex;
flex-direction: column;
gap: 1rem;
}
.appEventSeries__tabs {
display: flex;
border: 1px solid var(--border-color);
border-radius: var(--radius-md);
overflow: hidden;
}
.appEventSeries__tab {
flex: 1;
padding: 0.625rem 1rem;
font-size: 0.875rem;
font-weight: 500;
background: var(--surface-color);
color: var(--text-secondary);
border: none;
cursor: pointer;
transition: background var(--transition-fast), color var(--transition-fast);
}
.appEventSeries__tab:not(:last-child) {
border-right: 1px solid var(--border-color);
}
.appEventSeries__tab--active {
background: var(--primary-color);
color: var(--primary-foreground);
}
.appEventSeries__tab:not(.appEventSeries__tab--active):hover {
background: var(--hover-background-color);
color: var(--primary-color);
}
/* Grupos de campo */
.appEventSeries__form-group {
display: flex;
flex-direction: column;
gap: 0.375rem;
}
.appEventSeries__form-group--narrow {
max-width: 140px;
}
.appEventSeries__form-row {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 0.75rem;
}
.appEventSeries__form-label {
font-size: 0.875rem;
font-weight: 500;
color: var(--text-secondary);
}
/* Error inline del form */
.appEventSeries__form-error {
background: var(--danger-background);
color: var(--danger-color);
border-left: 3px solid var(--danger-color);
border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
padding: 0.5rem 0.75rem;
font-size: 0.875rem;
}
/* Acciones del form */
.appEventSeries__form-actions {
display: flex;
justify-content: flex-end;
gap: 0.625rem;
padding-top: 0.75rem;
border-top: 1px solid var(--border-color);
}
/* ── MODAL CONFIRMAR ─────────────────────────────────────────────────── */
.appEventSeries__confirm {
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.appEventSeries__confirm p {
font-size: 0.9375rem;
color: var(--text-color);
margin: 0;
}
.appEventSeries__confirm-hint {
font-size: 0.8125rem;
color: var(--text-muted);
font-style: italic;
}
/* ── CABECERA DE LÍNEA CON ÍCONO ─────────────────────────────────────── */
.appEventSeries__line-title {
display: flex;
align-items: center;
gap: 0.5rem;
}
.appEventSeries__line-icon {
font-size: 1.1rem;
line-height: 1;
flex-shrink: 0;
}
/* ── CUERPO DE LÍNEA ASIGNADA ────────────────────────────────────────── */
.appEventSeries__line-body {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.appEventSeries__serie-code {
font-size: 1rem;
font-weight: 700;
color: var(--primary-color);
font-family: 'Courier New', monospace;
letter-spacing: 0.04em;
}
.appEventSeries__serie-name {
font-size: 0.8125rem;
color: var(--text-secondary);
}
.appEventSeries__serie-meta {
display: flex;
gap: 0.375rem;
flex-wrap: wrap;
margin-top: 0.125rem;
}
.appEventSeries__meta-chip {
display: inline-flex;
align-items: center;
padding: 0.15rem 0.5rem;
border-radius: var(--radius-pill);
font-size: 0.6875rem;
font-weight: 600;
letter-spacing: 0.02em;
}
.appEventSeries__meta-chip--type {
background: var(--primary-background, rgba(99,102,241,.12));
color: var(--primary-color);
}
.appEventSeries__meta-chip--pac {
background: var(--surface-alt, var(--hover-background-color));
color: var(--text-muted);
}
.appEventSeries__line-empty-hint {
font-size: 0.8125rem;
color: var(--text-muted);
font-style: italic;
padding: 0.25rem 0;
}
/* ── CONTEXTO DE LÍNEA EN MODAL ──────────────────────────────────────── */
.appEventSeries__assign-context {
display: inline-flex;
align-items: center;
gap: 0.4rem;
padding: 0.4rem 0.85rem;
background: var(--primary-background, rgba(99,102,241,.1));
border-radius: var(--radius-pill);
font-size: 0.875rem;
font-weight: 600;
color: var(--primary-color);
align-self: flex-start;
}
.appEventSeries__assign-context-icon {
font-size: 1rem;
line-height: 1;
}
/* Iconos SVG dentro de las pestañas */
.appEventSeries__tab {
display: flex;
align-items: center;
justify-content: center;
gap: 0.375rem;
}
/* ── SECCIÓN DENTRO DEL FORM ─────────────────────────────────────────── */
.appEventSeries__form-section {
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.appEventSeries__form-section-hint {
font-size: 0.8125rem;
color: var(--text-secondary);
margin: 0;
line-height: 1.5;
padding: 0.5rem 0.75rem;
background: var(--surface-alt, var(--hover-background-color));
border-radius: var(--radius-sm);
border-left: 3px solid var(--primary-color);
}
/* Divisor con label dentro del form */
.appEventSeries__form-divider {
font-size: 0.75rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.06em;
color: var(--text-muted);
padding: 0.5rem 0 0.25rem;
border-top: 1px solid var(--border-color);
margin-top: 0.25rem;
}
/* ── CHIP DE CSD SELECCIONADO ────────────────────────────────────────── */
.appEventSeries__csd-chip {
display: inline-flex;
align-items: center;
gap: 0.4rem;
padding: 0.35rem 0.75rem;
border-radius: var(--radius-pill);
border: 1px solid var(--success-color);
background: var(--success-background);
color: var(--success-color);
font-size: 0.8125rem;
font-weight: 500;
align-self: flex-start;
flex-wrap: wrap;
}
.appEventSeries__csd-chip-sep {
opacity: 0.5;
}
/* ── PREVIEW CARD (serie existente seleccionada) ─────────────────────── */
.appEventSeries__preview-card {
display: flex;
flex-direction: column;
gap: 0.375rem;
padding: 0.75rem 1rem;
background: var(--surface-alt, var(--hover-background-color));
border-radius: var(--radius-md);
border: 1px solid var(--border-color);
}
.appEventSeries__preview-row {
display: flex;
align-items: center;
gap: 0.5rem;
font-size: 0.875rem;
}
.appEventSeries__preview-label {
font-size: 0.75rem;
color: var(--text-muted);
min-width: 60px;
}
/* ── RESPONSIVE ──────────────────────────────────────────────────────── */
@media (max-width: 640px) {
.appEventSeries__grid {
grid-template-columns: 1fr;
}
.appEventSeries__form-row {
grid-template-columns: 1fr;
}
.appEventSeries__form-group--narrow {
max-width: 100%;
}
.appEventSeries__search-row {
flex-direction: column;
align-items: stretch;
}
.appEventSeries__assign-context {
align-self: stretch;
justify-content: center;
}
}
/* =======================================================================
AppFiscalView — Visualización desacoplada de datos fiscales
BEM namespace: app-fiscal-view
======================================================================= */
.app-fiscal-view {
display: flex;
flex-direction: column;
gap: 1rem;
}
/* ── ESTADOS ─────────────────────────────────────────────────────────── */
.app-fiscal-view__loading {
display: flex;
align-items: center;
gap: 0.75rem;
padding: 1.5rem 1rem;
color: var(--text-secondary);
font-size: 0.875rem;
}
.app-fiscal-view__error {
padding: 0.75rem 1rem;
background: var(--danger-background);
color: var(--danger-color);
border-radius: var(--radius-md);
font-size: 0.875rem;
}
.app-fiscal-view__empty {
color: var(--text-muted);
font-size: 0.875rem;
font-style: italic;
padding: 0.5rem 0;
}
/* ── HEADER ──────────────────────────────────────────────────────────── */
.app-fiscal-view__header {
display: flex;
flex-direction: column;
gap: 0.25rem;
padding-bottom: 0.75rem;
border-bottom: 1px solid var(--border-color);
}
.app-fiscal-view__rfc-block {
display: flex;
align-items: center;
gap: 0.5rem;
flex-wrap: wrap;
}
.app-fiscal-view__rfc {
font-size: 1.125rem;
font-weight: 700;
color: var(--primary-color);
font-family: 'Courier New', monospace;
letter-spacing: 0.05em;
}
.app-fiscal-view__company {
font-size: 0.9375rem;
font-weight: 600;
color: var(--text-color);
margin: 0;
}
/* ── BADGES ──────────────────────────────────────────────────────────── */
.app-fiscal-view__badge {
display: inline-flex;
align-items: center;
gap: 0.25rem;
padding: 0.15rem 0.5rem;
border-radius: var(--radius-pill);
font-size: 0.6875rem;
font-weight: 600;
letter-spacing: 0.02em;
}
.app-fiscal-view__badge--default {
background: var(--success-background);
color: var(--success-color);
}
.app-fiscal-view__badge--inactive {
background: var(--danger-background);
color: var(--danger-color);
}
/* ── GRID DE CAMPOS ──────────────────────────────────────────────────── */
.app-fiscal-view__grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
gap: 0.75rem;
}
.app-fiscal-view__field,
.app-fiscal-view__address {
display: flex;
flex-direction: column;
gap: 0.2rem;
}
.app-fiscal-view__label {
font-size: 0.6875rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.05em;
color: var(--text-muted);
}
.app-fiscal-view__value {
font-size: 0.875rem;
color: var(--text-color);
line-height: 1.4;
}
/* ── ACCIONES ────────────────────────────────────────────────────────── */
.app-fiscal-view__actions {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
padding-top: 0.75rem;
border-top: 1px solid var(--border-color);
}
/* ── RESPONSIVE ──────────────────────────────────────────────────────── */
@media (max-width: 480px) {
.app-fiscal-view__grid {
grid-template-columns: 1fr;
}
}
/* 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;
}
/* ============================================================
AppFormStripe — BEM Component
Namespace único: appform-stripe
Fuente de colores: colors.css (variables CSS, sin hardcode)
Responsivo: sm / md / lg
============================================================ */
/* ── Bloque raíz ──────────────────────────────────────────── */
.appform-stripe {
display: block;
position: relative;
}
.appform-stripe--processing {
pointer-events: none;
opacity: 0.72;
}
/* ── Grupo de campo ───────────────────────────────────────── */
.appform-stripe__field-group {
margin-bottom: 1rem;
}
/* ── Label con ícono de tarjeta ───────────────────────────── */
.appform-stripe__label {
display: flex;
align-items: center;
gap: 0.4rem;
font-size: 0.8125rem;
font-weight: 600;
color: var(--text-secondary);
margin-bottom: 0.5rem;
letter-spacing: 0.01em;
}
.appform-stripe__label-icon {
width: 1rem;
height: 1rem;
flex-shrink: 0;
color: var(--primary-color);
}
/* ── Área de montaje del Card Element de Stripe ───────────── */
/* Imita exactamente el estilo de app-input__control del proyecto */
.appform-stripe__card-mount {
display: block;
width: 100%;
padding: 0.6875rem 0.875rem;
border: 1.5px solid var(--border-color);
border-radius: 8px;
background-color: var(--surface-color);
color: var(--text-color);
min-height: 46px;
box-sizing: border-box;
transition: border-color 0.18s ease, box-shadow 0.18s ease;
position: relative;
}
/* Dark mode explícito — garantiza que el fondo nunca quede blanco */
:root:not([data-theme='light']) .appform-stripe__card-mount,
:root[data-theme='dark'] .appform-stripe__card-mount {
background-color: #0f1428;
border-color: #1a2340;
}
.appform-stripe__card-mount:focus-within {
border-color: var(--primary-color);
box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary-color) 18%, transparent);
outline: none;
}
.appform-stripe__card-mount--error {
border-color: var(--danger-foreground);
box-shadow: 0 0 0 3px color-mix(in srgb, var(--danger-foreground) 14%, transparent);
}
/* ── Mensaje de error de campo ────────────────────────────── */
.appform-stripe__field-error {
margin-top: 0.35rem;
font-size: 0.78rem;
color: var(--danger-foreground);
display: flex;
align-items: center;
gap: 0.3rem;
line-height: 1.4;
}
/* ── Términos (slot pasado desde Register) ────────────────── */
.appform-stripe__terms {
margin-bottom: 0.75rem;
}
/* ── Mensaje de recovery (caso límite) ────────────────────── */
.appform-stripe__recovery {
margin-bottom: 1rem;
padding: 0.875rem 1rem;
border-radius: 8px;
border-left: 4px solid var(--warning-foreground);
background-color: var(--warning-background);
color: var(--warning-foreground);
font-size: 0.8375rem;
line-height: 1.5;
}
/* ── Área de acciones ─────────────────────────────────────── */
.appform-stripe__actions {
margin-top: 0.75rem;
}
.appform-stripe__actions button,
.appform-stripe__actions .app-button {
width: 100%;
}
/* ── Sello de seguridad ───────────────────────────────────── */
.appform-stripe__security {
display: flex;
align-items: flex-start;
gap: 0.5rem;
margin-top: 1rem;
padding: 0.6rem 0.75rem;
border-radius: 6px;
background-color: var(--success-background);
}
.appform-stripe__security-icon {
width: 0.9rem;
height: 0.9rem;
flex-shrink: 0;
margin-top: 0.1rem;
color: var(--success-foreground);
}
.appform-stripe__security-text {
font-size: 0.74rem;
color: var(--success-foreground);
line-height: 1.45;
}
/* ── Responsivo ───────────────────────────────────────────── */
@media (min-width: 480px) {
.appform-stripe__card-mount {
padding: 0.75rem 1rem;
}
}
@media (min-width: 768px) {
.appform-stripe__label {
font-size: 0.875rem;
}
.appform-stripe__field-error {
font-size: 0.8125rem;
}
}
/* 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; }
/* ============================================================
AppMyStand — BEM namespace: app-my-stand
SHARED/wwwroot/css/components/ui/appMyStand.css
============================================================ */
/* ── Contenedor raíz ── */
.app-my-stand {
width: 100%;
}
/* ── Estado de carga / error / vacío ── */
.app-my-stand__loading,
.app-my-stand__error,
.app-my-stand__empty {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
padding: 3rem 1rem;
gap: 1rem;
text-align: center;
color: var(--text-secondary);
}
.app-my-stand__error {
color: var(--danger-foreground);
}
/* ── Encabezado de sección ── */
.app-my-stand__header {
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: 0.75rem;
margin-bottom: 1.5rem;
}
.app-my-stand__title {
font-size: 1.4rem;
font-weight: 700;
color: var(--text-primary);
margin: 0;
}
/* ── Grid de tarjetas de stands ── */
.app-my-stand__list {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
gap: 1.25rem;
}
/* ── Tarjeta de stand ── */
.app-my-stand__card {
background: var(--card-background);
border: 1px solid var(--border-color);
border-radius: 12px;
padding: 1.25rem;
cursor: pointer;
transition: box-shadow 0.2s ease, border-color 0.2s ease, transform 0.15s ease;
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.app-my-stand__card:hover {
box-shadow: 0 4px 20px var(--shadow-color);
border-color: var(--accent-color);
transform: translateY(-2px);
}
.app-my-stand__card-header {
display: flex;
align-items: flex-start;
justify-content: space-between;
gap: 0.5rem;
}
.app-my-stand__card-name {
font-size: 1rem;
font-weight: 600;
color: var(--text-primary);
line-height: 1.3;
}
.app-my-stand__card-event {
font-size: 0.8rem;
color: var(--text-secondary);
margin-top: 0.1rem;
}
.app-my-stand__card-body {
display: flex;
gap: 1rem;
flex-wrap: wrap;
}
.app-my-stand__card-stat {
display: flex;
flex-direction: column;
gap: 0.1rem;
}
.app-my-stand__card-stat-value {
font-size: 1.1rem;
font-weight: 700;
color: var(--text-primary);
}
.app-my-stand__card-stat-label {
font-size: 0.72rem;
color: var(--text-secondary);
text-transform: uppercase;
letter-spacing: 0.04em;
}
.app-my-stand__card-footer {
display: flex;
align-items: center;
justify-content: space-between;
gap: 0.5rem;
margin-top: auto;
padding-top: 0.5rem;
border-top: 1px solid var(--border-color);
}
.app-my-stand__card-total {
font-size: 0.9rem;
font-weight: 600;
color: var(--text-primary);
}
/* ── Badges de estado ── */
.app-my-stand__status {
display: inline-flex;
align-items: center;
padding: 0.2rem 0.65rem;
border-radius: 999px;
font-size: 0.72rem;
font-weight: 600;
letter-spacing: 0.03em;
white-space: nowrap;
}
.app-my-stand__status--pending {
background: var(--warning-background);
color: var(--warning-foreground);
}
.app-my-stand__status--active {
background: var(--success-background);
color: var(--success-foreground);
}
.app-my-stand__status--inactive {
background: var(--neutral-background);
color: var(--neutral-foreground);
}
.app-my-stand__status--cancelled {
background: var(--danger-background);
color: var(--danger-foreground);
}
/* ── Paginación ── */
.app-my-stand__pagination {
display: flex;
align-items: center;
justify-content: center;
gap: 0.75rem;
margin-top: 1.5rem;
flex-wrap: wrap;
}
.app-my-stand__pagination-info {
font-size: 0.85rem;
color: var(--text-secondary);
}
/* ── Vista de detalle ── */
.app-my-stand__back-btn {
background: none;
border: none;
color: var(--accent-color);
font-size: 0.9rem;
font-weight: 600;
cursor: pointer;
padding: 0.25rem 0;
display: inline-flex;
align-items: center;
gap: 0.35rem;
margin-bottom: 1.25rem;
transition: opacity 0.15s;
}
.app-my-stand__back-btn:hover {
opacity: 0.75;
}
.app-my-stand__detail-header {
display: flex;
align-items: flex-start;
justify-content: space-between;
flex-wrap: wrap;
gap: 0.75rem;
margin-bottom: 1.5rem;
}
.app-my-stand__detail-name {
font-size: 1.4rem;
font-weight: 700;
color: var(--text-primary);
margin: 0;
}
.app-my-stand__detail-card {
background: var(--card-background);
border: 1px solid var(--border-color);
border-radius: 12px;
padding: 1.25rem 1.5rem;
margin-bottom: 1.5rem;
}
.app-my-stand__detail-section-title {
font-size: 0.85rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.06em;
color: var(--text-secondary);
margin: 0 0 1rem;
}
.app-my-stand__detail-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
gap: 1rem;
}
.app-my-stand__detail-field {
display: flex;
flex-direction: column;
gap: 0.2rem;
}
.app-my-stand__detail-field-label {
font-size: 0.72rem;
color: var(--text-secondary);
text-transform: uppercase;
letter-spacing: 0.05em;
}
.app-my-stand__detail-field-value {
font-size: 0.95rem;
font-weight: 600;
color: var(--text-primary);
}
.app-my-stand__notes-box {
background: var(--input-background);
border: 1px solid var(--border-color);
border-radius: 8px;
padding: 0.75rem 1rem;
font-size: 0.9rem;
color: var(--text-primary);
margin-top: 0.75rem;
white-space: pre-line;
}
/* ── Tabla de gafetes ── */
.app-my-stand__badges-section {
background: var(--card-background);
border: 1px solid var(--border-color);
border-radius: 12px;
overflow: hidden;
margin-bottom: 1.5rem;
}
.app-my-stand__badges-header {
display: flex;
align-items: center;
justify-content: space-between;
padding: 1rem 1.5rem;
border-bottom: 1px solid var(--border-color);
}
.app-my-stand__badges-title {
font-size: 1rem;
font-weight: 700;
color: var(--text-primary);
margin: 0;
}
.app-my-stand__badges-count {
font-size: 0.8rem;
color: var(--text-secondary);
}
.app-my-stand__badge-list {
display: flex;
flex-direction: column;
}
.app-my-stand__badge-item {
display: grid;
grid-template-columns: 1fr 1fr 1fr 1fr auto auto;
align-items: center;
gap: 0.75rem;
padding: 0.85rem 1.5rem;
border-bottom: 1px solid var(--border-color);
transition: background 0.15s;
}
.app-my-stand__badge-item:last-child {
border-bottom: none;
}
.app-my-stand__badge-item:hover {
background: var(--hover-background);
}
.app-my-stand__badge-field {
display: flex;
flex-direction: column;
gap: 0.1rem;
min-width: 0;
}
.app-my-stand__badge-field-label {
font-size: 0.68rem;
color: var(--text-secondary);
text-transform: uppercase;
letter-spacing: 0.05em;
}
.app-my-stand__badge-field-value {
font-size: 0.88rem;
color: var(--text-primary);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.app-my-stand__badge-field-value--empty {
color: var(--text-secondary);
font-style: italic;
}
.app-my-stand__badge-actions {
display: flex;
gap: 0.4rem;
align-items: center;
}
.app-my-stand__badge-btn {
display: inline-flex;
align-items: center;
gap: 0.3rem;
padding: 0.35rem 0.7rem;
border-radius: 6px;
font-size: 0.78rem;
font-weight: 600;
cursor: pointer;
border: 1px solid transparent;
transition: background 0.15s, opacity 0.15s;
white-space: nowrap;
}
.app-my-stand__badge-btn--edit {
background: var(--accent-light-background);
color: var(--accent-color);
border-color: var(--accent-color);
}
.app-my-stand__badge-btn--edit:hover:not(:disabled) {
background: var(--accent-color);
color: var(--accent-foreground);
}
.app-my-stand__badge-btn--qr {
background: var(--neutral-background);
color: var(--text-primary);
border-color: var(--border-color);
}
.app-my-stand__badge-btn--qr:hover:not(:disabled) {
background: var(--hover-background);
}
.app-my-stand__badge-btn:disabled {
opacity: 0.4;
cursor: not-allowed;
}
/* ── Modal interna: form de edición ── */
.app-my-stand__modal-form {
display: flex;
flex-direction: column;
gap: 0.85rem;
padding: 0.25rem 0;
}
.app-my-stand__modal-subtitle {
font-size: 0.85rem;
color: var(--text-secondary);
margin: 0 0 0.5rem;
}
/* ── Responsive ── */
@media (max-width: 768px) {
.app-my-stand__badge-item {
grid-template-columns: 1fr 1fr;
gap: 0.5rem;
padding: 1rem;
}
.app-my-stand__badge-actions {
grid-column: 1 / -1;
justify-content: flex-end;
}
.app-my-stand__detail-grid {
grid-template-columns: 1fr 1fr;
}
}
@media (max-width: 480px) {
.app-my-stand__list {
grid-template-columns: 1fr;
}
.app-my-stand__badge-item {
grid-template-columns: 1fr;
}
.app-my-stand__detail-grid {
grid-template-columns: 1fr;
}
.app-my-stand__card-body {
gap: 0.75rem;
}
}
/* 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: var(--radius-pill);
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;
}
/* =======================================================================
AppPaymentView — Visualización desacoplada de un Payment
BEM namespace: app-payment-view
======================================================================= */
.app-payment-view {
display: flex;
flex-direction: column;
gap: 1.25rem;
}
/* ── ESTADOS ─────────────────────────────────────────────────────────── */
.app-payment-view__loading {
display: flex;
align-items: center;
gap: 0.75rem;
padding: 2rem 1rem;
color: var(--text-secondary);
font-size: 0.875rem;
}
.app-payment-view__error {
padding: 0.75rem 1rem;
background: var(--danger-background);
color: var(--danger-color);
border-radius: var(--radius-md);
font-size: 0.875rem;
}
.app-payment-view__empty {
color: var(--text-muted);
font-size: 0.875rem;
font-style: italic;
}
/* ── HERO: MONTO + ESTADO ────────────────────────────────────────────── */
.app-payment-view__hero {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;
padding: 1rem 1.25rem;
background: var(--surface-alt, var(--hover-background-color));
border-radius: var(--radius-lg, var(--radius-md));
flex-wrap: wrap;
}
.app-payment-view__amount-block {
display: flex;
align-items: baseline;
gap: 0.375rem;
}
.app-payment-view__amount {
font-size: 1.875rem;
font-weight: 800;
color: var(--text-color);
letter-spacing: -0.02em;
line-height: 1;
}
.app-payment-view__currency {
font-size: 0.875rem;
font-weight: 600;
color: var(--text-muted);
}
.app-payment-view__status-block {
display: flex;
align-items: center;
gap: 0.5rem;
flex-wrap: wrap;
}
.app-payment-view__status {
display: inline-flex;
align-items: center;
gap: 0.3rem;
padding: 0.3rem 0.75rem;
border-radius: var(--radius-pill);
font-size: 0.8125rem;
font-weight: 700;
}
.app-payment-view__status--paid {
background: var(--success-background);
color: var(--success-color);
}
.app-payment-view__status--pending {
background: var(--warning-background);
color: var(--warning-color);
}
.app-payment-view__type-chip,
.app-payment-view__cfdi-chip {
display: inline-flex;
align-items: center;
gap: 0.25rem;
padding: 0.2rem 0.6rem;
border-radius: var(--radius-pill);
font-size: 0.6875rem;
font-weight: 600;
letter-spacing: 0.02em;
background: var(--surface-alt, var(--hover-background-color));
border: 1px solid var(--border-color);
color: var(--text-secondary);
}
.app-payment-view__cfdi-chip {
background: var(--primary-background, rgba(99,102,241,.1));
border-color: var(--primary-color);
color: var(--primary-color);
}
/* ── SECCIONES ───────────────────────────────────────────────────────── */
.app-payment-view__section {
display: flex;
flex-direction: column;
gap: 0.625rem;
}
.app-payment-view__section-title {
font-size: 0.75rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.06em;
color: var(--text-muted);
margin: 0;
padding-bottom: 0.375rem;
border-bottom: 1px solid var(--border-color);
}
/* ── GRID DE CAMPOS ──────────────────────────────────────────────────── */
.app-payment-view__grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(175px, 1fr));
gap: 0.625rem;
}
.app-payment-view__field {
display: flex;
flex-direction: column;
gap: 0.15rem;
}
.app-payment-view__field--full {
grid-column: 1 / -1;
}
.app-payment-view__label {
font-size: 0.6875rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.05em;
color: var(--text-muted);
}
.app-payment-view__value {
font-size: 0.875rem;
color: var(--text-color);
line-height: 1.4;
}
.app-payment-view__value--mono {
font-family: 'Courier New', monospace;
letter-spacing: 0.03em;
}
.app-payment-view__value--uuid {
font-size: 0.75rem;
word-break: break-all;
color: var(--text-secondary);
}
/* ── DESGLOSE DE MONTOS ──────────────────────────────────────────────── */
.app-payment-view__amounts {
display: flex;
flex-direction: column;
gap: 0.375rem;
padding: 0.75rem;
background: var(--surface-alt, var(--hover-background-color));
border-radius: var(--radius-md);
}
.app-payment-view__amount-row {
display: flex;
justify-content: space-between;
font-size: 0.875rem;
color: var(--text-color);
}
.app-payment-view__amount-row--discount {
color: var(--success-color);
}
.app-payment-view__amount-row--muted {
color: var(--text-muted);
font-size: 0.8125rem;
}
.app-payment-view__amount-row--total {
font-weight: 700;
font-size: 1rem;
padding-top: 0.5rem;
margin-top: 0.25rem;
border-top: 1px solid var(--border-color);
color: var(--text-color);
}
/* ── OBSERVACIONES ───────────────────────────────────────────────────── */
.app-payment-view__observations {
font-size: 0.875rem;
color: var(--text-secondary);
line-height: 1.6;
margin: 0;
padding: 0.75rem;
background: var(--surface-alt, var(--hover-background-color));
border-radius: var(--radius-md);
border-left: 3px solid var(--border-color);
}
/* ── ACCIONES ────────────────────────────────────────────────────────── */
.app-payment-view__actions {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
padding-top: 0.75rem;
border-top: 1px solid var(--border-color);
}
/* ── RESPONSIVE ──────────────────────────────────────────────────────── */
@media (max-width: 500px) {
.app-payment-view__hero {
flex-direction: column;
align-items: flex-start;
}
.app-payment-view__amount {
font-size: 1.5rem;
}
.app-payment-view__grid {
grid-template-columns: 1fr 1fr;
}
}
@media (max-width: 360px) {
.app-payment-view__grid {
grid-template-columns: 1fr;
}
}
/* --- 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%; }
/* =======================================================================
AppReceiptView — Visualización desacoplada de un Receipt
BEM namespace: app-receipt-view
======================================================================= */
.app-receipt-view {
display: flex;
flex-direction: column;
gap: 1.25rem;
}
/* ── ESTADOS ─────────────────────────────────────────────────────────── */
.app-receipt-view__loading {
display: flex;
align-items: center;
gap: 0.75rem;
padding: 2rem 1rem;
color: var(--text-secondary);
font-size: 0.875rem;
}
.app-receipt-view__error {
padding: 0.75rem 1rem;
background: var(--danger-background);
color: var(--danger-color);
border-radius: var(--radius-md);
font-size: 0.875rem;
}
.app-receipt-view__empty {
color: var(--text-muted);
font-size: 0.875rem;
font-style: italic;
}
/* ── HERO ────────────────────────────────────────────────────────────── */
.app-receipt-view__hero {
display: flex;
align-items: flex-start;
justify-content: space-between;
gap: 1rem;
padding: 1rem 1.25rem;
background: var(--surface-alt, var(--hover-background-color));
border-radius: var(--radius-lg, var(--radius-md));
flex-wrap: wrap;
}
.app-receipt-view__folio-block {
display: flex;
flex-direction: column;
}
.app-receipt-view__folio-label {
font-size: 0.6875rem;
text-transform: uppercase;
letter-spacing: 0.06em;
color: var(--text-muted);
font-weight: 600;
}
.app-receipt-view__folio {
font-size: 1.5rem;
font-weight: 800;
color: var(--primary-color);
line-height: 1.1;
letter-spacing: -0.02em;
}
.app-receipt-view__hero-right {
display: flex;
flex-direction: column;
align-items: flex-end;
gap: 0.375rem;
}
.app-receipt-view__amount-block {
display: flex;
align-items: baseline;
gap: 0.35rem;
}
.app-receipt-view__amount {
font-size: 1.875rem;
font-weight: 800;
color: var(--text-color);
letter-spacing: -0.02em;
line-height: 1;
}
.app-receipt-view__currency {
font-size: 0.875rem;
font-weight: 600;
color: var(--text-muted);
}
.app-receipt-view__status-row {
display: flex;
align-items: center;
gap: 0.4rem;
flex-wrap: wrap;
justify-content: flex-end;
}
.app-receipt-view__status {
display: inline-flex;
align-items: center;
gap: 0.3rem;
padding: 0.25rem 0.65rem;
border-radius: var(--radius-pill);
font-size: 0.75rem;
font-weight: 700;
}
.app-receipt-view__status--paid    { background: var(--success-background); color: var(--success-color); }
.app-receipt-view__status--pending { background: var(--warning-background); color: var(--warning-color); }
.app-receipt-view__cfdi-chip {
display: inline-flex;
align-items: center;
gap: 0.25rem;
padding: 0.2rem 0.55rem;
border-radius: var(--radius-pill);
font-size: 0.6875rem;
font-weight: 600;
background: var(--primary-background, rgba(99,102,241,.1));
border: 1px solid var(--primary-color);
color: var(--primary-color);
}
.app-receipt-view__date {
font-size: 0.75rem;
color: var(--text-muted);
}
/* ── SECCIONES ───────────────────────────────────────────────────────── */
.app-receipt-view__section {
display: flex;
flex-direction: column;
gap: 0.625rem;
}
.app-receipt-view__section-title {
font-size: 0.75rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.06em;
color: var(--text-muted);
margin: 0;
padding-bottom: 0.375rem;
border-bottom: 1px solid var(--border-color);
}
/* ── GRID CLIENTE ────────────────────────────────────────────────────── */
.app-receipt-view__grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(175px, 1fr));
gap: 0.625rem;
}
.app-receipt-view__field {
display: flex;
flex-direction: column;
gap: 0.15rem;
}
.app-receipt-view__field--full { grid-column: 1 / -1; }
.app-receipt-view__label {
font-size: 0.6875rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.05em;
color: var(--text-muted);
}
.app-receipt-view__value {
font-size: 0.875rem;
color: var(--text-color);
line-height: 1.4;
}
.app-receipt-view__value--mono {
font-family: 'Courier New', monospace;
letter-spacing: 0.03em;
}
/* ── CONCEPTOS ───────────────────────────────────────────────────────── */
.app-receipt-view__items {
display: flex;
flex-direction: column;
gap: 0;
border: 1px solid var(--border-color);
border-radius: var(--radius-md);
overflow: hidden;
}
.app-receipt-view__item {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;
padding: 0.625rem 0.875rem;
border-bottom: 1px solid var(--border-color);
}
.app-receipt-view__item:last-child { border-bottom: none; }
.app-receipt-view__item:nth-child(even) { background: var(--surface-alt, var(--hover-background-color)); }
.app-receipt-view__item-main {
display: flex;
flex-direction: column;
gap: 0.1rem;
flex: 1;
min-width: 0;
}
.app-receipt-view__item-code {
font-size: 0.6875rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.04em;
color: var(--text-muted);
font-family: 'Courier New', monospace;
}
.app-receipt-view__item-desc {
font-size: 0.875rem;
color: var(--text-color);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.app-receipt-view__item-amounts {
display: flex;
align-items: center;
gap: 0.5rem;
flex-shrink: 0;
}
.app-receipt-view__item-qty {
font-size: 0.75rem;
color: var(--text-muted);
background: var(--surface-alt, var(--hover-background-color));
padding: 0.1rem 0.4rem;
border-radius: var(--radius-sm);
}
.app-receipt-view__item-amount {
font-size: 0.875rem;
font-weight: 600;
color: var(--text-color);
min-width: 70px;
text-align: right;
}
/* ── TOTALES ─────────────────────────────────────────────────────────── */
.app-receipt-view__totals {
display: flex;
flex-direction: column;
gap: 0.3rem;
padding: 0.75rem;
background: var(--surface-alt, var(--hover-background-color));
border-radius: var(--radius-md);
max-width: 260px;
margin-left: auto;
}
.app-receipt-view__total-row {
display: flex;
justify-content: space-between;
font-size: 0.875rem;
color: var(--text-color);
}
.app-receipt-view__total-row--discount { color: var(--success-color); }
.app-receipt-view__total-row--grand {
font-weight: 800;
font-size: 1.0625rem;
padding-top: 0.5rem;
margin-top: 0.25rem;
border-top: 1.5px solid var(--border-color);
}
.app-receipt-view__total-row--paid   { color: var(--success-color); font-size: 0.8125rem; }
.app-receipt-view__total-row--balance { color: var(--warning-color); font-weight: 600; font-size: 0.8125rem; }
/* ── PAGOS ───────────────────────────────────────────────────────────── */
.app-receipt-view__payments {
display: flex;
flex-direction: column;
gap: 0;
border: 1px solid var(--border-color);
border-radius: var(--radius-md);
overflow: hidden;
}
.app-receipt-view__payment-row {
display: flex;
align-items: center;
justify-content: space-between;
gap: 0.75rem;
padding: 0.6rem 0.875rem;
border-bottom: 1px solid var(--border-color);
}
.app-receipt-view__payment-row:last-child { border-bottom: none; }
.app-receipt-view__payment-row:nth-child(even) { background: var(--surface-alt, var(--hover-background-color)); }
.app-receipt-view__payment-left {
display: flex;
align-items: center;
gap: 0.5rem;
flex-wrap: wrap;
flex: 1;
}
.app-receipt-view__payment-engine {
font-size: 0.8125rem;
font-weight: 600;
color: var(--text-color);
}
.app-receipt-view__payment-txn {
font-size: 0.75rem;
color: var(--text-muted);
font-family: 'Courier New', monospace;
}
.app-receipt-view__payment-type {
font-size: 0.6875rem;
padding: 0.1rem 0.45rem;
border-radius: var(--radius-pill);
background: var(--surface-alt, var(--hover-background-color));
border: 1px solid var(--border-color);
color: var(--text-muted);
font-weight: 600;
}
.app-receipt-view__payment-right {
display: flex;
align-items: center;
gap: 0.5rem;
}
.app-receipt-view__payment-status {
font-size: 0.6875rem;
font-weight: 700;
padding: 0.15rem 0.5rem;
border-radius: var(--radius-pill);
}
.app-receipt-view__payment-status--paid    { background: var(--success-background); color: var(--success-color); }
.app-receipt-view__payment-status--pending { background: var(--warning-background); color: var(--warning-color); }
.app-receipt-view__payment-amount {
font-size: 0.875rem;
font-weight: 700;
color: var(--text-color);
min-width: 70px;
text-align: right;
}
/* ── OBSERVACIONES ───────────────────────────────────────────────────── */
.app-receipt-view__observations {
font-size: 0.875rem;
color: var(--text-secondary);
line-height: 1.6;
margin: 0;
padding: 0.75rem;
background: var(--surface-alt, var(--hover-background-color));
border-radius: var(--radius-md);
border-left: 3px solid var(--border-color);
}
/* ── TOOLBAR ─────────────────────────────────────────────────────────── */
.app-receipt-view__toolbar {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
padding-top: 0.75rem;
border-top: 1px solid var(--border-color);
}
/* ── RESPONSIVE ──────────────────────────────────────────────────────── */
@media (max-width: 540px) {
.app-receipt-view__hero {
flex-direction: column;
}
.app-receipt-view__hero-right {
align-items: flex-start;
}
.app-receipt-view__status-row {
justify-content: flex-start;
}
.app-receipt-view__amount {
font-size: 1.5rem;
}
.app-receipt-view__grid {
grid-template-columns: 1fr 1fr;
}
.app-receipt-view__totals {
max-width: 100%;
}
}
@media (max-width: 360px) {
.app-receipt-view__grid {
grid-template-columns: 1fr;
}
.app-receipt-view__item {
flex-direction: column;
align-items: flex-start;
}
}
/* 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.75rem; left:0.75rem;
height:100dvh;
height: calc(100dvh - 1.5rem);
width: min(340px, calc(100vw - 1.5rem));
background: var(--gradient-surface);
color: var(--text-color);
border:1px solid var(--border-color);
border-radius: 1.5rem;
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;
overflow: hidden;
}
.app-sidebar--open .app-sidebar__panel { transform: translateX(0); }
.app-sidebar__panel::before {
content: '';
position: absolute;
inset: 0;
background: radial-gradient(circle at top left, var(--hover-background-color) 0, transparent 28%);
pointer-events: none;
}
/* 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: linear-gradient(180deg, var(--sidebar-header-bg) 0%, transparent 100%);
color: var(--text-color);
position: relative;
z-index: 1;
}
/* 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: 1px solid transparent;
font-size: 0.9375rem;
font-weight: 500;
}
.app-sidebar__link:hover {
background: var(--hover-background-color);
color: var(--primary-color);
border-color: var(--card-hover-border);
transform: translateX(2px);
}
.app-sidebar__link--active {
background: var(--sidebar-active-bg);
color: var(--primary-color);
border-color: var(--sidebar-active-border);
font-weight: 600;
box-shadow: var(--shadow-xs);
}
/* 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: .625rem .75rem; border:1px solid transparent; 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); border-color: var(--border-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__currency-badge {
display: inline-flex;
align-items: center;
gap: 0.4rem;
background: color-mix(in srgb, var(--primary-color) 10%, transparent);
border: 1px solid color-mix(in srgb, var(--primary-color) 30%, transparent);
border-radius: 20px;
padding: 0.25rem 0.75rem 0.25rem 0.5rem;
margin-bottom: 0.75rem;
}
.app-summary__currency-badge-icon {
width: 15px;
height: 15px;
stroke: var(--primary-color);
flex-shrink: 0;
}
.app-summary__currency-badge-label {
font-size: 0.72rem;
color: var(--text-muted);
font-weight: 500;
}
.app-summary__currency-badge-value {
font-size: 0.82rem;
font-weight: 700;
color: var(--primary-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;
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: stacked vertically ─────────────────────────────────── */
.app-user-photo-upload__bottom {
display: flex;
flex-direction: column;
align-items: center;
gap: .6rem;
padding: .75rem .9rem;
background: var(--surface-color);
text-align: center;
}
.app-user-photo-upload__texts {
color: var(--text-color);
}
.app-user-photo-upload__title {
font-weight: 600;
font-size: .95rem;
line-height: 1.3;
}
.app-user-photo-upload__hint {
font-size: .8rem;
color: var(--text-muted);
margin-top: .15rem;
}
/* ── Action buttons row ──────────────────────────────────────────────── */
.app-user-photo-upload__actions {
display: flex;
gap: .5rem;
align-items: center;
justify-content: center;
flex-wrap: wrap;
}
.app-user-photo-upload__action-btn {
display: inline-flex;
align-items: center;
gap: .35rem;
padding: .45rem .85rem;
border-radius: 8px;
font-size: .82rem;
font-weight: 600;
cursor: pointer;
border: 1px solid var(--border-color);
background: var(--surface-color);
color: var(--primary-color);
white-space: nowrap;
transition: background .15s, border-color .15s;
text-decoration: none;
}
.app-user-photo-upload__action-btn:hover,
.app-user-photo-upload__action-btn:focus-visible {
background: var(--primary-background, rgba(59,130,246,0.08));
border-color: var(--primary-color);
outline: none;
}
.app-user-photo-upload__action-icon {
flex-shrink: 0;
}
/* ── Hidden file input (activated by <label for>) ────────────────────── */
.app-user-photo-upload__input {
position: absolute;
width: 1px;
height: 1px;
overflow: hidden;
clip: rect(0,0,0,0);
white-space: nowrap;
border: 0;
padding: 0;
margin: -1px;
}
/* Error message */
.app-user-photo-upload__error {
color: var(--danger-color);
font-size: .85rem;
margin-top: .5rem;
text-align: center;
}
/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
.app-user-photo-upload__card {
transition: none;
}
}
/* ── Camera modal ─────────────────────────────────────────────────────── */
.app-user-photo-upload__camera-backdrop {
position: fixed;
inset: 0;
z-index: var(--z-modal);
background: rgba(0,0,0,0.65);
display: flex;
align-items: center;
justify-content: center;
padding: 1rem;
}
.app-user-photo-upload__camera-modal {
background: var(--surface-color, #fff);
border-radius: 16px;
padding: 1.5rem;
width: 100%;
max-width: 420px;
display: flex;
flex-direction: column;
gap: .75rem;
box-shadow: 0 20px 60px rgba(0,0,0,0.4);
}
.app-user-photo-upload__camera-title {
font-size: 1.05rem;
font-weight: 700;
margin: 0;
color: var(--text-color, #0f172a);
}
/* Viewfinder */
.app-user-photo-upload__camera-viewfinder {
position: relative;
width: 100%;
aspect-ratio: 1/1;
border-radius: 12px;
overflow: hidden;
background: #000;
}
.app-user-photo-upload__camera-video {
width: 100%;
height: 100%;
object-fit: cover;
transform: scaleX(-1);
}
.app-user-photo-upload__camera-loading {
position: absolute;
inset: 0;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: .5rem;
background: rgba(0,0,0,0.6);
color: rgba(255,255,255,0.8);
font-size: .85rem;
}
/* Preview */
.app-user-photo-upload__camera-preview {
width: 100%;
aspect-ratio: 1/1;
border-radius: 12px;
overflow: hidden;
background: #000;
}
.app-user-photo-upload__camera-preview-img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
}
/* Camera action buttons */
.app-user-photo-upload__camera-actions {
display: flex;
justify-content: center;
gap: .75rem;
}
.app-user-photo-upload__camera-btn {
padding: .6rem 1.25rem;
border-radius: 10px;
font-weight: 700;
font-size: .9rem;
cursor: pointer;
border: none;
transition: background .2s, opacity .2s;
}
.app-user-photo-upload__camera-btn:disabled {
opacity: .4;
cursor: not-allowed;
}
.app-user-photo-upload__camera-btn--capture {
width: 60px;
height: 60px;
border-radius: 50%;
background: var(--danger-color, #ef4444);
color: #fff;
display: flex;
align-items: center;
justify-content: center;
padding: 0;
box-shadow: 0 0 0 4px rgba(239,68,68,0.3);
}
.app-user-photo-upload__camera-btn--capture:hover:not(:disabled) {
box-shadow: 0 0 0 6px rgba(239,68,68,0.4);
}
.app-user-photo-upload__camera-btn--confirm {
background: var(--success-color, #10b981);
color: #fff;
}
.app-user-photo-upload__camera-btn--confirm:hover {
background: var(--success-dark, #059669);
}
.app-user-photo-upload__camera-btn--retake {
background: var(--secondary-background, #e2e8f0);
color: var(--text-color, #0f172a);
}
.app-user-photo-upload__camera-btn--retake:hover {
background: var(--secondary-hover, #cbd5e1);
}
.app-user-photo-upload__camera-close {
background: none;
border: none;
color: var(--text-muted, #64748b);
font-size: .85rem;
font-weight: 600;
cursor: pointer;
text-align: center;
padding: .25rem;
}
.app-user-photo-upload__camera-close:hover {
color: var(--text-color, #0f172a);
}
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}
}
/* Face validation status indicator */
.app-user-view__face-status{display:flex;align-items:center;justify-content:center;gap:.4rem;font-size:.82rem;font-weight:600;padding:.5rem .75rem;border-radius:8px;margin-top:.75rem;text-align:center;line-height:1.35}
.app-user-view__face-status--loading{color:var(--text-muted);background:var(--disabled-background)}
.app-user-view__face-status--valid{color:var(--success-color);background:var(--success-background, rgba(16,185,129,0.1))}
.app-user-view__face-status--invalid{color:var(--warning-color);background:var(--warning-background, rgba(245,158,11,0.1))}
/* 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; }
}
/* ================================================================
FloorPlanRenderer — BEM: fp-renderer
CSS en SHARED/wwwroot/css/components/ui/floorPlanRenderer.css
================================================================ */
/* Contenedor raíz */
.fp-renderer {
display: flex;
flex-direction: column;
gap: 0.75rem;
width: 100%;
}
/* ── Barra de zoom ──────────────────────────────────────── */
.fp-renderer__zoom-bar {
display: flex;
align-items: center;
gap: 0.6rem;
padding: 0.4rem 0.75rem;
border-radius: 8px;
background: var(--card-background);
border: 1px solid var(--border-color);
user-select: none;
}
.fp-renderer__zoom-icon {
font-size: 1rem;
line-height: 1;
color: var(--text-secondary);
flex-shrink: 0;
}
.fp-renderer__zoom-slider {
flex: 1;
min-width: 80px;
accent-color: var(--color-primary);
cursor: pointer;
height: 4px;
}
.fp-renderer__zoom-label {
font-size: 0.78rem;
font-weight: 600;
color: var(--text-secondary);
min-width: 3.2rem;
text-align: right;
flex-shrink: 0;
}
.fp-renderer__zoom-reset {
padding: 0.25rem 0.6rem;
border-radius: 6px;
border: 1px solid var(--border-color);
background: transparent;
color: var(--text-secondary);
font-size: 0.75rem;
font-weight: 600;
cursor: pointer;
transition: background 0.15s ease, color 0.15s ease;
flex-shrink: 0;
}
.fp-renderer__zoom-reset:hover {
background: var(--hover-background);
color: var(--text-primary);
}
/* ── Wrapper del SVG: scroll + escala ───────────────────── */
/* Outer: límite de tamaño y scroll */
.fp-renderer__container {
width: 100%;
overflow: auto;
border-radius: 8px;
border: 1px solid var(--border-color);
background: var(--card-background);
max-height: 70vh;
}
/* Inner: su ancho real lo controla CanvasStyle desde Blazor (ej. "150%").
min-width: 100% garantiza que al zoom=1 ocupe todo el espacio disponible. */
.fp-renderer__canvas {
display: block;
min-width: 100%;
}
/* El SVG ocupa siempre el 100% del canvas (sea cual sea su ancho) */
.fp-renderer__svg {
display: block;
width: 100%;
height: auto;
}
/* ── Slots ─────────────────────────────────────────────── */
.fp-renderer__slot {
stroke: rgba(0, 0, 0, 0.18);
stroke-width: 1.5;
opacity: 0.92;
transition: opacity 0.15s ease, filter 0.15s ease;
}
/* Verde profesional — disponible */
.fp-renderer__slot--available { fill: var(--success-color); }
/* Amarillo — reservado / en proceso de cobro */
.fp-renderer__slot--locked    { fill: var(--warning-color); }
.fp-renderer__slot--reserved  { fill: var(--warning-color); }
/* Rojo — ocupado / vendido */
.fp-renderer__slot--sold      { fill: var(--danger-color); }
/* Grupo clickable */
.fp-renderer__slot-group--clickable {
cursor: pointer;
}
.fp-renderer__slot-group--clickable:hover .fp-renderer__slot {
opacity: 1;
filter: brightness(1.1) drop-shadow(0 0 4px rgba(0,0,0,0.25));
}
.fp-renderer__slot-group--clickable:focus-visible {
outline: 2px solid var(--focus-ring);
outline-offset: 2px;
}
/* ── Número de stand (centrado, prominente) ─────────────── */
.fp-renderer__slot-number {
font-size: 18px;
font-weight: 800;
fill: #ffffff;
paint-order: stroke fill;
stroke: rgba(0,0,0,0.35);
stroke-width: 2.5px;
pointer-events: none;
user-select: none;
letter-spacing: 0.02em;
}
/* ── Dimensiones (inferior derecha, notable) ────────────── */
.fp-renderer__slot-dims {
font-size: 13px;
font-weight: 700;
fill: rgba(255,255,255,0.95);
paint-order: stroke fill;
stroke: rgba(0,0,0,0.3);
stroke-width: 2px;
pointer-events: none;
user-select: none;
}
/* ── Estado vacío ───────────────────────────────────────── */
.fp-renderer__empty {
padding: 2rem;
text-align: center;
color: var(--text-secondary);
font-size: 0.9rem;
}
/* ── Leyenda ────────────────────────────────────────────── */
.fp-renderer__legend {
display: flex;
flex-wrap: wrap;
gap: 0.5rem 1rem;
padding: 0.5rem 0.25rem;
}
.fp-renderer__legend-item {
display: flex;
align-items: center;
gap: 0.4rem;
font-size: 0.78rem;
color: var(--text-secondary);
}
.fp-renderer__legend-item::before {
content: '';
display: inline-block;
width: 12px;
height: 12px;
border-radius: 3px;
flex-shrink: 0;
}
.fp-renderer__legend-item--available::before { background: var(--success-color); }
.fp-renderer__legend-item--reserved::before  { background: var(--warning-color); }
.fp-renderer__legend-item--sold::before      { background: var(--danger-color); }
/* ── Responsivo ─────────────────────────────────────────── */
@media (max-width: 480px) {
.fp-renderer__legend {
gap: 0.4rem 0.75rem;
}
.fp-renderer__legend-item {
font-size: 0.72rem;
}
.fp-renderer__zoom-bar {
padding: 0.35rem 0.5rem;
gap: 0.4rem;
}
.fp-renderer__zoom-label {
font-size: 0.72rem;
min-width: 2.8rem;
}
.fp-renderer__container {
max-height: 55vh;
}
}
/* 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: linear-gradient(180deg, var(--surface-color) 0%, var(--surface-alt-color) 100%);
border: 1.5px solid var(--topbar-border);
border-radius: 999px;
color: var(--text-muted);
cursor: pointer;
transition: all 0.2s ease;
box-shadow: var(--shadow-xs);
}
.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: 1rem;
box-shadow: var(--shadow-xl);
border: 1px solid var(--border-color);
padding: 0.25rem;
display: none;
z-index: var(--z-topbar-popup);
animation: themeDropFadeIn 0.15s ease;
isolation: isolate;
backdrop-filter: blur(var(--glass-blur));
-webkit-backdrop-filter: blur(var(--glass-blur));
}
.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: var(--z-topbar-popup);
background: transparent;
}
/* ========================================== */
/*  TopBar — Premium glassmorphism header    */
/* ========================================== */
.app-topbar {
position: sticky;
top: 0;
left: 0;
right: 0;
z-index: var(--z-topbar);
width: 100%;
padding: 0.75rem clamp(0.75rem, 2vw, 1.25rem) 0;
background: transparent;
color: var(--text-color);
box-shadow: none;
border-bottom: none;
backdrop-filter: none;
-webkit-backdrop-filter: none;
transition: padding var(--transition-base);
}
/* Glow ambiental visible debajo del inner */
.app-topbar::before {
content: '';
position: absolute;
inset: 0 auto auto 50%;
width: min(70vw, 56rem);
height: 5rem;
transform: translateX(-50%);
background: var(--primary-color);
filter: blur(48px);
opacity: 0.07;
pointer-events: none;
transition: opacity var(--transition-slow);
}
/* ── Estado scrolled: padding reducido ── */
.app-topbar--scrolled {
padding: 0.75rem clamp(0.75rem, 2vw, 1.25rem) 0;
}
.app-topbar--scrolled::before {
opacity: 0.12;
}
@keyframes topbar-accent-shimmer {
0%, 100% { background-position: 0% 50%; }
50% { background-position: 100% 50%; }
}
/* Inner grid — 3 columnas */
.app-topbar__inner {
height: var(--layout-topbar-height);
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: var(--layout-shell-max-width);
margin: 0 auto;
box-sizing: border-box;
position: relative;
border-radius: 1.5rem;
background: var(--topbar-bg);
border: 1px solid var(--topbar-border);
box-shadow: var(--topbar-shadow);
backdrop-filter: blur(var(--glass-blur)) saturate(180%);
-webkit-backdrop-filter: blur(var(--glass-blur)) saturate(180%);
transition:
height var(--transition-base),
box-shadow var(--transition-base),
backdrop-filter var(--transition-base),
background var(--transition-base);
}
/* Estado scrolled: inner más delgado y glass más intenso */
.app-topbar--scrolled .app-topbar__inner {
height: 42px;
backdrop-filter: blur(24px) saturate(220%);
-webkit-backdrop-filter: blur(24px) saturate(220%);
box-shadow: var(--shadow-md), 0 0 0 1px var(--topbar-border);
}
/* ── Contenido slim al hacer scroll ── */
/* Logo ligeramente más compacto */
.app-topbar--scrolled .app-topbar__logo {
width: 32px;
height: 32px;
border-radius: 8px;
}
.app-topbar--scrolled .app-topbar__logo img {
width: 24px;
height: 24px;
}
/* Brand name: fuente un poco más pequeña */
.app-topbar--scrolled .app-topbar__brand-name {
font-size: 1rem;
}
/* Nav links más compactos */
.app-topbar--scrolled .app-topbar__nav-link {
padding: 0.3rem 0.75rem;
font-size: 0.75rem;
}
/* Botones de acción más pequeños */
.app-topbar--scrolled .app-topbar__language,
.app-topbar--scrolled .app-topbar__avatar,
.app-topbar--scrolled .app-topbar__menu-toggle {
width: 30px;
height: 30px;
}
.app-topbar--scrolled .app-topbar__language svg,
.app-topbar--scrolled .app-topbar__avatar svg {
width: 15px;
height: 15px;
}
.app-topbar--scrolled .app-topbar__language-label {
font-size: 0.58rem;
}
/* Botón admin: solo icono, sin label */
.app-topbar--scrolled .app-topbar__admin-btn {
height: 30px;
padding: 0 0.5rem;
}
.app-topbar--scrolled .app-topbar__admin-label {
display: none;
}
/* Línea accent inferior estilo Office */
.app-topbar--scrolled .app-topbar__inner::after {
content: '';
position: absolute;
bottom: -1px;
left: 10%;
right: 10%;
height: 2px;
border-radius: 0 0 2px 2px;
background: var(--gradient-primary);
opacity: 0.5;
pointer-events: none;
}
.app-topbar__inner::before {
content: '';
position: absolute;
inset: 0;
border-radius: inherit;
background:
radial-gradient(circle at left top, var(--hover-background-color) 0, transparent 26%),
radial-gradient(circle at right top, var(--secondary-background) 0, transparent 26%);
pointer-events: none;
}
.app-topbar__inner::after {
content: none;
}
/* ========================================== */
/*  Logo y Marca                             */
/* ========================================== */
.app-topbar__left, .app-topbar__center, .app-topbar__right {
min-width: 0;
position: relative;
z-index: 1;
}
.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(--gradient-surface);
border: 1px solid var(--topbar-border);
overflow: hidden;
transition: all 0.2s ease;
flex-shrink: 0;
box-shadow: var(--shadow-sm);
}
.app-topbar__logo:hover {
transform: translateY(-1px) scale(1.02);
box-shadow: var(--shadow-md);
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.1875rem;
font-weight: 800;
letter-spacing: -0.03em;
white-space: nowrap;
max-width: 180px;
overflow: hidden;
text-overflow: ellipsis;
display: inline-block;
color: inherit;
line-height: 1.2;
}
/* ========================================== */
/*  Navegación central — pill group          */
/* ========================================== */
.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: 4px;
border-radius: 999px;
background: var(--topbar-nav-bg);
border: 1px solid var(--topbar-nav-border);
box-shadow: inset 0 1px 0 var(--glass-border);
}
.app-topbar__nav-link {
color: var(--text-secondary);
text-decoration: none;
padding: 0.5rem 1rem;
border-radius: 999px;
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(--gradient-primary);
border-color: var(--primary-color);
box-shadow: var(--shadow-sm);
}
.app-topbar__nav-link--active:hover {
color: var(--primary-foreground);
background: var(--primary-hover);
border-color: var(--primary-hover);
}
/* ========================================== */
/*  Acciones derecha                         */
/* ========================================== */
.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: linear-gradient(180deg, var(--surface-color) 0%, var(--surface-alt-color) 100%);
border: 1.5px solid var(--primary-color);
color: var(--primary-color);
border-radius: 999px;
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: var(--shadow-xs);
}
.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: 999px;
cursor: pointer;
flex: 0 0 auto;
background: linear-gradient(180deg, var(--surface-color) 0%, var(--surface-alt-color) 100%);
border: 1.5px solid var(--topbar-border);
color: var(--text-muted);
box-shadow: var(--shadow-xs);
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-label {
font-size: 0.65rem;
font-weight: 700;
letter-spacing: 0.04em;
line-height: 1;
color: currentColor;
user-select: none;
transition: transform 0.2s ease;
}
.app-topbar__language:hover .app-topbar__language-label {
transform: scale(1.08);
}
.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: 1rem;
box-shadow: var(--shadow-xl);
border: 1px solid var(--border-color);
padding: 0.25rem;
display: none;
z-index: var(--z-topbar-popup);
animation: dropdownFadeIn 0.15s ease;
/* Ensure fully opaque — prevent topbar backdrop-filter bleed-through */
isolation: isolate;
backdrop-filter: blur(var(--glass-blur));
-webkit-backdrop-filter: blur(var(--glass-blur));
}
@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;
}
/* Ítem deshabilitado (próximamente) */
.app-topbar__dropdown-menu .app-topbar__dropdown-item--disabled {
opacity: 0.4;
cursor: not-allowed;
pointer-events: none;
}
/* ========================================== */
/*  Hamburguesa (móvil)                      */
/* ========================================== */
.app-topbar__hamburger {
display: none;
}
.app-topbar__menu-toggle {
background: linear-gradient(180deg, var(--surface-color) 0%, var(--surface-alt-color) 100%);
color: var(--text-color);
border: 1.5px solid var(--topbar-border);
border-radius: 999px;
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 {
padding-top: 0.625rem;
}
.app-topbar__inner {
grid-template-columns: auto 1fr auto;
padding: 0 1rem;
gap: 0.75rem;
height: 60px;
position: relative;
}
.app-topbar__brand-name {
display: none;
}
.app-topbar__hamburger {
display: block;
}
.app-topbar__center {
justify-content: flex-end;
overflow: visible;
}
.app-topbar__nav {
display: none;
background: transparent;
border: none;
padding: 0;
}
.app-topbar__nav--open {
display: flex;
position: absolute;
left: 0.75rem;
right: 0.75rem;
top: calc(100% + 0.75rem);
background: var(--surface-color);
padding: 0.5rem 1rem;
flex-direction: column;
gap: 2px;
border: 1px solid var(--border-color);
border-radius: 1rem;
z-index: var(--z-topbar-popup);
box-shadow: var(--shadow-lg);
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: 56px;
}
.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;
}
/* ── Ícono de mensajes (UserChats) ── */
.app-topbar__messages {
position: relative;
display: flex;
align-items: center;
justify-content: center;
width: 36px;
height: 36px;
background: linear-gradient(180deg, var(--surface-color) 0%, var(--surface-alt-color) 100%);
border: 1.5px solid var(--topbar-border);
border-radius: 999px;
color: var(--text-muted);
cursor: pointer;
transition: all 0.2s ease;
box-shadow: var(--shadow-xs);
flex-shrink: 0;
}
.app-topbar__messages:hover {
background: var(--hover-background-color);
border-color: var(--primary-color);
color: var(--primary-color);
transform: translateY(-1px);
}
.app-topbar__messages:focus-visible {
outline: 2px solid var(--focus-color);
outline-offset: 2px;
}
.app-topbar__messages svg {
width: 18px;
height: 18px;
flex-shrink: 0;
color: currentColor;
transition: transform 0.2s ease;
}
.app-topbar__messages:hover svg {
transform: scale(1.08);
}
/* Punto rojo reactivo */
.app-topbar__messages-dot {
position: absolute;
top: 4px;
right: 4px;
width: 8px;
height: 8px;
background: var(--error-foreground, #e53e3e);
border-radius: 50%;
border: 1.5px solid var(--topbar-bg, var(--surface-color));
animation: topbar-msg-pulse 2s ease-in-out infinite;
}
@keyframes topbar-msg-pulse {
0%, 100% { transform: scale(1); opacity: 1; }
50%       { transform: scale(1.15); opacity: 0.85; }
}
/* Tinte suave cuando hay mensajes no leídos */
.app-topbar__messages--unread {
animation: topbar-msg-blink 3s ease-in-out infinite;
}
.app-topbar__messages--unread svg {
color: var(--error-foreground, #e53e3e);
}
@keyframes topbar-msg-blink {
0%, 100% {
border-color: var(--topbar-border);
box-shadow: var(--shadow-xs);
color: var(--text-muted);
}
50% {
border-color: color-mix(in srgb, var(--error-foreground, #e53e3e) 55%, transparent);
box-shadow: 0 0 0 2px color-mix(in srgb, var(--error-foreground, #e53e3e) 12%, transparent);
color: var(--error-foreground, #e53e3e);
}
}
/* NexEvent — AppAccordion */
.app-accordion__item {
border-bottom: 1px solid var(--border-color);
background: var(--surface-color);
transition: background var(--transition-fast);
}
.app-accordion__item:last-child { border-bottom: none; }
.app-accordion__header {
width: 100%;
background: transparent;
border: none;
padding: 1rem 1.25rem;
text-align: left;
font-size: 0.9375rem;
font-weight: 600;
display: flex;
align-items: center;
justify-content: space-between;
cursor: pointer;
color: var(--text-color);
transition: all var(--transition-base);
letter-spacing: -0.01em;
}
.app-accordion__header:hover {
background: var(--hover-background-color);
color: var(--primary-color);
}
.app-accordion__icon {
font-size: 1.1em;
margin-left: 0.5em;
color: var(--primary-color);
transition: transform var(--transition-base);
flex-shrink: 0;
}
.app-accordion__item--open .app-accordion__icon {
transform: rotate(180deg);
}
.app-accordion__content {
padding: 1rem 1.25rem 1.25rem 1.25rem;
background: var(--surface-alt-color);
color: var(--text-color);
font-size: 0.9375rem;
animation: accordion-fadein 0.18s cubic-bezier(0.4, 0, 0.2, 1);
border-top: 1px solid var(--border-color);
}
.app-accordion__content, .app-accordion__content * { color: var(--text-color); }
@keyframes accordion-fadein {
from { opacity: 0; transform: translateY(-4px); }
to { opacity: 1; transform: translateY(0); }
}
/* =======================================================================
NexEvent — AppCard
Tarjetas con borde gradiente, glow en hover, acento superior
======================================================================= */
.app-card {
background-color: var(--card-bg-color);
border: 1.5px solid var(--border-color);
border-radius: var(--radius-lg);
box-shadow: var(--shadow-sm);
padding: 1.5rem;
margin: 0.75rem 0;
transition: all var(--transition-base);
display: flex;
flex-direction: column;
min-width: 0;
position: relative;
overflow: hidden;
}
.app-card::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
background: var(--card-accent-gradient);
opacity: 0;
transition: opacity var(--transition-base);
}
.app-card:hover {
box-shadow: var(--shadow-md);
border-color: var(--card-hover-border);
transform: translateY(-3px);
}
.app-card:hover::before { opacity: 1; }
.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.125rem;
font-weight: 700;
color: var(--text-color);
line-height: 1.4;
letter-spacing: -0.01em;
}
.app-card-body {
flex: 1 1 auto;
color: var(--text-color);
line-height: 1.6;
}
.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;
}
/* Interactivo */
.app-card--interactive { cursor: pointer; }
.app-card--interactive:hover {
box-shadow: var(--shadow-lg), var(--shadow-glow);
border-color: var(--primary-color);
transform: translateY(-4px);
}
.app-card--interactive:active {
transform: translateY(-1px);
box-shadow: var(--shadow-md);
}
/* Elevado */
.app-card--elevated { box-shadow: var(--shadow-md); }
.app-card--elevated:hover { box-shadow: var(--shadow-xl); }
/* Plano */
.app-card--flat { box-shadow: none; border-color: var(--border-color); }
.app-card--flat:hover { box-shadow: var(--shadow-sm); }
/* Acento superior siempre visible */
.app-card--accent-top::before { opacity: 1; }
/* Acento lateral */
.app-card--accent-left::after {
content: '';
position: absolute;
top: 0; left: 0; bottom: 0;
width: 3px;
background: var(--card-accent-gradient);
border-radius: var(--radius-lg) 0 0 var(--radius-lg);
}
/* Glow card */
.app-card--glow:hover {
box-shadow: var(--shadow-lg), var(--shadow-glow);
border-color: var(--primary-color);
}
/* Glass card */
.app-card--glass {
background: var(--glass-bg);
backdrop-filter: blur(var(--glass-blur));
-webkit-backdrop-filter: blur(var(--glass-blur));
border-color: var(--glass-border);
}
@media (max-width: 640px) {
.app-card { padding: 1.125rem; border-radius: var(--radius-md); }
}
.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);
}
/* ============================================================
AppCategoryRulesEditor
BEM namespace: cat-rules-editor
Responsivo: sm / md / lg
============================================================ */
/* ── Raíz ── */
.cat-rules-editor {
display: flex;
flex-direction: column;
gap: 1rem;
padding: 1rem 0;
}
/* ── Aviso backend pendiente ── */
.cat-rules-editor__pending-notice {
background: color-mix(in srgb, var(--warning-background, #78350f) 15%, var(--surface-color));
border: 1px solid var(--warning-foreground, #f59e0b);
border-left: 4px solid var(--warning-foreground, #f59e0b);
color: var(--warning-foreground, #f59e0b);
border-radius: .4rem;
padding: .6rem .85rem;
font-size: .8rem;
line-height: 1.5;
}
/* ── Cabecera ── */
.cat-rules-editor__header {
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: 0.5rem;
}
.cat-rules-editor__title {
font-weight: 600;
font-size: 0.95rem;
color: var(--text-primary);
}
/* ── Estados ── */
.cat-rules-editor__loading,
.cat-rules-editor__empty {
color: var(--text-secondary);
font-size: 0.875rem;
padding: 0.5rem 0;
}
.cat-rules-editor__error {
color: var(--danger-foreground);
background: var(--danger-background);
border-radius: 6px;
padding: 0.5rem 0.75rem;
font-size: 0.875rem;
}
/* ── Advertencia de totales ── */
.cat-rules-editor__warning {
color: var(--warning-foreground);
background: var(--warning-background);
border-radius: 6px;
padding: 0.5rem 0.75rem;
font-size: 0.875rem;
}
/* ── Tabla ── */
.cat-rules-editor__table-wrap {
overflow-x: auto;
border-radius: 8px;
border: 1px solid var(--border-color);
}
.cat-rules-editor__table {
width: 100%;
border-collapse: collapse;
font-size: 0.875rem;
color: var(--text-primary);
}
.cat-rules-editor__table thead th {
background: var(--surface-secondary);
color: var(--text-secondary);
font-weight: 600;
text-align: left;
padding: 0.5rem 0.75rem;
white-space: nowrap;
}
.cat-rules-editor__table tbody td {
padding: 0.5rem 0.75rem;
border-top: 1px solid var(--border-color);
vertical-align: middle;
}
.cat-rules-editor__row--inactive td {
opacity: 0.55;
}
/* ── Totales ── */
.cat-rules-editor__totals td {
padding: 0.5rem 0.75rem;
border-top: 2px solid var(--border-color);
font-weight: 700;
color: var(--text-primary);
}
.cat-rules-editor__totals-label {
text-align: right;
color: var(--text-secondary);
}
/* ── Formulario panel ── */
.cat-rules-editor__form-panel {
background: var(--surface-secondary);
border: 1px solid var(--border-color);
border-radius: 8px;
padding: 1.25rem;
display: flex;
flex-direction: column;
gap: 1rem;
}
.cat-rules-editor__form-title {
margin: 0;
font-size: 0.95rem;
font-weight: 600;
color: var(--text-primary);
}
.cat-rules-editor__form-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 0.75rem;
}
.cat-rules-editor__field {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.cat-rules-editor__field--wide {
grid-column: 1 / -1;
}
.cat-rules-editor__label {
font-size: 0.8125rem;
font-weight: 500;
color: var(--text-secondary);
}
.cat-rules-editor__form-error {
color: var(--danger-foreground);
font-size: 0.875rem;
}
.cat-rules-editor__form-actions {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
}
/* ── Responsivo ── */
@media (max-width: 768px) {
.cat-rules-editor__form-grid {
grid-template-columns: 1fr;
}
.cat-rules-editor__field--wide {
grid-column: 1;
}
}
@media (min-width: 1200px) {
.cat-rules-editor__form-grid {
grid-template-columns: repeat(3, 1fr);
}
.cat-rules-editor__field--wide {
grid-column: 1 / -1;
}
}
.app-color-picker { display:flex; flex-direction:column; gap:.4rem; color:var(--text-color); }
.app-color-picker__label{ font-size:.75rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:var(--text-muted); }
.app-color-picker__control{ display:flex; align-items:center; gap:.4rem; }
.app-color-picker__input{ flex:1 1 auto; min-width:8rem; padding:.55rem .75rem; border:1.5px solid var(--border-color); border-radius:var(--radius-md); background:var(--surface-color); color:var(--text-color); outline:none; transition:all var(--transition-base); }
.app-color-picker__input:focus{ border-color:var(--focus-color); box-shadow:0 0 0 3px var(--focus-ring), var(--shadow-sm); }
.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:1.5px solid var(--border-color); border-radius:var(--radius-sm); box-shadow:var(--shadow-xs); }
.app-color-picker__error{ color:var(--danger-color); font-size:.75rem; font-weight:500; }
.app-color-picker--disabled{ opacity:.6; pointer-events:none; }
/* ============================================================
AppContentEditor â€” BEM: cnt-editor
Editor de content items con tabs: Info | CFDI | Ponentes | Videos.
============================================================ */
.cnt-editor {
display: flex;
flex-direction: column;
gap: 0;
}
/* â”€â”€ Tabs â”€â”€ */
.cnt-editor__tabs {
display: flex;
gap: 0;
border-bottom: 2px solid var(--border-color);
margin-bottom: 1.25rem;
overflow-x: auto;
}
.cnt-editor__tab {
padding: 0.55rem 1rem;
font-size: 0.84rem;
font-weight: 500;
color: var(--text-muted);
background: none;
border: none;
border-bottom: 2px solid transparent;
margin-bottom: -2px;
cursor: pointer;
white-space: nowrap;
transition: color 0.15s, border-color 0.15s;
}
.cnt-editor__tab:hover {
color: var(--primary-color);
}
.cnt-editor__tab--active {
color: var(--primary-color);
border-bottom-color: var(--primary-color);
font-weight: 700;
}
/* â”€â”€ Error â”€â”€ */
.cnt-editor__error {
padding: 0.65rem 0.9rem;
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: 6px;
font-size: 0.84rem;
margin-bottom: 1rem;
}
/* â”€â”€ Secciones â”€â”€ */
.cnt-editor__section {
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.cnt-editor__field-group {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.cnt-editor__row {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
gap: 0.75rem;
}
.cnt-editor__colors {
display: flex;
flex-wrap: wrap;
gap: 1rem;
align-items: flex-end;
margin: 0.25rem 0;
}
.cnt-editor__switch-row {
display: flex;
align-items: center;
gap: 0.75rem;
margin: 0.25rem 0;
}
/* â”€â”€ Acciones del formulario â”€â”€ */
.cnt-editor__actions {
display: flex;
gap: 0.65rem;
padding-top: 0.75rem;
border-top: 1px solid var(--border-color);
margin-top: 0.5rem;
}
/* â”€â”€ Loading â”€â”€ */
.cnt-editor__loading {
display: flex;
justify-content: center;
padding: 2rem;
}
/* â”€â”€ Sub-editor ponentes (spk-editor) â”€â”€ */
.spk-editor {
display: flex;
flex-direction: column;
gap: 0.85rem;
}
.spk-editor__subtitle {
font-size: 0.9rem;
font-weight: 700;
color: var(--text-color);
margin: 0;
}
.spk-editor__subtitle--add {
margin-top: 0.5rem;
padding-top: 0.75rem;
border-top: 1px solid var(--border-color);
}
.spk-editor__empty {
font-size: 0.83rem;
color: var(--text-muted);
margin: 0;
}
.spk-editor__list {
list-style: none;
padding: 0;
margin: 0;
display: flex;
flex-direction: column;
gap: 0.4rem;
}
.spk-editor__item {
display: flex;
align-items: center;
justify-content: space-between;
gap: 0.75rem;
padding: 0.6rem 0.75rem;
background: var(--card-category-bg-color);
border-radius: 8px;
border: 1px solid var(--border-color);
}
.spk-editor__item-info {
display: flex;
align-items: center;
gap: 0.6rem;
flex: 1;
min-width: 0;
}
.spk-editor__photo {
width: 32px;
height: 32px;
border-radius: 50%;
object-fit: cover;
border: 2px solid var(--border-color);
flex-shrink: 0;
}
.spk-editor__avatar {
width: 32px;
height: 32px;
border-radius: 50%;
background: var(--primary-color);
color: var(--primary-foreground);
display: flex;
align-items: center;
justify-content: center;
font-size: 0.75rem;
font-weight: 700;
flex-shrink: 0;
}
.spk-editor__item-text {
display: flex;
flex-direction: column;
gap: 0.05rem;
min-width: 0;
}
.spk-editor__name {
font-size: 0.84rem;
font-weight: 600;
color: var(--text-color);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.spk-editor__role-badge {
font-size: 0.68rem;
background: var(--info-background);
color: var(--info-foreground);
padding: 0.05rem 0.4rem;
border-radius: 4px;
width: fit-content;
}
.spk-editor__org {
font-size: 0.7rem;
color: var(--text-muted);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.spk-editor__remove {
flex-shrink: 0;
color: var(--text-muted);
}
.spk-editor__error {
padding: 0.5rem 0.75rem;
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: 6px;
font-size: 0.82rem;
}
.spk-editor__search-row {
display: flex;
gap: 0.5rem;
align-items: flex-end;
}
.spk-editor__search-row > :first-child { flex: 1; }
.spk-editor__results {
list-style: none;
padding: 0;
margin: 0;
border: 1px solid var(--border-color);
border-radius: 8px;
overflow: hidden;
}
.spk-editor__result {
display: flex;
flex-direction: column;
gap: 0.1rem;
padding: 0.5rem 0.75rem;
cursor: pointer;
border-bottom: 1px solid var(--border-light);
transition: background 0.1s;
}
.spk-editor__result:last-child { border-bottom: none; }
.spk-editor__result:hover,
.spk-editor__result--selected {
background: var(--hover-background-color);
}
.spk-editor__result-name {
font-size: 0.84rem;
font-weight: 600;
color: var(--text-color);
}
.spk-editor__result-org {
font-size: 0.72rem;
color: var(--text-muted);
}
.spk-editor__assign-form {
display: flex;
flex-direction: column;
gap: 0.65rem;
padding: 0.75rem;
background: var(--secondary-background);
border-radius: 8px;
border: 1px solid var(--border-color);
}
.spk-editor__selected-name {
font-size: 0.83rem;
color: var(--text-color);
margin: 0;
}
.spk-editor__row {
display: grid;
grid-template-columns: 1fr 80px;
gap: 0.65rem;
}
/* â”€â”€ Sub-editor videos (vid-editor) â”€â”€ */
.vid-editor {
display: flex;
flex-direction: column;
gap: 0.85rem;
}
.vid-editor__header {
display: flex;
align-items: center;
justify-content: space-between;
gap: 0.5rem;
}
.vid-editor__subtitle {
font-size: 0.9rem;
font-weight: 700;
color: var(--text-color);
margin: 0;
}
.vid-editor__empty {
font-size: 0.83rem;
color: var(--text-muted);
margin: 0;
}
.vid-editor__list {
list-style: none;
padding: 0;
margin: 0;
display: flex;
flex-direction: column;
gap: 0.35rem;
}
.vid-editor__item {
display: flex;
align-items: center;
justify-content: space-between;
gap: 0.75rem;
padding: 0.6rem 0.75rem;
background: var(--card-category-bg-color);
border: 1px solid var(--border-color);
border-radius: 8px;
}
.vid-editor__item--inactive {
opacity: 0.6;
}
.vid-editor__item-info {
display: flex;
align-items: center;
gap: 0.6rem;
flex: 1;
min-width: 0;
}
.vid-editor__label {
font-size: 0.84rem;
font-weight: 600;
color: var(--text-color);
white-space: nowrap;
}
.vid-editor__type-badge {
font-size: 0.65rem;
font-weight: 700;
background: var(--info-background);
color: var(--info-foreground);
padding: 0.08rem 0.4rem;
border-radius: 4px;
text-transform: uppercase;
flex-shrink: 0;
}
.vid-editor__url {
font-size: 0.72rem;
color: var(--text-muted);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
flex: 1;
}
.vid-editor__item-actions {
display: flex;
gap: 0.25rem;
flex-shrink: 0;
}
.vid-editor__btn-delete {
color: var(--danger-color);
}
.vid-editor__form {
display: flex;
flex-direction: column;
gap: 0.65rem;
padding: 0.9rem;
background: var(--secondary-background);
border-radius: 8px;
border: 1px solid var(--border-color);
}
.vid-editor__error {
padding: 0.5rem 0.75rem;
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: 6px;
font-size: 0.82rem;
}
.vid-editor__row {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 0.65rem;
}
.vid-editor__field--switch {
display: flex;
align-items: flex-end;
padding-bottom: 0.2rem;
}
.vid-editor__form-actions {
display: flex;
gap: 0.5rem;
padding-top: 0.35rem;
}
.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: 1.5px solid var(--border-color);
border-radius: var(--radius-md);
padding: 0.625rem 0.75rem;
cursor: pointer;
transition: all var(--transition-base);
min-height: 2.5rem;
}
.adr__trigger:hover {
border-color: var(--primary-color);
}
.adr__trigger:focus-within {
border-color: var(--focus-color);
box-shadow: 0 0 0 3px var(--focus-ring), var(--shadow-sm);
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);
}
/* =====================================================================
AppEventAbstractsConfig
BEM namespace: app-event-abstracts-config
===================================================================== */
/* ── Contenedor raíz ─────────────────────────────────────────────── */
.app-event-abstracts-config {
display: flex;
flex-direction: column;
gap: 1rem;
padding: .5rem;
min-width: 0;
}
/* ── Error global ────────────────────────────────────────────────── */
.app-event-abstracts-config__error {
background: var(--danger-background);
color: var(--danger-foreground);
border: 1px solid var(--danger-foreground);
border-radius: .4rem;
padding: .6rem .9rem;
font-size: .875rem;
}
/* ── Tabs ────────────────────────────────────────────────────────── */
.app-event-abstracts-config__tabs {
display: flex;
gap: .25rem;
border-bottom: 2px solid var(--border-color);
flex-wrap: wrap;
}
.app-event-abstracts-config__tab {
background: none;
border: none;
padding: .55rem 1.1rem;
font-size: .875rem;
font-weight: 500;
color: var(--muted-foreground);
cursor: pointer;
border-bottom: 2px solid transparent;
margin-bottom: -2px;
transition: color .15s, border-color .15s;
border-radius: .3rem .3rem 0 0;
}
.app-event-abstracts-config__tab:hover {
color: var(--foreground);
background: var(--surface-hover);
}
.app-event-abstracts-config__tab--active {
color: var(--primary-foreground);
border-bottom-color: var(--primary);
font-weight: 700;
}
/* ── Sección ─────────────────────────────────────────────────────── */
.app-event-abstracts-config__section {
display: flex;
flex-direction: column;
gap: .75rem;
}
.app-event-abstracts-config__section-header {
display: flex;
align-items: center;
justify-content: space-between;
padding-bottom: .5rem;
border-bottom: 1px solid var(--border-color);
flex-wrap: wrap;
gap: .5rem;
}
.app-event-abstracts-config__section-title {
font-size: .9375rem;
font-weight: 700;
letter-spacing: .04em;
text-transform: uppercase;
color: var(--foreground);
margin: 0;
}
/* ── Lista de ítems ──────────────────────────────────────────────── */
.app-event-abstracts-config__list {
display: flex;
flex-direction: column;
gap: .4rem;
}
/* ── Ítem base (modo / eje / área / subárea) ─────────────────────── */
.app-event-abstracts-config__item,
.app-event-abstracts-config__axis,
.app-event-abstracts-config__area,
.app-event-abstracts-config__subarea {
background: var(--surface);
border: 1px solid var(--border-color);
border-radius: .45rem;
transition: border-color .15s;
}
.app-event-abstracts-config__item:hover,
.app-event-abstracts-config__axis:hover {
border-color: var(--border-color-hover, var(--primary));
}
.app-event-abstracts-config__item--inactive {
opacity: .6;
}
/* ── Ítem simple (modo) ──────────────────────────────────────────── */
.app-event-abstracts-config__item {
display: flex;
align-items: center;
justify-content: space-between;
padding: .55rem .75rem;
gap: .5rem;
}
/* ── Cabecera de eje ─────────────────────────────────────────────── */
.app-event-abstracts-config__axis-header,
.app-event-abstracts-config__area-header {
display: flex;
align-items: center;
gap: .5rem;
padding: .55rem .75rem;
}
/* ── Info del ítem ───────────────────────────────────────────────── */
.app-event-abstracts-config__item-info {
display: flex;
align-items: center;
flex-wrap: wrap;
gap: .4rem;
flex: 1;
min-width: 0;
}
.app-event-abstracts-config__item-name {
font-size: .9rem;
font-weight: 600;
color: var(--foreground);
word-break: break-word;
}
.app-event-abstracts-config__item-name--area {
font-size: .875rem;
font-weight: 600;
}
.app-event-abstracts-config__item-name--subarea {
font-size: .85rem;
font-weight: 500;
}
.app-event-abstracts-config__item-desc {
font-size: .8rem;
color: var(--muted-foreground);
word-break: break-word;
}
/* ── Badges de estado ────────────────────────────────────────────── */
.app-event-abstracts-config__badge {
font-size: .72rem;
font-weight: 600;
padding: .15rem .55rem;
border-radius: 1rem;
letter-spacing: .03em;
text-transform: uppercase;
white-space: nowrap;
}
.app-event-abstracts-config__badge--active {
background: var(--success-background);
color: var(--success-foreground);
}
.app-event-abstracts-config__badge--inactive {
background: var(--muted-background, var(--surface));
color: var(--muted-foreground);
border: 1px solid var(--border-color);
}
/* ── Acciones del ítem ───────────────────────────────────────────── */
.app-event-abstracts-config__item-actions {
display: flex;
align-items: center;
gap: .25rem;
flex-shrink: 0;
}
.app-event-abstracts-config__action-btn {
background: none;
border: 1px solid var(--border-color);
border-radius: .35rem;
padding: .3rem .4rem;
cursor: pointer;
color: var(--muted-foreground);
display: flex;
align-items: center;
transition: color .15s, background .15s, border-color .15s;
}
.app-event-abstracts-config__action-btn:hover {
color: var(--foreground);
background: var(--surface-hover);
border-color: var(--border-color-hover, var(--primary));
}
.app-event-abstracts-config__action-btn--danger:hover {
color: var(--danger-foreground);
background: var(--danger-background);
border-color: var(--danger-foreground);
}
.app-event-abstracts-config__action-btn--add:hover {
color: var(--success-foreground);
background: var(--success-background);
border-color: var(--success-foreground);
}
/* ── Botón expand (chevron) ──────────────────────────────────────── */
.app-event-abstracts-config__expand-btn {
background: none;
border: none;
cursor: pointer;
padding: .2rem;
display: flex;
align-items: center;
color: var(--muted-foreground);
flex-shrink: 0;
transition: color .15s;
}
.app-event-abstracts-config__expand-btn:hover {
color: var(--foreground);
}
.app-event-abstracts-config__chevron {
transition: transform .2s;
}
.app-event-abstracts-config__chevron--open {
transform: rotate(180deg);
}
/* ── Áreas anidadas ──────────────────────────────────────────────── */
.app-event-abstracts-config__areas {
border-top: 1px solid var(--border-color);
padding: .4rem .4rem .4rem 1.5rem;
display: flex;
flex-direction: column;
gap: .35rem;
}
/* ── Subáreas anidadas ───────────────────────────────────────────── */
.app-event-abstracts-config__subareas {
border-top: 1px solid var(--border-color);
padding: .35rem .35rem .35rem 1.5rem;
display: flex;
flex-direction: column;
gap: .3rem;
}
.app-event-abstracts-config__subarea {
display: flex;
align-items: center;
justify-content: space-between;
padding: .4rem .65rem;
gap: .5rem;
}
/* ── Carga y vacío ───────────────────────────────────────────────── */
.app-event-abstracts-config__loading {
display: flex;
align-items: center;
gap: .6rem;
color: var(--muted-foreground);
font-size: .875rem;
padding: .75rem 0;
}
.app-event-abstracts-config__loading--nested {
padding: .4rem 0;
font-size: .82rem;
}
.app-event-abstracts-config__empty {
color: var(--muted-foreground);
font-size: .875rem;
text-align: center;
padding: 1.25rem 0;
}
.app-event-abstracts-config__empty--nested {
padding: .5rem 0;
font-size: .82rem;
text-align: left;
}
/* ── Modales: error y contexto ───────────────────────────────────── */
.app-event-abstracts-config__modal-error {
background: var(--danger-background);
color: var(--danger-foreground);
border: 1px solid var(--danger-foreground);
border-radius: .4rem;
padding: .5rem .8rem;
font-size: .85rem;
margin-bottom: .5rem;
}
.app-event-abstracts-config__modal-context {
font-size: .85rem;
color: var(--muted-foreground);
margin-bottom: .25rem;
}
.app-event-abstracts-config__confirm-note {
font-size: .82rem;
color: var(--muted-foreground);
margin-top: .25rem;
}
/* ── Responsivo — md ─────────────────────────────────────────────── */
@media (max-width: 768px) {
.app-event-abstracts-config__tabs {
gap: 0;
}
.app-event-abstracts-config__tab {
flex: 1;
text-align: center;
padding: .5rem .5rem;
font-size: .8rem;
}
.app-event-abstracts-config__section-header {
flex-direction: column;
align-items: flex-start;
}
.app-event-abstracts-config__areas {
padding-left: 1rem;
}
.app-event-abstracts-config__subareas {
padding-left: 1rem;
}
}
/* ── Responsivo — sm ─────────────────────────────────────────────── */
@media (max-width: 480px) {
.app-event-abstracts-config__item-actions {
gap: .15rem;
}
.app-event-abstracts-config__action-btn {
padding: .25rem .3rem;
}
.app-event-abstracts-config__item-name {
font-size: .85rem;
}
}
/* =====================================================
AppEventCategoriesEditor — BEM namespace: evcat
===================================================== */
/* ── Contenedor raíz ── */
.evcat {
display: flex;
flex-direction: column;
gap: 1rem;
padding: .5rem;
}
/* ── Barra superior ── */
.evcat__topbar {
display: flex;
align-items: center;
justify-content: space-between;
padding-bottom: .5rem;
border-bottom: 1px solid var(--border-color);
}
.evcat__title {
font-size: 1rem;
font-weight: 700;
letter-spacing: .04em;
color: var(--foreground);
text-transform: uppercase;
}
.evcat__reload-btn {
background: transparent;
border: 1px solid var(--border-color);
border-radius: .35rem;
color: var(--muted-foreground);
cursor: pointer;
padding: .25rem .55rem;
font-size: 1rem;
transition: color .15s, border-color .15s;
}
.evcat__reload-btn:hover { color: var(--foreground); border-color: var(--foreground); }
/* ── Mensajes de estado ── */
.evcat__loading,
.evcat__empty,
.evcat__empty-sub {
color: var(--muted-foreground);
font-size: .875rem;
padding: .5rem 0;
text-align: center;
}
.evcat__error {
background: var(--danger-background);
color: var(--danger-foreground);
border: 1px solid var(--danger-foreground);
border-radius: .4rem;
padding: .45rem .75rem;
font-size: .875rem;
}
/* ── Toolbar de acciones globales ── */
.evcat__toolbar { display: flex; gap: .5rem; }
.evcat__add-btn {
display: flex;
align-items: center;
gap: .35rem;
font-weight: 600;
letter-spacing: .03em;
}
.evcat__add-icon { font-size: 1.1rem; line-height: 1; }
/* ── Lista de cards ── */
.evcat__list {
display: flex;
flex-direction: column;
gap: .6rem;
}
/* ── Card de categoría ── */
.evcat__card {
border: 1px solid var(--border-color);
border-radius: .6rem;
overflow: hidden;
transition: border-color .15s, box-shadow .15s;
}
.evcat__card--new {
border-color: var(--primary-color);
box-shadow: 0 0 0 2px color-mix(in srgb, var(--primary-color) 20%, transparent);
}
.evcat__card--open { border-color: var(--primary-color); }
/* ── Cabecera colapsable ── */
.evcat__card-header {
width: 100%;
display: flex;
align-items: center;
gap: .6rem;
padding: .6rem .85rem;
background: var(--surface-color);
border: none;
cursor: pointer;
text-align: left;
transition: background .15s;
flex-wrap: wrap;
}
.evcat__card-header:hover { background: color-mix(in srgb, var(--primary-color) 8%, var(--surface-color)); }
.evcat__card-toggle {
color: var(--muted-foreground);
font-size: .8rem;
min-width: .9rem;
transition: color .15s;
}
.evcat__card--open .evcat__card-toggle { color: var(--primary-color); }
/* Chip de color en la cabecera */
.evcat__card-chip {
display: inline-block;
padding: .2rem .65rem;
border-radius: 999px;
font-size: .82rem;
font-weight: 600;
white-space: nowrap;
max-width: 14rem;
overflow: hidden;
text-overflow: ellipsis;
}
.evcat__card-type {
font-size: .75rem;
font-weight: 500;
color: var(--muted-foreground);
background: var(--background);
border: 1px solid var(--border-color);
border-radius: .3rem;
padding: .15rem .45rem;
white-space: nowrap;
}
/* Badges de estado */
.evcat__badge {
font-size: .7rem;
font-weight: 700;
padding: .15rem .45rem;
border-radius: .3rem;
letter-spacing: .04em;
text-transform: uppercase;
white-space: nowrap;
}
.evcat__badge--new  { background: var(--primary-color); color: var(--primary-foreground); }
.evcat__badge--id   { background: transparent; color: var(--muted-foreground); border: 1px solid var(--border-color); }
.evcat__badge--inactive { background: var(--danger-background); color: var(--danger-foreground); }
/* ── Cuerpo de la card ── */
.evcat__card-body {
padding: .85rem;
background: var(--background);
display: flex;
flex-direction: column;
gap: .85rem;
border-top: 1px solid var(--border-color);
}
/* ── Secciones dentro de la card ── */
.evcat__section {
display: flex;
flex-direction: column;
gap: .5rem;
}
.evcat__section-title {
font-size: .7rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: .08em;
color: var(--primary-color);
padding-bottom: .25rem;
border-bottom: 1px solid color-mix(in srgb, var(--primary-color) 25%, transparent);
}
/* ── Filas de campos ── */
.evcat__row {
display: grid;
gap: .6rem;
}
.evcat__row--4 { grid-template-columns: repeat(4, minmax(0,1fr)); }
.evcat__row--2 { grid-template-columns: repeat(2, minmax(0,1fr)); }
.evcat__row--checks { grid-template-columns: repeat(auto-fill, minmax(14rem, 1fr)); }
@media (max-width: 700px) {
.evcat__row--4 { grid-template-columns: repeat(2, minmax(0,1fr)); }
.evcat__row--2 { grid-template-columns: 1fr; }
}
@media (max-width: 420px) {
.evcat__row--4 { grid-template-columns: 1fr; }
}
/* ── Campo individual ── */
.evcat__field {
display: flex;
flex-direction: column;
gap: .25rem;
}
.evcat__field--action {
justify-content: flex-end;
}
.evcat__label {
font-size: .72rem;
font-weight: 600;
color: var(--muted-foreground);
text-transform: uppercase;
letter-spacing: .04em;
}
.evcat__input {
width: 100%;
padding: .38rem .55rem;
border: 1px solid var(--border-color);
border-radius: .4rem;
background: var(--surface-color);
color: var(--foreground);
font-size: .875rem;
transition: border-color .15s, box-shadow .15s;
box-sizing: border-box;
}
.evcat__input:focus {
outline: none;
border-color: var(--primary-color);
box-shadow: 0 0 0 2px color-mix(in srgb, var(--primary-color) 20%, transparent);
}
.evcat__input--select { cursor: pointer; }
/* ── Checkbox rows ── */
.evcat__check {
display: flex;
align-items: center;
gap: .45rem;
font-size: .875rem;
color: var(--foreground);
cursor: pointer;
padding: .3rem 0;
}
.evcat__check input[type="checkbox"] {
accent-color: var(--primary-color);
width: 1rem;
height: 1rem;
cursor: pointer;
}
/* ── Vista previa del chip ── */
.evcat__field--preview { justify-content: flex-end; }
.evcat__preview-chip {
display: inline-block;
padding: .3rem .8rem;
border-radius: 999px;
font-size: .85rem;
font-weight: 600;
white-space: nowrap;
align-self: flex-start;
}
/* ── Acciones del formulario ── */
.evcat__form-actions {
display: flex;
gap: .6rem;
flex-wrap: wrap;
padding-top: .25rem;
border-top: 1px solid var(--border-color);
}
/* ── Subsecciones colapsables ── */
.evcat__sub {
border: 1px solid var(--border-color);
border-radius: .45rem;
overflow: hidden;
}
.evcat__sub-title {
font-size: .8rem;
font-weight: 700;
color: var(--muted-foreground);
cursor: pointer;
padding: .45rem .7rem;
background: var(--surface-color);
letter-spacing: .04em;
user-select: none;
list-style: none;
display: flex;
align-items: center;
gap: .4rem;
transition: background .15s, color .15s;
}
.evcat__sub-title::-webkit-details-marker { display: none; }
.evcat__sub[open] .evcat__sub-title {
color: var(--foreground);
background: color-mix(in srgb, var(--primary-color) 8%, var(--surface-color));
border-bottom: 1px solid var(--border-color);
}
.evcat__sub-body { padding: .7rem; }
/* ── Formulario de cuotas ── */
.evcat__fee-form {
display: grid;
grid-template-columns: repeat(5, minmax(0,1fr));
gap: .5rem;
margin-bottom: .6rem;
align-items: end;
}
@media (max-width: 900px) {
.evcat__fee-form { grid-template-columns: repeat(3, minmax(0,1fr)); }
}
@media (max-width: 700px) {
.evcat__fee-form { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
/* ── Tabla de cuotas ── */
.evcat__fee-table {
width: 100%;
border-collapse: collapse;
font-size: .82rem;
}
.evcat__fee-table th,
.evcat__fee-table td {
border: 1px solid var(--border-color);
padding: .35rem .55rem;
text-align: left;
}
.evcat__fee-table th {
background: var(--surface-color);
font-weight: 700;
color: var(--muted-foreground);
text-transform: uppercase;
font-size: .7rem;
letter-spacing: .04em;
}
/* ── Hint nueva categoría ── */
.evcat__new-hint {
font-size: .78rem;
color: var(--muted-foreground);
text-align: center;
padding: .4rem;
border-top: 1px dashed var(--border-color);
}
/* ── Modal ── */
.evcat__modal-warn {
font-size: .82rem;
color: var(--danger-foreground);
margin-top: .4rem;
}
/* ── Botones base (sólo los que necesita este componente) ── */
.btn {
padding: .38rem .7rem;
border: 1px solid var(--border-color);
background: var(--surface-color);
color: var(--foreground);
border-radius: .4rem;
cursor: pointer;
font-size: .875rem;
font-weight: 500;
transition: background .15s, border-color .15s, opacity .15s;
white-space: nowrap;
}
.btn:hover { opacity: .85; }
.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--sm { padding: .2rem .45rem; font-size: .78rem; }
/* ============================================================
AppEventCurrencyEditor
BEM namespace: evt-currency-editor
Responsivo: sm / md / lg
============================================================ */
/* ── Raíz ── */
.evt-currency-editor {
display: flex;
flex-direction: column;
gap: 1rem;
padding: 1rem 0;
}
/* ── Cabecera ── */
.evt-currency-editor__header {
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: 0.5rem;
}
.evt-currency-editor__title {
font-weight: 600;
font-size: 0.95rem;
color: var(--text-primary);
}
/* ── Estados ── */
.evt-currency-editor__loading,
.evt-currency-editor__empty {
color: var(--text-secondary);
font-size: 0.875rem;
padding: 0.5rem 0;
}
.evt-currency-editor__error {
color: var(--danger-foreground);
background: var(--danger-background);
border-radius: 6px;
padding: 0.5rem 0.75rem;
font-size: 0.875rem;
}
/* ── Tabla ── */
.evt-currency-editor__table-wrap {
overflow-x: auto;
border-radius: 8px;
border: 1px solid var(--border-color);
}
.evt-currency-editor__table {
width: 100%;
border-collapse: collapse;
font-size: 0.875rem;
color: var(--text-primary);
}
.evt-currency-editor__table thead th {
background: var(--surface-secondary);
color: var(--text-secondary);
font-weight: 600;
text-align: left;
padding: 0.5rem 0.75rem;
white-space: nowrap;
}
.evt-currency-editor__table tbody td {
padding: 0.5rem 0.75rem;
border-top: 1px solid var(--border-color);
vertical-align: middle;
}
.evt-currency-editor__row--inactive td {
opacity: 0.55;
}
/* ── Código + Símbolo ── */
.evt-currency-editor__code-chip {
display: inline-flex;
align-items: center;
gap: 0.35rem;
font-weight: 600;
font-size: 0.9rem;
}
.evt-currency-editor__symbol {
font-size: 0.8rem;
color: var(--text-secondary);
background: var(--surface-secondary);
border-radius: 4px;
padding: 0 0.35rem;
}
/* ── Formulario ── */
.evt-currency-editor__form-panel {
background: var(--surface-secondary);
border: 1px solid var(--border-color);
border-radius: 8px;
padding: 1rem;
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.evt-currency-editor__form-title {
font-size: 0.9rem;
font-weight: 600;
color: var(--text-primary);
margin: 0 0 0.25rem;
}
.evt-currency-editor__form-grid {
display: grid;
grid-template-columns: 1fr;
gap: 0.75rem;
}
@media (min-width: 600px) {
.evt-currency-editor__form-grid {
grid-template-columns: 1fr 1fr;
}
}
@media (min-width: 900px) {
.evt-currency-editor__form-grid {
grid-template-columns: 1fr 1fr 1fr;
}
}
.evt-currency-editor__field {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.evt-currency-editor__label {
font-size: 0.8rem;
font-weight: 500;
color: var(--text-secondary);
}
.evt-currency-editor__form-error {
color: var(--danger-foreground);
font-size: 0.8rem;
}
.evt-currency-editor__form-actions {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
justify-content: flex-end;
padding-top: 0.25rem;
}
/* ── Confirmación de eliminación ── */
.evt-currency-editor__confirm {
background: var(--danger-background);
border: 1px solid var(--danger-foreground);
border-radius: 8px;
padding: 0.75rem 1rem;
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.evt-currency-editor__confirm-text {
color: var(--danger-foreground);
font-size: 0.875rem;
}
.evt-currency-editor__confirm-actions {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
}
/* ── Nota informativa ── */
.evt-currency-editor__note {
background: var(--info-background, var(--surface-secondary));
color: var(--info-foreground, var(--text-secondary));
border-radius: 6px;
padding: 0.5rem 0.75rem;
font-size: 0.8rem;
}
/* =====================================================
AppEventFeeRules — BEM namespace: app-event-fee-rules
===================================================== */
/* ── Contenedor raíz ── */
.app-event-fee-rules {
display: flex;
flex-direction: column;
gap: 1rem;
padding: .5rem;
}
/* ── Header ── */
.app-event-fee-rules__header {
display: flex;
align-items: center;
justify-content: space-between;
padding-bottom: .5rem;
border-bottom: 1px solid var(--border-color);
}
.app-event-fee-rules__title {
font-size: 1rem;
font-weight: 700;
letter-spacing: .04em;
color: var(--foreground);
text-transform: uppercase;
margin: 0;
}
/* ── Filtros ── */
.app-event-fee-rules__filters {
display: flex;
gap: .75rem;
flex-wrap: wrap;
}
/* ── Estados de carga y vacío ── */
.app-event-fee-rules__loading {
display: flex;
align-items: center;
gap: .6rem;
color: var(--muted-foreground);
font-size: .875rem;
padding: .75rem 0;
}
.app-event-fee-rules__empty {
color: var(--muted-foreground);
font-size: .875rem;
text-align: center;
padding: 1.5rem 0;
}
/* ── Error ── */
.app-event-fee-rules__error {
background: var(--danger-background);
color: var(--danger-foreground);
border: 1px solid var(--danger-foreground);
border-radius: .4rem;
padding: .45rem .75rem;
font-size: .875rem;
}
/* ── Fila inactiva ── */
.app-event-fee-rules__row--inactive td {
opacity: .55;
}
/* ── Celda de país ── */
.app-event-fee-rules__country-code {
font-weight: 700;
font-size: .8rem;
letter-spacing: .06em;
color: var(--foreground);
margin-right: .35rem;
}
.app-event-fee-rules__country-name {
font-size: .875rem;
color: var(--muted-foreground);
}
/* ── Porcentaje ── */
.app-event-fee-rules__percent {
font-weight: 600;
font-variant-numeric: tabular-nums;
}
/* ── Badges de tipo de regla ── */
.app-event-fee-rules__badge {
display: inline-block;
padding: .15rem .55rem;
border-radius: 999px;
font-size: .75rem;
font-weight: 600;
letter-spacing: .03em;
}
.app-event-fee-rules__badge--general {
background: var(--info-background, rgba(59,130,246,.12));
color: var(--info-foreground, #3b82f6);
}
.app-event-fee-rules__badge--specific {
background: var(--warning-background, rgba(234,179,8,.12));
color: var(--warning-foreground, #ca8a04);
}
/* ── Badges de estado ── */
.app-event-fee-rules__status {
display: inline-block;
padding: .15rem .55rem;
border-radius: 999px;
font-size: .75rem;
font-weight: 600;
letter-spacing: .03em;
}
.app-event-fee-rules__status--active {
background: var(--success-background);
color: var(--success-foreground);
}
.app-event-fee-rules__status--inactive {
background: var(--muted-background, rgba(100,100,100,.12));
color: var(--muted-foreground);
}
/* ── Botones de acción en tabla ── */
.app-event-fee-rules__action-btn {
background: transparent;
border: 1px solid var(--border-color);
border-radius: .35rem;
color: var(--muted-foreground);
cursor: pointer;
padding: .25rem .4rem;
margin-right: .25rem;
transition: color .15s, border-color .15s;
display: inline-flex;
align-items: center;
}
.app-event-fee-rules__action-btn:hover {
color: var(--foreground);
border-color: var(--foreground);
}
.app-event-fee-rules__action-btn--danger:hover {
color: var(--danger-foreground);
border-color: var(--danger-foreground);
}
/* ── Modal: error inline ── */
.app-event-fee-rules__modal-error {
background: var(--danger-background);
color: var(--danger-foreground);
border: 1px solid var(--danger-foreground);
border-radius: .4rem;
padding: .45rem .75rem;
font-size: .875rem;
margin-bottom: .75rem;
}
/* ── Modal: info de edición ── */
.app-event-fee-rules__edit-info {
font-size: .875rem;
color: var(--muted-foreground);
margin-bottom: .75rem;
line-height: 1.6;
}
/* ── Modal: nota de confirmación ── */
.app-event-fee-rules__confirm-note {
font-size: .8rem;
color: var(--muted-foreground);
margin-top: .5rem;
}
/* ── Responsividad ── */
@media (max-width: 600px) {
.app-event-fee-rules__filters {
flex-direction: column;
}
.app-event-fee-rules__header {
flex-direction: column;
align-items: flex-start;
gap: .5rem;
}
}
.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; }
}
/* ============================================================
AppEventStripsEditor
BEM namespace: evt-strips-editor
Responsivo: sm / md / lg
============================================================ */
/* ── Raíz ── */
.evt-strips-editor {
display: flex;
flex-direction: column;
gap: 1rem;
padding: 1rem 0;
}
/* ── Cabecera ── */
.evt-strips-editor__header {
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: 0.5rem;
}
.evt-strips-editor__title {
font-weight: 600;
font-size: 0.95rem;
color: var(--text-primary);
}
/* ── Estados ── */
.evt-strips-editor__loading,
.evt-strips-editor__empty {
color: var(--text-secondary);
font-size: 0.875rem;
padding: 0.5rem 0;
}
.evt-strips-editor__error {
color: var(--danger-foreground);
background: var(--danger-background);
border-radius: 6px;
padding: 0.5rem 0.75rem;
font-size: 0.875rem;
}
/* ── Tabla ── */
.evt-strips-editor__table-wrap {
overflow-x: auto;
border-radius: 8px;
border: 1px solid var(--border-color);
}
.evt-strips-editor__table {
width: 100%;
border-collapse: collapse;
font-size: 0.875rem;
color: var(--text-primary);
}
.evt-strips-editor__table thead th {
background: var(--surface-secondary);
color: var(--text-secondary);
font-weight: 600;
text-align: left;
padding: 0.5rem 0.75rem;
white-space: nowrap;
}
.evt-strips-editor__table tbody td {
padding: 0.5rem 0.75rem;
border-top: 1px solid var(--border-color);
vertical-align: middle;
}
.evt-strips-editor__row--inactive td {
opacity: 0.55;
}
/* ── Chip de color del strip ── */
.evt-strips-editor__color-chip {
display: inline-flex;
align-items: center;
gap: 0.4rem;
font-size: 0.875rem;
font-weight: 500;
}
.evt-strips-editor__color-swatch {
display: inline-block;
width: 1.1rem;
height: 1.1rem;
border-radius: 3px;
border: 1px solid rgba(0,0,0,.15);
flex-shrink: 0;
}
/* ── Formulario ── */
.evt-strips-editor__form-panel {
background: var(--surface-secondary);
border: 1px solid var(--border-color);
border-radius: 8px;
padding: 1rem;
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.evt-strips-editor__form-title {
font-size: 0.9rem;
font-weight: 600;
color: var(--text-primary);
margin: 0 0 0.25rem;
}
.evt-strips-editor__form-grid {
display: grid;
grid-template-columns: 1fr;
gap: 0.75rem;
}
@media (min-width: 600px) {
.evt-strips-editor__form-grid {
grid-template-columns: 1fr 1fr;
}
}
.evt-strips-editor__field {
display: flex;
flex-direction: column;
gap: 0.25rem;
}
.evt-strips-editor__label {
font-size: 0.8rem;
font-weight: 500;
color: var(--text-secondary);
}
.evt-strips-editor__form-error {
color: var(--danger-foreground);
font-size: 0.8rem;
}
.evt-strips-editor__form-actions {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
justify-content: flex-end;
padding-top: 0.25rem;
}
/* ── Confirmación de eliminación ── */
.evt-strips-editor__confirm {
background: var(--danger-background);
border: 1px solid var(--danger-foreground);
border-radius: 8px;
padding: 0.75rem 1rem;
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.evt-strips-editor__confirm-text {
color: var(--danger-foreground);
font-size: 0.875rem;
}
.evt-strips-editor__confirm-actions {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
}
/* =======================================================================
NexEvent — AppModal
Modal con glassmorphism, glow border, animaciones fluidas
======================================================================= */
.app-modal {
position: fixed;
inset: 0;
z-index: var(--z-modal);
display: flex;
align-items: center;
justify-content: center;
padding: 0.5rem;
animation: app-modal-fade-in 0.18s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes app-modal-fade-in {
from { opacity: 0; }
to { opacity: 1; }
}
.app-modal__overlay {
position: absolute;
inset: 0;
background: var(--overlay-color);
backdrop-filter: blur(10px) saturate(160%);
-webkit-backdrop-filter: blur(10px) saturate(160%);
animation: app-modal-overlay-fade-in 0.18s 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(10px); }
}
.app-modal__dialog {
position: relative;
background: var(--surface-color);
color: var(--text-color);
border-radius: var(--radius-xl);
border: 1.5px solid var(--border-color);
width: 100%;
max-width: 520px;
max-height: 90vh;
overflow: hidden;
display: flex;
flex-direction: column;
box-shadow: var(--shadow-xl), var(--shadow-glow);
animation: app-modal-dialog-scale-in 0.24s cubic-bezier(0.34, 1.56, 0.64, 1);
}
/* Linea glow superior */
.app-modal__dialog::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
background: var(--card-accent-gradient);
border-radius: var(--radius-xl) var(--radius-xl) 0 0;
z-index: 1;
}
@keyframes app-modal-dialog-scale-in {
from { opacity: 0; transform: scale(0.94) translateY(16px); }
to { opacity: 1; transform: scale(1) translateY(0); }
}
.app-modal__dialog--wide { max-width: 940px; }
.app-modal__dialog--narrow { max-width: 420px; }
.app-modal__dialog--full { max-width: 1280px; }
.app-modal__dialog--xlarge { max-width: 1600px; width: 95vw; }
.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: 1.125rem 1.375rem;
border-bottom: 1px solid var(--divider-color);
flex-shrink: 0;
}
.app-modal__title {
margin: 0;
font-size: 1.25rem;
font-weight: 700;
color: var(--text-color);
line-height: 1.3;
letter-spacing: -0.02em;
word-break: break-word;
}
.app-modal__close-btn,
.app-modal__close {
background: transparent;
border: 1.5px solid transparent;
color: var(--text-muted);
width: 2.5rem;
height: 2.5rem;
min-width: 2.5rem;
border-radius: var(--radius-sm);
display: inline-flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: all var(--transition-base);
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);
border-color: var(--border-color);
color: var(--primary-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.93);
}
.app-modal__content {
padding: 1.375rem;
flex: 1 1 auto;
overflow-y: auto;
overflow-x: hidden;
color: var(--text-color);
line-height: 1.6;
}
.app-modal__content::-webkit-scrollbar { width: 5px; }
.app-modal__content::-webkit-scrollbar-track { background: transparent; }
.app-modal__content::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 3px; }
.app-modal__content::-webkit-scrollbar-thumb:hover { background: var(--primary-color); }
.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.375rem;
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 */
@media (min-width: 420px) and (max-width: 479px) {
.app-modal { padding: 0.375rem; }
.app-modal__dialog { max-width: 100%; max-height: 92vh; border-radius: var(--radius-lg); }
.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; }
}
@media (min-width: 480px) and (max-width: 639px) {
.app-modal { padding: 0.5rem; }
.app-modal__dialog { max-width: 100%; max-height: 92vh; border-radius: var(--radius-lg); }
.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; }
}
@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__title { font-size: 1.125rem; }
}
@media (min-width: 1025px) {
.app-modal { padding: 1rem; }
.app-modal__dialog { max-width: 580px; }
.app-modal__dialog--wide { max-width: min(940px, 85vw); }
.app-modal__dialog--full { max-width: min(1280px, 90vw); }
.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; }
}
@media (max-width: 419px) {
.app-modal { padding: 0; }
.app-modal__dialog, .app-modal__dialog--wide, .app-modal__dialog--narrow, .app-modal__dialog--full {
width: 100vw;
max-width: 100vw;
max-height: 100vh;
border-radius: 0;
border: none;
}
.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; }
}
/* =======================================================================
NexEvent — AppPagination
Paginacion con botones con glow y pagina activa con gradiente
======================================================================= */
.app-pagination {
display: flex;
align-items: center;
gap: 0.4rem;
justify-content: center;
margin: 1.5rem 0 1rem 0;
flex-wrap: wrap;
}
.app-pagination__nav-button {
background: var(--surface-color);
color: var(--primary-color);
border: 1.5px solid var(--border-color);
border-radius: var(--radius-md);
padding: 0.5rem 1rem;
font-size: 0.875rem;
font-weight: 600;
cursor: pointer;
transition: all var(--transition-base);
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);
letter-spacing: 0.01em;
}
.app-pagination__nav-button:hover:not(:disabled) {
background: var(--gradient-primary);
color: #ffffff;
border-color: transparent;
box-shadow: var(--shadow-sm), var(--shadow-glow);
transform: translateY(-1px);
}
.app-pagination__nav-button:active:not(:disabled) { transform: scale(0.97); 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;
}
.app-pagination__page-info {
font-weight: 700;
color: var(--text-color);
min-width: 4rem;
text-align: center;
padding: 0 0.5rem;
font-size: 0.875rem;
letter-spacing: 0.02em;
}
.app-pagination__page-info .app-pagination__current-page {
color: var(--primary-color);
font-weight: 800;
font-size: 1.0625rem;
}
.app-pagination__summary {
text-align: center;
color: var(--text-muted);
font-size: 0.8125rem;
margin-top: 0.5rem;
width: 100%;
letter-spacing: 0.02em;
}
/* Paginacion numerada */
.app-pagination--numbered { gap: 0.35rem; }
.app-pagination__page-button {
background: var(--surface-color);
color: var(--text-color);
border: 1.5px solid var(--border-color);
border-radius: var(--radius-md);
padding: 0.5rem 0.75rem;
font-size: 0.875rem;
font-weight: 600;
cursor: pointer;
transition: all var(--transition-base);
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(--gradient-primary);
color: #ffffff;
border-color: transparent;
font-weight: 700;
box-shadow: var(--shadow-sm), var(--shadow-glow);
pointer-events: none;
}
.app-pagination__page-button--dots {
pointer-events: none;
border: none;
box-shadow: none;
background: transparent;
color: var(--text-muted);
}
/* Tamanios */
.app-pagination--sm .app-pagination__nav-button,
.app-pagination--sm .app-pagination__page-button {
padding: 0.375rem 0.625rem;
font-size: 0.8125rem;
min-width: 2rem;
min-height: 2rem;
border-radius: var(--radius-sm);
}
.app-pagination--lg .app-pagination__nav-button,
.app-pagination--lg .app-pagination__page-button {
padding: 0.65rem 1.25rem;
font-size: 1rem;
min-width: 3rem;
min-height: 3rem;
}
/* Responsive */
@media (max-width: 768px) {
.app-pagination { font-size: 0.875rem; gap: 0.35rem; margin: 1rem 0 0.75rem 0; }
.app-pagination__nav-button, .app-pagination__page-button { padding: 0.4rem 0.75rem; font-size: 0.8125rem; min-width: 2.25rem; min-height: 2.25rem; }
.app-pagination__page-info { font-size: 0.8125rem; min-width: 3rem; }
.app-pagination__summary { font-size: 0.775rem; }
}
@media (max-width: 480px) {
.app-pagination__nav-button, .app-pagination__page-button { padding: 0.375rem 0.625rem; min-width: 2rem; min-height: 2rem; }
.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: var(--z-notification);
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;
}
}
/* Botones de acci�n dentro del resultado de pago */
.app-payment-result__actions {
display: flex;
flex-direction: column;
gap: 10px;
width: 100%;
align-items: center;
margin-top: 0.5rem;
}
.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;
}
}
/* NexEvent — AppProgressBar */
.app-progress-bar {
width: 100%;
max-width: 400px;
margin: 0.5rem 0;
}
.app-progress-bar__track {
width: 100%;
height: 0.5rem;
background: var(--border-color);
border-radius: var(--radius-pill);
overflow: hidden;
box-shadow: inset 0 1px 3px rgba(0,0,0,0.1);
position: relative;
}
.app-progress-bar__fill {
height: 100%;
background: var(--gradient-primary);
border-radius: var(--radius-pill);
transition: width 0.4s cubic-bezier(0.4, 1, 0.7, 1);
box-shadow: var(--shadow-glow);
}
/* 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(--gradient-primary);
border-radius: var(--radius-pill);
animation: app-progress-bar-animated 1.2s infinite linear;
box-shadow: var(--shadow-glow);
}
@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;
}
/* ==============================================
AppSpinner - Componente de carga moderno
============================================== */
.app-spinner__container {
display: flex;
align-items: center;
justify-content: center;
flex-direction: column;
gap: 1rem;
min-height: 80px;
min-width: 80px;
position: relative;
padding: 1rem;
}
.app-spinner__svg {
width: 64px;
height: 64px;
display: block;
}
/* Ring de fondo */
.app-spinner__ring {
stroke: var(--border-color);
stroke-width: 6;
opacity: 0.2;
fill: none;
}
/* Arco animado */
.app-spinner__arc {
stroke: var(--primary-color);
stroke-width: 6;
stroke-linecap: round;
stroke-dasharray: 90, 150;
stroke-dashoffset: 0;
fill: none;
transform-origin: 50% 50%;
animation: app-spinner-arc-spin 1.4s ease-in-out infinite;
}
@keyframes app-spinner-arc-spin {
0% {
stroke-dasharray: 1, 150;
stroke-dashoffset: 0;
transform: rotate(0deg);
}
50% {
stroke-dasharray: 90, 150;
stroke-dashoffset: -35;
transform: rotate(180deg);
}
100% {
stroke-dasharray: 90, 150;
stroke-dashoffset: -124;
transform: rotate(360deg);
}
}
/* Texto dentro del spinner */
.app-spinner__text {
fill: var(--primary-color);
font-family: 'Segoe UI', 'Roboto', Arial, sans-serif;
font-weight: 700;
font-size: 0.875rem;
pointer-events: none;
user-select: none;
opacity: 0.9;
animation: app-spinner-text-pulse 1.4s ease-in-out infinite;
}
@keyframes app-spinner-text-pulse {
0%, 100% {
opacity: 0.9;
}
50% {
opacity: 0.4;
}
}
/* Mensaje de carga */
.app-spinner__message {
color: var(--text-color);
font-size: 0.9375rem;
font-weight: 500;
text-align: center;
margin-top: 0.5rem;
animation: app-spinner-message-fade 1.4s ease-in-out infinite;
}
@keyframes app-spinner-message-fade {
0%, 100% {
opacity: 1;
}
50% {
opacity: 0.5;
}
}
/* ============================================== */
/* Variantes de tamaño */
/* ============================================== */
.app-spinner--sm .app-spinner__svg {
width: 32px;
height: 32px;
}
.app-spinner--sm .app-spinner__ring,
.app-spinner--sm .app-spinner__arc {
stroke-width: 4;
}
.app-spinner--lg .app-spinner__svg {
width: 96px;
height: 96px;
}
.app-spinner--lg .app-spinner__ring,
.app-spinner--lg .app-spinner__arc {
stroke-width: 8;
}
/* ============================================== */
/* Variantes de color */
/* ============================================== */
.app-spinner--secondary .app-spinner__arc {
stroke: var(--secondary-color);
}
.app-spinner--secondary .app-spinner__text {
fill: var(--secondary-color);
}
.app-spinner--success .app-spinner__arc {
stroke: var(--success-color);
}
.app-spinner--success .app-spinner__text {
fill: var(--success-color);
}
.app-spinner--danger .app-spinner__arc {
stroke: var(--danger-color);
}
.app-spinner--danger .app-spinner__text {
fill: var(--danger-color);
}
/* ============================================== */
/* Spinner de overlay (pantalla completa) */
/* ============================================== */
.app-spinner--overlay {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: var(--overlay-color);
backdrop-filter: blur(4px);
-webkit-backdrop-filter: blur(4px);
z-index: 9999;
display: flex;
align-items: center;
justify-content: center;
animation: app-spinner-overlay-fade-in 0.2s ease-out;
}
@keyframes app-spinner-overlay-fade-in {
from {
opacity: 0;
}
to {
opacity: 1;
}
}
.app-spinner--overlay .app-spinner__container {
background: var(--surface-color);
padding: 2rem;
border-radius: 1rem;
box-shadow: var(--shadow-xl);
min-width: 200px;
}
/* ============================================== */
/* Spinner inline (dentro de botones) */
/* ============================================== */
.app-spinner--inline {
display: inline-flex;
vertical-align: middle;
}
.app-spinner--inline .app-spinner__svg {
width: 1rem;
height: 1rem;
}
.app-spinner--inline .app-spinner__ring,
.app-spinner--inline .app-spinner__arc {
stroke-width: 4;
}
/* Contenedor principal */
.app-steps {
display: flex;
align-items: flex-end;
justify-content: center;
gap: 2.5rem;
width: 100%;
max-width: 100%;
overflow-x: auto;
padding: 0.5rem 0;
box-sizing: border-box;
}
/* Cada paso */
.app-steps__item {
display: flex;
flex-direction: column;
align-items: center;
position: relative;
min-width: 0;
}
/* Círculo del número/check */
.app-steps__circle {
width: 2.2rem;
height: 2.2rem;
border-radius: 50%;
background: var(--surface-color);
color: var(--primary-color);
display: flex;
align-items: center;
justify-content: center;
font-weight: bold;
font-size: 1.1rem;
border: 2px solid var(--primary-color);
transition: background 0.3s, color 0.3s, border-color 0.3s;
flex-shrink: 0;
}
/* Paso activo */
.app-steps__item--active .app-steps__circle {
background: var(--primary-color);
color: var(--text-light);
border-color: var(--primary-color);
}
/* Paso completado: animación y color */
.app-steps__item--completed .app-steps__circle {
background: var(--success-color);
color: var(--text-light);
border-color: var(--success-color);
animation: app-steps-check-pop 0.25s cubic-bezier(.4,1.3,.6,1) 1;
}
/* Animación "pop" al marcar completado */
@keyframes app-steps-check-pop {
0% {
transform: scale(1);
}
60% {
transform: scale(1.25);
}
100% {
transform: scale(1);
}
}
/* Etiqueta debajo del número */
.app-steps__label {
margin-top: 0.4rem;
font-size: 0.85rem;
color: var(--text-color);
min-width: 60px;
max-width: 90px;
text-align: center;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
line-height: 1.1;
transition: opacity 0.2s;
cursor: default;
}
/* Línea conectora entre pasos */
.app-steps__connector {
position: absolute;
top: 1.1rem;
left: 100%;
width: 2.5rem;
height: 2px;
background: var(--divider-color);
z-index: 0;
}
/* Check especial (puedes usar un span o svg con esta clase) */
.app-steps__check {
color: var(--success-background);
font-weight: bold;
font-size: 1.2em;
transition: color 0.3s;
}
/* Responsividad para móvil */
@media (max-width: 600px) {
.app-steps {
gap: 0.5rem;
padding: 0.5rem 0.2rem;
justify-content: flex-start;
}
.app-steps__label {
display: none;
}
.app-steps__connector {
width: 1.2rem;
}
.app-steps__circle {
width: 2rem;
height: 2rem;
font-size: 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: 0.5rem 1rem;
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: 1rem;
}
.app-table__head th:last-child {
border-top-right-radius: 0.5rem;
padding-right: 1rem;
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.5rem 0.875rem;
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: 1rem;
}
.app-table__body td:last-child {
padding-right: 1rem;
}
/* Ú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)}}
/* ═══════════════════════════════════════════════════════════════
AppToast — Glassmorphism · Electric Cobalt Design System
═══════════════════════════════════════════════════════════════ */
/* ── Contenedor posicionado ── */
.app-toast__container {
position: fixed;
top: 1.25rem;
right: 1.25rem;
z-index: var(--z-notification);
pointer-events: none;
}
/* ── Toast base ── */
.app-toast {
pointer-events: all;
position: relative;
display: flex;
align-items: flex-start;
gap: 0.75rem;
min-width: 18rem;
max-width: 22rem;
padding: 1rem 2.75rem 1rem 1rem;
border-radius: var(--radius-md);
overflow: hidden;
/* Glassmorphism */
background: var(--glass-bg);
backdrop-filter: blur(var(--glass-blur));
-webkit-backdrop-filter: blur(var(--glass-blur));
border: 1px solid var(--glass-border);
box-shadow: var(--shadow-xl), 0 0 0 1px rgba(255, 255, 255, 0.06) inset;
}
/* ── Animación de entrada ── */
.app-toast--entering {
animation: app-toast-enter 0.38s var(--transition-spring) both;
}
/* ── Animación de salida ── */
.app-toast--closing {
animation: app-toast-leave 0.32s cubic-bezier(0.4, 0, 1, 1) both;
}
/* ── Barra de acento izquierda ── */
.app-toast__accent-bar {
position: absolute;
inset-block: 0;
left: 0;
width: 4px;
border-radius: var(--radius-md) 0 0 var(--radius-md);
}
/* ── Icono ── */
.app-toast__icon {
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
width: 1.625rem;
height: 1.625rem;
border-radius: 50%;
margin-top: 0.05rem;
}
.app-toast__icon svg {
width: 1rem;
height: 1rem;
}
/* ── Cuerpo ── */
.app-toast__body {
flex: 1;
min-width: 0;
display: flex;
flex-direction: column;
gap: 0.2rem;
}
.app-toast__title {
margin: 0;
font-size: 0.9375rem;
font-weight: 700;
line-height: 1.3;
color: var(--text-color);
letter-spacing: -0.01em;
}
.app-toast__content {
margin: 0;
font-size: 0.8125rem;
line-height: 1.5;
color: var(--text-secondary);
word-break: break-word;
}
/* ── Link ── */
.app-toast__link {
display: inline-flex;
align-items: center;
gap: 0.3rem;
margin-top: 0.35rem;
font-size: 0.8125rem;
font-weight: 600;
color: var(--primary-color);
text-decoration: none;
transition: opacity var(--transition-fast);
}
.app-toast__link svg {
width: 0.75rem;
height: 0.75rem;
}
.app-toast__link:hover { opacity: 0.75; }
/* ── Botón cerrar ── */
.app-toast__close {
position: absolute;
top: 0.625rem;
right: 0.625rem;
display: flex;
align-items: center;
justify-content: center;
width: 1.625rem;
height: 1.625rem;
background: none;
border: none;
border-radius: var(--radius-sm);
color: var(--text-muted);
cursor: pointer;
padding: 0;
transition: background-color var(--transition-fast), color var(--transition-fast);
}
.app-toast__close svg { width: 0.875rem; height: 0.875rem; }
.app-toast__close:hover {
background-color: var(--hover-background-color);
color: var(--text-color);
}
/* ═══════════════════════════════════════════════════════════════
Variantes por tipo
═══════════════════════════════════════════════════════════════ */
/* ── Info (Ocean Jade) ── */
.app-toast--info .app-toast__accent-bar {
background: linear-gradient(180deg, var(--accent-color), var(--accent-dark));
}
.app-toast--info .app-toast__icon {
background-color: var(--info-background);
color: var(--accent-dark);
}
/* ── Success ── */
.app-toast--success .app-toast__accent-bar {
background: linear-gradient(180deg, var(--success-color), var(--success-dark));
}
.app-toast--success .app-toast__icon {
background-color: var(--success-background);
color: var(--success-dark);
}
/* ── Warning (Plasma Orange) ── */
.app-toast--warning .app-toast__accent-bar {
background: linear-gradient(180deg, var(--warning-color), var(--warning-dark));
}
.app-toast--warning .app-toast__icon {
background-color: var(--warning-background);
color: var(--warning-dark);
}
/* ── Error ── */
.app-toast--error .app-toast__accent-bar {
background: linear-gradient(180deg, var(--danger-color), var(--danger-dark));
}
.app-toast--error .app-toast__icon {
background-color: var(--danger-background);
color: var(--danger-dark);
}
/* ═══════════════════════════════════════════════════════════════
Dark mode
═══════════════════════════════════════════════════════════════ */
@media (prefers-color-scheme: dark) {
:root:not([data-theme='light']) .app-toast {
background: rgba(15, 20, 40, 0.88);
border-color: var(--border-color);
box-shadow: var(--shadow-xl), 0 0 0 1px rgba(91, 132, 240, 0.08) inset;
}
:root:not([data-theme='light']) .app-toast--info .app-toast__icon {
background-color: var(--info-background);
color: var(--accent-color);
}
:root:not([data-theme='light']) .app-toast--success .app-toast__icon {
background-color: var(--success-background);
color: var(--success-color);
}
:root:not([data-theme='light']) .app-toast--warning .app-toast__icon {
background-color: var(--warning-background);
color: var(--warning-color);
}
:root:not([data-theme='light']) .app-toast--error .app-toast__icon {
background-color: var(--danger-background);
color: var(--danger-color);
}
}
/* ═══════════════════════════════════════════════════════════════
Keyframes
═══════════════════════════════════════════════════════════════ */
@keyframes app-toast-enter {
from {
opacity: 0;
transform: translateX(1.5rem) scale(0.95);
}
to {
opacity: 1;
transform: translateX(0) scale(1);
}
}
@keyframes app-toast-leave {
from {
opacity: 1;
transform: translateX(0) scale(1);
max-height: 10rem;
}
to {
opacity: 0;
transform: translateX(1.5rem) scale(0.95);
max-height: 0;
}
}
/* ── Responsive ── */
@media (max-width: 480px) {
.app-toast__container {
top: auto;
bottom: 1rem;
right: 0.75rem;
left: 0.75rem;
}
.app-toast {
min-width: 0;
max-width: 100%;
}
@keyframes app-toast-enter {
from {
opacity: 0;
transform: translateY(1rem) scale(0.97);
}
to {
opacity: 1;
transform: translateY(0) scale(1);
}
}
@keyframes app-toast-leave {
from {
opacity: 1;
transform: translateY(0) scale(1);
}
to {
opacity: 0;
transform: translateY(1rem) scale(0.97);
}
}
}
.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: var(--z-tooltip);
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;
}
/* ============================================================
BundleListPage â€” BEM: bnd-list-page
PÃ¡gina admin de gestiÃ³n de Bundles / Tracks.
============================================================ */
.bnd-list-page {
display: flex;
flex-direction: column;
gap: 1rem;
padding: 1.25rem;
}
.bnd-list-page__error {
color: var(--danger-foreground);
background: var(--danger-background);
padding: 1rem;
border-radius: 8px;
}
/* â”€â”€ Breadcrumb â”€â”€ */
.bnd-list-page__breadcrumb {
display: flex;
align-items: center;
gap: 0.4rem;
font-size: 0.82rem;
color: var(--text-muted);
flex-wrap: wrap;
}
.bnd-list-page__breadcrumb-sep { opacity: 0.5; }
.bnd-list-page__breadcrumb-current {
color: var(--text-color);
font-weight: 500;
}
.bnd-list-page__title {
font-size: 1.4rem;
font-weight: 700;
color: var(--text-color);
margin: 0;
}
.bnd-list-page__spinner {
display: flex;
justify-content: center;
padding: 2rem;
}
.bnd-list-page__filter-group { margin-bottom: 1rem; }
/* Tabla */
.bnd-list-page__name-cell {
font-weight: 600;
color: var(--text-color);
}
.bnd-list-page__count-badge {
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 24px;
height: 24px;
padding: 0 6px;
background: var(--secondary-background);
color: var(--text-secondary);
border-radius: var(--radius-pill);
font-size: 0.74rem;
font-weight: 700;
}
.bnd-list-page__badge {
display: inline-block;
font-size: 0.7rem;
font-weight: 600;
padding: 0.15rem 0.5rem;
border-radius: var(--radius-pill);
}
.bnd-list-page__badge--active {
background: var(--success-background);
color: var(--success-foreground);
}
.bnd-list-page__badge--inactive {
background: var(--disabled-background);
color: var(--disabled-color);
}
/* â”€â”€ AppBundleEditor â€” BEM: bnd-editor â”€â”€ */
.bnd-editor {
display: flex;
flex-direction: column;
}
.bnd-editor__loading {
display: flex;
justify-content: center;
padding: 2rem;
}
.bnd-editor__tabs {
display: flex;
gap: 0;
border-bottom: 2px solid var(--border-color);
margin-bottom: 1.25rem;
}
.bnd-editor__tab {
padding: 0.55rem 1rem;
font-size: 0.84rem;
font-weight: 500;
color: var(--text-muted);
background: none;
border: none;
border-bottom: 2px solid transparent;
margin-bottom: -2px;
cursor: pointer;
transition: color 0.15s, border-color 0.15s;
white-space: nowrap;
}
.bnd-editor__tab:hover { color: var(--primary-color); }
.bnd-editor__tab--active {
color: var(--primary-color);
border-bottom-color: var(--primary-color);
font-weight: 700;
}
.bnd-editor__error {
padding: 0.65rem 0.9rem;
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: 6px;
font-size: 0.84rem;
margin-bottom: 1rem;
}
.bnd-editor__section {
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.bnd-editor__field { display: flex; flex-direction: column; gap: 0.25rem; }
.bnd-editor__switch-row {
display: flex;
align-items: center;
gap: 0.75rem;
}
.bnd-editor__actions {
display: flex;
gap: 0.65rem;
padding-top: 0.75rem;
border-top: 1px solid var(--border-color);
margin-top: 0.25rem;
}
/* Items del bundle */
.bnd-editor__subtitle {
font-size: 0.9rem;
font-weight: 700;
color: var(--text-color);
margin: 0;
}
.bnd-editor__subtitle--add {
margin-top: 0.5rem;
padding-top: 0.75rem;
border-top: 1px solid var(--border-color);
}
.bnd-editor__empty {
font-size: 0.83rem;
color: var(--text-muted);
margin: 0;
}
.bnd-editor__items {
list-style: none;
padding: 0;
margin: 0;
display: flex;
flex-direction: column;
gap: 0.35rem;
}
.bnd-editor__item {
display: flex;
align-items: center;
justify-content: space-between;
gap: 0.75rem;
padding: 0.6rem 0.75rem;
background: var(--card-category-bg-color);
border: 1px solid var(--border-color);
border-radius: 8px;
}
.bnd-editor__item-info {
display: flex;
align-items: center;
gap: 0.65rem;
flex: 1;
min-width: 0;
}
.bnd-editor__item-order {
display: inline-flex;
align-items: center;
justify-content: center;
width: 22px;
height: 22px;
background: var(--secondary-background);
color: var(--text-muted);
border-radius: 50%;
font-size: 0.72rem;
font-weight: 700;
flex-shrink: 0;
}
.bnd-editor__item-text {
display: flex;
flex-direction: column;
gap: 0.05rem;
min-width: 0;
}
.bnd-editor__item-title {
font-size: 0.84rem;
font-weight: 600;
color: var(--text-color);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.bnd-editor__item-meta {
font-size: 0.71rem;
color: var(--text-muted);
}
.bnd-editor__item-remove {
flex-shrink: 0;
color: var(--danger-color);
}
/* Buscador para agregar */
.bnd-editor__search-row {
display: flex;
gap: 0.5rem;
align-items: flex-end;
}
.bnd-editor__search-row > :first-child { flex: 1; }
.bnd-editor__results {
list-style: none;
padding: 0;
margin: 0;
border: 1px solid var(--border-color);
border-radius: 8px;
overflow: hidden;
}
.bnd-editor__result {
display: flex;
flex-direction: column;
gap: 0.1rem;
padding: 0.5rem 0.75rem;
cursor: pointer;
border-bottom: 1px solid var(--border-light);
transition: background 0.1s;
}
.bnd-editor__result:last-child { border-bottom: none; }
.bnd-editor__result:hover,
.bnd-editor__result--selected {
background: var(--hover-background-color);
}
.bnd-editor__result-title {
font-size: 0.84rem;
font-weight: 600;
color: var(--text-color);
}
.bnd-editor__result-meta {
font-size: 0.72rem;
color: var(--text-muted);
}
.bnd-editor__assign-form {
display: flex;
flex-direction: column;
gap: 0.65rem;
padding: 0.75rem;
background: var(--secondary-background);
border-radius: 8px;
border: 1px solid var(--border-color);
}
.bnd-editor__selected-name {
font-size: 0.83rem;
color: var(--text-color);
margin: 0;
}
.bnd-editor__row {
display: grid;
grid-template-columns: 120px;
gap: 0.5rem;
}
@media (max-width: 768px) {
.bnd-list-page { padding: 0.75rem; }
}
/* ============================================================
ContentListPage â€” BEM: cnt-list-page
PÃ¡gina admin de gestiÃ³n del programa acadÃ©mico.
============================================================ */
.cnt-list-page {
display: flex;
flex-direction: column;
gap: 1rem;
padding: 1.25rem;
}
.cnt-list-page__error {
color: var(--danger-foreground);
background: var(--danger-background);
padding: 1rem;
border-radius: 8px;
}
/* â”€â”€ Breadcrumb â”€â”€ */
.cnt-list-page__breadcrumb {
display: flex;
align-items: center;
gap: 0.4rem;
font-size: 0.82rem;
color: var(--text-muted);
}
.cnt-list-page__breadcrumb-sep {
opacity: 0.5;
}
.cnt-list-page__breadcrumb-current {
color: var(--text-color);
font-weight: 500;
}
.cnt-list-page__title {
font-size: 1.4rem;
font-weight: 700;
color: var(--text-color);
margin: 0;
}
.cnt-list-page__spinner {
display: flex;
justify-content: center;
padding: 2rem;
}
/* â”€â”€ Filtros â”€â”€ */
.cnt-list-page__filter-group {
margin-bottom: 1rem;
}
/* â”€â”€ Tabla â”€â”€ */
.cnt-list-page__title-cell {
display: flex;
align-items: center;
gap: 0.4rem;
}
.cnt-list-page__color-dot {
display: inline-block;
width: 10px;
height: 10px;
border-radius: 50%;
flex-shrink: 0;
border: 1px solid var(--border-color);
}
/* Badges de tipo */
.cnt-list-page__type-badge {
display: inline-block;
font-size: 0.68rem;
font-weight: 700;
padding: 0.15rem 0.5rem;
border-radius: 4px;
text-transform: uppercase;
letter-spacing: 0.05em;
}
.cnt-list-page__type-badge--session {
background: var(--info-background);
color: var(--info-foreground);
}
.cnt-list-page__type-badge--break {
background: var(--warning-background);
color: var(--warning-foreground);
}
.cnt-list-page__type-badge--label {
background: var(--secondary-background);
color: var(--text-secondary);
}
/* Badges de estado */
.cnt-list-page__badge {
display: inline-block;
font-size: 0.7rem;
font-weight: 600;
padding: 0.15rem 0.5rem;
border-radius: var(--radius-pill);
}
.cnt-list-page__badge--active {
background: var(--success-background);
color: var(--success-foreground);
}
.cnt-list-page__badge--inactive {
background: var(--disabled-background);
color: var(--disabled-color);
}
.cnt-list-page__badge--success {
background: var(--success-background);
color: var(--success-foreground);
}
.cnt-list-page__badge--neutral {
background: var(--secondary-background);
color: var(--text-secondary);
}
/* â”€â”€ Responsive â”€â”€ */
@media (max-width: 768px) {
.cnt-list-page { padding: 0.75rem; }
}
/* ============================================================
SpeakersListPage â€” BEM: spk-list-page
CatÃ¡logo global de ponentes.
============================================================ */
.spk-list-page {
display: flex;
flex-direction: column;
gap: 1rem;
padding: 1.25rem;
}
.spk-list-page__error {
color: var(--danger-foreground);
background: var(--danger-background);
padding: 1rem;
border-radius: 8px;
}
.spk-list-page__spinner {
display: flex;
justify-content: center;
padding: 2rem;
}
.spk-list-page__filter-group { margin-bottom: 1rem; }
/* â”€â”€ Tabla â”€â”€ */
.spk-list-page__th-photo { width: 44px; }
.spk-list-page__cell-photo { padding-right: 0 !important; }
.spk-list-page__photo {
width: 36px;
height: 36px;
border-radius: 50%;
object-fit: cover;
border: 2px solid var(--border-color);
display: block;
}
.spk-list-page__avatar {
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: 0.85rem;
font-weight: 700;
}
.spk-list-page__name {
font-size: 0.88rem;
font-weight: 600;
color: var(--text-color);
}
.spk-list-page__position {
font-size: 0.72rem;
color: var(--text-muted);
margin-top: 0.1rem;
}
.spk-list-page__badge {
display: inline-block;
font-size: 0.7rem;
font-weight: 600;
padding: 0.15rem 0.5rem;
border-radius: var(--radius-pill);
}
.spk-list-page__badge--active {
background: var(--success-background);
color: var(--success-foreground);
}
.spk-list-page__badge--inactive {
background: var(--disabled-background);
color: var(--disabled-color);
}
.spk-list-page__confirm-note {
font-size: 0.8rem;
color: var(--text-muted);
margin-top: 0.35rem;
}
/* ============================================================
AppSpeakerForm â€” BEM: spk-form
Formulario de creaciÃ³n y ediciÃ³n del ponente.
============================================================ */
.spk-form {
display: flex;
flex-direction: column;
gap: 1rem;
}
.spk-form__loading {
display: flex;
justify-content: center;
padding: 2rem;
}
.spk-form__error {
padding: 0.65rem 0.9rem;
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: 6px;
font-size: 0.84rem;
}
.spk-form__field { display: flex; flex-direction: column; gap: 0.25rem; }
.spk-form__textarea {
resize: vertical;
min-height: 80px;
font-family: inherit;
font-size: 0.88rem;
line-height: 1.5;
padding: 0.45rem 0.65rem;
}
/* Foto */
.spk-form__photo-preview {
display: flex;
align-items: center;
gap: 1rem;
padding: 0.5rem 0;
}
.spk-form__photo-img {
width: 72px;
height: 72px;
border-radius: 50%;
object-fit: cover;
border: 3px solid var(--border-color);
}
/* Fieldsets */
.spk-form__fieldset {
border: 1px solid var(--border-color);
border-radius: 10px;
padding: 1rem;
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.spk-form__legend {
font-size: 0.8rem;
font-weight: 700;
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: 0.05em;
padding: 0 0.4rem;
}
.spk-form__row {
display: grid;
gap: 0.75rem;
}
.spk-form__row--2 { grid-template-columns: 1fr 1fr; }
/* Email check */
.spk-form__email-wrap {
display: flex;
flex-direction: column;
gap: 0.2rem;
}
.spk-form__checking {
font-size: 0.72rem;
color: var(--text-muted);
}
/* Estado y acciones */
.spk-form__switch-row {
display: flex;
align-items: center;
gap: 0.75rem;
}
.spk-form__actions {
display: flex;
gap: 0.65rem;
padding-top: 0.75rem;
border-top: 1px solid var(--border-color);
}
/* â”€â”€ Responsive â”€â”€ */
@media (max-width: 640px) {
.spk-list-page { padding: 0.75rem; }
.spk-form__row--2 { grid-template-columns: 1fr; }
.spk-form__fieldset { padding: 0.75rem; }
}
/* =====================================================================
BadgeDesignerPage â€” BEM: bdg
3-panel layout: sidebar | canvas | properties
===================================================================== */
/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
RESET: general.css aplica --primary-color a button:not([class*="app-"]...).
La solucion correcta: cada clase bdg__xxx usa !important para sobreescribir
el estilo global (que no tiene !important). Solo reseteamos min-height/transform
que el global agrega y no queremos en ningun boton del diseÃ±ador.
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.bdg__section-hdr,
.bdg__seg-btn, .bdg__face-tab,
.bdg__layer-del, .bdg__layer-order,
.bdg__nudge-btn, .bdg__style-btn,
.bdg__preset, .bdg__add-btn,
.bdg__props-del, .bdg__zoom-btn {
min-height: auto !important;
}
.bdg__section-hdr:hover, .bdg__seg-btn:hover, .bdg__face-tab:hover,
.bdg__layer-del:hover, .bdg__layer-order:hover,
.bdg__nudge-btn:hover, .bdg__style-btn:hover,
.bdg__preset:hover, .bdg__add-btn:hover,
.bdg__props-del:hover, .bdg__zoom-btn:hover {
transform: none !important;
}
/* â”€â”€ Root â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
/* El diseÃ±ador ocupa la altura debajo del topbar principal (64px) */
.bdg {
display: flex;
flex-direction: column;
height: calc(100dvh - var(--layout-topbar-height, 64px));
min-height: 0;
overflow: hidden;
background: var(--background-color);
}
/* â”€â”€ Header â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__header {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;
flex-wrap: wrap;
padding: .625rem 1.25rem;
background: var(--surface-color);
border-bottom: 1px solid var(--border-color);
flex-shrink: 0;
box-shadow: var(--shadow-xs);
z-index: 10;
}
.bdg__header-left {
display: flex;
align-items: center;
gap: .625rem;
min-width: 0;
}
.bdg__header-icon {
color: var(--primary-color);
flex-shrink: 0;
}
.bdg__title {
font-size: 1.1rem;
font-weight: 800;
color: var(--text-color);
margin: 0;
white-space: nowrap;
}
.bdg__event-chip {
padding: .2rem .65rem;
background: var(--hover-background-color);
color: var(--primary-color);
border-radius: 999px;
font-size: .72rem;
font-weight: 700;
letter-spacing: .5px;
text-transform: uppercase;
border: 1.5px solid var(--primary-color);
flex-shrink: 0;
}
.bdg__header-actions {
display: flex;
align-items: center;
gap: .625rem;
flex-wrap: wrap;
}
.bdg__save-ok {
font-size: .8rem;
color: var(--success-color);
font-weight: 600;
}
.bdg__save-err {
font-size: .8rem;
color: var(--danger-color);
font-weight: 600;
max-width: 200px;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
/* â”€â”€ MAUI Warning â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__maui-warn {
display: flex;
align-items: flex-start;
gap: 1rem;
margin: 1.5rem;
padding: 1.25rem 1.5rem;
background: var(--warning-background);
border: 2px solid var(--warning-color);
border-radius: var(--border-radius);
color: var(--text-color);
}
.bdg__maui-warn-icon {
flex-shrink: 0;
color: var(--warning-color);
margin-top: .1rem;
}
.bdg__maui-warn strong {
display: block;
margin-bottom: .25rem;
color: var(--warning-foreground);
}
.bdg__maui-warn p {
margin: 0;
font-size: .875rem;
color: var(--text-muted);
}
/* â”€â”€ Event Picker â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__event-picker {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 1rem;
flex: 1;
padding: 3rem 2rem;
text-align: center;
}
.bdg__event-picker-icon {
color: var(--primary-color);
opacity: .6;
}
.bdg__event-picker-title {
font-size: 1.3rem;
font-weight: 800;
color: var(--text-color);
margin: 0;
}
.bdg__event-picker-hint {
font-size: .9rem;
color: var(--text-muted);
margin: 0;
}
.bdg__event-picker-selector {
width: 100%;
max-width: 480px;
}
/* â”€â”€ Loading â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__loading {
display: flex;
align-items: center;
justify-content: center;
gap: .875rem;
flex: 1;
color: var(--text-muted);
font-size: .9rem;
}
/* â”€â”€ Workspace (3 columnas con altura fija de viewport) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__workspace {
display: grid;
grid-template-columns: 280px 1fr 290px;
flex: 1;
min-height: 0;
overflow: hidden;
}
/* â”€â”€ Sidebar izquierdo â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__sidebar {
display: flex;
flex-direction: column;
background: var(--secondary-background);
border-right: 1px solid var(--border-color);
overflow-y: auto;
overflow-x: hidden;
height: 100%;
scrollbar-width: thin;
scrollbar-color: var(--border-color) transparent;
}
.bdg__sidebar-event {
padding: .375rem .625rem;
border-bottom: 1px solid var(--border-color);
background: var(--surface-color);
/* Fuerza el selector de evento a mostrarse de forma compacta */
font-size: .78rem;
}
/* Sobreescribir estilos internos del OnSiteEventSelector para modo compacto */
.bdg__sidebar-event .on-site-event-selector__active {
display: flex !important;
flex-direction: row !important;
align-items: center !important;
justify-content: space-between !important;
gap: .5rem !important;
flex-wrap: nowrap !important;
}
.bdg__sidebar-event .on-site-event-selector__event-info {
display: flex !important;
flex-direction: column !important;
gap: 0 !important;
min-width: 0 !important;
flex: 1 !important;
overflow: hidden !important;
}
.bdg__sidebar-event .on-site-event-selector__label {
font-size: .65rem !important;
text-transform: uppercase !important;
letter-spacing: .4px !important;
color: var(--text-muted) !important;
line-height: 1.2 !important;
}
.bdg__sidebar-event .on-site-event-selector__name {
font-size: .78rem !important;
font-weight: 600 !important;
white-space: nowrap !important;
overflow: hidden !important;
text-overflow: ellipsis !important;
line-height: 1.3 !important;
color: var(--text-color) !important;
}
.bdg__sidebar-event .on-site-event-selector__short {
display: none !important;  /* se muestra en el chip del header */
}
.bdg__sidebar-event .on-site-event-selector__actions {
flex-shrink: 0 !important;
}
.bdg__sidebar-event .on-site-event-selector__empty {
display: flex !important;
align-items: center !important;
gap: .5rem !important;
font-size: .78rem !important;
}
/* â”€â”€ Secciones del sidebar â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__section {
border-bottom: 1px solid var(--border-color);
display: flex;
flex-direction: column;
}
.bdg__section--grow {
flex: 1;
min-height: 0;
}
.bdg__section-hdr {
display: flex !important;
align-items: center !important;
justify-content: space-between !important;
padding: .625rem .875rem !important;
background: transparent !important;
border: none !important;
cursor: pointer !important;
width: 100%;
text-align: left;
gap: .5rem;
transition: background .12s;
min-height: 40px !important;
border-radius: 0 !important;
box-shadow: none !important;
color: inherit !important;
transform: none !important;
}
.bdg__section-hdr:hover {
background: var(--hover-background-color) !important;
transform: none !important;
}
.bdg__section-hdr--static {
cursor: default;
pointer-events: none;
}
.bdg__section-hdr--static:hover {
background: transparent;
}
.bdg__section-title {
display: flex;
align-items: center;
gap: .4rem;
font-size: .78rem;
font-weight: 700;
color: var(--text-secondary);
text-transform: uppercase;
letter-spacing: .5px;
}
.bdg__section-hdr-end {
display: flex;
align-items: center;
gap: .25rem;
margin-left: auto;
flex-shrink: 0;
}
.bdg__section-chevron {
font-size: .9rem;
color: var(--text-muted);
transition: transform .2s;
flex-shrink: 0;
line-height: 1;
}
.bdg__section-chevron--open {
transform: rotate(180deg);
}
.bdg__section-body {
padding: .75rem;
display: flex;
flex-direction: column;
gap: .625rem;
}
.bdg__section-body--no-pad {
padding: 0;
}
/* â”€â”€ Fondo / upload â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__bg-thumb {
position: relative;
border: 1.5px solid var(--border-color);
border-radius: var(--border-radius);
overflow: hidden;
}
.bdg__bg-thumb--new {
border-color: var(--primary-color);
}
.bdg__bg-thumb img {
display: block;
width: 100%;
height: 100px;
object-fit: cover;
}
.bdg__bg-thumb-label {
display: block;
padding: .25rem .5rem;
font-size: .7rem;
color: var(--text-muted);
background: var(--surface-color);
text-align: center;
}
.bdg__upload-label {
display: inline-flex;
align-items: center;
gap: .4rem;
padding: .4rem .85rem;
background: var(--surface-color);
border: 1.5px solid var(--border-color);
border-radius: var(--border-radius);
font-size: .8rem;
font-weight: 600;
color: var(--text-color);
cursor: pointer;
transition: border-color .15s, background .15s, color .15s;
align-self: flex-start;
}
.bdg__upload-label:hover {
border-color: var(--primary-color);
color: var(--primary-color);
background: var(--hover-background-color);
}
.bdg__upload-input {
display: none;
}
/* â”€â”€ Mensajes â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__msg {
font-size: .78rem;
padding: .4rem .65rem;
border-radius: var(--border-radius);
margin: 0;
}
.bdg__msg--error {
color: var(--danger-foreground);
background: var(--danger-background);
border: 1px solid var(--danger-color);
}
.bdg__msg--success {
color: var(--success-foreground);
background: var(--success-background);
border: 1px solid var(--success-color);
}
.bdg__hint {
font-size: .72rem;
color: var(--text-muted);
margin: 0;
}
/* â”€â”€ Dimensiones â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__warn-box {
display: flex;
align-items: flex-start;
gap: .4rem;
padding: .5rem .65rem;
background: var(--warning-background);
border: 1px solid var(--warning-color);
border-radius: var(--border-radius);
font-size: .75rem;
color: var(--warning-foreground);
line-height: 1.4;
}
.bdg__warn-box svg {
flex-shrink: 0;
margin-top: .1rem;
color: var(--warning-color);
}
.bdg__dims-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: .5rem;
}
/* En sidebar estrecho, usar col unica */
@media (max-width: 1100px) {
.bdg__dims-grid {
grid-template-columns: 1fr;
}
}
.bdg__presets-lbl {
font-size: .72rem;
font-weight: 600;
color: var(--text-muted);
margin: 0;
}
.bdg__presets {
display: flex;
flex-wrap: wrap;
gap: .35rem;
}
.bdg__preset {
padding: .2rem .55rem !important;
font-size: .72rem !important;
font-weight: 500 !important;
border: 1px solid var(--border-color) !important;
border-radius: var(--border-radius) !important;
background: var(--surface-color) !important;
color: var(--text-muted) !important;
cursor: pointer;
transition: border-color .12s, color .12s, background .12s;
}
/* Preset destacado — el más usado. Ámbar = "recomendado", no confunde con estado seleccionado */
.bdg__preset--featured {
border-color: #d97706 !important;
color: #92400e !important;
background: #fffbeb !important;
}
.bdg__preset--featured:hover {
background: #fef3c7 !important;
border-color: #b45309 !important;
color: #78350f !important;
}
.
border-color: var(--primary-color) !important;
color: var(--primary-color) !important;
background: var(--hover-background-color) !important;
transform: none !important;
}
.bdg__toggle-row {
display: flex;
align-items: center;
gap: .5rem;
flex-wrap: wrap;
}
.bdg__seg {
display: flex;
background: var(--border-color);
border-radius: var(--border-radius);
padding: 2px;
gap: 2px;
}
.bdg__seg-btn {
padding: .3rem .75rem !important;
font-size: .78rem !important;
font-weight: 600 !important;
border: 1.5px solid var(--border-color) !important;
border-radius: calc(var(--border-radius) - 2px) !important;
background: var(--surface-color) !important;
color: var(--text-color) !important;
cursor: pointer;
transition: background .12s, color .12s, border-color .12s;
white-space: nowrap;
}
.bdg__seg-btn:hover:not(.bdg__seg-btn--on) {
background: var(--hover-background-color) !important;
border-color: var(--primary-color) !important;
color: var(--primary-color) !important;
transform: none !important;
}
.bdg__seg-btn--on {
background: var(--primary-color) !important;
color: #fff !important;
border-color: var(--primary-color) !important;
box-shadow: var(--shadow-xs) !important;
}
.bdg__dims-info {
padding: .4rem .65rem;
background: var(--info-background);
border: 1px solid var(--info-color);
border-radius: var(--border-radius);
font-size: .775rem;
color: var(--info-foreground);
}
/* â”€â”€ Agregar elementos â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__add-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: .375rem;
}
.bdg__add-btn {
display: flex !important;
flex-direction: column !important;
align-items: center !important;
gap: .25rem !important;
padding: .625rem .4rem !important;
background: var(--surface-color) !important;
border: 1.5px solid var(--border-color) !important;
border-radius: var(--border-radius) !important;
font-size: .72rem !important;
font-weight: 600 !important;
color: var(--text-color) !important;
cursor: pointer;
transition: border-color .12s, background .12s, color .12s;
text-align: center;
}
.bdg__add-btn:hover {
border-color: var(--primary-color) !important;
color: var(--primary-color) !important;
background: var(--hover-background-color) !important;
transform: none !important;
}
.bdg__add-icon {
font-size: 1.1rem;
line-height: 1;
}
/* â”€â”€ Capas â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__layer-count {
font-weight: 400;
color: var(--text-muted);
font-size: .73rem;
}
.bdg__layer-order {
padding: .15rem .35rem !important;
font-size: .8rem !important;
background: transparent !important;
border: 1px solid var(--border-color) !important;
border-radius: 3px !important;
color: var(--text-muted) !important;
cursor: pointer;
line-height: 1;
transition: background .1s, color .1s;
}
.bdg__layer-order:hover {
background: var(--hover-background-color) !important;
color: var(--primary-color) !important;
border-color: var(--primary-color) !important;
transform: none !important;
}
.bdg__layers-list {
overflow-y: auto;
flex: 1;
}
.bdg__layer {
display: flex;
align-items: center;
gap: .5rem;
padding: .45rem .875rem;
cursor: pointer;
border-bottom: 1px solid var(--border-light);
transition: background .1s;
}
.bdg__layer:hover {
background: var(--hover-background-color);
}
.bdg__layer--selected {
background: var(--hover-background-color) !important;
border-left: 3px solid var(--primary-color);
padding-left: calc(.875rem - 3px);
}
.bdg__layer-icon {
font-size: .85rem;
width: 18px;
text-align: center;
flex-shrink: 0;
color: var(--text-secondary);
}
.bdg__layer-label {
flex: 1;
font-size: .78rem;
color: var(--text-color);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.bdg__layer-del {
background: transparent !important;
border: none !important;
color: var(--text-muted) !important;
cursor: pointer;
font-size: .8rem !important;
padding: .1rem .25rem !important;
border-radius: 3px !important;
line-height: 1;
flex-shrink: 0;
transition: background .1s, color .1s;
}
.bdg__layer-del:hover {
background: var(--danger-background) !important;
color: var(--danger-color) !important;
transform: none !important;
}
.bdg__layers-empty {
padding: 1rem .875rem;
font-size: .78rem;
color: var(--text-muted);
text-align: center;
margin: 0;
}
.bdg__layers-mirror {
padding: .5rem .875rem;
font-size: .72rem;
color: var(--info-foreground);
background: var(--info-background);
border-top: 1px solid var(--info-color);
margin: 0;
}
/* â”€â”€ Canvas area (centro) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__canvas-area {
display: flex;
flex-direction: column;
overflow: hidden; /* NO outer scroll: cada cara tiene su propio scroll */
height: 100%;
background: var(--background-color);
padding: .875rem 1rem;
gap: .625rem;
}
.bdg__canvas-ph {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 1rem;
flex: 1;
text-align: center;
color: var(--text-muted);
font-size: .9rem;
max-width: 360px;
margin: auto;
}
.bdg__canvas-ph-icon {
color: var(--border-color);
}
/* â”€â”€ Tabs de caras â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__canvas-toolbar {
display: flex;
align-items: center;
gap: .875rem;
flex-shrink: 0;
flex-wrap: wrap;
}
.bdg__toolbar-sep {
color: var(--border-color);
font-size: .9rem;
user-select: none;
}
.bdg__face-tabs {
display: flex;
gap: .375rem;
align-self: flex-start;
flex-shrink: 0;
}
.bdg__face-tab {
display: inline-flex !important;
align-items: center !important;
gap: .35rem !important;
padding: .45rem 1.1rem !important;
font-size: .82rem !important;
font-weight: 600 !important;
border: 1.5px solid var(--border-color) !important;
border-radius: var(--border-radius) !important;
background: var(--surface-color) !important;
color: var(--text-muted) !important;
cursor: pointer;
transition: background .12s, color .12s, border-color .12s;
}
.bdg__face-tab:hover:not(.bdg__face-tab--active) {
background: var(--hover-background-color) !important;
border-color: var(--primary-color) !important;
color: var(--primary-color) !important;
transform: none !important;
}
.bdg__face-tab--active {
background: var(--primary-color) !important;
color: #fff !important;
border-color: var(--primary-color) !important;
box-shadow: var(--shadow-sm) !important;
}
/* â”€â”€ Canvas scroll container â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__canvas-scroll {
display: flex;
flex-direction: row;
gap: 1.5rem;
flex: 1;
min-height: 0;
overflow: hidden;
align-items: flex-start;
}
.bdg__face-panel {
display: flex;
flex-direction: column;
gap: .4rem;
flex: 1;
min-width: 0;
min-height: 0;
height: 100%;
overflow: auto;
scrollbar-width: thin;
scrollbar-color: var(--border-color) transparent;
padding-bottom: .5rem;
}
.bdg__face-panel--inactive {
opacity: .4;
pointer-events: none;
}
.bdg__canvas-wrap {
display: flex;
flex-direction: column;
gap: .4rem;
flex-shrink: 0;
}
.bdg__canvas-lbl {
font-size: .72rem;
font-weight: 700;
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: .5px;
display: flex;
align-items: center;
gap: .5rem;
}
.bdg__canvas-lbl--mirror {
color: var(--info-foreground);
}
.bdg__canvas-lbl-badge {
padding: .1rem .4rem;
background: var(--info-background);
color: var(--info-foreground);
border-radius: 999px;
font-size: .65rem;
font-weight: 600;
text-transform: uppercase;
}
.bdg__canvas-lbl-badge--active {
background: var(--success-background);
color: var(--success-foreground);
}
/* â”€â”€ Barra de zoom â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__zoom-bar {
display: flex;
align-items: center;
gap: .25rem;
user-select: none;
flex-shrink: 0;
}
.bdg__zoom-btn {
width: 26px !important;
height: 26px !important;
border: 1.5px solid var(--border-color) !important;
border-radius: 5px !important;
background: var(--surface-color) !important;
color: var(--text-color) !important;
font-size: 1rem !important;
font-weight: 700 !important;
cursor: pointer;
display: flex !important;
align-items: center !important;
justify-content: center !important;
padding: 0 !important;
line-height: 1;
transition: background .1s, border-color .1s, color .1s;
}
.bdg__zoom-btn:hover {
background: var(--hover-background-color) !important;
border-color: var(--primary-color) !important;
color: var(--primary-color) !important;
transform: none !important;
}
.bdg__zoom-btn--reset {
font-size: .85rem !important;
}
.bdg__zoom-val {
min-width: 44px;
text-align: center;
font-size: .75rem;
font-weight: 700;
color: var(--text-secondary);
letter-spacing: .2px;
}
/* â”€â”€ El canvas (superficie de diseÃ±o) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
/* -- Papel wrapper (muestra tamano real de la cara con margenes visibles) -- */
.bdg__paper {
position: relative;
flex-shrink: 0;
background: #ffffff;
border: 1px solid var(--border-color);
box-shadow: var(--shadow-lg);
/* width y height se setean via inline style */
}
.bdg__paper--mirror {
opacity: .6;
pointer-events: none;
}
/* -- Lineas de margen (dashed) dentro del papel -- */
.bdg__margin-lines {
position: absolute;
inset: 0;
pointer-events: none;
z-index: 2;
}
/* Rectangulo dashed que delimita el area de diseno */
.bdg__margin-lines::before {
content: '';
position: absolute;
top: var(--mt);
bottom: var(--mb);
left: var(--ml);
right: var(--mr);
border: 1px dashed rgba(25, 69, 168, .35);
pointer-events: none;
}
/* Sombreado sutil en las areas de margen */
.bdg__margin-lines::after {
content: '';
position: absolute;
inset: 0;
pointer-events: none;
background:
linear-gradient(to right,  rgba(25,69,168,.04) var(--ml), transparent var(--ml)),
linear-gradient(to left,   rgba(25,69,168,.04) var(--mr), transparent var(--mr)),
linear-gradient(to bottom, rgba(25,69,168,.04) var(--mt), transparent var(--mt)),
linear-gradient(to top,    rgba(25,69,168,.04) var(--mb), transparent var(--mb));
}
/* -- Lineas de centro (horizontal y vertical) -- */
.bdg__center-lines {
position: absolute;
inset: 0;
pointer-events: none;
z-index: 2;
opacity: .25;
}
.bdg__center-lines::before {
content: '';
position: absolute;
left: 50%;
top: 0;
bottom: 0;
border-left: 1px dashed #e74c3c;
}
.bdg__center-lines::after {
content: '';
position: absolute;
top: 50%;
left: 0;
right: 0;
border-top: 1px dashed #e74c3c;
}
/* -- Reglas graduadas (mm) en los bordes del papel -- */
.bdg__ruler {
position: absolute;
pointer-events: none;
z-index: 3;
background: rgba(255,255,255,.85);
}
.bdg__ruler--top {
left: 0;
top: -14px;
right: 0;
height: 14px;
background-image:
repeating-linear-gradient(to right,
rgba(25,69,168,.5) 0, rgba(25,69,168,.5) 1px,
transparent 1px, transparent 10mm),
repeating-linear-gradient(to right,
rgba(25,69,168,.2) 0, rgba(25,69,168,.2) 1px,
transparent 1px, transparent 5mm);
background-size: 100% 10px, 100% 6px;
background-position: 0 bottom, 0 bottom;
background-repeat: repeat-x;
border-bottom: 1px solid rgba(25,69,168,.3);
}
.bdg__ruler--left {
top: 0;
left: -14px;
bottom: 0;
width: 14px;
background-image:
repeating-linear-gradient(to bottom,
rgba(25,69,168,.5) 0, rgba(25,69,168,.5) 1px,
transparent 1px, transparent 10mm),
repeating-linear-gradient(to bottom,
rgba(25,69,168,.2) 0, rgba(25,69,168,.2) 1px,
transparent 1px, transparent 5mm);
background-size: 10px 100%, 6px 100%;
background-position: right 0, right 0;
background-repeat: repeat-y;
border-right: 1px solid rgba(25,69,168,.3);
}
.bdg__canvas {
position: absolute;
overflow: hidden;
cursor: default;
/* width y height se setean via inline style (mm calculados por el usuario) */
}
.bdg__canvas:hover {
outline: 1px solid var(--secondary-color);
outline-offset: -1px;
}
.bdg__canvas--mirror {
pointer-events: none;
}
.bdg__canvas--inactive {
opacity: .55;
pointer-events: none;
}
/* â”€â”€ Elementos en el canvas â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__elem {
position: absolute;
cursor: pointer;
user-select: none;
white-space: nowrap;
outline: 1px dashed transparent;
outline-offset: 2px;
transition: outline-color .1s;
}
.bdg__elem:hover {
outline-color: var(--secondary-color);
z-index: 10;
}
.bdg__elem--selected {
outline: 2px solid var(--primary-color) !important;
outline-offset: 3px;
z-index: 50;
}
.bdg__elem--preview {
pointer-events: none;
outline: none !important;
}
/* Placeholders de elementos en el canvas */
.bdg__elem-qr-ph,
.bdg__elem-img-ph {
display: flex;
align-items: center;
justify-content: center;
width: 100%;
height: 100%;
border: 1.5px dashed var(--border-color);
border-radius: 2px;
font-size: .65rem;
font-weight: 700;
color: var(--text-muted);
background: var(--secondary-background);
}
.bdg__elem-qr-ph--static {
background: var(--info-background);
border-color: var(--info-color);
color: var(--info-foreground);
}
/* â”€â”€ Panel derecho: Propiedades â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__props {
display: flex;
flex-direction: column;
gap: .875rem;
background: var(--surface-color);
border-left: 1px solid var(--border-color);
overflow-y: auto;
height: 100%;
padding: .875rem;
scrollbar-width: thin;
scrollbar-color: var(--border-color) transparent;
}
.bdg__props-ph {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: .75rem;
flex: 1;
text-align: center;
color: var(--text-muted);
font-size: .85rem;
padding: 2rem 1rem;
}
.bdg__props-ph svg {
color: var(--border-color);
}
.bdg__props-ph p {
margin: 0;
}
/* â”€â”€ Encabezado de propiedades â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__props-hdr {
display: flex;
align-items: center;
justify-content: space-between;
gap: .5rem;
padding-bottom: .75rem;
border-bottom: 1px solid var(--border-color);
}
.bdg__props-type {
display: inline-flex;
align-items: center;
gap: .3rem;
padding: .25rem .6rem;
border-radius: var(--border-radius);
font-size: .75rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: .4px;
background: var(--secondary-background);
color: var(--text-secondary);
border: 1px solid var(--border-color);
}
.bdg__props-type--text     { background: var(--info-background);    color: var(--info-foreground);    border-color: var(--info-color); }
.bdg__props-type--qr       { background: var(--success-background);  color: var(--success-foreground); border-color: var(--success-color); }
.bdg__props-type--qr-static { background: var(--success-background); color: var(--success-foreground); border-color: var(--success-color); }
.bdg__props-type--image    { background: var(--warning-background);  color: var(--warning-foreground); border-color: var(--warning-color); }
.bdg__props-type--rect     { background: var(--secondary-background); color: var(--text-secondary);    border-color: var(--border-color); }
.bdg__props-del {
display: inline-flex !important;
align-items: center !important;
gap: .3rem !important;
padding: .3rem .65rem !important;
background: transparent !important;
border: 1px solid var(--danger-color) !important;
border-radius: var(--border-radius) !important;
color: var(--danger-color) !important;
font-size: .75rem !important;
font-weight: 600 !important;
cursor: pointer;
transition: background .12s, color .12s;
}
.bdg__props-del:hover {
background: var(--danger-background) !important;
transform: none !important;
}
/* â”€â”€ Grupos de propiedades â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__props-group {
display: flex;
flex-direction: column;
gap: .5rem;
}
.bdg__props-group-title {
font-size: .72rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: .5px;
color: var(--text-muted);
margin: 0;
}
.bdg__props-row {
display: grid;
grid-template-columns: 1fr 1fr;
gap: .5rem;
}
/* â”€â”€ Controles compactos de propiedades â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__prop-field {
display: flex;
flex-direction: column;
gap: .2rem;
}
.bdg__prop-label {
font-size: .7rem;
font-weight: 600;
color: var(--text-muted);
white-space: nowrap;
}
.bdg__prop-input {
width: 100%;
padding: .35rem .5rem;
border: 1.5px solid var(--border-color);
border-radius: var(--border-radius);
background: var(--surface-color);
color: var(--text-color);
font-size: .82rem;
transition: border-color .12s, box-shadow .12s;
box-sizing: border-box;
-moz-appearance: textfield;
-webkit-appearance: none;
appearance: none;
}
.bdg__prop-input::-webkit-inner-spin-button,
.bdg__prop-input::-webkit-outer-spin-button {
opacity: .7;
}
.bdg__prop-input:focus {
outline: none;
border-color: var(--primary-color);
box-shadow: 0 0 0 2px var(--focus-ring);
}
.bdg__prop-select {
width: 100%;
padding: .35rem .5rem;
border: 1.5px solid var(--border-color);
border-radius: var(--border-radius);
background: var(--surface-color);
color: var(--text-color);
font-size: .82rem;
transition: border-color .12s, box-shadow .12s;
cursor: pointer;
-webkit-appearance: none;
appearance: none;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2364748b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
background-repeat: no-repeat;
background-position: right .5rem center;
padding-right: 1.75rem;
}
.bdg__prop-select:focus {
outline: none;
border-color: var(--primary-color);
box-shadow: 0 0 0 2px var(--focus-ring);
}
/* â”€â”€ Nudge de posiciÃ³n â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__nudge {
display: flex;
align-items: center;
gap: .3rem;
flex-wrap: wrap;
}
.bdg__nudge-btn {
width: 30px !important;
height: 30px !important;
display: flex !important;
align-items: center !important;
justify-content: center !important;
background: var(--secondary-background) !important;
border: 1.5px solid var(--border-color) !important;
border-radius: var(--border-radius) !important;
font-size: .9rem !important;
color: var(--text-color) !important;
cursor: pointer;
transition: border-color .12s, background .12s, color .12s;
flex-shrink: 0;
}
.bdg__nudge-btn:hover {
border-color: var(--primary-color) !important;
background: var(--hover-background-color) !important;
color: var(--primary-color) !important;
transform: none !important;
}
.bdg__nudge-hint {
font-size: .68rem;
color: var(--text-muted);
margin-left: .15rem;
}
/* â”€â”€ Botones de estilo tipogrÃ¡fico (B / I) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__style-btns {
display: flex;
gap: .375rem;
}
.bdg__style-btn {
width: 32px !important;
height: 32px !important;
display: flex !important;
align-items: center !important;
justify-content: center !important;
background: var(--secondary-background) !important;
border: 1.5px solid var(--border-color) !important;
border-radius: var(--border-radius) !important;
font-size: .9rem !important;
cursor: pointer;
color: var(--text-color) !important;
transition: border-color .12s, background .12s;
}
.bdg__style-btn--on {
border-color: var(--primary-color) !important;
background: var(--hover-background-color) !important;
color: var(--primary-color) !important;
}
/* â”€â”€ Barra inferior de guardado â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__save-bar {
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: .75rem;
padding: .625rem 1.25rem;
background: var(--surface-color);
border-top: 1px solid var(--border-color);
box-shadow: 0 -2px 8px rgba(15, 23, 42, .06);
flex-shrink: 0;
z-index: 10;
}
.bdg__save-bar-actions {
display: flex;
gap: .5rem;
margin-left: auto;
}
/* â”€â”€ Preview modal â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__preview-info {
font-size: .85rem;
color: var(--text-muted);
margin-bottom: 1rem;
padding: .5rem .75rem;
background: var(--info-background);
border: 1px solid var(--info-color);
border-radius: var(--border-radius);
}
.bdg__preview-scroll {
overflow: auto;
display: flex;
justify-content: center;
padding: 1rem;
background: var(--background-color);
border-radius: var(--border-radius);
max-height: 70vh;
}
.bdg__preview-paper {
position: relative;
overflow: hidden;
box-shadow: var(--shadow-xl), 0 0 0 1px var(--border-color);
flex-shrink: 0;
}
.bdg__preview-face {
position: absolute;
overflow: hidden;
}
.bdg__preview-face--rotated {
transform: rotate(180deg);
transform-origin: center center;
}
/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
RESPONSIVE
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
@media (max-width: 1200px) {
.bdg__workspace {
grid-template-columns: 260px 1fr 270px;
}
}
@media (max-width: 1100px) {
.bdg__workspace {
grid-template-columns: 240px 1fr 250px;
}
}
@media (max-width: 900px) {
.bdg {
height: auto;
min-height: calc(100dvh - var(--layout-topbar-height, 64px));
overflow: visible;
}
.bdg__workspace {
grid-template-columns: 1fr;
grid-template-rows: auto 1fr auto;
overflow: auto;
height: auto;
flex: none;
}
.bdg__sidebar {
border-right: none;
border-bottom: 1px solid var(--border-color);
max-height: 360px;
height: auto;
overflow-y: auto;
}
.bdg__canvas-area {
min-height: 400px;
height: auto;
}
.bdg__props {
border-left: none;
border-top: 1px solid var(--border-color);
max-height: 420px;
height: auto;
overflow-y: auto;
}
.bdg__dims-grid {
grid-template-columns: 1fr 1fr;
}
}
@media (max-width: 600px) {
.bdg__header {
padding: .5rem .875rem;
}
.bdg__title {
font-size: .95rem;
}
.bdg__props-row {
grid-template-columns: 1fr;
}
.bdg__add-grid {
grid-template-columns: repeat(3, 1fr);
}
.bdg__dims-grid {
grid-template-columns: 1fr;
}
.bdg__save-bar {
flex-direction: column;
align-items: flex-start;
}
.bdg__save-bar-actions {
margin-left: 0;
width: 100%;
justify-content: flex-end;
}
}
/* â”€â”€ Cuadricula del canvas â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__canvas-grid {
position: absolute;
inset: 0;
pointer-events: none;
z-index: 1;
background-image:
linear-gradient(rgba(80,80,80,.12) 1px, transparent 1px),
linear-gradient(90deg, rgba(80,80,80,.12) 1px, transparent 1px);
background-size: var(--grid-step, 5mm) var(--grid-step, 5mm);
}
/* â”€â”€ Botones de alineacion rapida â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__align {
display: flex;
gap: .375rem;
flex-wrap: wrap;
}
.bdg__align-btn {
display: inline-flex !important;
align-items: center !important;
gap: .3rem !important;
padding: .3rem .55rem !important;
font-size: .72rem !important;
font-weight: 600 !important;
border: 1.5px solid var(--border-color) !important;
border-radius: var(--border-radius) !important;
background: var(--surface-color) !important;
color: var(--text-color) !important;
cursor: pointer;
transition: background .1s, border-color .1s, color .1s;
white-space: nowrap;
}
.bdg__align-btn:hover {
background: var(--hover-background-color) !important;
border-color: var(--primary-color) !important;
color: var(--primary-color) !important;
}
.bdg__align-btn--expand {
flex: 1 1 auto;
background: var(--secondary-background);
font-weight: 600;
}
/* -- Compensacion de impresora (offset) -- */
.bdg__offset-details {
margin-top: .5rem;
border: 1px solid var(--border-color);
border-radius: var(--border-radius);
padding: .4rem .6rem;
font-size: .75rem;
}
.bdg__offset-summary {
cursor: pointer;
font-weight: 600;
color: var(--text-muted);
font-size: .72rem;
text-transform: uppercase;
letter-spacing: .5px;
}
.bdg__offset-hint {
font-size: .68rem;
color: var(--text-muted);
margin: .3rem 0 .5rem;
line-height: 1.3;
}
/* â”€â”€ Boton duplicar en header de propiedades â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__props-hdr-actions {
display: flex;
gap: .375rem;
align-items: center;
}
.bdg__props-dup {
display: inline-flex !important;
align-items: center !important;
justify-content: center !important;
padding: .25rem .5rem !important;
border: 1.5px solid var(--border-color) !important;
border-radius: var(--border-radius) !important;
background: var(--surface-color) !important;
color: var(--text-muted) !important;
font-size: .75rem !important;
font-weight: 500 !important;
cursor: pointer;
transition: background .1s, border-color .1s, color .1s;
}
.bdg__props-dup:hover {
background: var(--hover-background-color) !important;
border-color: var(--primary-color) !important;
color: var(--primary-color) !important;
}
/* â”€â”€ Boton zoom activo (ej: cuadricula encendida) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__zoom-btn--active {
background: var(--primary-color) !important;
color: #fff !important;
border-color: var(--primary-color) !important;
}
/* â”€â”€ Info de bandera en panel de propiedades â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__flag-info {
padding: .4rem .6rem;
background: var(--info-background);
border: 1px solid var(--info-color);
border-radius: var(--border-radius);
font-size: .72rem;
color: var(--info-foreground);
line-height: 1.4;
}
.bdg__flag-info code {
font-family: monospace;
background: rgba(0,0,0,.08);
padding: .1rem .25rem;
border-radius: 3px;
}
/* â”€â”€ Listones / Ribbons placeholder â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__ribbons-ph {
display: block;
width: 100%;
height: 100%;
overflow: hidden;
}
.bdg__ribbon-strip {
display: flex;
align-items: center;
justify-content: center;
width: 100%;
/* height se calcula por C# como porcentaje exacto: 100%/N listones */
font-size: .55em;
font-weight: 700;
color: #fff;
letter-spacing: .8px;
text-transform: uppercase;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
padding: 0 4px;
box-sizing: border-box;
}
.bdg__ribbon-strip--1   { background: #3498db; }
.bdg__ribbon-strip--2   { background: #e74c3c; }
.bdg__ribbon-strip--3   { background: #2ecc71; }
.bdg__ribbon-strip--cat { background: #2ecc71; }
/* â”€â”€ Indicador de contraste en texto â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__contrast-indicator {
padding: .25rem .5rem;
border-radius: var(--border-radius);
font-size: .72rem;
font-weight: 600;
}
.bdg__contrast-indicator--ok {
background: var(--success-background);
color: var(--success-foreground);
}
.bdg__contrast-indicator--warn {
background: var(--warning-background);
color: var(--warning-foreground);
}
/* â”€â”€ Info de listones en panel de propiedades â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__ribbons-info {
padding: .4rem .6rem;
background: var(--info-background);
border: 1px solid var(--info-color);
border-radius: var(--border-radius);
font-size: .72rem;
color: var(--info-foreground);
line-height: 1.4;
display: flex;
flex-direction: column;
gap: .3rem;
}
.bdg__ribbons-info p { margin: 0; }
/* â”€â”€ Indicador de cara activa en seccion de fondo â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__bg-face-target {
display: flex;
align-items: center;
gap: .4rem;
font-size: .72rem;
padding: .3rem 0 .5rem;
flex-wrap: wrap;
}
.bdg__bg-face-label { color: var(--text-muted); }
.bdg__bg-face-hint {
color: var(--text-muted);
font-style: italic;
font-size: .68rem;
}
/* â”€â”€ Modal de compartir diseno â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__share-modal {
display: flex;
flex-direction: column;
gap: .875rem;
}
.bdg__share-modal-desc {
font-size: .85rem;
color: var(--text-secondary);
margin: 0;
line-height: 1.5;
}
.bdg__share-modal-actions {
display: flex;
justify-content: flex-end;
gap: .5rem;
}
/* â”€â”€ Selector de cara para imagen de fondo â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bdg__bg-face-selector {
display: flex;
gap: .5rem;
margin-bottom: .5rem;
}
.bdg__bg-face-card {
display: flex !important;
flex-direction: column !important;
align-items: center !important;
gap: .3rem !important;
flex: 1 !important;
padding: .375rem !important;
border: 2px solid var(--border-color) !important;
border-radius: var(--border-radius) !important;
background: var(--surface-color) !important;
color: var(--text-muted) !important;
cursor: pointer;
transition: border-color .12s, background .12s;
min-height: 0 !important;
font-size: .72rem !important;
}
.bdg__bg-face-card:hover {
border-color: var(--primary-color) !important;
background: var(--hover-background-color) !important;
}
.bdg__bg-face-card--active {
border-color: var(--primary-color) !important;
background: var(--primary-background) !important;
color: var(--primary-color) !important;
}
.bdg__bg-face-thumb {
width: 100%;
height: 48px;
object-fit: cover;
border-radius: 2px;
display: block;
}
.bdg__bg-face-empty {
width: 100%;
height: 48px;
display: flex;
align-items: center;
justify-content: center;
font-size: .65rem;
color: var(--text-muted);
background: var(--background-color);
border: 1px dashed var(--border-color);
border-radius: 2px;
}
.bdg__bg-face-lbl {
font-size: .68rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: .4px;
}
/* -- Aislamiento del modo dark en el canvas del gafete ------------------------
El canvas y el papel de preview representan output de impresión real.
Deben renderizarse siempre en modo claro, independientemente del tema de la app. */
.bdg__paper,
.bdg__canvas,
.bdg__preview-paper {
color-scheme: light;
/* Resetear variables de tema al valor light */
--border-color:          #dee2e6;
--text-muted:            #6c757d;
--secondary-background:  #f8f9fa;
--info-background:       #e7f3ff;
--info-color:            #0d6efd;
--input-bg:              #ffffff;
color: #212529;
background-color: #ffffff;
}
/* -- Footer de la modal de preview ------------------------------------------- */
.bdg__preview-footer {
display: flex;
align-items: center;
justify-content: flex-end;
gap: .75rem;
padding: .5rem 0;
}
/* -- Botón del diseñador (genérico) ------------------------------------------- */
.bdg__btn {
display: inline-flex;
align-items: center;
gap: .4rem;
padding: .45rem .9rem;
border: 1.5px solid transparent;
border-radius: 6px;
font-size: .82rem;
font-weight: 600;
line-height: 1.4;
cursor: pointer;
transition: background .15s, border-color .15s, opacity .15s;
white-space: nowrap;
text-decoration: none;
}
.bdg__btn:disabled {
opacity: .55;
cursor: not-allowed;
}
.bdg__btn--secondary {
background: transparent;
border-color: var(--border-color, #dee2e6);
color: var(--text-primary, #212529);
}
.bdg__btn--secondary:not(:disabled):hover {
background: var(--hover-background, #f1f3f5);
border-color: var(--border-color-hover, #adb5bd);
}
/* -- Spinner inline para estado de carga ------------------------------------- */
.bdg__btn-spinner {
display: inline-block;
width: 14px;
height: 14px;
border: 2px solid currentColor;
border-top-color: transparent;
border-radius: 50%;
animation: bdg-spin .65s linear infinite;
flex-shrink: 0;
}
@keyframes bdg-spin {
to { transform: rotate(360deg); }
}
/* -- Estilos de impresión — window.print() desde Vista previa -----------------
Fallback CSS: si el JS printWithDynamicPage no inyecta su propio @media print,
estos estilos ocultan todo excepto el papel del gafete.
Usa display:none (no visibility:hidden) para que los elementos ocultos NO
ocupen espacio y no generen páginas extra en la impresión.
Usa position:relative (NO fixed) para que el origen coincida con el papel. */
@media print {
/* Ocultar todo el DOM excepto el papel */
body > * {
display: none !important;
box-shadow: none !important;
}
/* Mostrar solo el papel del gafete */
#bdg-preview-paper {
display: block !important;
position: relative !important;
margin: 0 !important;
box-shadow: none !important;
-webkit-print-color-adjust: exact !important;
print-color-adjust: exact !important;
color-adjust: exact !important;
page-break-inside: avoid !important;
break-inside: avoid !important;
}
#bdg-preview-paper * {
visibility: visible !important;
-webkit-print-color-adjust: exact !important;
print-color-adjust: exact !important;
}
}
/* =======================================================================
cfdiListPage — Gestión de CFDIs
Sigue las convenciones BEM de OmniaBP Admin Pages
======================================================================= */
/* ── Layout base ──────────────────────────────────────────────────────── */
.cfdiListPage {
display: flex;
flex-direction: column;
gap: 1rem;
padding: 1.25rem clamp(0.75rem, 2vw, 1.5rem);
max-width: 1400px;
margin: 0 auto;
width: 100%;
}
.cfdiListPage__header {
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: 0.5rem;
}
.cfdiListPage__title {
font-size: clamp(1.1rem, 2.5vw, 1.5rem);
font-weight: 700;
color: var(--text-color);
margin: 0;
}
/* ── Estados de carga / error / vacío ─────────────────────────────────── */
.cfdiListPage__loading,
.cfdiListPage__error,
.cfdiListPage__empty {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 0.75rem;
padding: 3rem 1rem;
color: var(--text-muted);
font-size: 0.95rem;
text-align: center;
}
.cfdiListPage__error { color: var(--danger-foreground); }
/* ── Tabla ────────────────────────────────────────────────────────────── */
.cfdiListPage__table-wrapper {
width: 100%;
overflow-x: auto;
border-radius: var(--radius-lg);
}
.cfdiListPage__th-center,
.cfdiListPage__td-center {
text-align: center !important;
}
/* ── Botón de acciones por fila ───────────────────────────────────────── */
.cfdiListPage__btn-actions {
display: inline-flex;
align-items: center;
justify-content: center;
width: 2rem;
height: 2rem;
border: none;
border-radius: var(--radius-md);
background: transparent;
color: var(--text-muted);
cursor: pointer;
transition: background 0.15s, color 0.15s;
}
.cfdiListPage__btn-actions:hover {
background: var(--hover-background);
color: var(--text-color);
}
.cfdiListPage__btn-actions svg {
pointer-events: none;
}
/* ── Columna ID ───────────────────────────────────────────────────────── */
.cfdiListPage__id-col {
display: flex;
align-items: center;
flex-wrap: wrap;
gap: 0.35rem;
}
/* ── Chips de ID reutilizables ────────────────────────────────────────── */
.idChip--cfdi {
display: inline-flex;
align-items: center;
padding: 0.15rem 0.55rem;
border-radius: var(--radius-pill);
font-size: 0.7rem;
font-weight: 700;
letter-spacing: 0.02em;
background: color-mix(in srgb, var(--primary-color) 12%, transparent);
color: var(--primary-color);
border: 1px solid color-mix(in srgb, var(--primary-color) 25%, transparent);
cursor: default;
}
/* ── Columna Folio ────────────────────────────────────────────────────── */
.cfdiListPage__folio-col {
display: flex;
flex-direction: column;
gap: 0.15rem;
}
.cfdiListPage__folio {
font-weight: 700;
font-size: 0.9rem;
color: var(--text-color);
}
.cfdiListPage__uuid {
font-size: 0.68rem;
font-family: monospace;
color: var(--text-muted);
letter-spacing: 0.02em;
}
/* ── Chip de Serie ────────────────────────────────────────────────────── */
.cfdiListPage__serie-chip {
display: inline-flex;
align-items: center;
justify-content: center;
padding: 0.18rem 0.6rem;
border-radius: var(--radius-sm);
font-size: 0.78rem;
font-weight: 700;
letter-spacing: 0.06em;
text-transform: uppercase;
background: color-mix(in srgb, var(--primary-color) 10%, transparent);
color: var(--primary-color);
border: 1px solid color-mix(in srgb, var(--primary-color) 22%, transparent);
white-space: nowrap;
}
/* ── Columna Tipo ─────────────────────────────────────────────────────── */
.cfdiListPage__type-col {
display: flex;
flex-direction: column;
gap: 0.2rem;
}
/* ── Columna Receptor ─────────────────────────────────────────────────── */
.cfdiListPage__receiver-col {
display: flex;
flex-direction: column;
gap: 0.1rem;
}
.cfdiListPage__receiver-name {
font-size: 0.85rem;
font-weight: 600;
color: var(--text-color);
line-height: 1.3;
}
.cfdiListPage__receiver-rfc {
font-size: 0.72rem;
font-family: monospace;
color: var(--text-muted);
letter-spacing: 0.04em;
}
/* ── Importe ──────────────────────────────────────────────────────────── */
.cfdiListPage__amount {
font-weight: 700;
font-size: 0.9rem;
color: var(--text-color);
white-space: nowrap;
}
.cfdiListPage__currency {
font-weight: 400;
font-size: 0.75rem;
color: var(--text-muted);
}
/* ── Fechas ───────────────────────────────────────────────────────────── */
.cfdiListPage__date-col {
display: flex;
flex-direction: column;
gap: 0.05rem;
}
.cfdiListPage__date {
font-size: 0.82rem;
font-weight: 600;
color: var(--text-color);
}
.cfdiListPage__time {
font-size: 0.72rem;
color: var(--text-muted);
}
.cfdiListPage__text-muted { color: var(--text-muted); }
/* ── Badges ───────────────────────────────────────────────────────────── */
.cfdiListPage__badge {
display: inline-flex;
align-items: center;
gap: 0.2rem;
padding: 0.2rem 0.55rem;
border-radius: var(--radius-pill);
font-size: 0.72rem;
font-weight: 600;
white-space: nowrap;
}
.cfdiListPage__badge--compact {
padding: 0.15rem 0.35rem;
font-size: 0.7rem;
}
.cfdiListPage__badge--type {
background: color-mix(in srgb, var(--accent-color) 12%, transparent);
color: var(--accent-dark);
border: 1px solid color-mix(in srgb, var(--accent-color) 25%, transparent);
}
.cfdiListPage__badge--muted {
background: color-mix(in srgb, var(--text-muted) 10%, transparent);
color: var(--text-muted);
border: 1px solid color-mix(in srgb, var(--text-muted) 20%, transparent);
}
.cfdiListPage__badge--success {
background: var(--success-background);
color: var(--success-foreground);
border: 1px solid color-mix(in srgb, var(--success-foreground) 25%, transparent);
}
.cfdiListPage__badge--danger {
background: var(--danger-background);
color: var(--danger-foreground);
border: 1px solid color-mix(in srgb, var(--danger-foreground) 25%, transparent);
}
.cfdiListPage__badge--warning {
background: var(--warning-background);
color: var(--warning-foreground);
border: 1px solid color-mix(in srgb, var(--warning-foreground) 25%, transparent);
}
.cfdiListPage__badge--info {
background: color-mix(in srgb, var(--primary-color) 10%, transparent);
color: var(--primary-color);
border: 1px solid color-mix(in srgb, var(--primary-color) 20%, transparent);
}
/* ── Panel de filtros ─────────────────────────────────────────────────── */
.cfdiListPage__filter-group {
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.cfdiListPage__filter-section-title {
font-size: 0.72rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.06em;
color: var(--text-muted);
margin: 0;
}
.cfdiListPage__filter-divider {
height: 1px;
background: var(--border-color);
margin: 0.25rem 0;
}
/* ── Modal info ───────────────────────────────────────────────────────── */
.cfdiListPage__modal-info {
font-size: 0.9rem;
color: var(--text-color);
margin-bottom: 1rem;
line-height: 1.5;
}
/* ── Responsive ───────────────────────────────────────────────────────── */
@media (max-width: 768px) {
.cfdiListPage__receiver-name { font-size: 0.8rem; }
.cfdiListPage__folio          { font-size: 0.82rem; }
.cfdiListPage__amount         { font-size: 0.82rem; }
}
/* =============================================
FaceCollectionPage â€” BEM: face-collection
Admin: gestiÃ³n de colecciones faciales
============================================= */
.face-collection {
max-width: 900px;
margin: 0 auto;
padding: 2rem 1.5rem;
display: flex;
flex-direction: column;
gap: 1.5rem;
}
.face-collection__title {
font-size: 1.5rem;
font-weight: 800;
color: var(--text-color);
margin: 0;
}
.face-collection__subtitle {
font-size: 0.875rem;
color: var(--text-muted);
margin: 0;
line-height: 1.5;
}
.face-collection__selector {
max-width: 480px;
}
/* â”€â”€ Cards â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.face-collection__card {
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 12px;
padding: 1.5rem;
display: flex;
flex-direction: column;
gap: 1rem;
}
.face-collection__card-title {
font-size: 1.1rem;
font-weight: 700;
color: var(--text-color);
margin: 0;
}
/* â”€â”€ Status grid â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.face-collection__status {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
gap: 1rem;
}
.face-collection__stat {
display: flex;
flex-direction: column;
gap: 0.2rem;
padding: 0.75rem;
background: var(--surface-alt-color);
border: 1px solid var(--border-color);
border-radius: 8px;
}
.face-collection__stat-value {
font-size: 1.3rem;
font-weight: 800;
color: var(--text-color);
}
.face-collection__stat-value--ok {
color: var(--success-color);
}
.face-collection__stat-value--off {
color: var(--text-muted);
}
.face-collection__stat-value--mono {
font-size: 0.75rem;
font-family: 'Consolas', 'Courier New', monospace;
color: var(--text-muted);
word-break: break-all;
}
.face-collection__stat-label {
font-size: 0.7rem;
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: 0.5px;
font-weight: 600;
}
/* â”€â”€ Loading / Error â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.face-collection__loading {
display: flex;
align-items: center;
gap: 0.75rem;
color: var(--text-muted);
font-size: 0.875rem;
}
.face-collection__error {
padding: 0.75rem 1rem;
background: var(--danger-background);
border-left: 3px solid var(--danger-color);
border-radius: 6px;
color: var(--danger-foreground);
font-size: 0.875rem;
}
/* â”€â”€ Actions â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.face-collection__actions {
display: flex;
gap: 0.75rem;
}
.face-collection__action-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 1.5rem;
}
.face-collection__action-item {
display: flex;
flex-direction: column;
gap: 0.75rem;
padding: 1rem;
background: var(--surface-alt-color);
border: 1px solid var(--border-color);
border-radius: 8px;
}
.face-collection__action-title {
font-size: 0.95rem;
font-weight: 700;
color: var(--text-color);
margin: 0;
}
.face-collection__action-desc {
font-size: 0.8rem;
color: var(--text-muted);
margin: 0;
line-height: 1.5;
}
/* â”€â”€ Results â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.face-collection__result {
padding: 0.75rem 1rem;
border-radius: 6px;
font-size: 0.8rem;
line-height: 1.6;
}
.face-collection__result p {
margin: 0;
}
.face-collection__result--success {
background: var(--success-background);
border-left: 3px solid var(--success-color);
color: var(--success-foreground);
}
.face-collection__result--error {
background: var(--danger-background);
border-left: 3px solid var(--danger-color);
color: var(--danger-foreground);
}
.face-collection__result--warn {
color: var(--warning-color);
font-weight: 700;
}
/* â”€â”€ Confirm delete â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.face-collection__confirm {
display: flex;
flex-direction: column;
gap: 0.75rem;
}
.face-collection__confirm-text {
font-size: 0.85rem;
color: var(--danger-color);
font-weight: 600;
margin: 0;
}
.face-collection__confirm-actions {
display: flex;
gap: 0.75rem;
}
/* â”€â”€ Responsive â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 640px) {
.face-collection {
padding: 1rem;
}
.face-collection__action-grid {
grid-template-columns: 1fr;
}
.face-collection__status {
grid-template-columns: repeat(2, 1fr);
}
}
/* ═══════════════════════════════════════════════════════════════════════════
IoT Broadcast Admin Pages — BEM namespace: iot-broadcast-*
Compartido por: event, emergency, user, global pages
═══════════════════════════════════════════════════════════════════════════ */
/* ── Layout base (aplica a todas las páginas) ── */
.iot-broadcast-event-page,
.iot-broadcast-emergency-page,
.iot-broadcast-user-page,
.iot-broadcast-global-page {
display: flex;
flex-direction: column;
gap: 1.25rem;
width: 100%;
}
/* ── Cuerpo ── */
.iot-broadcast-event-page__body,
.iot-broadcast-emergency-page__body,
.iot-broadcast-user-page__body,
.iot-broadcast-global-page__body {
background: var(--card-background);
border: 1px solid var(--border-color);
border-radius: var(--radius-md);
padding: 1.5rem;
display: flex;
flex-direction: column;
gap: 1.25rem;
}
/* ── Descripción ── */
.iot-broadcast-event-page__description,
.iot-broadcast-emergency-page__description,
.iot-broadcast-user-page__description,
.iot-broadcast-global-page__description {
color: var(--text-secondary);
font-size: 0.875rem;
margin: 0;
line-height: 1.6;
}
/* ── Banner de advertencia ── */
.iot-broadcast-emergency-page__warning-banner,
.iot-broadcast-global-page__warning-banner {
display: flex;
align-items: flex-start;
gap: 0.75rem;
padding: 0.875rem 1rem;
background: var(--warning-background);
border: 1px solid var(--warning-border, var(--warning-foreground));
border-radius: var(--radius-sm);
color: var(--warning-foreground);
font-size: 0.875rem;
line-height: 1.5;
}
.iot-broadcast-emergency-page__warning-banner svg,
.iot-broadcast-global-page__warning-banner svg {
flex-shrink: 0;
width: 1.25rem;
height: 1.25rem;
margin-top: 0.1rem;
}
/* ── Grid de formulario ── */
.iot-broadcast-event-page__form,
.iot-broadcast-emergency-page__form,
.iot-broadcast-user-page__form,
.iot-broadcast-global-page__form {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 1rem;
}
/* ── Campo ── */
.iot-broadcast-event-page__field,
.iot-broadcast-emergency-page__field,
.iot-broadcast-user-page__field,
.iot-broadcast-global-page__field {
display: flex;
flex-direction: column;
}
/* ── Campo ancho completo ── */
.iot-broadcast-event-page__field--full,
.iot-broadcast-emergency-page__field--full,
.iot-broadcast-user-page__field--full,
.iot-broadcast-global-page__field--full {
grid-column: 1 / -1;
}
/* ── Errores ── */
.iot-broadcast-event-page__error,
.iot-broadcast-emergency-page__error,
.iot-broadcast-user-page__error,
.iot-broadcast-global-page__error {
color: var(--danger-foreground);
padding: 1rem;
background: var(--danger-background);
border-radius: var(--radius-sm);
font-size: 0.875rem;
}
.iot-broadcast-event-page__error-msg,
.iot-broadcast-emergency-page__error-msg,
.iot-broadcast-user-page__error-msg,
.iot-broadcast-global-page__error-msg {
color: var(--danger-foreground);
font-size: 0.875rem;
margin: 0;
}
/* ── Acciones ── */
.iot-broadcast-event-page__actions,
.iot-broadcast-emergency-page__actions,
.iot-broadcast-user-page__actions,
.iot-broadcast-global-page__actions {
grid-column: 1 / -1;
display: flex;
justify-content: flex-end;
padding-top: 0.5rem;
}
/* ── Modal de confirmación (emergencia) ── */
.iot-broadcast-emergency-page__confirm-text {
font-size: 0.9rem;
line-height: 1.6;
margin: 0 0 0.75rem;
color: var(--text-primary);
}
.iot-broadcast-emergency-page__confirm-url {
font-size: 0.85rem;
color: var(--text-secondary);
margin: 0;
word-break: break-all;
}
.iot-broadcast-emergency-page__confirm-url code {
background: var(--input-background);
padding: 0.1rem 0.35rem;
border-radius: var(--radius-xs, 3px);
font-family: monospace;
}
/* ── Responsive ── */
@media (max-width: 640px) {
.iot-broadcast-event-page__form,
.iot-broadcast-emergency-page__form,
.iot-broadcast-user-page__form,
.iot-broadcast-global-page__form {
grid-template-columns: 1fr;
}
}
/* -- Modal de confirmaci\u00f3n (global page) -- */
.iot-broadcast-global-page__confirm-text {
font-size: 0.9rem;
color: var(--text-secondary);
margin: 0 0 1rem;
line-height: 1.55;
}
.iot-broadcast-global-page__confirm-preview {
display: grid;
grid-template-columns: auto 1fr;
gap: 0.4rem 0.85rem;
background: var(--surface-secondary);
border: 1px solid var(--border-color);
border-radius: var(--radius-md);
padding: 0.85rem 1rem;
font-size: 0.85rem;
}
.iot-broadcast-global-page__confirm-label {
color: var(--text-muted);
font-weight: 600;
white-space: nowrap;
padding-top: 0.05rem;
}
.iot-broadcast-global-page__confirm-value {
color: var(--text-primary);
word-break: break-word;
}
/* -- Modal de confirmacion (event page) -- */
.iot-broadcast-event-page__confirm-text {
font-size: 0.9rem;
color: var(--text-secondary);
margin: 0 0 1rem;
line-height: 1.55;
}
.iot-broadcast-event-page__confirm-preview {
display: grid;
grid-template-columns: auto 1fr;
gap: 0.4rem 0.85rem;
background: var(--surface-secondary);
border: 1px solid var(--border-color);
border-radius: var(--radius-md);
padding: 0.85rem 1rem;
font-size: 0.85rem;
}
.iot-broadcast-event-page__confirm-label {
color: var(--text-muted);
font-weight: 600;
white-space: nowrap;
padding-top: 0.05rem;
}
.iot-broadcast-event-page__confirm-value {
color: var(--text-primary);
word-break: break-word;
}
/* =============================================
Kiosk Prep Modal â€” BEM: kiosk-prep
Modal de preparaciÃ³n de estaciÃ³n kiosk
en /admin/events
============================================= */
.kiosk-prep__intro {
padding: 0.75rem 1rem;
background: var(--info-background);
border-left: 3px solid var(--info-color);
border-radius: 6px;
margin-bottom: 1.25rem;
}
.kiosk-prep__intro-text {
margin: 0;
font-size: 0.85rem;
color: var(--info-foreground);
line-height: 1.5;
}
/* â”€â”€ Pasos â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.kiosk-prep__steps {
display: flex;
flex-direction: column;
gap: 0.75rem;
margin-bottom: 1.25rem;
}
.kiosk-prep__step {
display: flex;
align-items: flex-start;
gap: 0.75rem;
}
.kiosk-prep__step-num {
flex-shrink: 0;
width: 28px;
height: 28px;
border-radius: 50%;
background: var(--primary-color);
color: var(--primary-foreground);
font-size: 0.8rem;
font-weight: 800;
display: flex;
align-items: center;
justify-content: center;
}
.kiosk-prep__step-body {
display: flex;
flex-direction: column;
gap: 0.15rem;
padding-top: 0.25rem;
}
.kiosk-prep__step-body strong {
font-size: 0.85rem;
color: var(--text-color);
}
.kiosk-prep__step-body span {
font-size: 0.78rem;
color: var(--text-muted);
line-height: 1.4;
}
/* â”€â”€ URL copiable â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.kiosk-prep__url-block {
display: flex;
flex-direction: column;
gap: 0.4rem;
margin-bottom: 1.25rem;
}
.kiosk-prep__url-label {
font-size: 0.7rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.5px;
color: var(--text-muted);
}
.kiosk-prep__url-row {
display: flex;
align-items: center;
gap: 0.75rem;
background: var(--surface-alt-color);
border: 1px solid var(--border-color);
border-radius: 8px;
padding: 0.6rem 0.75rem;
}
.kiosk-prep__url-value {
flex: 1;
font-size: 0.85rem;
color: var(--accent-color);
font-family: 'Consolas', 'Courier New', monospace;
word-break: break-all;
user-select: all;
}
/* â”€â”€ Permisos â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.kiosk-prep__permissions {
padding: 0.75rem 1rem;
background: var(--surface-alt-color);
border: 1px solid var(--border-color);
border-radius: 8px;
}
.kiosk-prep__permissions-title {
font-size: 0.75rem;
font-weight: 700;
color: var(--text-secondary);
margin: 0 0 0.6rem;
text-transform: uppercase;
letter-spacing: 0.4px;
}
.kiosk-prep__permission-chips {
display: flex;
flex-wrap: wrap;
gap: 0.4rem;
align-items: center;
}
.kiosk-prep__chip {
font-size: 0.72rem;
font-weight: 700;
padding: 0.2rem 0.55rem;
border-radius: 20px;
font-family: 'Consolas', 'Courier New', monospace;
}
.kiosk-prep__chip--required {
background: var(--primary-color);
color: var(--primary-foreground);
}
.kiosk-prep__chip--optional {
background: var(--surface-color);
border: 1px solid var(--border-color);
color: var(--text-secondary);
}
.kiosk-prep__chip--note {
font-family: inherit;
font-weight: 400;
font-size: 0.72rem;
color: var(--text-muted);
background: none;
padding: 0;
}
/* =======================================================================
paymentListPage — Gestión de Pagos (Admin)
BEM namespace: paymentListPage
Paleta: colors.css — sin valores hardcodeados
======================================================================= */
/* ── Layout base ──────────────────────────────────────────────────────── */
.paymentListPage {
display: flex;
flex-direction: column;
gap: 1rem;
padding: 1.25rem clamp(0.75rem, 2vw, 1.5rem);
max-width: 1400px;
margin: 0 auto;
width: 100%;
}
/* ── Estados de carga / error / vacío ─────────────────────────────────── */
.paymentListPage__loading,
.paymentListPage__error,
.paymentListPage__empty {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 0.75rem;
padding: 3rem 1rem;
color: var(--text-muted);
font-size: 0.95rem;
text-align: center;
}
.paymentListPage__error { color: var(--danger-foreground); }
/* ── Tabla ────────────────────────────────────────────────────────────── */
.paymentListPage__table-wrapper {
width: 100%;
overflow-x: auto;
border-radius: var(--radius-lg);
}
.paymentListPage__th-center,
.paymentListPage__td-center {
text-align: center !important;
}
/* ── Columna ID ───────────────────────────────────────────────────────── */
.paymentListPage__id-col {
display: flex;
flex-direction: column;
align-items: flex-start;
gap: 0.2rem;
}
/* Selector contextual: gana sobre herencia de AppTable td (font-size: 0.875rem)
y sobre cualquier override posterior de idChip en otros archivos legacy */
.paymentListPage__id-col .idChip {
font-size: 0.63rem !important;
padding: 0.07rem 0.38rem !important;
line-height: 1.35;
}
.paymentListPage__id-col .idChip--payment {
background: color-mix(in srgb, var(--primary-color) 10%, transparent) !important;
color: var(--primary-dark) !important;
border: 1px solid color-mix(in srgb, var(--primary-color) 24%, transparent) !important;
font-weight: 600;
}
.paymentListPage__id-col .idChip--payment:hover {
background: color-mix(in srgb, var(--primary-color) 18%, transparent) !important;
border-color: color-mix(in srgb, var(--primary-color) 40%, transparent) !important;
}
.paymentListPage__id-col .idChip--receipt {
background: color-mix(in srgb, var(--secondary-color) 8%, transparent) !important;
color: var(--text-muted) !important;
border: 1px solid color-mix(in srgb, var(--secondary-color) 18%, transparent) !important;
font-weight: 500;
}
.paymentListPage__id-col .idChip--receipt:hover {
background: color-mix(in srgb, var(--secondary-color) 15%, transparent) !important;
border-color: color-mix(in srgb, var(--secondary-color) 30%, transparent) !important;
}
/* ── Columna Fecha ────────────────────────────────────────────────────── */
.paymentListPage__date-col {
display: flex;
flex-direction: column;
gap: 0.1rem;
}
.paymentListPage__date {
font-size: 0.85rem;
color: var(--text-color);
font-weight: 500;
}
.paymentListPage__time {
font-size: 0.72rem;
color: var(--text-muted);
}
/* ── Columna Motor ────────────────────────────────────────────────────── */
.paymentListPage__engine-col {
display: flex;
flex-direction: column;
gap: 0.15rem;
}
.paymentListPage__txn {
font-size: 0.68rem;
font-family: monospace;
color: var(--text-muted);
}
/* ── Badge motor: doble clase para ganar sobre .paymentListPage__badge del legacy ─ */
/* El legacy define padding: 0.25rem 0.5rem y border-radius cuadrado en
.paymentListPage__badge; la doble clase aqui tiene mayor especificidad */
.paymentListPage__badge.paymentListPage__badge--engine {
display: inline-flex;
align-items: center;
font-size: 0.6rem;
font-weight: 700;
letter-spacing: 0.06em;
padding: 0.1rem 0.42rem;
text-transform: uppercase;
border-radius: var(--radius-pill);
white-space: nowrap;
line-height: 1.3;
}
/* ── Colores por motor — paleta del sistema ──────────────────────────── */
/* Stripe: tono primary (azul-índigo de la paleta) */
.paymentListPage__badge--engine-stripe {
background: color-mix(in srgb, var(--primary-color) 12%, transparent);
color: var(--primary-dark);
border: 1px solid color-mix(in srgb, var(--primary-color) 26%, transparent);
}
/* OpenPay: tono accent-teal de la paleta */
.paymentListPage__badge--engine-openpay {
background: color-mix(in srgb, var(--accent-color) 12%, transparent);
color: var(--accent-dark);
border: 1px solid color-mix(in srgb, var(--accent-color) 28%, transparent);
}
/* MercadoPago: tono info de la paleta */
.paymentListPage__badge--engine-mercadopago {
background: color-mix(in srgb, var(--info-color) 14%, transparent);
color: var(--info-foreground);
border: 1px solid color-mix(in srgb, var(--info-color) 30%, transparent);
}
/* PayPal: tono secondary oscuro */
.paymentListPage__badge--engine-paypal {
background: color-mix(in srgb, var(--secondary-dark) 12%, transparent);
color: var(--secondary-dark);
border: 1px solid color-mix(in srgb, var(--secondary-dark) 28%, transparent);
}
/* Cash / Efectivo: tono success */
.paymentListPage__badge--engine-cash {
background: color-mix(in srgb, var(--success-dark) 12%, transparent);
color: var(--success-dark);
border: 1px solid color-mix(in srgb, var(--success-dark) 28%, transparent);
}
/* Transfer: tono highlight-energy (naranja de la paleta) */
.paymentListPage__badge--engine-transfer {
background: color-mix(in srgb, var(--highlight-energy) 12%, transparent);
color: var(--highlight-energy-dark);
border: 1px solid color-mix(in srgb, var(--highlight-energy) 28%, transparent);
}
/* Free / Gratis: muted */
.paymentListPage__badge--engine-free {
background: color-mix(in srgb, var(--secondary-color) 10%, transparent);
color: var(--text-muted);
border: 1px solid color-mix(in srgb, var(--secondary-color) 20%, transparent);
}
/* ── Columnas Total e IVA — estilo unificado ─────────────────────────── */
.paymentListPage__total-col {
display: flex;
flex-direction: column;
align-items: flex-start;
gap: 0.05rem;
}
/* Monto principal: tamaño y peso idéntico en ambas columnas */
.paymentListPage__amount,
.paymentListPage__tax {
font-size: 0.82rem;
font-weight: 600;
font-variant-numeric: tabular-nums;
line-height: 1.2;
}
/* Color semántico del total según estado de pago */
.paymentListPage__amount {
color: var(--text-color);
}
.paymentListPage__amount--paid {
color: var(--success-dark);
}
.paymentListPage__amount--pending {
color: var(--text-secondary);
}
/* Moneda debajo del monto: discreta */
.paymentListPage__currency {
font-size: 0.6rem;
color: var(--text-muted);
font-weight: 400;
text-transform: uppercase;
letter-spacing: 0.04em;
}
/* IVA: mismo peso visual que el total, color neutro */
.paymentListPage__tax {
color: var(--text-secondary);
}
.paymentListPage__tax-cell {
text-align: right;
padding-right: 0.25rem;
}
/* ── Columna Pagador ──────────────────────────────────────────────────── */
.paymentListPage__payer-col {
display: flex;
flex-direction: column;
gap: 0.1rem;
}
.paymentListPage__payer-name {
font-size: 0.875rem;
font-weight: 600;
color: var(--text-color);
}
.paymentListPage__payer-email {
font-size: 0.68rem;
color: var(--text-muted);
font-weight: 400;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
max-width: 180px;
}
/* ── Columna Estado ───────────────────────────────────────────────────── */
.paymentListPage__status-cell,
.paymentListPage__cfdi-cell,
.paymentListPage__actions-cell {
text-align: center;
}
.paymentListPage__status-badges,
.paymentListPage__cfdi-badges {
display: flex;
align-items: center;
justify-content: center;
flex-wrap: wrap;
gap: 0.2rem;
}
/* ── Íconos de estado compactos con tooltip nativo ───────────────────── */
.paymentListPage__status-icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 1.6rem;
height: 1.6rem;
border-radius: 50%;
cursor: default;
transition: transform 0.15s;
}
.paymentListPage__status-icon:hover {
transform: scale(1.15);
}
.paymentListPage__status-icon--success {
background: var(--success-background);
color: var(--success-foreground);
border: 1px solid color-mix(in srgb, var(--success-color) 35%, transparent);
}
.paymentListPage__status-icon--warning {
background: var(--warning-background);
color: var(--warning-foreground);
border: 1px solid color-mix(in srgb, var(--warning-color) 35%, transparent);
}
.paymentListPage__status-icon--danger {
background: var(--danger-background);
color: var(--danger-foreground);
border: 1px solid color-mix(in srgb, var(--danger-color) 35%, transparent);
}
.paymentListPage__status-icon--info {
background: var(--info-background);
color: var(--info-foreground);
border: 1px solid color-mix(in srgb, var(--info-color) 35%, transparent);
}
/* Columna Tipo */
.paymentListPage__type-cell {
text-align: center;
}
/* ── Columna CFDI (Serie + Folio + Estado) ────────────────────────────── */
.paymentListPage__cfdi-col {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.2rem;
}
/* Línea de referencia: serie (pill) + folio (monospace) en horizontal */
.paymentListPage__cfdi-ref {
display: flex;
align-items: center;
gap: 0.2rem;
flex-wrap: nowrap;
}
.paymentListPage__cfdi-serie {
font-size: 0.58rem;
font-weight: 700;
color: var(--primary-dark);
background: color-mix(in srgb, var(--primary-color) 10%, transparent);
border: 1px solid color-mix(in srgb, var(--primary-color) 22%, transparent);
border-radius: var(--radius-pill);
padding: 0.05rem 0.3rem;
text-transform: uppercase;
letter-spacing: 0.04em;
white-space: nowrap;
}
.paymentListPage__cfdi-folio {
font-size: 0.75rem;
font-weight: 600;
color: var(--text-color);
font-family: monospace;
}
.paymentListPage__cfdi-count {
font-size: 0.65rem;
color: var(--text-muted);
}
/* ── Badges ───────────────────────────────────────────────────────────── */
.paymentListPage__badge {
display: inline-flex;
align-items: center;
gap: 0.2rem;
padding: 0.2rem 0.55rem;
border-radius: var(--radius-pill);
font-size: 0.72rem;
font-weight: 600;
white-space: nowrap;
}
.paymentListPage__badge--success {
background: var(--success-background);
color: var(--success-foreground);
border: 1px solid color-mix(in srgb, var(--success-color) 30%, transparent);
}
.paymentListPage__badge--danger {
background: var(--danger-background);
color: var(--danger-foreground);
border: 1px solid color-mix(in srgb, var(--danger-color) 30%, transparent);
}
.paymentListPage__badge--warning {
background: var(--warning-background);
color: var(--warning-foreground);
border: 1px solid color-mix(in srgb, var(--warning-color) 30%, transparent);
}
.paymentListPage__badge--info {
background: var(--info-background);
color: var(--info-foreground);
border: 1px solid color-mix(in srgb, var(--info-color) 30%, transparent);
}
.paymentListPage__badge--muted {
background: color-mix(in srgb, var(--secondary-color) 10%, transparent);
color: var(--text-secondary);
border: 1px solid color-mix(in srgb, var(--secondary-color) 20%, transparent);
}
/* .paymentListPage__badge--engine — definido en sección Motor arriba */
.paymentListPage__badge--compact {
padding: 0.12rem 0.4rem;
font-size: 0.65rem;
}
.paymentListPage__badge-icon {
display: inline-flex;
align-items: center;
width: 12px;
height: 12px;
}
/* ── Texto muted ──────────────────────────────────────────────────────── */
.paymentListPage__text-muted {
color: var(--text-muted);
font-size: 0.8rem;
}
/* ── Panel filtros ────────────────────────────────────────────────────── */
.paymentListPage__filter-group {
display: flex;
flex-direction: column;
gap: 0.5rem;
padding: 0.5rem 0;
}
.paymentListPage__filter-section-title {
font-size: 0.75rem;
font-weight: 700;
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: 0.07em;
margin: 0 0 0.25rem 0;
}
.paymentListPage__filter-divider {
height: 1px;
background: var(--divider-color);
margin: 0.25rem 0;
}
/* ── Responsivo ───────────────────────────────────────────────────────── */
@media (max-width: 768px) {
.paymentListPage__total-col {
flex-direction: column;
gap: 0;
}
.paymentListPage__engine-col {
align-items: flex-start;
}
.paymentListPage__cfdi-col {
align-items: flex-start;
}
.paymentListPage__payer-email {
max-width: 140px;
}
.paymentListPage__tax-cell {
text-align: left;
}
}
@media (max-width: 480px) {
.paymentListPage__status-icon {
width: 1.4rem;
height: 1.4rem;
}
.paymentListPage__payer-email {
display: none;
}
}
/* =============================================
EventsListPage — Badge Reprint Config section
BEM: events-list-page__badge-*
============================================= */
.events-list-page__badge-section {
border: 1px solid var(--border-color);
border-radius: var(--border-radius);
overflow: hidden;
}
.events-list-page__badge-summary {
display: flex;
align-items: center;
justify-content: space-between;
padding: .75rem 1rem;
cursor: pointer;
background: var(--secondary-background);
font-size: .9rem;
font-weight: 700;
color: var(--text-color);
list-style: none;
user-select: none;
}
.events-list-page__badge-summary::-webkit-details-marker { display: none; }
.events-list-page__badge-cost-badge {
padding: .2rem .6rem;
background: var(--success-background);
color: var(--success-color);
border-radius: 999px;
font-size: .78rem;
font-weight: 700;
}
.events-list-page__badge-disabled-badge {
padding: .2rem .6rem;
background: var(--secondary-background);
color: var(--text-muted);
border-radius: 999px;
font-size: .78rem;
}
.events-list-page__badge-body {
padding: 1rem;
display: flex;
flex-direction: column;
gap: .875rem;
background: var(--surface-color);
border-top: 1px solid var(--border-color);
}
.events-list-page__badge-cfdi { margin-top: .25rem; }
.events-list-page__badge-cfdi summary {
cursor: pointer;
font-size: .85rem;
color: var(--text-muted);
padding: .4rem 0;
user-select: none;
}
.events-list-page__badge-cfdi-body {
display: flex; flex-direction: column; gap: .75rem; padding-top: .75rem;
}
.events-list-page__badge-error {
padding: .75rem 1rem;
background: var(--danger-background);
border-left: 3px solid var(--danger-color);
border-radius: var(--border-radius);
color: var(--danger-color);
font-size: .875rem;
}
.events-list-page__badge-success {
padding: .75rem 1rem;
background: var(--success-background);
border-left: 3px solid var(--success-color);
border-radius: var(--border-radius);
color: var(--success-color);
font-size: .875rem;
}
.events-list-page__badge-save { display: flex; justify-content: flex-end; }
/* =============================================
Modal rápido de configuración de gafete
BEM: events-list-page__badge-quick
============================================= */
.events-list-page__badge-quick {
display: flex;
flex-direction: column;
gap: 1rem;
padding-bottom: .25rem;
}
/* =============================================
BadgePayPage — BEM: badge-pay-page
============================================= */
.badge-pay-page {
width: 100%; max-width: 680px; margin: 0 auto;
padding: 1.25rem 1rem; display: flex; flex-direction: column; gap: 1.5rem;
}
.badge-pay-page__header { display: flex; flex-direction: column; gap: .75rem; }
.badge-pay-page__title  { font-size: 1.5rem; font-weight: 800; color: var(--text-color); margin: 0; }
.badge-pay-page__no-event {
padding: 2rem; text-align: center; color: var(--text-muted);
border: 2px dashed var(--border-color); border-radius: var(--border-radius);
}
.badge-pay-page__body   { display: flex; flex-direction: column; gap: 1.25rem; }
.badge-pay-page__search-card,
.badge-pay-page__payment-card {
background: var(--surface-color); border: 1px solid var(--border-color);
border-radius: var(--border-radius); padding: 1.25rem;
display: flex; flex-direction: column; gap: 1rem;
}
.badge-pay-page__search-title { font-size: 1rem; font-weight: 700; color: var(--text-color); margin: 0; }
.badge-pay-page__search-hint  { font-size: .875rem; color: var(--text-muted); margin: 0; }
.badge-pay-page__search-row {
display: flex; gap: .75rem; align-items: flex-end; flex-wrap: wrap;
}
.badge-pay-page__search-row > :first-child { flex: 1; min-width: 140px; }
.badge-pay-page__reprint-cost {
display: flex; align-items: center; justify-content: space-between;
padding: .75rem 1rem; background: var(--info-background);
border: 1px solid var(--info-color); border-radius: var(--border-radius);
font-size: .875rem; color: var(--text-color);
}
.badge-pay-page__reprint-cost strong { color: var(--info-color); font-size: 1.1rem; }
.badge-pay-page__receipt-info {
display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
padding: .75rem 1rem; background: var(--secondary-background);
border-radius: var(--border-radius);
}
.badge-pay-page__receipt-label { font-size: .8rem; color: var(--text-muted); font-weight: 600; text-transform: uppercase; }
.badge-pay-page__receipt-id    { font-size: 1.5rem; font-weight: 900; color: var(--primary-color); font-family: monospace; }
.badge-pay-page__receipt-total { font-size: 1.1rem; font-weight: 700; color: var(--success-color); margin-left: auto; }
.badge-pay-page__payment-title { font-size: .95rem; font-weight: 700; color: var(--text-color); margin: 0; }
.badge-pay-page__error {
padding: .75rem 1rem; background: var(--danger-background);
border-left: 3px solid var(--danger-color); border-radius: var(--border-radius);
color: var(--danger-color); font-size: .875rem;
}
.badge-pay-page__pay-actions { display: flex; gap: .75rem; flex-wrap: wrap; justify-content: flex-end; }
/* Resultado */
.badge-pay-page__result {
display: flex; flex-direction: column; align-items: center; gap: 1.25rem; padding: 2rem 1rem;
}
.badge-pay-page__result-badge {
display: flex; align-items: center; gap: .75rem;
padding: .75rem 1.5rem; background: var(--success-background);
border: 2px solid var(--success-color); border-radius: 999px;
}
.badge-pay-page__result-icon { font-size: 1.5rem; color: var(--success-color); }
.badge-pay-page__result-text { font-weight: 700; font-size: 1rem; color: var(--success-color); }
.badge-pay-page__result-hint { font-size: .875rem; color: var(--text-muted); margin: 0; text-align: center; }
.badge-pay-page__result-qr   { display: flex; flex-direction: column; align-items: center; gap: .5rem; }
.badge-pay-page__result-receipt-id { font-size: 1rem; font-weight: 700; color: var(--primary-color); font-family: monospace; }
@media (max-width: 600px) {
.badge-pay-page__search-row { flex-direction: column; }
}
/* =============================================
BadgeStationPage â€” BEM: badge-station
Kiosk full-screen con acceso facial + QR
============================================= */
/* â”€â”€ Contenedor raÃ­z â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station {
position: fixed;
inset: 0;
z-index: 9990;
display: flex;
flex-direction: column;
min-height: 100dvh;
overflow: hidden;
cursor: default;
font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
}
/* â”€â”€ Fondo animado â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__bg {
position: absolute;
inset: 0;
z-index: 0;
overflow: hidden;
}
.badge-station__bg-gradient {
position: absolute;
inset: 0;
}
.badge-station__bg-rings {
position: absolute;
inset: 0;
pointer-events: none;
}
.badge-station__bg-ring {
position: absolute;
border-radius: 50%;
border: 1px solid rgba(255,255,255,0.08);
}
.badge-station__bg-ring--1 {
width: 140vmax;
height: 140vmax;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
animation: badgeRingPulse 8s ease-in-out infinite;
}
.badge-station__bg-ring--2 {
width: 100vmax;
height: 100vmax;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
animation: badgeRingPulse 8s ease-in-out infinite 2.5s;
}
.badge-station__bg-ring--3 {
width: 60vmax;
height: 60vmax;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
animation: badgeRingPulse 8s ease-in-out infinite 5s;
}
@keyframes badgeRingPulse {
0%, 100% { opacity: 0.3; transform: translate(-50%,-50%) scale(0.9); }
50%      { opacity: 0.6; transform: translate(-50%,-50%) scale(1.05); }
}
/* â”€â”€ Contenido principal â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__content {
position: relative;
z-index: 1;
flex: 1;
display: flex;
gap: 0;
min-height: 0;
}
/* â”€â”€ Panel de cÃ¡mara (izquierda) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__camera {
position: relative;
width: 40%;
min-width: 300px;
max-width: 480px;
align-self: stretch;
background: rgba(0,0,0,0.4);
display: flex;
align-items: stretch;
justify-content: center;
overflow: hidden;
border-right: 1px solid rgba(255,255,255,0.1);
transition: border-color 0.4s;
}
.badge-station__camera--identifying { border-color: var(--accent-color); }
.badge-station__camera--match       { border-color: var(--success-color); }
.badge-station__camera--already     { border-color: var(--warning-color); }
.badge-station__camera--nomatch     { border-color: var(--danger-color); }
.badge-station__camera--error       { border-color: var(--danger-color); }
.badge-station__camera-video {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
object-fit: cover;
transform: scaleX(-1);
}
.badge-station__camera-overlay {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
pointer-events: none;
transform: scaleX(-1);
}
.badge-station__camera-status {
position: absolute;
bottom: 0;
left: 0;
right: 0;
padding: 1rem;
background: linear-gradient(transparent, rgba(0,0,0,0.7));
color: #fff;
text-align: center;
font-size: 0.9rem;
font-weight: 600;
}
.badge-station__camera-status-idle span,
.badge-station__camera-status-scan span,
.badge-station__camera-status-match span,
.badge-station__camera-status-already span,
.badge-station__camera-status-nomatch span,
.badge-station__camera-status-error span {
display: block;
text-shadow: 0 1px 4px rgba(0,0,0,0.6);
}
.badge-station__camera-status-match { color: var(--success-light); }
.badge-station__camera-status-already { color: var(--warning-light); }
.badge-station__camera-status-nomatch { color: var(--danger-light); }
.badge-station__camera-status-error { color: var(--danger-light); }
.badge-station__camera-check {
font-size: 2.5rem;
font-weight: 900;
}
.badge-station__camera-off {
position: absolute;
inset: 0;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 0.75rem;
color: rgba(255,255,255,0.5);
background: rgba(0,0,0,0.6);
}
.badge-station__camera-off span {
font-size: 0.85rem;
}
/* â”€â”€ AnimaciÃ³n de escaneo facial â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__scan-reticle {
width: 60px;
height: 60px;
margin: 0 auto 0.5rem;
border: 2px dashed rgba(255,255,255,0.4);
border-radius: 50%;
animation: badgeReticleSpin 4s linear infinite;
}
@keyframes badgeReticleSpin {
to { transform: rotate(360deg); }
}
.badge-station__scan-line {
width: 80%;
height: 2px;
margin: 0 auto 0.5rem;
background: linear-gradient(90deg, transparent, var(--accent-light), transparent);
animation: badgeScanLine 1.5s ease-in-out infinite;
}
@keyframes badgeScanLine {
0%   { opacity: 0.3; transform: translateY(-20px); }
50%  { opacity: 1;   transform: translateY(20px); }
100% { opacity: 0.3; transform: translateY(-20px); }
}
/* â”€â”€ Zona central â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__main {
flex: 1;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
position: relative;
padding: 2rem;
min-width: 0;
}
/* â”€â”€ Pantalla Setup (selecciÃ³n de evento) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__setup {
display: flex;
flex-direction: column;
align-items: center;
gap: 1.5rem;
max-width: 480px;
width: 100%;
animation: badgeIdleFadeIn 0.6s ease;
}
.badge-station__setup-icon {
width: clamp(60px, 12vw, 100px);
height: clamp(60px, 12vw, 100px);
color: rgba(255,255,255,0.3);
animation: badgeIconFloat 4s ease-in-out infinite;
}
.badge-station__setup-title {
font-size: clamp(1.5rem, 4vw, 2.5rem);
font-weight: 900;
color: #ffffff;
text-align: center;
margin: 0;
text-shadow: 0 2px 12px rgba(0,0,0,0.3);
}
.badge-station__setup-sub {
font-size: clamp(0.85rem, 2vw, 1.1rem);
color: rgba(255,255,255,0.7);
text-align: center;
margin: 0;
line-height: 1.5;
}
.badge-station__setup-select {
width: 100%;
background: rgba(255,255,255,0.95);
border-radius: 12px;
padding: 1.25rem;
box-shadow: 0 8px 32px rgba(0,0,0,0.3);
}
/* â”€â”€ Panel cambiar evento (footer expandible) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__change-event {
position: fixed;
bottom: 56px;
right: 1rem;
z-index: 200;
background: var(--surface-color, #fff);
border-radius: 12px;
padding: 1rem;
box-shadow: 0 -4px 24px rgba(0,0,0,0.25);
max-width: 420px;
width: calc(100% - 2rem);
animation: badgeChangeSlideUp 0.25s ease;
}
@keyframes badgeChangeSlideUp {
from { opacity: 0; transform: translateY(20px); }
to   { opacity: 1; transform: translateY(0); }
}
/* AnimaciÃ³n idle: Ã­cono de gafete */
.badge-station__idle-anim {
display: flex;
flex-direction: column;
align-items: center;
gap: 1rem;
margin-bottom: 2rem;
animation: badgeIdleFadeIn 0.6s ease;
}
@keyframes badgeIdleFadeIn {
from { opacity: 0; transform: translateY(20px); }
to   { opacity: 1; transform: translateY(0); }
}
.badge-station__badge-icon {
width: clamp(80px, 15vw, 160px);
height: clamp(80px, 15vw, 160px);
color: rgba(255,255,255,0.25);
animation: badgeIconFloat 4s ease-in-out infinite;
filter: drop-shadow(0 4px 20px rgba(0,0,0,0.2));
}
@keyframes badgeIconFloat {
0%, 100% { transform: translateY(0); }
50%      { transform: translateY(-12px); }
}
.badge-station__title {
font-size: clamp(1.8rem, 5vw, 3.5rem);
font-weight: 900;
color: #ffffff;
text-align: center;
margin: 0;
text-shadow: 0 2px 12px rgba(0,0,0,0.3);
letter-spacing: -0.5px;
}
.badge-station__subtitle {
font-size: clamp(0.9rem, 2vw, 1.3rem);
color: rgba(255,255,255,0.7);
text-align: center;
margin: 0;
font-weight: 500;
text-shadow: 0 1px 4px rgba(0,0,0,0.3);
}
/* â”€â”€ Ãrea de bÃºsqueda (dos inputs) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__input-area {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.75rem;
width: 90%;
max-width: 580px;
}
.badge-station__input-block {
display: flex;
flex-direction: column;
gap: 0.35rem;
width: 100%;
}
.badge-station__input-label {
display: flex;
align-items: center;
gap: 0.4rem;
font-size: 0.7rem;
font-weight: 700;
letter-spacing: 1px;
text-transform: uppercase;
color: rgba(255,255,255,0.65);
}
.badge-station__input-hint {
font-size: 0.65rem;
color: rgba(255,255,255,0.4);
text-align: center;
letter-spacing: 0.3px;
}
.badge-station__input-wrap {
position: relative;
width: 100%;
}
/* Base compartida â€” ambos inputs siempre sobre fondo azul oscuro del kiosk */
.badge-station__input {
width: 100%;
box-sizing: border-box;
padding: 0.85rem 1.25rem;
font-size: clamp(1.2rem, 2.8vw, 2rem);
font-weight: 700;
border: 2px solid rgba(255,255,255,0.25);
border-radius: 14px;
/* Fondo siempre opaco â€” sin backdrop-filter para evitar que el fondo oscuro sangre */
background: rgba(255,255,255,0.97);
/* Color siempre oscuro â€” var(--primary-dark) es azul marino en todos los temas */
color: var(--primary-dark);
text-align: center;
box-shadow: 0 4px 24px rgba(0,0,0,0.3);
outline: none;
caret-color: var(--primary-color);
transition: box-shadow 0.2s, border-color 0.2s;
}
.badge-station__input::placeholder {
color: var(--secondary-light);
font-weight: 400;
letter-spacing: normal;
font-size: 0.75em;
}
/* â”€â”€ Input QR: prominente, letra espaciada â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__input--qr {
font-size: clamp(1.5rem, 3.5vw, 2.4rem);
letter-spacing: 0.22em;
text-transform: uppercase;
border-color: rgba(255,255,255,0.4);
box-shadow: 0 6px 32px rgba(0,0,0,0.35);
}
.badge-station__input--qr:focus {
border-color: var(--success-color);
box-shadow: 0 6px 32px rgba(0,0,0,0.4), 0 0 0 4px var(--focus-ring);
}
/* â”€â”€ Input bÃºsqueda: tamaÃ±o medio, misma apariencia limpia â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__input--search {
font-size: clamp(1rem, 2vw, 1.4rem);
font-weight: 500;
border-color: rgba(255,255,255,0.25);
}
.badge-station__input--search:focus {
border-color: rgba(255,255,255,0.6);
box-shadow: 0 4px 24px rgba(0,0,0,0.35), 0 0 0 4px var(--focus-ring);
}
/* Divisor "o" entre inputs */
.badge-station__input-divider {
display: flex;
align-items: center;
gap: 0.75rem;
width: 80%;
color: rgba(255,255,255,0.3);
font-size: 0.75rem;
font-weight: 600;
letter-spacing: 1px;
}
.badge-station__input-divider::before,
.badge-station__input-divider::after {
content: '';
flex: 1;
height: 1px;
background: rgba(255,255,255,0.15);
}
.badge-station__input-spinner {
position: absolute;
right: 1rem;
top: 50%;
transform: translateY(-50%);
}
/* â”€â”€ Overlays â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__overlay {
position: absolute;
inset: 0;
z-index: 50;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 1rem;
padding: 2rem;
text-align: center;
animation: badgeOverlayIn 0.25s ease;
}
@keyframes badgeOverlayIn {
from { opacity: 0; transform: scale(0.96); }
to   { opacity: 1; transform: scale(1); }
}
.badge-station__overlay--success  { background: rgba(16,185,129,0.92); }
.badge-station__overlay--confirm  { background: rgba(25,69,168,0.92); }
.badge-station__overlay--printed  { background: rgba(217,119,6,0.92); }
.badge-station__overlay--receipt  { background: rgba(30,64,175,0.95); }
.badge-station__overlay--error    { background: rgba(220,38,38,0.92); }
.badge-station__overlay--warning  { background: rgba(180,120,0,0.92); }
/* Flash verde rápido — impresión enviada sin adicionales pendientes */
.badge-station__overlay--print-sent {
background: rgba(16,185,129,0.90);
animation: badgePrintSentFlash 1.5s ease forwards;
pointer-events: none;
}
@keyframes badgePrintSentFlash {
0%   { opacity: 0; transform: scale(0.94); }
15%  { opacity: 1; transform: scale(1); }
70%  { opacity: 1; }
100% { opacity: 0; transform: scale(1.02); }
}
.badge-station__overlay-check {
font-size: 5rem;
font-weight: 900;
color: #fff;
line-height: 1;
filter: drop-shadow(0 2px 8px rgba(0,0,0,0.25));
}
.badge-station__overlay-sent-label {
font-size: 1.5rem;
font-weight: 700;
color: #fff;
letter-spacing: 0.04em;
text-transform: uppercase;
}
.badge-station__overlay-icon {
font-size: 4rem;
font-weight: 900;
color: rgba(255,255,255,0.9);
line-height: 1;
}
.badge-station__overlay-icon--warn  { color: #fef3c7; }
.badge-station__overlay-icon--error { color: #fee2e2; }
.badge-station__overlay-category {
color: rgba(255,255,255,0.8);
font-size: 1rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.8px;
margin: 0;
}
.badge-station__overlay-name {
font-size: clamp(2rem, 5vw, 4rem);
font-weight: 900;
color: #ffffff;
margin: 0;
text-shadow: 0 2px 8px rgba(0,0,0,0.3);
line-height: 1.1;
}
/* Nombre completo en overlay de confirmaciÃ³n â€” mÃ¡s grande para validar duplicados */
.badge-station__overlay-name--full {
font-size: clamp(2.8rem, 6.5vw, 5.5rem);
text-shadow: 0 0 40px rgba(255,255,255,0.2), 0 2px 12px rgba(0,0,0,0.4);
letter-spacing: -0.5px;
}
.badge-station__overlay-sub {
font-size: 1.1rem;
color: rgba(255,255,255,0.9);
margin: 0;
max-width: 560px;
}
.badge-station__overlay-sub--hint {
font-size: 0.875rem;
color: rgba(255,255,255,0.7);
}
.badge-station__overlay-countdown {
font-size: 0.875rem;
color: rgba(255,255,255,0.6);
margin: 0;
}
/* Foto facial en overlay de match */
.badge-station__face-photo {
width: 100px;
height: 100px;
border-radius: 50%;
object-fit: cover;
border: 3px solid rgba(255,255,255,0.8);
box-shadow: 0 4px 16px rgba(0,0,0,0.3);
}
/* Carita triste â€” ya impreso y sin adicionales */
.badge-station__sad-face {
animation: badgeSadBounce 0.6s ease;
}
@keyframes badgeSadBounce {
0%   { opacity: 0; transform: scale(0.5); }
60%  { transform: scale(1.1); }
100% { opacity: 1; transform: scale(1); }
}
/* Adicionales */
.badge-station__overlay-aditionals {
background: rgba(0,0,0,0.2);
border-radius: 12px;
padding: 1rem 1.5rem;
display: flex;
flex-direction: column;
gap: 0.75rem;
max-width: 560px;
width: 100%;
text-align: left;
}
.badge-station__overlay-aditionals-title {
font-size: 0.85rem;
color: rgba(255,255,255,0.8);
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.5px;
margin: 0 0 0.25rem;
}
.badge-station__aditional-row {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;
flex-wrap: wrap;
}
.badge-station__aditional-info {
display: flex;
flex-direction: column;
gap: 0.15rem;
}
.badge-station__aditional-category {
font-size: 0.78rem;
color: rgba(255,255,255,0.7);
text-transform: uppercase;
}
.badge-station__aditional-name {
font-size: 1rem;
font-weight: 700;
color: #fff;
}
.badge-station__aditional-no-name {
font-size: 0.85rem;
color: #fbbf24;
font-style: italic;
}
/* Opciones de reimpresiÃ³n */
.badge-station__reprint-options {
display: flex;
flex-wrap: wrap;
gap: 0.75rem;
justify-content: center;
margin-top: 0.5rem;
}
/* Recibo QR */
.badge-station__receipt-number {
font-size: 5rem;
font-weight: 900;
color: #fff;
font-family: monospace;
line-height: 1;
margin: 0;
}
.badge-station__qr-wrap {
padding: 0.75rem;
background: #fff;
border-radius: 12px;
display: inline-flex;
}
.badge-station__receipt-total {
font-size: 1.5rem;
font-weight: 800;
color: rgba(255,255,255,0.9);
margin: 0;
}
/* â”€â”€ Footer discreto â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__footer {
position: relative;
z-index: 2;
display: flex;
align-items: center;
justify-content: space-between;
padding: 0.5rem 1.25rem;
background: rgba(0,0,0,0.25);
backdrop-filter: blur(12px);
border-top: 1px solid rgba(255,255,255,0.08);
gap: 1rem;
flex-shrink: 0;
}
.badge-station__footer-left {
display: flex;
align-items: center;
gap: 0.5rem;
min-width: 0;
}
.badge-station__footer-logo {
height: 24px;
width: auto;
object-fit: contain;
opacity: 0.7;
flex-shrink: 0;
}
.badge-station__footer-event {
font-size: 0.75rem;
color: rgba(255,255,255,0.6);
font-weight: 600;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.badge-station__footer-right {
display: flex;
align-items: center;
gap: 0.75rem;
flex-shrink: 0;
}
.badge-station__footer-stat {
font-size: 0.7rem;
color: rgba(255,255,255,0.5);
font-weight: 500;
}
.badge-station__footer-stat--ok {
color: var(--success-light);
}
.badge-station__footer-stat--warn {
color: var(--warning-light);
}
.badge-station__footer-btn {
background: rgba(255,255,255,0.1);
border: 1px solid rgba(255,255,255,0.15);
border-radius: 8px;
color: rgba(255,255,255,0.7);
font-size: 0.7rem;
font-weight: 600;
padding: 0.3rem 0.6rem;
cursor: pointer;
transition: background 0.2s;
}
.badge-station__footer-btn:hover {
background: rgba(255,255,255,0.2);
}
.badge-station__footer-btn--danger {
border-color: rgba(239,68,68,0.4);
color: rgba(252,165,165,0.9);
}
.badge-station__footer-btn--danger:hover {
background: rgba(239,68,68,0.15);
border-color: rgba(239,68,68,0.6);
}
/* â”€â”€ Modales â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__modal-backdrop {
position: fixed;
inset: 0;
z-index: 10000;
background: rgba(0,0,0,0.6);
display: flex;
align-items: center;
justify-content: center;
padding: 1rem;
}
.badge-station__modal {
background: var(--surface-color, #ffffff);
border-radius: 16px;
padding: 1.75rem;
width: 100%;
max-width: 480px;
display: flex;
flex-direction: column;
gap: 1rem;
box-shadow: var(--shadow-xl, 0 20px 60px rgba(0,0,0,0.4));
}
.badge-station__modal-title {
font-size: 1.1rem;
font-weight: 800;
color: var(--text-color, #0f172a);
margin: 0;
}
.badge-station__modal-body {
font-size: 0.9rem;
color: var(--text-color, #0f172a);
margin: 0;
}
.badge-station__modal-error {
padding: 0.75rem 1rem;
background: var(--danger-background, #fee2e2);
border-left: 3px solid var(--danger-color, #ef4444);
border-radius: 6px;
color: var(--danger-color, #ef4444);
font-size: 0.875rem;
}
.badge-station__modal-form {
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.badge-station__modal-actions {
display: flex;
gap: 0.75rem;
flex-wrap: wrap;
}
.badge-station__char-counter {
font-size: 0.75rem;
color: var(--text-muted, #64748b);
text-align: right;
margin-top: -0.25rem;
}
.badge-station__char-counter--over {
color: var(--danger-color, #ef4444);
font-weight: 700;
}
/* â”€â”€ Responsive â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 768px) {
.badge-station__camera {
display: none;
}
.badge-station__content {
flex-direction: column;
}
.badge-station__title {
font-size: 1.6rem;
}
.badge-station__input {
font-size: 1.1rem;
padding: 0.75rem 1rem;
}
.badge-station__input--qr {
font-size: 1.3rem;
}
.badge-station__overlay-name {
font-size: 2rem;
}
.badge-station__receipt-number {
font-size: 3.5rem;
}
}
@media (min-width: 769px) and (max-width: 1024px) {
.badge-station__camera {
width: 35%;
min-width: 250px;
}
}
@media (min-width: 1025px) {
.badge-station__camera {
width: 40%;
}
}
/* =====================================================================
BIOMETRIC SCAN ANIMATION â€” badge-station__bio
Full-screen overlay con mesh facial SVG, scan line y HUD
===================================================================== */
.badge-station__bio {
position: fixed;
inset: 0;
z-index: 9999;
background: rgba(0, 0, 0, 0.92);
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 2rem;
animation: bioFadeIn 0.3s ease;
}
@keyframes bioFadeIn {
from { opacity: 0; }
to   { opacity: 1; }
}
/* â”€â”€ Frame central con foto â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__bio-frame {
position: relative;
width: clamp(200px, 35vmin, 300px);
height: clamp(200px, 35vmin, 300px);
border-radius: 16px;
overflow: visible;
}
.badge-station__bio-photo {
position: absolute;
inset: 8%;
width: 84%;
height: 84%;
object-fit: cover;
border-radius: 12px;
opacity: 0.6;
filter: grayscale(0.4) brightness(0.8);
z-index: 0;
}
.badge-station__bio-silhouette {
position: absolute;
inset: 8%;
width: 84%;
height: 84%;
display: flex;
align-items: center;
justify-content: center;
color: rgba(255,255,255,0.15);
z-index: 0;
}
/* â”€â”€ Scan line â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__bio-scanline {
position: absolute;
left: 5%;
right: 5%;
height: 2px;
background: linear-gradient(90deg, transparent 0%, #10b981 30%, #34d399 50%, #10b981 70%, transparent 100%);
box-shadow: 0 0 12px #10b981, 0 0 24px rgba(16,185,129,0.4);
z-index: 3;
animation: bioScanSweep 1.6s ease-in-out forwards;
}
@keyframes bioScanSweep {
0%   { top: 5%; opacity: 0.5; }
10%  { opacity: 1; }
90%  { opacity: 1; }
100% { top: 95%; opacity: 0.3; }
}
/* â”€â”€ SVG Mesh facial â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__bio-mesh {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
z-index: 2;
pointer-events: none;
}
.badge-station__bio-wire {
stroke: #10b981;
stroke-width: 0.4;
opacity: 0;
animation: bioWireAppear 0.2s ease forwards;
animation-delay: calc(0.25s + var(--d, 0) * 0.05s);
}
@keyframes bioWireAppear {
from { opacity: 0; }
to   { opacity: 0.5; }
}
.badge-station__bio-point {
fill: #10b981;
filter: drop-shadow(0 0 3px #10b981);
opacity: 0;
transform-origin: center;
animation: bioPointPop 0.25s ease forwards;
animation-delay: calc(0.15s + var(--d, 0) * 0.065s);
}
@keyframes bioPointPop {
0%   { opacity: 0; transform: scale(0); }
60%  { opacity: 1; transform: scale(1.6); }
100% { opacity: 1; transform: scale(1); }
}
/* â”€â”€ Esquinas tipo HUD â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__bio-corner {
position: absolute;
width: 28px;
height: 28px;
z-index: 4;
}
.badge-station__bio-corner::before,
.badge-station__bio-corner::after {
content: '';
position: absolute;
background: #10b981;
box-shadow: 0 0 8px #10b981;
animation: bioCornerGlow 1.6s ease-in-out infinite alternate;
}
@keyframes bioCornerGlow {
from { opacity: 0.6; }
to   { opacity: 1; }
}
.badge-station__bio-corner::before { width: 100%; height: 2px; }
.badge-station__bio-corner::after  { width: 2px; height: 100%; }
.badge-station__bio-corner--tl { top: -4px; left: -4px; }
.badge-station__bio-corner--tl::before { top: 0; left: 0; }
.badge-station__bio-corner--tl::after  { top: 0; left: 0; }
.badge-station__bio-corner--tr { top: -4px; right: -4px; }
.badge-station__bio-corner--tr::before { top: 0; right: 0; }
.badge-station__bio-corner--tr::after  { top: 0; right: 0; }
.badge-station__bio-corner--bl { bottom: -4px; left: -4px; }
.badge-station__bio-corner--bl::before { bottom: 0; left: 0; }
.badge-station__bio-corner--bl::after  { bottom: 0; left: 0; }
.badge-station__bio-corner--br { bottom: -4px; right: -4px; }
.badge-station__bio-corner--br::before { bottom: 0; right: 0; }
.badge-station__bio-corner--br::after  { bottom: 0; right: 0; }
/* â”€â”€ HUD info debajo del frame â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge-station__bio-hud {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.5rem;
animation: bioHudSlide 0.5s ease 0.3s both;
}
@keyframes bioHudSlide {
from { opacity: 0; transform: translateY(16px); }
to   { opacity: 1; transform: translateY(0); }
}
.badge-station__bio-label {
font-size: 0.65rem;
font-weight: 700;
letter-spacing: 3px;
text-transform: uppercase;
color: var(--success-color);
font-family: 'Consolas', 'Courier New', monospace;
}
.badge-station__bio-welcome {
font-size: clamp(1.2rem, 3vw, 1.8rem);
font-weight: 600;
color: var(--success-light);
text-transform: uppercase;
letter-spacing: 2px;
opacity: 0;
animation: bioWelcomeAppear 0.5s ease 0.5s forwards;
}
@keyframes bioWelcomeAppear {
from { opacity: 0; transform: translateY(8px); }
to   { opacity: 1; transform: translateY(0); }
}
.badge-station__bio-name {
font-size: clamp(2rem, 6vw, 4rem);
font-weight: 900;
color: #ffffff;
text-shadow: 0 0 30px rgba(16,185,129,0.4), 0 2px 12px rgba(0,0,0,0.3);
text-align: center;
line-height: 1.1;
}
.badge-station__bio-progress {
width: clamp(160px, 30vmin, 260px);
height: 3px;
background: rgba(255,255,255,0.1);
border-radius: 2px;
overflow: hidden;
}
.badge-station__bio-progress-bar {
height: 100%;
background: linear-gradient(90deg, var(--success-color), var(--success-light));
box-shadow: 0 0 8px var(--success-color);
border-radius: 2px;
animation: bioProgressFill 1.6s ease forwards;
}
@keyframes bioProgressFill {
from { width: 0; }
to   { width: 100%; }
}
.badge-station__bio-status {
font-size: 0.8rem;
font-weight: 600;
color: var(--success-light);
font-family: 'Consolas', 'Courier New', monospace;
opacity: 0;
animation: bioStatusAppear 0.3s ease 1.4s forwards;
}
@keyframes bioStatusAppear {
from { opacity: 0; }
to   { opacity: 1; }
}
/* â”€â”€ Responsive bio â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 480px) {
.badge-station__bio-frame {
width: 180px;
height: 180px;
}
}
@media (prefers-reduced-motion: reduce) {
.badge-station__bio-scanline,
.badge-station__bio-wire,
.badge-station__bio-point,
.badge-station__bio-progress-bar {
animation-duration: 0.01s;
}
}
/* 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: var(--radius-sm);
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: var(--radius-sm);
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: var(--radius-sm);
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: var(--radius-sm);
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: var(--radius-sm);
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: var(--radius-sm);
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: var(--radius-sm);
}
.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%;
}
}
/* =======================================================================
CSD Admin Page — csdPage.css
BEM namespace: csdPage
Patrón admin estándar: igual que paymentListPage.
Variables del design system (colors.css). Sin hardcoded, sin dark media.
======================================================================= */
/* ── CONTENEDOR PÁGINA ───────────────────────────────────────────────── */
.csdPage {
width: 100%;
height: 100%;
padding: var(--spacing-md);
}
/* ── LOADING / ERROR / EMPTY ─────────────────────────────────────────── */
.csdPage__loading {
display: flex;
align-items: center;
justify-content: center;
padding: var(--spacing-xl);
color: var(--text-muted);
}
.csdPage__error {
padding: var(--spacing-md);
background: var(--danger-background);
border: 1px solid var(--danger-color);
border-radius: var(--border-radius);
color: var(--danger-foreground);
font-size: 0.875rem;
margin-bottom: var(--spacing-md);
}
.csdPage__empty {
padding: var(--spacing-xl);
text-align: center;
background: var(--surface-color);
border-radius: var(--border-radius);
color: var(--text-muted);
font-style: italic;
}
/* ── FILTROS ─────────────────────────────────────────────────────────── */
.csdPage__filter-group {
margin-bottom: var(--spacing-md);
}
/* ── TABLA ───────────────────────────────────────────────────────────── */
.csdPage__table-wrap {
background: var(--surface-color);
border-radius: var(--border-radius);
overflow: hidden;
box-shadow: var(--shadow-sm);
}
.csdPage__th--sortable {
cursor: pointer;
user-select: none;
}
.csdPage__th--sortable:hover {
background: var(--hover-background-color);
}
.csdPage__th--actions {
text-align: right;
}
/* Celdas */
.csdPage__cell-company {
display: flex;
flex-direction: column;
gap: 0.125rem;
}
.csdPage__company-name {
font-weight: 600;
color: var(--text-color);
}
.csdPage__company-zip {
font-size: 0.75rem;
color: var(--text-muted);
}
.csdPage__cell-rfc {
font-family: 'Courier New', monospace;
font-size: 0.875rem;
color: var(--text-secondary);
letter-spacing: 0.03em;
}
.csdPage__cell-expiration {
font-size: 0.875rem;
color: var(--text-secondary);
}
.csdPage__cell-status {
text-align: center;
}
.csdPage__cell-actions {
display: flex;
gap: 0.375rem;
align-items: center;
justify-content: flex-end;
}
/* ── BADGES DE ESTADO ────────────────────────────────────────────────── */
.csdPage__status {
display: inline-flex;
align-items: center;
padding: 0.2rem 0.625rem;
border-radius: var(--radius-pill);
font-size: 0.8125rem;
font-weight: 600;
}
.csdPage__status--active {
background: var(--success-background);
color: var(--success-foreground);
}
.csdPage__status--inactive {
background: var(--danger-background);
color: var(--danger-foreground);
}
/* ── FORMULARIO MODAL ────────────────────────────────────────────────── */
.csdPage__form-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 1rem 1.5rem;
}
.csdPage__form-error {
color: var(--danger-color);
font-size: 0.8125rem;
margin-top: 0.25rem;
}
.csdPage__form-actions {
display: flex;
gap: 0.75rem;
margin-top: 1.5rem;
justify-content: flex-end;
padding-top: 1rem;
border-top: 1px solid var(--border-color);
}
/* ── ARCHIVOS .cer / .key ────────────────────────────────────────────── */
.csdPage__files-section {
display: grid;
grid-template-columns: 1fr 1fr 1fr;
gap: 1rem;
margin-top: 1.25rem;
padding-top: 1.25rem;
border-top: 1px solid var(--border-color);
}
.csdPage__file-input {
display: flex;
flex-direction: column;
gap: 0.375rem;
}
.csdPage__file-input label {
font-size: 0.875rem;
font-weight: 500;
color: var(--text-secondary);
}
.csdPage__file-input input[type="file"] {
padding: 0.375rem 0.5rem;
border: 1.5px dashed var(--border-color);
border-radius: var(--radius-md);
background: var(--surface-alt-color);
color: var(--text-color);
font-size: 0.875rem;
cursor: pointer;
transition: border-color var(--transition-fast);
}
.csdPage__file-input input[type="file"]:hover {
border-color: var(--primary-color);
}
.csdPage__file-name {
display: inline-flex;
align-items: center;
padding: 0.25rem 0.625rem;
background: var(--hover-background-color);
border-radius: var(--radius-sm);
font-size: 0.8125rem;
color: var(--primary-color);
font-family: 'Courier New', monospace;
word-break: break-all;
}
/* ── ESTADO DE VALIDACIÓN ────────────────────────────────────────────── */
.csdPage__validate-ok {
display: flex;
align-items: center;
gap: 0.5rem;
background: var(--success-background);
color: var(--success-foreground);
border-left: 3px solid var(--success-color);
border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
padding: 0.625rem 0.875rem;
font-size: 0.875rem;
font-weight: 500;
margin-top: 0.75rem;
}
/* ── NOTA EDICIÓN ────────────────────────────────────────────────────── */
.csdPage__edit-hint {
font-size: 0.875rem;
color: var(--text-muted);
font-style: italic;
margin-bottom: 1.25rem;
padding: 0.5rem 0.75rem;
background: var(--surface-alt-color);
border-radius: var(--radius-sm);
border-left: 3px solid var(--border-color);
}
/* ── ACCIONES CONFIRMACIONES ─────────────────────────────────────────── */
.csdPage__modal-actions {
display: flex;
gap: 0.75rem;
margin-top: 1.25rem;
justify-content: flex-end;
padding-top: 0.875rem;
border-top: 1px solid var(--border-color);
}
/* ── RESPONSIVE ──────────────────────────────────────────────────────── */
@media (max-width: 900px) {
.csdPage__form-grid {
grid-template-columns: 1fr;
}
.csdPage__files-section {
grid-template-columns: 1fr;
}
}
@media (max-width: 767px) {
.csdPage {
padding: var(--spacing-sm);
}
.csdPage__title {
font-size: 1.5rem;
}
.csdPage__cell-actions {
justify-content: flex-start;
flex-wrap: wrap;
}
}
/* ============================================
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;
}
/* 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: var(--radius-pill);
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: var(--radius-pill);
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: var(--radius-pill);
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: var(--radius-pill);
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 Inscription Codes Page  —  namespace: bdc
Estructura visual idéntica al Register (register-content-card pattern)
============================================================ */
/* ── Wrapper general de la página ── */
.bdc {
width: 100%;
max-width: 680px;
margin: 2rem auto;
padding: 0 var(--spacing-md);
box-sizing: border-box;
display: flex;
flex-direction: column;
gap: 1.5rem;
}
/* ── Loading ── */
.bdc__loading {
display: flex;
justify-content: center;
padding: 3rem 0;
}
/* ── Error de página ── */
.bdc__page-error {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.75rem;
padding: 2rem;
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: 12px;
text-align: center;
}
.bdc__page-error-icon { font-size: 2rem; }
/* ── Header ── */
.bdc__header {
text-align: center;
display: flex;
flex-direction: column;
align-items: center;
gap: 0.5rem;
padding: 0 0 0.5rem;
}
.bdc__header-badge {
display: inline-block;
padding: 3px 14px;
border-radius: 999px;
background: var(--primary-background);
color: var(--primary-foreground);
font-size: 0.72rem;
font-weight: 700;
letter-spacing: 0.06em;
text-transform: uppercase;
}
.bdc__title {
font-size: 1.85rem;
font-weight: 800;
color: var(--text-color);
margin: 0;
letter-spacing: -0.02em;
}
.bdc__subtitle {
font-size: 0.9rem;
color: var(--text-secondary);
max-width: 500px;
line-height: 1.6;
margin: 0;
}
/* ── Error inline de formulario ── */
.bdc__form-error {
display: flex;
align-items: center;
gap: 0.6rem;
padding: 0.6rem 1rem;
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: 8px;
font-size: 0.875rem;
}
.bdc__form-error-icon { font-weight: 700; flex-shrink: 0; }
/* ══════════════════════════════════════════════
BODY — envuelve el contenido de cada paso
Patrón idéntico a register-content-card
══════════════════════════════════════════════ */
.bdc__body {
width: 100%;
background: var(--card-bg-color);
border-radius: 16px;
box-shadow: var(--shadow-md);
border: 1px solid var(--border-color);
padding: 1.75rem;
box-sizing: border-box;
display: flex;
flex-direction: column;
gap: 1.5rem;
}
/* ── How it works ── */
.bdc__howto {
background: var(--surface-alt-color);
border: 1px solid var(--border-color);
border-left: 4px solid var(--primary-color);
border-radius: 10px;
padding: 0.9rem 1.1rem;
}
.bdc__howto-title {
font-size: 0.78rem;
font-weight: 700;
color: var(--text-color);
text-transform: uppercase;
letter-spacing: 0.07em;
margin: 0 0 0.6rem;
}
.bdc__howto-steps {
list-style: none;
margin: 0;
padding: 0;
display: flex;
flex-direction: column;
gap: 0.4rem;
}
.bdc__howto-step {
display: flex;
align-items: baseline;
gap: 0.6rem;
font-size: 0.875rem;
color: var(--text-secondary);
line-height: 1.5;
}
.bdc__howto-num {
display: inline-flex;
align-items: center;
justify-content: center;
width: 18px;
height: 18px;
min-width: 18px;
border-radius: 50%;
background: var(--primary-color);
color: var(--primary-foreground);
font-size: 0.68rem;
font-weight: 700;
}
/* ── Secciones internas (bloque con título) ── */
.bdc__section {
display: flex;
flex-direction: column;
gap: 0;
border: 1px solid var(--border-color);
border-radius: 12px;
overflow: visible;
background: var(--surface-color);
}
.bdc__section-header {
display: flex;
align-items: center;
gap: 0.6rem;
padding: 0.75rem 1rem;
background: var(--surface-alt-color);
border-bottom: 1px solid var(--border-color);
border-radius: 12px 12px 0 0;
}
.bdc__section-num {
display: inline-flex;
align-items: center;
justify-content: center;
width: 26px;
height: 26px;
min-width: 26px;
border-radius: 50%;
background: var(--primary-color);
color: var(--primary-foreground);
font-size: 0.82rem;
font-weight: 700;
}
.bdc__section-title {
font-size: 0.95rem;
font-weight: 700;
color: var(--text-color);
margin: 0;
}
.bdc__section-description {
font-size: 0.855rem;
color: var(--text-secondary);
margin: 0;
padding: 0.6rem 1rem 0;
line-height: 1.5;
}
.bdc__section-content {
padding: 1rem 1rem 1.2rem;
display: flex;
flex-direction: column;
gap: 0.9rem;
}
/* ── Cantidad ── */
.bdc__quantity-row { max-width: 190px; }
.bdc__hint {
font-size: 0.8rem;
color: var(--text-muted);
line-height: 1.5;
margin: 0;
}
/* ── Rule cards (filas de descuento) ── */
.bdc__rule-card {
display: flex;
align-items: flex-start;
gap: 0.75rem;
padding: 0.85rem 0.9rem;
background: var(--surface-alt-color);
border: 1px solid var(--border-color);
border-radius: 10px;
transition: border-color 0.15s ease;
}
.bdc__rule-card:focus-within {
border-color: var(--primary-color);
position: relative;
z-index: 20;
}
.bdc__rule-card-num {
display: inline-flex;
align-items: center;
justify-content: center;
width: 22px;
height: 22px;
min-width: 22px;
border-radius: 50%;
background: var(--border-color);
color: var(--text-secondary);
font-size: 0.68rem;
font-weight: 700;
margin-top: 8px;
}
.bdc__rule-fields {
display: grid;
grid-template-columns: 2fr 1.2fr 1.2fr auto;
gap: 0.75rem;
flex: 1;
align-items: start;
}
.bdc__rule-field {
display: flex;
flex-direction: column;
gap: 3px;
}
.bdc__rule-value-hint {
font-size: 0.72rem;
color: var(--text-muted);
line-height: 1.4;
}
.bdc__rule-cost-label {
font-size: 0.7rem;
font-weight: 600;
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: 0.05em;
margin-top: 4px;
}
.bdc__rule-cost-value {
font-size: 1.25rem;
font-weight: 800;
color: var(--primary-color);
line-height: 1.1;
}
.bdc__rule-cost-base {
font-size: 0.7rem;
color: var(--text-muted);
}
.bdc__rule-remove {
background: none;
border: none;
cursor: pointer;
color: var(--danger-foreground);
font-size: 0.85rem;
width: 26px;
height: 26px;
display: flex;
align-items: center;
justify-content: center;
border-radius: 6px;
padding: 0;
margin-top: 6px;
flex-shrink: 0;
transition: background 0.12s;
}
.bdc__rule-remove:hover { background: var(--danger-background); }
.bdc__btn-add {
align-self: flex-start;
font-size: 0.875rem;
}
/* ── Summary card ── */
.bdc__summary {
background: var(--surface-alt-color);
border: 1px solid var(--border-color);
border-radius: 12px;
overflow: hidden;
}
.bdc__summary-title {
font-size: 0.78rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.07em;
color: var(--text-secondary);
margin: 0;
padding: 0.6rem 1rem;
background: var(--surface-color);
border-bottom: 1px solid var(--border-color);
}
.bdc__summary-body {
padding: 0.75rem 1rem;
display: flex;
flex-direction: column;
gap: 4px;
}
.bdc__summary-row {
display: flex;
justify-content: space-between;
align-items: center;
font-size: 0.875rem;
padding: 3px 0;
}
.bdc__summary-label { color: var(--text-secondary); }
.bdc__summary-value { font-weight: 600; color: var(--text-color); }
.bdc__summary-row--total {
border-top: 2px solid var(--primary-color);
margin-top: 0.5rem;
padding-top: 0.5rem;
}
.bdc__summary-row--total .bdc__summary-label {
font-size: 0.95rem;
font-weight: 700;
color: var(--text-color);
}
.bdc__summary-total {
font-size: 1.65rem;
font-weight: 800;
color: var(--primary-color);
letter-spacing: -0.02em;
}
/* ── Fiscal step ── */
.bdc__no-invoice {
display: flex;
align-items: center;
justify-content: space-between;
gap: 0.75rem;
padding: 0.8rem 1rem;
background: var(--surface-alt-color);
border: 1px solid var(--border-color);
border-radius: 10px;
flex-wrap: wrap;
}
.bdc__no-invoice-text {
font-size: 0.875rem;
color: var(--text-secondary);
margin: 0;
}
.bdc__no-invoice-confirmed {
display: flex;
align-items: flex-start;
gap: 0.6rem;
padding: 0.8rem 1rem;
background: var(--warning-background, var(--surface-alt-color));
color: var(--warning-foreground, var(--text-color));
border: 1px solid var(--warning-color, var(--border-color));
border-radius: 10px;
}
.bdc__no-invoice-confirmed-icon {
font-size: 1.2rem;
flex-shrink: 0;
margin-top: 1px;
}
.bdc__no-invoice-confirmed-body {
display: flex;
flex-direction: column;
gap: 3px;
font-size: 0.875rem;
}
.bdc__no-invoice-confirmed-body strong { color: var(--text-color); }
.bdc__no-invoice-confirmed-body p {
margin: 0;
color: var(--text-secondary);
line-height: 1.5;
}
.bdc__fiscal-selected {
display: flex;
align-items: center;
gap: 0.5rem;
padding: 0.5rem 0.9rem;
background: var(--success-background);
color: var(--success-foreground);
border-radius: 8px;
font-size: 0.875rem;
flex-wrap: wrap;
}
.bdc__fiscal-selected-label { font-weight: 600; }
.bdc__fiscal-selected-id { font-weight: 700; font-family: monospace; }
.bdc__fiscal-hint {
display: flex;
align-items: flex-start;
gap: 0.6rem;
padding: 0.6rem 0.9rem;
background: var(--surface-alt-color);
border-radius: 8px;
}
.bdc__fiscal-hint-icon {
width: 18px;
height: 18px;
min-width: 18px;
color: var(--primary-color);
margin-top: 1px;
}
.bdc__fiscal-hint-text {
font-size: 0.855rem;
color: var(--text-secondary);
margin: 0;
line-height: 1.5;
}
.bdc__fiscal-table { width: 100%; }
/* ── Pay step — recap ── */
.bdc__pay-recap {
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: 12px;
overflow: hidden;
}
.bdc__pay-recap-title {
font-size: 0.78rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.07em;
color: var(--text-secondary);
margin: 0;
padding: 0.6rem 1rem;
background: var(--surface-alt-color);
border-bottom: 1px solid var(--border-color);
}
.bdc__pay-recap-row {
display: flex;
justify-content: space-between;
align-items: center;
padding: 0.55rem 1rem;
font-size: 0.875rem;
border-bottom: 1px solid var(--border-color);
color: var(--text-secondary);
}
.bdc__pay-recap-row:last-child { border-bottom: none; }
.bdc__pay-recap-row--muted { color: var(--text-muted); font-style: italic; }
.bdc__pay-recap-row--total {
background: var(--surface-alt-color);
font-weight: 700;
color: var(--text-color);
padding: 0.85rem 1rem;
}
.bdc__pay-recap-total {
font-size: 1.65rem;
font-weight: 800;
color: var(--primary-color);
letter-spacing: -0.02em;
}
.bdc__pay-invoice-warning {
display: flex;
align-items: flex-start;
gap: 0.6rem;
padding: 0.65rem 0.9rem;
background: var(--warning-background, var(--surface-alt-color));
color: var(--warning-foreground, var(--text-secondary));
border: 1px solid var(--warning-color, var(--border-color));
border-radius: 10px;
font-size: 0.855rem;
line-height: 1.5;
}
.bdc__pay-invoice-warning svg { flex-shrink: 0; margin-top: 1px; }
.bdc__pay-invoice-warning p { margin: 0; }
/* ── Botón pagar ── */
.bdc__btn-pay {
display: inline-flex;
align-items: center;
gap: 0.5rem;
font-size: 1rem;
font-weight: 700;
padding: 0.75rem 2rem;
justify-content: center;
min-width: 200px;
}
/* ── Barra de acciones ── */
.bdc__actions {
display: flex;
justify-content: flex-end;
align-items: center;
gap: 0.75rem;
padding-top: 0.25rem;
}
.bdc__actions--pay { justify-content: space-between; }
/* ── Modal mismatch ── */
.bdc__mismatch-msg {
font-size: 0.875rem;
color: var(--text-secondary);
margin: 0 0 0.75rem;
line-height: 1.5;
}
.bdc__mismatch-amounts {
display: flex;
flex-direction: column;
gap: 4px;
background: var(--surface-alt-color);
border-radius: 8px;
padding: 0.75rem;
}
.bdc__mismatch-row {
display: flex;
justify-content: space-between;
font-size: 0.875rem;
color: var(--text-secondary);
}
.bdc__mismatch-row--server {
border-top: 1px solid var(--border-color);
padding-top: 6px;
margin-top: 4px;
color: var(--text-color);
font-weight: 600;
}
.bdc__mismatch-old { text-decoration: line-through; color: var(--text-muted); }
.bdc__mismatch-new { color: var(--primary-color); font-weight: 700; }
/* ── Modal no invoice ── */
.bdc__no-invoice-modal-msg {
font-size: 0.875rem;
color: var(--text-secondary);
line-height: 1.6;
margin: 0;
}
/* ── Responsive ── */
@media (max-width: 720px) {
.bdc__rule-fields { grid-template-columns: 1fr 1fr; }
.bdc__rule-field--cost {
grid-column: span 2;
flex-direction: row;
align-items: center;
gap: 0.5rem;
}
.bdc__rule-cost-label { margin-top: 0; }
.bdc__no-invoice { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 480px) {
.bdc {
padding: 1rem 0.5rem;
gap: 1rem;
margin: 1rem auto;
}
.bdc__body { padding: 1rem; gap: 1rem; }
.bdc__title { font-size: 1.45rem; }
.bdc__rule-card { flex-direction: column; }
.bdc__rule-card-num { display: none; }
.bdc__rule-fields { grid-template-columns: 1fr; width: 100%; }
.bdc__rule-field--cost {
grid-column: span 1;
flex-direction: row;
align-items: center;
gap: 0.5rem;
}
.bdc__rule-remove { align-self: flex-end; margin-top: 0; }
.bdc__quantity-row { max-width: 100%; }
.bdc__actions { flex-direction: column-reverse; align-items: stretch; }
.bdc__actions--pay { flex-direction: column; align-items: stretch; }
.bdc__btn-pay { min-width: unset; width: 100%; }
.bdc__summary-total,
.bdc__pay-recap-total { font-size: 1.35rem; }
}
/* ============================================
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;
}
}
/* EventLivePage — BEM namespace: event-live-page */
.content-area:has(.event-live-page) {
padding: 0;
overflow: hidden;
}
.main-layout:has(.event-live-page) .app-topbar {
padding-top: 0.375rem;
}
.main-layout:has(.event-live-page) .app-topbar__inner {
height: 52px;
}
.event-live-page {
--event-live-shell-gap: 0.625rem;
--event-live-shell-padding: 0.625rem;
width: 100%;
height: calc(100dvh - 58px);
padding: var(--event-live-shell-padding);
box-sizing: border-box;
overflow: hidden;
}
.event-live-page__layout {
display: grid;
grid-template-columns: minmax(0, 1fr) clamp(18rem, 25vw, 24rem);
gap: var(--event-live-shell-gap);
width: 100%;
height: 100%;
min-height: 0;
overflow: hidden;
}
.event-live-page__main,
.event-live-page__sidebar {
min-width: 0;
min-height: 0;
overflow: hidden;
}
.event-live-page__main {
display: grid;
grid-template-rows: minmax(0, 1fr);
gap: var(--event-live-shell-gap);
}
.event-live-page__sidebar {
display: flex;
flex-direction: column;
height: 100%;
}
.event-live-page__card {
min-width: 0;
min-height: 0;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: var(--radius-lg);
box-shadow: var(--shadow-sm);
overflow: hidden;
}
.event-live-page__card--player {
display: flex;
flex-direction: column;
border-radius: var(--radius-lg);
background: var(--surface-color);
border-color: var(--border-color);
box-shadow: var(--shadow-md);
}
.event-live-page__card--fill {
flex: 1;
display: flex;
flex-direction: column;
height: 100%;
}
.event-live-page__main > .event-live-page__card:not(.event-live-page__card--player) {
display: none;
}
.event-live-page__card--player .event-live-page__tabs {
display: flex;
flex-wrap: nowrap;
align-items: flex-end;
gap: 0;
min-height: 2.5rem;
padding: 0 0.75rem;
background: var(--surface-alt-color);
border-bottom: 2px solid var(--border-color);
overflow-x: auto;
scrollbar-width: none;
}
.event-live-page__card--player .event-live-page__tabs::-webkit-scrollbar {
display: none;
}
/* Reset absoluto de herencias button para los tabs — mayor especificidad con :where() para anular app-button */
.event-live-page__card--player .event-live-page__tab {
all: unset !important;
box-sizing: border-box !important;
position: relative !important;
flex-shrink: 0 !important;
display: inline-flex !important;
align-items: center !important;
justify-content: center !important;
min-height: 2.25rem !important;
padding: 0 1.125rem !important;
border: 1px solid transparent !important;
border-bottom: none !important;
border-radius: 0.4rem 0.4rem 0 0 !important;
background: transparent !important;
color: var(--text-secondary) !important;
font-family: inherit !important;
font-size: 0.75rem !important;
font-weight: 600 !important;
letter-spacing: 0.02em !important;
line-height: 1 !important;
white-space: nowrap !important;
cursor: pointer !important;
transition: color var(--transition-fast), background-color var(--transition-fast), border-color var(--transition-fast) !important;
margin-bottom: -2px !important;
outline: none !important;
user-select: none !important;
min-width: unset !important;
width: auto !important;
height: auto !important;
text-align: center !important;
overflow: visible !important;
isolation: auto !important;
box-shadow: none !important;
}
.event-live-page__card--player .event-live-page__tab:hover {
color: var(--primary-color) !important;
background: color-mix(in srgb, var(--primary-color) 8%, var(--surface-alt-color)) !important;
transform: none !important;
box-shadow: none !important;
}
.event-live-page__card--player .event-live-page__tab--active {
color: var(--primary-color) !important;
background: var(--surface-color) !important;
border-color: var(--border-color) !important;
border-bottom-color: var(--surface-color) !important;
font-weight: 700 !important;
}
.event-live-page__card--player .event-live-page__tab--active::after {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
height: 2px;
background: var(--primary-color);
border-radius: 0.4rem 0.4rem 0 0;
}
.event-live-page__card--player .app-event-live {
flex: 1;
min-height: 0;
border-radius: 0;
box-shadow: none;
}
.event-live-page__card--player .app-event-live::before {
height: 1px;
}
.event-live-page__card--player .app-event-live__iframe,
.event-live-page__card--player .app-event-live__video {
width: 100%;
height: 100%;
min-height: 0;
aspect-ratio: auto;
border-radius: 0;
object-fit: contain;
}
.event-live-page__stream-info {
display: flex;
align-items: center;
gap: 0.625rem;
min-height: 2rem;
padding: 0.25rem 0.625rem;
background: var(--surface-color);
border-top: 1px solid var(--border-color);
overflow: hidden;
}
.event-live-page__stream-badge {
display: inline-flex;
align-items: center;
gap: 0.375rem;
max-width: 40%;
min-width: 0;
padding: 0.1875rem 0.625rem;
border-radius: var(--radius-pill);
background: color-mix(in srgb, var(--primary-color) 10%, var(--surface-alt-color));
color: var(--primary-color);
font-size: 0.6875rem;
font-weight: 800;
letter-spacing: 0.04em;
text-transform: uppercase;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.event-live-page__stream-dot {
width: 0.4375rem;
height: 0.4375rem;
flex-shrink: 0;
border-radius: 50%;
background: var(--success-color);
box-shadow: 0 0 0 3px color-mix(in srgb, var(--success-color) 18%, transparent);
animation: elp-dot-pulse 1.4s ease-in-out infinite;
}
.event-live-page__stream-time {
display: inline-flex;
align-items: center;
gap: 0.3125rem;
min-width: 0;
color: var(--text-secondary);
font-size: 0.75rem;
font-variant-numeric: tabular-nums;
white-space: nowrap;
}
.event-live-page__stream-time svg {
width: 0.8125rem;
height: 0.8125rem;
flex-shrink: 0;
color: var(--accent-color);
}
.event-live-page__sidebar .omnia-evtchat {
min-height: 0;
height: 100%;
border: none;
border-radius: var(--radius-lg);
background: var(--surface-color);
box-shadow: none;
}
.event-live-page__sidebar .omnia-evtchat__header {
min-height: 2.5rem;
padding: 0.5rem 0.75rem;
background: var(--surface-alt-color);
border-bottom: 1px solid var(--border-color);
}
.event-live-page__sidebar .omnia-evtchat__title {
font-size: 0.875rem;
}
.event-live-page__sidebar .omnia-evtchat__messages {
min-height: 0;
padding: 0.25rem 0;
}
.event-live-page__sidebar .omnia-evtchat__input-row {
padding: 0.5rem 0.625rem;
background: var(--surface-color);
}
.event-live-page__loader,
.event-live-page__denied-wrapper,
.event-live-page__empty {
display: flex;
justify-content: center;
align-items: center;
width: 100%;
height: 100%;
min-height: 0;
box-sizing: border-box;
}
/* ── Card de acceso denegado ────────────────────────────────────────────── */
.event-live-page__denied-card {
display: flex;
flex-direction: column;
align-items: center;
gap: 1.25rem;
width: 100%;
max-width: 28rem;
padding: 2.75rem 2.5rem 2.25rem;
box-sizing: border-box;
background: var(--surface-color);
border: 1px solid var(--border-color);
border-radius: var(--radius-xl, 1.25rem);
box-shadow: var(--shadow-lg);
text-align: center;
position: relative;
overflow: hidden;
}
.event-live-page__denied-card::before {
content: '';
position: absolute;
inset: 0;
background: radial-gradient(
ellipse 80% 50% at 50% -10%,
color-mix(in srgb, var(--primary-color) 8%, transparent),
transparent 70%
);
pointer-events: none;
}
.event-live-page__denied-face {
display: flex;
align-items: center;
justify-content: center;
width: 5rem;
height: 5rem;
border-radius: 50%;
background: color-mix(in srgb, var(--primary-color) 10%, var(--surface-alt-color));
border: 1.5px solid color-mix(in srgb, var(--primary-color) 20%, var(--border-color));
flex-shrink: 0;
}
/* Contrarresta reset.css: svg { display: block } */
.event-live-page__denied-face-svg {
display: inline-block !important;
width: 2.75rem !important;
height: 2.75rem !important;
max-width: none !important;
color: var(--primary-color);
opacity: .85;
flex-shrink: 0;
}
.event-live-page__denied-title {
margin: 0;
font-size: 1.125rem;
font-weight: 700;
color: var(--text-primary);
letter-spacing: -.015em;
line-height: 1.35;
}
.event-live-page__denied-body {
margin: 0;
font-size: .9rem;
line-height: 1.65;
color: var(--text-secondary);
max-width: 22rem;
}
.event-live-page__denied-actions {
display: flex;
justify-content: center;
margin-top: 0.5rem;
}
/* Proteger AppButton dentro del card de acceso denegado de resets globales */
.event-live-page__denied-actions .app-button {
all: revert !important;
display: inline-flex !important;
align-items: center !important;
justify-content: center !important;
gap: 0.5rem !important;
padding: 0.625rem 1.5rem !important;
border-radius: var(--radius-md, 0.5rem) !important;
font-family: inherit !important;
font-size: 0.9rem !important;
font-weight: 600 !important;
cursor: pointer !important;
border: none !important;
transition: opacity 0.18s, box-shadow 0.18s !important;
text-decoration: none !important;
white-space: nowrap !important;
box-sizing: border-box !important;
}
.event-live-page__denied-actions .app-button--primary {
background: var(--primary-color) !important;
color: var(--primary-foreground, #fff) !important;
box-shadow: 0 2px 8px color-mix(in srgb, var(--primary-color) 35%, transparent) !important;
}
.event-live-page__denied-actions .app-button--primary:hover:not(:disabled) {
opacity: 0.88 !important;
box-shadow: 0 4px 14px color-mix(in srgb, var(--primary-color) 45%, transparent) !important;
}
.event-live-page__denied-actions .app-button__text {
display: inline !important;
visibility: visible !important;
opacity: 1 !important;
font-size: inherit !important;
color: inherit !important;
}
.event-live-page__denied-actions .app-button__icon {
display: inline-flex !important;
align-items: center !important;
line-height: 1 !important;
}
.event-live-page__denied-actions .app-button__icon svg {
width: 1em !important;
height: 1em !important;
display: inline-block !important;
}
/* ── Placeholder: sin live activo ───────────────────────────────────────── */
.event-live-page__no-live {
flex: 1;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 1rem;
padding: 2.5rem 2rem;
text-align: center;
color: var(--text-secondary);
user-select: none;
}
.event-live-page__no-live-icon {
width: 4rem;
height: 4rem;
flex-shrink: 0;
opacity: .35;
color: var(--text-secondary);
}
.event-live-page__no-live-title {
margin: 0;
font-size: 1.0625rem;
font-weight: 700;
color: var(--text-primary);
letter-spacing: -.01em;
}
.event-live-page__no-live-body {
margin: 0;
max-width: 28rem;
font-size: .875rem;
line-height: 1.6;
color: var(--text-secondary);
}
@keyframes elp-dot-pulse {
0%, 100% { opacity: 1; transform: scale(1); }
50% { opacity: 0.45; transform: scale(0.75); }
}
@media (max-width: 1100px) {
.event-live-page__layout {
grid-template-columns: minmax(0, 1fr) 18rem;
}
}
@media (max-width: 820px) {
.content-area:has(.event-live-page) {
overflow: auto;
}
.event-live-page {
height: auto;
min-height: calc(100dvh - 58px);
overflow: visible;
}
.event-live-page__layout {
grid-template-columns: 1fr;
height: auto;
overflow: visible;
}
.event-live-page__main {
display: flex;
flex-direction: column;
}
.event-live-page__card--player .app-event-live__iframe,
.event-live-page__card--player .app-event-live__video {
aspect-ratio: 16 / 9;
height: auto;
}
.event-live-page__sidebar {
height: min(26rem, 58dvh);
}
}
@media (max-width: 520px) {
.event-live-page {
--event-live-shell-padding: 0.375rem;
--event-live-shell-gap: 0.5rem;
}
.main-layout:has(.event-live-page) .app-topbar__inner {
height: 48px;
}
.event-live-page__card--player .event-live-page__tab {
min-height: 2rem;
padding: 0 0.625rem;
font-size: 0.7rem;
}
.event-live-page__stream-info {
flex-wrap: wrap;
min-height: unset;
}
}
/* ============================================================
EventProgramPage â€” wrapper para AppEventProgram
Ruta: /programa/{ShortName}
============================================================ */
.evt-prog-page {
max-width: 900px;
margin: 0 auto;
padding: 1.25rem 1rem;
}
@media (max-width: 640px) {
.evt-prog-page { padding: 0.75rem 0.5rem; }
}
/* NexEvent - EventsListPage */
.events-list-page {
display: flex;
flex-direction: column;
min-height: 100vh;
background: transparent;
}
.events-list-page__content { flex: 1; padding: 1rem; }
.events-list-page__loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 1rem;
padding: 3rem;
color: var(--text-muted);
}
.events-list-page__empty {
padding: 3rem;
text-align: center;
color: var(--text-muted);
font-size: 1rem;
}
.events-list-page__error {
padding: 1rem 1.25rem;
margin: 1rem;
background: var(--danger-background);
color: var(--danger-foreground);
border: 1px solid var(--danger-color);
border-radius: var(--radius-md);
}
.events-list-page__table-wrapper {
overflow-x: auto;
background: var(--surface-color);
border-radius: var(--radius-lg);
box-shadow: var(--shadow-sm);
border: 1.5px solid var(--border-color);
position: relative;
}
.events-list-page__table-wrapper::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
background: var(--card-accent-gradient);
border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.events-list-page__th-center { text-align: center !important; }
.events-list-page__actions-cell { text-align: center !important; }
@media (max-width: 750px) {
.events-list-page__table-wrapper { background: transparent; border: none; box-shadow: none; }
.events-list-page__content { padding: 0.5rem; }
}
/* ============================================
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
============================================ */
/* ============================================
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: var(--radius-pill);
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: var(--radius-pill);
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: var(--radius-pill);
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: var(--radius-sm);
}
.inscription-list-page__info {
padding: 0.75rem 1rem;
background: var(--info-background);
color: var(--info-foreground);
border-radius: var(--radius-sm);
}
/* -----------------------------------------------
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; }
}
/* =============================================
AutoPagosPage — BEM: auto-pagos-page
============================================= */
.auto-pagos-page {
width: 100%; max-width: 900px; margin: 0 auto;
padding: 1.25rem 1rem; display: flex; flex-direction: column; gap: 1.5rem;
}
.auto-pagos-page__header { display: flex; flex-direction: column; gap: 0.75rem; }
.auto-pagos-page__title  { font-size: 1.5rem; font-weight: 800; color: var(--text-color); margin: 0; }
.auto-pagos-page__no-event {
padding: 2rem; text-align: center; color: var(--text-muted);
}
.auto-pagos-page__error {
padding: 0.875rem 1rem; background: var(--danger-background);
border-left: 3px solid var(--danger-color); border-radius: var(--border-radius);
color: var(--danger-color); font-size: 0.875rem;
}
/* Panel de búsqueda */
.auto-pagos-page__search-panel {
background: var(--surface-color); border: 1px solid var(--border-color);
border-radius: var(--border-radius); padding: 1.25rem;
display: flex; flex-direction: column; gap: 0.875rem;
}
.auto-pagos-page__qr-row,
.auto-pagos-page__name-row {
display: flex; gap: 0.75rem; align-items: flex-end; flex-wrap: wrap;
}
.auto-pagos-page__qr-input-wrap { flex: 1; min-width: 180px; }
.auto-pagos-page__name-row > :first-child { flex: 1; min-width: 200px; }
/* Lista de recibos */
.auto-pagos-page__loading {
display: flex; align-items: center; gap: 0.75rem; padding: 1.5rem;
color: var(--text-muted);
}
.auto-pagos-page__empty {
padding: 2rem; text-align: center; color: var(--text-muted);
}
.auto-pagos-page__list { display: flex; flex-direction: column; gap: 0.5rem; }
.auto-pagos-page__receipt-card {
display: flex; align-items: center; gap: 1rem; padding: 0.875rem 1rem;
border: 1px solid var(--border-color); border-radius: var(--border-radius);
background: var(--surface-color); cursor: pointer; text-align: left;
transition: background .15s, border-color .15s;
}
.auto-pagos-page__receipt-card:hover {
background: var(--hover-background-color); border-color: var(--primary-color);
}
.auto-pagos-page__receipt-id {
font-size: 1.3rem; font-weight: 800; color: var(--primary-color);
min-width: 60px; font-family: monospace;
}
.auto-pagos-page__receipt-info { flex: 1; display: flex; flex-direction: column; gap: 0.15rem; }
.auto-pagos-page__receipt-name  { font-weight: 600; color: var(--text-color); }
.auto-pagos-page__receipt-email { font-size: 0.8rem; color: var(--text-muted); }
.auto-pagos-page__receipt-right { text-align: right; display: flex; flex-direction: column; gap: 0.15rem; }
.auto-pagos-page__receipt-total { font-weight: 700; color: var(--success-color); font-size: 1rem; }
.auto-pagos-page__receipt-items { font-size: 0.78rem; color: var(--text-muted); }
/* Panel de pago */
.auto-pagos-page__payment-panel {
background: var(--surface-color); border: 1px solid var(--border-color);
border-radius: var(--border-radius); padding: 1.25rem;
display: flex; flex-direction: column; gap: 1.25rem;
}
.auto-pagos-page__receipt-detail {
background: var(--secondary-background); border-radius: var(--border-radius); padding: 1rem;
display: flex; flex-direction: column; gap: 0.75rem;
}
.auto-pagos-page__detail-header {
display: flex; align-items: center; justify-content: space-between;
}
.auto-pagos-page__detail-id {
font-size: 1.1rem; font-weight: 800; color: var(--primary-color); font-family: monospace;
}
.auto-pagos-page__detail-body  { display: flex; flex-direction: column; gap: 0.4rem; }
.auto-pagos-page__detail-row   { display: flex; gap: 0.75rem; align-items: baseline; font-size: 0.875rem; }
.auto-pagos-page__detail-label { color: var(--text-muted); font-weight: 600; min-width: 80px; }
.auto-pagos-page__detail-value { color: var(--text-color); }
.auto-pagos-page__detail-total { font-size: 1.3rem; font-weight: 800; color: var(--success-color); }
.auto-pagos-page__pay-actions  { display: flex; gap: 0.75rem; flex-wrap: wrap; justify-content: flex-end; }
@media (max-width: 600px) {
.auto-pagos-page__receipt-card { flex-wrap: wrap; }
.auto-pagos-page__qr-row,
.auto-pagos-page__name-row { flex-direction: column; }
}
/* =============================================
AutoRegistroPage — BEM: auto-registro-page
============================================= */
.auto-registro-page {
width: 100%; max-width: 760px; margin: 0 auto;
padding: 1.25rem 1rem; display: flex; flex-direction: column; gap: 1.5rem;
box-sizing: border-box;
}
.auto-registro-page__header { display: flex; flex-direction: column; gap: 0.75rem; }
.auto-registro-page__title  { font-size: 1.5rem; font-weight: 800; color: var(--text-color); margin: 0; }
.auto-registro-page__no-event {
padding: 2rem; text-align: center; color: var(--text-muted); font-size: 0.95rem;
}
/* Indicador de pasos */
.auto-registro-page__steps {
display: flex; gap: 0.25rem; overflow-x: auto; padding-bottom: 0.25rem;
}
.auto-registro-page__step {
display: flex; flex-direction: column; align-items: center;
gap: 0.2rem; flex: 1; min-width: 60px; padding: 0.5rem 0.25rem;
border-bottom: 3px solid var(--border-color); opacity: 0.5; transition: all .2s;
}
.auto-registro-page__step--active {
border-bottom-color: var(--primary-color); opacity: 1;
}
.auto-registro-page__step--done {
border-bottom-color: var(--success-color); opacity: 0.8;
}
.auto-registro-page__step-num {
font-size: 1.1rem; font-weight: 700; color: var(--primary-color);
}
.auto-registro-page__step--done .auto-registro-page__step-num { color: var(--success-color); }
.auto-registro-page__step-label { font-size: 0.7rem; color: var(--text-muted); text-align: center; }
.auto-registro-page__error {
padding: 0.875rem 1rem; background: var(--danger-background);
border-left: 3px solid var(--danger-color); border-radius: var(--border-radius);
color: var(--danger-color); font-size: 0.875rem;
}
.auto-registro-page__content {
background: var(--surface-color); border: 1px solid var(--border-color);
border-radius: var(--border-radius); padding: 1.25rem;
box-shadow: var(--shadow-sm);
}
/* Paso 4: Confirmación */
.auto-registro-page__confirm-step { display: flex; flex-direction: column; gap: 1.25rem; }
.auto-registro-page__confirm-summary {
padding: 1rem; background: var(--secondary-background);
border-radius: var(--border-radius); display: flex; flex-direction: column; gap: 0.5rem;
}
.auto-registro-page__confirm-row  { display: flex; gap: 0.75rem; align-items: baseline; font-size: 0.9rem; }
.auto-registro-page__confirm-label { color: var(--text-muted); font-weight: 600; min-width: 80px; }
.auto-registro-page__confirm-value { color: var(--text-color); }
.auto-registro-page__confirm-total { font-size: 1.2rem; font-weight: 800; color: var(--primary-color); }
.auto-registro-page__preregister-info {
padding: 1rem; background: var(--info-background);
border: 1px solid var(--info-color); border-radius: var(--border-radius);
font-size: 0.875rem; color: var(--text-color);
}
.auto-registro-page__preregister-info p { margin: 0.25rem 0; }
/* Navegación */
.auto-registro-page__nav {
display: flex; gap: 0.75rem; justify-content: flex-end; flex-wrap: wrap;
}
@media (max-width: 600px) {
.auto-registro-page { padding: 1rem 0.5rem; }
.auto-registro-page__nav { justify-content: stretch; }
}
/* =============================================
SelfRegisterPage — BEM: self-register-page
============================================= */
.self-register-page {
width: 100%; max-width: 680px; margin: 0 auto;
padding: 1.25rem 1rem; display: flex; flex-direction: column; gap: 1.5rem;
}
.self-register-page__header  { display: flex; flex-direction: column; align-items: center; gap: 0.25rem; }
.self-register-page__title   { font-size: 1.75rem; font-weight: 900; color: var(--primary-color); margin: 0; }
.self-register-page__event-name {
font-size: 1rem; color: var(--text-muted); margin: 0; text-align: center;
}
.self-register-page__loading {
display: flex; align-items: center; gap: 0.75rem; justify-content: center;
padding: 2rem; color: var(--text-muted);
}
.self-register-page__error-full {
padding: 1.5rem; background: var(--danger-background);
border: 1px solid var(--danger-color); border-radius: var(--border-radius);
text-align: center; color: var(--danger-color);
}
.self-register-page__error {
padding: 0.875rem 1rem; background: var(--danger-background);
border-left: 3px solid var(--danger-color); border-radius: var(--border-radius);
color: var(--danger-color); font-size: 0.875rem;
}
/* Pasos */
.self-register-page__steps {
display: flex; gap: 0.25rem; overflow-x: auto;
}
.self-register-page__step {
display: flex; flex-direction: column; align-items: center; gap: 0.2rem;
flex: 1; min-width: 60px; padding: 0.5rem 0.25rem;
border-bottom: 3px solid var(--border-color); opacity: 0.5; transition: all .2s;
}
.self-register-page__step--active { border-bottom-color: var(--primary-color); opacity: 1; }
.self-register-page__step--done   { border-bottom-color: var(--success-color); opacity: 0.8; }
.self-register-page__step-num {
font-size: 1.1rem; font-weight: 700; color: var(--primary-color);
}
.self-register-page__step--done .self-register-page__step-num { color: var(--success-color); }
.self-register-page__step-label { font-size: 0.7rem; color: var(--text-muted); text-align: center; }
.self-register-page__content {
background: var(--surface-color); border: 1px solid var(--border-color);
border-radius: var(--border-radius); padding: 1.25rem; box-shadow: var(--shadow-sm);
}
/* Auth */
.self-register-page__auth-section { display: flex; flex-direction: column; gap: 0.75rem; }
.self-register-page__auth-hint   { color: var(--text-muted); font-size: 0.875rem; margin: 0; }
/* Confirmación */
.self-register-page__confirm { display: flex; flex-direction: column; gap: 1rem; }
.self-register-page__confirm-text {
font-size: 0.95rem; color: var(--text-color); line-height: 1.6; margin: 0;
}
.self-register-page__confirm-total {
display: flex; justify-content: space-between; align-items: center;
padding: 0.875rem 1rem; background: var(--success-background);
border: 1px solid var(--success-color); border-radius: var(--border-radius);
font-size: 1rem;
}
.self-register-page__confirm-total strong {
font-size: 1.4rem; color: var(--success-color);
}
/* Navegación */
.self-register-page__nav {
display: flex; gap: 0.75rem; justify-content: flex-end; flex-wrap: wrap;
}
@media (max-width: 600px) {
.self-register-page { padding: 1rem 0.5rem; }
.self-register-page__nav { justify-content: stretch; }
}
/* ============================================
PaymentListPage - Lista de Pagos (Admin)
============================================ */
.paymentListPage {
width: 100%;
height: 100%;
padding: 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 var(--transition-base);
}
.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: ver paymentListPage.css (admin/paymentListPage.css) */
.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;
}
}
/* ── ID column — chips clicables ────────────────────────── */
.paymentListPage__id-col {
display: flex;
flex-direction: column;
gap: 4px;
align-items: flex-start;
}
/* 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;
}
/* ==================== CONTENT ==================== */
.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 var(--transition-base);
}
.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);
}
}
/* =============================================
ReceiptListPage â€” Apply Payment Modal
BEM: rcp-apply-payment
============================================= */
.rcp-apply-payment {
display: flex;
flex-direction: column;
gap: 1rem;
}
.rcp-apply-payment__total {
display: flex;
align-items: center;
justify-content: space-between;
padding: 0.875rem 1rem;
background: var(--success-background);
border: 1px solid var(--success-color);
border-radius: var(--border-radius);
}
.rcp-apply-payment__total-label {
font-size: 0.875rem;
font-weight: 600;
color: var(--text-color);
}
.rcp-apply-payment__total-amount {
font-size: 1.4rem;
font-weight: 800;
color: var(--success-color);
}
.rcp-apply-payment__error {
padding: 0.75rem 1rem;
background: var(--danger-background);
border-left: 3px solid var(--danger-color);
border-radius: var(--border-radius);
color: var(--danger-color);
font-size: 0.875rem;
}
/* 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 var(--transition-slow);
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 var(--transition-slow);
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 var(--transition-slow);
}
.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 var(--transition-base);
}
.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 var(--transition-base);
}
.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;
}
}
/* Banner permanente de pago pendiente */
.receipt-page__unpaid-banner {
grid-column: 1 / -1;
display: flex;
align-items: flex-start;
gap: 1rem;
padding: 1.25rem 1.5rem;
background: var(--danger-background);
border: 1.5px solid var(--danger-foreground);
border-radius: 12px;
margin-bottom: 1.5rem;
box-shadow: 0 2px 10px rgba(0,0,0,0.08);
}
.receipt-page__unpaid-banner-icon {
width: 28px;
height: 28px;
color: var(--danger-foreground);
flex-shrink: 0;
margin-top: 0.1rem;
}
.receipt-page__unpaid-banner-content {
flex: 1;
}
.receipt-page__unpaid-banner-title {
display: block;
color: var(--danger-foreground);
font-size: 1rem;
font-weight: 700;
margin-bottom: 0.35rem;
}
.receipt-page__unpaid-banner-text {
color: var(--danger-foreground);
font-size: 0.9rem;
margin: 0;
line-height: 1.55;
opacity: 0.9;
}
.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: var(--radius-sm);
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;
position: sticky;
top: 1rem;
}
.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);
}
.currency-selector-wrapper {
display: flex;
align-items: center;
gap: 0.5rem;
background: var(--surface-alt-color);
border: 1.5px solid var(--primary-color);
border-radius: 10px;
padding: 0.15rem 0.55rem 0.15rem 0.4rem;
margin-left: 1rem;
flex-shrink: 0;
box-shadow: 0 1px 6px rgba(0,0,0,0.07);
transition: border-color 0.2s, box-shadow 0.2s;
}
.currency-selector-wrapper:focus-within {
border-color: var(--accent-color);
box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent-color) 20%, transparent);
}
.currency-selector-wrapper__icon {
width: 18px;
height: 18px;
color: var(--primary-color);
flex-shrink: 0;
stroke: var(--primary-color);
}
.currency-selector-wrapper__inner {
display: flex;
flex-direction: column;
gap: 0;
}
.currency-selector-wrapper__select {
font-size: 0.92rem;
font-weight: 600;
color: var(--text-color);
background: transparent;
border: none;
outline: none;
padding: 0;
cursor: pointer;
min-width: 80px;
appearance: auto;
}
.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;
}
.currency-selector-wrapper__label {
display: none;
}
.currency-selector-wrapper {
padding: 0.3rem 0.5rem;
}
}
@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;
}
/* ── Biometric Consent Step ──────────────────────────────────── */
.register-biometric {
display: flex;
flex-direction: column;
gap: 1.1rem;
}
/* Header: icono + título en fila + descripción corta */
.register-biometric__header {
display: flex;
gap: 0.75rem;
align-items: flex-start;
}
.register-biometric__icon {
flex-shrink: 0;
color: var(--accent-color);
margin-top: 0.15rem;
}
.register-biometric__header-text {
flex: 1;
min-width: 0;
}
.register-biometric__header-row {
display: flex;
align-items: center;
justify-content: space-between;
gap: 0.5rem;
flex-wrap: wrap;
}
.register-biometric__title {
font-size: 1rem;
font-weight: 600;
color: var(--primary-foreground);
margin: 0;
}
.register-biometric__description {
font-size: 0.82rem;
color: var(--secondary-foreground);
margin: 0.2rem 0 0 0;
line-height: 1.4;
}
.register-biometric__privacy-link {
font-size: 0.8rem;
white-space: nowrap;
flex-shrink: 0;
}
/* Card horizontal: foto + CTA */
.register-biometric__action-card {
display: flex;
gap: 1.25rem;
align-items: center;
background: var(--surface-alt-color);
border: 1px solid var(--border-color);
border-radius: 12px;
padding: 1.1rem 1.25rem;
}
.register-biometric__action-card--loading {
justify-content: center;
flex-direction: column;
padding: 1.5rem;
gap: 0.75rem;
}
/* Columna izquierda: foto circular + badge */
.register-biometric__photo-col {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.45rem;
flex-shrink: 0;
}
.register-biometric__photo-preview {
width: 80px;
height: 80px;
object-fit: cover;
border-radius: 50%;
border: 3px solid var(--border-color);
}
/* Columna derecha: texto + botones */
.register-biometric__cta-col {
flex: 1;
min-width: 0;
display: flex;
flex-direction: column;
gap: 0.65rem;
}
.register-biometric__cta-title {
font-size: 0.88rem;
font-weight: 500;
color: var(--primary-foreground);
margin: 0;
line-height: 1.35;
}
.register-biometric__cta-btn {
align-self: flex-start;
}
.register-biometric__secondary-actions {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
align-items: center;
}
/* Badge de estado */
.register-biometric__badge {
display: inline-flex;
align-items: center;
gap: 0.35rem;
padding: 0.2rem 0.6rem;
border-radius: 20px;
font-size: 0.75rem;
font-weight: 600;
white-space: nowrap;
}
.register-biometric__badge--valid {
background: var(--success-background);
color: var(--success-foreground);
}
.register-biometric__badge--invalid {
background: var(--danger-background);
color: var(--danger-foreground);
}
.register-biometric__reason {
font-size: 0.82rem;
color: var(--danger-foreground);
margin: 0;
}
/* Estado: validando */
.register-biometric__uploading-text {
font-size: 0.88rem;
color: var(--secondary-foreground);
text-align: center;
margin: 0;
}
/* Estado: sin foto — uploader compacto */
.register-biometric__uploader {
max-width: 340px;
margin: 0 auto;
width: 100%;
}
/* Reducir el área de imagen dentro del uploader biométrico */
.register-biometric__uploader .app-user-photo-upload__image {
aspect-ratio: 1 / 1;
max-height: 160px;
}
.register-biometric__uploader .app-user-photo-upload__placeholder svg {
width: 56px;
height: 56px;
}
.register-biometric__uploader .app-user-photo-upload__bottom {
padding: 0.5rem 0.75rem;
gap: 0.4rem;
}
.register-biometric__uploader .app-user-photo-upload__title {
font-size: 0.85rem;
}
.register-biometric__uploader .app-user-photo-upload__hint {
font-size: 0.75rem;
}
/* Mensaje de validación del uploader biométrico: encima del uploader */
.register-biometric__validation-alert {
display: flex;
align-items: flex-start;
gap: 0.55rem;
padding: 0.65rem 0.9rem;
border-radius: 8px;
font-size: 0.85rem;
font-weight: 500;
line-height: 1.4;
max-width: 340px;
margin: 0 auto;
width: 100%;
box-sizing: border-box;
}
.register-biometric__validation-alert--valid {
background: var(--success-background);
color: var(--success-foreground);
border: 1px solid var(--success-foreground);
}
.register-biometric__validation-alert--invalid {
background: var(--danger-background);
color: var(--danger-foreground);
border: 1px solid var(--danger-foreground);
}
.register-biometric__validation-alert svg {
flex-shrink: 0;
margin-top: 0.1rem;
}
.register-biometric__validation-alert-body {
display: flex;
flex-direction: column;
gap: 0.15rem;
}
.register-biometric__validation-alert-title {
font-weight: 700;
font-size: 0.88rem;
}
.register-biometric__validation-alert-reason {
font-size: 0.8rem;
opacity: 0.9;
}
.register-biometric__actions {
display: flex;
flex-wrap: wrap;
gap: 0.6rem;
align-items: center;
}
.register-biometric__actions--decline {
justify-content: flex-end;
}
/* Estado: declinó */
.register-biometric__declined-note {
display: flex;
align-items: flex-start;
gap: 0.6rem;
background: var(--warning-background);
color: var(--warning-foreground);
border-radius: 8px;
padding: 0.75rem 1rem;
font-size: 0.85rem;
line-height: 1.45;
}
.register-biometric__declined-note svg {
flex-shrink: 0;
margin-top: 0.15rem;
}
.register-biometric__declined-body {
display: flex;
flex-direction: column;
gap: 0.3rem;
}
.register-biometric__revert-link {
font-size: 0.82rem;
padding: 0;
height: auto;
align-self: flex-start;
}
/* Nota en paso Payment */
.register-biometric__declined-note--payment {
margin-top: 0.75rem;
font-size: 0.8rem;
padding: 0.6rem 0.85rem;
}
@media (max-width: 520px) {
.register-biometric__action-card {
flex-direction: column;
align-items: center;
text-align: center;
}
.register-biometric__cta-col {
align-items: center;
}
.register-biometric__cta-btn {
align-self: stretch;
}
.register-biometric__secondary-actions {
justify-content: center;
}
.register-biometric__header-row {
flex-direction: column;
align-items: flex-start;
}
}
.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;
}
}
/* SocietiesListPage — BEM namespace: societies-list-page */
.societies-list-page {
display: flex;
flex-direction: column;
min-height: 100vh;
background: transparent;
}
.societies-list-page__content { flex: 1; padding: 1rem; }
.societies-list-page__loading {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 1rem;
padding: 3rem;
color: var(--text-muted);
}
.societies-list-page__empty {
padding: 3rem;
text-align: center;
color: var(--text-muted);
font-size: 1rem;
}
.societies-list-page__error {
padding: 1rem 1.25rem;
margin: 1rem;
background: var(--danger-background);
color: var(--danger-foreground);
border: 1px solid var(--danger-color);
border-radius: var(--radius-md);
}
/* ── Tabla principal ── */
.societies-list-page__table-wrapper {
overflow-x: auto;
background: var(--surface-color);
border-radius: var(--radius-lg);
box-shadow: var(--shadow-sm);
border: 1.5px solid var(--border-color);
position: relative;
}
.societies-list-page__table-wrapper::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
background: var(--card-accent-gradient);
border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.societies-list-page__th-center { text-align: center !important; }
.societies-list-page__actions-cell { text-align: center !important; }
/* ── Badge de estado activo/inactivo ── */
.societies-list-page__badge {
display: inline-flex;
align-items: center;
gap: 0.3rem;
padding: 0.2rem 0.65rem;
border-radius: 999px;
font-size: 0.72rem;
font-weight: 600;
letter-spacing: 0.02em;
}
.societies-list-page__badge--active {
background: var(--success-background);
color: var(--success-foreground);
}
.societies-list-page__badge--inactive {
background: var(--danger-background);
color: var(--danger-foreground);
}
/* ── Filtros ── */
.societies-list-page__filter-group {
display: flex;
flex-direction: column;
gap: 0.4rem;
margin-bottom: 1rem;
}
.societies-list-page__label {
font-size: 0.8rem;
font-weight: 600;
color: var(--text-muted);
}
/* ── Modal de detalle con tabs ── */
.societies-list-page__tabs {
display: flex;
gap: 0.25rem;
border-bottom: 1.5px solid var(--border-color);
margin-bottom: 1.25rem;
overflow-x: auto;
}
.societies-list-page__tab {
padding: 0.5rem 1.1rem;
border: none;
background: transparent;
color: var(--text-muted);
font-size: 0.85rem;
font-weight: 600;
cursor: pointer;
border-bottom: 2.5px solid transparent;
transition: color 0.2s, border-color 0.2s;
white-space: nowrap;
}
.societies-list-page__tab--active {
color: var(--primary-color);
border-bottom-color: var(--primary-color);
}
.societies-list-page__tab:hover:not(.societies-list-page__tab--active) {
color: var(--text-color);
border-bottom-color: var(--border-color);
}
/* ── Access Key ── */
.societies-list-page__access-key {
display: flex;
align-items: center;
gap: 0.5rem;
background: var(--surface-alt-color);
border: 1.5px solid var(--border-color);
border-radius: var(--radius-md);
padding: 0.5rem 0.75rem;
font-family: monospace;
font-size: 0.8rem;
color: var(--text-muted);
word-break: break-all;
flex-wrap: wrap;
}
.societies-list-page__access-key-value {
flex: 1;
min-width: 0;
overflow: hidden;
text-overflow: ellipsis;
}
.societies-list-page__access-key-actions {
display: flex;
gap: 0.4rem;
flex-shrink: 0;
}
.societies-list-page__icon-btn {
display: inline-flex;
align-items: center;
justify-content: center;
width: 28px;
height: 28px;
border: none;
background: transparent;
color: var(--text-muted);
border-radius: var(--radius-sm);
cursor: pointer;
transition: color 0.2s, background 0.2s;
}
.societies-list-page__icon-btn:hover {
background: var(--hover-background-color);
color: var(--primary-color);
}
.societies-list-page__icon-btn--danger:hover {
color: var(--danger-foreground);
background: var(--danger-background);
}
/* ── Subtablas de categorías / regiones ── */
.societies-list-page__sub-toolbar {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 0.75rem;
gap: 0.5rem;
flex-wrap: wrap;
}
.societies-list-page__sub-title {
font-size: 0.88rem;
font-weight: 700;
color: var(--text-color);
}
.societies-list-page__sub-table-wrapper {
overflow-x: auto;
border: 1px solid var(--border-color);
border-radius: var(--radius-md);
margin-bottom: 1.25rem;
}
.societies-list-page__expand-btn {
display: inline-flex;
align-items: center;
gap: 0.3rem;
background: transparent;
border: none;
color: var(--primary-color);
font-size: 0.78rem;
font-weight: 600;
cursor: pointer;
padding: 0.2rem 0.4rem;
border-radius: var(--radius-sm);
transition: background 0.2s;
}
.societies-list-page__expand-btn:hover {
background: var(--hover-background-color);
}
/* ── Form dentro del modal ── */
.societies-list-page__form {
display: flex;
flex-direction: column;
gap: 0;
}
.societies-list-page__row {
display: grid;
grid-template-columns: 1fr;
gap: 0 1rem;
margin-bottom: 0.1rem;
}
.societies-list-page__row--2 {
grid-template-columns: 1fr 1fr;
}
.societies-list-page__row--3 {
grid-template-columns: 1fr 1fr 1fr;
}
.societies-list-page__switch-wrap {
display: flex;
align-items: center;
padding-top: 1.6rem;
}
.societies-list-page__section-title {
font-size: 0.78rem;
font-weight: 700;
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: 0.05em;
margin: 0.75rem 0 0.35rem;
}
.societies-list-page__hint {
font-size: 0.85rem;
color: var(--text-muted);
margin-bottom: 0.75rem;
}
.societies-list-page__modal-actions {
display: flex;
justify-content: flex-end;
gap: 0.5rem;
margin-top: 1.25rem;
padding-top: 0.75rem;
border-top: 1px solid var(--border-color);
}
/* ── Responsive ── */
@media (max-width: 750px) {
.societies-list-page__table-wrapper {
background: transparent;
border: none;
box-shadow: none;
}
.societies-list-page__content { padding: 0.5rem; }
.societies-list-page__row--2,
.societies-list-page__row--3 { grid-template-columns: 1fr; }
.societies-list-page__tabs { gap: 0; }
.societies-list-page__tab { padding: 0.5rem 0.75rem; font-size: 0.78rem; }
.societies-list-page__modal-actions { flex-wrap: wrap; }
}
@media (max-width: 480px) {
.societies-list-page__access-key { flex-direction: column; align-items: flex-start; }
.societies-list-page__access-key-actions { width: 100%; justify-content: flex-end; }
}
/* ================================================
admin-stands-list — BEM
================================================ */
.admin-stands-list {
display: flex;
flex-direction: column;
gap: 1rem;
padding: 1rem;
}
.admin-stands-list__error {
color: var(--danger-foreground);
background: var(--danger-background);
padding: 0.75rem 1rem;
border-radius: 0.5rem;
}
/* Filtros */
.admin-stands-list__filter-group {
display: flex;
flex-direction: column;
gap: 0.35rem;
margin-bottom: 1rem;
}
.admin-stands-list__label {
font-size: 0.8rem;
font-weight: 600;
color: var(--text-secondary);
text-transform: uppercase;
letter-spacing: 0.04em;
}
.admin-stands-list__filter-divider {
height: 1px;
background: var(--border-color);
margin: 0.75rem 0;
}
/* Status badge en tabla */
.admin-stands-list__badge {
display: inline-block;
padding: 0.18em 0.6em;
border-radius: 0.35rem;
font-size: 0.75rem;
font-weight: 600;
letter-spacing: 0.02em;
text-transform: uppercase;
}
.admin-stands-list__badge--pending_approval {
background: var(--warning-background);
color: var(--warning-foreground);
}
.admin-stands-list__badge--active {
background: var(--success-background);
color: var(--success-foreground);
}
.admin-stands-list__badge--inactive {
background: var(--muted-background);
color: var(--muted-foreground);
}
.admin-stands-list__badge--cancelled {
background: var(--danger-background);
color: var(--danger-foreground);
}
/* Responsivo */
@media (max-width: 600px) {
.admin-stands-list {
padding: 0.5rem;
}
}
/* NexEvent - AdminUsersList */
.admin-users {
width: 100%;
max-width: 100%;
padding: 1rem;
box-sizing: border-box;
}
.admin-users__content { width: 100%; margin-top: 1rem; }
.admin-users__loading {
display: flex;
align-items: center;
justify-content: center;
padding: 3rem;
}
.admin-users__error {
padding: 1rem 1.25rem;
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: var(--radius-md);
border: 1px solid var(--danger-color);
margin: 1rem 0;
}
.admin-users__empty {
text-align: center;
padding: 3rem;
color: var(--text-muted);
font-size: 1rem;
}
.admin-users__table-wrapper {
width: 100%;
overflow-x: auto;
margin-top: 1rem;
}
.admin-users__th {
text-align: left;
white-space: nowrap;
font-size: 0.75rem;
font-weight: 700;
letter-spacing: 0.08em;
text-transform: uppercase;
color: var(--table-header-text);
padding: 0.75rem 1rem;
}
.admin-users__th--sortable { cursor: pointer; user-select: none; }
.admin-users__th--sortable:hover { color: var(--primary-color); }
/* ── Celda de usuario con avatar ── */
.admin-users__user-cell {
display: flex;
align-items: center;
gap: 0.625rem;
}
.admin-users__avatar {
width: 34px;
height: 34px;
border-radius: 50%;
object-fit: cover;
flex-shrink: 0;
border: 2px solid var(--border-color);
background: var(--surface-alt-color);
}
.admin-users__avatar-initials {
width: 34px;
height: 34px;
border-radius: 50%;
flex-shrink: 0;
display: inline-flex;
align-items: center;
justify-content: center;
font-size: 0.7rem;
font-weight: 700;
letter-spacing: 0.03em;
text-transform: uppercase;
background: var(--primary-color);
color: var(--primary-foreground);
user-select: none;
}
.admin-users__user-info {
display: flex;
flex-direction: column;
gap: 0.125rem;
min-width: 0;
}
.admin-users__user-name {
font-weight: 600;
font-size: 0.875rem;
color: var(--text-color);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.admin-users__user-title {
font-size: 0.7rem;
color: var(--text-muted);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
/* ============================================================
MyStandsPage — BEM namespace: my-stands-page
SHARED/wwwroot/css/pages/user/myStandsPage.css
============================================================ */
.my-stands-page {
width: 100%;
max-width: 1100px;
margin: 0 auto;
padding: 2rem 1.25rem;
}
.my-stands-page__unauthorized {
display: flex;
align-items: center;
justify-content: center;
padding: 4rem 1rem;
color: var(--text-secondary);
font-size: 1rem;
}
@media (max-width: 768px) {
.my-stands-page {
padding: 1.25rem 0.75rem;
}
}
.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}
}
/* ============================================================
StandRequestPage — BEM namespace: stand-request-page
SHARED/wwwroot/css/pages/user/standRequestPage.css
============================================================ */
.stand-request-page {
width: 100%;
max-width: 720px;
margin: 0 auto;
padding: 2rem 1.25rem;
}
/* ── Loading / Error / Unauthorized ── */
.stand-request-page__loading,
.stand-request-page__error,
.stand-request-page__unauthorized {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
padding: 4rem 1rem;
gap: 1rem;
text-align: center;
color: var(--text-secondary);
}
.stand-request-page__error {
color: var(--danger-foreground);
}
/* ── Encabezado del evento ── */
.stand-request-page__event-header {
margin-bottom: 1.5rem;
padding-bottom: 1.25rem;
border-bottom: 1px solid var(--border-color);
}
.stand-request-page__event-name {
font-size: 1.4rem;
font-weight: 700;
color: var(--text-primary);
margin: 0 0 0.25rem;
}
.stand-request-page__event-meta {
font-size: 0.88rem;
color: var(--text-secondary);
margin: 0;
}
/* ── Pasos ── */
.stand-request-page__steps {
margin-bottom: 2rem;
}
/* ── Tarjeta de paso ── */
.stand-request-page__step-card {
background: var(--card-background);
border: 1px solid var(--border-color);
border-radius: 12px;
padding: 1.75rem 2rem;
display: flex;
flex-direction: column;
gap: 1rem;
}
.stand-request-page__step-card--success {
align-items: center;
text-align: center;
padding: 3rem 2rem;
}
.stand-request-page__step-title {
font-size: 1.1rem;
font-weight: 700;
color: var(--text-primary);
margin: 0;
}
.stand-request-page__step-desc {
font-size: 0.9rem;
color: var(--text-secondary);
margin: 0;
}
/* ── Grid de info del evento (paso 1) ── */
.stand-request-page__event-detail-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
gap: 1rem;
}
.stand-request-page__event-detail-field {
display: flex;
flex-direction: column;
gap: 0.15rem;
}
.stand-request-page__event-detail-label {
font-size: 0.72rem;
color: var(--text-secondary);
text-transform: uppercase;
letter-spacing: 0.05em;
}
.stand-request-page__event-detail-value {
font-size: 0.95rem;
font-weight: 600;
color: var(--text-primary);
}
/* ── Formulario (paso 2) ── */
.stand-request-page__form {
display: flex;
flex-direction: column;
gap: 0.85rem;
}
/* ── Fiscal seleccionado (paso 3) ── */
.stand-request-page__fiscal-selected {
margin-top: 0.5rem;
padding: 0.75rem 1rem;
background: var(--success-background);
color: var(--success-foreground);
border-radius: 8px;
font-size: 0.9rem;
display: flex;
align-items: center;
gap: 0.5rem;
flex-wrap: wrap;
}
.stand-request-page__fiscal-selected-label {
font-weight: 600;
}
/* ── Resumen (paso 4) ── */
.stand-request-page__summary {
display: flex;
flex-direction: column;
gap: 0.6rem;
background: var(--input-background);
border: 1px solid var(--border-color);
border-radius: 8px;
padding: 1rem 1.25rem;
}
.stand-request-page__summary-row {
display: flex;
align-items: flex-start;
gap: 0.75rem;
font-size: 0.9rem;
}
.stand-request-page__summary-label {
color: var(--text-secondary);
min-width: 120px;
flex-shrink: 0;
}
.stand-request-page__summary-value {
color: var(--text-primary);
font-weight: 600;
}
/* ── Error de envío ── */
.stand-request-page__submit-error {
padding: 0.75rem 1rem;
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: 8px;
font-size: 0.9rem;
}
/* ── Acciones del paso ── */
.stand-request-page__step-actions {
display: flex;
align-items: center;
justify-content: flex-end;
gap: 0.75rem;
margin-top: 0.5rem;
flex-wrap: wrap;
}
.stand-request-page__step-actions--center {
justify-content: center;
}
/* ── Éxito ── */
.stand-request-page__success-icon {
color: var(--success-foreground);
margin-bottom: 0.75rem;
}
.stand-request-page__success-title {
font-size: 1.3rem;
font-weight: 700;
color: var(--text-primary);
margin: 0;
}
.stand-request-page__success-desc {
font-size: 0.9rem;
color: var(--text-secondary);
margin: 0;
max-width: 420px;
}
/* ── Responsive ── */
@media (max-width: 600px) {
.stand-request-page {
padding: 1.25rem 0.75rem;
}
.stand-request-page__step-card {
padding: 1.25rem 1rem;
}
.stand-request-page__step-actions {
flex-direction: column-reverse;
align-items: stretch;
}
.stand-request-page__event-detail-grid {
grid-template-columns: 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;
}
/* =======================================================================
NexEvent — EventDetail Page
Detalle de evento con hero inmersivo, cards con glow
======================================================================= */
.event-detail-page {
display: flex;
flex-direction: column;
gap: 1.25rem;
width: 100%;
max-width: 1440px;
margin: 0 auto;
}
.event-detail-page__hero,
.event-detail-page__summary,
.event-detail-page__section,
.event-detail-page__state {
position: relative;
overflow: hidden;
border: 1.5px solid var(--border-color);
border-radius: var(--radius-xl);
background: var(--gradient-surface);
box-shadow: var(--shadow-lg);
}
.event-detail-page__hero::before,
.event-detail-page__section::before {
content: "";
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
background: var(--card-accent-gradient);
}
.event-detail-page__hero {
display: grid;
grid-template-columns: minmax(18rem, 26rem) minmax(0, 1fr);
gap: 1.5rem;
padding: clamp(1.5rem, 3vw, 2.25rem);
}
.event-detail-page__hero-media,
.event-detail-page__hero-copy,
.event-detail-page__summary,
.event-detail-page__section { position: relative; z-index: 1; }
.event-detail-page__hero-media {
overflow: hidden;
border-radius: var(--radius-lg);
border: 1.5px solid var(--border-color);
background: var(--surface-alt-color);
min-height: 20rem;
box-shadow: var(--shadow-md), var(--shadow-glow);
}
.event-detail-page__hero-image {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
}
.event-detail-page__hero-copy {
display: flex;
flex-direction: column;
gap: 1rem;
}
.event-detail-page__eyebrow {
display: inline-flex;
align-items: center;
width: fit-content;
padding: 0.45rem 0.9rem;
border-radius: var(--radius-pill);
background: var(--hover-background-color);
color: var(--primary-color);
font-size: 0.75rem;
font-weight: 700;
letter-spacing: 0.1em;
text-transform: uppercase;
border: 1px solid var(--primary-color);
}
.event-detail-page__title {
margin: 0;
font-size: clamp(2rem, 4vw, 3.5rem);
line-height: 1.02;
letter-spacing: -0.04em;
max-width: 14ch;
}
.event-detail-page__lead {
margin: 0;
max-width: 48rem;
color: var(--text-muted);
font-size: 0.9375rem;
}
.event-detail-page__meta-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 0.75rem;
}
.event-detail-page__meta-card,
.event-detail-page__summary-card,
.event-detail-page__category-card,
.event-detail-page__empty-card {
border-radius: var(--radius-md);
border: 1.5px solid var(--border-color);
background: var(--surface-color);
box-shadow: var(--shadow-xs);
transition: all var(--transition-base);
}
.event-detail-page__meta-card:hover,
.event-detail-page__summary-card:hover { border-color: var(--card-hover-border); box-shadow: var(--shadow-sm); }
.event-detail-page__meta-card { padding: 1rem; }
.event-detail-page__meta-label,
.event-detail-page__summary-label {
display: block;
margin-bottom: 0.35rem;
font-size: 0.7rem;
font-weight: 700;
letter-spacing: 0.1em;
text-transform: uppercase;
color: var(--text-muted);
}
.event-detail-page__meta-value,
.event-detail-page__summary-value,
.event-detail-page__fee-amount {
color: var(--text-color);
font-weight: 700;
}
.event-detail-page__section-subtitle,
.event-detail-page__category-description,
.event-detail-page__category-meta,
.event-detail-page__fee-window,
.event-detail-page__summary-text,
.event-detail-page__empty-description,
.event-detail-page__state-description { color: var(--text-muted); }
.event-detail-page__actions {
display: flex;
gap: 0.75rem;
flex-wrap: wrap;
}
.event-detail-page__summary {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 1rem;
}
.event-detail-page__summary-card,
.event-detail-page__empty-card,
.event-detail-page__state { padding: 1.35rem; }
.event-detail-page__summary-title,
.event-detail-page__section-title,
.event-detail-page__empty-title,
.event-detail-page__state-title {
margin: 0 0 0.75rem;
font-size: 1.25rem;
letter-spacing: -0.02em;
}
.event-detail-page__summary-list { display: grid; gap: 0.875rem; }
.event-detail-page__summary-item {
display: flex;
justify-content: space-between;
gap: 1rem;
padding-bottom: 0.85rem;
border-bottom: 1px solid var(--divider-color);
}
.event-detail-page__summary-item:last-child { padding-bottom: 0; border-bottom: none; }
.event-detail-page__chips {
display: flex;
flex-wrap: wrap;
gap: 0.65rem;
margin-top: 0.875rem;
}
.event-detail-page__chip {
display: inline-flex;
align-items: center;
padding: 0.4rem 0.8rem;
border-radius: var(--radius-pill);
background: var(--hover-background-color);
color: var(--primary-color);
border: 1px solid var(--primary-color);
font-size: 0.75rem;
font-weight: 700;
letter-spacing: 0.04em;
}
.event-detail-page__section { padding: clamp(1.25rem, 2vw, 1.75rem); }
.event-detail-page__section-header {
display: flex;
flex-direction: column;
gap: 0.4rem;
margin-bottom: 1.25rem;
}
.event-detail-page__section-title { margin-bottom: 0; }
.event-detail-page__catalog-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 1rem;
}
.event-detail-page__category-card {
padding: 1.2rem;
}
.event-detail-page__category-card:hover { border-color: var(--card-hover-border); box-shadow: var(--shadow-sm), var(--shadow-glow); }
.event-detail-page__category-header { display: flex; flex-direction: column; gap: 0.35rem; margin-bottom: 0.75rem; }
.event-detail-page__category-title, .event-detail-page__fee-name { margin: 0; }
.event-detail-page__category-meta, .event-detail-page__fee-window, .event-detail-page__category-empty { font-size: 0.875rem; }
.event-detail-page__category-description, .event-detail-page__category-empty { margin: 0 0 1rem; }
.event-detail-page__fee-list { display: grid; gap: 0.75rem; }
.event-detail-page__fee-item {
display: flex;
align-items: flex-start;
justify-content: space-between;
gap: 1rem;
padding: 0.875rem 0;
border-top: 1px solid var(--divider-color);
}
.event-detail-page__fee-item:first-child { border-top: none; padding-top: 0; }
.event-detail-page__fee-window { display: block; margin-top: 0.35rem; }
.event-detail-page__state {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 0.75rem;
min-height: 18rem;
text-align: center;
}
.event-detail-page__state--loading { margin: 0 auto; max-width: 1440px; }
@media (max-width: 1100px) {
.event-detail-page__hero, .event-detail-page__summary, .event-detail-page__catalog-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
.event-detail-page__meta-grid, .event-detail-page__catalog-grid { grid-template-columns: 1fr; }
.event-detail-page__actions { flex-direction: column; }
.event-detail-page__actions .app-button { width: 100%; }
.event-detail-page__title { max-width: none; font-size: clamp(2rem, 9vw, 3rem); }
}
/* =======================================================================
OmniaBP Design System — eventsPage.css
Cards horizontal: poster vertical izquierda + info derecha
======================================================================= */
.events-page {
display: flex;
flex-direction: column;
gap: 1.25rem;
width: 100%;
max-width: 1440px;
margin: 0 auto;
}
/* ── Toolbar: overflow visible (dropdowns de AppSelect no se recortan)
La línea de acento va en background multicapa — los backgrounds
siempre son recortados por border-radius sin necesitar overflow:hidden ── */
.events-page__toolbar {
position: relative;
border: 1.5px solid var(--border-color);
border-radius: var(--radius-xl);
box-shadow: var(--shadow-lg);
overflow: visible;
padding: clamp(1rem, 1.8vw, 1.35rem);
/* fondo: línea gradiente de 2px en el top + superficie normal */
background:
linear-gradient(var(--gradient-border), var(--gradient-border))
top center / 100% 2px no-repeat,
var(--gradient-surface);
}
/* ── Results: overflow hidden (contiene la grid de cards) ── */
.events-page__results {
position: relative;
border: 1.5px solid var(--border-color);
border-radius: var(--radius-xl);
background: var(--gradient-surface);
box-shadow: var(--shadow-lg);
overflow: hidden;
z-index: 1;
padding: clamp(1rem, 1.8vw, 1.35rem);
}
/* Línea de acento solo en results (tiene overflow:hidden, ::before funciona bien) */
.events-page__results::before {
content: "";
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
border-radius: var(--radius-xl) var(--radius-xl) 0 0;
background: var(--gradient-border);
pointer-events: none;
z-index: 1;
}
/* ── Filtros ── */
.events-page__filters {
display: grid;
grid-template-columns: minmax(0, 1.65fr) minmax(7.5rem, 9rem) minmax(7.5rem, 9rem) auto;
gap: 0.75rem;
align-items: center;
}
.events-page__filter { min-width: 0; }
.events-page__search-input,
.events-page__select-input { margin: 0 !important; }
.events-page__actions {
display: flex;
gap: 0.5rem;
align-items: center;
flex-shrink: 0;
}
/* ── Subtitulo de resultados ── */
.events-page__results-header { margin-bottom: 1.25rem; }
.events-page__results-subtitle {
margin: 0;
color: var(--text-muted);
font-size: 0.875rem;
letter-spacing: 0.01em;
}
/* ═══════════════════════════════════════════════════
GRID — 2 columnas de cards horizontales
═══════════════════════════════════════════════════ */
.events-page__grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(480px, 1fr));
gap: 1rem;
}
/* ═══════════════════════════════════════════════════
CARD HORIZONTAL: poster izquierda | info derecha
═══════════════════════════════════════════════════ */
.events-page__card {
display: flex;
flex-direction: row;
background: var(--card-bg-color);
border: 1.5px solid var(--border-color);
border-radius: var(--radius-lg);
box-shadow: var(--shadow-sm);
overflow: hidden;
transition: all var(--transition-base);
position: relative;
min-height: 200px;
}
/* Linea de acento lateral izquierda al hover */
.events-page__card::before {
content: '';
position: absolute;
top: 0; left: 0; bottom: 0;
width: 3px;
background: var(--card-accent-gradient);
opacity: 0;
transition: opacity var(--transition-base);
z-index: 2;
border-radius: var(--radius-lg) 0 0 var(--radius-lg);
}
.events-page__card:hover {
transform: translateY(-3px);
box-shadow: var(--shadow-lg);
border-color: var(--card-hover-border);
}
.events-page__card:hover::before {
opacity: 1;
}
/* ── Poster: columna izquierda ~30%, formato vertical ── */
.events-page__card-media {
flex: 0 0 30%;
max-width: 30%;
background: var(--events-card-image-bg);
overflow: hidden;
position: relative;
display: flex;
align-items: stretch;
}
.events-page__card-image {
width: 100%;
height: 100%;
object-fit: contain;
object-position: center center;
display: block;
transition: transform var(--transition-slow);
}
.events-page__card:hover .events-page__card-image {
transform: scale(1.04);
}
/* ── Info: columna derecha ── */
.events-page__card-body {
display: flex;
flex-direction: column;
gap: 0.5rem;
padding: 1rem 1.125rem;
flex: 1;
min-width: 0;
}
/* ── Tags ── */
.events-page__card-tags {
display: flex;
flex-wrap: wrap;
gap: 0.375rem;
align-items: center;
}
.events-page__tag {
display: inline-flex;
align-items: center;
padding: 0.2rem 0.6rem;
border-radius: var(--radius-pill);
font-size: 0.68rem;
font-weight: 700;
letter-spacing: 0.06em;
text-transform: uppercase;
line-height: 1.4;
border: 1px solid transparent;
white-space: nowrap;
}
.events-page__tag--soft {
background: var(--secondary-background);
color: var(--text-secondary);
border-color: var(--border-color);
}
.events-page__tag--active {
background: rgba(0, 212, 160, 0.12);
color: var(--accent-dark);
border-color: var(--accent-color);
}
.events-page__tag--upcoming {
background: rgba(255, 122, 24, 0.12);
color: var(--highlight-energy-dark);
border-color: var(--highlight-energy);
}
.events-page__tag--finished {
background: var(--secondary-background);
color: var(--text-muted);
border-color: var(--border-color);
}
.events-page__tag--cancelled {
background: rgba(239, 68, 68, 0.10);
color: var(--danger-dark);
border-color: var(--danger-color);
}
.events-page__tag--primary {
background: rgba(29, 68, 204, 0.10);
color: var(--primary-dark);
border-color: var(--primary-color);
}
/* ── Titulo ── */
.events-page__card-title {
margin: 0;
font-size: 1rem;
font-weight: 700;
line-height: 1.3;
color: var(--text-color);
letter-spacing: -0.01em;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
overflow: hidden;
}
/* ── Fecha ── */
.events-page__card-date {
margin: 0;
font-size: 0.8125rem;
color: var(--primary-color);
font-weight: 600;
letter-spacing: 0.01em;
}
/* ── Lugar ── */
.events-page__card-venue {
margin: 0;
font-size: 0.8rem;
color: var(--text-muted);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
/* ── Acciones ── */
.events-page__card-actions {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
margin-top: auto;
padding-top: 0.75rem;
border-top: 1px solid var(--divider-color);
}
.events-page__card-button {
flex: 1;
min-width: 0;
font-size: 0.8125rem !important;
}
/* ═══════════════════════════════════════════════════
ESTADOS
═══════════════════════════════════════════════════ */
.events-page__state {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 0.75rem;
min-height: 14rem;
text-align: center;
padding: 2rem;
}
.events-page__state--loading { color: var(--text-muted); }
.events-page__state-title {
margin: 0;
font-size: 1.125rem;
font-weight: 700;
color: var(--text-color);
}
.events-page__state-description {
margin: 0;
color: var(--text-muted);
font-size: 0.9375rem;
}
/* ── Paginacion ── */
.events-page__pagination {
padding-top: 0.75rem;
border-top: 1px solid var(--divider-color);
}
/* ═══════════════════════════════════════════════════
RESPONSIVE
═══════════════════════════════════════════════════ */
/* Tablet: 1 columna de cards */
@media (max-width: 1100px) {
.events-page__grid {
grid-template-columns: 1fr;
}
.events-page__card-media {
flex: 0 0 32%;
max-width: 32%;
}
}
/* Filtros: 2 columnas */
@media (max-width: 900px) {
.events-page__filters {
grid-template-columns: 1fr 1fr;
}
.events-page__filter--search {
grid-column: 1 / -1;
}
}
/* Movil: card vertical (poster arriba, info abajo) */
@media (max-width: 600px) {
.events-page__card {
flex-direction: column;
min-height: unset;
}
.events-page__card::before {
top: 0; left: 0; right: 0; bottom: auto;
height: 3px;
width: auto;
border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.events-page__card-media {
flex: 0 0 auto;
max-width: 100%;
width: 100%;
height: 240px;
}
.events-page__filters {
grid-template-columns: 1fr;
}
.events-page__actions {
flex-direction: row;
width: 100%;
}
.events-page__toolbar,
.events-page__results {
border-radius: var(--radius-lg);
}
}
/* Desktop amplio: 2 columnas de cards */
@media (min-width: 1200px) {
.events-page__grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
}
/* =======================================================================
OmniaBP Design System — help.css (Ayuda / Soporte)
Hero y form como cards consistentes con el resto del sistema
======================================================================= */
.help {
display: flex;
flex-direction: column;
gap: 1.25rem;
width: 100%;
max-width: 1440px;
margin: 0 auto;
}
/* ── Hero card ── */
.help__hero {
position: relative;
border: 1.5px solid var(--border-color);
border-radius: var(--radius-xl);
background: var(--gradient-surface);
box-shadow: var(--shadow-lg);
overflow: hidden;
padding: clamp(1.5rem, 2.5vw, 2.25rem) clamp(1rem, 2vw, 1.5rem);
}
.help__hero::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
border-radius: var(--radius-xl) var(--radius-xl) 0 0;
background: var(--gradient-border);
pointer-events: none;
z-index: 1;
}
.help__hero-inner {
max-width: 860px;
margin: 0 auto;
text-align: center;
}
.help__title {
margin: 0 0 0.375rem;
font-size: clamp(1.375rem, 2.5vw, 1.875rem);
font-weight: 800;
color: var(--text-color);
letter-spacing: -0.02em;
display: inline-flex;
align-items: center;
gap: 0.75rem;
line-height: 1.2;
}
.help__title::before {
content: '💬';
font-size: 1.4rem;
opacity: 0.85;
}
.help__subtitle {
margin: 0 auto;
max-width: 680px;
color: var(--text-muted);
font-size: clamp(0.875rem, 1.1vw, 0.9375rem);
line-height: 1.6;
font-weight: 400;
}
/* ── Form card ── */
.help__form-section {
position: relative;
border: 1.5px solid var(--border-color);
border-radius: var(--radius-xl);
background: var(--gradient-surface);
box-shadow: var(--shadow-lg);
overflow: hidden;
padding: clamp(1.25rem, 2vw, 1.75rem) clamp(1rem, 2vw, 1.5rem);
}
.help__form-section::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
border-radius: var(--radius-xl) var(--radius-xl) 0 0;
background: var(--gradient-border);
pointer-events: none;
z-index: 1;
}
.help__form-container {
max-width: 680px;
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;
}
/* ── Responsive ── */
@media (max-width: 640px) {
.help__hero,
.help__form-section {
border-radius: var(--radius-lg);
}
.help__actions {
flex-direction: column;
}
}
/* =======================================================================
NexEvent — Home Page
Hero immersivo con grid sutil, cards con glow, CTA gradiente energia
======================================================================= */
.home-page {
display: flex;
flex-direction: column;
gap: clamp(1.5rem, 3vw, 2.5rem);
padding: clamp(0.75rem, 1.5vw, 1.25rem);
width: 100%;
max-width: min(100%, 1440px);
margin: 0 auto;
}
.home-page, .home-page *, .home-page *::before, .home-page *::after {
box-sizing: border-box;
}
/* Seccion base */
.home-page__hero,
.home-page__section,
.home-page__cta {
position: relative;
overflow: hidden;
width: 100%;
border: 1.5px solid var(--border-color);
border-radius: var(--radius-xl);
background: var(--gradient-surface);
box-shadow: var(--shadow-lg);
}
/* Acento superior en hero y secciones */
.home-page__hero::before,
.home-page__section::before {
content: "";
position: absolute;
inset: 0 0 auto 0;
height: 2px;
background: var(--card-accent-gradient);
}
/* Grid background sutil en hero */
.home-page__hero {
display: flex;
flex-direction: column;
gap: clamp(1.25rem, 2.5vw, 2rem);
padding: clamp(1.5rem, 3vw, 2.75rem);
isolation: isolate;
}
.home-page__hero::after {
content: "";
position: absolute;
inset: 3.5rem 2.5rem 2rem 2.5rem;
border: 1px solid var(--border-light);
border-radius: var(--radius-xl);
background:
repeating-linear-gradient(90deg, transparent 0, transparent 2.95rem, var(--border-light) 2.95rem, var(--border-light) 3rem),
repeating-linear-gradient(180deg, transparent 0, transparent 2.95rem, var(--border-light) 2.95rem, var(--border-light) 3rem);
opacity: 0.25;
pointer-events: none;
z-index: 0;
}
.home-page__hero-copy,
.home-page__hero-panel,
.home-page__cta { min-width: 0; }
.home-page__hero-copy,
.home-page__hero-panel { position: relative; z-index: 1; }
.home-page__hero-main {
position: relative;
z-index: 1;
display: grid;
grid-template-columns: minmax(0, 1.25fr) minmax(20rem, 24rem);
gap: 1.5rem;
align-items: start;
}
.home-page__hero-copy {
display: flex;
flex-direction: column;
justify-content: center;
max-width: 100%;
}
.home-page__brand-row {
display: flex;
align-items: center;
gap: 0.875rem;
margin-bottom: 1.25rem;
flex-wrap: wrap;
}
.home-page__brand-mark {
width: 3.25rem;
height: 3.25rem;
border-radius: var(--radius-md);
display: inline-flex;
align-items: center;
justify-content: center;
background: var(--glass-bg);
border: 1.5px solid var(--glass-border);
box-shadow: var(--shadow-md), var(--shadow-glow);
backdrop-filter: blur(var(--glass-blur));
-webkit-backdrop-filter: blur(var(--glass-blur));
}
.home-page__brand-mark img {
width: 2rem;
height: 2rem;
object-fit: contain;
}
.home-page__eyebrow {
display: inline-flex;
align-items: center;
padding: 0.45rem 0.9rem;
border-radius: var(--radius-pill);
background: var(--hover-background-color);
color: var(--primary-color);
font-size: 0.75rem;
font-weight: 700;
letter-spacing: 0.1em;
text-transform: uppercase;
border: 1px solid var(--primary-color);
}
.home-page__title {
margin: 0 0 1rem;
font-size: clamp(1.85rem, 3.4vw, 3.4rem);
line-height: 1;
letter-spacing: -0.04em;
max-width: 16ch;
text-wrap: balance;
}
.home-page__lead {
margin: 0 0 0.875rem;
font-size: clamp(1.05rem, 2vw, 1.3rem);
font-weight: 600;
color: var(--primary-color);
max-width: 50rem;
}
.home-page__description,
.home-page__section-subtitle,
.home-page__panel-subtitle,
.home-page__feature-description,
.home-page__journey-description,
.home-page__audience-description,
.home-page__signal-description,
.home-page__cta-description,
.home-page__metric-label { color: var(--text-muted); }
.home-page__description { margin: 0; max-width: 38rem; font-size: 0.9375rem; }
.home-page__hero-actions,
.home-page__cta-actions {
display: flex;
gap: 0.875rem;
margin-top: 1.75rem;
flex-wrap: wrap;
}
.home-page__chips {
display: flex;
flex-wrap: wrap;
gap: 0.75rem;
margin-top: 1.5rem;
max-width: 42rem;
}
.home-page__chip {
display: inline-flex;
align-items: center;
max-width: 100%;
padding: 0.55rem 0.95rem;
border-radius: var(--radius-pill);
border: 1.5px solid var(--border-color);
background: var(--surface-color);
color: var(--text-secondary);
box-shadow: var(--shadow-xs);
font-size: 0.875rem;
font-weight: 600;
transition: all var(--transition-base);
}
.home-page__chip:hover {
border-color: var(--primary-color);
color: var(--primary-color);
background: var(--hover-background-color);
}
/* Panel lateral del hero (glass card) */
.home-page__hero-panel {
display: flex;
flex-direction: column;
gap: 1rem;
width: 100%;
padding: 1.25rem;
border-radius: var(--radius-lg);
background: var(--glass-bg);
border: 1.5px solid var(--glass-border);
box-shadow: var(--shadow-md), var(--shadow-glow);
backdrop-filter: blur(var(--glass-blur));
-webkit-backdrop-filter: blur(var(--glass-blur));
position: relative;
overflow: hidden;
}
.home-page__hero-panel::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
background: var(--card-accent-gradient);
}
.home-page__panel-header { display: flex; flex-direction: column; gap: 0.6rem; }
.home-page__panel-status {
display: inline-flex;
align-items: center;
gap: 0.5rem;
color: var(--success-text);
font-size: 0.8125rem;
font-weight: 700;
flex-wrap: wrap;
letter-spacing: 0.04em;
text-transform: uppercase;
}
.home-page__panel-status-dot {
width: 0.6rem;
height: 0.6rem;
border-radius: 50%;
background: var(--success-color);
box-shadow: 0 0 0 0.2rem var(--success-background), 0 0 8px var(--success-color);
}
.home-page__panel-title,
.home-page__section-title,
.home-page__cta-title {
margin: 0;
font-size: clamp(1.35rem, 2.2vw, 2rem);
letter-spacing: -0.025em;
}
.home-page__hero-summary-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 0.75rem;
}
.home-page__hero-summary-card {
padding: 0.9rem;
border-radius: var(--radius-md);
border: 1px solid var(--border-color);
background: var(--surface-color);
box-shadow: var(--shadow-xs);
transition: all var(--transition-base);
}
.home-page__hero-summary-card:hover {
border-color: var(--card-hover-border);
box-shadow: var(--shadow-sm);
}
.home-page__hero-summary-value {
margin-bottom: 0.3rem;
color: var(--primary-color);
font-size: 0.9375rem;
font-weight: 800;
letter-spacing: -0.02em;
}
.home-page__hero-summary-label {
margin: 0;
color: var(--text-muted);
font-size: 0.8125rem;
line-height: 1.5;
}
/* Grids de contenido */
.home-page__signal-grid,
.home-page__metrics-grid,
.home-page__features-grid,
.home-page__audiences-grid { display: grid; gap: 0.875rem; }
.home-page__signal-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.home-page__metrics-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.home-page__features-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.home-page__audiences-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
/* Cards de contenido */
.home-page__signal-card,
.home-page__metric-card,
.home-page__feature-card,
.home-page__journey-card,
.home-page__audience-card {
position: relative;
border-radius: var(--radius-md);
border: 1.5px solid var(--border-color);
background: var(--surface-color);
box-shadow: var(--shadow-sm);
transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
overflow: hidden;
}
.home-page__signal-card::before,
.home-page__feature-card::before,
.home-page__audience-card::before {
content: "";
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
background: var(--card-accent-gradient);
opacity: 0;
transition: opacity var(--transition-base);
}
.home-page__signal-card:hover,
.home-page__metric-card:hover,
.home-page__feature-card:hover,
.home-page__journey-card:hover,
.home-page__audience-card:hover {
transform: translateY(-3px);
box-shadow: var(--shadow-lg), var(--shadow-glow);
border-color: var(--card-hover-border);
}
.home-page__signal-card:hover::before,
.home-page__feature-card:hover::before,
.home-page__audience-card:hover::before { opacity: 1; }
.home-page__signal-card { padding: 1.1rem; }
.home-page__metric-card { padding: 1.35rem; background: var(--gradient-surface); }
.home-page__feature-card, .home-page__audience-card { padding: 1.35rem; }
.home-page__metric-value {
margin-bottom: 0.5rem;
color: var(--primary-color);
font-size: 1.125rem;
font-weight: 800;
letter-spacing: -0.02em;
}
.home-page__signal-title,
.home-page__feature-title,
.home-page__journey-title,
.home-page__audience-title {
margin: 0 0 0.65rem;
font-size: 0.9375rem;
font-weight: 700;
}
/* Section */
.home-page__section {
padding: clamp(1.5rem, 3vw, 2.5rem);
}
.home-page__section-header {
display: flex;
flex-direction: column;
gap: 0.6rem;
margin-bottom: 1.5rem;
}
/* Journey */
.home-page__section--journey { background: var(--surface-alt-color); }
.home-page__journey-list {
display: grid;
grid-template-columns: repeat(5, minmax(0, 1fr));
gap: 0.875rem;
counter-reset: journey-step;
}
.home-page__journey-card {
padding: 1.35rem 1.1rem 1.1rem;
counter-increment: journey-step;
}
.home-page__journey-card::before {
content: counter(journey-step, decimal-leading-zero);
display: inline-flex;
align-items: center;
justify-content: center;
width: 2.25rem;
height: 2.25rem;
margin-bottom: 1rem;
border-radius: var(--radius-pill);
background: var(--gradient-primary);
color: #ffffff;
box-shadow: var(--shadow-sm), var(--shadow-glow);
font-size: 0.8125rem;
font-weight: 800;
letter-spacing: 0.02em;
}
/* CTA */
.home-page__cta {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1.5rem;
padding: clamp(1.5rem, 3vw, 2.5rem);
background: var(--gradient-primary);
border-color: transparent;
}
.home-page__cta-content { color: #ffffff; }
.home-page__cta-content, .home-page__cta-content > * { color: #ffffff !important; }
.home-page__cta-content .home-page__cta-title,
.home-page__cta-content .home-page__cta-description { color: #ffffff; }
.home-page__cta-description { max-width: 52rem; opacity: 0.9; }
.home-page__cta-actions .app-button--outline {
border-color: rgba(255,255,255,0.7);
color: #ffffff;
background: transparent;
}
.home-page__cta-actions .app-button--outline:hover {
background: rgba(255,255,255,0.15);
border-color: #ffffff;
}
/* Responsive */
@media (max-width: 1200px) {
.home-page__hero-main { grid-template-columns: 1fr; }
.home-page__hero::after { display: none; }
.home-page__signal-grid, .home-page__metrics-grid, .home-page__audiences-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.home-page__features-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.home-page__journey-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.home-page__cta { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 768px) {
.home-page { gap: 1.5rem; padding: 0.75rem; }
.home-page__hero, .home-page__section, .home-page__cta { border-radius: var(--radius-lg); }
.home-page__hero-main, .home-page__hero-summary-grid, .home-page__signal-grid,
.home-page__metrics-grid, .home-page__features-grid, .home-page__journey-list, .home-page__audiences-grid { grid-template-columns: 1fr; }
.home-page__title { max-width: none; font-size: clamp(1.75rem, 9vw, 2.75rem); }
.home-page__chip, .home-page__eyebrow { width: 100%; justify-content: center; text-align: center; }
.home-page__hero-actions, .home-page__cta-actions { width: 100%; }
.home-page__hero-actions .app-button, .home-page__cta-actions .app-button { width: 100%; }
}
/* =======================================================================
NexEvent — Login Page
Pantalla de acceso con fondo hero oscuro y card glass
======================================================================= */
:host, .login-page, .auth-container {
min-height: 100dvh;
height: 100dvh;
box-sizing: border-box;
overflow-y: auto;
display: flex;
flex-direction: column;
align-items: center;
justify-content: flex-start;
padding-bottom: 40vh;
padding-top: 4vh;
background-image:
radial-gradient(ellipse 70% 50% at 15% 10%, rgba(124,58,237,0.18) 0%, transparent 55%),
radial-gradient(ellipse 50% 40% at 85% 15%, rgba(6,182,212,0.12) 0%, transparent 50%);
}
.login-page__card {
background: var(--surface-color);
border-radius: var(--radius-xl);
box-shadow: var(--shadow-xl), var(--shadow-glow);
padding: 2.75rem 2.25rem 2.25rem 2.25rem;
max-width: 480px;
width: 95vw;
min-width: 320px;
margin: 0 auto;
display: flex;
flex-direction: column;
align-items: stretch;
border: 1.5px solid var(--border-color);
margin-bottom: 2rem;
position: relative;
}
.login-page__card::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
background: var(--card-accent-gradient);
}
.login-page__header {
text-align: center;
margin-bottom: 2rem;
}
.login-page__logo {
width: 64px;
height: 64px;
margin-bottom: 1rem;
filter: drop-shadow(0 2px 12px rgba(124,58,237,0.35));
}
.login-page__title {
margin: 0 0 0.5rem 0;
font-weight: 800;
color: var(--primary-color);
letter-spacing: -0.03em;
}
.login-page__subtitle {
color: var(--text-muted);
font-size: 0.9375rem;
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.5rem 1rem;
max-width: 98vw;
margin-bottom: 1.5rem;
border-radius: var(--radius-lg);
}
.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: var(--radius-sm);
box-shadow: var(--shadow-sm);
}
}
/* =======================================================================
OmniaBP Design System — services.css
Hero y secciones como cards consistentes con el resto del sistema
======================================================================= */
.services {
display: flex;
flex-direction: column;
gap: 1.25rem;
width: 100%;
max-width: 1440px;
margin: 0 auto;
}
/* ── Hero card ── */
.services__hero {
position: relative;
border: 1.5px solid var(--border-color);
border-radius: var(--radius-xl);
background: var(--gradient-surface);
box-shadow: var(--shadow-lg);
overflow: hidden;
padding: clamp(1.5rem, 2.5vw, 2.25rem) clamp(1rem, 2vw, 1.5rem);
}
.services__hero::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
border-radius: var(--radius-xl) var(--radius-xl) 0 0;
background: var(--gradient-border);
pointer-events: none;
z-index: 1;
}
.services__hero-inner {
max-width: 1100px;
margin: 0 auto;
text-align: center;
}
.services__title {
font-size: clamp(1.375rem, 2.5vw, 1.875rem);
line-height: 1.2;
margin: 0 0 0.375rem;
font-weight: 800;
color: var(--text-color);
letter-spacing: -0.02em;
display: inline-flex;
align-items: center;
gap: 0.75rem;
}
.services__title::before {
content: '⚡';
font-size: 1.4rem;
opacity: 0.85;
}
.services__subtitle {
font-size: clamp(0.875rem, 1.1vw, 0.9375rem);
margin: 0 auto;
max-width: 680px;
color: var(--text-muted);
line-height: 1.6;
font-weight: 400;
}
/* ── Grid de servicios (section card) ── */
.services__grid-section {
position: relative;
border: 1.5px solid var(--border-color);
border-radius: var(--radius-xl);
background: var(--gradient-surface);
box-shadow: var(--shadow-lg);
overflow: hidden;
padding: clamp(1.25rem, 2vw, 1.75rem) clamp(1rem, 2vw, 1.5rem);
}
.services__grid-section::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
border-radius: var(--radius-xl) var(--radius-xl) 0 0;
background: var(--gradient-border);
pointer-events: none;
z-index: 1;
}
.services__grid {
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: var(--card-accent-gradient);
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.9375rem;
}
/* Empty state */
.services__empty {
grid-column: 1 / -1;
text-align: center;
color: var(--text-muted);
padding: 2rem;
}
/* ── CTA card ── */
.services__cta {
position: relative;
border-radius: var(--radius-xl);
overflow: hidden;
box-shadow: var(--shadow-xl), var(--shadow-glow);
}
.services__cta-inner {
background: var(--gradient-energy);
color: var(--primary-foreground);
border-radius: var(--radius-xl);
padding: clamp(2rem, 3vw, 3rem) clamp(1.5rem, 2.5vw, 2.5rem);
text-align: center;
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.08;
border-radius: 50%;
pointer-events: none;
}
.services__cta-title {
margin: 0 0 0.75rem;
font-size: clamp(1.25rem, 2vw, 1.625rem);
font-weight: 800;
letter-spacing: -0.02em;
color: var(--primary-foreground);
}
.services__cta-text {
margin: 0 auto 1.5rem;
color: var(--primary-foreground);
opacity: 0.92;
max-width: 600px;
font-size: 0.9375rem;
line-height: 1.6;
}
/* ── Responsive ── */
@media (max-width: 1024px) {
.services__grid {
grid-template-columns: repeat(2, 1fr);
}
}
@media (max-width: 640px) {
.services__hero,
.services__grid-section,
.services__cta {
border-radius: var(--radius-lg);
}
.services__grid {
grid-template-columns: 1fr;
}
.services__card {
grid-template-columns: 40px 1fr;
}
.services__card-icon {
width: 40px;
height: 40px;
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;
}
}
/* =======================================================================
NexEvent — MainLayout
Layout principal con background deep space y blobs de luz
======================================================================= */
:root {
--layout-content-padding: clamp(12px, 2vw, 20px);
--layout-topbar-height: 68px;
--layout-topbar-gap: 1.5rem;     /* espacio fijo entre TopBar y contenido */
--layout-sidebar-width: min(320px, 90vw);
--layout-shell-max-width: 1540px;
}
.main-layout {
position: relative;
min-height: 100dvh;
display: flex;
flex-direction: column;
background: transparent;
overflow: clip; /* clip recorta visualmente sin crear scroll container — sticky funciona */
}
/* Blobs de luz ambiente — Tech atmosphere */
.main-layout::before,
.main-layout::after {
content: "";
position: fixed;
inset: auto;
border-radius: 999px;
pointer-events: none;
z-index: -1;
transition: background var(--transition-slow);
}
.main-layout::before {
width: 40rem;
height: 40rem;
top: -14rem;
left: -12rem;
background: radial-gradient(circle, rgba(29, 68, 204, 0.10) 0%, transparent 70%);
filter: blur(60px);
}
.main-layout::after {
width: 36rem;
height: 36rem;
top: 6rem;
right: -14rem;
background: radial-gradient(circle, rgba(0, 212, 160, 0.07) 0%, transparent 70%);
filter: blur(60px);
}
.content-area {
position: relative;
padding: var(--layout-content-padding);
padding-top: var(--layout-topbar-gap);
transition: margin-left 0.28s cubic-bezier(0.4, 0, 0.2, 1);
display: block;
}
main.content-area {
padding-top: var(--layout-topbar-gap);
min-height: calc(100dvh - var(--layout-topbar-height));
}
@media (min-width: 1024px) {
.content-area--shifted {
margin-left: var(--layout-sidebar-width);
}
}
/* ── AdminFloorPlanWizard ───────────────────────────────────────────── */
.afp-wizard {
display: flex;
flex-direction: column;
gap: 1.5rem;
padding: 0.5rem 0;
}
/* Indicador de pasos */
.afp-wizard__steps {
display: flex;
align-items: center;
gap: 0;
}
.afp-wizard__step {
display: flex;
align-items: center;
gap: 0.5rem;
font-size: 0.85rem;
color: var(--text-secondary);
transition: color 0.2s;
}
.afp-wizard__step--active {
color: var(--color-primary);
font-weight: 600;
}
.afp-wizard__step--done {
color: var(--success-foreground);
}
.afp-wizard__step-num {
width: 1.6rem;
height: 1.6rem;
border-radius: 50%;
background: var(--input-background);
border: 2px solid var(--border-color);
display: flex;
align-items: center;
justify-content: center;
font-size: 0.78rem;
font-weight: 700;
}
.afp-wizard__step--active .afp-wizard__step-num {
background: var(--color-primary);
border-color: var(--color-primary);
color: #fff;
}
.afp-wizard__step--done .afp-wizard__step-num {
background: var(--success-background);
border-color: var(--success-foreground);
color: var(--success-foreground);
}
.afp-wizard__step-sep {
flex: 1;
height: 2px;
background: var(--border-color);
margin: 0 0.5rem;
min-width: 2rem;
}
/* Cuerpo de cada paso */
.afp-wizard__body {
display: flex;
flex-direction: column;
gap: 1rem;
}
.afp-wizard__row {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 1rem;
}
@media (max-width: 600px) {
.afp-wizard__row {
grid-template-columns: 1fr;
}
}
/* Drop zone (paso 2) */
.afp-wizard__dropzone {
position: relative;
min-height: 180px;
border: 2px dashed var(--border-color);
border-radius: 8px;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: border-color 0.2s, background 0.2s;
overflow: hidden;
}
.afp-wizard__dropzone--active,
.afp-wizard__dropzone:hover {
border-color: var(--color-primary);
background: var(--hover-background);
}
.afp-wizard__dropzone-hint {
font-size: 0.9rem;
color: var(--text-secondary);
text-align: center;
padding: 1rem;
}
.afp-wizard__dropzone-preview {
max-width: 100%;
max-height: 220px;
object-fit: contain;
}
.afp-wizard__dropzone-input {
position: absolute;
inset: 0;
opacity: 0;
cursor: pointer;
width: 100%;
height: 100%;
z-index: 2;
}
.afp-wizard__uploading {
display: flex;
justify-content: center;
padding: 0.5rem;
}
/* Editor (paso 3) */
.afp-wizard__body--editor {
gap: 0.75rem;
}
.afp-wizard__toolbar {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
align-items: center;
padding: 0.5rem;
background: var(--card-background);
border: 1px solid var(--border-color);
border-radius: 6px;
}
.afp-wizard__toolbar-spacer { flex: 1; }
/* Error */
.afp-wizard__error {
padding: 0.6rem 1rem;
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: 6px;
font-size: 0.875rem;
}
/* ── AdminFloorPlanSlotModal ────────────────────────────────────────── */
.afp-slot-modal__form {
display: flex;
flex-direction: column;
gap: 1rem;
}
.afp-slot-modal__row {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 1rem;
}
@media (max-width: 600px) {
.afp-slot-modal__row {
grid-template-columns: 1fr;
}
}
.afp-slot-modal__shape-info {
background: var(--input-background);
border: 1px solid var(--border-color);
border-radius: 6px;
padding: 0.5rem 0.75rem;
font-size: 0.8rem;
display: flex;
gap: 0.5rem;
align-items: baseline;
flex-wrap: wrap;
}
.afp-slot-modal__shape-label {
color: var(--text-secondary);
font-weight: 600;
}
.afp-slot-modal__shape-code {
color: var(--color-primary);
word-break: break-all;
}
.afp-slot-modal__error {
padding: 0.6rem 1rem;
background: var(--danger-background);
color: var(--danger-foreground);
border-radius: 6px;
font-size: 0.875rem;
}
/* ── AdminFloorPlansPage — secciones adicionales ───────────────────── */
.admin-floor-plans-page__loading {
display: flex;
justify-content: center;
padding: 2rem;
}
.admin-floor-plans-page__empty {
display: flex;
flex-direction: column;
align-items: center;
gap: 1rem;
padding: 3rem 1rem;
color: var(--text-secondary);
}
.admin-floor-plans-page__list {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
gap: 1rem;
padding: 1rem 0;
}
.admin-floor-plans-page__card {
background: var(--card-background);
border: 1px solid var(--border-color);
border-radius: 8px;
padding: 1rem;
display: flex;
flex-direction: column;
gap: 0.5rem;
transition: box-shadow 0.2s;
}
.admin-floor-plans-page__card:hover {
box-shadow: 0 2px 8px var(--shadow-color, rgba(0,0,0,0.12));
}
.admin-floor-plans-page__card-header {
display: flex;
justify-content: space-between;
align-items: center;
gap: 0.5rem;
}
.admin-floor-plans-page__card-name {
font-weight: 600;
font-size: 1rem;
color: var(--text-primary);
}
.admin-floor-plans-page__card-status {
font-size: 0.72rem;
font-weight: 700;
text-transform: uppercase;
padding: 0.15rem 0.55rem;
border-radius: 20px;
}
.admin-floor-plans-page__card-status--draft    { background: var(--warning-background); color: var(--warning-foreground); }
.admin-floor-plans-page__card-status--active   { background: var(--success-background); color: var(--success-foreground); }
.admin-floor-plans-page__card-status--inactive { background: var(--color-disabled-bg, var(--input-background)); color: var(--text-secondary); }
.admin-floor-plans-page__card-meta {
font-size: 0.8rem;
color: var(--text-secondary);
}
.admin-floor-plans-page__card-actions {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
margin-top: 0.25rem;
}
.admin-floor-plans-page__editor {
display: flex;
flex-direction: column;
gap: 0.75rem;
margin-top: 1rem;
padding: 1rem;
background: var(--card-background);
border: 1px solid var(--border-color);
border-radius: 8px;
}
.admin-floor-plans-page__editor-toolbar {
display: flex;
gap: 0.5rem;
flex-wrap: wrap;
}
/* Editor SVG styles — usados por FloorPlanRenderer en modo admin */
.fp-renderer__svg--editor {
cursor: crosshair;
}
.fp-editor__preview {
fill: var(--color-primary);
fill-opacity: 0.25;
stroke: var(--color-primary);
stroke-width: 2;
stroke-dasharray: 6 4;
pointer-events: none;
}
.fp-editor__poly-cursor {
fill: var(--color-primary);
opacity: 0.7;
pointer-events: none;
}
/* ============================================================
admin-floor-plans-page — BEM namespace
Página hub administrativa del plano de exposición de un evento.
============================================================ */
.admin-floor-plans-page {
display: flex;
flex-direction: column;
gap: 1.25rem;
width: 100%;
min-height: 0;
}
/* Mensaje de acceso denegado */
.admin-floor-plans-page__error {
padding: 2rem;
text-align: center;
color: var(--danger-foreground);
font-size: 1rem;
}
/* Barra de acciones rápidas */
.admin-floor-plans-page__actions-bar {
display: flex;
flex-wrap: wrap;
gap: 0.75rem;
padding: 0 0.25rem;
}
/* Contenedor del plano */
.admin-floor-plans-page__floor-plan {
flex: 1;
min-height: 0;
border-radius: 0.5rem;
overflow: hidden;
background: var(--surface-background);
border: 1px solid var(--border-color);
}
/* ── Responsivo ─────────────────────────────────────────────── */
@media (max-width: 600px) {
.admin-floor-plans-page__actions-bar {
flex-direction: column;
}
}
/* -- Modo editor (pantalla completa) ------------------------------------ */
.admin-floor-plans-page--editor-mode {
display: flex;
flex-direction: column;
height: calc(100vh - 56px);
gap: 0;
}
.admin-floor-plans-page__editor-header {
display: flex;
align-items: center;
gap: 12px;
padding: 8px 16px;
background: var(--surface-secondary);
border-bottom: 1px solid var(--border-color);
flex-shrink: 0;
}
.admin-floor-plans-page__back-btn {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 5px 12px;
border: 1px solid var(--border-color);
border-radius: 6px;
background: var(--surface-primary);
color: var(--text-primary);
font-size: 0.85rem;
cursor: pointer;
transition: background .15s;
}
.admin-floor-plans-page__back-btn:hover { background: var(--surface-hover); }
.admin-floor-plans-page__editor-title {
font-weight: 600;
font-size: 1rem;
flex: 1;
}
.admin-floor-plans-page__editor-body {
flex: 1;
min-height: 0;
padding: 12px;
display: flex;
flex-direction: column;
}
/* ── AppFormStandStripe ─────────────────────────────────────────────────────
Componente de pago Stripe para stands.
BEM namespace: appform-stand-stripe
───────────────────────────────────────────────────────────────────────── */
.appform-stand-stripe {
display: flex;
flex-direction: column;
gap: 1.25rem;
width: 100%;
}
/* ── Campo de tarjeta ────────────────────────────────────────────────────── */
.appform-stand-stripe__field-group {
display: flex;
flex-direction: column;
gap: 0.5rem;
}
.appform-stand-stripe__label {
display: flex;
align-items: center;
gap: 0.5rem;
font-size: 0.875rem;
font-weight: 600;
color: var(--label-foreground);
}
.appform-stand-stripe__label-icon {
width: 1rem;
height: 1rem;
opacity: 0.7;
}
.appform-stand-stripe__card-mount {
padding: 0.75rem 1rem;
border: 1.5px solid var(--input-border);
border-radius: 0.5rem;
background: var(--input-background);
transition: border-color 0.2s;
min-height: 2.75rem;
}
.appform-stand-stripe__card-mount--error {
border-color: var(--danger-foreground);
}
.appform-stand-stripe__field-error {
display: flex;
align-items: center;
gap: 0.375rem;
font-size: 0.8125rem;
color: var(--danger-foreground);
}
/* ── Loading ─────────────────────────────────────────────────────────────── */
.appform-stand-stripe__loading {
display: flex;
align-items: center;
justify-content: center;
gap: 0.375rem;
padding: 0.75rem;
}
.appform-stand-stripe__loading-dot {
width: 8px;
height: 8px;
border-radius: 50%;
background: var(--primary-foreground);
animation: stand-stripe-dot-pulse 1.2s ease-in-out infinite;
}
.appform-stand-stripe__loading-dot:nth-child(2) { animation-delay: 0.2s; }
.appform-stand-stripe__loading-dot:nth-child(3) { animation-delay: 0.4s; }
@keyframes stand-stripe-dot-pulse {
0%, 80%, 100% { opacity: 0.25; transform: scale(0.85); }
40%            { opacity: 1;    transform: scale(1);    }
}
/* ── Acciones ────────────────────────────────────────────────────────────── */
.appform-stand-stripe__actions {
display: flex;
justify-content: flex-end;
}
.appform-stand-stripe__pay-btn {
display: flex;
align-items: center;
gap: 0.5rem;
min-width: 180px;
justify-content: center;
}
.appform-stand-stripe--processing .appform-stand-stripe__card-mount {
opacity: 0.6;
pointer-events: none;
}
/* ── Spinner inline ──────────────────────────────────────────────────────── */
.appform-stand-stripe__spinner {
width: 1rem;
height: 1rem;
border: 2px solid rgba(255, 255, 255, 0.4);
border-top-color: #fff;
border-radius: 50%;
animation: stand-stripe-spin 0.7s linear infinite;
flex-shrink: 0;
}
@keyframes stand-stripe-spin {
to { transform: rotate(360deg); }
}
/* ── Recovery ────────────────────────────────────────────────────────────── */
.appform-stand-stripe__recovery {
padding: 1rem;
border-radius: 0.5rem;
background: var(--warning-background);
color: var(--warning-foreground);
font-size: 0.875rem;
line-height: 1.5;
}
.appform-stand-stripe__recovery-ref {
font-family: monospace;
font-size: 0.8125rem;
margin-top: 0.375rem;
word-break: break-all;
opacity: 0.85;
}
/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 480px) {
.appform-stand-stripe__pay-btn {
width: 100%;
}
.appform-stand-stripe__actions {
justify-content: stretch;
}
}
/* =============================================================
cfdi-manual-wizard.css
Namespace BEM: cfdi-manual-wiz
============================================================= */
/* ── Modal contenedor ──────────────────────────────────────── */
.cfdi-manual-wiz {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
/* ── Stepper ────────────────────────────────────────────────── */
.cfdi-manual-wiz__stepper {
display: flex;
align-items: center;
justify-content: center;
gap: 0;
padding: 0.25rem 0 0.75rem;
flex-wrap: nowrap;
overflow-x: auto;
}
.cfdi-manual-wiz__step {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.35rem;
flex-shrink: 0;
}
.cfdi-manual-wiz__step-bubble {
width: 2rem;
height: 2rem;
border-radius: 50%;
border: 2px solid var(--border-color);
background: var(--surface-background);
color: var(--text-secondary);
font-size: 0.8rem;
font-weight: 600;
display: flex;
align-items: center;
justify-content: center;
transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.cfdi-manual-wiz__step--active .cfdi-manual-wiz__step-bubble {
border-color: var(--primary-color);
background: var(--primary-color);
color: var(--primary-foreground);
}
.cfdi-manual-wiz__step--done .cfdi-manual-wiz__step-bubble {
border-color: var(--success-color);
background: var(--success-background);
color: var(--success-foreground);
}
.cfdi-manual-wiz__step-label {
font-size: 0.7rem;
color: var(--text-secondary);
white-space: nowrap;
}
.cfdi-manual-wiz__step--active .cfdi-manual-wiz__step-label {
color: var(--primary-color);
font-weight: 600;
}
.cfdi-manual-wiz__step--done .cfdi-manual-wiz__step-label {
color: var(--success-foreground);
}
.cfdi-manual-wiz__step-line {
height: 2px;
width: 2.5rem;
background: var(--border-color);
flex-shrink: 0;
margin: 0 0.1rem;
margin-bottom: 1.2rem;
transition: background 0.2s;
}
.cfdi-manual-wiz__step-line--done {
background: var(--success-color);
}
/* ── Banner de error ────────────────────────────────────────── */
.cfdi-manual-wiz__error-banner {
background: var(--danger-background);
color: var(--danger-foreground);
border: 1px solid var(--danger-color);
border-radius: 0.5rem;
padding: 0.65rem 1rem;
font-size: 0.875rem;
}
/* ── Cuerpo del paso ────────────────────────────────────────── */
.cfdi-manual-wiz__step-body {
display: flex;
flex-direction: column;
gap: 1rem;
}
.cfdi-manual-wiz__section-title {
font-size: 0.95rem;
font-weight: 600;
color: var(--text-primary);
margin: 0 0 0.25rem;
}
/* ── Layouts de campos ──────────────────────────────────────── */
.cfdi-manual-wiz__field-group {
display: flex;
flex-direction: column;
gap: 0.35rem;
}
.cfdi-manual-wiz__row {
display: grid;
gap: 0.75rem;
}
.cfdi-manual-wiz__row--2 { grid-template-columns: 1fr 1fr; }
.cfdi-manual-wiz__row--3 { grid-template-columns: 1fr 1fr 1fr; }
@media (max-width: 640px) {
.cfdi-manual-wiz__row--2,
.cfdi-manual-wiz__row--3 {
grid-template-columns: 1fr;
}
}
/* ── Labels ─────────────────────────────────────────────────── */
.cfdi-manual-wiz__label {
font-size: 0.8rem;
font-weight: 500;
color: var(--text-secondary);
}
.cfdi-manual-wiz__required {
color: var(--danger-color);
margin-left: 0.15rem;
}
.cfdi-manual-wiz__hint {
font-size: 0.75rem;
color: var(--text-secondary);
margin: 0;
}
.cfdi-manual-wiz__hint--warn {
color: var(--warning-foreground);
background: var(--warning-background);
border-left: 3px solid var(--warning-color);
padding: 0.4rem 0.65rem;
border-radius: 0.25rem;
}
.cfdi-manual-wiz__hint--info {
color: var(--info-foreground);
background: var(--info-background);
border-left: 3px solid var(--info-color);
padding: 0.4rem 0.65rem;
border-radius: 0.25rem;
}
/* ── Conceptos ──────────────────────────────────────────────── */
.cfdi-manual-wiz__concepts-header {
display: flex;
align-items: center;
justify-content: space-between;
}
.cfdi-manual-wiz__concepts-empty {
text-align: center;
color: var(--text-secondary);
padding: 1.5rem;
border: 1px dashed var(--border-color);
border-radius: 0.5rem;
font-size: 0.875rem;
}
.cfdi-manual-wiz__concept-card {
border: 1px solid var(--border-color);
border-radius: 0.5rem;
padding: 1rem;
display: flex;
flex-direction: column;
gap: 0.75rem;
background: var(--surface-background);
}
.cfdi-manual-wiz__concept-header {
display: flex;
align-items: center;
justify-content: space-between;
}
.cfdi-manual-wiz__concept-num {
font-size: 0.8rem;
font-weight: 600;
color: var(--primary-color);
}
/* Impuesto — radio group */
.cfdi-manual-wiz__tax-row {
display: flex;
flex-direction: column;
gap: 0.4rem;
}
.cfdi-manual-wiz__tax-options {
display: flex;
gap: 1.25rem;
flex-wrap: wrap;
}
.cfdi-manual-wiz__tax-option {
display: flex;
align-items: center;
gap: 0.4rem;
font-size: 0.85rem;
color: var(--text-primary);
cursor: pointer;
}
.cfdi-manual-wiz__tax-option input[type="radio"] {
accent-color: var(--primary-color);
cursor: pointer;
}
/* Preview del concepto */
.cfdi-manual-wiz__concept-preview {
display: flex;
gap: 1.25rem;
flex-wrap: wrap;
padding: 0.5rem 0.75rem;
background: var(--background-secondary);
border-radius: 0.35rem;
font-size: 0.8rem;
color: var(--text-secondary);
}
.cfdi-manual-wiz__concept-preview strong {
color: var(--text-primary);
}
/* ── Totales ────────────────────────────────────────────────── */
.cfdi-manual-wiz__totals {
border-top: 1px solid var(--border-color);
padding-top: 0.75rem;
display: flex;
flex-direction: column;
gap: 0.35rem;
align-items: flex-end;
}
.cfdi-manual-wiz__totals-row {
display: flex;
gap: 2rem;
font-size: 0.875rem;
color: var(--text-secondary);
min-width: 16rem;
justify-content: space-between;
}
.cfdi-manual-wiz__totals-row--total {
font-size: 1rem;
font-weight: 700;
color: var(--text-primary);
border-top: 1px solid var(--border-color);
padding-top: 0.35rem;
}
.cfdi-manual-wiz__totals-disclaimer {
font-size: 0.7rem;
color: var(--text-secondary);
margin: 0;
font-style: italic;
}
/* ── Summary card (paso 4) ──────────────────────────────────── */
.cfdi-manual-wiz__summary-card {
border: 1px solid var(--border-color);
border-radius: 0.5rem;
overflow: hidden;
}
.cfdi-manual-wiz__summary-row {
display: flex;
justify-content: space-between;
padding: 0.55rem 0.85rem;
font-size: 0.875rem;
border-bottom: 1px solid var(--border-color);
}
.cfdi-manual-wiz__summary-row:last-child { border-bottom: none; }
.cfdi-manual-wiz__summary-row span {
color: var(--text-secondary);
}
.cfdi-manual-wiz__summary-row--total {
background: var(--background-secondary);
font-weight: 700;
}
/* ── Loading ────────────────────────────────────────────────── */
.cfdi-manual-wiz__loading {
display: flex;
align-items: center;
gap: 0.75rem;
color: var(--text-secondary);
font-size: 0.875rem;
padding: 0.5rem 0;
}
/* ── Resultado ──────────────────────────────────────────────── */
.cfdi-manual-wiz__result {
display: flex;
flex-direction: column;
align-items: center;
gap: 1rem;
padding: 1.5rem;
border-radius: 0.75rem;
text-align: center;
}
.cfdi-manual-wiz__result--success {
background: var(--success-background);
border: 1px solid var(--success-color);
}
.cfdi-manual-wiz__result--error {
background: var(--danger-background);
border: 1px solid var(--danger-color);
}
.cfdi-manual-wiz__result-icon {
font-size: 2.5rem;
line-height: 1;
}
.cfdi-manual-wiz__result--success .cfdi-manual-wiz__result-icon { color: var(--success-foreground); }
.cfdi-manual-wiz__result--error  .cfdi-manual-wiz__result-icon { color: var(--danger-foreground); }
.cfdi-manual-wiz__result-title {
font-size: 1.1rem;
font-weight: 700;
color: var(--text-primary);
margin: 0;
}
.cfdi-manual-wiz__result-list {
display: grid;
grid-template-columns: auto 1fr;
gap: 0.35rem 1rem;
text-align: left;
font-size: 0.875rem;
width: 100%;
max-width: 28rem;
}
.cfdi-manual-wiz__result-list dt {
color: var(--text-secondary);
font-weight: 500;
}
.cfdi-manual-wiz__result-list dd {
color: var(--text-primary);
margin: 0;
word-break: break-all;
}
.cfdi-manual-wiz__result-uuid {
font-family: monospace;
font-size: 0.8rem;
}
.cfdi-manual-wiz__result-note {
font-size: 0.82rem;
color: var(--text-secondary);
background: var(--background-secondary);
border-radius: 0.35rem;
padding: 0.5rem 0.75rem;
max-width: 28rem;
}
.cfdi-manual-wiz__result-error-msg {
color: var(--danger-foreground);
font-size: 0.9rem;
max-width: 30rem;
}
/* ── Navegación ─────────────────────────────────────────────── */
.cfdi-manual-wiz__nav {
display: flex;
justify-content: flex-end;
gap: 0.75rem;
padding-top: 0.5rem;
border-top: 1px solid var(--border-color);
}
/* ── stamp-complement-modal (componente auxiliar) ────────────── */
.stamp-complement-modal {
display: flex;
flex-direction: column;
gap: 1rem;
}
.stamp-complement-modal__subtitle {
font-size: 0.875rem;
color: var(--text-secondary);
margin: 0;
}
.stamp-complement-modal__info {
font-size: 0.875rem;
color: var(--text-secondary);
margin: 0;
}
.stamp-complement-modal__field {
display: flex;
flex-direction: column;
gap: 0.3rem;
}
.stamp-complement-modal__label {
font-size: 0.8rem;
font-weight: 500;
color: var(--text-secondary);
}
.stamp-complement-modal__required {
color: var(--danger-color);
margin-left: 0.15rem;
}
.stamp-complement-modal__hint {
font-size: 0.75rem;
color: var(--text-secondary);
margin: 0;
}
.stamp-complement-modal__error {
background: var(--danger-background);
color: var(--danger-foreground);
border: 1px solid var(--danger-color);
border-radius: 0.4rem;
padding: 0.55rem 0.75rem;
font-size: 0.85rem;
}
.stamp-complement-modal__loading {
display: flex;
align-items: center;
gap: 0.6rem;
font-size: 0.875rem;
color: var(--text-secondary);
}
.stamp-complement-modal__actions {
display: flex;
justify-content: flex-end;
gap: 0.65rem;
}
.stamp-complement-modal__success {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.85rem;
padding: 1rem;
background: var(--success-background);
border: 1px solid var(--success-color);
border-radius: 0.6rem;
text-align: center;
}
.stamp-complement-modal__success-icon {
font-size: 2rem;
color: var(--success-foreground);
}
.stamp-complement-modal__success-title {
font-size: 1rem;
font-weight: 700;
color: var(--text-primary);
margin: 0;
}
.stamp-complement-modal__result-list {
display: grid;
grid-template-columns: auto 1fr;
gap: 0.3rem 1rem;
text-align: left;
font-size: 0.875rem;
width: 100%;
max-width: 22rem;
}
.stamp-complement-modal__result-list dt { color: var(--text-secondary); }
.stamp-complement-modal__result-list dd { color: var(--text-primary); margin: 0; }
.stamp-complement-modal__uuid {
font-family: monospace;
font-size: 0.78rem;
word-break: break-all;
}
/* ═══════════════════════════════════════════════════════════════════════
finkok-report-modals.css
Estilos compartidos y específicos para los 3 modales de utilidades Finkok:
- FinkokReportCreditModal  (.finkok-credit-modal)
- FinkokReportTotalModal   (.finkok-total-modal)
- FinkokReportUuidModal    (.finkok-uuid-modal)
Fuente: SHARED/wwwroot/css/ (incluido automáticamente por post-build)
═══════════════════════════════════════════════════════════════════════ */
/* ── BASE COMPARTIDA ──────────────────────────────────────────────────── */
.finkok-credit-modal,
.finkok-total-modal,
.finkok-uuid-modal {
display: flex;
flex-direction: column;
gap: 1rem;
}
.finkok-credit-modal__subtitle,
.finkok-total-modal__subtitle,
.finkok-uuid-modal__subtitle {
font-size: 0.875rem;
color: var(--text-secondary);
margin: 0;
}
.finkok-credit-modal__loading,
.finkok-total-modal__loading,
.finkok-uuid-modal__loading {
display: flex;
align-items: center;
gap: 0.75rem;
padding: 1.5rem 0;
color: var(--text-secondary);
font-size: 0.875rem;
}
.finkok-credit-modal__error,
.finkok-total-modal__error,
.finkok-uuid-modal__error {
padding: 0.75rem 1rem;
border-radius: 6px;
background: var(--danger-background);
color: var(--danger-foreground);
font-size: 0.875rem;
}
.finkok-credit-modal__empty,
.finkok-total-modal__empty,
.finkok-uuid-modal__empty {
padding: 1.5rem;
text-align: center;
color: var(--text-secondary);
font-size: 0.875rem;
border: 1px dashed var(--border-color);
border-radius: 8px;
}
/* ── TABLAS ───────────────────────────────────────────────────────────── */
.finkok-credit-modal__table-wrap,
.finkok-total-modal__table-wrap,
.finkok-uuid-modal__table-wrap {
overflow-x: auto;
border-radius: 8px;
border: 1px solid var(--border-color);
}
.finkok-credit-modal__table,
.finkok-total-modal__table,
.finkok-uuid-modal__table {
width: 100%;
border-collapse: collapse;
font-size: 0.85rem;
}
.finkok-credit-modal__table thead th,
.finkok-total-modal__table thead th,
.finkok-uuid-modal__table thead th {
padding: 0.65rem 0.9rem;
background: var(--table-header-background);
color: var(--table-header-foreground);
font-weight: 600;
text-align: left;
white-space: nowrap;
border-bottom: 1px solid var(--border-color);
}
.finkok-credit-modal__table tbody tr,
.finkok-total-modal__table tbody tr,
.finkok-uuid-modal__table tbody tr {
transition: background 0.15s;
}
.finkok-credit-modal__table tbody tr:hover,
.finkok-total-modal__table tbody tr:hover,
.finkok-uuid-modal__table tbody tr:hover {
background: var(--table-row-hover);
}
.finkok-credit-modal__table tbody td,
.finkok-total-modal__table tbody td,
.finkok-uuid-modal__table tbody td {
padding: 0.6rem 0.9rem;
border-bottom: 1px solid var(--border-color);
color: var(--text-primary);
vertical-align: middle;
}
.finkok-credit-modal__table tbody tr:last-child td,
.finkok-total-modal__table tbody tr:last-child td,
.finkok-uuid-modal__table tbody tr:last-child td {
border-bottom: none;
}
/* Columnas numéricas alineadas a la derecha */
.finkok-credit-modal__th--right,
.finkok-total-modal__th--right,
.finkok-uuid-modal__th--right {
text-align: right !important;
}
.finkok-credit-modal__td--right,
.finkok-total-modal__td--right,
.finkok-uuid-modal__td--right {
text-align: right;
}
/* Destacar valores numéricos clave */
.finkok-credit-modal__td--credit {
font-weight: 600;
color: var(--success-foreground);
}
.finkok-total-modal__td--total {
font-weight: 600;
color: var(--info-foreground, var(--text-primary));
}
/* UUID en fuente monospace para legibilidad */
.finkok-uuid-modal__td--uuid {
font-family: monospace;
font-size: 0.78rem;
letter-spacing: 0.02em;
word-break: break-all;
}
/* ── FILTROS (Total y UUID modals) ────────────────────────────────────── */
.finkok-total-modal__filters,
.finkok-uuid-modal__filters {
display: flex;
flex-wrap: wrap;
gap: 1rem;
align-items: flex-end;
}
.finkok-total-modal__filter-date,
.finkok-uuid-modal__filter-date {
flex: 1 1 280px;
}
.finkok-total-modal__filter-type,
.finkok-uuid-modal__filter-type {
flex: 0 1 180px;
display: flex;
flex-direction: column;
gap: 0.35rem;
}
.finkok-total-modal__label,
.finkok-uuid-modal__label {
font-size: 0.8rem;
font-weight: 500;
color: var(--text-secondary);
}
.finkok-total-modal__query-action,
.finkok-uuid-modal__query-action {
display: flex;
justify-content: flex-end;
}
/* ── CONTADOR DE RESULTADOS (UUID modal) ─────────────────────────────── */
.finkok-uuid-modal__count {
font-size: 0.8rem;
color: var(--text-secondary);
margin: 0;
}
/* ── ACCIONES ─────────────────────────────────────────────────────────── */
.finkok-credit-modal__actions,
.finkok-total-modal__actions,
.finkok-uuid-modal__actions {
display: flex;
justify-content: flex-end;
gap: 0.5rem;
flex-wrap: wrap;
}
/* ── RESPONSIVIDAD ────────────────────────────────────────────────────── */
@media (max-width: 600px) {
.finkok-total-modal__filters,
.finkok-uuid-modal__filters {
flex-direction: column;
}
.finkok-total-modal__filter-type,
.finkok-uuid-modal__filter-type {
flex: 1 1 100%;
}
.finkok-credit-modal__actions,
.finkok-total-modal__actions,
.finkok-uuid-modal__actions {
justify-content: stretch;
}
.finkok-credit-modal__actions > *,
.finkok-total-modal__actions > *,
.finkok-uuid-modal__actions > * {
flex: 1;
}
}
/* ==========================================================================
floor-plan-editor.css — FloorPlanEditor component
BEM namespace UI   : fpe__*      (contenedor raíz: .fpe)
BEM namespace SVG  : fp-ed__*   (elementos insertados por el módulo JS)
Reglas:
- Todos los selectores interactivos llevan el prefijo .fpe para
tener mayor especificidad que los estilos globales de la app.
- Colores de UI: CSS variables de colors.css (dark/light automático).
- Colores SVG: valores hex directos de la paleta (las CSS custom
properties no son accesibles en fill/stroke de SVG en WASM).
========================================================================== */
/* ══════════════════════════════════════════════════════
RESET INTERNO — neutralizar herencia del app
══════════════════════════════════════════════════════ */
.fpe button,
.fpe input,
.fpe select,
.fpe label {
all: unset;
box-sizing: border-box;
}
/* ══════════════════════════════════════════════════════
RAÍZ
══════════════════════════════════════════════════════ */
.fpe {
display: flex;
flex-direction: column;
width: 100%;
height: 100%;
min-height: 600px;
background: var(--background-color);
color: var(--text-color);
border-radius: var(--radius-md);
overflow: hidden;
box-shadow: var(--shadow-lg);
font-family: inherit;
}
/* ══════════════════════════════════════════════════════
TOOLBAR
══════════════════════════════════════════════════════ */
.fpe__toolbar {
display: flex;
align-items: center;
gap: 0.2rem;
padding: 0.4rem 0.6rem;
background: var(--surface-color);
border-bottom: 1px solid var(--border-color);
flex-wrap: wrap;
min-height: 46px;
flex-shrink: 0;
}
.fpe__tbg {
display: flex;
align-items: center;
gap: 0.2rem;
}
.fpe__tbg--wrap { flex-wrap: wrap; }
.fpe__tbsep {
width: 1px;
height: 22px;
background: var(--divider-color);
margin: 0 0.25rem;
flex-shrink: 0;
}
.fpe__tbspacer { flex: 1 1 0; }
/* ══════════════════════════════════════════════════════
BOTONES BASE
Prefijo .fpe para vencer a "button { ... }" del app.
══════════════════════════════════════════════════════ */
.fpe button.fpe__btn,
.fpe label.fpe__btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.28rem;
padding: 0.32rem 0.6rem;
border: 1px solid var(--border-color);
border-radius: var(--radius-sm);
background: var(--surface-color);
color: var(--text-color);
font-size: 0.78rem;
font-weight: 500;
line-height: 1.2;
cursor: pointer;
white-space: nowrap;
user-select: none;
text-decoration: none;
transition:
background 150ms ease,
border-color 150ms ease,
color 150ms ease,
box-shadow 150ms ease;
min-width: 30px;
min-height: 30px;
}
.fpe button.fpe__btn:hover:not(:disabled),
.fpe label.fpe__btn:hover {
background: var(--hover-background-color);
border-color: var(--primary-color);
color: var(--primary-color);
}
.fpe button.fpe__btn:disabled {
opacity: 0.38;
cursor: not-allowed;
pointer-events: none;
}
/* ─── Solo ícono ────────────────────────────── */
.fpe button.fpe__btn--icon {
padding: 0.3rem;
width: 30px;
height: 30px;
}
/* ─── Herramienta (cursor / draw) ───────────── */
.fpe button.fpe__btn--tool {
color: var(--text-secondary);
background: var(--surface-color);
border-color: var(--border-color);
}
.fpe button.fpe__btn--tool:hover:not(:disabled) {
background: var(--hover-background-color);
border-color: var(--primary-color);
color: var(--primary-color);
}
.fpe button.fpe__btn--tool-active {
background: var(--primary-color) !important;
border-color: var(--primary-dark) !important;
color: var(--primary-foreground) !important;
box-shadow: var(--shadow-sm);
}
/* ─── Toggle (grid / snap) ──────────────────── */
.fpe button.fpe__btn--toggle {
color: var(--text-muted);
background: var(--surface-color);
border-color: var(--border-color);
}
.fpe button.fpe__btn--toggle-on {
background: var(--primary-color) !important;
border-color: var(--primary-dark) !important;
color: var(--primary-foreground) !important;
}
/* ─── Peligro ───────────────────────────────── */
.fpe button.fpe__btn--danger {
background: transparent;
border-color: var(--danger-color);
color: var(--danger-color);
}
.fpe button.fpe__btn--danger:hover:not(:disabled) {
background: var(--danger-background);
border-color: var(--danger-dark);
color: var(--danger-dark);
}
/* ─── Publicar ──────────────────────────────── */
.fpe button.fpe__btn--publish {
background: var(--accent-color) !important;
border-color: var(--accent-dark) !important;
color: var(--accent-foreground) !important;
font-weight: 600;
}
.fpe button.fpe__btn--publish:hover:not(:disabled) {
background: var(--accent-dark) !important;
}
.fpe button.fpe__btn--published {
background: var(--success-color) !important;
border-color: var(--success-dark) !important;
color: var(--text-light) !important;
font-weight: 600;
cursor: default;
pointer-events: none;
}
/* ─── Upload ────────────────────────────────── */
.fpe label.fpe__btn--upload { cursor: pointer; }
.fpe .fpe__btn--busy { opacity: 0.7; cursor: wait; }
/* ─── Guardar layout (aparece cuando _layoutDirty) ──────── */
.fpe button.fpe__btn--save-layout {
background: var(--warning-background, #fff4e5) !important;
border-color: var(--warning-color, #e08000) !important;
color: var(--warning-color, #e08000) !important;
font-weight: 600;
animation: fpe-pulse-border 1.6s ease-in-out infinite;
}
.fpe button.fpe__btn--save-layout:hover:not(:disabled) {
background: var(--warning-color, #e08000) !important;
color: #fff !important;
}
@keyframes fpe-pulse-border {
0%, 100% { box-shadow: 0 0 0 0 rgba(224, 128, 0, 0.4); }
50%       { box-shadow: 0 0 0 4px rgba(224, 128, 0, 0); }
}
/* ─── Guardar / Cancelar (panel slot) ───────── */
.fpe button.fpe__btn--save {
background: var(--primary-color) !important;
border-color: var(--primary-dark) !important;
color: var(--primary-foreground) !important;
font-weight: 600;
width: 100%;
justify-content: center;
padding: 0.5rem;
}
.fpe button.fpe__btn--save:hover:not(:disabled) {
background: var(--primary-hover) !important;
}
.fpe button.fpe__btn--cancel {
width: 100%;
justify-content: center;
padding: 0.5rem;
border-color: var(--border-color);
color: var(--text-secondary);
}
.fpe button.fpe__btn--cancel:hover:not(:disabled) {
background: var(--hover-background-color);
color: var(--text-color);
}
/* ─── Ghost (cancelar alternativo) ─────────── */
.fpe button.fpe__btn--ghost {
background: transparent;
border-color: var(--border-color);
color: var(--text-secondary);
}
.fpe button.fpe__btn--ghost:hover:not(:disabled) {
background: var(--hover-background-color);
color: var(--text-color);
}
/* ─── Primary (guardar alternativo) ─────────── */
.fpe button.fpe__btn--primary {
background: var(--primary-color) !important;
border-color: var(--primary-dark) !important;
color: var(--primary-foreground) !important;
font-weight: 600;
}
.fpe button.fpe__btn--primary:hover:not(:disabled) {
background: var(--primary-hover) !important;
}
/* ─── Porcentaje zoom ────────────────────────── */
.fpe button.fpe__btn--zoom-pct {
min-width: 46px;
font-variant-numeric: tabular-nums;
color: var(--text-muted);
background: transparent;
border-color: transparent;
font-size: 0.78rem;
}
/* ══════════════════════════════════════════════════════
GRID INPUT & LABEL
══════════════════════════════════════════════════════ */
.fpe__grid-label {
display: inline-flex;
align-items: center;
gap: 0.25rem;
font-size: 0.74rem;
color: var(--text-muted);
cursor: default;
}
.fpe input.fpe__grid-input {
width: 46px;
padding: 0.22rem 0.3rem;
border: 1px solid var(--border-color);
border-radius: var(--radius-sm);
background: var(--surface-color);
color: var(--text-color);
font-size: 0.76rem;
text-align: center;
-moz-appearance: textfield;
cursor: text;
}
.fpe input.fpe__grid-input:focus {
border-color: var(--focus-color);
box-shadow: 0 0 0 2px var(--focus-ring);
outline: none;
}
.fpe input.fpe__grid-input::-webkit-inner-spin-button,
.fpe input.fpe__grid-input::-webkit-outer-spin-button { opacity: 0.5; }
/* ══════════════════════════════════════════════════════
ICONOS SVG INLINE
══════════════════════════════════════════════════════ */
.fpe__ico {
width: 16px;
height: 16px;
flex-shrink: 0;
fill: currentColor;
pointer-events: none;
display: inline-block;
vertical-align: middle;
}
.fpe__ico--sm { width: 13px; height: 13px; }
/* ══════════════════════════════════════════════════════
BARRA DE SELECCIÓN ACTIVA
══════════════════════════════════════════════════════ */
.fpe__selbar {
display: flex;
align-items: center;
gap: 0.45rem;
padding: 0.26rem 0.75rem;
background: var(--hover-background-color);
border-bottom: 1px solid var(--border-color);
font-size: 0.76rem;
color: var(--primary-color);
font-weight: 500;
flex-wrap: wrap;
flex-shrink: 0;
}
.fpe__selbar-hint {
color: var(--text-muted);
font-weight: 400;
}
.fpe button.fpe__selbar-clear {
margin-left: auto;
background: transparent;
border: none;
cursor: pointer;
font-size: 0.74rem;
color: var(--text-muted);
padding: 0.1rem 0.35rem;
border-radius: var(--radius-sm);
transition: color 150ms ease, background 150ms ease;
}
.fpe button.fpe__selbar-clear:hover {
color: var(--danger-color);
background: var(--danger-background);
}
/* ══════════════════════════════════════════════════════
CUERPO
══════════════════════════════════════════════════════ */
.fpe__body {
display: flex;
flex: 1 1 0;
overflow: hidden;
min-height: 0;
}
/* ── Canvas ──────────────────────────────────── */
.fpe__canvas-wrap {
flex: 1 1 0;
position: relative;
overflow: hidden;
background: var(--secondary-background);
min-width: 0;
}
.fpe__canvas-scroll {
width: 100%;
height: 100%;
overflow: auto;
}
.fpe__svg {
display: block;
touch-action: none;
/* Fondo blanco = papel del plano */
background: #ffffff;
box-shadow: var(--shadow-md);
margin: 16px auto;
}
.fpe__canvas-loading {
position: absolute;
inset: 0;
display: flex;
align-items: center;
justify-content: center;
gap: 0.6rem;
background: var(--overlay-color);
color: var(--text-light);
font-size: 0.9rem;
z-index: 10;
}
/* ══════════════════════════════════════════════════════
PANEL LATERAL DE SLOT
══════════════════════════════════════════════════════ */
.fpe__slot-panel {
width: 280px;
min-width: 250px;
max-width: 310px;
background: var(--surface-color);
border-left: 1px solid var(--border-color);
display: none;
flex-direction: column;
overflow-y: auto;
flex-shrink: 0;
}
.fpe__slot-panel--visible { display: flex; }
.fpe__slot-panel-header {
display: flex;
align-items: center;
justify-content: space-between;
padding: 0.6rem 0.85rem;
border-bottom: 1px solid var(--border-color);
background: var(--surface-alt-color);
flex-shrink: 0;
}
.fpe__slot-panel-title {
font-size: 0.87rem;
font-weight: 600;
color: var(--text-color);
margin: 0;
}
.fpe button.fpe__slot-panel-close {
background: transparent;
border: none;
cursor: pointer;
color: var(--text-muted);
padding: 0.2rem;
display: flex;
align-items: center;
border-radius: var(--radius-sm);
transition: color 150ms ease, background 150ms ease;
}
.fpe button.fpe__slot-panel-close:hover {
color: var(--danger-color);
background: var(--danger-background);
}
.fpe__slot-geometry {
display: flex;
align-items: center;
gap: 0.35rem;
padding: 0.35rem 0.85rem;
background: var(--card-category-bg-color);
border-bottom: 1px solid var(--border-color);
font-size: 0.73rem;
color: var(--text-muted);
flex-shrink: 0;
}
/* ── Formulario ──────────────────────────────── */
.fpe__slot-form {
padding: 0.7rem 0.85rem;
display: flex;
flex-direction: column;
gap: 0.5rem;
flex: 1 1 0;
}
.fpe__field {
display: flex;
flex-direction: column;
gap: 0.2rem;
}
.fpe__field-row {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(60px, 1fr));
gap: 0.4rem;
}
.fpe__label {
font-size: 0.7rem;
font-weight: 600;
color: var(--text-secondary);
letter-spacing: 0.04em;
text-transform: uppercase;
cursor: default;
}
.fpe__req { color: var(--danger-color); margin-left: 0.12rem; }
.fpe input.fpe__input,
.fpe select.fpe__select {
width: 100%;
padding: 0.38rem 0.55rem;
border: 1px solid var(--border-color);
border-radius: var(--radius-sm);
background: var(--surface-color);
color: var(--text-color);
font-size: 0.81rem;
-moz-appearance: textfield;
-webkit-appearance: none;
appearance: none;
cursor: text;
}
.fpe input.fpe__input:focus,
.fpe select.fpe__select:focus {
border-color: var(--focus-color);
box-shadow: 0 0 0 3px var(--focus-ring);
outline: none;
}
.fpe select.fpe__select { cursor: pointer; }
.fpe input.fpe__input::placeholder { color: var(--text-muted); }
.fpe input.fpe__input::-webkit-inner-spin-button,
.fpe input.fpe__input::-webkit-outer-spin-button { opacity: 0.5; }
.fpe input.fpe__input--error { border-color: var(--danger-color); }
.fpe__field-error {
font-size: 0.68rem;
color: var(--error-text);
}
/* ── Alert inline ────────────────────────────── */
.fpe__alert {
display: flex;
align-items: flex-start;
gap: 0.4rem;
padding: 0.45rem 0.6rem;
border-radius: var(--radius-sm);
font-size: 0.76rem;
line-height: 1.4;
flex-shrink: 0;
}
.fpe__alert--error {
background: var(--danger-background);
border: 1px solid var(--danger-color);
color: var(--danger-foreground);
}
/* ── Acciones del panel ──────────────────────── */
.fpe__slot-actions {
display: flex;
flex-direction: column;
gap: 0.3rem;
padding: 0.6rem 0.85rem;
border-top: 1px solid var(--border-color);
flex-shrink: 0;
}
/* Compatibilidad con footer class antigua */
.fpe__slot-panel-footer {
display: flex;
align-items: center;
justify-content: flex-end;
gap: 0.4rem;
padding: 0.6rem 0.85rem;
border-top: 1px solid var(--border-color);
flex-shrink: 0;
flex-wrap: wrap;
}
.fpe__slot-panel-footer-right {
display: flex;
align-items: center;
gap: 0.4rem;
margin-left: auto;
}
/* ══════════════════════════════════════════════════════
BARRA DE ESTADO
══════════════════════════════════════════════════════ */
.fpe__statusbar {
display: flex;
align-items: center;
gap: 0.5rem;
padding: 0.22rem 0.75rem;
background: var(--surface-color);
border-top: 1px solid var(--border-color);
font-size: 0.74rem;
min-height: 28px;
flex-shrink: 0;
}
.fpe__statusbar--ok  { color: var(--success-text); }
.fpe__statusbar--err { color: var(--error-text); }
/* ══════════════════════════════════════════════════════
SPINNER
══════════════════════════════════════════════════════ */
.fpe__spinner {
display: inline-block;
width: 14px;
height: 14px;
border: 2px solid var(--border-color);
border-top-color: var(--primary-color);
border-radius: 50%;
animation: fpe-spin 0.65s linear infinite;
flex-shrink: 0;
}
.fpe__spinner--lg {
width: 26px;
height: 26px;
border-width: 3px;
}
@keyframes fpe-spin { to { transform: rotate(360deg); } }
/* ══════════════════════════════════════════════════════
ELEMENTOS SVG — namespace fp-ed__
Colores hex directos (la paleta Electric Cobalt + Ocean Jade).
El SVG siempre tiene fondo blanco (#ffffff = papel del plano).
══════════════════════════════════════════════════════ */
/* Imagen de fondo */
.fp-ed__bg {
pointer-events: none;
user-select: none;
}
/* Líneas de cuadrícula */
.fp-ed__grid-line {
stroke: #c8d0e8;
stroke-width: 0.5;
opacity: 0.85;
pointer-events: none;
}
/* Slot base */
.fp-ed__slot {
cursor: move;
}
/* Forma del slot — disponible */
.fp-ed__slot-shape {
fill: rgba(29, 68, 204, 0.12);
stroke: #1d44cc;
stroke-width: 1.5;
transition: fill 0.12s;
}
.fp-ed__slot:hover .fp-ed__slot-shape {
fill: rgba(29, 68, 204, 0.24);
}
/* Slot seleccionado */
.fp-ed__slot--selected .fp-ed__slot-shape {
fill: rgba(0, 212, 160, 0.18);
stroke: #00a87e;
stroke-width: 2.5;
}
/* Estado locked / reservado */
.fp-ed__slot--locked .fp-ed__slot-shape {
fill: rgba(255, 122, 24, 0.14);
stroke: #e05f00;
}
.fp-ed__slot--reserved .fp-ed__slot-shape {
fill: rgba(0, 212, 160, 0.14);
stroke: #00a87e;
}
/* Estado sold — no editable */
.fp-ed__slot--sold .fp-ed__slot-shape {
fill: rgba(148, 163, 184, 0.18);
stroke: #64748b;
stroke-width: 1;
cursor: not-allowed;
}
/* Etiqueta del stand */
.fp-ed__slot-label {
font-size: 11px;
font-weight: 600;
fill: #0c111a;
pointer-events: none;
user-select: none;
}
/* Rect de preview al dibujar */
.fp-ed__preview {
fill: rgba(29, 68, 204, 0.08);
stroke: #1d44cc;
stroke-width: 1.5;
stroke-dasharray: 6 4;
pointer-events: none;
}
/* Marco de selección múltiple */
.fp-ed__sel-rect {
fill: rgba(29, 68, 204, 0.05);
stroke: #1d44cc;
stroke-width: 1;
stroke-dasharray: 5 4;
pointer-events: none;
}
/* Handles de redimensionado */
.fp-ed__handle {
fill: #ffffff;
stroke: #1d44cc;
stroke-width: 1.5;
}
.fp-ed__handle:hover { fill: #1d44cc; }
/* ══════════════════════════════════════════════════════
RESPONSIVE
══════════════════════════════════════════════════════ */
@media (max-width: 768px) {
.fpe__slot-panel { width: 230px; min-width: 200px; }
.fpe__toolbar { gap: 0.1rem; padding: 0.3rem 0.4rem; }
.fpe button.fpe__btn { font-size: 0.72rem; padding: 0.25rem 0.45rem; }
}
@media (max-width: 520px) {
.fpe__body { flex-direction: column; }
.fpe__slot-panel {
width: 100%; max-width: 100%; min-width: 0;
border-left: none;
border-top: 1px solid var(--border-color);
max-height: 240px;
}
}
