/* =====================================================================
   Clínica Ortiz Especialistas — main.css
   Sistema de diseño base. Mobile-first. Variables CSS.
   ===================================================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
img,svg,video{display:block;max-width:100%;height:auto}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
ul{list-style:none}
input,textarea,select{font:inherit;color:inherit} 

:root{
  --c-teal:#1DAEA7; --c-teal-dark:#178A85; --c-teal-darker:#0F5D5A;
  --c-mint:#E2F0ED; --c-mint-soft:#F1F8F6;
  --c-coral:#CE4C57; --c-coral-dark:#A83A44;
  --c-graphite:#293A37; --c-graphite-soft:#3A4F4B;
  --c-text:#293A37; --c-text-soft:#5C6B68; --c-muted:#8A9794;
  --c-border:#D9E3E1; --c-bg:#FFFFFF; --c-bg-alt:#F6F8F8; --c-bg-dark:#1A2624;
  --f-display:'Fraunces',Georgia,'Times New Roman',serif;
  --f-sans:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Arial,sans-serif;
  --fs-xs:clamp(0.75rem,0.72rem + 0.15vw,0.825rem);
  --fs-sm:clamp(0.875rem,0.84rem + 0.2vw,0.95rem);
  --fs-base:1rem;
  --fs-lg:clamp(1.05rem,1rem + 0.3vw,1.15rem);
  --fs-xl:clamp(1.25rem,1.15rem + 0.6vw,1.5rem);
  --fs-2xl:clamp(1.5rem,1.3rem + 1.2vw,2.1rem);
  --fs-3xl:clamp(1.9rem,1.5rem + 2vw,3rem);
  --fs-4xl:clamp(2.4rem,1.8rem + 3vw,4rem);
  --s-1:.25rem; --s-2:.5rem; --s-3:.75rem; --s-4:1rem;
  --s-5:1.5rem; --s-6:2rem; --s-7:3rem; --s-8:4rem; --s-9:5rem; --s-10:7rem;
  --container-w:1180px; --container-px:clamp(1rem,2vw,1.75rem);
  --radius-sm:6px; --radius:12px; --radius-lg:20px; --radius-pill:999px;
  --shadow-sm:0 1px 2px rgba(41,58,55,.06);
  --shadow:0 6px 24px rgba(41,58,55,.08);
  --shadow-lg:0 18px 48px rgba(41,58,55,.12); 
  --ease:cubic-bezier(.2,.7,.2,1); --t-fast:140ms; --t-base:240ms;
}

html{font-family:var(--f-sans);font-size:16px;line-height:1.6;color:var(--c-text);background:var(--c-bg);-webkit-font-smoothing:antialiased}
body{min-height:100vh;display:flex;flex-direction:column}
h1,h2,h3,h4{font-family:var(--f-display);font-weight:500;line-height:1.15;letter-spacing:-0.02em;color:var(--c-graphite)}
h1{font-size:var(--fs-4xl);font-weight:600}
h2{font-size:var(--fs-3xl)}
h3{font-size:var(--fs-2xl)}
h4{font-size:var(--fs-xl)}
p{max-width:62ch}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--c-teal);outline-offset:3px;border-radius:4px}
.eyebrow{display:inline-block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.22em;color:var(--c-teal-dark)}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--c-graphite);color:#fff;padding:.75rem 1rem;z-index:1000}
.skip-link:focus{left:0}

.container{width:100%;max-width:var(--container-w);margin-inline:auto;padding-inline:var(--container-px)}
.site-main{flex:1}
section{padding-block:var(--s-9)}
@media (max-width:640px){section{padding-block:var(--s-7)}}

.site-header{position:sticky;top:0;z-index:50;background:var(--c-mint);border-bottom:1px solid rgba(29,174,167,.18);backdrop-filter:saturate(120%) blur(8px)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:var(--s-5);min-height:140px;padding-block:var(--s-2)}
.site-header__brand{display:inline-flex;align-items:center}
.site-header__logo{height:120px;width:auto;object-fit:contain;display:block}
@media (max-width:959px){
  .site-header__inner{min-height:104px}
  .site-header__logo{height:80px}
}
@media (max-width:480px){
  .site-header__logo{height:64px}
}
.site-header__toggle{display:inline-flex;flex-direction:column;gap:5px;width:44px;height:44px;align-items:center;justify-content:center}
.site-header__toggle span{display:block;width:24px;height:2px;background:var(--c-graphite);border-radius:1px;transition:transform var(--t-base) var(--ease),opacity var(--t-fast)}
.site-header__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.site-header__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.site-header__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.site-nav{display:none;align-items:center;gap:var(--s-5)}
.site-nav__link{padding:.5rem .25rem;color:var(--c-graphite);font-weight:500;position:relative}
.site-nav__link.is-active{color:var(--c-teal-dark)}
.site-nav__link:hover{color:var(--c-teal-dark)}
.site-nav__cta{margin-left:var(--s-2)}

@media (min-width:960px){.site-header__toggle{display:none}.site-nav{display:flex}}
@media (max-width:959px){
  .site-nav{position:absolute;inset:100% 0 auto 0;background:var(--c-mint);border-bottom:1px solid rgba(29,174,167,.18);flex-direction:column;align-items:stretch;padding:var(--s-4) var(--container-px) var(--s-5);gap:var(--s-2);transform:translateY(-12px);opacity:0;pointer-events:none;transition:transform var(--t-base) var(--ease),opacity var(--t-base) var(--ease)}
  .site-nav.is-open{transform:none;opacity:1;pointer-events:auto;display:flex}
  .site-nav__link{padding:.75rem 0;border-bottom:1px solid var(--c-border)}
  .site-nav__cta{margin:.5rem 0 0;text-align:center}
}

.site-header--oscuro{background:var(--c-graphite);border-bottom-color:rgba(255,255,255,.08)}
.site-header--oscuro .site-nav__link{color:#fff}
.site-header--oscuro .site-nav__link.is-active{color:var(--c-mint)}
.site-header--oscuro .site-header__toggle span{background:#fff}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 1.4rem;border-radius:var(--radius-pill);font-weight:600;font-size:.95rem;line-height:1;transition:background var(--t-fast),color var(--t-fast),transform var(--t-fast);white-space:nowrap}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:none}
.btn--primary{background:var(--c-teal);color:#fff}
.btn--primary:hover{background:var(--c-teal-dark)}
.btn--coral{background:var(--c-coral);color:#fff}
.btn--coral:hover{background:var(--c-coral-dark)}
.btn--ghost{background:transparent;color:var(--c-graphite);border:1px solid var(--c-border)}
.btn--ghost:hover{border-color:var(--c-teal);color:var(--c-teal-dark)}
.btn--block{width:100%}

.hero{position:relative;background:var(--c-graphite);color:#fff;overflow:hidden;padding-block:clamp(4rem,8vw,7rem) clamp(4rem,8vw,7rem)}
.hero__bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero__bg img{width:100%;height:100%;object-fit:cover;opacity:.35;filter:saturate(.85)}
.hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,93,90,.85) 0%,rgba(26,38,36,.7) 60%,rgba(26,38,36,.95) 100%)}
.hero__inner{position:relative;z-index:1;max-width:760px}
.hero h1{color:#fff;font-size:var(--fs-4xl);font-weight:600;margin-block:.6rem 1.2rem}
.hero h1 em{font-style:normal;color:var(--c-mint)}
.hero__lead{font-size:var(--fs-lg);color:#D8E5E3;margin-bottom:2rem;max-width:58ch}
.hero__actions{display:flex;flex-wrap:wrap;gap:.85rem}
.hero__strip{position:relative;z-index:1;margin-top:3rem;display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;border-top:1px solid rgba(255,255,255,.15);padding-top:1.75rem}
.hero__strip-item .v{font-family:var(--f-display);font-size:var(--fs-2xl);color:#fff}
.hero__strip-item .l{font-size:.8rem;color:#A8BFBC;text-transform:uppercase;letter-spacing:.18em}
@media (min-width:768px){.hero__strip{grid-template-columns:repeat(4,1fr)}}

.section-head{max-width:760px;margin:0 auto var(--s-7);text-align:center}
.section-head h2{margin-block:.5rem .75rem}
.grid-cards{display:grid;gap:var(--s-5);grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.card{background:#fff;border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:var(--s-5);transition:transform var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease),border-color var(--t-fast)}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:transparent}
.card__icon{width:48px;height:48px;border-radius:14px;background:var(--c-mint);display:inline-flex;align-items:center;justify-content:center;color:var(--c-teal-darker);margin-bottom:.85rem;font-family:var(--f-display);font-weight:600;font-size:1.4rem}
.card__title{font-size:var(--fs-xl);margin-bottom:.4rem}
.card__text{color:var(--c-text-soft);font-size:.95rem}
.card__link{display:inline-block;margin-top:1rem;color:var(--c-teal-dark);font-weight:600}
.card__link::after{content:" →"}
.card--proximamente{opacity:.7}
.card--proximamente .card__title::after{content:" · próximamente";color:var(--c-muted);font-weight:400;font-size:.75rem;text-transform:uppercase;letter-spacing:.18em}

.por-que{background:var(--c-mint-soft)}
.por-que__grid{display:grid;gap:var(--s-5);grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.por-que__item .n{font-family:var(--f-display);font-size:3rem;color:var(--c-teal);line-height:1;display:block;margin-bottom:.5rem}
.por-que__item .t{font-weight:600;font-size:var(--fs-lg);margin-bottom:.25rem;color:var(--c-graphite)}
.por-que__item .d{color:var(--c-text-soft);font-size:.95rem}

.doctor-feat{background:var(--c-graphite);color:#fff;border-radius:var(--radius-lg);overflow:hidden}
.doctor-feat__grid{display:grid;grid-template-columns:1fr;gap:0}
.doctor-feat__media img{width:100%;height:100%;object-fit:cover;min-height:340px}
.doctor-feat__body{padding:clamp(1.5rem,4vw,3rem)}
.doctor-feat__body h2{color:#fff;font-size:var(--fs-3xl);margin-bottom:.75rem}
.doctor-feat__body .eyebrow{color:var(--c-mint)}
.doctor-feat__body p{color:#CFDDD9;margin-block:1rem;max-width:50ch}
.doctor-feat__meta{margin-top:1rem;font-size:.85rem;color:#9FB1AD}
@media (min-width:900px){.doctor-feat__grid{grid-template-columns:5fr 7fr}}

.form-lead{display:grid;gap:var(--s-4);background:#fff;border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:clamp(1.25rem,3vw,2rem);box-shadow:var(--shadow-sm)}
.form-lead__row{display:grid;gap:var(--s-4)}
@media (min-width:640px){.form-lead__row--2{grid-template-columns:1fr 1fr}}
.form-lead label{font-weight:600;font-size:.85rem;color:var(--c-graphite);display:block;margin-bottom:.35rem}
.form-lead input,.form-lead select,.form-lead textarea{width:100%;padding:.85rem 1rem;border:1px solid var(--c-border);border-radius:var(--radius);background:#fff;color:var(--c-text);transition:border-color var(--t-fast),box-shadow var(--t-fast)}
.form-lead input:focus,.form-lead select:focus,.form-lead textarea:focus{border-color:var(--c-teal);box-shadow:0 0 0 3px rgba(29,174,167,.15);outline:none}
.form-lead textarea{min-height:120px;resize:vertical}
.form-lead__legal{font-size:.78rem;color:var(--c-text-soft);line-height:1.45}
.form-lead__legal a{color:var(--c-teal-dark);text-decoration:underline}
.form-lead__check{display:flex;gap:.6rem;align-items:flex-start}
.form-lead__check input{width:18px;height:18px;flex:none;margin-top:.15rem}
.form-status{padding:.85rem 1rem;border-radius:var(--radius);font-size:.9rem;display:none}
.form-status.is-ok{display:block;background:var(--c-mint);color:var(--c-teal-darker)}
.form-status.is-err{display:block;background:#FBE6E8;color:var(--c-coral-dark)}

.cta-band{background:var(--c-teal);color:#fff;text-align:center;border-radius:var(--radius-lg)}
.cta-band__inner{padding:clamp(2rem,4vw,3rem)}
.cta-band h2{color:#fff;margin-bottom:.5rem}
.cta-band p{color:#E7F5F4;margin:.5rem auto 1.5rem;max-width:55ch}
.cta-band .btn{background:#fff;color:var(--c-teal-dark)}
.cta-band .btn:hover{background:var(--c-mint)}

.site-footer{background:var(--c-graphite);color:#CFDDD9;margin-top:var(--s-9)}
.site-footer__grid{display:grid;gap:var(--s-6);padding-block:var(--s-8) var(--s-7);grid-template-columns:1fr}
@media (min-width:720px){.site-footer__grid{grid-template-columns:1.4fr 1fr 1fr 1fr}}
.site-footer__logo{height:84px;width:auto;margin-bottom:1.25rem;object-fit:contain;max-width:100%}
.site-footer__tagline{color:#9FB1AD;max-width:34ch}
.site-footer__social{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}
.site-footer__social a{display:inline-block;padding:.35rem .75rem;border:1px solid rgba(255,255,255,.18);border-radius:var(--radius-pill);font-size:.8rem;color:#fff}
.site-footer__social a:hover{background:rgba(255,255,255,.08)}
.site-footer__title{color:#fff;font-family:var(--f-sans);font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;margin-bottom:.85rem}
.site-footer__addr p{margin-bottom:.4rem;font-size:.95rem}
.site-footer__addr a{color:#fff;text-decoration:underline;text-decoration-color:rgba(255,255,255,.25);text-underline-offset:3px}
.site-footer__links li{margin-bottom:.4rem;font-size:.95rem}
.site-footer__nota{margin-top:1rem;font-size:.85rem;color:#9FB1AD;font-style:italic}
.site-footer__legal{background:#16201E;padding-block:1.25rem;color:#9FB1AD;font-size:.78rem;line-height:1.55}
.site-footer__legal p{margin-bottom:.35rem;max-width:none}
.site-footer__disclaimer{color:#7D908C}
.site-footer__copy{color:#7D908C}

.floating-wa{position:fixed;right:1rem;bottom:1rem;z-index:60;display:inline-flex;align-items:center;gap:.5rem;background:#25D366;color:#fff;padding:.7rem 1rem;border-radius:var(--radius-pill);box-shadow:var(--shadow-lg);font-weight:600;font-size:.9rem;transition:transform var(--t-fast),background var(--t-fast)}
.floating-wa:hover{background:#1FB957;transform:translateY(-2px)}
@media (max-width:480px){.floating-wa span{display:none}.floating-wa{padding:.7rem}}

/* Prose para páginas de contenido (legales, institucional) */
.prose h2{margin-top:2.2rem;margin-bottom:.6rem;font-size:var(--fs-xl)}
.prose h3{margin-top:1.5rem;margin-bottom:.4rem;font-size:var(--fs-lg)}
.prose p,.prose ul,.prose ol{margin-bottom:1rem;color:var(--c-text-soft);line-height:1.7}
.prose ul,.prose ol{padding-left:1.5rem}
.prose li{margin-bottom:.35rem}
.prose a{color:var(--c-teal-dark);text-decoration:underline;text-underline-offset:3px}

