/* Irulegui Centro Canino — landing
   Paleta: negro / crema / rojo huella
*/

:root{
  --ink:#0a0a0a;
  --ink-2:#171719;
  --ink-soft:#26262a;
  --paper:#ffffff;
  --paper-2:#f5f5f7;
  --paper-3:#ececef;
  --line:#e4e4e7;
  --red:#de1b3b;
  --red-dark:#b1142c;
  --muted:#5b5b62;
  --muted-2:#8a8a92;

  --font-display:'Fraunces','Cormorant Garamond',Georgia,serif;
  --font-body:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

  --radius:14px;
  --radius-sm:8px;
  --shadow-sm:0 1px 2px rgba(10,10,10,.06),0 6px 18px rgba(10,10,10,.05);
  --shadow:0 12px 40px rgba(10,10,10,.12);
  --container:min(1180px,100% - 2.5rem);

  --t:.35s cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg,iframe{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;letter-spacing:-.01em;line-height:1.1;margin:0}
p{margin:0 0 1em}
em{font-style:italic;color:var(--red)}

.skip{position:absolute;left:-1000px}
.skip:focus{left:1rem;top:1rem;background:#fff;padding:.5rem 1rem;z-index:9999}

.container{width:var(--container);margin:0 auto}

/* ── eyebrow / section heads ───────── */
.eyebrow{
  display:inline-block;
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--red);
  font-weight:600;
  margin-bottom:1rem;
}
.eyebrow--light{color:#ffadbb}
.section__head{max-width:720px;margin:0 0 3.5rem}
.section__head h2{font-size:clamp(1.9rem,4vw,2.9rem);margin-bottom:1rem}
.section__head p{color:var(--muted);font-size:1.08rem}

/* ── nav ───────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:1.1rem 0;
  transition:background var(--t),backdrop-filter var(--t),box-shadow var(--t),padding var(--t);
}
.nav.is-scrolled{background:rgba(10,10,10,.92);backdrop-filter:blur(10px);padding:.7rem 0;box-shadow:0 1px 0 rgba(255,255,255,.06)}
.nav__inner{
  width:var(--container);margin:0 auto;
  display:flex;align-items:center;gap:2rem;
}
.nav__brand{display:flex;align-items:center;gap:.7rem;color:#fff}
.nav__mark{
  display:inline-flex;align-items:center;justify-content:center;
  background:#fff;border-radius:10px;
  width:46px;height:46px;
  box-shadow:0 2px 8px rgba(0,0,0,.18);
  flex-shrink:0;
  transition:width var(--t),height var(--t);
}
.nav.is-scrolled .nav__mark{width:40px;height:40px}
.nav__mark img{width:80%;height:auto;display:block;object-fit:contain}
.nav__brandtext{display:flex;flex-direction:column;line-height:1}
.nav__brandtext strong{font-family:var(--font-display);font-size:1.2rem;letter-spacing:.02em;font-weight:700}
.nav__brandtext small{font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:#9a9aa2;margin-top:3px}

.nav__menu{margin-left:auto;display:flex;gap:1.6rem}
.nav__menu a{color:#f4f4f7;font-size:.93rem;font-weight:500;opacity:.85;transition:opacity var(--t),color var(--t);position:relative}
.nav__menu a:hover{opacity:1;color:#fff}
.nav__menu a::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:1px;background:var(--red);transition:right var(--t)}
.nav__menu a:hover::after{right:0}

.nav__cta{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--red);color:#fff;padding:.65rem 1.05rem;border-radius:999px;
  font-size:.86rem;font-weight:600;
  transition:background var(--t),transform var(--t);
}
.nav__cta:hover{background:var(--red-dark);transform:translateY(-1px)}

.nav__burger{display:none;width:36px;height:36px;flex-direction:column;justify-content:center;gap:5px;align-items:center}
.nav__burger span{width:22px;height:2px;background:#fff;transition:transform var(--t),opacity var(--t)}
.nav__burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger.is-open span:nth-child(2){opacity:0}
.nav__burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── hero ───────── */
.hero{
  position:relative;
  min-height:100vh;min-height:100svh;
  display:flex;align-items:center;
  color:#fff;
  overflow:hidden;
  isolation:isolate;
}
.hero__bg{position:absolute;inset:0;z-index:-1}
.hero__bg img{width:100%;height:100%;object-fit:cover;animation:zoom 18s ease-out infinite alternate}
@keyframes zoom{from{transform:scale(1.0)}to{transform:scale(1.08)}}
.hero__veil{position:absolute;inset:0;background:
  radial-gradient(ellipse at 20% 80%,rgba(200,16,46,.18),transparent 55%),
  linear-gradient(180deg,rgba(10,10,10,.55) 0%,rgba(10,10,10,.78) 100%)}
.hero__inner{
  width:var(--container);margin:0 auto;
  padding:9rem 0 7rem;
  max-width:920px;
}
.hero__title{
  font-size:clamp(2.4rem,6.5vw,5rem);
  font-weight:500;
  letter-spacing:-.02em;
  line-height:1.02;
  margin:.4rem 0 1.4rem;
}
.hero__title span{display:block}
.hero__kicker{font-family:var(--font-display);font-style:italic;font-size:clamp(1.1rem,1.8vw,1.45rem);color:#ff8aa0;margin:.2rem 0 1.4rem;letter-spacing:.005em;font-weight:400}
.hero__lead{font-size:clamp(1.05rem,1.6vw,1.22rem);max-width:640px;color:#d8d8de;margin-bottom:2rem}
.hero__ctas{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:2.4rem}
.hero__meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;color:#b8b8be;font-size:.92rem}
.hero__meta .rating strong{color:#fff;font-size:1.05rem;margin-right:.3rem}
.hero__meta .rating small{margin-left:.4rem;color:#82828a}
.hero__meta .dot{width:4px;height:4px;border-radius:50%;background:#5a5a62}
.hero__scroll{
  position:absolute;left:50%;bottom:2rem;transform:translateX(-50%);
  width:24px;height:38px;border:1.5px solid rgba(255,255,255,.5);border-radius:13px;
  display:flex;justify-content:center;
}
.hero__scroll span{display:block;width:2px;height:7px;background:#fff;margin-top:7px;border-radius:1px;animation:scroll 1.6s ease-in-out infinite}
@keyframes scroll{0%,100%{opacity:0;transform:translateY(0)}50%{opacity:1;transform:translateY(8px)}}

/* ── buttons ───────── */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.95rem 1.45rem;border-radius:999px;
  font-size:.96rem;font-weight:600;
  letter-spacing:.01em;
  transition:transform var(--t),background var(--t),color var(--t),box-shadow var(--t);
  white-space:nowrap;
}
.btn--primary{background:var(--red);color:#fff;box-shadow:0 8px 24px rgba(200,16,46,.35)}
.btn--primary:hover{background:var(--red-dark);transform:translateY(-2px);box-shadow:0 10px 30px rgba(200,16,46,.45)}
.btn--ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.4)}
.btn--ghost:hover{background:#fff;color:var(--ink);border-color:#fff}

/* alt ghost on light bg */
.visit__info .btn--ghost{color:var(--ink);border-color:var(--ink)}
.visit__info .btn--ghost:hover{background:var(--ink);color:#fff}

/* ── band ───────── */
.band{background:var(--ink);color:#fff;padding:1.4rem 0;border-top:1px solid #1c1c1c;border-bottom:1px solid #1c1c1c}
.band__inner{
  width:var(--container);margin:0 auto;
  display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;
  font-size:.93rem;color:#b8b8be;
}
.band__inner strong{color:#fff;font-weight:600}

/* ── services ───────── */
.services{padding:7rem 0 6rem}
.grid{display:grid;gap:1.4rem}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}

.card{
  position:relative;
  background:linear-gradient(180deg,#fff 0%,#fafafb 100%);
  border:1px solid var(--line);
  padding:2.1rem 1.8rem 1.8rem;
  border-radius:18px;
  overflow:hidden;
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
  isolation:isolate;
}
.card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent 0%,var(--red) 50%,transparent 100%);
  transform:scaleX(0);transform-origin:center;
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
}
.card::after{
  content:"";position:absolute;top:-30px;right:-30px;
  width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle,rgba(222,27,59,.06) 0%,transparent 70%);
  opacity:0;transition:opacity var(--t);
  pointer-events:none;z-index:-1;
}
.card:hover{
  transform:translateY(-6px);
  box-shadow:0 18px 48px rgba(10,10,10,.10),0 4px 12px rgba(222,27,59,.06);
  border-color:rgba(222,27,59,.22);
}
.card:hover::before{transform:scaleX(1)}
.card:hover::after{opacity:1}

.card__ico{
  display:inline-flex;align-items:center;justify-content:center;
  width:56px;height:56px;border-radius:16px;
  background:linear-gradient(135deg,#fde7ec 0%,#fff5f7 100%);
  color:var(--red);
  margin-bottom:1.4rem;
  position:relative;
  box-shadow:inset 0 0 0 1px rgba(222,27,59,.12),0 6px 14px rgba(222,27,59,.08);
  transition:transform var(--t),background var(--t),color var(--t),box-shadow var(--t);
}
.card__ico::before{
  content:"";position:absolute;inset:-4px;border-radius:20px;
  background:radial-gradient(circle,rgba(222,27,59,.18) 0%,transparent 70%);
  opacity:0;transition:opacity var(--t);z-index:-1;
}
.card__ico svg{width:28px;height:28px;transition:transform var(--t)}
.card:hover .card__ico{
  background:linear-gradient(135deg,var(--red) 0%,var(--red-dark) 100%);
  color:#fff;
  transform:scale(1.05) rotate(-3deg);
  box-shadow:0 10px 24px rgba(222,27,59,.35);
}
.card:hover .card__ico::before{opacity:1}
.card:hover .card__ico svg{transform:scale(1.08)}

.card h3{font-size:1.32rem;margin-bottom:.55rem;letter-spacing:-.005em}
.card p{color:var(--muted);font-size:.95rem;margin-bottom:.5rem;line-height:1.55}
.card__tag{
  display:inline-block;margin-top:.7rem;
  font-size:.74rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--red);background:#fde6ea;padding:.4rem .85rem;border-radius:999px;
  border:1px solid rgba(222,27,59,.12);
}
.card__list{
  list-style:none;padding:0;margin:1.1rem 0 0;
  border-top:1px solid var(--line);padding-top:1.1rem;
  display:flex;flex-direction:column;gap:.6rem;
}
.card__list li{
  position:relative;padding-left:1.5rem;
  font-size:.92rem;color:var(--ink-soft);line-height:1.5;
  transition:color var(--t),padding-left var(--t);
}
.card__list li::before{
  content:"";position:absolute;left:0;top:.62rem;
  width:10px;height:2px;background:var(--red);border-radius:1px;
  transition:width var(--t);
}
.card:hover .card__list li::before{width:14px}

/* ── who ───────── */
.who{padding:7rem 0 6rem;background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.who__grid{gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}
.who__card{
  padding:2.2rem 1.8rem;
  border-right:1px solid var(--line);
  transition:background var(--t);
}
.who__card:last-child{border-right:0}
.who__card:hover{background:var(--paper-2)}
.who__num{
  font-family:var(--font-display);
  font-size:.9rem;letter-spacing:.18em;color:var(--red);font-weight:600;
  display:inline-block;margin-bottom:1.4rem;
  position:relative;padding-left:1.6rem;
}
.who__num::before{
  content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:1rem;height:1px;background:var(--red);
}
.who__card h3{font-size:1.15rem;margin-bottom:.6rem;line-height:1.25}
.who__card p{font-size:.92rem;color:var(--muted);margin:0;line-height:1.55}

/* ── filosofía ───────── */
.philo{
  background:var(--ink) url("../assets/philosophy.webp") center/cover;
  background-blend-mode:multiply;
  color:#fff;padding:8rem 0;position:relative;
}
.philo::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.85),rgba(10,10,10,.92))}
.philo__inner{position:relative;width:var(--container);margin:0 auto;max-width:920px;text-align:center}
.philo__quote{margin:0 0 2.4rem;border:0;padding:0}
.philo__quote p{
  font-family:var(--font-display);
  font-size:clamp(1.6rem,3.4vw,2.6rem);
  line-height:1.3;font-weight:400;letter-spacing:-.01em;
  margin:0;color:#fff;
}
.philo__quote em{color:#ff8aa0;font-style:italic}
.philo__copy{max-width:680px;margin:0 auto;color:#c8c8ce;font-size:1.05rem}

/* ── team ───────── */
.team{padding:7rem 0}
.team__grid{gap:2rem}
.person{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:grid;grid-template-columns:200px 1fr;
  transition:transform var(--t),box-shadow var(--t);
}
.person:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.person__photo{background:var(--ink) center/cover;min-height:260px;position:relative}
.person__photo--mikel{background-image:url("../assets/mikel.webp");background-position:center 35%}
.person__photo--patricia{background-image:url("../assets/patricia.webp");background-position:center 18%}
.person__photo::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,10,10,.05),rgba(200,16,46,.08))}
.person__body{padding:1.8rem 1.8rem 1.8rem 1.8rem}
.person__body h3{font-size:1.4rem;margin-bottom:.2rem}
.person__role{font-size:.85rem;color:var(--red);font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:.6rem}
.person__cert{font-size:.82rem;color:var(--ink);font-weight:500;margin-bottom:1rem;padding:.45rem .7rem;background:var(--paper-2);border-left:2px solid var(--red);border-radius:0 6px 6px 0;line-height:1.4}
.person__body p{color:var(--muted);font-size:.96rem;margin:0}

/* ── process ───────── */
.process{padding:6rem 0;background:var(--paper-2)}
.steps{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;
  counter-reset:step;
}
.steps li{position:relative;padding-top:1.5rem;border-top:1px solid var(--line)}
.steps__num{
  font-family:var(--font-display);
  font-size:1.05rem;color:var(--red);font-weight:600;letter-spacing:.06em;
  margin-bottom:1rem;display:inline-block;
}
.steps h3{font-size:1.2rem;margin-bottom:.5rem}
.steps p{color:var(--muted);font-size:.95rem;margin:0}

/* ── gallery ───────── */
.gallery{padding:7rem 0;background:var(--paper)}
.gallery__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:240px;
  gap:1rem;
}
.gallery__item{margin:0;overflow:hidden;border-radius:var(--radius-sm);position:relative}
.gallery__item img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .8s ease}
.gallery__item:hover img{transform:scale(1.05)}
.gallery__item--tall{grid-row:span 2}
.gallery__item--wide{grid-column:span 2}
.gallery__note{margin-top:1.5rem;color:var(--muted);text-align:center}

/* ── reviews ───────── */
.reviews{padding:7rem 0;background:#fff}
.reviews__grid{gap:1.6rem;margin-bottom:2.5rem}
.review{
  background:var(--paper);border:1px solid var(--line);
  padding:2rem 1.8rem;border-radius:var(--radius);
  display:flex;flex-direction:column;
}
.review__stars{color:var(--red);font-size:1.1rem;letter-spacing:.18em;margin-bottom:1rem}
.review p{font-size:1rem;color:var(--ink-soft);margin-bottom:1.4rem;flex:1}
.review footer{border-top:1px solid var(--line);padding-top:1rem;display:flex;flex-direction:column}
.review footer strong{font-weight:600}
.review footer small{color:var(--muted);font-size:.82rem;margin-top:.2rem}
.reviews__cta{text-align:center}
.link--arrow{font-weight:600;color:var(--red);font-size:1rem}
.link--arrow:hover{color:var(--red-dark)}

/* ── visit ───────── */
.visit{padding:7rem 0;background:var(--paper-2)}
.visit__grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-bottom:3rem;align-items:start}
.visit__info h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:2rem}
.visit__list{list-style:none;padding:0;margin:0 0 2rem;display:flex;flex-direction:column;gap:1.2rem}
.visit__list li{display:grid;grid-template-columns:140px 1fr;gap:1rem;border-bottom:1px solid var(--line);padding-bottom:1.2rem}
.visit__list li:last-child{border-bottom:0}
.visit__list strong{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--red);font-weight:600;padding-top:3px}
.visit__list a:hover{color:var(--red)}
.visit__ctas{display:flex;gap:.8rem;flex-wrap:wrap}

