@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;600;700;800&display=swap');
:root{--gold:#a68966;--dark:#2d241d;--cream-light:#fdfcf9;--champagne:#f0ebe3;--wa-green:#25d366}
html{scroll-behavior:smooth}
*,*::before,*::after{box-sizing:border-box}
body{font-family:'Plus Jakarta Sans',sans-serif;background:#f8f5f0;color:var(--dark);margin:0;overflow-x:hidden}

.anim-fade-up,.anim-fade-left,.anim-fade-right,.anim-zoom-in{opacity:0;transition:opacity .8s cubic-bezier(.25,.1,.25,1),transform .8s cubic-bezier(.25,.1,.25,1)}
.anim-fade-up{transform:translateY(40px) scale(.97)}
.anim-fade-left{transform:translateX(40px) scale(.97)}
.anim-fade-right{transform:translateX(-40px) scale(.97)}
.anim-zoom-in{transform:scale(.9)}
.anim-visible.anim-fade-up,.anim-visible.anim-fade-left,.anim-visible.anim-fade-right,.anim-visible.anim-zoom-in{opacity:1;transform:translateY(0) translateX(0) scale(1)}

@keyframes kenBurns{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
@keyframes shimmerGold{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes gradientShift{0%{filter:hue-rotate(0deg)}50%{filter:hue-rotate(12deg)}100%{filter:hue-rotate(0deg)}}
@keyframes pulseRing{0%{transform:scale(1);opacity:.5}100%{transform:scale(2.4);opacity:0}}
@keyframes blinkCursor{0%,100%{opacity:1}50%{opacity:0}}
@keyframes bounce{0%,20%,50%,80%,100%{transform:translateX(-50%) translateY(0)}40%{transform:translateX(-50%) translateY(6px)}60%{transform:translateX(-50%) translateY(3px)}}
@keyframes dragHintFade{0%,100%{opacity:0}25%,75%{opacity:.7}}
@keyframes kprGradient{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes floatPulse{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes skeletonShimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes iconBounce{0%,100%{transform:translateY(0)}40%{transform:translateY(-4px)}70%{transform:translateY(-2px)}}
@keyframes ambientPulse{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.15)}}

#scroll-progress{position:absolute;top:0;left:0;height:2px;width:0;background:var(--gold);z-index:10;transition:width .1s linear}

nav.site-nav{position:fixed;top:0;width:100%;z-index:1000;padding:18px 24px;display:flex;justify-content:space-between;align-items:center;background:transparent;transition:background .4s cubic-bezier(.25,.1,.25,1),box-shadow .4s cubic-bezier(.25,.1,.25,1),backdrop-filter .4s cubic-bezier(.25,.1,.25,1)}
nav.nav-scrolled{background:rgba(255,255,255,.85);backdrop-filter:blur(20px) saturate(180%);box-shadow:0 1px 20px rgba(0,0,0,.06)}
.nav-brand{font-weight:800;font-size:13px;letter-spacing:-.03em;text-transform:uppercase;cursor:pointer}

#mobile-menu{position:fixed;top:0;right:-100%;width:85%;height:100%;background:#fff;z-index:2000;transition:.5s cubic-bezier(.19,1,.22,1);padding:40px;box-shadow:-10px 0 30px rgba(0,0,0,.05);display:flex;flex-direction:column}
#mobile-menu.active{right:0}
.menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0);z-index:1500;display:none;transition:background .3s ease}
.menu-overlay.active{background:rgba(0,0,0,.5)}
.menu-active{color:var(--gold)!important;position:relative}
.menu-active::after{content:'';width:6px;height:6px;background:var(--gold);border-radius:50%;position:absolute;left:-16px;top:50%;transform:translateY(-50%)}

#about-me-panel{position:fixed;top:0;right:0;width:100%;height:100%;background:#1a1613;z-index:3000;color:var(--cream-light);clip-path:inset(0 100% 0 0);transition:clip-path .6s cubic-bezier(.19,1,.22,1)}
#about-me-panel.active{clip-path:inset(0 0% 0 0)}
.about-scroll{position:relative;height:100%;overflow-y:auto;padding-bottom:50px}
.btn-close-about{position:sticky;top:25px;left:25px;width:45px;height:45px;background:rgba(255,255,255,.05);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold);z-index:10;border:1px solid rgba(166,137,102,.3);margin-bottom:-20px;cursor:pointer;min-width:45px;min-height:45px}
.about-header{display:flex;gap:20px;align-items:center;padding:100px 25px 30px}
.about-pfp{width:100px;height:100px;border-radius:20px;border:3px solid var(--gold);overflow:hidden;flex-shrink:0;box-shadow:0 10px 30px rgba(0,0,0,.5)}
.about-pfp img{width:100%;height:100%;object-fit:cover;transform:scale(.85);transition:transform .6s cubic-bezier(.19,1,.22,1)}
#about-me-panel.active .about-pfp img{transform:scale(1)}
.about-medsos-icons{display:flex;gap:18px;margin-top:15px}
.about-medsos-icons a{color:var(--gold);font-size:20px;min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}
.about-desc-section{padding:40px 25px;border-top:1px solid rgba(255,255,255,.05);margin-top:10px}
.about-desc-section p{font-size:13px;line-height:1.8;color:#bbb}
.achievement-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;padding:0 25px}
.polaroid-card{background:var(--cream-light);padding:10px 10px 25px;border-radius:2px;box-shadow:0 15px 35px rgba(0,0,0,.4);transform:rotate(-3deg) translateY(30px);opacity:0;transition:transform .6s cubic-bezier(.19,1,.22,1),opacity .6s ease}
.polaroid-card:nth-child(even){transform:rotate(3deg) translateY(30px)}
.polaroid-card.polaroid-visible{opacity:1;transform:rotate(-3deg) translateY(0)}
.polaroid-card:nth-child(even).polaroid-visible{transform:rotate(3deg) translateY(0)}
.polaroid-card img{width:100%;aspect-ratio:1/1;object-fit:cover}
.polaroid-label{color:var(--dark);font-size:9px;font-weight:800;text-align:center;margin-top:12px;text-transform:uppercase}

.wa-float-about{position:absolute;bottom:30px;right:30px;width:60px;height:60px;background:var(--wa-green);color:#fff;border-radius:50%;font-size:30px;box-shadow:0 10px 25px rgba(0,0,0,.3);z-index:5000;display:flex;align-items:center;justify-content:center;animation:floatPulse 3s ease-in-out infinite;transition:transform .4s cubic-bezier(.34,1.56,.64,1);text-decoration:none;min-width:60px;min-height:60px}
.wa-float-about:hover{transform:scale(1.12)!important}
.wa-float-about::before,.wa-float-about::after{content:'';position:absolute;width:100%;height:100%;border-radius:50%;border:2px solid var(--wa-green);animation:pulseRing 2s ease-out infinite}
.wa-float-about::after{animation-delay:.8s}

.profile-section-wrap{position:relative;overflow:hidden}
#particle-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}
.profile-bg-gradient{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 40%,rgba(166,137,102,.05) 0%,transparent 70%);animation:gradientShift 8s ease-in-out infinite;z-index:0}
#profile-section{width:100%;max-width:1000px;margin:0 auto;position:relative;touch-action:none;cursor:grab;z-index:1}
#profile-section.grabbing{cursor:grabbing}
.profile-container{transition:all .6s cubic-bezier(.19,1,.22,1);display:flex;flex-direction:column;align-items:center;text-align:center;padding:120px 20px 50px;width:100%;background:var(--cream-light);border-bottom:1px solid var(--champagne)}
.profile-image-wrapper{width:135px;height:135px;border-radius:50%;overflow:hidden;border:4px solid #fff;box-shadow:0 15px 35px rgba(0,0,0,.1);transition:all .7s cubic-bezier(.19,1,.22,1);margin-bottom:20px;flex-shrink:0;position:relative;background:radial-gradient(circle,rgba(166,137,102,.08) 0%,transparent 70%)}
.btn-reset-profile{position:absolute;bottom:-5px;left:-10px;width:35px;height:35px;background:var(--dark);border-radius:50%;display:none;align-items:center;justify-content:center;box-shadow:0 4px 10px rgba(0,0,0,.2);color:#fff;z-index:100;cursor:pointer;font-size:12px;border:none}
.is-transformed .btn-reset-profile{display:flex}
.drag-arrow-outer{position:absolute;bottom:0;left:50%;transform:translateX(-50%);color:var(--gold);font-size:18px;animation:bounce 2s infinite;z-index:5}
.drag-hint-text{position:absolute;bottom:-28px;left:50%;transform:translateX(-50%);font-size:9px;font-weight:700;color:var(--gold);white-space:nowrap;opacity:0;animation:dragHintFade 6s ease 2s 1 forwards;text-transform:uppercase;letter-spacing:.15em}
.sosmed-list{display:flex;gap:15px;margin-top:20px;justify-content:center}
.sosmed-list a{font-size:22px;color:var(--dark);transition:.3s;opacity:.8;min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}
.sosmed-list a:hover{color:var(--gold);opacity:1}
.profile-desc{font-size:11px;color:#888;max-width:320px;margin:12px auto;line-height:1.7;font-weight:500}
.is-transformed .profile-container{flex-direction:row;text-align:left;padding:115px 25px 30px}
.is-transformed .profile-image-wrapper{width:80px;height:80px;border-radius:18px;margin-bottom:0;margin-right:20px}
.is-transformed .drag-arrow-outer,.is-transformed .drag-hint-text{display:none}
.is-transformed .sosmed-list{justify-content:flex-start;margin-top:12px}
.is-transformed .profile-desc{margin-left:0;text-align:left}
.is-transformed .quick-tabs{justify-content:flex-start}
.quick-tabs{display:flex;gap:8px;margin-top:15px;justify-content:center}
.tab-btn{padding:12px 22px;background:#fff;border-radius:50px;font-size:10px;font-weight:800;border:1px solid #eee;display:flex;align-items:center;gap:8px;box-shadow:0 4px 10px rgba(0,0,0,.02);min-height:44px;transition:all .3s ease}
.tab-btn:hover{border-color:var(--gold);color:var(--gold)}

.ambient-glow{position:absolute;border-radius:50%;pointer-events:none;z-index:0}
.ambient-glow-1{width:200px;height:200px;background:rgba(166,137,102,.06);filter:blur(40px);top:50%;left:50%;transform:translate(-50%,-50%);animation:ambientPulse 4s ease-in-out infinite alternate}
.ambient-glow-2{width:300px;height:300px;background:rgba(166,137,102,.04);filter:blur(60px);top:45%;left:55%;transform:translate(-50%,-50%);animation:ambientPulse 4s ease-in-out infinite alternate .5s}

.typewriter-char{display:inline-block;opacity:0;transform:translateY(15px);animation:charReveal .3s ease forwards}
@keyframes charReveal{to{opacity:1;transform:translateY(0)}}
.typewriter-cursor{display:inline-block;animation:blinkCursor .8s infinite;color:var(--gold);font-weight:300}
.title-sep{color:var(--gold);-webkit-text-fill-color:var(--gold);padding:0 2px;display:inline-block}

.stats-strip{background:var(--dark);color:#fff;position:relative;z-index:1}
.stat-number{font-size:2rem;font-weight:800;color:var(--gold);letter-spacing:-.03em}
.stat-suffix{font-size:1.5rem;font-weight:800;color:var(--gold)}
.stat-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:rgba(255,255,255,.5);margin-top:4px}

.unit-card{background:var(--cream-light);border-radius:2.2rem;overflow:hidden;border:1px solid var(--champagne);display:flex;flex-direction:column;transition:transform .3s cubic-bezier(.25,.1,.25,1),box-shadow .3s cubic-bezier(.25,.1,.25,1);will-change:auto;transform-style:preserve-3d}
.unit-card:hover{transform:translateY(-8px) scale(1.01);box-shadow:0 20px 60px rgba(0,0,0,.1)}
.hero-view{width:100%;aspect-ratio:1/1;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;transition:all .6s cubic-bezier(.19,1,.22,1)}
.hero-view.is-detail{aspect-ratio:16/9;background:#fff}
.hero-view>img{width:100%;height:100%;object-fit:cover;transition:.5s;animation:kenBurns 8s ease-in-out infinite}
.static-photo-wrapper{width:100%;aspect-ratio:1/1;border-radius:1rem;overflow:hidden;cursor:pointer}
.static-photo-wrapper img{width:100%;height:100%;object-fit:cover}
.swiper-container-custom{width:100%;aspect-ratio:16/9;border-radius:1rem;overflow:hidden}
.btn-back-photo{position:absolute;top:15px;right:15px;background:rgba(255,255,255,.9);width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;opacity:0;transition:.3s;z-index:10;border:none;cursor:pointer}
.hero-view.is-detail .btn-back-photo{opacity:1}
.phase-btn{padding:12px 28px;border-radius:14px;font-size:11px;font-weight:800;border:1px solid #eee;background:#fff;transition:all .3s ease;cursor:pointer;position:relative;min-height:44px}
.phase-btn:hover{border-color:var(--gold);color:var(--gold)}
.phase-btn.active{background:var(--dark);color:#fff!important;box-shadow:0 10px 20px rgba(0,0,0,.1);border-color:var(--dark)}
.phase-btn.active::after{content:'';position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);width:20px;height:3px;background:var(--gold);border-radius:2px}
.phase-bar-sticky{position:sticky;top:70px;background:#fff;z-index:500;padding:12px 0;box-shadow:0 4px 20px rgba(0,0,0,.06);margin-left:-24px;margin-right:-24px;padding-left:24px;padding-right:24px}
.price-shimmer{background:linear-gradient(90deg,var(--gold) 0%,#d4b896 40%,var(--gold) 80%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;background-size:200% 100%;animation:shimmerGold 2s ease 1}
.no-scrollbar::-webkit-scrollbar{display:none}
.icon-bounce{animation:iconBounce .5s ease}

.skeleton-card{background:var(--cream-light);border-radius:2.2rem;overflow:hidden;border:1px solid var(--champagne)}
.skeleton-block{background:linear-gradient(90deg,#f0ebe3 25%,#fdfcf9 50%,#f0ebe3 75%);background-size:200% 100%;animation:skeletonShimmer 1.5s infinite;border-radius:8px}

.blur-up{filter:blur(8px);transform:scale(1.02);transition:filter .6s ease,transform .6s ease;background:var(--champagne)}
.blur-up.loaded{filter:blur(0);transform:scale(1)}

.kpr-result-card{background:linear-gradient(135deg,#2d241d 0%,#3d3127 50%,#2d241d 100%);background-size:200% 200%;animation:kprGradient 6s ease infinite;position:relative;overflow:hidden}
.dp-progress-bar{width:100%;height:4px;background:rgba(0,0,0,.06);border-radius:2px;margin-top:8px;overflow:hidden}
.dp-progress-fill{height:100%;background:var(--gold);border-radius:2px;transition:width .4s ease}

.section-divider{height:1px;background:linear-gradient(to right,transparent,rgba(166,137,102,.08) 50%,transparent);margin:0}

.lightbox-overlay{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:6000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease}
.lightbox-overlay.active{opacity:1;pointer-events:auto}
.lightbox-img{max-width:90vw;max-height:90vh;object-fit:contain;transform:scale(.85);transition:transform .3s ease;border-radius:4px}
.lightbox-overlay.active .lightbox-img{transform:scale(1)}
.lightbox-btn-close{position:absolute;top:20px;right:20px;width:44px;height:44px;background:rgba(255,255,255,.1);border:none;color:#fff;font-size:20px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .3s}
.lightbox-btn-close:hover{background:rgba(255,255,255,.2)}
.lightbox-btn-nav{position:absolute;top:50%;width:44px;height:44px;background:rgba(255,255,255,.1);border:none;color:#fff;font-size:18px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transform:translateY(-50%);transition:background .3s}
.lightbox-btn-nav:hover{background:rgba(255,255,255,.2)}
.lightbox-prev{left:20px}
.lightbox-next{right:20px}

.toast-notification{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(100px);background:var(--dark);color:#fff;padding:12px 24px;border-radius:50px;font-size:12px;font-weight:700;z-index:7000;opacity:0;transition:transform .4s cubic-bezier(.25,.1,.25,1),opacity .4s ease;pointer-events:none;white-space:nowrap}
.toast-notification.visible{transform:translateX(-50%) translateY(0);opacity:1}

.back-to-top{position:fixed;bottom:30px;left:30px;width:44px;height:44px;background:var(--dark);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;z-index:4000;opacity:0;pointer-events:none;transition:opacity .3s ease,transform .3s ease;cursor:pointer;border:none;box-shadow:0 4px 15px rgba(0,0,0,.2)}
.back-to-top.visible{opacity:1;pointer-events:auto}
.back-to-top:hover{transform:translateY(-3px)}

.footer-divider{height:1px;background:linear-gradient(to right,transparent,rgba(166,137,102,.15) 50%,transparent)}

@media(max-width:767px){
.tab-btn{min-height:44px;padding:14px 22px}
.phase-btn{min-height:44px;padding:14px 24px}
.stats-strip .stat-number{font-size:1.5rem}
}
