/* ============================================================
   gladia-vlasta.css — Vlasta Premier Design System
   Luxury real estate: rich animations, gold accents,
   fluid transitions, decorative elements, gradient text.
   ============================================================ */

:root {
  --width-container: calc(100vw - 150px);
  --container-padding: calc((100vw - var(--width-container)) / 2);
  --transition-all: all .5s cubic-bezier(.25,.1,.25,1);
  --transition-smooth: all .65s cubic-bezier(.22,.61,.36,1);
  --transition-bounce: all .55s cubic-bezier(.34,1.56,.64,1);
  --color-primary: #e4b040;
  --color-primary-light: #f0d078;
  --color-secondary: #806b4c;
  --color-accent: #1a474f;
  --brown-dark: #3e241e;
  --brown-darker: #2a1814;
  --brown-text: #492919;
  --brown-mid: #804d37;
  --brown-light: #a0715a;
  --cream: #f5efe0;
  --cream-light: #fdf9f3;
  --cream-dark: #ede1cd;
  --white: #fff;
  --font-title: 'Playfair Display', Georgia, serif;
  --font-body: 'Inter', Arial, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;font-size:15px}
body.gladia-vlasta{margin:0;background:var(--cream);color:var(--brown-text);font-family:var(--font-body);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body.gladia-vlasta h1,body.gladia-vlasta h2,body.gladia-vlasta h3,body.gladia-vlasta h4,body.gladia-vlasta h5,body.gladia-vlasta h6{font-family:var(--font-title);font-weight:400;color:var(--brown-dark);line-height:1.2}
/* Dark bg headings — MUST beat body.gladia-vlasta h* (0,1,2) so use (0,2,2) */
body.gladia-vlasta .bg-brown h1,body.gladia-vlasta .bg-brown h2,body.gladia-vlasta .bg-brown h3,body.gladia-vlasta .bg-brown h4,
body.gladia-vlasta .banner-section h1,body.gladia-vlasta .banner-section h2,body.gladia-vlasta .banner-section h3,
body.gladia-vlasta .cinematic h1,body.gladia-vlasta .cinematic h2,body.gladia-vlasta .cinematic h3,
body.gladia-vlasta .footer-section h1,body.gladia-vlasta .footer-section h2,body.gladia-vlasta .footer-section h3,body.gladia-vlasta .footer-section h4,
body.gladia-vlasta .floor-section h1,body.gladia-vlasta .floor-section h2,body.gladia-vlasta .floor-section h3{color:#fff}
body.gladia-vlasta .bg-brown .text-grd,body.gladia-vlasta .cinematic .text-grd,body.gladia-vlasta .footer-section .text-grd{color:#e8cc8a}
body.gladia-vlasta .bg-brown .text-grd-light,body.gladia-vlasta .cinematic .text-grd-light,body.gladia-vlasta .footer-section .text-grd-light{color:#ddb675}
.gladia-vlasta img{max-width:100%;display:block}

/* Container */
.container-fluid{width:var(--width-container);margin:0 auto;position:relative;z-index:1}

/* Typography */
.font-title{font-family:var(--font-title)}

/* Gold gradient text — warm brown-to-gold */
.text-grd{
  background:linear-gradient(135deg,#9b6b43 0%,#d4a853 35%,#e8cc8a 55%,#c9984a 75%,#8b5a32 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  text-shadow:none;
  color:#8b5a32; /* solid fallback if gradient text fails */
}
/* Lighter gold-cream-green gradient */
.text-grd-light{
  background:linear-gradient(90deg,#ddb675 0%,#e2bf7d 16%,#c1c598 37%,#88beae 55%,#5cb0b2 74%,#329299 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  color:#ddb675; /* solid fallback */
}

/* Section Backgrounds */
.bg-cream{background:var(--cream)}
.bg-cream-light{background:var(--cream-light)}
.bg-brown{background:var(--brown-dark);color:#fff}
.section{position:relative;overflow:hidden}
.section-pad{padding:130px 0}
.section-pad-top{padding-top:130px}
.section-pad-bottom{padding-bottom:130px}

/* Section decorative divider */
.section-divider{position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(228,176,64,.35),transparent)}
.section-divider.top{top:0}
.section-divider.bottom{bottom:0}

/* Eyebrow label */
.eyebrow{
  font-size:13px;letter-spacing:.22em;text-transform:uppercase;
  font-weight:600;color:var(--color-primary);margin-bottom:24px;
  position:relative;display:inline-block;
}
.eyebrow:after{
  content:'';display:block;width:48px;height:2px;
  background:var(--color-primary);margin-top:14px;opacity:.7;
}
.center .eyebrow:after{margin-left:auto;margin-right:auto}

/* Gold accent line */
.gold-line{width:60px;height:2px;background:var(--color-primary);margin:24px 0;opacity:.8}
.center .gold-line{margin-left:auto;margin-right:auto}

/* Title scale */
body.gladia-vlasta .title-xl,.title-xl{
  font-family:var(--font-title);font-size:clamp(32px,4.5vw,58px);
  line-height:1.2;font-weight:400;letter-spacing:-.03em;text-transform:uppercase;
  color:#fff;margin:0 0 16px;
}
.title-lg{
  font-family:var(--font-title);font-size:clamp(26px,3vw,44px);
  line-height:1.2;font-weight:400;letter-spacing:-.02em;text-transform:uppercase;
  color:var(--brown-dark);margin:0 0 12px;
}
.title-md{
  font-family:var(--font-title);font-size:clamp(22px,2.4vw,34px);
  line-height:1.2;font-weight:400;text-transform:uppercase;
  color:var(--brown-dark);margin:0 0 10px;
}
.title-sm{
  font-family:var(--font-title);font-size:clamp(20px,2vw,28px);
  line-height:1.2;font-weight:400;margin:0 0 8px;
}

.lead{font-size:17px;line-height:1.7}
.muted{opacity:.78}
.center{text-align:center}
.upper{text-transform:uppercase}

/* ============================================================
   FIXED CONTACT BAR
   ============================================================ */
.fixed-contact{
  position:fixed;right:0;top:50%;transform:translateY(-50%);
  z-index:10000;display:flex;flex-direction:column;gap:1px;
}
.fixed-contact a{
  width:56px;height:56px;background:rgba(62,36,30,.94);
  color:#fff;display:grid;place-items:center;text-decoration:none;
  border:1px solid rgba(228,176,64,.25);font-weight:700;font-size:18px;
  transition:var(--transition-smooth);
}
.fixed-contact a:hover{background:var(--color-primary);color:var(--brown-dark);border-color:var(--color-primary)}

/* ============================================================
   HEADER
   ============================================================ */
.header{
  height:84px;position:fixed!important;left:0;top:0;width:100%;z-index:9999;
  transition:var(--transition-smooth);color:#fff;
}
.header.scrolled,.header.menu-open{
  background:rgba(62,36,30,.97);backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  box-shadow:0 8px 40px rgba(0,0,0,.18);
}
.header-inner{height:84px;display:flex;align-items:center;justify-content:space-between}
.logo{height:44px;width:auto;transition:var(--transition-smooth)}
.header.scrolled .logo{height:38px}

.main-nav{display:flex;align-items:center;gap:32px}
.main-nav a{
  color:#fff;text-decoration:none;text-transform:uppercase;
  font-size:13px;font-weight:600;letter-spacing:.07em;opacity:.88;
  transition:var(--transition-all);position:relative;padding:4px 0;
}
.main-nav a:after{
  content:'';position:absolute;bottom:-2px;left:0;width:0;height:1.5px;
  background:var(--color-primary);transition:width .35s ease;
}
.main-nav a:hover{color:var(--color-primary);opacity:1}
.main-nav a:hover:after{width:100%}

.header-actions{display:flex;align-items:center;gap:14px}
.phone-pill{
  color:#fff;text-decoration:none;font-weight:700;font-size:15px;
  transition:var(--transition-all);
}
.phone-pill:hover{color:var(--color-primary)}

/* ============================================================
   BUTTONS
   ============================================================ */
.button-blur,.btn-cream,.btn-brown,.btn-gold{
  height:52px;border-radius:116px;display:inline-flex;align-items:center;
  justify-content:center;padding:0 32px;text-decoration:none;
  text-transform:uppercase;font-size:13px;font-weight:700;
  letter-spacing:.07em;transition:var(--transition-bounce);
  cursor:pointer;border:0;gap:10px;position:relative;overflow:hidden;
}

/* Glass button */
.button-blur{
  color:#fff;background:rgba(255,255,255,.08);
  border:1.5px solid rgba(255,255,255,.18);backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.button-blur:hover{
  background:rgba(255,255,255,.18);transform:translateY(-3px);
  border-color:rgba(255,255,255,.35);box-shadow:0 12px 30px rgba(0,0,0,.2);
}
.button-blur:active{transform:translateY(-1px)}

/* Cream button */
.btn-cream{
  background:var(--cream);color:var(--brown-dark);
  box-shadow:0 4px 15px rgba(62,36,30,.1);
}
.btn-cream:hover{
  transform:translateY(-3px);box-shadow:0 14px 32px rgba(62,36,30,.18);
  background:#fff;
}
.btn-cream:active{transform:translateY(-1px)}

/* Brown button */
.btn-brown{
  background:var(--brown-dark);color:#fff;
  box-shadow:0 4px 15px rgba(0,0,0,.15);
}
.btn-brown:hover{
  background:var(--brown-darker);transform:translateY(-3px);
  box-shadow:0 14px 32px rgba(0,0,0,.25);
}

/* Gold button */
.btn-gold{
  background:var(--color-primary);color:var(--brown-dark);
  box-shadow:0 4px 18px rgba(228,176,64,.25);
}
.btn-gold:hover{
  background:var(--color-primary-light);transform:translateY(-3px);
  box-shadow:0 14px 35px rgba(228,176,64,.35);
}

/* Button shimmer effect */
.button-blur:before,.btn-gold:before{
  content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);
  transition:left .7s ease;
}
.button-blur:hover:before,.btn-gold:hover:before{left:100%}

/* ============================================================
   HAMBURGER
   ============================================================ */
.hamburger{
  display:flex;align-items:center;justify-content:center;width:48px;height:48px;
  border:1.5px solid rgba(255,255,255,.2);border-radius:50%;
  background:rgba(255,255,255,.06);padding:0;cursor:pointer;
  transition:var(--transition-all);
}
.hamburger:hover{border-color:rgba(255,255,255,.4);background:rgba(255,255,255,.12)}
.hamburger span{display:block;width:20px;height:2px;background:#fff;margin:5px auto;transition:var(--transition-all);border-radius:2px}
.hamburger.menu-open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.menu-open span:nth-child(2){opacity:0}
.hamburger.menu-open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ============================================================
   HERO / BANNER
   ============================================================ */
.banner-section{
  min-height:100vh;position:relative;background:#111;color:#fff;overflow:hidden;
}
.banner-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.02);animation:heroZoom 20s ease-in-out infinite alternate;
  will-change:transform;
}
.banner-bg:after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,
    rgba(0,0,0,.18) 0%,
    rgba(62,36,30,.2) 30%,
    rgba(62,36,30,.45) 60%,
    rgba(42,24,20,.78) 100%
  );
}
.banner-content{
  position:relative;z-index:2;min-height:100vh;
  display:flex;align-items:flex-end;padding-bottom:120px;
}
.hero-copy{max-width:960px}
.hero-badge{
  font-size:15px;text-transform:uppercase;letter-spacing:.22em;margin-bottom:20px;
  color:var(--color-primary);font-weight:700;
  display:inline-flex;align-items:center;gap:16px;
}
.hero-badge:before{
  content:'';display:inline-block;width:36px;height:1.5px;background:var(--color-primary);
}
body.gladia-vlasta .hero-title,.hero-title{
  font-family:var(--font-title);font-size:clamp(32px,4.5vw,58px);
  font-weight:400;text-transform:uppercase;line-height:1.2;
  letter-spacing:-.03em;margin:0 0 16px;color:#fff;
  text-shadow:0 4px 40px rgba(0,0,0,.3);
}
.hero-desc{
  max-width:680px;font-size:18px;line-height:1.7;margin:30px 0 38px;
  color:rgba(255,255,255,.8);
}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}

/* Scroll indicator */
.scroll-down{
  position:absolute;z-index:3;bottom:40px;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,.85);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;text-align:center;
  animation:scrollPulse 2.5s ease-in-out infinite;
}
.scroll-line{
  width:1px;height:64px;background:rgba(255,255,255,.35);margin:14px auto 0;
  position:relative;overflow:hidden;border-radius:2px;
}
.scroll-line:after{
  content:'';position:absolute;left:0;top:-20px;width:100%;height:20px;
  background:var(--color-primary);animation:scrollDot 1.8s infinite;
  border-radius:2px;
}

/* ============================================================
   SECTION: INTRODUCTION
   ============================================================ */
.intro-grid{
  display:grid;grid-template-columns:1fr 1.15fr;gap:90px;align-items:center;
}
.intro-kicker{
  font-family:var(--font-title);font-size:clamp(26px,3vw,44px);
  line-height:1.2;text-transform:uppercase;
  color:var(--brown-dark);margin:0 0 12px;
}

/* ============================================================
   IMAGE CARD
   ============================================================ */
.image-card{
  position:relative;border-radius:2px;overflow:hidden;
  box-shadow:0 24px 70px rgba(73,41,25,.14);
  transition:var(--transition-smooth);
}
.image-card img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.image-card:hover img{transform:scale(1.04)}
.image-card:after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(62,36,30,.12) 100%);
  pointer-events:none;
}

