/* ============================================
   ESPACIO SALUD PB · Diseño moderno
   Paleta botánica · cálida · serena
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400;1,500&family=Inter:wght@300;400;500;600&display=swap');

:root{
  /* Colores */
  --cream:        #f6f1e8;
  --cream-soft:   #fbf7f0;
  --paper:        #ffffff;
  --ink:          #2a2a26;
  --ink-soft:     #4a4a44;
  --muted:        #8a877f;
  --line:         #e6dfd1;

  --sage:         #8a9a7b;
  --sage-deep:    #6e8164;
  --sage-soft:    #c4cdb6;
  --sage-mist:    #e8ede0;

  --terra:        #c87761;
  --terra-deep:   #a45c47;
  --terra-soft:   #e8c4b6;
  --terra-mist:   #f5e6df;

  --shadow-sm: 0 2px 8px rgba(74, 65, 50, .06);
  --shadow-md: 0 8px 24px rgba(74, 65, 50, .08);
  --shadow-lg: 0 24px 60px rgba(74, 65, 50, .12);

  /* Tipografía */
  --serif: 'Cormorant Garamond', 'Times New Roman', serif;
  --sans:  'Inter', system-ui, -apple-system, sans-serif;

  /* Layout */
  --max:    1200px;
  --gutter: clamp(1.25rem, 4vw, 2.5rem);
  --radius: 14px;
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; overflow-x:hidden; }

body{
  margin:0;
  font-family:var(--sans);
  font-weight:400;
  font-size:16px;
  line-height:1.7;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; transition:color .25s ease; }
a:hover{ color:var(--terra); }

::selection{ background:var(--terra-soft); color:var(--ink); }

/* ============================================
   TIPOGRAFÍA
   ============================================ */
h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:500;
  line-height:1.15;
  letter-spacing:-.01em;
  color:var(--ink);
  margin:0 0 .5em;
}
h1{ font-size:clamp(2.4rem, 5.5vw, 4.6rem); font-weight:400; }
h2{ font-size:clamp(1.9rem, 3.8vw, 3rem); font-weight:400; }
h3{ font-size:clamp(1.35rem, 2.2vw, 1.7rem); font-weight:500; }
h4{ font-size:1.1rem; font-weight:500; }

p{ margin:0 0 1.1em; color:var(--ink-soft); }
.eyebrow{
  font-family:var(--sans);
  font-size:.78rem;
  font-weight:500;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--terra);
  display:inline-block;
  margin-bottom:1rem;
}

.lead{
  font-family:var(--serif);
  font-size:clamp(1.15rem, 1.8vw, 1.4rem);
  font-style:italic;
  font-weight:400;
  line-height:1.5;
  color:var(--ink-soft);
}

/* Subrayado decorativo bajo titulares */
.title-underline{
  position:relative;
  padding-bottom:.7em;
}
.title-underline::after{
  content:"";
  position:absolute;
  left:0; bottom:0;
  width:60px; height:2px;
  background:var(--terra);
}
.title-underline.center{ display:inline-block; }
.title-underline.center::after{
  left:50%; transform:translateX(-50%);
}

/* ============================================
   LAYOUT
   ============================================ */
.container{
  width:100%;
  max-width:var(--max);
  margin:0 auto;
  padding-inline:var(--gutter);
}
.container-narrow{ max-width:780px; }

section{ position:relative; }

.section{
  padding-block:clamp(4rem, 9vw, 7rem);
}

.section-bg-cream{ background:var(--cream-soft); }
.section-bg-sage{ background:var(--sage-mist); }
.section-bg-paper{ background:var(--paper); }

/* ============================================
   HEADER / NAV
   ============================================ */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(246, 241, 232, .85);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s ease, background .3s ease;
}
.site-header.scrolled{
  border-bottom-color:var(--line);
  background:rgba(246, 241, 232, .95);
}
.site-header .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:2rem;
  padding-block:1.1rem;
}

.logo{
  display:flex;
  align-items:center;
  gap:.7rem;
  font-family:var(--serif);
  font-size:1.35rem;
  font-weight:500;
  letter-spacing:.04em;
  color:var(--ink);
}
.logo:hover{ color:var(--ink); }
.logo svg{
  width:34px; height:34px;
  flex-shrink:0;
  color:var(--sage-deep);
}
.logo-text{ display:flex; flex-direction:column; line-height:1; }
.logo-text small{
  font-family:var(--sans);
  font-size:.62rem;
  font-weight:500;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--terra);
  margin-top:.3rem;
}

