/* ==========================================================
   1. VARIABLES Y BASES (Consistente con tu diseño)
   ========================================================== */
:root {
    --bg-main: #1A1A2E;
    --bg-container: #16213E;
    --bg-chat: #0F172A;
    --text-main: #E2E8F0;
    --accent: #22D3EE; 
    --text-on-accent: #0f172a; 
    --msg-user: #28283D;
    --msg-bot: #1B2E36;
    --border: #334155;
}

.light-theme {
    --bg-main: #F8FAFC;
    --bg-container: #FFFFFF;
    --bg-chat: #FFFFFF;
    --text-main: #1E293B;
    --accent: #0891B2; 
    --msg-user: #CFFAFE; 
    --msg-bot: #F1F5F9;  
    --border: #E2E8F0;
}

/* Placeholder con el color del rayo */
#chat-input::placeholder {
    color: #2dd4bf; /* El Cian exacto del rayo */
    opacity: 0.5;
}

.aura-2m-circular {
    width: 45px;
    height: 45px;
    border-radius: 50px;
    background-color: rgba(45, 212, 191, 0.15);
    border: 1px solid rgba(45, 212, 191, 0.4);
    cursor: pointer;
    overflow: hidden;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
    padding: 0 12px;
}

/* Hover: Se expande y cambia colores */
.aura-2m-circular:hover {
    width: 90px;
    background-color: #2dd4bf;
    border-color: #2dd4bf;
}

.btn-2m-content {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.icon-rayo {
    color: #2dd4bf;
    font-size: 1.1rem;
    transition: color 0.3s ease;
}

.text-2m {
    color: #0f172a;
    font-size: 10px;
    font-weight: 900;
    display: none; /* Escondido inicialmente */
    opacity: 0;
    transition: opacity 0.3s ease;
}

/* Cambios al hacer Hover */
.aura-2m-circular:hover .icon-rayo {
    color: #0f172a; /* Rayo oscuro sobre fondo cian */
}

.aura-2m-circular:hover .text-2m {
    display: inline;
    opacity: 1;
}

* { 
    box-sizing: border-box; 
    margin: 0; 
    padding: 0; 
}

/* El truco del 100dvh para que no se oculte el footer */
html, body {
    height: 100dvh;
    font-family: 'Nunito', sans-serif;
    background-color: var(--bg-main);
    color: var(--text-main);
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

/* ==========================================================
   2. LAYOUT DINÁMICO (Flexbox es la clave)
   ========================================================== */
header {
    flex-shrink: 0; /* No se achica */
    padding: 0.5rem 1rem;
    background-color: var(--bg-container);
    border-bottom: 1px solid var(--border);
    min-height: 50px;
}

#chat-messages {
    flex: 1; /* Ocupa todo el espacio restante */
    overflow-y: auto;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    background-color: var(--bg-chat);
    -webkit-overflow-scrolling: touch;
}

#input-area {
    flex-shrink: 0;
    background-color: var(--bg-container);
    border-top: 1px solid var(--border);
    padding: 10px; /* Reducimos un poco el padding */
    width: 100%; /* Asegura que no se pase del borde */
}

/* El contenedor interno debe ser el que controle el ancho máximo */
.input-container {
    max-width: 100%; /* En móvil que ocupe todo */
    margin: 0 auto;
    display: flex;
    align-items: center;
    gap: 8px; /* Espacio entre botones e input */
}

/* ==========================================================
   3. COMPONENTES RE-AJUSTADOS
   ========================================================== */
.chat-message {
    padding: 10px 16px;
    border-radius: 1.2rem;
    max-width: 85%;
    font-size: 0.95rem;
    line-height: 1.4;
}

/* Corrección para mensajes del Coachee (Usuario) */
.chat-message.user {
    background-color: var(--accent); /* Tu color cyan/teal */
    color: #0f172a; /* Texto oscuro para que resalte sobre el cyan */
    align-self: flex-end;
    border-bottom-right-radius: 4px;
}

/* Ajustes específicos para el Modo Claro */
.light-theme {
    --bg-main: #f8fafc;
    --bg-card: #ffffff;
    --text-main: #1e293b;
}