/* ============================================================
   STORY LINE (cinematic quote)
   ============================================================ */
.story-line{
  padding:100px 0;text-align:center;
  position:relative;
}
.story-line:before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:80px;height:2px;background:var(--color-primary);opacity:.5;
}
.story-line:after{
  content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:80px;height:2px;background:var(--color-primary);opacity:.5;
}
.story-line .title-lg{max-width:980px;margin:0 auto}

/* ============================================================
   OVERVIEW (brown section)
   ============================================================ */
.overview-wrap{
  display:grid;grid-template-columns:1fr 1.15fr;gap:80px;align-items:center;
}
.overview-image{aspect-ratio:934/588;overflow:hidden;border-radius:2px}

.facts-list{border-top:1px solid rgba(228,176,64,.15)}
.fact-row{
  display:grid;grid-template-columns:190px 1fr;gap:32px;
  padding:24px 0;border-bottom:1px solid rgba(228,176,64,.1);
  transition:var(--transition-all);
}
.fact-row:hover{background:rgba(255,255,255,.02);padding-left:12px}
.fact-label{
  font-size:13px;text-transform:uppercase;line-height:1.55;
  color:rgba(255,255,255,.82);letter-spacing:.04em;
}
.fact-value{font-size:16px;line-height:1.5;color:#fff;font-weight:700}

/* ============================================================
   MAP / LOCATION
   ============================================================ */
.map-layout{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:80px;align-items:center;
}
.map-img{position:relative}
.map-img img{
  width:100%;filter:drop-shadow(0 24px 40px rgba(73,41,25,.12));
  border-radius:2px;
}
.map-img:before{
  content:'';position:absolute;inset:-8px;
  border:1px solid rgba(228,176,64,.2);border-radius:4px;pointer-events:none;
}

/* Time distance cards */
.time-list{margin-top:40px;display:grid;gap:14px}
.time-item{
  display:grid;grid-template-columns:100px 1fr;align-items:center;
  background:rgba(255,255,255,.55);border:1px solid rgba(62,36,30,.08);
  padding:18px 22px;border-radius:12px;
  transition:var(--transition-bounce);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.time-item:hover{
  transform:translateX(6px);
  background:rgba(255,255,255,.85);border-color:rgba(228,176,64,.3);
  box-shadow:0 8px 28px rgba(73,41,25,.08);
}
.time-num{
  font-family:var(--font-title);font-size:48px;line-height:1;color:var(--brown-dark);
}
.time-num span{
  font-family:var(--font-body);font-size:13px;text-transform:uppercase;
  margin-left:4px;font-weight:600;color:var(--brown-mid);
}

/* ============================================================
   TABS
   ============================================================ */
.tabs{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin:38px 0}
.tab-btn{
  border:1.5px solid rgba(62,36,30,.18);background:transparent;
  color:var(--brown-dark);height:48px;border-radius:50px;
  padding:0 28px;text-transform:uppercase;font-size:13px;
  font-weight:700;cursor:pointer;letter-spacing:.05em;
  transition:var(--transition-bounce);
}
.tab-btn.active,.tab-btn:hover{
  background:var(--brown-dark);color:#fff;border-color:var(--brown-dark);
  box-shadow:0 6px 22px rgba(62,36,30,.2);
}
.tab-btn:active{transform:scale(.96)}

/* ============================================================
   AMENITIES
   ============================================================ */
.amenity-map{
  display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:start;
}
.amenity-image{
  position:relative;min-height:540px;background:var(--cream-dark);
  overflow:hidden;border-radius:2px;
  box-shadow:0 20px 60px rgba(73,41,25,.1);
}
.amenity-image img{width:100%;height:100%;min-height:540px;object-fit:cover}
.markers{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.marker-item{
  display:flex;gap:14px;align-items:center;padding:14px 0;
  border-bottom:1px solid rgba(62,36,30,.1);
  transition:var(--transition-all);
}
.marker-item:hover{padding-left:6px;border-bottom-color:rgba(228,176,64,.3)}
.marker-no{
  width:36px;height:36px;border-radius:50%;background:var(--brown-dark);
  color:#fff;display:grid;place-items:center;font-weight:700;flex:none;
  font-size:14px;transition:var(--transition-all);
}
.marker-item:hover .marker-no{background:var(--color-primary);color:var(--brown-dark)}

/* ============================================================
   CINEMATIC PARALLAX SECTION
   ============================================================ */
.cinematic{
  min-height:760px;display:flex;align-items:center;
  background-size:cover;background-position:center;
  background-attachment:fixed;position:relative;
}
.cinematic:before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(0deg,
    rgba(42,24,20,.92) 0%,
    rgba(62,36,30,.5) 50%,
    rgba(62,36,30,.7) 100%
  );
}
.cinematic-content{position:relative;z-index:1;color:#fff;max-width:920px}
.cinematic-content .title-xl{text-shadow:0 4px 30px rgba(0,0,0,.25)}

/* ============================================================
   FLOOR PLAN / TOWER
   ============================================================ */
.floor-section{position:relative}
.tower-tabs{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border:1px solid rgba(228,176,64,.12);margin-bottom:44px;border-radius:2px;
  overflow:hidden;
}
.tower-tab{
  padding:42px;color:#fff;border-right:1px solid rgba(228,176,64,.1);
  transition:var(--transition-smooth);cursor:pointer;
}
.tower-tab:last-child{border-right:0}
.tower-tab:hover,.tower-tab.active{background:rgba(255,255,255,.04)}
.tower-tab p{opacity:.85;line-height:1.6}
.floor-img{
  background:rgba(255,255,255,.04);padding:36px;border-radius:2px;
  border:1px solid rgba(255,255,255,.06);
}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:18px;grid-auto-rows:280px}
.gallery-grid .image-card{box-shadow:0 16px 48px rgba(73,41,25,.1);height:100%;overflow:hidden}

/* ============================================================
   PARTNERS / CARDS
   ============================================================ */
.partner-grid,.agency-grid,.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.partner-card,.agency-card,.news-card{
  background:rgba(255,255,255,.5);border:1px solid rgba(62,36,30,.08);
  padding:34px;min-height:200px;transition:var(--transition-bounce);
  border-radius:2px;position:relative;
}
.partner-card:hover,.agency-card:hover{
  transform:translateY(-8px);background:#fff;
  border-color:rgba(228,176,64,.2);
  box-shadow:0 20px 50px rgba(73,41,25,.1);
}
.partner-logo{
  height:72px;display:flex;align-items:center;
  color:var(--brown-dark);font-weight:800;font-size:22px;
}

/* ============================================================
   AWARDS / BRAND
   ============================================================ */
.award-section{background:var(--cream-light)}
.award-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:80px;align-items:center}
.award-list{max-height:540px;overflow-y:auto;display:grid;gap:10px}
.award-list::-webkit-scrollbar{width:4px}
.award-list::-webkit-scrollbar-thumb{background:rgba(62,36,30,.15);border-radius:4px}
.award-item{
  display:flex;gap:22px;align-items:flex-start;padding:20px 0;
  border-bottom:1px solid rgba(62,36,30,.08);transition:var(--transition-all);
}
.award-item:hover{padding-left:8px;border-bottom-color:rgba(228,176,64,.2)}
.award-year{
  font-family:var(--font-title);font-size:38px;color:var(--brown-mid);
  line-height:1;min-width:50px;
}
.award-item strong{display:block;margin-bottom:4px;font-size:16px}

/* ============================================================
   AGENCY
   ============================================================ */
.agency-card{display:grid;grid-template-columns:110px 1fr;gap:24px;align-items:center}
.agency-card h3{font-family:var(--font-body);font-weight:600;font-size:18px;margin:0 0 6px}
.agency-logo{
  height:96px;background:#fff;border-radius:6px;display:grid;
  place-items:center;font-weight:800;color:var(--brown-dark);
  font-size:20px;border:1px solid rgba(62,36,30,.08);
  transition:var(--transition-all);
}
.agency-card:hover .agency-logo{border-color:var(--color-primary);box-shadow:0 8px 24px rgba(228,176,64,.15)}

/* ============================================================
   NEWS
   ============================================================ */
.news-card{padding:0;overflow:hidden;border-radius:2px}
.news-img{aspect-ratio:416/290;overflow:hidden}
.news-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.news-card:hover .news-img img{transform:scale(1.08)}
.news-body{padding:26px}
.news-body h3{
  font-family:var(--font-body);font-size:20px;line-height:1.4;
  margin:0 0 24px;color:var(--brown-dark);font-weight:600;
}
.detail-link{
  display:inline-flex;align-items:center;gap:10px;
  color:var(--brown-dark);text-decoration:none;
  text-transform:uppercase;font-size:13px;font-weight:700;
  letter-spacing:.06em;transition:var(--transition-all);
}
.detail-link:hover{color:var(--color-primary);gap:15px}

/* Category badge */
.news-cat{
  display:inline-block;background:var(--color-primary);color:var(--brown-dark);
  font-size:11px;text-transform:uppercase;font-weight:700;letter-spacing:.08em;
  padding:5px 14px;border-radius:50px;margin-bottom:14px;
}

/* ============================================================
   STATS COUNTER
   ============================================================ */
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center;
}
.stat-item{padding:30px}
.stat-num{
  font-family:var(--font-title);font-size:clamp(42px,5vw,72px);
  color:var(--color-primary);line-height:1;
}
.stat-label{font-size:14px;text-transform:uppercase;letter-spacing:.08em;margin-top:12px;opacity:.75}

