/* ============================================================
   SOLUCIÓNATE — Sitio web corporativo
   Estilos compartidos (responsive, SEO-friendly, mobile-first)
   ============================================================ */

@import url("colors_and_type.css");

/* ---------- RESET ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font-sans);
  font-weight: var(--fw-regular);
  color: var(--fg);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
::selection { background: var(--sol-green-200); color: var(--sol-ink-900); }
:focus-visible { outline: 3px solid var(--focus-ring); outline-offset: 2px; border-radius: 4px; }

/* ---------- LAYOUT ---------- */
.container {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px;
}
@media (min-width: 768px) {
  .container { padding: 0 32px; }
}

section { scroll-margin-top: 88px; }

/* ---------- NAV ---------- */
.site-nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255, 255, 255, 0.82);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid transparent;
  transition: border-color 240ms cubic-bezier(0.22, 0.61, 0.36, 1),
              background 240ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
.site-nav.is-scrolled {
  background: rgba(255, 255, 255, 0.92);
  border-bottom-color: var(--border);
}
.nav-inner {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px 0;
}
.nav-logo {
  display: flex;
  align-items: center;
  height: 36px;
  flex: none;
}
.nav-logo img { height: 32px; }
.nav-links {
  display: none;
  flex: 1;
  gap: 28px;
  margin-left: 24px;
}
.nav-links a {
  font: 500 14px/1 var(--font-sans);
  color: var(--fg);
  letter-spacing: 0.01em;
  transition: color 160ms;
  position: relative;
  padding: 4px 0;
}
.nav-links a:hover,
.nav-links a[aria-current="page"] {
  color: var(--sol-green-700);
}
.nav-links a[aria-current="page"]::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 2px;
  background: var(--sol-green-600);
  border-radius: 2px;
}
.nav-phone {
  display: none;
  align-items: center;
  gap: 8px;
  color: var(--sol-green-700);
  font: 600 14px/1 var(--font-sans);
}
.nav-phone svg { width: 16px; height: 16px; }
.nav-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 40px;
  padding: 0 18px;
  background: var(--sol-green-600);
  color: #fff;
  border: none;
  border-radius: 999px;
  font: 600 13px/1 var(--font-sans);
  letter-spacing: 0.02em;
  white-space: nowrap;
  box-shadow: 0 6px 16px rgba(19,165,56,0.25);
  transition: background 160ms, transform 80ms;
  margin-left: auto;
}
.nav-cta:hover { background: var(--sol-green-700); }
.nav-cta:active { transform: scale(0.97); }
.nav-burger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px; height: 40px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 10px;
  color: var(--fg-strong);
  flex: none;
}
.nav-burger svg { width: 22px; height: 22px; }

@media (min-width: 980px) {
  .nav-links { display: flex; }
  .nav-phone { display: inline-flex; margin-right: 6px; }
  .nav-cta { margin-left: 0; }
  .nav-burger { display: none; }
}

/* ---------- MOBILE MENU ---------- */
.mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 60;
  background: #fff;
  display: flex;
  flex-direction: column;
  padding: 16px 24px 32px;
  transform: translateX(100%);
  transition: transform 280ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
.mobile-menu.is-open { transform: translateX(0); }
.mobile-menu .mm-top {
  display: flex; align-items: center; justify-content: space-between;
  padding: 4px 0 24px;
}
.mobile-menu .mm-top img { height: 28px; }
.mobile-menu .mm-close {
  width: 40px; height: 40px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--fg-strong);
}
.mobile-menu .mm-links { display: flex; flex-direction: column; gap: 2px; }
.mobile-menu .mm-links a {
  font: 600 22px/1.2 var(--font-sans);
  color: var(--fg-strong);
  letter-spacing: -0.01em;
  padding: 18px 0;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
}
.mobile-menu .mm-links a[aria-current="page"] { color: var(--sol-green-700); }
.mobile-menu .mm-links a .arrow { color: var(--sol-green-600); }
.mobile-menu .mm-contact {
  margin-top: auto;
  padding-top: 24px;
  display: flex; flex-direction: column; gap: 16px;
}
.mobile-menu .mm-cta {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px;
  height: 52px;
  background: var(--sol-green-600); color: #fff;
  border-radius: 999px;
  font: 600 14px/1 var(--font-sans); letter-spacing: 0.04em;
}
.mobile-menu .mm-phone {
  display: inline-flex; align-items: center; gap: 10px;
  color: var(--sol-green-700);
  font: 600 16px/1 var(--font-sans);
}