nav .nav-links{
  display:flex;
  align-items:center;
  gap:2.2rem;
  list-style:none;
  margin:0; padding:0;
}
nav .nav-links > li > a{
  font-family:var(--sans);
  font-size:.95rem;
  font-weight:400;
  color:var(--ink);
  position:relative;
  padding:.4rem 0;
}
nav .nav-links > li > a::after{
  content:"";
  position:absolute;
  left:0; bottom:0;
  height:1.5px; width:0;
  background:var(--terra);
  transition:width .3s ease;
}
nav .nav-links > li > a:hover::after,
nav .nav-links > li > a.active::after{ width:100%; }
nav .nav-links > li > a.active{ color:var(--terra); }

/* Dropdown */
.dropdown{ position:relative; }
.dropdown > a::before{
  content:"›";
  display:inline-block;
  margin-right:.3rem;
  transform:rotate(90deg);
  font-size:.8em;
  opacity:.6;
}
.dropdown-menu{
  position:absolute;
  top:calc(100% + 14px);
  left:50%;
  transform:translateX(-50%) translateY(8px);
  min-width:280px;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  padding:.6rem;
  list-style:none;
  margin:0;
  opacity:0;
  visibility:hidden;
  transition:all .25s ease;
}
.dropdown-menu::before{
  content:"";
  position:absolute;
  top:-6px; left:50%;
  width:12px; height:12px;
  background:var(--paper);
  border-left:1px solid var(--line);
  border-top:1px solid var(--line);
  transform:translateX(-50%) rotate(45deg);
}
.dropdown:hover .dropdown-menu,
.dropdown:focus-within .dropdown-menu{
  opacity:1; visibility:visible;
  transform:translateX(-50%) translateY(0);
}
.dropdown-menu li a{
  display:block;
  padding:.7rem .9rem;
  font-size:.92rem;
  border-radius:8px;
  transition:background .2s ease, color .2s ease;
}
.dropdown-menu li a:hover{
  background:var(--cream-soft);
  color:var(--terra);
}

.cta-header{
  background:var(--terra);
  color:var(--paper) !important;
  padding:.7rem 1.4rem !important;
  border-radius:50px;
  font-size:.88rem !important;
  font-weight:500 !important;
  letter-spacing:.02em;
  transition:all .3s ease !important;
  box-shadow:0 4px 14px rgba(200,119,97,.25);
}
.cta-header:hover{
  background:var(--terra-deep);
  transform:translateY(-1px);
  box-shadow:0 6px 18px rgba(200,119,97,.35);
}
.cta-header::after{ display:none !important; }

.nav-toggle{
  display:none;
  background:none; border:none;
  font-size:1.5rem;
  color:var(--ink);
  cursor:pointer;
  padding:.4rem;
}

/* ============================================
   BOTONES
   ============================================ */
.btn{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  font-family:var(--sans);
  font-size:.92rem;
  font-weight:500;
  letter-spacing:.02em;
  padding:.95rem 1.8rem;
  border-radius:50px;
  border:1px solid transparent;
  cursor:pointer;
  transition:all .3s ease;
  text-decoration:none;
  line-height:1;
  white-space:nowrap;
}
.btn::after{
  content:"→";
  transition:transform .3s ease;
}
.btn-primary{
  background:var(--terra);
  color:var(--paper);
  box-shadow:0 4px 14px rgba(200,119,97,.25);
}
.btn-primary:hover{
  background:var(--terra-deep);
  color:var(--paper);
  transform:translateY(-2px);
  box-shadow:0 8px 22px rgba(200,119,97,.35);
}
.btn-primary:hover::after{ transform:translateX(4px); }

.btn-secondary{
  background:transparent;
  color:var(--ink);
  border-color:var(--ink-soft);
}
.btn-secondary:hover{
  background:var(--ink);
  color:var(--paper);
  border-color:var(--ink);
}
.btn-secondary:hover::after{ transform:translateX(4px); }

.btn-sage{
  background:var(--sage);
  color:var(--paper);
}
.btn-sage:hover{
  background:var(--sage-deep);
  color:var(--paper);
  transform:translateY(-2px);
}
.btn-sage:hover::after{ transform:translateX(4px); }

.btn-ghost{
  background:transparent;
  color:var(--terra);
  padding-inline:0;
  border-radius:0;
}
.btn-ghost::after{
  content:"→";
  transition:transform .3s ease;
}
.btn-ghost:hover{ color:var(--terra-deep); }
.btn-ghost:hover::after{ transform:translateX(6px); }

/* ============================================
   HERO (Index)
   ============================================ */
