/* ============================================================
   VOZCORPORATIVA — styles.css (DEPURADO / REORGANIZADO)
   Estructura:
   BASE / LAYOUT / COMPONENTES / UTILIDADES / RESPONSIVE
   ============================================================ */


/* === BLOQUE 01 INICIO: BASE (VARIABLES / RESET / FONDO) === */
:root{
  /* Paleta */
  --bg: #F3F6FA;
  --bg-deep: #EEF3F9;
  --nav: rgba(243,246,250,0.78);
  --hero-glow: rgba(47,111,255,0.18);

  --panel:#ffffff;
  --panel2:#ffffff;

  --text:rgba(15,23,42,0.94);
  --muted:rgba(71,85,105,0.86);
  --muted2:rgba(71,85,105,0.68);

  --line:rgba(15,23,42,0.10);
  --line2:rgba(15,23,42,0.16);
  --focus:rgba(47,111,255,0.55);

  --accent:#2f6fff;
  --accent2:#4aa3ff;

  --sans:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,"Noto Sans","Liberation Sans",sans-serif;

  --container:1120px;

  --topbar-h:52px;
  --footer-h:32px;

  --radius:16px;

  /* desplazamiento horizontal del dibujo */
  --bg-art-shift-x:-140px;
}

*{box-sizing:border-box}

html{
  scroll-behavior:smooth;
  height:100%;
}

body{

  margin:0;
  height:100%;
  overflow:hidden;

  background:#000;

  color:var(--text);
  font-family:var(--sans);
  line-height:1.55;

  position:relative;
  z-index:0;
}

/* ===== FONDO ARTÍSTICO ===== */

body::before{

  content:"";
  position:fixed;
  inset:0;

  z-index:-1;
  pointer-events:none;

  background:

  radial-gradient(
    circle at 50% 45%,
    rgba(255,255,255,0.10) 0%,
    rgba(0,0,0,0.32) 55%,
    rgba(0,0,0,0.70) 100%
  ),

  url("../img/Pedro-Rode.png");

  background-repeat:no-repeat,no-repeat;

  background-position:
  center,
  calc(50% + var(--bg-art-shift-x)) 50%;

  background-size:
  cover,
  contain;

  /* ANTES 0.22 → ahora más visible */
  opacity:0.30;
}

img{
  max-width:100%;
  display:block;
}

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

.container{
  width:min(var(--container),calc(100% - 40px));
  margin:0 auto;
}
/* === BLOQUE 01 FIN: BASE (VARIABLES / RESET / FONDO) === */


/* === BLOQUE 02 INICIO: LAYOUT — TOPBAR (FIJA) === */
.topbar{
  background: #000;
  border-bottom: 1px solid rgba(255,255,255,0.08);

  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--topbar-h);
  z-index: 1000;

  display: flex;
  align-items: center;
}

.topbar__inner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
}

.brand{
  display: flex;

  /* ✅ alinea “Pedro…” y “VOZ CORPORATIVA” en el mismo eje */
  align-items: baseline;

  gap: 10px;
}

.brand__name{
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.4px;
  line-height: 1;

  /* ✅ blanco roto */
  color: rgba(248,244,236,0.92);
}

.brand__tag{
  font-size: 11px;
  letter-spacing: 1px;
  text-transform: uppercase;
  line-height: 1;

  /* ✅ blanco roto (más suave) */
  color: rgba(248,244,236,0.65);
}

.nav{
  display: flex;
  align-items: center;
  gap: 26px;
  height: 100%;
}

.nav__link{
  font-size: 13px;
  letter-spacing: 1.2px;
  text-transform: uppercase;

  /* ✅ blanco roto por defecto */
  color: rgba(248,244,236,0.65);

  display: flex;
  align-items: center;
  height: 100%;
  transition: color 0.2s ease;
}

.nav__link:hover{ color: rgba(248,244,236,0.92); }

.nav__link.is-active{
  color: rgba(248,244,236,0.92);
  font-weight: 500;
}

/* ==========================
   RELOJ TOPBAR (PEQUEÑO + FINO)
   ========================== */
.topbar__clock{
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
  text-align: right;
  line-height: 1.05;
  gap: 2px;
}

.topbar__clockTime{
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.4px;

  /* ✅ blanco roto */
  color: rgba(248,244,236,0.90);

  font-variant-numeric: tabular-nums;
}