/* ---------- HERO ---------- */
.hero {
  position: relative;
  background: linear-gradient(135deg, #95c11f 0%, #13a538 100%);
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.hero::before {
  content: "";
  position: absolute;
  inset: -10% -10% auto auto;
  width: 70vw; max-width: 720px;
  aspect-ratio: 1/1;
  background: radial-gradient(circle at 50% 50%, rgba(255,255,255,0.18), rgba(255,255,255,0) 60%);
  z-index: 0;
  pointer-events: none;
}
.hero-inner {
  position: relative;
  z-index: 2;
  padding: 72px 0 88px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 48px;
  align-items: center;
}
@media (min-width: 980px) {
  .hero-inner {
    grid-template-columns: 1.15fr 1fr;
    padding: 104px 0 120px;
    gap: 64px;
  }
}
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font: 600 11px/1 var(--font-sans);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.92);
  background: rgba(255,255,255,0.14);
  padding: 8px 14px;
  border-radius: 999px;
  margin-bottom: 22px;
  backdrop-filter: blur(8px);
}
.hero-eyebrow .tri {
  width: 0; height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 7px solid #fff;
}
.hero h1 {
  font: 600 clamp(40px, 7vw, 72px) / 1.02 var(--font-sans);
  letter-spacing: -0.025em;
  color: #fff;
  margin: 0;
  text-wrap: balance;
}
.hero h1 .ink { color: var(--sol-ink-900); }
.hero .lead {
  font: 300 clamp(16px, 1.5vw, 19px) / 1.55 var(--font-sans);
  color: rgba(255,255,255,0.94);
  margin: 22px 0 0;
  max-width: 540px;
  text-wrap: pretty;
}
.hero-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 32px;
}
.btn-primary, .btn-ghost {
  display: inline-flex; align-items: center; gap: 10px;
  height: 52px;
  padding: 0 24px;
  border-radius: 999px;
  font: 600 15px/1 var(--font-sans);
  letter-spacing: 0.02em;
  transition: background 160ms, border-color 160ms, transform 80ms, color 160ms;
  border: none;
}
.btn-primary {
  background: var(--sol-ink-700);
  color: #fff;
  box-shadow: 0 10px 22px rgba(0,0,0,0.18);
}
.btn-primary:hover { background: #000; }
.btn-primary:active { transform: scale(0.98); }
.btn-ghost {
  background: transparent;
  color: #fff;
  border: 1.5px solid rgba(255,255,255,0.6);
}
.btn-ghost:hover { background: rgba(255,255,255,0.14); border-color: #fff; }

.hero-trust {
  margin-top: 32px;
  display: flex; align-items: center; gap: 14px;
  font: 500 13px/1.4 var(--font-sans);
  color: rgba(255,255,255,0.92);
}
.hero-trust .num {
  font: 600 28px/1 var(--font-sans);
  letter-spacing: -0.02em;
}

.hero-visual {
  position: relative;
  width: 100%;
  max-width: 460px;
  aspect-ratio: 1/1;
  margin: 0 auto;
}
.hero-visual .iso-main {
  width: 100%; height: 100%;
  object-fit: contain;
  opacity: 0.5;
  filter: drop-shadow(0 30px 60px rgba(0,0,0,0.18));
  transition: transform 600ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
/* Floating chips around the isotipo */
.hero-chip {
  position: absolute;
  background: #fff;
  color: var(--sol-ink-900);
  border-radius: 999px;
  padding: 10px 14px;
  font: 600 12px/1 var(--font-sans);
  letter-spacing: 0.04em;
  display: inline-flex; align-items: center; gap: 8px;
  box-shadow: 0 12px 28px rgba(0,0,0,0.18);
  white-space: nowrap;
  animation: floatChip 5.4s cubic-bezier(0.45, 0, 0.55, 1) infinite;
}
.hero-chip svg { width: 14px; height: 14px; color: var(--sol-green-600); }
.hero-chip.c1 { top: 8%;  left: -8%;   animation-delay: 0s;    animation-duration: 5.2s; }
.hero-chip.c2 { top: 36%; right: -10%; animation-delay: -1.1s; animation-duration: 6.0s; }
.hero-chip.c3 { bottom: 8%; left: 4%;  animation-delay: -2.3s; animation-duration: 4.8s; }
.hero-chip.c4 { bottom: 28%; right: -4%; animation-delay: -0.6s; animation-duration: 5.6s; }
.hero-chip.c5 { top: 4%; right: 14%;   animation-delay: -1.7s; animation-duration: 5.0s; }
@keyframes floatChip {
  0%   { transform: translate(0, 0) rotate(0deg); }
  25%  { transform: translate(6px, -12px) rotate(2.5deg); }
  50%  { transform: translate(0, -20px) rotate(-1.5deg); }
  75%  { transform: translate(-6px, -10px) rotate(2.5deg); }
  100% { transform: translate(0, 0) rotate(0deg); }
}

/* The big background isotipo that moves on scroll */
.hero-bg-iso {
  position: absolute;
  z-index: 0;
  pointer-events: none;
  opacity: 0.10;
  width: 60vw; max-width: 640px;
  top: -10%;
  right: -8%;
}
/* Falling triangles that drop on scroll (creative scroll effect) */
.hero-tris {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
}
.hero-tris .t {
  position: absolute;
  width: 0; height: 0;
  border-left: 32px solid transparent;
  border-right: 32px solid transparent;
  border-top: 48px solid rgba(255,255,255,0.18);
  transform: translateY(var(--ty, 0px)) rotate(var(--r, 0deg));
  will-change: transform;
  transition: transform 80ms linear;
}
.hero-tris .t.t1 { left: 8%;  top: 14%; border-top-color: rgba(255,255,255,0.22); }
.hero-tris .t.t2 { left: 22%; top: 6%;  transform-origin: 50% 100%; border-top-color: rgba(255,255,255,0.14); border-left-width: 24px; border-right-width: 24px; border-top-width: 38px; }
.hero-tris .t.t3 { right: 24%; top: 22%; border-top-color: rgba(0,0,0,0.10); }
.hero-tris .t.t4 { right: 10%; top: 8%;  border-top-color: rgba(255,255,255,0.18); border-left-width: 20px; border-right-width: 20px; border-top-width: 32px; }
.hero-tris .t.t5 { left: 48%; top: 70%; border-top-color: rgba(255,255,255,0.16); }

.hero-scroll-cue {
  position: absolute;
  left: 50%;
  bottom: 22px;
  transform: translateX(-50%);
  z-index: 3;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  font: 600 10px/1 var(--font-sans);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.85);
  opacity: 1;
  transition: opacity 240ms;
}
.hero-scroll-cue .mouse {
  width: 22px; height: 36px;
  border: 2px solid rgba(255,255,255,0.8);
  border-radius: 12px;
  position: relative;
}
.hero-scroll-cue .mouse::before {
  content: "";
  position: absolute;
  left: 50%; top: 6px;
  width: 3px; height: 6px; border-radius: 2px;
  background: #fff;
  transform: translateX(-50%);
  animation: wheel 1.6s ease-in-out infinite;
}
@keyframes wheel {
  0%   { transform: translate(-50%, 0); opacity: 1; }
  60%  { transform: translate(-50%, 12px); opacity: 0; }
  100% { transform: translate(-50%, 0); opacity: 0; }
}

/* ---------- SECTION HEAD ---------- */
.eyebrow {
  display: inline-block;
  font: 600 12px/1 var(--font-sans);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--sol-green-600);
  margin-bottom: 14px;
}
.section-head h2 {
  font: 600 clamp(28px, 4vw, 44px) / 1.06 var(--font-sans);
  letter-spacing: -0.02em;
  color: var(--fg-strong);
  margin: 0 0 12px;
  text-wrap: balance;
}
.section-head .lead {
  font: 300 clamp(15px, 1.4vw, 18px) / 1.55 var(--font-sans);
  color: var(--fg-muted);
  max-width: 560px;
  margin: 0;
  text-wrap: pretty;
}

/* ---------- BULLETS BAND ---------- */
.bullets {
  background: var(--sol-ink-50);
  padding: 56px 0;
}
.bullets-grid {
  display: grid; grid-template-columns: 1fr; gap: 28px;
}
@media (min-width: 768px) { .bullets-grid { grid-template-columns: repeat(3, 1fr); gap: 32px; } }
.bullet {
  display: flex; gap: 18px; align-items: flex-start;
}
.bullet .ico {
  flex: none; width: 48px; height: 48px; border-radius: 50%;
  background: #fff; color: var(--sol-green-600);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 14px rgba(19,165,56,0.14);
}
.bullet h3 { font: 600 18px/1.3 var(--font-sans); color: var(--fg-strong); margin: 0 0 6px; }
.bullet p { font: 400 14.5px/1.55 var(--font-sans); color: var(--fg-muted); margin: 0; }

/* ---------- PRODUCT GRID ---------- */
.products {
  padding: 88px 0 64px;
}
.products-head {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  margin-bottom: 40px;
}
.products-head__text { display: flex; flex-direction: column; }
.products-head__text .eyebrow { margin-bottom: 6px; }
.products-head__text h2 { margin: 0; }
.products-head__media {
  position: relative;
  margin: 0;
  border-radius: var(--radius-lg, 16px);
  overflow: hidden;
  aspect-ratio: 16 / 7;
  box-shadow: 0 18px 36px rgba(60,60,59,0.10);
}
.products-head__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 58%;
  display: block;
  transition: transform 600ms cubic-bezier(0.22,0.61,0.36,1);
}
.products-head__media:hover img { transform: scale(1.03); }
@media (min-width: 980px) {
  .products-head {
    grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.35fr);
    grid-template-rows: auto auto;
    column-gap: 48px;
    row-gap: 18px;
    align-items: start;
  }
  .products-head__text {
    grid-column: 1; grid-row: 1 / span 2;
    align-self: start;
  }
  .products-head__media { grid-column: 2; grid-row: 1; }
  .products-head .lead { grid-column: 2; grid-row: 2; text-align: left; margin: 0; }
}
.products-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}
.product-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 22px 22px 22px;
  display: flex; flex-direction: column; gap: 12px;
  transition: transform 240ms cubic-bezier(0.22, 0.61, 0.36, 1),
              box-shadow 240ms, border-color 240ms;
  min-height: 220px;
  position: relative;
  overflow: hidden;
}
.product-card::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--sol-lime), var(--sol-green));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 360ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
.product-card:hover {
  transform: translateY(-4px);
  border-color: var(--sol-green-400);
  box-shadow: 0 18px 36px rgba(60,60,59,0.10);
}
.product-card:hover::after { transform: scaleX(1); }
.product-card .ico {
  width: 48px; height: 48px; border-radius: 14px;
  background: var(--sol-green-50); color: var(--sol-green-700);
  display: flex; align-items: center; justify-content: center;
}
.product-card .label {
  font: 600 11px/1 var(--font-sans);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--sol-green-700);
}
.product-card h3 { font: 600 18px/1.2 var(--font-sans); color: var(--fg-strong); margin: 0; }
.product-card p { font: 400 13.5px/1.55 var(--font-sans); color: var(--fg-muted); margin: 0; }
.product-card .arrow {
  margin-top: auto;
  display: inline-flex; align-items: center; gap: 6px;
  font: 600 12px/1 var(--font-sans);
  color: var(--sol-green-700);
  letter-spacing: 0.04em;
  padding-top: 6px;
}

