/* ============================================================
   INNOVAMED — Shared Stylesheet
   Versión: 20260529
   ============================================================ */

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

:root{
  --teal:#2B5A57;
  --teal-dark:#1D3E3C;
  --teal-mid:#234e4b;
  --gold:#C9A256;
  --gold-light:#DDB96A;
  --gold-pale:#EDD89A;
  --cream:#F7F2E9;
  --cream-dark:#EDE7D9;
  --white:#FFFFFF;
  --text-dark:#1A2E2D;
  --text-mid:#3D5553;
  --ff-d:'Cormorant Garamond',Georgia,serif;
  --ff-b:'Jost',sans-serif;
  --nav-h:72px;
}

html{scroll-behavior:smooth;scroll-padding-top:var(--nav-h);overflow-x:clip}
body{font-family:var(--ff-b);background:var(--cream);color:var(--text-dark);font-size:16px;line-height:1.7;overflow-x:clip;max-width:100vw}

/* ── CONTAINER ─────────────────────────────────────────────── */
.container{width:90%;max-width:1100px;margin:0 auto}

/* ── TYPOGRAPHY ─────────────────────────────────────────────── */
.tag{
  display:inline-block;
  font-family:var(--ff-b);
  font-size:.68rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);border:1px solid var(--gold);
  padding:.32em 1.1em;border-radius:2px;margin-bottom:1.1rem
}
.s-title{
  font-family:var(--ff-d);
  font-size:clamp(2rem,4vw,3rem);font-weight:500;line-height:1.2;
  color:var(--teal-dark)
}
.s-title em{font-style:italic;color:var(--gold)}
.s-sub{
  font-family:var(--ff-b);
  font-size:.97rem;font-weight:300;color:var(--text-mid);
  max-width:560px;margin:0 auto;line-height:1.85
}
.gline{display:block;width:50px;height:2px;background:var(--gold);margin:1rem auto}

/* ── NUMBERS fix: lining tabular numerals ───────────────────── */
.num-display{
  font-family:var(--ff-b);
  font-variant-numeric:lining-nums tabular-nums;
  font-feature-settings:"lnum","tnum";
}