.topbar__clockDate{
  font-size: 9px;
  letter-spacing: 0.8px;
  text-transform: uppercase;

  /* ✅ blanco roto suave */
  color: rgba(248,244,236,0.55);
}

/* ✅ PARPADEO DE “:” */
.topbar__clockColon{
  display: inline-block;
  width: 0.55em;
  text-align: center;
  animation: topbarColonBlink 1s steps(1, end) infinite;
}

@keyframes topbarColonBlink{
  0%   { opacity: 1; }
  49%  { opacity: 1; }
  50%  { opacity: 0; }
  100% { opacity: 0; }
}
/* === BLOQUE 02 FIN: LAYOUT — TOPBAR (FIJA) === */

/* === BLOQUE 03 INICIO: LAYOUT — FOOTER (TEXTO SUELTO) + MAIN (ALTURA ÚTIL) === */
.footer{
  position: fixed;
  left: 18px;
  right: auto;
  bottom: 10px;

  height: auto;
  z-index: 1000;

  display: flex;
  align-items: center;
  padding: 0;

  /* ✅ sin “barra” */
  border: 0;
  background: transparent;
}

.footer__inner{
  width: auto;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0;
}

.footer__text{
  font-size: 12px;
  line-height: 1;
  margin: 0;

  /* ✅ blanco roto */
  color: rgba(248,244,236,0.65);
}

/* Si existe enlace “volver arriba”, lo ocultamos en 1-pantalla */
.footer__top{ display: none !important; }

/* ✅ Área útil: ya NO reservamos hueco de footer */
main{
  height: calc(100vh - var(--topbar-h));
  margin-top: var(--topbar-h);
  margin-bottom: 0;
  overflow: hidden;
}
/* === BLOQUE 03 FIN: LAYOUT — FOOTER (TEXTO SUELTO) + MAIN (ALTURA ÚTIL) === */


/* === BLOQUE 04 INICIO: COMPONENTES — HERO (PORTADA) === */

.hero{
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:0;
  color:rgba(248,244,236,0.92);
}

.hero__container{
  max-width:920px;
  margin-top:-70px;
}

/* VOZ PARA COMUNICACIÓN */

.hero__kicker{
  font-size:clamp(18px,2vw,22px);
  letter-spacing:2.4px;
  text-transform:uppercase;
  color:rgba(248,244,236,0.55);
  margin:0 0 18px 0;
}

/* TITULAR */

.hero__headline{
  font-size:clamp(34px,3.6vw,44px);
  line-height:1.08;
  margin:0 0 20px 0;
  text-transform:uppercase;
  letter-spacing:1.6px;
  color:rgba(248,244,236,0.94);
}

/* NOMBRE */

.hero__byline{
  font-size:clamp(22px,2.4vw,28px);
  margin:0 0 24px 0;
  color:rgba(248,244,236,0.78);
  font-weight:500;
}

/* TAGS */

.hero__tags{
  font-size:clamp(16px,1.8vw,20px);
  color:rgba(248,244,236,0.46);
  margin:0 0 36px 0;
}

.hero__actions{
  display:flex;
  justify-content:center;
}

/* ENTRAR — BOTÓN TIPOGRÁFICO */

.btn{

  background:none;
  border:none;

  font-size:14px;

  letter-spacing:3px;

  text-transform:uppercase;

  color:rgba(248,244,236,0.70);

  cursor:pointer;

  padding:8px 10px;

  transition:all .18s ease;
}

.btn:hover{

  color:rgba(248,244,236,0.95);

  letter-spacing:4px;

}

/* === BLOQUE 04 FIN: COMPONENTES — HERO (PORTADA) === */


/* === BLOQUE 05 INICIO: COMPONENTES — MOSAICO (GRID) + TARJETAS BASE === */

.mosaic{
  height: 100%;
  padding: 0;
  display: flex;
  align-items: stretch;
}

.mosaic .container{
  height: 100%;
  display: flex;
  align-items: stretch;
}

.mosaic__grid{
  --mosaic-gap: 14px;

  width: 100%;
  height: 100%;
  display: grid;

  gap: var(--mosaic-gap);
  padding: 14px 0 54px;

  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;

  grid-template-areas:
    "perfil demos"
    "contacto demos";
}