/* ---------- AUDIENCE ---------- */
.audience {
  padding: 64px 0;
  background: var(--sol-ink-50);
}
.audience-grid {
  display: grid; grid-template-columns: 1fr; gap: 32px; align-items: center;
}
@media (min-width: 980px) {
  .audience-grid { grid-template-columns: 0.9fr 1.2fr; gap: 64px; }
}
.audience-chips {
  display: flex; flex-wrap: wrap; gap: 12px;
}
.audience-chip {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 12px 18px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 999px;
  font: 500 15px/1 var(--font-sans);
  color: var(--fg-strong);
  transition: border-color 160ms, transform 160ms, box-shadow 160ms;
}
.audience-chip:hover {
  border-color: var(--sol-green-400);
  transform: translateY(-2px);
  box-shadow: 0 6px 14px rgba(19,165,56,0.12);
}
.audience-chip .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--sol-green-600);
}

/* ---------- PROCESS STEPS ---------- */
.process { padding: 88px 0; }
.process-head { text-align: center; max-width: 680px; margin: 0 auto 56px; }
.process-steps {
  display: grid; grid-template-columns: 1fr; gap: 32px;
  position: relative;
}
@media (min-width: 768px) {
  .process-steps { grid-template-columns: repeat(5, 1fr); gap: 4px; }
  .process-line {
    position: absolute;
    left: 10%; right: 10%; top: 32px;
    height: 2px;
    background: repeating-linear-gradient(90deg, var(--sol-green-300) 0 6px, transparent 6px 12px);
    z-index: 0;
  }
}
.process-line { display: none; }
@media (min-width: 768px) { .process-line { display: block; } }
.process-step {
  display: flex; flex-direction: column; align-items: center;
  position: relative; z-index: 1; padding: 0 12px;
  text-align: center;
}
.process-step .num {
  width: 64px; height: 64px; border-radius: 50%;
  background: #fff; border: 2px solid var(--sol-green-600);
  color: var(--sol-green-700);
  display: flex; align-items: center; justify-content: center;
  font: 600 22px/1 var(--font-sans);
  box-shadow: 0 6px 14px rgba(19,165,56,0.18);
  margin-bottom: 14px;
  transition: background 240ms, color 240ms, transform 240ms;
}
.process-step:hover .num {
  background: var(--sol-green-600); color: #fff;
  transform: translateY(-3px);
}
.process-step .label {
  font: 600 12px/1 var(--font-sans);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--sol-green-700);
  margin-bottom: 6px;
}
.process-step p {
  font: 400 14px/1.5 var(--font-sans);
  color: var(--fg);
  margin: 0;
  max-width: 180px;
}

