:root {
  --sv-velvet: #750851;
  --sv-velvet-soft: #b03787;
  --sv-petrol: #142b36;
  --sv-petrol-2: #203f4b;
  --sv-ivory: #fffaf0;
  --sv-sand: #f3e6d4;
  --sv-graphite: #33343a;
  --sv-muted: rgba(51,52,58,.72);
  --sv-border: rgba(117,8,81,.14);
  --sv-shadow: 0 20px 60px rgba(20,43,54,.14);
  --sv-shadow-soft: 0 10px 30px rgba(20,43,54,.09);
  --sv-radius: 28px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.svt-body { margin: 0; color: var(--sv-graphite); background: var(--sv-ivory); font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
img, video { max-width: 100%; height: auto; display: block; }
button { font: inherit; }
.sv-container { width: min(1180px, calc(100% - 40px)); margin: 0 auto; }
.sv-icon { width: 20px; height: 20px; flex: 0 0 auto; }
.sv-header { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; transition: .3s ease; }
.sv-header.is-scrolled { background: rgba(255,250,240,.92); box-shadow: var(--sv-shadow-soft); backdrop-filter: blur(18px); }
.sv-header__inner { min-height: 78px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.sv-logo { display: inline-flex; align-items: center; gap: 12px; font-weight: 700; color: var(--sv-petrol); }
.sv-logo__mark { width: 34px; height: 34px; border-radius: 999px; background: linear-gradient(135deg, var(--sv-velvet), var(--sv-velvet-soft)); box-shadow: 0 12px 28px rgba(117,8,81,.32); display: inline-block; }
.sv-logo__text { font-family: "Cormorant Garamond", Georgia, serif; font-size: 29px; line-height: 1; }
.custom-logo { max-height: 58px; width: auto; }
.sv-nav { display: flex; align-items: center; gap: 24px; font-size: 14px; color: rgba(51,52,58,.82); }
.sv-nav a { transition: .25s ease; }
.sv-nav a:hover { color: var(--sv-velvet); }
.sv-btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; border: 0; border-radius: 999px; padding: 13px 22px; background: var(--sv-velvet); color: white; font-weight: 700; box-shadow: 0 16px 38px rgba(117,8,81,.22); transition: .25s ease; cursor: pointer; }
.sv-btn:hover { transform: translateY(-2px); filter: brightness(1.06); }
.sv-btn--ghost { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.32); color: var(--sv-ivory); box-shadow: none; backdrop-filter: blur(12px); }
.sv-btn--large { padding: 18px 34px; font-size: 18px; }
.sv-menu-btn { display: none; width: 44px; height: 44px; border: 0; border-radius: 999px; background: var(--sv-petrol); padding: 11px; cursor: pointer; }
.sv-menu-btn span { display: block; height: 2px; background: var(--sv-ivory); margin: 5px 0; border-radius: 10px; }
.sv-mobile-menu { display: none; background: rgba(255,250,240,.98); box-shadow: var(--sv-shadow); padding: 0 24px 24px; }
.sv-mobile-menu a:not(.sv-btn) { display: block; padding: 14px 0; border-bottom: 1px solid rgba(117,8,81,.1); color: var(--sv-graphite); }
.sv-hero { min-height: 100vh; position: relative; display: flex; align-items: center; overflow: hidden; padding: 120px 0 76px; background: radial-gradient(circle at 22% 22%, rgba(176,55,135,.32), transparent 34%), linear-gradient(135deg, #142b36 0%, #203f4b 55%, #750851 130%); }
.sv-orb { position: absolute; border-radius: 999px; filter: blur(20px); opacity: .46; pointer-events: none; }
.sv-orb--one { width: 380px; height: 380px; left: -120px; top: 110px; background: rgba(117,8,81,.48); }
.sv-orb--two { width: 420px; height: 420px; right: -130px; bottom: -80px; background: rgba(243,230,212,.16); }
.sv-hero__grid { display: grid; grid-template-columns: 1.05fr .8fr; gap: 70px; align-items: center; position: relative; z-index: 1; }
.sv-eyebrow { display: inline-flex; align-items: center; gap: 10px; color: var(--sv-velvet); font-size: 12px; text-transform: uppercase; letter-spacing: .23em; font-weight: 800; }
.sv-eyebrow span { width: 28px; height: 1px; background: currentColor; display: inline-block; }
.sv-hero .sv-eyebrow, .sv-final-cta .sv-eyebrow { color: #f2a6d4; }
.sv-hero h1, .sv-final-cta h2, .sv-section-title h2 { font-family: "Cormorant Garamond", Georgia, serif; font-weight: 700; letter-spacing: -.02em; margin: 0; }
.sv-hero h1 { color: var(--sv-ivory); font-size: clamp(44px, 6vw, 76px); line-height: .98; max-width: 780px; margin: 22px 0; }
.sv-hero h1 em, .sv-final-cta em { color: #f2a6d4; font-style: normal; }
.sv-hero p { color: rgba(255,250,240,.82); font-size: 20px; line-height: 1.65; max-width: 590px; margin: 0 0 30px; }
.sv-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 36px; }
.sv-badges { display: flex; flex-wrap: wrap; gap: 14px 22px; color: rgba(255,250,240,.86); }
.sv-badge { display: inline-flex; align-items: center; gap: 9px; font-size: 14px; }
.sv-badge .sv-icon { width: 35px; height: 35px; padding: 8px; border-radius: 999px; color: #f2a6d4; background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.18); }
.sv-hero__visual { position: relative; min-height: 560px; border-radius: 34px; overflow: hidden; box-shadow: 0 24px 80px rgba(0,0,0,.28); }
.sv-placeholder { position: relative; min-height: 260px; background: radial-gradient(circle at 26% 18%, rgba(255,250,240,.26), transparent 30%), radial-gradient(circle at 78% 82%, rgba(0,0,0,.28), transparent 48%), linear-gradient(135deg, #1a2a38, #750851); overflow: hidden; }
.sv-placeholder span, .sv-gallery-item span { position: absolute; left: 20px; right: 20px; bottom: 18px; color: rgba(255,250,240,.92); font-weight: 700; letter-spacing: .02em; }
.sv-placeholder--hero { height: 100%; min-height: 560px; }
.sv-hero__note { position: absolute; left: 24px; right: 24px; bottom: 24px; padding: 20px; border-radius: 22px; background: rgba(255,250,240,.11); border: 1px solid rgba(255,250,240,.2); color: var(--sv-ivory); backdrop-filter: blur(14px); }
.sv-section { padding: 96px 0; }
.sv-section--warm { background: linear-gradient(135deg, var(--sv-ivory), var(--sv-sand)); }
.sv-section--plain { background: var(--sv-ivory); }
.sv-section-title { max-width: 680px; margin-bottom: 52px; }
.sv-section-title--center { text-align: center; margin-left: auto; margin-right: auto; }
.sv-section-title h2 { color: var(--sv-petrol); font-size: clamp(36px, 5vw, 58px); line-height: 1.02; margin-top: 12px; }
.sv-section-title p { color: var(--sv-muted); font-size: 18px; line-height: 1.7; margin: 16px 0 0; }
.sv-benefits-grid, .sv-services-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.sv-card, .sv-service-card, .sv-amenity, .sv-info-grid div { background: rgba(255,255,255,.78); border: 1px solid var(--sv-border); border-radius: 24px; box-shadow: var(--sv-shadow-soft); }
.sv-card { padding: 28px; transition: .35s ease; }
.sv-card:hover, .sv-service-card:hover, .sv-amenity:hover { transform: translateY(-5px); box-shadow: var(--sv-shadow); }
.sv-card-icon { width: 58px; height: 58px; display: flex; align-items: center; justify-content: center; border-radius: 20px; color: white; background: linear-gradient(135deg, var(--sv-velvet), var(--sv-velvet-soft)); margin-bottom: 20px; }
.sv-card-icon .sv-icon { width: 30px; height: 30px; }
.sv-card h3, .sv-service-card h3, .sv-model-card h3 { font-family: "Cormorant Garamond", Georgia, serif; color: var(--sv-petrol); font-size: 29px; line-height: 1; margin: 0 0 10px; }
.sv-card p, .sv-model-card p { color: var(--sv-muted); line-height: 1.65; margin: 0; }
.sv-services-grid { align-items: stretch; }
.sv-service-card { position: relative; padding: 30px; display: flex; flex-direction: column; transition: .35s ease; }
.sv-service-card.is-popular { background: var(--sv-petrol); color: var(--sv-ivory); border-color: var(--sv-petrol); }
.sv-popular { position: absolute; top: -14px; left: 26px; padding: 7px 13px; border-radius: 999px; background: var(--sv-velvet); color: white; font-size: 12px; font-weight: 800; }
.sv-duration { color: var(--sv-velvet); text-transform: uppercase; letter-spacing: .12em; font-size: 12px; font-weight: 800; margin-bottom: 10px; }
.sv-service-card.is-popular .sv-duration { color: #f2a6d4; }
.sv-service-card strong { font-family: "Cormorant Garamond", Georgia, serif; color: var(--sv-petrol); font-size: 38px; line-height: 1; margin: 10px 0 20px; }
.sv-service-card.is-popular h3, .sv-service-card.is-popular strong { color: var(--sv-ivory); }
.sv-service-card ul { margin: 0 0 26px; padding: 0; list-style: none; flex: 1; color: var(--sv-muted); }
.sv-service-card.is-popular ul { color: rgba(255,250,240,.78); }
.sv-service-card li { margin: 10px 0; padding-left: 18px; position: relative; }
.sv-service-card li:before { content: ''; width: 6px; height: 6px; border-radius: 999px; background: var(--sv-velvet); position: absolute; left: 0; top: .62em; }
.sv-service-card a { display: inline-flex; align-items: center; justify-content: center; gap: 8px; border-radius: 999px; background: var(--sv-petrol); color: white; padding: 13px; font-weight: 800; }
.sv-service-card.is-popular a { background: var(--sv-velvet); }
.sv-models-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.sv-model-card { overflow: hidden; border-radius: 28px; background: rgba(255,255,255,.8); border: 1px solid var(--sv-border); box-shadow: var(--sv-shadow-soft); transition: .35s ease; }
.sv-model-card:hover { transform: translateY(-5px); box-shadow: var(--sv-shadow); }
.sv-model-card__image { min-height: 430px; background-size: cover; background-position: center; }
.sv-model-card__body { padding: 22px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.sv-model-card__body p { margin-top: 4px; }
.sv-model-card__actions { display: flex; gap: 10px; flex-wrap: wrap; }
.sv-model-card__actions button, .sv-model-card__actions a { border: 0; background: transparent; color: var(--sv-velvet); font-weight: 800; cursor: pointer; padding: 0; }
.sv-videos-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 250px)); gap: 24px; justify-content: center; }
.sv-phone-video { aspect-ratio: 9/19; border-radius: 34px; padding: 9px; background: var(--sv-petrol); box-shadow: var(--sv-shadow); }
.sv-phone-video > div { height: 100%; border-radius: 26px; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 12px; text-align: center; overflow: hidden; color: var(--sv-ivory); background: radial-gradient(circle at 30% 20%, rgba(255,250,240,.22), transparent 32%), linear-gradient(135deg, #203f4b, #750851); }
.sv-phone-video video, .sv-phone-video iframe { width: 100%; height: 100%; object-fit: cover; border: 0; border-radius: 26px; }
.sv-phone-video .sv-icon { width: 28px; height: 28px; color: #f2a6d4; }
.sv-gallery-grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 190px; gap: 18px; }
.sv-gallery-item { position: relative; border: 0; border-radius: 24px; overflow: hidden; cursor: pointer; box-shadow: var(--sv-shadow-soft); background: radial-gradient(circle at 26% 18%, rgba(255,250,240,.24), transparent 30%), linear-gradient(135deg, #203f4b, #750851); transition: .35s ease; }
.sv-gallery-item:hover { transform: scale(1.015); box-shadow: var(--sv-shadow); }
.sv-gallery-item--1 { grid-column: span 2; grid-row: span 2; }
.sv-gallery-item--5 { grid-column: span 2; }
.sv-amenities-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.sv-amenity { padding: 26px 18px; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 12px; transition: .35s ease; }
.sv-amenity .sv-icon { width: 48px; height: 48px; padding: 12px; color: var(--sv-velvet); border-radius: 999px; background: rgba(117,8,81,.08); border: 1px solid rgba(117,8,81,.12); }
.sv-location-grid { display: grid; grid-template-columns: 1fr .86fr; gap: 54px; align-items: center; }
.sv-info-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-bottom: 28px; }
.sv-info-grid div { padding: 18px; }
.sv-info-grid span { display: block; color: var(--sv-velvet); text-transform: uppercase; letter-spacing: .12em; font-size: 12px; font-weight: 800; margin-bottom: 7px; }
.sv-info-grid strong { color: var(--sv-petrol); }
.sv-payments { margin-top: 34px; }
.sv-payments h3 { color: var(--sv-velvet); text-transform: uppercase; letter-spacing: .12em; font-size: 13px; }
.sv-payments span { display: inline-flex; margin: 0 8px 8px 0; padding: 10px 15px; border-radius: 999px; background: white; border: 1px solid var(--sv-border); }
.sv-map-card { min-height: 520px; border-radius: 34px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; color: var(--sv-ivory); text-align: center; background: linear-gradient(135deg, var(--sv-petrol), var(--sv-velvet)); box-shadow: var(--sv-shadow); position: relative; overflow: hidden; }
.sv-map-card:before { content: ''; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,250,240,.12) 1px, transparent 1px), linear-gradient(90deg, rgba(255,250,240,.12) 1px, transparent 1px); background-size: 42px 42px; opacity: .45; }
.sv-map-card .sv-icon { position: relative; width: 74px; height: 74px; padding: 17px; border-radius: 999px; background: var(--sv-velvet); box-shadow: 0 14px 44px rgba(117,8,81,.38); }
.sv-map-card strong, .sv-map-card span { position: relative; }
.sv-map-card strong { font-family: "Cormorant Garamond", Georgia, serif; font-size: 32px; }
.sv-faq-container { max-width: 820px; }
.sv-faq { display: grid; gap: 14px; }
.sv-faq-item { border-radius: 22px; border: 1px solid var(--sv-border); background: rgba(255,255,255,.82); overflow: hidden; box-shadow: var(--sv-shadow-soft); }
.sv-faq-item button { width: 100%; display: flex; justify-content: space-between; align-items: center; text-align: left; border: 0; background: transparent; padding: 22px 24px; cursor: pointer; color: var(--sv-petrol); font-weight: 800; }
.sv-faq-item button b { color: var(--sv-velvet); transition: .3s ease; }
.sv-faq-item.is-open button b { transform: rotate(180deg); }
.sv-faq-item div { display: grid; grid-template-rows: 0fr; transition: .3s ease; }
.sv-faq-item.is-open div { grid-template-rows: 1fr; }
.sv-faq-item p { overflow: hidden; padding: 0 24px; margin: 0; color: var(--sv-muted); line-height: 1.7; }
.sv-faq-item.is-open p { padding-bottom: 22px; }
.sv-final-cta { padding: 105px 0; text-align: center; color: var(--sv-ivory); background: radial-gradient(circle at 30% 40%, rgba(176,55,135,.4), transparent 36%), linear-gradient(135deg, var(--sv-petrol), var(--sv-velvet)); }
.sv-final-cta h2 { font-size: clamp(42px, 6vw, 72px); line-height: 1; margin: 20px auto; max-width: 820px; }
.sv-final-cta p { margin: 0 auto 34px; max-width: 610px; color: rgba(255,250,240,.78); font-size: 19px; line-height: 1.65; }
.sv-footer { background: var(--sv-petrol); color: rgba(255,250,240,.72); padding: 58px 0 30px; }
.sv-footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 36px; }
.sv-footer .sv-logo__text, .sv-footer .sv-logo { color: var(--sv-ivory); }
.sv-footer h4 { color: #f2a6d4; text-transform: uppercase; letter-spacing: .12em; font-size: 13px; }
.sv-footer p { line-height: 1.7; margin: 0; }
.sv-footer a:hover, .sv-footer strong { color: #f2a6d4; }
.sv-footer__bottom { margin-top: 34px; padding-top: 22px; border-top: 1px solid rgba(255,250,240,.12); display: flex; justify-content: space-between; gap: 14px; font-size: 13px; }
.sv-floating-wa { position: fixed; right: 22px; bottom: 22px; z-index: 999; width: 58px; height: 58px; border-radius: 999px; display: flex; align-items: center; justify-content: center; color: white; background: var(--sv-velvet); box-shadow: 0 16px 38px rgba(117,8,81,.36); transition: .25s ease; }
.sv-floating-wa:hover { transform: scale(1.08); }
.sv-floating-wa .sv-icon { width: 31px; height: 31px; }
.sv-lightbox { position: fixed; inset: 0; z-index: 2000; display: none; align-items: center; justify-content: center; padding: 24px; background: rgba(20,43,54,.88); backdrop-filter: blur(10px); }
.sv-lightbox.is-open { display: flex; }
.sv-lightbox button { position: absolute; top: 24px; right: 24px; width: 48px; height: 48px; border-radius: 999px; border: 1px solid rgba(255,250,240,.2); background: rgba(255,250,240,.12); color: white; font-size: 32px; cursor: pointer; }
.sv-lightbox > div { width: min(900px, 92vw); aspect-ratio: 4 / 3; border-radius: 30px; overflow: hidden; box-shadow: var(--sv-shadow); background: radial-gradient(circle at 26% 18%, rgba(255,250,240,.24), transparent 30%), linear-gradient(135deg, #203f4b, #750851); position: relative; }
.sv-lightbox span { position: absolute; left: 28px; bottom: 24px; color: white; font-family: "Cormorant Garamond", Georgia, serif; font-size: 40px; font-weight: 700; }
@media (max-width: 1100px) {
  .sv-nav, .sv-btn--header { display: none; }
  .sv-menu-btn { display: block; }
  .sv-mobile-menu.is-open { display: block; }
  .sv-hero__grid, .sv-location-grid { grid-template-columns: 1fr; }
  .sv-hero__visual { min-height: 440px; }
  .sv-benefits-grid, .sv-services-grid, .sv-amenities-grid { grid-template-columns: repeat(2, 1fr); }
  .sv-models-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 720px) {
  .sv-container { width: min(100% - 28px, 1180px); }
  .sv-header__inner { min-height: 68px; }
  .sv-logo__text { font-size: 24px; }
  .sv-hero { padding-top: 100px; }
  .sv-hero h1 { font-size: 46px; }
  .sv-hero p { font-size: 17px; }
  .sv-actions .sv-btn { width: 100%; }
  .sv-section { padding: 72px 0; }
  .sv-benefits-grid, .sv-services-grid, .sv-models-grid, .sv-amenities-grid, .sv-videos-grid, .sv-info-grid, .sv-footer__grid { grid-template-columns: 1fr; }
  .sv-gallery-grid { grid-template-columns: 1fr; grid-auto-rows: 240px; }
  .sv-gallery-item--1, .sv-gallery-item--5 { grid-column: auto; grid-row: auto; }
  .sv-model-card__image { min-height: 380px; }
  .sv-map-card { min-height: 360px; }
  .sv-footer__bottom { flex-direction: column; }
}
.sv-lightbox > div.has-images { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; aspect-ratio: auto; padding: 10px; background: rgba(255,250,240,.08); }
.sv-lightbox > div.has-images img { width: 100%; height: 230px; object-fit: cover; border-radius: 18px; }
.sv-lightbox > div.has-images span { position: static; grid-column: 1 / -1; padding: 10px 12px 4px; font-size: 34px; }
@media (max-width: 720px) { .sv-lightbox > div.has-images { grid-template-columns: 1fr; overflow:auto; max-height: 86vh; } .sv-lightbox > div.has-images img { height: 260px; } }


/* 2026-07-03 ajustes solicitados: hero full width, sin cuadro lateral, layout centrado y responsive */
.sv-hero__grid--full { grid-template-columns: 1fr; gap: 0; justify-items: center; text-align: center; }
.sv-hero__content--centered { max-width: 980px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; }
.sv-hero__content--centered .sv-eyebrow,
.sv-section-title--center .sv-eyebrow,
.sv-final-cta .sv-eyebrow { justify-content: center; }
.sv-hero__content--centered h1,
.sv-hero__content--centered p { max-width: 980px; }
.sv-hero__content--centered p { margin-left: auto; margin-right: auto; }
.sv-hero__content--centered .sv-actions,
.sv-hero__content--centered .sv-badges { justify-content: center; }
.sv-hero__note--inline { position: static; margin-top: 26px; width: min(100%, 520px); text-align: center; }

.sv-section-title { margin-left: auto; margin-right: auto; text-align: center; }
.sv-benefit,
.sv-card,
.sv-service-card,
.sv-model-card__body,
.sv-info-grid div,
.sv-payments,
.sv-footer,
.sv-footer__bottom { text-align: center; }
.sv-card-icon { margin-left: auto; margin-right: auto; }
.sv-service-card { align-items: center; }
.sv-service-card ul { text-align: left; width: 100%; max-width: 240px; margin-left: auto; margin-right: auto; }
.sv-model-card__body { flex-direction: column; justify-content: center; }
.sv-model-card__actions { justify-content: center; }
.sv-location-grid { justify-items: center; }
.sv-location-grid > div:first-child { width: 100%; max-width: 760px; text-align: center; }
.sv-info-grid { max-width: 720px; margin-left: auto; margin-right: auto; }
.sv-payments span { margin-left: 4px; margin-right: 4px; }
.sv-footer__grid > div { text-align: center; }
.sv-footer .sv-logo--footer { justify-content: center; }
.sv-footer__bottom { align-items: center; }

@media (max-width: 1100px) {
  .sv-hero__grid--full { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .sv-hero { min-height: auto; }
  .sv-hero h1 { font-size: clamp(40px, 11vw, 56px); }
  .sv-hero__note--inline { width: 100%; padding: 18px; }
  .sv-badges { gap: 12px; }
  .sv-badge { justify-content: center; width: 100%; }
  .sv-location-grid > div:first-child { max-width: none; }
}