/* ── BUTTONS ─────────────────────────────────────────────────── */
.btn-p{
  display:inline-block;
  font-family:var(--ff-b);font-size:.8rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;text-decoration:none;
  color:var(--teal-dark);background:var(--gold);
  padding:.95rem 2.4rem;border:2px solid var(--gold);border-radius:2px;
  cursor:pointer;transition:all .3s
}
.btn-p:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,162,86,.35)}
.btn-o{
  display:inline-block;
  font-family:var(--ff-b);font-size:.8rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;text-decoration:none;
  color:#fff;background:transparent;
  padding:.95rem 2.4rem;border:2px solid rgba(255,255,255,.5);border-radius:2px;
  cursor:pointer;transition:all .3s
}
.btn-o:hover{background:rgba(255,255,255,.1);border-color:#fff;transform:translateY(-2px)}
.btn-teal{
  display:inline-block;
  font-family:var(--ff-b);font-size:.8rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;text-decoration:none;
  color:var(--gold-pale);background:var(--teal-dark);
  padding:.95rem 2.4rem;border:2px solid var(--teal-dark);border-radius:2px;
  cursor:pointer;transition:all .3s
}
.btn-teal:hover{background:var(--teal);transform:translateY(-2px);box-shadow:0 8px 24px rgba(29,62,60,.3)}

/* ── NAV ─────────────────────────────────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:var(--nav-h);
  display:flex;align-items:center;
  background:rgba(29,62,60,.96);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(201,162,86,.18);
  transition:background .3s
}
.nav-inner{
  width:90%;max-width:1200px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:2rem
}
.nav-logo{
  display:flex;align-items:center;text-decoration:none;flex-shrink:0
}
.nav-logo img{height:42px;width:auto;transition:transform .25s}
.nav-logo:hover img{transform:scale(1.03)}
.nav-links{
  display:flex;align-items:center;gap:1.3rem;list-style:none
}
.nav-links a{
  font-family:var(--ff-b);font-size:.76rem;font-weight:500;
  letter-spacing:.1em;text-transform:uppercase;text-decoration:none;
  color:rgba(255,255,255,.72);transition:color .25s;white-space:nowrap
}
.nav-links a:hover,.nav-links a.active{color:var(--gold-light)}
.nav-links a.active{border-bottom:1px solid var(--gold);padding-bottom:2px}
.nav-cta{
  font-family:var(--ff-b);font-size:.72rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;text-decoration:none;
  color:var(--teal-dark);background:var(--gold);
  padding:.6rem 1.4rem;border-radius:2px;border:2px solid var(--gold);
  white-space:nowrap;transition:all .3s;flex-shrink:0
}
.nav-cta:hover{background:var(--gold-light);transform:translateY(-1px)}
.nav-burger{
  display:none;background:none;border:none;cursor:pointer;
  padding:4px;flex-shrink:0;
  min-width:44px;min-height:44px;
  align-items:center;justify-content:center
}
.nb-svg{display:block;width:20px;height:33px;overflow:visible;color:#C9A256}
.nb-lines,.nb-xmark{transition:opacity .22s}
.nb-xmark{opacity:0}
.nav.open .nb-lines{opacity:0}
.nav.open .nb-xmark{opacity:1}
.nav.scrolled{
  background:rgba(13,32,30,.99);
  box-shadow:0 2px 32px rgba(0,0,0,.32)
}
/* ── NAV PHONE WRAP (dropdown) ─────────────────────────────── */
.nav-phone-wrap{position:relative;flex-shrink:0}
.nav-phone-btn{
  display:flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;
  background:rgba(201,162,86,.12);border:1px solid rgba(201,162,86,.35);
  cursor:pointer;transition:background .2s,border-color .2s
}
.nav-phone-btn:hover{background:rgba(201,162,86,.22);border-color:var(--gold)}
.nav-phone-btn svg{width:15px;height:15px;fill:var(--gold);flex-shrink:0}
.nav-phone-drop{
  display:none;position:absolute;top:calc(100% + .55rem);right:0;
  min-width:160px;
  background:rgba(29,62,60,.98);backdrop-filter:blur(14px);
  border:1px solid rgba(201,162,86,.2);border-radius:10px;
  box-shadow:0 14px 48px rgba(0,0,0,.38);padding:.4rem;
  z-index:1200
}
.nav-phone-wrap.open .nav-phone-drop{display:block}
.np-opt{
  display:flex;align-items:center;gap:.55rem;
  padding:.52rem .72rem;border-radius:6px;text-decoration:none;
  font-family:var(--ff-b);font-size:.82rem;font-weight:600;
  color:rgba(255,255,255,.85);transition:background .15s
}
.np-opt:hover{background:rgba(201,162,86,.13);color:#fff}
.np-opt svg{width:14px;height:14px;fill:var(--gold);flex-shrink:0}
/* ── INSTAGRAM FOOTER BANNER ────────────────────────────────── */
@keyframes ig-flow{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}
.footer-ig-banner{
  display:flex;align-items:center;gap:1.2rem;
  padding:1.15rem 1.6rem;border-radius:14px;text-decoration:none;
  background:linear-gradient(110deg,#6a11cb 0%,#c0392b 30%,#fd7e14 60%,#c0392b 80%,#6a11cb 100%);
  background-size:260% 100%;
  animation:ig-flow 5s ease-in-out infinite;
  border:1px solid rgba(255,255,255,.1);
  transition:transform .25s,box-shadow .25s;
  margin-bottom:1.5rem
}
.footer-ig-banner:hover{
  transform:translateY(-3px);
  box-shadow:0 12px 40px rgba(192,57,43,.45)
}
.fig-icon{
  width:50px;height:50px;border-radius:50%;
  background:rgba(255,255,255,.18);backdrop-filter:blur(4px);
  border:1px solid rgba(255,255,255,.25);
  display:flex;align-items:center;justify-content:center;flex-shrink:0
}
.fig-icon svg{width:26px;height:26px;fill:#fff}
.fig-text{display:flex;flex-direction:column;gap:.12rem;flex:1}
.fig-cta{
  font-family:var(--ff-b);font-size:.68rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.82)
}
.fig-user{
  font-family:var(--ff-b);font-size:1.1rem;font-weight:700;color:#fff;letter-spacing:-.01em
}
.fig-arrow{
  width:22px;height:22px;flex-shrink:0;color:rgba(255,255,255,.7);
  transition:transform .22s
}
.footer-ig-banner:hover .fig-arrow{transform:translateX(5px)}
.footer-ig-link:hover svg{fill:#fcb045}
/* ── NAV LANG ──────────────────────────────────────────────── */
.nl-flag{display:flex;align-items:center;flex-shrink:0}
.nl-flag-img{width:20px;height:15px;border-radius:2px;object-fit:cover;flex-shrink:0;display:block}
.nav-lang-drop button .nl-flag-img{width:18px;height:13px;border-radius:2px}
.nav-lang{position:relative;flex-shrink:0}
.nav-lang-btn{
  display:flex;align-items:center;gap:.28rem;
  background:none;border:1px solid rgba(201,162,86,.35);border-radius:5px;
  padding:.38rem .52rem;font-family:var(--ff-b);font-size:.68rem;font-weight:700;
  color:var(--gold);cursor:pointer;white-space:nowrap;letter-spacing:.06em;
  transition:border-color .2s,background .2s;line-height:1
}
.nav-lang-btn:hover{border-color:var(--gold);background:rgba(201,162,86,.08)}
.nav-lang-btn svg{width:13px;height:13px;fill:var(--gold);flex-shrink:0}
.nl-arrow{font-size:.5rem;transition:transform .22s;display:inline-block;margin-left:.08rem}
.nav-lang.open .nl-arrow{transform:rotate(180deg)}
.nav-lang-drop{
  display:none;position:absolute;top:calc(100% + .55rem);right:0;
  min-width:152px;
  background:rgba(29,62,60,.98);backdrop-filter:blur(14px);
  border:1px solid rgba(201,162,86,.2);border-radius:10px;
  box-shadow:0 14px 48px rgba(0,0,0,.38);list-style:none;padding:.4rem;
  z-index:1200
}
.nav-lang.open .nav-lang-drop{display:block}
.nav-lang-drop li{margin:0}
.nav-lang-drop button{
  display:block;width:100%;background:none;border:none;
  padding:.48rem .72rem;text-align:left;font-family:var(--ff-b);
  font-size:.8rem;color:rgba(255,255,255,.82);cursor:pointer;
  border-radius:6px;transition:background .15s
}
.nav-lang-drop button:hover{background:rgba(201,162,86,.13);color:#fff}
.nav-lang-drop button.nl-active{color:var(--gold);font-weight:700}
/* ── GOOGLE TRANSLATE OVERRIDES ────────────────────────────── */
.goog-te-banner-frame,.goog-te-balloon-frame,.goog-te-menu-frame{display:none!important}
.skiptranslate{display:none!important}
body{top:0!important}
#goog-gt-tt{display:none!important}

/* ── HERO ─────────────────────────────────────────────────────── */
.hero{
  position:relative;
  min-height:100vh;
  min-height:100svh;
  background:linear-gradient(145deg,#1D3E3C 0%,#2B5A57 55%,#3d7570 100%);
  display:flex;align-items:center;
  overflow:hidden;
  padding:calc(var(--nav-h) + 4rem) 0 5rem
}
.hero::before{
  content:'';position:absolute;top:-180px;right:-180px;
  width:650px;height:650px;border-radius:50%;
  border:1px solid rgba(201,162,86,.1);pointer-events:none
}
.hero::after{
  content:'';position:absolute;bottom:-100px;left:-100px;
  width:400px;height:400px;border-radius:50%;
  border:1px solid rgba(201,162,86,.06);pointer-events:none
}
.hero-inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center
}
.hero-logo{width:100%;max-width:400px;margin-bottom:1.8rem;display:block}
.hero-ey{
  font-family:var(--ff-b);font-size:.7rem;font-weight:700;
  letter-spacing:.24em;text-transform:uppercase;color:var(--gold);
  margin-bottom:1rem;display:flex;align-items:center;gap:.8rem;flex-wrap:wrap
}
.hero-ey::before{content:'';width:28px;height:1px;background:var(--gold);display:inline-block}
.hero-title{
  font-family:var(--ff-d);
  font-size:clamp(2.8rem,5vw,4.2rem);font-weight:400;line-height:1.12;
  color:#fff;margin-bottom:1.3rem
}
.hero-title em{font-style:italic;color:var(--gold-pale)}
.hero-sub{
  font-family:var(--ff-b);font-size:.97rem;font-weight:300;
  color:rgba(255,255,255,.78);max-width:440px;margin-bottom:2.2rem;line-height:1.85
}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap}

/* ── HERO SIDE CARD ─────────────────────────────────────────── */
.hero-card{
  background:rgba(29,62,60,.72);
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(201,162,86,.28);
  border-radius:10px;padding:2.4rem 2rem;
}
.hero-card-title{
  font-family:var(--ff-b);font-size:.68rem;font-weight:700;
  letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:1.6rem
}

/* Stats grid (replacing countdown) */
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}

/* Mutua logo chips inside hero card */
.hero-mutuas{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(80px,1fr));
  grid-auto-rows:42px;
  gap:.3rem;
  padding-top:.9rem;
  border-top:1px solid rgba(201,162,86,.18)
}
.hero-mutua-chip{
  background:#fff;
  border-radius:5px;
  padding:.2rem .4rem;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.hero-mutua-chip img{
  width:72px;height:26px;
  object-fit:contain;
  display:block;
}
.stat-unit{
  background:rgba(0,0,0,.2);
  border:1px solid rgba(201,162,86,.16);
  border-radius:6px;padding:1.1rem .8rem;text-align:center
}
.stat-num{
  display:block;
  font-family:var(--ff-b);font-size:2.2rem;font-weight:700;
  font-variant-numeric:lining-nums tabular-nums;
  font-feature-settings:"lnum","tnum";
  color:var(--gold-pale);line-height:1;letter-spacing:-.02em
}
.stat-lbl{
  display:block;
  font-family:var(--ff-b);font-size:.6rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.42);margin-top:.35rem
}
/* ── STRIP MARQUEE ──────────────────────────────────────────────── */
.strip{
  background:var(--teal-dark);padding:1rem 0;
  border-top:1px solid rgba(201,162,86,.16);
  border-bottom:1px solid rgba(201,162,86,.16);
  position:relative;overflow:hidden
}
.strip-track{
  display:flex;width:max-content;
  animation:strip-scroll 36s linear infinite
}
.strip-track:hover{animation-play-state:paused}
.strip-item{
  font-family:var(--ff-b);font-size:.76rem;font-weight:500;
  letter-spacing:.08em;color:var(--gold-light);
  white-space:nowrap;padding:0 2.2rem;
  display:flex;align-items:center;gap:.6rem
}
.strip-item::before{content:'✦';font-size:.48rem;color:var(--gold);opacity:.8}
@keyframes strip-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){
  .strip-track{animation:none;flex-wrap:wrap;justify-content:center}
  .wa-float{animation:none}
  .prox-dots{animation:none;opacity:1}
  .oferta-flash{animation:none}
  .oferta-card{animation:none}
}

/* ── SECTIONS ─────────────────────────────────────────────────── */
.sec{padding:6rem 0;position:relative;overflow:hidden}
.sec-center{text-align:center}
.sec-teal{background:var(--teal-dark)}
.sec-cream{background:var(--cream)}
.sec-cream-dark{background:var(--cream-dark)}
.sec-white{background:var(--white)}

/* Section page hero (interior pages) */
.page-hero{
  background:linear-gradient(145deg,#1D3E3C 0%,#2B5A57 60%,#3d7570 100%);
  padding:calc(var(--nav-h) + 4rem) 0 4rem;
  text-align:center;position:relative;overflow:hidden
}
.page-hero::before{
  content:'';position:absolute;top:-120px;right:-120px;
  width:500px;height:500px;border-radius:50%;
  border:1px solid rgba(201,162,86,.1);pointer-events:none
}
.page-hero-title{
  font-family:var(--ff-d);
  font-size:clamp(2.4rem,5vw,3.8rem);font-weight:400;line-height:1.15;
  color:#fff;position:relative;z-index:1
}
.page-hero-title em{font-style:italic;color:var(--gold-pale)}
.page-hero-sub{
  font-family:var(--ff-b);font-size:.97rem;font-weight:300;
  color:rgba(255,255,255,.72);max-width:540px;margin:.9rem auto 0;
  line-height:1.8;position:relative;z-index:1
}
.page-hero .tag{position:relative;z-index:1}


/* ── SERVICE CARDS ─────────────────────────────────────────────── */
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:3.5rem}
.srv-card{
  background:var(--white);
  border:1px solid rgba(201,162,86,.15);border-radius:8px;
  padding:1.8rem 1.5rem;position:relative;overflow:hidden;
  transition:transform .3s,box-shadow .3s;text-align:left
}
.sec-teal .srv-card{background:rgba(255,255,255,.05);border-color:rgba(201,162,86,.15)}
.srv-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(43,90,87,.1)}
.srv-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold),var(--gold-pale))
}
.srv-icon{
  width:40px;height:40px;
  background:rgba(201,162,86,.12);border:1px solid rgba(201,162,86,.25);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  margin-bottom:.9rem
}
.srv-icon svg{width:18px;height:18px;fill:var(--gold)}
.srv-card h3{
  font-family:var(--ff-d);font-size:1.18rem;font-weight:600;
  color:var(--teal-dark);margin-bottom:.4rem
}
.sec-teal .srv-card h3{color:var(--gold-pale)}
.srv-card p{
  font-family:var(--ff-b);font-size:.84rem;font-weight:300;
  color:var(--text-mid);line-height:1.7
}
.sec-teal .srv-card p{color:rgba(255,255,255,.62)}
.srv-badge{
  display:inline-block;
  font-family:var(--ff-b);font-size:.6rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);margin-top:.7rem
}