.hero{
  position:relative;
  min-height:calc(100vh - 76px);
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:3rem;
  align-items:center;
  padding:clamp(3rem, 7vw, 6rem) var(--gutter);
  max-width:var(--max);
  margin:0 auto;
  overflow:hidden;
}
.hero-content{ position:relative; z-index:2; }
.hero h1{
  font-size:clamp(2.4rem, 5vw, 4.2rem);
  font-weight:400;
  margin-bottom:.3em;
  line-height:1.05;
}
.hero h1 em{
  font-style:italic;
  color:var(--sage-deep);
}
.hero .name-tag{
  font-family:var(--sans);
  font-size:.78rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--terra);
  margin-bottom:1.6rem;
  display:flex;
  align-items:center;
  gap:.9rem;
}
.hero .name-tag::before{
  content:"";
  width:36px; height:1px;
  background:var(--terra);
}
.hero .lead{
  margin-block:1.2rem 2.2rem;
  max-width:520px;
}

.cta-buttons{
  display:flex;
  flex-wrap:wrap;
  gap:1rem;
}

/* Hero visual (lado derecho) */
.hero-visual{
  position:relative;
  aspect-ratio: 4/5;
  max-height:680px;
  align-self:stretch;
}
.hero-visual .frame{
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse 70% 50% at 30% 30%, rgba(196,205,182,.5), transparent 70%),
    linear-gradient(140deg, var(--sage-mist) 0%, var(--terra-mist) 100%);
  border-radius:300px 300px 24px 24px;
  overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.hero-visual .frame::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    radial-gradient(circle at 20% 80%, rgba(138,154,123,.15) 0, transparent 40%),
    radial-gradient(circle at 80% 20%, rgba(200,119,97,.12) 0, transparent 40%);
}
.hero-visual .botanical{
  position:absolute;
  width:90%;
  bottom:-2%;
  left:50%;
  transform:translateX(-50%);
  opacity:.95;
}
.hero-visual .floating-card{
  position:absolute;
  background:var(--paper);
  border-radius:14px;
  padding:1rem 1.2rem;
  box-shadow:var(--shadow-md);
  font-size:.85rem;
  display:flex;
  align-items:center;
  gap:.7rem;
  animation:float 5s ease-in-out infinite;
}
.hero-visual .card-1{
  top:8%; left:-6%;
  animation-delay:0s;
}
.hero-visual .card-2{
  bottom:18%; right:-8%;
  animation-delay:1.5s;
}
.hero-visual .card-icon{
  width:38px; height:38px;
  border-radius:50%;
  background:var(--sage-mist);
  color:var(--sage-deep);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.hero-visual .card-2 .card-icon{
  background:var(--terra-mist);
  color:var(--terra-deep);
}
.hero-visual .card-text strong{
  display:block;
  font-family:var(--serif);
  font-size:1.05rem;
  color:var(--ink);
  font-weight:500;
}
.hero-visual .card-text span{
  font-size:.78rem;
  color:var(--muted);
}

@keyframes float{
  0%,100%{ transform:translateY(0); }
  50%{    transform:translateY(-10px); }
}

/* Decoración hero: ramitas botánicas */
.hero-decoration{
  position:absolute;
  pointer-events:none;
  opacity:.4;
}
.hero-decoration.top-left{
  top:8%; left:-30px;
  width:160px;
  transform:rotate(-15deg);
}
.hero-decoration.bottom-left{
  bottom:5%; left:35%;
  width:120px;
  transform:rotate(15deg);
  opacity:.3;
}

/* ============================================
   INNER HERO (subpáginas)
   ============================================ */
.inner-hero{
  position:relative;
  padding:clamp(4rem, 9vw, 7rem) var(--gutter) clamp(3rem, 6vw, 5rem);
  background:linear-gradient(180deg, var(--sage-mist) 0%, var(--cream) 100%);
  text-align:center;
  overflow:hidden;
}
.inner-hero .container{ position:relative; z-index:2; }
.inner-hero .eyebrow{ color:var(--terra); }
.inner-hero h1{
  margin:0 auto .8rem;
  max-width:900px;
}
.inner-hero p{
  max-width:680px;
  margin:0 auto;
  font-size:1.1rem;
}

.inner-hero .botanical-decor{
  position:absolute;
  pointer-events:none;
  opacity:.25;
}
.inner-hero .botanical-decor.left{
  top:10%; left:-40px;
  width:200px;
  transform:rotate(-20deg);
}
.inner-hero .botanical-decor.right{
  bottom:-20px; right:-30px;
  width:180px;
  transform:rotate(160deg);
}

/* ============================================
   FEATURES / TARJETAS DE SERVICIO
   ============================================ */
.features-intro{
  text-align:center;
  max-width:680px;
  margin:0 auto 4rem;
}

.features-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1.6rem;
}
.feature-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:2.4rem 1.8rem 2rem;
  position:relative;
  transition:all .4s ease;
  overflow:hidden;
}
.feature-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 60%, var(--cream-soft) 100%);
  opacity:0;
  transition:opacity .4s ease;
  pointer-events:none;
}
.feature-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg);
  border-color:var(--sage-soft);
}
.feature-card:hover::before{ opacity:1; }
.feature-card .icon-circle{
  width:64px; height:64px;
  border-radius:50%;
  background:var(--sage-mist);
  color:var(--sage-deep);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:1.4rem;
  transition:transform .4s ease;
}
.feature-card:nth-child(2) .icon-circle{
  background:var(--terra-mist);
  color:var(--terra-deep);
}
.feature-card:hover .icon-circle{ transform:scale(1.06) rotate(-4deg); }
.feature-card h3{ margin-bottom:.6em; }
.feature-card p{
  font-size:.95rem;
  line-height:1.65;
  margin-bottom:1.4rem;
}
.feature-card .btn-ghost{ font-size:.9rem; }

