







/************ Ajuste ancho máximo de la web ***********************/ 

/************************** Header **************************************/  
#headerwrap {
    position: fixed !important;
}

#header {
    padding-inline: clamp(1em, 5vw, 5em) !important;
}

/************************** Botones de medición *************************/ 

@media screen and (min-width: 500px) {
.desktop {display: inline;}
.movil {display: none;}
    }

@media screen and (max-width: 499px) {
    #header {
        padding-inline: 1em !important;
    }
.desktop {display: none;}
.movil {display: inline;}
.container-contact  {
    -webkit-box-orient: vertical !important;
    -webkit-box-direction: normal !important;
    -webkit-flex-direction: column !important;
        -ms-flex-direction: column !important;
            flex-direction: column !important;
}
    }

.boton {
    background-color: white;
    color: #B6B6B6;
    border-radius: 0 !important;
    width: 100%;
    font-weight: 300 !important;
    text-transform: none !important;
}



.container-contact {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-flex: 1;
    -webkit-flex: 1;
        -ms-flex: 1;
            flex: 1;
    gap: 10px;
}


/** Mosaico Home ****/ 
.mosaic-grid{
  --mosaic-gap:16px;
  --mosaic-cols:4;
  display:grid;
  grid-template-columns:repeat(var(--mosaic-cols),1fr);
  gap:var(--mosaic-gap);
  width:100%;
  background:transparent;
}

.mosaic-grid .cell{
  position:relative;
  aspect-ratio:1/1;
  overflow:hidden;
  background:transparent;
}

.mosaic-grid .media{
  position:absolute;
  inset:0;
  opacity:0;
  -webkit-transition:opacity .6s ease-in-out;
  transition:opacity .6s ease-in-out; /* más suave */
}

.mosaic-grid .media.in{
  opacity:1;
}

.mosaic-grid .media.out{
  opacity:0;
}

.mosaic-grid img,
.mosaic-grid video{
  width:100%;
  height:100%;
  -o-object-fit:cover;
     object-fit:cover;
  display:block;
}

/* Por si el JS no llegara a ejecutar, tenemos el fallback en CSS */
@media (max-width: 768px){
  .mosaic-grid{
    grid-template-columns:repeat(3,1fr);
    gap:4px; /* estilo IG */
  }
}

/* ===== Tarjeta estilo fijo — versión final (igual al diseño original del slider) ===== */
.tattoo-card{
  position:relative !important;
  --label-w:68px;                 /* ancho de la franja blanca */
  --label-color:#8e8e8e;          /* tono gris del texto */
}

/* Tarjeta base limpia */
.tattoo-card a.style-card{
  position:relative !important;
  display:block !important;
  background:#fff !important;
  overflow:hidden !important;
  border:0 !important;
  -webkit-box-shadow:none !important;
          box-shadow:none !important;
  text-decoration:none !important;
  color:inherit !important;
  margin:0 !important;
  padding:0 !important;
}

/* Imagen: desplazada para dejar el espacio de la franja */
.tattoo-card a.style-card > img{
  display:block !important;
  width:100% !important;
  height:540px !important;                /* igual que el slider */
  -o-object-fit:cover !important;
     object-fit:cover !important;
  -o-object-position:center !important;
     object-position:center !important;
  -webkit-transform:translateX(var(--label-w)) !important;
      -ms-transform:translateX(var(--label-w)) !important;
          transform:translateX(var(--label-w)) !important;
  -webkit-transition:-webkit-transform .4s ease !important;
  transition:-webkit-transform .4s ease !important;
  transition:transform .4s ease !important;
  transition:transform .4s ease, -webkit-transform .4s ease !important;
}

/* Franja blanca con texto vertical centrado (exactamente como el slider) */
.tattoo-card .style-label{
  position:absolute !important;
  left:0 !important;
  top:0 !important;
  bottom:0 !important;
  width:var(--label-w) !important;
  display:-webkit-box !important;
  display:-webkit-flex !important;
  display:-ms-flexbox !important;
  display:flex !important;
  -webkit-box-align:center !important;
  -webkit-align-items:center !important;
      -ms-flex-align:center !important;
          align-items:center !important;          /* centrado vertical */
  -webkit-box-pack:start !important;
  -webkit-justify-content:flex-start !important;
      -ms-flex-pack:start !important;
          justify-content:flex-start !important;  /* texto pegado al borde izquierdo de la franja */
  background:#fff !important;
  color:var(--label-color) !important;
  font-family:'Helvetica Neue', Helvetica, Arial, sans-serif !important;
  font-weight:600 !important;
  font-size:18px !important;              /* más grande, como en el original */
  letter-spacing:0.03em !important;
  -webkit-writing-mode:vertical-rl !important;
      -ms-writing-mode:tb-rl !important;
          writing-mode:vertical-rl !important;
  -webkit-transform:rotate(180deg) !important;
      -ms-transform:rotate(180deg) !important;
          transform:rotate(180deg) !important;
  padding-inline:6px !important;          /* deja aire entre texto e imagen */
  pointer-events:none !important;
  -webkit-user-select:none !important;
     -moz-user-select:none !important;
      -ms-user-select:none !important;
          user-select:none !important;
  text-transform:none !important;
  line-height:1.1 !important;
}