/* ── DIFFERENTIATOR (quirófano) ─────────────────────────────── */
.diff-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.diff-inner > div:only-child{grid-column:1/-1;max-width:760px}
/* Scoped: color overrides only when diff-inner is inside a dark section */
.sec-teal .diff-inner .s-title{color:#fff}
.sec-teal .diff-inner .s-sub{color:rgba(255,255,255,.62);text-align:left;margin:0}
.sec-teal .diff-inner .gline{margin:1rem 0}
/* On light backgrounds, diff-inner uses default text colors */
.sec-cream .diff-inner .s-title{color:var(--teal-dark)}
.sec-cream .diff-inner .s-sub{color:var(--text-mid);text-align:left;margin:0}
.diff-list{list-style:none;margin-top:1.8rem}
.diff-list li{
  font-family:var(--ff-b);font-size:.92rem;font-weight:400;
  color:rgba(255,255,255,.8);padding:.75rem 0;
  border-bottom:1px solid rgba(201,162,86,.1);
  display:flex;align-items:flex-start;gap:.9rem
}
.diff-list li:last-child{border-bottom:none}
.diff-li-icon{
  width:28px;height:28px;
  background:rgba(201,162,86,.15);border:1px solid rgba(201,162,86,.25);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;margin-top:2px
}
.diff-li-icon svg{width:12px;height:12px;fill:var(--gold)}
.diff-li-text strong{display:block;font-weight:600;color:var(--gold-light);font-size:.85rem;margin-bottom:.15rem}
.diff-quote{
  font-family:var(--ff-d);font-size:1.15rem;font-weight:400;
  font-style:italic;color:rgba(255,255,255,.55);
  line-height:1.5;margin-top:1.8rem;max-width:480px
}
/* ── TEAM ────────────────────────────────────────────────────── */
.team-intro{
  max-width:620px;margin:1.8rem auto 0;text-align:left;
}
.team-intro p{
  font-size:1rem;color:var(--text-mid);line-height:1.8;margin-bottom:1.1rem;
}
.team-intro p:last-child{margin-bottom:0}
.team-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;
  margin-top:3.5rem;max-width:820px;margin-left:auto;margin-right:auto
}
.team-card{
  background:var(--white);border-radius:10px;overflow:hidden;
  border:1px solid rgba(201,162,86,.18);
  transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column
}
.team-card:hover{transform:translateY(-5px);box-shadow:0 18px 52px rgba(43,90,87,.13)}
.team-photo{position:relative;overflow:hidden;aspect-ratio:4/5}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .4s}
.team-card:hover .team-photo img{transform:scale(1.04)}
.team-photo-overlay{
  position:absolute;bottom:0;left:0;right:0;height:45%;
  background:linear-gradient(to top,rgba(29,62,60,.95),transparent);pointer-events:none
}
.team-photo-name{position:absolute;bottom:1.2rem;left:1.4rem;right:1.4rem}
.team-photo-name h3{
  font-family:var(--ff-d);font-size:1.6rem;font-weight:500;
  color:#fff;line-height:1.1;margin-bottom:.2rem
}
.team-photo-name .role{
  font-family:var(--ff-b);font-size:.62rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--gold)
}
.team-body{padding:1.6rem;flex:1}
.team-body p{
  font-family:var(--ff-b);font-size:.86rem;font-weight:300;
  color:var(--text-mid);line-height:1.75;margin-bottom:1.1rem
}
.team-specs{list-style:none;display:flex;flex-direction:column;gap:.35rem}
.team-specs li{
  font-family:var(--ff-b);font-size:.77rem;font-weight:500;
  color:var(--text-dark);display:flex;align-items:center;gap:.55rem
}
.spec-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0}

/* ── REVIEWS ─────────────────────────────────────────────────────── */
.reviews-hero-title{
  font-family:var(--ff-d);
  font-size:clamp(2.6rem,6vw,4.8rem);font-weight:400;line-height:1.15;
  color:#fff;margin:.8rem 0 .5rem
}
.reviews-hero-title em{font-style:italic;color:var(--gold-pale)}
.reviews-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:1.4rem;margin-top:2.5rem
}
.review-card{
  background:var(--white);border:1px solid rgba(201,162,86,.16);
  border-radius:10px;padding:1.8rem 1.7rem;
  position:relative;transition:transform .3s,box-shadow .3s
}
.review-card:hover{transform:translateY(-4px);box-shadow:0 14px 44px rgba(43,90,87,.1)}
.review-card::before{
  content:'\201C';position:absolute;top:.6rem;right:1.2rem;
  font-family:var(--ff-d);font-size:4.5rem;font-weight:600;
  color:rgba(201,162,86,.1);line-height:1;pointer-events:none
}
.review-stars{font-size:.9rem;color:var(--gold);letter-spacing:.04em;margin-bottom:.75rem}
.review-text{
  font-family:var(--ff-b);font-size:.87rem;font-weight:300;
  color:var(--text-mid);line-height:1.8;margin-bottom:1.3rem;font-style:italic
}
.review-meta{display:flex;justify-content:space-between;align-items:flex-end;gap:.5rem;flex-wrap:wrap}
.review-name{font-family:var(--ff-b);font-size:.82rem;font-weight:700;color:var(--teal-dark)}
.review-date{font-family:var(--ff-b);font-size:.68rem;font-weight:400;color:rgba(0,0,0,.32)}
.reviews-empty{
  text-align:center;padding:3.5rem 1.5rem;
  font-family:var(--ff-b);font-size:.95rem;font-weight:300;color:var(--text-mid)
}
.reviews-empty-icon{font-size:2.8rem;display:block;margin-bottom:1rem;opacity:.4}
/* Star selector */
.star-group{display:flex;gap:.1rem;margin:.5rem 0 1.2rem;cursor:pointer}
.star-group .star{
  font-size:2.2rem;color:rgba(255,255,255,.2);
  transition:color .12s;line-height:1;padding:0 .1rem;
  user-select:none;-webkit-user-select:none
}
.star-group .star.active{color:var(--gold)}
.star-group .star:hover{transform:scale(1.1)}
.star-error{color:#f87171;font-family:var(--ff-b);font-size:.75rem;margin-top:-.8rem;margin-bottom:.8rem;display:none}
.star-error.show{display:block}
/* Review form card */
.review-form-card{
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(201,162,86,.28);border-radius:12px;
  padding:2.8rem 2.4rem;max-width:620px;margin:0 auto
}
.review-form-card label{color:rgba(255,255,255,.75)}
.review-form-card input,
.review-form-card textarea{
  background:rgba(255,255,255,.08);
  border-color:rgba(201,162,86,.22);color:#fff
}
.review-form-card input::placeholder,
.review-form-card textarea::placeholder{color:rgba(255,255,255,.3)}
.review-form-card input:focus,
.review-form-card textarea:focus{
  border-color:var(--gold);
  background:rgba(255,255,255,.12);
  box-shadow:0 0 0 3px rgba(201,162,86,.15)
}
.review-suc{
  display:none;text-align:center;padding:2.5rem 1.5rem
}
.review-suc.show{display:block}
.review-suc-icon{font-size:3rem;display:block;margin-bottom:1rem}
.review-suc h3{
  font-family:var(--ff-d);font-size:1.8rem;font-weight:400;
  color:#fff;margin-bottom:.5rem
}
.review-suc h3 em{color:var(--gold-pale);font-style:italic}
.review-suc p{font-family:var(--ff-b);font-size:.88rem;color:rgba(255,255,255,.6);margin-bottom:1.5rem}

/* ── TESTIMONIALS ──────────────────────────────────────────────── */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;margin-top:3.5rem}
.testi-card{
  background:var(--white);
  border:1px solid rgba(201,162,86,.16);
  border-radius:10px;padding:2rem 1.8rem;
  text-align:left;position:relative;
  transition:transform .3s,box-shadow .3s
}
.testi-card:hover{transform:translateY(-4px);box-shadow:0 14px 44px rgba(43,90,87,.1)}
.testi-card::before{
  content:'\201C';position:absolute;top:.8rem;right:1.4rem;
  font-family:var(--ff-d);font-size:5rem;font-weight:600;
  color:rgba(201,162,86,.12);line-height:1;pointer-events:none
}
.testi-stars{font-size:.85rem;color:var(--gold);letter-spacing:.04em;margin-bottom:.9rem}
.testi-text{
  font-family:var(--ff-b);font-size:.87rem;font-weight:300;
  color:var(--text-mid);line-height:1.8;margin-bottom:1.4rem;font-style:italic
}
.testi-author{display:flex;flex-direction:column;gap:.12rem}
.testi-name{font-family:var(--ff-b);font-size:.82rem;font-weight:700;color:var(--teal-dark)}
.testi-role{
  font-family:var(--ff-b);font-size:.65rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;color:var(--gold)
}
@media(max-width:900px){.testi-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.testi-grid{grid-template-columns:1fr;max-width:400px;margin-left:auto;margin-right:auto}}

