/* =========================================================================
   styles.css — SOLO estilos del panel de Marta.
   Temas con variables: CLARO por defecto (:root) y OSCURO ([data-theme="dark"]).
   Los nombres antiguos (--green-card, --soft, --white, --line-2…) se mantienen
   como ALIAS de los tokens del tema, así todas las reglas siguen funcionando.
   Prohibido el estilo inline en las vistas.
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Fredoka:wght@500;600;700&family=Quicksand:wght@400;500;600;700&family=Oswald:wght@500;600;700&display=swap');

/* --- TEMA CLARO (por defecto) --- */
:root {
    /* Tipografías */
    --fuente-titulo: 'Fredoka', system-ui, sans-serif;
    --fuente-texto:  'Quicksand', system-ui, sans-serif;
    --fuente-label:  'Oswald', sans-serif;
    --radio: 14px;

    /* Tokens del tema (claro) */
    --bg: #f4efe6;
    --bg-glow: #e9f3f0;
    --surface: #ffffff;
    --surface-2: #faf7f1;
    --surface-3: #f0ece3;
    --ink: #14241f;
    --ink-soft: #5d6b66;
    --turquoise: #0f9d8b;          /* acentos / texto (más oscuro para contraste) */
    --turquoise-bright: #1ecdba;   /* rellenos (botones, activos) */
    --teal: #0e857a;
    --sand: #e7ddcc;
    --gold: #b88a16;
    --red: #c96a5b;
    --line: rgba(20, 36, 31, 0.10);
    --line-strong: rgba(20, 36, 31, 0.22);
    --tint-turq: rgba(15, 157, 139, 0.12);
    --tint-gold: rgba(184, 138, 22, 0.14);
    --tint-red: rgba(201, 106, 91, 0.14);
    --card-shadow: 0 6px 20px rgba(20, 36, 31, 0.06);

    color-scheme: light;

    /* Alias de compatibilidad (nombres antiguos -> tokens del tema) */
    --green-deep: var(--bg);
    --green-deep-2: var(--surface);
    --green-card: var(--surface);
    --green-card-2: var(--surface-3);
    --panel-bg: var(--surface);
    --turquoise-soft: var(--turquoise-bright);
    --white: var(--ink);
    --soft: var(--ink-soft);
    --line-2: var(--line);
}

/* --- TEMA OSCURO --- */
[data-theme="dark"] {
    --bg: #052623;
    --bg-glow: #0c4a43;
    --surface: #0b423c;
    --surface-2: #0e4d45;
    --surface-3: #105751;
    --ink: #ffffff;
    --ink-soft: rgba(255, 255, 255, 0.74);
    --turquoise: #1ecdba;
    --turquoise-bright: #2adfca;
    --teal: #0e857a;
    --sand: #d9ccb7;
    --gold: #ecbb52;
    --red: #e08a7d;
    --line: rgba(255, 255, 255, 0.10);
    --line-strong: rgba(255, 255, 255, 0.30);
    --tint-turq: rgba(30, 205, 186, 0.16);
    --tint-gold: rgba(236, 187, 82, 0.16);
    --tint-red: rgba(224, 138, 125, 0.18);
    --card-shadow: none;

    color-scheme: dark;
}

/* --- Reset ligero --- */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html, body {
    height: 100%;
}

/* Fondo del tema: degradado fijo al viewport, en el background del propio html.
   Así queda SIEMPRE por detrás del contenido (sin z-index que pueda montarse
   sobre las tarjetas) y sin bandas al hacer scroll. */
html {
    background-color: var(--bg);
    background-image:
        radial-gradient(80% 60% at 85% -10%, var(--bg-glow) 0%, transparent 55%),
        radial-gradient(70% 50% at 0% 0%, var(--bg-glow) 0%, transparent 50%);
    background-attachment: fixed;
    background-repeat: no-repeat;
}

body {
    font-family: var(--fuente-texto);
    color: var(--ink);
    background: transparent;       /* el fondo lo pinta el html */
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}

/* --- Contenedor central --- */
.contenedor {
    width: 100%;
    max-width: 880px;
    margin: 0 auto;
    padding: 0 20px;
}

/* --- Cabecera (check.php / layout) --- */
.cabecera {
    padding: 32px 0 24px;
    border-bottom: 1px solid var(--line);
}

.marca {
    font-family: var(--fuente-titulo);
    font-weight: 700;
    font-size: 1.9rem;
    color: var(--turquoise);
    letter-spacing: 0.3px;
}

.marca-sub {
    color: var(--ink-soft);
    font-size: 0.95rem;
    margin-top: 2px;
}

/* --- Cuerpo --- */
main.contenedor {
    padding-top: 28px;
    padding-bottom: 48px;
}

/* --- Estados --- */
.estado {
    font-family: var(--fuente-titulo);
    font-weight: 600;
    font-size: 1.05rem;
    padding: 12px 16px;
    border-radius: var(--radio);
    margin-bottom: 22px;
}

.estado-ok {
    background: var(--tint-turq);
    color: var(--turquoise);
    border: 1px solid var(--tint-turq);
}

.estado-error {
    background: var(--tint-gold);
    color: var(--gold);
    border: 1px solid var(--tint-gold);
}

.detalle-error {
    font-family: monospace;
    font-size: 0.85rem;
    color: var(--ink-soft);
    background: var(--surface);
    padding: 12px 16px;
    border-radius: var(--radio);
    overflow-x: auto;
}

/* --- Tabla de comprobación --- */
.tabla-check {
    width: 100%;
    border-collapse: collapse;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radio);
    overflow: hidden;
    box-shadow: var(--card-shadow);
}

.tabla-check th,
.tabla-check td {
    text-align: left;
    padding: 12px 16px;
    border-bottom: 1px solid var(--line);
}

.tabla-check thead th {
    font-family: var(--fuente-titulo);
    font-weight: 600;
    color: var(--gold);
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.tabla-check tbody tr:last-child td {
    border-bottom: none;
}

.tabla-check td.num {
    font-variant-numeric: tabular-nums;
    color: var(--ink-soft);
}

/* Badge de estado por fila */
.badge {
    display: inline-block;
    font-size: 0.78rem;
    font-weight: 600;
    padding: 3px 10px;
    border-radius: 999px;
    background: var(--tint-turq);
    color: var(--turquoise);
}

.fila-falta .badge {
    background: var(--tint-gold);
    color: var(--gold);
}

.fila-falta td {
    opacity: 0.7;
}

/* --- Pie --- */
.pie {
    border-top: 1px solid var(--line);
    padding: 20px 0;
    color: var(--ink-soft);
    font-size: 0.85rem;
}

/* =========================================================================
   BLOQUE 2 — Login.
   ========================================================================= */

.login-wrap {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.login-card {
    width: 100%;
    max-width: 380px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radio);
    padding: 34px 30px;
    text-align: center;
    box-shadow: var(--card-shadow);
}

.login-logo {
    width: 64px;
    height: 64px;
    margin: 0 auto 16px;
}

.login-logo svg,
.login-logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.login-titulo {
    font-family: var(--fuente-titulo);
    font-weight: 700;
    font-size: 1.4rem;
    color: var(--turquoise);
}

.login-sub {
    color: var(--ink-soft);
    font-size: 0.9rem;
    margin: 4px 0 22px;
}

.login-error {
    background: var(--tint-gold);
    color: var(--gold);
    border: 1px solid var(--tint-gold);
    border-radius: var(--radio);
    padding: 10px 14px;
    font-size: 0.9rem;
    margin-bottom: 18px;
}

.login-form {
    text-align: left;
}

.login-label {
    display: block;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--ink-soft);
    margin: 14px 0 6px;
}

