/* ==========================================================================
   ADIAFARM · Hoja de estilos
   Estética: salud / farmacia · verde esmeralda + teal · limpio y de alto impacto
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Sora:wght@500;600;700;800&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

:root{
  --verde:#1f6dff; --verde-2:#155fe6; --verde-3:#1456c9;
  --teal:#06b6d4; --teal-2:#0891b2;
  --tinta:#0a1733; --acento:#22d3ee;
  --bg:#f3f7ff; --bg-2:#ffffff; --card:#ffffff;
  --txt-2:#5b6b86; --linea:#e2eaf6;
  --sombra:0 10px 40px -12px rgba(15,70,160,.18);
  --sombra-sm:0 4px 16px -6px rgba(15,70,160,.16);
  --radio:18px; --radio-sm:12px;
  --display:'Sora',system-ui,sans-serif; --body:'Plus Jakarta Sans',system-ui,sans-serif;
}
html[data-theme="dark"]{
  --bg:#060d1c; --bg-2:#0a1428; --card:#0e1a33; --tinta:#eaf2ff;
  --txt:#e8f0ff; --txt-2:#8fa3c4; --linea:#1b2a48;
  --sombra:0 14px 48px -16px rgba(0,0,0,.6);
  --sombra-sm:0 6px 20px -8px rgba(0,0,0,.5);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--body); background:var(--bg); color:var(--txt);
  line-height:1.6; overflow-x:hidden; transition:background .3s,color .3s;
}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;display:block}
.container{width:min(1180px,92%);margin-inline:auto}
section{position:relative}

h1,h2,h3,.display{font-family:var(--display);line-height:1.1;letter-spacing:-.02em}

/* ---------- Botones ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--display);
  font-weight:700;font-size:.95rem;padding:.85rem 1.6rem;border-radius:999px;
  border:none;cursor:pointer;transition:transform .2s,box-shadow .2s,background .2s;white-space:nowrap}
.btn-pri{background:linear-gradient(120deg,var(--verde),var(--teal));color:#fff;
  box-shadow:0 8px 24px -8px rgba(15,184,122,.6)}
.btn-pri:hover{transform:translateY(-2px);box-shadow:0 14px 32px -10px rgba(15,184,122,.7)}
.btn-out{background:transparent;color:var(--txt);border:1.6px solid var(--linea)}
.btn-out:hover{border-color:var(--verde);color:var(--verde)}
.btn-ghost{background:var(--card);color:var(--txt);box-shadow:var(--sombra-sm)}
.btn-lg{padding:1.05rem 2.1rem;font-size:1.05rem}
.btn-blanco{background:#fff;color:var(--verde-3)}

/* ---------- Badges / títulos sección ---------- */
.badge{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--display);
  font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--verde-3);background:rgba(15,184,122,.12);padding:.42rem .9rem;border-radius:999px}
html[data-theme="dark"] .badge{color:var(--acento);background:rgba(22,224,154,.14)}
.sec-title{font-size:clamp(1.9rem,4vw,2.9rem);font-weight:800;margin:1rem 0 .8rem}
.sec-title span{background:linear-gradient(120deg,var(--verde),var(--teal));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.sec-sub{color:var(--txt-2);font-size:1.08rem;max-width:620px;margin-inline:auto}
.text-center{text-align:center}
.pad{padding:clamp(3.5rem,8vw,6.5rem) 0}

/* ---------- NAV ---------- */
header.nav{position:fixed;inset:0 0 auto;z-index:100;transition:.3s}
header.nav .bar{display:flex;align-items:center;justify-content:space-between;
  padding:1rem 0;transition:.3s}
header.nav.scr{background:color-mix(in srgb,var(--bg) 85%,transparent);
  backdrop-filter:blur(14px);border-bottom:1px solid var(--linea)}
.logo{display:flex;align-items:center;gap:.6rem;font-family:var(--display);font-weight:800}
.logo-mark{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--verde),var(--teal));color:#fff;font-size:1.15rem;
  box-shadow:0 6px 18px -6px rgba(15,184,122,.6)}
