/* ==========================================================
   Raíces de Tegualda — CSS Principal
   ========================================================== */

/* ── Variables ── */
:root {
	--papel:  #E8E4DD;
	--signal: #32CD32;
	--roto:   #F5F3EE;
	--negro:  #111111;
	--gris:   #6B6B6B;
	--rojo:   #E63B2E;
	--wa:     #25D366;
}

/* ── Reset base ── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body { margin: 0; padding: 0; background: var(--roto); color: var(--negro); font-family: 'Space Grotesk', sans-serif; font-size: 16px; line-height: 1.5; overflow-x: hidden; }
img  { display: block; max-width: 100%; }
a    { text-decoration: none; }
ul   { list-style: none; margin: 0; padding: 0; }
p    { margin: 0; }

::-webkit-scrollbar       { width: 6px; }
::-webkit-scrollbar-track { background: var(--papel); }
::-webkit-scrollbar-thumb { background: var(--negro); border-radius: 3px; }

body::before {
	content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 9999;
	opacity: 0.04;
	background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
	background-size: 256px 256px;
}

/* ── Layout helpers ── */
.container         { max-width: 72rem; margin: 0 auto; padding: 0 1.5rem; width: 100%; }
.container--narrow { max-width: 56rem; margin: 0 auto; padding: 0 1.5rem; width: 100%; }

.section-header         { margin-bottom: 4rem; }
.section-header--center { text-align: center; }

.section-title      { font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: clamp(2.5rem,5vw,4rem); line-height: 1; margin: 0 0 1rem; }
.section-title em   { font-family: 'DM Serif Display', serif; font-style: italic; color: var(--signal); }
.section-title--dark  { color: var(--negro); }
.section-title--light { color: var(--roto); }

.section-desc       { font-family: 'Space Grotesk', sans-serif; font-size: 1.125rem; line-height: 1.6; max-width: 36rem; }
.section-desc--dark { color: var(--gris); }

/* ── Tag pill ── */
.tag {
	display: inline-flex; align-items: center; gap: 6px;
	font-family: 'Space Mono', monospace; font-size: 11px;
	letter-spacing: 0.08em; text-transform: uppercase;
	padding: 4px 12px; border-radius: 999px; border: 1px solid currentColor;
	margin-bottom: 1rem;
}
.tag--dark    { color: var(--negro);  border-color: rgba(17,17,17,.3); }
.tag--signal  { color: var(--signal); border-color: var(--signal); }
.tag--glass   { color: var(--roto);   border-color: rgba(245,243,238,.3); background: rgba(17,17,17,.4); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); }

/* ── Botones ── */
.btn {
	display: inline-flex; align-items: center; justify-content: center;
	position: relative; overflow: hidden;
	font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 1rem;
	padding: 1rem 2rem; border-radius: 999px; cursor: pointer;
	transition: transform .2s ease; border: none;
}
.btn:hover            { transform: scale(1.03); }
.btn__fill            { position: absolute; inset: 0; border-radius: 999px; transform: translateY(100%); transition: transform .35s cubic-bezier(.76,0,.24,1); }
.btn:hover .btn__fill { transform: translateY(0); }
.btn__text            { position: relative; z-index: 1; display: inline-flex; align-items: center; gap: 6px; }
.btn--full            { width: 100%; }
.btn--sm              { padding: .5rem 1rem; font-size: .875rem; }

.btn--primary            { background: var(--signal); color: var(--roto); }
.btn--primary .btn__fill { background: rgba(245,243,238,.15); }

.btn--secondary {
	background: rgba(245,243,238,.1); border: 1px solid rgba(245,243,238,.3);
	color: var(--roto); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
}
.btn--secondary .btn__fill { background: rgba(245,243,238,.1); }

