/* Contactanos page styles */
:root {
	--contact-bg: #b3926e;    
	--contact-panel: #3e230f;  
	--contact-text: #2b2b2b;     
	--contact-white: #ffffff;
	--contact-muted: #f2eee9;   
	--contact-radius-lg: 20px;
	--contact-radius-md: 12px;
}

.alert{
	padding:12px 16px;
	border-radius:12px;
	margin-bottom:16px;
	font-size:.95rem;
	line-height:1.4;
	border:1px solid transparent;
}
.alert--success{
	background:rgba(34,197,94,0.12);
	color:#166534;
	border-color:rgba(34,197,94,0.32);
}
.alert--error{
	background:rgba(248,113,113,0.12);
	color:#991b1b;
	border-color:rgba(248,113,113,0.32);
}
.alert__list{
	margin:0;
	padding-left:18px;
}
.alert__list li + li{
	margin-top:4px;
}

.contactanos {
	padding: 40px 16px 80px;
}

.contactanos__card {
	max-width: 1100px;
	margin: 0 auto;
	background: var(--contact-bg);
	border-radius: var(--contact-radius-lg);
	padding: 36px 32px;
	display: grid;
	grid-template-columns: 340px 1fr;
	gap: 28px;
	box-shadow: 0 10px 24px rgba(0,0,0,.08);
}

.contactanos__card.js-animate-up {
	opacity: 0;
	transform: none !important;
	transition: opacity var(--animate-duration, 700ms) cubic-bezier(0.2,0.8,0.2,1) !important;
}

.contactanos__card.js-animate-up.is-animating {
	will-change: opacity;
}

.contactanos__card.js-animate-up.is-visible {
	opacity: 1;
}

.contactanos__card.js-animate-up .contactanos__info,
.contactanos__card.js-animate-up .contactanos__form,
.contactanos__card.js-animate-up .contactanos__info-title,
.contactanos__card.js-animate-up .contactanos__list,
.contactanos__card.js-animate-up .contactanos__form-title,
.contactanos__card.js-animate-up .contact-form,
.contactanos__card.js-animate-up .contactanos__info > * {
	opacity: 0;
	transform: translate3d(0, 24px, 0);
	transition: transform var(--animate-duration, 750ms) cubic-bezier(0.2,0.8,0.2,1), opacity var(--animate-duration, 750ms);
}

.contactanos__card.js-animate-up.is-visible .contactanos__info,
.contactanos__card.js-animate-up.is-visible .contactanos__form,
.contactanos__card.js-animate-up.is-visible .contactanos__info-title,
.contactanos__card.js-animate-up.is-visible .contactanos__list,
.contactanos__card.js-animate-up.is-visible .contactanos__form-title,
.contactanos__card.js-animate-up.is-visible .contact-form,
.contactanos__card.js-animate-up.is-visible .contactanos__info > * {
	opacity: 1;
	transform: translate3d(0, 0, 0);
}

/* Left panel */
.contactanos__info {
    background: var(--contact-panel);
    color: var(--contact-white);
    border-radius: 16px;
    padding: 28px 24px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    gap: 18px;
}

.contactanos__info-logo {
    display: flex;
    justify-content: center;
}

.contactanos__info-title {
	font-size: 25px;
	line-height: 1.25;
	font-weight: 700;
	margin: 0 0 8px 0;
}

.contactanos__list { margin: 8px 0 0 0; padding: 0; list-style: none; display: grid; gap: 14px; }
.contactanos__item { display: inline-flex; align-items: center; gap: 12px; font-size: 20px; opacity: .95; }
.contactanos__icon { width: 22px; height: 22px; object-fit: contain; filter: brightness(0) invert(1); }

/* Right form */
.contactanos__form { color: var(--contact-white); }
.contactanos__form-title { 
	color: var(--contact-white);
	font-size: 22px; 
	text-align: center; 
	margin: 4px 0 18px; 
	font-weight: 700;
}

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; }
.grid-3 { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; }
.field { display: grid; gap: 10px; margin-bottom: 18px; }
.label { color: var(--contact-white); font-size: 14px; }

.input, .textarea, .select {
	width: 94%;
	background: #ffefdf;
	color: var(--contact-text);
	border: 0;
	border-radius: var(--contact-radius-md);
	padding: 10px 12px;
	box-shadow: inset 0 0 0 1px rgba(0,0,0,.06);
}
.contactanos__form .textarea[name="mensaje"] {
	width: 97%;
}

.input:focus, .textarea:focus, .select:focus { outline: 2px solid rgba(255,255,255,.6); box-shadow: inset 0 0 0 1px rgba(0,0,0,.06), 0 0 0 3px rgba(255,255,255,.25); }
.input:focus, .textarea:focus, .select:focus { outline: 2px solid rgba(62,35,15,.45); box-shadow: inset 0 0 0 1px rgba(0,0,0,.06), 0 0 0 3px rgba(62,35,15,.18); }
.textarea { resize: vertical; min-height: 96px; }