/* ============================================
   ABOUT (split)
   ============================================ */
.about-wrapper{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:clamp(2rem, 5vw, 5rem);
  align-items:center;
}
.about-image{
  position:relative;
  aspect-ratio: 4/5;
}
.about-image .photo-frame{
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse at 50% 30%, var(--sage-soft), var(--sage-mist) 70%);
  border-radius:300px 300px 20px 20px;
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  display:flex;
  align-items:center;
  justify-content:center;
}
.about-image .photo-frame::after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:60%;
  background:linear-gradient(180deg, transparent, rgba(110,129,100,.2));
  pointer-events:none;
}
.about-image .photo-placeholder{
  position:relative;
  z-index:2;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:1rem;
  color:var(--sage-deep);
  text-align:center;
}
.about-image .photo-placeholder svg{
  width:90px;
  height:90px;
  opacity:.55;
}
.about-image .photo-placeholder span{
  font-family:var(--sans);
  font-size:.78rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--sage-deep);
  opacity:.7;
  padding:.4rem .9rem;
  border:1px dashed var(--sage-deep);
  border-radius:50px;
}
.about-image .frame-botanical{
  position:absolute;
  width:45%;
  bottom:0;
  left:-5%;
  z-index:3;
  pointer-events:none;
}
.about-image .floating-badge{
  position:absolute;
  bottom:30px; right:-30px;
  background:var(--paper);
  padding:1.2rem 1.5rem;
  border-radius:14px;
  box-shadow:var(--shadow-md);
  text-align:center;
  animation:float 6s ease-in-out infinite;
}
.about-image .floating-badge strong{
  display:block;
  font-family:var(--serif);
  font-size:2rem;
  color:var(--terra);
  font-weight:500;
  line-height:1;
}
.about-image .floating-badge span{
  font-size:.75rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
}
.about-decoration{
  position:absolute;
  width:140px;
  top:-30px; left:-30px;
  opacity:.6;
  z-index:-1;
}

.about-content h2{ margin-bottom:1.2rem; }
.about-content .signature{
  margin-top:2rem;
  padding-top:1.5rem;
  border-top:1px solid var(--line);
  display:flex;
  align-items:center;
  gap:1rem;
}
.about-content .signature-name{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.4rem;
  color:var(--terra);
}
.about-content .signature-role{
  font-size:.82rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--muted);
}

/* ============================================
   QUOTE / Cita
   ============================================ */
.quote-section{
  text-align:center;
  position:relative;
  padding-block:clamp(4rem, 8vw, 6rem);
}
.quote-section::before{
  content:"\201C";
  display:block;
  font-family:var(--serif);
  font-size:8rem;
  line-height:.8;
  color:var(--terra);
  opacity:.25;
  margin-bottom:.5rem;
}
.quote-section blockquote{
  margin:0 auto;
  max-width:780px;
  font-family:var(--serif);
  font-size:clamp(1.5rem, 3vw, 2.2rem);
  font-weight:400;
  font-style:italic;
  line-height:1.4;
  color:var(--ink);
}
.quote-section cite{
  display:block;
  margin-top:1.5rem;
  font-family:var(--sans);
  font-size:.82rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--muted);
  font-style:normal;
}

/* ============================================
   TWO-COLUMN CONTENT (subpáginas con texto)
   ============================================ */
