/* ============================================================
   PRIMEWORLD PINNACLE — Landing Page
   Brand: copper/bronze/gold · deep slate blue · ivory cream
   Type:  Cinzel (eyebrows/labels) · Cormorant Garamond (display)
          Jost (body) — no italics anywhere
   ============================================================ */

:root{
  /* Brand palette */
  --cream:        #f4eee2;
  --cream-2:      #efe7d7;
  --slate:        #2e3a4d;
  --slate-2:      #3a4a63;
  --slate-deep:   #232d3c;
  --ink:          #2a2622;
  --ink-soft:     #5c5347;

  /* Bronze / gold */
  --bronze-d:     #7a3f1e;
  --bronze:       #b06a33;
  --gold:         #d49a52;
  --gold-l:       #e7c389;
  --grad-bronze:  linear-gradient(135deg,#7a3f1e 0%,#b06a33 38%,#d49a52 70%,#e7c389 100%);
  --grad-gold:    linear-gradient(120deg,#c98a45 0%,#e7c389 50%,#c98a45 100%);

  --line:         rgba(0,0,0,.10);
  --line-light:   rgba(255,255,255,.16);
  --shadow:       0 24px 60px -28px rgba(20,26,38,.45);
  --shadow-soft:  0 18px 44px -26px rgba(20,26,38,.40);

  --maxw: 1200px;
  --r: 14px;
  --ease: cubic-bezier(.22,.61,.36,1);

  /* Subtle fan / scallop motif (echoes the brand deck) */
  --scallop: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='46' height='46' viewBox='0 0 46 46'%3E%3Cg fill='none' stroke='%23e7c389' stroke-width='1' stroke-opacity='0.5'%3E%3Cpath d='M0 46a23 23 0 0 1 46 0'/%3E%3Cpath d='M-23 46a23 23 0 0 1 46 0'/%3E%3Cpath d='M23 46a23 23 0 0 1 46 0'/%3E%3C/g%3E%3C/svg%3E");
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Jost",system-ui,sans-serif;
  font-weight:300;
  color:var(--ink);
  background:var(--cream);
  line-height:1.7;
  font-style:normal;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
*{font-style:normal}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px}
.narrow{max-width:820px}
.center{text-align:center}

/* ---------- Typography ---------- */
.eyebrow{
  font-family:"Cinzel",serif;
  font-weight:600;
  letter-spacing:.26em;
  text-transform:uppercase;
  font-size:.72rem;
  color:var(--bronze);
  margin:0 0 1.1rem;
}
.section-dark .eyebrow,.section-broker .eyebrow,.closing .eyebrow{color:var(--gold-l)}

.display{
  font-family:"Cormorant Garamond",serif;
  font-weight:600;
  font-size:clamp(2rem,4.6vw,3.4rem);
  line-height:1.08;
  letter-spacing:.005em;
  margin:0 0 1.3rem;
  color:var(--ink);
}
.display.light{color:var(--cream)}
.center .display{margin-left:auto;margin-right:auto}

.lead{font-size:1.15rem;font-weight:300;color:var(--ink-soft);margin:0 auto 1.1rem}
.lead.light{color:rgba(244,238,226,.82)}
.body{font-size:1.02rem;color:var(--ink-soft);margin:0 auto}
.body.light{color:rgba(244,238,226,.78)}
.center .lead,.center .body{max-width:680px}

.gold{
  background:var(--grad-gold);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:var(--gold);
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:"Jost",sans-serif;font-weight:500;
  letter-spacing:.04em;font-size:.95rem;
  padding:.92em 1.9em;border-radius:50px;
  cursor:pointer;border:1px solid transparent;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s,color .35s;
  white-space:nowrap;
}
.btn-primary{background:var(--grad-bronze);color:#fff;box-shadow:0 12px 26px -12px rgba(122,63,30,.7)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 34px -12px rgba(122,63,30,.78)}
.btn-ghost{border-color:var(--bronze);color:var(--bronze);background:transparent}
.btn-ghost:hover{background:var(--bronze);color:#fff;transform:translateY(-3px)}
.btn-ghost-light{border-color:rgba(255,255,255,.45);color:var(--cream);background:transparent}
.btn-ghost-light:hover{background:rgba(255,255,255,.10);transform:translateY(-3px)}
.btn-block{width:100%}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:18px 0;
  transition:padding .4s var(--ease),background .4s,box-shadow .4s,backdrop-filter .4s;
}
.site-header.scrolled{
  padding:10px 0;
  background:rgba(35,45,60,.86);
  backdrop-filter:blur(12px);
  box-shadow:0 10px 30px -18px rgba(0,0,0,.6);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand-logo{height:74px;width:auto;transition:height .4s var(--ease);
  filter:drop-shadow(0 4px 14px rgba(0,0,0,.35))}
.scrolled .brand-logo{height:56px}

.nav{display:flex;align-items:center;gap:34px}
.nav a{
  font-size:.92rem;font-weight:400;letter-spacing:.04em;
  color:rgba(255,255,255,.9);position:relative;padding:4px 0;
  text-shadow:0 1px 8px rgba(0,0,0,.4);
}
.nav a:not(.nav-cta)::after{
  content:"";position:absolute;left:0;bottom:-2px;height:1.5px;width:0;
  background:var(--grad-gold);transition:width .35s var(--ease);
}
.nav a:not(.nav-cta):hover::after{width:100%}
.nav-cta{
  background:var(--grad-bronze);color:#fff;padding:.6em 1.4em;border-radius:50px;
  box-shadow:0 10px 22px -12px rgba(122,63,30,.7);text-shadow:none;
}
.nav-cta:hover{transform:translateY(-2px)}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:26px;height:2px;background:#fff;border-radius:2px;transition:.3s var(--ease)}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  background:radial-gradient(120% 120% at 80% 0%,#3a4a63 0%,#2e3a4d 45%,#232d3c 100%);
  color:var(--cream);padding:140px 0 80px;overflow:hidden;
}
.hero-pattern{position:absolute;inset:0;opacity:.5;
  background-image:var(--scallop);background-size:46px 46px;mix-blend-mode:soft-light;pointer-events:none}
.hero-grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero-copy{max-width:600px}
.hero-title{
  font-family:"Cormorant Garamond",serif;font-weight:600;
  font-size:clamp(3.2rem,8vw,6rem);line-height:.98;margin:.2rem 0 1.4rem;letter-spacing:.01em;
}
.hero-lead{font-size:1.18rem;font-weight:300;color:rgba(244,238,226,.85);max-width:520px;margin:0 0 1.6rem}
.hero-location{display:flex;align-items:flex-start;gap:.6rem;font-size:.95rem;color:var(--gold-l);margin:0 0 2.2rem;letter-spacing:.02em}
.hero-location .pin{width:20px;height:20px;flex:none;fill:var(--gold);margin-top:1px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}

.hero-media{position:relative}
.hero-media img{
  width:100%;border-radius:18px;box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.08);
}
.hero-media::after{
  content:"";position:absolute;inset:0;border-radius:18px;
  box-shadow:inset 0 0 0 1px rgba(231,195,137,.18);pointer-events:none;
}

.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);
  width:26px;height:42px;border:1.5px solid rgba(231,195,137,.55);border-radius:14px;display:block}