/* Hover sutil */
.tattoo-card a.style-card:hover > img{
  -webkit-transform:translateX(var(--label-w)) scale(1.03) !important;
      -ms-transform:translateX(var(--label-w)) scale(1.03) !important;
          transform:translateX(var(--label-w)) scale(1.03) !important;
}

/* Responsivo */
@media (max-width:1024px){
  .tattoo-card{ --label-w:60px; }
  .tattoo-card a.style-card > img{ height:460px !important; }
  .tattoo-card .style-label{ font-size:16px !important; }
}
@media (max-width:480px){
  .tattoo-card{ --label-w:54px; }
  .tattoo-card a.style-card > img{ height:420px !important; }
  .tattoo-card .style-label{ font-size:15px !important; }
  #menu.legal{
    -webkit-box-orient: vertical !important;
    -webkit-box-direction: normal !important;
    -webkit-flex-direction: column !important;
        -ms-flex-direction: column !important;
            flex-direction: column !important;
  }
}

#menu-legal{
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 20px;
}

/****** footer widget ************/ 
#nav_menu-5 , #block-2, #themify-social-links-4, #nav_menu-6, #block-3 {
    margin: 0 !important;
}


/* ================== BASE / RESET ================== */
.form-contacto,
.form-contacto *,
.form-contacto *::before,
.form-contacto *::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/* Algunos wrappers (CF7/Elementor) traen min-width ~360px */
.form-contacto,
.wpcf7,
.wpcf7-form,
.elementor-widget-container {
  min-width: 0 !important;
  max-width: 100% !important;
}

/* ================== LAYOUT ================== */
.form-contacto {
  position: relative;
  width: 100%;
}

/* 2 columnas en desktop */
.form-contacto.form-2cols {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 16px 28px;
  min-width: 0;
  max-width: 100%;
}

.form-contacto.form-2cols > * {
  min-width: 0;
}

/* 3 columnas para la primera fila */
.form-contacto.form-3cols {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 10px 18px;
}

/* items que ocupan 1/3 */
.form-contacto .third {
  min-width: 0;
}

/* items de ancho completo */
.form-contacto .full,
.form-contacto .legal,
.form-contacto .actions {
  grid-column: 1 / -1;
  text-align: center;
}

/* limpiar márgenes */
.form-contacto p {
  margin: 0;
}

/* ================== LABELS ================== */
.form-contacto .half label {
  position: absolute;
  clip: rect(0 0 0 0);
  -webkit-clip-path: inset(50%);
          clip-path: inset(50%);
  height: 1px;
  width: 1px;
  overflow: hidden;
  white-space: nowrap;
}

.form-contacto .legal label {
  position: static;
  clip: auto;
  -webkit-clip-path: none;
          clip-path: none;
  height: auto;
  width: auto;
}

/* ================== CAMPOS ================== */
.form-contacto input[type="text"],
.form-contacto input[type="email"],
.form-contacto input[type="tel"],
.form-contacto textarea,
.form-contacto select {
  display: block;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  border: 0;
  border-radius: 4px;
  background: #fff;
  min-height: 48px;   /* altura fina */
  padding: 12px 18px;
  -webkit-box-shadow: 0 0 0 1px rgba(0,0,0,.08) inset;
          box-shadow: 0 0 0 1px rgba(0,0,0,.08) inset;
  font-size: 16px;
  line-height: 1.25;
  text-align: left;
}

.form-contacto ::-webkit-input-placeholder {
  color: #bdbdbd;
  font-weight: 600;
}

.form-contacto ::-moz-placeholder {
  color: #bdbdbd;
  font-weight: 600;
}

.form-contacto :-ms-input-placeholder {
  color: #bdbdbd;
  font-weight: 600;
}

.form-contacto ::-ms-input-placeholder {
  color: #bdbdbd;
  font-weight: 600;
}

