:root {
    --bg-color: #f7f7ff;
    --content-bg: #fff;
    --card-bg:  #fffcee;
    --chat-bg: #ffffff;
    --primary-purple: #44607c;
    --primary-purple-dark: #2c3e50;
    --light-purple: #44607c14;
    --text-dark: #1e1e1e;
    --text-light: #6b7280;
    --text-suggestion: #2c2a50;
    --border-color: #e5e7eb;
    --success-color: #1AA99D;
    --font-family: 'Inter', sans-serif;
    --shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
    --shadow-hover: 0 6px 20px rgba(0, 0, 0, 0.08);
    --transition-fast: all 0.2s ease-in-out;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: var(--font-family); background-color: var(--card-bg); color: var(--text-dark); -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
.app-container { display: flex; min-height: 100vh; }
.hidden { display: none !important; }

/* --- Keyframes --- */
@keyframes dot-pulse{0%,80%,100%{transform:scale(0)}40%{transform:scale(1)}}
@keyframes pulse-glow {
    0% { transform: scale(1); box-shadow: 0 0 0 0 rgba(71, 112, 235, 0.7); }
    50% { transform: scale(1.03); }
    70% { box-shadow: 0 0 0 15px rgba(122, 92, 255, 0); }
    100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(66, 84, 252, 0); }
}
@keyframes blink { 50% { opacity: 0; } }
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* --- Sidebar, Header, etc. --- */
.sidebar{width:260px;background-color:var(--card-bg);padding:24px;display:flex;flex-direction:column;transition:var(--transition-fast)}.sidebar-header{display:flex;align-items:center;gap:8px;margin-bottom:32px}.logo-rpp{height:30px}.logo-epetm{height:30px}.sidebar-nav{display:flex;flex-direction:column;gap:12px}.nav-button{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:8px;text-decoration:none;font-weight:bold;font-size:15px;transition:var(--transition-fast)}.nav-button.nuevo-hilo{background-color:var(--light-purple);color:var(--primary-purple);border:1px solid var(--border-color);box-shadow:0 2px 8px rgba(122, 92, 255, 0.04);transition:var(--transition-fast),box-shadow .2s}.nav-button.nuevo-hilo:hover{background-color:var(--primary-purple);color:#fff;box-shadow:0 4px 16px rgba(122, 92, 255, 0.12);border-color:var(--primary-purple);transform:translateY(-2px) scale(1.04)}.nav-button.nuevo-hilo:active{background-color:var(--primary-purple-dark);color:#fff;box-shadow:0 2px 4px rgba(122, 92, 255, 0.1);border-color:var(--primary-purple-dark);transform:translateY(1px) scale(0.98)}.nav-button.iniciar-sesion{background-color:transparent;color:var(--text-dark);border:1px solid transparent}.sidebar-footer{margin-top:auto}.mas-title{font-size:14px;font-weight:600;color:var(--text-light);margin-bottom:12px}.footer-link{display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--text-light);padding:8px 0;font-size:15px;font-weight:500;transition:color .2s ease}.mobile-header{display:none}
.overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgba(0,0,0,.5);z-index:999;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.overlay.visible{opacity:1;visibility:visible}.body-no-scroll{overflow:hidden}
.main-content-wrapper { flex-grow: 1; display: flex; flex-direction: column; padding: 20px; max-height: 100vh; overflow: hidden; }
.main-content { flex-grow: 1; display: flex; flex-direction: column; background-color: var(--chat-bg); border-radius: 20px; box-shadow: 0 8px 30px rgba(0,0,0,0.05); position: relative; overflow-y: auto; border: solid 1px #e1e1e1cc; scroll-behavior: smooth; }
#welcome-view { padding: 20px; text-align: center; }
.logo-brujula img { opacity:.9; width:90px; height:90px; border-radius:22px; margin: 0 auto 24px; }
h1#welcome-heading { color: #2c2a50; font-size: clamp(1.4rem, 3vw, 1.8rem); font-weight: 700; line-height: 1.4; margin: 24px 80px; min-height: 80px; }
h1#welcome-heading::after { content: '|'; animation: blink 1s step-end infinite; font-weight: 100; color: #ccc; }
h1#welcome-heading.animation-complete::after { content: ''; }
.fade-in-item { opacity: 0; transform: translateY(20px); transition: opacity 0.5s ease, transform 0.5s ease; }
.fade-in-item.visible { opacity: 1; transform: translateY(0); }
#welcome-view .logo-brujula { transition-delay: 0s; }
#welcome-view #welcome-heading { transition-delay: 0s; }
#welcome-view .search-container-wrapper { transition-delay: 0.1s; }
#welcome-view .rpp-disclaimer { transition-delay: 0.2s; }
#welcome-view .suggestion-title { transition-delay: 0.3s; }
#welcome-view .suggestions-grid { transition-delay: 0.4s; }
.suggestion-title { font-size:.8rem; font-weight:600; color:var(--text-light); letter-spacing:.5px; margin:40px 0 20px; }
.suggestions-grid { display: grid; gap: 16px; grid-template-columns: repeat(3, 1fr); max-width: 900px; margin: 0 auto; }
.suggestion-card { display:flex; padding:16px; border:1px solid var(--border-color); border-radius:12px; font-weight:500; text-decoration:none; color:var(--text-dark); line-height: 1.4; text-align:left; align-items:center; justify-content:space-between; box-shadow:var(--shadow); transition:var(--transition-fast); background-color: var(--content-bg); cursor: pointer; }
.suggestion-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-hover); border-color: #d1c4ff; will-change: transform, box-shadow; }
.suggestion-card span { flex-grow: 1; padding-right: 8px; }

/* --- Componente de Búsqueda y Disclaimer --- */
.search-container-wrapper { position: relative; max-width: 900px; margin: 0 auto; }
.search-container { display: flex; align-items: center; gap: 8px; width: 100%; max-width: 900px; margin: 0 auto; padding: 8px 8px 8px 24px; border-radius: 28px; border: 1px solid #2c3e509e; background-color: #fff; box-shadow: var(--shadow); }
.search-container:focus-within { border-color: var(--primary-purple-dark); box-shadow: 0 0 0 4px var(--light-purple), 0 4px 12px rgba(0, 0, 0, 0.1); }
.search-container textarea { flex-grow: 1; border: none; background-color: transparent; box-shadow: none; padding: 0; margin: 0; font-size: 1rem; font-family: var(--font-family); line-height: 1.5; resize: none; overflow-y: hidden; min-height: 24px; }
.search-container textarea:focus { outline: none; }
.search-container textarea::placeholder { color: var(--text-light); }
.send-button { flex-shrink: 0; align-self: flex-end; width: 44px; height: 44px; border:none; border-radius:50%; color:#fff; cursor:pointer; display:flex; align-items:center; justify-content:center; background-image:linear-gradient(to top,var(--primary-purple),var(--primary-purple-dark)); transition:var(--transition-fast) }
.send-button:hover { transform: scale(1.08); box-shadow: 0 4px 15px rgba(106,72,242,.4); will-change: transform, box-shadow; }
#autocomplete-results { position: absolute; background: #fff; border: 1px solid var(--border-color); border-top: none; border-radius: 0 0 16px 16px; width: 100%; top: 95%; left: 0; z-index: 10; box-shadow: var(--shadow); }
.autocomplete-item { padding: 12px 24px; text-align: left; cursor: pointer; }
.autocomplete-item:hover { background-color: #f9fafb; }
.rpp-disclaimer { display: flex; align-items: center; justify-content: center; gap: 6px; margin-top: 12px; }
.rpp-disclaimer p { font-size: 13px; color: var(--text-light); margin: 0; }
.rpp-disclaimer svg { width: 16px; height: 16px; color: #1AA99D; }
#chat-flow-container { display: flex; flex-direction: column; height: 100%; }
.chat-log { flex-grow: 1; padding: 24px; display: flex; flex-direction: column; gap: 24px; max-width: 900px; width: 100%; margin: 0 auto; }
.user-bubble { align-self: flex-end; background-color: #44607c45; color: #000000; padding: 12px 20px; border-radius: 20px 20px 4px 20px; max-width: 80%; font-weight: 500; }
.assistant-response { display: flex; align-items: flex-start; gap: 12px; max-width: 100%; }
.assistant-response .logo-brujula { flex-shrink: 0; width: 32px; height: 32px; border-radius: 8px; }
.assistant-response .response-content { flex-grow: 1; color: var(--text-dark); line-height: 1.6; }
.assistant-response .response-content > div { transition: opacity 0.3s ease; }
.assistant-response p { margin-bottom: 1em; }
.preloader {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 16px;
}

.preloader-text {
    font-size: 15px;
    color: var(--text-dark);
    opacity: 1;
    transform: none;
}

.preloader-message {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px;
    transition: all 0.3s ease;
    opacity: 1;
}

.preloader-message.sponsored-message {
    background: linear-gradient(135deg, #002A8D, var(--primary-purple));
    color: white;
    padding: 16px 20px;
    transform: scale(1.05);
    box-shadow: 0 4px 15px rgba(0, 42, 141, 0.2);
    border-radius: 12px;
    font-weight: 600;
    animation: fadeInScale 0.3s ease-out;
}

@keyframes fadeInScale {
    from {
        opacity: 0;
        transform: scale(0.95);
    }
    to {
        opacity: 1;
        transform: scale(1.05);
    }
}

.preloader-icon {
    font-size: 1.2em;
    display: flex;
    align-items: center;
}

.preloader-text-content {
    flex-grow: 1;
}

.loading-dots {
    display: inline-flex;
    gap: 4px;
    margin-left: 4px;
}

.loading-dots span {
    width: 4px;
    height: 4px;
    background-color: currentColor;
    border-radius: 50%;
    animation: dotPulse 1.4s infinite;
}

.loading-dots span:nth-child(2) { animation-delay: 0.2s; }
.loading-dots span:nth-child(3) { animation-delay: 0.4s; }

@keyframes dotPulse {
    0%, 80%, 100% { transform: scale(0); opacity: 0; }
    40% { transform: scale(1); opacity: 1; }
}

.response-footer{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:16px;border-top:1px solid var(--border-color)}
.sources-button{display:flex;align-items:center;gap:8px;background-color:var(--primary-purple);color:#fff;border:none;padding:8px 12px 8px 16px;border-radius:99px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 2px 5px rgba(0,0,0,.1);transition:var(--transition-fast)}.sources-button.glow-animation{animation:pulse-glow 1.5s 1 .5s}.sources-button:hover{background-color:var(--primary-purple-dark);box-shadow:0 4px 10px rgba(0,0,0,.15);transform:translateY(-2px)}.sources-button:active{transform:translateY(0);box-shadow:0 2px 5px rgba(0,0,0,.1);background-color:#3b5a7a}
.notification-badge{display:flex;align-items:center;justify-content:center;width:22px;height:22px;background-color:var(--primary-purple-dark);color:#fff;border-radius:50%;font-size:12px;font-weight:700}
.feedback-buttons{display:flex;align-items:center;gap:4px}.feedback-buttons button{background:0 0;border:none;cursor:pointer;color:var(--text-light);padding:5px;border-radius:50%;position:relative;transition:var(--transition-fast);width: 30px;height: 30px;display: flex;align-items: center;justify-content: center}
.feedback-buttons button:hover{color:var(--primary-purple)}.feedback-buttons button:active{transform:scale(.9)}.feedback-buttons button.active{background-color:var(--light-purple);color:var(--primary-purple)}
.feedback-buttons button.copied { color: var(--success-color) !important; background-color: rgba(26, 169, 157, 0.1); }
.feedback-buttons button::after{content:attr(data-tooltip);position:absolute;bottom:120%;left:50%;transform:translateX(-50%);background-color:var(--text-dark);color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease}.feedback-buttons button:hover::after{opacity:1;visibility:visible}
.icon-thumb-up,
.icon-copy,
.icon-check {
    display: inline-block;
    width: 30px;
    height: 30px;
    background-color: currentColor;
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
}
.icon-thumb-up{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 9V5a3 3 0 0 0-3-3l-4 9v11h11.28a2 2 0 0 0 2-1.7l1.38-9a2 2 0 0 0-2-2.3zM7 22H4a2 2 0 0 1-2-2v-7a2 2 0 0 1 2-2h3'%3E%3C/path%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 9V5a3 3 0 0 0-3-3l-4 9v11h11.28a2 2 0 0 0 2-1.7l1.38-9a2 2 0 0 0-2-2.3zM7 22H4a2 2 0 0 1-2-2v-7a2 2 0 0 1 2-2h3'%3E%3C/path%3E%3C/svg%3E")}
.icon-copy{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='9' y='9' width='13' height='13' rx='2' ry='2'%3E%3C/rect%3E%3Cpath d='M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1'%3E%3C/path%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='9' y='9' width='13' height='13' rx='2' ry='2'%3E%3C/rect%3E%3Cpath d='M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1'%3E%3C/path%3E%3C/svg%3E")}
.icon-check{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E")}
.icon-inverted { transform: rotate(180deg); }
.related-section, .sources-section { border: 1px solid var(--border-color); border-radius: 16px; margin-top: 24px; background-color: var(--chat-bg); transition: opacity .3s ease; }
.related-title { display: flex; align-items: center; gap: 8px; font-weight: 600; padding: 16px; border-bottom: 1px solid var(--border-color); }
.related-item { display: flex; justify-content: space-between; align-items: center; padding: 16px; text-decoration: none; color: var(--text-dark); font-weight: 500; transition: background-color .2s ease; }
.related-item:not(:last-child) { border-bottom: 1px solid var(--border-color); }
.related-item:hover { background-color: #f9fafb; }
.related-item svg { color: var(--primary-purple); flex-shrink: 0; }
.sources-section .related-title { justify-content: space-between; padding: 12px 16px; }
.source-item { display: flex; align-items: center; gap: 16px; padding: 16px; text-decoration: none; color: var(--text-dark); transition: background-color .2s ease; }
.source-item:not(:last-child) { border-bottom: 1px solid var(--border-color); }
.source-item:hover { background-color: #f9fafb; }
.source-item-img { width: 100px; height: 100px; object-fit: cover; border-radius: 8px; flex-shrink: 0; }
.source-item-text { flex: 1; min-width: 0; }
.source-item-text h4 { margin: 0 0 4px; font-size: 1rem; font-weight: 600; white-space: normal; word-break: break-word; }
.source-item-text p { margin: 0; font-size: 13px; color: var(--text-light); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.back-button { background: 0 0; border: none; cursor: pointer; color: var(--text-light); font-weight: 600; font-size: 14px; padding: 4px; display: flex; align-items: center; gap: 4px; }
.back-button:hover { color: var(--primary-purple); }
.list-item-paragraph{padding-left:25px;text-indent:-25px}
.sticky-input-wrapper{position:sticky;bottom:0;background-image:linear-gradient(to top,var(--chat-bg) 80%,rgba(247,247,247,0));padding:16px 24px}
#chat-search-container{max-width:900px;margin:0 auto}

.sponsor-section {
    margin-top: 40px;
    text-align: center;
}

.sponsor-text {
    font-size: 14px;
    color: var(--text-light);
    margin-bottom: 12px;
}

.sponsor-logo {
    max-width: 270px;
    width: 100%;
    height: auto;
}

@media (max-width:768px){
    body{background-color:var(--card-bg)}.app-container{flex-direction:column}
    .sidebar{position:fixed;top:0;left:-280px;z-index:1001;height:100%;box-shadow:0 0 60px rgba(0,0,0,.2);background-color:var(--card-bg)}
    .sidebar.visible{left:0}
    .mobile-header{position:sticky;top:0;z-index:999;display:flex;padding:12px 16px;border-bottom:1px solid rgba(229,231,255,.5);align-items:center;justify-content:flex-start;gap:16px;background-color:rgba(255,255,255,.8);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
    .nuevo-hilo-compact{margin-left:auto;padding:8px;border-radius:50%;border: 1px solid var(--border-color);background-color:var(--light-purple);color:var(--primary-purple)}
    .main-content-wrapper{padding:0;overflow:visible;max-height:none}
    .main-content{z-index:1;padding:0;border:none;margin-top:0;box-shadow:none;border-radius:0}
    #welcome-view{padding:12px}
    .logo-brujula img { width:70px; height:70px; border-radius:18px; margin: 0 auto 16px; }
    h1#welcome-heading { font-size: clamp(1.2rem, 2.5vw, 1.5rem); margin: 0 0 16px 0; min-height: 60px; }
    .search-container { padding: 8px 8px 8px 16px; margin: 50px 0px 10px 0px;}
    .rpp-disclaimer { margin-top: 10px; }
    .suggestion-title { margin: 50px 0px 12px; }
    .suggestions-grid{display:grid;grid-auto-flow:column;grid-template-rows:repeat(2,auto);gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -12px;padding:4px 12px;scrollbar-width:none}.suggestions-grid::-webkit-scrollbar{display:none}.suggestion-card{width:265px;padding:12px}
    .search-container-wrapper{max-width:100%}
    .chat-log{padding:16px 16px 140px}
    .sticky-input-wrapper{position:fixed;bottom:0;left:0;right:0;background-color:var(--chat-bg);padding:12px 16px;border-top:1px solid var(--border-color);background-image:none}
    .menu-toggle{background:0 0;border:none;cursor:pointer;padding:0;width:24px;height:24px;position:relative;z-index:1002}
    .menu-toggle .bar{display:block;width:100%;height:2px;background-color:var(--text-dark);border-radius:2px;position:absolute;left:0;transition:all .3s ease}
    .menu-toggle .bar:nth-child(1){top:4px}
    .menu-toggle .bar:nth-child(2){top:10.5px}
    .menu-toggle .bar:nth-child(3){top:17px}
    .menu-toggle.is-active .bar:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
    .menu-toggle.is-active .bar:nth-child(2){opacity:0}
    .menu-toggle.is-active .bar:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
    .assistant-response { flex-direction: column; align-items: flex-start; gap: 8px; }
    .assistant-response .response-content { width: 100%; }
    .source-item { gap: 12px; padding: 12px; }
    .source-item-img { width: 80px; height: 80px; }
    .source-item-text h4 { font-size: 0.9rem; }
    .sponsor-section {
        margin-top: 16px;
    }
    .sponsor-logo {
        max-width: 150px;
    }
    .responsive-table {
        overflow: auto;
        -webkit-overflow-scrolling: touch;
    }
    .responsive-table th,
    .responsive-table td {
        padding: 12px 16px;
        font-size: 0.85rem;
    }
    .sponsor-section{
        margin-bottom: 180px;
    }
}
/* Hide login button */
.nav-button.iniciar-sesion, .mobile-user-icon {
    display: none !important;
}

.sponsor-block {
    margin-top: 24px;
    padding-top: 16px;
    border-top: 1px solid var(--border-color);
    text-align: center;
}

.sponsor-text-footer {
    font-size: 12px;
    color: var(--text-light);
    margin-bottom: 8px;
}

.sponsor-logo-footer {
    max-width: 150px;
    height: auto;
    opacity: 0.8;
}

/* --- MAS SECTION (Recursos Interactivos) --- */
.mas-section {
    padding: 20px 0;
    margin: 24px 0;
}
.mas-title {
    font-size: 1rem;
    font-weight: 500;
    color: var(--primary-purple);
    margin-bottom: 4px;
}
.mas-desc {
    font-size: 0.95rem;
    color: var(--text-light);
    margin-bottom: 16px;
}
.mas-links {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.mas-card {
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--light-purple);
    border-radius: 8px;
    padding: 12px 16px;
    box-shadow: 0 1px 4px rgba(122, 92, 255, 0.05);
    transition: box-shadow 0.2s;
    text-decoration: none;
    color: var(--primary-purple);
    font-weight: 600;
    border: 1px solid #e2e2e2;
}
.mas-card:hover {
    box-shadow: 0 4px 12px rgba(122, 92, 255, 0.12);
    background: var(--light-purple);
    color: var(--primary-purple-dark);
}
.mas-icon {
    font-size: 1.3em;
    display: flex;
    align-items: center;
}
@media (max-width: 768px) {
    .mas-section {
        margin: 16px 0;
        padding: 16px 0;
    }
    .mas-card {
        padding: 10px 12px;
        font-size: 0.98em;
    }
}

/* === Table Enhancements === */
.responsive-table {
    border-radius: 12px;
    overflow: hidden; /* Ensures the border-radius is respected by the table inside */
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
    margin: 1.5em 0;
    border: 1px solid #e0e0e0;
}

.responsive-table table {
    width: 100%;
    border-collapse: collapse;
    background-color: #ffffff;
    border-radius: 10px;
    overflow: hidden;
}

.responsive-table th,
.responsive-table td {
    padding: 16px 20px;
    text-align: left;
    border-bottom: 1px solid #e9e9e9;
}

.responsive-table thead th {
    background-color: #f7f9fa;
    font-weight: 600;
    color: #333;
    font-size: 0.9em;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.responsive-table tbody tr:last-child td {
    border-bottom: none;
}

.responsive-table tbody tr:hover {
    background-color: #fcfcfc;
}

/* === Animation for scroll-in === */
.hidden-initially {
    opacity: 0;
    transform: translateY(20px);
    visibility: hidden;
    height: 0;
    overflow: hidden;
    transition: opacity 0.6s ease-out, transform 0.6s ease-out, visibility 0.6s ease-out, height 0.6s ease-out;
}

.fade-in-up {
    opacity: 1;
    transform: translateY(0);
    visibility: visible;
    height: auto;
    overflow: visible;
}

/* === Sponsor CTA Enhancements (Native Feel) === */
.sponsored-content-card {
    position: relative; /* For label positioning */
    overflow: hidden; /* To clip the label to the border-radius */
    border-radius: 16px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    border-left: 5px solid #002A8D; /* Borde de acento con color sponsor */
    box-shadow: var(--shadow); /* Sombra estándar de la app */
    margin: 1.5em 0em;
    background-color: var(--card-bg); /* Fondo nativo */
    color: var(--text-dark); /* Texto nativo */
    transition: var(--transition-fast);
}

.sponsored-content-card::after {
    content: 'CONTENIDO PATROCINADO';
    position: absolute;
    top: 0;
    right: 0;
    padding: 6px 12px;
    background-color: var(--light-purple);
    color: var(--primary-purple);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.5px;
    border-bottom-left-radius: 16px; /* Shape for the corner */
    text-transform: uppercase;
}

.sponsored-content-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-hover);
}

.sponsored-content-card .sponsor-logo-container {
    margin-bottom: 0;
}

.sponsored-content-card .sponsor-logo-small {
    max-height: 30px;
    width: auto;
}

.sponsored-content-card .sponsor-content-text h4 {
    font-size: 1.1rem;
    font-weight: 700;
    margin: 0 0 8px 0;
    color: #002A8D; /* Título con color sponsor para branding */
}

.sponsored-content-card .sponsor-content-text p {
    font-size: 0.95rem;
    line-height: 1.6;
    margin: 0 0 16px 0;
    color: var(--text-light); /* Color de texto secundario nativo */
    opacity: 1;
}

.sponsor-cta-button {
    display: inline-block;
    padding: 12px 24px;
    border-radius: 8px;
    font-weight: 600;
    text-decoration: none;
    text-align: center;
    transition: var(--transition-fast);
    /* CTA con el color primario de la app para coherencia */
    background-image: linear-gradient(to top, var(--primary-purple), var(--primary-purple-dark));
    color: #ffffff;
    border: none;
    cursor: pointer;
    align-self: flex-start; /* Alinear a la izquierda */
}

.sponsor-cta-button:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(106, 72, 242, 0.4); /* Sombra del botón nativo */
}

.responsive-table,
.sponsored-content-card {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.6s ease, transform 0.6s ease;
}

.responsive-table.visible,
.sponsored-content-card.visible {
    opacity: 1;
    transform: translateY(0);
}

.preloader-message {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px;
    transition: all 0.3s ease;
    opacity: 1;
}

.preloader-message.sponsored-message {
    background: linear-gradient(135deg, #002A8D, var(--primary-purple));
    color: white;
    padding: 16px 20px;
    transform: scale(1.05);
    box-shadow: 0 4px 15px rgba(0, 42, 141, 0.2);
    font-weight: 600;
    animation: fadeInScale 0.3s ease-out;
}

@keyframes fadeInScale {
    from {
        opacity: 0;
        transform: scale(0.95);
    }
    to {
        opacity: 1;
        transform: scale(1.05);
    }
}

/* elevenlabs-convai{
    display: none;
} */