.btn--wa            { background: var(--wa); color: #fff; }
.btn--wa .btn__fill { background: rgba(255,255,255,.15); }

.btn--negro            { background: rgba(17,17,17,.15); border: 1px solid rgba(17,17,17,.3); color: var(--negro); }
.btn--negro .btn__fill { background: rgba(17,17,17,.1); }

.btn--negro-solid            { background: var(--negro); color: var(--roto); }
.btn--negro-solid .btn__fill { background: rgba(245,243,238,.1); }

.btn--roto            { background: var(--roto); color: var(--rojo); }
.btn--roto .btn__fill { background: rgba(17,17,17,.1); }

.btn--urgency-secondary            { background: rgba(17,17,17,.15); border: 1px solid rgba(17,17,17,.3); color: var(--negro); }
.btn--urgency-secondary .btn__fill { background: rgba(17,17,17,.1); }

/* ── Inputs ── */
.input {
	width: 100%; border-radius: 1.5rem; padding: .75rem 1.25rem;
	font-family: 'Space Grotesk', sans-serif; font-size: .875rem;
	transition: border-color .2s; outline: none;
}
.input--dark { background: rgba(232,228,221,.05); border: 1px solid rgba(232,228,221,.15); color: var(--roto); }
.input--dark::placeholder { color: rgba(232,228,221,.3); }
.input--dark:focus        { border-color: var(--signal); }
.textarea { resize: none; }

/* ── Form helpers ── */
.field { display: flex; flex-direction: column; gap: .5rem; }
label  { font-family: 'Space Mono', monospace; font-size: .75rem; color: rgba(232,228,221,.4); text-transform: uppercase; letter-spacing: .05em; }
.field__error   { font-family: 'Space Mono', monospace; font-size: .75rem; color: var(--signal); }
.form-subtitle  { font-family: 'Space Mono', monospace; font-size: .75rem; color: rgba(232,228,221,.4); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 1.5rem; }
.form-legal     { font-family: 'Space Mono', monospace; font-size: .625rem; color: rgba(232,228,221,.25); text-align: center; line-height: 1.6; }
.form-card      { background: rgba(232,228,221,.05); border: 1px solid rgba(232,228,221,.1); border-radius: 2rem; padding: 2rem; }
.form-card--dark{ background: var(--negro); border-radius: 2rem; padding: 2rem; display: flex; flex-direction: column; gap: 1.25rem; }
.form-row       { display: grid; gap: 1rem; }
@media(min-width:640px){ .form-row { grid-template-columns: 1fr 1fr; } }

.form-success { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 3rem 1.5rem; gap: 1rem; }
.form-success__icon { width: 5rem; height: 5rem; border-radius: 50%; background: rgba(50,205,50,.2); display: flex; align-items: center; justify-content: center; }
.form-success__link { font-family: 'Space Grotesk', sans-serif; color: var(--signal); font-size: .875rem; text-decoration: underline; text-underline-offset: 4px; }
.btn-wa-success { display: inline-flex; align-items: center; gap: .5rem; background: var(--wa); color: #fff; font-family: 'Space Grotesk', sans-serif; font-weight: 600; padding: .75rem 1.5rem; border-radius: 999px; font-size: .875rem; margin-top: 1rem; }

/* ── Reveal / GSAP ── */
.reveal-up { opacity: 0; transform: translateY(40px); }

/* ── Sig pulse ── */
.sig-pulse-dot { display: inline-block; width: .5rem; height: .5rem; border-radius: 50%; background: var(--signal); animation: sig-pulse 1.4s ease infinite; }
@keyframes sig-pulse { 0%,100%{opacity:1} 50%{opacity:.4} }
@keyframes wa-pulse  { 0%,100%{box-shadow:0 0 0 0 rgba(37,211,102,.5)} 50%{box-shadow:0 0 0 14px rgba(37,211,102,0)} }
.wa-pulse { animation: wa-pulse 2s ease infinite; }

/* ════════════════════════════════════════════
   HEADER
════════════════════════════════════════════ */
.site-header {
	position: fixed; top: 1rem; left: 50%; transform: translateX(-50%);
	z-index: 50; width: calc(100% - 2rem); max-width: 64rem;
	background: rgba(17,17,17,.7); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
	border-radius: 999px; padding: .5rem 1.25rem;
	transition: background .5s, box-shadow .5s; opacity: 0;
}
.site-header.scrolled { background: rgba(17,17,17,.92); box-shadow: 0 8px 32px rgba(0,0,0,.4); }
.site-header__inner   { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.site-header__logo img { height: 3rem; width: auto; object-fit: contain; display: block; }
.site-header__nav      { display: none; align-items: center; gap: 1.5rem; }
.site-header__nav a    { font-family: 'Space Grotesk', sans-serif; font-size: .875rem; color: rgba(232,228,221,.7); transition: color .2s; }
.site-header__nav a:hover { color: var(--papel); }
.site-header__actions  { display: flex; align-items: center; gap: .75rem; }
.mobile-toggle         { background: none; border: none; cursor: pointer; color: var(--papel); padding: .25rem; display: flex; }
.mobile-menu           { padding: 1rem 0 .5rem; border-top: 1px solid rgba(232,228,221,.1); margin-top: .5rem; display: flex; flex-direction: column; gap: .75rem; }
.mobile-menu__link     { font-family: 'Space Grotesk', sans-serif; font-size: .875rem; color: rgba(232,228,221,.8); }
@media(min-width:768px){
	.site-header__nav { display: flex; }
	.mobile-toggle    { display: none; }
}

/* ════════════════════════════════════════════
   HERO
════════════════════════════════════════════ */
.hero { position: relative; min-height: 100svh; display: flex; flex-direction: column; justify-content: flex-end; overflow: hidden; }
.hero__bg { position: absolute; inset: 0; z-index: 0; }
.hero__bg-img { width: 100%; height: 100%; object-fit: cover; }
.hero__overlay-b { position: absolute; inset: 0; background: linear-gradient(to top,#111 0%,rgba(17,17,17,.55) 50%,rgba(17,17,17,.15) 100%); }
.hero__overlay-t { position: absolute; top: 0; left: 0; right: 0; height: 33%; background: linear-gradient(to bottom,rgba(17,17,17,.4),transparent); }
.hero__content   { position: relative; z-index: 10; max-width: 72rem; margin: 0 auto; padding: 8rem 1.5rem 5rem; width: 100%; }
.hero__badge     { margin-bottom: 2rem; opacity: 0; }
.tag             { display: inline-flex; align-items: center; gap: 6px; font-family: 'Space Mono',monospace; font-size: 11px; letter-spacing: .08em; text-transform: uppercase; padding: 4px 12px; border-radius: 999px; border: 1px solid rgba(232,228,221,.2); color: rgba(232,228,221,.6); margin-bottom: 0; }
.hero__headline  { overflow: hidden; margin-bottom: 1.5rem; }
.hero__headline > div { opacity: 0; }
.hero__h-bold    { display: block; font-family: 'Space Grotesk',sans-serif; font-weight: 700; font-size: clamp(2.6rem,7vw,6rem); line-height: 1; color: #F5F3EE; }
.hero__h-italic  { display: block; font-family: 'DM Serif Display',serif; font-style: italic; font-size: clamp(3rem,9vw,8rem); line-height: 1; color: #32CD32; }
.hero__desc      { font-family: 'Space Grotesk',sans-serif; color: rgba(232,228,221,.7); font-size: 1.125rem; line-height: 1.6; max-width: 36rem; margin: 0 0 2.5rem; opacity: 0; }
.hero__ctas      { display: flex; flex-wrap: wrap; gap: 1rem; margin-bottom: 4rem; }
.hero__ctas > *  { opacity: 0; }
.hero__stats     { padding-top: 2rem; border-top: 1px solid rgba(232,228,221,.1); display: grid; grid-template-columns: repeat(2,1fr); gap: 1.5rem; }
@media(min-width:768px){ .hero__stats { grid-template-columns: repeat(4,1fr); } }
.hero__stat-num   { font-family: 'Space Mono',monospace; color: #32CD32; font-size: 1.875rem; font-weight: 700; }
.hero__stat-label { font-family: 'Space Grotesk',sans-serif; color: rgba(232,228,221,.5); font-size: .75rem; margin-top: .25rem; text-transform: uppercase; letter-spacing: .05em; }
.hero__scroll     { position: absolute; bottom: 2rem; right: 2rem; z-index: 10; display: flex; flex-direction: column; align-items: center; gap: .5rem; color: rgba(232,228,221,.4); font-family: 'Space Mono',monospace; font-size: .75rem; }
.hero__scroll svg { animation: bounce-down 1s ease infinite; }
@keyframes bounce-down { 0%,100%{transform:translateY(0)} 50%{transform:translateY(5px)} }

/* ════════════════════════════════════════════
   UBICACIÓN
════════════════════════════════════════════ */
.section-location { padding: 6rem 0; background: var(--roto); overflow: hidden; }
.location-grid    { display: grid; gap: 1rem; }
@media(min-width:1024px){ .location-grid { grid-template-columns: 1fr 1fr; } }

.location-map         { border-radius: 2rem; overflow: hidden; aspect-ratio: 4/3; position: relative; }
.location-map img     { width: 100%; height: 100%; object-fit: cover; }
.location-map__overlay{ position: absolute; inset: 0; background: linear-gradient(to top,rgba(17,17,17,.6),transparent); }
.location-map__badge  { position: absolute; bottom: 1.5rem; left: 1.5rem; }

.location-distances   { display: flex; flex-direction: column; gap: 1rem; }
.distance-card        { background: var(--negro); border-radius: 2rem; padding: 1.5rem; display: flex; align-items: center; justify-content: space-between; transition: background .3s; }
.distance-card:hover  { background: rgba(50,205,50,.1); }
.distance-card__left  { display: flex; align-items: center; gap: 1rem; }
.distance-card__icon  { width: 2.5rem; height: 2.5rem; border-radius: 1.5rem; background: rgba(232,228,221,.05); display: flex; align-items: center; justify-content: center; }
.distance-card__label { font-family: 'Space Grotesk',sans-serif; font-weight: 600; color: var(--roto); font-size: 1.125rem; }
.distance-card__time  { font-family: 'Space Mono',monospace; font-size: 1.5rem; color: var(--signal); font-weight: 700; }

.location-quote   { background: var(--signal); border-radius: 2rem; padding: 1.5rem; margin-top: .5rem; }
.location-quote p { font-family: 'DM Serif Display',serif; font-style: italic; color: var(--negro); font-size: 1.5rem; line-height: 1.3; }
.location-quote span { font-family: 'Space Mono',monospace; color: rgba(17,17,17,.6); font-size: .75rem; margin-top: 1rem; display: block; text-transform: uppercase; letter-spacing: .05em; }

.location-attrs { margin-top: 2rem; display: grid; grid-template-columns: repeat(2,1fr); gap: 1rem; }
@media(min-width:768px){ .location-attrs { grid-template-columns: repeat(4,1fr); } }
.location-attr        { background: var(--negro); border-radius: 2rem; padding: 1.25rem; }
.location-attr__label { font-family: 'Space Grotesk',sans-serif; font-weight: 600; color: var(--roto); font-size: .875rem; margin-bottom: .25rem; }
.location-attr__desc  { font-family: 'Space Mono',monospace; color: rgba(232,228,221,.4); font-size: .75rem; }

/* ════════════════════════════════════════════
   GALERÍA
════════════════════════════════════════════ */
.section-gallery { padding: 6rem 0; background: var(--negro); overflow: hidden; }

.gallery-grid {
	display: grid;
	grid-template-columns: repeat(4,1fr);
	grid-template-rows: repeat(3, 200px);
	gap: .75rem;
	margin-bottom: 2rem;
}
@media(min-width:768px){ .gallery-grid { grid-template-rows: repeat(3, calc((700px - 1.5rem) / 3)); } }

.gallery-item              { position: relative; border-radius: 1.5rem; overflow: hidden; cursor: pointer; background: rgba(17,17,17,.2); }
.gallery-item--large       { grid-column: span 2; grid-row: span 2; }
.gallery-item--wide        { grid-column: span 2; }
.gallery-item img          { width: 100%; height: 100%; object-fit: cover; transition: transform .7s; }
.gallery-item:hover img    { transform: scale(1.05); }
.gallery-item__overlay     { position: absolute; inset: 0; background: transparent; transition: background .3s; }
.gallery-item:hover .gallery-item__overlay { background: rgba(17,17,17,.3); }
.gallery-item__caption     { position: absolute; bottom: 0; left: 0; right: 0; padding: 1rem; opacity: 0; transition: opacity .3s; }
.gallery-item:hover .gallery-item__caption { opacity: 1; }
.gallery-item__caption     { font-family: 'Space Mono',monospace; color: var(--roto); font-size: .75rem; background: rgba(17,17,17,.6); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); margin: .75rem; border-radius: 999px; padding: .25rem .75rem; display: inline-block; width: auto; }
.gallery-item__zoom        { position: absolute; top: 1rem; right: 1rem; opacity: 0; transition: opacity .3s; color: var(--roto); }
.gallery-item:hover .gallery-item__zoom { opacity: 1; }

.gallery-tour { background: rgba(232,228,221,.05); border: 1px solid rgba(232,228,221,.1); border-radius: 2rem; padding: 2rem; display: flex; flex-direction: column; gap: 1rem; align-items: flex-start; }
@media(min-width:768px){ .gallery-tour { flex-direction: row; align-items: center; justify-content: space-between; } }
.gallery-tour h3 { font-family: 'Space Grotesk',sans-serif; font-weight: 600; color: var(--roto); font-size: 1.25rem; margin-bottom: .25rem; }
.gallery-tour p  { font-family: 'Space Grotesk',sans-serif; color: rgba(232,228,221,.5); font-size: .875rem; }

/* Lightbox */
.lightbox            { position: fixed; inset: 0; z-index: 200; background: rgba(17,17,17,.95); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); display: flex; align-items: center; justify-content: center; padding: 1rem; opacity: 0; pointer-events: none; transition: opacity .3s; }
.lightbox.is-open    { opacity: 1; pointer-events: auto; }
.lightbox__close     { position: absolute; top: 1.5rem; right: 1.5rem; background: none; border: none; cursor: pointer; color: var(--papel); transition: color .2s; }
.lightbox__close:hover { color: var(--signal); }
.lightbox__inner     { display: flex; flex-direction: column; align-items: center; gap: 1rem; max-width: 90vw; }
.lightbox__inner img { max-width: 100%; max-height: 80vh; border-radius: 2rem; object-fit: contain; box-shadow: 0 24px 80px rgba(0,0,0,.6); }
.lightbox__caption   { font-family: 'Space Mono',monospace; color: rgba(232,228,221,.5); font-size: .75rem; }

/* ════════════════════════════════════════════
   BROCHURE
════════════════════════════════════════════ */
.section-brochure { padding: 6rem 0; background: var(--negro); overflow: hidden; }
.brochure-grid    { display: grid; gap: 2rem; }
@media(min-width:1024px){ .brochure-grid { grid-template-columns: 1fr 1fr; align-items: center; } }

.brochure-copy h2   { margin: 1.5rem 0; }
.brochure-copy__desc{ font-family: 'Space Grotesk',sans-serif; color: rgba(232,228,221,.6); font-size: 1.125rem; line-height: 1.6; margin-bottom: 2rem; }
.brochure-bullets   { display: flex; flex-direction: column; gap: .75rem; }
.brochure-bullets li { display: flex; align-items: center; gap: .75rem; font-family: 'Space Grotesk',sans-serif; color: rgba(232,228,221,.7); font-size: .875rem; }
.brochure-bullet__check { width: 1.25rem; height: 1.25rem; border-radius: 50%; background: rgba(50,205,50,.2); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }

.brochure-form-inner h3 { font-family: 'Space Grotesk',sans-serif; font-weight: 600; color: var(--roto); font-size: 1.25rem; margin: 0 0 .5rem; }

/* ════════════════════════════════════════════
   CONTACTO
════════════════════════════════════════════ */
.section-contact { padding: 6rem 0; background: var(--roto); overflow: hidden; }
.contact-grid    { display: grid; gap: 2rem; }
@media(min-width:1024px){ .contact-grid { grid-template-columns: 3fr 2fr; } }
.lg-col-3 { }

.intent-group  { display: flex; flex-wrap: wrap; gap: .5rem; }
.intent-btn    { font-family: 'Space Grotesk',sans-serif; font-size: .75rem; padding: .5rem 1rem; border-radius: 999px; border: 1px solid rgba(232,228,221,.15); color: rgba(232,228,221,.5); background: none; cursor: pointer; transition: all .2s; }
.intent-btn:hover   { border-color: rgba(50,205,50,.5); color: var(--papel); }
.intent-btn.active  { background: var(--signal); border-color: var(--signal); color: var(--negro); }

.contact-sidebar { display: flex; flex-direction: column; gap: 1rem; }
.contact-card    { background: var(--negro); border-radius: 2rem; padding: 1.5rem; display: flex; flex-direction: column; gap: 1rem; }
.contact-card--signal { background: var(--signal); }
.contact-card--rojo   { background: var(--rojo); }
.contact-card p  { font-family: 'Space Grotesk',sans-serif; color: rgba(232,228,221,.6); font-size: .875rem; line-height: 1.6; }
.contact-card__header { display: flex; align-items: center; gap: .75rem; }
.contact-card__icon   { width: 2.5rem; height: 2.5rem; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.contact-card__icon--wa    { background: rgba(37,211,102,.2); }
.contact-card__icon--phone { background: rgba(17,17,17,.15); }
.contact-card__icon--mappin{ background: rgba(245,243,238,.2); }
.contact-card__name  { font-family: 'Space Grotesk',sans-serif; font-weight: 600; color: var(--roto); font-size: .875rem; }
.contact-card__sub   { font-family: 'Space Mono',monospace; color: rgba(232,228,221,.4); font-size: .75rem; }

/* ════════════════════════════════════════════
   FAQ
════════════════════════════════════════════ */
.section-faq { padding: 6rem 0; background: var(--negro); overflow: hidden; }
.faq-list    { display: flex; flex-direction: column; gap: .5rem; }
.faq-item    { background: rgba(232,228,221,.05); border: 1px solid rgba(232,228,221,.1); border-radius: 2rem; overflow: hidden; }
.faq-item__btn  { width: 100%; display: flex; align-items: center; justify-content: space-between; padding: 1.5rem; text-align: left; background: none; border: none; cursor: pointer; gap: 1rem; }
.faq-item__btn span { font-family: 'Space Grotesk',sans-serif; font-weight: 600; color: var(--roto); font-size: 1rem; line-height: 1.4; transition: color .2s; }
.faq-item__btn:hover span { color: var(--signal); }
.faq-item__icon  { width: 1.75rem; height: 1.75rem; border-radius: 50%; border: 1px solid rgba(232,228,221,.2); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: all .2s; }
.faq-item__btn:hover .faq-item__icon { border-color: var(--signal); background: rgba(50,205,50,.1); }
.faq-item__btn[aria-expanded="true"] .faq-item__icon { border-color: var(--signal); background: rgba(50,205,50,.1); }
.icon-minus { display: none; }
.faq-item__btn[aria-expanded="true"] .icon-plus  { display: none; }
.faq-item__btn[aria-expanded="true"] .icon-minus { display: block; }
.faq-item__body { padding: 0 1.5rem 1.5rem; }
.faq-item__body p { font-family: 'Space Grotesk',sans-serif; color: rgba(232,228,221,.6); font-size: .875rem; line-height: 1.7; }
.faq-cta { margin-top: 3rem; text-align: center; }
.faq-cta p { font-family: 'Space Grotesk',sans-serif; color: rgba(232,228,221,.5); margin-bottom: 1rem; }

/* ════════════════════════════════════════════
   URGENCIA
════════════════════════════════════════════ */
.section-urgency { padding: 6rem 0; background: var(--signal); overflow: hidden; }
.urgency-header  { text-align: center; margin-bottom: 3rem; }
.urgency-badge   { display: inline-flex; align-items: center; gap: .5rem; background: rgba(17,17,17,.15); border-radius: 999px; padding: .5rem 1rem; margin-bottom: 1.5rem; font-family: 'Space Mono',monospace; color: var(--negro); font-size: .75rem; text-transform: uppercase; letter-spacing: .1em; }
.urgency-title   { font-family: 'Space Grotesk',sans-serif; font-weight: 700; font-size: clamp(2.5rem,5vw,4.5rem); color: var(--negro); line-height: 1; margin: 0 0 1rem; }
.urgency-title em{ font-family: 'DM Serif Display',serif; font-style: italic; }
.urgency-desc    { font-family: 'Space Grotesk',sans-serif; color: rgba(17,17,17,.7); font-size: 1.125rem; max-width: 42rem; margin: 0 auto; line-height: 1.6; }

.urgency-countdown { display: flex; justify-content: center; margin-bottom: 3rem; }
.countdown         { background: rgba(17,17,17,.15); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); border-radius: 2rem; padding: 1.5rem; display: inline-flex; align-items: center; gap: .5rem; }
@media(min-width:768px){ .countdown { gap: 1.5rem; } }
.countdown-unit    { text-align: center; }
.countdown-num     { display: block; font-family: 'Space Mono',monospace; font-size: clamp(2.5rem,6vw,4rem); font-weight: 700; color: var(--negro); font-variant-numeric: tabular-nums; line-height: 1; }
.countdown-label   { font-family: 'Space Mono',monospace; color: rgba(17,17,17,.5); font-size: .75rem; text-transform: uppercase; letter-spacing: .1em; margin-top: .25rem; display: block; }
.countdown-sep     { font-family: 'Space Mono',monospace; font-size: clamp(2rem,5vw,3rem); font-weight: 700; color: rgba(17,17,17,.3); }

.urgency-note   { text-align: center; font-family: 'Space Grotesk',sans-serif; color: rgba(17,17,17,.6); font-size: .875rem; margin-bottom: 2.5rem; }
.urgency-points { display: grid; gap: 1rem; margin-bottom: 3rem; }
@media(min-width:768px){ .urgency-points { grid-template-columns: repeat(3,1fr); } }
.urgency-point  { background: rgba(17,17,17,.15); border-radius: 2rem; padding: 1.5rem; }
.urgency-point svg { margin-bottom: 1rem; display: block; }
.urgency-point h3  { font-family: 'Space Grotesk',sans-serif; font-weight: 600; color: var(--negro); font-size: 1rem; margin: 0 0 .5rem; }
.urgency-point p   { font-family: 'Space Grotesk',sans-serif; color: rgba(17,17,17,.6); font-size: .875rem; line-height: 1.6; }
.urgency-ctas      { display: flex; flex-direction: column; gap: 1rem; justify-content: center; }
@media(min-width:640px){ .urgency-ctas { flex-direction: row; } }
.urgency-disclaimer { text-align: center; font-family: 'Space Mono',monospace; color: rgba(17,17,17,.4); font-size: .75rem; margin-top: 1.5rem; }

/* ════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════ */
.site-footer   { background: var(--negro); border-top: 1px solid rgba(232,228,221,.1); }
.site-footer .container { padding-top: 4rem; padding-bottom: 4rem; }
.footer-grid   { display: grid; gap: 2.5rem; margin-bottom: 3rem; }
@media(min-width:768px){ .footer-grid { grid-template-columns: 2fr 1fr 1fr; } }

.footer-brand img { height: 4rem; width: auto; object-fit: contain; margin-bottom: 1.25rem; }
.footer-brand p   { font-family: 'Space Grotesk',sans-serif; color: rgba(232,228,221,.5); font-size: .875rem; line-height: 1.7; max-width: 20rem; margin-bottom: 1.5rem; }
.footer-social    { display: flex; gap: .75rem; }
.footer-social__link { width: 2.25rem; height: 2.25rem; border-radius: 50%; border: 1px solid rgba(232,228,221,.15); display: flex; align-items: center; justify-content: center; color: rgba(232,228,221,.4); transition: all .2s; }
.footer-social__link:hover { color: var(--signal); border-color: var(--signal); }

.footer-nav__title { font-family: 'Space Mono',monospace; color: rgba(232,228,221,.3); font-size: .75rem; text-transform: uppercase; letter-spacing: .1em; margin-bottom: 1rem; }
.footer-nav ul, .footer-contact ul { display: flex; flex-direction: column; gap: .75rem; }
.footer-nav a  { font-family: 'Space Grotesk',sans-serif; color: rgba(232,228,221,.5); font-size: .875rem; transition: color .2s; }
.footer-nav a:hover { color: var(--papel); }
.footer-contact li { display: flex; align-items: flex-start; gap: .75rem; }
.footer-contact a, .footer-contact span { font-family: 'Space Grotesk',sans-serif; color: rgba(232,228,221,.5); font-size: .875rem; display: flex; align-items: flex-start; gap: .75rem; transition: color .2s; }
.footer-contact a:hover { color: var(--papel); }

.footer-rule   { border: none; border-top: 1px solid rgba(232,228,221,.1); margin-bottom: 2rem; }
.footer-bottom { display: flex; flex-direction: column; gap: 1rem; align-items: center; }
@media(min-width:640px){ .footer-bottom { flex-direction: row; justify-content: space-between; } }
.footer-bottom p  { font-family: 'Space Mono',monospace; color: rgba(232,228,221,.25); font-size: .75rem; }
.footer-status    { display: flex; align-items: center; gap: .5rem; font-family: 'Space Mono',monospace; color: rgba(232,228,221,.25); font-size: .75rem; }

/* ════════════════════════════════════════════
   WHATSAPP FAB
════════════════════════════════════════════ */
.fab-wrap    { position: fixed; bottom: 1.5rem; right: 1.5rem; z-index: 100; display: flex; flex-direction: column; align-items: flex-end; gap: .75rem; }
.fab-wrap[aria-hidden="true"] .fab-btn { opacity: 0; pointer-events: none; transform: scale(.8); }
.fab-wrap.visible .fab-btn { opacity: 1; pointer-events: auto; transform: scale(1); }
.fab-btn     { width: 3.5rem; height: 3.5rem; border-radius: 50%; background: var(--wa); border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 20px rgba(0,0,0,.3); transition: transform .2s, opacity .3s; }
.fab-btn:hover { transform: scale(1.08) !important; }

.fab-panel { background: var(--negro); border: 1px solid rgba(232,228,221,.1); border-radius: 2rem; padding: 1.25rem; width: 16rem; box-shadow: 0 8px 40px rgba(0,0,0,.4); }
.fab-panel__header { display: flex; align-items: center; gap: .75rem; margin-bottom: .75rem; }
.fab-panel__avatar { width: 2.25rem; height: 2.25rem; border-radius: 50%; background: rgba(37,211,102,.2); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.fab-panel__name   { font-family: 'Space Grotesk',sans-serif; font-weight: 600; color: var(--roto); font-size: .875rem; }
.fab-panel__status { display: flex; align-items: center; gap: .375rem; }
.fab-panel__status span { font-family: 'Space Mono',monospace; color: rgba(232,228,221,.4); font-size: .625rem; }
.fab-panel__msg    { font-family: 'Space Grotesk',sans-serif; color: rgba(232,228,221,.6); font-size: .75rem; line-height: 1.6; margin-bottom: 1rem; }
.fab-panel__actions{ display: flex; flex-direction: column; gap: .5rem; }
.fab-panel__btn    { display: flex; align-items: center; justify-content: space-between; font-family: 'Space Grotesk',sans-serif; font-weight: 600; font-size: .75rem; padding: .75rem 1rem; border-radius: 1.5rem; text-decoration: none; transition: opacity .2s; }
.fab-panel__btn:hover { opacity: .9; }
.fab-panel__btn--wa   { background: var(--wa); color: #fff; }
.fab-panel__btn--call { background: rgba(232,228,221,.05); border: 1px solid rgba(232,228,221,.1); color: var(--roto); }
