:root {
    --site-bg: #0A0A0A;
    --site-bg-2: #111111;
    --site-surface: rgba(255, 215, 0, 0.055);
    --site-surface-2: rgba(255, 215, 0, 0.075);
    --site-primary: #FFD700;
    --site-primary-dark: #FFC107;
    --site-accent: #000000;
    --site-blue: #FFD700;
    --site-violet: #FFC107;
    --site-text: #FFFFFF;
    --site-muted: #BFBFBF;
    --site-border: rgba(255, 215, 0, 0.16);
    --site-soft: rgba(255, 215, 0, 0.06);
    --site-warning: rgba(255, 215, 0, 0.14);
    --site-shadow: 0 18px 48px rgba(0, 0, 0, 0.55);
    --site-radius: 16px;
    --container: 1180px;
    --container-wide: 1280px;
    --space-xs: .45rem;
    --space-sm: .75rem;
    --space-md: 1rem;
    --space-lg: 1.35rem;
    --space-xl: 2rem;
    --space-2xl: clamp(2.6rem, 6vw, 5.2rem);
    --space-3xl: clamp(4rem, 8vw, 7.6rem);
    --ease: cubic-bezier(.2, .8, .2, 1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 104px; }
body {
    margin: 0;
    min-width: 320px;
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: var(--site-text);
    line-height: 1.68;
    background:
        radial-gradient(circle at 13% 6%, rgba(255, 215, 0, 0.12), transparent 26%),
        radial-gradient(circle at 86% 16%, rgba(255, 193, 7, 0.08), transparent 28%),
        linear-gradient(180deg, #0A0A0A 0%, #050505 58%, #0A0A0A 100%);
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
}
body.nav-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
a:hover { color: var(--site-primary); }
img { max-width: 100%; display: block; }
button, input, select, textarea { font: inherit; }
:focus-visible { outline: 3px solid rgba(255, 215, 0, .72); outline-offset: 4px; }
::selection { background: rgba(255, 215, 0, .28); color: #fff; }

.container { width: min(var(--container), calc(100% - 32px)); margin-inline: auto; }
.container-wide { width: min(var(--container-wide), calc(100% - 32px)); margin-inline: auto; }
.narrow { width: min(880px, calc(100% - 32px)); margin-inline: auto; }
.mt-large { margin-top: var(--space-xl); }
.compact-head { margin-top: var(--space-xl); }

/* Header público: misma paleta, mejor arquitectura visual */
.site-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: rgba(10, 10, 10, .82);
    border-bottom: 1px solid rgba(255, 215, 0, .13);
    box-shadow: 0 14px 40px rgba(0,0,0,.32);
    backdrop-filter: blur(16px);
    transition: background .25s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease);
}
.site-header.is-scrolled { background: rgba(10,10,10,.94); border-color: rgba(255,215,0,.2); box-shadow: 0 18px 46px rgba(0,0,0,.55); }
.header-topline { border-bottom: 1px solid rgba(255,215,0,.08); background: rgba(255,215,0,.025); }
.header-topline-inner { min-height: 34px; display: flex; align-items: center; justify-content: space-between; gap: 16px; color: var(--site-muted); font-size: 12px; font-weight: 780; }
.header-topline-inner span { display: inline-flex; align-items: center; gap: 8px; }
.header-topline-inner span::before { content: ""; width: 7px; height: 7px; border-radius: 999px; background: var(--site-primary); box-shadow: 0 0 0 4px rgba(255,215,0,.08); }
.navbar { min-height: 84px; display: flex; align-items: center; justify-content: space-between; gap: 22px; }
.brand { display: inline-flex; align-items: center; gap: 14px; min-width: 0; padding: 8px 0; }
.brand-logo {
    width: 72px;
    height: 58px;
    object-fit: contain;
    padding: 7px;
    border-radius: 18px;
    background: rgba(255,255,255,.96);
    border: 1px solid rgba(255,215,0,.20);
    box-shadow: 0 10px 30px rgba(255,215,0,.08), inset 0 0 0 1px rgba(0,0,0,.06);
    flex: 0 0 auto;
}
.brand-text { display: grid; min-width: 0; line-height: 1.15; }
.brand-text strong { color: #fff; font-size: clamp(13px, 1.22vw, 16px); letter-spacing: -.02em; max-width: 260px; }
.brand-text span { margin-top: 3px; color: var(--site-muted); font-size: 12px; font-weight: 850; text-transform: uppercase; letter-spacing: .08em; }
.nav-links { display: flex; align-items: center; gap: 4px; color: #f5f5f5; font-size: 13px; font-weight: 850; }
.nav-links a:not(.btn) { position: relative; display: inline-flex; align-items: center; min-height: 40px; padding: 9px 10px; border-radius: 999px; color: rgba(255,255,255,.82); }
.nav-links a:not(.btn):hover { color: #fff; background: rgba(255,215,0,.07); }
.nav-links a:not(.btn)::after { content: ""; position: absolute; left: 14px; right: 14px; bottom: 5px; height: 1px; background: var(--site-primary); transform: scaleX(0); transform-origin: left; transition: transform .2s var(--ease); opacity: .75; }
.nav-links a:not(.btn):hover::after { transform: scaleX(1); }
.nav-primary, .nav-secondary { display: contents; }
.nav-cta-group { display: inline-flex; align-items: center; gap: 8px; margin-left: 6px; }
.nav-cta-group .btn { padding-inline: 16px; }
.nav-mobile-head { display: none; }
.nav-toggle { display: none; align-items: center; gap: 10px; min-height: 44px; border: 1px solid var(--site-border); color: #fff; background: rgba(255,215,0,.06); border-radius: 999px; padding: 10px 13px; font-weight: 950; cursor: pointer; }
.nav-toggle-bars, .nav-toggle-bars::before, .nav-toggle-bars::after { display: block; width: 18px; height: 2px; border-radius: 999px; background: currentColor; transition: transform .22s var(--ease), opacity .22s var(--ease); }
.nav-toggle-bars { position: relative; }
.nav-toggle-bars::before, .nav-toggle-bars::after { content: ""; position: absolute; left: 0; }
.nav-toggle-bars::before { top: -6px; }
.nav-toggle-bars::after { top: 6px; }
.nav-toggle[aria-expanded="true"] .nav-toggle-bars { transform: rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle-bars::before { transform: translateY(6px) rotate(90deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle-bars::after { transform: translateY(-6px); opacity: 0; }
.nav-backdrop { position: fixed; inset: 0; z-index: 900; background: rgba(0,0,0,.62); backdrop-filter: blur(3px); }
.nav-backdrop[hidden] { display: none; }

/* Botones */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 44px;
    padding: 12px 18px;
    border: 1px solid transparent;
    border-radius: 999px;
    cursor: pointer;
    font-weight: 950;
    line-height: 1.1;
    text-align: center;
    transition: transform .22s var(--ease), box-shadow .22s var(--ease), border-color .22s var(--ease), filter .22s var(--ease), background .22s var(--ease);
}
.btn:hover { transform: translateY(-2px); }
.btn-primary { color: #FFFFFF; background: linear-gradient(45deg, #FFD700 0%, #B99100 52%, #000000 100%); border-color: rgba(255, 215, 0, 0.24); box-shadow: 0 8px 32px rgba(255, 215, 0, 0.22); }
.btn-primary:hover { filter: brightness(1.08); box-shadow: 0 16px 46px rgba(255,215,0,.26); color: #fff; }
.btn-secondary, .btn-light { background: rgba(255, 215, 0, 0.045); color: #FFFFFF; border-color: rgba(255, 215, 0, 0.18); }
.btn-secondary:hover, .btn-light:hover { border-color: rgba(255, 215, 0, 0.55); box-shadow: 0 8px 28px rgba(255, 215, 0, 0.12); color: #fff; }
.btn-mini { min-height: 38px; padding: 10px 14px; font-size: 12px; }

/* Composición global */
main { overflow: clip; }
.section { position: relative; padding: var(--space-2xl) 0; }
.section + .section { border-top: 1px solid rgba(255,215,0,.055); }
.section-alt, .section-soft { background: linear-gradient(180deg, rgba(255,215,0,.035), rgba(255,215,0,.018)); border-block: 1px solid rgba(255,215,0,.10); backdrop-filter: blur(12px); }
.section-head { max-width: 780px; margin-bottom: clamp(24px, 4vw, 42px); }
.section-head.center { text-align: center; margin-left: auto; margin-right: auto; }
.section-head.split { max-width: none; display: grid; grid-template-columns: minmax(0, .85fr) minmax(260px, .42fr); gap: 32px; align-items: end; }
.section-head p, .hero p, .article-hero p, .content-card p, .service-card p, .info-card p, .faq-item p, .cta-panel p, .footer-grid p { color: var(--site-muted); }
.kicker, .eyebrow { display: inline-flex; align-items: center; gap: 8px; color: #FFD700; background: rgba(255, 215, 0, 0.07); border: 1px solid rgba(255, 215, 0, 0.18); border-radius: 999px; padding: 7px 12px; font-weight: 950; text-transform: uppercase; letter-spacing: .09em; font-size: 12px; line-height: 1.1; }
.eyebrow { margin-bottom: 18px; }
.kicker::before, .eyebrow::before { content: ""; width: 7px; height: 7px; border-radius: 999px; background: currentColor; box-shadow: 0 0 0 4px rgba(255,215,0,.08); }
h1, h2, h3 { color: #fff; margin: 0; line-height: 1.08; letter-spacing: -.04em; }
h1 { font-size: clamp(34px, 5vw, 64px); }
h2 { font-size: clamp(27px, 3vw, 42px); }
h3 { font-size: clamp(19px, 2vw, 24px); }
p { margin: 0 0 1rem; }
p:last-child { margin-bottom: 0; }

/* Hero y páginas internas */
.hero, .article-hero, .page-hero {
    position: relative;
    overflow: hidden;
    padding: clamp(58px, 7vw, 98px) 0 clamp(44px, 5vw, 74px);
    background:
        linear-gradient(135deg, rgba(255,215,0,.07), transparent 34%),
        radial-gradient(circle at 18% 14%, rgba(255, 215, 0, 0.15), transparent 34%),
        radial-gradient(circle at 82% 18%, rgba(255, 193, 7, 0.08), transparent 32%);
}
.hero::before, .article-hero::before, .page-hero::before { content: ""; position: absolute; inset: 18px; border: 1px solid rgba(255,215,0,.06); border-radius: 32px; pointer-events: none; }
.hero::after, .article-hero::after, .page-hero::after { content: ""; position: absolute; right: -160px; bottom: -210px; width: 520px; height: 520px; border-radius: 999px; background: rgba(255, 215, 0, 0.07); filter: blur(2px); }
.hero-compact { padding: clamp(52px, 6vw, 78px) 0 clamp(38px, 5vw, 58px); }
.hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, 1.04fr) minmax(330px, .82fr); gap: clamp(28px, 5vw, 56px); align-items: center; }
.hero-content { max-width: 790px; }
.hero-content > p, .hero .container > p, .article-hero p { margin-top: 18px; max-width: 760px; font-size: clamp(17px, 1.8vw, 20px); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.hero-card, .content-card, .service-card, .info-card, .faq-item, .contact-card, .appointment-card, .search-panel, .cta-panel, .content-block, .article-body, .review-box, .map-box, .faq-detail, .process-card, .region-meta-grid article, .feature-list li, .region-related-list a, .trust-card, .visual-panel, .form-card, .location-card, .blog-card, .doctor-card, .sidebar-card, .metric-card, .geo-state-card {
    background: rgba(255, 215, 0, 0.05);
    border: 1px solid rgba(255, 215, 0, 0.13);
    border-radius: var(--site-radius);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.42);
    backdrop-filter: blur(12px);
}
.hero-card, .visual-panel { position: relative; padding: clamp(20px, 3vw, 30px); overflow: hidden; }
.hero-card::before, .visual-panel::before, .cta-panel::before { content: ""; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(135deg, rgba(255,215,0,.11), transparent 42%); opacity: .72; }
.hero-card > *, .visual-panel > *, .cta-panel > * { position: relative; z-index: 1; }
.hero-card img { width: 100%; aspect-ratio: 16 / 11; object-fit: cover; border-radius: calc(var(--site-radius) - 2px); border: 1px solid rgba(255,215,0,.12); background: #111; }
.hero-card-note { margin-top: 16px; padding: 16px; border-radius: 14px; background: rgba(255,215,0,.07); color: #FFE680; border: 1px solid rgba(255,215,0,.18); font-weight: 800; }
.hero-meta { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; margin-top: 28px; }
.hero-meta article, .metric-card { padding: 16px; }
.hero-meta strong, .metric-card strong { display: block; color: #fff; font-size: 18px; line-height: 1.15; }
.hero-meta span, .metric-card span { display: block; margin-top: 5px; color: var(--site-muted); font-size: 13px; font-weight: 780; }
.hero-badges { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px; }
.hero-badges span { display: inline-flex; align-items: center; gap: 7px; min-height: 36px; padding: 8px 11px; border-radius: 999px; background: rgba(255,215,0,.055); border: 1px solid rgba(255,215,0,.12); color: rgba(255,255,255,.86); font-weight: 850; font-size: 13px; }
.hero-badges span::before { content: ""; width: 6px; height: 6px; background: var(--site-primary); border-radius: 999px; }

/* Componentes */
.cards-grid, .content-grid, .blog-grid, .region-grid, .faq-grid, .trust-strip, .service-feature-grid, .resource-grid { display: grid; gap: 18px; }
.cards-grid, .content-grid, .blog-grid, .region-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.cards-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.full-card { grid-column: 1 / -1; }
.two-col, .split-section { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: clamp(22px, 4vw, 42px); align-items: start; }
.content-card, .service-card, .info-card, .faq-item, .contact-card, .appointment-card, .content-block, .blog-card, .sidebar-card, .doctor-card, .form-card, .location-card { padding: clamp(20px, 2.4vw, 30px); }
.content-card, .service-card, .blog-card, .faq-item, .info-card, .contact-card { transition: transform .28s var(--ease), box-shadow .28s var(--ease), border-color .28s var(--ease); }
.content-card:hover, .service-card:hover, .blog-card:hover, .faq-item:hover, .info-card:hover, .contact-card:hover, .geo-state-card:hover { transform: translateY(-5px); border-color: rgba(255, 215, 0, .27); box-shadow: 0 18px 54px rgba(0,0,0,.56); }
.content-card h2, .content-card h3, .service-card h3, .blog-card h3 { margin: 12px 0 10px; }
.content-card h2 { font-size: clamp(21px, 2vw, 27px); }
.content-card h3, .service-card h3, .blog-card h3 { font-size: clamp(19px, 2vw, 23px); }
.content-card a:hover, .service-card a:hover, .blog-card a:hover { color: #FFD700; }
.icon-dot, .service-index, .process-card::before, .step-number { width: 42px; height: 42px; border-radius: 14px; display: grid; place-items: center; color: #111; background: linear-gradient(45deg, #FFD700, #FFC107); border: 1px solid rgba(255, 215, 0, 0.24); font-weight: 950; margin-bottom: 14px; box-shadow: 0 10px 24px rgba(255,215,0,.14); }
.badge-soft, .region-card .region-location, .tag-row span { display: inline-flex; align-items: center; padding: 6px 10px; border-radius: 999px; color: #FFD700; background: rgba(255, 215, 0, 0.07); border: 1px solid rgba(255, 215, 0, 0.18); font-weight: 900; font-size: 12px; line-height: 1.1; }
.card-meta, .article-meta { display: flex; flex-wrap: wrap; gap: 10px; color: var(--site-muted); font-size: 13px; font-weight: 780; margin: 14px 0; }
.card-meta span, .article-meta span { display: inline-flex; padding: 6px 10px; border: 1px solid rgba(255,215,0,.1); background: rgba(255,215,0,.035); border-radius: 999px; }
.link-arrow { color: #FFD700; font-weight: 950; display: inline-flex; align-items: center; gap: 6px; margin-top: 8px; }
.link-arrow::after { content: "→"; transition: transform .2s var(--ease); }
.link-arrow:hover::after { transform: translateX(4px); }
.feature-list, .check-list, .link-list { list-style: none; padding: 0; margin: 20px 0 0; display: grid; gap: 12px; }
.feature-list li, .check-list li { padding: 13px 15px 13px 42px; position: relative; color: #ddd; }
.feature-list li::before, .check-list li::before { content: ""; position: absolute; left: 16px; top: 1.25em; width: 9px; height: 9px; border-radius: 999px; background: var(--site-primary); box-shadow: 0 0 0 4px rgba(255,215,0,.08); }
.link-list li a, .resource-link, .region-related-list a { display: flex; align-items: center; justify-content: space-between; gap: 12px; min-height: 46px; padding: 12px 14px; border-radius: 14px; background: rgba(255,215,0,.04); border: 1px solid rgba(255,215,0,.11); color: #fff; font-weight: 850; }
.link-list li a::after, .resource-link::after, .region-related-list a::after { content: "→"; color: var(--site-primary); }
.link-list li a:hover, .resource-link:hover, .region-related-list a:hover { border-color: rgba(255,215,0,.3); color: #fff; transform: translateY(-2px); }

/* Home */
.home-hero { padding-top: clamp(66px, 7vw, 104px); }
.home-hero .hero-card { display: grid; gap: 14px; }
.home-hero-panel { display: grid; gap: 14px; }
.home-hero-panel .metric-card:first-of-type { background: rgba(255,215,0,.08); }
.trust-strip { grid-template-columns: repeat(4, minmax(0, 1fr)); margin-top: -34px; position: relative; z-index: 5; }
.trust-card { padding: 20px; min-height: 132px; }
.trust-card strong { display: block; color: #fff; font-size: 17px; margin-bottom: 7px; }
.trust-card span { color: var(--site-muted); font-weight: 760; font-size: 13px; }
.trust-card .icon-dot { width: 34px; height: 34px; border-radius: 12px; font-size: 12px; margin-bottom: 12px; }
.service-feature-grid { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.service-feature { grid-column: span 2; min-height: 100%; }
.service-feature.wide { grid-column: span 3; }
.process-timeline { counter-reset: step; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; position: relative; }
.process-card { counter-increment: step; position: relative; padding: 24px; overflow: hidden; }
.process-card::before { content: counter(step, decimal-leading-zero); }
.process-card::after { content: ""; position: absolute; left: 24px; right: 24px; bottom: 0; height: 3px; border-radius: 99px 99px 0 0; background: linear-gradient(90deg, rgba(255,215,0,.85), transparent); opacity: .75; }
.patient-route { display: grid; grid-template-columns: .78fr 1.22fr; gap: 24px; align-items: stretch; }
.patient-route .visual-panel { display: grid; align-content: center; }
.location-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(22px, 4vw, 42px); align-items: stretch; }
.map-box, .map-placeholder { min-height: 360px; border-radius: var(--site-radius); border: 1px dashed rgba(255,215,0,.24); background: linear-gradient(135deg, rgba(255,215,0,.07), rgba(255,215,0,.025)); display: grid; place-items: center; padding: 28px; text-align: center; color: var(--site-muted); }
.map-placeholder h2, .map-box h2 { margin-bottom: 10px; }
.cta-band, .cta-panel { position: relative; overflow: hidden; padding: clamp(24px, 4vw, 42px); display: flex; align-items: center; justify-content: space-between; gap: 22px; background: linear-gradient(135deg, rgba(255,215,0,.10), rgba(255,215,0,.035)); border: 1px solid rgba(255,215,0,.16); border-radius: calc(var(--site-radius) + 8px); box-shadow: var(--site-shadow); }
.cta-panel { display: block; }
.cta-panel .btn, .cta-band .btn { margin-top: 0; }
.cta-panel .btn + .btn { margin-left: 8px; margin-top: 10px; }
.medical-disclaimer, .geo-disclaimer, .alert-box.warning, .medical-note, .location-truth { background: rgba(255, 215, 0, 0.09); border: 1px solid rgba(255, 215, 0, 0.22); color: #FFE680; border-radius: var(--site-radius); padding: 18px; }
.medical-disclaimer a, .geo-disclaimer a, .medical-note a { text-decoration: underline; color: #fff; }

/* Servicios */
.services-hero .hero-card, .blog-hero .hero-card, .contact-hero .hero-card, .geo-hero .hero-card { min-height: 100%; display: grid; align-content: center; gap: 14px; }
.service-public-card, .service-card { position: relative; overflow: hidden; }
.service-public-card::after, .service-card::after, .blog-card::after { content: ""; position: absolute; inset: auto 0 0 0; height: 3px; background: linear-gradient(90deg, var(--site-primary), transparent); opacity: .6; }
.service-detail-grid { display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: 24px; align-items: start; }
.service-detail-aside { position: sticky; top: 118px; display: grid; gap: 16px; }
.appointment-panel { padding: 24px; }
.appointment-panel .btn { width: 100%; margin-top: 10px; }
.quick-answer-block { border-color: rgba(255,215,0,.24); background: linear-gradient(135deg, rgba(255,215,0,.09), rgba(255,215,0,.04)); }

/* Blog y artículo */
.search-panel { display: grid; grid-template-columns: 1.4fr .75fr auto auto; gap: 14px; padding: 18px; margin-bottom: 30px; align-items: end; }
.search-panel form { display: contents; }
.blog-card { display: flex; flex-direction: column; min-height: 100%; }
.blog-card .link-arrow { margin-top: auto; padding-top: 12px; }
.article-layout { width: min(960px, calc(100% - 32px)); margin-inline: auto; }
.article-shell { display: grid; grid-template-columns: minmax(0, 1fr) 300px; gap: 24px; align-items: start; width: min(1180px, calc(100% - 32px)); margin-inline: auto; }
.article-main { min-width: 0; display: grid; gap: 22px; }
.article-sidebar { position: sticky; top: 118px; display: grid; gap: 16px; }
.article-body { padding: clamp(24px, 4vw, 44px); color: #e8e8e8; font-size: clamp(17px, 1.45vw, 19px); line-height: 1.84; }
.article-body h2 { margin: 38px 0 14px; font-size: clamp(25px, 2.7vw, 36px); }
.article-body h3 { margin: 28px 0 12px; font-size: clamp(21px, 2.1vw, 27px); }
.article-body h2:first-child, .article-body h3:first-child { margin-top: 0; }
.article-body p { margin-bottom: 1.1em; }
.article-body ul, .article-body ol { padding-left: 1.25em; }
.article-body li { margin-bottom: .55em; }
.article-body a { color: #FFD700; text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
.article-body blockquote { margin: 28px 0; padding: 18px 22px; border-left: 4px solid var(--site-primary); background: rgba(255,215,0,.06); border-radius: 0 var(--site-radius) var(--site-radius) 0; color: #FFE680; }
.article-toc { padding: 20px; }
.article-toc h2, .article-toc h3 { font-size: 18px; margin-bottom: 12px; }
.article-toc ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.article-toc a { color: rgba(255,255,255,.84); font-size: 14px; font-weight: 800; }
.article-toc a:hover { color: var(--site-primary); }
.review-box { padding: 15px 16px; color: #FFE680; }
.tag-row { display: flex; flex-wrap: wrap; gap: 8px; }

/* FAQ */
.faq-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
.faq-item h3 { margin-bottom: 10px; font-size: 19px; }
.faq-list { display: grid; gap: 12px; }
.faq-detail { padding: 0; overflow: hidden; }
.faq-detail summary { cursor: pointer; padding: 16px 18px; color: #fff; font-weight: 950; list-style: none; }
.faq-detail summary::-webkit-details-marker { display: none; }
.faq-detail summary::after { content: "+"; float: right; color: var(--site-primary); font-size: 22px; line-height: 1; }
.faq-detail[open] summary::after { content: "–"; }
.faq-detail > div { padding: 0 18px 18px; color: var(--site-muted); }

/* Formularios y contacto */
label { display: block; margin-bottom: 7px; color: #f5f5f5; font-weight: 850; font-size: 14px; }
input, select, textarea { width: 100%; min-height: 46px; border: 1px solid rgba(255, 215, 0, 0.16); border-radius: 14px; padding: 12px 14px; background: rgba(10, 10, 10, 0.78); color: #FFFFFF; outline: none; transition: border-color .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease); }
textarea { min-height: 150px; resize: vertical; }
input:focus, select:focus, textarea:focus { border-color: #FFD700; box-shadow: 0 0 0 4px rgba(255, 215, 0, 0.13); background: rgba(10,10,10,.92); }
input::placeholder, textarea::placeholder { color: rgba(191,191,191,.72); }
.form-page { padding: clamp(48px, 7vw, 92px) 0; background: radial-gradient(circle at 12% 12%, rgba(255,215,0,.08), transparent 32%); }
.form-shell { display: grid; grid-template-columns: minmax(280px, .72fr) minmax(0, 1.2fr); gap: clamp(22px, 4vw, 42px); align-items: start; }
.form-card, .appointment-card { padding: clamp(24px, 4vw, 38px); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-grid .full { grid-column: 1 / -1; }
.help-text { color: var(--site-muted); font-size: 14px; }
.field-error, .error, .alert-danger { color: #FFE680; background: rgba(255,215,0,.08); border: 1px solid rgba(255,215,0,.2); padding: 10px 12px; border-radius: 12px; margin-top: 8px; }
.input-error { border-color: rgba(255,215,0,.55) !important; }
.checkbox-line { display: flex; align-items: flex-start; gap: 10px; line-height: 1.45; }
.checkbox-line input { width: auto; min-height: 0; margin-top: 3px; }
.checkbox-line a { color: #FFD700; text-decoration: underline; }
.honeypot { position: absolute !important; left: -10000px !important; width: 1px !important; height: 1px !important; overflow: hidden !important; }
.contact-layout { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 24px; align-items: start; }
.contact-panel { display: grid; gap: 16px; }
.contact-methods { display: grid; gap: 12px; margin-top: 18px; }
.contact-methods a, .contact-methods div { padding: 14px 16px; border-radius: 14px; background: rgba(255,215,0,.05); border: 1px solid rgba(255,215,0,.12); }

/* Regiones */
.geo-state-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 16px; margin-bottom: 28px; }
.geo-state-card { display: grid; gap: 8px; padding: 20px; color: #fff; }
.geo-state-card strong { color: #fff; font-size: 20px; }
.geo-state-card span { color: var(--site-muted); font-size: 14px; }
.geo-search-panel { margin-top: 26px; }
.region-card { display: flex; flex-direction: column; justify-content: space-between; min-height: 100%; }
.region-layout { display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: 24px; align-items: start; }
.region-aside { position: sticky; top: 118px; display: grid; gap: 16px; }
.region-meta-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 12px; margin-top: 24px; }
.region-meta-grid article { padding: 16px; }
.region-meta-grid strong { display: block; color: #fff; }
.region-meta-grid span { display: block; color: var(--site-muted); font-weight: 760; }
.region-related-list { display: grid; gap: 10px; margin-top: 12px; }
.location-truth { color: #FFE680; }

/* Páginas legales e informativas */
.page-shell { display: grid; gap: 22px; }
.page-card-list { display: grid; gap: 16px; }
.legal-page .article-body p, .legal-page .article-body li { color: #e4e4e4; }
.success-panel { padding: 130px 0 70px; min-height: 70vh; display: grid; align-items: center; }
.success-card { text-align: center; }

/* Footer */
.site-footer { position: relative; background: rgba(255, 215, 0, 0.035); border-top: 1px solid rgba(255, 215, 0, 0.12); backdrop-filter: blur(12px); padding: 0 0 28px; overflow: hidden; }
.site-footer::before { content: ""; position: absolute; inset: -160px auto auto -160px; width: 360px; height: 360px; border-radius: 999px; background: rgba(255,215,0,.08); filter: blur(8px); }
.footer-cta { position: relative; z-index: 1; margin-top: 0; transform: translateY(-34px); }
.footer-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1.18fr .72fr .72fr .82fr; gap: clamp(18px, 3vw, 32px); color: var(--site-muted); }
.footer-brand { display: grid; gap: 14px; }
.footer-brand-row { display: flex; gap: 13px; align-items: center; }
.footer-logo { width: 64px; height: 52px; object-fit: contain; padding: 6px; background: rgba(255,255,255,.96); border-radius: 16px; border: 1px solid rgba(255,215,0,.18); }
.footer-grid strong, .footer-grid h3 { display: block; color: #fff; margin: 0 0 12px; font-size: 16px; }
.footer-grid a { display: block; color: var(--site-muted); margin: 8px 0; font-weight: 780; }
.footer-grid a:hover { color: #FFD700; }
.footer-disclaimer, .legal-note { margin-top: 18px; padding: 15px; border-radius: 14px; background: rgba(255,215,0,.055); border: 1px solid rgba(255,215,0,.12); color: #BFBFBF; font-size: 13px; }
.footer-bottom { position: relative; z-index: 1; display: flex; flex-wrap: wrap; gap: 12px; align-items: center; justify-content: space-between; margin-top: 30px; padding-top: 20px; border-top: 1px solid rgba(255,215,0,.1); color: var(--site-muted); font-size: 13px; }
.footer-bottom-links { display: flex; flex-wrap: wrap; gap: 12px; }
.footer-bottom-links a { color: var(--site-muted); font-weight: 850; }

/* WhatsApp flotante: conserva icono y aro, mejora composición sin paleta nueva */
.whatsapp-float,
.whatsapp-float:visited,
.whatsapp-float:hover,
.whatsapp-float:focus {
    position: fixed;
    right: 20px;
    bottom: 20px;
    z-index: 1100;
    width: 62px;
    min-width: 62px;
    height: 62px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    border: 0 !important;
    box-shadow: none !important;
    color: transparent;
    font-size: 0;
    line-height: 0;
    overflow: visible;
    isolation: isolate;
}
.whatsapp-float::before { content: ""; position: absolute; inset: -8px; border-radius: 999px; border: 1px solid rgba(37, 211, 102, 0.45); animation: whatsapp-wave 1.8s ease-out infinite; pointer-events: none; z-index: 0; }
.whatsapp-pulse { position: absolute; inset: -16px; border-radius: 999px; border: 1px solid rgba(37, 211, 102, 0.28); animation: whatsapp-wave-soft 2.4s ease-out infinite; pointer-events: none; z-index: 0; background: transparent !important; }
.whatsapp-float img, .whatsapp-icon { width: 58px; height: 58px; display: block; object-fit: contain; position: relative; z-index: 2; border-radius: 0; background: transparent !important; filter: drop-shadow(0 12px 26px rgba(0,0,0,.42)); }
.whatsapp-fallback-icon { position: relative; z-index: 2; display: grid; place-items: center; width: 58px; height: 58px; border-radius: 999px; background: #25d366; color: #fff; font-size: 24px; }
@keyframes whatsapp-wave { 0% { opacity: .7; transform: scale(.88); } 100% { opacity: 0; transform: scale(1.34); } }
@keyframes whatsapp-wave-soft { 0% { opacity: .45; transform: scale(.78); } 100% { opacity: 0; transform: scale(1.45); } }

/* Reveal visual no invasivo */
[data-reveal] { opacity: 0; transform: translateY(18px); transition: opacity .55s var(--ease), transform .55s var(--ease); }
[data-reveal].is-visible { opacity: 1; transform: translateY(0); }

@media (max-width: 1120px) {
    .nav-links { gap: 1px; font-size: 12px; }
    .nav-links a:not(.btn) { padding-inline: 8px; }
    .brand-text strong { max-width: 220px; }
    .service-feature-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
    .service-feature, .service-feature.wide { grid-column: auto; }
}

@media (max-width: 980px) {
    html { scroll-padding-top: 82px; }
    .header-topline { display: none; }
    .navbar { min-height: 76px; }
    .brand-logo { width: 62px; height: 50px; }
    .brand-text strong { max-width: 210px; }
    .brand-text span { font-size: 11px; }
    .nav-toggle { display: inline-flex; }
    .nav-links {
        position: fixed;
        top: 12px;
        right: 12px;
        bottom: 12px;
        left: auto;
        z-index: 1001;
        width: min(390px, calc(100% - 24px));
        max-height: none;
        overflow-y: auto;
        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
        padding: 18px;
        background: rgba(10, 10, 10, 0.98);
        border: 1px solid rgba(255, 215, 0, 0.18);
        border-radius: 24px;
        box-shadow: 0 18px 58px rgba(0, 0, 0, 0.64);
        transform: translateX(calc(100% + 26px));
        opacity: 0;
        pointer-events: none;
        transition: transform .28s var(--ease), opacity .28s var(--ease);
    }
    .nav-links.is-open { transform: translateX(0); opacity: 1; pointer-events: auto; }
    .nav-mobile-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding-bottom: 12px; margin-bottom: 2px; border-bottom: 1px solid rgba(255,215,0,.1); }
    .nav-mobile-head strong { color: #fff; }
    .nav-mobile-head span { display: block; color: var(--site-muted); font-size: 12px; font-weight: 760; }
    .nav-mobile-close { display: inline-grid; place-items: center; width: 40px; height: 40px; border-radius: 999px; border: 1px solid rgba(255,215,0,.16); background: rgba(255,215,0,.06); color: #fff; cursor: pointer; font-weight: 950; }
    .nav-primary, .nav-secondary { display: grid; gap: 8px; }
    .nav-secondary { padding-top: 8px; border-top: 1px solid rgba(255,215,0,.09); }
    .nav-links a:not(.btn) { justify-content: space-between; min-height: 48px; padding: 13px 14px; border: 1px solid rgba(255,215,0,.09); background: rgba(255,215,0,.035); border-radius: 14px; font-size: 15px; }
    .nav-links a:not(.btn)::after { content: "→"; position: static; width: auto; height: auto; background: transparent; transform: none; color: var(--site-primary); opacity: 1; }
    .nav-cta-group { display: grid; gap: 10px; margin: 8px 0 0; }
    .nav-cta-group .btn { width: 100%; }
    .hero-grid, .two-col, .split-section, .location-grid, .patient-route, .form-shell, .contact-layout, .service-detail-grid, .article-shell, .region-layout, .section-head.split { grid-template-columns: 1fr; }
    .service-detail-aside, .article-sidebar, .region-aside { position: static; }
    .trust-strip { grid-template-columns: repeat(2, minmax(0,1fr)); margin-top: 18px; }
    .cards-grid, .content-grid, .blog-grid, .region-grid, .geo-state-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
    .process-timeline { grid-template-columns: repeat(2, minmax(0,1fr)); }
    .search-panel { grid-template-columns: 1fr 1fr; }
    .footer-cta { transform: none; margin: 26px 0; }
    .footer-grid { grid-template-columns: 1fr 1fr; }
    .cta-band { align-items: flex-start; flex-direction: column; }
}

@media (max-width: 680px) {
    .container, .container-wide, .narrow, .article-layout, .article-shell { width: min(100% - 24px, var(--container)); }
    .hero, .article-hero, .page-hero { padding-block: 44px; }
    .hero::before, .article-hero::before, .page-hero::before { inset: 10px; border-radius: 24px; }
    .brand { gap: 10px; }
    .brand-logo { width: 54px; height: 45px; border-radius: 14px; }
    .brand-text strong { max-width: 170px; font-size: 12.5px; }
    .brand-text span { font-size: 10px; letter-spacing: .06em; }
    .nav-toggle-text { display: none; }
    .hero-actions, .cta-panel { align-items: stretch; }
    .hero-actions .btn, .cta-panel .btn, .cta-band .btn { width: 100%; }
    .cta-panel .btn + .btn { margin-left: 0; }
    .hero-meta, .trust-strip, .cards-grid, .content-grid, .blog-grid, .region-grid, .geo-state-grid, .process-timeline, .faq-grid, .service-feature-grid, .region-meta-grid, .search-panel, .form-grid { grid-template-columns: 1fr; }
    .content-card, .service-card, .info-card, .faq-item, .contact-card, .appointment-card, .content-block, .blog-card, .sidebar-card, .doctor-card, .form-card, .location-card, .article-body { padding: 20px; }
    .section { padding: 46px 0; }
    .map-placeholder, .map-box { min-height: 230px; }
    .footer-grid { grid-template-columns: 1fr; }
    .footer-bottom { align-items: flex-start; flex-direction: column; }
    .whatsapp-float { right: 15px; bottom: 15px; width: 58px; min-width: 58px; height: 58px; }
    .whatsapp-icon, .whatsapp-float img, .whatsapp-fallback-icon { width: 54px; height: 54px; }
}

@media (max-width: 380px) {
    .brand-text { display: none; }
    .navbar { min-height: 70px; }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: .01ms !important; }
    [data-reveal] { opacity: 1; transform: none; }
}