.logo-txt strong{display:block;font-size:1.18rem;letter-spacing:-.02em}
.logo-txt span{display:block;font-size:.66rem;color:var(--txt-2);font-weight:600;
  text-transform:uppercase;letter-spacing:.12em;font-family:var(--body)}
.nav-links{display:flex;align-items:center;gap:1.6rem}
.nav-links a.lk{font-weight:600;font-size:.95rem;color:var(--txt-2);transition:.2s;position:relative}
.nav-links a.lk:hover{color:var(--verde)}
.nav-tools{display:flex;align-items:center;gap:.7rem}
.sel-wrap{position:relative}
.mini-sel{font-family:var(--display);font-weight:700;font-size:.85rem;cursor:pointer;
  background:var(--card);color:var(--txt);border:1.4px solid var(--linea);
  border-radius:999px;padding:.5rem .85rem;appearance:none;padding-right:1.9rem}
.sel-wrap::after{content:'▾';position:absolute;right:.7rem;top:50%;transform:translateY(-50%);
  pointer-events:none;color:var(--txt-2);font-size:.7rem}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.4rem}
.burger span{width:24px;height:2.5px;background:var(--txt);border-radius:2px;transition:.3s}

/* ---------- HERO SLIDER (full width) ---------- */
#bg-canvas{position:absolute;inset:0;z-index:0;opacity:.85}
.hero-slider{position:relative;min-height:92vh;overflow:hidden;display:flex;align-items:center}
.hslide{position:absolute;inset:0;display:flex;align-items:center;opacity:0;visibility:hidden;
  transition:opacity .8s ease, visibility .8s;z-index:1}
.hslide.on{opacity:1;visibility:visible;z-index:2}
.hslide-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center;
  position:relative;z-index:3;padding-top:5rem}
.hslide-text{transform:translateY(28px);opacity:0;transition:.8s .2s cubic-bezier(.2,.7,.2,1)}
.hslide.on .hslide-text{transform:none;opacity:1}
.hslide-text h1{font-size:clamp(2.2rem,5vw,3.9rem);font-weight:800;margin:1rem 0 1.1rem;line-height:1.08}
.hslide-text .lead{font-size:1.14rem;color:var(--txt-2);max-width:540px;margin-bottom:1.8rem}
.hero-btns{display:flex;gap:.9rem;flex-wrap:wrap}

/* fondo de cada slide según tema */
.hslide::before{content:'';position:absolute;inset:0;z-index:0;opacity:.5;transition:.8s}
.hk-sky::before{background:radial-gradient(circle at 78% 30%,rgba(31,109,255,.20),transparent 55%)}
.hk-cyan::before{background:radial-gradient(circle at 75% 35%,rgba(6,182,212,.22),transparent 55%)}
.hk-deep::before{background:radial-gradient(circle at 80% 25%,rgba(20,86,201,.22),transparent 55%)}

/* visual: ilustración grande con anillo animado */
.hslide-vis{position:relative;display:grid;place-items:center;height:380px}
.hslide-ill{width:240px;height:240px;position:relative;z-index:2;
  filter:drop-shadow(0 24px 48px rgba(15,70,160,.28));animation:floaty 5s ease-in-out infinite}
.hslide.on .hslide-ill{animation:popIn .9s .25s both, floaty 5s 1.1s ease-in-out infinite}
.hslide-ring{position:absolute;width:340px;height:340px;border-radius:50%;z-index:1;
  border:2px dashed color-mix(in srgb,var(--verde) 40%,transparent);
  animation:spin 22s linear infinite}
.hslide-ring::after{content:'';position:absolute;inset:34px;border-radius:50%;
  border:2px solid color-mix(in srgb,var(--teal) 35%,transparent)}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes popIn{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

/* flechas */
.hs-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:6;width:48px;height:48px;
  border-radius:50%;border:1.5px solid var(--linea);background:var(--card);color:var(--txt);
  font-size:1.6rem;cursor:pointer;box-shadow:var(--sombra-sm);transition:.25s;display:grid;place-items:center}
