/* ============================================================
   FUNDACIÓN · Sistema visual + navegación + pantalla "Hoy"
   Centraliza tokens y componentes reutilizables (aurora).
   Aislado a propósito: quitar este archivo + su <link> revierte
   la fundación sin tocar el resto. Prefijo .fnd-  para no chocar.
   ============================================================ */
:root{
  --fnd-brand:#16C2B0; --fnd-brand-d:#0E9E70;
  --fnd-pine:linear-gradient(157deg,#10433A,#0A2A22 64%,#072019);
  --fnd-au:linear-gradient(110deg,#1FB58A,#16C2B0,#36C8C2,#7FD08A,#9AD15A,#5FB6DE);
  --fnd-ink:#15302A; --fnd-ink2:#5C726A; --fnd-ink3:#86998F;
  --fnd-lime:#9AD15A; --fnd-pos:#0B7A53; --fnd-neg:#B24B3E; --fnd-warn:#B5730B;
  --fnd-surf:#fff; --fnd-line:rgba(20,70,58,.12);
  --fnd-r:20px; --fnd-r-sm:14px;
  --fnd-sh:0 18px 40px -26px rgba(16,80,66,.42);
  --fnd-bnav-h:64px;
}

/* ---------- Pantalla "Hoy" ---------- */
.fnd-home{ max-width:760px; margin:0 auto; padding:4px 0 24px; }
.fnd-hi{ font-family:'Newsreader',Georgia,serif; font-weight:400; font-size:1.6rem; letter-spacing:-.01em; color:var(--fnd-ink); margin:2px 0 2px; }
.fnd-sub{ color:var(--fnd-ink3); font-size:.92rem; margin:0 0 18px; }

/* Hero: la respuesta principal del día */
.fnd-hero{ position:relative; overflow:hidden; border-radius:var(--fnd-r); padding:24px 22px; color:#EAF6F0; background:var(--fnd-pine); box-shadow:var(--fnd-sh); }
.fnd-hero::after{ content:""; position:absolute; inset:0 0 auto 0; height:3px; background:var(--fnd-au); opacity:.9; }
.fnd-hero .eye{ font-size:.72rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase; color:#8FE6CE; }
.fnd-hero .big{ font-size:3rem; font-weight:800; line-height:1.02; margin:6px 0 2px; letter-spacing:-.02em; }
.fnd-hero .big small{ font-size:1.1rem; font-weight:700; color:#B9E8D6; }
.fnd-hero .meta{ color:#B9E8D6; font-size:.95rem; }

/* Veredicto en PALABRAS + color (no chips) */
.fnd-verdict{ display:inline-flex; align-items:center; gap:6px; font-weight:800; font-size:.84rem; padding:5px 11px; border-radius:999px; margin-top:12px; }
.fnd-verdict.ok{ background:rgba(154,209,90,.18); color:#CDEB9C; }
.fnd-verdict.warn{ background:rgba(245,180,80,.18); color:#F4CE8A; }
.fnd-verdict.bad{ background:rgba(196,87,74,.20); color:#F3B3A8; }

/* Señales: rejilla de “una idea por tarjeta” */
.fnd-signals{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:14px; }
.fnd-signal{ background:var(--fnd-surf); border:1px solid var(--fnd-line); border-radius:var(--fnd-r-sm); padding:14px 15px; box-shadow:0 10px 24px -20px rgba(16,80,66,.5); }
.fnd-signal .lbl{ color:var(--fnd-ink3); font-size:.8rem; font-weight:700; }
.fnd-signal .val{ font-size:1.7rem; font-weight:800; color:var(--fnd-ink); letter-spacing:-.02em; margin-top:2px; }
.fnd-signal .tag{ font-size:.78rem; font-weight:800; margin-top:3px; }
.fnd-signal .tag.ok{ color:var(--fnd-pos); } .fnd-signal .tag.warn{ color:var(--fnd-warn); } .fnd-signal .tag.bad{ color:var(--fnd-neg); }
.fnd-signal.ia{ background:linear-gradient(150deg,#10433A,#0A2A22); color:#EAF6F0; border:0; }
.fnd-signal.ia .lbl{ color:#8FE6CE; } .fnd-signal.ia .val{ color:#fff; } .fnd-signal.ia .tag{ color:var(--fnd-lime); }

/* Encabezado de sección */
.fnd-sech{ display:flex; align-items:baseline; justify-content:space-between; margin:24px 2px 10px; }
.fnd-sech h2{ font-size:1.05rem; font-weight:800; color:var(--fnd-ink); margin:0; }
.fnd-sech a{ font-size:.82rem; font-weight:700; color:var(--fnd-brand-d); cursor:pointer; text-decoration:none; }

/* Lista de acciones: “qué hacer”, cada fila lleva a su sitio */
.fnd-actions{ display:flex; flex-direction:column; gap:10px; }
.fnd-act{ display:flex; align-items:center; gap:13px; width:100%; text-align:left; background:var(--fnd-surf); border:1px solid var(--fnd-line); border-radius:var(--fnd-r-sm); padding:14px 15px; cursor:pointer; transition:.15s; }
.fnd-act:hover{ border-color:rgba(20,70,58,.28); transform:translateY(-1px); }
.fnd-act:focus-visible{ outline:none; box-shadow:0 0 0 3px rgba(18,184,134,.28); }
.fnd-act .ic{ width:38px; height:38px; flex:none; border-radius:11px; display:flex; align-items:center; justify-content:center; }
.fnd-act .ic svg{ width:20px; height:20px; }
.fnd-act .ic.warn{ background:#FFF1DC; color:var(--fnd-warn); } .fnd-act .ic.info{ background:#E7F7F0; color:var(--fnd-brand-d); } .fnd-act .ic.bad{ background:#FCE9E6; color:var(--fnd-neg); }
.fnd-act .tx{ flex:1; min-width:0; }
.fnd-act .tx b{ display:block; font-size:.95rem; color:var(--fnd-ink); font-weight:700; }
.fnd-act .tx small{ color:var(--fnd-ink3); font-size:.82rem; }
.fnd-act .chev{ color:var(--fnd-ink3); flex:none; }

/* Estado “todo en orden” */
.fnd-allgood{ display:flex; align-items:center; gap:12px; background:linear-gradient(150deg,#EAF8F1,#F4FBF7); border:1px solid var(--fnd-line); border-radius:var(--fnd-r-sm); padding:16px; color:var(--fnd-ink2); font-weight:600; }
.fnd-allgood .em{ font-size:1.5rem; }

/* Estado del asistente (línea calmada) */
.fnd-bot{ display:inline-flex; align-items:center; gap:7px; font-size:.8rem; font-weight:700; color:var(--fnd-pos); margin:-10px 0 16px; }
.fnd-bot .pip{ width:8px; height:8px; border-radius:50%; background:var(--fnd-brand); box-shadow:0 0 0 0 rgba(18,184,134,.5); animation:fndPulse 2.2s infinite; }
@keyframes fndPulse{ 0%{box-shadow:0 0 0 0 rgba(18,184,134,.5)} 70%{box-shadow:0 0 0 7px rgba(18,184,134,0)} 100%{box-shadow:0 0 0 0 rgba(18,184,134,0)} }

/* Próximo hueco libre */
.fnd-slot{ display:flex; align-items:center; gap:11px; background:linear-gradient(150deg,#EAF8F1,#F4FBF7); border:1px solid var(--fnd-line); border-radius:var(--fnd-r-sm); padding:13px 15px; margin-top:10px; color:var(--fnd-ink); font-weight:700; font-size:.92rem; }
.fnd-slot .pip{ width:9px; height:9px; border-radius:50%; background:var(--fnd-brand); flex:none; }
.fnd-slot b{ color:var(--fnd-brand-d); }

/* Mini-agenda del día */
.fnd-agenda{ display:flex; flex-direction:column; gap:2px; background:var(--fnd-surf); border:1px solid var(--fnd-line); border-radius:var(--fnd-r-sm); padding:6px; }
.fnd-arow{ display:flex; align-items:center; gap:12px; width:100%; text-align:left; background:none; border:0; border-radius:11px; padding:11px 11px; cursor:pointer; }
.fnd-arow:hover{ background:#F2F8F5; }
.fnd-arow:focus-visible{ outline:none; box-shadow:0 0 0 3px rgba(18,184,134,.25); }
.fnd-arow .t{ font-weight:800; color:var(--fnd-ink); font-size:.9rem; width:46px; flex:none; font-variant-numeric:tabular-nums; }
.fnd-arow .who{ flex:1; min-width:0; }
.fnd-arow .who b{ display:block; font-size:.92rem; color:var(--fnd-ink); font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.fnd-arow .who small{ color:var(--fnd-ink3); font-size:.8rem; }
.fnd-arow .ia{ font-size:.62rem; font-weight:800; color:#2C7FB0; background:#E5F1FA; padding:2px 6px; border-radius:6px; }
.fnd-arow .dot{ width:9px; height:9px; border-radius:50%; flex:none; }
.dot-pend{ background:#F5A623; } .dot-conf{ background:var(--fnd-brand); } .dot-done{ background:#9FB3AA; }

/* Estado vacío (negocio nuevo) */
.fnd-empty{ text-align:center; padding:38px 20px; color:var(--fnd-ink2); }
.fnd-empty .em{ font-size:2.2rem; }
.fnd-empty b{ display:block; color:var(--fnd-ink); font-size:1.05rem; margin:8px 0 4px; }

/* Esqueleto de carga */
.fnd-skel{ border-radius:var(--fnd-r-sm); background:linear-gradient(90deg,#EEF4F1,#F7FBF9,#EEF4F1); background-size:200% 100%; animation:fndSk 1.2s infinite; }
@keyframes fndSk{ 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* ---------- Navegación inferior (solo móvil) ---------- */
.fnd-bnav{ display:none; }
.fnd-sheet{ display:none; }
@media(max-width:760px){
  /* la barra inferior sustituye al scroller superior de secciones */
  #subtabs{ display:none !important; }
  body{ padding-bottom:calc(var(--fnd-bnav-h) + env(safe-area-inset-bottom)) !important; }

  .fnd-bnav{
    display:flex; position:fixed; left:0; right:0; bottom:0; z-index:900;
    background:rgba(255,255,255,.96); -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);
    border-top:1px solid var(--fnd-line); padding:6px 4px calc(6px + env(safe-area-inset-bottom));
    box-shadow:0 -10px 30px -18px rgba(16,80,66,.4);
  }
  .fnd-bnav button{ flex:1; background:none; border:0; display:flex; flex-direction:column; align-items:center; gap:3px; padding:5px 2px; color:#7C9389; font-weight:700; font-size:.66rem; cursor:pointer; border-radius:12px; }
  .fnd-bnav button svg{ width:23px; height:23px; }
  .fnd-bnav button.on{ color:var(--fnd-brand-d); }
  .fnd-bnav button.on svg{ stroke:var(--fnd-brand-d); }

  /* hoja “Más” */
  .fnd-sheet.open{ display:block; position:fixed; inset:0; z-index:950; }
  .fnd-sheet .bg{ position:absolute; inset:0; background:rgba(8,30,24,.45); }
  .fnd-sheet .panel{ position:absolute; left:0; right:0; bottom:0; background:#fff; border-radius:20px 20px 0 0; padding:10px 12px calc(16px + env(safe-area-inset-bottom)); box-shadow:0 -20px 50px -20px rgba(8,30,24,.5); animation:fndUp .22s cubic-bezier(.2,.8,.25,1); }
  @keyframes fndUp{ from{transform:translateY(100%)} to{transform:none} }
  .fnd-sheet .grab{ width:38px; height:4px; border-radius:99px; background:#D7E4DD; margin:4px auto 10px; }
  .fnd-sheet button.row{ display:flex; align-items:center; gap:14px; width:100%; background:none; border:0; padding:14px 10px; font-size:1rem; font-weight:700; color:var(--fnd-ink); cursor:pointer; border-radius:12px; text-align:left; }
  .fnd-sheet button.row:hover{ background:#F2F8F5; }
  .fnd-sheet button.row svg{ width:21px; height:21px; color:var(--fnd-brand-d); flex:none; }
  .fnd-sheet button.row.danger{ color:var(--fnd-neg); } .fnd-sheet button.row.danger svg{ color:var(--fnd-neg); }
}

/* En escritorio, el botón "Hoy" vive en el sidebar como una sección más (sin estilos extra). */
.fnd-signals.one{ grid-template-columns:1fr; }

/* ============================================================
   Calendario · escritorio: panel persistente + re-skin aurora
   Arregla el "scroll fantasma": el panel era un cajón fixed fuera
   de pantalla. En pantallas anchas pasa a columna fija visible.
   ============================================================ */
#sub-cal .cal-title{ font-family:'Newsreader',Georgia,serif; font-weight:400; letter-spacing:-.01em; }
#sub-cal .cal-eyebrow-dot{ background:var(--fnd-au) !important; }
#sub-cal .cal-viewsel{ background:#EAF2EC; border-radius:12px; padding:3px; gap:2px; }
#sub-cal .cal-viewsel button{ border:0; background:none; padding:7px 15px; border-radius:9px; font-weight:700; font-size:.85rem; color:var(--fnd-ink2); cursor:pointer; transition:.15s; }
#sub-cal .cal-viewsel button:hover{ color:var(--fnd-ink); }
#sub-cal .cal-viewsel button.on{ background:#fff; color:var(--fnd-brand-d); box-shadow:0 2px 8px -4px rgba(16,80,66,.45); }

@media(min-width:1000px){
  #sub-cal .callayout{ display:grid !important; grid-template-columns:minmax(0,1fr) 344px; gap:22px; align-items:start; }
  #sub-cal #calSidePanel{ position:static !important; transform:none !important; display:flex !important; width:auto; max-width:none; height:auto;
    background:linear-gradient(180deg,#F7FBF9,#EFF6F1); border:1px solid var(--fnd-line); border-radius:var(--fnd-r);
    box-shadow:0 18px 40px -30px rgba(16,80,66,.4); padding:18px; }
  #sub-cal .cal-panel-x{ display:none; }                              /* es columna fija: no se cierra */
  #sub-cal .cal-occpill{ cursor:default; pointer-events:none; }       /* ocupación = solo dato (panel ya visible) */
}
@media(max-width:999px){
  #calSidePanel:not(.open){ display:none; }   /* cerrado = fuera del flujo → sin scroll horizontal fantasma */
}

/* Mes · leyenda del mapa de calor */
.cal-month .month-heatlg{ grid-column:1/-1; display:flex; align-items:center; justify-content:center; gap:5px; margin-top:12px; font-size:.74rem; font-weight:600; color:var(--fnd-ink3); }
.cal-month .month-heatlg i{ width:18px; height:12px; border-radius:3px; display:inline-block; border:1px solid rgba(20,70,58,.08); }

/* ============================================================
   Asistente · portada que destaca los canales (WhatsApp + Teléfono)
   ============================================================ */
#asist-home{ max-width:760px; margin:0 auto; }
.asist-hero{ position:relative; overflow:hidden; background:var(--fnd-pine); color:#EAF6F0; border-radius:var(--fnd-r); padding:26px 24px; box-shadow:var(--fnd-sh); }
.asist-hero::after{ content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--fnd-au); }
.asist-hero .eye{ font-size:.72rem; font-weight:800; letter-spacing:.14em; color:#8FE6CE; }
.asist-hero h2{ font-family:'Newsreader',Georgia,serif; font-weight:400; font-size:1.7rem; margin:6px 0 8px; line-height:1.15; letter-spacing:-.01em; }
.asist-hero p{ color:#B9E8D6; margin:0; font-size:.95rem; max-width:50ch; }
.asist-channels{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:16px; }
.asist-ch{ display:flex; flex-direction:column; gap:3px; text-align:left; background:var(--fnd-surf); border:1px solid var(--fnd-line); border-radius:var(--fnd-r-sm); padding:18px; cursor:pointer; transition:.15s; }
.asist-ch:hover{ transform:translateY(-3px); box-shadow:var(--fnd-sh); border-color:rgba(20,70,58,.22); }
.asist-ch:focus-visible{ outline:none; box-shadow:0 0 0 3px rgba(18,184,134,.28); }
.asist-ch .ch-ic{ width:46px; height:46px; border-radius:13px; display:flex; align-items:center; justify-content:center; margin-bottom:8px; }
.asist-ch .ch-ic svg{ width:25px; height:25px; }
.asist-ch.wa .ch-ic{ background:#E7F8EE; color:#1FA855; }
.asist-ch.tel .ch-ic{ background:#E7F7F0; color:var(--fnd-brand-d); }
.asist-ch b{ font-size:1.08rem; color:var(--fnd-ink); }
.asist-ch small{ color:var(--fnd-ink3); font-size:.84rem; line-height:1.35; }
.asist-ch .ch-go{ margin-top:10px; font-weight:800; font-size:.84rem; color:var(--fnd-brand-d); }
.asist-conv-entry{ display:flex; align-items:center; gap:14px; width:100%; text-align:left; background:var(--fnd-surf); border:1px solid var(--fnd-line); border-radius:var(--fnd-r-sm); padding:16px; cursor:pointer; margin-top:14px; transition:.15s; }
.asist-conv-entry:hover{ border-color:rgba(20,70,58,.22); transform:translateY(-1px); }
.asist-conv-entry .ch-ic{ width:42px; height:42px; border-radius:12px; background:#EEF4F1; color:var(--fnd-ink2); display:flex; align-items:center; justify-content:center; flex:none; }
.asist-conv-entry .ch-ic svg{ width:21px; height:21px; }
.asist-conv-entry b{ display:block; color:var(--fnd-ink); }
.asist-conv-entry small{ color:var(--fnd-ink3); font-size:.84rem; }
.asist-conv-entry .chev{ margin-left:auto; color:var(--fnd-ink3); font-size:1.4rem; }
.asist-back{ background:none; border:0; color:var(--fnd-brand-d); font-weight:800; font-size:.92rem; cursor:pointer; padding:2px 0 14px; }
.asist-back:hover{ text-decoration:underline; }
@media(max-width:620px){ .asist-channels{ grid-template-columns:1fr; } }

/* ============================================================
   Pacientes/Clientes · acciones rápidas + re-skin de la ficha
   ============================================================ */
#sub-pac .pac-actions{ display:flex; gap:10px; margin:14px 0 6px; flex-wrap:wrap; }
#sub-pac .pac-act{ display:inline-flex; align-items:center; gap:7px; background:var(--fnd-surf); border:1px solid var(--fnd-line); border-radius:11px; padding:9px 15px; font-weight:700; font-size:.88rem; color:var(--fnd-ink); cursor:pointer; transition:.15s; }
#sub-pac .pac-act svg{ width:17px; height:17px; }
#sub-pac .pac-act:hover{ border-color:rgba(20,70,58,.28); transform:translateY(-1px); }
#sub-pac .pac-act:focus-visible{ outline:none; box-shadow:0 0 0 3px rgba(18,184,134,.28); }
#sub-pac .pac-act.primary{ background:linear-gradient(150deg,#16C2B0,#0E9E70); color:#fff; border:0; box-shadow:0 10px 22px -14px rgba(14,158,112,.7); }
#sub-pac .pac-act.wa svg{ color:#1FA855; }
/* resumen como tarjetas tipo "señal" */
#sub-pac .pac-stats{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:10px; width:100%; margin-top:14px; }
#sub-pac .pac-stat{ background:var(--fnd-surf); border:1px solid var(--fnd-line); border-radius:12px; padding:10px 12px; }
#sub-pac .pac-stat b{ display:block; font-size:1.12rem; font-weight:800; color:var(--fnd-ink); line-height:1.1; }
#sub-pac .pac-stat span{ font-size:.72rem; color:var(--fnd-ink3); font-weight:700; }
/* pestañas con activo aurora */
#sub-pac .pac-tabs button.on{ color:var(--fnd-brand-d); }

/* Ajustes · navegación por categorías */
#sub-aj .aj-nav{ display:flex; gap:7px; flex-wrap:wrap; margin:2px 0 18px; }
#sub-aj .aj-nav button{ border:1px solid var(--fnd-line); background:#fff; color:var(--fnd-ink2); border-radius:999px; padding:8px 17px; font-weight:700; font-size:.88rem; cursor:pointer; transition:.15s; }
#sub-aj .aj-nav button:hover{ border-color:rgba(20,70,58,.3); }
#sub-aj .aj-nav button.on{ background:linear-gradient(150deg,#16C2B0,#0E9E70); color:#fff; border-color:transparent; box-shadow:0 8px 18px -12px rgba(14,158,112,.7); }

/* Reputación · botón para desplegar el análisis completo */
#rep-informe .rep-toggle{ display:inline-flex; align-items:center; gap:7px; margin:16px 0 4px; background:none; border:0; color:var(--fnd-brand-d); font-weight:800; font-size:.9rem; cursor:pointer; }
#rep-informe .rep-toggle svg{ width:16px; height:16px; transition:transform .2s; }
#rep-informe .rep-toggle.open svg{ transform:rotate(180deg); }
#rep-informe .rep-toggle:hover{ text-decoration:underline; }

/* Resultados · Resumen: tarjeta de previsión "a este ritmo" */
#r2Tab .r2-forecast{ margin-top:16px; border:1px solid var(--fnd-line); border-radius:var(--fnd-r); padding:16px 18px; background:linear-gradient(150deg,#F3FAF6,#EAF6F0); }
#r2Tab .r2-forecast .fc-h{ display:flex; align-items:center; gap:8px; font-weight:800; color:var(--fnd-ink2); font-size:.86rem; }
#r2Tab .r2-forecast .fc-h svg{ width:18px; height:18px; color:var(--fnd-brand-d); flex:none; }
#r2Tab .r2-forecast .fc-row{ display:flex; gap:30px; margin-top:10px; }
#r2Tab .r2-forecast .fc-it b{ display:block; font-size:1.6rem; font-weight:800; color:var(--fnd-brand-d); letter-spacing:-.02em; line-height:1.05; }
#r2Tab .r2-forecast .fc-it span{ font-size:.78rem; color:var(--fnd-ink3); font-weight:700; }
#r2Tab .r2-forecast .fc-note{ margin-top:9px; font-size:.74rem; color:var(--fnd-ink3); }

/* Día (rejilla) · línea de "ahora" */
.cal-dstaff .ds-now{ position:relative; pointer-events:none; z-index:8; }
.cal-dstaff .ds-now::before{ content:''; position:absolute; left:56px; right:0; top:calc(var(--minfrac,0) * 100%); height:2px; background:#E5484D; box-shadow:0 0 6px -1px rgba(229,72,77,.5); }
.cal-dstaff .ds-now::after{ content:''; position:absolute; left:56px; top:calc(var(--minfrac,0) * 100%); width:9px; height:9px; border-radius:50%; background:#E5484D; transform:translate(-50%,-50%); }
.cal-dstaff .ds-now-t{ position:absolute; left:3px; top:calc(var(--minfrac,0) * 100%); transform:translateY(-50%); font-size:.6rem; font-weight:800; color:#fff; background:#E5484D; padding:1px 5px; border-radius:6px; }