/* Páginas institucionales */
.valor-card{background:#fff;border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:var(--s-5);transition:transform var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease)}
.valor-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.valor-card .nombre{font-family:var(--f-display);font-size:var(--fs-xl);color:var(--c-teal-darker);margin-bottom:.35rem;letter-spacing:-0.01em}
.valor-card .desc{color:var(--c-text-soft);font-size:.95rem;line-height:1.6}

/* /clinica — Hero institucional */
.hero--inst h1{font-size:var(--fs-3xl);max-width:18ch}
.hero--inst .hero__lead{font-size:var(--fs-base);max-width:64ch;color:#CFDDD9;line-height:1.7}

/* /clinica — Misión + Visión duo */
.duo-grid{display:grid;gap:var(--s-5);grid-template-columns:1fr}
@media (min-width:880px){.duo-grid{grid-template-columns:1fr 1fr}}
.duo-card{background:#fff;border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:clamp(1.5rem,3vw,2.5rem)}
.duo-card--mint{background:var(--c-mint);border-color:transparent}
.duo-card__title{font-size:var(--fs-2xl);margin-block:.5rem 1rem;color:var(--c-graphite)}
.duo-card p{color:var(--c-text-soft);line-height:1.7;max-width:none}

/* /clinica — Propósito destacado */
.proposito-section{padding-block:clamp(4rem,8vw,6rem)}
.proposito{max-width:920px;margin:0 auto;text-align:center;padding:clamp(2rem,4vw,3rem);background:#fff;border-radius:var(--radius-lg);border-left:6px solid var(--c-teal);box-shadow:var(--shadow-sm)}
.proposito__texto{font-family:var(--f-display);font-size:clamp(1.25rem,1.05rem + 1vw,1.7rem);color:var(--c-graphite);line-height:1.45;margin-top:1rem;max-width:none}

/* /clinica — Grid común valores y principios (3 columnas en desktop) */
.valores-grid{display:grid;gap:var(--s-5);grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}

/* /clinica — Políticas (3 cards más altas con icono) */
.politicas-grid{display:grid;gap:var(--s-5);grid-template-columns:1fr}
@media (min-width:880px){.politicas-grid{grid-template-columns:repeat(3,1fr)}}
.politica-card{background:#fff;border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:clamp(1.5rem,3vw,2rem);display:flex;flex-direction:column;gap:.75rem}
.politica-card__icon{width:52px;height:52px;border-radius:14px;background:var(--c-mint);color:var(--c-teal-darker);display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:600;font-family:var(--f-display)}
.politica-card__icon--coral{background:#FBE6E8;color:var(--c-coral-dark)}
.politica-card__title{font-size:var(--fs-lg);color:var(--c-graphite);margin-bottom:.25rem}
.politica-card p{color:var(--c-text-soft);font-size:.95rem;line-height:1.65;max-width:none}

/* /clinica — Objetivos estratégicos */
.objetivos-grid{display:grid;gap:var(--s-4);grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.objetivo-card{background:#fff;border:1px solid var(--c-border);border-radius:var(--radius);padding:1.25rem 1.5rem;transition:border-color var(--t-fast)}
.objetivo-card:hover{border-color:var(--c-teal)}
.objetivo-card__eje{font-family:var(--f-sans);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--c-teal-dark);margin-bottom:.5rem}
.objetivo-card__txt{color:var(--c-text-soft);font-size:.95rem;line-height:1.55;max-width:none}

/* /clinica — Lista numerada de compromisos */
.compromisos-list{list-style:none;counter-reset:compromiso;padding:0}
.compromisos-list li{position:relative;padding:1.1rem 1.25rem 1.1rem 4rem;background:#fff;border:1px solid var(--c-border);border-radius:var(--radius);margin-bottom:.75rem;color:var(--c-graphite);font-size:1rem;line-height:1.55;counter-increment:compromiso;transition:border-color var(--t-fast),transform var(--t-fast)}
.compromisos-list li::before{content:counter(compromiso,decimal-leading-zero);position:absolute;left:1.1rem;top:50%;transform:translateY(-50%);font-family:var(--f-display);font-weight:600;font-size:1.4rem;color:var(--c-teal);min-width:2.2rem}
.compromisos-list li:hover{border-color:var(--c-teal);transform:translateX(2px)}

/* ===== Page hero genérico (sin imagen, fondo mint suave) ===== */
.page-hero{background:var(--c-mint-soft);padding-block:clamp(3rem,6vw,5rem) clamp(2.5rem,5vw,4rem);border-bottom:1px solid rgba(29,174,167,.12)}
.page-hero__inner{max-width:760px}
.page-hero h1{font-size:var(--fs-3xl);margin-block:.5rem .85rem;max-width:22ch}
.page-hero__lead{font-size:var(--fs-lg);color:var(--c-text-soft);max-width:60ch;line-height:1.6}

/* ===== Breadcrumbs ===== */
.breadcrumbs{font-size:.85rem;color:var(--c-text-soft);margin-bottom:1.25rem;display:flex;flex-wrap:wrap;align-items:center;gap:.4rem}
.breadcrumbs a{color:var(--c-teal-dark);font-weight:500}
.breadcrumbs a:hover{text-decoration:underline}
.breadcrumbs span[aria-hidden]{color:var(--c-muted)}
.breadcrumbs span[aria-current]{color:var(--c-graphite);font-weight:500}
.breadcrumbs--light a{color:var(--c-mint)}
.breadcrumbs--light span[aria-hidden],.breadcrumbs--light span[aria-current]{color:rgba(255,255,255,.8)}

/* ===== Aviso "próximamente" en página detalle ===== */
.aviso-proximamente{margin-top:1.5rem;padding:1rem 1.25rem;background:#FFF7E6;border:1px solid #F2D58A;border-radius:var(--radius);color:#7A5800;font-size:.95rem;max-width:60ch}
.aviso-proximamente strong{color:#5A4100}

/* ===== Especialidades — otras (cross-link footer) ===== */
.otras-grid{display:grid;gap:var(--s-3);grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.otra-card{display:flex;align-items:center;gap:.85rem;padding:1rem 1.25rem;background:#fff;border:1px solid var(--c-border);border-radius:var(--radius);color:var(--c-graphite);font-weight:500;font-size:.95rem;transition:border-color var(--t-fast),transform var(--t-fast)}
.otra-card:hover{border-color:var(--c-teal);transform:translateY(-2px)}
.otra-card__icon{width:36px;height:36px;border-radius:10px;background:var(--c-mint);color:var(--c-teal-darker);display:inline-flex;align-items:center;justify-content:center;font-family:var(--f-display);font-weight:600;flex:none}

/* ===== Medicos — grid y card ===== */
.medicos-grid{display:grid;gap:var(--s-5);grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.medicos-grid--lg{grid-template-columns:1fr}
@media (min-width:880px){.medicos-grid--lg{grid-template-columns:repeat(auto-fit,minmax(420px,1fr))}}

.medico-card{background:#fff;border:1px solid var(--c-border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;transition:transform var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease)}
.medico-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.medico-card__media{aspect-ratio:4/5;overflow:hidden;background:var(--c-graphite-soft)}
.medico-card__media img{width:100%;height:100%;object-fit:cover}
.medico-card__body{padding:var(--s-5);display:flex;flex-direction:column;gap:.35rem}
.medico-card__nombre{font-size:var(--fs-xl);color:var(--c-graphite);margin:.25rem 0}
.medico-card__bio{color:var(--c-text-soft);font-size:.95rem;line-height:1.55;margin-block:.25rem .5rem}
.medico-card__meta{font-size:.78rem;color:var(--c-muted);text-transform:uppercase;letter-spacing:.12em;margin-top:.5rem}
.medico-card--lg .medico-card__media{aspect-ratio:1/1}
@media (min-width:880px){
  .medico-card--lg{flex-direction:row;align-items:stretch}
  .medico-card--lg .medico-card__media{flex:0 0 44%;aspect-ratio:auto;min-height:340px}
  .medico-card--lg .medico-card__body{flex:1;justify-content:center;padding:clamp(1.5rem,3vw,2.25rem)}
}

/* ===== Médico hero (página perfil) ===== */
.medico-hero{background:var(--c-graphite);color:#fff;padding-block:clamp(3rem,6vw,5rem)}
.medico-hero__grid{display:grid;gap:var(--s-6);grid-template-columns:1fr;align-items:center}
@media (min-width:900px){.medico-hero__grid{grid-template-columns:5fr 7fr}}
.medico-hero__media{border-radius:var(--radius-lg);overflow:hidden;background:#0F2421;aspect-ratio:4/5;max-height:560px}
.medico-hero__media img{width:100%;height:100%;object-fit:cover}
.medico-hero h1{color:#fff;font-size:var(--fs-4xl);margin-block:.5rem 1rem}
.medico-hero__bio{font-size:var(--fs-lg);color:#CFDDD9;line-height:1.65;max-width:55ch;margin-bottom:1.5rem}
.medico-hero__creds{list-style:none;padding:0;margin-block:1rem 1.5rem;display:flex;flex-direction:column;gap:.45rem}
.medico-hero__creds li{font-size:.95rem;color:#CFDDD9}
.medico-hero__creds strong{color:#fff;font-weight:600}

/* ===== Contacto — grid de 2 columnas (info + form) ===== */
.contacto-grid{display:grid;gap:var(--s-7);grid-template-columns:1fr;align-items:start}
@media (min-width:960px){.contacto-grid{grid-template-columns:5fr 7fr}}
.contacto-info{display:flex;flex-direction:column;gap:var(--s-5)}
.contacto-info__item p{margin-top:.25rem;font-size:1.05rem;color:var(--c-graphite);max-width:none}
.contacto-info__item a{color:var(--c-teal-dark);font-weight:500;text-decoration:underline;text-underline-offset:3px}
.contacto-form{padding:0}

/* ===== Mapa ===== */
.mapa-wrap{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.mapa-wrap iframe{display:block;width:100%}

/* ===== /clinica — Tabla de servicios habilitados REPS ===== */
.habilitaciones-tabla{display:flex;flex-direction:column;gap:var(--s-6);max-width:980px;margin:0 auto}
.habilitaciones-grupo{background:#fff;border:1px solid var(--c-border);border-radius:var(--radius-lg);overflow:hidden}
.habilitaciones-grupo__titulo{font-family:var(--f-sans);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--c-teal-darker);background:var(--c-mint);padding:.85rem 1.25rem;margin:0;border-bottom:1px solid rgba(29,174,167,.18)}
.habilitaciones-rows{display:flex;flex-direction:column}
.habilitaciones-row{display:grid;grid-template-columns:60px 1fr 130px 110px;gap:1rem;align-items:center;padding:.85rem 1.25rem;border-bottom:1px solid var(--c-border);font-size:.95rem}
.habilitaciones-row:last-child{border-bottom:0}
.habilitaciones-row__cod{font-family:var(--f-display);font-weight:600;color:var(--c-teal-dark);font-size:1rem}
.habilitaciones-row__nombre{color:var(--c-graphite);font-weight:500}
.habilitaciones-row__dhss{color:var(--c-text-soft);font-size:.85rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.habilitaciones-row__estado{text-align:right}
.habilitaciones-row--prox{opacity:.7;background:var(--c-bg-alt)}
.habilitaciones-row--prox .habilitaciones-row__cod{color:var(--c-muted)}

@media (max-width:720px){
  .habilitaciones-row{grid-template-columns:50px 1fr;gap:.5rem;padding:.85rem 1rem}
  .habilitaciones-row__dhss,.habilitaciones-row__estado{grid-column:2;text-align:left;margin-top:.2rem}
}

.badge{display:inline-block;padding:.25rem .65rem;border-radius:var(--radius-pill);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;line-height:1}
.badge--ok{background:rgba(29,174,167,.15);color:var(--c-teal-darker)}
.badge--prox{background:#FFF7E6;color:#7A5800;border:1px solid #F2D58A}

.habilitaciones-foot{font-size:.85rem;text-align:center;margin-top:var(--s-5);max-width:680px;margin-inline:auto}

.text-center{text-align:center}
.muted{color:var(--c-text-soft)}
.bg-alt{background:var(--c-bg-alt)}
.hide-mobile{display:none}
@media (min-width:720px){.hide-mobile{display:initial}.hide-desktop{display:none}}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}