/* ============================================================
   CONTACT FORM
   ============================================================ */
.form-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  padding:42px;border-radius:2px;transition:var(--transition-smooth);
}
.form-card:hover{border-color:rgba(228,176,64,.15)}
.form-card input,.form-card textarea{
  width:100%;border:0;border-bottom:1.5px solid rgba(255,255,255,.2);
  background:transparent;color:#fff;padding:18px 0;margin-bottom:16px;
  font:inherit;font-size:16px;transition:var(--transition-all);
  outline:none;
}
.form-card input:focus,.form-card textarea:focus{
  border-bottom-color:var(--color-primary);
}
.form-card textarea{min-height:100px;resize:vertical}
.form-card input::placeholder,.form-card textarea::placeholder{color:rgba(255,255,255,.55)}
.form-msg{margin-top:14px;font-size:14px;font-weight:600}
.disclaimer{
  font-size:12px;line-height:1.7;color:rgba(255,255,255,.62);
  margin-top:32px;font-style:italic;
}

/* ============================================================
   CONTACT INFO BLOCKS
   ============================================================ */
.contact-info{display:grid;gap:28px}
.contact-block-label{
  font-size:13px;text-transform:uppercase;color:rgba(255,255,255,.55);
  margin-bottom:8px;letter-spacing:.08em;
}
.contact-block-value{font-size:18px;line-height:1.55;font-weight:700}

