/* ============================================
   PALMAS DE LA ROMANA — 1122 Real Estate
   Brand: Navy #1F2C50 · Gold #D4A634
   ============================================ */

:root{
  --primary:#1F2C50;        /* navy */
  --primary-dark:#141C36;
  --primary-light:#2C3D6E;
  --navy:#1F2C50;
  --navy-dark:#141C36;
  --accent:#D4A634;         /* gold */
  --accent-dark:#B8902A;
  --accent-light:#E5BE5C;
  --gold:#D4A634;
  --gold-light:#E5BE5C;
  --cream:#F8F6F1;
  --sand:#EDE8DC;
  --ink:#1A1A1A;
  --muted:#5B5B5B;
  --line:#E3DED2;
  --white:#fff;

  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --container: 1180px;
  --radius:14px;
  --radius-sm:8px;
  --shadow-sm:0 2px 8px rgba(20,28,54,.06);
  --shadow-md:0 12px 32px rgba(20,28,54,.10);
  --shadow-lg:0 24px 60px rgba(20,28,54,.18);

  --t:.25s ease;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--white);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,picture,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 20px;
}

.skip-link{
  position:absolute; left:-9999px; top:8px;
  background:var(--navy); color:#fff; padding:10px 14px; border-radius:6px; z-index:9999;
}
.skip-link:focus{left:8px}

/* ============== TYPE ============== */
h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:600;
  letter-spacing:-.01em;
  line-height:1.15;
  margin:0 0 .4em;
  color:var(--navy);
}
h1{font-size:clamp(2.2rem, 5.5vw, 3.8rem); letter-spacing:-.02em}
h2{font-size:clamp(1.7rem, 3.8vw, 2.6rem)}
h3{font-size:clamp(1.2rem, 2.4vw, 1.5rem)}
h4{font-size:1.05rem; font-family:var(--sans); font-weight:700}
em{font-style:italic; color:var(--accent-dark); font-weight:500}
p{margin:0 0 1em}
.eyebrow{
  display:inline-block;
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--accent-dark);
  margin-bottom:.7em;
}
.eyebrow.light{color:var(--gold-light)}
.lead{font-size:1.08rem; color:var(--muted); max-width:60ch}
.muted{color:var(--muted)}

/* ============== NAV ============== */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color var(--t), box-shadow var(--t);
}
.nav.scrolled{border-bottom-color:var(--line); box-shadow:var(--shadow-sm)}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  height:68px;
}
.nav-actions{
  display:flex; align-items:center; gap:12px;
}
.brand{
  display:inline-flex; align-items:center;
  color:var(--primary);
}
.brand-logo{
  display:block;
  width:auto;
  height:38px;
  max-width:112px;
}