/* ---------- BENEFITS ---------- */
.benefits {
  padding: 80px 0;
  background: var(--sol-ink-50);
}
.benefits-head {
  display: grid; grid-template-columns: 1fr; gap: 16px; margin-bottom: 40px;
}
@media (min-width: 980px) {
  .benefits-head { grid-template-columns: 1fr 1fr; gap: 48px; align-items: end; }
}
.benefits-grid {
  display: grid; grid-template-columns: 1fr; gap: 16px;
}
@media (min-width: 640px) {
  .benefits-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 980px) {
  .benefits-grid { grid-template-columns: repeat(3, 1fr); }
}
.benefit-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 26px;
  display: flex; flex-direction: column; gap: 10px;
  min-height: 200px;
  transition: transform 240ms, box-shadow 240ms, background 240ms, border-color 240ms, color 240ms;
}
.benefit-card:hover,
.benefit-card:focus-within {
  transform: translateY(-3px);
  background: linear-gradient(160deg, #95c11f 0%, #13a538 100%);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 18px 38px rgba(19,165,56,0.28);
}
.benefit-card.is-featured {
  /* neutralised — green look is now hover-only */
}
.benefit-card .ico {
  width: 44px; height: 44px; border-radius: 12px;
  background: var(--sol-green-50); color: var(--sol-green-700);
  display: flex; align-items: center; justify-content: center;
  transition: background 240ms, color 240ms;
}
.benefit-card:hover .ico,
.benefit-card:focus-within .ico { background: rgba(255,255,255,0.2); color: #fff; }
.benefit-card h3 { font: 600 19px/1.25 var(--font-sans); margin: 0; color: var(--fg-strong); transition: color 240ms; }
.benefit-card:hover h3,
.benefit-card:focus-within h3 { color: #fff; }
.benefit-card p { font: 400 14px/1.55 var(--font-sans); color: var(--fg-muted); margin: 0; transition: color 240ms; }
.benefit-card:hover p,
.benefit-card:focus-within p { color: rgba(255,255,255,0.92); }

/* ---------- PARTNERS WALL ---------- */
.partners { padding: 88px 0; }
.partners-head { text-align: center; margin-bottom: 36px; }
.partners-table {
  display: grid;
  grid-template-columns: 1fr;
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
}
@media (min-width: 768px) {
  .partners-table { grid-template-columns: 180px 1fr; }
}
.partners-row { display: contents; }
.partners-cat {
  background: var(--sol-green-50);
  color: var(--sol-green-800);
  font: 600 12px/1 var(--font-sans);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 20px 22px;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center;
}
.partners-brands {
  padding: 18px 22px;
  border-bottom: 1px solid var(--border);
  display: flex; flex-wrap: wrap; gap: 12px 28px;
  align-items: center;
  justify-content: center;
}
.partners-brands .b {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 4px 6px;
  color: var(--fg-muted);
  transition: transform 200ms cubic-bezier(0.22,0.61,0.36,1);
}
.partners-brands .b img {
  height: 32px;
  width: auto;
  max-width: 130px;
  object-fit: contain;
  display: block;
  opacity: 0.88;
  transition: opacity 200ms cubic-bezier(0.22,0.61,0.36,1);
}
/* Per-brand size overrides — visually compensate for very small/large logo crops */
.partners-brands .b img[src$="vodafone.png"],
.partners-brands .b img[src$="yoigo.png"] {
  height: 16px;
  max-width: 80px;
}
.partners-brands .b img[src$="endesa.png"],
.partners-brands .b img[src$="totalenergies.svg"] {
  height: 64px;
  max-width: 220px;
}
.partners-brands .b:hover { transform: translateY(-2px); }
.partners-brands .b:hover img { opacity: 1; }

.partners-row:last-child .partners-cat,
.partners-row:last-child .partners-brands {
  border-bottom: none;
}

/* Marquee variant */
.marquee {
  margin-top: 32px;
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.marquee-track {
  display: flex; gap: 56px;
  animation: marquee 28s linear infinite;
  width: max-content;
  align-items: center;
}
.marquee-track .b {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 44px;
  flex: none;
}
.marquee-track .b img {
  height: 32px;
  width: auto;
  max-width: 140px;
  object-fit: contain;
  display: block;
  opacity: 0.85;
}
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ---------- CTA BAND ---------- */
.cta-band {
  position: relative;
  background: linear-gradient(135deg, #95c11f 0%, #13a538 100%);
  color: #fff;
  overflow: hidden;
  padding: 72px 0 80px;
}
.cta-band::before {
  content: "";
  position: absolute;
  left: -100px; bottom: -120px;
  width: 460px; height: 460px;
  background: url("assets/isotipo-white.png") center/contain no-repeat;
  opacity: 0.10;
  pointer-events: none;
}
.cta-band-inner {
  display: grid; grid-template-columns: 1fr; gap: 36px; align-items: center;
  position: relative; z-index: 1;
}
@media (min-width: 980px) {
  .cta-band-inner { grid-template-columns: 1fr 1fr; gap: 64px; }
}
.cta-band .eyebrow-light {
  display: inline-block;
  padding: 6px 14px;
  background: rgba(255,255,255,0.16);
  color: #fff;
  font: 600 12px/1 var(--font-sans);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-radius: 999px;
  margin-bottom: 18px;
}
.cta-band h2 {
  font: 600 clamp(34px, 5vw, 52px) / 1.02 var(--font-sans);
  letter-spacing: -0.025em;
  color: #fff;
  margin: 0;
  text-wrap: balance;
}
.cta-band .lead-light {
  font: 300 clamp(15px, 1.4vw, 18px) / 1.55 var(--font-sans);
  color: rgba(255,255,255,0.92);
  margin-top: 16px;
  max-width: 460px;
}
.cta-band-card {
  background: #fff;
  border-radius: 20px;
  padding: 22px;
  box-shadow: 0 24px 48px rgba(0,0,0,0.18);
  color: var(--fg);
}
.cta-band-card h3 {
  font: 600 18px/1.2 var(--font-sans);
  color: var(--fg-strong);
  margin: 0 0 14px;
}
.cta-band-card iframe {
  width: 100%;
  display: block;
  border: 0;
  border-radius: 12px;
  background: #f8f8f4;
}

/* ---------- FOOTER ---------- */
.site-footer {
  background: var(--sol-ink-700);
  color: #fff;
  padding: 56px 0 24px;
}
.footer-top {
  display: grid;
  grid-template-columns: 1fr;
  gap: 36px;
  margin-bottom: 40px;
}
@media (min-width: 768px) {
  .footer-top { grid-template-columns: 1.1fr repeat(4, 1fr); gap: 32px 48px; }
}
.footer-brand { display: flex; flex-direction: column; gap: 14px; }
.footer-brand img { height: 36px; align-self: flex-start; }
.footer-brand p {
  font: 300 14px/1.5 var(--font-sans);
  color: rgba(255,255,255,0.72);
  max-width: 320px;
  margin: 0;
}
.footer-col h4 {
  font: 600 11.5px/1 var(--font-sans);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--sol-green-300);
  margin: 0 0 14px;
}
.footer-col a, .footer-col .contact {
  display: flex; align-items: center; gap: 10px;
  font: 400 14px/1.55 var(--font-sans);
  color: rgba(255,255,255,0.82);
  transition: color 160ms;
}
.footer-col a:hover { color: var(--sol-green-300); }
.footer-col h4.footer-col--portal { color: #b3da5e; }
.footer-col .contact svg {
  color: var(--sol-green-300);
  flex: none;
}
.footer-bottom {
  padding-top: 22px;
  border-top: 1px solid rgba(255,255,255,0.12);
  display: flex; flex-direction: column; gap: 18px;
  font: 400 12px/1.4 var(--font-sans);
  color: rgba(255,255,255,0.6);
}
@media (min-width: 768px) {
  .footer-bottom { flex-direction: row; justify-content: space-between; align-items: center; }
}
.footer-legal { display: flex; flex-wrap: wrap; gap: 16px; }
.footer-legal a { color: rgba(255,255,255,0.66); }
.footer-legal a:hover { color: #fff; }
.footer-socials { display: flex; gap: 10px; }
.footer-socials a {
  width: 38px; height: 38px; border-radius: 50%;
  background: rgba(255,255,255,0.08);
  color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background 200ms, transform 200ms;
}
.footer-socials a:hover { background: var(--sol-green-600); transform: translateY(-2px); }
.footer-socials svg { width: 16px; height: 16px; }

/* ---------- PAGE HEADERS (inner pages) ---------- */
.page-header {
  background: var(--sol-ink-50);
  padding: 88px 0 56px;
  position: relative;
  overflow: hidden;
}
.page-header::after {
  content: "";
  position: absolute;
  right: -120px; top: -80px;
  width: 360px; height: 360px;
  background: url("assets/isotipo-gradient.png") center/contain no-repeat;
  opacity: 0.10;
  pointer-events: none;
}
.page-header .breadcrumb {
  font: 500 12px/1 var(--font-sans);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-bottom: 14px;
  display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
}
.page-header .breadcrumb a { color: var(--sol-green-700); }
.page-header .breadcrumb .sep { color: var(--fg-subtle); }
.page-header h1 {
  font: 600 clamp(36px, 6vw, 64px) / 1.04 var(--font-sans);
  letter-spacing: -0.025em;
  color: var(--fg-strong);
  margin: 0 0 14px;
  max-width: 800px;
  text-wrap: balance;
}
.page-header .page-lead {
  font: 300 clamp(16px, 1.5vw, 20px) / 1.55 var(--font-sans);
  color: var(--fg);
  max-width: 640px;
  margin: 0;
  text-wrap: pretty;
}

/* ---------- REVEAL ANIMATIONS ---------- */
.reveal {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 600ms cubic-bezier(0.22, 0.61, 0.36, 1),
              transform 600ms cubic-bezier(0.22, 0.61, 0.36, 1);
  transition-delay: var(--rd, 0ms);
}
.reveal.is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal.is-in { opacity: 1; transform: none; transition: none; }
  .hero-chip, .marquee-track, .hero-scroll-cue .mouse::before { animation: none; }
}

/* ---------- LEGAL / TEXT PAGES ---------- */
.legal {
  padding: 56px 0 96px;
}
.legal .container { max-width: 880px; }
.legal h2 {
  font: 600 24px/1.2 var(--font-sans);
  color: var(--fg-strong);
  margin: 40px 0 12px;
  letter-spacing: -0.01em;
}
.legal h3 {
  font: 600 18px/1.3 var(--font-sans);
  color: var(--fg-strong);
  margin: 28px 0 8px;
}
.legal p, .legal li {
  font: 400 15px/1.7 var(--font-sans);
  color: var(--fg);
  text-wrap: pretty;
}
.legal ul, .legal ol { padding-left: 22px; }
.legal a { color: var(--sol-green-700); text-decoration: underline; text-underline-offset: 3px; }
.legal .updated {
  display: inline-block;
  padding: 6px 12px;
  background: var(--sol-green-50);
  color: var(--sol-green-800);
  border-radius: 999px;
  font: 600 12px/1 var(--font-sans);
  letter-spacing: 0.04em;
}

/* ---------- VALUES (about page) ---------- */
.values { padding: 80px 0; }
.values-grid {
  display: grid; grid-template-columns: 1fr; gap: 18px;
}
@media (min-width: 768px) { .values-grid { grid-template-columns: repeat(3, 1fr); } }
.value-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 28px;
  display: flex; flex-direction: column; gap: 10px;
  position: relative; overflow: hidden;
}
.value-card .num {
  font: 600 64px/1 var(--font-sans);
  letter-spacing: -0.04em;
  background: linear-gradient(135deg, var(--sol-lime), var(--sol-green));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  margin-bottom: 4px;
}
.value-card h3 { font: 600 22px/1.2 var(--font-sans); color: var(--fg-strong); margin: 0; }
.value-card p { font: 400 14.5px/1.55 var(--font-sans); color: var(--fg-muted); margin: 0; }

/* Mission/Vision/Values - dark hero card */
.mvv {
  padding: 80px 0;
  background: var(--sol-ink-700);
  color: #fff;
  position: relative;
  overflow: hidden;
}
.mvv::before {
  content: "";
  position: absolute;
  inset: -10% auto auto -10%;
  width: 500px; height: 500px;
  background: url("assets/isotipo-green-361.png") center/contain no-repeat;
  opacity: 0.12;
}
.mvv-grid {
  display: grid; grid-template-columns: 1fr; gap: 24px;
  position: relative; z-index: 1;
}
@media (min-width: 768px) { .mvv-grid { grid-template-columns: repeat(3, 1fr); } }
.mvv-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 18px;
  padding: 28px;
  backdrop-filter: blur(8px);
}
.mvv-card .label {
  font: 600 11px/1 var(--font-sans);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--sol-green-300);
  margin-bottom: 12px;
  display: inline-block;
}
.mvv-card h3 {
  font: 600 24px/1.2 var(--font-sans);
  color: #fff;
  margin: 0 0 10px;
}
.mvv-card p {
  font: 300 15px/1.6 var(--font-sans);
  color: rgba(255,255,255,0.88);
  margin: 0;
  text-wrap: pretty;
}

/* ---------- CONTACT GRID ---------- */
.contact-page { padding: 72px 0 96px; }
.contact-grid {
  display: grid; grid-template-columns: 1fr; gap: 32px;
}
@media (min-width: 980px) {
  .contact-grid {
    grid-template-columns: 260px minmax(0, 1fr);
    gap: 28px;
    align-items: start;
  }
}
.contact-card { align-self: start; }
.contact-card {
  background: var(--sol-ink-50);
  border-radius: 20px;
  padding: 24px;
}
.contact-card h2 { font: 600 20px/1.2 var(--font-sans); margin: 0 0 12px; color: var(--fg-strong); }
.contact-card .row {
  display: flex; gap: 12px; padding: 12px 0;
  border-bottom: 1px solid var(--border);
  align-items: center;
}
.contact-card .row:last-child { border-bottom: none; }
.contact-card .row .ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: #fff; color: var(--sol-green-600);
  display: inline-flex; align-items: center; justify-content: center;
  flex: none;
}
.contact-card .row .ico svg { width: 18px; height: 18px; }
.contact-card .row .lbl {
  font: 600 10.5px/1 var(--font-sans);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-bottom: 4px;
}
.contact-card .row .val {
  font: 600 14px/1.3 var(--font-sans);
  color: var(--fg-strong);
  word-break: break-word;
}
.contact-form-wrap {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 24px;
}
.contact-form-wrap h2 { font: 600 24px/1.2 var(--font-sans); margin: 0 0 8px; color: var(--fg-strong); }
.contact-form-wrap p { font: 400 14.5px/1.55 var(--font-sans); color: var(--fg-muted); margin: 0 0 16px; }
.contact-form-wrap iframe { width: 100%; display: block; border: 0; border-radius: 12px; }

/* ---------- UTILITIES ---------- */
.text-gradient {
  background: linear-gradient(135deg, var(--sol-lime), var(--sol-green));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.no-wrap { white-space: nowrap; }
.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;
}

/* Tiny green triangle bullet */
.tri-bullet { list-style: none; padding-left: 0; }
.tri-bullet li {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 6px 0;
}
.tri-bullet li::before {
  content: "";
  flex: none;
  width: 0; height: 0; margin-top: 10px;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 9px solid var(--sol-green-600);
}


/* ============================================================
   COOKIE BANNER + MODAL
   ============================================================ */
.cookie-banner,
.cookie-modal { font-family: var(--font-sans); }

.cookie-banner {
  position: fixed;
  left: 16px; right: 16px; bottom: 16px;
  z-index: 9000;
  background: #fff;
  border-radius: var(--radius-lg, 16px);
  box-shadow: 0 18px 40px rgba(60,60,59,0.18), 0 2px 6px rgba(60,60,59,0.08);
  border: 1px solid var(--sol-ink-100);
  overflow: hidden;
  transform: translateY(24px);
  opacity: 0;
  transition: transform 360ms cubic-bezier(0.22,0.61,0.36,1),
              opacity 240ms cubic-bezier(0.22,0.61,0.36,1);
  max-width: 1100px;
  margin: 0 auto;
}
.cookie-banner.is-in { transform: translateY(0); opacity: 1; }
.cookie-banner[hidden] { display: none !important; }

.cookie-banner::before {
  content: "";
  display: block;
  height: 3px;
  background: linear-gradient(90deg, var(--sol-lime), var(--sol-green));
}

.cookie-banner__inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 20px;
  align-items: center;
  padding: 22px 24px;
}
.cookie-banner__icon {
  width: 48px; height: 48px;
  border-radius: 14px;
  background: var(--sol-green-50);
  color: var(--sol-green-700);
  display: flex; align-items: center; justify-content: center;
  flex: none;
}
.cookie-banner__icon svg { width: 24px; height: 24px; }
.cookie-banner__body h3 {
  margin: 0 0 4px;
  font: 600 16px/1.3 var(--font-sans);
  color: var(--fg-strong);
  letter-spacing: -0.005em;
}
.cookie-banner__body p {
  margin: 0;
  font: 400 14px/1.55 var(--font-sans);
  color: var(--fg);
  max-width: 62ch;
  text-wrap: pretty;
}
.cookie-banner__body a {
  color: var(--sol-green-700);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.cookie-banner__body a:hover { color: var(--sol-green-800); }

.cookie-banner__actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  flex: none;
}
.cookie-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 42px;
  padding: 0 18px;
  border-radius: 999px;
  font: 600 13px/1 var(--font-sans);
  letter-spacing: 0.02em;
  border: none;
  background: transparent;
  color: var(--fg-strong);
  white-space: nowrap;
  transition: background 160ms cubic-bezier(0.22,0.61,0.36,1),
              color 160ms cubic-bezier(0.22,0.61,0.36,1),
              border-color 160ms cubic-bezier(0.22,0.61,0.36,1),
              transform 160ms cubic-bezier(0.22,0.61,0.36,1);
  cursor: pointer;
}
.cookie-btn:active { transform: scale(0.97); }