.mosaic__tile{
  position: relative;

  border-radius: 12px;
  border: 1px solid rgba(248,244,236,0.28);

  /* 🔧 FONDO 10% MÁS TRASLÚCIDO */
  background: rgba(248,244,236,0.30);

  backdrop-filter: blur(3px);

  box-shadow: 0 14px 36px rgba(0,0,0,0.26);

  overflow: hidden;

  display:flex;
  flex-direction:column;

  min-height:0;

  transition: transform 220ms ease,
              box-shadow 220ms ease,
              border-color 220ms ease;
}

.mosaic__tile > *{
  position: relative;
  z-index: 1;
}

.mosaic__tile:hover{
  transform: translateY(-2px);
  border-color: rgba(248,244,236,0.42);
  box-shadow: 0 18px 46px rgba(0,0,0,0.30);
}

.mosaic__tile::before{ display:none; }

/* CONTENIDO INTERIOR */

.mosaic__tileInner{

  height:100%;

  min-height:0;

  padding:20px 22px;

  display:flex;
  flex-direction:column;

  gap:12px;

  overflow-y:auto;
  overflow-x:hidden;
}

/* subir ligeramente perfil y demos */

.mosaic__tile--perfil .mosaic__tileInner,
.mosaic__tile--demos  .mosaic__tileInner{
  padding-top:12px;
}

.mosaic__tileInner--tight{
  gap:4px;
}

/* áreas */

.mosaic__tile--perfil{ grid-area: perfil; }
.mosaic__tile--contacto{ grid-area: contacto; }
.mosaic__tile--demos{ grid-area: demos; }

/* demos centrada ocupando altura de una fila */

.mosaic__tile--demos{
  height: calc((100% - var(--mosaic-gap)) / 2);
  align-self: center;
  justify-self: stretch;
}

/* === BLOQUE 05 FIN: COMPONENTES — MOSAICO (GRID) + TARJETAS BASE === */

/* === BLOQUE 06 INICIO: COMPONENTES — TIPOGRAFÍA MOSAICO (CONTRASTE EN 3 VENTANAS) === */

/* Texto base dentro de las tarjetas (Perfil / Demos / Contacto) */
.mosaic__tile{
  color: rgba(255,255,255,0.90);
}

/* Títulos/Kickers (QUIÉN SOY / DEMOS / QUIÉN ERES) */
.mosaic__kicker,
.perfil__title,
.demos__title{
  margin: 0 0 10px 0;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-size: 15px;
  color: rgba(255,255,255,0.95);
}

/* Texto de párrafos en Perfil */
.mosaic__tile--perfil .perfil__text{
  color: rgba(255,255,255,0.90);
}

/* DEMOS: título de cada demo */
.mosaic__tile--demos .demo__title{
  margin: 0 0 8px 0;
  font-weight: 700;
  letter-spacing: .04em;
  color: rgba(255,255,255,0.92);
}

/* CONTACTO: labels en claro */
.mosaic__tile--contacto .field__label{
  color: rgba(255,255,255,0.70);
}

/* CONTACTO: inputs siguen con texto oscuro (porque su fondo es claro) */
.mosaic__tile--contacto .field__input,
.mosaic__tile--contacto .field__textarea,
.mosaic__tile--contacto select.field__input{
  color: rgba(15,23,42,0.92);
}

/* Placeholder algo más suave */
.mosaic__tile--contacto .field__input::placeholder,
.mosaic__tile--contacto .field__textarea::placeholder{
  color: rgba(71,85,105,0.60);
}

/* Contador dentro de consulta */
.mosaic__tile--contacto .consulta-counter{
  color: rgba(255,255,255,0.70);
}

/* ENVIAR tipográfico (si tu botón ya va como texto) */
.mosaic__tile--contacto button[type="submit"]{
  color: rgba(255,255,255,0.55);
}
.mosaic__tile--contacto button[type="submit"]:hover{
  color: rgba(255,255,255,0.92);
}

/* === BLOQUE 06 FIN: COMPONENTES — TIPOGRAFÍA MOSAICO (CONTRASTE EN 3 VENTANAS) === */


/* === BLOQUE 07 INICIO: COMPONENTES — PERFIL (TÍTULO ARRIBA + FOTO + SCROLL) === */
.perfil__wrap{
  display:flex;
  flex-direction:column;
  height:100%;
}

.perfil__header{
  position: sticky;
  top: 0;
  z-index: 2;
  background: transparent;
  padding: 0 0 10px 0;
}