.nav-menu{display:flex; align-items:center; gap:6px}
.nav-menu a{
  padding:10px 14px; border-radius:8px;
  font-size:.92rem; font-weight:500; color:var(--navy);
  transition:background var(--t), color var(--t);
}
.nav-menu a:hover{background:var(--sand); color:var(--primary)}
.nav-cta{
  background:var(--accent)!important; color:var(--navy-dark)!important; padding:10px 18px!important;
  margin-left:8px; font-weight:700;
}
.nav-cta:hover{background:var(--accent-dark)!important; color:#fff!important}

.nav-toggle{
  display:none;
  width:42px; height:42px;
  flex-direction:column; align-items:center; justify-content:center; gap:5px;
  border-radius:8px;
}
.lang-toggle{
  display:inline-flex; align-items:center; gap:8px;
  min-height:42px; padding:0 14px;
  border:1px solid rgba(31,44,80,.14);
  border-radius:999px;
  background:rgba(248,246,241,.85);
  color:var(--navy);
  font-size:.82rem; font-weight:700; letter-spacing:.08em;
  text-transform:uppercase;
  transition:background var(--t), border-color var(--t), transform var(--t), box-shadow var(--t);
}
.lang-toggle:hover{
  background:#fff;
  border-color:rgba(31,44,80,.22);
  transform:translateY(-1px);
  box-shadow:var(--shadow-sm);
}
.lang-toggle svg{
  width:16px; height:16px;
  color:var(--accent-dark);
  flex-shrink:0;
}
.lang-option{opacity:.45; transition:opacity var(--t), color var(--t)}
.lang-option.is-active{opacity:1; color:var(--navy-dark)}
.lang-separator{opacity:.28}
.nav-toggle span{width:22px; height:2px; background:var(--navy); border-radius:2px; transition:transform .3s, opacity .3s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:860px){
  .nav-inner{height:64px}
  .nav-toggle{display:flex}
  .nav-menu{
    position:absolute; top:64px; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:0;
    background:#fff; border-bottom:1px solid var(--line);
    padding:8px 16px 16px;
    transform:translateY(-12px); opacity:0; pointer-events:none;
    transition:transform .25s ease, opacity .25s ease;
  }
  .nav-menu.open{transform:translateY(0); opacity:1; pointer-events:auto}
  .nav-menu a{padding:14px 8px; border-bottom:1px solid var(--line); border-radius:0}
  .nav-menu a:last-child{border-bottom:0}
  .nav-cta{margin:10px 0 0!important; text-align:center; border-radius:8px!important}
  .lang-toggle{padding:0 12px; min-height:40px; font-size:.76rem}
}

/* ============== BUTTONS ============== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:14px 26px; border-radius:999px;
  font-weight:600; font-size:.95rem; letter-spacing:.01em;
  transition:transform var(--t), background var(--t), color var(--t), box-shadow var(--t);
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--accent); color:var(--navy-dark); box-shadow:0 8px 22px rgba(212,166,52,.35)}
.btn-primary:hover{background:var(--accent-dark); color:#fff; box-shadow:0 12px 28px rgba(212,166,52,.5)}
.btn-outline{border:1.5px solid var(--primary); color:var(--primary)}
.btn-outline:hover{background:var(--primary); color:#fff}
.btn-ghost{background:rgba(255,255,255,.18); color:#fff; border:1px solid rgba(255,255,255,.5); backdrop-filter:blur(8px)}
.btn-ghost:hover{background:rgba(255,255,255,.28)}
.btn-block{width:100%}

/* ============== HERO ============== */
.hero{
  position:relative; isolation:isolate;
  min-height:min(94vh, 760px);
  display:flex; align-items:flex-end;
  color:#fff;
  padding:120px 0 70px;
  overflow:hidden;
}
.hero-bg{position:absolute; inset:0; z-index:-2}
.hero-bg img{width:100%; height:100%; object-fit:cover}
.hero-overlay{
  position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(180deg, rgba(20,28,54,.25) 0%, rgba(20,28,54,.45) 60%, rgba(20,28,54,.85) 100%),
    radial-gradient(80% 60% at 30% 70%, rgba(31,44,80,.4), transparent 70%);
}
.hero-content{position:relative}
.hero h1{color:#fff; margin-bottom:.3em; max-width:18ch}
.hero h1 em{color:var(--gold-light)}
.hero .eyebrow{color:var(--gold-light); margin-bottom:1em}
.hero-sub{color:rgba(255,255,255,.92); font-size:1.15rem; max-width:55ch; margin-bottom:1.8em}
.hero-sub strong{color:var(--gold-light); font-weight:600}
.hero-cta{display:flex; gap:12px; flex-wrap:wrap; margin-bottom:2.5em}
.hero-stats{
  display:flex; flex-wrap:wrap; gap:18px 36px;
  list-style:none; padding:0; margin:0;
  border-top:1px solid rgba(255,255,255,.2);
  padding-top:24px; max-width:680px;
}
.hero-stats li{font-size:.85rem; color:rgba(255,255,255,.78); letter-spacing:.04em; text-transform:uppercase}
.hero-stats li span{
  display:block; font-family:var(--serif); font-size:1.85rem; color:#fff;
  font-weight:600; letter-spacing:0; text-transform:none; margin-bottom:2px;
}

/* ============== SECTIONS ============== */
.section{
  padding:90px 0;
  content-visibility:auto;
  contain-intrinsic-size:1px 900px;
}
.section-alt{background:var(--cream)}
.section-head{margin-bottom:50px; max-width:760px}
.section-head.center{margin:0 auto 50px; text-align:center}
.section-head.center .lead{margin-left:auto; margin-right:auto}

.grid-2{display:grid; gap:50px; grid-template-columns:1fr 1fr; align-items:center}
@media (max-width:860px){.grid-2{grid-template-columns:1fr; gap:36px}}

.figure-card{
  margin:0; border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow-md);
}
.figure-card img{width:100%; height:auto; display:block}

.check-list{list-style:none; padding:0; margin:1.4em 0 1.6em; display:grid; gap:10px}
.check-list li{
  position:relative; padding-left:30px; color:var(--navy);
}
.check-list li::before{
  content:""; position:absolute; left:0; top:.45em;
  width:18px; height:18px; border-radius:50%;
  background:var(--accent-dark);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/12px no-repeat;
          mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/12px no-repeat;
}

/* ============== APARTAMENTOS ============== */
.cards{display:grid; gap:24px; grid-template-columns:repeat(2, 1fr)}
@media (max-width:760px){.cards{grid-template-columns:1fr}}

.card-apt{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:32px;
  transition:transform var(--t), box-shadow var(--t), border-color var(--t);
  display:flex; flex-direction:column;
}
.card-apt:hover{transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:transparent}
.card-apt header{display:flex; align-items:baseline; justify-content:space-between; margin-bottom:14px}
.card-apt h3{margin:0; color:var(--navy)}
.card-apt .tag{
  font-size:.75rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  background:var(--navy); color:var(--gold-light); padding:6px 12px; border-radius:999px;
}
.card-apt .price{
  font-size:1rem; color:var(--muted); margin:0 0 18px;
}
.card-apt .price strong{
  display:block; font-family:var(--serif); font-size:2rem; color:var(--navy); font-weight:700; margin-top:4px;
}
.card-apt ul{list-style:none; padding:0; margin:0 0 24px; display:grid; gap:8px; flex:1}
.card-apt ul li{font-size:.95rem; color:var(--ink)}
.card-apt ul li b{color:var(--navy)}
.card-apt.featured{
  border-color:var(--accent); background:linear-gradient(180deg, #fff 0%, #fdfaf0 100%);
  box-shadow:var(--shadow-sm);
  position:relative;
}
.card-apt.featured::before{
  content:attr(data-badge); position:absolute; top:-12px; right:24px;
  background:var(--accent); color:var(--navy-dark); font-size:.7rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase; padding:5px 14px; border-radius:999px;
}

/* ============== AMENIDADES ============== */
.amenities{
  list-style:none; padding:0; margin:0;
  display:grid; gap:18px;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
}
.amenities li{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:28px 24px;
  transition:transform var(--t), box-shadow var(--t);
}
.amenities li:hover{transform:translateY(-3px); box-shadow:var(--shadow-md)}
.amenities svg{
  width:34px; height:34px; stroke:var(--accent-dark); fill:none; stroke-width:1.6;
  stroke-linecap:round; stroke-linejoin:round; margin-bottom:14px;
}
.amenities h3{font-size:1.1rem; margin-bottom:6px}
.amenities p{font-size:.92rem; color:var(--muted); margin:0}

/* ============== GALLERY ============== */
.gallery{
  display:grid; gap:12px;
  grid-template-columns:repeat(4, 1fr);
}
@media (max-width:860px){.gallery{grid-template-columns:repeat(2, 1fr)}}
.g-item{
  position:relative; padding:0; border-radius:var(--radius-sm); overflow:hidden;
  aspect-ratio:4/3; background:var(--sand);
  cursor:zoom-in;
}
.g-item img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .5s ease;
}
.g-item:hover img{transform:scale(1.06)}

.masterplan{
  margin:50px 0 0; border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow-md);
  position:relative;
}
.masterplan img{width:100%; height:auto}
.masterplan figcaption{
  position:absolute; left:20px; bottom:20px;
  background:rgba(255,255,255,.92); padding:8px 16px; border-radius:999px;
  font-size:.85rem; font-weight:600; color:var(--navy);
  backdrop-filter:blur(6px);
}