/* ── BOOKING FORM ─────────────────────────────────────────────── */
.bk-inner{display:grid;grid-template-columns:1fr 1.6fr;gap:5rem;align-items:start}
.bk-info .s-title{color:#fff;text-align:left}
.bk-info .gline{margin:1rem 0}
.bk-info .s-sub{color:rgba(255,255,255,.62);text-align:left;margin:0}
.bk-badges{margin-top:2.2rem;display:flex;flex-direction:column;gap:1.1rem}
.bk-badge{display:flex;align-items:center;gap:.9rem}
.bk-badge-icon{
  width:40px;height:40px;
  background:rgba(201,162,86,.12);border:1px solid rgba(201,162,86,.25);
  border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0
}
.bk-badge-icon svg{width:15px;height:15px;fill:var(--gold)}
.bk-badge-text{font-family:var(--ff-b);font-size:.85rem;font-weight:300;color:rgba(255,255,255,.68)}
.bk-badge-text strong{display:block;font-weight:600;color:#fff;font-size:.88rem}
.form-card{background:var(--white);border-radius:12px;padding:2.8rem;box-shadow:0 24px 80px rgba(0,0,0,.22)}
.form-ftitle{font-family:var(--ff-d);font-size:1.65rem;font-weight:500;color:var(--teal-dark);margin-bottom:.25rem}
.form-ftitle em{font-style:italic;color:var(--gold)}
.form-fsub{font-family:var(--ff-b);font-size:.85rem;font-weight:300;color:var(--text-mid);margin-bottom:1.8rem}
.flabel{
  display:block;font-family:var(--ff-b);font-size:.68rem;font-weight:800;
  letter-spacing:.2em;text-transform:uppercase;color:var(--gold);
  margin:1.4rem 0 .8rem;padding-bottom:.45rem;border-bottom:1px solid rgba(201,162,86,.18)
}
.fg{margin-bottom:.85rem}
label{
  display:block;font-family:var(--ff-b);font-size:.74rem;font-weight:600;
  letter-spacing:.05em;color:var(--text-dark);margin-bottom:.4rem
}
input:not([type=checkbox]):not([type=radio]),select,textarea{
  width:100%;font-family:var(--ff-b);font-size:.88rem;font-weight:400;
  color:var(--text-dark);background:var(--cream);
  border:1.5px solid rgba(43,90,87,.15);border-radius:6px;
  padding:.7rem .95rem;outline:none;
  transition:border-color .25s,box-shadow .25s;appearance:none
}
/* Evita que iOS haga zoom al tocar inputs (requiere ≥16px) */
@media(max-width:900px){
  input:not([type=checkbox]):not([type=radio]),select,textarea{font-size:1rem}
}
input:not([type=checkbox]):not([type=radio]):focus,select:focus,textarea:focus{
  border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,86,.12);background:#fff
}
input[type=checkbox]{
  width:17px;height:17px;flex-shrink:0;
  accent-color:var(--teal-dark);cursor:pointer;
}
textarea{resize:vertical;min-height:80px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.radio-g{display:flex;gap:.9rem}
.radio-opt{flex:1;position:relative}
.radio-opt input[type=radio]{position:absolute;opacity:0;pointer-events:none}
.radio-lbl{
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-b);font-size:.83rem;font-weight:500;
  color:var(--text-dark);background:var(--cream);
  border:1.5px solid rgba(43,90,87,.15);border-radius:6px;
  padding:.7rem;cursor:pointer;transition:all .25s
}
.radio-opt input:checked+.radio-lbl{background:var(--teal-dark);color:#fff;border-color:var(--teal-dark)}
.mutua-f{display:none}
.mutua-f.show{display:block}
.sbtn{
  width:100%;font-family:var(--ff-b);font-size:.82rem;font-weight:800;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--teal-dark);
  background:linear-gradient(90deg,var(--gold),var(--gold-light));
  border:none;border-radius:6px;padding:1.05rem;
  cursor:pointer;margin-top:1.4rem;transition:all .3s;
  box-shadow:0 4px 18px rgba(201,162,86,.35)
}
.sbtn:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(201,162,86,.48)}
.hora-picker{
  display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.4rem;align-items:center;
}
.hora-chip{
  font-family:var(--ff-b);font-size:.82rem;font-weight:600;
  color:var(--teal-dark);background:var(--cream);
  border:1.5px solid rgba(43,90,87,.15);border-radius:6px;
  padding:.38rem .75rem;cursor:pointer;user-select:none;
  transition:all .14s;white-space:nowrap;
}
.hora-chip:hover{border-color:var(--gold);background:rgba(201,162,86,.08)}
.hora-chip.active{background:var(--teal-dark);color:#fff;border-color:var(--teal-dark)}
.hora-turno{
  width:100%;font-family:var(--ff-b);font-size:.65rem;font-weight:700;
  color:var(--teal-dark);text-transform:uppercase;letter-spacing:.08em;
  margin-top:.3rem;
}
.hora-note{
  font-size:.7rem;line-height:1.5;color:var(--text-mid);
  margin-top:.45rem;margin-bottom:0;
}
.ftrust{display:flex;gap:1.3rem;margin-top:1.1rem;justify-content:center;flex-wrap:wrap}
.ftrust span{
  font-family:var(--ff-b);font-size:.72rem;font-weight:500;
  color:var(--text-mid);display:flex;align-items:center;gap:.3rem
}
.ftrust span::before{content:'✔';color:var(--teal);font-size:.65rem}
.success-m{
  display:none;background:rgba(43,90,87,.08);
  border:1px solid var(--teal);border-radius:8px;
  padding:1.2rem 1.5rem;margin-top:1rem;text-align:center;
  font-family:var(--ff-b);font-size:.9rem;color:var(--teal-dark);font-weight:500
}
.success-m.show{display:block}

/* ── FAQ ─────────────────────────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem;max-width:880px;margin:3rem auto 0}
.faq-item{
  background:var(--white);border:1px solid rgba(201,162,86,.16);
  border-radius:8px;padding:1.7rem 1.7rem 1.7rem 2.1rem;
  position:relative;transition:box-shadow .25s
}
.faq-item:hover{box-shadow:0 8px 32px rgba(43,90,87,.08)}
.faq-item::before{
  content:'';position:absolute;top:0;left:0;bottom:0;width:4px;
  background:linear-gradient(180deg,var(--gold),var(--gold-pale));
  border-radius:8px 0 0 8px
}
.faq-item h4{
  font-family:var(--ff-d);font-size:1.05rem;font-weight:600;
  color:var(--teal-dark);margin-bottom:.55rem;line-height:1.4
}
.faq-item p{font-family:var(--ff-b);font-size:.86rem;font-weight:300;color:var(--text-mid);line-height:1.75}

/* ── CONTACT INFO STRIP ─────────────────────────────────────── */
.contact-strip{display:none}

/* ── GOOGLE MAP ─────────────────────────────────────────────── */
.map-section{background:var(--cream-dark);padding:0}
.map-wrapper{
  position:relative;width:100%;height:420px;
  border-top:3px solid var(--gold);
}
.map-wrapper iframe{width:100%;height:100%;border:0;display:block}
.map-overlay-card{
  position:absolute;top:2rem;left:2rem;
  background:var(--white);border-radius:10px;
  padding:1.5rem 1.8rem;
  box-shadow:0 8px 40px rgba(29,62,60,.18);
  border:1px solid rgba(201,162,86,.2);
  max-width:280px;z-index:5
}
.map-overlay-card h4{
  font-family:var(--ff-d);font-size:1.2rem;font-weight:600;
  color:var(--teal-dark);margin-bottom:.4rem
}
.map-overlay-card p{
  font-family:var(--ff-b);font-size:.82rem;font-weight:300;
  color:var(--text-mid);line-height:1.65;margin-bottom:.9rem
}
.map-overlay-card a{
  font-family:var(--ff-b);font-size:.75rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--teal-dark);background:var(--gold);
  padding:.5rem 1.1rem;border-radius:2px;text-decoration:none;
  display:inline-block;transition:all .3s
}
.map-overlay-card a:hover{background:var(--gold-light)}

