/* Reset some default styles */
body, h1, h2, h3, p {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* Hero section*/
.hero {
    color: #333333;
    word-wrap: break-word;
}

.hero-container {
    background-image: url(static/Fondo2.png);
    margin-top: auto;
    height: 90.6vh;
    background-size: cover;
    background-position: center;
    color: #000000;
    padding: 2.5% 2%; /* Utilizando porcentajes para adaptabilidad */
    display: flex;
    justify-content: space-between;
    align-items: top;
    box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.1);
}

/* Cube, Text-title, Text-content */
.hero h2,
.hero h3,
.hero p {
    position: absolute;
}

.hero h3 {
    font-size: 2.7vw;
    top: 65vh;
    left: 9vw;
}

.hero p {
    font-size: 2vw;
    width: 30vw;
    top: 72vh;
    left: 5.7vw;
}

#cube {
    position: absolute;
    width: 43vw; 
    left: 55vw; 
    top: 5vh;
}

/* Media Query para dispositivos móviles */
@media (max-width: 768px) {
    .hero-container {
        height: 90.6vw;
    }

    .hero h3 {
        top: 65vw;
    }

    .hero p {
        top: 72vw;
    }

    #cube{
      top: 25vh;
      width: 53vw; 
      left: 45vw; 
    }

}

/* Block section (reusable simple content section with text, button and image) */
.block {
    background-color: #ffffff;
    text-align: center;
    padding: 22vh 2%; /* Utilizando porcentajes para adaptabilidad */
    color: #333333;
}

.block-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.block-content {
    flex: 1;
    text-align: center;
}

.block h2 {
    font-size: 4vw;
    margin-bottom: 1.5vh;
}

.block p {
    font-size: 2vw;
    margin-bottom: 3vh;
}

.cta-button {
    display: inline-block;
    background-color: #ed4624;
    color: #ffffff;
    padding: 2.5% 4%; /* Utilizando porcentajes para adaptabilidad */
    text-decoration: none;
    border-radius: 5px;
    font-weight: bold;
    font-size: 2vw;
    transition: background-color 0.3s;
}

.block-image img {
    width: 45vw;
    margin-right: 3vw;
    border-radius: 35vw;
}

/* Media Query para pantallas pequeñas */
@media (max-width: 768px) {
    .block {
        padding: 15vh 2%; /* Ajustar el padding para pantallas pequeñas */
    }

    .block-container {
        margin-top: 5vh; /* Agregar un margen superior en pantallas pequeñas */
        display: flex;
        flex-direction: column; /* Cambiar a columna en pantallas pequeñas */
        align-items: center;
        gap: 6vh;
    }
    

    .cta-button {
        padding: 4% 6%; /* Ajustar el padding del botón para pantallas pequeñas */
        font-size: 3vw; /* Ajustar el tamaño del texto del botón para pantallas pequeñas */
    }

    .block-image img {
        width: 70vw; /* Hacer la imagen ocupar el 100% del ancho en pantallas pequeñas */
        margin-right: 0; /* Eliminar el margen derecho en pantallas pequeñas */
        margin-bottom: 3vh; /* Agregar un margen inferior en pantallas pequeñas */
    }
}





/* Redes sociales */
.red {
    background-color: #ed4624;
    background-size: cover;
    background-position: center;
    text-align: center;
    color: #ffffff;
}

.red h2 {
    font-size: 2.7vw;
    padding-top: 5%;
}

.red-container {
    display: flex;
    flex-direction: line; /* Cambiado a columna en pantallas pequeñas */
    justify-content: left; /* Centrar verticalmente en pantallas pequeñas */
    align-items: center;
    padding: 3% 0; /* Ajuste de espacio en pantallas pequeñas */
}

.red-text {
    text-align: center; /* Alineación de texto centrado */
    padding: 0 5%; /* Ajuste de espacio horizontal */
}

.red-logos {
    display: flex;
    align-items: center;
    justify-content: center; /* Centrar horizontalmente en pantallas pequeñas */
    padding-top: 1%;
}