.content-split{
  display:grid;
  grid-template-columns:.5fr 1fr;
  gap:clamp(2rem, 6vw, 5rem);
  align-items:start;
}
.content-split .col-aside{
  position:sticky;
  top:120px;
}
.content-split .col-aside .number{
  font-family:var(--serif);
  font-size:5rem;
  font-weight:300;
  line-height:.8;
  color:var(--terra);
  opacity:.5;
  display:block;
  margin-bottom:1rem;
}
.content-split .col-aside .label{
  font-family:var(--sans);
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
}
.content-split .col-main p{
  font-size:1.05rem;
  line-height:1.85;
}
.content-split .col-main p:first-of-type{
  font-family:var(--serif);
  font-size:clamp(1.3rem,2vw,1.55rem);
  font-style:italic;
  color:var(--ink);
  line-height:1.5;
  margin-bottom:1.8rem;
}

/* Tarjetas de "lo que trabajamos" en subpáginas */
.topics-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:1rem;
  margin-top:3rem;
}
.topic-pill{
  padding:1.2rem 1.4rem;
  background:var(--cream-soft);
  border:1px solid var(--line);
  border-radius:12px;
  display:flex;
  align-items:center;
  gap:.9rem;
  transition:all .3s ease;
}
.topic-pill:hover{
  background:var(--paper);
  border-color:var(--sage-soft);
  transform:translateY(-2px);
}
.topic-pill .dot{
  width:8px; height:8px;
  border-radius:50%;
  background:var(--terra);
  flex-shrink:0;
}
.topic-pill span{
  font-size:.95rem;
  color:var(--ink);
  font-weight:500;
}

/* ============================================
   MODALITY CARDS (consulta)
   ============================================ */
.modality-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.6rem;
  margin-top:3rem;
}
.modality-card{
  padding:2.4rem 2rem;
  border-radius:var(--radius);
  position:relative;
  overflow:hidden;
  transition:transform .4s ease, box-shadow .4s ease;
}
.modality-card.sage{
  background:linear-gradient(160deg, var(--sage-mist) 0%, var(--cream-soft) 100%);
  border:1px solid var(--sage-soft);
}
.modality-card.terra{
  background:linear-gradient(160deg, var(--terra-mist) 0%, var(--cream-soft) 100%);
  border:1px solid var(--terra-soft);
}
.modality-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
}
.modality-card .icon-circle{
  width:54px; height:54px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:1.2rem;
}
.modality-card.sage .icon-circle{
  background:var(--paper); color:var(--sage-deep);
}
.modality-card.terra .icon-circle{
  background:var(--paper); color:var(--terra-deep);
}
.modality-card h3{ margin-bottom:.6em; }
.modality-card .tag{
  display:inline-block;
  margin-top:1rem;
  padding:.35rem .8rem;
  font-size:.75rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  background:var(--paper);
  color:var(--ink);
  border-radius:50px;
}

/* ============================================
   BLOG
   ============================================ */
.blog-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:2rem;
  margin-bottom:4rem;
}
.blog-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  transition:all .4s ease;
  display:flex;
  flex-direction:column;
}
.blog-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-lg);
  border-color:var(--sage-soft);
}
.blog-card-image{
  aspect-ratio: 16/10;
  background:linear-gradient(135deg, var(--sage-mist), var(--terra-mist));
  position:relative;
  overflow:hidden;
}
.blog-card-image .botanical{
  position:absolute;
  width:50%;
  bottom:-10%;
  right:-5%;
  opacity:.4;
}
.blog-card-image .article-tag{
  position:absolute;
  top:1rem; left:1rem;
  padding:.4rem .9rem;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);
  border-radius:50px;
  font-size:.72rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--terra);
  font-weight:500;
}
.blog-card-content{
  padding:2rem 1.8rem;
  display:flex;
  flex-direction:column;
  flex-grow:1;
}
.blog-card h2{
  font-size:clamp(1.35rem, 2vw, 1.7rem);
  margin-bottom:.6em;
  line-height:1.25;
}
.blog-meta{
  font-family:var(--sans);
  font-size:.78rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:1rem;
}
.blog-card p{
  font-size:.95rem;
  margin-bottom:1.5rem;
  flex-grow:1;
}
.blog-card .btn-ghost{ align-self:flex-start; }

.recent-posts{
  background:var(--cream-soft);
  padding:2.5rem 2.5rem 2rem;
  border-radius:var(--radius);
  border:1px solid var(--line);
}
.recent-posts h3{ margin-bottom:1.5rem; }
.recent-posts ul{
  list-style:none;
  padding:0; margin:0;
}
.recent-posts li{
  padding:1.2rem 0;
  border-bottom:1px solid var(--line);
  display:flex;
  flex-wrap:wrap;
  gap:1rem;
  align-items:baseline;
}
.recent-posts li:last-child{ border-bottom:none; }
.recent-posts li .date{
  font-size:.78rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
  flex-shrink:0;
  min-width:140px;
}
.recent-posts li a{
  font-family:var(--serif);
  font-size:1.2rem;
  color:var(--ink);
  flex-grow:1;
  transition:color .25s ease;
}
.recent-posts li a:hover{ color:var(--terra); }