/* ============== PRICING ============== */
.pricing{display:grid; gap:24px; grid-template-columns:repeat(2, 1fr); margin-bottom:24px}
@media (max-width:860px){.pricing{grid-template-columns:1fr}}

.price-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:30px; box-shadow:var(--shadow-sm);
}
.price-card h3{margin:0 0 4px}
.price-card h3 span{font-family:var(--sans); font-size:.85rem; font-weight:500; color:var(--muted); letter-spacing:0}
.price-card table{width:100%; border-collapse:collapse; margin:18px 0; font-size:.92rem}
.price-card thead th{
  text-align:left; padding:10px 8px;
  font-size:.72rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--muted); border-bottom:2px solid var(--line); font-weight:600;
}
.price-card tbody td{padding:12px 8px; border-bottom:1px solid var(--line)}
.price-card tbody tr:last-child td{border-bottom:0}
.price-card tbody tr:hover{background:var(--cream)}
.price-card td:nth-child(3){font-weight:600; color:var(--navy)}
.price-card td:nth-child(4){color:var(--accent-dark); font-weight:700; white-space:nowrap}
.bono{
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-dark) 100%); padding:14px 18px; border-radius:var(--radius-sm);
  font-size:.9rem; color:rgba(255,255,255,.85); margin:0;
}
.bono strong{color:var(--gold-light)}
.bono small{
  display:block;
  color:rgba(255,255,255,.7);
  margin-top:4px;
  font-size:.8rem;
  font-weight:500;
}