.scroll-cue span{position:absolute;top:8px;left:50%;width:4px;height:8px;margin-left:-2px;border-radius:2px;
  background:var(--gold-l);animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%{opacity:0;transform:translateY(0)}40%{opacity:1}80%{opacity:0;transform:translateY(14px)}100%{opacity:0}}

/* ---------- Sections ---------- */
.section{padding:clamp(74px,9vw,128px) 0}
.section-cream{background:var(--cream)}
.section-dark{background:
  radial-gradient(130% 120% at 15% 0%,#3a4a63 0%,#2e3a4d 48%,#232d3c 100%);color:var(--cream)}

/* Stats */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;margin-top:64px;
  padding-top:48px;border-top:1px solid var(--line)}
.stat{text-align:center}
.stat-num{display:block;font-family:"Cormorant Garamond",serif;font-weight:600;
  font-size:clamp(2.6rem,5vw,3.6rem);line-height:1;color:var(--bronze)}
.stat-num small{font-size:.4em;font-family:"Jost",sans-serif;font-weight:400}
.stat-label{display:block;margin-top:.5rem;font-size:.86rem;letter-spacing:.04em;color:var(--ink-soft)}

/* Showcase pair */
.showcase{display:grid;grid-template-columns:1fr 1fr;gap:0}
.showcase-item{position:relative;margin:0;overflow:hidden;aspect-ratio:16/9}
.showcase-item img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.showcase-item:hover img{transform:scale(1.06)}
.showcase-item figcaption{position:absolute;left:24px;bottom:20px;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.6)}
.showcase-item figcaption span{display:block;font-family:"Cormorant Garamond",serif;font-size:1.5rem;font-weight:600}
.showcase-item figcaption em{font-size:.8rem;letter-spacing:.06em;color:var(--gold-l);font-style:normal}