/* Blog post (artículo individual) */
.article-hero-section{
  background:linear-gradient(180deg, var(--sage-mist) 0%, var(--cream) 100%);
  padding:clamp(3rem, 7vw, 5rem) var(--gutter) clamp(2rem, 4vw, 3rem);
  text-align:center;
}
.article-hero-section .container{ max-width:780px; }
.article-hero-section .eyebrow{ margin-bottom:.8rem; }
.article-hero-section .article-meta{
  margin-top:2rem;
  font-size:.85rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--muted);
}
.article-body{
  max-width:720px;
  margin:0 auto;
  padding-block:clamp(3rem, 6vw, 5rem);
  padding-inline:var(--gutter);
}
.article-body p{
  font-size:1.1rem;
  line-height:1.85;
  margin-bottom:1.4em;
}
.article-body p:first-of-type::first-letter{
  font-family:var(--serif);
  font-size:4.2rem;
  font-weight:400;
  float:left;
  line-height:.9;
  margin:.1em .12em 0 0;
  color:var(--terra);
}
.article-body blockquote{
  margin:2.5em 0;
  padding:2rem 2.4rem;
  border-left:3px solid var(--terra);
  background:var(--cream-soft);
  font-family:var(--serif);
  font-size:1.45rem;
  line-height:1.5;
  font-style:italic;
  color:var(--ink);
  border-radius:0 12px 12px 0;
  position:relative;
}

/* ============================================
   CONTACT
   ============================================ */
.contact-wrapper{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:clamp(2rem, 5vw, 5rem);
  align-items:start;
}
.contact-info h1{
  font-size:clamp(2.4rem, 4.5vw, 3.6rem);
  line-height:1;
  margin-bottom:.2em;
}
.contact-info h1.amp{
  font-style:italic;
  color:var(--terra);
  font-weight:300;
  margin-block:.1em;
}
.contact-block{
  margin-top:2.5rem;
  padding-top:2rem;
  border-top:1px solid var(--line);
}
.contact-block .label{
  font-family:var(--sans);
  font-size:.78rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--terra);
  margin-bottom:.7rem;
  display:flex;
  align-items:center;
  gap:.6rem;
}
.contact-block .label svg{ width:16px; height:16px; }
.contact-block p,
.contact-block a{
  font-family:var(--serif);
  font-size:1.4rem;
  color:var(--ink);
  margin:0;
}
.contact-block a:hover{ color:var(--terra); }

.contact-form{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:clamp(1.8rem, 3vw, 2.8rem);
  box-shadow:var(--shadow-sm);
}
.contact-form h3{
  margin-bottom:1.6rem;
}
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
}
.contact-form label{
  display:block;
  font-size:.8rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--ink-soft);
  margin:0 0 .4rem;
  font-weight:500;
}
.contact-form input,
.contact-form textarea{
  width:100%;
  padding:.85rem 1rem;
  border:1px solid var(--line);
  border-radius:10px;
  background:var(--cream-soft);
  font-family:var(--sans);
  font-size:.95rem;
  color:var(--ink);
  transition:all .25s ease;
  margin-bottom:1.1rem;
}
.contact-form input:focus,
.contact-form textarea:focus{
  outline:none;
  border-color:var(--sage);
  background:var(--paper);
  box-shadow:0 0 0 4px rgba(138,154,123,.12);
}
.contact-form textarea{
  resize:vertical;
  min-height:130px;
}
.checkbox{
  display:flex;
  align-items:flex-start;
  gap:.7rem;
  font-size:.85rem;
  letter-spacing:0;
  text-transform:none;
  font-weight:400;
  color:var(--ink-soft);
  margin-bottom:1.4rem;
  line-height:1.5;
  cursor:pointer;
}
.checkbox input{
  width:auto;
  margin:.25rem 0 0;
  accent-color:var(--sage);
}

.privacy-note{
  margin-top:2rem;
  font-size:.8rem;
  line-height:1.65;
  color:var(--muted);
  padding:1.4rem;
  background:var(--cream-soft);
  border-radius:10px;
  border:1px solid var(--line);
}

/* ============================================
   CTA BANNER (final)
   ============================================ */