.perfil__scroll{
  overflow: auto;
  flex: 1;
  min-height: 0;
  padding-right: 6px;
}

.perfil__intro{ display: flow-root; }

.perfil__photo{
  float: left;
  width: 120px;
  border-radius: 14px;
  margin: 0 14px 10px 0;
  object-fit: cover;
  background: transparent;
  border: 0;
  box-shadow: 0 12px 26px rgba(0,0,0,0.18);
}

/* TEXTO PERFIL */
.perfil__text{
  font-size: 14px;
  line-height: 1.5;

  /* ✅ blanco suave para contraste */
  color: rgba(255,255,255,0.92);
}

.perfil__text p{ margin: 0 0 10px 0; }

/* === BLOQUE 07 FIN: COMPONENTES — PERFIL (TÍTULO ARRIBA + FOTO + SCROLL) === */


/* === BLOQUE 08 INICIO: COMPONENTES — CONTACTO (GRID + ENVIAR TIPOGRÁFICO) === */

.contact__form{
  padding: 0;
  width: 100%;
}

.mosaic__tile--contacto .form-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:6px 10px;
  align-items:start;
}

.field{ display: grid; gap: 6px; }
.field--full{ grid-column: 1 / -1; }

.field--actions{
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
}

.field__label{
  margin:0 0 3px 0;
  font-size:10.5px;
  letter-spacing:.06em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.70);
}

/* ✅ Inputs menos blancos (crema suave) */
.field__input,
.field__textarea{
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 14px;
  padding: 8px 10px;

  /* antes: rgba(255,255,255,0.85) */
  background: rgba(248,244,236,0.72);

  color: rgba(15,23,42,0.92);
}

.field__input:focus,
.field__textarea:focus{
  outline: 2px solid rgba(255,255,255,0.45);
  outline-offset: 3px;
}

/* Contador */
.mosaic__tile--contacto .field:has(#c_msg){ position: relative; }

.mosaic__tile--contacto textarea#c_msg{
  min-height: 108px;
  resize: none;
  padding-bottom: 26px;
}

.mosaic__tile--contacto .consulta-counter{
  position:absolute;
  left:12px;
  bottom:10px;
  font-size:12px;
  font-weight:600;
  opacity:.85;
  pointer-events:none;
  color: rgba(255,255,255,0.70);
}

/* ENVIAR tipográfico */
.mosaic__tile--contacto .btn,
.mosaic__tile--contacto .btn.btn--primary,
.mosaic__tile--contacto button[type="submit"]{
  background: none !important;
  border: 0 !important;
  box-shadow: none !important;

  padding: 0 !important;
  margin: 0 !important;

  width: auto !important;
  min-width: 0 !important;

  font-size: 12px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;

  color: rgba(255,255,255,0.55) !important;
  cursor: pointer !important;

  transition: color .18s ease, letter-spacing .18s ease !important;
}

.mosaic__tile--contacto .btn:hover,
.mosaic__tile--contacto .btn.btn--primary:hover,
.mosaic__tile--contacto button[type="submit"]:hover{
  color: rgba(255,255,255,0.92) !important;
  letter-spacing: 4px !important;
}

.mosaic__tile--contacto .btn:disabled,
.mosaic__tile--contacto button[type="submit"]:disabled{
  opacity: .45 !important;
  cursor: not-allowed !important;
}

/* === BLOQUE 08 FIN: COMPONENTES — CONTACTO (GRID + ENVIAR TIPOGRÁFICO) === */


/* === BLOQUE 09 INICIO: COMPONENTES — DEMOS (ACORDEONES + REPRODUCTOR CUSTOM, ESTÉTTICA PREMIUM) === */

.demoAccWrap{
display:flex;
flex-direction:column;
gap:8px;
}

.demoAcc{
border:1px solid rgba(255,255,255,0.10);
border-radius:12px;
background:rgba(255,255,255,0.03);
overflow:hidden;
}

/* Cabecera del desplegable */
.demoAcc__sum{
cursor:pointer;
user-select:none;
display:flex;
align-items:center;
justify-content:space-between;
padding:6px 12px;

font-weight:700;
letter-spacing:.05em;
font-size:12px;
line-height:1.15;
text-transform:uppercase;
color:rgba(255,255,255,0.92);

list-style:none;
outline:none;
box-shadow:none;
-webkit-tap-highlight-color:transparent;
background:transparent;
}