/* Location */
.location-head{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;margin-bottom:56px}
.location-intro{color:rgba(244,238,226,.8);font-size:1.05rem;margin:0}
.location-grid{display:grid;grid-template-columns:1.25fr .85fr;gap:40px;align-items:center}
.map{margin:0;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line-light)}
.vicinity-title{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:1.7rem;margin:0 0 1rem;color:var(--gold-l)}
.vicinity-list{list-style:none;margin:0;padding:0}
.vicinity-list li{display:grid;grid-template-columns:88px 1fr;gap:16px;padding:14px 0;border-top:1px solid var(--line-light);align-items:baseline}
.vicinity-list .dist{font-family:"Cinzel",serif;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}
.vicinity-list .places{color:rgba(244,238,226,.84);font-size:.96rem}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:60px}
.g-item{position:relative;margin:0;border-radius:var(--r);overflow:hidden;cursor:pointer;
  aspect-ratio:4/3;box-shadow:var(--shadow-soft)}
.g-item.span-2{grid-column:span 2;aspect-ratio:8/3}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.g-item:hover img{transform:scale(1.08)}
.g-item figcaption{position:absolute;inset:auto 0 0 0;padding:34px 18px 16px;color:#fff;
  background:linear-gradient(to top,rgba(20,26,38,.82),transparent);
  transform:translateY(8px);opacity:.92;transition:.4s var(--ease)}
.g-item:hover figcaption{transform:translateY(0);opacity:1}
.g-item figcaption span{display:block;font-family:"Cormorant Garamond",serif;font-size:1.3rem;font-weight:600;line-height:1.1}
.g-item figcaption em{font-size:.74rem;letter-spacing:.05em;color:var(--gold-l);font-style:normal}
.disclaimer{margin-top:28px;font-size:.8rem;color:var(--ink-soft);text-align:center}
.section-dark .disclaimer{color:rgba(244,238,226,.55)}

/* Units */
.unit-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:56px}
.unit-card{
  background:rgba(255,255,255,.05);border:1px solid var(--line-light);border-radius:var(--r);
  padding:38px 30px;text-align:center;transition:transform .4s var(--ease),border-color .4s,background .4s;
}
.unit-card:hover{transform:translateY(-6px);border-color:rgba(231,195,137,.5);background:rgba(255,255,255,.08)}
.unit-card.featured{background:linear-gradient(160deg,rgba(176,106,51,.22),rgba(255,255,255,.04));border-color:rgba(231,195,137,.4)}
.unit-tag{font-family:"Cinzel",serif;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-l);margin-bottom:.8rem}
.unit-size{font-family:"Cormorant Garamond",serif;font-size:3.4rem;font-weight:600;line-height:1;color:var(--cream)}
.unit-size span{font-family:"Jost",sans-serif;font-size:1rem;font-weight:300;color:var(--gold-l);margin-left:.3rem}
.unit-card p{font-size:.92rem;color:rgba(244,238,226,.72);margin:1rem 0 0}
.units-plan{margin:48px auto 0;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line-light)}
.units-plan figcaption{text-align:center;font-size:.8rem;letter-spacing:.06em;color:rgba(244,238,226,.6);padding:14px;background:rgba(0,0,0,.25)}