.select {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	/* match input background */
	background: #ffefdf;
	color: var(--contact-text);
	border-radius: 999px;
	box-shadow: 0 6px 14px rgba(0,0,0,.10), inset 0 0 0 1px rgba(0,0,0,0.06);
	font-weight: 600;
	padding: 12px 16px;
	transition: filter .2s ease, transform .05s ease, box-shadow .2s ease;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%236b5b4a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	padding-right: 46px; 
	cursor: pointer;
}
.select:hover { filter: brightness(1.02); }
.select:active { transform: translateY(1px); }
.select:invalid { color: #6b6b6b; }

.select option { color: var(--contact-text); background: var(--contact-white); }

/* New servicio modal/button styles (scoped to contactanos) */
.servicio-field{display:block}
.btn-servicio{display:inline-block;padding:10px 14px;border-radius:999px;background:#6b3f2b;color:#fff;border:none;cursor:pointer;font-weight:700}
.servicio-modal{position:absolute;left:0;top:calc(100% + 8px);background:#fff;color:#222;border-radius:8px;box-shadow:0 12px 30px rgba(0,0,0,0.15);border:1px solid rgba(0,0,0,0.06);min-width:220px;z-index:250000}
.servicio-modal__inner{display:flex;flex-direction:column;padding:8px}
.servicio-option{padding:10px 12px;border-radius:6px;cursor:pointer}
.servicio-option:hover,.servicio-option:focus{background:#f0ebe7;outline:none}

/* Compact dropdown styles for servicio selector */
.services-dropdown{position:fixed;display:block;z-index:200000;opacity:0;transform-origin:top left;transition:opacity .18s ease,transform .18s cubic-bezier(.2,.9,.3,1)}
.services-dropdown.is-open{opacity:1;transform:none}
.services-dropdown__panel{background:#fff;color:#222;border-radius:10px;padding:12px;box-shadow:0 14px 40px rgba(0,0,0,.14);min-width:240px;max-height:calc(100vh - 160px);overflow:hidden}

/* header inside the services modal */
.services-dropdown__header{
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 6px 12px 6px 6px;
	margin-bottom: 6px;
}
.services-dropdown__title{margin:0 0 8px;font-size:14px;font-weight:700}

.services-dropdown__clear--top{
	position: static; /* place inline in flex header */
	margin-left: 30px; /* increased gap */
	padding: 8px 12px;
	border-radius: 999px;
}
.services-dropdown__clear--top{box-shadow:0 4px 10px rgba(0,0,0,0.08)}

@media (max-width:600px){
	.services-dropdown__clear--top{
		margin-left: 16px;
		padding: 6px 10px;
	}
}
.services-dropdown__title{margin:0 0 8px;font-size:14px;font-weight:700}
.service-item{display:block;text-align:left;padding:10px;border-radius:8px;background:#fbfbfb;border:1px solid rgba(0,0,0,0.04);cursor:pointer;position:relative}
.service-item:focus{outline:2px solid rgba(107,63,43,0.12)}
.service-item.is-active,
.service-item.has-selection {
	border-color: rgba(107,63,43,0.35);
	background: #fff7f0;
	box-shadow: 0 8px 20px rgba(107,63,43,0.12);
}
.services-dropdown__grid .service-item.is-active,
.services-dropdown__grid .service-item.has-selection,
.services-dropdown .service-item.is-active,
.services-dropdown .service-item.has-selection {
	/* Stronger selector to avoid being overridden by other stylesheet rules */
	border-color: rgba(107,63,43,0.35) !important;
	background: #fff7f0 !important;
	box-shadow: 0 8px 20px rgba(107,63,43,0.12) !important;
}
.service-item.has-selection::after{content:attr(data-selected-count);position:absolute;top:10px;right:12px;min-width:22px;height:22px;border-radius:999px;background:rgba(107,63,43,0.12);color:#6b3f2b;font-size:.75rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center;padding:0 6px}
.service-item__desc{margin-top:6px;color:#666;font-size:13px}
/* Panel layout: two-column by default (categories left, details right). */
.services-dropdown__panel{
	display:grid;
	grid-template-columns:minmax(220px,260px) 1fr;
	align-items:start;
	gap:14px;
}
.services-dropdown__panel .services-dropdown__header{grid-column:1 / -1}
.services-dropdown__grid{
	display:flex;
	flex-direction:column;
	gap:8px;
}
.services-dropdown__subarea{
	grid-column:2;
	margin-top:0;
	padding-top:0;
	border-top:0;
	overflow:hidden;
	max-height:0;
	opacity:0;
	transform:translateY(-6px);
	transition:max-height .32s cubic-bezier(.2,.9,.3,1),opacity .22s ease,transform .24s ease;
}
.services-dropdown__subarea.is-open{
	max-height:calc(100vh - 220px);
	opacity:1;
	transform:none;
	overflow-y:auto;
	padding-right:6px;
	padding-bottom:28px;
}
.services-dropdown__subarea::after{content:'';display:block;height:28px;width:100%;pointer-events:none}

.services-dropdown__subarea.is-open.is-architect{max-height:calc(100vh - 180px);padding-bottom:120px}
.services-dropdown__subarea.is-architect::after{height:120px}

/* Scrollbar styling for service modal panel */
.services-dropdown__panel::-webkit-scrollbar{width:10px;height:10px}
.services-dropdown__panel::-webkit-scrollbar-track{background:transparent;border-radius:999px}
.services-dropdown__panel::-webkit-scrollbar-thumb{background:rgba(107,63,43,0.18);border-radius:999px;border:2px solid transparent;background-clip:padding-box}
.services-dropdown__panel::-webkit-scrollbar-thumb:hover{background:rgba(107,63,43,0.26)}

/* Restore subarea scrollbar rules so subarea (category items) scrolls instead of the panel. */
.services-dropdown__subarea::-webkit-scrollbar{width:10px;height:10px}
.services-dropdown__subarea::-webkit-scrollbar-track{background:transparent;border-radius:999px}
.services-dropdown__subarea::-webkit-scrollbar-thumb{background:rgba(107,63,43,0.14);border-radius:999px;border:2px solid transparent;background-clip:padding-box}
.services-dropdown__subarea::-webkit-scrollbar-thumb:hover{background:rgba(107,63,43,0.22)}

/* Firefox */
.services-dropdown__subarea{scrollbar-width:thin;scrollbar-color: rgba(107,63,43,0.14) transparent}

/* Firefox */
.services-dropdown__panel{scrollbar-width:thin;scrollbar-color: rgba(107,63,43,0.18) transparent}
.services-dropdown__subgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-top:8px}
.service-subitem{display:inline-block;padding:10px 12px;border-radius:8px;background:#fff;border:1px solid rgba(0,0,0,0.06);cursor:pointer;text-align:center}
.service-subitem:focus{outline:2px solid rgba(107,63,43,0.12)}
.service-subitem.selected{background:#6b3f2b;color:#fff;border-color:rgba(0,0,0,0.06);box-shadow:0 6px 18px rgba(107,63,43,0.12)}
.services-dropdown__footer{margin-top:16px;display:flex;justify-content:flex-end}
.services-dropdown__cancel{background:transparent;border:1px solid rgba(0,0,0,0.08);padding:10px 14px;border-radius:999px;cursor:pointer}

/* Clear button inside servicio modal footer */
.services-dropdown__clear{background:var(--contact-panel);color:var(--contact-white);border:none;padding:8px 12px;border-radius:999px;cursor:pointer;font-weight:700;margin-right:8px}
.services-dropdown__clear:hover{filter:brightness(1.03)}

@media (max-width:600px){
	.services-dropdown__panel{padding:12px;border-radius:10px}
	.services-dropdown__title{font-size:13px}
}

@media (max-width: 768px) {
	.select { padding: 12px 14px; background-position: right 12px center; padding-right: 42px; }
}

@media (max-width: 900px) {
	/* Revert to stacked layout on narrower screens so subarea sits below categories */
	.services-dropdown__panel {
		display: block !important;
		max-height: none;
	}
	.services-dropdown__grid {
		margin-bottom: 12px;
	}
	.services-dropdown__subarea {
		grid-column: auto !important;
		margin-top: 10px;
		padding-top: 10px;
		border-top: 1px dashed rgba(107,63,43,0.18);
		max-height: none;
		overflow: visible;
	}
}

.actions { display: flex; justify-content: center; margin-top: 10px; }
.btn-primary {
	background: var(--contact-panel);
	color: var(--contact-white);
	border: none;
	border-radius: 999px;
	padding: 10px 28px;
	font-weight: 600;
	cursor: pointer;
	transition: transform .05s ease, filter .2s ease;
}
.btn-primary:hover { filter: brightness(1.05); }
.btn-primary:active { transform: translateY(1px); }

/* Ensure the services modal doesn't block clicks when it's hidden
   The modal is appended to <body> and uses opacity toggles; make it non-interactive when aria-hidden="true" */
.services-dropdown[aria-hidden="true"] {
  pointer-events: none;
  visibility: hidden;
}

/* When open, allow interactions and make visible */
.services-dropdown.is-open[aria-hidden="false"] {
  pointer-events: auto;
  visibility: visible;
}

/* Responsive */
@media (max-width: 992px) {
	.contactanos__card { grid-template-columns: 320px 1fr; padding: 32px 24px; }
}
@media (max-width: 768px) {
	.contactanos { padding: 28px 12px 64px; }
	.contactanos__card { grid-template-columns: 1fr; padding: 20px 16px; gap: 16px; }
	.contactanos__info { min-height: auto; padding: 20px 18px; }
}

/* Ajuste extra para móviles pequeños se maneja desde mobile.css */
