:root{
  --bg:#eef5f1; --panel:#ffffffc7; --text:#1f2d2a; --muted:#577e73;
  --primary:#2f7d69; --primary-2:#4fb290;
  --ring:0 0 0 6px rgba(47,125,105,.18);
  --border:rgba(47,125,105,.18);
  --shadow:0 14px 40px rgba(47,125,105,.15);
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial;color:var(--text);background:var(--bg);line-height:1.6;overflow-x:hidden}
img{max-width:100%;height:auto}
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
.container{width:min(1150px,90%);margin-inline:auto}

/* Fondo decorativo */
.bg{position:fixed;inset:0;z-index:-2}
.bg-pattern{position:absolute;inset:-2px;background-image:radial-gradient(rgba(47,125,105,.08) 1px, transparent 1.5px);background-size:20px 20px;mask: linear-gradient(#000,transparent 85%)}
.blob{position:absolute;filter:blur(35px);opacity:.22;border-radius:50%}
.b1{width:520px;height:520px;left:-90px;top:-140px;background:radial-gradient(circle,var(--primary),transparent 60%);animation:float 14s ease-in-out infinite}
.b2{width:420px;height:420px;right:-120px;top:-100px;background:radial-gradient(circle,var(--primary-2),transparent 60%);animation:float 16s ease-in-out infinite reverse}
.b3{width:360px;height:360px;left:20%;bottom:-140px;background:radial-gradient(circle,#8bc8b2,transparent 60%);animation:float 18s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

/* Header/Nav */
.header{position:sticky;top:0;background:rgba(255,255,255,.72);backdrop-filter:saturate(180%) blur(12px);z-index:50;border-bottom:1px solid var(--border);transition:box-shadow .25s ease}
.header.scrolled{box-shadow:0 10px 28px rgba(0,0,0,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px;color:inherit;text-decoration:none}
.brand-logo{width:44px;height:44px;object-fit:contain}
.brand-text{font-weight:800;letter-spacing:.3px}
.menu{display:flex;gap:22px;align-items:center}
.menu a{color:var(--text);text-decoration:none;opacity:.9}
.menu .btn{margin-left:6px}
.nav-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  padding:0;
  border:0;
  border-radius:12px;
  background:transparent;
  color:var(--text);
  font-size:26px;
  line-height:1;
  cursor:pointer;
  transition:color .18s ease, background .18s ease, box-shadow .18s ease;
}
.nav-toggle[aria-expanded="true"]{
  background:rgba(47,125,105,.12);
  color:#0f5b4a;
}
.nav-toggle:hover{background:rgba(255,255,255,.75)}
.nav-toggle:focus-visible{
  outline:3px solid rgba(79,178,144,.5);
  outline-offset:2px;
}

/* Botones */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 18px;border-radius:14px;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#083a2f;text-decoration:none;font-weight:700;box-shadow:var(--shadow);transition:transform .18s ease, box-shadow .18s ease}
.btn:hover{transform:translateY(-2px);box-shadow:0 18px 42px rgba(79,178,144,.25)}
.btn--sm{padding:8px 12px;border-radius:10px;font-size:14px}
.btn--ghost{background:transparent;border:1px solid var(--border);color:var(--text);backdrop-filter:blur(2px)}

/* Hero */
.hero{position:relative;padding:110px 0 70px}
.hero-inner{display:grid;grid-template-columns:1.2fr .8fr;gap:44px;align-items:center}
.hero-left{max-width:520px}
.badge{display:inline-block;margin-bottom:12px;padding:6px 10px;border-radius:999px;background:#ffffff;border:1px solid var(--border);color:var(--muted);font-size:12px}
.hero h1{font-size:clamp(34px,4.8vw,56px);line-height:1.1;margin:0 0 14px}
.accent{background:linear-gradient(90deg,var(--primary),var(--primary-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero .lead{font-size:clamp(16px,2.3vw,18px);color:#2f5a4f;max-width:60ch;margin:0 0 10px}
.cta{display:flex;gap:12px;margin:20px 0 14px;flex-wrap:wrap}
.pillars{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 0;padding:0;list-style:none}
.pillars li{padding:8px 12px;border:1px solid var(--border);border-radius:999px;color:#2f5a4f;background:#fff}
.hero-card{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;background:#ffffffc7;border:1px solid var(--border);border-radius:18px;padding:20px;animation:pop .6s ease both;align-self:auto;max-width:520px;justify-self:center;width:100%}
@keyframes pop{from{transform:translateY(8px);opacity:0}to{transform:none;opacity:1}}
.hero-stat{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:18px;border-radius:14px;background:#fff;border:1px solid var(--border)}
.hero-stat strong{font-size:28px;color:#0f5b4a}
.hero-stat span{font-size:14px;color:#2f5a4f;margin-top:4px}
@media (max-width:640px){
  .hero-card{grid-template-columns:1fr;max-width:320px;margin:0 auto;padding:18px}
  .hero-stat{flex-direction:row;justify-content:space-between;gap:12px;text-align:left}
  .hero-stat strong{font-size:26px}
  .hero-stat span{font-size:14px;margin-top:0}
  .hero{padding:80px 0 60px}
  .hero-inner{gap:28px}
  .hero-left{max-width:100%}
}

/* Onda: color que NO se sale */
.wave{position:relative;height:78px;line-height:0}
.wave svg{position:absolute;inset:0;width:100%;height:100%}
.wave.single path{fill:#ffffffcc} /* coincide con el fondo de #servicios */

/* Secciones */
.section{position:relative;padding:80px 0}
.section.alt{background:#ffffffcc}
.section-head{margin:0 0 24px}
.section-head h2{margin:0 0 6px;font-size:clamp(24px,3.5vw,34px)}
.section-head p{margin:0;color:#2f5a4f}
.section-head--compact{
  margin:0 0 16px;
}
.section-head--compact h2{
  margin:0 0 6px;
  font-size:clamp(22px,3vw,28px);
}
.section-head--compact p{
  margin:0;
  color:#2f5a4f;
}
.section-head--center{
  text-align:center;
  max-width:640px;
  margin:0 auto 34px;
}
.section-head--center p{
  margin-inline:auto;
  max-width:60ch;
}
.section-eyebrow{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:6px 14px;
  border-radius:999px;
  background:color-mix(in srgb,var(--primary) 20%,#fff);
  color:#0f5b4a;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.75rem;
  margin:0 0 14px;
  box-shadow:0 8px 24px rgba(47,125,105,.14);
}

/* Reveal */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .6s ease, transform .6s ease}
.reveal.visible{opacity:1;transform:none}
.lift{transition:transform .18s ease, box-shadow .18s ease}
.lift:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(0,0,0,.08)}
.float-up{animation:float 12s ease-in-out infinite}
.glass{background:#ffffffc7;backdrop-filter:blur(8px) saturate(1.2);border:1px solid var(--border);border-radius:16px}

/* Grids globales */
.grid{display:grid;gap:22px}
.grid.team{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.grid.cols-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}

/* Notas */
.note{margin-top:18px;padding:14px;border-radius:12px;background:#e9f7f1;border:1px solid var(--border);color:#0f5b4a}

/* Mapa */
.map-embed{position:relative;height:330px;border-radius:16px;overflow:hidden}
.map-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* Contacto */
.contact{align-items:start}
.contact-card{padding:20px}
.contact-card a{color:var(--text)}
.form{display:grid;gap:12px}
.form input,.form textarea{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:#ffffff;color:var(--text)}
.form textarea{resize:none;min-height:140px}
.form input:focus,.form textarea:focus{outline:none;box-shadow:var(--ring)}
.form .small{color:#2f5a4f;font-size:12px}

/* Redes */
.social{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.social-icon{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:12px;border:1px solid var(--border);text-decoration:none;color:var(--text);background:#fff;transition:transform .18s ease}
.social-icon:hover{transform:translateY(-2px)}

/* FAB WhatsApp */
.fab{position:fixed;right:16px;bottom:16px;width:54px;height:54px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#083a2f;text-decoration:none;font-size:22px;box-shadow:var(--shadow)}

/* Footer */
.footer{padding:48px 0 40px;border-top:1px solid var(--border);background:#fff;position:relative;overflow:hidden}
.footer::before{content:none}
.footer-grid{
  position:relative;
  z-index:1;
  display:flex;
  flex-wrap:wrap;
  gap:32px;
  align-items:flex-start;
}
.footer-brand{
  display:flex;
  flex-direction:column;
  gap:12px;
  flex:1 1 280px;
  min-width:0;
  max-width:360px;
}
.footer-logo{padding:0;margin:0;text-decoration:none}
.footer-tagline{margin:6px 0 0;color:#2f5a4f;font-size:1rem;max-width:38ch}
.footer-copy{margin:0;color:#396457;font-size:.92rem}
.footer-col{
  display:flex;
  flex-direction:column;
  gap:12px;
  flex:1 1 240px;
  min-width:0;
}
.footer-title{margin:0;font-size:1.05rem;color:#0f5b4a}
.footer-list{margin:0;padding:0;list-style:none;display:grid;gap:8px;color:#2f5a4f;font-size:.95rem}
.footer-list a{color:inherit;text-decoration:none;border-bottom:1px solid transparent;padding-bottom:2px;display:inline-block;max-width:100%}
.footer-list a:hover{color:var(--primary);border-color:color-mix(in srgb,var(--primary) 45%,#fff)}
.footer-list li{
  min-width:0;
}
.footer-list a,
.info-row a{
  display:inline-block;
  max-width:100%;
  overflow-wrap:anywhere;
  word-break:break-word;
}
.legal-strip{margin-top:44px;border-top:1px solid var(--border);background:rgba(255,255,255,.9)}
.legal-strip__inner{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;padding:12px 0}
.legal-links{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.legal-links a{color:#2f5a4f;text-decoration:none;font-size:.92rem}
.legal-links a:hover{color:var(--primary)}
.legal-cookie-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:999px;padding:10px 18px;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#073f32;font-weight:700;cursor:pointer;box-shadow:var(--shadow);transition:transform .18s ease, box-shadow .18s ease}
.legal-cookie-btn:hover{transform:translateY(-2px);box-shadow:0 18px 42px rgba(79,178,144,.25)}
.legal-top{display:inline-flex;align-items:center;gap:6px;text-decoration:none;color:#2f5a4f;font-weight:600;padding:8px 12px;border-radius:12px;border:1px solid transparent;transition:color .18s ease,border-color .18s ease}
.legal-top:hover{color:var(--primary);border-color:rgba(47,125,105,.32)}
.to-top{display:inline-flex;width:36px;height:36px;border-radius:10px;align-items:center;justify-content:center;border:1px solid var(--border);background:#fff}

/* ===== Tarjetas SLIM (servicios) ===== */
.cards-slim{--gap:22px;display:grid;gap:var(--gap);grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.card-slim{
  position:relative;overflow:hidden;
  padding:18px 18px 16px;border-radius:16px;background:#fff;
  border:1px solid transparent;
  background:linear-gradient(#fff,#fff) padding-box,linear-gradient(135deg, color-mix(in srgb, var(--primary) 60%, white), color-mix(in srgb, var(--primary-2) 60%, white)) border-box;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.card-slim::before{
  content:"";position:absolute;inset:0 0 auto 0;height:6px;border-radius:16px 16px 0 0;
  background: linear-gradient(90deg, var(--primary), var(--primary-2));opacity:.2;pointer-events:none
}
.card-slim:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(0,0,0,.06);border-color:color-mix(in srgb, var(--primary) 30%, var(--border))}
.card-slim.is-soft{
  background:linear-gradient(#fff,#fff) padding-box,linear-gradient(135deg, color-mix(in srgb, var(--primary) 35%, #fff), color-mix(in srgb, var(--primary-2) 35%, #fff)) border-box;
}
.card-slim__head{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.card-slim__icon{inline-size:42px;block-size:42px;flex:0 0 42px;display:grid;place-items:center;border-radius:50%;background:color-mix(in srgb, var(--primary) 18%, #fff);color:#0f5b4a;border:1px solid var(--border)}
.card-slim__title{margin:0;font-size:1.05rem}
.card-slim__list{margin:8px 0 0;padding:0;list-style:none;display:grid;gap:7px}
.card-slim__list li{position:relative;padding-left:26px;color:#2f5a4f}
.card-slim__list li::before{
  content:"";position:absolute;left:0;top:.35em;width:18px;height:18px;border-radius:6px;background:linear-gradient(135deg,var(--primary),var(--primary-2));
  -webkit-mask: radial-gradient(closest-side, transparent 44%, #000 45%) center/100% 100% no-repeat;
          mask: radial-gradient(closest-side, transparent 44%, #000 45%) center/100% 100% no-repeat;
  box-shadow:0 2px 10px rgba(47,125,105,.18)
}
.card-slim__list li::after{content:"";position:absolute;left:5px;top:.63em;width:8px;height:4px;border:2px solid #0f5b4a;border-top:none;border-right:none;transform:rotate(-45deg)}

/* FAQ */
.faq-grid{
  display:grid;
  gap:26px;
  grid-template-columns:minmax(0,0.92fr) minmax(0,1.08fr);
  align-items:start;
}
.faq-intro{
  display:flex;
  flex-direction:column;
  gap:18px;
  padding:30px;
  border-radius:18px;
  box-shadow:0 18px 42px rgba(47,125,105,.12);
}
.faq-intro h3{
  margin:0;
  font-size:1.35rem;
  color:#0f5b4a;
}
.faq-intro p{
  margin:0;
  color:#2f5a4f;
}
.faq-intro .btn{
  align-self:flex-start;
  margin-top:8px;
}
.faq-highlights{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:12px;
}
.faq-highlights li{
  position:relative;
  padding-left:26px;
  color:#2f5a4f;
}
.faq-highlights li::before{
  content:"";
  position:absolute;
  inset:.35em auto auto 0;
  width:18px;
  height:18px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--primary-2));
  box-shadow:0 6px 16px rgba(47,125,105,.24);
}
.faq-highlights li::after{
  content:"";
  position:absolute;
  left:6px;
  top:.68em;
  width:8px;
  height:4px;
  border:2px solid #083a2f;
  border-top:none;
  border-right:none;
  transform:rotate(-45deg);
}
.accordion{
  display:grid;
  gap:18px;
}
.faq-item{
  position:relative;
  padding:0;
  border-radius:18px;
  background:linear-gradient(rgba(255,255,255,.94),rgba(255,255,255,.94)) padding-box, linear-gradient(135deg, color-mix(in srgb,var(--primary) 30%, #fff), color-mix(in srgb,var(--primary-2) 30%, #fff)) border-box;
  border:1px solid transparent;
  transition:box-shadow .22s ease, border-color .22s ease;
  overflow:hidden;
}
.faq-item summary{
  display:flex;
  align-items:center;
  gap:16px;
  padding:24px 26px;
  margin:0;
  list-style:none;
  cursor:pointer;
  font-weight:700;
  color:#0f5b4a;
  font-size:1.05rem;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-number{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:38px;
  height:38px;
  border-radius:12px;
  background:color-mix(in srgb,var(--primary) 16%,#fff);
  color:#0f5b4a;
  font-size:.82rem;
  font-weight:700;
  box-shadow:0 8px 18px rgba(47,125,105,.18);
  transition:transform .22s ease, background .22s ease, box-shadow .22s ease;
}
.faq-question{flex:1}
.faq-arrow{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:32px;
  height:32px;
  border-radius:50%;
  background:color-mix(in srgb,var(--primary) 12%,#fff);
  transition:transform .25s ease, background .25s ease;
  margin-left:auto;
}
.faq-arrow::before{
  content:"";
  width:10px;
  height:10px;
  border:2px solid #0f5b4a;
  border-top:none;
  border-left:none;
  transform:rotate(45deg);
  transition:transform .25s ease;
}
.faq-content{
  padding:0 26px 24px;
  border-top:1px solid rgba(47,125,105,.16);
}
.faq-content p{
  margin:18px 0 0;
  color:#2f5a4f;
}
.faq-item[open]{
  box-shadow:0 18px 44px rgba(47,125,105,.18);
  border-color:color-mix(in srgb,var(--primary) 36%, var(--border));
}
.faq-item[open] .faq-number{
  background:linear-gradient(135deg,var(--primary),var(--primary-2));
  color:#083a2f;
  transform:translateY(-2px);
  box-shadow:0 14px 30px rgba(47,125,105,.26);
}
.faq-item[open] .faq-arrow{
  background:color-mix(in srgb,var(--primary) 26%,#fff);
}
.faq-item[open] .faq-arrow::before{
  transform:rotate(-135deg);
}


/* Responsive */
@media (max-width:1000px){
  .hero-inner{grid-template-columns:1fr}
  .hero-left{max-width:100%}
  .hero-card{justify-self:center;max-width:440px;margin:0}
  .faq-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  .menu{display:none;position:absolute;top:56px;right:5%;flex-direction:column;gap:12px;background:#fff;padding:14px;border-radius:14px;border:1px solid var(--border)}
  .nav-toggle{display:inline-flex}
  .menu.open{display:flex}
  .faq-intro{padding:24px}
  .faq-intro .btn{width:100%;justify-content:center}
  .faq-item summary{padding:20px 22px;flex-wrap:wrap}
  .faq-content{padding:0 22px 22px}
  .faq-number{width:34px;height:34px}
}
/* Accesibilidad movimiento */
@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation:none!important;transition:none!important}}

/* ==== TEAM (Equipo) – tarjetas ligeras y consistentes ==== */
.team-cards{
  --gap:22px;
  display:grid; gap:var(--gap);
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
}
.team-card{
  position:relative; overflow:hidden;
  padding:18px; border-radius:16px; background:#fff;
  border:1px solid transparent;
  background:
    linear-gradient(#fff,#fff) padding-box,
    linear-gradient(135deg,
      color-mix(in srgb, var(--primary) 35%, #fff),
      color-mix(in srgb, var(--primary-2) 35%, #fff)
    ) border-box;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.team-card:hover{ transform:translateY(-2px); box-shadow:0 10px 26px rgba(0,0,0,.06)}
.team-card__head{ display:flex; align-items:center; gap:12px; margin-bottom:10px }
.team-card__avatar{
  inline-size:44px; block-size:44px; flex:0 0 44px;
  display:grid; place-items:center; border-radius:50%;
  background: color-mix(in srgb, var(--primary) 16%, #fff);
  color:#0f5b4a; border:1px solid var(--border)
}
.team-card__title{ margin:0; font-size:1.02rem }
.team-card__desc{ margin:.25rem 0 0; color:#2f5a4f; font-size:.95rem; line-height:1.5 }
.team-card__tag{
  display:inline-block; margin-top:8px; font-size:.72rem; letter-spacing:.3px; font-weight:700;
  padding:6px 10px; border-radius:999px; color:#0f4439;
  background: linear-gradient(135deg,var(--primary),var(--primary-2)); opacity:.95;
}

/* ==== CONTACTO – tarjeta de información + formulario afinados ==== */
.contact-wrap{
  display:grid; gap:22px;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  align-items:start;
}
.contact-panel{
  position:relative; overflow:hidden;
  padding:20px; border-radius:16px; background:#fff;
  border:1px solid transparent;
  background:
    linear-gradient(#fff,#fff) padding-box,
    linear-gradient(135deg,
      color-mix(in srgb, var(--primary) 40%, #fff),
      color-mix(in srgb, var(--primary-2) 40%, #fff)
    ) border-box;
}
.contact-panel--form{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.info-list{ display:grid; gap:10px; margin:10px 0 14px; padding:0; list-style:none }
.info-row{ display:flex; align-items:flex-start; gap:10px; color:#2f5a4f; flex-wrap:wrap }
.info-row > div{flex:1 1 200px; min-width:0}
.info-ico{
  inline-size:32px; block-size:32px; flex:0 0 32px;
  display:grid; place-items:center;
  border-radius:10px; background:color-mix(in srgb, var(--primary) 16%, #fff);
  color:#0f5b4a; border:1px solid var(--border)
}

/* Inputs más pulidos (reutiliza estilos existentes) */
.form .row{ display:grid; gap:12px; grid-template-columns:1fr 1fr }
@media (max-width:640px){
  .form .row{ grid-template-columns:1fr }
}
.form input:valid, .form textarea:valid{ border-color:color-mix(in srgb, var(--primary) 40%, var(--border)) }
.form-consent{
  display:grid;
  grid-template-columns:auto 1fr;
  align-items:flex-start;
  gap:12px;
  margin:12px 0 4px;
  padding:14px 16px;
  border-radius:14px;
  border:1px solid rgba(47,125,105,.26);
  background:rgba(255,255,255,.95);
  font-size:.92rem;
  color:#2f5a4f;
  box-shadow:0 10px 24px rgba(47,125,105,.08);
  transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
.form-consent input{
  margin-top:2px;
  inline-size:18px;
  block-size:18px;
  accent-color:var(--primary);
  border-radius:6px;
}
.form-consent input:focus-visible{
  outline:3px solid rgba(79,178,144,.45);
  outline-offset:2px;
}
.form-consent span{display:block;line-height:1.55}
.form-consent__msg{
  grid-column:1 / -1;
  margin-top:4px;
  font-size:.92rem;
  color:#c72f23;
}
.form-consent__msg[hidden]{display:none}
.form-consent a{color:var(--primary);text-decoration:underline;font-weight:600}
.form-consent a:hover{text-decoration:none;color:var(--primary-2)}
.form-consent--error{border-color:#e5534b;background:rgba(229,83,75,.08)}
.form-consent--error a{color:#c72f23}

/* Social compactas */
.social.compact .social-icon{
  padding:10px 12px;
  border-radius:10px;
  justify-content:center;
  width:100%;
}
.social.compact{width:100%;flex-direction:column;align-items:stretch;gap:8px}
@media (max-width:640px){
  .footer{padding-top:40px}
  .footer-grid{gap:28px;flex-direction:column}
  .footer-brand,.footer-col{flex:1 1 100%;max-width:100%;min-width:0;align-items:flex-start}
  .footer-tagline{max-width:100%}
  .legal-strip__inner{flex-direction:column;align-items:flex-start;width:100%}
  .legal-links{gap:12px}
  .legal-cookie-btn{width:100%;justify-content:center;text-align:center}
  .legal-top{width:100%;justify-content:center;text-align:center;border-color:rgba(47,125,105,.25)}
  .form-consent{grid-template-columns:1fr;gap:10px}
  .form-consent input{margin-top:0;justify-self:start}
}
@media (max-width:480px){
  .footer{padding-top:36px}
  .footer-grid{grid-template-columns:1fr}
  .footer-brand,.footer-col{align-items:flex-start;text-align:left}
  .legal-strip__inner{gap:12px}
  .legal-cookie-btn{width:100%}
}
@media (max-width:420px){
  .form-consent{padding:12px 14px}
  .form-consent span{font-size:.9rem}
}
