/* ============================================================
   Hospital Sta. Margarita — Sistema de diseño
   "Modern tech-health": aire, claridad, confianza.
   ============================================================ */

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

:root{
  /* Marca — verde/teal Sta. Margarita */
  --primary:        #0c8a6f;
  --primary-deep:   #086a55;
  --primary-press:  #064e3f;
  --primary-soft:   #e4f4ef;
  --primary-tint:   #f1faf7;
  --mint:           #b8e6d8;

  /* Neutros con leve temperatura fría-verde */
  --bg:        #f4f8f6;
  --surface:   #ffffff;
  --surface-2: #fbfdfc;
  --ink:       #0e231d;
  --ink-soft:  #3c544d;
  --muted:     #6c827b;
  --line:      #e2ece8;
  --line-soft: #eef4f1;

  /* Acentos */
  --emergency: #e0483d;
  --emergency-soft: #fdecea;
  --gold:      #d9a441;

  /* Radios */
  --r-xs: 6px;
  --r-sm: 10px;
  --r:    12px;
  --r-lg: 16px;
  --r-xl: 20px;
  --r-pill: 999px;

  /* Sombras */
  --sh-sm: 0 1px 2px rgba(14,35,29,.05), 0 1px 1px rgba(14,35,29,.04);
  --sh:    0 4px 16px rgba(14,35,29,.06), 0 1px 3px rgba(14,35,29,.05);
  --sh-md: 0 12px 34px rgba(14,35,29,.09), 0 4px 10px rgba(14,35,29,.05);
  --sh-lg: 0 30px 70px rgba(14,35,29,.14), 0 10px 24px rgba(14,35,29,.07);
  --sh-primary: 0 14px 30px rgba(12,138,111,.28);

  /* Tipografía */
  --sans: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --mono: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;

  --maxw: 1240px;
  --gut: clamp(20px, 5vw, 64px);
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{ margin:0; line-height:1.08; letter-spacing:-0.02em; font-weight:800; }
p{ margin:0; }
::selection{ background:var(--mint); color:var(--primary-press); }

/* ---------- Layout helpers ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); }
.section{ padding-block:clamp(64px, 9vw, 132px); }
.section-tight{ padding-block:clamp(44px, 6vw, 80px); }
.center{ text-align:center; }

.eyebrow{
  font-size:13px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--primary-deep);
  display:inline-block;
}

h1.display{ font-size:clamp(2.6rem, 6vw, 4.6rem); letter-spacing:-0.035em; }
h2.title{ font-size:clamp(2rem, 4vw, 3.2rem); letter-spacing:-0.03em; }
h3.sub{ font-size:clamp(1.3rem, 2vw, 1.7rem); }
.lead{ font-size:clamp(1.05rem, 1.5vw, 1.28rem); color:var(--ink-soft); line-height:1.6; }
.kicker{ color:var(--muted); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-weight:700; font-size:1rem; letter-spacing:-.01em;
  padding:15px 26px; border-radius:var(--r-pill);
  border:1.5px solid transparent; transition:.22s cubic-bezier(.2,.7,.3,1);
  white-space:nowrap;
}
.btn svg{ width:18px;height:18px; }
.btn-primary{ background:var(--primary); color:#fff; box-shadow:var(--sh-primary); }
.btn-primary:hover{ background:var(--primary-deep); transform:translateY(-2px); box-shadow:0 18px 38px rgba(12,138,111,.34); }
.btn-ghost{ background:var(--surface); color:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--primary); color:var(--primary-deep); transform:translateY(-2px); box-shadow:var(--sh); }
.btn-emergency{ background:var(--emergency); color:#fff; }
.btn-emergency:hover{ background:#c43a30; transform:translateY(-2px); }
.btn-lg{ padding:18px 32px; font-size:1.08rem; }
.btn-white{ background:#fff; color:var(--primary-deep); }
.btn-white:hover{ transform:translateY(-2px); box-shadow:var(--sh-md); }

/* ---------- Header / Nav ---------- */
.topbar{ background:var(--primary-press); color:#cfe7df; font-size:13px; border-bottom:1px solid rgba(255,255,255,.07); }
.topbar .wrap{ display:flex; align-items:center; justify-content:space-between; gap:18px; min-height:46px; }
.topbar a{ color:#cfe7df; transition:.2s; }
.topbar a:hover{ color:#fff; }
.topbar-left, .topbar-right{ display:flex; align-items:center; gap:16px; }
.topbar .ti{ display:inline-flex; align-items:center; gap:8px; font-size:12.5px; letter-spacing:.01em; color:#bcdacf; }
.topbar .ti svg{ width:14px;height:14px; opacity:.7; }
.topbar .ti-sep{ width:1px; height:15px; background:rgba(255,255,255,.16); flex:none; }
.topbar .emerg{ display:inline-flex; align-items:center; gap:9px; color:#fff; font-weight:600; }
.topbar .emerg .edot{ width:7px;height:7px;border-radius:50%;background:#ff6f62; box-shadow:0 0 0 3px rgba(255,111,98,.22); flex:none; }
.topbar .emerg b{ color:#fff; font-weight:700; letter-spacing:.01em; }
.topbar .emerg:hover b{ color:#eafaf5; }
.topbar .socials{ display:flex; gap:13px; }
.topbar .socials a{ display:inline-flex; color:#9fc2b6; }
.topbar .socials a:hover{ color:#fff; }
.topbar .socials svg{ width:15px;height:15px; }

.nav{
  position:sticky; top:0; z-index:60;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(1.4) blur(14px);
  -webkit-backdrop-filter:saturate(1.4) blur(14px);
  border-bottom:1px solid var(--line-soft);
  transition:box-shadow .3s, background .3s;
}
.nav.scrolled{ box-shadow:0 6px 24px rgba(14,35,29,.07); background:rgba(255,255,255,.93); }
.nav .wrap{ display:flex; align-items:center; justify-content:space-between; gap:24px; min-height:78px; }
.brand{ display:flex; align-items:center; gap:13px; }
.brand .mark{ height:44px; flex:none; display:flex; align-items:center; }
.brand .mark img{ display:block; height:100%; width:auto; object-fit:contain; }
.brand .bt{ display:flex; flex-direction:column; line-height:1.1; }
.brand .bt b{ font-size:1.02rem; font-weight:800; letter-spacing:-.02em; }
.brand .bt span{ font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }

.nav .wrap{ max-width:1320px; padding-inline:clamp(20px,3vw,44px); }
.nav .wrap{ display:flex; align-items:center; justify-content:space-between; gap:16px; min-height:78px; }
.menu{ display:flex; align-items:center; gap:2px; }
.menu a{
  padding:9px 12px; border-radius:var(--r-pill); font-weight:600; font-size:.94rem;
  color:var(--ink-soft); transition:.18s; position:relative; white-space:nowrap;
}
.menu a:hover{ color:var(--primary-deep); background:var(--primary-tint); }
.menu a.active{ color:var(--primary-deep); background:var(--primary-soft); }

/* Dropdown de Servicios */
.menu-item{ position:relative; display:flex; align-items:center; }
.menu-item > a{ display:inline-flex; align-items:center; gap:6px; }
.menu-item .caret{ transition:transform .22s; }
.menu-item:hover .caret, .menu-item.open .caret{ transform:rotate(180deg); }
.menu-item .dropdown{
  position:absolute; top:calc(100% + 12px); left:50%;
  transform:translateX(-50%) translateY(8px);
  min-width:240px; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--r); box-shadow:var(--sh-lg); padding:8px;
  display:flex; flex-direction:column; gap:2px;
  opacity:0; visibility:hidden; pointer-events:none; transition:.22s cubic-bezier(.2,.7,.3,1); z-index:70;
}
.menu-item .dropdown::before{ content:""; position:absolute; top:-14px; left:0; right:0; height:16px; }
.menu-item:hover .dropdown, .menu-item.open .dropdown{ opacity:1; visibility:visible; pointer-events:auto; transform:translateX(-50%) translateY(0); }
.menu-item .dropdown a{
  padding:12px 14px !important; border-radius:12px; font-weight:600; font-size:.95rem;
  color:var(--ink-soft) !important; background:none !important;
  display:flex; align-items:center; gap:11px; white-space:nowrap; position:relative;
}
.menu-item .dropdown a::before{
  content:""; width:7px;height:7px;border-radius:2px; background:var(--mint);
  flex:none; transition:.2s;
}
.menu-item .dropdown a:hover{ background:var(--primary-tint) !important; color:var(--primary-deep) !important; }
.menu-item .dropdown a:hover::before{ background:var(--primary); transform:scale(1.25); }

/* Laboratorios: dropdown alineado a la derecha (en nav-cta) */
.menu-item.drop-right .dropdown{ left:auto; right:0; transform:translateY(8px); min-width:220px; }
.menu-item.drop-right:hover .dropdown, .menu-item.drop-right.open .dropdown{ transform:translateY(0); }
.nav-cta .menu-item.has-drop > a.btn{ padding-block:13px; }

/* sub-items en menú móvil */
.m-sub{ display:flex; flex-direction:column; margin:2px 0 8px; padding-left:10px; border-left:2px solid var(--line); }
.m-sub a{ padding:11px 14px !important; font-size:.98rem !important; font-weight:600; color:var(--ink-soft); border-radius:10px; }
.m-sub a:hover{ background:var(--primary-tint); color:var(--primary-deep); }

.nav-cta{ display:flex; align-items:center; gap:10px; }
.nav .nav-cta .btn{ padding:12px 17px; font-size:.92rem; }

.burger{ display:none; width:46px;height:46px;border-radius:12px; border:1px solid var(--line); background:#fff; place-items:center; }
.burger svg{ width:22px;height:22px; }

.mobile-menu{
  display:none; position:fixed; inset:0; z-index:80;
  background:rgba(8,30,24,.4); backdrop-filter:blur(4px);
}
.mobile-menu.open{ display:block; }
.mobile-panel{
  position:absolute; top:0; right:0; height:100%; width:min(86%,360px);
  background:#fff; padding:26px; display:flex; flex-direction:column; gap:6px;
  box-shadow:var(--sh-lg); animation:slideIn .3s cubic-bezier(.2,.8,.2,1);
}
@keyframes slideIn{ from{ transform:translateX(100%);} to{ transform:translateX(0);} }
.mobile-panel a{ padding:15px 14px; border-radius:14px; font-weight:600; font-size:1.1rem; }
.mobile-panel a:hover{ background:var(--primary-tint); }
.mobile-panel .mtop{ display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; }
.mobile-panel .close{ width:44px;height:44px;border-radius:12px;border:1px solid var(--line);background:#fff;display:grid;place-items:center; }

/* ---------- Cards & chips ---------- */
.card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--sh-sm); }
.chip{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 14px;border-radius:var(--r-pill);
  font-size:13px;font-weight:600;
  background:var(--primary-soft); color:var(--primary-deep);
}
.chip-line{ background:#fff;border:1px solid var(--line); color:var(--ink-soft); }
.pill-stat{ font-family:var(--mono); }

/* ---------- Footer ---------- */
.footer{ background:var(--ink); color:#c7d6d0; padding-block:72px 30px; }
.footer a{ color:#c7d6d0; opacity:.86; transition:.2s; }
.footer a:hover{ opacity:1; color:#fff; }
.footer-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1.3fr; gap:48px; }
.footer h5{ color:#fff; font-size:.95rem; letter-spacing:.02em; margin-bottom:18px; font-weight:700; }
.footer .fcol ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; font-size:.95rem; }
.footer .fcol ul li{ display:flex; align-items:flex-start; gap:9px; }
.footer .fcol ul li a{ display:inline-flex; align-items:flex-start; gap:9px; }
.footer .fcol svg{ width:16px; height:16px; flex:none; margin-top:2px; opacity:.7; }
.footer .brand .bt b{ color:#fff; }
.footer .brand .bt span{ color:#7e978f; }
.foot-bottom{ border-top:1px solid rgba(255,255,255,.1); margin-top:54px; padding-top:24px; display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; font-size:13px; color:#8aa098; }
.foot-soc{ display:flex; gap:12px; }
.foot-soc a{ width:38px;height:38px;border-radius:11px; background:rgba(255,255,255,.07); display:grid;place-items:center; }
.foot-soc a:hover{ background:var(--primary); }
.foot-soc svg{ width:17px;height:17px; }

/* ---------- WhatsApp flotante ---------- */
.wa-float{ position:fixed; right:20px; bottom:20px; z-index:65; width:54px; height:54px; border-radius:50%; background:#25D366; color:#fff; display:grid; place-items:center; box-shadow:0 10px 26px rgba(37,211,102,.42); transition:.24s cubic-bezier(.2,.7,.3,1); }
.wa-float:hover{ transform:translateY(-3px) scale(1.06); box-shadow:0 16px 34px rgba(37,211,102,.5); color:#fff; }
.wa-float svg{ width:28px; height:28px; }

/* ---------- Overlay en tarjetas de doctor ---------- */
.doc .ph{ position:relative; }
.doc .ph .ov{ position:absolute; left:0; right:0; bottom:0; padding:46px 18px 14px; background:linear-gradient(transparent, rgba(6,78,63,.88)); color:#fff; font-weight:700; font-size:.9rem; display:flex; align-items:center; gap:8px; opacity:0; transform:translateY(10px); transition:.28s cubic-bezier(.2,.7,.3,1); z-index:2; }
.doc .ph .ov svg{ width:15px; height:15px; }
.doc:hover .ph .ov{ opacity:1; transform:none; }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s cubic-bezier(.2,.7,.3,1), transform .7s cubic-bezier(.2,.7,.3,1); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* ---------- Page hero (subpáginas) ---------- */
.page-hero{
  position:relative; overflow:hidden; isolation:isolate; color:#eaf6f1;
  background:
    radial-gradient(130% 130% at 85% -25%, #16a181 0%, transparent 56%),
    linear-gradient(150deg, #0c8a6f 0%, var(--primary-press) 56%, #04382d 100%);
}
.page-hero::before{ content:""; position:absolute; inset:0; z-index:-1;
  background-image:radial-gradient(rgba(255,255,255,.07) 1.2px, transparent 1.2px);
  background-size:26px 26px; opacity:.6; }
.page-hero::after{ content:""; position:absolute; z-index:-1; right:-150px; bottom:-190px;
  width:480px; height:480px; border-radius:50%;
  background:radial-gradient(circle, rgba(184,230,216,.22), transparent 68%); }
.page-hero .wrap{ padding-block:clamp(54px,7vw,92px) clamp(48px,6.5vw,82px); }
.crumbs{ display:flex; align-items:center; gap:9px; font-family:var(--mono); font-size:12.5px; color:#a7d2c6; margin-bottom:22px; }
.page-hero .crumbs a{ color:#d3ece4; }
.page-hero .crumbs a:hover{ color:#fff; }
.crumbs .sep{ opacity:.45; }
.page-hero .eyebrow{ color:#a4ecd3; }
.page-hero h1{ color:#fff; font-size:clamp(2.2rem,4.5vw,3.5rem); max-width:18ch; }
.page-hero .lead{ color:#cfe7df; max-width:56ch; margin-top:18px; }
.page-hero .ph-row{ display:flex; align-items:center; justify-content:space-between; gap:34px; flex-wrap:wrap; }
.page-hero .btn-primary{ background:#fff; color:var(--primary-press); box-shadow:0 14px 32px rgba(0,0,0,.20); }
.page-hero .btn-primary:hover{ background:#eafaf5; color:var(--primary-press); transform:translateY(-2px); box-shadow:0 20px 42px rgba(0,0,0,.26); }

.shead{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; margin-bottom:42px; }
.shead .lead{ max-width:52ch; margin-top:14px; }
.shead.center{ flex-direction:column; align-items:center; text-align:center; }
@media (max-width:760px){ .shead{ flex-direction:column; align-items:flex-start; } }

/* ---------- Reusable service card ---------- */
.svc{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:28px 26px; transition:.26s cubic-bezier(.2,.7,.3,1); position:relative; overflow:hidden; display:block; }
.svc:hover{ transform:translateY(-2px); box-shadow:var(--sh-md); }
.svc .ic{ width:48px;height:48px;border-radius:10px;background:var(--primary-soft);color:var(--primary-deep);display:grid;place-items:center;margin-bottom:18px;transition:.26s; }
.svc:hover .ic{ background:var(--primary); color:#fff; }
.svc .ic svg{ width:28px;height:28px; }
.svc h4{ font-size:1.18rem; margin-bottom:8px; }
.svc p{ font-size:.95rem; color:var(--muted); line-height:1.55; }
.svc .cat{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--primary); margin-bottom:14px; display:block; }
/* ---------- Emergency band (compartido) ---------- */
.eband{ background:radial-gradient(130% 150% at 88% -30%, #12705a 0%, transparent 56%), linear-gradient(150deg, #0a5b48 0%, var(--primary-press) 58%, #053b30 100%); color:#fff; border-radius:var(--r-xl); padding:clamp(34px,4vw,56px); display:grid; grid-template-columns:1.4fr 1fr; gap:34px; align-items:center; position:relative; overflow:hidden; }
.eband::before{ content:""; position:absolute; inset:0; background-image:radial-gradient(rgba(255,255,255,.06) 1.2px, transparent 1.2px); background-size:26px 26px; }
.eband > *{ position:relative; }
.eband h2{ color:#fff; font-size:clamp(1.7rem,3vw,2.5rem); }
.eband p{ color:#d6f0e8; margin-top:14px; max-width:46ch; }
.eband .phone{ text-align:right; }
.eband .phone .lbl{ font-size:12px; letter-spacing:.1em; text-transform:uppercase; font-weight:700; color:#bfe6da; }
.eband .phone .num{ font-size:clamp(2rem,4vw,3rem); font-weight:800; letter-spacing:-.02em; display:block; margin:6px 0 14px; }
@media (max-width:880px){ .eband{ grid-template-columns:1fr; } .eband .phone{ text-align:left; } }

/* ---------- CTA final (compartido) ---------- */
.cta-final{ text-align:center; }
.cta-final .box{ background:radial-gradient(130% 160% at 85% -35%, #12705a 0%, transparent 55%), linear-gradient(150deg, #0a5b48 0%, var(--primary-press) 58%, #04382d 100%); color:#fff; border-radius:var(--r-xl); padding:clamp(48px,6vw,88px); position:relative; overflow:hidden; }
.cta-final .box::before{ content:""; position:absolute; inset:0; background-image:radial-gradient(rgba(255,255,255,.06) 1.2px, transparent 1.2px); background-size:26px 26px; }
.cta-final h2{ color:#fff; position:relative; }
.cta-final p{ color:#aebfb8; max-width:50ch; margin:18px auto 32px; position:relative; }
.cta-final .acts{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; position:relative; z-index:2; }

/* ---------- Utility ---------- */
.grid{ display:grid; gap:24px; }
.flow > * + *{ margin-top:18px; }
.badge-24{ display:inline-flex;align-items:center;gap:8px;padding:6px 13px;border-radius:var(--r-pill);background:var(--emergency-soft);color:var(--emergency);font-weight:700;font-size:13px; }
.badge-24 .dot{ display:none; }
@keyframes pulse{ 0%,100%{ opacity:1;} 50%{ opacity:1;} }

.img-ph{
  background:
    repeating-linear-gradient(45deg, #eef4f1 0 12px, #e8f1ed 12px 24px);
  display:grid;place-items:center; color:var(--muted);
  font-family:var(--mono); font-size:12px; letter-spacing:.08em;
}

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  /* Oculta solo el dropdown de Laboratorios para dar espacio al menú principal */
  .nav-cta .menu-item{ display:none; }
}
@media (max-width:900px){
  .menu, .nav-cta .btn-ghost{ display:none; }
  .burger{ display:grid; }
}
@media (max-width:980px){
  .footer-grid{ grid-template-columns:1fr 1fr; gap:36px; }
  .topbar-left .hide-sm{ display:none; }
}
@media (max-width:560px){
  body{ font-size:16px; }
  .footer-grid{ grid-template-columns:1fr; }
  .topbar .socials{ display:none; }
}