.demoAcc__sum::-webkit-details-marker{
display:none;
}

.demoAcc__sum:focus,
.demoAcc__sum:focus-visible{
outline:none !important;
box-shadow:none !important;
}

/* Flecha desplegable */
.demoAcc__sum::after{
content:"▸";
font-size:12px;
line-height:1;
opacity:.8;
transition:transform .15s ease;
}

.demoAcc[open] > .demoAcc__sum::after{
content:"▾";
}

/* Cuerpo desplegable */
.demoAcc__body{
padding:8px 12px 10px;
border-top:1px solid rgba(255,255,255,0.06);
}

.demoAcc__list{
display:flex;
flex-direction:column;
gap:10px;
}

/* Demo individual */
.pDemo{
padding:2px 0 0 0;
border:0;
background:transparent;
}

/* Cabecera demo */
.pDemo__meta{
display:flex;
align-items:baseline;
justify-content:space-between;
gap:12px;
margin-bottom:4px;
}

.pDemo__label{
font-size:12px;
line-height:1.2;
font-weight:600;
letter-spacing:.01em;
color:rgba(255,255,255,0.88);
}

.pDemo__time{
font-size:11px;
line-height:1;
letter-spacing:.03em;
color:rgba(255,255,255,0.62);
white-space:nowrap;
}

.pDemo__sep{
opacity:.45;
padding:0 4px;
}

/* Controles reproductor */
.pDemo__controls{
display:grid;
grid-template-columns:18px 1fr;
align-items:center;
gap:8px;
}

/* Botón play minimal */
.pDemo__play{
width:18px;
height:18px;
padding:0;
border:0;
background:transparent;
color:rgba(255,255,255,0.88);
font-size:11px;
display:flex;
align-items:center;
justify-content:center;
cursor:pointer;
}

.pDemo__play:hover{
color:white;
}

/* Barra premium fina */
.pDemo__seek{
width:100%;
appearance:none;
-webkit-appearance:none;
background:transparent;
outline:none;
}

/* Track */
.pDemo__seek::-webkit-slider-runnable-track{
height:2px;
border-radius:999px;
background:rgba(255,255,255,0.20);
}

.pDemo__seek::-moz-range-track{
height:2px;
border-radius:999px;
background:rgba(255,255,255,0.20);
border:0;
}

/* Thumb */
.pDemo__seek::-webkit-slider-thumb{
-webkit-appearance:none;
width:8px;
height:8px;
margin-top:-3px;
border-radius:50%;
border:0;
background:rgba(255,255,255,0.92);
}

.pDemo__seek::-moz-range-thumb{
width:8px;
height:8px;
border-radius:50%;
border:0;
background:rgba(255,255,255,0.92);
}

/* Audio oculto */
.pAudio{
display:none;
}

/* === BLOQUE 09 FIN: COMPONENTES — DEMOS === */


/* === BLOQUE 10 INICIO: CONTACTO — SELECT CUSTOM ESTILO (TRANSLÚCIDO PREMIUM) === */

.cselect{
position:relative;
}

.cselect__trigger{
width:100%;
display:flex;
align-items:center;
justify-content:space-between;
gap:10px;

background:rgba(248,244,236,0.65);
color:#1a1a1a;
border:1px solid rgba(255,255,255,0.18);

backdrop-filter:blur(6px);

cursor:pointer;
text-align:left;
}

.cselect__trigger:focus{
outline:2px solid rgba(255,255,255,0.45);
outline-offset:3px;
}

.cselect__text{
white-space:nowrap;
overflow:hidden;
text-overflow:ellipsis;
}

.cselect__chevron{
font-size:12px;
opacity:.7;
transition:transform .15s ease;
}

.cselect.is-open .cselect__chevron{
transform:rotate(180deg);
}

.cselect__menu{
position:absolute;
top:calc(100% + 6px);
left:0;
right:0;

display:none;
flex-direction:column;
gap:2px;

padding:6px;
border-radius:12px;

background:rgba(248,244,236,0.55);
border:1px solid rgba(255,255,255,0.22);

backdrop-filter:blur(10px);

box-shadow:0 12px 30px rgba(0,0,0,0.35);
z-index:50;
}

.cselect.is-open .cselect__menu{
display:flex;
}

