/* ==========================================================================
   Rental Bliss — páginas internas y fichas.
   Reutiliza los tokens y componentes de marea.css (navy/dorado/ink,
   Clash Display/Satoshi/Bodoni). NO define colores ni fuentes nuevos.
   Sin dependencia de GSAP (.reveal): el contenido es visible por defecto.
   ========================================================================== */

/* Cabecera estándar de página interna */
.ipage-head { display:flex; flex-direction:column; gap:14px; margin-bottom:clamp(28px,4vw,48px); max-width:760px; }
.ipage-head h1 {
  font-family:var(--font-display); font-weight:500;
  font-size:clamp(2rem,4.4vw,3.4rem); line-height:1.05; letter-spacing:-.02em;
  text-wrap:balance;
}
.ipage-head h1 em { font-style:italic; font-weight:400; color:var(--gold); }
.ipage-head .lead { color:var(--ink-2); font-size:clamp(15px,1.7vw,18px); line-height:1.6; max-width:60ch; }
.nav-links a.is-current { color:var(--gold); }
.back-link { display:inline-flex; align-items:center; gap:8px; font-size:13px; letter-spacing:.04em; color:var(--ink-3); margin-bottom:22px; transition:color .3s var(--e-soft); }
.back-link svg { transform:rotate(180deg); }
.back-link:hover { color:var(--gold); }
.back-link svg { width:15px; height:11px; }

/* --------------------------------------------------------------------------
   FICHA DE PROPIEDAD (single-propiedad)
   -------------------------------------------------------------------------- */
.pd-grid { display:grid; grid-template-columns:1fr; gap:clamp(28px,4vw,56px); align-items:start; }
@media(min-width:960px){ .pd-grid { grid-template-columns:1.55fr .95fr; } }

.pd-photo { position:relative; border-radius:24px; overflow:hidden; aspect-ratio:16/10; background:var(--navy-3); border:1px solid rgba(243,177,59,.18); box-shadow:inset 0 1px 0 rgba(255,255,255,.06); }
.pd-photo img { width:100%; height:100%; object-fit:cover; }
.pd-loc { display:inline-flex; align-items:center; gap:7px; margin-top:22px; font-size:12px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-deep); }
.pd-loc svg { width:14px; height:14px; }
.pd-title { font-family:var(--font-display); font-weight:500; font-size:clamp(1.9rem,3.6vw,2.8rem); line-height:1.08; letter-spacing:-.02em; margin:10px 0 0; }
.pd-specs { list-style:none; margin:22px 0 0; padding:0; display:flex; flex-wrap:wrap; gap:10px; }
.pd-specs li { display:inline-flex; align-items:center; gap:8px; padding:9px 15px; border-radius:999px; background:rgba(255,255,255,.05); border:1px solid rgba(243,177,59,.18); font-size:13.5px; color:var(--ink-2); }
.pd-specs li b { color:var(--ink); font-weight:600; font-variant-numeric:tabular-nums; }
.pd-desc { margin-top:30px; color:var(--ink-2); font-size:16px; line-height:1.75; max-width:62ch; }
.pd-desc p { margin:0 0 1em; }