.cookie-btn--ghost {
  background: transparent;
  color: var(--fg);
  border: 1px solid var(--sol-ink-200);
}
.cookie-btn--ghost:hover {
  background: var(--sol-ink-50);
  color: var(--fg-strong);
}

.cookie-btn--secondary {
  background: transparent;
  color: var(--sol-green-700);
  border: 1.5px solid var(--sol-green-600);
}
.cookie-btn--secondary:hover {
  background: var(--sol-green-50);
  color: var(--sol-green-800);
}

.cookie-btn--primary {
  background: var(--sol-green-600);
  color: #fff;
  box-shadow: 0 8px 18px rgba(19,165,56,0.22);
}
.cookie-btn--primary:hover {
  background: var(--sol-green-700);
  box-shadow: 0 10px 22px rgba(19,165,56,0.28);
}

/* ---------- modal ---------- */
.cookie-modal {
  position: fixed; inset: 0;
  z-index: 9100;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.cookie-modal.is-open { display: flex; }
.cookie-modal__overlay {
  position: absolute; inset: 0;
  background: rgba(60,60,59,0.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  opacity: 0;
  transition: opacity 240ms cubic-bezier(0.22,0.61,0.36,1);
}
.cookie-modal.is-open .cookie-modal__overlay { opacity: 1; }
.cookie-modal__dialog {
  position: relative;
  background: #fff;
  width: 100%;
  max-width: 580px;
  max-height: calc(100vh - 32px);
  display: flex; flex-direction: column;
  border-radius: 20px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.28);
  overflow: hidden;
  transform: translateY(16px) scale(0.98);
  opacity: 0;
  transition: transform 360ms cubic-bezier(0.22,0.61,0.36,1),
              opacity 240ms cubic-bezier(0.22,0.61,0.36,1);
}
.cookie-modal.is-open .cookie-modal__dialog {
  transform: translateY(0) scale(1);
  opacity: 1;
}

.cookie-modal__head {
  padding: 24px 28px 16px;
  border-bottom: 1px solid var(--sol-ink-100);
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 16px;
}
.cookie-modal__head h2 {
  margin: 0 0 4px;
  font: 600 20px/1.25 var(--font-sans);
  color: var(--fg-strong);
  letter-spacing: -0.01em;
}
.cookie-modal__head p {
  margin: 0;
  font: 400 14px/1.55 var(--font-sans);
  color: var(--fg);
}
.cookie-modal__close {
  flex: none;
  width: 36px; height: 36px;
  border-radius: 50%;
  border: none;
  background: var(--sol-ink-50);
  color: var(--fg-strong);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background 160ms;
}
.cookie-modal__close:hover { background: var(--sol-ink-100); }
.cookie-modal__close svg { width: 18px; height: 18px; }

.cookie-modal__body {
  padding: 20px 28px;
  overflow-y: auto;
  display: flex; flex-direction: column; gap: 14px;
}
.cookie-cat {
  border: 1px solid var(--sol-ink-100);
  border-radius: 14px;
  padding: 16px 18px;
  transition: border-color 160ms, background 160ms;
}
.cookie-cat:has(.cookie-toggle input:checked) {
  border-color: var(--sol-green-300);
  background: linear-gradient(180deg, rgba(19,165,56,0.04), rgba(19,165,56,0));
}
.cookie-cat__head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 16px;
}
.cookie-cat__title {
  display: flex; align-items: center; gap: 10px;
  font: 600 12px/1 var(--font-sans);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--sol-green-700);
  margin: 0;
}
.cookie-cat__title .name {
  color: var(--fg-strong);
  font-size: 15px;
  letter-spacing: -0.005em;
  text-transform: none;
}
.cookie-cat__title .tri {
  width: 0; height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 6px solid var(--sol-green-600);
  flex: none;
}
.cookie-cat__desc {
  margin: 8px 0 10px;
  font: 400 13px/1.55 var(--font-sans);
  color: var(--fg);
}
.cookie-cat__link {
  font: 600 12px/1 var(--font-sans);
  color: var(--sol-green-700);
  letter-spacing: 0.04em;
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 6px;
}
.cookie-cat__link:hover { color: var(--sol-green-800); text-decoration: underline; text-underline-offset: 3px; }