.red h1 {
    margin: 1vh 0; /* Ajuste de margen en pantallas pequeñas */
}

.red img {
    width: 6vw;
    margin: 1vh 1vw; /* Ajuste de margen entre imágenes en pantallas pequeñas */
}


/* Estilos para pantallas pequeñas */
@media screen and (max-width: 768px) {
    .red h2 {
        font-size: 2em; /* Tamaño del título ajustado para pantallas pequeñas */
    }

    .red-container {
        flex-direction: column; /* Cambiado a columna en pantallas pequeñas */
        padding: 5% 0; /* Ajuste de espacio en pantallas pequeñas */
    }

    .red-text {
        flex: 1;
        text-align: left; /* Alineación de texto en pantallas pequeñas */
    }

    .red-logos {
        flex-direction: line; /* Cambiado a columna en pantallas pequeñas */
        gap: 12%;
    }

    .red h1 {
        margin: 1vh 0; /* Ajuste de margen en pantallas pequeñas */
    }

    .red img {
        width: 8vw; /* Ajuste del tamaño de la imagen en pantallas pequeñas */
        margin: 1vh 0; /* Ajuste de margen en pantallas pequeñas */
    }
}


/* Services section */
.services {
    background-color: #fff;
    padding: 5vh 2%; /* Utilizando porcentajes para adaptabilidad */
}

.services h2 {
    font-size: 1.7em;
    text-align: center;
    color: #333333;
}

.services-container {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(25vw, 1fr));
    gap: 2vw;
    justify-content: center;
    margin-left: 4vw; /* Ajuste del margen */
    margin-right: 4vw; /* Ajuste del margen */
    margin-top: 8vh;
    margin-bottom: 7vh;
}

.service-card {
    background-color: #f0f0f0;
    color: #000;
    border-radius: 1vw 1vw 0.5vw 0.5vw; /* Ajuste de la esquina redonda */
    box-shadow: 0 1vw 2vw rgba(0, 0, 0, 0.1);
    text-align: center;
    transition: transform 0.3s, box-shadow 0.3s;
    height: 110%;
    width: 90%;
    margin: auto;
}

.service-card img {
    width: 100%;
    height: 100%;
    margin-bottom: 1vh;
    margin-top: 0vh;
    object-fit: cover;
    border-radius: 1vw 1vw 0 0; /* 1vw para las esquinas superiores, 0 para las esquinas inferiores */
}


.service-card h3 {
    font-size: 1.7vw;
    margin-bottom: 1.7vh;
    color: #ed4624;
}

.service-card p {
    margin-bottom: 3.2vh;
    word-wrap: break-word;
    width: 90%;
    margin: auto;
    text-align: center;
}

.service-card:hover {
    transform: translateY(-0.5vw);
    box-shadow: 0 1vw 2vw rgba(0, 0, 0, 0.2);
}

/* Estilos para pantallas pequeñas */
@media screen and (max-width: 768px) {
    .services-container {
        grid-template-columns: 1fr; /* Cambia a una columna en pantallas pequeñas */
        gap: 7vh; /* Espacio entre las tarjetas */
        margin-left: 2vw; /* Ajuste del margen */
        margin-right: 2vw; /* Ajuste del margen */
    }

    .service-card {
        width: calc(100% - 30vw); /* Ocupa el 100% del ancho con espacio a los lados */
        margin-bottom: 2vw; /* Espacio entre las tarjetas */
    }

    .service-card h3 {
        font-size: 2em; /* Tamaño del título ajustado */
    }

    .service-card p {
        font-size: 1.2em; /* Tamaño del párrafo ajustado */
    }
}

/* Clients section */
.clients {
    background-color: #ffffff;
    height: 18vh;
    text-align: center;
    padding: 7vh 2%; /* Utilizando porcentajes para adaptabilidad */
    color: #333333;
}

.clients h1,
.clients img {
    position: relative;
}

.clients h2 {
    font-size: 4vw;
}

.clients p {
    font-size: 2vw;
}