/* ============================================================
   FOOTER
   ============================================================ */
.footer-section{
  background:var(--brown-darker);color:#fff;position:relative;overflow:hidden;
}
.footer-section:before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--color-primary),transparent);
}
.footer-grid{
  display:grid;grid-template-columns:1fr 1.15fr;gap:90px;
}
.copyright{
  border-top:1px solid rgba(228,176,64,.1);padding:22px 0;margin-top:70px;
  font-size:12px;color:rgba(255,255,255,.62);letter-spacing:.03em;
}

/* ============================================================
   SCROLL REVEAL ANIMATION
   ============================================================ */
.reveal{
  opacity:0;transform:translateY(38px);
  transition:opacity .85s cubic-bezier(.22,.61,.36,1),
             transform .85s cubic-bezier(.22,.61,.36,1);
}
.reveal.in{opacity:1;transform:none}

/* Stagger children */
.reveal-stagger > *{opacity:0;transform:translateY(30px)}
.reveal-stagger.in > *:nth-child(1){transition:opacity .6s .05s,transform .6s .05s;opacity:1;transform:none}
.reveal-stagger.in > *:nth-child(2){transition:opacity .6s .15s,transform .6s .15s;opacity:1;transform:none}
.reveal-stagger.in > *:nth-child(3){transition:opacity .6s .25s,transform .6s .25s;opacity:1;transform:none}
.reveal-stagger.in > *:nth-child(4){transition:opacity .6s .35s,transform .6s .35s;opacity:1;transform:none}
.reveal-stagger.in > *:nth-child(5){transition:opacity .6s .45s,transform .6s .45s;opacity:1;transform:none}
.reveal-stagger.in > *:nth-child(6){transition:opacity .6s .55s,transform .6s .55s;opacity:1;transform:none}