/* toggle */
.cookie-toggle {
  position: relative;
  display: inline-block;
  width: 44px; height: 26px;
  flex: none;
}
.cookie-toggle input {
  position: absolute;
  opacity: 0;
  width: 100%; height: 100%;
  margin: 0;
  cursor: pointer;
}
.cookie-toggle .track {
  position: absolute; inset: 0;
  background: var(--sol-ink-200);
  border-radius: 999px;
  transition: background 200ms cubic-bezier(0.22,0.61,0.36,1);
}
.cookie-toggle .thumb {
  position: absolute;
  top: 3px; left: 3px;
  width: 20px; height: 20px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 2px 4px rgba(0,0,0,0.18);
  transition: transform 200ms cubic-bezier(0.22,0.61,0.36,1);
}
.cookie-toggle input:checked + .track { background: var(--sol-green-600); }
.cookie-toggle input:checked + .track + .thumb { transform: translateX(18px); }
.cookie-toggle input:disabled { cursor: not-allowed; }
.cookie-toggle input:disabled + .track { background: var(--sol-green-300); opacity: 0.85; }
.cookie-toggle input:focus-visible + .track {
  outline: 3px solid var(--focus-ring);
  outline-offset: 2px;
}

.cookie-modal__foot {
  padding: 18px 28px 22px;
  border-top: 1px solid var(--sol-ink-100);
  display: flex; gap: 10px; flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
.cookie-modal__foot .cookie-modal__foot-actions {
  display: flex; gap: 10px; flex-wrap: wrap;
}

/* responsive */
@media (max-width: 820px) {
  .cookie-banner__inner {
    grid-template-columns: 1fr;
    gap: 14px;
    padding: 20px;
  }
  .cookie-banner__icon { display: none; }
  .cookie-banner__actions { width: 100%; flex-direction: column-reverse; align-items: stretch; }
  .cookie-btn { width: 100%; }
}
@media (max-width: 520px) {
  .cookie-banner { left: 8px; right: 8px; bottom: 8px; }
  .cookie-modal__head { padding: 20px 20px 14px; }
  .cookie-modal__body { padding: 16px 20px; }
  .cookie-modal__foot { padding: 16px 20px 20px; }
  .cookie-modal__foot,
  .cookie-modal__foot .cookie-modal__foot-actions { width: 100%; }
  .cookie-modal__foot .cookie-modal__foot-actions { flex-direction: column-reverse; }
  .cookie-modal__foot .cookie-btn { width: 100%; }
}

body.cookie-modal-open { overflow: hidden; }

/* small "manage cookies" link inside the legal page */
.legal .cookie-manage-row {
  margin-top: 16px;
  display: flex; gap: 12px; flex-wrap: wrap; align-items: center;
}
.legal .cookie-manage-row .cookie-btn--secondary { height: 40px; padding: 0 18px; }


/* ============================================================
   Page header with side media (Quiénes somos)
   ============================================================ */
.page-header--media .page-header__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  align-items: center;
}
@media (min-width: 900px) {
  .page-header--media .page-header__grid {
    grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
    gap: 56px;
  }
}
.page-header--media .page-header__text > .breadcrumb { margin-bottom: 12px; }
.page-header--media .page-header__text h1 { margin-top: 10px; }
.page-header--media .page-header__text .page-lead { margin-top: 18px; }