/* ── VALUES / FEATURES ──────────────────────────────────────── */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3.5rem}
.value-item{text-align:center;padding:2rem 1.5rem}
.value-icon{
  width:60px;height:60px;margin:0 auto 1.2rem;
  background:rgba(201,162,86,.1);border:1px solid rgba(201,162,86,.25);
  border-radius:50%;display:flex;align-items:center;justify-content:center
}
.value-icon svg{width:24px;height:24px;fill:var(--gold)}
.value-item h3{
  font-family:var(--ff-d);font-size:1.2rem;font-weight:600;
  color:var(--teal-dark);margin-bottom:.5rem
}
.value-item p{font-family:var(--ff-b);font-size:.86rem;font-weight:300;color:var(--text-mid);line-height:1.7}

/* ── LEGAL PAGES ─────────────────────────────────────────────── */
.legal-body{
  padding:calc(var(--nav-h) + 3rem) 0 5rem;
  min-height:100vh;background:var(--cream);
  position:relative;overflow:hidden
}
.legal-body h1{
  font-family:var(--ff-d);font-size:clamp(1.8rem,3vw,2.6rem);
  font-weight:500;color:var(--teal-dark);margin-bottom:2rem;
  padding-bottom:1rem;border-bottom:2px solid rgba(201,162,86,.3)
}
.legal-body h2{
  font-family:var(--ff-d);font-size:1.3rem;font-weight:600;
  color:var(--teal-dark);margin:2rem 0 .8rem
}
.legal-body p,.legal-body ul,.legal-body ol{
  font-family:var(--ff-b);font-size:.9rem;font-weight:300;
  color:var(--text-mid);line-height:1.85;margin-bottom:1rem
}
.legal-body ul,.legal-body ol{padding-left:1.5rem}
.legal-body li{margin-bottom:.4rem}
.legal-body a{color:var(--teal);font-weight:500}

/* ── FOOTER ─────────────────────────────────────────────────── */
.footer{background:var(--teal-dark);padding:3.5rem 0 0;border-top:2px solid var(--gold)}
.footer-brand{
  display:flex;align-items:center;gap:1.4rem;
  padding-bottom:2.2rem;
  border-bottom:1px solid rgba(201,162,86,.12);
  margin-bottom:2.5rem
}
.footer-logo{height:38px;width:auto;opacity:.88}
.footer-tagline{
  font-family:var(--ff-d);font-size:.96rem;font-style:italic;font-weight:400;
  color:rgba(255,255,255,.42);line-height:1.55
}
.footer-cols{
  display:grid;grid-template-columns:1.3fr 1fr 1.1fr;
  gap:3rem;padding-bottom:3rem;
  border-bottom:1px solid rgba(201,162,86,.12)
}
.footer-col-title{
  font-family:var(--ff-b);font-size:.62rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);margin-bottom:1.3rem
}
.footer-contact-list{list-style:none;display:flex;flex-direction:column;gap:.85rem}
.footer-contact-list li{
  display:flex;align-items:flex-start;gap:.65rem;
  font-family:var(--ff-b);font-size:.84rem;font-weight:300;
  color:rgba(255,255,255,.52);line-height:1.5
}
.footer-contact-list li svg{
  width:14px;height:14px;fill:var(--gold);flex-shrink:0;margin-top:.18rem
}
.footer-contact-list a{
  color:rgba(255,255,255,.8);text-decoration:none;font-weight:500;transition:color .2s
}
.footer-contact-list a:hover{color:var(--gold-light)}
.footer-schedule{display:flex;flex-direction:column;gap:.45rem}
.fs-day{
  font-family:var(--ff-b);font-size:.65rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.35);
  margin-bottom:.15rem
}
.fs-hours{
  font-family:var(--ff-b);font-size:.98rem;font-weight:600;
  color:var(--gold-light)
}
.fs-closed{
  font-family:var(--ff-b);font-size:.76rem;font-weight:300;
  color:rgba(255,255,255,.28);margin-top:.4rem
}
.footer .footer-ig-banner{margin-bottom:0}
.footer-bottom{
  padding:1.2rem 0;
  display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem
}
.footer-bottom p{
  font-family:var(--ff-b);font-size:.73rem;font-weight:300;color:rgba(255,255,255,.32)
}
.footer-bottom-links{display:flex;gap:1.5rem;flex-wrap:wrap}
.footer-bottom-links a{
  font-family:var(--ff-b);font-size:.73rem;font-weight:300;
  color:rgba(255,255,255,.42);text-decoration:none;transition:color .2s
}
.footer-bottom-links a:hover{color:var(--gold-light)}

/* ── WA FLOAT ─────────────────────────────────────────────────── */
.wa-float{
  position:fixed;bottom:2rem;right:2rem;z-index:200;
  width:56px;height:56px;background:#25D366;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;
  box-shadow:0 4px 20px rgba(37,211,102,.5);
  animation:pwa 2.5s infinite
}
.wa-float svg{width:26px;height:26px;fill:#fff}
@keyframes pwa{
  0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.5)}
  50%{box-shadow:0 4px 32px rgba(37,211,102,.75),0 0 0 8px rgba(37,211,102,.12)}
}

/* ── LOGO — nav full height, crisp ─────────────────────────── */
.nav-logo img,
.hero-logo{mix-blend-mode:normal}

:root{--nav-h:80px}
.nav-logo img{height:60px;width:auto;transition:transform .25s}

/* ── HERO CARD — 3 stats columns ────────────────────────────── */
.hero-card .stats-grid{grid-template-columns:1fr 1fr}
.hero-card .stats-grid .stat-unit:last-child{
  grid-column:1/-1;
  max-width:calc(50% - .5rem);
  margin:0 auto
}

/* ── OFERTA LANZAMIENTO ──────────────────────────────────────── */
.oferta-sec{
  background:linear-gradient(135deg,#0b1e1d 0%,#162e2b 45%,#0b1e1d 100%);
  position:relative;overflow:hidden;padding:5rem 0
}
.oferta-sec::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 80% at 75% 50%,rgba(201,162,86,.09),transparent);
  pointer-events:none
}
.oferta-flash{
  display:block;text-align:center;width:100%;
  font-family:var(--ff-b);font-size:.8rem;font-weight:700;
  letter-spacing:.1em;color:var(--teal-dark);
  background:var(--gold);padding:.75rem 1.5rem;border-radius:4px;
  margin-bottom:3rem;position:relative;z-index:1;
  animation:flash-pulse 2.8s ease-in-out infinite
}
@keyframes flash-pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(201,162,86,.5)}
  60%{box-shadow:0 0 0 10px rgba(201,162,86,.0)}
}
.oferta-inner{
  display:grid;grid-template-columns:1.1fr 1fr;
  gap:4rem;align-items:center;position:relative;z-index:1
}
.oferta-list{list-style:none;margin:1.8rem 0 1.5rem}
.oferta-list li{
  display:flex;align-items:flex-start;gap:1rem;
  padding:.85rem 0;border-bottom:1px solid rgba(201,162,86,.1)
}
.oferta-list li:last-child{border-bottom:none}
.ol-icon{
  width:26px;height:26px;flex-shrink:0;margin-top:2px;
  background:rgba(201,162,86,.15);border:1px solid rgba(201,162,86,.3);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:.65rem;color:var(--gold)
}
.oferta-list strong{
  display:block;font-family:var(--ff-b);font-size:.88rem;font-weight:600;
  color:#fff;margin-bottom:.15rem
}
.oferta-list span{
  font-family:var(--ff-b);font-size:.79rem;font-weight:300;
  color:rgba(255,255,255,.55);line-height:1.5
}
.oferta-nota{
  font-family:var(--ff-b);font-size:.76rem;font-weight:500;
  color:rgba(255,255,255,.32);letter-spacing:.04em;
  padding-top:.8rem;border-top:1px solid rgba(255,255,255,.08)
}
.oferta-card{
  background:rgba(255,255,255,.05);
  border:1.5px solid rgba(201,162,86,.35);
  border-radius:16px;padding:2.5rem 2rem;text-align:center;
  box-shadow:0 28px 80px rgba(0,0,0,.35);
  animation:card-glow 3s ease-in-out infinite
}
@keyframes card-glow{
  0%,100%{box-shadow:0 28px 80px rgba(0,0,0,.35),0 0 0 0 rgba(201,162,86,.1)}
  50%{box-shadow:0 28px 80px rgba(0,0,0,.35),0 0 35px 8px rgba(201,162,86,.2)}
}
.oc-sup{
  font-family:var(--ff-b);font-size:.62rem;font-weight:700;
  letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold);display:block;margin-bottom:1.2rem
}
.oc-prices{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:.3rem}
.oc-antes{
  font-family:var(--ff-b);font-size:1.1rem;font-weight:300;
  color:rgba(255,255,255,.3);text-decoration:line-through
}
.oc-tachado{
  font-family:var(--ff-b);font-size:1.4rem;font-weight:600;
  color:rgba(255,255,255,.45);text-decoration:line-through;
  text-decoration-color:var(--gold);text-decoration-thickness:2px
}
.oc-price-hero{
  display:flex;align-items:flex-start;justify-content:center;
  gap:.04em;margin:.4rem 0 .7rem;line-height:1
}
.oc-eur{
  font-family:var(--ff-d);font-size:2.8rem;font-weight:500;
  font-style:italic;color:var(--gold);margin-top:1.1rem
}
.oc-num{
  font-family:var(--ff-b);font-size:7.2rem;font-weight:800;
  color:var(--gold-pale);letter-spacing:-.05em;
  font-variant-numeric:tabular-nums lining-nums;
  font-feature-settings:"tnum" 1,"lnum" 1;
  text-shadow:0 0 50px rgba(237,216,154,.35);line-height:.9
}
.oferta-plazas{
  font-family:var(--ff-b);font-size:.72rem;font-weight:600;
  color:rgba(237,216,154,.7);letter-spacing:.04em;margin-bottom:1rem
}
.oc-badge-save{
  display:inline-block;
  font-family:var(--ff-b);font-size:.7rem;font-weight:800;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--teal-dark);background:var(--gold);
  padding:.38em 1.1em;border-radius:3px;margin-bottom:1.5rem
}
.oc-divider{height:1px;background:rgba(201,162,86,.18);margin:1.4rem 0}
.oc-exp-label{
  font-family:var(--ff-b);font-size:.62rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.38);margin-bottom:.8rem
}
.oc-countdown{
  display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1.8rem
}
.ocu{
  text-align:center;background:rgba(0,0,0,.22);
  border:1px solid rgba(201,162,86,.15);
  border-radius:6px;padding:.65rem .9rem;min-width:54px
}
.ocu-n{
  display:block;font-family:var(--ff-b);font-size:1.5rem;font-weight:700;
  font-variant-numeric:lining-nums tabular-nums;
  font-feature-settings:"lnum","tnum";
  color:var(--gold-pale);line-height:1
}
.ocu-l{
  display:block;font-family:var(--ff-b);font-size:.46rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.28);margin-top:.3rem
}
.ocu-sep{
  font-family:var(--ff-b);font-size:1.1rem;font-weight:300;
  color:rgba(201,162,86,.4);line-height:1
}
.oc-btn{
  display:block;text-decoration:none;
  font-family:var(--ff-b);font-size:.82rem;font-weight:800;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--teal-dark);
  background:linear-gradient(90deg,var(--gold),var(--gold-light));
  padding:1.05rem 1.5rem;border-radius:6px;
  transition:all .3s;box-shadow:0 6px 22px rgba(201,162,86,.4)
}
.oc-btn:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(201,162,86,.6)}
.oc-trust{
  font-family:var(--ff-b);font-size:.69rem;font-weight:400;
  color:rgba(255,255,255,.28);margin-top:.9rem
}
@media(max-width:900px){.oferta-inner{grid-template-columns:1fr;gap:2.5rem}}
@media(max-width:600px){
  .oferta-sec{padding:3.5rem 0}
  .oferta-flash{font-size:.72rem;padding:.6rem 1rem}
  .oc-num{font-size:4.8rem}
  .oc-eur{font-size:2.2rem;margin-top:.85rem}
  .oc-antes{font-size:1rem}
  .oferta-card{padding:2rem 1.4rem}
}