/* Tarjeta de reserva — doble-borde (shell + core) */
.pd-book { position:sticky; top:96px; padding:6px; border-radius:24px; background:var(--navy-2); border:1px solid rgba(243,177,59,.22); box-shadow:inset 0 1px 0 rgba(255,255,255,.07), 0 22px 50px -26px rgba(0,0,0,.65); }
.pd-book-core { border-radius:18px; background:#fff; box-shadow:inset 0 1px 1px rgba(255,255,255,.5); padding:26px 24px; color:var(--navy); }
.pd-price { display:flex; align-items:baseline; gap:7px; }
.pd-price small { font-size:13px; color:#5d6b78; font-weight:500; }
.pd-price strong { font-family:var(--font-display); font-weight:600; font-size:34px; letter-spacing:-.02em; color:var(--navy); font-variant-numeric:tabular-nums; }
.pd-price span { font-size:14px; color:#5d6b78; }
.pd-book-note { margin-top:12px; font-size:13px; color:#5d6b78; line-height:1.5; }
.pd-book .btn { width:100%; justify-content:center; margin-top:20px; }
.pd-avail { margin-top:18px; padding-top:18px; border-top:1px solid rgba(10,26,46,.1); font-size:13px; color:#5d6b78; line-height:1.55; display:flex; gap:9px; align-items:flex-start; }
.pd-avail svg { width:16px; height:16px; color:var(--gold-deep); flex:0 0 16px; margin-top:1px; }

/* Fila "más propiedades" reutiliza grid de tarjetas (.props2 .prop-card) */
.pd-more { margin-top:clamp(40px,6vw,72px); }

/* --------------------------------------------------------------------------
   CATÁLOGO DE PROPIEDADES (archive-propiedad) — grid usando .props2 .prop-card
   -------------------------------------------------------------------------- */
.props-grid-all { list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:24px; }
.props-grid-all .prop-card { flex:initial; min-width:0; }
@media(max-width:1024px){ .props-grid-all { grid-template-columns:repeat(3,minmax(0,1fr)); } }
@media(max-width:760px){ .props-grid-all { grid-template-columns:repeat(2,minmax(0,1fr)); gap:16px; } }
@media(max-width:480px){ .props-grid-all { grid-template-columns:1fr; } }

/* Filtro por zona (pills) */
.zona-filter { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:clamp(24px,3vw,36px); }
.zona-filter a { padding:9px 17px; border-radius:999px; font-size:13.5px; color:var(--ink-2); background:rgba(255,255,255,.05); border:1px solid rgba(243,177,59,.18); transition:background .25s var(--e-soft),color .25s,border-color .25s; }
.zona-filter a:hover { color:var(--gold); border-color:rgba(243,177,59,.45); }
.zona-filter a.is-active { background:var(--gold); color:var(--navy); border-color:var(--gold); font-weight:600; }

/* --------------------------------------------------------------------------
   FICHA / HUB DE SERVICIOS
   -------------------------------------------------------------------------- */
.sd-grid { display:grid; grid-template-columns:1fr; gap:clamp(28px,4vw,52px); align-items:start; }
@media(min-width:960px){ .sd-grid { grid-template-columns:1.6fr .9fr; } }
.sd-photo { border-radius:24px; overflow:hidden; aspect-ratio:16/10; margin-bottom:28px; border:1px solid rgba(243,177,59,.18); background:var(--navy-3); }
.sd-photo img { width:100%; height:100%; object-fit:cover; }
.sd-lead { font-family:var(--font-display); font-weight:400; font-style:italic; font-size:clamp(1.2rem,2vw,1.55rem); line-height:1.4; color:var(--ink); max-width:46ch; }
.sd-body p { color:var(--ink-2); font-size:16px; line-height:1.75; max-width:62ch; }
.sd-faq { margin-top:clamp(28px,4vw,44px); border-top:1px solid rgba(243,177,59,.16); }
.sd-faq details { border-bottom:1px solid rgba(243,177,59,.16); padding:18px 0; }
.sd-faq summary { cursor:pointer; list-style:none; font-family:var(--font-display); font-weight:500; font-size:1.05rem; color:var(--ink); display:flex; justify-content:space-between; align-items:center; gap:16px; }
.sd-faq summary::-webkit-details-marker { display:none; }
.sd-faq summary::after { content:'+'; color:var(--gold); font-size:22px; line-height:1; transition:transform .3s var(--e-soft); }
.sd-faq details[open] summary::after { transform:rotate(45deg); }
.sd-faq p { margin:12px 0 0; color:var(--ink-2); font-size:15px; line-height:1.65; }

/* Tarjeta lateral CTA (servicios + dueños) — doble-borde */
.cta-card { position:sticky; top:96px; padding:6px; border-radius:24px; background:var(--navy-2); border:1px solid rgba(243,177,59,.22); box-shadow:inset 0 1px 0 rgba(255,255,255,.07), 0 22px 50px -26px rgba(0,0,0,.65); }
.cta-card-core { border-radius:18px; background:linear-gradient(180deg,var(--navy-3),var(--navy-2)); padding:26px 24px; box-shadow:inset 0 1px 1px rgba(255,255,255,.08); }
.cta-card .price { font-family:var(--font-display); font-weight:600; font-size:26px; color:var(--gold); letter-spacing:-.01em; font-variant-numeric:tabular-nums; }
.cta-card .label { font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-3); margin-bottom:6px; }
.cta-card p { color:var(--ink-2); font-size:14px; line-height:1.6; margin:14px 0 0; }
.cta-card .btn { width:100%; justify-content:center; margin-top:18px; }

/* Hub de servicios — grid reutilizando .svc-core */
.svc-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:20px; }
.svc-grid .svc { grid-column:auto !important; grid-row:auto !important; }

/* --------------------------------------------------------------------------
   PÁGINA DUEÑOS (la página dinero)
   -------------------------------------------------------------------------- */
.lede-cta { margin-top:30px; display:flex; flex-wrap:wrap; gap:14px; }

.triada { display:grid; grid-template-columns:1fr; gap:20px; }
@media(min-width:820px){ .triada { grid-template-columns:repeat(3,1fr); } }
.triada-card { padding:6px; border-radius:22px; background:var(--navy-2); border:1px solid rgba(243,177,59,.18); box-shadow:inset 0 1px 0 rgba(255,255,255,.06); }
.triada-core { border-radius:16px; background:linear-gradient(180deg,var(--navy-3),var(--navy-2)); padding:28px 26px; height:100%; box-shadow:inset 0 1px 1px rgba(255,255,255,.07); }
.triada-ic { width:46px; height:46px; border-radius:12px; display:grid; place-items:center; background:rgba(243,177,59,.12); color:var(--gold); margin-bottom:18px; }
.triada-ic svg { width:24px; height:24px; }
.triada-card h3 { font-family:var(--font-display); font-weight:500; font-size:1.3rem; line-height:1.2; margin:0 0 10px; }
.triada-card p { color:var(--ink-2); font-size:15px; line-height:1.6; margin:0; }

/* Tarifa transparente */
.fee-band { display:grid; grid-template-columns:1fr; gap:clamp(24px,4vw,48px); align-items:center; }
@media(min-width:880px){ .fee-band { grid-template-columns:auto 1fr; } }
.fee-num { font-family:var(--font-display); font-weight:600; font-size:clamp(3.4rem,8vw,5.2rem); line-height:.9; color:var(--gold); letter-spacing:-.03em; font-variant-numeric:tabular-nums; }
.fee-num span { font-size:.4em; vertical-align:.7em; }
.fee-copy h2 { font-family:var(--font-display); font-weight:500; font-size:clamp(1.5rem,2.6vw,2.1rem); line-height:1.15; margin:0 0 12px; letter-spacing:-.01em; }
.fee-copy h2 em { font-style:italic; color:var(--gold); }
.fee-copy p { color:var(--ink-2); font-size:16px; line-height:1.7; max-width:54ch; margin:0; }

/* Prueba (stats sobre fondo arena) */
.proof-grid { display:grid; grid-template-columns:1fr 1fr; gap:36px 24px; }
@media(min-width:880px){ .proof-grid { grid-template-columns:auto repeat(3,1fr); align-items:center; gap:48px; } }
.proof-lead { font-family:var(--font-display); font-weight:500; font-size:clamp(1.4rem,2.4vw,2rem); line-height:1.08; letter-spacing:-.02em; grid-column:1/-1; color:var(--ink-dark); }
@media(min-width:880px){ .proof-lead { grid-column:auto; max-width:14ch; } }
.proof-num { font-family:var(--font-display); font-style:italic; font-weight:400; font-size:clamp(2.6rem,5vw,3.6rem); line-height:.95; color:var(--gold-deep); font-variant-numeric:tabular-nums; letter-spacing:-.03em; }
.proof-num sup { font-size:.42em; vertical-align:.5em; }
.proof-lbl { font-size:13px; color:var(--ink-dark-2); line-height:1.4; margin-top:8px; }

/* Bloque CONFOTUR / pasos */
.steps { display:grid; grid-template-columns:1fr; gap:18px; counter-reset:step; }
@media(min-width:760px){ .steps { grid-template-columns:repeat(3,1fr); } }
.step { padding:26px 24px; border-radius:18px; background:rgba(255,255,255,.04); border:1px solid rgba(243,177,59,.16); }
.step::before { counter-increment:step; content:counter(step); font-family:var(--font-display); font-weight:600; font-size:20px; color:var(--gold); display:inline-grid; place-items:center; width:38px; height:38px; border-radius:999px; background:rgba(243,177,59,.12); margin-bottom:16px; }
.step h3 { font-family:var(--font-display); font-weight:500; font-size:1.15rem; margin:0 0 8px; }
.step p { color:var(--ink-2); font-size:14.5px; line-height:1.6; margin:0; }

/* --------------------------------------------------------------------------
   HISTORIA
   -------------------------------------------------------------------------- */
.story-grid { display:grid; grid-template-columns:1fr; gap:clamp(28px,4vw,52px); align-items:center; }
@media(min-width:880px){ .story-grid { grid-template-columns:.9fr 1.1fr; } }
.story-photo { border-radius:24px; overflow:hidden; aspect-ratio:4/5; background:var(--navy-3); border:1px solid rgba(243,177,59,.2); display:grid; place-items:center; box-shadow:inset 0 1px 0 rgba(255,255,255,.06); }
.story-photo img { width:100%; height:100%; object-fit:cover; }
.story-photo .ph-note { padding:24px; text-align:center; color:var(--ink-3); font-size:13px; line-height:1.5; }
.story-body p { color:var(--ink-2); font-size:16.5px; line-height:1.8; max-width:60ch; margin:0 0 1.1em; }
.story-body p:first-of-type { font-family:var(--font-display); font-weight:400; font-style:italic; font-size:clamp(1.2rem,2vw,1.5rem); color:var(--ink); line-height:1.45; }
.signature { margin-top:26px; font-family:var(--font-display); font-style:italic; font-size:18px; color:var(--gold); }

/* --------------------------------------------------------------------------
   CONTACTO
   -------------------------------------------------------------------------- */
.contact-grid { display:grid; grid-template-columns:1fr; gap:20px; }
@media(min-width:760px){ .contact-grid { grid-template-columns:repeat(3,1fr); } }
.contact-card { padding:28px 26px; border-radius:20px; background:var(--navy-2); border:1px solid rgba(243,177,59,.18); box-shadow:inset 0 1px 0 rgba(255,255,255,.06); display:flex; flex-direction:column; gap:10px; }
.contact-card .ic { width:46px; height:46px; border-radius:12px; display:grid; place-items:center; background:rgba(243,177,59,.12); color:var(--gold); margin-bottom:6px; }
.contact-card .ic svg { width:23px; height:23px; }
.contact-card h3 { font-family:var(--font-display); font-weight:500; font-size:1.2rem; margin:0; }
.contact-card p { color:var(--ink-2); font-size:14.5px; line-height:1.6; margin:0; }
.contact-card a.line { color:var(--gold); font-size:15px; word-break:break-word; }
.contact-card a.line:hover { text-decoration:underline; }
.contact-areas { margin-top:clamp(30px,4vw,48px); padding-top:clamp(26px,3vw,36px); border-top:1px solid rgba(243,177,59,.16); display:flex; flex-wrap:wrap; gap:10px; align-items:center; }
.contact-areas span:first-child { font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-3); margin-right:8px; }
.contact-areas .pill { padding:8px 15px; border-radius:999px; background:rgba(255,255,255,.05); border:1px solid rgba(243,177,59,.18); font-size:13.5px; color:var(--ink-2); }

/* fondo arena reutilizable para secciones claras */
.panel-sand { background:var(--sand); color:var(--ink-dark); }
.panel-sand .section-title, .panel-sand h2 { color:var(--ink-dark); }
.panel-sand .eyebrow { color:var(--gold-deep); }
.panel-sand .eyebrow::before { background:var(--gold-deep); }

/* --------------------------------------------------------------------------
   Accesibilidad (focus visible) + micro-interacción táctil.
   Reutiliza --gold y --e-out: no introduce colores ni fuentes.
   -------------------------------------------------------------------------- */
.back-link:focus-visible,
.zona-filter a:focus-visible,
.svc-grid .svc-core:focus-visible,
.contact-card a.line:focus-visible,
.sd-faq summary:focus-visible { outline:2px solid var(--gold); outline-offset:3px; border-radius:8px; }
.props-grid-all .prop-card:focus-within { border-color:rgba(243,177,59,.55); }

.triada-card, .contact-card, .step { transition:transform .45s var(--e-out), border-color .4s var(--e-out); }
.triada-card:hover, .contact-card:hover, .step:hover { transform:translateY(-4px); border-color:rgba(243,177,59,.4); }

@media (prefers-reduced-motion: reduce) {
	.triada-card, .contact-card, .step { transition:none; }
	.triada-card:hover, .contact-card:hover, .step:hover { transform:none; }
	.sd-faq details[open] summary::after { transition:none; }
}