.clients img {
    width: 6vw;
    padding-top: 1.5vh;
    margin: 0 1vw;
}











/* ===== TOKENS / BASE ===== */
:root{
  --bg:#ffffff; --ink:#0f172a; --muted:#475569; --line:#e2e8f0;
  --accent:#0e7490; /* cyan-700 */
  --accent-50:#ecfeff; /* cyan-50 */
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Helvetica,Arial,sans-serif}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1120px;margin:0 auto;padding:0 24px}
.section{padding:72px 0}
.section-alt{background:#f8fafc}
h1{font-size:40px;line-height:1.1;margin:12px 0 8px}
h2{font-size:28px;margin:0 0 8px}
.lead{color:var(--muted);margin:6px 0 0}
.meta{color:#64748b;font-size:12px;margin-top:8px}
.center{text-align:center}

/* ===== NAVBAR ===== */
/* .bcc-navbar{
position:sticky;top:0;z-index:1000;
backdrop-filter:blur(6px);
background:rgba(255,255,255,.85);border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 24px}
.brand{display:flex;align-items:center;gap:10px;font-weight:600}
.brand-dot{width:20px;height:20px;border-radius:6px;background:#ed4624}
.nav-links{display:flex;gap:20px}
.nav-cta{display:flex;gap:10px;align-items:center}
.nav-toggle{display:none;border:1px solid var(--line);background:#fff;border-radius:8px;padding:6px 10px;font-size:18px} */

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:12px;padding:12px 16px;font-weight:600;font-size:14px;border:1px solid var(--line)}
.btn-dark{background:#0b1220;color:#fff;border-color:#0b1220}
.btn-dark:hover{background:#111827}
.btn-ghost:hover{background:#f1f5f9}

/* ===== LAYOUT ===== */
/* .container{max-width:1120px;margin:0 auto;padding:0 24px}
.section{padding:72px 0}
.section-alt{background:var(--bg-alt)}
.lead{color:var(--muted);margin:8px 0 0}
.meta{color:#64748b;font-size:12px;margin-top:8px} */

/* ===== NAV ===== */
.navbar{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.9);
  backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line);
  box-shadow: 0 1px 0 var(--line);
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 24px;
}
.logo{ height:36px; }
.nav-links{ display:flex; gap:18px; font-size:14px; }
.nav-actions{ display:flex; gap:10px; }

/* Nav link underline animation + active state */
.nav-links a{
  position:relative; padding:10px 0;
  transition: color .2s ease, opacity .2s ease;
  background-image: linear-gradient(currentColor,currentColor);
  background-size: 0% 2px; background-position: 0 100%; background-repeat: no-repeat;
}
.nav-links a:hover{ color: var(--accent); background-size: 100% 2px; }
.nav-links a.is-active,
.nav-links a[aria-current="page"]{ color: var(--accent); }


/* ===== HERO ===== */
.hero{position:relative;isolation:isolate;overflow:hidden;background:linear-gradient(180deg,var(--accent-50),#fff)}
.hero-grid{display:grid;grid-template-columns:1.2fr .9fr;gap:32px;padding:64px 0}
.eyebrow{color:var(--accent);font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:12px}
.hero .accent{color:var(--accent)}
.sub{color:var(--muted);font-size:18px;margin:10px 0 0}
.hero-cta{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
.hero-media .media-box{
  background:#e2e8f0;border-radius:16px;min-height:260px;display:flex;align-items:center;justify-content:center;color:#94a3b8;font-weight:600
}
.media-caption{font-size:12px;color:#64748b;margin-top:6px}

/* ===== GRIDS / CARDS ===== */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}

.cards .card{border:1px solid var(--line);border-radius:16px;padding:18px;display:block;transition:box-shadow .2s, transform .2s;background:#fff}
.cards .card:hover{box-shadow:0 10px 24px rgba(2,6,23,.08);transform:translateY(-2px)}
.card-thumb{height:110px;background:#eef2f7;border-radius:12px;margin-bottom:12px}
.card-thumb.sm{height:64px; background:#fff}
.card-title{font-weight:600;margin-bottom:4px}
.card-text{color:var(--muted);font-size:14px}
.card-link{margin-top:8px;color:var(--accent);font-size:14px}
.cards-tight .card{padding:16px}

.panel{border:1px solid var(--line);border-radius:16px;padding:20px;background:#fff}
.panel-title{font-weight:600;margin-bottom:12px}
.feature-list{margin:14px 0 0;padding-left:18px}
.feature-list li{margin:6px 0}

/* ===== ROWS ===== */
.row-cta{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
.row-between{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}

/* ===== LOGOS ===== */
.logo-row{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-top:16px}
.logo-box{display:flex;align-items:center;justify-content:center;padding:12px;border:1px solid var(--line);border-radius:12px;background:#fff;box-shadow:0 4px 12px rgba(2,6,23,.08);height:55px}

/* ===== CTA FINAL ===== */
/* .cta-final{background:linear-gradient(180deg,#fff,var(--accent-50))} */

/* ===== FOOTER ===== */
.footer{ border-top:1px solid var(--line); padding:28px 0; background:#fff; }
.foot-inner{ display:flex; justify-content:center; }
.footer p{ color:#64748b; font-size:12px; margin:0; }

/* ===== RESPONSIVE ===== */
@media (max-width: 960px){
  .hero-grid{grid-template-columns:1fr;gap:20px}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:1fr 1fr}
  .grid-2{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 680px){
  .nav-links{display:none}
  .nav-links.open{display:flex;position:absolute;top:56px;left:0;right:0;background:#fff;border-top:1px solid var(--line);padding:12px 24px;gap:16px;flex-direction:column}
  .nav-toggle{display:inline-block}
  h1{font-size:34px}
  .grid-4{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}






/* ===== ALIGN PACK (match MAP-Nano look) ===== */
/* Acento y altura de navbar (fallback) */
:root{
  --accent:#ed4624;
  --accent-50: color-mix(in oklab, var(--accent) 10%, #fff 90%);
  --nav-h:64px;
}
@media (max-width:640px){ :root{ --nav-h:56px; } }

/* HERO: fullscreen + halo + retícula sutil */
.hero{
  position:relative; isolation:isolate; overflow:hidden;
  background: linear-gradient(180deg, var(--accent-50), #fff);
  min-height: calc(100vh - var(--nav-h));
  min-height: calc(100svh - var(--nav-h));
  min-height: calc(100dvh - var(--nav-h));
  display:flex; align-items:center;
  padding-block: clamp(24px, 6vh, 64px);
}
.hero::before{
  content:""; position:absolute; inset:-30% -40%;
  background: radial-gradient(closest-side, color-mix(in oklab, var(--accent) 35%, #fff 65%) 0%, transparent 70%) no-repeat;
  filter: blur(40px); opacity:.35; transform:rotate(0deg); z-index:-2;
  animation: heroHalo 36s linear infinite;
}
.hero::after{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(circle at 1px 1px, rgba(2,6,23,.06) 1px, transparent 0) 0 0 / 22px 22px,
    linear-gradient(to bottom, rgba(2,6,23,.04), rgba(2,6,23,0));
  mix-blend-mode:multiply; z-index:-1; pointer-events:none; opacity:.6;
}
@keyframes heroHalo{ to{ transform: rotate(360deg);} }

/* HERO layout: más peso a la imagen */
.hero-grid{
  display:grid; grid-template-columns: .95fr 1.35fr; 
  gap: clamp(24px, 4vw, 48px); align-items:center; padding:0;
}
.eyebrow{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-weight:700}
.hero .accent{color:var(--accent)}
.sub{color:#475569;font-size: clamp(16px,1.6vw,18px);margin-top:10px}
.hero-cta{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}

/* Hero visual (imagen o placeholder) */
.hero-media{position:relative;display:flex;flex-direction:column;gap:6px;align-items:center;transform: translateX(2%);}
.hero-media img,
.hero-media .media-box{
  width:100%;
  border-radius:22px;
  border:1px solid color-mix(in oklab, var(--line) 90%, #fff 10%);
  background:#fff;
  box-shadow:
    0 40px 80px rgba(2,6,23,.20),
    0 16px 32px rgba(2,6,23,.12),
    inset 0 1px 0 rgba(255,255,255,.55);
  max-height: clamp(520px, 78dvh, 860px);
  height:auto; object-fit:contain;
  min-height: 320px;            /* por si usas media-box sin imagen */
  display:flex; align-items:center; justify-content:center; color:#94a3b8; font-weight:600;
}
.media-caption{font-size:12px;color:#64748b;opacity:.8;margin-top:6px}

/* Cards (hover sutil con acento BCC) */
.cards .card{
  border:1px solid var(--line); border-radius:16px; padding:18px; background:#fff;
  transition: transform .2s cubic-bezier(.22,.61,.36,1), box-shadow .25s ease, border-color .25s ease;
}
.cards .card:hover{
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(2,6,23,.12);
  border-color: rgba(237,70,36,.35);
}
.card-link{
  background-image: linear-gradient(currentColor,currentColor);
  background-size: 0% 2px; background-position:0 100%; background-repeat:no-repeat;
  transition: background-size .25s ease; color:var(--accent);
}
.cards .card:hover .card-link{ background-size: 100% 2px; }

/* Reveal on scroll (opcional) */
.reveal{ opacity:0; transform: translateY(12px); transition: opacity .6s ease, transform .6s ease; }
.reveal.is-visible{ opacity:1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce){
  .reveal, .cards .card{ transition:none!important; transform:none!important; }
}




/* === HERO fullscreen robusto + safe areas === */
.hero-product{
  /* ya usas 100vh/svh/dvh; sumamos safe areas */
  padding-left:  max(24px, env(safe-area-inset-left));
  padding-right: max(24px, env(safe-area-inset-right));
  padding-top:   calc(clamp(24px, 6vh, 64px) + env(safe-area-inset-top)/2);
  padding-bottom: clamp(24px, 6vh, 64px);
  container-type: inline-size; /* activa container queries opcionales */
}

/* === Breakpoints por ancho === */
@media (max-width: 960px){
  .hero-grid{ grid-template-columns: 1fr; gap: 20px; }
  .hero-media{ order: -1; transform: none; } /* imagen primero en móvil */
  .hero-media img{ max-height: clamp(320px, 60svh, 680px); width: 100%; }
  .hero-copy h1{ font-size: clamp(28px, 7vw, 40px); padding-left: 12px; }
  .chip-row{ gap: 6px; }
  .cta-row{ gap: 8px; }
  .btn{ padding: 12px 14px; }
}
@media (max-width: 640px){
  .hero-copy .sub{ font-size: clamp(15px, 4vw, 16px); }
}

/* === Breakpoints por alto === */
@media (max-height: 720px) and (min-width: 961px){
  .hero-product{ padding-block: 24px; }
  .hero-grid{ gap: 24px; }
  .hero-media img{ max-height: 56vh; }
  .hero-copy .sub{ font-size: clamp(14px, 1.4vw, 16px); }
}

@media (max-height: 560px){
  /* evita sensación de aplastamiento: relaja el fullscreen */
  .hero-product{ min-height: auto; padding-block: 24px; }
  .hero-media img{ max-height: 48vh; }
}

/* === Imagen del hero: ratio y prioridad visual === */
.hero-media img{
  /* aspect-ratio: 16 / 10;             ayuda a reservar espacio */
  object-fit: contain;
  width: 100%;
}

/* Activo porque a .hero-product le pusimos container-type: inline-size */
@container (max-width: 880px){
  .hero-grid{ grid-template-columns: 1fr; gap: 18px; }
  .hero-copy h1{ font-size: clamp(28px, 6.5vw, 38px); }
  .hero-media img{ max-height: clamp(300px, 55svh, 600px); }
}