.page-header__media {
  position: relative;
  margin: 0;
  border-radius: 24px;
  overflow: hidden;
  aspect-ratio: 4 / 5;
  box-shadow: 0 24px 50px rgba(60,60,59,0.18), 0 2px 6px rgba(60,60,59,0.08);
  isolation: isolate;
  transform: translateZ(0);
  transition: transform 480ms cubic-bezier(0.22, 0.61, 0.36, 1),
              box-shadow 480ms cubic-bezier(0.22, 0.61, 0.36, 1);
  cursor: pointer;
}
.page-header__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 45%;
  display: block;
  transition: transform 900ms cubic-bezier(0.22, 0.61, 0.36, 1),
              filter 480ms cubic-bezier(0.22, 0.61, 0.36, 1);
  will-change: transform;
}
/* gradient sheen that sweeps across on hover */
.page-header__media::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(115deg,
    transparent 0%,
    transparent 38%,
    rgba(149,193,31,0.0) 50%,
    rgba(149,193,31,0.45) 55%,
    rgba(19,165,56,0.0) 70%,
    transparent 100%);
  transform: translateX(-110%);
  transition: transform 900ms cubic-bezier(0.22, 0.61, 0.36, 1);
  mix-blend-mode: screen;
  pointer-events: none;
  z-index: 2;
}
/* subtle bottom vignette so the tag reads well */
.page-header__media::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 38%;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,0.32));
  pointer-events: none;
  z-index: 1;
}
.page-header__media-tag {
  position: absolute;
  left: 16px; bottom: 16px;
  z-index: 3;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border-radius: 999px;
  font: 600 12px/1 var(--font-sans);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--sol-green-800);
  box-shadow: 0 6px 14px rgba(0,0,0,0.12);
  transform: translateY(6px);
  opacity: 0.92;
  transition: transform 480ms cubic-bezier(0.22, 0.61, 0.36, 1),
              opacity 320ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
.page-header__media-tag .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--sol-green-600);
  box-shadow: 0 0 0 4px rgba(19,165,56,0.18);
}

/* ---- hover state ---- */
.page-header__media:hover {
  transform: translateY(-4px);
  box-shadow: 0 34px 60px rgba(19,165,56,0.22), 0 4px 10px rgba(60,60,59,0.10);
}
.page-header__media:hover img {
  transform: scale(1.05);
  filter: saturate(1.08) contrast(1.02);
}
.page-header__media:hover::before { transform: translateX(110%); }
.page-header__media:hover .page-header__media-tag {
  transform: translateY(0);
  opacity: 1;
}

@media (prefers-reduced-motion: reduce) {
  .page-header__media,
  .page-header__media img,
  .page-header__media::before,
  .page-header__media-tag { transition: none; }
}


