/* 
Theme Name: Hello Elementor Child
Theme URI: https://github.com/elementor/hello-theme-child/
Description: Hello Elementor Child is a child theme of Hello Elementor, created by Elementor team
Author: Elementor Team
Author URI: https://elementor.com/
Template: hello-elementor
Version: 2.0.0
Text Domain: hello-elementor-child
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/

/* Add your custom styles here */

/* CSS Reset */
*,
*::before,
*::after {
	box-sizing: border-box;
}
body, h1, h2, h3, h4, h5, h5, figure, blockquote, dl, dd {
	margin: 0;
	padding: 0;
}
p {
  margin: 0 0 10px;
}
h1, h2, h3, h4, h5, h6 {
	text-wrap: balance;
	margin-bottom: 10px;
}
html:focus-within {
	scroll-behavior: smooth;
}
body {
	line-height: 1.5;
	-webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
img, picture, video, canvas, svg {
	display: block;
	max-width: 100%;
}
input, button, textarea, select {
	font: inherit;
}
@media (prefers-reduced-motion: reduce) {
	html:focus-within {
		scroll-behavior: auto;
	}

	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}

/* Home */
#main-box {
	position: absolute;
	left: 60%;
	top: 55%;
	transform: translateY(-50%);
	width: auto;
}
.logo {
	display: none;
}
.text-box {
	transform: translate(100px);
	transition: all 1.5s ease-in-out 0s;
	opacity: 0;
}
.text-box.slide {
	transform: translate(0px);
	transition: all 1.5s ease-in-out 0s;
	opacity: 1;
}
.text-box a.phone {
	color: #e2e2d5;
}
#principal .footer-left {
	width: auto;
}
@media (max-width: 1366px) {
	#principal {
		background-image: url('/wp-content/uploads/2024/11/map-home-1366.webp');
	}
	#main-box {
		left: auto;
		right: 0;
	}
}
@media (max-width: 1024px) {
	#principal {
		background-position: 90% 0;
	}
	#main-box {
		left: 50%;
		transform: translate(-20%, -50%);
	}
	#main-box .text-box {
		min-width: 300px;
	}
}
@media (max-width: 768px) {
	#principal {
		background-image: url('/wp-content/uploads/2024/11/map-home-768.webp');
	}
	#main-box {
		width: 100%;
		position: relative;
		top: auto;
		right: auto;
		left: auto;
		transform: none;
	}
	#main-box .text-box {
		min-width: auto;
	}
}

/* Modal */
#modal {
	display: none;
	position: fixed;
	z-index: 1;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	overflow: auto;
	background-color: rgba(0, 0, 0, 0.4);
	animation: fade-in 0.3s ease-in-out;
}
.modal-content {
	padding: 50px 30px 30px 30px;
	border-radius: 30px;
	width: 500px;
	max-width: 100%;
	color: #958529;
}
.modal-content::after {
	content: "";
	background: url('/wp-content/uploads/2024/11/map-grey-768-2.webp') top center no-repeat;
	background-size: cover;
	border-radius: 30px;
	position: absolute;
	inset: 0;
	z-index: -2;
}
.modal-content::before {
	content: "";
	background-color: rgba(172, 173, 166, 0.53);
	position: absolute;
	inset: 0;
	border-radius: 30px;
	z-index: -1;
	mix-blend-mode: multiply;
}
.close-btn {
	position: absolute;
	right: 30px;
	top: 15px;
	font-size: 24px;
	font-weight: bold;
	cursor: pointer;
	color: #666;
	transition: color 0.3s ease;
}
.close-btn:hover {
	color: #ef8300;
}
/* Fade in animation */
@keyframes fade-in {
	from { opacity: 0; }
	to { opacity: 1; }
}
 /* Fade in animation for forms */
