/* ============================================================
   DRA. MILK — styles.css
   Sistema: azul cobijo + oro calostro · Cormorant Garamond + Mulish
   Tipografías AUTO-ALOJADAS en /assets/fonts (sin terceros).
   ============================================================ */

/* ---------- Fuentes ---------- */
@font-face{font-family:'Cormorant Garamond';src:url('../fonts/Cormorant-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Cormorant Garamond';src:url('../fonts/Cormorant-It500.woff2') format('woff2');font-weight:500;font-style:italic;font-display:swap}
@font-face{font-family:'Mulish';src:url('../fonts/Mulish-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Mulish';src:url('../fonts/Mulish-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Mulish';src:url('../fonts/Mulish-700.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Mulish';src:url('../fonts/Mulish-800.woff2') format('woff2');font-weight:800;font-style:normal;font-display:swap}

/* ---------- Variables ---------- */
:root{
  --marfil:#FAF4EA;
  --arena:#EFE3D2;
  --linea:#E2D2BC;
  --navy:#243748;
  --deep:#1B2A38;
  --oro:#C2A05A;
  --oro-claro:#CDAE68;
  --terracota:#C67B5C;
  --texto:#3c4a55;
  --maxw:1080px;
  --radius:16px;
}

/* ---------- Base ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--marfil);color:var(--navy);font-family:'Mulish',system-ui,sans-serif;line-height:1.7;font-size:16.5px;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{padding:84px 0}
h1,h2,h3{font-family:'Cormorant Garamond',serif;font-weight:600;line-height:1.12}
h2{font-size:clamp(32px,5vw,48px);margin-bottom:14px}
h3{font-size:clamp(20px,2.6vw,25px)}
.it{font-style:italic;font-weight:500}
.kicker{display:inline-block;font-weight:700;text-transform:uppercase;letter-spacing:.26em;font-size:12px;color:var(--oro);margin-bottom:14px}
.kicker.on-dark{color:var(--oro-claro)}
p{color:var(--texto)}
.lead{font-size:18px;max-width:62ch}
.gold-rule{width:54px;height:2px;background:var(--oro);border:0;margin:18px 0 26px}

/* Accesibilidad: enlace para saltar al contenido */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--navy);color:var(--marfil);padding:12px 20px;z-index:100;border-radius:0 0 10px 0}
.skip-link:focus{left:0}
:focus-visible{outline:3px solid var(--oro);outline-offset:2px}

/* ---------- Botones ---------- */
.btn{display:inline-block;font-family:'Mulish';font-weight:700;font-size:15px;letter-spacing:.04em;padding:15px 32px;border-radius:50px;transition:transform .15s ease,box-shadow .15s ease;cursor:pointer;border:0}
.btn:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(36,55,72,.18)}
.btn-primary{background:var(--navy);color:var(--marfil)}
.btn-gold{background:var(--oro);color:var(--navy)}
.btn-outline{background:transparent;color:var(--navy);border:1.6px solid var(--navy)}
.btn-outline.on-dark{color:var(--marfil);border-color:rgba(250,244,234,.5)}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(250,244,234,.93);backdrop-filter:blur(8px);border-bottom:1px solid var(--linea);transition:box-shadow .2s}
.site-header.scrolled{box-shadow:0 6px 24px rgba(27,42,56,.08)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;max-width:var(--maxw);margin:0 auto;gap:16px}
.brand img{height:46px;width:auto}
.nav-links{display:flex;gap:26px;font-size:14.5px;font-weight:600;align-items:center}
/* Variante para páginas interiores sin botón hamburguesa: el menú corto queda siempre visible */
.nav-links.always{display:flex}
.nav-links a:hover{color:var(--oro)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:2.5px;background:var(--navy);margin:5px 0;border-radius:2px;transition:.2s}
@media(max-width:880px){
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--marfil);flex-direction:column;padding:18px 24px;border-bottom:1px solid var(--linea);gap:16px}
  .nav-links.open{display:flex}
  .nav-toggle{display:block}
}