.cta-banner{
  background:linear-gradient(135deg, var(--sage) 0%, var(--sage-deep) 100%);
  color:var(--paper);
  padding:clamp(3rem, 6vw, 5rem) var(--gutter);
  text-align:center;
  position:relative;
  overflow:hidden;
}
.cta-banner::before{
  content:"";
  position:absolute;
  top:-50%; left:-10%;
  width:60%; height:200%;
  background:radial-gradient(ellipse, rgba(255,255,255,.08), transparent 60%);
  pointer-events:none;
}
.cta-banner::after{
  content:"";
  position:absolute;
  bottom:-50%; right:-10%;
  width:60%; height:200%;
  background:radial-gradient(ellipse, rgba(255,255,255,.06), transparent 60%);
  pointer-events:none;
}
.cta-banner .container{ position:relative; z-index:1; }
.cta-banner h2{
  color:var(--paper);
  margin-bottom:.4em;
}
.cta-banner p{
  color:rgba(255,255,255,.85);
  max-width:580px;
  margin:0 auto 2rem;
  font-size:1.1rem;
}
.cta-banner .btn-primary{
  background:var(--paper);
  color:var(--ink);
  box-shadow:0 6px 20px rgba(0,0,0,.15);
}
.cta-banner .btn-primary:hover{
  background:var(--cream-soft);
  color:var(--ink);
}

/* ============================================
   LEGAL / PRIVACY (texto largo)
   ============================================ */
.legal-content{
  max-width:820px;
  margin:0 auto;
}
.legal-content h2{
  margin-top:0;
  margin-bottom:2rem;
  padding-bottom:1.5rem;
  border-bottom:1px solid var(--line);
}
.legal-content h3{
  margin-top:2.6rem;
  font-size:1.25rem;
  color:var(--terra-deep);
}
.legal-content p,
.legal-content li{
  font-size:.98rem;
  line-height:1.75;
  color:var(--ink-soft);
}
.legal-content ul{
  padding-left:1.4rem;
  margin-bottom:1.4em;
}
.legal-content li{ margin-bottom:.5em; }
.legal-content strong{ color:var(--ink); font-weight:600; }

/* ============================================
   FOOTER
   ============================================ */
.site-footer{
  background:var(--ink);
  color:rgba(255,255,255,.78);
  padding:clamp(3rem, 6vw, 5rem) var(--gutter) 2rem;
  position:relative;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:3rem;
  margin-bottom:3rem;
  max-width:var(--max);
  margin-inline:auto;
}
.footer-brand .logo{ color:var(--paper); margin-bottom:1rem; }
.footer-brand .logo svg{ color:var(--sage-soft); }
.footer-brand p{
  color:rgba(255,255,255,.6);
  font-size:.92rem;
  max-width:320px;
}
.footer-col h4{
  color:var(--paper);
  font-family:var(--sans);
  font-size:.78rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  margin-bottom:1.2rem;
  font-weight:500;
}
.footer-col ul{
  list-style:none;
  padding:0; margin:0;
}
.footer-col li{ margin-bottom:.7rem; }
.footer-col a{
  color:rgba(255,255,255,.65);
  font-size:.92rem;
  transition:color .25s ease;
}
.footer-col a:hover{ color:var(--terra-soft); }
.footer-col p{
  color:rgba(255,255,255,.65);
  font-size:.92rem;
  margin:0 0 .4em;
}

.footer-bottom{
  max-width:var(--max);
  margin:0 auto;
  padding-top:2rem;
  border-top:1px solid rgba(255,255,255,.1);
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:1rem;
  font-size:.82rem;
  color:rgba(255,255,255,.5);
}
.footer-bottom a{ color:rgba(255,255,255,.6); }
.footer-bottom a:hover{ color:var(--terra-soft); }

/* ============================================
   ANIMACIONES DE ENTRADA (scroll reveal)
   Sólo ocultas si JS está habilitado (clase .js en html)
   ============================================ */
.js .reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1);
}
.js .reveal.in{
  opacity:1;
  transform:translateY(0);
}
.reveal-delay-1{ transition-delay:.1s; }
.reveal-delay-2{ transition-delay:.2s; }
.reveal-delay-3{ transition-delay:.3s; }
.reveal-delay-4{ transition-delay:.4s; }

/* Hero animations on load */
.hero-animate > *{
  opacity:0;
  animation:heroIn .9s cubic-bezier(.2,.7,.2,1) forwards;
}
.hero-animate > *:nth-child(1){ animation-delay:.1s; }
.hero-animate > *:nth-child(2){ animation-delay:.25s; }
.hero-animate > *:nth-child(3){ animation-delay:.4s; }
.hero-animate > *:nth-child(4){ animation-delay:.55s; }
.hero-animate > *:nth-child(5){ animation-delay:.7s; }
@keyframes heroIn{
  from{ opacity:0; transform:translateY(28px); }
  to  { opacity:1; transform:translateY(0); }
}