/* ── PRÓXIMAMENTE ─────────────────────────────────────────── */
.prox-sec{
  background:linear-gradient(160deg,#0b1e1d 0%,var(--teal-dark) 45%,#0b1e1d 100%);
  padding:6rem 0 5rem;
  text-align:center;
  position:relative;
  overflow:hidden
}
.prox-sec::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 50% at 50% 55%,rgba(201,162,86,.07),transparent);
  pointer-events:none
}
.prox-header{margin-bottom:3rem;position:relative;z-index:1}
.prox-eyebrow{
  display:inline-block;
  font-family:var(--ff-b);font-size:.65rem;font-weight:700;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);border:1px solid rgba(201,162,86,.35);
  padding:.35em 1.4em;border-radius:2px;margin-bottom:1.5rem
}
.prox-title{
  font-family:var(--ff-d);
  font-size:clamp(3rem,11vw,9rem);
  font-weight:300;font-style:italic;
  color:#fff;line-height:1;cursor:default;
  text-shadow:0 0 80px rgba(201,162,86,.2);
  transition:text-shadow .4s,color .4s
}
.prox-title:hover{color:var(--gold-pale);text-shadow:0 0 140px rgba(201,162,86,.6)}
.prox-dots{
  color:var(--gold);
  animation:dot-pulse 2.4s ease-in-out infinite
}
@keyframes dot-pulse{0%,100%{opacity:1}50%{opacity:.25}}
.prox-date-label{
  font-family:var(--ff-b);font-size:.88rem;font-weight:400;
  letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.38);margin-top:1.2rem
}
.prox-video-solo{
  max-width:420px;
  width:90%;
  margin:0 auto 1.5rem;
  border-radius:12px;
  overflow:hidden;
  border:2px solid rgba(201,162,86,.4);
  box-shadow:0 16px 50px rgba(0,0,0,.4);
  aspect-ratio:9/16
}
.prox-video-solo video{width:100%;height:100%;object-fit:cover;display:block}
/* Carrusel dentro de prox-sec (fondo oscuro) */
.galeria-prox{margin:2rem 0 0}
.prox-sec .galeria-btn{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.2);
  color:#fff
}
.prox-sec .galeria-btn:hover{background:rgba(255,255,255,.22);transform:translateY(-50%) scale(1.06)}
.prox-sec .galeria-dot{background:rgba(255,255,255,.22)}
.prox-sec .galeria-dot.active{background:var(--gold)}
.prox-sec .galeria-dots{padding:1.2rem 0 2.5rem}
.prox-sec .galeria-slide{border:1px solid rgba(201,162,86,.18)}
.prox-countdown{
  display:flex;align-items:center;justify-content:center;
  gap:.8rem;margin-top:3rem;flex-wrap:wrap
}
.cu{
  text-align:center;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(201,162,86,.2);
  border-radius:8px;padding:1.1rem 1.5rem;min-width:80px
}
.cu-num{
  display:block;font-family:var(--ff-b);font-size:2.4rem;font-weight:700;
  font-variant-numeric:lining-nums tabular-nums;
  font-feature-settings:"lnum","tnum";
  color:var(--gold-pale);line-height:1
}
.cu-lbl{
  display:block;font-family:var(--ff-b);
  font-size:.56rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.35);margin-top:.45rem
}
.cu-sep{
  font-family:var(--ff-b);font-size:1.8rem;font-weight:300;
  color:rgba(201,162,86,.4);line-height:1
}
/* Mobile */
@media(max-width:600px){
  .prox-sec{padding:4rem 0 3.5rem}
  .prox-title{font-size:clamp(2.4rem,12vw,4rem)}
  .prox-video-solo{max-width:320px}
  .cu{padding:.85rem .9rem;min-width:60px}
  .cu-num{font-size:1.6rem}
  .prox-countdown{gap:.4rem}
  .cu-sep{font-size:1.2rem}
  .prox-date-label{font-size:.76rem;letter-spacing:.12em}
  /* Stats 3-col compact en móvil */
  .hero-card .stat-unit{padding:.75rem .35rem}
  .hero-card .stat-lbl{font-size:.48rem;letter-spacing:.06em}
  .hero-card .stat-num{font-size:1.6rem}
}

