:root{
  --black:#f3f4f7;        /* fondo principal, claro */
  --black-2:#dde0e6;      /* paneles / secciones */
  --red:#ad1510;          /* nuevo rojo Atlantic */
  --yellow:#FFD100;       /* lo dejamos por si lo usas en algo puntual */
  --white:#FFFFFF;
  --muted:#6c6f78;
  --container:1200px;
  --radius:16px;
  --shadow:0 10px 30px rgba(0,0,0,.18);

  /* tonos metálicos */
  --metal:#d0d4dc;
  --metal-soft:rgba(208,212,220,.7);
  --metal-dark:#3c4049;
}

*{box-sizing:border-box}
html,body{height:100%}
html, body { overflow-x: hidden; }

body{
  margin:0;
  font-family:"Urbanist",system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial;
  color:#111217;
  /* fondo metálico claro */
  background:
    radial-gradient(circle at 10% 0%, rgba(173,21,16,.12) 0, transparent 55%),
    linear-gradient(180deg,#f7f8fa 0%,#e3e6ec 50%,#d0d4dc 100%);
  line-height:1.6;
}

/* Utilities */
.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding:0 20px;
}
.center{text-align:center}
.accent{color:var(--red)}
.full{width:100%}

/* highlight ahora con borde plateado y glow rojo suave */
.highlight{
  display:inline-block;
  padding:6px 12px;
  border-left:4px solid var(--metal-dark);
  background:linear-gradient(90deg,rgba(173,21,16,.12),rgba(255,255,255,.9));
  border-radius:10px;
  box-shadow:0 0 0 1px rgba(0,0,0,.03),
             0 10px 30px rgba(0,0,0,.15);
}