.disclaimer{
  font-size:.82rem; color:var(--muted); text-align:center; margin:8px 0 50px;
  font-style:italic;
}

.benefits h3{text-align:center; margin-bottom:30px}
.benefits-grid{
  display:grid; gap:24px;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
}
.benefits-grid > div{
  padding:24px; background:var(--cream); border-radius:var(--radius);
  border-left:3px solid var(--accent);
}
.benefits-grid h4{color:var(--navy); margin-bottom:8px}
.benefits-grid p{margin:0; font-size:.94rem; color:var(--ink)}

/* ============== UBICACIÓN / MAP ============== */
.map-embed{
  border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow-md); aspect-ratio:4/3;
  border:1px solid var(--line);
}
.map-embed iframe{width:100%; height:100%; border:0; display:block}

/* ============== CTA / FORM ============== */
.cta-section{
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-dark) 100%);
  color:#fff; position:relative; overflow:hidden;
}
.cta-section::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(60% 80% at 80% 30%, rgba(212,166,52,.22), transparent 70%);
  pointer-events:none;
}
.cta-section .section-head h2{color:#fff}
.cta-section .section-head h2 em{color:var(--gold-light)}
.cta-section .lead{color:rgba(255,255,255,.78)}
.cta-section .container{position:relative}

.form{
  max-width:680px; margin:0 auto;
  background:#fff; padding:32px;
  border-radius:var(--radius); color:var(--ink);
  box-shadow:var(--shadow-lg);
  display:grid; gap:14px;
}
.form .row{display:grid; gap:14px; grid-template-columns:1fr 1fr}
@media (max-width:600px){.form .row{grid-template-columns:1fr}}
.form label{
  display:flex; flex-direction:column; gap:6px;
  font-size:.85rem; font-weight:600; color:var(--navy);
  letter-spacing:.02em;
}
.form input, .form select, .form textarea{
  width:100%; padding:12px 14px;
  border:1px solid var(--line); border-radius:var(--radius-sm);
  font:inherit; font-size:.95rem; color:var(--ink);
  background:#fff; transition:border-color var(--t), box-shadow var(--t);
  font-weight:400;
}
.form input:focus, .form select:focus, .form textarea:focus{
  outline:0; border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(212,166,52,.22);
}
.form textarea{resize:vertical; min-height:90px}
.form-note{
  text-align:center; font-size:.9rem; min-height:1.2em; margin:4px 0 0;
  color:var(--accent-dark); font-weight:600;
}
.form-note.success{color:#1a8a4a}

.contact-direct{
  display:flex; gap:14px; justify-content:center; margin-top:30px; flex-wrap:wrap;
}
.contact-pill{
  display:inline-flex; align-items:center; gap:10px;
  padding:12px 22px; border-radius:999px;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.25);
  color:#fff; font-weight:600; font-size:.95rem;
  transition:background var(--t), transform var(--t);
}
.contact-pill:hover{background:rgba(255,255,255,.18); transform:translateY(-2px)}
.contact-pill svg{width:20px; height:20px; flex-shrink:0}
.contact-pill.wa{background:#25D366; border-color:#25D366}
.contact-pill.wa:hover{background:#1eb858; border-color:#1eb858}
.contact-pill.wa strong{font-weight:700; letter-spacing:.02em}

/* ============== FOOTER ============== */
.footer{background:var(--cream); color:var(--muted); padding:64px 0 24px; border-top:1px solid var(--line)}
.footer-inner{
  display:grid; gap:40px;
  grid-template-columns:1fr 2fr;
  padding-bottom:40px; border-bottom:1px solid var(--line);
}
@media (max-width:760px){.footer-inner{grid-template-columns:1fr}}
.footer-brand img{margin-bottom:18px; height:auto; max-width:140px; width:auto; display:block}
.footer-brand p{font-size:.9rem; margin:0; color:var(--navy)}
.footer-brand strong{color:var(--accent-dark); font-weight:700}

.footer-cols{display:grid; gap:30px; grid-template-columns:repeat(3, 1fr)}
@media (max-width:600px){.footer-cols{grid-template-columns:1fr 1fr}}
.footer-cols h3{color:var(--navy); margin:0 0 14px; font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; font-weight:700}
.footer-cols a, .footer-cols p{
  display:block; font-size:.9rem; color:var(--muted);
  margin:0 0 8px; transition:color var(--t);
  line-height:1.5;
}
.footer-cols a:hover{color:var(--accent-dark)}

.footer-bottom{
  display:flex; justify-content:space-between; align-items:center;
  padding-top:22px; flex-wrap:wrap; gap:8px;
  font-size:.82rem; color:var(--muted);
}
.footer-bottom p{margin:0}

/* ============== FLOATING WHATSAPP ============== */
.wa-float{
  position:fixed; right:18px; bottom:18px; z-index:60;
  display:inline-flex; align-items:center; gap:10px;
  padding:12px 20px 12px 14px;
  background:#25D366; color:#fff;
  border-radius:999px;
  box-shadow:0 10px 28px rgba(37,211,102,.45), 0 4px 10px rgba(0,0,0,.12);
  font-weight:700; font-size:.95rem;
  transition:transform var(--t), box-shadow var(--t), background var(--t);
}
.wa-float:hover{transform:translateY(-3px); background:#1eb858; box-shadow:0 14px 34px rgba(37,211,102,.55)}
.wa-float svg{width:26px; height:26px; flex-shrink:0}
.wa-float-label{white-space:nowrap}
@media (max-width:520px){
  .wa-float{padding:14px; gap:0}
  .wa-float svg{width:28px; height:28px}
  .wa-float-label{display:none}
}

/* ============== LIGHTBOX ============== */
.lightbox{
  position:fixed; inset:0; z-index:1000;
  background:rgba(15,20,40,.95);
  display:none; align-items:center; justify-content:center;
  padding:60px 20px;
}
.lightbox.open{display:flex}
.lightbox img{
  max-width:100%; max-height:100%;
  border-radius:var(--radius-sm);
  box-shadow:var(--shadow-lg);
}
.lb-close, .lb-prev, .lb-next{
  position:absolute; color:#fff;
  width:48px; height:48px; border-radius:50%;
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2);
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem; transition:background var(--t);
}
.lb-close:hover, .lb-prev:hover, .lb-next:hover{background:rgba(255,255,255,.25)}
.lb-close{top:20px; right:20px; font-size:1.8rem}
.lb-prev{left:20px; top:50%; transform:translateY(-50%)}
.lb-next{right:20px; top:50%; transform:translateY(-50%)}

/* ============== REVEAL ANIMS ============== */
.reveal{opacity:0; transform:translateY(20px); transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1; transform:none}
@media (prefers-reduced-motion: reduce){
  *{animation:none!important; transition:none!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1; transform:none}
}

/* ============== MOBILE TWEAKS ============== */
@media (max-width:760px){
  .section{padding:64px 0}
  .section-head{margin-bottom:32px}

  /* Hero: compact, content-driven */
  .hero{
    min-height:auto;
    padding:76px 0 28px;
    align-items:center;
  }
  .hero-overlay{
    background:
      linear-gradient(180deg, rgba(20,28,54,.36) 0%, rgba(20,28,54,.58) 48%, rgba(20,28,54,.9) 100%),
      radial-gradient(72% 58% at 28% 72%, rgba(31,44,80,.28), transparent 72%);
  }
  .hero-content{
    max-width:34rem;
    text-align:center;
    margin:0 auto;
  }
  .hero h1{
    font-size:clamp(1.62rem, 7.2vw, 2.2rem);
    line-height:1.12;
    margin-bottom:.38em;
    max-width:13ch;
    margin-left:auto;
    margin-right:auto;
  }
  .hero .eyebrow{font-size:.68rem; letter-spacing:.14em; margin-bottom:.7em}
  .hero-sub{
    font-size:.92rem;
    line-height:1.46;
    max-width:30ch;
    margin-bottom:1.15em;
    margin-left:auto;
    margin-right:auto;
  }
  .hero-cta{
    gap:10px;
    margin-bottom:1.2em;
    width:100%;
    justify-content:center;
  }
  .hero-cta .btn{flex:1; padding:12px 15px; font-size:.84rem; min-width:0}
  .hero-stats{
    gap:10px 12px;
    padding-top:16px;
    display:grid;
    grid-template-columns:repeat(2, 1fr);
    max-width:100%;
    margin-left:auto;
    margin-right:auto;
    text-align:center;
  }
  .hero-stats li{font-size:.62rem; letter-spacing:.06em}
  .hero-stats li span{font-size:1.16rem; font-weight:700; margin-bottom:1px}
}

@media (max-width:600px){
  .brand-logo{height:32px; max-width:94px}
  .form{padding:20px}
  .price-card{padding:20px 16px}
  .price-card table{font-size:.8rem}
  .price-card thead th, .price-card tbody td{padding:9px 5px}
  .price-card thead th{font-size:.65rem; letter-spacing:.06em}
  .card-apt{padding:22px}
  .card-apt header{flex-wrap:wrap; gap:8px}
  .section-head h2{font-size:1.55rem}
  .container{padding:0 16px}
  .contact-direct{gap:10px}
  .contact-pill{padding:11px 16px; font-size:.85rem; width:100%; justify-content:center}
  .lang-toggle{padding:0 11px; min-height:38px}
  .hero{padding:72px 0 24px}
  .hero-cta{display:grid; grid-template-columns:1fr}
  .hero-cta .btn{width:100%}
}

@media (max-width:380px){
  .nav-actions{gap:8px}
  .lang-toggle{padding:0 10px; font-size:.72rem}
  .hero{padding:68px 0 22px}
  .hero h1{font-size:1.48rem}
  .hero-sub{font-size:.88rem}
  .hero-stats{grid-template-columns:1fr 1fr; gap:10px 0}
  .hero-stats li span{font-size:1.05rem}
}