.hs-arrow:hover{background:var(--verde);color:#fff;border-color:var(--verde)}
.hs-prev{left:1.2rem}.hs-next{right:1.2rem}

/* controles: dots + stats */
.hs-controls{position:absolute;left:50%;transform:translateX(-50%);bottom:1.6rem;z-index:6;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;width:min(1180px,92%)}
.hs-dots{display:flex;gap:.5rem}
.hs-dot{width:34px;height:6px;border:none;background:transparent;cursor:pointer;padding:0}
.hs-dot i{display:block;height:6px;border-radius:99px;background:color-mix(in srgb,var(--txt-2) 35%,transparent);transition:.3s}
.hs-dot.on i{background:linear-gradient(90deg,var(--verde),var(--teal))}
.hs-dot.on{width:48px}
.hs-stats{display:flex;gap:1.8rem;flex-wrap:wrap}
.hs-stats b{font-family:var(--display);font-weight:800;font-size:1.4rem;display:block;
  background:linear-gradient(120deg,var(--verde),var(--teal));-webkit-background-clip:text;
  background-clip:text;-webkit-text-fill-color:transparent}
.hs-stats span{font-size:.78rem;color:var(--txt-2);font-weight:600}

/* ---------- MÓDULOS ---------- */
.mods-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:3rem}
.mod{background:var(--card);border:1px solid var(--linea);border-radius:var(--radio);
  padding:1.7rem;box-shadow:var(--sombra-sm);transition:.3s;position:relative;overflow:hidden}
.mod::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;
  background:linear-gradient(90deg,var(--verde),var(--teal));transform:scaleX(0);
  transform-origin:left;transition:.4s}
.mod:hover{transform:translateY(-6px);box-shadow:var(--sombra);border-color:transparent}
.mod:hover::before{transform:scaleX(1)}
.mod-ico{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;
  font-size:1.6rem;margin-bottom:1.1rem;
  background:linear-gradient(135deg,rgba(15,184,122,.16),rgba(10,160,168,.16))}
.mod h3{font-size:1.2rem;font-weight:800;margin-bottom:.5rem}
.mod p{color:var(--txt-2);font-size:.94rem}

/* ---------- Toggle ciclo mensual/anual ---------- */
.ciclo-toggle{display:inline-flex;gap:.3rem;margin:1.4rem auto .4rem;padding:.35rem;
  background:var(--card);border:1.4px solid var(--linea);border-radius:999px;box-shadow:var(--sombra-sm)}
.ciclo-btn{font-family:var(--display);font-weight:700;font-size:.92rem;cursor:pointer;
  border:none;background:transparent;color:var(--txt-2);padding:.55rem 1.3rem;border-radius:999px;
  transition:.25s;display:inline-flex;align-items:center;gap:.45rem}
.ciclo-btn.on{background:linear-gradient(120deg,var(--verde),var(--teal));color:#fff;
  box-shadow:0 6px 16px -6px rgba(15,184,122,.6)}
.ciclo-tag{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;
  background:rgba(255,255,255,.25);padding:.15rem .5rem;border-radius:999px}
.ciclo-btn:not(.on) .ciclo-tag{background:rgba(15,184,122,.15);color:var(--verde-3)}

/* ---------- PLANES ---------- */
.plan-pais{display:flex;align-items:center;justify-content:center;gap:.8rem;
  margin:1.8rem 0 .6rem;flex-wrap:wrap}
.plan-pais label{font-weight:700;font-family:var(--display);font-size:.95rem}
.plan-pais select{font-family:var(--display);font-weight:700;font-size:1rem;
  background:var(--card);color:var(--txt);border:1.6px solid var(--verde);
  border-radius:999px;padding:.65rem 1.3rem;cursor:pointer}
.plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.4rem;align-items:start}
.plan{background:var(--card);border:1.5px solid var(--linea);border-radius:22px;
  padding:2rem 1.8rem;box-shadow:var(--sombra-sm);transition:.3s;position:relative}
.plan:hover{transform:translateY(-6px);box-shadow:var(--sombra)}
.plan.pop{border-color:var(--verde);box-shadow:0 18px 50px -18px rgba(15,184,122,.5);transform:scale(1.03)}
.plan.pop:hover{transform:scale(1.03) translateY(-6px)}
.plan-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:linear-gradient(120deg,var(--verde),var(--teal));color:#fff;font-family:var(--display);
  font-weight:800;font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;
  padding:.42rem 1rem;border-radius:999px;white-space:nowrap}
