/*
Theme Name: Il Gatto Rosso - Divi Child
Template: Divi
Author: Dusty Sun LLC
Version: 0.1aa
Updated: 2024-12-04
*/


/* Google reCAPTCHA badge */
.grecaptcha-badge {
    visibility: hidden !important;
}

/* Popup */
#popmake-160 {
	max-width: 92%;
}
@media (max-width: 767px) {
	#popmake-160 p {
		font-size: 16px !important;
		padding: 0 !important
	}
}

/* Header */
.header_menu ul {
	list-style: none;
	padding:  0;
	display:  flex;
	flex-direction:  row;
	flex-wrap:  wrap;
	justify-content: space-between;
	align-items: center;
}
.header_menu ul > li {
	padding: 0 5px;
}
@media (max-width: 767px) {
	.header_menu ul > li:nth-child(even) {
		  display: none;
	}
	.header_menu ul {
		  justify-content: space-evenly;
	}
}
/* Footer */
.footer-map-wrapper {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	height: 100%;
}
.footer-map-wrapper p {
	letter-spacing: 2px;
	line-height: 1.5em;
	color: #fff;
}
.footer-map-wrapper p a {
	color: #fff;
	font-style: oblique;
}
.footer-map-wrapper .footer-map {
	flex: 1 1 50%;
}
.footer-map-wrapper .footer-map iframe {
	height: 100%;
	min-height: 400px;
}
@media (min-width: 768px) {
	.footer-map-wrapper .footer-map {
		padding-right: 50px;
	}
}
@media (max-width: 767px) {
	.footer-map-wrapper .footer-map {
		flex: 1 1 100%;
		margin-bottom: 20px;
	}
}
.footer-map-wrapper .footer-hours {
	flex: 0 0 200px;
	display: flex;
	flex-direction: column;
}
.footer-map-wrapper .social-icons {
	margin-top: auto;
	padding-top: 20px;
}
.footer-map-wrapper .social-icons p {
	padding-bottom: 0;
}
.vertical-center .et_pb_column {
    display: flex;
    flex-direction: column;
    justify-content: center;
}
/* Contact Form 7 */
/* Loader */
.wpcf7 form .ajax-loader {
    background: url('data:image/svg+xml;utf8,');
}
/* Submit button */
.wpcf7-submit {
	line-height: 1.7em !important;
    font-size: 24px;
    background-color: #844129;
    color: #ffffff !important;
    font-weight: 700 !important;
    border: none !important;
    text-align: left;
	padding: 0 5px;
    margin-top: 10px;
	width: 100%;
    text-transform: uppercase;
}
.wpcf7-submit:hover {
    background-image: initial!important;
    background-color: #f47d3a!important;
    cursor: pointer;
}
/* input box styling */
.wpcf7-form .wpcf7-date, .wpcf7-form .wpcf7-text, .wpcf7-form .wpcf7-number, .wpcf7-form .wpcf7-textarea, .wpcf7-form .wpcf7-captchar, .wpcf7 .wpcf7-form select {
	background-color: #efecd7a6;
    border: none;
    box-shadow: 1px 1px 3px 1px #0000002e;
    border-bottom:  2px solid #c6c6c6;
    color: #7e402c;
    width: 100%;
    -moz-border-radius: 0 !important;
    -webkit-border-radius: 0 !important;
    border-radius: 0 !important;
    font-size: 20px;
    padding: 10px 8px !important;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-appearance: none;
    display: block;
}
.wpcf7-form .wpcf7-text:focus, .wpcf7-form .wpcf7-number:focus, .wpcf7-form .wpcf7-textarea:focus, .wpcf7-form .wpcf7-captchar:focus {
	color: #7e402c;
}
.wpcf7-form .wpcf7-date::placeholder, .wpcf7-form .wpcf7-text::placeholder, .wpcf7-form .wpcf7-number::placeholder, .wpcf7-form .wpcf7-textarea::placeholder, .wpcf7-form .wpcf7-captchar::placeholder {
	color: #84412a87;
    font-style: oblique
}
.dark-form .wpcf7-form .wpcf7-date, .dark-form .wpcf7-form .wpcf7-text, .dark-form .wpcf7-form .wpcf7-number, .dark-form .wpcf7-form .wpcf7-textarea, .dark-form .wpcf7-form .wpcf7-captchar, .dark-form .wpcf7 .wpcf7-form select {
	background-color: #eaeaea;
	color: #000;
	border: 2px solid #fff;
	padding: 10px 15px !important;
}
.dark-form .wpcf7-form .wpcf7-date::placeholder, .dark-form .wpcf7-form .wpcf7-text::placeholder, .dark-form .wpcf7-form .wpcf7-number::placeholder, .dark-form .wpcf7-form .wpcf7-textarea::placeholder, .dark-form .wpcf7-form .wpcf7-captchar::placeholder {
	color: #333;
}

