/* =========================================================
   DR. JAVIER CARRILLO PIÑERO — Traumatólogo Murcia
   Sistema de diseño compartido
   ========================================================= */

:root{
  --navy:#0d1b2a;
  --navy-2:#13243a;
  --teal:#1a7a6e;
  --teal-light:#2aaa99;
  --sand:#f5f0e8;
  --warm-white:#fdfbf7;
  --accent:#c8a96e;
  --text:#1c1c1c;
  --muted:#6b7280;
  --line:rgba(13,27,42,.12);
  --line-light:rgba(255,255,255,.14);
  --shadow-sm:0 1px 2px rgba(13,27,42,.06), 0 2px 8px rgba(13,27,42,.04);
  --shadow-md:0 8px 24px rgba(13,27,42,.08), 0 2px 6px rgba(13,27,42,.04);
  --shadow-lg:0 24px 60px rgba(13,27,42,.18), 0 6px 18px rgba(13,27,42,.08);
  --ease:cubic-bezier(.2,.7,.2,1);
  --container:1200px;
  --serif:"Playfair Display", "Cormorant Garamond", Georgia, serif;
  --sans:"DM Sans","Helvetica Neue", Helvetica, Arial, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--sans);
  font-weight:400;
  color:var(--text);
  background:var(--warm-white);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .25s var(--ease)}
button{font-family:inherit}

/* Selection */
::selection{background:var(--teal);color:#fff}

/* Page fade-in on load */
body{animation:pageIn .6s var(--ease) both}
@keyframes pageIn{from{opacity:0}to{opacity:1}}

/* ========= TYPOGRAPHY ========= */
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;color:var(--navy);letter-spacing:-.01em;line-height:1.15;margin:0 0 .4em}
h1{font-size:clamp(2.4rem,5.6vw,4.6rem);font-weight:600}
h2{font-size:clamp(1.9rem,3.6vw,3rem)}
h3{font-size:clamp(1.25rem,2vw,1.6rem)}
h4{font-size:1.05rem;font-family:var(--sans);font-weight:500;color:var(--navy);letter-spacing:.02em}
p{margin:0 0 1em;text-wrap:pretty}
.lede{font-size:1.18rem;color:#3a4856;line-height:1.65}

.eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--sans);font-weight:500;
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal-light);
}
.eyebrow::before{
  content:"";display:inline-block;width:36px;height:1px;background:var(--teal-light);
  transform-origin:left;transform:scaleX(0);
  animation:lineGrow 1s var(--ease) .2s forwards;
}
.eyebrow.dark{color:#fff}
.eyebrow.dark::before{background:var(--accent)}
.is-revealed .eyebrow::before,
.eyebrow.always::before{transform:scaleX(1)}

@keyframes lineGrow{to{transform:scaleX(1)}}

.section-title{margin:0 0 .35em}
.section-sub{color:var(--muted);max-width:62ch;font-size:1.05rem}

/* ========= LAYOUT ========= */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 28px}
section{padding:clamp(64px,9vw,128px) 0}
section.tight{padding:clamp(48px,7vw,96px) 0}

.grid{display:grid;gap:28px}
.two-col{grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:900px){.two-col{grid-template-columns:1.05fr 1fr;gap:80px}}

.divider{height:1px;background:var(--line);border:0;margin:0}