/* Scale reveal */
.reveal-scale{opacity:0;transform:scale(.94);transition:opacity .8s ease,transform .8s ease}
.reveal-scale.in{opacity:1;transform:scale(1)}

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes heroZoom{
  from{transform:scale(1.02)}
  to{transform:scale(1.12)}
}
@keyframes scrollDot{
  0%{top:-20px}100%{top:68px}
}
@keyframes scrollPulse{
  0%,100%{opacity:1;transform:translateX(-50%) translateY(0)}
  50%{opacity:.6;transform:translateX(-50%) translateY(6px)}
}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(30px)}
  to{opacity:1;transform:none}
}
@keyframes shimmer{
  0%{background-position:-200% center}
  100%{background-position:200% center}
}
@keyframes float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-12px)}
}
@keyframes goldPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(228,176,64,.4)}
  50%{box-shadow:0 0 0 12px rgba(228,176,64,0)}
}

/* Floating decorative elements */
.float-slow{animation:float 6s ease-in-out infinite}
.float-medium{animation:float 4.5s ease-in-out infinite}
.float-fast{animation:float 3s ease-in-out infinite}

/* Gold decorative dots */
.gold-dots{
  position:absolute;width:6px;height:6px;border-radius:50%;
  background:var(--color-primary);opacity:.35;
}

/* Decorative corner accent */
.corner-accent{
  position:absolute;width:40px;height:40px;pointer-events:none;
}
.corner-accent:before,.corner-accent:after{
  content:'';position:absolute;background:var(--color-primary);opacity:.25;
}
.corner-accent.tl{top:20px;left:20px}
.corner-accent.tl:before{top:0;left:0;width:40px;height:1px}
.corner-accent.tl:after{top:0;left:0;width:1px;height:40px}
.corner-accent.br{bottom:20px;right:20px}
.corner-accent.br:before{bottom:0;right:0;width:40px;height:1px}
.corner-accent.br:after{bottom:0;right:0;width:1px;height:40px}

/* ============================================================
   MOBILE NAV
   ============================================================ */
.mobile-nav-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:9998;
  opacity:0;pointer-events:none;transition:opacity .4s ease;
}
.mobile-nav-overlay.open{opacity:1;pointer-events:auto}