.cselect__option{
padding:8px 10px;
border-radius:8px;
background:transparent;
border:0;

font-size:14px;
text-align:left;
cursor:pointer;

color:#1a1a1a;
}

.cselect__option:hover{
background:rgba(255,255,255,0.25);
}

.cselect__option.is-selected{
background:rgba(255,255,255,0.35);
font-weight:600;
}


/* === SUBBLOQUE 10B — MENSAJE CONFIRMACIÓN FORMULARIO === */

.contact-feedback{
position:absolute;
inset:0;

display:flex;
align-items:center;
justify-content:center;

background:rgba(0,0,0,0.55);
backdrop-filter:blur(4px);

border-radius:12px;

z-index:20;

opacity:0;
pointer-events:none;
transition:opacity .25s ease;
}

.contact-feedback.is-visible{
opacity:1;
pointer-events:auto;
}

.contact-feedback__box{
max-width:320px;
padding:18px 20px;

border-radius:12px;

background:rgba(248,244,236,0.92);
color:#1a1a1a;

text-align:center;

box-shadow:0 18px 40px rgba(0,0,0,0.35);
}

.contact-feedback__title{
font-size:15px;
font-weight:600;
margin-bottom:6px;
}

.contact-feedback__text{
font-size:13px;
line-height:1.45;
opacity:.85;
}

/* === FIN SUBBLOQUE 10B — MENSAJE CONFIRMACIÓN FORMULARIO === */


/* === BLOQUE 10C INICIO: DEMOS — TEXTO BASE TARJETA === */

.demos__layout{
display:flex;
flex-direction:column;
height:100%;
}

.demos__scroll{
flex:1;
}

.demos__footer{
margin-top:auto;
font-size:13px;
line-height:1.4;
color:rgba(255,255,255,0.75);
}

/* === BLOQUE 10C FIN: DEMOS — TEXTO BASE TARJETA === */

/* === BLOQUE 10 FIN: CONTACTO — SELECT CUSTOM ESTILO === */


/* === BLOQUE 11 INICIO: RESPONSIVE INDEX === */
@media (max-width: 900px){
  .hero{
    min-height: calc(100vh - var(--topbar-h));
    height: auto;
    padding: 0;
    align-items: center;
    justify-content: center;
  }

  .hero__container{
    max-width: 100%;
    padding: 0 18px;
    margin-top: -225px;
  }

  .hero__kicker{
    font-size: clamp(13px, 3.7vw, 15px);
    letter-spacing: 1.7px;
    margin: 0 0 10px 0;
  }

  .hero__headline{
    font-size: clamp(16px, 5.2vw, 22px);
    line-height: 1.04;
    letter-spacing: 0.35px;
    margin: 0 0 10px 0;
  }

  .hero__byline{
    font-size: clamp(16px, 4.8vw, 21px);
    margin: 0 0 12px 0;
  }

  .hero__tags{
    font-size: clamp(12px, 3.6vw, 15px);
    line-height: 1.32;
    margin: 0 0 20px 0;
  }

 body::before{
  background-repeat: no-repeat, no-repeat;
  background-position:
    center,
    75% 45%;
  background-size:
    cover,
    150%;
  opacity: 0.40;
}
}
/* === BLOQUE 11 FIN: RESPONSIVE INDEX === */


/* === BLOQUE 12 INICIO: RESPONSIVE MOSAICO === */
@media (max-width: 900px){
  html,
  body{
    overflow-y: auto;
    overflow-x: hidden;
  }

  main{
    height: auto;
    overflow: visible;
  }

  .mosaic{
    height: auto;
    min-height: auto;
    overflow: visible;
  }

  .mosaic .container{
    height: auto;
    overflow: visible;
  }

  .mosaic__grid{
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    grid-template-areas:
      "perfil"
      "demos"
      "contacto";
    gap: 12px;
    padding: 12px 0 24px;
    height: auto;
  }

  .mosaic__tile--demos,
  .mosaic__tile--perfil,
  .mosaic__tile--contacto{
    height: auto;
    min-height: auto;
    align-self: stretch;
    overflow: visible;
  }

  .footer{
    display: none;
  }
}

@media (max-width: 720px){
  .mosaic__tile--contacto .form-grid{
    grid-template-columns: 1fr;
  }
}
/* === BLOQUE 12 FIN: RESPONSIVE MOSAICO === */