/* ========= BUTTONS ========= */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  padding:.95em 1.6em;border-radius:2px;
  font-family:var(--sans);font-weight:500;font-size:.95rem;
  letter-spacing:.04em;text-transform:uppercase;
  border:1px solid transparent;cursor:pointer;
  transition:all .3s var(--ease);
  white-space:nowrap;
}
.btn .arrow{transition:transform .3s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}
.btn-primary{background:var(--teal);color:#fff;box-shadow:0 6px 18px rgba(26,122,110,.25)}
.btn-primary:hover{background:#16695f;box-shadow:0 10px 28px rgba(26,122,110,.35);transform:translateY(-1px)}
.btn-outline-white{border-color:rgba(255,255,255,.7);color:#fff}
.btn-outline-white:hover{background:#fff;color:var(--navy)}
.btn-outline{border-color:var(--navy);color:var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}
.btn-ghost{color:var(--teal);padding:.5em 0;letter-spacing:.06em}
.btn-ghost:hover{color:#16695f}

/* ========= NAVBAR ========= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:80;
  padding:18px 0;
  transition:all .35s var(--ease);
  background:transparent;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(13,27,42,.78);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom-color:rgba(255,255,255,.06);
  padding:12px 0;
}
.nav .container{display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo{display:flex;align-items:center}
.nav-logo img{height:70px;width:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));transition:height .3s var(--ease)}
.nav.scrolled .nav-logo img{height:48px}
.nav-links{display:none;gap:34px;align-items:center;list-style:none;margin:0;padding:0}
@media(min-width:980px){.nav-links{display:flex}}
.nav-links a{
  color:rgba(255,255,255,.85);font-size:.92rem;font-weight:400;letter-spacing:.02em;
  position:relative;padding:6px 0;
}
.nav-links a::after{
  content:"";position:absolute;left:0;right:0;bottom:-4px;height:1px;
  background:var(--teal-light);transform:scaleX(0);transform-origin:left;
  transition:transform .3s var(--ease);
}
.nav-links a:hover,.nav-links a.active{color:#fff}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-cta{display:none}
@media(min-width:980px){.nav-cta{display:inline-flex}}

.nav-burger{
  display:flex;flex-direction:column;gap:5px;width:28px;height:28px;
  background:transparent;border:0;cursor:pointer;padding:0;align-items:center;justify-content:center;
}
.nav-burger span{display:block;width:24px;height:1.5px;background:#fff;transition:all .3s var(--ease)}
@media(min-width:980px){.nav-burger{display:none}}
.nav-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

.mobile-menu{
  position:fixed;top:0;right:-100%;width:min(86vw,380px);height:100vh;
  background:var(--navy);z-index:90;padding:96px 32px 32px;
  transition:right .4s var(--ease);
  display:flex;flex-direction:column;gap:8px;
  box-shadow:-30px 0 60px rgba(0,0,0,.3);
}
.mobile-menu.open{right:0}
.mobile-menu a{
  color:rgba(255,255,255,.85);font-size:1.05rem;padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
  display:flex;justify-content:space-between;align-items:center;
}
.mobile-menu a:hover,.mobile-menu a.active{color:var(--teal-light)}
.mobile-menu .btn{margin-top:24px;justify-content:center}
.mobile-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:85;
  opacity:0;pointer-events:none;transition:opacity .3s var(--ease);
}
.mobile-backdrop.open{opacity:1;pointer-events:auto}

/* ========= HERO ========= */
.hero{
  position:relative;min-height:100vh;background:var(--navy);
  color:#fff;overflow:hidden;display:flex;align-items:center;
  padding:140px 0 80px;
}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-bg::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 80% 30%, rgba(42,170,153,.18), transparent 50%),
    radial-gradient(circle at 10% 80%, rgba(200,169,110,.10), transparent 55%),
    linear-gradient(135deg,#0a1622 0%, #0d1b2a 50%, #122438 100%);
}
.hero-bg::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    /* Caduceus-inspired thin diagonal weave */
    repeating-linear-gradient(35deg,
      rgba(200,169,110,.05) 0,
      rgba(200,169,110,.05) 1px,
      transparent 1px,
      transparent 22px
    ),
    repeating-linear-gradient(-35deg,
      rgba(42,170,153,.045) 0,
      rgba(42,170,153,.045) 1px,
      transparent 1px,
      transparent 22px
    ),
    /* Subtle dot grid */
    radial-gradient(rgba(255,255,255,.06) 1px, transparent 1.4px);
  background-size: 44px 44px, 44px 44px, 28px 28px;
  background-position: 0 0, 0 0, 0 0;
  mask-image: radial-gradient(ellipse at 30% 50%, #000 0%, rgba(0,0,0,.6) 55%, transparent 90%);
  -webkit-mask-image: radial-gradient(ellipse at 30% 50%, #000 0%, rgba(0,0,0,.6) 55%, transparent 90%);
  opacity:.9;
}
.hero::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;z-index:1;
  background:linear-gradient(90deg, transparent 0%, rgba(200,169,110,.5) 20%, rgba(42,170,153,.6) 50%, rgba(200,169,110,.5) 80%, transparent 100%);
  opacity:.6;
}
.hero::after{
  /* Soft glow orb anchored bottom-left to add depth behind the portrait area */
  content:"";position:absolute;left:-10%;bottom:-20%;
  width:60vmax;height:60vmax;border-radius:50%;
  background:radial-gradient(circle, rgba(42,170,153,.10) 0%, transparent 60%);
  pointer-events:none;z-index:0;
  animation:heroGlow 12s ease-in-out infinite alternate;
}
@keyframes heroGlow{
  0%{transform:translate(0,0) scale(1);opacity:.7}
  100%{transform:translate(40px,-30px) scale(1.08);opacity:1}
}
.hero-bg canvas{position:absolute;inset:0;width:100%;height:100%;opacity:.35}
.hero-portrait{
  position:absolute;right:40px;bottom:0;height:92vh;max-height:100%;width:auto;
  z-index:1;pointer-events:none;
  opacity:0;transform:translate(40px,30px) scale(.96);
  display:none;
  animation:heroPortraitIn 1.6s cubic-bezier(.2,.7,.2,1) .35s forwards;
}
@keyframes heroPortraitIn{
  0%{opacity:0;transform:translate(60px,40px) scale(.96)}
  100%{opacity:.95;transform:translate(0,0) scale(1)}
}
@media(min-width:900px){.hero-portrait{display:block}}
.hero .container{position:relative;z-index:2}
.hero-content{max-width:680px}
.hero-content > *{opacity:0;transform:translateY(20px);animation:rise .9s var(--ease) forwards}
.hero-content > *:nth-child(1){animation-delay:.15s}
.hero-content > *:nth-child(2){animation-delay:.30s}
.hero-content > *:nth-child(3){animation-delay:.45s}
.hero-content > *:nth-child(4){animation-delay:.60s}
@keyframes rise{to{opacity:1;transform:none}}

.hero h1{color:#fff;font-weight:500}
.hero h1 em{font-style:italic;color:var(--teal-light);font-weight:400}
.hero .lede{color:rgba(255,255,255,.78);max-width:54ch;margin-top:1.4em}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:2.2em}

.hero-scroll{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,.45);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
  display:none;flex-direction:column;align-items:center;gap:12px;z-index:2;
}
@media(min-width:900px){.hero-scroll{display:flex}}
.hero-scroll::after{
  content:"";width:1px;height:48px;background:rgba(255,255,255,.3);
  animation:scrollHint 2s var(--ease) infinite;
}
@keyframes scrollHint{0%,100%{transform:scaleY(1);transform-origin:top}50%{transform:scaleY(.3);transform-origin:top}}

/* Compact hero (inner pages) */
.hero-compact{min-height:60vh;padding:160px 0 80px}
.hero-compact h1{font-size:clamp(2.2rem,4.4vw,3.6rem)}

/* ========= TRUST BAR ========= */
.trust{background:var(--sand);padding:48px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:32px;text-align:center;align-items:center;justify-items:center;
}
@media(min-width:760px){.trust-grid{grid-template-columns:repeat(3,1fr)}}
.trust-item{position:relative}
.trust-item + .trust-item::before{
  content:"";position:absolute;left:-16px;top:50%;transform:translateY(-50%);
  width:1px;height:48px;background:var(--line);
  display:none;
}
@media(min-width:760px){.trust-item + .trust-item::before{display:block}}
.trust-num{font-family:var(--serif);font-size:clamp(2rem,3.4vw,2.8rem);color:var(--navy);line-height:1;font-weight:600}
.trust-num .unit{font-size:.6em;color:var(--accent);margin-left:.1em}
.trust-label{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:10px}

/* ========= REVEAL ANIMATION ========= */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease), transform .9s var(--ease)}
.reveal.is-revealed{opacity:1;transform:none}
.reveal-stagger > *{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease), transform .8s var(--ease)}
.reveal-stagger.is-revealed > *{opacity:1;transform:none}
.reveal-stagger.is-revealed > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.is-revealed > *:nth-child(2){transition-delay:.15s}
.reveal-stagger.is-revealed > *:nth-child(3){transition-delay:.25s}
.reveal-stagger.is-revealed > *:nth-child(4){transition-delay:.35s}
.reveal-stagger.is-revealed > *:nth-child(5){transition-delay:.45s}
.reveal-stagger.is-revealed > *:nth-child(6){transition-delay:.55s}
.reveal-stagger.is-revealed > *:nth-child(7){transition-delay:.65s}
.reveal-stagger.is-revealed > *:nth-child(8){transition-delay:.75s}

