/* ============================================================
   Elements Residences — front-end styles
   Last modified: 2026-06-12
   Palette taken from the brochure: warm taupe/greige, walnut brown,
   muted gold. Display serif = Cormorant Garamond; UI sans = Jost.
   ============================================================ */

:root {
    --el-cream:   #efeae1;
    --el-sand:    #d9cfbe;
    --el-taupe:   #9a8c78;
    --el-stone:   #7d7464;
    --el-walnut:  #4a3f35;
    --el-bark:    #2f2820;
    --el-gold:    #b2965f;
    --el-ink:     #2a2620;
    --el-paper:   #f6f3ee;
    --el-line:    rgba(74,63,53,.16);
    --el-serif:   'Cormorant Garamond', Georgia, serif;
    --el-sans:    'Jost', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --el-maxw:    1200px;
    --el-pad:     clamp(1.25rem, 5vw, 4rem);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body.el {
    margin: 0;
    font-family: var(--el-sans);
    font-weight: 300;
    color: var(--el-ink);
    background: var(--el-paper);
    line-height: 1.65;
    letter-spacing: .01em;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
h1, h2, h3 { font-weight: 400; margin: 0; }

.el-eyebrow {
    display: inline-block;
    font-size: .72rem;
    letter-spacing: .28em;
    text-transform: uppercase;
    color: var(--el-gold);
    margin-bottom: 1rem;
}

/* ── Brand mark (CSS hexagon placeholder until the gold SVG arrives) ── */
.el-nav__brand-mark {
    width: 26px; height: 30px;
    background: var(--el-gold);
    clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
    display: inline-block;
}
.el-nav__brand-mark--lg { width: 44px; height: 50px; margin: 0 auto .9rem; }

/* ── Navigation ─────────────────────────────────────────── */
.el-nav {
    position: fixed; inset: 0 0 auto 0; z-index: 50;
    transition: background .35s ease, box-shadow .35s ease;
}
.el-nav__inner {
    max-width: var(--el-maxw); margin: 0 auto;
    padding: 1.1rem var(--el-pad);
    display: flex; align-items: center; justify-content: space-between; gap: 1.5rem;
}
.el-nav__brand { display: flex; align-items: center; gap: .6rem; color: #fff; }
.el-nav__brand-text { font-family: var(--el-sans); font-weight: 400; letter-spacing: .22em; font-size: .9rem; line-height: 1; display: flex; flex-direction: column; }
.el-nav__brand-text small { font-size: .52rem; letter-spacing: .42em; opacity: .8; margin-top: 2px; }
.el-nav__links { display: flex; align-items: center; gap: 1.6rem; }
.el-nav__links a { color: #fff; font-size: .8rem; letter-spacing: .12em; text-transform: uppercase; opacity: .9; transition: opacity .2s, color .2s; }
.el-nav__links a:hover { opacity: 1; color: var(--el-gold); }
.el-nav__lang { border: 1px solid rgba(255,255,255,.5); padding: .25rem .6rem; border-radius: 2px; font-size: .7rem !important; }
.el-nav__burger { display: none; flex-direction: column; gap: 5px; background: none; border: 0; cursor: pointer; padding: 6px; }
.el-nav__burger span { width: 26px; height: 2px; background: #fff; transition: .25s; }
.el-nav__drawer { display: none; }

/* Scrolled / solid nav */
.el-nav.is-solid { background: rgba(47,40,32,.96); box-shadow: 0 1px 0 rgba(255,255,255,.08); backdrop-filter: blur(6px); }

/* ── Hero ───────────────────────────────────────────────── */
.el-hero { position: relative; height: 100svh; min-height: 560px; overflow: hidden; color: #fff; }
.el-hero__slider, .el-hero__slide { position: absolute; inset: 0; }
.el-hero__slide { opacity: 0; transition: opacity 1.4s ease; margin: 0; }
.el-hero__slide.is-active { opacity: 1; }
.el-hero__slide img { width: 100%; height: 100%; object-fit: cover; }
.el-hero__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(20,16,12,.45) 0%, rgba(20,16,12,.05) 35%, rgba(20,16,12,.45) 100%);
}
.el-hero__bar {
    position: absolute; left: 50%; bottom: clamp(5rem, 16vh, 9rem);
    transform: translateX(-50%);
    width: min(92%, 880px); text-align: center;
    background: rgba(30,24,18,.28);
    backdrop-filter: blur(7px);
    border: 1px solid rgba(255,255,255,.16);
    padding: 2rem clamp(1rem, 4vw, 3rem);
}
.el-hero__eyebrow { display: block; font-size: .72rem; letter-spacing: .32em; text-transform: uppercase; color: rgba(255,255,255,.88); }
.el-hero__rule { display: block; width: 46px; height: 1px; background: var(--el-gold); margin: 1.1rem auto; }
.el-hero__title { font-family: var(--el-sans); font-weight: 300; letter-spacing: .34em; font-size: clamp(1.4rem, 4.5vw, 2.7rem); }
.el-hero__title span { font-weight: 500; }
.el-hero__tag { font-family: var(--el-serif); font-style: italic; font-size: clamp(1.05rem, 2.4vw, 1.5rem); margin: 0; color: rgba(255,255,255,.95); }
.el-hero__dots { position: absolute; left: 50%; bottom: 2.2rem; transform: translateX(-50%); display: flex; gap: .6rem; z-index: 3; }
.el-hero__dot { width: 9px; height: 9px; border-radius: 50%; border: 1px solid #fff; background: transparent; cursor: pointer; padding: 0; transition: background .25s; }
.el-hero__dot.is-active { background: var(--el-gold); border-color: var(--el-gold); }
.el-hero__scroll { position: absolute; left: 50%; bottom: 1rem; transform: translateX(-50%); width: 1px; height: 38px; background: rgba(255,255,255,.5); overflow: hidden; }
.el-hero__scroll span { position: absolute; top: -38px; left: 0; width: 1px; height: 38px; background: var(--el-gold); animation: el-scroll 2.2s infinite; }
@keyframes el-scroll { 0% { top: -38px; } 60%,100% { top: 38px; } }

/* ── Content bands ──────────────────────────────────────── */
.el-band { padding: clamp(3.5rem, 9vw, 7rem) var(--el-pad); }
.el-band:nth-child(odd of .el-band) { background: var(--el-paper); }
.el-band__inner {
    max-width: var(--el-maxw); margin: 0 auto;
    display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 6vw, 5rem); align-items: center;
}
.el-band--flip .el-band__media { order: -1; }
.el-band--solo .el-band__inner { grid-template-columns: 1fr; max-width: 760px; text-align: center; }
.el-band--solo .el-eyebrow { margin-left: auto; margin-right: auto; }
.el-band__h2 { font-family: var(--el-serif); font-size: clamp(1.8rem, 4vw, 3rem); line-height: 1.1; color: var(--el-walnut); margin-bottom: 1.4rem; }
.el-prose { font-size: 1.02rem; color: var(--el-stone); }
.el-prose p { margin: 0 0 1rem; }
.el-prose strong { color: var(--el-walnut); font-weight: 500; }
.el-prose a { color: var(--el-gold); text-decoration: underline; text-underline-offset: 3px; }
/* Eyebrow + heading authored inside the section's TinyMCE body */
.el-prose .el-eyebrow { display: inline-block; margin: 0 0 .8rem; }
.el-prose h2 { font-family: var(--el-serif); font-weight: 400; font-size: clamp(1.8rem, 4vw, 3rem); line-height: 1.1; color: var(--el-walnut); margin: 0 0 1.3rem; }
.el-prose h3 { font-family: var(--el-serif); font-weight: 400; font-size: 1.5rem; color: var(--el-walnut); margin: 1.6rem 0 .6rem; }
.el-band__fig { margin: 0; overflow: hidden; }
.el-band__fig img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.el-band__thumbs { display: grid; grid-template-columns: repeat(3, 1fr); gap: .6rem; margin-top: .6rem; }
.el-band__thumbs img { aspect-ratio: 1; object-fit: cover; }

/* ── Floorplans ─────────────────────────────────────────── */
.el-fp .el-fp__intro { max-width: 760px; margin: 0 auto; text-align: center; }
.el-fp__elevation { margin: 2.5rem auto 3rem; max-width: 920px; text-align: center; }
.el-fp__elevation img { width: 100%; background: #fff; }
.el-fp__elevation figcaption { font-size: .75rem; letter-spacing: .18em; text-transform: uppercase; color: var(--el-stone); margin-top: .8rem; }

/* Balanced grid — 4 then 3 centred; wraps gracefully on smaller screens */
.el-fp__grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 1.4rem; max-width: var(--el-maxw); margin: 0 auto; }
.el-fp__card { flex: 0 1 270px; background: #fff; border: 1px solid var(--el-line); padding: 0; text-align: left; cursor: pointer; font: inherit; color: inherit; display: flex; flex-direction: column; transition: box-shadow .25s ease, transform .25s ease; }
.el-fp__card:hover { box-shadow: 0 14px 34px rgba(47,40,32,.16); transform: translateY(-3px); }
.el-fp__card:focus-visible { outline: 2px solid var(--el-gold); outline-offset: 2px; }
.el-fp__card.is-sold { opacity: .6; }
.el-fp__iso { background: #fff; padding: 1rem 1rem .6rem; display: flex; justify-content: center; align-items: center; }
.el-fp__iso img { width: 100%; height: 150px; object-fit: contain; }
.el-fp__meta { padding: 1rem 1.3rem 1.4rem; border-top: 1px solid var(--el-line); display: flex; flex-direction: column; gap: .25rem; }
.el-fp__name { font-family: var(--el-serif); font-size: 1.5rem; color: var(--el-walnut); display: flex; align-items: center; gap: .5rem; }
.el-fp__chip { font-family: var(--el-sans); font-style: normal; font-size: .58rem; letter-spacing: .14em; text-transform: uppercase; color: var(--el-gold); border: 1px solid var(--el-gold); padding: .12rem .45rem; border-radius: 2px; }
.el-fp__floor { font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--el-stone); }
.el-fp__from { font-size: .92rem; color: var(--el-walnut); font-weight: 500; margin-top: .35rem; }
.el-fp__card::after { content: ''; }

/* Popup / lightbox */
.el-fp-lb { position: fixed; inset: 0; z-index: 200; background: rgba(28,22,16,.93); display: flex; align-items: center; justify-content: center; padding: 5vmin 3vmin; }
.el-fp-lb[hidden] { display: none; }
.el-fp-lb__stage { margin: 0; max-width: 1080px; width: 100%; display: flex; flex-direction: column; align-items: center; }
.el-fp-lb__img { max-width: 100%; max-height: 74vh; object-fit: contain; background: #fff; padding: 1.4rem; }
.el-fp-lb__img.is-in { animation: el-lb-in .35s ease; }
@keyframes el-lb-in { from { opacity: .2; transform: scale(.985); } to { opacity: 1; transform: none; } }
.el-fp-lb__bar { margin-top: 1.1rem; text-align: center; color: #fff; display: flex; flex-direction: column; gap: .35rem; }
.el-fp-lb__name { font-family: var(--el-serif); font-size: 1.7rem; }
.el-fp-lb__specs { font-size: .85rem; color: rgba(255,255,255,.82); }
.el-fp-lb__price { font-size: .95rem; color: var(--el-gold); letter-spacing: .03em; }
.el-fp-lb__close { position: absolute; top: 1rem; right: 1.4rem; background: none; border: 0; color: #fff; font-size: 2.6rem; line-height: 1; cursor: pointer; }
.el-fp-lb__nav { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(255,255,255,.12); border: 0; color: #fff; font-size: 1.8rem; width: 48px; height: 48px; border-radius: 50%; cursor: pointer; }
.el-fp-lb__nav:hover { background: rgba(255,255,255,.26); }
.el-fp-lb__prev { left: 2.5vmin; }
.el-fp-lb__next { right: 2.5vmin; }
.el-fp-lb__toggle { position: absolute; top: 1.1rem; left: 50%; transform: translateX(-50%); display: flex; gap: .4rem; z-index: 2; }
.el-fp-lb__toggle[hidden] { display: none; }
.el-fp-lb__toggle button { background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.32); color: #fff; font-family: var(--el-sans); font-size: .7rem; letter-spacing: .12em; text-transform: uppercase; padding: .4rem .9rem; cursor: pointer; border-radius: 2px; }
.el-fp-lb__toggle button.is-active { background: var(--el-gold); border-color: var(--el-gold); color: #2a2620; }

/* ── Pricing ────────────────────────────────────────────── */
.el-price .el-price__intro { max-width: 760px; margin: 0 auto 2.2rem; text-align: center; }
.el-price__wrap { max-width: 820px; margin: 0 auto; overflow-x: auto; }
.el-price__table { width: 100%; }
.el-price table { width: 100%; border-collapse: collapse; font-size: .92rem; }
.el-price th { font-family: var(--el-sans); font-weight: 500; font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--el-gold); text-align: left; padding: .6rem .5rem; border-bottom: 1px solid var(--el-taupe); }
.el-price td { padding: .7rem .5rem; border-bottom: 1px solid var(--el-line); color: var(--el-stone); }
.el-price td strong { color: var(--el-walnut); }
.el-price__amt { text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; color: var(--el-walnut) !important; }
.el-price tr.is-sold td { text-decoration: line-through; opacity: .55; }
.el-price__note { max-width: 820px; margin: 2.2rem auto 0; text-align: center; font-size: .82rem; color: var(--el-stone); }

/* ── Interiors gallery ──────────────────────────────────── */
.el-gallery .el-gallery__intro { max-width: 760px; margin: 0 auto 2.5rem; text-align: center; }
.el-gallery__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
.el-gallery__item { margin: 0; overflow: hidden; }
.el-gallery__item img { width: 100%; aspect-ratio: 3/2; object-fit: cover; transition: transform .6s ease; }
.el-gallery__item:hover img { transform: scale(1.04); }

/* ── Nav brochure button ────────────────────────────────── */
.el-nav__cta { font-family: var(--el-sans); font-size: .72rem; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: #fff; background: var(--el-gold); border: 1px solid var(--el-gold); padding: .5rem 1.1rem; cursor: pointer; transition: background .2s, color .2s; }
.el-nav__cta:hover { background: transparent; color: var(--el-gold); }
.el-nav.is-solid .el-nav__cta { color: #2a2620; }
.el-nav.is-solid .el-nav__cta:hover { color: var(--el-gold); }

/* ── Brochure CTA strip ─────────────────────────────────── */
.el-cta { background: linear-gradient(150deg, var(--el-walnut), var(--el-bark)); color: #fff; padding: clamp(3rem, 7vw, 5rem) var(--el-pad); text-align: center; }
.el-cta__inner { max-width: 720px; margin: 0 auto; }
.el-cta__text { color: rgba(255,255,255,.9); }
.el-cta__text .el-eyebrow { color: var(--el-gold); }
.el-cta__text h2 { color: #fff; font-family: var(--el-serif); font-size: clamp(1.7rem, 3.6vw, 2.6rem); margin: 0 0 1rem; }
.el-cta__text strong { color: #fff; }
.el-cta__btn { margin-top: 1.8rem; font-family: var(--el-sans); font-size: .8rem; font-weight: 500; letter-spacing: .18em; text-transform: uppercase; color: #2a2620; background: var(--el-gold); border: 1px solid var(--el-gold); padding: .95rem 2.4rem; cursor: pointer; transition: background .2s, color .2s, transform .2s; }
.el-cta__btn:hover { background: transparent; color: var(--el-gold); transform: translateY(-1px); }

/* ── Modal ──────────────────────────────────────────────── */
.el-modal { position: fixed; inset: 0; z-index: 300; display: flex; align-items: center; justify-content: center; padding: 5vmin 4vmin; }
.el-modal[hidden] { display: none; }
.el-modal__backdrop { position: absolute; inset: 0; background: rgba(28,22,16,.74); backdrop-filter: blur(3px); }
.el-modal__dialog { position: relative; background: var(--el-paper); max-width: 460px; width: 100%; padding: clamp(1.8rem, 4vw, 2.8rem); text-align: center; box-shadow: 0 30px 80px rgba(0,0,0,.4); }
.el-modal__close { position: absolute; top: .7rem; right: 1rem; background: none; border: 0; font-size: 2rem; line-height: 1; color: var(--el-stone); cursor: pointer; }
.el-modal__eyebrow { display: inline-block; font-size: .7rem; letter-spacing: .28em; text-transform: uppercase; color: var(--el-gold); margin-bottom: .7rem; }
.el-modal__title { font-family: var(--el-serif); font-weight: 400; font-size: 1.9rem; line-height: 1.15; color: var(--el-walnut); margin: 0 0 .8rem; }
.el-modal__title em { font-style: italic; }
.el-modal__intro { font-size: .95rem; color: var(--el-stone); margin: 0 0 1.6rem; }
.el-modal__form { max-width: none; }
.el-modal__form .el-form__label { text-align: left; }

/* ── Contact form ───────────────────────────────────────── */
.el-contact .el-contact__intro { max-width: 640px; margin: 0 auto 2.5rem; text-align: center; }
.el-form { max-width: 640px; margin: 0 auto; text-align: left; }
.el-form__row { margin-bottom: 1.1rem; }
.el-form__row--2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.el-form__field { display: flex; flex-direction: column; gap: .4rem; }
.el-form__label { font-size: .78rem; letter-spacing: .08em; text-transform: uppercase; color: var(--el-stone); }
.el-form__req { color: var(--el-gold); margin-left: 2px; }
.el-form__input { font-family: var(--el-sans); font-weight: 300; font-size: 1rem; color: var(--el-ink); background: #fff; border: 1px solid var(--el-line); border-radius: 0; padding: .75rem .85rem; width: 100%; outline: none; transition: border-color .2s, box-shadow .2s; }
.el-form__input:focus { border-color: var(--el-gold); box-shadow: 0 0 0 3px rgba(178,150,95,.14); }
.el-form__textarea { resize: vertical; min-height: 120px; }
.el-form__select { appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--el-stone) 50%), linear-gradient(135deg, var(--el-stone) 50%, transparent 50%); background-position: calc(100% - 18px) 1.15rem, calc(100% - 13px) 1.15rem; background-size: 5px 5px; background-repeat: no-repeat; }
.el-form__check { display: flex; align-items: center; gap: .5rem; font-size: .95rem; color: var(--el-stone); cursor: pointer; }
.el-form__check input { accent-color: var(--el-gold); }
.el-form__hp { position: absolute; left: -10000px; width: 1px; height: 1px; overflow: hidden; }
.el-form__actions { margin-top: 1.6rem; text-align: center; }
.el-form__submit { font-family: var(--el-sans); font-size: .8rem; font-weight: 500; letter-spacing: .18em; text-transform: uppercase; color: #fff; background: var(--el-walnut); border: 0; padding: .95rem 2.6rem; cursor: pointer; transition: background .2s, transform .2s; }
.el-form__submit:hover { background: var(--el-bark); transform: translateY(-1px); }
.el-form__submit:disabled { opacity: .55; cursor: default; transform: none; }
.el-form__msg { margin-top: 1.1rem; text-align: center; font-size: .92rem; padding: 0; }
.el-form__msg.is-ok { color: #2f6b3a; }
.el-form__msg.is-err { color: #9f1239; }
@media (max-width: 560px) { .el-form__row--2 { grid-template-columns: 1fr; } }

/* ── Footer ─────────────────────────────────────────────── */
.el-footer { background: var(--el-bark); color: rgba(255,255,255,.82); padding: clamp(3rem,7vw,5rem) var(--el-pad) 0; }
.el-footer__inner { max-width: var(--el-maxw); margin: 0 auto; display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 2.5rem; text-align: center; }
.el-footer__brand { text-align: center; }
.el-footer__name { font-family: var(--el-sans); letter-spacing: .3em; font-size: 1rem; margin: 0; }
.el-footer__name span { display: block; font-size: .6rem; letter-spacing: .5em; opacity: .7; }
.el-footer__loc { font-size: .8rem; opacity: .7; margin-top: .6rem; }
.el-footer__col { text-align: center; }
.el-footer__col h3 { font-size: .72rem; letter-spacing: .24em; text-transform: uppercase; color: var(--el-gold); margin-bottom: .8rem; font-weight: 400; }
.el-footer__col a { font-size: .95rem; }
.el-footer__col a:hover { color: #fff; }
.el-footer__sister a small { display: block; font-size: .72rem; opacity: .6; margin-top: .2rem; }
.el-footer__bar { max-width: var(--el-maxw); margin: 2.5rem auto 0; border-top: 1px solid rgba(255,255,255,.12); padding: 1.4rem 0; display: flex; justify-content: space-between; font-size: .75rem; opacity: .7; }
.el-footer__bar a:hover { color: #fff; }

/* ── Responsive ─────────────────────────────────────────── */
@media (max-width: 860px) {
    .el-nav__links { display: none; }
    .el-nav__burger { display: flex; }
    .el-nav__drawer { display: flex; flex-direction: column; gap: 1.2rem; padding: 1.5rem var(--el-pad) 2rem; background: rgba(47,40,32,.98); transform: translateY(-120%); transition: transform .3s ease; }
    .el-nav__drawer.is-open { transform: translateY(0); }
    .el-nav__drawer a { color: #fff; letter-spacing: .12em; text-transform: uppercase; font-size: .85rem; }
    .el-nav.is-open { background: rgba(47,40,32,.98); }
    .el-band__inner { grid-template-columns: 1fr; }
    .el-band--flip .el-band__media { order: 0; }
    .el-footer__inner { grid-template-columns: 1fr; }
    .el-footer__bar { flex-direction: column; gap: .6rem; text-align: center; }
    .el-fp__grid { grid-template-columns: 1fr 1fr; gap: 1rem; }
    .el-price__tables { grid-template-columns: 1fr; gap: 2rem; }
}
@media (max-width: 560px) {
    .el-fp__grid { grid-template-columns: 1fr; }
    .el-gallery__grid { grid-template-columns: 1fr; }
    .el-price__hide { display: none; }
}