.plan-name{font-family:var(--display);font-weight:800;font-size:1.4rem}
.plan-desc{color:var(--txt-2);font-size:.92rem;margin:.4rem 0 1.3rem;min-height:42px}
.plan-price{display:flex;align-items:flex-end;gap:.3rem;margin-bottom:.2rem}
.plan-cur{font-family:var(--display);font-weight:700;font-size:1.2rem;color:var(--txt-2);margin-bottom:.45rem}
.plan-amt{font-family:var(--display);font-weight:800;font-size:2.9rem;line-height:1}
.plan-per{color:var(--txt-2);font-weight:600;margin-bottom:.5rem}
.plan-ref{font-size:.8rem;color:var(--txt-2);margin-bottom:1.3rem}
.plan-ref b{color:var(--verde)}
.plan ul{margin:1.2rem 0 1.6rem;display:flex;flex-direction:column;gap:.65rem}
.plan ul li{display:flex;gap:.6rem;align-items:flex-start;font-size:.93rem}
.plan ul li::before{content:'✓';color:var(--verde);font-weight:800;flex:none}
.plan ul li.cat{font-weight:800;color:var(--txt);font-family:var(--display)}
.plan ul li.cat::before{content:'★';color:var(--teal)}

/* ---------- CONTADOR / STATS BANNER ---------- */
.statband{background:linear-gradient(120deg,var(--verde-3),var(--teal-2));color:#fff;
  border-radius:26px;padding:2.6rem;display:grid;grid-template-columns:repeat(4,1fr);
  gap:1.5rem;text-align:center;box-shadow:var(--sombra)}
.statband .n{font-family:var(--display);font-weight:800;font-size:2.4rem}
.statband .l{opacity:.9;font-size:.92rem;font-weight:600}

/* ---------- TESTIMONIOS ---------- */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:3rem}
.testi{background:var(--card);border:1px solid var(--linea);border-radius:var(--radio);
  padding:1.8rem;box-shadow:var(--sombra-sm)}
.testi .stars{color:#f6b73c;margin-bottom:.7rem}
.testi p{font-style:italic;color:var(--txt);margin-bottom:1.2rem}
.testi .who{display:flex;align-items:center;gap:.7rem}
.testi .av{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--verde),var(--teal));color:#fff;font-weight:800}
.testi .who b{display:block;font-family:var(--display)}
.testi .who span{font-size:.82rem;color:var(--txt-2)}

/* ---------- CTA ---------- */
.cta{background:linear-gradient(120deg,var(--verde-3),var(--teal-2));border-radius:28px;
  padding:clamp(2.5rem,5vw,4rem);text-align:center;color:#fff;position:relative;overflow:hidden}
.cta::after{content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.18),transparent 45%)}
.cta h2{font-size:clamp(1.8rem,4vw,2.7rem);font-weight:800;position:relative}
.cta p{opacity:.92;max-width:560px;margin:1rem auto 1.8rem;position:relative}

/* ---------- CONTACTO ---------- */
.cont-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:3rem;align-items:start;margin-top:2.5rem}
.cont-info .ci{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.4rem}
.cont-info .ci .ic{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;
  font-size:1.3rem;background:linear-gradient(135deg,rgba(15,184,122,.16),rgba(10,160,168,.16));flex:none}
.cont-info .ci b{font-family:var(--display);display:block}
.cont-info .ci span{color:var(--txt-2);font-size:.93rem}
.form{background:var(--card);border:1px solid var(--linea);border-radius:22px;
  padding:2rem;box-shadow:var(--sombra)}
.fg{margin-bottom:1.1rem}
.fg label{display:block;font-weight:600;font-size:.88rem;margin-bottom:.4rem}
.fg input,.fg select,.fg textarea{width:100%;font-family:var(--body);font-size:.95rem;
  padding:.8rem 1rem;border:1.5px solid var(--linea);border-radius:12px;
  background:var(--bg-2);color:var(--txt);transition:.2s}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--verde);
  box-shadow:0 0 0 3px rgba(15,184,122,.15)}