/* Pricing */
.price-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:56px}
.price-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:42px 40px;
  box-shadow:var(--shadow-soft);display:flex;flex-direction:column;transition:transform .4s var(--ease),box-shadow .4s}
.price-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.price-card.featured{position:relative;border-color:rgba(176,106,51,.5);
  background:linear-gradient(170deg,#fff 0%,#fbf4e8 100%)}
.price-card.featured::before{content:"Most Popular";position:absolute;top:18px;right:18px;
  font-family:"Cinzel",serif;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;
  background:var(--grad-bronze);padding:.4em .9em;border-radius:50px}
.price-head{margin-bottom:1.2rem}
.price-head .unit-tag{display:block;color:var(--bronze);margin-bottom:.2rem}
.price-sub{font-size:.92rem;color:var(--ink-soft);letter-spacing:.02em}
.price-amount{display:flex;flex-direction:column;padding-bottom:1.4rem;margin-bottom:1.4rem;border-bottom:1px solid var(--line)}
.price-amount .from{font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.price-amount .amt{font-family:"Cormorant Garamond",serif;font-weight:700;font-size:clamp(2.6rem,5vw,3.6rem);
  line-height:1;color:var(--ink);
  background:var(--grad-bronze);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.price-terms{list-style:none;margin:0 0 1.8rem;padding:0;flex:1}
.price-terms li{position:relative;padding:10px 0 10px 30px;border-top:1px solid var(--line);color:var(--ink-soft);font-size:.98rem}
.price-terms li:first-child{border-top:0}
.price-terms li strong{color:var(--ink);font-weight:500}
.price-terms li::before{content:"";position:absolute;left:0;top:14px;width:16px;height:16px;border-radius:50%;background:var(--grad-bronze)}
.price-terms li::after{content:"";position:absolute;left:5px;top:17px;width:5px;height:8px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}

.reservation-bar{display:flex;align-items:center;gap:28px;margin-top:30px;
  background:radial-gradient(120% 160% at 0% 0%,#3a4a63,#232d3c);color:var(--cream);
  border-radius:var(--r);padding:26px 38px;box-shadow:var(--shadow);flex-wrap:wrap}
.reservation-bar .rb-label{display:block;font-family:"Cinzel",serif;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-l)}
.reservation-bar .rb-note{font-size:.86rem;color:rgba(244,238,226,.7)}
.reservation-bar .rb-amount{font-family:"Cormorant Garamond",serif;font-weight:700;font-size:2.6rem;line-height:1;
  margin-left:auto;color:var(--cream)}
.reservation-bar .btn{flex:none}

/* Requirements */
.req-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:56px}
.req-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:40px 38px;box-shadow:var(--shadow-soft)}
.req-card h3{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:1.7rem;margin:0 0 1.4rem;color:var(--ink)}
.req-card h3 small{font-family:"Jost",sans-serif;font-size:.8rem;font-weight:300;color:var(--bronze);letter-spacing:.02em}
.check-list{list-style:none;margin:0;padding:0}
.check-list li{position:relative;padding:11px 0 11px 34px;border-top:1px solid var(--line);color:var(--ink-soft);font-size:.98rem}
.check-list li:first-child{border-top:0}
.check-list li::before{content:"";position:absolute;left:0;top:15px;width:18px;height:18px;border-radius:50%;
  background:var(--grad-bronze)}
.check-list li::after{content:"";position:absolute;left:6px;top:19px;width:5px;height:9px;
  border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
.req-cta{margin-top:1.8rem}

/* Broker */
.section-broker{padding:0;background:var(--slate-deep);color:var(--cream)}
.broker-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:0;align-items:stretch}
.broker-photo{margin:0;position:relative;background:linear-gradient(160deg,#37445a,#232d3c)}
.broker-photo img{width:100%;height:100%;object-fit:cover;object-position:top center}
.broker-copy{padding:clamp(54px,7vw,96px) clamp(28px,5vw,72px)}
.broker-copy .body{margin-bottom:1.8rem}
.broker-id{display:flex;align-items:center;gap:24px;padding:20px 0;border-top:1px solid var(--line-light);border-bottom:1px solid var(--line-light);margin-bottom:1.8rem;flex-wrap:wrap}
.broker-name{font-family:"Cormorant Garamond",serif;font-size:1.9rem;font-weight:600;margin:0;color:var(--cream);line-height:1}
.broker-role{margin:.3rem 0 0;font-size:.82rem;letter-spacing:.06em;color:var(--gold-l)}
.broker-brokerage{height:52px;width:auto;margin-left:auto}
.broker-actions{display:flex;gap:14px;flex-wrap:wrap}

/* Closing */
.closing{position:relative;padding:clamp(90px,12vw,150px) 0;text-align:center;color:var(--cream);
  background:radial-gradient(120% 130% at 50% 0%,#3a4a63,#232d3c 70%);overflow:hidden}
.closing-pattern{position:absolute;inset:0;opacity:.45;background-image:var(--scallop);background-size:46px 46px;mix-blend-mode:soft-light}
.closing .container{position:relative}
.closing-title{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:clamp(2.4rem,6vw,4.4rem);
  line-height:1.04;margin:.4rem 0 1.4rem;
  background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.closing-lead{max-width:640px;margin:0 auto 2.2rem;color:rgba(244,238,226,.82);font-size:1.1rem;font-weight:300}

/* Contact */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:start}
.contact-list{list-style:none;margin:2rem 0 0;padding:0}
.contact-list li{padding:16px 0;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:3px}
.ci-label{font-family:"Cinzel",serif;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bronze)}
.contact-list a{color:var(--ink);transition:color .3s}
.contact-list a:hover{color:var(--bronze)}
.contact-form{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:40px;box-shadow:var(--shadow-soft)}
.field{margin-bottom:18px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field label{display:block;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.5rem;font-weight:400}
.field label .req{color:var(--bronze);font-weight:600}
.hp-field{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden}
.field input,.field select,.field textarea{
  width:100%;padding:.85em 1em;border:1px solid var(--line);border-radius:10px;
  font-family:"Jost",sans-serif;font-size:.98rem;font-weight:300;color:var(--ink);background:var(--cream);
  transition:border-color .3s,box-shadow .3s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--bronze);box-shadow:0 0 0 3px rgba(176,106,51,.15)}
.field textarea{resize:vertical}
.form-note{margin:14px 0 0;font-size:.9rem;color:var(--bronze);text-align:center}

/* Footer */
.site-footer{background:var(--slate-deep);color:rgba(244,238,226,.7);padding:64px 0 28px}
.footer-inner{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;
  padding-bottom:36px;border-bottom:1px solid var(--line-light)}
.footer-logo{height:118px;width:auto;margin-bottom:14px}
.footer-tag{max-width:320px;font-size:.9rem;margin:0}
.footer-nav{display:flex;flex-wrap:wrap;gap:14px 26px}
.footer-nav a{font-size:.9rem;color:rgba(244,238,226,.78);transition:color .3s}
.footer-nav a:hover{color:var(--gold-l)}
.footer-bottom{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;padding-top:24px;font-size:.78rem;color:rgba(244,238,226,.5)}
.footer-bottom p{margin:0}
.footer-disclaimer{max-width:560px;text-align:right}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(20,24,32,.94);
  display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.lightbox.open{display:flex;opacity:1}
.lightbox img{max-width:90vw;max-height:82vh;border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb-close,.lb-prev,.lb-next{position:absolute;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);
  color:#fff;cursor:pointer;border-radius:50%;transition:background .3s}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:var(--bronze)}
.lb-close{top:24px;right:28px;width:46px;height:46px;font-size:1.6rem;line-height:1}
.lb-prev,.lb-next{top:50%;transform:translateY(-50%);width:54px;height:54px;font-size:2rem;line-height:1}
.lb-prev{left:24px}.lb-next{right:24px}
.lb-caption{position:absolute;bottom:26px;left:0;right:0;text-align:center;color:var(--gold-l);font-size:.92rem;letter-spacing:.04em}

/* Brand chat buttons (broker section) */
.btn-wa,.btn-viber{gap:.6em;color:#fff}
.btn-wa svg,.btn-viber svg{width:1.15em;height:1.15em;fill:currentColor;flex:none}
.btn-wa{background:#25D366;box-shadow:0 12px 26px -12px rgba(37,211,102,.7)}
.btn-wa:hover{background:#1ebe5b;transform:translateY(-3px)}
.btn-viber{background:#7360f2;box-shadow:0 12px 26px -12px rgba(115,96,242,.7)}
.btn-viber:hover{background:#5f4ee0;transform:translateY(-3px)}

/* Floating quick-contact */
.float-contact{position:fixed;right:24px;bottom:84px;z-index:45;display:flex;flex-direction:column;gap:14px}
.fc-btn{position:relative;width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:#fff;box-shadow:0 14px 30px -10px rgba(0,0,0,.5);transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.fc-btn svg{width:28px;height:28px;fill:#fff}
.fc-btn:hover{transform:translateY(-4px) scale(1.06);box-shadow:0 18px 36px -10px rgba(0,0,0,.55)}
.fc-whatsapp{background:#25D366}
.fc-messenger{background:linear-gradient(45deg,#0099ff 0%,#a033ff 50%,#ff5280 75%,#ff7061 100%)}
.fc-btn::before{content:"";position:absolute;inset:0;border-radius:50%;background:inherit;z-index:-1;
  animation:fcPulse 2.6s var(--ease) infinite}
.fc-whatsapp::before{background:#25D366}
.fc-messenger::before{background:#a033ff}
@keyframes fcPulse{0%{transform:scale(1);opacity:.55}70%{transform:scale(1.7);opacity:0}100%{opacity:0}}

/* Back to top */
.to-top{position:fixed;right:24px;bottom:24px;z-index:40;width:48px;height:48px;border-radius:50%;
  background:var(--grad-bronze);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.3rem;
  box-shadow:0 12px 26px -12px rgba(122,63,30,.8);opacity:0;visibility:hidden;transform:translateY(12px);
  transition:.4s var(--ease)}
.to-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.to-top:hover{transform:translateY(-4px)}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-media{max-width:460px;order:-1}
  .hero{min-height:auto;padding:130px 0 70px}
  .location-head,.location-grid,.contact-grid,.broker-grid{grid-template-columns:1fr}
  .broker-photo{aspect-ratio:4/5;max-height:560px}
  .stat-row{grid-template-columns:repeat(2,1fr);gap:34px 20px}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .g-item.span-2{grid-column:span 2;aspect-ratio:16/7}
  .req-grid,.unit-cards,.price-grid{grid-template-columns:1fr}
  .reservation-bar{justify-content:space-between}
  .reservation-bar .rb-amount{margin-left:0}
  .footer-disclaimer{text-align:left}
}
@media (max-width:680px){
  .container{padding:0 20px}
  .nav{position:fixed;inset:0 0 0 auto;width:min(80vw,320px);flex-direction:column;
    align-items:flex-start;justify-content:center;gap:26px;padding:0 36px;
    background:rgba(35,45,60,.97);backdrop-filter:blur(14px);
    transform:translateX(100%);transition:transform .4s var(--ease);box-shadow:-20px 0 60px rgba(0,0,0,.4)}
  .nav.open{transform:translateX(0)}
  .nav a{font-size:1.1rem}
  .nav-toggle{display:flex;z-index:60}
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .showcase{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .footer-inner{flex-direction:column}
  .brand-logo{height:52px}
  .float-contact{right:16px;bottom:74px;gap:12px}
  .fc-btn{width:50px;height:50px}
  .fc-btn svg{width:25px;height:25px}
  .to-top{right:16px;bottom:16px}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