/* ---------- Hero ---------- */
.hero{background:var(--navy);color:var(--marfil);padding:96px 0;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;width:620px;height:620px;border-radius:50%;border:1px solid rgba(205,174,104,.18);top:-260px;right:-180px}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;position:relative}
.hero h1{font-size:clamp(40px,6.4vw,64px);font-weight:600;color:var(--marfil)}
.hero h1 .gold{color:var(--oro-claro);font-style:italic;font-weight:500}
.hero .sub{color:#cdd6dd;font-size:18px;margin:20px 0 32px;max-width:50ch}
.hero .cred{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:#8da0ac;margin-top:26px}
.hero-logo{display:flex;justify-content:center}
.hero-logo img{width:min(320px,64vw);height:auto}
.hero .actions{display:flex;gap:14px;flex-wrap:wrap}
@media(max-width:880px){.hero-grid{grid-template-columns:1fr}.hero-logo{order:-1}.hero-logo img{width:190px}}

/* ---------- Franja de confianza ---------- */
.trust{background:var(--arena);padding:26px 0;border-bottom:1px solid var(--linea)}
.trust .wrap{display:flex;flex-wrap:wrap;gap:14px 40px;justify-content:center;font-size:14px;font-weight:600;color:var(--navy)}
.trust span::before{content:"✦";color:var(--oro);margin-right:8px}

/* ---------- Tarjetas / grillas ---------- */
.grid{display:grid;gap:22px}
.g2{grid-template-columns:1fr 1fr}
.g3{grid-template-columns:repeat(3,1fr)}
@media(max-width:880px){.g2,.g3{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--linea);border-radius:var(--radius);padding:28px 26px}
.card.warm{background:var(--arena)}
.card h3{margin-bottom:10px}
.card p{font-size:15px}

/* ---------- Sobre mí ---------- */
.about{background:var(--arena)}
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:center}
@media(max-width:880px){.about-grid{grid-template-columns:1fr}}
.photo-ph{aspect-ratio:4/5;border-radius:var(--radius);background:linear-gradient(160deg,var(--arena),#e6d6c0);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:14px;border:1px solid var(--linea)}
.photo-ph img{width:110px;opacity:.92}
.photo-ph small{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#9b8a6f}
.creds{list-style:none;margin-top:22px}
.creds li{padding:10px 0 10px 32px;position:relative;font-size:15.5px;border-bottom:1px dashed var(--linea)}
.creds li:last-child{border:0}
.creds li::before{content:"✓";position:absolute;left:0;color:var(--oro);font-weight:800}

/* ---------- Servicios ---------- */
.svc{background:#fff;border:1px solid var(--linea);border-radius:var(--radius);padding:28px 26px;display:flex;flex-direction:column}
.svc .tagline{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--oro);font-weight:700;margin-bottom:8px}
.svc p{font-size:14.5px;flex:1}
.svc a{margin-top:18px;font-weight:700;font-size:14px;color:var(--navy)}
.svc a::after{content:" →";color:var(--oro)}

/* ---------- Mitos ---------- */
.myths{background:var(--deep);color:var(--marfil)}
.myths h2{color:var(--marfil)}
.myths p.lead{color:#cdd6dd}
.myth{background:rgba(255,255,255,.045);border:1px solid rgba(205,174,104,.25);border-radius:var(--radius);padding:24px}
.myth .m{font-family:'Cormorant Garamond';font-style:italic;font-size:19px;color:var(--terracota);text-decoration:line-through;text-decoration-thickness:1px}
.myth .r{margin-top:12px;font-size:14.5px;color:#dfe7ec}
.myth .r b{color:var(--oro-claro)}

/* ---------- Señales ---------- */
.alerts .card{border-left:4px solid var(--oro)}
.alerts .card.urgent{border-left-color:var(--terracota)}
.alerts ul{list-style:none;margin-top:8px}
.alerts li{padding:7px 0 7px 28px;position:relative;font-size:15px;color:var(--texto)}
.alerts li::before{content:"•";position:absolute;left:8px;color:var(--oro);font-weight:800}
.alerts .urgent li::before{color:var(--terracota)}

/* ---------- Testimonios ---------- */
.testi{background:var(--arena)}
.testi blockquote{background:#fff;border:1px solid var(--linea);border-radius:var(--radius);padding:30px 26px;font-family:'Cormorant Garamond';font-style:italic;font-size:19px;line-height:1.5;position:relative}
.testi blockquote::before{content:"\201C";font-size:64px;color:var(--oro);position:absolute;top:-6px;left:18px;font-style:normal}
.testi figcaption{margin-top:14px;font-family:'Mulish';font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#8a97a1;font-style:normal}

/* ---------- FAQ ---------- */
.faq details{background:#fff;border:1px solid var(--linea);border-radius:12px;padding:0 22px;margin-bottom:12px}
.faq summary{cursor:pointer;list-style:none;font-weight:700;font-size:15.5px;padding:18px 0;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:22px;color:var(--oro);font-weight:400;flex-shrink:0}
.faq details[open] summary::after{content:"–"}
.faq details p{padding:0 0 18px;font-size:15px}

/* ---------- CTA final ---------- */
.cta-final{background:var(--navy);color:var(--marfil);text-align:center}
.cta-final h2{color:var(--marfil)}
.cta-final p{color:#cdd6dd;max-width:54ch;margin:0 auto 30px}
.cta-final .note{font-size:13px;color:#8da0ac;margin-top:18px}

/* ---------- Footer ---------- */
.site-footer{background:var(--deep);color:#aebcc6;padding:56px 0 32px;font-size:14px}
.foot-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:36px;margin-bottom:36px}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr}}
.site-footer h4{font-family:'Cormorant Garamond';color:var(--marfil);font-size:19px;margin-bottom:12px}
.site-footer a:hover{color:var(--oro-claro)}
.foot-links a{display:block;padding:4px 0}
.foot-brand img{width:230px;height:auto;margin-bottom:14px}
.disclaimer{border-top:1px solid rgba(255,255,255,.12);padding-top:24px;font-size:12.5px;line-height:1.7;color:#8da0ac}
.disclaimer.bare{border:0;padding-top:0}
.disclaimer a{text-decoration:underline}

/* ---------- WhatsApp flotante ---------- */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:60;width:58px;height:58px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 26px rgba(0,0,0,.25);transition:transform .15s}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:30px;height:30px;fill:#fff}

/* ---------- Páginas legales ---------- */
.legal-page{padding:72px 0;max-width:780px;margin:0 auto}
.legal-page h1{font-size:clamp(30px,4.6vw,42px);margin-bottom:8px}
.legal-page .updated{font-size:13px;color:#8a97a1;margin-bottom:34px}
.legal-page h2{font-size:24px;margin:34px 0 10px}
.legal-page p,.legal-page li{font-size:15.5px;color:var(--texto);margin-bottom:12px}
.legal-page ul{padding-left:22px}
.legal-page .back{display:inline-block;margin-bottom:28px;font-weight:700;font-size:14px;color:var(--oro)}

/* ---------- 404 ---------- */
.page-404{min-height:70vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 24px}
.page-404 img{width:120px;margin-bottom:24px}
.page-404 h1{font-size:clamp(34px,6vw,54px)}
.page-404 p{margin:12px 0 28px}

/* ---------- Utilidades ---------- */
.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .btn,.wa-float{transition:none}
}

/* ---------- Blog / Recursos ---------- */
.blog-hero{background:var(--arena);padding:64px 0;border-bottom:1px solid var(--linea)}
.blog-hero h1{font-size:clamp(32px,5vw,48px)}
.post-card{background:#fff;border:1px solid var(--linea);border-radius:var(--radius);padding:26px;display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s}
.post-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(27,42,56,.10)}
.post-card .pill{align-self:flex-start;font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--oro);background:rgba(194,160,90,.12);padding:6px 14px;border-radius:40px;margin-bottom:14px}
.post-card h3{margin-bottom:10px;font-size:22px}
.post-card p{font-size:14.5px;flex:1}
.post-card .more{margin-top:16px;font-weight:700;font-size:14px}
.post-card .more::after{content:" →";color:var(--oro)}
.article{max-width:740px;margin:0 auto;padding:64px 24px}
.article .crumb{font-size:13px;font-weight:700;color:var(--oro);display:inline-block;margin-bottom:18px}
.article h1{font-size:clamp(30px,5vw,44px);margin-bottom:14px}
.article .meta{font-size:13px;color:#8a97a1;margin-bottom:30px;padding-bottom:18px;border-bottom:1px solid var(--linea)}
.article h2{font-size:26px;margin:38px 0 12px}
.article h3{font-size:20px;margin:26px 0 8px}
.article p,.article li{font-size:16.5px;color:var(--texto);margin-bottom:14px}
.article ul,.article ol{padding-left:24px;margin-bottom:14px}
.article blockquote{border-left:4px solid var(--oro);background:var(--arena);padding:18px 22px;border-radius:0 12px 12px 0;font-family:'Cormorant Garamond';font-style:italic;font-size:19px;margin:22px 0;color:var(--navy)}
.article .keybox{background:#fff;border:1px solid var(--linea);border-left:4px solid var(--oro);border-radius:12px;padding:20px 22px;margin:22px 0}
.article .keybox b{color:var(--navy)}
.article .alertbox{background:#fff;border:1px solid var(--linea);border-left:4px solid var(--terracota);border-radius:12px;padding:20px 22px;margin:22px 0;font-size:15px}
.article .cta-inline{background:var(--navy);color:var(--marfil);border-radius:var(--radius);padding:30px;text-align:center;margin:38px 0}
.article .cta-inline h3{color:var(--marfil);margin-bottom:6px}
.article .cta-inline p{color:#cdd6dd;margin-bottom:18px}
.article .sources{font-size:13.5px;color:#8a97a1;border-top:1px solid var(--linea);margin-top:40px;padding-top:18px}
.article .sources a{text-decoration:underline}
.article .sources li{font-size:13.5px;color:#8a97a1;margin-bottom:6px}
.author-box{display:flex;gap:18px;align-items:center;background:var(--arena);border-radius:var(--radius);padding:20px 22px;margin-top:34px}
.author-box img{width:64px;height:64px;border-radius:14px;flex-shrink:0}
.author-box p{font-size:13.5px;margin:0}
.author-box b{display:block;font-size:15px;color:var(--navy)}