.light-theme .chat-message.model {
    background-color: #e2e8f0;
    color: #1e293b; /* Texto de Aura Jade en gris oscuro */
}

/* Asegurar que el input del chat se vea bien */
.light-theme #chat-input {
    background-color: #ffffff;
    color: #1e293b;
    border-color: #cbd5e1;
}

.light-theme #chat-input::placeholder {
    color: #94a3b8;
}

.chat-message.model {
    align-self: flex-start;
    background-color: var(--msg-bot);
    border: 1px solid var(--border);
    border-bottom-left-radius: 4px;
}

/* Estilo del Slider compacto en footer */
.slider-wrapper {
    display: flex;
    align-items: center;
    gap: 10px;
    background: rgba(0, 0, 0, 0.2);
    padding: 4px 12px;
    border-radius: 12px;
    margin-bottom: 8px;
}

/* Gradiente dinámico para el slider */
input[type=range].slider-progress {
    --range-limit: 16.6%; /* 10min/60min para Sembrar */
    background: linear-gradient(to right, var(--accent) 0%, var(--accent) var(--range-limit), #334155 var(--range-limit), #334155 100%);
}

.light-theme input[type=range].slider-progress {
    background: linear-gradient(to right, var(--accent) 0%, var(--accent) var(--range-limit), #cbd5e1 var(--range-limit), #cbd5e1 100%);
}

input[type="range"] {
    flex: 1;
    height: 4px;
    accent-color: var(--accent);
}

#chat-input {
    flex: 1;
    padding: 10px 18px;
    border-radius: 20px;
    border: 1px solid var(--border);
    background-color: var(--bg-main);
    color: var(--text-main);
    font-size: 16px; /* Evita zoom automático en iOS */
    outline: none;
}

button {
    background-color: var(--accent);
    color: white;
    border: none;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hidden { display: none !important; }

/* Asegura que el texto del input sea oscuro en modo claro */
.light-theme #chat-input {
    background-color: #f1f5f9; /* Un gris muy suave */
    color: #1e293b !important; /* Azul oscuro/negro */
    border: 1px solid #cbd5e1;
}

/* Cambia el color del placeholder para que se vea */
.light-theme #chat-input::placeholder {
    color: #64748b;
}

/* Asegura que las letras del temporizador y slider sean legibles */
.light-theme #slider-val, 
.light-theme .slider-wrapper span {
    color: #0891b2 !important; /* Cian oscuro */
}

/* Si el texto de las burbujas de Aura desapareció: */
.light-theme .chat-message.model {
    color: #1e293b !important;
    background-color: #f1f5f9;
    border: 1px solid #e2e8f0;
}

/* ==========================================================
   3.1. IDENTIDAD DINÁMICA POR NIVEL 
   (Sobrescribe el Cian solo en la burbuja del Coachee)
   ========================================================== */

/* Nivel SEMILLA 🌱 - Verde Menta (Calma inicial) */
.aura-ui-semilla .chat-message.user {
    background-color: #86efac; 
    color: #064e3b !important; /* Texto verde oscuro */
    box-shadow: 0 4px 12px rgba(134, 239, 172, 0.2);
}
.aura-ui-semilla #chat-messages {
    border-top: 2px solid #86efac;
}

/* Nivel CRECER 🌿 - El Cian Eléctrico (Tu favorito) */
.aura-ui-crecer .chat-message.user {
    background-color: var(--accent); 
    color: var(--text-on-accent) !important;
}
.aura-ui-crecer #chat-messages {
    border-top: 2px solid var(--accent);
}

/* Nivel FLORECER 🌻 - Dorado Solar (Máxima expansión) */
.aura-ui-florecer .chat-message.user {
    background-color: #facc15; 
    color: #422006 !important; /* Texto marrón oscuro para contraste */
    box-shadow: 0 4px 15px rgba(250, 204, 21, 0.3);
}
.aura-ui-florecer #chat-messages {
    border-top: 2px solid #facc15;
    background-image: radial-gradient(circle at top right, rgba(250, 204, 21, 0.05), transparent);
}

/* El Rayo 2M se mantiene Cian para dar coherencia a la marca */