.visit__form{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:2.2rem;display:flex;flex-direction:column;gap:1rem;
  box-shadow:var(--shadow-sm);
}
.visit__form h3{font-size:1.4rem;margin-bottom:.4rem}
.visit__form label{display:flex;flex-direction:column;gap:.4rem;font-size:.85rem;font-weight:500}
.visit__form input,.visit__form textarea{
  font:inherit;font-size:.96rem;
  border:1px solid var(--line);background:var(--paper);
  border-radius:10px;padding:.8rem 1rem;color:var(--ink);
  transition:border-color var(--t),background var(--t);
}
.visit__form input:focus,.visit__form textarea:focus{outline:none;border-color:var(--red);background:#fff}
.visit__form textarea{resize:vertical;min-height:110px}
.visit__form .btn{justify-content:center;margin-top:.4rem}
.visit__legal{margin:0;color:var(--muted);font-size:.78rem}

.visit__map{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line)}

/* ── ctaband intermedio ───────── */
.ctaband{
  background:var(--ink) url("../assets/ctaband.webp") center/cover;
  background-blend-mode:multiply;
  padding:5rem 0;color:#fff;position:relative;
}
.ctaband::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,10,10,.94) 0%,rgba(10,10,10,.78) 100%)}
.ctaband__inner{
  position:relative;width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr;gap:3rem;align-items:center;
}
.ctaband h2{font-size:clamp(1.6rem,3vw,2.4rem);margin-bottom:.7rem;color:#fff}
.ctaband p{color:#c8c8ce;max-width:520px;margin:0;font-size:1.02rem}
.ctaband__actions{display:flex;gap:.8rem;flex-wrap:wrap;justify-content:flex-end}
.ctaband .btn--ghost{color:#fff;border-color:rgba(255,255,255,.45)}
.ctaband .btn--ghost:hover{background:#fff;color:var(--ink);border-color:#fff}

/* ── faq ───────── */
.faq{padding:7rem 0;background:var(--paper)}
.faq__list{display:flex;flex-direction:column;gap:.6rem;max-width:880px;margin:0 auto}
.faq__item{
  background:var(--paper-2);border:1px solid var(--line);
  border-radius:var(--radius-sm);
  transition:border-color var(--t),background var(--t);
}
.faq__item[open]{background:#fff;border-color:var(--ink);box-shadow:var(--shadow-sm)}
.faq__item summary{
  list-style:none;cursor:pointer;
  padding:1.2rem 1.5rem;
  font-family:var(--font-display);font-size:1.08rem;font-weight:500;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  color:var(--ink);
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{
  content:"";flex-shrink:0;
  width:20px;height:20px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23de1b3b' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M12 5v14M5 12h14'/%3E%3C/svg%3E");
  background-size:contain;background-repeat:no-repeat;background-position:center;
  transition:transform var(--t);
}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__item > div{padding:0 1.5rem 1.4rem;color:var(--muted);font-size:.98rem;line-height:1.6}
.faq__item > div p{margin:0}

/* ── footer ───────── */
.foot{background:var(--ink);color:#b8b8be;padding:3.5rem 0 2rem}
.foot__inner{
  width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:1fr auto 1fr;gap:2rem;align-items:center;
}
.foot__brand{display:flex;align-items:center;gap:1rem;color:#fff}
.foot__mark{
  display:inline-flex;align-items:center;justify-content:center;
  background:#fff;border-radius:12px;padding:8px;
  width:96px;height:96px;flex-shrink:0;
  box-shadow:0 4px 18px rgba(0,0,0,.25);
}
.foot__mark img{max-width:100%;max-height:100%;display:block;object-fit:contain}
.foot__brand strong{display:block;font-family:var(--font-display);font-size:1.05rem;color:#fff;font-weight:600}
.foot__brand small{font-size:.78rem;color:#76767e}
.foot__nav{display:flex;gap:1.4rem;justify-content:center}
.foot__nav a{font-size:.9rem;color:#b8b8be}
.foot__nav a:hover{color:#fff}
.foot__legal{display:flex;gap:1.2rem;justify-content:flex-end;align-items:center;font-size:.85rem;color:#5a5a62}
.foot__legal a:hover{color:#fff}

/* ── floating WhatsApp ───────── */
.wfloat{
  position:fixed;right:1.4rem;bottom:1.4rem;z-index:60;
  width:56px;height:56px;border-radius:50%;
  background:#25d366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 28px rgba(37,211,102,.45);
  transition:transform var(--t),box-shadow var(--t);
}
.wfloat::before{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  border:2px solid #25d366;opacity:.45;animation:pulse 2.4s infinite;
}
@keyframes pulse{0%{transform:scale(.9);opacity:.6}100%{transform:scale(1.5);opacity:0}}
.wfloat:hover{transform:scale(1.07);box-shadow:0 12px 36px rgba(37,211,102,.6)}

/* ── reveal animation ───────── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.is-in{opacity:1;transform:none}

/* ── responsive ───────── */
@media (max-width:1000px){
  .grid--3{grid-template-columns:repeat(2,1fr)}
  .grid--4{grid-template-columns:repeat(2,1fr)}
  .who__grid{grid-template-rows:auto auto}
  .who__card:nth-child(2){border-right:0}
  .who__card:nth-child(1),.who__card:nth-child(2){border-bottom:1px solid var(--line)}
  .who__card:nth-child(3){border-right:1px solid var(--line)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .gallery__grid{grid-template-columns:repeat(3,1fr)}
  .ctaband__inner{grid-template-columns:1fr;gap:1.5rem}
  .ctaband__actions{justify-content:flex-start}
  .visit__grid{grid-template-columns:1fr}
  .foot__inner{grid-template-columns:1fr;text-align:center}
  .foot__nav{justify-content:center}
  .foot__legal{justify-content:center}
}
@media (max-width:720px){
  body{font-size:16px}
  .nav__menu{
    position:fixed;inset:60px 0 auto 0;
    background:rgba(10,10,10,.97);backdrop-filter:blur(10px);
    flex-direction:column;gap:0;padding:1rem 1.5rem 1.5rem;
    transform:translateY(-110%);transition:transform var(--t);
    border-top:1px solid #1c1c1c;
  }
  .nav__menu.is-open{transform:translateY(0)}
  .nav__menu a{padding:.85rem 0;border-bottom:1px solid #1c1c1c;font-size:1rem;opacity:1;color:#fff}
  .nav__menu a::after{display:none}
  .nav__cta span{display:none}
  .nav__cta{padding:.55rem .85rem}
  .nav__burger{display:flex}

  /* Hero más compacto sin perder impacto */
  .hero{min-height:88vh;min-height:88svh}
  .hero__inner{padding:5.5rem 0 3rem}
  .hero__title{margin:.3rem 0 .9rem}
  .hero__kicker{margin:.1rem 0 1rem}
  .hero__lead{margin-bottom:1.4rem}
  .hero__ctas{width:100%;margin-bottom:1.6rem}
  .hero__ctas .btn{flex:1;justify-content:center}

  .grid{gap:1rem}
  .grid--3,.grid--2,.grid--4{grid-template-columns:1fr}

  /* Cards más compactas */
  .card{padding:1.4rem 1.3rem}
  .card__list{margin-top:.8rem;padding-top:.8rem;gap:.45rem}
  .card h3{margin-bottom:.45rem}
  .card__ico{width:42px;height:42px;margin-bottom:.85rem}

  .who__card{border-right:0!important;border-bottom:1px solid var(--line);padding:1.5rem 1.4rem}
  .who__card:last-child{border-bottom:0}
  .who__num{margin-bottom:.9rem}

  .steps{grid-template-columns:1fr;gap:1rem}
  .steps li{padding-top:1rem}
  .steps__num{margin-bottom:.55rem}
  .steps h3{margin-bottom:.35rem}

  .gallery__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px;gap:.7rem}
  .gallery__item--wide{grid-column:span 2}
  .gallery__item--tall{grid-row:span 1}

  .person{grid-template-columns:1fr}
  .person__photo{min-height:0;aspect-ratio:5/4}
  .person__photo--patricia{background-position:center 22%}
  .person__photo--mikel{background-position:center 40%}
  .person__body{padding:1.3rem 1.4rem}
  .person__role{margin-bottom:.5rem}
  .person__cert{margin-bottom:.75rem;padding:.4rem .65rem;font-size:.78rem}

  .reviews__grid{gap:1rem;margin-bottom:1.6rem}
  .review{padding:1.4rem 1.3rem}
  .review__stars{margin-bottom:.7rem}
  .review p{margin-bottom:.9rem}

  .faq__list{gap:.45rem}
  .faq__item summary{padding:.9rem 1.1rem;font-size:1rem}
  .faq__item > div{padding:0 1.1rem 1rem}

  .philo__quote{margin:0 0 1.5rem}
  .philo__copy p{margin-bottom:.8rem}

  .visit__info h2{margin-bottom:1.2rem}
  .visit__list{gap:.7rem;margin-bottom:1.4rem}
  .visit__list li{grid-template-columns:1fr;gap:.25rem;padding-bottom:.7rem}
  .visit__form{padding:1.5rem;gap:.75rem}
  .visit__form h3{margin-bottom:.2rem}
  .visit__map iframe{height:300px}

  .ctaband__actions .btn{padding:.85rem 1.2rem}

  /* Paddings de sección compactados (era 4.5rem → 2.6rem; ahorra ~340px de scroll) */
  .services,.team,.process,.gallery,.reviews,.visit,.who,.faq{padding:2.6rem 0}
  .services{padding-bottom:2.2rem}
  .ctaband{padding:2.2rem 0}
  .philo{padding:3rem 0}
  .section__head{margin:0 0 1.4rem;max-width:100%}
  .section__head h2{margin-bottom:.6rem}
  .section__head p{font-size:1rem}
  .eyebrow{margin-bottom:.6rem}

  .band{padding:1rem 0}
  .band__inner{justify-content:flex-start;gap:.7rem;font-size:.83rem}
  .band__inner div{flex:1 1 45%}

  .foot{padding:2rem 0 1.2rem}
  .foot__inner{gap:1.2rem}
  .foot__nav{gap:1rem;flex-wrap:wrap}
  .foot__mark{width:80px;height:80px;padding:6px}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .hero__bg img{animation:none}
}
