:root{
  --accent:#ff1978;
  --bg:#f6fefb;
  --card:#ffffff;
  --text:#0b0b0b;
  --muted:#6f7777;
  --radius:16px;
  --hero-height:34vh;
  --max-width:920px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,Segoe UI,Roboto,"Helvetica Neue",Arial;
  color:var(--text);
  background:var(--bg);
  display:flex;
  justify-content:center;
  padding:20px 12px;
}

.wrap{width:100%;max-width:none}
header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  width: 100%;
  padding:2px 12px 12px 12px;
}
.brand{display:flex;align-items:center;gap:12px}
.logo{font-weight:800;font-size:38px;letter-spacing:-1px}
a{color:var(--accent);font-weight:bold;text-decoration:none}
.actions{display:flex;gap:12px;align-items:center}
.link-apply{color:var(--accent);font-weight:600;text-decoration:none;font-size:15px}
.lang{background:transparent;border:0;font-size:15px;color:var(--muted);cursor:pointer}

.hero-s {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  margin-top: 6px;
  display: flex;                /* Para centrar vertical y horizontalmente */
  justify-content: center;      /* Centrado horizontal */
  align-items: center;          /* Centrado vertical */
  text-align: center;
  padding: 20px;                /* Espacio dentro del contenedor */
}

.hero-s::before {
  content:"";
  position:absolute;
  inset:0;
  background-image: linear-gradient(90deg, rgba(15,40,56,0.6), rgba(15,40,56,0.35)), url('https://images.unsplash.com/photo-1524504388940-b1c1722653e1?q=80&w=1600&auto=format&fit=crop&ixlib=rb-4.0.3&s=6c6dfb1a2f2a6b6c7d9d85d6a9d8b6e5');
  background-size:cover;
  background-position:center right;
  transform:scale(1.02);
  z-index:0;
}

.hero-content-s {
  position: relative;
  z-index: 1;
  max-width: 720px;
  padding: 20px;       /* Espacio interno para que el texto no toque los bordes */
  box-sizing: border-box;
}

.hero-title-s {
  font-size: clamp(28px, 6vw, 62px);
  line-height: 1.1;
  font-weight: 800;
  color: white;
  margin: 0;
  letter-spacing: -1px;
  text-align: center;
}

.hero {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  margin-top: 6px;
  display: flex;
  justify-content: center; /* centra horizontal */
  align-items: center;     /* centra vertical */
  text-align: center;
  padding: 40px 20px;      /* más espacio arriba y abajo */
  height: auto;            /* será ajustado por JS */
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: 
    linear-gradient(90deg, rgba(15,40,56,0.6), rgba(15,40,56,0.35)),
    url('https://images.unsplash.com/photo-1524504388940-b1c1722653e1?q=80&w=1600&auto=format&fit=crop&ixlib=rb-4.0.3&s=6c6dfb1a2f2a6b6c7d9d85d6a9d8b6e5');
  background-size: cover;
  background-position: center right;
  transform: scale(1.02);
  z-index: 0;
}

.hero-content {
  position: relative;
  z-index: 1;
  max-width: 720px;
  width: 100%;
  padding: 20px;          /* más espacio interno para que no toque los bordes */
  box-sizing: border-box;
}

.hero-title {
  font-size: clamp(28px, 6vw, 62px);
  line-height: 1.2;
  font-weight: 800;
  color: white;
  margin: 0 0 24px 0;     /* más espacio entre título y barra */
  letter-spacing: -1px;
  text-align: center;
}

.search {
  display: flex;
  align-items: center;
  gap: 12px;
  background: rgba(255,255,255,0.95);
  border-radius: 40px;
  padding: 16px 20px;     /* padding interno más cómodo */
  width: 100%;
  max-width: 500px;
  margin: 0 auto;
  box-shadow: 0 6px 18px rgba(8,12,16,0.08);
}

.search svg {
  width: 22px;
  height: 22px;
  flex: 0 0 22px;
  opacity: 0.6;
}

.search input {
  border: 0;
  outline: none;
  font-size: 16px;
  background: transparent;
  color: #0b0b0b;
  width: 100%;
}

.big-section{margin-top:28px;background:var(--bg);padding:22px 4px}
.big-text {font-size: clamp(28px, 6vw, 62px);line-height:1.1;font-weight:800;color:black;letter-spacing:-0.8px;text-align:left;margin:6px 0 40px}

.card {
  background: var(--card);
  border-radius: 16px;
  padding: 22px 18px;
  box-shadow: 0 6px 20px rgba(10,15,20,0.05);
  margin-bottom: 22px;
  text-align: center;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  width: 80%;
  max-width: 100%;
  margin: 0 auto 22px;
}
.card:hover {transform: translateY(-4px);box-shadow:0 8px 24px rgba(10,15,20,0.12)}
.card img {width:75px;height:75px;object-fit:contain;margin-bottom:14px}
.card-title {font-weight:700 !important;font-size:16px !important;margin-bottom:8px !important;color:black;line-height:1.3}
.card-desc {color: var(--muted);font-size:14px !important;line-height:1.2}

.social-icons {display:flex;gap:20px;margin-top:10px}
.icon {
  width:4vh !important;
  height:4vh !important;
  max-width:40px;
  max-height:40px;
  border-radius:50%;
  background-color:#e0e0e0;
  display:flex;
  justify-content:center;
  align-items:center;
  text-decoration:none;
  color:#000;
  font-size: 18px;
  transition: background-color 0.3s,color 0.3s;
}
.icon:hover {background-color:#333;color:#fff}
.facebook, .instagram, .twitter {background-color:black;color:white !important}

.footer {text-align:center;padding:20px;background-color:transparent;font-size:clamp(12px,1.7vw,18px);line-height:1.4}
.footer-links {display:flex;flex-direction:column;align-items:center;gap:15px;margin-bottom:15px}
.footer-row {display:flex;gap:20px;justify-content:center;flex-wrap:wrap}
.footer-row a {text-decoration:none;color:black;transition:color 0.3s}
.footer-row a:hover {color:var(--accent)}
.footer-info {color:black;font-size:clamp(12px,1.5vw,16px);line-height:1.4}

@media(min-width:640px){
  .hero-title{font-size:48px}
  .big-text{font-size:48px}
  .search input{font-size:18px}
}
@media(min-width:726px){
  body{padding:28px}
  .hero{height:26vh}
  .hero-title{font-size:48px}
  .search input{font-size:20px}
}

.error-msg {
  display: block;
  margin: 4px 0 12px;
  font-size: 13px;
  color: red;
}

.lang-dropdown {position:relative;display:inline-block}
.lang-btn {background:transparent;border:1px solid var(--muted);border-radius:12px;padding:6px 12px;cursor:pointer;font-size:14px;color:var(--text);display:flex;align-items:center;gap:6px}
.lang-menu {position:absolute;top:110%;left:0;background:var(--card);border-radius:12px;box-shadow:0 6px 18px rgba(0,0,0,0.1);list-style:none;padding:6px 0;margin:0;display:none;min-width:120px;z-index:10}
.lang-menu li {padding:8px 12px;cursor:pointer;transition:background 0.2s}
.lang-menu li:hover {background:var(--accent);color:white}