/* ========= SECTION HEADER ========= */
.section-header{margin-bottom:56px;max-width:780px}
.section-header.center{margin-left:auto;margin-right:auto;text-align:center}
.section-header.center .eyebrow{justify-content:center}

/* ========= CARDS / SPECIALTIES ========= */
.cards{display:grid;gap:22px;grid-template-columns:1fr}
@media(min-width:680px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.cards.cols-3{grid-template-columns:repeat(3,1fr)}}

.card{
  position:relative;background:#fff;border:1px solid var(--line);
  padding:36px 32px;transition:all .35s var(--ease);
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;min-height:280px;
  overflow:hidden;
}
.card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--teal);transform:scaleX(0);transform-origin:left;
  transition:transform .4s var(--ease);
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);background:#fff}
.card:hover::before{transform:scaleX(1)}
.card-icon{
  width:64px;height:64px;
  border-radius:50%;
  background:rgb(26,122,110);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:8px;
  flex-shrink:0;
}
.card-icon svg{width:36px;height:36px}
.card-icon img{width:38px;height:38px;object-fit:contain}
.card h3{margin:0}
.card p{color:var(--muted);font-size:.96rem;margin:0;flex:1}
.card .more{
  color:var(--teal);font-weight:500;font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.5em;margin-top:auto;
}
.card .more .arrow{transition:transform .3s var(--ease)}
.card:hover .more .arrow{transform:translateX(4px)}

/* Image card */
.card-image{padding:0;overflow:hidden}
.card-image .img{aspect-ratio:4/3;background:#eee;overflow:hidden}
.card-image .img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.card-image:hover .img img{transform:scale(1.05)}
.card-image .body{padding:28px 28px 32px;display:flex;flex-direction:column;gap:12px}

/* ========= ABOUT SECTION ========= */
.about{background:var(--warm-white);position:relative;overflow:hidden}
.about .deco{
  position:absolute;right:-60px;top:80px;width:240px;height:240px;opacity:.06;
  border:1px solid var(--navy);transform:rotate(45deg);pointer-events:none;
}
.about-portrait{
  position:relative;aspect-ratio:4/5;background:var(--sand);overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.about-portrait img{width:100%;height:100%;object-fit:cover}
.about-portrait::after{
  content:"";position:absolute;inset:auto -16px -16px auto;width:60%;height:30%;
  border-right:1px solid var(--accent);border-bottom:1px solid var(--accent);
  z-index:-1;
}
.about-quote{
  font-family:var(--serif);font-style:italic;font-size:1.18rem;color:var(--navy);
  border-left:2px solid var(--accent);padding-left:20px;margin:24px 0;line-height:1.55;
}
.signature{height:64px;width:auto;opacity:.85;margin-top:14px}

/* ========= ABOUT BIO ========= */
.about-bio{padding:100px 0;background:var(--warm-white)}
.about-bio-grid{
  display:grid;grid-template-columns:1fr;gap:64px;align-items:start;
}
@media(min-width:900px){
  .about-bio-grid{grid-template-columns:420px 1fr;gap:80px}
}
.about-bio-photo{position:sticky;top:120px}
.about-bio-badges{
  margin-top:24px;display:flex;flex-wrap:wrap;gap:16px;align-items:center;
  padding:20px;background:#fff;border:1px solid var(--line);
  box-shadow:0 2px 12px rgba(13,27,42,.06);
}
.badge-topdoctors img{
  height:52px;width:auto;display:block;
  transition:opacity .2s;
}
.badge-topdoctors:hover img{opacity:.8}
.about-bio-text h2{margin:.35em 0 1em;font-size:clamp(1.6rem,2.8vw,2.2rem)}
.about-bio-text p{margin-bottom:1.1em;color:var(--muted);line-height:1.75}
.about-bio-booking{
  margin-top:36px;padding-top:32px;
  border-top:1px solid var(--line);
}
.about-bio-booking iframe{
  border:none;overflow:hidden;width:100%;height:244px;
  border-radius:2px;
}

/* ========= ENTREVISTAS ========= */
.entrevistas{padding:100px 0;background:#fff}
.entrevistas-grid{
  display:grid;grid-template-columns:1fr;gap:32px;margin-top:56px;
}
@media(min-width:700px){.entrevistas-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1100px){.entrevistas-grid{grid-template-columns:repeat(3,1fr)}}
.entrevista-card{
  background:#fff;border:1px solid var(--line);
  box-shadow:0 2px 16px rgba(13,27,42,.06);
  transition:box-shadow .3s var(--ease),transform .3s var(--ease);
  overflow:hidden;
}
.entrevista-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.entrevista-thumb{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--navy)}
.entrevista-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s var(--ease)}
.entrevista-card:hover .entrevista-thumb img{transform:scale(1.04)}
.entrevista-play{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  opacity:.85;transition:opacity .2s;
}
.entrevista-card:hover .entrevista-play{opacity:1}
.entrevista-play svg{width:64px;height:64px}
.entrevista-meta{padding:24px 28px 28px}
.entrevista-tag{
  display:inline-block;font-size:.72rem;font-weight:500;letter-spacing:.18em;
  text-transform:uppercase;color:var(--teal);margin-bottom:12px;
}
.entrevista-meta h3{
  font-family:var(--serif);font-size:1.15rem;color:var(--navy);
  margin:0 0 16px;line-height:1.35;
}
.entrevista-link{
  font-size:.88rem;font-weight:500;color:var(--navy);
  display:inline-flex;align-items:center;gap:.4em;
  border-bottom:1px solid var(--line);padding-bottom:2px;
  transition:color .2s,border-color .2s;
}
.entrevista-link:hover{color:var(--teal);border-color:var(--teal)}

/* ========= TIMELINE ========= */
.timeline{margin:32px 0;position:relative;padding-left:24px}
.timeline::before{
  content:"";position:absolute;left:0;top:8px;bottom:8px;width:1px;background:var(--line);
}
.timeline-item{position:relative;padding-bottom:20px}
.timeline-item::before{
  content:"";position:absolute;left:-28px;top:8px;width:8px;height:8px;
  background:var(--accent);border-radius:50%;
}
.timeline-year{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);font-weight:500}
.timeline-text{color:var(--text);font-size:.98rem;margin:4px 0 0}

