*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:'Space Grotesk',system-ui,sans-serif;color:#121212;background:#fff;line-height:1.5;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
button{border:none;background:none;cursor:pointer;font-family:inherit}
input,textarea{font-family:inherit}

/* .site-header{position:fixed;top:0;left:0;right:0;z-index:50;transform:translateY(-100%);opacity:0;transition:all .7s ease}
.site-header.is-visible{transform:translateY(0);opacity:1}
.header-inner{background:rgba(255,255,255,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(18,18,18,.05);display:flex;align-items:center;justify-content:space-between;padding:20px 32px}
@media(min-width:1024px){.header-inner{padding:20px 64px}}
.header-logo-img{height:32px;width:auto}
.header-actions{display:flex;align-items:center;gap:32px}
.header-phone{display:flex;align-items:center;gap:8px;color:#121212;font-size:14px;transition:color .3s}
.header-phone:hover{color:#EC008C}
.header-phone-text{display:none}
@media(min-width:640px){.header-phone-text{display:inline}}
.header-cta{background:#EC008C;color:#fff;padding:10px 24px;font-size:12px;font-weight:500;letter-spacing:.15em;text-transform:uppercase;transition:background .3s}
.header-cta:hover{background:#d4007d} */

/* ===== HERO OPENING ===== */
.hero{position:relative;width:100%;height:100vh;overflow:hidden;background:#EC008C;transition:background-color 1.2s cubic-bezier(0.4,0,0.2,1);}
.hero.to-white{background:#fff;}
.hero-opening{position:absolute;top:0;left:0;width:100%;height:100%;z-index:20;}
.typewriter-stage{position:absolute;top:0;left:0;width:100%;height:100%;z-index:30;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;}
.typewriter-line{font-size:clamp(24px,5vw,64px);font-weight:500;letter-spacing:2px;line-height:1.4;white-space:nowrap;overflow:hidden;min-height:1.4em;}
.typewriter-line .cursor{display:inline-block;width:2px;height:1em;background:currentColor;margin-left:4px;vertical-align:text-bottom;animation:blink 0.8s step-end infinite;}
.typewriter-line .cursor.done{animation:none;opacity:0;}
.typewriter-line.black{color:#121212;}
.typewriter-line.white{color:#fff;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0;}}
.diamond-stage{position:absolute;top:0;left:0;width:100%;height:100%;z-index:20;display:flex;align-items:center;justify-content:center;background:#E17427;opacity:0;pointer-events:none;transition:opacity 1.2s cubic-bezier(0.4,0,0.2,1);}
.diamond-stage.active{opacity:1;}
.diamond-stage.fadeout{opacity:0;}
.diamond-svg{width:80px;height:80px;transform:scale(1) rotate(0deg);opacity:1;}
.diamond-svg.animate{animation:diamondExpand 1.6s cubic-bezier(0.65,0,0.35,1) forwards;}
@keyframes diamondExpand{0%{transform:scale(1) rotate(0deg);opacity:1;}50%{opacity:1;}100%{transform:scale(45) rotate(90deg);opacity:0;}}
.hero-image-wrap{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;}
.hero-image{width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.08);}
.hero-image.show{animation:imageReveal 2s cubic-bezier(0.25,0.46,0.45,0.94) forwards;}
@keyframes imageReveal{0%{opacity:0;transform:scale(1.08);}100%{opacity:1;transform:scale(1);}}
.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,rgba(0,0,0,0.35) 0%,rgba(0,0,0,0.1) 30%,rgba(0,0,0,0.1) 70%,rgba(0,0,0,0.45) 100%);z-index:5;opacity:0;}
.hero-overlay.show{animation:fadeIn 1.5s ease 0.5s forwards;}
.hero-logo-stage{position:absolute;top:0;left:0;width:100%;height:100%;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;opacity:0;pointer-events:none;}
.hero-logo-stage.show{animation:fadeSlideUp 1.5s cubic-bezier(0.22,1,0.36,1) 0.6s forwards;}
.hero-logo-img{width:480px;height:auto;margin-bottom:48px;filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.5));}
.hero-slogan{font-size:28px;font-weight:500;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,0.9);    filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.5));}
.hero-scroll-hint{position:absolute;bottom:60px;left:50%;transform:translateX(-50%);z-index:15;display:flex;flex-direction:column;align-items:center;opacity:0;pointer-events:none;}
.hero-scroll-hint.show{animation:fadeIn 1s ease 1s forwards;}
.hero-scroll-icon{width:32px;height:32px;animation:bounceDown 2s ease-in-out infinite;filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.5));}
@keyframes bounceDown{0%,100%{transform:translateY(0);}50%{transform:translateY(12px);}}
.hero-side-deco{position:absolute;left:32px;bottom:80px;z-index:10;writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);font-family:'Helvetica Neue',Arial,sans-serif;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.6);opacity:0;}
.hero-side-deco.show{animation:fadeIn 1.2s ease 1s forwards;}
.hero-corner-label{position:absolute;right:32px;bottom:32px;z-index:10;font-family:'Helvetica Neue',Arial,sans-serif;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.5);opacity:0;}
.hero-corner-label.show{animation:fadeIn 1.2s ease 1s forwards;}
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(25px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
@media(max-width:768px){.hero-logo-img{width:280px;}.hero-slogan{font-size:18px;}.hero-scroll-icon{width:24px;height:24px;}}

/* Scroll lock */
html.scroll-locked,body.scroll-locked{overflow:hidden!important;height:100%!important;touch-action:none;}
html.scroll-locked{position:fixed;width:100%;}

/* .hero{position:relative;width:100%;height:100vh;min-height:600px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#f0eeeb}
.hero-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center}
.hero-video {width: 100%;height: 100%;object-fit: cover;display: block;}
.hero-brandmark{width:30%;;position:relative;z-index:10;opacity:0;transform:translateY(24px);transition:all 1.5s .5s ease}
.hero.is-loaded .hero-brandmark{opacity:1;transform:translateY(0)}
.hero-brandmark img{height:176px;width:auto;filter: drop-shadow(0 8px 24px rgba(0,0,0,0.75));}
@media(min-width:768px){.hero-brandmark img{height:176px}}
@media(min-width:1024px){.hero-brandmark img{height:224px}} */


/* ===== Orb Hero Background ===== */
/* .hero {
    position: relative;
    width: 100%;
    height: 100vh;
    min-height: 600px;
    background: #000; 
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hero-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.hero-orb-canvas {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    z-index: 1;
}

.hero-orb-fallback {
    position: absolute;
    inset: 0;
    z-index: 0;
    background-size: cover;
    background-position: center;
    transition: opacity 0.8s ease;
} */


/* .brand-statement{position:relative;width:100%;aspect-ratio:16/9;display:flex;align-items:center;padding:0 32px;overflow:hidden;background:#fff}
.brand-media-bg{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0}
.brand-fallback-bg{position:absolute;inset:0;background:#fff;z-index:0}
.brand-video-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.brand-statement-inner{position:relative;z-index:10;width:100%;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;text-align:left;opacity:0;transform:translateY(40px);transition:all 1s ease}
.brand-statement.is-visible .brand-statement-inner{opacity:1;transform:translateY(0)}
.brand-statement-title-wrap{grid-column:1;grid-row:1;position:relative;width:100%;display:flex;justify-content:center;align-items:center;padding:16px 0}
.frame-line{position:absolute;background:#EC008C}
.frame-line-top,.frame-line-bottom {left: 0;width: 100%;height: 0;background: none;}
.frame-line-top {top: 16px;border-top: 1px solid #EC008C;}
.frame-line-bottom {bottom: 16px;border-bottom: 1px solid #EC008C;}
.frame-center{position:relative;display:inline-block;padding:36px}
.frame-line-left,.frame-line-right {top: -60px;bottom: -60px;width: 0;background: none;}
.frame-line-left {left: 0;border-left: 1px solid #EC008C;}
.frame-line-right {right: 0;border-right: 1px solid #EC008C;}
.frame-diamond{position:absolute;width:18px;height:18px;display:flex;align-items:center;justify-content:center}
.frame-diamond img{width:100%;height:100%}
.frame-diamond-tl{top:0.5px;left:0.5px;transform:translate(-50%,-50%)}
.frame-diamond-tr{top:0.5px;right:0.5px;transform:translate(50%,-50%)}
.frame-diamond-bl{bottom:0.5px;left:0.5px;transform:translate(-50%,50%)}
.frame-diamond-br{bottom:0.5px;right:0.5px;transform:translate(50%,50%)}
.brand-statement-title{position:relative;z-index:1;font-size:26px;font-weight:500;color:#EC008C;line-height:1.15;text-align:center;margin:0}
.brand-statement-desc{grid-column:1;grid-row:2;align-self:center;justify-self:center;text-align:center;font-size:14px;color:#414042;line-height:1.8;max-width:480px;margin-top:80px}
@media(min-width:768px){.brand-statement-desc{font-size:16px}}
@media(max-width:767px){.brand-statement-inner{grid-template-columns:1fr}.brand-statement-title-wrap{justify-self:center}.brand-statement-desc{grid-column:1;grid-row:2;margin-top:24px;max-width:none}} */

.brand-statement{position:relative;width:100%;aspect-ratio:16/9;display:flex;align-items:center;padding:0 32px;overflow:hidden;background:#fff}
.brand-media-bg{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0}
.brand-fallback-bg{position:absolute;inset:0;background:#fff;z-index:0}
.brand-video-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.brand-statement-inner{position:relative;z-index:10;width:100%;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;text-align:left;opacity:0;transform:translateY(40px);transition:all 1s ease}
.brand-statement.is-visible .brand-statement-inner{opacity:1;transform:translateY(0)}
.brand-statement-title-wrap{grid-column:1;grid-row:1;position:relative;width:100%;display:flex;justify-content:center;align-items:center;padding:16px 0}
.frame-line{position:absolute;background:#EC008C}
.frame-line-top,.frame-line-bottom{left:0;width:100%;height:0;background:none}
.frame-line-top{top:16px;border-top:1px solid #EC008C}
.frame-line-bottom{bottom:16px;border-bottom:1px solid #EC008C}
.frame-center{position:relative;display:inline-block;padding:36px 138px}
.frame-line-left,.frame-line-right{top:-60px;bottom:-60px;width:0;background:none}
.frame-line-left{left:0;border-left:1px solid #EC008C}
.frame-line-right{right:0;border-right:1px solid #EC008C}
.frame-diamond{position:absolute;width:18px;height:18px;display:flex;align-items:center;justify-content:center}
.frame-diamond img{width:100%;height:100%}
.frame-diamond-tl{top:0.5px;left:0.5px;transform:translate(-50%,-50%)}
.frame-diamond-tr{top:0.5px;right:0.5px;transform:translate(50%,-50%)}
.frame-diamond-bl{bottom:0.5px;left:0.5px;transform:translate(-50%,50%)}
.frame-diamond-br{bottom:0.5px;right:0.5px;transform:translate(50%,50%)}
.brand-statement-title{position:relative;z-index:1;font-size:32px;font-weight:500;color:#EC008C;line-height:1.15;text-align:center;margin:0}
/* .brand-statement-desc{grid-column:1;grid-row:2;align-self:center;justify-self:center;text-align:center;font-size:14px;color:#414042;line-height:1.8;max-width:480px;margin-top:180px} */
/* @media(min-width:768px){.brand-statement-desc{font-size:16px}} */
@media(max-width:767px){
    .frame-center{position:relative;display:inline-block;padding:36px}
    .brand-statement{aspect-ratio:auto;display:flex;flex-direction:column-reverse;align-items:stretch;padding:0}
    .brand-media-bg{position:relative;width:100%;overflow:hidden}
    .brand-video-bg{position:relative;width:250%;height:auto;margin-left:-150%;display:block}
    .brand-statement-inner{grid-template-columns:1fr;background:#fff;padding:80px 0px}
    .brand-statement-title-wrap{justify-self:center}
    /* .brand-statement-desc{grid-column:1;grid-row:2;margin-top:80px;padding:0px 32px;max-width:none} */
}

.brand-statement-desc{
    grid-column:1;
    grid-row:2;
    align-self:center;
    justify-self:center;
    text-align:left;
    max-width:480px;
    margin-top:120px
}

.brand-statement-desc .brand-statement-lead{
    font-size:14px;
    font-weight:600;
    color:#121212;
    line-height:1.6;
    margin-bottom:20px
}

.brand-statement-desc p{
    font-size:14px;
    font-weight:300;
    color:#414042;
    line-height:1.8;
    margin-bottom:16px
}
.brand-statement-desc p:last-child{
    margin-bottom:0
}
.brand-statement-subtitle{
    font-size:20px;
    font-weight:400;
    color:#EC008C;
    line-height:1.4;
    text-transform:uppercase;
    letter-spacing:0.04em;
    margin-bottom:24px
}
@media(min-width:768px){
    .brand-statement-desc .brand-statement-lead{font-size:16px}
    .brand-statement-desc p{font-size:16px}
    .brand-statement-subtitle{font-size:22px}
}
@media(max-width:767px){
    .brand-statement-desc{
        grid-column:1;
        grid-row:2;
        margin-top:60px;
        padding:0px 32px;
        max-width:none
    }
}

/* .future-statement{position:relative;width:100%;min-height:50vh;display:flex;align-items:center;justify-content:center;padding:280px 0px;overflow:hidden;background-color:#fff}
.future-statement-inner{position:relative;z-index:10;width:60%;margin:0 auto;text-align:center;opacity:0;transform:translateY(40px);transition:all 1s ease;animation:fadeInUp 1s .3s ease forwards}
.future-statement.is-visible .future-statement-inner{opacity:1;transform:translateY(0);animation:none}
@keyframes fadeInUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
.future-statement-title-wrap{position:relative;width:100%;display:flex;justify-content:center;align-items:center;padding:16px 0}
.frame-line{position:absolute;background:#EC008C}
.frame-line-top,.frame-line-bottom{left:0;width:100%;height:0;background:none}
.frame-line-top{top:16px;border-top:1px solid #EC008C}
.frame-line-bottom{bottom:16px;border-bottom:1px solid #EC008C}
.frame-center{position:relative;display:inline-block;padding:32px 48px}
.frame-line-left,.frame-line-right{top:-60px;bottom:-60px;width:0;background:none}
.frame-line-left{left:0;border-left:1px solid #EC008C}
.frame-line-right{right:0;border-right:1px solid #EC008C}
.frame-diamond{position:absolute;width:18px;height:18px;display:flex;align-items:center;justify-content:center}
.frame-diamond img{width:100%;height:100%}
.frame-diamond-tl{top:0.5px;left:0.5px;transform:translate(-50%,-50%)}
.frame-diamond-tr{top:0.5px;right:0.5px;transform:translate(50%,-50%)}
.frame-diamond-bl{bottom:0.5px;left:0.5px;transform:translate(-50%,50%)}
.frame-diamond-br{bottom:0.5px;right:0.5px;transform:translate(50%,50%)}
.future-statement-title{position:relative;z-index:1;font-size:32px;font-weight:700;color:#EC008C;line-height:1.15;letter-spacing:.08em;text-align:center;margin:0}
@media(min-width:768px){.future-statement-title{font-size:34px}}
@media(min-width:1024px){.future-statement-title{font-size:42px}} */

.history-transition{position:relative;height:250vh;background:#fff}
.history-sticky{position:sticky;top:0;height:100vh;width:100%;overflow:hidden;display:flex;align-items:center;justify-content:center}
.history-layer{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.history-layer--history{z-index:2}
.history-layer--future{z-index:1}
.history-inner{width:80%;margin:0 auto}
.history-grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:center}
@media(min-width:1024px){.history-grid{grid-template-columns:1fr 1fr;gap:64px}}
.history-text{display:flex;flex-direction:column;justify-content:center}
.history-title{font-size:36px;font-weight:700;color:#121212;line-height:1.1;letter-spacing:-.08em}
@media(min-width:768px){.history-title{font-size:48px}}
@media(min-width:1024px){.history-title{font-size:60px}}
.history-title--future{color:#EC008C}
.history-desc{margin-top:32px;font-size:14px;color:#414042;line-height:1.75;max-width:480px}
@media(min-width:768px){.history-desc{font-size:16px}}
.history-images{position:relative;height:420px}
@media(min-width:768px){.history-images{height:520px}}
@media(min-width:1024px){.history-images{height:560px}}
.history-img{position:absolute}
.history-img-1{top:0;left:0;width:58%;aspect-ratio:4/5;background:#c8c3b8;z-index:10}
.history-img-2{top:42%;right:0;width:62%;aspect-ratio:16/10;background:#d4cfc8;z-index:20}
.history-img-3{bottom:0;left:18%;width:38%;aspect-ratio:3/4;background:#b8b3a8;z-index:30}
.history-grid-future{grid-template-columns:1fr}
@media(min-width:1024px){.history-grid-future{grid-template-columns:1fr 1fr;gap:80px}}
.history-placeholder{width:100%;max-width:480px;aspect-ratio:3/4;background:#c8c3b8;background-size:cover}

.marquee-section{width:100%;background:#121212;overflow:hidden;padding:20px 0}
.marquee-track{display:flex;align-items:center;white-space:nowrap;animation:marquee-scroll 30s linear infinite}
@keyframes marquee-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.marquee-item{flex-shrink:0;margin:0 32px;font-size:18px;letter-spacing:.2em;font-weight:500;}

.overview{position:relative;width:100%;padding:128px 32px 48px 32px;background:#fff;overflow:hidden}
@media(min-width:768px){.overview{padding:90px 32px}}
@media(min-width:1024px){.overview{padding:200px 80px}}
.overview-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center}
.overview-inner{position:relative;z-index:10;width:80%;margin:0 auto;opacity:0;transform:translateY(32px);transition:all 1s .2s ease}
.overview.is-visible .overview-inner{opacity:1;transform:translateY(0)}
.overview-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:start}
@media(min-width:1024px){.overview-grid{grid-template-columns:1fr 1fr;gap:64px}}
.overview-brandmark{display:flex;justify-content:flex-start}
.overview-brandmark-ph{width:119px;}
.overview-brandmark-ph img {width: 100%;height: auto;display: block;}
@media(min-width:768px){.overview-brandmark-ph{width:119px;}}
.overview-lead{font-size:20px;font-weight:500;color:#121212;line-height:1.6}
@media(min-width:768px){.overview-lead{font-size:24px}}
@media(min-width:1024px){.overview-lead{font-size:32px}}
.overview-body{margin-top:40px}
.overview-body p{font-size:14px;color:#414042;line-height:1.75}
@media(min-width:768px){.overview-body p{font-size:16px}}

.cgi-gallery{position:relative;width:100%;height:100vh;min-height:500px;background:#f0eeeb;overflow:hidden}
.cgi-slide{position:absolute;inset:0;opacity:0;transition:opacity 1s ease;z-index:0}
.cgi-slide.is-active{opacity:1;z-index:10}
.cgi-slide-inner{width:100%;height:100%}
.cgi-slide-inner img{width:100%;height:100%;object-fit:cover;display:block}
.cgi-dots{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);z-index:20;display:flex;align-items:center;gap:12px}
.cgi-dot{border:none;padding:0;cursor:pointer;transition:all .5s ease}
.cgi-dot.is-active{width:32px;height:8px;background:#fff}
.cgi-dot:not(.is-active){width:8px;height:8px;background:rgba(255,255,255,.5)}
.cgi-dot:not(.is-active):hover{background:rgba(255,255,255,.8)}
@media(max-width:767px){
    .cgi-gallery{height:auto;min-height:auto}
    .cgi-slide{position:absolute;inset:0;opacity:0}
    .cgi-slide.is-active{position:relative;opacity:1;z-index:10}
    .cgi-slide-inner{height:auto}
    .cgi-slide-inner img{width:100%;height:auto;display:block}
    .cgi-dots{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);padding:0}
}

.architecture{width:100%;padding:0 32px 160px;background:#fff}
@media(min-width:768px){.architecture{padding:0 32px 208px}}
@media(min-width:1024px){.architecture{padding:0 80px 256px}}
.architecture-inner{width:100%;max-width:720px;margin:0 auto;opacity:0;transform:translateY(40px);transition:all 1s ease}
.architecture.is-visible .architecture-inner{opacity:1;transform:translateY(0)}
.architecture-text{text-align:center;margin-bottom:64px}
.architecture-diamond{margin-bottom:24px;color:#121212;font-size:10px}
.architecture-title{font-size:32px;font-weight:700;color:#121212;line-height:1.15;letter-spacing:-.08em}
@media(min-width:768px){.architecture-title{font-size:44px}}
@media(min-width:1024px){.architecture-title{font-size:52px}}
.architecture-desc{margin-top:32px;font-size:14px;color:#414042;line-height:1.75;max-width:480px;margin-left:auto;margin-right:auto}
@media(min-width:768px){.architecture-desc{font-size:16px}}
.architecture-image{display:flex;justify-content:center}
.architecture-ph{width:100%;max-width:420px;aspect-ratio:3/4;background:#d4d0c8}

.interior{position:relative;width:100%;padding:128px 32px;background:#fff;overflow:hidden}
@media(min-width:768px){.interior{padding:176px 32px}}
@media(min-width:1024px){.interior{padding:224px 80px}}

/* 手机端放宽到 88%，避免 60% 在窄屏上过度拥挤 */
.interior-inner{position:relative;width:88%;margin:0 auto;display:grid;grid-template-columns:1fr;gap:48px;align-items:center;opacity:0;transform:translateY(40px);transition:opacity 1s ease,transform 1s ease}
@media(min-width:768px){.interior-inner{width:60%}}
@media(min-width:1024px){.interior-inner{grid-template-columns:1fr 1fr;gap:80px}}

.interior.is-visible .interior-inner{opacity:1;transform:translateY(0)}

/* 确保图片容器撑满整列 */
.interior-image{display:flex;justify-content:center;align-self:stretch;overflow:hidden;width:100%}
.interior-ph{width:100%;height:100%;aspect-ratio:3/4}
.interior-ph img{width:100%;height:100%;object-fit:cover;display:block}

.interior-text{text-align:center}
@media(min-width:1024px){.interior-text{text-align:left}}
.interior-accent{margin-bottom:24px}
.interior-diamond{display:inline-block;height:128px;width:auto;animation:diamond-step 6s ease-in-out infinite;transform-origin:center center}
@keyframes diamond-step{0%{transform:rotate(0deg)}10%{transform:rotate(90deg)}25%{transform:rotate(90deg)}35%{transform:rotate(180deg)}50%{transform:rotate(180deg)}60%{transform:rotate(270deg)}75%{transform:rotate(270deg)}85%{transform:rotate(360deg)}100%{transform:rotate(360deg)}}
@media(max-width:767px){.interior-diamond{height:60px}}

.interior-title{font-size:32px;font-weight:700;color:#121212;line-height:1.15;letter-spacing:.08em;margin-bottom:32px}
@media(min-width:768px){.interior-title{font-size:44px}}
@media(min-width:1024px){.interior-title{font-size:42px}}

.interior-desc{font-size:14px;color:#414042;line-height:1.75;max-width:420px;margin:0 auto 40px}
@media(min-width:1024px){.interior-desc{margin:0 0 40px}}
@media(min-width:768px){.interior-desc{font-size:16px}}

/* flex-wrap 防止手机端标签溢出换行后顶出容器 */
.interior-brands{display:flex;align-items:center;justify-content:center;gap:20px;font-size:11px;color:rgba(65,64,66,.5);letter-spacing:.15em;text-transform:uppercase;flex-wrap:wrap}
@media(min-width:1024px){.interior-brands{justify-content:flex-start}}
.interior-dot{font-size:6px;color:rgba(18,18,18,.25);line-height:1}

/* .carousel-section{width:100%;background:#fff}
.carousel-wrap{width:100%;transition:all 1s ease;opacity:0}
.carousel-section.is-visible .carousel-wrap{opacity:1}
.carousel-stage{position:relative;width:100%;aspect-ratio:16/9;max-height:80vh;overflow:hidden}
@media(min-width:768px){.carousel-stage{aspect-ratio:21/9}}
.carousel-slide{position:absolute;inset:0;transition:opacity .7s ease-out;opacity:0;z-index:0}
.carousel-slide.is-active{opacity:1;z-index:10}
.carousel-slide-bg{width:100%;height:100%;background:#d4cfc8;background-size:cover;}
.carousel-slide-overlay{position:absolute;inset:0;background:rgba(0,0,0,.2)}
.carousel-slide-content{position:absolute;bottom:0;left:0;right:0;padding:32px 32px 48px}
@media(min-width:768px){.carousel-slide-content{padding:64px}}
@media(min-width:1024px){.carousel-slide-content{padding:80px}}
.carousel-slide-title{color:#fff;font-size:24px;font-weight:700;letter-spacing:-.08em}
@media(min-width:768px){.carousel-slide-title{font-size:36px}}
@media(min-width:1024px){.carousel-slide-title{font-size:48px}}
.carousel-slide-subtitle{color:rgba(255,255,255,.7);font-size:14px;margin-top:8px}
@media(min-width:768px){.carousel-slide-subtitle{font-size:16px}}
.carousel-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;background:rgba(255,255,255,.9);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:20;transition:background .3s;cursor:pointer}
.carousel-nav:hover{background:#fff}
.carousel-nav-prev{left:24px}
.carousel-nav-next{right:24px}
.carousel-nav svg{width:20px;height:20px;color:#121212}
.carousel-bar{width:100%;padding:24px 32px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(18,18,18,.05)}
.carousel-current{color:#121212;font-weight:500;font-size:14px;font-variant-numeric:tabular-nums}
.carousel-progress{flex:1;margin:0 24px;height:1px;background:rgba(18,18,18,.1);position:relative}
.carousel-progress-fill{position:absolute;top:0;left:0;height:100%;background:#EC008C;transition:width .5s}
.carousel-total{color:rgba(65,64,66,.4);font-size:14px;font-variant-numeric:tabular-nums} */

.carousel-section{width:100%;background:#fff}
.carousel-wrap{width:100%;transition:all 1s ease;opacity:0}
.carousel-section.is-visible .carousel-wrap{opacity:1}
.carousel-stage{position:relative;width:100%;aspect-ratio:16/9;max-height:80vh;overflow:hidden}
@media(min-width:768px){.carousel-stage{aspect-ratio:21/9}}
.carousel-slide{position:absolute;inset:0;transition:opacity .7s ease-out;opacity:0;z-index:0}
.carousel-slide.is-active{opacity:1;z-index:10}
.carousel-slide-bg{width:100%;height:100%;background:#d4cfc8;background-size:cover}
.carousel-slide-overlay{position:absolute;inset:0;background:rgba(0,0,0,.2)}
.carousel-slide-content{position:absolute;bottom:0;left:0;right:0;padding:32px 32px 48px}
@media(min-width:768px){.carousel-slide-content{padding:64px}}
@media(min-width:1024px){.carousel-slide-content{padding:80px}}
.carousel-slide-title{color:#fff;font-size:24px;font-weight:700;letter-spacing:-.08em}
@media(min-width:768px){.carousel-slide-title{font-size:36px}}
@media(min-width:1024px){.carousel-slide-title{font-size:48px}}
.carousel-slide-subtitle{color:rgba(255,255,255,.7);font-size:14px;margin-top:8px}
@media(min-width:768px){.carousel-slide-subtitle{font-size:16px}}
.carousel-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;background:rgba(255,255,255,.5);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:20;transition:background .3s;cursor:pointer;border:none}
.carousel-nav:hover{background:rgba(255,255,255,.8)}
.carousel-nav-prev{left:24px}
.carousel-nav-next{right:24px}
.carousel-nav svg{width:20px;height:20px;color:#121212}
.carousel-bar{width:100%;padding:24px 32px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(18,18,18,.05)}
.carousel-current{color:#121212;font-weight:500;font-size:14px;font-variant-numeric:tabular-nums}
.carousel-progress{flex:1;margin:0 24px;height:1px;background:rgba(18,18,18,.1);position:relative}
.carousel-progress-fill{position:absolute;top:0;left:0;height:100%;background:#EC008C;transition:width .5s}
.carousel-total{color:rgba(65,64,66,.4);font-size:14px;font-variant-numeric:tabular-nums}
@media(max-width:767px){
    .carousel-nav{width:20px;height:20px;top:auto;bottom:90px;transform:none;background:rgba(255,255,255,.5)}
    .carousel-nav-prev{left:8px}
    .carousel-nav-next{right:8px}
    .carousel-nav svg{width:16px;height:16px}
    .carousel-slide-content{padding:40px}
}

.home-future{position:relative;width:100%;background:#E17427;overflow:hidden}
.home-future-mask{position:absolute;top:0;left:0;right:0;height:300px;background:#fff;z-index:0}
@media(min-width:768px){.home-future-mask{height:480px}}
.home-future-inner{position:relative;z-index:10;width:100%;padding:96px 0 80px}
@media(min-width:768px){.home-future-inner{padding:240px 0 112px}}
.home-future-row1{width:60%;margin:0 auto;display:flex;align-items:start;opacity:0;transform:translateY(40px);transition:all 1s ease}
.home-future.is-visible .home-future-row1{opacity:1;transform:translateY(0)}
.home-future-imga{width:260px;flex-shrink:0}
@media(min-width:768px){.home-future-imga{width:320px}}
@media(min-width:1024px){.home-future-imga{width:360px}}
.home-future-imga-inner{width:100%;height: 100%;aspect-ratio:3/4;overflow: hidden;}
.home-future-imga-inner img { width: 100%;height: 100%;object-fit: cover;display: block;}
.home-future-title{flex:1;text-align:right;padding-top:24px;padding-left:32px}
@media(min-width:768px){.home-future-title{padding-top:48px}}
@media(min-width:1024px){.home-future-title{padding-top:80px}}
.home-future-title h2{font-size:16px;font-weight:500;color:#121212;line-height:1.4;}
@media(min-width:768px){.home-future-title h2{font-size:20px}}
@media(min-width:1024px){.home-future-title h2{font-size:42px}}
.home-future-carousel-wrap{position:relative;width:80%;margin:32px auto 0;z-index:10}
@media(min-width:768px){.home-future-carousel-wrap{margin-top:96px}}
.home-future-carousel{position:relative;width:100%;aspect-ratio:16/9;max-height:100vh;overflow:hidden;opacity:0;transform:translateY(40px);transition:all 1s .4s ease}
.home-future.is-visible .home-future-carousel{opacity:1;transform:translateY(0)}
.home-future-carousel-slide{position:absolute;inset:0;transition:opacity .7s ease;opacity:0;z-index:0}
.home-future-carousel-slide.is-active{opacity:1;z-index:10}
.home-future-carousel-slide-inner{width:100%;height:100%;background:#d4d0c8}
.home-future-dots{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);z-index:20;display:flex;align-items:center;gap:12px}
.home-future-dot{border:none;padding:0;cursor:pointer;transition:all .5s ease}
.home-future-dot.is-active{width:32px;height:3px;background:#fff}
.home-future-dot:not(.is-active){width:3px;height:3px;background:rgba(255,255,255,.5)}
.home-future-dot:not(.is-active):hover{background:rgba(255,255,255,.8)}

/* ─── Intelligence Section ─── */
/* Calibrated for 1905px viewport. All inner positions use percentages
   relative to the fixed-ratio canvas so zoom never breaks alignment. */

.intelligence { position: relative; background: #FFFFFF; overflow: hidden; }

.intelligence-container {
    position: relative;
    width: 80%;
    max-width: none;
    margin: 0 auto;
    padding: 120px 0;
}

/* ─── Canvas: fixed-ratio drawing sheet ─── */
.intelligence-canvas {
    position: relative;
    width: 100%;
    aspect-ratio: 1524 / 1000;
    /* Fallback for very old browsers: padding-bottom: 65.616% */
}

/* Title */
.intelligence-title {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    z-index: 10;
    opacity: 0;
    transition: opacity 1.2s cubic-bezier(0.16, 1, 0.3, 1);
    pointer-events: none;
}
.intelligence-title.visible { opacity: 1; }
.intelligence-eyebrow {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: #EC008C;
    margin-bottom: 20px;
    display: block;
}
.intelligence-heading {
    font-size: clamp(36px, 5vw, 68px);
    font-weight: 300;
    line-height: 1.05;
    letter-spacing: -0.03em;
    color: #121212;
    margin-bottom: 26px;
}
.intelligence-heading em {
    font-style: normal;
    font-weight: 500;
    color: #EC008C;
}
.intelligence-subtitle {
    font-size: 12px;
    font-weight: 400;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: #999;
}

/* Visuals */
.intelligence-visual {
    position: absolute;
    z-index: 5;
    opacity: 0;
    transform: translateY(16px);
    transition: all 1s cubic-bezier(0.16, 1, 0.3, 1);
}
.intelligence-visual.visible {
    opacity: 1;
    transform: translateY(0);
    animation: subtle-float 4s ease-in-out infinite 1.5s;
}
.intelligence-visual img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 1px;
    filter: contrast(105%) saturate(85%);
}
.intelligence-visual::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(0,60,140,0.07) 0%, rgba(0,0,0,0) 60%);
    pointer-events: none;
    border-radius: 1px;
}

/* P1 image: 360x480 on 1524x1000 sheet */
.p1-visual {
    left: 2.62%;
    top: 6%;
    width: 23.62%;
    aspect-ratio: 3 / 4;
}

/* P2 image: anchored by top now so zoom cannot break it */
.p2-visual {
    right: 2.62%;
    top: 46%;
    width: 23.62%;
    aspect-ratio: 3 / 4;
}

/* Corner marks */
.corner-marks {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 2;
}
.corner-marks::before,
.corner-marks::after,
.corner-marks span::before,
.corner-marks span::after {
    content: '';
    position: absolute;
    width: 14px;
    height: 14px;
    border-color: #c0c0c0;
    border-style: solid;
    border-width: 0;
}
.corner-marks::before      { top: -7px; left: -7px; border-top-width: 1px; border-left-width: 1px; }
.corner-marks::after       { top: -7px; right: -7px; border-top-width: 1px; border-right-width: 1px; }
.corner-marks span::before { bottom: -7px; left: -7px; border-bottom-width: 1px; border-left-width: 1px; }
.corner-marks span::after  { bottom: -7px; right: -7px; border-bottom-width: 1px; border-right-width: 1px; }

/* Annotation Groups */
.annotation-group {
    position: absolute;
    z-index: 6;
    opacity: 0;
    transform: translateY(6px);
    transition: opacity 0.3s ease, transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    pointer-events: auto;
}
.annotation-group.active {
    opacity: 1;
    transform: translateY(0);
}
.annotation-group svg {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    overflow: visible;
}
.anno-line {
    fill: none;
    stroke: #EC008C;
    stroke-width: 1;
}
.anno-node {
    /* external SVG image node */
}
.anno-card-bg {
    fill: rgba(255,255,255,0.96);
    stroke: #e0e0e0;
    stroke-width: 1;
}
.anno-card-accent {
    stroke: #EC008C;
    stroke-width: 2;
}
.annotation-text {
    position: absolute;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 18px 20px;
}
.anno-num {
    font-size: 10px;
    font-weight: 600;
    color: #E17427;
    letter-spacing: 0.15em;
    margin-bottom: 6px;
}
.annotation-text h4 {
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin-bottom: 6px;
    color: #121212;
    line-height: 1.3;
}
.annotation-text p {
    font-size: 11.5px;
    line-height: 1.6;
    color: #777;
    font-weight: 400;
}

/* ─── Part 1 Annotation Positions ─── */
/* Group: width & aspect-ratio must match SVG viewBox ratio exactly */
.p1-g1 {
    left: 27.56%;
    top: 14%;
    width: 17.06%;
    aspect-ratio: 260 / 160;
}
.p1-g1 .annotation-text {
    left: 46.15%;
    top: -6.25%;
    width: 84.62%;
    height: 68.75%;
}

.p1-g2 {
    left: 5.25%;
    top: 58%;
    width: 26.25%;
    aspect-ratio: 400 / 240;
}
.p1-g2 .annotation-text {
    left: 50%;
    top: 33.33%;
    width: 55%;
    height: 45.83%;
}

.p1-g3 {
    left: 27.56%;
    top: 28%;
    width: 17.06%;
    aspect-ratio: 260 / 240;
}
.p1-g3 .annotation-text {
    left: 46.15%;
    top: -41.67%;
    width: 84.62%;
    height: 45.83%;
}

/* ─── Part 2 Annotation Positions ─── */
.p2-g1 {
    left: 65.62%;
    top: 68%;
    width: 18.37%;
    aspect-ratio: 280 / 200;
}
.p2-g1 .annotation-text {
    left: -78.57%;
    top: 10%;
    width: 78.57%;
    height: 55%;
}

.p2-g2 {
    left: 78%;
    top: 36%;
    width: 17.06%;
    aspect-ratio: 260 / 320;
}
.p2-g2 .annotation-text {
    left: -88.46%;
    top: -37.5%;
    width: 76.92%;
    height: 31.25%;
}

/* Float Animation */
@keyframes subtle-float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-6px); }
}

/* ─── Responsive ─── */
@media (max-width: 1024px) {
    .intelligence-container {
        padding: 80px 30px;
    }
    .intelligence-canvas {
        aspect-ratio: auto;
        height: auto;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 20px;
    }
    .intelligence-title {
        position: relative;
        top: auto; left: auto;
        transform: none;
        margin-bottom: 40px;
        pointer-events: auto;
    }
    .intelligence-visual {
        position: relative;
        top: auto; left: auto; right: auto; bottom: auto;
        width: 100% !important;
        max-width: 400px;
        aspect-ratio: 3 / 4;
        animation: none;
    }
    .intelligence-visual img {
        width: 100%;
        height: auto;
    }
    .annotation-group {
        position: relative;
        left: auto !important;
        top: auto !important;
        width: 100% !important;
        height: auto !important;
        aspect-ratio: auto !important;
        opacity: 1 !important;
        transform: none !important;
        margin-top: 20px;
    }
    .annotation-group svg { display: none; }
    .annotation-text {
        position: relative;
        left: auto !important;
        top: auto !important;
        width: 100% !important;
        height: auto !important;
        padding: 12px 18px;
        border: 1px solid #e5e5e5;
        background: rgba(255,255,255,0.96);
    }
    .annotation-text::before {
        content: '';
        display: block;
        width: 24px;
        height: 2px;
        background: #EC008C;
        margin-bottom: 10px;
    }
}
@media (max-width: 640px) {
    .intelligence-container { padding: 60px 20px; }
    .intelligence-heading { font-size: 32px; }
}

/* ─── Location Section ─── */
.location{width:100%;background:#fff;overflow:hidden;padding:0 0}
@media(min-width:768px){.location{padding:0 0}}
.location-headline-wrap{width:100%;background:rgba(236,0,140,.6);display:flex;align-items:center;gap:4vw;padding:28px 4vw;border-bottom:1px solid rgba(0,0,0,.25)}
@media(min-width:768px){.location-headline-wrap{gap:2vw;padding:28px 2vw}}
.headline-star{width:12px;height:12px;flex-shrink:0;display:block}
@media(min-width:768px){.headline-star{width:12px;height:12px}}
.location-headline{font-size:clamp(22px,4.5vw,52px);font-weight:700;letter-spacing:.08em;text-transform:uppercase;line-height:1.2;text-align:left;margin:0}
@media(max-width:767px){
    .location-headline{font-size:clamp(16px,5.2vw,22px)}
    .headline-black,
    .headline-white{display:block}
}
.headline-black{color:#000}
.headline-white{color:#fff}
.marquee-row{width:100%;overflow:hidden;position:relative;padding:28px 0;border-bottom:1px solid rgba(0,0,0,.25)}
.items-row-right{background:rgba(236,0,140,.8)}
.items-row-left{background:#EC008C}
.marquee-track{display:flex;width:max-content;will-change:transform}
.items-row-right .marquee-track{animation:scroll-right 35s linear infinite}
.items-row-left .marquee-track{animation:scroll-left 35s linear infinite}
.marquee-cell{display:flex;align-items:center;gap:10px;padding:0 12px;white-space:nowrap;flex-shrink:0}
.marquee-divider{display:flex;align-items:center;padding:0 12px;flex-shrink:0}
.marquee-icon{width:28px;height:28px;flex-shrink:0;display:block}
.marquee-label{font-size:clamp(13px,3.8vw,16px);font-weight:500;color:#fff;letter-spacing:.1em;text-transform:uppercase}
@media(min-width:768px){
    .marquee-cell{padding:0 56px;gap:16px}
    .marquee-divider{padding:0 56px}
    .marquee-icon{width:44px;height:44px}
    .marquee-label{font-size:clamp(18px,3vw,32px)}
}
.marquee-star{width:12px;height:12px;display:block}
@media(min-width:768px){.marquee-star{width:12px;height:12px}}
@keyframes scroll-left{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes scroll-right{0%{transform:translateX(-50%)}100%{transform:translateX(0)}}



.map-section{width:100%;background:#121212}
.map-tabs{display:flex;justify-content:center;gap:60px;padding-top:64px;padding-bottom:32px}
@media(min-width:768px){.map-tabs{padding-top:96px}}
.map-tab{font-size:24px;letter-spacing:.25em;text-transform:uppercase;padding-bottom:8px;border-bottom:2px solid transparent;color:rgba(255,255,255,.3);transition:all .3s;background:none;cursor:pointer}
.map-tab:hover{color:rgba(255,255,255,.6)}
.map-tab.is-active{color:#fff;border-bottom-color:#fff}
.map-panel{display:none}
.map-panel.is-active{display:block}
.map-area{padding:0 24px 60px}
@media(min-width:768px){.map-area{padding:0 32px 96px}}
@media(min-width:1024px){.map-area{padding:0 80px 96px}}
.map-viewport{position:relative;width:100%;height:70vh;min-height:400px;max-height:800px;overflow:hidden;border-radius:6px;background:#1a1a1a;touch-action:none;cursor:grab}
.map-viewport:active{cursor:grabbing}
.map-layer{position:absolute;top:0;left:0;width:300%;transform-origin:center center;will-change:transform}
.map-layer img{width:100%;height:auto;display:block}
@media(min-width:769px){
.map-viewport{height:auto;min-height:0;max-height:none;overflow:visible;cursor:default;touch-action:auto}
.map-viewport:active{cursor:default}
.map-layer{position:relative;width:100%;transform:none!important}
}
.map-hotspot{position:absolute;width:32px;height:32px;transform:translate(-50%,-50%);cursor:pointer;z-index:2;border-radius:50%}
.map-hotspot-main{width:64px;height:64px;cursor:default;z-index:3}
.map-title-tip{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(4px);background:#fff;color:#121212;padding:7px 14px;border-radius:4px;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap;box-shadow:0 4px 16px rgba(0,0,0,.2);opacity:0;visibility:hidden;transition:all .22s ease;pointer-events:none;z-index:50}
.map-title-tip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:#fff}
.map-hotspot:hover .map-title-tip{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.map-title-tip.dir-down{bottom:auto;top:calc(100% + 10px);transform:translateX(-50%) translateY(-4px)}
.map-title-tip.dir-down::after{top:auto;bottom:100%;border-top-color:transparent;border-bottom-color:#fff}
.map-hotspot:hover .map-title-tip.dir-down{transform:translateX(-50%) translateY(0)}
.map-title-tip.dir-left{bottom:auto;top:50%;right:calc(100% + 10px);left:auto;transform:translateY(-50%) translateX(4px)}
.map-title-tip.dir-left::after{top:50%;left:100%;right:auto;bottom:auto;transform:translateY(-50%);border:5px solid transparent;border-left-color:#fff;border-top-color:transparent;border-bottom-color:transparent}
.map-hotspot:hover .map-title-tip.dir-left{transform:translateY(-50%) translateX(0)}
.map-title-tip.dir-right{bottom:auto;top:50%;left:calc(100% + 10px);transform:translateY(-50%) translateX(-4px)}
.map-title-tip.dir-right::after{top:50%;right:100%;left:auto;bottom:auto;transform:translateY(-50%);border:5px solid transparent;border-right-color:#fff;border-top-color:transparent;border-bottom-color:transparent}
.map-hotspot:hover .map-title-tip.dir-right{transform:translateY(-50%) translateX(0)}
.map-card-tip{position:absolute;width:240px;background:#fff;border-radius:6px;box-shadow:0 16px 48px rgba(0,0,0,.25);opacity:0;visibility:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);pointer-events:none;overflow:hidden;z-index:100}
.map-card-img{width:100%;height:130px;background:linear-gradient(135deg,#EC008C 0%,#E17427 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;font-weight:600;position:relative}
.map-card-img img{width:100%;height:100%;object-fit:cover;display:block;position:absolute;top:0;left:0}
.map-card-body{padding:16px 18px 18px}
.map-card-body h4{font-size:12px;letter-spacing:1.2px;color:#121212;margin-bottom:6px;font-weight:600;text-transform:uppercase}
.map-card-body p{font-size:13px;color:#414042;line-height:1.5;margin:0}
.map-card-meta{font-size:11px;color:#EC008C;margin-top:8px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}
.map-hotspot:hover .map-card-tip,.map-hotspot.active .map-card-tip{opacity:1;visibility:visible;pointer-events:auto}
.map-card-tip.dir-up{bottom:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(6px) scale(.96)}
.map-card-tip.dir-up::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:8px solid transparent;border-top-color:#fff}
.map-hotspot:hover .map-card-tip.dir-up,.map-hotspot.active .map-card-tip.dir-up{transform:translateX(-50%) translateY(0) scale(1)}
.map-card-tip.dir-down{top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(-6px) scale(.96)}
.map-card-tip.dir-down::after{content:'';position:absolute;bottom:100%;left:50%;transform:translateX(-50%);border:8px solid transparent;border-bottom-color:#fff}
.map-hotspot:hover .map-card-tip.dir-down,.map-hotspot.active .map-card-tip.dir-down{transform:translateX(-50%) translateY(0) scale(1)}
.map-card-tip.dir-left{right:calc(100% + 14px);top:50%;transform:translateY(-50%) translateX(6px) scale(.96)}
.map-card-tip.dir-left::after{content:'';position:absolute;top:50%;left:100%;transform:translateY(-50%);border:8px solid transparent;border-left-color:#fff}
.map-hotspot:hover .map-card-tip.dir-left,.map-hotspot.active .map-card-tip.dir-left{transform:translateY(-50%) translateX(0) scale(1)}
.map-card-tip.dir-right{left:calc(100% + 14px);top:50%;transform:translateY(-50%) translateX(-6px) scale(.96)}
.map-card-tip.dir-right::after{content:'';position:absolute;top:50%;right:100%;transform:translateY(-50%);border:8px solid transparent;border-right-color:#fff}
.map-hotspot:hover .map-card-tip.dir-right,.map-hotspot.active .map-card-tip.dir-right{transform:translateY(-50%) translateX(0) scale(1)}
.map-legend{margin-top:48px;display:grid;gap:24px 16px}
.map-panel[data-panel=area] .map-legend{grid-template-columns:repeat(6,1fr)}
.map-panel[data-panel=location] .map-legend{grid-template-columns:repeat(8,1fr)}
.map-legend-col{}
.map-legend-heading{display:flex;align-items:center;gap:8px;font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:#fff;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.08);white-space:nowrap}
.map-legend-icon{width:14px;height:14px;flex-shrink:0;display:block}
.map-legend-item{font-size:11px;color:#999;line-height:2;letter-spacing:.3px}
.map-legend-item span{color:#666;margin-right:6px;font-weight:500}
.map-legend-subgrid{display:grid;grid-template-columns:1fr 1fr;gap:0 12px}
@media(max-width:1200px){
.map-panel[data-panel=area] .map-legend{grid-template-columns:repeat(3,1fr)}
.map-panel[data-panel=location] .map-legend{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:768px){
.map-area{padding:0 16px 40px}
.map-viewport{height:60vh;min-height:320px;border-radius:4px}
.map-panel[data-panel=area] .map-legend{grid-template-columns:repeat(2,1fr)}
.map-panel[data-panel=location] .map-legend{grid-template-columns:repeat(2,1fr)}
.map-legend-heading{font-size:9px;letter-spacing:1px}
.map-legend-item{font-size:10px}
.map-card-tip{width:200px}
.map-card-img{height:110px}
.map-card-body{padding:14px}
.map-hotspot{width:40px;height:40px}
.map-hotspot-main{width:56px;height:56px}
}
@media(max-width:480px){
.map-panel[data-panel=area] .map-legend{grid-template-columns:1fr}
.map-panel[data-panel=location] .map-legend{grid-template-columns:1fr}
.map-legend-subgrid{grid-template-columns:1fr}
}

.ending{width:100%;background:#fff;padding-bottom: 80px;}
.ending-wrap{display:flex;flex-wrap:wrap;}
@media(min-width:1024px){.ending-wrap{flex-wrap:nowrap;min-height:600px;padding:80px 0}}
.ending-content{width:100%;padding:80px 40px;}
@media(min-width:1024px){.ending-content{width:30%;padding:120px 60px;display:flex;flex-direction:column;justify-content:center;}}
.ending-title{font-size:11px;font-weight:500;color:#EC008C;letter-spacing:.1em;text-transform:uppercase;margin-bottom:24px;}
.ending-subtitle{font-size:24px;font-weight:700;color:#121212;line-height:1.2;margin-bottom:32px;}
@media(min-width:768px){.ending-subtitle{font-size:32px;}}
.ending-body{font-size:13px;color:#414042;line-height:1.8;letter-spacing:.05em;}
.ending-body p{margin-bottom:16px;}
.ending-image-wrap{width:100%;position:relative;}
@media(min-width:1024px){.ending-image-wrap{width:70%;}}
.ending-image{width:100%;height:400px;object-fit:cover;display:block;}
@media(min-width:1024px){.ending-image{height:100%;position:absolute;top:0;left:0;}}


.enquiry{width:100%;background:#121212;position:relative;}
.enquiry-delimeter{width:100%;display:block;}
.enquiry-header-wrap{width:80%;margin:0 auto;padding-top:0;padding-bottom:48px}
@media(min-width:768px){.enquiry-header-wrap{padding-top:0}}
.enquiry-header{opacity:0;transform:translateY(40px);transition:all 1s ease}
.enquiry.is-visible .enquiry-header{opacity:1;transform:translateY(0)}
.enquiry-title{font-size:48px;font-weight:700;color:#fff;line-height:1.05}
@media(min-width:768px){.enquiry-title{font-size:60px}}
@media(min-width:1024px){.enquiry-title{font-size:72px}}
.enquiry-content{width:80%;margin:0 auto;padding-bottom:96px}
@media(min-width:768px){.enquiry-content{padding-bottom:128px}}
.enquiry-grid{display:grid;grid-template-columns:1fr;gap:64px}
@media(min-width:1024px){.enquiry-grid{grid-template-columns:1fr 1fr;gap:80px}}
.enquiry-info{opacity:0;transform:translateY(40px);transition:all 1s .2s ease}
.enquiry.is-visible .enquiry-info{opacity:1;transform:translateY(0)}
.enquiry-desc{font-size:14px;color:rgba(255,255,255,.7);line-height:1.75;margin-bottom:48px;max-width:480px}
@media(min-width:768px){.enquiry-desc{font-size:16px}}
.enquiry-contact{margin-bottom:48px}
.enquiry-contact-item{display:flex;align-items:flex-start;gap:16px;margin-bottom:24px}
.enquiry-contact-icon{width:16px;height:16px;color:#EC008C;flex-shrink:0;margin-top:2px}
a.enquiry-contact-item{transition:color .3s}
a.enquiry-contact-item:hover{color:#EC008C}
.enquiry-contact-text{font-size:14px;color:rgba(255,255,255,.9)}
.enquiry-contact-title{display:block;font-size:14px;font-weight:500;color:#fff}
.enquiry-contact-detail{display:block;font-size:14px;color:rgba(255,255,255,.7)}
.enquiry-social{display:flex;align-items:center;gap:16px}
.enquiry-social-logo{height:128px;width:auto;margin-right:24px;display:block}
.enquiry-social-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;transition:opacity .3s;opacity: 0.8;}
.enquiry-social-link img{width:24px;height:24px}
.enquiry-social-link:hover{opacity:1}
.enquiry-form-wrap{opacity:0;transform:translateY(40px);transition:all 1s .4s ease}
.enquiry.is-visible .enquiry-form-wrap{opacity:1;transform:translateY(0)}
.enquiry-form{display:flex;flex-direction:column;gap:20px}
.enquiry-form-row{display:grid;grid-template-columns:1fr;gap:20px}
.enquiry-form-row-full{grid-template-columns:1fr}
@media(min-width:640px){.enquiry-form-row{grid-template-columns:1fr 1fr}}
.enquiry-field{display:flex;flex-direction:column;gap:8px}
.enquiry-field-label{font-size:11px;color:rgba(255,255,255,.5);letter-spacing:.15em;text-transform:uppercase}
.enquiry-field-input{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);padding:14px 16px;color:#fff;font-size:14px;transition:border-color .3s;border-radius:0}
.enquiry-field-input:focus{outline:none;border-color:rgba(236,0,140,.4)}
.enquiry-textarea{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);padding:14px 16px;color:#fff;font-size:14px;transition:border-color .3s;resize:none;border-radius:0}
.enquiry-textarea:focus{outline:none;border-color:rgba(236,0,140,.4)}
.enquiry-submit{background:#EC008C;color:#fff;padding:16px 48px;font-size:13px;font-weight:500;letter-spacing:.15em;text-transform:uppercase;transition:background-color .3s;align-self:flex-start;cursor:pointer;border-radius:0;border:none}
.enquiry-submit:hover{background:#d4007d}
.enquiry-success{display:none;flex-direction:column;align-items:center;justify-content:center;min-height:300px}
.enquiry-success.is-visible{display:flex}
.enquiry-success-icon{width:56px;height:56px;background:rgba(236,0,140,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:24px}
.enquiry-success-icon svg{width:24px;height:24px;color:#EC008C}
.enquiry-success-title{color:#fff;font-size:24px;font-weight:500;margin-bottom:12px}
.enquiry-success-text{color:rgba(255,255,255,.5);font-size:14px;line-height:1.6;max-width:400px;text-align:center}
.site-footer-bar{border-top:1px solid rgba(255,255,255,.06);padding:24px 32px;display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:16px}
@media(min-width:768px){.site-footer-bar{flex-direction:row}}
.site-footer-copy{font-size:12px;color:rgba(255,255,255,.25)}
.site-footer-links{display:flex;gap:32px}
.site-footer-links a,.site-footer-links span{font-size:12px;color:rgba(255,255,255,.25);transition:color .3s}
.site-footer-links a:hover{color:rgba(255,255,255,.5)}

/* Transition Section */
.transition{position:relative;width:100%;padding:90px 0;background:#fff;overflow:hidden}
.transition-inner{width:88%;margin:0 auto;text-align:center;position:relative;z-index:2}

/* 统一入场动画节奏 */
.transition-eyebrow,.transition-title-wrap,.transition-desc{opacity:0;transform:translateY(40px);transition:opacity 1.2s cubic-bezier(0.25,0.46,0.45,0.94),transform 1.2s cubic-bezier(0.25,0.46,0.45,0.94);will-change:transform,opacity}
.transition.is-visible .transition-eyebrow,.transition.is-visible .transition-title-wrap,.transition.is-visible .transition-desc{opacity:1;transform:translateY(0)}

.transition-eyebrow{font-size:11px;font-weight:600;letter-spacing:0.3em;text-transform:uppercase;color:#121212;margin-bottom:20px;display:block}
.transition-title-wrap{position:relative;display:inline-block;margin-bottom:40px;cursor:default}
.transition-title{font-size:clamp(32px,8vw,56px);font-weight:500;line-height:1.08;letter-spacing:-0.02em;text-transform:uppercase;text-align:center}
.transition-title span{display:block}
.transition-title-base{color:#EC008C}
.transition-title-spotlight{position:absolute;top:0;left:0;width:100%;height:100%;color:#E17427;clip-path:circle(0px at 50% 50%);will-change:clip-path;transition:clip-path .15s ease-out;pointer-events:none}
.transition-inner:hover .transition-title-spotlight{clip-path:circle(120px at var(--mouse-x,50%) var(--mouse-y,50%))}

.transition-desc{font-size:13px;font-weight:400;line-height:1.8;letter-spacing:.03em;color:#414042;max-width:600px;margin:0 auto;white-space:pre-line}
.transition-desc+.transition-desc{margin-top:24px}

/* Gallery 动画优化 */
.transition-gallery{display:grid;grid-template-columns:1fr;gap:96px;margin-top:80px;text-align:left;opacity:0;transform:translateY(40px);transition:opacity 1.2s cubic-bezier(0.25,0.46,0.45,0.94) .3s,transform 1.2s cubic-bezier(0.25,0.46,0.45,0.94) .3s;will-change:transform,opacity}
.transition.is-visible .transition-gallery{opacity:1;transform:translateY(0)}
.transition-gallery-item{position:relative}
.transition-gallery-img{position:relative;width:100%;aspect-ratio:3/4;overflow:hidden;background:#f5f5f5}
.transition-gallery-img img{width:100%;height:100%;object-fit:cover;display:block}
.transition-gallery-title{font-size:16px;font-weight:600;color:#121212;margin-top:20px;letter-spacing:.02em;text-transform:uppercase}
.transition-gallery-sub{font-size:13px;font-weight:400;color:#414042;margin-top:6px;line-height:1.6;letter-spacing:.01em}

/* Banner 全宽背景：上 50% 橙色，下 50% 白色 */
.transition-banner{width:100%;position:relative;background:linear-gradient(to bottom,#E17427 50%,#ffffff 50%);padding:40px 0;margin-top:80px;opacity:0;transform:translateY(40px);transition:opacity 1.2s cubic-bezier(0.25,0.46,0.45,0.94) .4s,transform 1.2s cubic-bezier(0.25,0.46,0.45,0.94) .4s;will-change:transform,opacity}
.transition.is-visible .transition-banner{opacity:1;transform:translateY(0)}
.transition-banner-inner{width:88%;margin:0 auto;position:relative;z-index:2}
.transition-banner-img{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;background:#f5f5f5}
.transition-banner-img img{width:100%;height:100%;object-fit:cover;display:block}
.transition-banner-text{display:flex;justify-content:space-between;align-items:flex-end;margin-top:24px;gap:24px}
.transition-banner-title{font-size:14px;font-weight:600;color:#121212;line-height:1.5;letter-spacing:.02em;text-transform:uppercase;text-align:left;max-width:55%}
.transition-banner-desc{font-size:13px;font-weight:400;color:#414042;line-height:1.6;letter-spacing:.01em;text-align:right;max-width:320px}

/* Responsive */
@media(min-width:768px){
    .transition{padding:120px 0}
    .transition-inner{width:80%}
    .transition-banner-inner{width:80%}
    .transition-title{font-size:clamp(40px,5.5vw,72px)}
    .transition-desc{font-size:14px}
    .transition-gallery{grid-template-columns:repeat(3,1fr);gap:24px;margin-top:100px}
    .transition-gallery-item--left{transform:translateY(-40px)}
    .transition-gallery-item--right{transform:translateY(-40px)}
    .transition-gallery-item--center{transform:translateY(56px)}
    .transition-gallery-title{font-size:18px}
    .transition-gallery-sub{font-size:14px}
    .transition-banner{margin-top:100px}
    .transition-banner-title{font-size:16px}
    .transition-banner-desc{font-size:14px;max-width:400px}
}
@media(min-width:1024px){
    .transition{padding:220px 0}
    .transition-inner{width:60%}
    .transition-banner-inner{width:60%}
    .transition-title{font-size:clamp(40px,5.5vw,80px)}
    .transition-desc{font-size:16px}
    .transition-gallery{gap:96px;margin-top:160px}
    .transition-gallery-item--left{transform:translateY(-48px)}
    .transition-gallery-item--right{transform:translateY(-48px)}
    .transition-gallery-item--center{transform:translateY(64px)}
    .transition-banner{margin-top:160px}
    .transition-banner-title{font-size:20px}
    .transition-banner-desc{font-size:15px}
}

/* ===== SECTION: LANDING ===== */
.section-landing {
    position: relative;
    width: 100%;
    background: #ffffff;
    padding: 180px 0;
    overflow: hidden;
}

/* SVG pattern rendered in light grey via CSS mask */
.section-landing::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
-webkit-mask-image: url('../images/section-landing/landing-bg3.svg');
mask-image: url('../images/section-landing/landing-bg3.svg');
    -webkit-mask-size: cover;
    mask-size: cover;
    -webkit-mask-position: bottom;
    mask-position: bottom;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    background-color: #E17427;
    opacity: 0.6;
    pointer-events: none;
    z-index: 0;
}

.section-landing-inner {
    position: relative;
    z-index: 2;
    width: 100%;
}

.section-landing-container {
    width: 60%;
    max-width: 900px;
    margin: 0 auto;
    text-align: center;
}

.section-landing-title {
    font-size: clamp(26px, 4.2vw, 50px);
    font-weight: 500;
    color: #EC008C;
    letter-spacing: 0.06em;
    line-height: 1.25;
    text-transform: uppercase;
    margin-bottom: 44px;
}

.section-landing-subtitle {
    font-size: clamp(15px, 1.8vw, 20px);
    font-weight: 400;
    color: #121212;
    line-height: 1.6;
    margin-bottom: 44px;
}

.section-landing-body {
    font-size: clamp(14px, 1.4vw, 17px);
    font-weight: 300;
    color: #414042;
    line-height: 1.9;
    margin-bottom: 28px;
}

.section-landing-body:last-of-type {
    margin-bottom: 0;
}

.section-landing-body strong {
    font-weight: 500;
    color: #EC008C;
}

/* Mobile */
@media (max-width: 768px) {
    .section-landing {
        padding: 100px 0;
    }
    
    .section-landing-container {
        width: 88%;
    }
    
    .section-landing-title {
        margin-bottom: 32px;
    }
    
    .section-landing-subtitle {
        margin-bottom: 32px;
    }
    
    .section-landing-body {
        margin-bottom: 24px;
    }
}

/* ============================================
   ANNOUNCEMENT MODAL — Image Fix
   ============================================ */
.announcement-overlay{position:fixed;inset:0;z-index:9999;background:rgba(18,18,18,0.35);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:opacity .5s ease,visibility .5s ease}
.announcement-overlay.active{opacity:1;visibility:visible}
.announcement-modal{position:relative;width:80%;max-width:720px;background:#EC008C;border-radius:4px;overflow:hidden;transform:translateY(30px) scale(0.96);transition:transform .6s cubic-bezier(.22,1,.36,1);box-shadow:0 25px 80px rgba(0,0,0,0.25)}
.announcement-overlay.active .announcement-modal{transform:translateY(0) scale(1)}
.announcement-title{text-align:center;padding:28px 24px 20px;color:#fff;font-size:13px;font-weight:500;letter-spacing:3.5px;text-transform:uppercase;background:#EC008C;border-bottom:1px solid rgba(255,255,255,0.25)}
.announcement-close{position:absolute;top:16px;right:16px;z-index:10;width:40px;height:40px;border:none;background:rgba(255,255,255,0.3);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .3s ease,transform .3s ease}
.announcement-close:hover{background:#fff;transform:rotate(90deg)}
.announcement-close:hover svg{stroke:#EC008C}
.announcement-close svg{width:16px;height:16px;stroke:#fff;stroke-width:2;fill:none;transition:stroke .3s ease}
.announcement-body{padding:12px;background:#fff}

/* === Image: full display, no crop, original ratio === */
.announcement-image-wrap{
    width:100%;
    display:flex;
    align-items:center;
    justify-content:center;
}
.announcement-image-wrap img{
    max-width:100%;
    max-height:85vh;
    width:auto;
    height:auto;
    object-fit:contain;
    display:block;
}

@media(max-width:768px){
    .announcement-modal{width:92%;max-width:none}
    .announcement-image-wrap img{max-height:65vh}
    .announcement-title{padding:22px 16px 16px;font-size:12px;letter-spacing:2.5px}
    .announcement-close{top:12px;right:12px;width:36px;height:36px}
}