.login-input {
    width: 100%;
    padding: 11px 14px;
    font-family: var(--fuente-texto);
    font-size: 0.95rem;
    color: var(--ink);
    background: var(--surface-2);
    border: 1px solid var(--line);
    border-radius: 10px;
    outline: none;
}

.login-input:focus {
    border-color: var(--turquoise);
}

.login-btn {
    width: 100%;
    margin-top: 22px;
    padding: 12px 16px;
    font-family: var(--fuente-titulo);
    font-weight: 600;
    font-size: 1rem;
    color: #042;
    background: var(--turquoise-bright);
    border: none;
    border-radius: 10px;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease;
}

.login-btn:hover {
    background: var(--teal);
    color: #ffffff;
}

/* --- Página protegida (saludo de bienvenida) --- */
.panel-bienvenida {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radio);
    padding: 28px;
    box-shadow: var(--card-shadow);
}

.saludo {
    font-family: var(--fuente-titulo);
    font-weight: 700;
    font-size: 1.6rem;
    color: var(--turquoise);
}

.saludo-sub {
    color: var(--ink-soft);
    margin: 6px 0 18px;
}

.enlace-logout {
    color: var(--gold);
    text-decoration: none;
    font-weight: 600;
}

.enlace-logout:hover {
    text-decoration: underline;
}

/* =========================================================================
   BLOQUE 3 — Dashboard (bento).
   ========================================================================= */

body.dash {
    color: var(--ink);
    font-family: var(--fuente-texto);
    min-height: 100vh;
    overflow-x: hidden; /* el drawer vive fuera de pantalla a la derecha */
}

.dash .glow { text-shadow: 0 0 16px rgba(255, 255, 255, 0.35), 0 0 40px rgba(30, 205, 186, 0.18); }
.dash .wrap { max-width: 1180px; margin: 0 auto; padding: 34px 28px 60px; }

/* --- Cabecera del dashboard --- */
.dash .top { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 30px; flex-wrap: wrap; gap: 16px; }
.dash .logo { display: flex; align-items: center; gap: 12px; }
.dash .logo svg { width: 42px; height: 42px; }
/* Logo de marca como imagen transparente (vale para tema claro y oscuro) */
.dash .logo .logo-img { height: 42px; width: auto; display: block; }
.dash .logo .t b { font-family: var(--fuente-titulo); font-weight: 600; font-size: 18px; display: block; line-height: 1; }
.dash .logo .t span { font-family: var(--fuente-label); font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; font-size: 10px; color: var(--turquoise); }
.dash .hi .eyebrow { font-family: var(--fuente-label); font-weight: 600; letter-spacing: 2px; text-transform: uppercase; font-size: 11px; color: var(--turquoise); display: block; }
.dash .hi h1 { font-family: var(--fuente-titulo); font-weight: 600; font-size: 30px; line-height: 1.05; }
.dash .logout-link { color: var(--gold); text-decoration: none; font-weight: 600; font-size: 12px; }
.dash .logout-link:hover { text-decoration: underline; }

/* Bloque izquierdo de cabecera: logo arriba y saludo justo debajo */
.dash .brand { display: flex; flex-direction: column; gap: 14px; }
/* Acciones a la derecha: botón de tema + cerrar sesión */
.dash .top-actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }

/* Botón de tema (claro/oscuro) — sin scope, sirve en el dashboard y en check.php */
.theme-btn { display: inline-flex; align-items: center; gap: 6px; border: 1px solid var(--line); background: var(--surface); color: var(--ink); border-radius: 20px; padding: 8px 14px; font-family: var(--fuente-texto); font-weight: 600; font-size: 12.5px; cursor: pointer; transition: 0.2s; box-shadow: var(--card-shadow); }
.theme-btn:hover { border-color: var(--turquoise); color: var(--turquoise); }

/* Cabecera de check.php: marca a la izquierda, botón de tema a la derecha */
.cabecera-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.acciones-inline { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }

/* =========================================================================
   PÁGINA DE USUARIOS (equipo de admins + accesos de clientes).
   Reutiliza .card, .cli, .pill, .btn, .ctrl, .lbl, .form-sec ya existentes.
   ========================================================================= */

.dash .usuarios-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 18px; }
@media (max-width: 860px) { .dash .usuarios-grid { grid-template-columns: minmax(0, 1fr); } }

.dash .u-lista { margin-top: 6px; }
.dash .u-lista .cli { border: none; border-bottom: 1px solid var(--line); border-radius: 0; }
.dash .u-lista .cli:last-child { border-bottom: none; }
.dash .u-lista .cli:hover { background: transparent; }

/* Botón eliminar admin */
.dash .u-del { flex: none; border: 1px solid var(--line); background: var(--surface-2); color: var(--red); font-family: var(--fuente-texto); font-weight: 600; font-size: 11.5px; padding: 6px 12px; border-radius: 20px; cursor: pointer; transition: 0.2s; }
.dash .u-del:hover { border-color: var(--red); }

/* Columna de estado + acción de cada cliente */
.dash .u-estado-col { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; flex: none; }
.dash .u-reset { border: 1px solid var(--line); background: var(--surface-2); color: var(--turquoise); font-family: var(--fuente-texto); font-weight: 600; font-size: 11.5px; padding: 6px 12px; border-radius: 20px; cursor: pointer; transition: 0.2s; white-space: nowrap; }
.dash .u-reset:hover { border-color: var(--turquoise); }
.dash .u-reset[disabled] { opacity: 0.5; cursor: not-allowed; }

/* Pastillas de estado de acceso */
.dash .pill.estado-con-acceso { background: var(--tint-turq); color: var(--turquoise); }
.dash .pill.estado-pendiente { background: var(--tint-gold); color: var(--gold); }
.dash .pill.estado-sin-email { background: var(--surface-2); color: var(--ink-soft); }

/* =========================================================================
   EDITOR DE MENÚS (7 días × 5 comidas) + acciones.
   ========================================================================= */

/* Rejilla de días: se apila en móvil, varias columnas en pantallas anchas */
.dash .menu-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 16px; margin-top: 16px; }

/* Tarjeta de cada día */
.dash .menu-dia-tit { font-family: var(--fuente-titulo); font-weight: 600; font-size: 16px; color: var(--turquoise); margin-bottom: 6px; }
.dash .menu-dia .lbl { margin: 10px 0 4px; }
.dash .menu-campo { min-height: 44px; line-height: 1.4; }

/* Acciones (guardar / PDF) */
.dash .menu-acciones { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 18px; }
.dash .menu-acciones .btn { margin-top: 0; }