.hero-visual-animate{
  opacity:0;
  animation:visualIn 1.1s .3s cubic-bezier(.2,.7,.2,1) forwards;
}
@keyframes visualIn{
  from{ opacity:0; transform:translateY(40px) scale(.96); }
  to  { opacity:1; transform:translateY(0) scale(1); }
}

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

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 980px){
  .hero{
    grid-template-columns:1fr;
    gap:3rem;
    min-height:auto;
    text-align:left;
  }
  .hero-visual{
    max-height:520px;
    aspect-ratio:1/1;
    /* Fix Safari iOS: align-self:stretch heredado + aspect-ratio + grid
       hace que Safari calcule la anchura desde la altura del row,
       desbordando el viewport. Forzamos un ancho controlado. */
    align-self:start;
    width:100%;
    max-width:480px;
    margin-inline:auto;
  }
  .features-grid{ grid-template-columns:1fr; }
  .about-wrapper,
  .contact-wrapper{ grid-template-columns:1fr; }
  .content-split{ grid-template-columns:1fr; }
  .content-split .col-aside{ position:static; }
  .modality-grid{ grid-template-columns:1fr; }
  .blog-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:2.4rem; }
}

@media (max-width: 720px){
  .nav-toggle{ display:block; }
  nav .nav-links{
    position:fixed;
    top:72px;
    left:0; right:0;
    flex-direction:column;
    align-items:flex-start;
    background:var(--cream);
    padding:1.5rem var(--gutter) 2rem;
    gap:0;
    border-bottom:1px solid var(--line);
    box-shadow:var(--shadow-md);
    transform:translateY(calc(-100% - 100px));
    transition:transform .35s ease;
    max-height:calc(100vh - 72px);
    overflow-y:auto;
    visibility:hidden;
  }
  nav .nav-links.open{
    transform:translateY(0);
    visibility:visible;
  }
  nav .nav-links > li{
    width:100%;
    border-bottom:1px solid var(--line);
  }
  nav .nav-links > li:last-child{ border-bottom:none; padding-top:1rem; }
  nav .nav-links > li > a{
    display:block;
    padding:1rem 0;
    font-size:1rem;
  }
  .dropdown-menu{
    position:static;
    box-shadow:none;
    border:none;
    background:transparent;
    transform:none;
    opacity:1; visibility:visible;
    padding:0 0 .8rem 1rem;
    min-width:0;
  }
  .dropdown-menu::before{ display:none; }
  .dropdown-menu li a{
    padding:.5rem 0;
    font-size:.88rem;
    color:var(--muted);
  }
  .cta-header{
    width:auto;
    align-self:flex-start;
  }

  .form-row{ grid-template-columns:1fr; gap:0; }
  .footer-grid{ grid-template-columns:1fr; gap:2rem; }
  .recent-posts li{ flex-direction:column; gap:.3rem; }
  .recent-posts li .date{ min-width:0; }

  .hero-visual .floating-card.card-1{ left:0; top:0; transform:scale(.85); transform-origin:top left; }
  .hero-visual .floating-card.card-2{ right:0; bottom:8%; transform:scale(.85); transform-origin:bottom right; }
  .about-image .floating-badge{ right:0; }

  /* Hero: ajustes para que el H1 respire en pantallas pequeñas */
  .hero h1{
    font-size:clamp(1.85rem, 7.5vw, 2.4rem);
    text-wrap:balance;
  }
  .hero .lead{ text-wrap:pretty; }
  .hero-decoration{ display:none; }
}

.about-photo {
  width: 100%;
  height: 100%;
  min-height: 420px;
  object-fit: cover;
  display: block;
  border-radius: 2rem;
}


/* ============================================
   CONTACT v2 · acciones directas (WhatsApp/Email/Tel)
   ============================================ */
.contact-info h1{
  line-height:1.08;
  margin-bottom:1.4rem;
}

.contact-actions{
  display:flex;
  flex-direction:column;
  gap:.85rem;
  margin:1.6rem 0 1.4rem;
}
.contact-actions .btn{
  justify-content:flex-start;
  width:100%;
  padding:1.05rem 1.4rem;
  font-size:.95rem;
}
.contact-actions .btn svg{
  flex-shrink:0;
}
.contact-actions .btn::after{
  margin-left:auto;
}

.contact-location{
  display:inline-flex;
  align-items:center;
  gap:.8rem;
  margin-top:2.5rem;
  font-family:var(--sans);
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
}
.contact-location::before{
  content:"";
  width:28px;
  height:1px;
  background:var(--muted);
}