/* ============================================================
   MOBILE STICKY BOTTOM FORM
   ============================================================ */
.mobile-bar{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:10001;
  background:rgba(42,24,20,.97);backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-top:1px solid rgba(228,176,64,.18);
  padding:6px 10px 4px;
  padding-bottom:max(4px,env(safe-area-inset-bottom));
}
.mb-headline{
  display:block;text-align:center;font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;
  color:var(--color-primary);margin-bottom:4px;
}
.mobile-bar form.gladia-cf7-mobile{
  display:flex;gap:5px;align-items:center;
}
.mobile-bar .gladia-cf7-mobile .form-row{flex:1;min-width:0}
.mobile-bar .gladia-cf7-mobile input,
.mobile-bar .gladia-cf7-mobile .wpcf7-text{
  width:100%;height:36px;border-radius:7px;
  border:1.5px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.07);color:#fff;
  padding:0 8px;font:12px/1 var(--font-body);outline:none;
  transition:var(--transition-all);margin:0;box-sizing:border-box;
}
.mobile-bar .gladia-cf7-mobile input:focus{border-color:var(--color-primary);background:rgba(255,255,255,.12)}
.mobile-bar .gladia-cf7-mobile input::placeholder{color:rgba(255,255,255,.45);font-size:10px}
.mobile-bar .gladia-cf7-mobile .form-submit{flex:none}
.mobile-bar .gladia-cf7-mobile button,
.mobile-bar .gladia-cf7-mobile .wpcf7-submit,
.mobile-bar .gladia-cf7-mobile input[type="submit"]{
  height:36px;padding:0 14px;border-radius:7px;border:0;
  background:var(--color-primary);color:var(--brown-dark);
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.04em;cursor:pointer;white-space:nowrap;
  transition:var(--transition-bounce);margin:0;
}
.mobile-bar .gladia-cf7-mobile button:hover,
.mobile-bar .gladia-cf7-mobile .wpcf7-submit:hover{background:var(--color-primary-light)}
.mobile-bar .gladia-cf7-mobile button:active,
.mobile-bar .gladia-cf7-mobile .wpcf7-submit:active{transform:scale(.95)}
/* Hide CF7's default response output (inline toast instead) */
.mobile-bar .wpcf7-response-output{
  position:absolute;bottom:100%;left:10px;right:10px;
  background:#4caf50;color:#fff;text-align:center;font-size:11px;
  font-weight:600;padding:6px 12px;border-radius:6px 6px 0 0;
  margin:0!important;border:0;
}
/* Hide CF7 spinner */
.mobile-bar .wpcf7-spinner{display:none}
/* CF7 validation errors — compact */
.mobile-bar .wpcf7-not-valid-tip{font-size:9px;position:absolute;bottom:-14px;left:0;color:#ff6b6b}

/* Hide Flatsome elements that conflict on gladia-vlasta pages */
body.gladia-vlasta .flatsome-footer,
body.gladia-vlasta .absolute-footer,
body.gladia-vlasta .footer-wrapper{display:none!important}

/* Agency card heading color */
.agency-card h3{color:var(--brown-dark)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1279px){
  :root{--width-container:calc(100vw - 72px)}
  html{font-size:14px}
  .main-nav{gap:18px}
  .section-pad{padding:90px 0}
  .section-pad-top{padding-top:90px}
  .section-pad-bottom{padding-bottom:90px}
  .intro-grid,.overview-wrap,.map-layout,.award-layout,.footer-grid{gap:50px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:900px){
  :root{--width-container:100vw}
  .container-fluid{width:100%;padding:0 18px}
  .main-nav,.header-actions{display:none}
  .hamburger{display:block}
  .header{position:fixed!important}

  /* Mobile bottom form */
  .mobile-bar{display:block}
  body.gladia-vlasta{padding-bottom:96px}
  .fixed-contact{display:none!important}
  .footer-section{padding-bottom:96px}

    z-index:9999;
    display:flex;position:absolute;left:16px;right:16px;top:90px;
    background:rgba(62,36,30,.985);padding:28px;
    flex-direction:column;align-items:flex-start;
    border:1px solid rgba(228,176,64,.12);border-radius:2px;
    box-shadow:0 20px 50px rgba(0,0,0,.3);

  .intro-grid,.overview-wrap,.map-layout,.amenity-map,.award-layout,.footer-grid{
    grid-template-columns:1fr;gap:42px;
  }
  .fact-row{grid-template-columns:1fr;gap:8px}
  .partner-grid,.agency-grid,.news-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr}
  .tower-tabs{grid-template-columns:1fr}
  .tower-tab{border-right:0;border-bottom:1px solid rgba(228,176,64,.1)}
  .stats-grid{grid-template-columns:1fr 1fr;gap:20px}

  .hero-title{font-size:clamp(28px,7vw,40px)}
  .banner-content{padding-bottom:100px}
  .cinematic{min-height:580px;background-attachment:scroll}
  .fixed-contact{display:none}
  .hero-badge:before{width:24px}
  .story-line{padding:70px 0}
}

@media(max-width:549px){
  html{font-size:13px}
  .section-pad{padding:64px 0}
  .section-pad-top{padding-top:64px}
  .section-pad-bottom{padding-bottom:64px}
  .markers{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr}
  .hero-actions{flex-direction:column}
  .hero-actions .button-blur,.hero-actions .btn-cream{width:100%}
  .time-item{grid-template-columns:72px 1fr;padding:14px 16px}
  .time-num{font-size:36px}
  .tabs{gap:8px}
  .tab-btn{padding:0 18px;height:42px;font-size:12px}
  .footer-grid{gap:50px}
}

/* ============================================================
   FULLSCREEN OVERLAY MENU
   ============================================================ */
.full-menu-overlay{
  position:fixed;inset:0;z-index:99999;
  background:rgba(6,20,38,.97);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .35s ease, visibility .35s ease;
}
.full-menu-overlay.open{
  opacity:1;visibility:visible;pointer-events:auto;
}
.full-menu-container{
  text-align:center;padding:40px 24px;max-width:420px;width:100%;
}
.full-menu-close{
  position:absolute;top:18px;right:20px;
  background:none;border:none;color:#f5e6d3;
  font-size:36px;line-height:1;cursor:pointer;
  padding:8px 12px;opacity:.7;transition:opacity .25s;
}
.full-menu-close:hover{opacity:1}
.full-menu-nav{
  display:flex;flex-direction:column;gap:0;
  margin-bottom:40px;
}
.full-menu-nav a{
  display:block;padding:14px 0;
  color:rgba(245,230,211,.8);
  font-family:'Playfair Display',Georgia,serif;
  font-size:22px;font-weight:500;letter-spacing:1px;
  text-decoration:none;transition:color .25s, padding-left .25s;
  border-bottom:1px solid rgba(228,176,64,.12);
}
.full-menu-nav a:hover{color:#e4b040;padding-left:8px}
.full-menu-contact{
  display:flex;flex-direction:column;gap:14px;align-items:center;
}
.full-menu-contact .phone-pill{
  font-size:20px;font-weight:600;color:#f5e6d3;
  text-decoration:none;letter-spacing:.5px;
}
.full-menu-contact .button-blur{
  display:inline-block;padding:12px 36px;
  background:rgba(228,176,64,.15);border:1px solid rgba(228,176,64,.35);
  color:#e4b040;font-size:15px;font-weight:600;text-decoration:none;
  border-radius:2px;transition:all .25s;
}
.full-menu-contact .button-blur:hover{
  background:rgba(228,176,64,.25);border-color:#e4b040;
}

@media(max-width:480px){
  .full-menu-nav a{font-size:19px;padding:12px 0}
  .full-menu-container{padding:32px 20px}
}


/* ============================================================
   MOBILE HOMEPAGE POLISH — 2026-06-08
   Desktop giữ nguyên, chỉ chỉnh <= 767px.
   ============================================================ */
@media (max-width: 767px) {
  html { overflow-x: hidden; }
  body.gladia-vlasta { overflow-x: hidden; background: var(--cream-light); padding-bottom: 104px; }
  .container-fluid { width: 100% !important; max-width: 100% !important; padding-left: 18px !important; padding-right: 18px !important; }

  .header { padding: 10px 0 !important; background: linear-gradient(180deg, rgba(42,24,20,.96), rgba(42,24,20,.78)) !important; backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid rgba(215,173,90,.14); }
  .header-inner { min-height: 54px; }
  .logo { max-height: 38px !important; max-width: 148px; object-fit: contain; }
  .hamburger { display: inline-flex !important; width: 44px; height: 44px; align-items: center; justify-content: center; border: 1px solid rgba(255,255,255,.18); border-radius: 999px; background: rgba(255,255,255,.08); }
  .hamburger span { width: 18px; height: 2px; background: #fff; margin: 3px 0; display: block; }

  .full-menu-overlay.open, .full-menu-overlay.active { padding: 20px !important; }
  .full-menu-container { width: 100% !important; min-height: auto !important; padding: 56px 24px 28px !important; border-radius: 18px !important; }
  .full-menu-nav { gap: 8px !important; }
  .full-menu-nav a { font-size: 22px !important; line-height: 1.2 !important; padding: 10px 0 !important; }

  .banner-section { min-height: 88svh !important; align-items: flex-end !important; }
  .banner-bg { background-position: center top !important; transform: none !important; }
  .banner-bg:after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(42,24,20,.34) 0%, rgba(42,24,20,.42) 34%, rgba(42,24,20,.92) 100%); }
  .banner-content { min-height: 88svh !important; align-items: flex-end !important; padding-top: 92px !important; padding-bottom: 82px !important; }
  .hero-copy { max-width: 100% !important; }
  .hero-badge { font-size: 11px !important; letter-spacing: .13em !important; line-height: 1.5 !important; margin-bottom: 12px !important; gap: 10px !important; }
  .hero-badge:before { width: 24px !important; }
  body.gladia-vlasta .hero-title, .hero-title { font-size: clamp(28px, 8.4vw, 36px) !important; line-height: 1.12 !important; letter-spacing: -.025em !important; margin-bottom: 14px !important; text-wrap: balance; }
  .hero-desc { font-size: 15px !important; line-height: 1.58 !important; margin: 0 0 22px !important; max-width: 100% !important; color: rgba(255,255,255,.88) !important; }
  .hero-actions { display: grid !important; grid-template-columns: 1fr !important; gap: 10px !important; width: 100% !important; }
  .hero-actions a, .button-blur, .btn-cream { width: 100%; justify-content: center; min-height: 48px; padding: 13px 18px !important; font-size: 13px !important; border-radius: 999px !important; }
  .scroll-down { display: none !important; }

  .section-pad { padding-top: 64px !important; padding-bottom: 64px !important; }
  .section-pad-top { padding-top: 64px !important; }
  .section-pad-bottom { padding-bottom: 64px !important; }
  .story-line { padding: 54px 0 !important; }
  .eyebrow { font-size: 11px !important; letter-spacing: .14em !important; margin-bottom: 10px !important; }
  .title-xl, .title-lg, .title-md, .intro-kicker { font-size: clamp(24px, 7.2vw, 32px) !important; line-height: 1.18 !important; letter-spacing: -.015em !important; text-wrap: balance; }
  .lead { font-size: 15px !important; line-height: 1.72 !important; }
  .gold-line { margin: 18px 0 !important; }
  .center .gold-line { margin-left: auto !important; margin-right: auto !important; }

  .intro-grid, .overview-wrap, .map-layout, .amenity-map, .award-layout, .footer-grid { display: grid !important; grid-template-columns: 1fr !important; gap: 28px !important; }
  .image-card, .overview-image, .map-img, .floor-img, .amenity-image { border-radius: 16px !important; box-shadow: 0 14px 38px rgba(73,41,25,.12) !important; }
  .image-card img, .map-img img, .floor-img img, .amenity-image img { min-height: 0 !important; height: auto !important; aspect-ratio: 16 / 10; object-fit: cover; }
  .amenity-image { min-height: 0 !important; }

  .bg-brown .eyebrow, .bg-brown .title-lg, .bg-brown .title-md { color: #fff !important; }
  .facts-list { margin-top: 10px; }
  .fact-row { grid-template-columns: 1fr !important; gap: 6px !important; padding: 16px 0 !important; }
  .fact-row:hover { padding-left: 0 !important; }
  .fact-label { font-size: 11px !important; color: rgba(255,255,255,.68) !important; }
  .fact-value { font-size: 15px !important; }

  .time-list { margin-top: 24px !important; gap: 10px !important; }
  .time-item { grid-template-columns: 72px 1fr !important; gap: 12px !important; padding: 14px !important; border-radius: 14px !important; background: rgba(255,255,255,.78) !important; }
  .time-num { font-size: 34px !important; }
  .time-num span { display: block; margin: 2px 0 0 !important; font-size: 10px !important; }

  .tabs { display: flex !important; overflow-x: auto !important; gap: 8px !important; justify-content: flex-start !important; padding: 0 2px 10px !important; margin: 24px -2px 24px !important; scrollbar-width: none; }
  .tabs::-webkit-scrollbar { display: none; }
  .tab-btn { flex: 0 0 auto !important; height: 42px !important; padding: 0 16px !important; font-size: 11px !important; white-space: nowrap !important; }

  .markers { grid-template-columns: 1fr !important; gap: 6px !important; }
  .marker-item { padding: 10px 0 !important; gap: 12px !important; }
  .marker-no { width: 30px !important; height: 30px !important; font-size: 12px !important; }
  .cinematic { min-height: 520px !important; padding: 86px 0 !important; background-position: center !important; }
  .cinematic-content { max-width: 100% !important; padding: 26px 22px !important; border-radius: 18px !important; background: rgba(42,24,20,.62) !important; backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }

  .tower-tabs { grid-template-columns: 1fr !important; gap: 12px !important; }
  .tower-tab { padding: 22px !important; border-radius: 16px !important; }
  .gallery-grid, .partner-grid, .agency-grid, .news-grid { grid-template-columns: 1fr !important; gap: 16px !important; grid-auto-rows: auto !important; }
  .gallery-grid .image-card { height: auto !important; }
  .partner-card, .agency-card, .news-card { min-height: 0 !important; padding: 22px !important; border-radius: 16px !important; background: rgba(255,255,255,.74) !important; }
  .partner-logo { height: auto !important; min-height: 48px; font-size: 19px !important; }
  .award-list { max-height: none !important; overflow: visible !important; }
  .award-item { gap: 14px !important; padding: 16px 0 !important; }
  .award-year { font-size: 22px !important; min-width: 42px; }

  .news-img img { width: 100%; aspect-ratio: 16 / 10; object-fit: cover; border-radius: 14px 14px 0 0; }
  .news-body { padding: 18px !important; }
  .news-body h3 { font-size: 18px !important; line-height: 1.35 !important; }

  .footer-section { padding-bottom: 112px !important; }
  .footer-grid { gap: 28px !important; }
  .contact-info .logo { max-width: 160px; }
  .form-card { padding: 24px !important; border-radius: 18px !important; }
  .form-card input, .form-card textarea { min-height: 48px !important; font-size: 15px !important; }

  .mobile-bar { display: block !important; padding: 8px 10px max(8px, env(safe-area-inset-bottom)) !important; background: rgba(42,24,20,.98) !important; }
  .mb-headline { font-size: 10px !important; margin-bottom: 6px !important; }
  .mobile-bar form.gladia-cf7-mobile { gap: 6px !important; }
  .mobile-bar .gladia-cf7-mobile input { height: 40px !important; border-radius: 10px !important; font-size: 12px !important; }
  .mobile-bar .gladia-cf7-mobile button, .mobile-bar .gladia-cf7-mobile input[type=submit] { height: 40px !important; border-radius: 10px !important; padding: 0 12px !important; font-size: 11px !important; white-space: nowrap !important; }
}

@media (max-width: 380px) {
  body.gladia-vlasta .hero-title, .hero-title { font-size: 27px !important; }
  .title-xl, .title-lg, .title-md, .intro-kicker { font-size: 23px !important; }
  .container-fluid { padding-left: 14px !important; padding-right: 14px !important; }
  .mobile-bar form.gladia-cf7-mobile { display: grid !important; grid-template-columns: 1fr 1fr 88px; }
}

/* Fix Flatsome off-canvas menu leaking into custom homepage when Flatsome CSS is dequeued */
body.gladia-vlasta #main-menu.mobile-sidebar,
body.gladia-vlasta .mobile-sidebar.mfp-hide,
body.gladia-vlasta .mfp-hide {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Delayed non-critical UI for mobile performance */
body.gladia-vlasta [data-delay-show] {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transition: opacity .35s ease, visibility .35s ease !important;
}
body.gladia-vlasta [data-delay-show].is-visible {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}
@media (max-width: 767px) {
  body.gladia-vlasta { padding-bottom: 0 !important; }
  body.gladia-vlasta:has(.mobile-bar.is-visible) { padding-bottom: 96px !important; }
}