.fg textarea{resize:vertical;min-height:90px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.alert{padding:.9rem 1.1rem;border-radius:12px;font-weight:600;margin-bottom:1rem}
.alert.ok{background:rgba(15,184,122,.14);color:var(--verde-3);border:1px solid rgba(15,184,122,.3)}
.alert.err{background:rgba(229,72,77,.12);color:#d33;border:1px solid rgba(229,72,77,.3)}

/* ---------- FOOTER ---------- */
footer.ft{background:var(--bg-2);border-top:1px solid var(--linea);padding:3.5rem 0 1.5rem;margin-top:4rem}
.ft-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2.5rem}
.ft-grid p{color:var(--txt-2);font-size:.92rem;margin:1rem 0}
.ft-soc{display:flex;gap:.6rem}
.ft-soc a{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;
  background:var(--card);border:1px solid var(--linea);font-weight:700;transition:.2s}
.ft-soc a:hover{background:var(--verde);color:#fff;border-color:var(--verde)}
.ft-col h4{font-family:var(--display);font-size:1rem;margin-bottom:1rem}
.ft-col li{margin-bottom:.6rem}
.ft-col a{color:var(--txt-2);font-size:.92rem;transition:.2s}
.ft-col a:hover{color:var(--verde)}
.ft-selects{display:flex;flex-direction:column;gap:.7rem}
.ft-selects small{font-weight:700;color:var(--txt-2);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em}
.ft-bottom{border-top:1px solid var(--linea);margin-top:2.5rem;padding-top:1.5rem;
  text-align:center;color:var(--txt-2);font-size:.86rem}

/* ---------- Botón de tema en el pie ---------- */
.ft-theme-btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--display);
  font-weight:700;font-size:.85rem;cursor:pointer;background:var(--card);color:var(--txt);
  border:1.4px solid var(--linea);border-radius:999px;padding:.5rem .9rem;transition:.2s;width:fit-content}
.ft-theme-btn:hover{border-color:var(--verde);color:var(--verde)}
.ft-theme-ico{font-size:1.05rem}

/* ---------- Auth / Panel ---------- */
.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:6rem 1rem 3rem}
.auth-card{width:min(440px,100%);background:var(--card);border:1px solid var(--linea);
  border-radius:24px;padding:2.4rem;box-shadow:var(--sombra)}
.auth-card h2{text-align:center;margin-bottom:1.6rem}
.auth-switch{text-align:center;margin-top:1.2rem;color:var(--txt-2);font-size:.92rem}
.auth-switch a{color:var(--verde);font-weight:700}
.panel-wrap{padding:7rem 0 3rem}
.tag{display:inline-block;font-family:var(--display);font-weight:700;font-size:.74rem;
  padding:.3rem .75rem;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}
.tag.aprobado{background:rgba(15,184,122,.15);color:var(--verde-3)}
.tag.pendiente{background:rgba(246,183,60,.18);color:#b9821a}
.tag.nueva{background:rgba(10,160,168,.15);color:var(--teal-2)}
.tabla{width:100%;border-collapse:collapse;background:var(--card);border-radius:16px;overflow:hidden;box-shadow:var(--sombra-sm)}
.tabla th,.tabla td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid var(--linea);font-size:.92rem}
.tabla th{background:var(--bg-2);font-family:var(--display);font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em}
.tabla tr:last-child td{border-bottom:none}
.admin-tabs{display:flex;gap:.6rem;margin-bottom:1.6rem;flex-wrap:wrap}
.admin-tabs a{font-family:var(--display);font-weight:700;font-size:.9rem;padding:.6rem 1.1rem;
  border-radius:999px;background:var(--card);border:1px solid var(--linea);transition:.2s}
