/*
Theme Name: Monoblend
Template: cassini
Author: Sky Ads Co
Tags: barber,barber shop,beauty,cosmetic,creative,fashion,hair salon,hair salon branch,masonry,multipurpose,photography,portfolio,resort,spa,travel
Version: 1.0.3.1769327434
Updated: 2026-01-25 08:50:34

*/

/* HINT */
.mb-hair-hint{
  margin:10px 0 12px;
  font-size:14px;
  opacity:.78;
}

/* GRID: 5 kolumn */
.hair-color-grid{
  display:grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap:12px;
  margin-top:10px;
}

@media (max-width: 1000px){
  .hair-color-grid{ grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
@media (max-width: 760px){
  .hair-color-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 520px){
  .hair-color-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* SWATCH */
.hair-swatch{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:10px;
  border:1px solid rgba(0,0,0,.12);
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  text-align:center;
  transform-origin:center;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}

.hair-swatch:hover{
  transform: scale(1.08);
  z-index:5;
  box-shadow: 0 10px 22px rgba(0,0,0,.12);
  border-color: rgba(0,0,0,.28);
}

.hair-swatch__img{
  width:100%;
  aspect-ratio: 1 / 1;
  object-fit:cover;
  border-radius:10px;
  border:1px solid rgba(0,0,0,.08);
  display:block;
}

.hair-swatch__label{
  font-size:13px;
  font-weight:600;
  opacity:.92;
  line-height:1.2;
  word-break: break-word;
}

/* ACTIVE (wyraźnie) */
.hair-swatch.is-active{
  border-color: rgba(0,0,0,.55);
  box-shadow: 0 0 0 3px rgba(0,0,0,.10);
}

.hair-swatch.is-active::after{
  content:"✓";
  position:absolute;
  top:8px;
  right:8px;
  width:24px;
  height:24px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#111;
  color:#fff;
  font-size:14px;
  line-height:1;
}

/* SELECTED list */
.mb-selected{
  margin-top:14px;
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.mb-selected__empty{
  opacity:.65;
  font-size:14px;
}

.mb-selected__card{
  position:relative;
  width:130px;
  border:1px solid rgba(0,0,0,.12);
  border-radius:12px;
  overflow:hidden;
  background:#fff;
}

.mb-selected__img{
  width:100%;
  aspect-ratio: 1 / 1;
  object-fit:cover;
  display:block;
}

.mb-selected__label{
  padding:8px 10px;
  font-size:13px;
  opacity:.9;
}

.mb-selected__remove{
  position:absolute;
  top:6px;
  left:6px;
  width:26px;
  height:26px;
  border-radius:10px;
  border:1px solid rgba(0,0,0,.15);
  background:rgba(255,255,255,.92);
  cursor:pointer;
  line-height:1;
  font-size:16px;
}

/* CHECKBOX grid 2 kolumny */
.wpcf7 .extras-grid .wpcf7-form-control.wpcf7-checkbox{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px 24px;
}
.wpcf7 .extras-grid .wpcf7-list-item{ margin:0; display:block; }
.wpcf7 .extras-grid .wpcf7-list-item-label{ margin-left:6px; }

/* ===== Formularz CF7 – kafelki jak w sklepie ===== */
.wpcf7 .hair-color-grid{
  display:grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap:28px;                 /* jak siatka produktów */
  margin-top:18px;
  margin-bottom:8px;
}

/* responsywność */
@media (max-width: 1100px){
  .wpcf7 .hair-color-grid{ grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
@media (max-width: 820px){
  .wpcf7 .hair-color-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); gap:18px; }
}
@media (max-width: 560px){
  .wpcf7 .hair-color-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); gap:14px; }
}

/* karta jak produkt */
.wpcf7 .hair-swatch{
  position:relative;
  display:block;
  padding:0;
  border:0;
  background:transparent;
  cursor:pointer;
  text-align:left;
  transform-origin:center;
  transition: transform .14s ease, box-shadow .14s ease;
}

/* “frame” jak w loop: jasne tło, marginesy */
.wpcf7 .hair-swatch{
  border-radius:0; /* w sklepie często jest kanciasto */
}

/* wewnętrzny “box” jak produkt */
.wpcf7 .hair-swatch__img{
  width:100%;
  aspect-ratio: 1 / 1;
  object-fit:cover;
  display:block;

  /* imitacja białego pola wokół zdjęcia (jak w sklepie) */
  background:#f3f3f3;
  border:12px solid #f3f3f3;

  /* delikatna ramka jak thumbnail */
  outline:1px solid rgba(0,0,0,.06);
  outline-offset:-1px;
}

/* podpis jak tytuł produktu */
.wpcf7 .hair-swatch__label{
  margin-top:14px;
  font-size:22px;          /* podobnie do tytułów produktów na screenie */
  line-height:1.05;
  letter-spacing:-0.01em;
  font-weight:500;
  color:inherit;
  opacity:1;
  text-align:left;
}

/* hover jak produkt card */
.wpcf7 .hair-swatch:hover{
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 16px 28px rgba(0,0,0,.08);
}

/* aktywny wybór: obwódka jak “selected” */
.wpcf7 .hair-swatch.is-active{
  box-shadow: 0 0 0 2px rgba(0,0,0,.20);
}

/* check w rogu jak znacznik */
.wpcf7 .hair-swatch.is-active::after{
  content:"✓";
  position:absolute;
  top:10px;
  right:10px;
  width:30px;
  height:30px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#111;
  color:#fff;
  font-size:16px;
  line-height:1;
  box-shadow: 0 8px 18px rgba(0,0,0,.18);
}

/* (opcjonalnie) lekkie przyciemnienie miniatury aktywnej – jak focus */
.wpcf7 .hair-swatch.is-active .hair-swatch__img{
  outline-color: rgba(0,0,0,.18);
}

/* ===== Wybrane kolory pod gridem – też jak produkty ===== */
.wpcf7 .mb-selected{
  margin-top:18px;
  display:flex;
  flex-wrap:wrap;
  gap:18px;
}

.wpcf7 .mb-selected__empty{
  opacity:.7;
  font-size:14px;
}

.wpcf7 .mb-selected__card{
  position:relative;
  width:180px; /* wizualnie jak mini-karta produktu */
  background:transparent;
}

.wpcf7 .mb-selected__img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  display:block;
  background:#f3f3f3;
  border:12px solid #f3f3f3;
  outline:1px solid rgba(0,0,0,.06);
  outline-offset:-1px;
}

.wpcf7 .mb-selected__label{
  margin-top:12px;
  font-size:18px;
  line-height:1.1;
  font-weight:500;
}

.wpcf7 .mb-selected__remove{
  position:absolute;
  top:10px;
  left:10px;
  width:30px;
  height:30px;
  border-radius:999px;
  border:0;
  background:rgba(17,17,17,.92);
  color:#fff;
  cursor:pointer;
  line-height:1;
  font-size:18px;
}

.lakit-hamburger-panel__toggle-icon svg path {
  fill: #fff;
  stroke: #fff;
}

/* =========================================================
   FIX: LAKit Woo Product Gallery – wymuś 1:1 bez skakania
   ========================================================= */

/* 1. Kontener galerii – reset wysokości z JS */
.elementor-lakit-wooproduct-images
.la-woo-product-gallery
.flex-viewport{
  height: auto !important;
  max-height: none !important;
  min-height: 0 !important;
  overflow: hidden !important;
  position: relative !important;
}

/* 2. Tworzymy SZTYWNY KWADRAT */
.elementor-lakit-wooproduct-images
.la-woo-product-gallery
.flex-viewport::before{
  content: "";
  display: block;
  padding-top: 100%; /* 1:1 */
}

/* 3. Wrapper slajdów wypełnia kwadrat */
.elementor-lakit-wooproduct-images
.la-woo-product-gallery
.woocommerce-product-gallery__wrapper{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
}

/* 4. Każdy slajd = 100% wysokości */
.elementor-lakit-wooproduct-images
.la-woo-product-gallery
.woocommerce-product-gallery__image{
  height: 100% !important;
  position: relative !important;
  overflow: hidden !important;
}

/* 5. Obraz wypełnia CAŁĄ powierzchnię */
.elementor-lakit-wooproduct-images
.la-woo-product-gallery
.woocommerce-product-gallery__image img{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  max-width: none !important;
  max-height: none !important;
  display: block !important;
}

/* 6. Miniatury – zostają normalne */
.elementor-lakit-wooproduct-images
.flex-control-thumbs img{
  object-fit: cover;
}


/*Ukrycie elementów w minicart */

.cart-footer-actions {
  display: none !important;
}
.cart-subtotal,
.order-total {
  display: none !important;
}