.form-contacto ::placeholder {
  color: #bdbdbd;
  font-weight: 600;
}

/* TEXTAREA: fino y sin restricciones */
.form-contacto textarea {
  resize: none;        /* OK si vas a usar auto-resize por JS */
  overflow-y: hidden;  /* también OK para auto-resize */
  min-height: 48px;
}


/* ================== FOCUS ================== */
.form-contacto input:focus-visible,
.form-contacto textarea:focus-visible,
.form-contacto select:focus-visible {
  outline: 2px solid #222;
  outline-offset: 2px;
}

/* ================== LÍNEA DIVISORIA ================== */
.form-contacto.form-2cols::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 1px;
  background: rgba(0,0,0,.12);
  pointer-events: none;
}

/* ================== ACEPTACIÓN ================== */
.form-contacto .legal .wpcf7-list-item {
  margin: 0;
}

.form-contacto .legal label {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  color: #fff;
  line-height: 1.35;
  word-break: break-word;
}

.form-contacto .legal input[type="checkbox"] {
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 auto;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 18px;
  height: 18px;
  margin-top: 2px;
}

/* ================== BOTÓN ================== */
.form-contacto .actions {
  text-align: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}

.form-contacto input[type="submit"] {
  display: inline-block;
  border: 0;
  border-radius: 4px;
  padding: 14px 28px;
  background: #1e1e1e;
  color: #fff;
  cursor: pointer;
  font-weight: 600;
  width: 100%;
  max-width: 100%;
}

.form-contacto input[type="submit"]:hover {
  -webkit-filter: brightness(1.05);
          filter: brightness(1.05);
}

.form-contacto input[type="submit"]:active {
  -webkit-transform: translateY(1px);
      -ms-transform: translateY(1px);
          transform: translateY(1px);
}

/* ================== RESPONSIVE ================== */
@media (max-width: 640px) {
  /* Todas las variantes de columnas pasan a 1 sola columna */
  .form-contacto.form-2cols,
  .form-contacto.form-3cols {
    grid-template-columns: minmax(0, 1fr);
    gap: 14px;
  }

  /* Quitamos la línea vertical de separación en 2 columnas */
  .form-contacto.form-2cols::before {
    display: none;
  }

  /* Un poco de respiro lateral en móvil */
  .form-contacto {
    padding-left: 16px;
    padding-right: 16px;
  }
}
/* ====== FLIP (Themify Ultra) ====== */
.flip1, .flip2, .flip3, .flip4, .flip5{
  -webkit-perspective:1000px;
          perspective:1000px;
}

/* El Row en Themify suele ser .module_row */
.flip1.module_row, .flip2.module_row, .flip3.module_row, .flip4.module_row, .flip5.module_row{
  position:relative;
}

/* Contenedor que rotamos */
.flip1 .row_inner, .flip2 .row_inner, .flip3 .row_inner, .flip4 .row_inner, .flip5 .row_inner{
  position:relative;
  -webkit-transform-style:preserve-3d;
          transform-style:preserve-3d;
  -webkit-transition:-webkit-transform .65s ease;
  transition:-webkit-transform .65s ease;
  transition:transform .65s ease;
  transition:transform .65s ease, -webkit-transform .65s ease;
  min-height:220px;
}

/* Activa el giro */
.flip1:hover .row_inner, .flip2:hover .row_inner, .flip3:hover .row_inner, .flip4:hover .row_inner, .flip5:hover .row_inner{
  -webkit-transform:rotateY(180deg);
          transform:rotateY(180deg);
}

/* Las dos caras (tus dos Text Modules) */
.flip1 .flip-front, .flip2 .flip-front, .flip3 .flip-front, .flip4 .flip-front, .flip5 .flip-front,
.flip1 .flip-back,  .flip2 .flip-back,  .flip3 .flip-back,  .flip4 .flip-back,  .flip5 .flip-back{
  position:absolute !important;
  inset:0;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
  display:-webkit-box;
  display:-webkit-flex;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-align:center;
  -webkit-align-items:center;
      -ms-flex-align:center;
          align-items:center;
  -webkit-box-pack:center;
  -webkit-justify-content:center;
      -ms-flex-pack:center;
          justify-content:center;
  padding:30px;
  -webkit-box-sizing:border-box;
          box-sizing:border-box;
}

/* Cara trasera */
.flip1 .flip-back, .flip2 .flip-back, .flip3 .flip-back, .flip4 .flip-back, .flip5 .flip-back{
  -webkit-transform:rotateY(180deg);
          transform:rotateY(180deg);
  background:#111;
  color:#fff;
  text-align:center;
}
