.stack-sans-notch-<uniquifier> {
      font-family: "Stack Sans Notch", sans-serif;
      font-optical-sizing: auto;
      font-weight: <weight>;
      font-style: normal;
    }

    .google-sans-flex-<uniquifier> {
      font-family: "Google Sans Flex", sans-serif;
      font-optical-sizing: auto;
      font-weight: <weight>;
      font-style: normal;
      font-variation-settings:
        "slnt" 0,
        "wdth" 100,
        "GRAD" 0,
        "ROND" 0;
    }
    /* ─── TOKENS ────────────────────────────────────────────────── */
    :root {
      --verde-dark:   #0D1F0E;
      --verde-corp:   #1B4D1F;
      --verde-mid:    #3A7D2C;
      --verde-acento: #6BBF47;
      --verde-light:  #A8E063;
      --blanco:       #F5F8F4;
      --gris-text:    #B8C9B4;
      --negro:        #080F08;

      --font-display: 'Stack Sans Notch', sans-serif;
      --font-body:    'Google Sans Flex', sans-serif;

      --radius-card:  12px;
      --transition:   0.35s cubic-bezier(0.4, 0, 0.2, 1);
    }

    /* ─── RESET / BASE ───────────────────────────────────────────── */
    *, *::before, *::after { box-sizing: border-box; }

    html { scroll-behavior: smooth; }

    body {
      background-color: var(--verde-dark);
      color: var(--blanco);
      font-family: var(--font-body);
      font-size: 16px;
      line-height: 1.65;
      overflow-x: hidden;
    }

    h1, h2, h3, h4, h5 {
      font-family: var(--font-display);
      font-weight: 700;
      letter-spacing: -0.01em;
      line-height: 1.15;
      text-transform: none;
    }

    a { color: inherit; text-decoration: none; }

    img { max-width: 100%; }

    section { position: relative; overflow: hidden; }

    .section-eyebrow {
      font-family: var(--font-display);
      font-size: 0.78rem;
      font-weight: 700;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: var(--verde-acento);
      display: inline-block;
      margin-bottom: 0.75rem;
    }

    /* ─── NAV ────────────────────────────────────────────────────── */
    #mainNav {
      background: rgba(8, 15, 8, 0.0);
      backdrop-filter: blur(0px);
      transition: background var(--transition), backdrop-filter var(--transition);
      padding: 1rem 0;
      z-index: 1000;
    }

    #mainNav.scrolled {
      background: rgba(8, 15, 8, 0.92);
      backdrop-filter: blur(16px);
      padding: 0.8rem 0;
      box-shadow: 0 2px 24px rgba(0,0,0,0.45);
    }

    .navbar-brand img {
      height: 90px;
      width: auto;
    }

    .nav-link {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 1rem;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: var(--blanco) !important;
      padding: 0.5rem 1rem !important;
      transition: color var(--transition);
    }

    .nav-link:hover { color: var(--verde-acento) !important; }

    .nav-link.active { color: var(--verde-acento) !important; }

    /* Botón cotizar en nav — pulso constante */
    .btn-cotizar-nav {
      font-family: var(--font-display);
      font-weight: 800;
      font-size: 0.95rem;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      background: var(--verde-acento);
      color: var(--negro) !important;
      border: none;
      border-radius: 6px;
      padding: 0.5rem 1.4rem;
      position: relative;
      animation: navBtnPulse 2.2s ease-in-out infinite;
      cursor: pointer;
      transition: background var(--transition), transform var(--transition);
    }

    .btn-cotizar-nav:hover {
      background: var(--verde-light);
      transform: scale(1.05);
      animation-play-state: paused;
    }

    @keyframes navBtnPulse {
      0%, 100% { box-shadow: 0 0 0 0 rgba(107,191,71,0.55); }
      50% { box-shadow: 0 0 0 10px rgba(107,191,71,0); }
    }

    .navbar-toggler {
      border: 1.5px solid var(--verde-acento);
      padding: 0.35rem 0.6rem;
    }

    .navbar-toggler-icon {
      background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%236BBF47' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
    }

    /* ─── HERO ───────────────────────────────────────────────────── */
    #inicio {
      min-height: 100svh;
      display: flex;
      align-items: center;
      position: relative;
      padding: 130px 0 80px;
    }

    .hero-bg {
      position: absolute;
      inset: 0;
      background:
        linear-gradient(160deg, rgba(13,31,14,0.82) 40%, rgba(27,77,31,0.55) 100%),
        url('img/hero.webp') center/cover no-repeat;
      z-index: 0;
    }

    /* Partículas decorativas */
    .hero-bg::after {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(ellipse 60% 70% at 70% 50%, rgba(58,125,44,0.18) 0%, transparent 70%);
    }

    .hero-content { position: relative; z-index: 1; }

    .hero-tag {
      display: inline-flex;
      align-items: center;
      gap: 0.5rem;
      background: rgba(107,191,71,0.12);
      border: 1px solid rgba(107,191,71,0.4);
      border-radius: 100px;
      padding: 0.35rem 1rem;
      font-size: 0.8rem;
      font-weight: 600;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--verde-acento);
      margin-bottom: 1.5rem;
    }

    .hero-tag .dot {
      width: 8px; height: 8px;
      border-radius: 50%;
      background: var(--verde-acento);
      animation: blink 1.8s ease-in-out infinite;
    }

    @keyframes blink {
      0%, 100% { opacity: 1; }
      50% { opacity: 0.2; }
    }

    .hero-h1 {
      font-size: clamp(2.4rem, 6vw, 4.8rem);
      font-weight: 800;
      letter-spacing: -0.03em;
      color: var(--blanco);
      margin-bottom: 1.25rem;
      line-height: 1.08;
    }

    .hero-h1 span { color: var(--verde-acento); }

    .hero-sub {
      font-size: clamp(1rem, 2.2vw, 1.2rem);
      color: var(--gris-text);
      max-width: 560px;
      margin-bottom: 0.75rem;
      font-weight: 300;
    }

    .hero-zona {
      font-size: 0.85rem;
      color: var(--verde-acento);
      letter-spacing: 0.06em;
      margin-bottom: 2.25rem;
      display: flex;
      align-items: center;
      gap: 0.4rem;
    }

    .btn-hero {
      font-family: var(--font-display);
      font-weight: 800;
      font-size: 1.05rem;
      letter-spacing: 0.07em;
      text-transform: uppercase;
      background: var(--verde-acento);
      color: var(--negro);
      border: none;
      border-radius: 8px;
      padding: 0.85rem 2rem;
      cursor: pointer;
      transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
      display: inline-flex;
      align-items: center;
      gap: 0.6rem;
    }

    .btn-hero:hover {
      background: var(--verde-light);
      transform: translateY(-3px);
      box-shadow: 0 12px 32px rgba(107,191,71,0.35);
    }

    /* Servicios rápidos en hero bottom */
    .hero-pills {
      display: flex;
      flex-wrap: wrap;
      gap: 0.5rem;
      margin-top: 3rem;
    }

    .hero-pill {
      background: rgba(255,255,255,0.06);
      border: 1px solid rgba(255,255,255,0.1);
      border-radius: 100px;
      padding: 0.35rem 0.9rem;
      font-size: 0.8rem;
      font-weight: 500;
      color: var(--gris-text);
      backdrop-filter: blur(6px);
    }

    /* Hero right — imagen/card flotante */
    .hero-card-float {
      background: rgba(27,77,31,0.35);
      border: 1px solid rgba(107,191,71,0.25);
      border-radius: 16px;
      backdrop-filter: blur(16px);
      padding: 2rem;
      animation: floatCard 4s ease-in-out infinite;
    }

    @keyframes floatCard {
      0%, 100% { transform: translateY(0); }
      50% { transform: translateY(-14px); }
    }

    .hero-stat {
      text-align: center;
      padding: 1rem 0;
      border-bottom: 1px solid rgba(107,191,71,0.15);
    }

    .hero-stat:last-child { border-bottom: none; }

    .hero-stat-num {
      font-family: var(--font-display);
      font-size: 2.4rem;
      font-weight: 900;
      color: var(--verde-acento);
      line-height: 1;
    }

    .hero-stat-label {
      font-size: 0.78rem;
      color: var(--gris-text);
      text-transform: uppercase;
      letter-spacing: 0.1em;
      margin-top: 0.25rem;
    }

    /* ─── SECTION FADE TRANSITION ───────────────────────────────── */
    .section-fade-top {
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 80px;
      background: linear-gradient(to bottom, var(--verde-dark), transparent);
      z-index: 1;
      pointer-events: none;
    }

    /* ─── SERVICIOS ──────────────────────────────────────────────── */
    #servicios {
      background: var(--negro);
      padding: 100px 0;
    }

    .section-title {
      font-size: clamp(1.85rem, 4.5vw, 3rem);
      font-weight: 700;
      color: var(--blanco);
      margin-bottom: 0.5rem;
      letter-spacing: -0.02em;
    }

    .section-sub {
      color: var(--gris-text);
      font-size: 1rem;
      font-weight: 300;
      max-width: 640px;
    }

    .servicio-card {
      background: #0D1F0E;
      background: linear-gradient(180deg,rgba(13, 31, 14, 1) 0%, rgba(13, 31, 14, 0) 100%);
      border: 1px solid linear-gradient(180deg,rgba(107, 191, 71, 1) 0%, rgba(107, 191, 71, 0) 100%); 
      border-radius: var(--radius-card);
      height: 100%;
      transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition);
      cursor: pointer;
      position: relative;
      overflow: hidden;
      display: flex;
      flex-direction: column;
      padding: 30px;
    }

    /* Photo slot at top of card */
    .servicio-card-img {
      width: 100%;
      height: 160px;
      object-fit: cover;
      display: block;
      filter: brightness(0.75) saturate(1.1);
      transition: filter var(--transition), transform 0.5s ease;
      flex-shrink: 0;
    }

    .servicio-card:hover .servicio-card-img {
      filter: brightness(0.9) saturate(1.3);
      transform: scale(1.04);
    }

    /* Gradient fade from image into card body */
    .servicio-card-fade {
      position: relative;
      margin-top: -48px;
      padding: 0 1.75rem 1.75rem;
      flex: 1;
      display: flex;
      flex-direction: column;
    }

    .servicio-card-fade::before {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 80px;
      background: linear-gradient(to bottom, transparent, rgba(13,31,14,0.96));
      pointer-events: none;
    }

    .servicio-card:hover {
      border-color: rgba(107,191,71,0.4);
      transform: translateY(-6px);
      box-shadow: 0 24px 56px rgba(0,0,0,0.55), 0 0 0 1px rgba(107,191,71,0.18);
    }

    .servicio-icon {
      width: 48px; height: 48px;
      border-radius: 10px;
      background: rgba(107,191,71,0.14);
      border: 1px solid rgba(107,191,71,0.3);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.3rem;
      color: var(--verde-acento);
      margin-bottom: 1rem;
      margin-top: 0.5rem;
      position: relative;
      z-index: 1;
      transition: background var(--transition), transform var(--transition);
    }

    .servicio-card:hover .servicio-icon {
      background: rgba(107,191,71,0.24);
      transform: scale(1.08) rotate(-3deg);
    }

    .servicio-card h4 {
      font-size: 1.1rem;
      font-weight: 700;
      color: var(--blanco);
      margin-bottom: 0.5rem;
      position: relative;
      z-index: 1;
    }

    .servicio-card p {
      font-size: 0.875rem;
      color: var(--gris-text);
      font-weight: 300;
      margin-bottom: 1.25rem;
      line-height: 1.6;
      flex: 1;
      position: relative;
      z-index: 1;
    }

    .btn-servicio {
      font-family: var(--font-display);
      font-size: 0.8rem;
      font-weight: 600;
      letter-spacing: 0.04em;
      text-transform: uppercase;
      color: var(--verde-acento);
      background: transparent;
      border: 1px solid rgba(107,191,71,0.35);
      border-radius: 6px;
      padding: 0.4rem 1rem;
      cursor: pointer;
      transition: background var(--transition), color var(--transition), border-color var(--transition);
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      position: relative;
      z-index: 1;
      align-self: flex-start;
    }

    .btn-servicio:hover {
      background: var(--verde-acento);
      color: var(--negro);
      border-color: var(--verde-acento);
    }

    /* Imagen banner inter-sección servicios */
    .servicios-banner {
      width: 100%;
      height: 260px;
      object-fit: cover;
      border-radius: var(--radius-card);
      margin: 3rem 0;
      filter: brightness(0.75) saturate(1.1);
    }

    /* ─── MATERIALES ─────────────────────────────────────────────── */
    #materiales {
      background: var(--verde-dark);
      padding: 100px 0;
      position: relative;
    }

    #materiales::before {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 1px;
      background: linear-gradient(90deg, transparent, rgba(107,191,71,0.35), transparent);
    }

    .mat-photo {
      border-radius: var(--radius-card);
      width: 100%;
      height: 420px;
      object-fit: cover;
      filter: brightness(0.8) saturate(1.15);
      box-shadow: 0 24px 64px rgba(0,0,0,0.5);
    }

    .materiales-grid {
      display: flex;
      flex-wrap: wrap;
      gap: 0.6rem;
    }

    .mat-chip {
      background: rgba(107,191,71,0.08);
      border: 1px solid rgba(107,191,71,0.25);
      border-radius: 8px;
      padding: 0.6rem 1.1rem;
      font-size: 0.9rem;
      font-weight: 500;
      color: var(--blanco);
      display: flex;
      align-items: center;
      gap: 0.5rem;
      transition: background var(--transition), border-color var(--transition), transform var(--transition);
      cursor: default;
    }

    .mat-chip:hover {
      background: rgba(107,191,71,0.18);
      border-color: rgba(107,191,71,0.5);
      transform: scale(1.04);
    }

    .mat-chip i { color: var(--verde-acento); font-size: 1rem; }

    .mat-cta-box {
      background: rgba(107,191,71,0.07);
      border: 1px solid rgba(107,191,71,0.2);
      border-radius: var(--radius-card);
      padding: 1.5rem;
      margin-top: 2rem;
    }

    .mat-cta-box p {
      font-size: 0.92rem;
      color: var(--gris-text);
      margin-bottom: 1rem;
    }

    /* ─── POR QUÉ ────────────────────────────────────────────────── */
    #por-que {
      background: var(--negro);
      padding: 100px 0;
      position: relative;
    }

    .porq-photo {
      width: 100%;
      height: 480px;
      object-fit: cover;
      border-radius: var(--radius-card);
      filter: brightness(0.75) saturate(1.1);
    }

    .check-item {
      display: flex;
      align-items: flex-start;
      gap: 0.85rem;
      padding: 0.85rem 0;
      border-bottom: 1px solid rgba(107,191,71,0.1);
      transition: padding-left var(--transition);
    }

    .check-item:hover { padding-left: 6px; }

    .check-item:last-of-type { border-bottom: none; }

    .check-icon {
      width: 28px; height: 28px;
      border-radius: 50%;
      background: rgba(107,191,71,0.15);
      border: 1px solid rgba(107,191,71,0.35);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.85rem;
      color: var(--verde-acento);
      flex-shrink: 0;
      margin-top: 2px;
    }

    .check-text {
      font-size: 0.95rem;
      color: var(--blanco);
      font-weight: 400;
    }

    /* Cobertura badge */
    .cobertura-badge {
      display: inline-flex;
      align-items: center;
      gap: 0.6rem;
      background: rgba(107,191,71,0.1);
      border: 1px solid rgba(107,191,71,0.3);
      border-radius: 8px;
      padding: 0.6rem 1.1rem;
      font-size: 0.85rem;
      color: var(--verde-acento);
      font-weight: 600;
      margin-top: 1.5rem;
    }

    /* ─── COMPROMISO AMBIENTAL BANNER ────────────────────────────── */
    #compromiso {
      position: relative;
      padding: 120px 0;
    }

    .compromiso-bg {
      position: absolute;
      inset: 0;
      background:
        linear-gradient(to right, rgba(13,31,14,0.93) 0%, rgba(13,31,14,0.65) 60%, rgba(13,31,14,0.3) 100%),
        url('img/sustentable.webp') center/cover no-repeat;
      z-index: 0;
    }

    .compromiso-content {
      position: relative;
      z-index: 1;
    }

    .compromiso-content h2 {
      font-size: clamp(2rem, 5vw, 3.8rem);
      color: var(--blanco);
      margin-bottom: 1rem;
    }

    .compromiso-content p {
      color: var(--gris-text);
      font-size: 1rem;
      font-weight: 300;
      max-width: 580px;
      margin-bottom: 2rem;
    }

    /* ─── MODAL DE CONTACTO ──────────────────────────────────────── */
    .modal-backdrop { --bs-backdrop-opacity: 0.75; }

    .modal-content {
      background: #0e1f0f;
      border: 1px solid rgba(107,191,71,0.25);
      border-radius: 16px;
    }

    .modal-header {
      border-bottom: 1px solid rgba(107,191,71,0.15);
      padding: 1.5rem 2rem;
    }

    .modal-title {
      font-family: var(--font-display);
      font-size: 1.8rem;
      font-weight: 800;
      text-transform: uppercase;
      color: var(--blanco);
    }

    .modal-header .btn-close {
      filter: invert(1);
      opacity: 0.6;
    }

    .modal-body { padding: 2rem; }

    .modal-sub {
      color: var(--gris-text);
      font-size: 0.93rem;
      margin-bottom: 2rem;
      line-height: 1.6;
    }

    .contact-item {
      display: flex;
      align-items: center;
      gap: 1rem;
      padding: 0.85rem 0;
      border-bottom: 1px solid rgba(107,191,71,0.1);
    }

    .contact-item:last-of-type { border-bottom: none; }

    .contact-icon {
      width: 42px; height: 42px;
      border-radius: 10px;
      background: rgba(107,191,71,0.1);
      border: 1px solid rgba(107,191,71,0.25);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.1rem;
      color: var(--verde-acento);
      flex-shrink: 0;
    }

    .contact-label {
      font-size: 0.72rem;
      text-transform: uppercase;
      letter-spacing: 0.1em;
      color: var(--gris-text);
      margin-bottom: 0.1rem;
    }

    .contact-value {
      font-size: 0.95rem;
      color: var(--blanco);
      font-weight: 500;
    }

    .contact-value a { color: var(--blanco); transition: color var(--transition); }
    .contact-value a:hover { color: var(--verde-acento); }

    .btn-wa-modal {
      width: 100%;
      font-family: var(--font-display);
      font-size: 1.1rem;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      background: #25D366;
      color: #fff;
      border: none;
      border-radius: 10px;
      padding: 1rem;
      margin-top: 1.75rem;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0.6rem;
      cursor: pointer;
      transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
    }

    .btn-wa-modal:hover {
      background: #1ebe5c;
      transform: translateY(-2px);
      box-shadow: 0 10px 28px rgba(37,211,102,0.35);
    }

    /* ─── FAB WHATSAPP ───────────────────────────────────────────── */
    .fab-wa {
      position: fixed;
      bottom: 28px;
      right: 24px;
      width: 60px; height: 60px;
      background: #25D366;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.65rem;
      color: #fff;
      z-index: 9999;
      cursor: pointer;
      text-decoration: none;
      transition: transform var(--transition), box-shadow var(--transition);
    }

    .fab-wa::before, .fab-wa::after {
      content: '';
      position: absolute;
      inset: 0;
      border-radius: 50%;
      border: 2px solid #25D366;
      animation: sonar 2.5s ease-out infinite;
    }

    .fab-wa::after { animation-delay: 1.25s; }

    @keyframes sonar {
      0%   { transform: scale(1); opacity: 0.8; }
      100% { transform: scale(2.4); opacity: 0; }
    }

    .fab-wa:hover {
      transform: scale(1.12);
      box-shadow: 0 8px 28px rgba(37,211,102,0.5);
    }

    .fab-wa:hover::before, .fab-wa:hover::after { animation-play-state: paused; }

    /* ─── FOOTER ─────────────────────────────────────────────────── */
    footer {
      background: var(--negro);
      border-top: 1px solid rgba(107,191,71,0.12);
      padding: 1.75rem 0;
    }

    .footer-brand {
      font-family: var(--font-display);
      font-size: 1rem;
      font-weight: 700;
      color: var(--verde-acento);
      text-transform: uppercase;
      letter-spacing: 0.06em;
    }

    .footer-copy {
      font-size: 0.8rem;
      color: var(--gris-text);
    }

    .footer-links a {
      font-family: var(--font-display);
      font-size: 0.82rem;
      font-weight: 600;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: var(--gris-text);
      transition: color var(--transition);
    }

    .footer-links a:hover { color: var(--verde-acento); }

    /* ─── UTILITIES / RESPONSIVE ─────────────────────────────────── */
    .btn-outline-acento {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 0.95rem;
      letter-spacing: 0.07em;
      text-transform: uppercase;
      color: var(--verde-acento);
      border: 1.5px solid var(--verde-acento);
      border-radius: 8px;
      padding: 0.7rem 1.6rem;
      background: transparent;
      cursor: pointer;
      transition: background var(--transition), color var(--transition);
      display: inline-flex;
      align-items: center;
      gap: 0.5rem;
    }

    .btn-outline-acento:hover {
      background: var(--verde-acento);
      color: var(--negro);
    }

    @media (max-width: 767.98px) {
      #inicio { padding: 130px 0 60px; }

      .hero-card-float {
        margin-top: 2.5rem;
        animation: none;
      }

      .navbar-collapse {
        background: rgba(8,15,8,0.96);
        backdrop-filter: blur(16px);
        border-radius: 12px;
        padding: 1rem;
        margin-top: 0.5rem;
        border: 1px solid rgba(107,191,71,0.15);
      }

      .nav-link { padding: 0.65rem 0.5rem !important; border-bottom: 1px solid rgba(107,191,71,0.08); }
      .nav-link:last-of-type { border-bottom: none; }

      .btn-cotizar-nav { width: 100%; text-align: center; margin-top: 0.5rem; }

      .mat-photo { height: 250px; }
      .porq-photo { height: 280px; }

      .footer-links { justify-content: center !important; flex-wrap: wrap; gap: 0.5rem !important; }
    }

    @media (min-width: 992px) {
      .servicio-card-fade { padding: 0 2rem 2rem; }
    }

    #nosotros-hero {
      min-height: 52vh;
      display: flex;
      align-items: flex-end;
      padding: 120px 0 64px;
      position: relative;
    }

    .nosotros-hero-bg {
      position: absolute;
      inset: 0;
      background:
        linear-gradient(175deg, rgba(13,31,14,0.78) 50%, rgba(13,31,14,0.95) 100%),
        url('img/nosotros1.webp')
        center/cover no-repeat;
      z-index: 0;
    }

    .nosotros-hero-bg::after {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(ellipse 50% 80% at 80% 40%, rgba(58,125,44,0.14) 0%, transparent 70%);
    }

    .nosotros-hero-content {
      position: relative;
      z-index: 1;
    }

    .nosotros-hero-content h1 {
      font-size: clamp(2.2rem, 5.5vw, 4.2rem);
      font-weight: 800;
      letter-spacing: -0.03em;
      line-height: 1.08;
      color: var(--blanco);
      margin-bottom: 1rem;
    }

    .nosotros-hero-content h1 span { color: var(--verde-acento); }

    .nosotros-hero-content p {
      font-size: 1.05rem;
      color: var(--gris-text);
      font-weight: 300;
      max-width: 560px;
      line-height: 1.7;
    }

    /* Breadcrumb minimalista */
    .nosotros-breadcrumb {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      font-size: 0.78rem;
      font-weight: 500;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--gris-text);
      margin-bottom: 1.5rem;
    }

    .nosotros-breadcrumb a { color: var(--verde-acento); transition: opacity var(--transition); }
    .nosotros-breadcrumb a:hover { opacity: 0.75; }
    .nosotros-breadcrumb i { font-size: 0.6rem; color: rgba(255,255,255,0.25); }

    /* ── Sección identidad (párrafo quiénes somos) ─────────────── */
    #identidad {
      background: var(--negro);
      padding: 80px 0;
      position: relative;
    }

    #identidad::before {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 1px;
      background: linear-gradient(90deg, transparent, rgba(107,191,71,0.3), transparent);
    }

    .identidad-foto {
      width: 100%;
      height: 400px;
      object-fit: cover;
      border-radius: var(--radius-card);
      filter: brightness(0.8) saturate(1.1);
      box-shadow: 0 24px 64px rgba(0,0,0,0.5);
    }

    .identidad-texto h2 {
      font-size: clamp(1.7rem, 3.5vw, 2.6rem);
      font-weight: 700;
      letter-spacing: -0.02em;
      margin-bottom: 1rem;
    }

    .identidad-texto p {
      font-size: 1rem;
      color: var(--gris-text);
      font-weight: 300;
      line-height: 1.75;
      margin-bottom: 0;
    }

    /* ── Misión / Visión ───────────────────────────────────────── */
    #mision-vision {
      background: var(--verde-dark);
      padding: 80px 0;
      position: relative;
    }

    #mision-vision::before {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 1px;
      background: linear-gradient(90deg, transparent, rgba(107,191,71,0.2), transparent);
    }

    .mv-card {
      background: rgba(27,77,31,0.14);
      border: 1px solid rgba(107,191,71,0.14);
      border-radius: var(--radius-card);
      padding: 2.5rem 2rem;
      height: 100%;
      position: relative;
      overflow: hidden;
      transition: border-color var(--transition), background var(--transition);
    }

    .mv-card:hover {
      background: rgba(27,77,31,0.26);
      border-color: rgba(107,191,71,0.35);
    }

    /* Acento de línea superior en cada card */
    .mv-card::before {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 3px;
      border-radius: var(--radius-card) var(--radius-card) 0 0;
    }

    .mv-card.mision::before { background: var(--verde-acento); }
    .mv-card.vision::before  { background: var(--verde-mid); }

    .mv-label {
      display: inline-flex;
      align-items: center;
      gap: 0.5rem;
      font-size: 0.72rem;
      font-weight: 700;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      color: var(--verde-acento);
      margin-bottom: 1.25rem;
    }

    .mv-label i { font-size: 1rem; }

    .mv-card h3 {
      font-size: 1.55rem;
      font-weight: 700;
      letter-spacing: -0.02em;
      color: var(--blanco);
      margin-bottom: 1rem;
    }

    .mv-card p {
      font-size: 0.95rem;
      color: var(--gris-text);
      font-weight: 300;
      line-height: 1.75;
      margin-bottom: 0;
    }

    /* ── CTA de cierre ─────────────────────────────────────────── */
    #nosotros-cta {
      background: var(--negro);
      padding: 80px 0;
      text-align: center;
      position: relative;
    }

    #nosotros-cta::before {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 1px;
      background: linear-gradient(90deg, transparent, rgba(107,191,71,0.25), transparent);
    }

    .cta-tagline {
      font-size: clamp(1.5rem, 3.5vw, 2.4rem);
      font-weight: 700;
      letter-spacing: -0.02em;
      color: var(--blanco);
      margin-bottom: 0.75rem;
    }

    .cta-tagline span { color: var(--verde-acento); }

    .cta-sub {
      font-size: 1rem;
      color: var(--gris-text);
      font-weight: 300;
      max-width: 480px;
      margin: 0 auto 2rem;
      line-height: 1.7;
    }

    /* ── Responsive exclusivo de esta página ───────────────────── */
    @media (max-width: 767.98px) {
      #nosotros-hero { min-height: 44vh; padding: 130px 0 48px; }
      .identidad-foto { height: 260px; }
      .mv-card { padding: 2rem 1.5rem; }
    }

    @media (min-width:576px)
    .modal-sm {
    --bs-modal-width: 600px!important;
    }
    .modal{
      z-index: 10000!important;
    }

    .cintillo-wrap{
  overflow:hidden;
  width:100%;
  background:var(--negro);
  border-top:1px solid rgba(107,191,71,0.15);
  border-bottom:1px solid rgba(107,191,71,0.15);
  padding:14px 0;
}
.cintillo-track{
  display:flex;
  width:max-content;
  animation:cintillo-scroll 22s linear infinite;
}
.cintillo-item{
  display:flex;
  align-items:center;
  gap:8px;
  font-family:var(--font-display);
  font-size:1rem;
  font-weight:700;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--verde-acento);
  white-space:nowrap;
  padding:0 32px;
  border-right:1px solid rgba(107,191,71,0.2);
}
@keyframes cintillo-scroll{
  from{ transform:translateX(0); }
  to{ transform:translateX(-50%); }
}
@media (prefers-reduced-motion:reduce){
  .cintillo-track{ animation:none; }
}