/* Square variant for soluciones hero — same component, different aspect + tilt hover */
.page-header__media--square { aspect-ratio: 1 / 1; }
.page-header__media--square img { object-position: center center; }
@media (min-width: 900px) {
  .page-header--media .page-header__grid:has(.page-header__media--square) {
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
  }
}
.page-header__media--square:hover { transform: translateY(-4px) rotate(-1.2deg); }
.page-header__media--square:hover img { transform: scale(1.04) rotate(0.6deg); }


/* Landscape variant for colaborador hero — emphasises horizontal motion */
.page-header__media--landscape { aspect-ratio: 3 / 2; }
.page-header__media--landscape img { object-position: center 60%; }
@media (min-width: 900px) {
  .page-header--media .page-header__grid:has(.page-header__media--landscape) {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  }
}
/* Hover: subtle parallax-ish lift + image pan to the right
   (revealing more of the stacked coins) */
.page-header__media--landscape:hover img {
  transform: scale(1.06) translateX(-1.5%);
}


/* Contact hero — playful tilt + lift on hover */
.page-header__media--contact { aspect-ratio: 3 / 2; }
.page-header__media--contact img { object-position: 60% center; }
.page-header__media--contact:hover {
  transform: translateY(-4px) rotate(0.8deg);
}
.page-header__media--contact:hover img {
  transform: scale(1.04);
  filter: saturate(1.1) brightness(1.02);
}


/* ============================================================
   TWEAKS PANEL — VIEWPORT PREVIEW
   ============================================================ */
.tw-panel {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 11000;
  width: 320px;
  background: #fff;
  border-radius: 18px;
  box-shadow: 0 24px 60px rgba(60,60,59,0.25), 0 2px 6px rgba(60,60,59,0.10);
  border: 1px solid var(--sol-ink-100);
  font-family: var(--font-sans);
  opacity: 0;
  transform: translateY(10px);
  pointer-events: none;
  transition: opacity 240ms cubic-bezier(0.22,0.61,0.36,1),
              transform 240ms cubic-bezier(0.22,0.61,0.36,1);
}
.tw-panel.is-on {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.tw-panel__head {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 16px 18px 12px;
  border-bottom: 1px solid var(--sol-ink-100);
  user-select: none;
}
.tw-panel__eyebrow {
  font: 600 10px/1 var(--font-sans);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--sol-green-700);
  margin-bottom: 6px;
}
.tw-panel__head h3 {
  margin: 0;
  font: 600 16px/1.2 var(--font-sans);
  color: var(--fg-strong);
  letter-spacing: -0.005em;
}
.tw-panel__close {
  flex: none;
  width: 28px; height: 28px;
  border-radius: 50%;
  border: none;
  background: var(--sol-ink-50);
  color: var(--fg-strong);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background 160ms;
}
.tw-panel__close:hover { background: var(--sol-ink-100); }

.tw-panel__body { padding: 14px 18px 18px; }
.tw-panel__caption {
  margin: 0 0 14px;
  font: 400 12.5px/1.5 var(--font-sans);
  color: var(--fg-muted);
}

.tw-radio {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
}
.tw-radio__opt {
  appearance: none;
  background: var(--sol-ink-50);
  border: 1.5px solid transparent;
  border-radius: 12px;
  padding: 12px 6px 10px;
  display: flex; flex-direction: column;
  align-items: center; gap: 6px;
  color: var(--fg);
  cursor: pointer;
  transition: background 160ms, border-color 160ms, color 160ms, transform 160ms;
}
.tw-radio__opt:hover { background: #fff; border-color: var(--sol-ink-200); color: var(--fg-strong); }
.tw-radio__opt:active { transform: scale(0.97); }
.tw-radio__opt.is-on {
  background: var(--sol-green-50);
  border-color: var(--sol-green-600);
  color: var(--sol-green-800);
}
.tw-radio__icon { color: currentColor; }
.tw-radio__label {
  font: 600 10px/1 var(--font-sans);
  letter-spacing: 0.10em;
}

/* ---------- preview overlay ---------- */
html.tw-preview-on body > *:not(.tw-panel):not(.tw-preview) {
  display: none !important;
}
html.tw-preview-on body {
  background: var(--sol-ink-700);
  min-height: 100vh;
}
.tw-preview {
  position: fixed;
  inset: 0;
  z-index: 10900;
  display: none;
  align-items: flex-start;
  justify-content: center;
  padding: 40px 16px 32px;
  background: radial-gradient(120% 80% at 50% 0%, #2b3636 0%, #1a2424 100%);
  overflow: auto;
}
.tw-preview.is-on { display: flex; }
.tw-preview__stage {
  display: flex; flex-direction: column; align-items: center;
}
.tw-preview__device {
  --dw: 820px;
  --dh: 1180px;
}
.tw-preview__bezel {
  position: relative;
  width: calc(var(--dw) + 28px);
  height: calc(var(--dh) + 56px);
  background: linear-gradient(160deg, #1c1c1c, #0a0a0a);
  border-radius: 38px;
  padding: 28px 14px;
  box-shadow:
    0 0 0 1.5px rgba(255,255,255,0.06),
    0 30px 80px rgba(0,0,0,0.6),
    0 6px 16px rgba(0,0,0,0.35);
}
.tw-preview__device[data-device="tablet"] .tw-preview__bezel { border-radius: 28px; padding: 32px 14px; height: calc(var(--dh) + 64px); }
.tw-preview__device[data-device="movil"]  .tw-preview__bezel { border-radius: 44px; padding: 22px 10px; width: calc(var(--dw) + 20px); height: calc(var(--dh) + 44px); }

.tw-preview__screen {
  position: relative;
  width: var(--dw);
  height: var(--dh);
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.04);
}
.tw-preview__device[data-device="tablet"] .tw-preview__screen { border-radius: 10px; }
.tw-preview__device[data-device="movil"]  .tw-preview__screen { border-radius: 28px; }

.tw-preview__frame {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
  background: #fff;
}

/* notch / camera */
.tw-preview__notch { display: none; }
.tw-preview__device[data-device="movil"] .tw-preview__notch {
  display: block;
  position: absolute;
  top: 32px;
  left: 50%;
  transform: translateX(-50%);
  width: 100px; height: 22px;
  background: #000;
  border-radius: 999px;
  z-index: 2;
}

.tw-preview__label {
  margin-top: 18px;
  font: 600 11px/1 var(--font-sans);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
  padding: 8px 14px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 999px;
}

@media (max-width: 880px) {
  .tw-preview__device {
    transform: scale(0.55);
    transform-origin: top center;
  }
}
@media (max-width: 600px) {
  .tw-panel { left: 12px; right: 12px; width: auto; bottom: 12px; }
}