.wpcf7-form .wpcf7-date {
    padding-top: 14px !important;
    padding-bottom: 14px !important;
}
.wpcf7-form .wpcf7-date:focus,
.wpcf7-form .wpcf7-text:focus,
.wpcf7-form .wpcf7-number:focus,
.wpcf7-form .wpcf7-textarea:focus,
.wpcf7-form .wpcf7-captchar:focus,
.wpcf7-form .wpcf7-select {
    border-bottom: 2px solid #fff !important;
}
/* Select styling */
.wpcf7-form span.ds-wpcf7-select.wpcf7-form-control-wrap {
    display: block;
    padding: 0;
    margin: 0;
    border: 2px solid #eee;
    width: 100%;
    border-radius: 0;
    /*overflow: hidden;*/
    background-color: #fff;
    background: #fff;
    position: relative;
    color: #2b2b2b;
}
.wpcf7-form span.ds-wpcf7-select.wpcf7-form-control-wrap:hover {
    border-color: #000;
}
.wpcf7-form span.ds-wpcf7-select.wpcf7-form-control-wrap:after {
    top: 50%;
    right: 10px;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
    border-color: rgba(0, 0, 0, 0);
    border-top-color: #000000;
    border-width: 5px;
    margin-top: -2px;
    z-index: 100;
}
.wpcf7-form span.ds-wpcf7-select.wpcf7-form-control-wrap select {
    color: #2b2b2b;
    font-size: 16px;
    padding: 16px;
    width: 100%;
    border: none;
    box-shadow: none;
    background-color: transparent;
    background-image: none;
    -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
.wpcf7-form span.ds-wpcf7-select.wpcf7-form-control-wrap select::-ms-expand{
      display: none;
}
.wpcf7-form span.ds-wpcf7-select.wpcf7-form-control-wrap select:focus {
    outline: none;
}
.wpcf7-form span.ds-wpcf7-select.wpcf7-form-control-wrap select:-moz-focusring {
      color: transparent;
      text-shadow: 0 0 0 #000;
}
/* Not valid tips */
.wpcf7-form span.wpcf7-not-valid-tip {
    padding: 0 16px;
    white-space: nowrap;
    background-color: #f47d3a;
    color: #FFF;
    font-weight: bold;
    font-size: 14px;
    line-height: 22px;
}
.wpcf7-form span.wpcf7-form-control-wrap.ds-wpcf7-select span.wpcf7-not-valid-tip {
    top: auto;
    bottom:-12px;
    left:-2px;
}
.wpcf7-spinner {
    position: absolute;
    right: 20px;
    top: 15px;
}
div.wpcf7-response-output {
      margin-top: 15px !important;
      text-align: center;
}
.wpcf7 form.sent .wpcf7-response-output {
	padding: 40px 20px;
	text-align: center;
	font-weight: 700 !important;
	font-size: 22px;
	border-color: #f4f0ed;
	line-height: 1.4em;
	background-color: #184273;
	border-radius: 30px;
	box-shadow: 3px 2px 8px 4px rgb(0 0 0 / 20%);
}
/* Hide the form on successful send */
.wpcf7-form.sent .contact-flex {
    display:none;
}
.contact-flex {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    margin: 0 -8px;
    position: relative;
}
.contact-flex .contact-half {
    position: relative;
    flex: 1 1 48%;
    padding: 0 8px 6px;
}
.contact-flex .contact-third {
    position: relative;
    flex: 1 1 30%;
    padding: 0 8px 6px;
}
.contact-flex .contact-full {
    position: relative;
    flex: 1 1 100%;
    padding: 0 8px 6px;
}
.contact-flex label {
    font-weight: 600;
}

@media (max-width: 767px) { 
    .contact-flex .contact-half,
    .contact-flex .contact-third {
        flex-basis: 100%;
    }
    span.wpcf7-form-control.g-recaptcha.wpcf7-recaptcha iframe {transform: scale(0.7);transform-origin: 0 0;}

}

/* Scope everything to this gallery only */
.igr-custom-slider {
  --igr-gap: 10px;
  --igr-arrow-size: 40px;
  --igr-arrow-z: 2;
}

/* Main image area */
.igr-custom-slider .igr-main {
  margin-bottom: var(--igr-gap);
    --igr-main-h: clamp(280px, 60vh, 780px);
  height: var(--igr-main-h);
  overflow: hidden; /* crop */
  position: relative;
}
.igr-custom-slider .igr-main a { display: block; line-height: 0; }
.igr-custom-slider .igr-main img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: center;
}

