/* ============================================
   KROMA CAPITAL × TESLA-STYLE
   Full-viewport, scroll-snap, minimal luxury
   ============================================ */
:root {
    --gold: #C5A55A;
    --gold-d: #A8893E;
    --gold-l: #D4BA7A;
    --green: #5B7B6A;
    --dark: #0a0a0a;
    --white: #FFFFFF;
    --gray: #999;
    --font-h: 'Prata', Georgia, serif;
    --font-b: 'Inter', -apple-system, sans-serif;
    --ease: cubic-bezier(.25,.46,.45,.94);
    --ease-out: cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;scroll-behavior:smooth}
body{font-family:var(--font-b);color:var(--white);background:var(--dark);overflow-x:hidden}
a{text-decoration:none;color:inherit}
ul{list-style:none}

/* ---- NAV ---- */
#nav{
    position:fixed;top:0;left:0;width:100%;z-index:100;
    display:flex;align-items:center;justify-content:space-between;
    padding:20px 40px;transition:all .4s;
}
#nav.scrolled{background:rgba(10,10,10,.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:14px 40px}
.nav-logo{display:flex;align-items:center;gap:7px}
.nl-icon{color:var(--gold);font-size:1.2rem}
.nl-text{font-family:var(--font-h);font-size:1.1rem;letter-spacing:.22em;color:#fff}
.nl-sub{font-size:.5rem;letter-spacing:.3em;color:var(--gold);font-weight:300}
.nav-center{display:flex;gap:28px}
.nav-center a{font-size:.75rem;color:rgba(255,255,255,.5);letter-spacing:.04em;font-weight:400;transition:color .3s}
.nav-center a:hover{color:#fff}
.nav-cta{font-size:.72rem;font-weight:500;padding:8px 20px;border:1.5px solid var(--gold);color:var(--gold);border-radius:4px;letter-spacing:.04em;transition:all .3s}
.nav-cta:hover{background:var(--gold);color:#fff}
.nav-burger{display:none;background:none;border:none;cursor:pointer;padding:6px;flex-direction:column;gap:6px;z-index:110}
.nav-burger span{display:block;width:22px;height:1.5px;background:#fff;transition:all .3s;transform-origin:center}
.nav-burger.open span:first-child{transform:rotate(45deg) translate(4px,4px)}
.nav-burger.open span:last-child{transform:rotate(-45deg) translate(4px,-4px)}

#mob-menu{
    position:fixed;inset:0;background:rgba(10,10,10,.97);z-index:105;
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;
    opacity:0;visibility:hidden;transition:all .35s;
}
#mob-menu.open{opacity:1;visibility:visible}
#mob-menu a{font-family:var(--font-h);font-size:1.4rem;color:rgba(255,255,255,.6);transition:color .3s}
#mob-menu a:hover{color:var(--gold)}
.mob-cta{font-size:.85rem!important;font-family:var(--font-b)!important;padding:12px 32px;border:1.5px solid var(--gold);color:var(--gold)!important;border-radius:4px}

/* ---- SCROLL SNAP ---- */
#scroll-container{
    height:100vh;overflow-y:scroll;
    scroll-snap-type:y mandatory;
    -webkit-overflow-scrolling:touch;
}
.snap-section{
    scroll-snap-align:start;
    min-height:100vh;width:100%;
    position:relative;
    display:flex;flex-direction:column;
    align-items:center;justify-content:center;
    overflow:hidden;
}

/* ---- BACKGROUNDS ---- */
.bg-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.bg-img{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.bg-gradient{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,10,10,.3)0%,rgba(10,10,10,.65)100%);z-index:1}
.bg-gradient-strong{background:linear-gradient(to bottom,rgba(10,10,10,.4)0%,rgba(10,10,10,.8)100%)}
.bg-gradient-left{background:linear-gradient(to right,rgba(10,10,10,.85)0%,rgba(10,10,10,.3)60%,transparent 100%)}
.bg-gradient-bottom{background:linear-gradient(to top,rgba(10,10,10,.9)0%,rgba(10,10,10,.2)50%,rgba(10,10,10,.5)100%)}
.bg-solid{position:absolute;inset:0;background:#111}
.bg-solid-dark{position:absolute;inset:0;background:linear-gradient(160deg,#0d120f,#0a0a0a 50%,#111510)}
.map-bg{position:absolute;inset:0;z-index:0}
.map-bg iframe{width:100%;height:100%;filter:brightness(.7) saturate(.8)}

/* ---- CTAs ---- */
.cta{
    display:inline-flex;align-items:center;justify-content:center;
    min-width:240px;padding:14px 32px;border-radius:4px;
    font-size:.88rem;font-weight:500;letter-spacing:.02em;
    transition:all .35s var(--ease);cursor:pointer;border:none;
}
.cta-gold{background:var(--gold);color:#fff}
.cta-gold:hover{background:var(--gold-l);transform:translateY(-1px)}
.cta-outline{background:transparent;border:2px solid rgba(255,255,255,.3);color:#fff}
.cta-outline:hover{border-color:#fff}
.cta-lg{padding:16px 40px;font-size:.92rem}

/* ---- HERO ---- */
#hero{justify-content:space-between;padding:0}
.hero-top{
    position:relative;z-index:2;text-align:center;
    margin-top:22vh;
}
.hero-location{font-size:.78rem;color:var(--gold-l);letter-spacing:.08em;margin-bottom:14px;font-weight:400}
#hero h1{font-family:var(--font-h);font-size:clamp(3.5rem,9vw,7rem);line-height:1;margin-bottom:16px}
.hero-sub{font-size:1.05rem;color:rgba(255,255,255,.5);font-weight:300;max-width:500px;margin:0 auto}
.hero-bottom{
    position:relative;z-index:2;
    display:flex;gap:14px;margin-bottom:14vh;
}
.scroll-hint{
    position:absolute;bottom:20px;left:50%;transform:translateX(-50%);z-index:2;
    color:rgba(255,255,255,.3);animation:bounce 2s ease-in-out infinite;
}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ---- SECTION CENTER TEXT ---- */
.section-center{position:relative;z-index:2;text-align:center;margin-top:-8vh}
.section-center h2,.features-content h2,.gallery-header h2,.location-overlay h2{
    font-family:var(--font-h);font-size:clamp(2rem,4.5vw,3.2rem);line-height:1.15;margin-bottom:12px;
}
.section-center p,.gallery-header p,.location-overlay p{
    font-size:.95rem;color:rgba(255,255,255,.5);font-weight:300;
}

/* ---- SPECS OVERLAY ---- */
.specs-overlay{
    position:relative;z-index:2;
    display:flex;gap:16px;flex-wrap:wrap;justify-content:center;
    margin-top:40px;padding:0 20px;
}
.spec-pill{
    background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);
    backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
    padding:18px 28px;border-radius:8px;text-align:center;
    min-width:130px;transition:border-color .3s;
}
.spec-pill:hover{border-color:rgba(197,165,90,.3)}
.spec-pill strong{display:block;font-family:var(--font-h);font-size:1.3rem;color:var(--gold);margin-bottom:2px}
.spec-pill span{font-size:.7rem;color:rgba(255,255,255,.4);letter-spacing:.04em;font-weight:300}

/* ---- FEATURES ---- */
.features-content{
    position:relative;z-index:2;
    max-width:520px;padding:0 40px;
    align-self:flex-start;margin-left:8%;
}
.features-content h2{text-align:left;margin-bottom:32px}
.features-list{display:flex;flex-direction:column;gap:20px}
.feat{
    display:flex;flex-direction:column;gap:2px;
    padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.06);
}
.feat:last-child{border-bottom:none;padding-bottom:0}
.feat-title{font-family:var(--font-h);font-size:1.05rem;color:#fff}
.feat-desc{font-size:.82rem;color:rgba(255,255,255,.4);font-weight:300}

/* ---- GALLERY — Vertical Videos in Phones ---- */
.gallery-section{justify-content:flex-start;padding-top:10vh}
.gallery-header{position:relative;z-index:2;text-align:center;margin-bottom:36px}
.gallery-videos{
    position:relative;z-index:2;
    display:flex;gap:32px;justify-content:center;align-items:flex-start;
    flex-wrap:wrap;padding:0 20px;
}
.gv-item{text-align:center}
.gv-phone{
    width:200px;aspect-ratio:9/16;
    background:#000;border-radius:24px;padding:6px;
    box-shadow:0 16px 60px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.06);
    overflow:hidden;transition:transform .5s var(--ease-out),box-shadow .5s;
}
.gv-phone:hover{
    transform:translateY(-8px) scale(1.02);
    box-shadow:0 24px 80px rgba(0,0,0,.7),0 0 0 1px rgba(197,165,90,.15),0 0 30px rgba(197,165,90,.06);
}
.gv-screen{width:100%;height:100%;border-radius:18px;overflow:hidden;position:relative;background:#111}
.gv-screen iframe{position:absolute;top:-12%;left:-12%;width:124%;height:124%;border:none}
.gv-label{display:block;margin-top:14px;font-size:.78rem;color:rgba(255,255,255,.45);font-weight:400;letter-spacing:.03em}

/* ---- ROOMS ---- */
.rooms-row{
    position:relative;z-index:2;
    display:flex;gap:12px;flex-wrap:wrap;justify-content:center;
    margin-top:36px;padding:0 20px;max-width:1100px;
}
.room-pill{
    display:flex;align-items:center;gap:14px;
    background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07);
    backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    padding:16px 22px;border-radius:8px;flex:1;min-width:200px;
    transition:border-color .3s;
}
.room-pill:hover{border-color:rgba(197,165,90,.25)}
.room-main{border-color:rgba(197,165,90,.2);background:rgba(197,165,90,.06)}
.rp-num{font-family:var(--font-h);font-size:1.6rem;color:rgba(197,165,90,.2);flex-shrink:0;min-width:36px}
.room-pill strong{display:block;font-family:var(--font-h);font-size:.9rem;color:#fff;margin-bottom:2px}
.room-pill span{font-size:.72rem;color:rgba(255,255,255,.4);font-weight:300;line-height:1.5}

/* ---- LOCATION ---- */
.location-overlay{
    position:relative;z-index:2;text-align:center;
    margin-top:auto;padding-bottom:12vh;
}
.loc-tags{display:flex;gap:14px;justify-content:center;margin-top:18px;flex-wrap:wrap}
.loc-tags span{
    padding:8px 20px;background:rgba(255,255,255,.07);
    border:1px solid rgba(255,255,255,.08);border-radius:100px;
    font-size:.78rem;color:rgba(255,255,255,.55);font-weight:400;
    backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}

/* ---- INVEST ---- */
.invest-section{justify-content:center;gap:40px}
.invest-content{position:relative;z-index:2;text-align:center;max-width:600px;padding:0 30px}
.invest-label{font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:8px}
.invest-price{font-family:var(--font-h);font-size:clamp(2rem,5vw,3.4rem);color:var(--gold);line-height:1.1;margin-bottom:6px}
.invest-price span{font-size:.7em;color:rgba(255,255,255,.3);font-weight:300}
.invest-words{font-size:.82rem;color:rgba(255,255,255,.3);font-weight:300;margin-bottom:28px}
.invest-converter{display:flex;gap:12px;justify-content:center;margin-bottom:24px;flex-wrap:wrap}
.ic-chip{
    display:flex;align-items:center;gap:10px;
    padding:10px 20px;background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.06);border-radius:6px;
}
.ic-flag{font-size:.72rem;font-weight:600;color:var(--gold);letter-spacing:.06em}
.ic-chip span:last-child{font-family:var(--font-h);font-size:.92rem;color:#fff}
.invest-checks{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:8px}
.invest-checks span{
    font-size:.78rem;color:rgba(255,255,255,.5);font-weight:400;
    padding-left:18px;position:relative;
}
.invest-checks span::before{
    content:'✓';position:absolute;left:0;color:var(--green);font-weight:600;
}
.invest-ctas{position:relative;z-index:2;display:flex;gap:14px;flex-wrap:wrap;justify-content:center}

/* ---- FOOTER ---- */
footer{background:#050505;padding:24px 40px;position:relative;z-index:2}
.footer-inner{display:flex;align-items:center;justify-content:space-between}
.footer-brand{font-family:var(--font-h);font-size:.82rem;color:var(--gold);letter-spacing:.15em}
.footer-inner p{font-size:.68rem;color:rgba(255,255,255,.2)}
.footer-inner a:last-child{font-size:.72rem;color:rgba(255,255,255,.35);transition:color .3s}
.footer-inner a:last-child:hover{color:var(--gold)}

/* ---- WA FLOAT ---- */
.wa-float{
    position:fixed;bottom:26px;right:26px;width:54px;height:54px;
    background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;
    color:#fff;box-shadow:0 6px 20px rgba(37,211,102,.4);z-index:90;transition:transform .3s;
}
.wa-float:hover{transform:scale(1.1)}

/* ---- ANIMATIONS ---- */
[data-animate]{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
[data-animate].visible{opacity:1;transform:translateY(0)}

/* ---- RESPONSIVE ---- */
@media(max-width:900px){
    #nav{padding:16px 20px}
    #nav.scrolled{padding:12px 20px}
    .nav-center,.nav-cta{display:none}
    .nav-burger{display:flex}
    .hero-top{margin-top:28vh}
    .hero-bottom{margin-bottom:16vh}
    .features-content{margin-left:0;align-self:center;padding:0 24px}
    .features-content h2{text-align:center}
    .gallery-section{padding-top:8vh}
    .gv-phone{width:170px;border-radius:20px;padding:5px}
    .gv-screen{border-radius:15px}
    .gallery-videos{gap:20px}
    .rooms-row{flex-direction:column;align-items:center;max-width:400px}
    .room-pill{min-width:100%}
    .specs-overlay{gap:10px}
    .spec-pill{padding:14px 18px;min-width:110px}
    footer .footer-inner{flex-direction:column;gap:8px;text-align:center}
    .invest-checks{flex-direction:column;align-items:center;gap:8px}
}
@media(max-width:600px){
    .hero-top{margin-top:30vh}
    #hero h1{font-size:clamp(2.8rem,12vw,4rem)}
    .hero-sub{font-size:.88rem;padding:0 20px}
    .hero-bottom{flex-direction:column;align-items:center;gap:10px}
    .cta{min-width:260px}
    .gallery-videos{flex-direction:column;align-items:center;gap:28px}
    .gv-phone{width:200px}
    .specs-overlay{gap:8px}
    .spec-pill{min-width:calc(50% - 8px);padding:12px 14px}
    .spec-pill strong{font-size:1.1rem}
    .loc-tags{flex-direction:column;align-items:center;gap:8px}
    .invest-converter{flex-direction:column;align-items:center}
}