/* ── COOKIE BANNER ───────────────────────────────────────────── */
.cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:500;
  background:rgba(29,62,60,.97);
  border-top:1px solid rgba(201,162,86,.35);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  transform:translateY(100%);
  transition:transform .45s cubic-bezier(.16,1,.3,1);
  padding:1.1rem 0
}
.cookie-banner.cb-visible{transform:translateY(0)}
.cookie-banner-inner{
  width:90%;max-width:1100px;margin:0 auto;
  display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap
}
.cookie-banner-text{
  flex:1;min-width:220px;
  font-family:var(--ff-b);font-size:.82rem;font-weight:300;
  color:rgba(255,255,255,.75);line-height:1.6
}
.cookie-banner-text strong{color:var(--gold-light);font-weight:600}
.cookie-banner-text a{color:var(--gold);text-decoration:underline}
.cookie-banner-actions{display:flex;gap:.6rem;flex-shrink:0;flex-wrap:wrap}
.cb-btn{
  font-family:var(--ff-b);font-size:.72rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  padding:.6rem 1.3rem;border-radius:2px;cursor:pointer;
  border:2px solid transparent;transition:all .25s;white-space:nowrap
}
.cb-btn-accept{
  background:var(--gold);color:var(--teal-dark);border-color:var(--gold)
}
.cb-btn-accept:hover{background:var(--gold-light);border-color:var(--gold-light)}
.cb-btn-reject{
  background:transparent;color:rgba(255,255,255,.7);
  border-color:rgba(255,255,255,.25)
}
.cb-btn-reject:hover{border-color:rgba(255,255,255,.6);color:#fff}

@media(max-width:600px){
  .cookie-banner-inner{flex-direction:column;align-items:stretch;gap:1rem}
  .cookie-banner-actions{justify-content:stretch}
  .cb-btn{flex:1;text-align:center;padding:.7rem 1rem}
  .cookie-banner{padding:1.2rem 0}
}

/* ── ANIMATIONS ─────────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
.fu{animation:fadeUp .8s ease both}
.d1{animation-delay:.12s}.d2{animation-delay:.26s}.d3{animation-delay:.4s}.d4{animation-delay:.56s}

.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal[data-split]{opacity:1;transform:none}

/* ── RESPONSIVE ─────────────────────────────────────────────── */

/* Hero eyebrow — reducir letter-spacing en pantallas medias (hero 2 columnas) */
@media(max-width:1280px){
  .hero-ey{letter-spacing:.12em}
}

@media(max-width:1024px){
  .hero-ey{letter-spacing:.1em}
}
/* ── RESPONSIVE — NAV MOBILE 1100px ────────────────────────── */
@media(max-width:1100px){
  .nav-inner{width:100%;padding:0 1rem;box-sizing:border-box;gap:.4rem}
  .nav-links,.nav-cta{display:none}
  .nav-cta{display:none!important}
  .nav-burger{display:flex;margin-right:0;flex-shrink:0}
  /* Phone button: visible on mobile (icon only) */
  .nav-phone-wrap{display:block}
  .nav-phone-btn{width:36px;height:36px}
  .nav-phone-drop{right:0;left:auto}
  /* Lang: flag + code, no arrow */
  .nl-arrow{display:none}
  .nl-flag{font-size:1rem}
  .nav-lang-btn{padding:.32rem .42rem;border-color:rgba(201,162,86,.25)}
  .nav-lang-drop{right:0;left:auto}
  /* Open menu */
  .nav.open .nav-links{
    display:flex;flex-direction:column;align-items:flex-start;gap:0;
    position:fixed;top:var(--nav-h);left:0;right:0;
    background:rgba(29,62,60,.98);backdrop-filter:blur(14px);
    padding:1rem 0;border-bottom:1px solid rgba(201,162,86,.18);
    max-height:calc(100svh - var(--nav-h));overflow-y:auto;z-index:1100
  }
  .nav.open .nav-links li{width:100%}
  .nav.open .nav-links a{
    display:block;font-size:.95rem;letter-spacing:.06em;
    padding:1rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.06);width:100%
  }
  .nav.open .nl-phone-li{display:block}
  .nav.open .nl-phone-li a{color:var(--gold-light)}
  .nav.open .nav-cta{display:block;margin:1rem 1.5rem;text-align:center}
}

/* ── RESPONSIVE — TABLET 900px ─────────────────────────────── */
@media(max-width:900px){
  .hero-inner,.diff-inner,.bk-inner{grid-template-columns:1fr;gap:3rem}
  /* Hero eyebrow — 1 columna, ancho completo, display block para wrap natural */
  .hero-ey{display:block;letter-spacing:.1em}
  .hero-ey::before{margin-right:.6rem}
  .srv-grid{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:1fr 1fr;max-width:100%}
  .faq-grid{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr 1fr}
  .bk-info .s-title,.bk-info .s-sub,.bk-info .gline{text-align:center;margin-left:auto;margin-right:auto}
  .map-overlay-card{top:1rem;left:1rem;max-width:240px;padding:1.1rem 1.3rem}
  /* Contact cards grid tablet */
  .contact-cards-grid{grid-template-columns:1fr 1fr !important}
}

/* ── RESPONSIVE — MOBILE 600px ─────────────────────────────── */
@media(max-width:600px){
  :root{--nav-h:64px}

  /* Typography */
  .s-title{font-size:clamp(1.7rem,6vw,2.4rem)}
  .page-hero-title{font-size:clamp(2rem,8vw,3rem)}

  /* Hero */
  .hero{padding:calc(var(--nav-h) + 3rem) 0 3.5rem}
  .hero-logo{width:100%;max-width:340px;margin-bottom:1.2rem}
  .hero-ey{font-size:.6rem;letter-spacing:.08em}
  .hero-ey::before{display:none}
  .hero-ctas{flex-direction:column}
  .hero-ctas .btn-p,.hero-ctas .btn-o{width:100%;text-align:center}
  /* Hero card */
  .hero-card{padding:1.6rem 1rem}
  .hero-card .stats-grid{grid-template-columns:1fr 1fr}

  /* Stats */
  .stats-grid{grid-template-columns:1fr 1fr}
  .stat-num{font-size:1.9rem}

  /* Services */
  .srv-grid{grid-template-columns:1fr}

  /* Section */
  .sec{padding:4rem 0}

  /* Team */
  .team-grid{grid-template-columns:1fr;max-width:420px;margin-left:auto;margin-right:auto}

  /* Values */
  .values-grid{grid-template-columns:1fr}

  /* Contact cards */
  .contact-cards-grid{grid-template-columns:1fr 1fr !important}

  /* Bk info center */
  .bk-info .s-title{font-size:clamp(1.6rem,6vw,2.2rem)}

  /* Form */
  .form-card{padding:1.8rem 1.2rem}

  /* Map */
  .map-wrapper{height:280px}
  .map-overlay-card{display:none}

  /* Footer */
  .footer-bottom{flex-direction:column;text-align:center}
  .footer-bottom-links{justify-content:center}

  /* Diff visual */
  .diff-visual{padding:1.8rem 1.2rem}
  .diff-visual-num{font-size:4rem}

  /* Legal */
  .legal-body{padding:calc(var(--nav-h) + 2rem) 0 3rem}

  /* Nav */
  .nav-inner{padding:0 1rem}
}