@keyframes form-fade-in {
	from { 
		opacity: 0;
		transform: translateY(-20px);
	}
	to { 
		opacity: 1;
		transform: translateY(0);
	}
}
.form-container {
	display: none;
	animation: form-fade-in 0.3s ease-in-out;
}
.modal-buttons {
	display: flex;
	gap: 20px;
	flex-direction: column;
	justify-content: space-between;
	margin-top: 20px;
}
.modal-buttons button {
	cursor: pointer;
	font-family: "Hurme Geometric Sans", sans-serif;
	font-weight: 600;
	color: #333333;
	padding: 12px 15px;
	border: none;
	border-radius: 30px;
	background-color: #E3E1D4;
	transition: all 0.3s ease;
}
.modal-buttons button:hover {
	background-color: #AEAEAA;
	color: #333333;
}
.modal-buttons button.go-back-btn {
	margin-top: 15px;
	background: none;
	text-decoration: underline;
	color: #333333;
}
.modal-buttons button.go-back-btn:hover {
	background: none;
	color: #ef8300;
}
.home-footer .elementor-widget-container p {
	margin-bottom: 0;
}
.home-footer .elementor-widget-container a {
	color: #e2e2d5;
	font-size: 14px;
	font-weight: 300;
}
.home-footer .elementor-widget-container a:hover {
	color: #e2e2d5;
	text-decoration: underline;
}
@media (min-width: 768px) {
	#principal .home-footer {
		position: absolute;
		right: 20px;
		bottom: 20px;
	}
	#principal .footer-left {
		position: absolute;
		left: 20px;
		bottom: 20px;
	}
	#principal .inquires {
		position: absolute;
		right: 20px;
		bottom: 80px;
	}
}
/* Forms */
form.forminator-ui {
	font-family: "Hurme Geometric Sans", sans-serif;
	color: #000;
}
#principal form.forminator-ui .forminator-field h2.forminator-title {
	font-size: 16px;
	font-weight: 600;
	padding-top: 10px;
}
#principal form.forminator-ui .budget-title .forminator-field h2.forminator-title {
	font-size: 14px;
}
#principal form.forminator-ui .budget-label .forminator-field .forminator-label {
	font-size: 12px;
}
#principal form.forminator-ui .forminator-field .forminator-label {
	font-size: 14px;
}
#principal form.forminator-ui .forminator-field  .forminator-input {
	font-size: 12px;
	padding: 7px 10px;
	border-radius: 30px;
}
#principal form.forminator-ui .forminator-field-radio .forminator-label {
	display: inline-block;
	margin-right: 20px;
}
#principal form.forminator-ui .forminator-radio {
	margin-top: 0;
}
#principal form.forminator-ui .forminator-radio-label {
	font-size: 12px;
	font-weight: 600;
}
#principal form.forminator-ui .forminator-description {
	display: none;
}
#principal form.forminator-ui .forminator-field .forminator-textarea {
	height: 80px;
	font-size: 12px;
	padding: 7px 10px;
	border-radius: 10px;
}
#principal form.forminator-ui .forminator-field .forminator-select2 + .forminator-select .selection .select2-selection--single[role="combobox"] {
	border-radius: 30px;
}
.forminator-select.forminator-select-dropdown-container--open .forminator-select-dropdown.forminator-dropdown--flat {
	border-radius: 10px;
	margin-top: 3px;
}
#principal form.forminator-ui .forminator-field select.forminator-select2 + .forminator-select .selection .select2-selection--single[role="combobox"] .select2-selection__rendered {
	font-size: 12px;
	padding: 7px 10px;
}
span.forminator-select-dropdown-container--open .forminator-custom-form-448.forminator-dropdown--flat .select2-results .select2-results__options .select2-results__option {
	font-size: 12px;
	padding: 7px;
	font-family: "Hurme Geometric Sans", sans-serif;
}
#principal form.forminator-ui .forminator-field button.forminator-button-submit {
	border-radius: 30px;
	font-weight: 600;
	padding: 12px 15px;
}
#principal form.forminator-ui .forminator-field button.forminator-button-submit:hover,
#principal form.forminator-ui .forminator-field button.forminator-button-submit:focus {
	box-shadow: none;
}
#principal form.forminator-ui .forminator-field .forminator-error-message {
	line-height: 1.2em;
	background: none;
	color: #FFC9D3;
}
#principal form.forminator-ui .forminator-response-message {
	border-radius: 10px;
}
#principal form.forminator-ui .forminator-field .forminator-input-with-icon .forminator-input {
	padding-left: 36px;
}
#ui-datepicker-div {
	font-family: "Hurme Geometric Sans", sans-serif;
}
.forminator-input-with-suffix::after {
	content:"€";
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
}
#principal form.forminator-ui .forminator-suffix {
	display: none;
}
@media (min-width: 769px) {
	.shrink {
		margin-top: 10px;
	}
	.shrink .forminator-field {
		display: flex;
		align-items: center;
		gap: 20px;
	}
	#principal form.forminator-ui .shrink .forminator-field label {
		width: auto;
		line-height: 1.2em;
	}
	#principal form.forminator-ui .shrink .forminator-field .forminator-number--field {
		width: 25%;
	}
	#principal form.forminator-ui .shrink .forminator-field .forminator-input-with-icon {
		width: 30%;
	}
}
@media (max-width: 768px) {
	#principal form.forminator-ui .forminator-field-radio .forminator-label {
		display: block;
		margin-right: 0;
	}
	#principal form.forminator-ui .forminator-field button.forminator-button-submit {
		margin-top: 10px;
	}
}
/* Internas */
.legales .elementor-widget-container a {
	color: #333;
	font-weight: 600;
	text-decoration: underline;
}
.legales .elementor-widget-container a:hover {
	color: #333;
}
.inner-footer .elementor-widget-container p {
	margin-bottom: 0;
}
.inner-footer .elementor-widget-container a {
	color: #313131;
	font-size: 14px;
	font-weight: 300;
}
.inner-footer .elementor-widget-container a:hover {
	color: #313131;
	text-decoration: underline;
}
.contenedor table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 20px;
}
.contenedor thead th {
    background-color: #f2f2f2;
    padding: 10px;
    text-align: left;
}
.contenedor tbody td {
    background-color: #ffffff4f;
    padding: 10px;
    border-top: 1px solid #ddd;
}
@media (max-width: 768px) {
    .background {background-image: url('img/map-grey-768.webp');}
    .footer{left:20px;right:auto;}
}
@media (max-width: 600px) {
    .contenedor table, .contenedor thead, .contenedor tbody, .contenedor th, .contenedor td, .contenedor tr {
        display: block;
        width: 100%;
    }
    .contenedor thead {
        display: none; /* Hide header row */
    }
    .contenedor tbody tr {
        margin-bottom: 15px;
        border-bottom: 1px solid #ddd;
        padding-bottom: 10px;
    }
    .contenedor tbody td {
        display: flex;
        justify-content: space-between;
        padding: 10px;
        border: none;
    }
}