:root {
    --color-azul: #003366;
    --color-turquesa: #00a79d;
    --color-dorado: #f0e68c;
    --color-gris: #f4f4f4;
    --color-blanco: #ffffff;
    --color-negro: #333;
    --color-texto: #555;
    --color-turquesa-light: rgba(0, 167, 157, 0.1);
    --color-gris-medio: #e0e0e0;
    
    --shadow-sm: 0 1px 3px rgba(0,0,0,0.1);
    --shadow-md: 0 4px 6px rgba(0,0,0,0.1);
    --shadow-lg: 0 10px 15px rgba(0,0,0,0.1);
    
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 16px;
    --radius-xl: 24px;
    
    --transition: all 0.3s ease;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    font-size: 16px;
}

body {
    font-family: 'Times New Roman';
    font-size: clamp(1.1rem, 1.5vw, 1.3rem);
    color: var(--color-azul);
    background-color: var(--color-blanco);
    line-height: 1.6;
}

img {
    max-width: 100%;
    display: block;
}

/* Tipografía */
h1, h2, h3, h4 {
    font-weight: 800;
    color: var(--color-azul);
    line-height: 1.2;
    margin-bottom: 1rem;
}

h2 {
    font-size: clamp(1.8rem, 5vw, 2.5rem);
    letter-spacing: -0.015em;
}

.body--narrow { 
    max-width: 46ch; 
    margin-inline: auto; 
}

/* Contenedores */
.container { 
    width: min(90%, 1280px);
    margin: 0 auto; 
    padding: 0 1.5rem; 
}

.section { 
    padding: clamp(4rem, 7vw, 6rem) 0; 
}

/* Botones */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--color-azul);
    color: var(--color-blanco);
    font-weight: 700;
    text-decoration: none;
    padding: 0.85rem 1.75rem;
    border-radius: 999px;
    box-shadow: var(--shadow-sm);
    transition: var(--transition);
    border: 2px solid transparent;
    font-size: 1rem;
    gap: 0.5rem;
    cursor: pointer;
}

.btn:hover { 
    transform: translateY(-3px); 
    background: #002b55;
    box-shadow: var(--shadow-lg);
}

/* ===== HERO (fondo ClaudiaDrone + título centrado) ===== */
.hero{
  position: relative;
  padding: 0;
  isolation: isolate;

  /* Imagen de fondo */
  background-image: url('/images/graficos/Ramp.png');
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;

  /* Altura fluida con tope de 800px */
  height: clamp(420px, 60vh, 800px);
  max-height: 800px;

  border-radius: var(--border-radius);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  background-color: #000; /* fallback mientras carga la imagen */
}

/* Overlay para mejorar contraste del texto */
.hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.30) 0%, rgba(0,0,0,.18) 45%, rgba(0,0,0,.35) 100%);
  pointer-events: none;
  z-index: 0;
}

/* Grid mínimo para centrar el contenido vertical y horizontalmente */
.hero .parent{
  display: grid;
  place-items: center; /* centra .div2 en medio */
  height: 100%;
  padding: clamp(1rem, 3vw, 2rem);
}

/* Contenedor del título sobre el overlay */
.hero .div2{
  position: relative;
  z-index: 1;
  text-align: center;
}

/* Título “Services” centrado y legible */
.hero .div2 h1{
  color: var(--color-blanco);
  font-weight: 800;
  letter-spacing: -0.02em;
  font-size: clamp(2.25rem, 7vw, 5rem);
  line-height: 1.1;

  /* Pastilla sutil para contraste */
  padding: .3em .8em;
  border-radius: calc(var(--border-radius) + .25rem);
  /*background: rgba(0,0,0,0.25);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);*/
}

/* Accesibilidad: sin animaciones innecesarias */
@media (prefers-reduced-motion: reduce){
  .hero{ scroll-behavior: auto; }
}


/* ===== Services (6 tarjetas, sin bordes, fondo blanco, hover scale) ===== */
.services{
  padding: clamp(2.5rem, 6vw, 4rem) 0;
  background: var(--color-blanco);
}

/* Título con línea a la derecha (como el ejemplo) */
.services__header{
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 1rem;
  margin-bottom: clamp(1.25rem, 3vw, 2rem);
}
.services__title{
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 800;
  color: var(--color-azul);
  white-space: nowrap;
}
.services__rule{
  height: 1px;
  background: linear-gradient(90deg, rgba(0,0,0,.12), rgba(0,0,0,.06) 60%, transparent);
}

/* Grid de 6, responsivo */
.services__grid{
  display: grid;
  gap: clamp(1rem, 2.5vw, 1.5rem);
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 640px){
  .services__grid{ grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1024px){
  .services__grid{ grid-template-columns: repeat(6, 1fr); }
}

/* Tarjeta clickable (sin borde, fondo blanco) */
.service-card{
  display: block;
  background: var(--color-blanco);
  text-decoration: none;
  border-radius: var(--border-radius);
  overflow: hidden;
  transform: translateZ(0);
  transition: transform .25s ease;
  will-change: transform;
  cursor: pointer;
}
@media (hover:hover){
  .service-card:hover{ transform: scale(1.04); } /* agrandar solo al hover */
}

/* Imagen 16:9 que cubre la tarjeta */
.service-card__media{
  margin: 0;
  aspect-ratio: 16 / 9;
  background: var(--color-gris);
}
.service-card__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

/* Título debajo de la imagen */
.service-card__title{
  margin-top: .65rem;
  color: var(--color-negro);
  font-weight: 700;
  font-size: clamp(1rem, 1.3vw, 1.125rem);
  line-height: 1.35;
}

/* Accesibilidad (teclado) */
.service-card:focus-visible{
  outline: 2px solid var(--color-turquesa);
  outline-offset: 3px;
}

/* Preferencias de reducción de movimiento */
@media (prefers-reduced-motion: reduce){
  .service-card{ transition: none; }
}