/* ── GOOGLE REVIEWS PAGE ─────────────────────────────────────── */
.gr-cta-wrap{
  max-width:600px;margin:0 auto;text-align:center;
  padding:3rem 2.5rem;
  background:#fff;border-radius:1.2rem;
  box-shadow:0 4px 40px rgba(29,62,60,.08);
}
.gr-stars{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1.5rem}
.gr-g-logo{width:2.4rem;height:2.4rem;flex-shrink:0}
.gr-stars-row{font-size:1.8rem;color:#FBBC04;letter-spacing:.05em}
.gr-cta-title{font-family:var(--ff-d);font-size:2.4rem;font-weight:500;color:var(--text-dark);margin-bottom:1rem;line-height:1.15}
.gr-cta-title em{font-style:italic;color:var(--teal)}
.gr-cta-text{font-size:.95rem;color:var(--text-mid);line-height:1.7;margin-bottom:2rem;max-width:440px;margin-left:auto;margin-right:auto}
.gr-btn{display:inline-flex;align-items:center;gap:.45em;font-size:.82rem}
.gr-cta-note{margin-top:1rem;font-size:.78rem;color:#aaa;letter-spacing:.02em}

/* ── GMAP SECTION ────────────────────────────────────────────── */
.gmap-section{background:var(--cream-dark)}
.gmap-frame{
  border-radius:12px;overflow:hidden;
  box-shadow:0 8px 40px rgba(29,62,60,.14);
  margin:2.5rem 0 2rem;
  border:1px solid rgba(201,162,86,.2)
}
.gmap-frame iframe{display:block}
.gmap-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ── REVIEW STEPS ────────────────────────────────────────────── */
.review-steps{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2rem;margin-top:3rem;text-align:left
}
.review-step{
  padding:2rem 1.6rem;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(201,162,86,.2);
  border-radius:10px
}
.rs-num{
  display:block;
  font-family:var(--ff-b);font-size:2.4rem;font-weight:700;
  font-variant-numeric:lining-nums tabular-nums;
  font-feature-settings:"lnum","tnum";
  color:var(--gold-pale);line-height:1;margin-bottom:.8rem
}
.review-step h3{
  font-family:var(--ff-b);font-size:.82rem;font-weight:700;
  color:#fff;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.6rem
}
.review-step p{
  font-family:var(--ff-b);font-size:.85rem;font-weight:300;
  color:rgba(255,255,255,.58);line-height:1.75
}

@media(max-width:720px){
  .gr-cta-wrap{padding:2rem 1.4rem}
  .gr-cta-title{font-size:1.9rem}
  .review-steps{grid-template-columns:1fr}
  .gmap-frame iframe{height:300px}
}

@media(max-width:720px){
  .footer-cols{grid-template-columns:1fr;gap:2rem}
  .footer-brand{flex-direction:column;align-items:flex-start;gap:.8rem}
  .footer-bottom{flex-direction:column;text-align:center}
  .footer-bottom-links{justify-content:center}
}

/* ── RESPONSIVE — XS 400px ──────────────────────────────────── */
@media(max-width:400px){
  .contact-cards-grid{grid-template-columns:1fr !important}
  .stats-grid{grid-template-columns:1fr 1fr}
  .hero-ctas .btn-p,.hero-ctas .btn-o{padding:.85rem 1.5rem;font-size:.75rem}
  .hero-ey{font-size:.58rem;letter-spacing:.06em}
  .hero-card .stats-grid{grid-template-columns:1fr}
  .hero-card .stats-grid .stat-unit:last-child{max-width:100%}
  .hero-card{padding:1.4rem .9rem}
}

/* ── MUTUA GRID (servicios.html) ─────────────────────────────────────────── */
.mutua-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(128px,1fr));
  gap:.9rem;
  margin-top:2.5rem;
  text-align:center;
}
.mutua-card{
  background:#fff;
  border:1.5px solid rgba(201,162,86,.2);
  border-radius:10px;
  padding:1rem .7rem .9rem;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:.6rem;
  min-height:82px;
  transition:border-color .2s, box-shadow .2s, transform .18s;
}
.mutua-card:hover{
  border-color:rgba(201,162,86,.55);
  box-shadow:0 4px 20px rgba(26,107,94,.1);
  transform:translateY(-2px);
}
.mutua-logo{
  width:90px;height:46px;
  object-fit:contain;
  display:block;
  flex-shrink:0;
}
.mutua-name{
  font-family:var(--ff-b);
  font-size:.65rem;font-weight:700;
  color:var(--teal-dark);
  text-transform:uppercase;letter-spacing:.08em;
  line-height:1.3;
  text-align:center;
}
/* ── HERO MUTUA MORE BADGE ─────────────────────────────────────────────── */
.hero-mutua-more{
  font-family:var(--ff-b);font-size:.65rem;font-weight:700;
  color:var(--gold);
  background:rgba(201,162,86,.12);
  border:1px solid rgba(201,162,86,.35);
  border-radius:4px;padding:.22rem .55rem;
  white-space:nowrap;
}
/* ── MUTUA CHIP PICKER (form) ──────────────────────────────────────────── */
.mutua-picker{
  display:flex;flex-wrap:wrap;gap:.4rem;
  margin-top:.5rem;
  max-height:180px;
  overflow-y:auto;
  padding:.5rem;
  background:var(--cream);
  border:1.5px solid rgba(201,162,86,.22);
  border-radius:8px;
  scrollbar-width:thin;
  scrollbar-color:rgba(201,162,86,.4) transparent;
}
.mutua-pick-chip{
  font-family:var(--ff-b);
  font-size:.72rem;font-weight:600;
  color:var(--teal-dark);
  background:var(--white);
  border:1.5px solid rgba(201,162,86,.28);
  border-radius:20px;
  padding:.35rem .85rem;
  cursor:pointer;user-select:none;
  transition:all .14s;white-space:nowrap;
}
.mutua-pick-chip:hover{
  border-color:var(--gold);
  background:rgba(201,162,86,.08);
}
.mutua-pick-chip.active{
  background:var(--teal);color:#fff;
  border-color:var(--teal);
}
@media(max-width:720px){
  .mutua-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.65rem}
  .mutua-card{padding:1rem .5rem .85rem}
}
@media(max-width:540px){
  .mutua-grid{grid-template-columns:repeat(3,1fr)}
}

/* ── MODAL CONFIRMACIÓN CITA ─────────────────────────────────────────────── */
.cita-modal-overlay{
  position:fixed;inset:0;z-index:9999;
  background:rgba(15,30,29,.72);
  display:flex;align-items:center;justify-content:center;
  padding:1rem;
  backdrop-filter:blur(4px);
  animation:fadeInOverlay .25s ease;
}
@keyframes fadeInOverlay{from{opacity:0}to{opacity:1}}
.cita-modal-box{
  background:#fff;border-radius:16px;
  padding:2.4rem 2rem 2rem;
  max-width:480px;width:100%;
  text-align:center;
  box-shadow:0 32px 80px rgba(0,0,0,.28);
  animation:slideUpModal .3s cubic-bezier(.22,1,.36,1);
}
@keyframes slideUpModal{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
.cita-modal-check{width:56px;height:56px;margin:0 auto 1.2rem}
.cita-modal-check svg{width:100%;height:100%}
.cita-modal-title{
  font-family:var(--ff-d);font-size:1.6rem;font-weight:600;
  color:var(--teal-dark);margin:0 0 .8rem;
}
.cita-modal-msg{
  font-size:.88rem;line-height:1.7;color:var(--text-mid);margin:0 0 1.2rem;
}
.cita-modal-contact-row{
  display:flex;gap:.6rem;justify-content:center;margin:.9rem 0 1rem;
}
.cita-contact-chip{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.6rem 1.1rem;border-radius:50px;
  font-family:var(--ff-b);font-size:.85rem;font-weight:600;
  text-decoration:none;transition:transform .15s,box-shadow .15s;
}
.cita-contact-chip svg{width:16px;height:16px;flex-shrink:0}
.cita-contact-chip:hover{transform:translateY(-2px);box-shadow:0 5px 16px rgba(0,0,0,.13)}
.cita-chip-call{background:var(--cream-dark);color:var(--teal-dark);border:1.5px solid rgba(43,90,87,.15)}
.cita-chip-wa{background:#25D366;color:#fff}
.cita-modal-divider{
  height:1px;background:rgba(201,162,86,.2);margin:1.2rem 0;
}
.cita-modal-social-title{
  font-family:var(--ff-b);font-size:.8rem;font-weight:600;
  color:var(--teal-dark);text-transform:uppercase;letter-spacing:.06em;
  margin:0 0 1rem;
}
.cita-modal-actions{
  display:flex;flex-direction:column;gap:.65rem;margin-bottom:1.4rem;
}
.cita-modal-btn{
  display:flex;align-items:center;justify-content:center;gap:.55rem;
  padding:.85rem 1.2rem;border-radius:8px;
  font-family:var(--ff-b);font-size:.85rem;font-weight:600;
  text-decoration:none;transition:transform .15s,box-shadow .15s;
}
.cita-modal-btn svg{width:18px;height:18px;flex-shrink:0}
.cita-modal-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.12)}
.cita-btn-review{
  background:var(--teal-dark);color:#fff;
}
.cita-btn-ig{
  background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);
  color:#fff;
}
.cita-modal-close{
  background:none;border:none;
  font-family:var(--ff-b);font-size:.8rem;font-weight:500;
  color:var(--text-mid);cursor:pointer;padding:.4rem 1rem;
  text-decoration:underline;text-underline-offset:3px;
}
.cita-modal-close:hover{color:var(--teal-dark)}
@media(max-width:480px){
  .cita-modal-box{padding:1.8rem 1.2rem 1.4rem}
  .cita-modal-title{font-size:1.35rem}
}

/* Elimina el delay de 300ms en tap (móvil) en todos los elementos interactivos */
a,button,.hora-chip,.mutua-pick-chip,.radio-lbl,.btn-p,.btn-o,.nav-cta,.oc-btn{
  touch-action:manipulation
}

/* ── GALERÍA CARRUSEL (transform GPU) ─────────────────────────── */
.galeria-outer{
  position:relative;
  overflow:hidden;
  width:100%;
  user-select:none;
  -webkit-user-select:none;
  cursor:grab;
}
.galeria-outer:active{cursor:grabbing}
.galeria-track{
  display:flex;
  gap:1rem;
  will-change:transform;
}
.galeria-slide{
  flex-shrink:0;
  width:400px;
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 4px 24px rgba(0,0,0,.18);
}
.galeria-slide img{
  width:100%;
  aspect-ratio:3/4;
  object-fit:cover;
  display:block;
  pointer-events:none;
}
.galeria-btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  background:rgba(255,255,255,.92);
  border:1px solid rgba(43,90,87,.15);
  width:46px;height:46px;
  border-radius:50%;
  font-size:1.6rem;line-height:1;
  cursor:pointer;
  z-index:2;
  box-shadow:0 2px 12px rgba(0,0,0,.12);
  transition:background .15s,box-shadow .15s;
  display:flex;align-items:center;justify-content:center;
  color:var(--teal-dark);
  touch-action:manipulation;
}
.galeria-btn:hover{background:#fff;box-shadow:0 4px 20px rgba(0,0,0,.2)}
.galeria-prev{left:1rem}
.galeria-next{right:1rem}
.galeria-dots{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:.55rem;
  padding:1.4rem 0 3rem;
}
.galeria-dot{
  width:8px;height:8px;
  border-radius:50%;
  border:none;
  background:rgba(43,90,87,.2);
  transition:background .25s,transform .25s;
  cursor:pointer;
  padding:0;
  touch-action:manipulation;
}
.galeria-dot.active{
  background:var(--teal);
  transform:scale(1.4);
}
@media(max-width:720px){
  .galeria-btn{display:none}
  .galeria-slide{width:84vw;border-radius:12px}
}
