:root {
    --imp-primary: #f16334;
    --imp-primary-dark: #d9552a;
    --imp-secondary: #93C5C4;
    --imp-accent: #fdd8b6;
    --imp-dark: #526072;
    --imp-gray-50: #f9fafb;
    --imp-gray-100: #f3f4f6;
    --imp-gray-200: #e5e7eb;
    --imp-gray-400: #9ca3af;
    --imp-gray-500: #6b7280;
    --imp-gray-600: #4b5563;
    --imp-gray-700: #374151;
    --imp-gray-800: #1f2937;
    --imp-gray-900: #111827;
    --imp-amber-100: #fef3c7;
    --imp-amber-600: #d97706;
    --imp-amber-700: #b45309;
    --imp-green-100: #dcfce7;
    --imp-green-500: #22c55e;
    --imp-green-700: #15803d;
    --imp-radius: 12px;
    --imp-radius-lg: 16px;
    --imp-radius-xl: 24px;
    --imp-transition: all 0.2s ease;
    --imp-amber-50: #fff7ed;
    --imp-bg-surface: #ffffff;
    --imp-bg-header: rgba(255,255,255,0.95);
}

/* ========== DARK MODE ========== */
[data-theme="dark"] {
    --imp-gray-50: #0f172a;
    --imp-gray-100: #1e293b;
    --imp-gray-200: #334155;
    --imp-gray-300: #475569;
    --imp-gray-400: #94a3b8;
    --imp-gray-500: #94a3b8;
    --imp-gray-600: #cbd5e1;
    --imp-gray-700: #e2e8f0;
    --imp-gray-800: #f1f5f9;
    --imp-gray-900: #f8fafc;
    --imp-amber-50: #78350f;
    --imp-amber-100: #451a03;
    --imp-amber-600: #fbbf24;
    --imp-amber-700: #fcd34d;
    --imp-green-100: #052e16;
    --imp-green-500: #4ade80;
    --imp-green-700: #86efac;
    --imp-accent: #78350f;
    --imp-bg-surface: #1e293b;
    --imp-bg-header: rgba(15,23,42,0.95);
}
/* Dark: elementos con fondo oscuro intencional */
[data-theme="dark"] .imp-perfil-card,
[data-theme="dark"] .imp-perfil-card-v2 { background: linear-gradient(135deg, #1e293b, #0f172a); }
[data-theme="dark"] .imp-cookie-banner { background: #0f172a; }
[data-theme="dark"] .imp-cookie-prefs { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .imp-cookie-cat { border-color: #334155; }
[data-theme="dark"] .imp-btn-white { background: #e2e8f0; color: var(--imp-primary); }
/* Dark: tags con colores hardcodeados */
[data-theme="dark"] .imp-analisis-tag-cadena { background: #052e16; color: #6ee7b7; }
[data-theme="dark"] .imp-analisis-tag-producto { background: #312e81; color: #a5b4fc; }
/* Dark: estados de error */
[data-theme="dark"] .imp-auth-error,
[data-theme="dark"] .imp-form-error,
[data-theme="dark"] .imp-contacto-error { background: #450a0a; border-color: #991b1b; color: #fca5a5; }
[data-theme="dark"] .imp-btn-logout:hover { background: #450a0a; border-color: #991b1b; color: #fca5a5; }
/* Dark: auth bonus */
[data-theme="dark"] .imp-auth-bonus { background: linear-gradient(135deg, #052e16, #064e3b); border-color: #065f46; color: #6ee7b7; }
/* Dark: contenido gratuito */
[data-theme="dark"] .imp-badge-gratuito { background: #4d7c0f; }
[data-theme="dark"] .imp-visor-hero-gratuito { background: linear-gradient(135deg, #4d7c0f, #365314) !important; }
/* Dark: visor de informes — forzar texto claro en contenido HTML */
[data-theme="dark"] .imp-visor-texto-gratuito,
[data-theme="dark"] .imp-visor-seccion-content,
[data-theme="dark"] .imp-visor-resumen,
[data-theme="dark"] .imp-visor-resumen div,
[data-theme="dark"] .imp-visor-conclusiones,
[data-theme="dark"] .imp-visor-conclusiones div { color: #e2e8f0 !important; }
[data-theme="dark"] .imp-visor-texto-gratuito h1,
[data-theme="dark"] .imp-visor-texto-gratuito h2,
[data-theme="dark"] .imp-visor-texto-gratuito h3,
[data-theme="dark"] .imp-visor-seccion-content h1,
[data-theme="dark"] .imp-visor-seccion-content h2,
[data-theme="dark"] .imp-visor-seccion-content h3,
[data-theme="dark"] .imp-visor-seccion h3,
[data-theme="dark"] .imp-visor-resumen h3,
[data-theme="dark"] .imp-visor-conclusiones h3 { color: #f8fafc !important; }
[data-theme="dark"] .imp-visor-texto-gratuito strong,
[data-theme="dark"] .imp-visor-texto-gratuito b,
[data-theme="dark"] .imp-visor-seccion-content strong,
[data-theme="dark"] .imp-visor-seccion-content b,
[data-theme="dark"] .imp-visor-resumen strong,
[data-theme="dark"] .imp-visor-conclusiones strong { color: #f8fafc !important; }
/* Dark: forzar colores en contenido con estilos inline (Quill/HTML) */
[data-theme="dark"] .imp-visor-texto-gratuito [style*="color"],
[data-theme="dark"] .imp-visor-seccion-content [style*="color"],
[data-theme="dark"] .imp-visor-resumen [style*="color"],
[data-theme="dark"] .imp-visor-conclusiones [style*="color"] { color: #e2e8f0 !important; }
[data-theme="dark"] .imp-visor-texto-gratuito span,
[data-theme="dark"] .imp-visor-seccion-content span,
[data-theme="dark"] .imp-visor-resumen span,
[data-theme="dark"] .imp-visor-conclusiones span { color: inherit !important; }
/* Dark: tablas en informes */
[data-theme="dark"] .imp-visor-texto-gratuito th,
[data-theme="dark"] .imp-visor-seccion-content th,
[data-theme="dark"] .imp-visor-resumen th,
[data-theme="dark"] .imp-visor-conclusiones th { background: #334155; color: #f8fafc !important; }
[data-theme="dark"] .imp-visor-texto-gratuito td,
[data-theme="dark"] .imp-visor-seccion-content td,
[data-theme="dark"] .imp-visor-resumen td,
[data-theme="dark"] .imp-visor-conclusiones td { color: #e2e8f0 !important; }
[data-theme="dark"] .imp-visor-texto-gratuito tr:nth-child(even),
[data-theme="dark"] .imp-visor-seccion-content tr:nth-child(even),
[data-theme="dark"] .imp-visor-resumen tr:nth-child(even),
[data-theme="dark"] .imp-visor-conclusiones tr:nth-child(even) { background: rgba(255,255,255,0.03); }
[data-theme="dark"] .imp-visor-texto-gratuito tr:hover,
[data-theme="dark"] .imp-visor-seccion-content tr:hover { background: rgba(255,255,255,0.06); }
/* Dark: resumen y conclusiones backgrounds */
[data-theme="dark"] .imp-visor-resumen { background: rgba(241, 99, 52, 0.1); border-color: rgba(241, 99, 52, 0.2); }
[data-theme="dark"] .imp-visor-conclusiones { background: #1e293b; }
/* Dark: blockquotes en informes */
[data-theme="dark"] .imp-visor-texto-gratuito blockquote,
[data-theme="dark"] .imp-visor-seccion-content blockquote { background: #1e293b; color: #cbd5e1 !important; }
/* Texto sombreado/highlighted (Quill) — quitar fondo, usar color teal en ambos modos */
.imp-visor-texto-gratuito [style*="background-color"],
.imp-visor-seccion-content [style*="background-color"],
.imp-visor-resumen [style*="background-color"],
.imp-visor-conclusiones [style*="background-color"],
.imp-analisis-resultado-contenido [style*="background-color"] { background-color: transparent !important; color: #3d8584 !important; }
.imp-visor-texto-gratuito [style*="background"],
.imp-visor-seccion-content [style*="background"],
.imp-visor-resumen [style*="background"],
.imp-visor-conclusiones [style*="background"] { background: transparent !important; color: #3d8584 !important; }
[data-theme="dark"] .imp-visor-texto-gratuito [style*="background-color"],
[data-theme="dark"] .imp-visor-seccion-content [style*="background-color"],
[data-theme="dark"] .imp-visor-resumen [style*="background-color"],
[data-theme="dark"] .imp-visor-conclusiones [style*="background-color"],
[data-theme="dark"] .imp-analisis-resultado-contenido [style*="background-color"] { background-color: transparent !important; color: #93C5C4 !important; }
[data-theme="dark"] .imp-visor-texto-gratuito [style*="background"],
[data-theme="dark"] .imp-visor-seccion-content [style*="background"],
[data-theme="dark"] .imp-visor-resumen [style*="background"],
[data-theme="dark"] .imp-visor-conclusiones [style*="background"] { background: transparent !important; color: #93C5C4 !important; }
/* Dark: saldo card border */
[data-theme="dark"] .imp-saldo-card { border-color: rgba(251, 191, 36, 0.3); }
[data-theme="dark"] .imp-analisis-saldo { border-color: rgba(251, 191, 36, 0.3); }
/* Dark: resultado análisis IA en portal */
[data-theme="dark"] .imp-analisis-resultado-contenido { color: #e2e8f0 !important; }
[data-theme="dark"] .imp-analisis-resultado-contenido [style*="color"] { color: #e2e8f0 !important; }
[data-theme="dark"] .imp-analisis-resultado-contenido strong,
[data-theme="dark"] .imp-analisis-resultado-contenido b { color: #f8fafc !important; }
[data-theme="dark"] .imp-analisis-resultado-contenido span { color: inherit !important; }
[data-theme="dark"] .imp-analisis-indicadores { background: #1e293b; }
[data-theme="dark"] .imp-analisis-indicadores h3 { color: #e2e8f0; }
[data-theme="dark"] .imp-indicador-label { color: #94a3b8 !important; }
[data-theme="dark"] .imp-indicador-valor { color: #f8fafc !important; }
[data-theme="dark"] .imp-analisis-form-card { background: #1e293b; }
[data-theme="dark"] .imp-analisis-filtro select { background-color: #0f172a; border-color: #334155; color: #e2e8f0; }
[data-theme="dark"] .imp-analisis-auth-required { background: linear-gradient(135deg, #0f172a, #1e293b); }
* { box-sizing: border-box; margin: 0; padding: 0; }
.imp-app { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; font-size: 16px; line-height: 1.5; color: var(--imp-gray-900); background: var(--imp-gray-50); min-height: 100vh; display: flex; flex-direction: column; }
.imp-loading { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 100vh; gap: 16px; }
.imp-loading-spinner { width: 40px; height: 40px; border: 3px solid var(--imp-gray-200); border-top-color: var(--imp-primary); border-radius: 50%; animation: spin 0.8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes slideUp { from { transform: translateY(100%); } to { transform: translateY(0); } }
.imp-header { position: sticky; top: 0; z-index: 40; background: var(--imp-bg-header); backdrop-filter: blur(10px); border-bottom: 1px solid var(--imp-gray-200); }
.imp-header-inner { max-width: 1400px; margin: 0 auto; padding: 0 24px; height: 60px; display: flex; align-items: center; justify-content: space-between; }
.imp-logo { display: flex; align-items: center; gap: 8px; cursor: pointer; }
.imp-logo-img { height: 40px; width: auto; max-width: 200px; object-fit: contain; border-radius: 6px; }
.imp-logo-icon { width: 36px; height: 36px; border-radius: 10px; background: linear-gradient(135deg, var(--imp-primary), var(--imp-secondary)); display: flex; align-items: center; justify-content: center; color: white; font-weight: 700; font-size: 14px; }
.imp-logo-text { font-weight: 700; color: var(--imp-gray-900); }
.imp-header-tokens { display: flex; align-items: center; gap: 6px; background: var(--imp-amber-100); color: var(--imp-amber-700); padding: 6px 12px; border-radius: 20px; font-weight: 600; font-size: 14px; }
.imp-header-suscripcion { display: flex; align-items: center; gap: 4px; background: var(--imp-green-100); color: var(--imp-green-700); padding: 5px 10px; border-radius: 20px; font-weight: 600; font-size: 12px; white-space: nowrap; }
.imp-suscripcion-badge { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; background: var(--imp-green-100); color: var(--imp-green-700); padding: 10px 14px; border-radius: 10px; font-size: 13px; font-weight: 600; margin: 12px 0 4px; }
.imp-suscripcion-badge svg { flex-shrink: 0; }
.imp-suscripcion-badge small { font-weight: 400; font-size: 12px; color: var(--imp-green-600); width: 100%; }
.imp-dark-toggle { width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--imp-gray-200); background: var(--imp-bg-surface); color: var(--imp-gray-600); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: var(--imp-transition); }
.imp-dark-toggle:hover { background: var(--imp-gray-100); color: var(--imp-primary); }
.imp-header-nav { display: none; align-items: center; gap: 4px; }
.imp-header-nav-item { padding: 8px 16px; border-radius: 8px; font-weight: 500; color: var(--imp-gray-600); cursor: pointer; border: none; background: none; font-size: 15px; transition: var(--imp-transition); text-decoration: none; }
.imp-header-nav-item:hover { background: var(--imp-gray-100); }
.imp-header-nav-item.active { background: var(--imp-accent); color: var(--imp-primary); }
.imp-bottom-nav { position: fixed; bottom: 0; left: 0; right: 0; background: var(--imp-bg-surface); border-top: 1px solid var(--imp-gray-200); z-index: 40; padding-bottom: env(safe-area-inset-bottom); }
.imp-bottom-nav-inner { display: flex; justify-content: space-around; align-items: center; height: 56px; max-width: 600px; margin: 0 auto; }
.imp-nav-item { display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 6px 6px; border: none; background: none; cursor: pointer; color: var(--imp-gray-400); transition: var(--imp-transition); text-decoration: none; }
.imp-nav-item.active { color: var(--imp-primary); }
.imp-nav-item svg { width: 22px; height: 22px; }
.imp-nav-item span { font-size: 10px; font-weight: 500; }
.imp-main { max-width: 1400px; margin: 0 auto; padding: 20px 24px 24px; flex: 1; width: 100%; box-sizing: border-box; }
.imp-page-title { font-size: 24px; font-weight: 700; margin-bottom: 8px; }
.imp-page-subtitle { color: var(--imp-gray-500); margin-bottom: 24px; }
.imp-hero { position: relative; overflow: hidden; border-radius: var(--imp-radius-xl); background: linear-gradient(135deg, var(--imp-primary), var(--imp-secondary)); padding: 32px 24px; color: white; margin-bottom: 24px; }
.imp-hero::before, .imp-hero::after { content: ''; position: absolute; border-radius: 50%; background: rgba(255,255,255,0.1); }
.imp-hero::before { width: 200px; height: 200px; top: -100px; right: -50px; }
.imp-hero::after { width: 100px; height: 100px; bottom: -50px; left: -25px; }
.imp-hero-content { position: relative; z-index: 1; }
.imp-hero-badge { display: inline-flex; align-items: center; gap: 8px; background: rgba(255,255,255,0.2); padding: 6px 14px; border-radius: 20px; font-size: 13px; margin-bottom: 16px; }
.imp-hero h1 { font-size: 28px; font-weight: 700; margin-bottom: 12px; }
.imp-hero p { opacity: 0.85; margin-bottom: 24px; max-width: 400px; }
.imp-hero-with-image { background: none; }
.imp-hero-with-image::before, .imp-hero-with-image::after { display: none; }
.imp-hero-image { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 0; }
.imp-hero-image img { width: 100%; height: 100%; object-fit: cover; }
.imp-hero-image .imp-hero-img-mobile { display: none; }
.imp-hero-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 0; background: rgba(0,0,0,0.45); }
.imp-hero-with-image .imp-hero-content { position: relative; z-index: 1; text-shadow: 0 1px 4px rgba(0,0,0,0.5); }
.imp-hero-with-image .imp-hero-badge { background: var(--imp-primary); text-shadow: none; }
.imp-hero-with-image .imp-btn-white { text-shadow: none; }
.imp-hero-with-image .imp-btn-outline-white { text-shadow: none; }
@media (max-width: 767px) {
    .imp-hero-image .imp-hero-img-desktop { display: none; }
    .imp-hero-image .imp-hero-img-mobile { display: block; width: 100%; height: 100%; object-fit: cover; }
}
.imp-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 12px 24px; border-radius: var(--imp-radius); font-weight: 600; font-size: 15px; border: none; cursor: pointer; transition: var(--imp-transition); text-decoration: none; }
.imp-btn-primary { background: var(--imp-primary); color: white; }
.imp-btn-primary:hover { background: var(--imp-primary-dark); }
.imp-btn-white { background: var(--imp-bg-surface); color: var(--imp-primary); }
.imp-btn-secondary { background: var(--imp-secondary); color: white; }
.imp-btn-outline { background: transparent; border: 2px solid var(--imp-gray-200); color: var(--imp-gray-700); }
.imp-btn-disabled { background: var(--imp-gray-100) !important; color: var(--imp-gray-400) !important; cursor: not-allowed !important; }
.imp-btn-danger { background: #dc2626; color: white; border: none; }
.imp-btn-danger:hover { background: #b91c1c; }
.imp-text-danger { color: #dc2626; }
[data-theme="dark"] .imp-text-danger { color: #fca5a5; }
[data-theme="dark"] .imp-btn-danger { background: #991b1b; }
[data-theme="dark"] .imp-btn-danger:hover { background: #b91c1c; }
.imp-btn-block { width: 100%; }
.imp-btn-sm { padding: 8px 16px; font-size: 13px; }
.imp-btn-lg { padding: 16px 32px; }
.imp-saldo-card { background: linear-gradient(135deg, var(--imp-amber-100), var(--imp-amber-50)); border: 1px solid rgba(217, 119, 6, 0.2); border-radius: var(--imp-radius-lg); padding: 20px; margin-bottom: 24px; }
.imp-saldo-label { font-size: 13px; color: var(--imp-amber-700); opacity: 0.8; margin-bottom: 4px; }
.imp-saldo-amount { display: flex; align-items: baseline; gap: 8px; margin-bottom: 16px; }
.imp-saldo-number { font-size: 40px; font-weight: 700; color: var(--imp-amber-600); }
.imp-saldo-unit { font-size: 16px; color: var(--imp-amber-700); }
.imp-section { margin-bottom: 32px; }
.imp-section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.imp-section-title { font-size: 20px; font-weight: 700; }
.imp-section-link { font-size: 14px; font-weight: 500; color: var(--imp-primary); cursor: pointer; background: none; border: none; padding: 0; }
.imp-informes-grid { display: grid; gap: 16px; }
.imp-informe-card { background: var(--imp-bg-surface); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius-lg); padding: 20px; transition: var(--imp-transition); cursor: pointer; display: flex; flex-direction: column; }
.imp-informe-card:hover { border-color: var(--imp-primary); box-shadow: 0 4px 20px rgba(241, 99, 52, 0.15); }
.imp-informe-header { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 12px; }
.imp-informe-icon { width: 48px; height: 48px; border-radius: 12px; background: linear-gradient(135deg, var(--imp-primary), var(--imp-secondary)); display: flex; align-items: center; justify-content: center; color: white; flex-shrink: 0; }
.imp-informe-info { flex: 1; min-width: 0; }
.imp-informe-categoria { display: inline-block; background: var(--imp-accent); color: var(--imp-primary); font-size: 11px; font-weight: 600; padding: 4px 10px; border-radius: 20px; margin-bottom: 6px; }
.imp-informe-titulo { font-size: 16px; font-weight: 600; margin-bottom: 4px; }
.imp-informe-descripcion { font-size: 14px; color: var(--imp-gray-500); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.imp-informe-preview { font-size: 13px; color: var(--imp-gray-400); line-height: 1.5; margin-top: 8px; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.imp-preview-btn { font-size: 13px; margin-top: 6px; color: var(--imp-primary); font-weight: 500; }
.imp-preview-btn:hover { text-decoration: underline; }
.imp-preview-content { max-height: 300px; overflow-y: auto; }
.imp-informe-footer { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: 16px; }
.imp-informe-precio { display: flex; align-items: center; gap: 6px; background: var(--imp-amber-100); color: var(--imp-amber-700); padding: 6px 12px; border-radius: 20px; font-weight: 600; font-size: 14px; }
.imp-filtros { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 8px; margin-bottom: 20px; }
.imp-filtros::-webkit-scrollbar { display: none; }
.imp-filtro-btn { padding: 8px 16px; border-radius: 20px; font-size: 14px; font-weight: 500; border: none; cursor: pointer; white-space: nowrap; transition: var(--imp-transition); background: var(--imp-gray-100); color: var(--imp-gray-600); }
.imp-filtro-btn:hover { background: var(--imp-gray-200); }
.imp-filtro-btn.active { background: var(--imp-primary); color: white; }
.imp-bonos-grid { display: grid; gap: 16px; }
.imp-bono-card { position: relative; background: var(--imp-bg-surface); border: 2px solid var(--imp-gray-200); border-radius: var(--imp-radius-lg); padding: 24px; text-align: center; cursor: pointer; transition: var(--imp-transition); }
.imp-bono-card:hover { border-color: var(--imp-primary); box-shadow: 0 4px 20px rgba(241, 99, 52, 0.15); }
.imp-bono-card.popular { border-color: var(--imp-primary); }
.imp-bono-badge { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); background: var(--imp-primary); color: white; font-size: 11px; font-weight: 700; padding: 4px 12px; border-radius: 20px; }
.imp-bono-tokens { font-size: 36px; font-weight: 700; }
.imp-bono-tokens span { font-size: 16px; font-weight: 400; color: var(--imp-gray-500); }
.imp-bono-ahorro { display: inline-block; background: var(--imp-green-100); color: var(--imp-green-700); font-size: 12px; font-weight: 600; padding: 4px 10px; border-radius: 20px; margin: 8px 0; }
.imp-bono-precio { font-size: 28px; font-weight: 700; color: var(--imp-primary); margin-top: 8px; }

/* Suscripciones */
.imp-suscripcion-grid { display: grid; gap: 16px; }
.imp-suscripcion-card { position: relative; background: var(--imp-bg-surface); border: 2px solid var(--imp-gray-200); border-radius: var(--imp-radius-lg); padding: 24px; text-align: center; cursor: pointer; transition: var(--imp-transition); }
.imp-suscripcion-card:hover { border-color: var(--imp-primary); box-shadow: 0 4px 20px rgba(241, 99, 52, 0.15); }
.imp-suscripcion-card.popular { border-color: var(--imp-primary); }
.imp-suscripcion-nombre { font-size: 18px; font-weight: 700; margin-bottom: 8px; }
.imp-suscripcion-creditos { font-size: 36px; font-weight: 700; }
.imp-suscripcion-creditos span { font-size: 16px; font-weight: 400; color: var(--imp-gray-500); }
.imp-suscripcion-periodo { font-size: 13px; color: var(--imp-gray-500); margin-bottom: 8px; }
.imp-suscripcion-precio { font-size: 28px; font-weight: 700; color: var(--imp-primary); margin-top: 8px; }
.imp-suscripcion-precio span { font-size: 14px; font-weight: 400; }
.imp-suscripcion-activa { background: var(--imp-bg-surface); border: 2px solid var(--imp-primary); border-radius: var(--imp-radius-lg); padding: 24px; display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.imp-suscripcion-activa-badge { display: inline-block; background: var(--imp-green-100); color: var(--imp-green-700); font-size: 12px; font-weight: 600; padding: 4px 10px; border-radius: 20px; margin-bottom: 8px; }
.imp-suscripcion-activa h3 { font-size: 18px; font-weight: 700; margin-bottom: 4px; }
.imp-suscripcion-activa p { font-size: 14px; color: var(--imp-gray-600); margin: 0; }

.imp-perfil-card { background: linear-gradient(135deg, var(--imp-gray-800), var(--imp-gray-900)); border-radius: var(--imp-radius-lg); padding: 24px; color: white; margin-bottom: 24px; }
.imp-perfil-header { display: flex; align-items: center; gap: 16px; margin-bottom: 20px; }
.imp-perfil-avatar { width: 64px; height: 64px; border-radius: 50%; background: linear-gradient(135deg, var(--imp-primary), var(--imp-secondary)); display: flex; align-items: center; justify-content: center; font-size: 24px; font-weight: 700; }
.imp-perfil-name { font-size: 20px; font-weight: 700; }
.imp-perfil-email { color: var(--imp-gray-400); font-size: 14px; }
.imp-perfil-saldo { display: flex; align-items: center; justify-content: space-between; background: rgba(255,255,255,0.1); padding: 16px; border-radius: 12px; }
.imp-perfil-saldo-label { color: var(--imp-gray-300); }
.imp-perfil-saldo-amount { font-size: 24px; font-weight: 700; }
.imp-mis-informes-grid { display: grid; gap: 12px; }
.imp-mi-informe-card { background: var(--imp-gray-50); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius); padding: 12px 16px; display: flex; align-items: center; gap: 12px; cursor: pointer; transition: var(--imp-transition); }
.imp-mi-informe-card:hover { border-color: var(--imp-primary); background: var(--imp-bg-surface); }
.imp-mi-informe-icon { width: 36px; height: 36px; border-radius: 8px; background: linear-gradient(135deg, var(--imp-primary), var(--imp-secondary)); display: flex; align-items: center; justify-content: center; color: white; flex-shrink: 0; }
.imp-mi-informe-icon svg { width: 18px; height: 18px; }
.imp-mi-informe-info { flex: 1; min-width: 0; }
.imp-mi-informe-titulo { font-weight: 600; font-size: 14px; color: var(--imp-gray-900); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.imp-mi-informe-categoria { font-size: 12px; color: var(--imp-gray-500); margin-top: 2px; }
.imp-mi-informe-card > svg { width: 18px; height: 18px; color: var(--imp-gray-400); flex-shrink: 0; }
.imp-visor { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: var(--imp-gray-50); z-index: 50; overflow-y: auto; }
.imp-visor-header { position: sticky; top: 0; background: var(--imp-bg-header); backdrop-filter: blur(10px); border-bottom: 1px solid var(--imp-gray-200); padding: 16px; display: flex; align-items: center; gap: 16px; z-index: 10; }
.imp-visor-back { width: 40px; height: 40px; border-radius: 10px; border: none; background: var(--imp-gray-100); color: var(--imp-gray-700); cursor: pointer; display: flex; align-items: center; justify-content: center; }
[data-theme="dark"] .imp-visor-back { background: #334155; color: #f8fafc; }
.imp-visor-title { flex: 1; min-width: 0; }
.imp-visor-title h1 { font-size: 16px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.imp-visor-title span { font-size: 13px; color: var(--imp-gray-500); }
.imp-visor-content { max-width: 1200px; width: 92%; margin: 0 auto; padding: 24px 0 100px; }
.imp-visor-hero { background: linear-gradient(135deg, var(--imp-primary), var(--imp-secondary)); border-radius: var(--imp-radius-lg); padding: 24px; color: white; margin-bottom: 24px; }
.imp-visor-hero h2 { font-size: 22px; margin-bottom: 8px; }
.imp-visor-resumen { background: rgba(253, 216, 182, 0.3); border: 1px solid rgba(241, 99, 52, 0.2); border-radius: var(--imp-radius); padding: 20px; margin-bottom: 24px; }
.imp-visor-resumen h3 { color: var(--imp-primary); font-size: 14px; margin-bottom: 8px; }
.imp-visor-seccion { background: var(--imp-bg-surface); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius); padding: 20px; margin-bottom: 16px; }
.imp-visor-seccion-header { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.imp-visor-seccion-num { width: 32px; height: 32px; border-radius: 50%; background: var(--imp-primary); color: white; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 14px; flex-shrink: 0; }
.imp-visor-seccion h3 { font-size: 16px; font-weight: 600; }
.imp-visor-seccion .imp-visor-seccion-content { color: var(--imp-gray-600); line-height: 1.7; padding-left: 44px; }
.imp-visor-conclusiones { background: linear-gradient(135deg, var(--imp-gray-50), var(--imp-gray-100)); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius); padding: 20px; margin-top: 24px; }
.imp-visor-conclusiones h3 { display: flex; align-items: center; gap: 8px; font-size: 16px; margin-bottom: 12px; }
.imp-visor-iframe-container { margin-top: 24px; background: var(--imp-bg-surface); border-radius: var(--imp-radius-lg); border: 1px solid var(--imp-gray-200); overflow: hidden; }
.imp-iframe-wrapper { position: relative; width: 100%; padding-bottom: 56.25%; height: 0; overflow: hidden; }
.imp-iframe-wrapper iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none; }
@media (max-width: 768px) { .imp-iframe-wrapper { padding-bottom: 75%; } }
.imp-modal-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.6); backdrop-filter: blur(4px); z-index: 50; display: flex; align-items: flex-end; justify-content: center; }
.imp-modal { background: var(--imp-bg-surface); width: 100%; max-width: 420px; max-height: 90vh; border-radius: var(--imp-radius-xl) var(--imp-radius-xl) 0 0; overflow: hidden; animation: slideUp 0.3s ease; display: flex; flex-direction: column; }
.imp-modal-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--imp-gray-100); flex-shrink: 0; }
.imp-modal-header h3 { font-size: 18px; font-weight: 600; }
.imp-modal-close { width: 36px; height: 36px; border-radius: 50%; border: none; background: var(--imp-gray-100); cursor: pointer; display: flex; align-items: center; justify-content: center; }
.imp-modal-body { padding: 14px 20px 16px; overflow-y: auto; flex: 1; min-height: 0; -webkit-overflow-scrolling: touch; }
.imp-empty { text-align: center; padding: 40px 20px; background: var(--imp-gray-50); border-radius: var(--imp-radius-lg); }
.imp-empty-icon { width: 64px; height: 64px; margin: 0 auto 16px; background: var(--imp-gray-100); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--imp-gray-400); }
.imp-empty p { color: var(--imp-gray-500); }
.imp-login-box { background: var(--imp-bg-surface); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius-lg); padding: 32px; text-align: center; max-width: 400px; margin: 40px auto; }
.imp-login-box h3 { font-size: 20px; margin-bottom: 8px; }
.imp-login-box p { color: var(--imp-gray-500); margin-bottom: 24px; }
.imp-success-content { text-align: center; padding: 20px; }
.imp-success-icon { width: 80px; height: 80px; margin: 0 auto 20px; background: var(--imp-green-100); border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.imp-success-icon-inner { width: 50px; height: 50px; background: var(--imp-green-500); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: white; }
.imp-como-funciona { background: var(--imp-gray-50); border-radius: var(--imp-radius-lg); padding: 24px; }
.imp-como-funciona h3 { font-size: 18px; margin-bottom: 20px; }
.imp-paso { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 16px; }
.imp-paso-num { width: 32px; height: 32px; border-radius: 50%; background: var(--imp-primary); color: white; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 14px; flex-shrink: 0; }
.imp-paso h4 { font-size: 15px; font-weight: 600; margin-bottom: 4px; }
.imp-paso p { font-size: 14px; color: var(--imp-gray-500); }

/* Bonos Populares Sidebar */
.imp-bonos-populares { background: var(--imp-bg-surface); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius-lg); padding: 24px; margin-top: 24px; }
.imp-bonos-populares h3 { font-size: 18px; margin-bottom: 16px; }
.imp-bonos-mini-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.imp-bono-mini { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; background: var(--imp-gray-50); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius); cursor: pointer; transition: var(--imp-transition); }
.imp-bono-mini:hover { border-color: var(--imp-primary); background: var(--imp-bg-surface); }
.imp-bono-mini.popular { border-color: var(--imp-primary); background: rgba(241, 99, 52, 0.05); }
.imp-bono-mini-info { display: flex; align-items: center; gap: 10px; }
.imp-bono-mini-tokens { font-weight: 600; color: var(--imp-gray-900); }
.imp-bono-mini-badge { font-size: 11px; font-weight: 600; background: var(--imp-primary); color: white; padding: 2px 8px; border-radius: 10px; }
.imp-bono-mini-precio { font-weight: 700; color: var(--imp-primary); font-size: 15px; }
.imp-bonos-populares .imp-section-link { display: block; text-align: center; margin-top: 8px; background: none; border: none; padding: 0; }

/* Contenido editable de paginas */
.imp-pagina-contenido { margin-bottom: 24px; line-height: 1.7; color: var(--imp-gray-700); }
.imp-pagina-contenido h1, .imp-pagina-contenido h2, .imp-pagina-contenido h3 { color: var(--imp-gray-900); margin: 20px 0 10px; }
.imp-pagina-contenido img { max-width: 100%; height: auto; border-radius: var(--imp-radius); margin: 12px 0; }
.imp-pagina-contenido img[style*="float:left"], .imp-pagina-contenido img[style*="float: left"] { margin: 4px 16px 8px 0; }
.imp-pagina-contenido img[style*="float:right"], .imp-pagina-contenido img[style*="float: right"] { margin: 4px 0 8px 16px; }
.imp-pagina-contenido p { margin: 0 0 12px; }
.imp-pagina-contenido a { color: var(--imp-primary); }

/* CTA Final */
.imp-cta-final { background: var(--imp-bg-surface); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius-lg); padding: 32px 24px; margin-top: 32px; text-align: center; }
.imp-cta-final h2 { font-size: 22px; margin-bottom: 8px; }
.imp-cta-final p { color: var(--imp-gray-600); margin-bottom: 20px; font-size: 15px; }

@media (min-width: 640px) { .imp-informes-grid { grid-template-columns: repeat(2, 1fr); } .imp-bonos-grid, .imp-suscripcion-grid { grid-template-columns: repeat(2, 1fr); } .imp-mis-informes-grid { grid-template-columns: repeat(2, 1fr); } .imp-alertas-grid { grid-template-columns: repeat(2, 1fr); } .imp-modal { border-radius: var(--imp-radius-xl); margin: auto; max-height: 92vh; max-width: 560px; } .imp-auth-modal { max-width: 640px; } .imp-modal-overlay { align-items: center; padding: 20px; } .imp-auth-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; } .imp-auth-row-3 { grid-template-columns: 1fr 1fr 1fr; } }
@media (max-height: 700px) { .imp-modal { max-height: 95vh; } .imp-modal-body { padding: 12px 16px 16px; } .imp-modal-header { padding: 12px 16px; } }
@media (min-width: 768px) { .imp-header-nav { display: flex; } .imp-bottom-nav { display: none; } .imp-main { padding-bottom: 40px; } .imp-hero { padding: 48px 40px; } .imp-hero h1 { font-size: 36px; } .imp-page-title { font-size: 28px; } }
@media (min-width: 1024px) { .imp-informes-grid { grid-template-columns: repeat(3, 1fr); } .imp-bonos-grid, .imp-suscripcion-grid { grid-template-columns: repeat(4, 1fr); } .imp-alertas-grid { grid-template-columns: repeat(3, 1fr); } .imp-layout-sidebar { display: grid; grid-template-columns: 2fr 1fr; gap: 32px; } .imp-layout-sidebar > div:last-child .imp-informes-grid { grid-template-columns: 1fr; } .imp-layout-sidebar > div:first-child .imp-informes-grid { grid-template-columns: repeat(2, 1fr); } .imp-layout-sidebar > div:last-child .imp-section { margin-top: 32px; } }

/* ========== ANÁLISIS IA ========== */
.imp-spin { animation: spin 1s linear infinite; }
.imp-analisis-page { width: 100%; padding: 0 1.5rem; box-sizing: border-box; }
.imp-analisis-saldo { display: inline-flex; align-items: center; gap: 8px; background: linear-gradient(135deg, var(--imp-amber-100), var(--imp-amber-50)); border: 1px solid rgba(217, 119, 6, 0.2); padding: 10px 20px; border-radius: 50px; margin-bottom: 24px; }
.imp-analisis-saldo-valor { font-size: 24px; font-weight: 700; color: var(--imp-amber-600); }
.imp-analisis-saldo-label { color: var(--imp-amber-700); font-size: 14px; }
.imp-analisis-form-card { background: var(--imp-bg-surface); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius-lg); padding: 24px; box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08); }
.imp-analisis-loading { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 40px 20px; color: var(--imp-gray-500); gap: 12px; }
.imp-analisis-filtros { display: grid; grid-template-columns: 1fr; gap: 20px; margin-bottom: 24px; }
@media (min-width: 640px) { .imp-analisis-filtros { grid-template-columns: repeat(3, 1fr); } }
.imp-analisis-filtro label { display: block; font-weight: 600; color: var(--imp-gray-700); font-size: 14px; margin-bottom: 8px; }
.imp-analisis-filtro select { width: 100%; padding: 12px 16px; font-size: 15px; border: 2px solid var(--imp-gray-200); border-radius: var(--imp-radius); background: var(--imp-gray-50); color: var(--imp-gray-900); cursor: pointer; transition: var(--imp-transition); appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; }
.imp-analisis-filtro select:hover:not(:disabled) { border-color: var(--imp-primary); }
.imp-analisis-filtro select:focus { outline: none; border-color: var(--imp-primary); box-shadow: 0 0 0 3px rgba(241, 99, 52, 0.15); background-color: var(--imp-bg-surface); }
.imp-analisis-filtro select:disabled { background-color: var(--imp-gray-100); color: var(--imp-gray-400); cursor: not-allowed; }
.imp-analisis-resumen { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 16px; padding: 20px; background: var(--imp-gray-50); border-radius: var(--imp-radius); margin-bottom: 24px; }
.imp-analisis-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.imp-analisis-tag { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border-radius: 20px; font-size: 13px; font-weight: 500; }
.imp-analisis-tag-semana { background: var(--imp-amber-100); color: var(--imp-amber-700); }
.imp-analisis-tag-cadena { background: #d1fae5; color: #065f46; }
.imp-analisis-tag-producto { background: #e0e7ff; color: #3730a3; }
.imp-analisis-coste { color: var(--imp-gray-600); font-size: 14px; }
.imp-analisis-coste strong { color: var(--imp-primary); font-size: 16px; }
.imp-analisis-submit { text-align: center; }
.imp-analisis-sin-creditos { text-align: center; }
.imp-analisis-sin-creditos p { color: var(--imp-gray-500); margin-bottom: 12px; }

/* Auth required para Análisis */
.imp-analisis-auth-required { text-align: center; padding: 20px; background: linear-gradient(135deg, var(--imp-gray-50), var(--imp-accent)); border-radius: var(--imp-radius); border: 1px solid rgba(241, 99, 52, 0.2); }
.imp-analisis-auth-required p { color: var(--imp-gray-600); margin-bottom: 16px; font-size: 15px; }
.imp-analisis-auth-buttons { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
@media (max-width: 400px) { .imp-analisis-auth-buttons { flex-direction: column; } .imp-analisis-auth-buttons .imp-btn { width: 100%; } }

/* Resultado Análisis */
.imp-analisis-resultado-page { max-width: 1200px; width: 92%; margin: 0 auto; }
.imp-analisis-resultado-header { background: linear-gradient(135deg, var(--imp-primary), var(--imp-secondary)); border-radius: var(--imp-radius-lg); padding: 32px; color: white; margin-bottom: 24px; text-align: center; }
.imp-analisis-resultado-header h2 { font-size: 24px; margin-bottom: 8px; }
.imp-analisis-resultado-header p { opacity: 0.85; }
.imp-analisis-resultado-contenido { background: var(--imp-bg-surface); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius-lg); padding: 24px; white-space: pre-wrap; line-height: 1.8; font-size: 15px; color: var(--imp-gray-700); margin-bottom: 24px; }
.imp-analisis-informe-guardado { margin-bottom: 24px; }
.imp-analisis-informe-guardado #ia-pdf-btn, .imp-analisis-informe-guardado #ia-pdf-btn-completo { display: none !important; }
.imp-analisis-resultado-footer { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; }
.imp-analisis-resultado-footer .imp-btn { min-width: 160px; }
.imp-btn-gradient { background: linear-gradient(135deg, var(--imp-primary), var(--imp-secondary)); color: #fff; border: none; font-weight: 600; transition: var(--imp-transition); }
.imp-btn-gradient:hover { opacity: 0.9; transform: translateY(-1px); }
.imp-analisis-indicadores { background: var(--imp-bg-surface); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius-lg); padding: 24px; margin-bottom: 24px; }
.imp-analisis-indicadores h3 { font-size: 16px; color: var(--imp-gray-700); margin-bottom: 16px; padding-bottom: 8px; border-bottom: 2px solid var(--imp-accent); }
.imp-indicadores-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 8px; }
.imp-indicador-item { display: flex; justify-content: space-between; align-items: center; padding: 8px 12px; background: var(--imp-gray-50, #f8f9fa); border-radius: 6px; font-size: 13px; }
.imp-indicador-label { color: var(--imp-gray-500, #6b7280); font-weight: 500; margin-right: 8px; }
.imp-indicador-valor { color: var(--imp-gray-700); font-weight: 600; text-align: right; }

/* ========== AUTENTICACIÓN ========== */
.imp-auth-modal { max-width: 400px; }
.imp-auth-form { display: flex; flex-direction: column; gap: 10px; }
.imp-form-group { display: flex; flex-direction: column; gap: 6px; }
.imp-form-group label { font-weight: 600; font-size: 14px; color: var(--imp-gray-700); }
.imp-form-group input:not([type="checkbox"]):not([type="radio"]), .imp-form-group select { width: 100%; padding: 12px 16px; font-size: 15px; border: 2px solid var(--imp-gray-200); border-radius: var(--imp-radius); background: var(--imp-gray-50); color: var(--imp-gray-900); transition: var(--imp-transition); }
.imp-form-group input:not([type="checkbox"]):not([type="radio"]):focus { outline: none; border-color: var(--imp-primary); background: var(--imp-bg-surface); box-shadow: 0 0 0 3px rgba(241, 99, 52, 0.15); }
.imp-form-group input::placeholder { color: var(--imp-gray-400); }
.imp-info-box-blue { background: #dbeafe; border: 1px solid #93c5fd; border-radius: 12px; padding: 16px; margin-bottom: 20px; font-size: 14px; color: #1e40af; }
[data-theme="dark"] .imp-info-box-blue { background: #1e3a5f; border-color: #2563eb; color: #93c5fd; }
.imp-auth-error { background: #fef2f2; border: 1px solid #fecaca; color: #991b1b; padding: 12px 16px; border-radius: var(--imp-radius); font-size: 14px; margin-bottom: 8px; }
.imp-auth-switch { text-align: center; margin-top: 20px; padding-top: 20px; border-top: 1px solid var(--imp-gray-200); font-size: 14px; color: var(--imp-gray-500); }
.imp-link-btn { background: none; border: none; color: var(--imp-primary); font-weight: 600; cursor: pointer; padding: 0; font-size: inherit; }
.imp-link-btn:hover { text-decoration: underline; }
.imp-auth-bonus { margin-top: 16px; padding: 12px 16px; background: linear-gradient(135deg, var(--imp-green-100), #ecfdf5); border: 1px solid #86efac; border-radius: var(--imp-radius); text-align: center; font-size: 14px; color: var(--imp-green-700); }

/* Modal Form Styles */
.imp-modal-form { display: flex; flex-direction: column; gap: 10px; }
.imp-modal-form label { font-size: 13px; margin-bottom: 2px; }
.imp-modal-form input, .imp-modal-form select { padding: 8px 12px; font-size: 14px; }
.imp-modal-desc { color: var(--imp-gray-600); font-size: 14px; margin-bottom: 8px; }
.imp-form-input { width: 100%; padding: 12px 16px; font-size: 15px; border: 2px solid var(--imp-gray-200); border-radius: var(--imp-radius); background: var(--imp-gray-50); transition: var(--imp-transition); }
.imp-form-input:focus { outline: none; border-color: var(--imp-primary); background: var(--imp-bg-surface); box-shadow: 0 0 0 3px rgba(241, 99, 52, 0.15); }
.imp-form-input::placeholder { color: var(--imp-gray-400); }
.imp-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.imp-form-error { background: #fef2f2; border: 1px solid #fecaca; color: #991b1b; padding: 12px 16px; border-radius: var(--imp-radius); font-size: 14px; }

/* ========== HISTORIAL ========== */
.imp-historial-list { background: var(--imp-bg-surface); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius-lg); overflow: hidden; }
.imp-historial-item { display: flex; align-items: center; gap: 12px; padding: 16px; border-bottom: 1px solid var(--imp-gray-100); transition: var(--imp-transition); }
.imp-historial-item:last-child { border-bottom: none; }
.imp-historial-item:hover { background: var(--imp-gray-50); }
.imp-historial-icono { font-size: 20px; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; background: var(--imp-gray-100); border-radius: 50%; }
.imp-historial-info { flex: 1; min-width: 0; }
.imp-historial-desc { font-weight: 500; color: var(--imp-gray-900); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.imp-historial-fecha { font-size: 13px; color: var(--imp-gray-500); margin-top: 2px; }
.imp-historial-tokens { font-weight: 600; font-size: 14px; white-space: nowrap; }
.imp-historial-tokens.positivo { color: var(--imp-green-600); }
.imp-historial-tokens.negativo { color: var(--imp-gray-600); }

/* ========== MIS ANÁLISIS ========== */
.imp-mis-analisis-grid { display: grid; grid-template-columns: 1fr; gap: 12px; }
@media (min-width: 640px) { .imp-mis-analisis-grid { grid-template-columns: repeat(2, 1fr); } }
.imp-mi-analisis-card { display: flex; align-items: center; gap: 12px; padding: 12px 16px; background: var(--imp-gray-50); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius); cursor: pointer; transition: var(--imp-transition); }
.imp-mi-analisis-card:hover { border-color: var(--imp-primary); background: var(--imp-bg-surface); }
.imp-mi-analisis-icon { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--imp-accent), rgba(147, 197, 196, 0.3)); border-radius: 8px; font-size: 18px; flex-shrink: 0; }
.imp-mi-analisis-info { flex: 1; min-width: 0; }
.imp-mi-analisis-titulo { font-weight: 600; font-size: 14px; color: var(--imp-gray-900); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.imp-mi-analisis-meta { font-size: 12px; color: var(--imp-gray-500); margin-top: 2px; }
.imp-mi-analisis-card > svg { width: 18px; height: 18px; color: var(--imp-gray-400); flex-shrink: 0; }

/* ========== PÁGINA MI CUENTA V2 ========== */
.imp-cuenta-layout { display: flex; flex-direction: column; gap: 24px; }
@media (min-width: 1024px) { .imp-cuenta-layout { display: grid; grid-template-columns: 320px 1fr; gap: 32px; align-items: start; } }

/* Sidebar de perfil */
.imp-cuenta-sidebar { display: flex; flex-direction: column; gap: 16px; }
@media (min-width: 1024px) { .imp-cuenta-sidebar { position: sticky; top: 80px; } }

.imp-perfil-card-v2 { background: linear-gradient(135deg, var(--imp-gray-800), var(--imp-gray-900)); border-radius: var(--imp-radius-lg); padding: 32px 24px; color: white; text-align: center; }
.imp-perfil-avatar-lg { width: 80px; height: 80px; border-radius: 50%; background: linear-gradient(135deg, var(--imp-primary), var(--imp-secondary)); display: flex; align-items: center; justify-content: center; font-size: 32px; font-weight: 700; margin: 0 auto 16px; }
.imp-perfil-name-lg { font-size: 20px; font-weight: 700; margin-bottom: 4px; }
.imp-perfil-email-lg { color: var(--imp-gray-400); font-size: 14px; margin-bottom: 20px; }
.imp-perfil-saldo-v2 { display: flex; align-items: baseline; justify-content: center; gap: 8px; background: rgba(255,255,255,0.1); padding: 16px; border-radius: var(--imp-radius); }
.imp-perfil-saldo-number { font-size: 32px; font-weight: 700; color: var(--imp-amber-600); }
.imp-perfil-saldo-v2 .imp-perfil-saldo-label { font-size: 14px; color: var(--imp-gray-300); }
[data-theme="dark"] .imp-perfil-saldo-number { color: #fbbf24; }
[data-theme="dark"] .imp-perfil-saldo-v2 .imp-perfil-saldo-label { color: #94a3b8; }

/* Acciones de cuenta */
.imp-cuenta-acciones { background: var(--imp-bg-surface); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius-lg); overflow: hidden; }
.imp-cuenta-accion { display: flex; align-items: center; gap: 12px; width: 100%; padding: 16px 20px; border: none; background: none; cursor: pointer; text-align: left; transition: var(--imp-transition); border-bottom: 1px solid var(--imp-gray-100); }
.imp-cuenta-accion:last-child { border-bottom: none; }
.imp-cuenta-accion:hover { background: var(--imp-gray-50); }
.imp-cuenta-accion-icon { font-size: 18px; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; background: var(--imp-gray-100); border-radius: 8px; }
.imp-cuenta-accion span:nth-child(2) { flex: 1; font-weight: 500; color: var(--imp-gray-700); }
.imp-cuenta-accion svg { color: var(--imp-gray-400); }

.imp-btn-logout { margin-top: 8px; color: var(--imp-gray-600); }
.imp-btn-logout:hover { background: #fef2f2; border-color: #fecaca; color: #991b1b; }

/* Contenido principal */
.imp-cuenta-content { display: flex; flex-direction: column; gap: 24px; }

/* Pestañas de cuenta */
.imp-cuenta-tabs { display: flex; gap: 4px; background: var(--imp-gray-100); padding: 4px; border-radius: var(--imp-radius-lg); overflow-x: auto; -webkit-overflow-scrolling: touch; }
.imp-cuenta-tab { flex: 0 0 auto; padding: 10px 16px; border: none; background: none; cursor: pointer; font-size: 14px; font-weight: 500; color: var(--imp-gray-500); border-radius: var(--imp-radius); transition: var(--imp-transition); white-space: nowrap; }
.imp-cuenta-tab:hover { color: var(--imp-gray-700); }
.imp-cuenta-tab.active { background: var(--imp-bg-surface); color: var(--imp-gray-900); font-weight: 600; box-shadow: 0 1px 3px rgba(0,0,0,0.1); }
[data-theme="dark"] .imp-cuenta-tabs { background: #1e293b; }
[data-theme="dark"] .imp-cuenta-tab.active { background: #334155; color: #f8fafc; }

.imp-cuenta-section { background: var(--imp-bg-surface); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius-lg); padding: 24px; }

/* Lista de items dentro de las secciones */
.imp-cuenta-items-list { display: flex; flex-direction: column; gap: 8px; max-height: 300px; overflow-y: auto; }
.imp-cuenta-items-list-full { max-height: none; }
.imp-cuenta-items-list::-webkit-scrollbar { width: 6px; }
.imp-cuenta-items-list::-webkit-scrollbar-track { background: var(--imp-gray-100); border-radius: 3px; }
.imp-cuenta-items-list::-webkit-scrollbar-thumb { background: var(--imp-gray-300); border-radius: 3px; }
.imp-cuenta-items-list::-webkit-scrollbar-thumb:hover { background: var(--imp-gray-400); }
.imp-cuenta-section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.imp-cuenta-section-header h2 { font-size: 18px; font-weight: 600; color: var(--imp-gray-900); }
.imp-cuenta-section-count { background: var(--imp-gray-100); color: var(--imp-gray-600); font-size: 13px; font-weight: 600; padding: 4px 10px; border-radius: 20px; }

.imp-empty-sm { text-align: center; padding: 24px; background: var(--imp-gray-50); border-radius: var(--imp-radius); }
.imp-empty-sm p { color: var(--imp-gray-500); font-size: 14px; margin-bottom: 12px; }

/* Historial como tabla */
.imp-historial-table { border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius); overflow: hidden; }
.imp-historial-table-header { display: none; }
@media (min-width: 768px) {
    .imp-historial-table-header { display: grid; grid-template-columns: 60px 1fr 100px 80px 70px 36px; background: var(--imp-gray-50); padding: 12px 16px; font-size: 12px; font-weight: 600; color: var(--imp-gray-500); text-transform: uppercase; letter-spacing: 0.5px; }
}
.imp-historial-row { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; padding: 16px; border-bottom: 1px solid var(--imp-gray-100); }
.imp-historial-row:last-child { border-bottom: none; }
.imp-historial-row:hover { background: var(--imp-gray-50); }
@media (min-width: 768px) {
    .imp-historial-row { display: grid; grid-template-columns: 60px 1fr 100px 80px 70px 36px; gap: 16px; align-items: center; }
}
.imp-historial-tipo-badge { font-size: 18px; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; background: var(--imp-gray-100); border-radius: 8px; }
.imp-historial-col-desc { flex: 1; font-weight: 500; color: var(--imp-gray-900); min-width: 150px; }
.imp-historial-col-fecha { color: var(--imp-gray-500); font-size: 13px; }
.imp-historial-col-tokens { font-weight: 600; font-size: 14px; }
.imp-historial-col-tokens.positivo { color: var(--imp-green-600); }
.imp-historial-col-tokens.negativo { color: var(--imp-gray-600); }
.imp-historial-col-factura { text-align: center; display: flex; gap: 4px; justify-content: center; }
.imp-btn-factura { background: var(--imp-primary); color: white; border: none; width: 28px; height: 28px; border-radius: 6px; cursor: pointer; font-size: 12px; transition: var(--imp-transition); display: inline-flex; align-items: center; justify-content: center; }
.imp-btn-factura:hover { background: var(--imp-primary-dark); transform: scale(1.05); }
.imp-btn-factura-ver { background: var(--imp-gray-200); color: var(--imp-gray-700); }
.imp-btn-factura-ver:hover { background: var(--imp-gray-300); }
.imp-factura-pending { opacity: 0.5; }
.imp-historial-col-acciones { text-align: center; }

/* Botón eliminar en cards de cuenta */
.imp-btn-delete-item { width: 28px; height: 28px; border-radius: 6px; border: none; background: transparent; color: var(--imp-gray-400); cursor: pointer; font-size: 18px; line-height: 1; display: inline-flex; align-items: center; justify-content: center; transition: var(--imp-transition); flex-shrink: 0; }
.imp-btn-delete-item:hover { background: #fef2f2; color: #dc2626; }
[data-theme="dark"] .imp-btn-delete-item:hover { background: #450a0a; color: #f87171; }

/* Responsive móvil para historial */
@media (max-width: 767px) {
    .imp-historial-col-tipo { order: 1; }
    .imp-historial-col-desc { order: 2; width: calc(100% - 52px); }
    .imp-historial-col-fecha { order: 4; width: auto; }
    .imp-historial-col-tokens { order: 3; margin-left: auto; }
    .imp-historial-col-factura { order: 5; }
}

/* Contenido Gratuito */
.imp-badge-gratuito { display: inline-flex; align-items: center; gap: 4px; background: #83BC08; color: white; font-size: 11px; font-weight: 600; padding: 4px 10px; border-radius: 20px; text-transform: uppercase; letter-spacing: 0.5px; }
.imp-informe-gratuito { position: relative; transition: border-color 0.2s ease; }
.imp-informe-gratuito:hover { border-color: #93c5c4; }
.imp-btn-success { background: #fdd8b6; color: var(--imp-gray-900); border: none; font-weight: 500; }
[data-theme="dark"] .imp-btn-success { background: #78350f; color: #fcd34d; }
[data-theme="dark"] .imp-btn-success:hover { background: #92400e; }
.imp-btn-success:hover { background: #f5c9a0; transform: translateY(-1px); box-shadow: 0 4px 12px rgba(253, 216, 182, 0.4); }
.imp-visor-hero-gratuito { background: linear-gradient(135deg, #83BC08, #6fa006) !important; }
.imp-visor-texto-gratuito { background: var(--imp-bg-surface); padding: 32px; border-radius: var(--imp-radius-lg); border: 1px solid var(--imp-gray-200); line-height: 1.8; color: var(--imp-gray-700); }
.imp-visor-texto-gratuito p { margin-bottom: 16px; }
.imp-visor-texto-gratuito p:last-child { margin-bottom: 0; }

/* ========================================
   RICH HTML CONTENT STYLES
   Tablas, listas, encabezados, etc.
======================================== */

/* Contenido gratuito */
.imp-visor-texto-gratuito h1, .imp-visor-texto-gratuito h2, .imp-visor-texto-gratuito h3 { margin: 24px 0 12px 0; line-height: 1.3; }
.imp-visor-texto-gratuito h1 { font-size: 24px; } .imp-visor-texto-gratuito h2 { font-size: 20px; } .imp-visor-texto-gratuito h3 { font-size: 17px; }
.imp-visor-texto-gratuito h1:first-child, .imp-visor-texto-gratuito h2:first-child, .imp-visor-texto-gratuito h3:first-child { margin-top: 0; }
.imp-visor-texto-gratuito strong, .imp-visor-texto-gratuito b { font-weight: 600; }
.imp-visor-texto-gratuito ul, .imp-visor-texto-gratuito ol { margin: 12px 0; padding-left: 24px; }
.imp-visor-texto-gratuito li { margin-bottom: 6px; }
.imp-visor-texto-gratuito table { width: 100%; border-collapse: collapse; margin: 16px 0; font-size: 14px; }
.imp-visor-texto-gratuito th, .imp-visor-texto-gratuito td { border: 1px solid var(--imp-gray-200); padding: 10px 14px; text-align: left; }
.imp-visor-texto-gratuito th { font-weight: 600; }
.imp-visor-texto-gratuito tr:hover { background: rgba(0,0,0,0.02); }
.imp-visor-texto-gratuito blockquote { border-left: 4px solid var(--imp-primary); margin: 16px 0; padding: 12px 20px; background: var(--imp-gray-50); color: var(--imp-gray-600); font-style: italic; }
.imp-visor-texto-gratuito a { color: var(--imp-primary); text-decoration: underline; }
.imp-visor-texto-gratuito img { max-width: 100%; height: auto; border-radius: 8px; margin: 12px 0; }
.imp-visor-texto-gratuito iframe { max-width: 100%; border-radius: 8px; margin: 16px 0; display: block; }
.imp-iframe-responsive { position: relative; width: 100%; overflow: hidden; border-radius: 8px; margin: 16px 0; background: var(--imp-gray-100); }
.imp-iframe-responsive iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none; }

/* Contenido de análisis IA vinculado - usa el CSS de styles.css cargado dinámicamente */
.imp-visor-analisis-contenido { padding: 0; border-radius: var(--imp-radius-lg); overflow: hidden; }
.imp-visor-analisis-contenido .container { max-width: 100%; }
.imp-visor-analisis-contenido .imp-main-analisis,
.imp-visor-analisis-contenido .imp-header,
.imp-visor-analisis-contenido .imp-footer,
.imp-visor-analisis-contenido .imp-bottom-nav { display: none; }

/* Secciones de informes premium */
.imp-visor-seccion-content h1, .imp-visor-seccion-content h2, .imp-visor-seccion-content h3 { margin: 16px 0 8px 0; }
.imp-visor-seccion-content h1 { font-size: 20px; } .imp-visor-seccion-content h2 { font-size: 18px; } .imp-visor-seccion-content h3 { font-size: 16px; }
.imp-visor-seccion-content strong, .imp-visor-seccion-content b { font-weight: 600; }
.imp-visor-seccion-content ul, .imp-visor-seccion-content ol { margin: 8px 0; padding-left: 24px; }
.imp-visor-seccion-content li { margin-bottom: 4px; }
.imp-visor-seccion-content table { width: 100%; border-collapse: collapse; margin: 12px 0; font-size: 14px; }
.imp-visor-seccion-content th, .imp-visor-seccion-content td { border: 1px solid var(--imp-gray-200); padding: 8px 12px; text-align: left; }
.imp-visor-seccion-content th { font-weight: 600; }
.imp-visor-seccion-content blockquote { border-left: 3px solid var(--imp-primary); margin: 12px 0; padding: 8px 16px; background: rgba(253,216,182,0.15); }
.imp-visor-seccion-content a { color: var(--imp-primary); }
.imp-visor-seccion-content img { max-width: 100%; height: auto; border-radius: 6px; margin: 8px 0; }

/* Resumen y Conclusiones */
.imp-visor-resumen div, .imp-visor-conclusiones div { line-height: 1.7; }
.imp-visor-resumen strong, .imp-visor-conclusiones strong { font-weight: 600; }
.imp-visor-resumen ul, .imp-visor-resumen ol, .imp-visor-conclusiones ul, .imp-visor-conclusiones ol { margin: 8px 0; padding-left: 20px; }
.imp-visor-resumen a, .imp-visor-conclusiones a { color: var(--imp-primary); }
.imp-visor-resumen table, .imp-visor-conclusiones table { width: 100%; border-collapse: collapse; margin: 12px 0; }
.imp-visor-resumen th, .imp-visor-resumen td, .imp-visor-conclusiones th, .imp-visor-conclusiones td { border: 1px solid var(--imp-gray-200); padding: 8px 12px; }
.imp-visor-resumen th, .imp-visor-conclusiones th { font-weight: 600; }

/* ========================================
   QUILL EDITOR CSS CLASSES
   Necesarias para renderizar contenido
   generado por Quill WYSIWYG
======================================== */

/* Tamaños de texto Quill */
.imp-visor-texto-gratuito .ql-size-small,
.imp-visor-seccion-content .ql-size-small,
.imp-visor-resumen .ql-size-small,
.imp-visor-conclusiones .ql-size-small { font-size: 0.75em; }

.imp-visor-texto-gratuito .ql-size-large,
.imp-visor-seccion-content .ql-size-large,
.imp-visor-resumen .ql-size-large,
.imp-visor-conclusiones .ql-size-large { font-size: 1.5em; }

.imp-visor-texto-gratuito .ql-size-huge,
.imp-visor-seccion-content .ql-size-huge,
.imp-visor-resumen .ql-size-huge,
.imp-visor-conclusiones .ql-size-huge { font-size: 2em; }

/* Alineación Quill */
.ql-align-center { text-align: center; }
.ql-align-right { text-align: right; }
.ql-align-justify { text-align: justify; }

/* Indentación Quill */
.ql-indent-1 { padding-left: 3em; }
.ql-indent-2 { padding-left: 6em; }
.ql-indent-3 { padding-left: 9em; }
.ql-indent-4 { padding-left: 12em; }
.ql-indent-5 { padding-left: 15em; }

/* Fuentes Quill */
.ql-font-serif { font-family: Georgia, "Times New Roman", serif; }
.ql-font-monospace { font-family: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace; }

/* Listas con indentación Quill (li con clase) */
li.ql-indent-1 { padding-left: 3em; }
li.ql-indent-2 { padding-left: 6em; }
li.ql-indent-3 { padding-left: 9em; }

/* Imágenes con borde roto ocultas */
.imp-visor-texto-gratuito img[src=""],
.imp-visor-texto-gratuito img:not([src]),
.imp-visor-seccion-content img[src=""],
.imp-visor-seccion-content img:not([src]) { display: none; }

/* Estilos inline comunes de Word que Quill puede preservar */
.imp-visor-texto-gratuito [style*="font-size"],
.imp-visor-seccion-content [style*="font-size"] { line-height: 1.4; }

/* Contenedor de imagen responsive */
.imp-visor-texto-gratuito img,
.imp-visor-seccion-content img,
.imp-visor-resumen img,
.imp-visor-conclusiones img { max-width: 100%; height: auto; display: block; margin: 12px auto; }

/* ========================================
   CONTACTO
======================================== */
.imp-contacto-page { max-width: 640px; margin: 0 auto; }
.imp-contacto-form { display: flex; flex-direction: column; gap: 16px; }
.imp-contacto-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 500px) { .imp-contacto-row { grid-template-columns: 1fr; } }
.imp-contacto-field { display: flex; flex-direction: column; gap: 4px; }
.imp-contacto-field label { font-size: 14px; font-weight: 500; color: var(--imp-gray-700); }
.imp-contacto-field input, .imp-contacto-field select, .imp-contacto-field textarea { width: 100%; padding: 10px 14px; border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius); font-size: 14px; color: var(--imp-gray-900); background: var(--imp-bg-surface); transition: var(--imp-transition); font-family: inherit; }
.imp-contacto-field input:focus, .imp-contacto-field select:focus, .imp-contacto-field textarea:focus { outline: none; border-color: var(--imp-primary); box-shadow: 0 0 0 3px rgba(241, 99, 52, 0.1); }
.imp-contacto-field textarea { resize: vertical; min-height: 120px; }
.imp-contacto-checkboxes { display: flex; flex-direction: column; gap: 10px; }
.imp-contacto-legal-info { background: var(--imp-gray-50); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius); padding: 14px 16px; font-size: 12px; line-height: 1.6; color: var(--imp-gray-500); }
.imp-contacto-success { background: var(--imp-green-100); color: var(--imp-green-700); border: 1px solid rgba(34,139,34,0.2); border-radius: var(--imp-radius); padding: 14px 16px; font-size: 14px; margin-bottom: 16px; }
.imp-contacto-error { background: #fef2f2; color: #dc2626; border: 1px solid rgba(220,38,38,0.2); border-radius: var(--imp-radius); padding: 14px 16px; font-size: 14px; margin-bottom: 16px; }

/* ========================================
   LEGAL / RGPD
======================================== */

/* Footer del portal */
/* Footer simple */
/* Trust Badges */
.imp-trust-badges { display: flex; justify-content: center; gap: 24px; padding: 16px 20px; flex-wrap: wrap; }
.imp-trust-badge { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--imp-gray-600); font-weight: 500; }
.imp-trust-badge svg { width: 18px; height: 18px; color: var(--imp-primary); flex-shrink: 0; }
@media (max-width: 480px) { .imp-trust-badges { gap: 12px; } .imp-trust-badge { font-size: 12px; } }

.imp-footer-portal { background: var(--imp-gray-100); border-top: 1px solid var(--imp-gray-200); padding: 20px 16px; text-align: center; margin-bottom: 70px; }
@media (min-width: 768px) { .imp-footer-portal { margin-bottom: 0; } }
.imp-footer-links { display: flex; align-items: center; justify-content: center; gap: 8px; flex-wrap: wrap; font-size: 13px; margin-bottom: 8px; }
.imp-footer-links:last-child { margin-bottom: 0; }
.imp-footer-links a { color: var(--imp-gray-500); text-decoration: none; transition: var(--imp-transition); }
.imp-footer-links a:hover { color: var(--imp-primary); }
.imp-footer-legal-links { font-size: 12px; }
.imp-footer-copyright { font-size: 11px; color: var(--imp-gray-400); margin-top: 8px; }
.imp-footer-sep { color: var(--imp-gray-300); }
/* Footer avanzado con columnas */
.imp-footer-advanced { text-align: left; padding: 0; }
.imp-footer-advanced .imp-footer-links a { color: inherit; opacity: 0.7; }
.imp-footer-advanced .imp-footer-links a:hover { opacity: 1; color: var(--imp-primary); }
.imp-footer-advanced .imp-footer-sep { color: inherit; opacity: 0.3; }
.imp-footer-advanced .imp-footer-copyright { color: inherit; opacity: 0.5; }
.imp-footer-columns { display: flex; flex-wrap: wrap; gap: 24px; max-width: 1200px; margin: 0 auto; padding: 40px 24px 24px; }
.imp-footer-col h4 { font-size: 14px; font-weight: 600; margin: 0 0 12px 0; text-transform: uppercase; letter-spacing: 0.5px; opacity: 0.9; }
.imp-footer-col p { font-size: 13px; line-height: 1.7; margin: 0; opacity: 0.8; }
.imp-footer-col ul { list-style: none; padding: 0; margin: 0; }
.imp-footer-col ul li { margin-bottom: 8px; }
.imp-footer-col ul li a { font-size: 13px; color: inherit; text-decoration: none; opacity: 0.7; transition: var(--imp-transition); }
.imp-footer-col ul li a:hover { opacity: 1; color: var(--imp-primary); }
.imp-footer-col img { max-width: 180px; height: auto; }
.imp-footer-bottom { border-top: 1px solid rgba(128,128,128,0.2); padding: 16px 24px; text-align: center; max-width: 1200px; margin: 0 auto; }
@media (max-width: 600px) { .imp-footer-columns { flex-direction: column; padding: 24px 16px 16px; } .imp-footer-col { flex: 1 1 100% !important; } }

/* Cookie banner */
.imp-cookie-banner { position: fixed; bottom: 0; left: 0; right: 0; background: var(--imp-gray-900); color: white; z-index: 1000; box-shadow: 0 -4px 20px rgba(0,0,0,0.15); }
.imp-cookie-banner-inner { max-width: 960px; margin: 0 auto; padding: 16px; display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.imp-cookie-banner p { font-size: 13px; margin: 0; line-height: 1.5; color: var(--imp-gray-300); flex: 1; min-width: 200px; }
.imp-cookie-banner-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; flex-wrap: wrap; }
.imp-cookie-link { color: var(--imp-gray-400); font-size: 13px; text-decoration: underline; white-space: nowrap; margin-right: 4px; }
.imp-cookie-link:hover { color: white; }
.imp-cookie-btn-outline { background: transparent; border: 1px solid var(--imp-gray-500); color: white; }
.imp-cookie-btn-outline:hover { border-color: white; background: rgba(255,255,255,0.1); }
/* Cookie preferences panel */
.imp-cookie-prefs { background: var(--imp-gray-800); border-top: 1px solid var(--imp-gray-700); }
.imp-cookie-prefs-inner { max-width: 960px; margin: 0 auto; padding: 16px; }
.imp-cookie-cat { display: flex; align-items: flex-start; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--imp-gray-700); }
.imp-cookie-cat:last-of-type { border-bottom: none; }
.imp-cookie-cat strong { font-size: 14px; color: white; }
.imp-cookie-cat p { font-size: 12px; color: var(--imp-gray-400); margin: 2px 0 0; }
.imp-cookie-always { font-size: 11px; color: var(--imp-primary); margin-left: 4px; }
.imp-cookie-prefs-actions { padding-top: 12px; text-align: right; }
/* Toggle switch */
.imp-cookie-toggle { position: relative; display: inline-block; width: 44px; height: 24px; flex-shrink: 0; margin-top: 2px; cursor: pointer; }
.imp-cookie-toggle input { opacity: 0; width: 0; height: 0; }
.imp-toggle-slider { position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; background: var(--imp-gray-600); border-radius: 24px; transition: 0.2s; }
.imp-toggle-slider:before { content: ''; position: absolute; height: 18px; width: 18px; left: 3px; bottom: 3px; background: white; border-radius: 50%; transition: 0.2s; }
.imp-cookie-toggle input:checked + .imp-toggle-slider { background: var(--imp-primary); }
.imp-cookie-toggle input:checked + .imp-toggle-slider:before { transform: translateX(20px); }
.imp-cookie-toggle input:disabled + .imp-toggle-slider { opacity: 0.6; cursor: default; }
@media (max-width: 640px) {
    .imp-cookie-banner-inner { flex-direction: column; align-items: stretch; }
    .imp-cookie-banner-actions { justify-content: center; }
}

/* Checkbox legal en registro */
.imp-checkbox-legal { display: flex; align-items: flex-start; gap: 8px; cursor: pointer; font-size: 13px; color: var(--imp-gray-600); line-height: 1.5; font-weight: 400; }
.imp-checkbox-legal input[type="checkbox"] { margin-top: 3px; flex-shrink: 0; accent-color: var(--imp-primary); width: auto; height: auto; }
.imp-checkbox-legal a { color: var(--imp-primary); text-decoration: underline; }
.imp-checkbox-legal a:hover { color: var(--imp-secondary); }

/* Paginas legales */
.imp-legal-page { max-width: 760px; margin: 0 auto; }
.imp-legal-content { background: var(--imp-bg-surface); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius-lg); padding: 32px; line-height: 1.8; color: var(--imp-gray-700); font-size: 14px; }
.imp-legal-content h2 { font-size: 22px; color: var(--imp-gray-900); margin: 0 0 20px 0; padding-bottom: 12px; border-bottom: 2px solid var(--imp-primary); }
.imp-legal-content h3 { font-size: 17px; color: var(--imp-gray-800); margin: 24px 0 8px 0; }
.imp-legal-content h4 { font-size: 15px; color: var(--imp-gray-700); margin: 16px 0 6px 0; }
.imp-legal-content p { margin: 8px 0; }
.imp-legal-content ul, .imp-legal-content ol { margin: 8px 0; padding-left: 24px; }
.imp-legal-content li { margin-bottom: 4px; }
.imp-legal-content strong { color: var(--imp-gray-900); }
.imp-legal-content a { color: var(--imp-primary); }

/* ========== BLOQUES DE CONTENIDO ========== */
/* ========== BLOQUE SUPERIOR (3 columnas) ========== */
.imp-bloque-superior-wrap { margin: 32px 0; }
.imp-bs-titulo-general { font-size: 24px; font-weight: 800; color: var(--imp-gray-900); text-align: center; margin: 0 0 20px 0; }
.imp-bloque-superior { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.imp-bs-col { background: var(--imp-bg-surface); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius-lg); padding: 24px; text-align: center; }
.imp-bs-imagen { margin-bottom: 16px; }
.imp-bs-imagen img { max-height: 80px; width: auto; display: inline-block; border-radius: var(--imp-radius); }
.imp-bs-titulo { font-size: 18px; font-weight: 700; color: var(--imp-gray-900); margin: 0 0 8px 0; }
.imp-bs-texto { color: var(--imp-gray-600); font-size: 14px; line-height: 1.6; }
@media (max-width: 768px) {
    .imp-bloque-superior { grid-template-columns: 1fr; gap: 16px; }
}

/* ========== FEATURES / POR QUE ELEGIRNOS ========== */
.imp-features-section { margin: 32px 0; text-align: center; }
.imp-features-title { font-size: 24px; font-weight: 800; color: var(--imp-gray-900); margin: 0 0 8px 0; }
.imp-features-subtitle { font-size: 15px; color: var(--imp-gray-500); margin: 0 0 24px 0; }
.imp-features-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.imp-feature-card { background: var(--imp-bg-surface); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius-lg); padding: 24px 20px; text-align: center; transition: box-shadow 0.2s, border-color 0.2s; }
.imp-feature-card:hover { border-color: var(--imp-primary); box-shadow: 0 4px 12px rgba(0,0,0,0.08); }
.imp-feature-icon { color: var(--imp-primary); margin-bottom: 12px; display: flex; justify-content: center; }
.imp-feature-titulo { font-size: 16px; font-weight: 700; color: var(--imp-gray-900); margin: 0 0 6px 0; }
.imp-feature-desc { font-size: 13px; color: var(--imp-gray-500); line-height: 1.5; margin: 0; }

.imp-bloques-contenido { display: flex; flex-direction: column; gap: 24px; margin: 32px 0; }
.imp-bloques-titulo { font-size: 28px; font-weight: 800; color: var(--imp-gray-900); text-align: center; margin: 0 0 8px 0; letter-spacing: -0.3px; }
.imp-bc-texto[style*="color"] p,
.imp-bc-texto[style*="color"] li,
.imp-bc-texto[style*="color"] strong { color: inherit; }
.imp-bloque-contenido { background: var(--imp-bg-surface); border: 1px solid var(--imp-gray-200); border-radius: var(--imp-radius-lg); padding: 28px; }
.imp-bc-titulo { font-size: 22px; font-weight: 700; color: var(--imp-gray-900); margin: 0 0 12px 0; }
.imp-bc-texto { color: var(--imp-gray-700); font-size: 15px; line-height: 1.7; }
.imp-bc-texto p { margin: 8px 0; }
.imp-bc-texto ul, .imp-bc-texto ol { margin: 8px 0; padding-left: 24px; }
.imp-bc-texto li { margin-bottom: 4px; }
.imp-bc-texto strong { color: var(--imp-gray-900); }
.imp-bc-imagen img { border-radius: var(--imp-radius); display: block; height: auto; }
.imp-bc-vertical { display: flex; flex-direction: column; gap: 16px; }
.imp-bc-vertical .imp-bc-imagen { text-align: center; }
.imp-bc-pos-centrada .imp-bc-imagen { display: flex; justify-content: center; }
.imp-bc-horizontal { display: flex; gap: 24px; align-items: flex-start; }
.imp-bc-pos-derecha { flex-direction: row; }
.imp-bc-pos-derecha .imp-bc-content { order: -1; }
.imp-bc-pos-izquierda { flex-direction: row; }
.imp-bc-horizontal .imp-bc-content { flex: 1; min-width: 0; }
.imp-bc-horizontal .imp-bc-imagen { flex-shrink: 0; }
@media (max-width: 768px) {
    .imp-bc-horizontal { flex-direction: column; }
    .imp-bc-pos-derecha .imp-bc-content { order: 0; }
    .imp-bc-imagen img { max-width: 100% !important; }
}

/* ========== ALERTAS DE PRECIOS ========== */
.imp-alertas-grid { display: grid; gap: 16px; }
.imp-alerta-plan-card { position: relative; background: var(--imp-bg-surface); border: 2px solid var(--imp-gray-200); border-radius: var(--imp-radius-lg); padding: 24px; text-align: center; transition: var(--imp-transition); }
.imp-alerta-plan-card:hover { border-color: var(--imp-primary); box-shadow: 0 4px 20px rgba(241, 99, 52, 0.15); }
.imp-alerta-plan-card.popular { border-color: var(--imp-primary); }
.imp-alerta-plan-nombre { font-size: 18px; font-weight: 700; color: var(--imp-gray-900); margin-bottom: 8px; }
.imp-alerta-plan-alertas { font-size: 36px; font-weight: 700; color: var(--imp-gray-900); }
.imp-alerta-plan-alertas span { font-size: 16px; font-weight: 400; color: var(--imp-gray-500); }
.imp-alerta-plan-checks { font-size: 13px; color: var(--imp-gray-500); margin: 4px 0 8px 0; }
.imp-alerta-plan-precio { font-size: 28px; font-weight: 700; color: var(--imp-primary); margin-top: 8px; }
.imp-alerta-plan-precio span { font-size: 14px; font-weight: 400; }
.imp-alerta-plan-ahorro { font-size: 13px; color: var(--imp-green-700); margin-top: 4px; }