.admin-tabs a.on,.admin-tabs a:hover{background:var(--verde);color:#fff;border-color:var(--verde)}
.btn-sm{padding:.4rem .9rem;font-size:.82rem}

/* reglas chatbot admin */
.bot-rule{background:var(--card);border:1px solid var(--linea);border-radius:14px;padding:1rem;margin-bottom:1rem;box-shadow:var(--sombra-sm)}
.bot-rule.off{opacity:.55}
.bot-kw{width:100%;font-family:var(--display);font-weight:700;font-size:.9rem;border:1.4px solid var(--linea);
  background:var(--bg-2);color:var(--verde);border-radius:9px;padding:.5rem .7rem;margin-bottom:.5rem}
.bot-resp{width:100%;font-family:var(--body);font-size:.9rem;border:1.4px solid var(--linea);
  background:var(--bg-2);color:var(--txt);border-radius:9px;padding:.5rem .7rem;min-height:64px;resize:vertical;margin-bottom:.6rem}
.bot-actions{display:flex;gap:.4rem;flex-wrap:wrap}
.bot-kw:focus,.bot-resp:focus{outline:none;border-color:var(--verde)}

/* ---------- Logo imagen (PNG) ---------- */
.logo-img{padding:0;background:transparent !important;overflow:hidden}
.logo-img img{width:100%;height:100%;object-fit:contain}

/* ---------- Nav dropdown (Soluciones) ---------- */
.nav-drop{position:relative}
.nav-drop-menu{position:absolute;top:140%;left:50%;transform:translateX(-50%) translateY(8px);
  background:var(--card);border:1px solid var(--linea);border-radius:14px;box-shadow:var(--sombra);
  padding:.5rem;min-width:190px;opacity:0;visibility:hidden;transition:.25s;z-index:50}
.nav-drop:hover .nav-drop-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-drop-menu a{display:block;padding:.6rem .8rem;border-radius:9px;font-weight:600;font-size:.92rem;color:var(--txt-2);transition:.18s}
.nav-drop-menu a:hover{background:rgba(15,184,122,.12);color:var(--verde)}

/* ---------- Parallax hero shapes ---------- */
.parallax-layer{position:absolute;border-radius:50%;filter:blur(2px);opacity:.5;z-index:1;pointer-events:none}
.px1{width:220px;height:220px;top:6%;right:8%;background:radial-gradient(circle,rgba(15,184,122,.35),transparent 70%)}
.px2{width:160px;height:160px;bottom:12%;left:4%;background:radial-gradient(circle,rgba(10,160,168,.3),transparent 70%)}
.px3{width:90px;height:90px;top:40%;right:38%;background:radial-gradient(circle,rgba(22,224,154,.4),transparent 70%)}
.px-ill{position:absolute;width:74px;height:74px;z-index:1;opacity:.85;pointer-events:none;
  filter:drop-shadow(0 10px 20px rgba(8,80,55,.18))}
.pi1{top:14%;right:6%}.pi2{bottom:18%;left:3%}.pi3{top:50%;right:42%;width:54px;height:54px}

/* ---------- Ilustraciones en módulos ---------- */
.ilus-row{display:flex;justify-content:center;gap:1.5rem;margin:2.4rem 0 0;flex-wrap:wrap}
.ilus-chip{width:88px;height:88px;background:var(--card);border:1px solid var(--linea);
  border-radius:22px;padding:14px;box-shadow:var(--sombra-sm);transition:.3s}
.ilus-chip:hover{transform:translateY(-6px) rotate(-4deg);box-shadow:var(--sombra)}
.ilus-chip svg{width:100%;height:100%}
.mod-ilus{width:60px;height:60px;margin-bottom:1rem}
.mod-ilus svg{width:100%;height:100%}

/* ---------- Tabs ERP (portada) ---------- */
.erp-section{background:var(--bg-2)}
.erp-tabs{display:flex;justify-content:center;gap:.5rem;margin:2.2rem 0 2rem;flex-wrap:wrap}
.erp-tab{font-family:var(--display);font-weight:700;font-size:.95rem;cursor:pointer;border:1.5px solid var(--linea);
  background:var(--card);color:var(--txt-2);padding:.7rem 1.4rem;border-radius:999px;transition:.25s;display:inline-flex;align-items:center;gap:.5rem}
.erp-tab.on{background:linear-gradient(120deg,var(--verde),var(--teal));color:#fff;border-color:transparent;
  box-shadow:0 8px 22px -8px rgba(15,184,122,.6)}
.erp-stage{max-width:760px;margin:0 auto;position:relative}
.erp-frame{background:var(--card);border:1px solid var(--linea);border-radius:20px;padding:1rem;box-shadow:var(--sombra);
  position:relative;overflow:hidden}
.erp-panel{display:none;animation:fadeUp .5s ease}
.erp-panel.on{display:block}
.erp-svg{width:100%;height:auto;border-radius:10px;display:block}
.erp-cap{text-align:center;color:var(--txt-2);margin-top:1rem;font-size:.95rem}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ---------- Chatbot ---------- */
.chat-launch{position:fixed;right:1.4rem;bottom:1.6rem;z-index:95;display:flex;align-items:center;gap:.6rem;cursor:pointer}
.chat-launch-ico{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;font-size:1.5rem;
  background:linear-gradient(135deg,var(--verde),var(--teal));color:#fff;box-shadow:0 10px 26px -8px rgba(15,184,122,.7);
  transition:.3s;order:2}
.chat-launch:hover .chat-launch-ico{transform:scale(1.08)}
.chat-bubble-hint{background:var(--card);border:1px solid var(--linea);box-shadow:var(--sombra-sm);
  padding:.5rem .9rem;border-radius:999px 999px 4px 999px;font-weight:700;font-size:.85rem;order:1;
  animation:floaty 3s ease-in-out infinite}
.chat-box{position:fixed;right:1.4rem;bottom:1.6rem;z-index:96;width:min(360px,calc(100vw - 2rem));
  height:520px;max-height:calc(100vh - 7rem);background:var(--card);border:1px solid var(--linea);
  border-radius:20px;box-shadow:var(--sombra);display:flex;flex-direction:column;overflow:hidden;
  opacity:0;visibility:hidden;transform:translateY(20px) scale(.97);transition:.3s}
.chat-box.open{opacity:1;visibility:visible;transform:none}
.chat-head{background:linear-gradient(120deg,var(--verde),var(--teal));color:#fff;padding:1rem 1.1rem;
  display:flex;align-items:center;justify-content:space-between}
.chat-head-l{display:flex;align-items:center;gap:.7rem}
.chat-avatar{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.22);display:grid;place-items:center;font-size:1.3rem}
.chat-head b{display:block;font-family:var(--display);font-size:1rem}
.chat-head span{font-size:.78rem;opacity:.9;display:flex;align-items:center;gap:.3rem}
.chat-head span::before{content:'';width:7px;height:7px;border-radius:50%;background:#7CFFB2;display:inline-block}
.chat-close{background:transparent;border:none;color:#fff;font-size:1.1rem;cursor:pointer;opacity:.85}
.chat-msgs{flex:1;overflow-y:auto;padding:1.1rem;display:flex;flex-direction:column;gap:.7rem}
.chat-msg{max-width:82%;padding:.7rem .95rem;border-radius:16px;font-size:.92rem;line-height:1.45;animation:fadeUp .35s ease}
.chat-msg.bot{align-self:flex-start;background:var(--bg-2);border:1px solid var(--linea);border-bottom-left-radius:5px}
.chat-msg.user{align-self:flex-end;background:linear-gradient(120deg,var(--verde),var(--teal));color:#fff;border-bottom-right-radius:5px}
.chat-quick{display:flex;gap:.4rem;padding:0 1.1rem .6rem;flex-wrap:wrap}
.chat-quick button{font-size:.8rem;font-weight:600;border:1.4px solid var(--linea);background:var(--bg-2);
  color:var(--verde);padding:.4rem .8rem;border-radius:999px;cursor:pointer;transition:.2s}
.chat-quick button:hover{background:var(--verde);color:#fff;border-color:var(--verde)}
.chat-input{display:flex;gap:.5rem;padding:.8rem 1.1rem;border-top:1px solid var(--linea)}
.chat-input input{flex:1;border:1.5px solid var(--linea);background:var(--bg-2);color:var(--txt);
  border-radius:999px;padding:.65rem 1rem;font-family:var(--body);font-size:.92rem}
.chat-input input:focus{outline:none;border-color:var(--verde)}
.chat-input button{width:42px;height:42px;border-radius:50%;border:none;cursor:pointer;flex:none;
  background:linear-gradient(135deg,var(--verde),var(--teal));color:#fff;font-size:1rem}
.chat-typing{align-self:flex-start;display:flex;gap:4px;padding:.7rem .95rem}
.chat-typing i{width:7px;height:7px;border-radius:50%;background:var(--txt-2);opacity:.5;animation:blink 1.2s infinite}
.chat-typing i:nth-child(2){animation-delay:.2s}.chat-typing i:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,60%,100%{opacity:.3}30%{opacity:1}}

/* ---------- Rubro features ---------- */
.rubro-feats{display:flex;flex-direction:column;gap:.7rem;margin:1.4rem 0 1.8rem}
.rubro-feats li{font-size:1rem;color:var(--txt);display:flex;gap:.5rem;align-items:flex-start}

/* ---------- Page hero (subpáginas) ---------- */
.page-hero{padding:8.5rem 0 3rem;text-align:center;position:relative;overflow:hidden}
.page-hero .crumb{color:var(--txt-2);font-size:.88rem;margin-bottom:1rem}
.page-hero .crumb a{color:var(--verde);font-weight:600}
.page-hero h1{font-size:clamp(2.1rem,4.6vw,3.2rem);font-weight:800;margin:.6rem 0 1rem}
.page-hero h1 span{background:linear-gradient(120deg,var(--verde),var(--teal));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.page-hero p{color:var(--txt-2);max-width:640px;margin:0 auto;font-size:1.08rem}
.split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.split-ill{display:grid;place-items:center}
.split-ill .ilus-chip{width:200px;height:200px;border-radius:36px;padding:34px}
@media(max-width:860px){.split{grid-template-columns:1fr}}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .hslide-grid,.cont-grid,.split{grid-template-columns:1fr}
  .hslide-grid{text-align:center;padding-top:6rem}
  .hslide-text{order:2}.hslide-vis{order:1;height:240px}
  .hslide-text .lead{margin-inline:auto}
  .hero-btns{justify-content:center}
  .hslide-ill{width:170px;height:170px}.hslide-ring{width:240px;height:240px}
  .hs-stats{display:none}
  .hs-controls{justify-content:center}
  .mods-grid,.testi-grid{grid-template-columns:repeat(2,1fr)}
  .plans-grid{grid-template-columns:1fr;max-width:440px;margin-inline:auto}
  .plan.pop{transform:none}.plan.pop:hover{transform:translateY(-6px)}
  .ft-grid{grid-template-columns:1fr 1fr}
  .statband{grid-template-columns:1fr 1fr;gap:2rem}
  .nav-drop-menu{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;
    border:none;padding:.2rem 0 .2rem 1rem;min-width:auto}
}
@media(max-width:640px){
  .nav-links{position:fixed;inset:64px 0 auto;flex-direction:column;background:var(--bg-2);
    padding:1.5rem;gap:1.1rem;border-bottom:1px solid var(--linea);transform:translateY(-130%);
    transition:.35s;box-shadow:var(--sombra);max-height:calc(100vh - 64px);overflow-y:auto}
  .nav-links.open{transform:none}
  .burger{display:flex}
  .mods-grid,.testi-grid,.ft-grid,.statband,.frow{grid-template-columns:1fr}
  .hero-slider{min-height:auto;padding:7rem 0 5rem}
  .hslide{position:relative;inset:auto;display:none}
  .hslide.on{display:flex}
  .hslide-text h1{font-size:2rem}
  .hs-arrow{width:40px;height:40px;font-size:1.3rem}
  .hs-prev{left:.5rem}.hs-next{right:.5rem}
  .hs-controls{position:relative;bottom:auto;margin-top:1.5rem}
  .erp-tabs,.ciclo-toggle{flex-wrap:wrap}
  .erp-tab{font-size:.85rem;padding:.6rem 1rem}
  .chat-box{width:calc(100vw - 1.6rem);right:.8rem;height:70vh}
  .chat-launch{right:.9rem;bottom:1rem}
  .split-ill .ilus-chip{width:150px;height:150px}
  .ilus-row{gap:.8rem}.ilus-chip{width:64px;height:64px;padding:10px}
  .page-hero{padding-top:7rem}
  .cont-grid{gap:1.6rem}
}
@media(max-width:400px){
  .hslide-text h1{font-size:1.7rem}
  .btn-lg{padding:.85rem 1.4rem;font-size:.95rem}
  .hero-btns{flex-direction:column}
  .hero-btns .btn{width:100%;justify-content:center}
}