/* Botón secundario "ghost" */
.dash .btn.ghost { background: transparent; border: 1px solid var(--line); color: var(--ink); }
/* Botón de acción destructiva (eliminar) */
.dash .btn.peligro { background: transparent; border: 1px solid #e0a59c; color: #c0503c; }
.dash .btn.peligro:hover { background: rgba(192, 80, 60, 0.08); border-color: #c0503c; }
.dash .btn.ghost:hover { border-color: var(--turquoise); color: var(--turquoise); filter: none; }

/* --- Menús por semana: tarjetas de cliente, navegación y tarjeta de la ficha --- */

/* Lista de clientes (una tarjeta por cliente) */
.dash .menu-clientes-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 14px; }
.dash .menu-cli-card { display: flex; flex-direction: column; align-items: center; gap: 10px; text-align: center; text-decoration: none; color: var(--ink); cursor: pointer; }
.dash .menu-cli-card .av { width: 54px; height: 54px; font-size: 18px; }
.dash .menu-cli-nombre { font-family: var(--fuente-titulo); font-weight: 500; font-size: 14px; }

/* Navegación por semanas en el editor */
.dash .sem-nav { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-top: 10px; }
.dash .sem-rango { font-family: var(--fuente-titulo); font-weight: 600; font-size: 15px; }

/* Tarjeta "Menú semanal" dentro de la ficha (lectura) */
.dash .fm-nav { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 12px; }
.dash .fm-rango { font-family: var(--fuente-titulo); font-weight: 600; font-size: 14px; text-transform: capitalize; }
.dash .fm-dia { background: var(--surface-2); border: 1px solid var(--line); border-radius: 13px; padding: 10px 14px 12px; margin-bottom: 8px; }
.dash .fm-dia-tit { font-family: var(--fuente-label); font-weight: 600; letter-spacing: 0.8px; text-transform: uppercase; font-size: 10px; color: var(--turquoise); margin-bottom: 4px; }
.dash .fm-comida { margin-top: 6px; }
.dash .fm-comida span { font-size: 10px; text-transform: uppercase; letter-spacing: 0.4px; color: var(--ink-soft); font-weight: 700; }
.dash .fm-comida p { font-size: 12.5px; color: var(--ink-soft); line-height: 1.45; }
.dash #fm-editar { margin-top: 12px; }

/* --- IA: sugerencias de "siguientes pasos" (borrador editable) --- */
.dash #ns-ia { margin-top: 10px; }
.dash .ia-cargando { color: var(--ink-soft); font-size: 13px; padding: 14px 0; text-align: center; }
.dash .ia-vacio { color: var(--ink-soft); font-size: 13px; padding: 12px 0; }
.dash .ia-sug { margin-top: 10px; }
.dash .ia-item { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.dash .ia-item .ia-check { width: 18px; height: 18px; flex: none; accent-color: var(--turquoise-bright); cursor: pointer; }
.dash .ia-item .ia-texto { flex: 1; min-width: 0; }
.dash .ia-item .ia-prio { flex: none; width: 92px; }

/* Botón y aviso de "rellenar desde foto" */
.dash #foto-ia { margin-top: 0; margin-bottom: 6px; }
.dash .ia-borrador { background: var(--tint-gold); color: var(--gold); border: 1px solid var(--tint-gold); border-radius: 12px; padding: 10px 14px; font-size: 12.5px; font-weight: 600; margin: 4px 0 6px; }

/* --- Cuadrícula del dashboard (áreas) --- */
.dash .grid {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
    grid-template-areas:
        "cal cal"
        "priv cli"
        "priv todo";
    gap: 18px;
}
.dash .card { background: var(--surface); border: 1px solid var(--line); border-radius: 22px; padding: 22px; position: relative; overflow: hidden; min-width: 0; box-shadow: var(--card-shadow); }
.dash .card h2 { font-family: var(--fuente-titulo); font-weight: 600; font-size: 18px; display: flex; align-items: center; gap: 10px; margin-bottom: 4px; }
.dash .card .sub { font-size: 12.5px; color: var(--ink-soft); margin-bottom: 16px; }
.dash .card .ic { width: 36px; height: 36px; border-radius: 11px; background: var(--tint-turq); display: flex; align-items: center; justify-content: center; flex: none; }

/* Asignación de cada tarjeta a su área */
.dash .c-stats   { grid-area: cal; }
.dash .c-clients { grid-area: priv; }
.dash .c-wa      { grid-area: cli; }
.dash .c-tasks   { grid-area: todo; }

@media (max-width: 860px) {
    .dash .grid {
        grid-template-columns: minmax(0, 1fr);
        grid-template-areas:
            "cal"
            "priv"
            "cli"
            "todo";
    }
}

/* Etiqueta discreta "se conecta en el próximo bloque" */
.dash .soon {
    position: absolute; top: 18px; right: 18px;
    font-family: var(--fuente-label); font-size: 9px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.6px; color: var(--gold);
    background: var(--tint-gold); border: 1px solid var(--tint-gold);
    padding: 4px 9px; border-radius: 20px;
}

/* --- Lista de pacientes / filas tipo cliente --- */
.dash .cli { display: flex; align-items: center; gap: 13px; padding: 12px; border-radius: 14px; border: 1px solid transparent; transition: 0.18s; }
.dash .cli:hover { background: var(--surface-3); border-color: var(--line); }
.dash .av { width: 42px; height: 42px; border-radius: 50%; flex: none; display: flex; align-items: center; justify-content: center; font-family: var(--fuente-titulo); font-weight: 600; color: #042; font-size: 16px; }

/* Los 5 colores de avatar (turquesa de marca en ambos temas) */
.dash .av.c0 { background: linear-gradient(135deg, #1ecdba, #0a4a44); }
.dash .av.c1 { background: linear-gradient(135deg, #ecbb52, #0a4a44); }
.dash .av.c2 { background: linear-gradient(135deg, #3aa0d8, #0a4a44); }
.dash .av.c3 { background: linear-gradient(135deg, #d88a8a, #0a4a44); }
.dash .av.c4 { background: linear-gradient(135deg, #a3c97a, #0a4a44); }

.dash .cli .grow { flex: 1; min-width: 0; }
.dash .cli h4 { font-family: var(--fuente-titulo); font-weight: 500; font-size: 15px; }
.dash .cli p { font-size: 12px; color: var(--ink-soft); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dash .pill { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; padding: 4px 9px; border-radius: 20px; background: var(--tint-turq); color: var(--turquoise); flex: none; }
.dash .pill.lead { background: var(--tint-gold); color: var(--gold); }

/* --- Formularios --- */
.dash .lbl { font-family: var(--fuente-label); font-weight: 600; letter-spacing: 1px; text-transform: uppercase; font-size: 10px; color: var(--turquoise); margin: 14px 0 6px; display: block; }
.dash .ctrl { width: 100%; background: var(--surface-2); border: 1.5px solid var(--line); border-radius: 13px; color: var(--ink); font-family: var(--fuente-texto); font-weight: 500; font-size: 14px; padding: 12px 14px; outline: none; transition: 0.2s; }
.dash .ctrl:focus { border-color: var(--turquoise); }
.dash textarea.ctrl { resize: vertical; min-height: 64px; line-height: 1.5; }
.dash input.ctrl[type="date"] { color-scheme: inherit; }
.dash .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.dash .btn { border: none; border-radius: 50px; padding: 13px 22px; font-family: var(--fuente-titulo); font-weight: 600; font-size: 14px; cursor: pointer; transition: 0.22s; background: var(--turquoise-bright); color: #042; }
.dash .btn:hover { filter: brightness(1.06); }
.dash .btn.full { width: 100%; margin-top: 18px; }
.dash .btn.wa { background: #25D366; color: #053; }
.dash .btn[disabled] { opacity: 0.5; cursor: not-allowed; }
.dash .ctrl[disabled] { opacity: 0.65; cursor: not-allowed; }

/* --- Tareas (placeholder antiguo) --- */
.dash .task { display: flex; align-items: flex-start; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--line); }
.dash .task:last-child { border-bottom: none; }
.dash .task .box { width: 20px; height: 20px; border-radius: 6px; border: 2px solid var(--line-strong); flex: none; margin-top: 1px; }
.dash .task .grow { flex: 1; }
.dash .task h4 { font-family: var(--fuente-texto); font-weight: 600; font-size: 14px; }
.dash .task p { font-size: 11.5px; color: var(--ink-soft); }
.dash .task .time { font-size: 11px; color: var(--gold); font-weight: 700; flex: none; }

/* --- Facturación (placeholder antiguo) --- */
.dash .stat-top { display: flex; gap: 14px; margin-bottom: 18px; }
.dash .stat { flex: 1; background: var(--surface-2); border-radius: 14px; padding: 13px; }
.dash .stat b { font-family: var(--fuente-titulo); font-weight: 600; font-size: 24px; display: block; }
.dash .stat span { font-size: 11px; color: var(--ink-soft); }
.dash .stat.main b { color: var(--turquoise); }
.dash .chart { display: flex; align-items: flex-end; gap: 9px; height: 120px; }
.dash .chart .col { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 7px; height: 100%; justify-content: flex-end; }
.dash .chart .bar { width: 100%; border-radius: 7px 7px 0 0; background: linear-gradient(180deg, var(--turquoise-bright), var(--teal)); min-height: 4px; }
.dash .chart .col:last-child .bar { background: linear-gradient(180deg, var(--gold), #c79528); }
.dash .chart .col span { font-size: 10px; color: var(--ink-soft); font-weight: 600; }
.dash .chart .col:nth-child(1) .bar { height: 49%; }
.dash .chart .col:nth-child(2) .bar { height: 56%; }
.dash .chart .col:nth-child(3) .bar { height: 67%; }
.dash .chart .col:nth-child(4) .bar { height: 75%; }
.dash .chart .col:nth-child(5) .bar { height: 84%; }
.dash .chart .col:nth-child(6) .bar { height: 92%; }

/* =========================================================================
   BLOQUE 4 — Ficha del paciente (drawer con pestañas).
   ========================================================================= */

.dash .scrim { position: fixed; inset: 0; background: rgba(2, 15, 13, 0.6); backdrop-filter: blur(3px); opacity: 0; pointer-events: none; transition: 0.3s; z-index: 40; }
.dash .scrim.show { opacity: 1; pointer-events: auto; }

.dash .drawer { position: fixed; top: 0; right: 0; height: 100%; width: 480px; max-width: 92vw; background: var(--surface); border-left: 1px solid var(--line); transform: translateX(100%); transition: 0.34s cubic-bezier(0.3, 0.9, 0.3, 1); z-index: 50; overflow-y: auto; box-shadow: -30px 0 80px rgba(0, 0, 0, 0.35); }
.dash .drawer.show { transform: none; }
.dash .d-head { position: sticky; top: 0; background: var(--surface); padding: 24px 26px 14px; display: flex; align-items: center; justify-content: space-between; z-index: 2; border-bottom: 1px solid var(--line); }
.dash .d-head h3 { font-family: var(--fuente-titulo); font-weight: 600; font-size: 20px; }
.dash .close { width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--line); background: var(--surface-2); color: var(--ink); cursor: pointer; font-size: 18px; }
.dash .close:hover { background: var(--surface-3); }
.dash .d-body { padding: 0 26px 40px; overflow-x: hidden; }

/* Cabecera de la ficha */
.dash .ficha-hero { display: flex; align-items: center; gap: 16px; padding: 6px 0 18px; }
.dash .ficha-hero .av { width: 60px; height: 60px; font-size: 22px; }
.dash .ficha-hero .grow { flex: 1; min-width: 0; }
.dash .ficha-hero h3 { font-family: var(--fuente-titulo); font-weight: 600; font-size: 22px; }
.dash .ficha-hero p { font-size: 13px; color: var(--ink-soft); }

/* Pestañas (barra de una sola fila, deslizable y contenida en el drawer) */
/* El envoltorio aporta la pista de "hay más" (degradado a la derecha). */
.dash .tabs-wrap { position: relative; width: 100%; max-width: 100%; margin: 4px 0 18px; }
.dash .tabs-wrap::after {
    content: "";
    position: absolute; top: 0; right: 0; bottom: 0;
    width: 28px; pointer-events: none;
    border-radius: 0 14px 14px 0;
    background: linear-gradient(to right, rgba(0, 0, 0, 0), var(--surface-2));
}
.dash .tabs {
    display: flex; flex-wrap: nowrap;
    width: 100%; max-width: 100%;
    gap: 6px; background: var(--surface-2); padding: 5px; border-radius: 14px; margin: 0;
    overflow-x: auto;                       /* desliza si no caben */
    -webkit-overflow-scrolling: touch;      /* desplazamiento suave en iOS */
    scroll-snap-type: x proximity;
    scrollbar-width: none;                  /* oculta la barra (Firefox) */
}
.dash .tabs::-webkit-scrollbar { display: none; } /* oculta la barra (Chrome/Safari) */
.dash .tab {
    flex: 0 0 auto;                         /* ni se encogen ni se cortan */
    white-space: nowrap;
    scroll-snap-align: start;
    border: none; background: none; color: var(--ink-soft);
    font-family: var(--fuente-texto); font-weight: 600; font-size: 12.5px;
    padding: 9px 14px; border-radius: 10px; cursor: pointer; transition: 0.2s;
}
.dash .tab.on { background: var(--turquoise-bright); color: #042; }
.dash .tabpane { display: none; max-width: 100%; }
.dash .tabpane.on { display: block; max-width: 100%; animation: dfade 0.3s ease; }
@keyframes dfade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

/* Tiles de datos */
.dash .data-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 8px; }
.dash .dt { background: var(--surface-2); border: 1px solid var(--line); border-radius: 13px; padding: 12px 14px; min-width: 0; overflow: hidden; }
.dash .dt span { font-size: 10px; text-transform: uppercase; letter-spacing: 0.8px; color: var(--ink-soft); font-weight: 700; }
.dash .dt b { display: block; font-family: var(--fuente-titulo); font-weight: 500; font-size: 15px; margin-top: 3px; overflow-wrap: anywhere; }
.dash .dt.wide { grid-column: span 2; }

/* Títulos de sección dentro de la ficha */
.dash .sec-t { font-family: var(--fuente-label); font-weight: 600; letter-spacing: 1.2px; text-transform: uppercase; font-size: 11px; color: var(--turquoise); margin: 22px 0 10px; }

/* Hoja de sesión / detalle de nota: texto largo y tareas */
.dash .hoja-texto { background: var(--surface-2); border: 1px solid var(--line); border-radius: 13px; padding: 12px 14px; font-size: 13px; color: var(--ink); line-height: 1.55; white-space: normal; word-break: break-word; }
.dash .hoja-tarea { background: var(--surface-2); border: 1px solid var(--line); border-radius: 10px; padding: 8px 12px; font-size: 12.5px; color: var(--ink); margin-bottom: 6px; }
.dash .hoja-tarea.hecha { text-decoration: line-through; color: var(--ink-soft); opacity: 0.7; }

/* Conversación dentro de una nota (chat) */
.dash .chat { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.dash .chat-msg { display: flex; }
.dash .chat-msg.mia { justify-content: flex-end; }
.dash .chat-msg.suya { justify-content: flex-start; }
.dash .chat-bubble { max-width: 80%; border: 1px solid var(--line); border-radius: 14px; padding: 9px 12px; font-size: 13px; line-height: 1.5; color: var(--ink); }
.dash .chat-msg.mia .chat-bubble { background: var(--tint-turq); border-color: var(--turquoise); }
.dash .chat-msg.suya .chat-bubble { background: var(--surface-2); }
.dash .chat-quien { font-size: 10px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--ink-soft); font-weight: 700; margin-bottom: 3px; }

/* Campanita de avisos del panel */
.campana-admin { position: relative; }
.campana-admin .campana-badge { position: absolute; top: -6px; right: -6px; min-width: 18px; height: 18px; padding: 0 4px; border-radius: 9px; background: var(--gold); color: #042; font-family: var(--fuente-titulo); font-weight: 700; font-size: 10px; line-height: 18px; text-align: center; }

/* Lista de avisos en el drawer */
.dash .aviso { background: var(--surface-2); border: 1px solid var(--line); border-radius: 13px; padding: 12px 14px; margin-bottom: 8px; }
.dash .aviso.nuevo { border-left: 3px solid var(--turquoise); }
.dash .aviso[data-cliente] { cursor: pointer; transition: border-color 0.15s; }
.dash .aviso[data-cliente]:hover { border-color: var(--turquoise); }
.dash .aviso-h { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; }
.dash .aviso-h b { font-family: var(--fuente-titulo); font-weight: 500; font-size: 14px; }
.dash .aviso-h small { font-size: 10.5px; color: var(--ink-soft); flex: none; }
.dash .aviso p { font-size: 12.5px; color: var(--ink-soft); line-height: 1.5; margin-top: 3px; }

/* Notas pendientes de responder (pestaña "Notas privadas") — apartado normal, sin amarillo */
.dash .pend-row { display: flex; align-items: center; gap: 10px; background: var(--surface-2); border: 1px solid var(--line); border-radius: 11px; padding: 9px 12px; margin-bottom: 6px; cursor: pointer; transition: border-color 0.15s; }
.dash .pend-row:hover { border-color: var(--turquoise); }
.dash .conv-pend { flex: none; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px; color: var(--gold); background: var(--tint-gold); border-radius: 20px; padding: 3px 8px; }
.dash .pend-row .grow { flex: 1; min-width: 0; }
.dash .pend-row p { font-size: 13px; color: var(--ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dash .pend-row small { font-size: 10.5px; color: var(--ink-soft); }
.dash .pend-flecha { color: var(--ink-soft); font-size: 18px; flex: none; }

/* Sesiones y notas clicables dentro del drawer */
.dash .sess[data-sesion-id] { cursor: pointer; transition: border-color 0.15s; }
.dash .sess[data-sesion-id]:hover { border-color: var(--turquoise); }
.dash .cli[data-nota-id] { cursor: pointer; transition: border-color 0.15s; }
.dash .cli[data-nota-id]:hover { border-color: var(--turquoise); }

/* Acciones dentro de la hoja de sesión (confirmar/rechazar arriba) */
.dash .hoja-acciones { display: flex; flex-direction: column; gap: 8px; margin: 4px 0 10px; }

/* Selector de cita reservada al apuntar una sesión */
.dash .cita-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.dash .cita-op { display: flex; flex-direction: column; gap: 3px; text-align: left; width: 100%; background: var(--surface-2); border: 1px solid var(--line); border-radius: 13px; padding: 11px 14px; cursor: pointer; transition: border-color 0.15s; }
.dash .cita-op:hover { border-color: var(--turquoise); }
.dash .cita-op .cita-fh { font-size: 14px; color: var(--ink); }
.dash .cita-op .cita-meta { font-size: 11px; text-transform: uppercase; letter-spacing: 0.6px; color: var(--ink-soft); font-weight: 700; }

/* Pautas enviadas (pestaña Pautas de la ficha) */
.dash .pauta-row { display: flex; gap: 12px; background: var(--surface-2); border: 1px solid var(--line); border-radius: 13px; padding: 12px 14px; margin-bottom: 8px; cursor: pointer; transition: border-color 0.15s; }
.dash .pauta-row:hover { border-color: var(--turquoise); }
.dash .pauta-row .grow { flex: 1; min-width: 0; }
.dash .pauta-meta { display: flex; align-items: center; flex-wrap: wrap; gap: 6px; margin-bottom: 5px; }
.dash .pauta-meta small { font-size: 10.5px; color: var(--ink-soft); margin-left: auto; }
.dash .pauta-row p { font-size: 13px; color: var(--ink-soft); line-height: 1.5; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.dash .pauta-titulo { font-family: var(--fuente-titulo); font-weight: 500; font-size: 14.5px; margin: 2px 0; }
/* Casillas de envío y enlace a archivo en el formulario de pauta */
.dash .check-row { display: flex; align-items: center; gap: 8px; font-size: 13.5px; color: var(--ink); padding: 7px 0; cursor: pointer; }
.dash .check-row input { width: 17px; height: 17px; accent-color: var(--turquoise); }
.dash .pauta-file-link { display: inline-block; margin-top: 6px; font-size: 13px; color: var(--turquoise); font-weight: 600; }

/* Suplementación (ficha) */
.dash .sup-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.dash .sup-card { background: var(--surface-2); border: 1px solid var(--line); border-radius: 13px; overflow: hidden; cursor: pointer; transition: border-color 0.15s; }
.dash .sup-card:hover { border-color: var(--turquoise); }
.dash .sup-foto { display: block; width: 100%; height: 110px; object-fit: cover; background: var(--surface); }
.dash .sup-foto-no { display: flex; align-items: center; justify-content: center; font-size: 40px; }
.dash .sup-info { padding: 9px 11px; }
.dash .sup-info b { display: block; font-family: var(--fuente-titulo); font-weight: 500; font-size: 13.5px; color: var(--ink); }
.dash .sup-marca { display: block; font-size: 11px; color: var(--turquoise); font-weight: 600; margin-top: 1px; }
.dash .sup-info p { font-size: 12px; color: var(--ink-soft); margin-top: 4px; line-height: 1.4; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.dash .sup-foto-prev { display: block; width: 100%; max-height: 180px; object-fit: contain; border-radius: 12px; background: var(--surface-2); margin-bottom: 8px; }

/* Archivos del cliente (ficha) */
.dash .fa-subir { display: flex; flex-direction: column; gap: 8px; margin-bottom: 6px; }
.dash .fa-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.dash .fa-item { position: relative; background: var(--surface-2); border: 1px solid var(--line); border-radius: 13px; overflow: hidden; }
.dash .fa-thumb { display: block; width: 100%; height: 120px; object-fit: cover; cursor: pointer; background: var(--surface); }
.dash .fa-item figcaption { padding: 8px 10px; }
.dash .fa-item figcaption b { display: block; font-family: var(--fuente-titulo); font-weight: 500; font-size: 12.5px; color: var(--ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dash .fa-item figcaption small { display: block; font-size: 10.5px; color: var(--ink-soft); margin-top: 2px; }
.dash .fa-del { position: absolute; top: 6px; right: 6px; width: 26px; height: 26px; border: none; border-radius: 50%; background: rgba(0, 0, 0, 0.55); color: #fff; font-size: 13px; cursor: pointer; line-height: 26px; text-align: center; }
.dash .fa-del:hover { background: rgba(200, 40, 40, 0.85); }
.dash .fa-item { cursor: pointer; }
/* Icono para archivos que no son imagen */
.dash .fa-icono { display: flex; align-items: center; justify-content: center; height: 120px; font-size: 44px; background: var(--surface); }
.dash .fa-icono.grande { height: 180px; font-size: 72px; border-radius: 13px; border: 1px solid var(--line); }
/* Detalle de archivo */
.dash .archivo-vista { margin-bottom: 12px; }
.dash .archivo-grande { display: block; width: 100%; max-height: 360px; object-fit: contain; border-radius: 13px; background: var(--surface-2); }

/* Pestaña Tanita */
.dash .tanita-row { background: var(--surface-2); border: 1px solid var(--line); border-radius: 13px; padding: 12px 14px; margin-bottom: 8px; cursor: pointer; transition: border-color 0.15s; }
.dash .tanita-row:hover { border-color: var(--turquoise); }
.dash .tanita-row .th { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; margin-bottom: 6px; }
.dash .tanita-row .th b { font-family: var(--fuente-titulo); font-weight: 500; font-size: 14px; }
.dash .tanita-row .th span { font-family: var(--fuente-titulo); color: var(--turquoise); font-weight: 600; }
.dash .tanita-row .tvals { display: flex; flex-wrap: wrap; gap: 6px 14px; font-size: 12px; color: var(--ink-soft); }
.dash .tanita-row .tvals b { color: var(--ink); font-weight: 600; }
.dash .auto-out { background: var(--tint-turq); color: var(--turquoise); border-radius: 10px; padding: 8px 12px; font-size: 12.5px; font-weight: 600; margin: 2px 0 6px; }
.dash .tanita-leyenda { display: flex; gap: 14px; justify-content: center; font-size: 11px; color: var(--ink-soft); margin: -6px 0 10px; }
.dash .tanita-leyenda span { display: inline-flex; align-items: center; gap: 5px; }
.dash .tanita-leyenda i { width: 10px; height: 10px; border-radius: 50%; display: inline-block; }

/* Síntesis Biológico · Físico · Emocional */
.dash .syn { display: flex; flex-direction: column; gap: 8px; }
.dash .syn .s { background: var(--surface-2); border: 1px solid var(--line); border-left: 3px solid var(--turquoise); border-radius: 13px; padding: 11px 14px; }
.dash .syn .s span { font-size: 10px; text-transform: uppercase; letter-spacing: 0.8px; color: var(--ink-soft); font-weight: 700; }
.dash .syn .s p { font-size: 13px; color: var(--ink-soft); line-height: 1.5; margin-top: 3px; }
.dash .syn .s.bio { border-left-color: var(--teal); }
.dash .syn .s.fis { border-left-color: var(--gold); }
.dash .syn .s.emo { border-left-color: var(--turquoise); }

/* Bloques de historia */
.dash .hblock { background: var(--surface-2); border: 1px solid var(--line); border-radius: 13px; padding: 10px 14px 14px; margin-bottom: 8px; }
.dash .field-lbl { font-size: 10px; text-transform: uppercase; letter-spacing: 0.6px; color: var(--turquoise); font-weight: 700; margin: 10px 0 3px; }
.dash .hblock p { font-size: 12.5px; color: var(--ink-soft); line-height: 1.5; }

/* Gráfica de peso (SVG) */
.dash .lchart { width: 100%; height: auto; display: block; margin: 2px 0 16px; }
.dash .lchart .lc-x { fill: var(--ink-soft); font-family: var(--fuente-label); font-size: 9px; }
.dash .lchart .lc-v { fill: var(--ink); font-family: var(--fuente-titulo); font-size: 11px; font-weight: 600; }

/* Tarjetas de sesión */
.dash .sess { background: var(--surface-2); border: 1px solid var(--line); border-radius: 14px; padding: 14px; margin-bottom: 10px; }
.dash .sess .sh { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.dash .sess .sh b { font-family: var(--fuente-titulo); font-weight: 500; font-size: 14px; }
.dash .sess .sh em { font-style: normal; font-size: 11px; color: var(--gold); font-weight: 700; }
.dash .sess p { font-size: 12.5px; color: var(--ink-soft); line-height: 1.5; }

/* Chips de tareas (en la sesión) */
.dash .chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.dash .chip { font-size: 11px; font-weight: 600; color: var(--turquoise); background: var(--tint-turq); border: 1px solid var(--tint-turq); padding: 4px 10px; border-radius: 20px; }
.dash .chip.hecha { color: var(--ink-soft); text-decoration: line-through; opacity: 0.7; background: var(--surface-2); border-color: var(--line); }

/* Estado vacío */
.dash .empty { text-align: center; color: var(--ink-soft); font-size: 13px; padding: 22px; border: 1px dashed var(--line); border-radius: 14px; }

/* Botón de la nota rápida a ancho completo */
.dash #nota-add { width: 100%; margin-top: 10px; }

/* Toast */
.dash .toast { position: fixed; left: 50%; bottom: 28px; transform: translateX(-50%) translateY(160%); background: var(--turquoise-bright); color: #042; border-radius: 14px; padding: 14px 24px; font-family: var(--fuente-titulo); font-weight: 600; font-size: 14px; z-index: 90; transition: 0.4s cubic-bezier(0.2, 0.8, 0.2, 1); box-shadow: 0 16px 40px rgba(0, 0, 0, 0.25); }
.dash .toast.show { transform: translateX(-50%) translateY(0); }

/* =========================================================================
   BLOQUE 5 — Drawer de Nueva sesión y botones de captura.
   ========================================================================= */

.dash .ns-form { padding-top: 4px; }
.dash .capture-row { display: flex; gap: 10px; margin-top: 8px; }
.dash .capture-btn { flex: 1; display: flex; align-items: center; justify-content: center; gap: 8px; border: 1.5px dashed var(--line); background: var(--surface-2); color: var(--ink-soft); border-radius: 13px; padding: 14px 10px; font-family: var(--fuente-texto); font-weight: 600; font-size: 13px; cursor: pointer; transition: 0.2s; }
.dash .capture-btn:hover { border-color: var(--turquoise); color: var(--turquoise); }

/* =========================================================================
   BLOQUE 6 — Tarjeta "Notas para clientes" y control de canal.
   ========================================================================= */

.dash .notas-cliente-list { margin-top: 12px; }
.dash .nota-tags { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; flex: none; }
.dash .pill.borrador { background: var(--tint-gold); color: var(--gold); }

.dash .canal-seg { display: flex; gap: 8px; background: var(--surface-2); padding: 5px; border-radius: 14px; margin: 6px 0 4px; }
.dash .canal-opt { flex: 1; border: none; background: none; color: var(--ink-soft); font-family: var(--fuente-texto); font-weight: 600; font-size: 12.5px; padding: 9px 6px; border-radius: 10px; cursor: pointer; transition: 0.2s; }
.dash .canal-opt.on { background: var(--turquoise-bright); color: #042; }

/* =========================================================================
   BLOQUE 7 — To-do "Tu siguiente paso".
   ========================================================================= */

.dash .todo-list { margin-top: 6px; }
.dash .todo { display: flex; align-items: flex-start; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--line); }
.dash .todo:last-child { border-bottom: none; }
.dash .todo.done { opacity: 0.5; }
.dash .todo.done h4 { text-decoration: line-through; }

.dash .todo-check { width: 22px; height: 22px; border-radius: 7px; border: 2px solid var(--line-strong); background: none; flex: none; margin-top: 2px; cursor: pointer; display: flex; align-items: center; justify-content: center; padding: 0; transition: 0.2s; }
.dash .todo-check svg { opacity: 0; transition: 0.2s; }
.dash .todo.done .todo-check { background: var(--turquoise-bright); border-color: var(--turquoise-bright); }
.dash .todo.done .todo-check svg { opacity: 1; }

.dash .todo .grow { flex: 1; min-width: 0; }
.dash .todo h4 { font-family: var(--fuente-texto); font-weight: 600; font-size: 14px; margin-top: 4px; }
.dash .todo-motivo { font-size: 11.5px; color: var(--ink-soft); margin-top: 2px; }

/* Distintivo de prioridad */
.dash .prio { display: inline-block; font-family: var(--fuente-label); font-size: 9px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.6px; padding: 3px 8px; border-radius: 20px; }
.dash .prio.prio-0 { background: var(--tint-red); color: var(--red); }
.dash .prio.prio-1 { background: var(--tint-gold); color: var(--gold); }
.dash .prio.prio-2 { background: var(--tint-turq); color: var(--turquoise); }
.dash .prio.prio-3 { background: var(--surface-2); color: var(--ink-soft); }

/* Botón "Abrir" */
.dash .todo-abrir { flex: none; align-self: center; border: 1px solid var(--line); background: var(--surface-2); color: var(--ink); font-family: var(--fuente-texto); font-weight: 600; font-size: 11.5px; padding: 6px 12px; border-radius: 20px; cursor: pointer; transition: 0.2s; }
.dash .todo-abrir:hover { border-color: var(--turquoise); color: var(--turquoise); }
/* Botón editar tarea (icono lápiz) */
.dash .todo-editar { flex: none; align-self: center; width: 30px; height: 30px; border: 1px solid var(--line); background: var(--surface-2); color: var(--ink-soft); font-size: 13px; border-radius: 50%; cursor: pointer; transition: 0.2s; margin-right: 4px; }
.dash .todo-editar:hover { border-color: var(--turquoise); color: var(--turquoise); }

/* Cabecera de grupo del to-do */
.dash .todo-group { font-family: var(--fuente-label); font-weight: 600; letter-spacing: 1px; text-transform: uppercase; font-size: 10px; color: var(--ink-soft); margin: 14px 0 4px; }

/* Botón "Ver todo / Ver menos" */
.dash .todo-toggle { width: 100%; margin-top: 12px; border: 1px solid var(--line); background: var(--surface-2); color: var(--turquoise); font-family: var(--fuente-titulo); font-weight: 600; font-size: 13px; padding: 10px; border-radius: 12px; cursor: pointer; transition: 0.2s; }
.dash .todo-toggle:hover { background: var(--surface-3); }

/* =========================================================================
   BLOQUE 8 — Calendario "Tu semana" (rejilla semanal).
   ========================================================================= */

.dash .cal-grid { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 8px; margin-top: 6px; }
.dash .cal-day { background: var(--surface-2); border: 1px solid var(--line); border-radius: 12px; padding: 8px 6px; min-height: 96px; }
.dash .cal-day.hoy { border-color: var(--turquoise); background: var(--tint-turq); }
.dash .cal-dow { font-family: var(--fuente-label); font-size: 9px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; color: var(--ink-soft); text-align: center; }
.dash .cal-num { font-family: var(--fuente-titulo); font-weight: 600; font-size: 15px; text-align: center; margin-bottom: 6px; }
.dash .cal-day.hoy .cal-num { color: var(--turquoise); }
/* Cabecera del día (semana): botón seleccionable que entra en la vista Día */
.dash .cal-day-head { display: block; width: 100%; background: none; border: none; padding: 0; margin: 0 0 2px; cursor: pointer; border-radius: 8px; transition: background 0.15s; }
.dash .cal-day-head:hover { background: var(--tint-turq); }
.dash .cal-day-head .cal-num { margin-bottom: 2px; }

.dash .cal-sesiones { display: flex; flex-direction: column; gap: 6px; }
/* Sesiones del calendario: entrada limpia con una línea de color a la izquierda (sin caja). */
.dash .cal-pill { display: flex; flex-direction: column; gap: 1px; width: 100%; text-align: left; background: none; border: none; border-left: 3px solid var(--gold); cursor: pointer; border-radius: 0; padding: 1px 0 1px 8px; font-family: var(--fuente-texto); transition: 0.18s; }
.dash .cal-pill.online { border-left-color: var(--turquoise); }
.dash .cal-pill.pres { border-left-color: var(--gold); }
.dash .cal-pill:hover { background: var(--surface-2); }
.dash .cal-hora { font-size: 10px; font-weight: 700; color: var(--gold); }
.dash .cal-pill.online .cal-hora { color: var(--turquoise); }
.dash .cal-nombre { font-size: 12px; font-weight: 600; color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dash .cal-mod { font-size: 9px; color: var(--ink-soft); text-transform: uppercase; letter-spacing: 0.4px; }

/* Sesiones SOLICITADAS (pendientes de confirmar): línea discontinua */
.dash .cal-pill.solicitada { border-left: 3px dashed var(--gold); }
.dash .cal-pill.solicitada .cal-hora,
.dash .cal-pill.solicitada .cal-mod { color: var(--gold); }
.dash .cal-dia-row.solicitada { border-style: dashed; border-left-color: var(--gold); }
.dash .cal-dia-row.solicitada .cal-dia-hora,
.dash .cal-dia-row.solicitada .cal-dia-mod { color: var(--gold); }

/* =========================================================================
   BLOQUE 8.5 — Cabecera de tarjeta con acción + tarjetas-resumen clicables.
   ========================================================================= */

.dash .card-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 4px; }
.dash .card-head h2 { margin-bottom: 0; }

.dash .card-action { flex: none; border: 1px solid var(--line); background: var(--surface-2); color: var(--turquoise); font-family: var(--fuente-texto); font-weight: 600; font-size: 11.5px; padding: 6px 12px; border-radius: 20px; cursor: pointer; white-space: nowrap; transition: 0.2s; }
.dash .card-action:hover { border-color: var(--turquoise); background: var(--surface-3); }

.dash .card.clicable { cursor: pointer; transition: border-color 0.2s, background 0.2s; }
.dash .card.clicable:hover { border-color: var(--turquoise); background: var(--surface-2); }
.dash .card.clicable:focus-visible { outline: 2px solid var(--turquoise); outline-offset: 2px; }
.dash .card.clicable .cli,
.dash .card.clicable .todo { pointer-events: none; }

.dash .card-hint { flex: none; color: var(--ink-soft); font-size: 16px; line-height: 1; transition: color 0.2s, transform 0.2s; }
.dash .card.clicable:hover .card-hint { color: var(--turquoise); transform: translate(2px, -2px); }

.dash .c-clients { display: flex; flex-direction: column; min-height: 0; overflow: hidden; }
.dash .c-clients .card-head,
.dash .c-clients > .sub { flex: none; }
.dash .pacientes-list { flex: 1; min-height: 0; overflow: hidden; }

.dash .todo-meta { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-bottom: 2px; }
.dash .todo-cliente { font-size: 10px; font-weight: 600; color: var(--ink-soft); background: var(--surface-2); border: 1px solid var(--line); border-radius: 20px; padding: 3px 8px; max-width: 140px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Seguridad de texto */
.dash .cli h4 { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dash .todo h4,
.dash .todo-motivo,
.dash .card .sub,
.dash .sess p,
.dash .hblock p { overflow-wrap: break-word; }

/* ---------- Responsive (móvil ≤ 860px) ---------- */
@media (max-width: 860px) {
    .dash .wrap { padding: 22px 16px 48px; }
    .dash .card { padding: 18px; }
    .dash .hi h1 { font-size: 26px; }

    .dash .c-clients { overflow: visible; }
    .dash .pacientes-list { flex: none; overflow: visible; }

    .dash .cal-grid { grid-template-columns: repeat(7, minmax(82px, 1fr)); overflow-x: auto; -webkit-overflow-scrolling: touch; }

    .dash .drawer { width: 100%; max-width: 100%; }
    .dash .d-body { padding: 0 18px 40px; }
    .dash .data-grid { grid-template-columns: 1fr; }

    .dash .btn { padding: 14px 22px; }
    .dash .card-action,
    .dash .todo-abrir { padding: 9px 14px; }
    .dash .canal-opt { padding: 12px 6px; }
    .dash .tab { padding: 10px 14px; } /* sigue deslizable; padding cómodo sin cortes */
    .dash .todo-check { width: 26px; height: 26px; }
    .dash .close { width: 42px; height: 42px; }
}

/* =========================================================================
   ALTA / FORMULARIO COMPLETO DE PACIENTE.
   ========================================================================= */

.dash #paciente-nuevo,
.dash #nota-nueva-drawer { margin-top: 0; margin-bottom: 14px; }

.dash .form-sec {
    font-family: var(--fuente-label);
    font-weight: 600;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    font-size: 11px;
    color: var(--turquoise);
    margin: 20px 0 8px;
    padding-top: 16px;
    border-top: 1px solid var(--line);
}
.dash .form-sec:first-child { margin-top: 2px; padding-top: 0; border-top: none; }

/* =========================================================================
   CALENDARIO — 3 vistas (cabecera, navegación, vista diaria, rejilla mensual).
   ========================================================================= */

.dash .cal-head { flex-wrap: wrap; row-gap: 10px; }
.dash .cal-vista { margin: 0; }

.dash .cal-nav { display: flex; align-items: center; gap: 6px; }
.dash .cal-navbtn { min-width: 36px; height: 36px; padding: 0 10px; border: 1px solid var(--line); background: var(--surface-2); color: var(--ink); border-radius: 10px; font-family: var(--fuente-texto); font-weight: 600; font-size: 14px; cursor: pointer; transition: 0.2s; }
.dash .cal-navbtn:hover { border-color: var(--turquoise); color: var(--turquoise); }

.dash #cal-titulo { font-family: var(--fuente-titulo); font-weight: 600; font-size: 15px; color: var(--ink); margin: 8px 0 14px; text-transform: capitalize; }

.dash #calBody { min-height: 200px; }

/* Vista DÍA */
.dash .cal-dia { display: flex; flex-direction: column; gap: 8px; }
.dash .cal-dia-row { display: flex; align-items: center; gap: 12px; width: 100%; text-align: left; border: 1px solid var(--line); border-left-width: 3px; border-radius: 12px; background: var(--surface-2); color: var(--ink); padding: 12px 14px; cursor: pointer; font-family: var(--fuente-texto); transition: 0.18s; }
.dash .cal-dia-row.online { border-left-color: var(--turquoise); }
.dash .cal-dia-row.pres { border-left-color: var(--gold); }
.dash .cal-dia-row:hover { background: var(--surface-3); }
.dash .cal-dia-hora { font-family: var(--fuente-titulo); font-weight: 600; font-size: 15px; min-width: 50px; color: var(--gold); }
.dash .cal-dia-row.online .cal-dia-hora { color: var(--turquoise); }
.dash .cal-dia-nombre { flex: 1; min-width: 0; font-weight: 600; font-size: 14px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dash .cal-dia-mod { flex: none; font-size: 9px; text-transform: uppercase; letter-spacing: 0.4px; color: var(--ink-soft); }

/* Vista MES (rejilla compacta) */
.dash .cal-mes { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 4px; }
.dash .cal-mes-dow { text-align: center; font-family: var(--fuente-label); font-weight: 600; font-size: 9px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--ink-soft); padding-bottom: 2px; }
.dash .cal-mes-dia { position: relative; height: 36px; border: 1px solid var(--line); border-radius: 8px; background: var(--surface-2); color: var(--ink); font-family: var(--fuente-texto); font-size: 12px; cursor: pointer; display: flex; align-items: center; justify-content: center; padding: 0; transition: 0.15s; }
.dash .cal-mes-dia:hover { border-color: var(--turquoise); }
.dash .cal-mes-dia.fuera { opacity: 0.35; }
.dash .cal-mes-dia.hoy { border-color: var(--turquoise); background: var(--tint-turq); color: var(--turquoise); }
.dash .cal-mes-dot { position: absolute; bottom: 4px; left: 50%; transform: translateX(-50%); width: 5px; height: 5px; border-radius: 50%; background: var(--gold); }
.dash .cal-mes-dia.hoy .cal-mes-dot { background: var(--turquoise); }

/* =========================================================================
   FICHA A PANTALLA COMPLETA EN ORDENADOR Y TABLET (>= 768px).
   En vez de deslizar desde la derecha, aparece a pantalla completa con un
   fundido + ligera escala. En móvil (< 768px) se mantiene el deslizamiento.
   Va al final para tener prioridad sobre las reglas base del drawer.
   ========================================================================= */
@media (min-width: 768px) {
    .dash .drawer {
        width: 100%;
        max-width: 100%;
        height: 100%;
        border-left: none;
        box-shadow: none;
        transform: scale(0.985);   /* sin deslizamiento lateral */
        opacity: 0;
        visibility: hidden;
        transition: opacity 0.25s ease, transform 0.25s ease;
    }
    .dash .drawer.show {
        transform: scale(1);
        opacity: 1;
        visibility: visible;
    }
    /* El contenido sigue sin desbordar y las pestañas con su barra deslizable. */
    .dash .d-body { overflow-x: hidden; }
}

/* =========================================================================
   AJUSTES: enlaces que actúan como BOTÓN (sin subrayado) y selector de semana.
   ========================================================================= */
/* Enlaces con aspecto de botón: nunca subrayados (← Clientes, ← Panel, Menús…). */
.theme-btn,
.theme-btn:hover,
.dash .menu-cli-card,
.dash .menu-cli-card:hover { text-decoration: none; }

/* "Cerrar sesión": mismo aspecto de botón que los demás, sin subrayado. */
.dash .logout-link {
    display: inline-flex;
    align-items: center;
    border: 1px solid var(--line);
    background: var(--surface);
    border-radius: 20px;
    padding: 8px 14px;
    box-shadow: var(--card-shadow);
    transition: 0.2s;
}
.dash .logout-link:hover { text-decoration: none; border-color: var(--gold); color: var(--gold); }

/* Botones de navegación (‹ › "Esta semana" / "Hoy"): sin subrayado y centrados. */
.dash .cal-navbtn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    line-height: 1;
}

/* Selector de semana en Menús: ‹ "Esta semana" › en fila, misma altura, cuadrados. */
.dash .sem-nav { align-items: center; gap: 8px; }
.dash .sem-nav .cal-navbtn { height: 38px; }
.dash .sem-nav .sem-rango { margin-left: auto; } /* el rango, a la derecha */