/* ========= OR / DARK SECTION ========= */
.dark{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.dark h2{color:#fff}
.dark .section-sub{color:rgba(255,255,255,.7)}
.dark .eyebrow{color:var(--teal-light)}

.masonry{
  column-count:1;column-gap:18px;
}
@media(min-width:680px){.masonry{column-count:2}}
@media(min-width:1000px){.masonry{column-count:3}}
.masonry .tile{
  break-inside:avoid;margin-bottom:18px;position:relative;overflow:hidden;cursor:pointer;
  background:#0a1622;border:1px solid rgba(255,255,255,.06);
}
.masonry .tile img{width:100%;height:auto;display:block;transition:all .6s var(--ease)}
.masonry .tile::after{
  content:"";position:absolute;inset:0;background:linear-gradient(0deg, rgba(13,27,42,.4), transparent 50%);
  opacity:0;transition:opacity .3s var(--ease);
}
.masonry .tile:hover img{transform:scale(1.04);filter:brightness(1.1)}
.masonry .tile:hover::after{opacity:1}

.hospitals{display:grid;grid-template-columns:1fr;gap:20px;margin-top:48px}
@media(min-width:760px){.hospitals{grid-template-columns:1fr 1fr}}
.hospital{
  border:1px solid rgba(255,255,255,.12);padding:32px;display:flex;gap:20px;align-items:flex-start;
  background:rgba(255,255,255,.02);
}
.hospital-num{font-family:var(--serif);font-size:2rem;color:var(--accent);line-height:1}
.hospital h4{color:#fff;font-family:var(--serif);font-size:1.35rem;margin:0 0 8px}
.hospital p{color:rgba(255,255,255,.65);margin:0;font-size:.92rem}

/* ========= LIGHTBOX ========= */
.lightbox{
  position:fixed;inset:0;background:rgba(8,16,28,.94);z-index:100;
  display:none;align-items:center;justify-content:center;padding:32px;
  opacity:0;transition:opacity .3s var(--ease);
}
.lightbox.open{display:flex;opacity:1}
.lightbox img{max-width:92vw;max-height:88vh;box-shadow:var(--shadow-lg)}
.lightbox .close{
  position:absolute;top:24px;right:24px;width:44px;height:44px;
  background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3);
  cursor:pointer;font-size:1.4rem;
}

/* ========= CTA BANNER ========= */
.cta-banner{
  background:linear-gradient(115deg, var(--navy) 0%, #0e3b3b 60%, var(--teal) 130%);
  color:#fff;text-align:center;position:relative;overflow:hidden;
}
.cta-banner::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 20%, rgba(200,169,110,.15), transparent 40%),
             radial-gradient(circle at 80% 80%, rgba(42,170,153,.25), transparent 50%);
  pointer-events:none;
}
.cta-banner h2{color:#fff;max-width:18ch;margin:0 auto .3em}
.cta-banner p{color:rgba(255,255,255,.8);max-width:50ch;margin:0 auto 2em;font-size:1.1rem}
.cta-banner .btn{background:#fff;color:var(--navy);font-weight:500;box-shadow:0 14px 40px rgba(0,0,0,.3)}
.cta-banner .btn:hover{background:var(--accent);color:#fff;transform:translateY(-2px)}
.cta-banner .container{position:relative;z-index:1}

/* ========= TESTIMONIALS ========= */
.testimonials{background:var(--navy)}
.testimonials .section-header h2{color:#fff}
.testi-track{display:flex;gap:24px;overflow:hidden;scroll-snap-type:x mandatory}
.testi-card{
  flex:0 0 100%;
  background:rgba(255,255,255,0.04);
  border-left:3px solid var(--teal);
  border-top:none;border-right:none;border-bottom:none;
  padding:36px 36px 36px 40px;
  scroll-snap-align:start;
  display:flex;flex-direction:column;gap:20px;
  position:relative;overflow:hidden;
}
@media(min-width:760px){.testi-card{flex:0 0 calc(50% - 12px)}}
.testi-bigquote{
  position:absolute;top:-10px;right:20px;
  font-family:Georgia,serif;font-size:120px;line-height:1;
  color:rgba(255,255,255,0.06);
  pointer-events:none;user-select:none;
}
.testi-quote{
  font-family:var(--serif);font-style:italic;
  font-size:1.05rem;color:rgba(255,255,255,0.88);line-height:1.65;
  position:relative;z-index:1;
}
.testi-footer{margin-top:auto;padding-top:20px;border-top:1px solid rgba(255,255,255,0.1)}
.testi-name{font-weight:600;font-size:.92rem;color:#fff;letter-spacing:0.01em}
.testi-meta{font-size:.78rem;color:var(--teal);margin-top:3px;letter-spacing:0.02em}

.testi-nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:36px}
.testi-prev,.testi-next{
  width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.2);
  background:transparent;color:rgba(255,255,255,.7);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;transition:all .25s var(--ease);
  flex-shrink:0;
}
.testi-prev:hover,.testi-next:hover{background:var(--teal);color:#fff;border-color:var(--teal)}

/* ========= FAQ ========= */
.faq{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line);padding:0}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  padding:24px 0;cursor:pointer;font-family:var(--serif);font-size:1.18rem;color:var(--navy);
  user-select:none;
}
.faq-q .toggle{
  width:32px;height:32px;flex:0 0 32px;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--teal);
  transition:all .3s var(--ease);
}
.faq-item.open .faq-q .toggle{background:var(--teal);color:#fff;border-color:var(--teal);transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease);color:var(--muted)}
.faq-a-inner{padding:0 0 24px;max-width:74ch}
.faq-item.open .faq-a{max-height:600px}

/* ========= CONTACT ========= */
.contact-grid{display:grid;grid-template-columns:1fr;gap:48px}
@media(min-width:900px){.contact-grid{grid-template-columns:1.1fr .9fr;gap:72px}}
.form-field{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.form-field label{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:500}
.form-field input,
.form-field textarea,
.form-field select{
  border:0;border-bottom:1px solid var(--line);
  padding:12px 0;background:transparent;font-family:var(--sans);font-size:1rem;color:var(--text);
  transition:border-color .3s var(--ease);
}
.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus{outline:none;border-bottom-color:var(--teal)}
.form-field textarea{resize:vertical;min-height:100px}
.form-field.error input,.form-field.error textarea{border-bottom-color:#c4382c}
.form-field .err{color:#c4382c;font-size:.78rem;display:none}
.form-field.error .err{display:block}
.form-status{margin-top:16px;font-size:.92rem;color:var(--teal);display:none}
.form-status.show{display:block}

.contact-info{display:flex;flex-direction:column;gap:30px}
.info-block .info-label{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:500;margin-bottom:8px}
.info-block .info-value{font-family:var(--serif);font-size:1.4rem;color:var(--navy);line-height:1.3}
.info-block .info-value a{color:var(--navy);border-bottom:1px solid transparent;transition:border-color .3s var(--ease)}
.info-block .info-value a:hover{border-bottom-color:var(--accent)}
.map-placeholder{
  aspect-ratio:4/3;background:var(--navy);position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:32px 32px;
}
.map-pin{
  width:18px;height:18px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 6px rgba(200,169,110,.2), 0 0 0 14px rgba(200,169,110,.1);
  animation:pinPulse 2s ease-in-out infinite;
}
@keyframes pinPulse{0%,100%{box-shadow:0 0 0 6px rgba(200,169,110,.2), 0 0 0 14px rgba(200,169,110,.1)}50%{box-shadow:0 0 0 10px rgba(200,169,110,.25), 0 0 0 22px rgba(200,169,110,.08)}}

.whatsapp-cta{
  display:inline-flex;align-items:center;gap:12px;padding:14px 24px;
  background:#25d366;color:#fff;font-weight:500;font-size:.95rem;
  border-radius:2px;transition:all .3s var(--ease);
}
.whatsapp-cta:hover{background:#1eb955;transform:translateY(-2px);box-shadow:0 10px 28px rgba(37,211,102,.3)}
.whatsapp-cta img{width:22px;height:22px;filter:brightness(0) invert(1)}

/* ========= FOOTER ========= */
.footer{background:var(--navy);color:rgba(255,255,255,.7);padding:48px 0 32px;position:relative}

.footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, var(--accent) 50%, transparent);
  opacity:.3;
}
.footer-grid{
  display:grid;gap:48px;grid-template-columns:1fr;
  padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08);
}
@media(min-width:760px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}}
.footer-logo img{height:60px;width:auto;margin-bottom:20px}
.footer-about{font-size:.92rem;line-height:1.6;max-width:36ch}
.footer h5{color:#fff;font-family:var(--sans);font-size:.8rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;margin:0 0 20px}
.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.footer a{font-size:.92rem;color:rgba(255,255,255,.7);transition:color .3s var(--ease)}
.footer a:hover{color:var(--teal-light)}
.footer .social{display:flex;gap:14px;margin-top:20px}
.footer .social a{
  width:38px;height:38px;border:1px solid rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  transition:all .3s var(--ease);
}
.footer .social a:hover{border-color:var(--teal-light);background:var(--teal-light)}
.footer .social img{width:16px;height:16px;filter:brightness(0) invert(1);opacity:.85}
.footer-bottom{
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;
  padding-top:32px;font-size:.82rem;color:rgba(255,255,255,.5);
}
.footer-bottom .legal{display:flex;flex-wrap:wrap;gap:24px}

/* ========= MISC ========= */
.split-quote{
  background:var(--sand);padding:80px 0;
}
.split-quote blockquote{
  margin:0;max-width:920px;margin-inline:auto;text-align:center;
  font-family:var(--serif);font-style:italic;font-size:clamp(1.4rem,2.4vw,2rem);
  color:var(--navy);line-height:1.45;
}
.split-quote .attr{font-family:var(--sans);font-style:normal;font-size:.85rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:24px;display:block}

.criteria-list{display:grid;grid-template-columns:1fr;gap:16px;margin:24px 0}
@media(min-width:680px){.criteria-list{grid-template-columns:1fr 1fr}}
.criteria-item{
  display:flex;gap:16px;padding:20px;background:var(--warm-white);border:1px solid var(--line);
}
.criteria-item .num{font-family:var(--serif);font-size:1.4rem;color:var(--accent);line-height:1;flex:0 0 auto}
.criteria-item p{margin:0;font-size:.96rem;color:var(--text)}

/* Floating WhatsApp */
.fab-wa{
  position:fixed;bottom:24px;right:24px;z-index:70;
  width:56px;height:56px;border-radius:50%;background:#25d366;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 30px rgba(37,211,102,.4);
  transition:all .3s var(--ease);
}
.fab-wa:hover{transform:scale(1.08)}
.fab-wa img{width:28px;height:28px;filter:brightness(0) invert(1)}

/* ========= CONTACT — PREMIUM ========= */
.form-section{
  position:relative;background:var(--warm-white);
  padding:120px 0 140px;overflow:hidden;
}
.form-section::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(900px 500px at 88% -10%, rgba(26,122,110,.08), transparent 60%),
    radial-gradient(700px 500px at -5% 110%, rgba(200,169,110,.10), transparent 60%);
  pointer-events:none;
}
.form-bg-grid{
  position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:
    linear-gradient(rgba(13,27,42,.04) 1px,transparent 1px),
    linear-gradient(90deg, rgba(13,27,42,.04) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse at 50% 30%, #000 30%, transparent 70%);
}
.form-section .container{position:relative;z-index:2}

.form-header{max-width:760px;margin:0 auto 56px;text-align:center}
.form-header h2{margin:14px 0 14px}
.form-header .lede{color:var(--muted);max-width:64ch;margin:0 auto}

.form-shell{
  display:grid;grid-template-columns:1fr;gap:0;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:
    0 1px 0 rgba(13,27,42,.04),
    0 30px 80px -40px rgba(13,27,42,.35),
    0 8px 24px -12px rgba(13,27,42,.18);
  position:relative;border-radius:2px;overflow:hidden;
}
.form-shell::before{
  content:"";position:absolute;left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg, var(--teal) 0%, var(--teal-light) 35%, var(--accent) 100%);
  z-index:3;
}
@media(min-width:980px){
  .form-shell{grid-template-columns:.85fr 1.15fr}
}

/* LEFT side — dark info column */
.form-side{
  background:
    radial-gradient(600px 400px at 0% 0%, rgba(42,170,153,.16), transparent 60%),
    linear-gradient(180deg, #102234 0%, #0a1622 100%);
  color:#fff;padding:48px 44px;position:relative;
}
.form-side::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(ellipse at 100% 100%, #000 0%, transparent 70%);
  opacity:.7;
}
.form-side-inner{position:relative;z-index:1;display:flex;flex-direction:column;gap:32px;height:100%}

.form-mark{display:flex;align-items:center;gap:14px}
.form-mark span{font-family:var(--serif);font-size:1rem;color:rgba(255,255,255,.85)}
.form-side-title{
  font-family:var(--serif);font-size:clamp(1.6rem,2.2vw,2rem);
  font-weight:500;color:#fff;line-height:1.15;margin:0;
}
.form-side-lede{color:rgba(255,255,255,.72);font-size:.98rem;line-height:1.55;margin:-12px 0 0;max-width:38ch}

.form-channels{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.channel{
  display:grid;grid-template-columns:42px 1fr auto;align-items:center;gap:16px;
  padding:16px 18px;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  transition:all .3s var(--ease);color:#fff;
}
.channel:hover{
  background:rgba(42,170,153,.12);
  border-color:rgba(42,170,153,.5);
  transform:translateX(3px);
}
.channel-icon{
  width:42px;height:42px;display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.18);color:var(--teal-light);
  border-radius:50%;
}
.channel-body{display:flex;flex-direction:column;gap:2px;line-height:1.2}
.channel-lbl{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:500}
.channel-val{font-family:var(--serif);font-size:1.08rem;color:#fff}
.channel-arrow{color:var(--accent);font-size:1.1rem;transition:transform .3s var(--ease)}
.channel:hover .channel-arrow{transform:translateX(4px)}

.form-hours{
  border-top:1px solid rgba(255,255,255,.1);
  border-bottom:1px solid rgba(255,255,255,.1);
  padding:20px 0;display:flex;flex-direction:column;gap:10px;
}
.hours-title{display:flex;align-items:center;gap:10px;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:6px;font-weight:500}
.hours-title .dot{width:8px;height:8px;border-radius:50%;background:#2aaa99;box-shadow:0 0 0 4px rgba(42,170,153,.2);animation:pinPulse 2s ease-in-out infinite}
.hours-row{display:flex;justify-content:space-between;font-size:.92rem;color:rgba(255,255,255,.85)}
.hours-row span:last-child{color:rgba(255,255,255,.6)}

.form-quote{
  margin:auto 0 0;position:relative;padding:0 0 0 22px;
  font-family:var(--serif);font-style:italic;font-size:1.02rem;line-height:1.55;
  color:rgba(255,255,255,.88);border-left:1px solid var(--accent);
}
.form-quote .q-mark{position:absolute;left:-2px;top:-18px;font-size:3rem;color:var(--accent);line-height:1;font-family:var(--serif)}
.form-quote footer{margin-top:10px;font-family:var(--sans);font-style:normal;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(200,169,110,.85)}

/* RIGHT side — form */
.form-main{padding:48px 44px;background:#fff;position:relative}
@media(min-width:980px){.form-main{padding:56px 56px 48px}}

.form-steps{
  display:flex;align-items:center;gap:10px;margin-bottom:36px;flex-wrap:wrap;
  padding-bottom:24px;border-bottom:1px solid var(--line);
}
.form-steps .step{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.form-steps .step i{
  font-family:var(--serif);font-style:normal;font-size:.85rem;letter-spacing:0;
  width:26px;height:26px;border:1px solid var(--line);border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;color:var(--muted);
}
.form-steps .step.active{color:var(--navy)}
.form-steps .step.active i{border-color:var(--teal);background:var(--teal);color:#fff}
.form-steps .step-line{flex:1;min-width:20px;height:1px;background:var(--line)}

.contact-form.premium{display:flex;flex-direction:column;gap:24px}

.ff{position:relative;display:flex;flex-direction:column}
.ff input:not([type="radio"]):not([type="checkbox"]),.ff textarea{
  appearance:none;-webkit-appearance:none;
  width:100%;background:transparent;border:0;
  border-bottom:1px solid var(--line);
  padding:24px 0 10px;
  font-family:var(--sans);font-size:1.02rem;color:var(--text);
  transition:border-color .3s var(--ease);
}
.ff textarea{padding-top:30px;resize:vertical;min-height:110px;line-height:1.55}
.ff > label:not(.ff-static){
  position:absolute;left:0;top:24px;
  font-size:1rem;color:var(--muted);pointer-events:none;
  transition:all .25s var(--ease);font-weight:400;letter-spacing:0;text-transform:none;
}
.ff input:not([type="radio"]):not([type="checkbox"]):focus,.ff textarea:focus{outline:none;border-bottom-color:var(--teal)}
.ff input:not([type="radio"]):not([type="checkbox"]):focus + label,
.ff textarea:focus + label,
.ff input:not([type="radio"]):not([type="checkbox"]):not(:placeholder-shown) + label,
.ff textarea:not(:placeholder-shown) + label,
.ff textarea + label{
  top:0;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--teal);font-weight:500;
}
.ff .ff-line{
  position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--teal);
  transition:width .35s var(--ease);
}
.ff input:focus ~ .ff-line,.ff textarea:focus ~ .ff-line{width:100%}
.ff-static{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:500;margin-bottom:14px;margin-top:8px;display:block}
.ff-row{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:560px){.ff-row{grid-template-columns:1fr 1fr}}

/* Chip grid (motivo) */
.ff-select{display:flex;flex-direction:column;gap:12px;position:static}
.chip-grid{display:flex;flex-wrap:wrap;gap:10px;position:relative;z-index:1;min-height:50px;align-content:flex-start}
.chip{position:relative;cursor:pointer}
.chip input{position:absolute;opacity:0;inset:0;cursor:pointer}
.chip span{
  display:inline-flex;align-items:center;gap:8px;padding:10px 16px;
  border:1px solid var(--line);font-size:.92rem;color:var(--text);
  transition:all .25s var(--ease);background:#fff;
  border-radius:999px;
}
.chip:hover span{border-color:var(--teal);color:var(--teal)}
.chip input:checked + span{
  background:var(--navy);color:#fff;border-color:var(--navy);
  box-shadow:0 6px 18px -6px rgba(13,27,42,.4);
}
.chip input:checked + span::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--teal-light);
}

/* Contact pref */
.ff-pref{display:flex;flex-direction:column;gap:12px}
.pref-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.pref{position:relative;cursor:pointer}
.pref input{position:absolute;opacity:0;inset:0;cursor:pointer}
.pref span{
  display:flex;align-items:center;justify-content:center;
  padding:14px;border:1px solid var(--line);font-size:.92rem;color:var(--text);
  transition:all .25s var(--ease);background:#fff;text-align:center;
}
.pref:hover span{border-color:var(--teal);color:var(--teal)}
.pref input:checked + span{background:var(--teal);color:#fff;border-color:var(--teal)}

/* Premium checkbox */
.check.premium{
  display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:flex-start;
  font-size:.88rem;color:var(--muted);line-height:1.5;cursor:pointer;
  padding:14px 16px;background:var(--sand);border:1px solid var(--line);
}
.check.premium input{
  appearance:none;-webkit-appearance:none;
  width:18px;height:18px;border:1.5px solid var(--muted);background:#fff;
  margin-top:2px;cursor:pointer;position:relative;flex:0 0 18px;border-radius:3px;
  transition:all .25s var(--ease);
}
.check.premium input:checked{background:var(--teal);border-color:var(--teal)}
.check.premium input:checked::after{
  content:"";position:absolute;left:5px;top:1px;width:5px;height:10px;
  border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);
}
.check.premium a{color:var(--navy);text-decoration:underline;text-underline-offset:3px}

.form-actions{
  display:flex;flex-wrap:wrap;align-items:center;gap:18px;margin-top:8px;
}
.btn-lg{padding:16px 32px;font-size:.95rem;letter-spacing:.14em}
.btn-wa-alt{
  font-size:.88rem;color:var(--muted);text-decoration:none;
  border-bottom:1px solid var(--line);padding-bottom:2px;
  transition:all .3s var(--ease);
}
.btn-wa-alt:hover{color:#1eb955;border-bottom-color:#1eb955}

.form-trust{
  display:flex;flex-wrap:wrap;gap:24px;margin-top:18px;padding-top:22px;
  border-top:1px dashed var(--line);
}
.trust-item{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;color:var(--muted);letter-spacing:.04em}
.trust-item svg{color:var(--teal);flex:0 0 auto}

/* MAP BLOCK */
.map-block{
  margin-top:56px;background:#fff;border:1px solid var(--line);
  box-shadow:0 1px 0 rgba(13,27,42,.04), 0 24px 60px -30px rgba(13,27,42,.25);
  position:relative;border-radius:2px;overflow:hidden;
}
.map-block-head{
  display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;align-items:flex-end;
  padding:32px 36px 24px;
}
.map-block-head h3{margin:6px 0 4px;font-family:var(--serif);font-size:clamp(1.4rem,2vw,1.8rem);color:var(--navy)}
.map-addr{color:var(--muted);font-size:.95rem;margin:0}
.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;padding:12px 22px;
  border:1px solid var(--navy);color:var(--navy);background:transparent;font-size:.82rem;
  letter-spacing:.16em;text-transform:uppercase;font-weight:500;
  transition:all .3s var(--ease);
}
.btn-ghost:hover{background:var(--navy);color:#fff}

.map-frame{
  position:relative;aspect-ratio:21/9;background:var(--navy);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;
}
.map-frame iframe{
  position:absolute;inset:0;width:100%;height:100%;border:0;
  filter:grayscale(.35) contrast(1.02);
}
.map-frame::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg, rgba(13,27,42,.0) 60%, rgba(13,27,42,.15) 100%);
}
.map-card-overlay{
  position:absolute;left:32px;bottom:28px;z-index:2;
  display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;
  background:#fff;padding:18px 22px;
  box-shadow:0 18px 50px -10px rgba(13,27,42,.4), 0 6px 18px rgba(13,27,42,.15);
  max-width:380px;
  border-left:3px solid var(--teal);
}
.mco-icon{display:flex;align-items:center;justify-content:center}
.mco-title{font-family:var(--serif);font-size:1.05rem;color:var(--navy);line-height:1.2}
.mco-sub{font-size:.82rem;color:var(--muted);margin-top:2px}
.mco-meta{font-size:.78rem;color:var(--muted);margin-top:6px}
.mco-cta{
  width:42px;height:42px;border-radius:50%;background:var(--teal);color:#fff;
  display:flex;align-items:center;justify-content:center;transition:all .3s var(--ease);
}
.mco-cta:hover{background:var(--navy);transform:translateX(2px)}

.map-foot{
  display:grid;grid-template-columns:1fr;gap:0;
  padding:0;background:var(--sand);
}
@media(min-width:760px){.map-foot{grid-template-columns:repeat(3,1fr)}}
.mf-col{
  padding:22px 28px;display:flex;flex-direction:column;gap:6px;
  border-top:1px solid var(--line);
}
@media(min-width:760px){.mf-col + .mf-col{border-left:1px solid var(--line);border-top:0}}
.mf-lbl{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:500}
.mf-val{font-family:var(--serif);font-size:1.02rem;color:var(--navy);line-height:1.3}

@media(max-width:640px){
  .form-side,.form-main{padding:36px 26px}
  .map-block-head{padding:24px 22px 18px}
  .map-card-overlay{left:12px;right:12px;bottom:12px;max-width:none;padding:14px 16px}
  .pref-grid{grid-template-columns:1fr}
}

/* ========= VALORES (equipo-quirofano) ========= */
.valores-section{
  padding:80px 0;
  background:var(--sand);
  border-top:1px solid var(--line);
}
.valores-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:2px;
  background:var(--line);
  border:1px solid var(--line);
}
.valor-item{
  background:var(--sand);
  padding:48px 36px 44px;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:20px;
  transition:background .3s var(--ease);
}
.valor-item:hover{background:var(--warm-white)}
.valor-icon{
  width:80px;height:80px;
  border-radius:50%;
  background:var(--warm-white);
  border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  color:var(--accent);
  flex-shrink:0;
  transition:all .3s var(--ease);
}
.valor-item:hover .valor-icon{
  background:var(--navy);
  border-color:var(--navy);
  color:#fff;
  transform:translateY(-3px);
  box-shadow:0 12px 28px rgba(13,27,42,.15);
}
.valor-icon svg{width:32px;height:32px}
.valor-item h4{
  font-family:var(--sans);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--navy);
  margin:0;
}
.valor-item p{
  font-size:.92rem;
  color:var(--muted);
  line-height:1.7;
  margin:0;
}
@media(max-width:860px){
  .valores-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
  .valores-grid{grid-template-columns:1fr;gap:0}
  .valor-item{padding:36px 28px}
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001s !important;transition-duration:.001s !important}
}

/* ========= FAQ v2 ========= */
.faq2{
  max-width:820px;margin:0 auto;
  border-top:1px solid var(--line);
}
.faq2-item{
  border-bottom:1px solid var(--line);
}
.faq2-item summary{
  display:grid;
  grid-template-columns:48px 1fr 32px;
  align-items:center;
  gap:16px;
  padding:26px 0;
  cursor:pointer;
  list-style:none;
}
.faq2-item summary::-webkit-details-marker{display:none}
.faq2-num{
  font-family:var(--serif);
  font-size:1.1rem;
  font-weight:600;
  color:var(--teal);
  line-height:1;
}
.faq2-q{
  font-family:var(--serif);
  font-size:1.15rem;
  color:var(--navy);
  line-height:1.3;
  transition:color .25s var(--ease);
}
.faq2-item[open] .faq2-q{color:var(--teal)}
.faq2-icon{
  width:32px;height:32px;flex:0 0 32px;
  border:1px solid var(--line);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  position:relative;
  transition:all .3s var(--ease);
}
.faq2-icon::before,
.faq2-icon::after{
  content:"";position:absolute;
  background:var(--teal);
  transition:transform .3s var(--ease), opacity .3s var(--ease);
}
.faq2-icon::before{width:12px;height:1.5px}
.faq2-icon::after{width:1.5px;height:12px}
.faq2-item[open] .faq2-icon{background:var(--teal);border-color:var(--teal)}
.faq2-item[open] .faq2-icon::before{background:#fff}
.faq2-item[open] .faq2-icon::after{background:#fff;transform:rotate(90deg);opacity:0}
.faq2-body{
  padding:0 0 26px 64px;
}
.faq2-body p{
  color:var(--muted);
  line-height:1.75;
  margin:0;
  max-width:68ch;
}
.faq2-item summary:hover .faq2-q{color:var(--teal)}
.faq2-item summary:hover .faq2-icon{border-color:var(--teal)}
@media(max-width:600px){
  .faq2-item summary{grid-template-columns:36px 1fr 28px;gap:12px;padding:20px 0}
  .faq2-num{font-size:.95rem}
  .faq2-q{font-size:1rem}
  .faq2-body{padding:0 0 20px 48px}
}

/* ========= COOKIE BANNER ========= */
.cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:9000;
  padding:20px 24px;
  background:var(--navy);
  border-top:3px solid var(--teal);
  box-shadow:0 -8px 40px rgba(13,27,42,.35);
  transform:translateY(100%);
  transition:transform .45s cubic-bezier(.2,.7,.2,1);
}
.cookie-banner.visible{transform:translateY(0)}

.cookie-banner-inner{
  max-width:var(--container);
  margin:0 auto;
  display:flex;
  flex-wrap:wrap;
  gap:20px 40px;
  align-items:center;
}

.cookie-banner-text{
  flex:1 1 340px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.cookie-banner-text p{
  margin:0;
  font-size:.92rem;
  color:rgba(255,255,255,.82);
  line-height:1.6;
}
.cookie-policy-link{
  font-size:.8rem;
  color:var(--teal-light);
  letter-spacing:.06em;
  transition:color .2s;
}
.cookie-policy-link:hover{color:#fff}

.cookie-banner-actions{
  display:flex;
  flex-shrink:0;
  gap:12px;
  align-items:center;
}

.cookie-btn{
  cursor:pointer;border:none;
  font-family:var(--sans);font-weight:500;
  font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;
  padding:12px 24px;
  transition:all .25s var(--ease);
}
.cookie-btn-primary{
  background:var(--teal);color:#fff;
}
.cookie-btn-primary:hover{background:var(--teal-light)}
.cookie-btn-secondary{
  background:transparent;color:rgba(255,255,255,.6);
  border:1px solid rgba(255,255,255,.2);
}
.cookie-btn-secondary:hover{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.4)}

@media(max-width:600px){
  .cookie-banner{padding:20px 18px}
  .cookie-banner-actions{width:100%;justify-content:flex-end}
}