/* Header / Nav */
.site-header{
  position:sticky;top:0;z-index:50;
  background:linear-gradient(180deg,#fdfdfe,#e5e8ee);
  backdrop-filter:saturate(1.1) blur(10px);
  border-bottom:1px solid rgba(0,0,0,.06);
  box-shadow:0 8px 24px rgba(0,0,0,.16);
}
.nav-wrap{
  display:flex;align-items:center;justify-content:space-between;
  min-height:70px;gap:20px;
}
.logo{
  display:flex;align-items:center;gap:10px;
  color:#111217;text-decoration:none;font-weight:800;letter-spacing:.3px;
}
.logo svg{color:#111217}
.nav-toggle{
  display:none;flex-direction:column;gap:6px;
  background:transparent;border:0;cursor:pointer
}
.nav-toggle .bar{
  width:26px;height:2px;background:#111217;display:block
}
.nav-menu{
  display:flex;align-items:center;gap:18px;list-style:none;margin:0;padding:0
}
.nav-menu a{
  color:#111217;text-decoration:none;font-weight:700;opacity:.95;
  letter-spacing:.03em;
}
.nav-menu a:hover{
  color:var(--red);
}

/* Mantener texto blanco en el botón rojo del header */
.nav-menu .pill-red:hover {
  color: #fff !important;
}

.nav-menu .pill{
  border:1px solid var(--metal-soft);
  padding:8px 12px;border-radius:999px;
  background:#f5f6fa;
  box-shadow:0 6px 18px rgba(0,0,0,.16);
}
.nav-menu .pill-red{
  border-color:transparent;
  background:linear-gradient(120deg,#c24331,var(--red));
  color:#fff;
  box-shadow:0 10px 24px rgba(173,21,16,.45);
}
.nav-menu .divider{width:1px;height:22px;background:#b8bcc4}

/* Hero */

/* Contenido */
/* Hero */
.hero{
  position:relative;
  min-height:78vh;
  display:grid;
  place-items:center;
  isolation:isolate;
}

/* Imagen limpia */
.hero-media{
  position:absolute;
  inset:0;
  z-index:-2;
  background:url("img/hero7.webp") center/cover no-repeat fixed;
  /* Ajustes para más claridad */
  filter:
    brightness(1.25)
    saturate(1.15)
    contrast(1.05);
}

/* SIN overlay */
.hero-overlay{
  display:none !important;
}

/* Contenido */
.hero-inner{
  text-align:center;
  max-width:900px;
  padding:80px 0 60px;
}

.hero h1{
  font-size:clamp(2rem,4.2vw,3.5rem);
  line-height:1.1;
  margin:0 0 10px;
  font-weight:800;
  text-shadow:0 6px 22px rgba(0,0,0,.35);
  color:#ffffff;
}

.hero p{
  font-size:clamp(1rem,1.6vw,1.25rem);
  color:#ffffff;
  margin:0 auto 24px;
  max-width:780px;
}

.hero-cta{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
}

.hero-badges{
  margin-top:18px;
  display:flex;
  gap:10px;
  justify-content:center;
  flex-wrap:wrap;
}

.hero-badges span{
  border:1px solid var(--metal-soft);
  background:rgba(255,255,255,.9);
  padding:6px 10px;
  border-radius:999px;
  color:#111217;
  font-size:.9rem;
  box-shadow:0 4px 16px rgba(0,0,0,.18);
}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:10px;padding:12px 20px;border-radius:12px;font-weight:800;text-decoration:none;
  border:1px solid var(--metal-soft);
  background:#f2f3f7;color:#111217;transition:.25s;
  box-shadow:0 8px 18px rgba(0,0,0,.18);
}
.btn:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 28px rgba(0,0,0,.25);
}
.btn-red{
  background:linear-gradient(120deg,#c24331,var(--red));
  border-color:transparent;
  color:#fff;
  box-shadow:0 14px 32px rgba(173,21,16,.55);
}
.btn-outline{
  background:#ffffff;
  border-color:var(--metal-soft);
  color:#111217;
}

/* Strips / Sections */
.strip{
  background:#e4e6ec;
  border-block:1px solid rgba(0,0,0,.04);
}
/* ===== STRIP ITEMS PREMIUM ===== */
.strip-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  padding: 18px 0;
}

.strip-grid > div {
  background: rgba(255,255,255,0.95); /* fondo metálico claro */
  border: 1px solid rgba(182,184,190,0.9); /* borde plateado */
  border-radius: 14px;
  padding: 12px 14px;
  box-shadow: 0 4px 14px rgba(0,0,0,0.16);
  backdrop-filter: blur(4px) saturate(1.2);
}

/* TITULO: Phone, Email... */
.strip-grid strong {
  display: block;
  font-size: 0.92rem;
  color: #444854;
  margin-bottom: 4px;
  letter-spacing: .3px;
  text-transform: uppercase;
  opacity: 0.9;
}

/* CONTENIDO: el valor */
.strip-grid a,
.strip-grid div {
  font-size: 1.05rem;
  color: #111217;
  font-weight: 600;
  text-decoration: none;
}

.strip-grid a:hover {
  color: var(--red);
}

.section{
  padding:70px 0;
  border-top:1px solid rgba(0,0,0,.03);
  border-bottom:1px solid rgba(0,0,0,.03);
  background:linear-gradient(180deg,#f5f6f9,#dde0e7);
}
.section.alt{
  background:#e4e6ee;
}
.section-title{
  font-size:clamp(1.6rem,3vw,2.2rem);margin:0 0 10px;font-weight:800;color:#111217;
}
.section-sub{
  color:#555965;
  margin:0 auto 30px;
  max-width:720px;
}

/* Two columns */
.two-col{display:grid;grid-template-columns:1.1fr .9fr;gap:34px;align-items:center}
.two-col .media img{
  width:100%;height:auto;border-radius:var(--radius);
  box-shadow:var(--shadow);
  border:1px solid var(--metal-soft);
  background:#f3f4f7;
}

/* About */
.checklist{list-style:none;margin:18px 0 0;padding:0;display:grid;gap:8px}
.checklist li{
  position:relative;padding-left:28px;color:#2a2e37;
}
.checklist li::before{
  content:"";
  position:absolute;
  left:0;
  top:9px;
  width:12px;
  height:12px;
  border-radius:50%;
  background: var(--red);
  box-shadow:0 0 12px rgba(173,21,16,.6);
}

.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}

/* Services */
.cards{
  display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:24px
}
.card{
  position:relative;
  background:linear-gradient(180deg,#fdfdfe 0%,#e4e6ee 100%);
  border:1px solid var(--metal-soft);
  border-radius:18px;overflow:hidden;box-shadow:var(--shadow);
  transform:translateY(10px);opacity:0;transition:transform .6s ease,opacity .6s ease,box-shadow .3s ease,border .3s ease;
}
.card::before{
  content:"";
  position:absolute;inset:0;
  border-radius:18px;
  pointer-events:none;
  border-top:1px solid rgba(255,255,255,.7);
  border-bottom:1px solid rgba(0,0,0,.08);
}
.card.reveal.in{transform:translateY(0);opacity:1}
.card:hover{
  box-shadow:0 18px 40px rgba(0,0,0,.24);
  border-color:rgba(173,21,16,.8);
}
.card-media img{
  display:block;width:100%;height:200px;object-fit:cover;
  filter:saturate(1.1) contrast(1.05) brightness(1.05);
}
.card-body{padding:18px}
.card-body h3{margin:0 0 8px;font-size:1.2rem;color:#111217;}
.card-body p{margin:0 0 10px;color:#424650}
.mini-list{list-style:none;margin:0;padding:0;display:grid;gap:6px;color:#4e5260}

/* Banner */
.banner{position:relative;isolation:isolate;text-align:center}
.banner-media{
  position:absolute;inset:0;z-index:-2;
  background:url("img/about.webp") center/cover no-repeat fixed
}
.banner-overlay{
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(circle at 15% 0%,rgba(173,21,16,.35),transparent 60%),
    linear-gradient(0deg, rgba(250,250,252,.94), rgba(236,238,243,.9));
}
.banner-inner{padding:70px 0}
.banner h3{margin:0 0 6px;font-size:clamp(1.4rem,2.8vw,2rem);color:#111217;}
.banner p{margin:0;color:#555965}

/* Contact (info only) */
.contact-list{list-style:none;margin:14px 0 20px;padding:0;display:grid;gap:6px}
.contact-list a{color:#111217;text-decoration:none;border-bottom:1px dotted transparent}
.contact-list a:hover{border-bottom-color:var(--red)}
.map-wrap{
  margin-top:14px;
  border-radius:14px;overflow:hidden;
  border:1px solid var(--metal-soft);
  box-shadow:0 14px 32px rgba(0,0,0,.2);
  background:#f3f4f7;
}
.map-wrap iframe{width:100%;height:260px;border:0}

/* Footer */
.site-footer{
  background:#e1e3ea;
  border-top:1px solid rgba(0,0,0,.06);
  box-shadow:0 -10px 30px rgba(0,0,0,.12);
}
.footer-grid{
  display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:24px;padding:34px 0
}
.footer-brand .logo{font-weight:800;text-decoration:none;color:#111217}
.footer-brand .tagline{color:#4a4e5a;margin-top:6px}
.footer-nav ul, .footer-contact ul{
  list-style:none;margin:10px 0 0;padding:0;display:grid;gap:8px
}
.footer-nav a, .footer-contact a{color:#111217;text-decoration:none;opacity:.95}
.footer-nav a:hover, .footer-contact a:hover{color:var(--red)}
.socials{display:flex;gap:10px;margin-top:8px}
.social{
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:10px;
  background:#f7f8fb;
  border:1px solid var(--metal-soft);
  text-decoration:none;color:#111217;
}
.social:hover{background:#ffffff;border-color:var(--red);color:var(--red);}
.footer-bottom{
  border-top:1px solid rgba(0,0,0,.06);
  background:#d5d8e0;
}
.footer-bottom small{
  display:block;padding:12px 0;color:#4f535f
}

/* Logo size tweaks */
.logo-img {
  height: 40px;
  width: auto;
  display: inline-block;
  vertical-align: middle;
  filter: brightness(1.05) contrast(1.1);
}
.site-header .logo-img { height: 44px;margin-right: 8px; }
.site-footer .logo-img {
  height: 36px;
  margin-right: 8px;
  opacity: 0.95;
}

/* Footer mobile centering */
@media (max-width: 820px) {
  .footer-grid {
    grid-template-columns: 1fr;
    text-align: center;
    justify-items: center;
    gap: 28px;
  }
  .footer-brand,
  .footer-nav,
  .footer-contact { width: 100%; }
  .footer-nav ul,
  .footer-contact ul { align-items: center; }
  .socials { justify-content: center; }

  .footer-brand {
    display:flex;flex-direction:column;align-items:center;justify-content:center;
  }
  .footer-brand .logo{
    display:flex;align-items:center;justify-content:center;
  }
  .footer-brand .logo-img{
    display:block;margin:0 auto;
  }
}

/* Nav mobile tweaks */
@media (max-width: 820px){
  .two-col{grid-template-columns:1fr;gap:22px}
  .two-col .media{order:-1}
  .nav-toggle{display:flex}
  .nav-menu{
    position:absolute;right:20px;top:70px;flex-direction:column;align-items:flex-start;
    background:#f5f6fa;border:1px solid var(--metal-soft);border-radius:14px;padding:12px;gap:10px;
    width:min(92vw,360px);display:none;
    box-shadow:0 18px 40px rgba(0,0,0,.22);
  }
  .nav-menu.show{display:flex}
  .nav-menu .divider{display:none}

  .nav-menu li { width: 100%; }
  .nav-menu li + li { margin-top: 8px; }
  .nav-menu .pill {
    display:block;width:100%;text-align:center;padding:10px 14px;
  }
  .nav-menu .pill + .pill { margin-top: 8px; }
}


/* Cards / grids responsive */
@media (max-width: 1024px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .strip-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 560px){
  .cards{grid-template-columns:1fr}
  .hero-badges{gap:8px}
}

/* RESPONSIVE */
@media (max-width: 820px) {
  .strip-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 560px) {
  .strip-grid {
    grid-template-columns: 1fr;
  }
}

/* Services page tweaks, testimonials, gallery, etc. */

.hero-slim {
  min-height: 74vh;
}

.faq { display:grid; gap:10px; margin-top:10px; }
.faq details{
  background:#f5f6fa;
  border:1px solid var(--metal-soft);
  border-radius:14px; padding:12px;
  color:#111217;
}
.faq summary{ cursor:pointer; font-weight:700; }

.testimonials{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:18px; margin-top:14px;
}
.testimonials blockquote{
  margin:0; padding:18px; border-radius:16px;
  background:#f5f6fa;
  border:1px solid var(--metal-soft);
  box-shadow:var(--shadow);
  color:#111217;
}
@media (max-width:1024px){ .testimonials{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .testimonials{ grid-template-columns:1fr; } }

.section .col.media img {
  width: 100%;
  height: 360px;
  object-fit: cover;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border:1px solid var(--metal-soft);
}
@media (max-width: 820px) {
  .section .col.media img { height: 280px; }
}

/* About values */
.values{
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 18px;
  margin-top: 14px;
}
.value{
  background:#f5f6fa;
  border:1px solid var(--metal-soft);
  border-radius:16px;
  padding:16px;
  box-shadow:var(--shadow);
  color:#111217;
}
.value h3{ margin:0 0 6px; }

@media (max-width:1024px){
  .values{ grid-template-columns: 1fr 1fr; }
}
@media (max-width:560px){
  .values{ grid-template-columns: 1fr; }
}

/* Gallery Page */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 18px;
  margin-top: 26px;
}
.gallery-grid img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  transition: transform 0.4s ease, filter 0.4s ease, box-shadow 0.4s ease;
  border:1px solid var(--metal-soft);
}
.gallery-grid img:hover {
  transform: scale(1.05);
  filter: brightness(1.15) contrast(1.1) saturate(1.2);
  box-shadow: 0 8px 28px rgba(173, 21, 16, 0.5);
  cursor: pointer;
}
@media (max-width: 768px) {
  .gallery-grid img { height: 180px; }
}

.lang-switch {
    display: flex;
    gap: 8px;
}

.lang-switch button {
    background: #d0d4dc;
    color: #111217;
    border: none;
    padding: 5px 10px;
    cursor: pointer;
    border-radius: 4px;
    font-weight: 600;
}

.lang-switch button:hover {
    background: #ad1510;
    color:#ffffff;
}

.theme-toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:34px;
  border-radius:999px;
  border:1px solid var(--metal-soft);
  background:rgba(0,0,0,.06);
  box-shadow:0 4px 12px rgba(0,0,0,.18);
  cursor:pointer;
  font-size:18px;
  line-height:1;
  padding:0;
}
.theme-toggle:hover{
  background:#ffffff;
  border-color:var(--red);
  transform:translateY(-1px);
}
@media (max-width:820px){
  .theme-toggle{
    width:32px;height:32px;
  }
}

