/* ============================================================
   Gestión en Salud — Blog
   Mismo sistema visual que eduardocontreras.cl
   (Tailwind + Spectral/Manrope + navy/dorado). Este archivo
   replica las clases de marca del sitio y agrega lo del blog.
   ============================================================ */

:root{
  --navy-900:#0B1B33;
  --navy-800:#102744;
  --navy-700:#163356;
  --navy-600:#1E4575;
  --navy-500:#2B5A92;
  --gold:#C49A3C;
  --gold-deep:#A67C1F;
  --gold-700:#8C6A1E;
  --gold-300:#E7CF93;
  --ink:#0B1B33;
  --paper:#F7F4EE;
  --whats:#25D366;
  --read:720px;
}

html,body{ font-family:'Manrope', ui-sans-serif, system-ui, sans-serif; color:#0B1B33; background:#fff; }
body{ -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden; margin:0; }
::selection{ background:#163356; color:#fff; }
h1,h2,h3,h4{ font-family:'Spectral', ui-serif, Georgia, serif; }
img{ max-width:100%; display:block; }

/* ---------- Brand lockup (idéntico al sitio) ---------- */
.brand{ display:inline-flex; align-items:center; gap:13px; text-decoration:none; }
.brand-mark{ width:52px; height:52px; border-radius:13px; background:#fff; padding:6px; box-shadow:0 8px 18px -8px rgba(0,0,0,.35); display:block; flex:none; }
.brand-mark img{ width:100%; height:100%; object-fit:contain; display:block; }
.brand-div{ height:30px; width:1px; background:rgba(255,255,255,.20); }
.brand-txt{ display:flex; flex-direction:column; line-height:1.05; }
.brand-txt strong{ font-family:'Spectral',serif; font-weight:600; font-size:19px; letter-spacing:.01em; }
.brand-txt span{ font-size:10.5px; opacity:.78; letter-spacing:.10em; font-weight:600; margin-top:3px; text-transform:uppercase; }

/* ---------- Buttons (idénticos al sitio) ---------- */
.btn-gold{
  background:linear-gradient(180deg, #ddbf72, #c49a3c 55%, #a67c1f);
  color:#0B1B33;
  box-shadow:0 1px 0 rgba(255,255,255,.45) inset, 0 10px 24px -8px rgba(166,124,31,.55);
  transition:transform .25s cubic-bezier(.2,.7,.2,1), box-shadow .25s, filter .25s; will-change:transform;
}
.btn-gold:hover{ transform:scale(1.03); filter:brightness(1.04); box-shadow:0 0 0 6px rgba(196,154,60,.18), 0 18px 40px -12px rgba(166,124,31,.6); }
.btn-gold:active{ transform:scale(.99); }
.btn-whats{
  background:linear-gradient(180deg, #2bdc6e, #1aa84f); color:#fff;
  box-shadow:0 1px 0 rgba(255,255,255,.25) inset, 0 10px 24px -8px rgba(37,211,102,.5);
  transition:transform .25s cubic-bezier(.2,.7,.2,1), box-shadow .25s, filter .25s;
}
.btn-whats:hover{ transform:scale(1.03); filter:brightness(1.04); box-shadow:0 0 0 6px rgba(37,211,102,.16), 0 18px 40px -12px rgba(37,211,102,.55); }
.btn-ghost{ transition:transform .25s, background .25s, border-color .25s; }
.btn-ghost:hover{ transform:scale(1.03); background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.55); }
.btn-outline{ transition:transform .25s, background .25s, border-color .25s; }
.btn-outline:hover{ transform:scale(1.02); background:rgba(22,51,86,.05); }

/* ---------- Eyebrow / pills (idénticos al sitio) ---------- */
.eyebrow{ font-size:13px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:#A67C1F; }
.eyebrow.on-navy{ color:#D8B86A; }
.pill-gold{ display:inline-flex; align-items:center; gap:.5rem; padding:6px 12px; border-radius:9999px; background:rgba(196,154,60,.12); color:#8C6A1E; font-weight:600; font-size:13px; border:1px solid rgba(196,154,60,.30); }
.pill-dark{ display:inline-flex; align-items:center; gap:.5rem; padding:6px 12px; border-radius:9999px; background:rgba(255,255,255,.07); color:#fff; font-weight:600; font-size:13px; border:1px solid rgba(255,255,255,.16); }

/* ---------- Cards / glass / textures (idénticos al sitio) ---------- */
.card{ position:relative; transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s, border-color .35s; will-change:transform; }
.card::before{ content:""; position:absolute; left:0; top:14px; bottom:14px; width:3px; border-radius:3px; background:var(--gold); transform:scaleY(0); transform-origin:top; transition:transform .4s cubic-bezier(.2,.7,.2,1); }
.card:hover{ transform:translateY(-6px); }
.card:hover::before{ transform:scaleY(1); }
.card.dark:hover{ box-shadow:0 24px 60px -18px rgba(0,0,0,.5), 0 0 0 1px rgba(216,184,106,.30) inset; }
.card.light:hover{ box-shadow:0 24px 60px -18px rgba(11,27,51,.20); }
.glass{ background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04)); backdrop-filter:blur(12px) saturate(140%); -webkit-backdrop-filter:blur(12px) saturate(140%); border:1px solid rgba(255,255,255,.16); }
.grain{ position:absolute; inset:0; pointer-events:none; opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>"); }
.accent-italic{ font-family:'Spectral', serif; font-style:italic; font-weight:500; }
.bar{ height:4px; width:56px; border-radius:4px; background:linear-gradient(90deg, #163356, #2B5A92 50%, #C49A3C); }
.ic{ width:24px; height:24px; stroke-width:1.6; stroke:currentColor; fill:none; stroke-linecap:round; stroke-linejoin:round; }

/* ---------- Header (sólido navy en el blog) ---------- */
.blog-header{ position:sticky; top:0; z-index:40; background:rgba(11,27,51,.92); backdrop-filter:blur(10px); border-bottom:1px solid rgba(255,255,255,.07); }
.blog-header .wrap{ max-width:80rem; margin:0 auto; padding:14px 20px; display:flex; align-items:center; justify-content:space-between; gap:16px; }
@media (min-width:1024px){ .blog-header .wrap{ padding:14px 40px; } }
.nav-links{ display:none; align-items:center; gap:8px; }
@media (min-width:768px){ .nav-links{ display:flex; } }
.mobile-home-btn{ display:inline-flex; align-items:center; color:rgba(255,255,255,.95); font-weight:600; font-size:12px; padding:6px 14px; border-radius:9999px; border:1px solid rgba(255,255,255,.3); text-decoration:none; }
@media (min-width:768px){ .mobile-home-btn{ display:none; } }
.nav-links a.txt{ color:rgba(255,255,255,.9); font-weight:600; font-size:14px; padding:8px 14px; border-radius:9999px; text-decoration:none; transition:background .2s,color .2s; }
.nav-links a.txt:hover{ background:rgba(255,255,255,.08); }
.nav-links a.txt.active{ color:#E7CF93; }

/* ---------- Wrap helper ---------- */
.wrap{ width:100%; max-width:80rem; margin:0 auto; padding:0 20px; }
@media (min-width:1024px){ .wrap{ padding:0 40px; } }

/* ---------- Blog hero ---------- */
.blog-hero{ position:relative; color:#fff; overflow:hidden;
  background:
    radial-gradient(ellipse 80% 60% at 86% 6%, rgba(216,184,106,.20), transparent 60%),
    radial-gradient(ellipse 72% 52% at 8% 94%, rgba(78,123,176,.32), transparent 60%),
    radial-gradient(ellipse 120% 120% at 50% 0%, #1b3e6e 0%, #102744 48%, #0b1b33 100%);
}
.blog-hero .inner{ position:relative; z-index:1; max-width:56rem; padding:60px 0 72px; }
.blog-hero h1{ font-size:clamp(34px,5vw,56px); line-height:1.1; letter-spacing:-.02em; font-weight:800; margin:18px 0 16px; }
.blog-hero p{ font-size:clamp(17px,2vw,20px); color:rgba(255,255,255,.82); max-width:40rem; line-height:1.6; margin:0; }
.hero-stats{ display:flex; flex-wrap:wrap; gap:28px 48px; margin-top:34px; }
.hero-stats b{ display:block; font-size:30px; font-weight:800; color:#fff; letter-spacing:-.02em; font-family:'Manrope',sans-serif; }
.hero-stats span{ font-size:13px; color:rgba(255,255,255,.6); }
.wave{ display:block; width:100%; height:60px; position:absolute; bottom:0; left:0; right:0; }

/* ---------- Listado: featured + grid ---------- */
.blog-main{ background:var(--paper); }
.featured{ display:grid; grid-template-columns:1.1fr .9fr; background:#fff; border:1px solid rgba(11,27,51,.07); border-radius:26px; overflow:hidden; box-shadow:0 1px 2px rgba(11,27,51,.04), 0 30px 60px -24px rgba(11,27,51,.20); text-decoration:none; color:inherit; }
.featured .media{ position:relative; min-height:330px; padding:34px; color:#fff; display:flex; flex-direction:column; justify-content:space-between; background:linear-gradient(155deg,#1b3e6e,#102744 55%,#0b1b33); }
.featured .media .num{ position:relative; z-index:1; font-family:'Spectral',serif; font-weight:700; font-size:80px; color:rgba(255,255,255,.14); line-height:.85; }
.featured .body{ padding:38px; display:flex; flex-direction:column; }
.featured .body h3{ font-size:28px; line-height:1.18; font-weight:700; color:var(--ink); margin:14px 0 12px; }
.featured .body p{ color:#475569; line-height:1.6; margin:0 0 22px; }

.post-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.post-card{ display:flex; flex-direction:column; background:#fff; border:1px solid rgba(11,27,51,.07); border-radius:20px; overflow:hidden; box-shadow:0 1px 2px rgba(11,27,51,.04), 0 12px 32px -8px rgba(11,27,51,.10); text-decoration:none; color:inherit; }
.post-card .top{ position:relative; height:108px; padding:20px 22px 0; display:flex; align-items:flex-start; justify-content:space-between; background:linear-gradient(135deg,#f6f2e8,#efe6d0); border-bottom:1px solid rgba(11,27,51,.05); }
.post-card .top .num{ font-family:'Spectral',serif; font-weight:700; font-size:48px; color:var(--navy-900); opacity:.13; line-height:.8; }
.post-card .body{ padding:18px 22px 22px; display:flex; flex-direction:column; flex:1; }
.post-card h3{ font-size:18.5px; line-height:1.25; font-weight:700; color:var(--ink); margin:10px 0 8px; }
.post-card .body p{ font-size:14px; color:#64748b; line-height:1.55; margin:0 0 16px; }
.post-card .foot{ margin-top:auto; display:flex; align-items:center; justify-content:space-between; }
.post-card .meta{ font-size:12.5px; color:#94a3b8; }

.tag{ display:inline-flex; align-items:center; font-size:11.5px; font-weight:700; letter-spacing:.02em; padding:5px 11px; border-radius:9999px; background:rgba(196,154,60,.12); color:#8C6A1E; border:1px solid rgba(196,154,60,.28); }
.tag.light{ background:rgba(255,255,255,.12); color:#E7CF93; border-color:rgba(255,255,255,.2); }
.tag.hot{ background:#fdeee6; color:#b8501f; border-color:#f4d6c4; }
.tag.hot.light{ background:rgba(216,120,60,.22); color:#ffd9c4; border-color:rgba(255,180,140,.3); }
.read-more{ display:inline-flex; align-items:center; gap:7px; font-weight:700; font-size:14px; color:var(--gold-deep); text-decoration:none; }
.read-more svg{ width:16px; height:16px; transition:transform .2s ease; }
.post-card:hover .read-more svg, .featured:hover .read-more svg, .read-more:hover svg{ transform:translateX(3px); }

/* ---------- Artículo ---------- */
.breadcrumb{ background:var(--paper); border-bottom:1px solid rgba(11,27,51,.07); }
.breadcrumb .wrap{ display:flex; align-items:center; gap:9px; height:48px; font-size:13px; color:#64748b; overflow:hidden; white-space:nowrap; }
.breadcrumb a{ color:#64748b; font-weight:600; text-decoration:none; }
.breadcrumb a:hover{ color:var(--gold-deep); }
.breadcrumb .sep{ opacity:.5; }
.breadcrumb .cur{ color:var(--ink); font-weight:600; overflow:hidden; text-overflow:ellipsis; }

.article-head{ padding:46px 0 6px; }
.article-head .col{ max-width:var(--read); margin:0 auto; }
.article-head .tags{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:18px; }
.article-head h1{ font-size:clamp(30px,4.4vw,46px); line-height:1.12; letter-spacing:-.02em; font-weight:800; color:var(--ink); margin:0 0 18px; }
.standfirst{ font-size:20px; line-height:1.55; color:#475569; margin:0 0 26px; }
.byline{ display:flex; align-items:center; gap:13px; padding:18px 0; border-top:1px solid rgba(11,27,51,.08); border-bottom:1px solid rgba(11,27,51,.08); }
.byline img{ width:46px; height:46px; border-radius:9999px; object-fit:cover; object-position:50% 22%; }
.byline .bl b{ display:block; font-size:15px; font-weight:700; color:var(--ink); }
.byline .bl span{ display:block; font-size:13px; color:#64748b; }
.byline .blm{ margin-left:auto; text-align:right; font-size:12.5px; color:#94a3b8; line-height:1.5; }

.article-body{ padding:14px 0 36px; }
.article-body .col{ max-width:var(--read); margin:0 auto; }
.prose{ font-size:18px; line-height:1.72; color:#27364b; }
.prose h2{ font-family:'Spectral',serif; font-size:28px; font-weight:700; letter-spacing:-.01em; color:var(--ink); margin:44px 0 14px; }
.prose h3{ font-family:'Spectral',serif; font-size:21px; font-weight:600; color:var(--ink); margin:30px 0 10px; }
.prose p{ margin:0 0 20px; }
.prose a{ color:var(--gold-deep); text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1.5px; text-decoration-color:rgba(166,124,31,.4); }
.prose a:hover{ text-decoration-color:var(--gold-deep); }
.prose strong{ color:var(--ink); font-weight:700; }
.prose ul, .prose ol{ margin:0 0 22px; padding-left:2px; list-style:none; }
.prose li{ position:relative; padding-left:30px; margin-bottom:11px; }
.prose ul li::before{ content:""; position:absolute; left:6px; top:.6em; width:8px; height:8px; border-radius:9999px; background:var(--gold); }
.prose ol{ counter-reset:li; }
.prose ol li{ counter-increment:li; }
.prose ol li::before{ content:counter(li); position:absolute; left:0; top:.05em; width:23px; height:23px; border-radius:7px; background:rgba(196,154,60,.16); color:var(--gold-700); font-family:'Manrope',sans-serif; font-weight:700; font-size:13px; display:flex; align-items:center; justify-content:center; }
.prose hr{ border:none; border-top:1px solid rgba(11,27,51,.1); margin:36px 0; }

.callout{ font-size:16px; line-height:1.6; color:var(--ink); border-radius:14px; padding:20px 22px 20px 56px; margin:28px 0; position:relative; background:rgba(196,154,60,.10); border:1px solid rgba(196,154,60,.28); }
.callout::before{ content:""; position:absolute; left:20px; top:21px; width:22px; height:22px; border-radius:9999px; background:var(--gold-deep); }
.callout .ci{ position:absolute; left:25px; top:23px; color:#fff; font-weight:800; font-size:14px; z-index:1; }
.callout.warn{ background:#fff6ec; border-color:#f3ddba; }
.callout.warn::before{ background:#d98a1f; }
.callout.tip{ background:#ecfaf1; border-color:#c4ecd3; }
.callout.tip::before{ background:#1aa84f; }

.pull{ font-family:'Spectral',serif; font-style:italic; font-size:24px; line-height:1.42; color:var(--navy-700); font-weight:500; border-left:4px solid var(--gold); padding:4px 0 4px 24px; margin:30px 0; }

.figure{ background:var(--navy-900); color:#fff; border-radius:18px; padding:26px 28px; margin:30px 0; display:flex; gap:26px; flex-wrap:wrap; }
.figure .fg{ flex:1 1 130px; }
.figure .fg b{ display:block; font-size:34px; font-weight:800; letter-spacing:-.02em; line-height:1; font-family:'Manrope',sans-serif; }
.figure .fg span{ display:block; font-size:13px; color:rgba(255,255,255,.6); margin-top:7px; }

.tbl-wrap{ margin:28px 0; overflow-x:auto; border:1px solid rgba(11,27,51,.1); border-radius:14px; }
table.cmp{ width:100%; border-collapse:collapse; font-size:15px; min-width:480px; }
table.cmp th, table.cmp td{ text-align:left; padding:13px 16px; border-bottom:1px solid rgba(11,27,51,.07); }
table.cmp thead th{ background:var(--navy-900); color:#fff; font-weight:700; font-size:13.5px; }
table.cmp tbody tr:nth-child(even){ background:var(--paper); }
table.cmp tbody td:first-child{ font-weight:700; color:var(--ink); }

.toc{ background:var(--paper); border:1px solid rgba(11,27,51,.08); border-radius:14px; padding:20px 22px; margin:0 0 30px; }
.toc b{ display:block; font-size:12.5px; text-transform:uppercase; letter-spacing:.1em; color:#94a3b8; margin-bottom:12px; font-family:'Manrope',sans-serif; font-weight:700; }
.toc ol{ margin:0; padding:0; list-style:none; counter-reset:toc; }
.toc li{ counter-increment:toc; margin-bottom:8px; padding-left:28px; position:relative; }
.toc li::before{ content:counter(toc,decimal-leading-zero); position:absolute; left:0; top:1px; font-size:12px; font-weight:700; color:var(--gold-deep); }
.toc a{ color:var(--ink); font-weight:600; font-size:15px; text-decoration:none; }
.toc a:hover{ color:var(--gold-deep); }

.faq-sec{ background:var(--paper); border-top:1px solid rgba(11,27,51,.07); padding:54px 0; }
.faq-sec .col{ max-width:var(--read); margin:0 auto; }
.faq-sec h2{ font-family:'Spectral',serif; font-size:30px; font-weight:700; color:var(--ink); margin:8px 0 22px; }
.faq details{ background:#fff; border:1px solid rgba(11,27,51,.08); border-radius:14px; margin-bottom:12px; overflow:hidden; }
.faq summary{ list-style:none; cursor:pointer; padding:18px 52px 18px 20px; font-weight:700; font-size:16.5px; color:var(--ink); position:relative; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; position:absolute; right:20px; top:50%; transform:translateY(-50%); font-size:22px; color:var(--gold-deep); }
.faq details[open] summary::after{ content:"−"; }
.faq .a{ padding:0 20px 20px; color:#475569; font-size:15.5px; line-height:1.6; }
.faq .a p{ margin:0; }

.author{ padding:46px 0; }
.author .col{ max-width:var(--read); margin:0 auto; }
.author-card{ display:flex; gap:22px; align-items:flex-start; background:#fff; border:1px solid rgba(11,27,51,.08); border-radius:20px; padding:26px; box-shadow:0 1px 2px rgba(11,27,51,.04), 0 12px 32px -8px rgba(11,27,51,.10); }
.author-card img{ width:78px; height:78px; border-radius:9999px; object-fit:cover; object-position:50% 22%; flex-shrink:0; }
.author-card .at b{ font-family:'Spectral',serif; font-size:18px; color:var(--ink); font-weight:600; }
.author-card .at .role{ font-size:13.5px; color:var(--gold-deep); font-weight:700; margin:3px 0 10px; }
.author-card .at p{ font-size:14.5px; color:#475569; line-height:1.55; margin:0 0 14px; }
.author-card .links{ display:flex; gap:10px; flex-wrap:wrap; }

.cta-band{ position:relative; color:#fff; overflow:hidden; padding:56px 0; background:linear-gradient(120deg,#163356,#2B5A92); }
.cta-band .col{ position:relative; z-index:1; max-width:48rem; margin:0 auto; text-align:center; }
.cta-band h2{ font-size:clamp(26px,3.6vw,40px); font-weight:800; line-height:1.15; margin:14px 0 14px; }
.cta-band p{ color:rgba(255,255,255,.85); font-size:18px; max-width:34rem; margin:0 auto 26px; line-height:1.6; }
.cta-actions{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

.related{ background:#fff; padding:54px 0; }
.related h2{ font-family:'Spectral',serif; font-size:24px; font-weight:700; color:var(--ink); margin:8px 0 22px; }
.related-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }

/* ---------- Footer (idéntico al sitio) ---------- */
.blog-footer{ background:var(--navy-900); color:#fff; padding:48px 0 30px; }
.blog-footer .top{ display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:40px; padding-bottom:32px; border-bottom:1px solid rgba(255,255,255,.1); }
.blog-footer .about{ margin:18px 0 0; max-width:24rem; color:rgba(255,255,255,.7); line-height:1.65; font-size:15px; }
.blog-footer h4{ font-size:12px; text-transform:uppercase; letter-spacing:.16em; color:#E7CF93; margin:0 0 16px; font-weight:700; font-family:'Manrope',sans-serif; }
.blog-footer ul{ list-style:none; margin:0; padding:0; }
.blog-footer li{ margin-bottom:10px; font-size:14.5px; color:rgba(255,255,255,.75); }
.blog-footer a{ color:rgba(255,255,255,.75); text-decoration:none; }
.blog-footer a:hover{ color:#E7CF93; }
.blog-footer .bottom{ padding-top:22px; text-align:center; font-size:12.5px; color:rgba(255,255,255,.45); }

/* ---------- WhatsApp flotante ---------- */
.wa-float{ position:fixed; z-index:50; right:20px; bottom:20px; display:inline-flex; align-items:center; justify-content:center; width:62px; height:62px; border-radius:9999px; background:var(--whats); color:#fff; box-shadow:0 18px 40px -8px rgba(37,211,102,.6), 0 0 0 4px rgba(255,255,255,.18); transition:transform .3s; }
.wa-float:hover{ transform:scale(1.06); }
.wa-float svg{ width:32px; height:32px; }
@media (min-width:1024px){ .wa-float{ right:28px; bottom:28px; width:66px; height:66px; } }

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .featured{ grid-template-columns:1fr; }
  .featured .media{ min-height:190px; }
  .post-grid, .related-grid{ grid-template-columns:1fr 1fr; }
  .blog-footer .top{ grid-template-columns:1fr 1fr; }
}
@media (max-width:640px){
  .prose{ font-size:17px; }
  .post-grid, .related-grid{ grid-template-columns:1fr; }
  .blog-footer .top{ grid-template-columns:1fr; gap:28px; }
  .byline .blm{ display:none; }
  .article-head{ padding-top:30px; }
}