/* Thumbs wrapper with arrows layered on top */
.igr-custom-slider .igr-thumbs-wrap {
  position: relative;
}

/* Make the Divi gallery items a horizontal rail */
.igr-custom-slider .et_pb_gallery_items {
  display: flex !important;
  flex-wrap: nowrap;
  gap: var(--igr-gap);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 2px;
  margin-top: 0 !important; 
  float: none !important;
  justify-content: center;
}

/* Hide scrollbar (keeps scrolling functional for touch/trackpad) */
.igr-custom-slider .et_pb_gallery_items::-webkit-scrollbar { display: none; }
.igr-custom-slider .et_pb_gallery_items { scrollbar-width: none; }

/* Thumb sizing */
.igr-custom-slider .et_pb_gallery_item {
  flex: 0 0 auto;
  width: 120px !important;              /* tweak as needed */
  scroll-snap-align: start;
  margin: 0 !important;
}
.igr-custom-slider .et_pb_gallery_image,
.igr-custom-slider .et_pb_gallery_image a,
.igr-custom-slider .et_pb_gallery_image img {
  display: block;
  width: 100% !important;
  height: auto !important;
}
.igr-custom-slider .et_pb_grid_item img {
    opacity: 0.7;
}
/* Active thumb outline */
.igr-custom-slider .igr-thumb-active img {
  /* outline: 2px solid #333; */
  /* outline-offset: 2px; */
  opacity: 1;
}

/* Arrow buttons */
.igr-custom-slider .igr-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: var(--igr-arrow-z);
  width: var(--igr-arrow-size);
  height: var(--igr-arrow-size);
  border-radius: 999px;
  border: 0;
  background: rgba(255,255,255,0.9);
  box-shadow: 0 2px 10px rgba(0,0,0,0.15);
  display: grid;
  place-items: center;
  cursor: pointer;
  user-select: none;
}
.igr-custom-slider .igr-nav svg {
  width: 18px; height: 18px;
}
.igr-custom-slider .igr-nav.prev { left: 4px; }
.igr-custom-slider .igr-nav.next { right: 4px; }

.igr-custom-slider .igr-nav[disabled] {
  opacity: .4;
  pointer-events: none;
}

/* Respect reduced-motion users */
@media (prefers-reduced-motion: reduce) {
  .igr-custom-slider .et_pb_gallery_items {
    scroll-behavior: auto !important;
  }
}

/* Responsive height adjustments to remove big gaps */
@media (max-height: 900px) {
  .igr-custom-slider .igr-main {
    --igr-main-h: clamp(200px, 50vh, 600px);
  }
}

@media (max-height: 700px) {
  .igr-custom-slider .igr-main {
    --igr-main-h: clamp(160px, 45vh, 500px);
  }
}

@media (max-height: 600px) {
  .igr-custom-slider .igr-main {
    --igr-main-h: clamp(140px, 40vh, 400px);
  }
}

@media (max-width: 767px) {
  .igr-custom-slider .igr-main {
    height: auto !important;
  }
}
/* Also prevent margin collapse between main and thumbs */
.igr-custom-slider .igr-main {
  margin-bottom: 1rem; /* ensures consistent spacing */
}