:root {
  --navy: #071b35;
  --blue: #0b3f7a;
  --electric: #2f7cf6;
  --ice: #edf4fa;
  --ink: #0a1d31;
  --muted: #617082;
  --white: #fff;
  --line: rgba(10, 29, 49, .12);
  --radius: 24px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: #f8fafc; font-family: "DM Sans", "Noto Sans TC", sans-serif; }
img { display: block; width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; }

.site-header {
  position: fixed; z-index: 20; inset: 0 0 auto; height: 80px; padding: 0 clamp(24px, 5vw, 80px);
  display: flex; align-items: center; justify-content: space-between; color: white;
  border-bottom: 1px solid rgba(255,255,255,.15); transition: .3s ease;
}
.site-header.scrolled { height: 68px; background: rgba(7,27,53,.94); backdrop-filter: blur(14px); }
.brand { display: inline-flex; align-items: center; gap: 10px; }
.brand-mark { width: 38px; height: 38px; display: grid; place-items: center; border: 2px solid currentColor; border-radius: 50%; font-weight: 800; }
.brand strong, .brand small { display: block; line-height: 1; }
.brand strong { font-size: 14px; letter-spacing: .12em; }
.brand small { margin-top: 5px; font: 500 10px/1 "Noto Sans TC", sans-serif; opacity: .68; }
nav { display: flex; gap: 34px; font-size: 13px; }
nav a { opacity: .75; transition: .2s; }
nav a:hover { opacity: 1; }
.header-actions { display: flex; align-items: center; gap: 14px; }
.lang-switch { border: 0; color: white; background: transparent; cursor: pointer; font-weight: 700; }
.button { display: inline-flex; justify-content: center; align-items: center; min-height: 52px; padding: 0 24px; border-radius: 999px; background: var(--electric); color: white; font-weight: 600; font-size: 14px; transition: transform .2s, background .2s; }
.button:hover { transform: translateY(-2px); background: #1767df; }
.button-small { min-height: 40px; padding: 0 18px; }
.button-light { background: white; color: var(--navy); }
.button-light:hover { background: #eaf2ff; }
.menu-toggle { display: none; }

.hero { position: relative; height: min(920px, 100vh); min-height: 720px; color: white; overflow: hidden; background: var(--navy); }
.hero-media { position: absolute; inset: 0; background: url("/images/image-1-1.png") center/cover; transform: scale(1.02); }
.hero-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(4,18,37,.96) 0%, rgba(4,18,37,.78) 42%, rgba(4,18,37,.16) 75%), linear-gradient(0deg, rgba(4,18,37,.7), transparent 48%); }
.hero-content { position: relative; z-index: 2; width: min(760px, 78vw); padding-top: clamp(170px, 23vh, 240px); margin-left: clamp(24px, 8vw, 130px); }
.eyebrow { margin: 0 0 22px; font-size: 12px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: #77aaff; }
.eyebrow.dark { color: var(--blue); }
h1, h2, h3, p { margin-top: 0; }
h1 { margin-bottom: 28px; font-family: "Noto Sans TC", sans-serif; font-size: clamp(48px, 6vw, 88px); line-height: 1.08; letter-spacing: -.05em; }
.hero-lead { max-width: 660px; font-size: clamp(17px, 1.5vw, 21px); line-height: 1.8; color: rgba(255,255,255,.78); }
.hero-actions { display: flex; align-items: center; gap: 28px; margin-top: 42px; }
.text-link { font-size: 14px; border-bottom: 1px solid rgba(255,255,255,.5); padding-bottom: 5px; }
.hero-stats { position: absolute; z-index: 3; left: 7%; right: 7%; bottom: 0; display: grid; grid-template-columns: repeat(4,1fr); border-top: 1px solid rgba(255,255,255,.22); }
.hero-stats div { padding: 28px 34px; border-right: 1px solid rgba(255,255,255,.18); }
.hero-stats div:last-child { border-right: 0; }
.hero-stats strong { display: block; font-size: 28px; }
.hero-stats sup { font-size: 13px; }
.hero-stats span { display: block; margin-top: 5px; font-size: 11px; opacity: .66; }

.section { padding: 130px clamp(24px, 8vw, 130px); }
.intro { display: grid; grid-template-columns: 1.1fr .9fr; gap: 10vw; align-items: end; background: white; }
h2 { font-family: "Noto Sans TC", sans-serif; font-size: clamp(36px, 4.2vw, 64px); line-height: 1.16; letter-spacing: -.04em; }
.intro h2 { max-width: 720px; margin-bottom: 0; }
.intro-copy p { font-size: 18px; line-height: 1.85; color: var(--muted); }
.arrow-link { display: inline-block; margin-top: 18px; color: var(--blue); font-weight: 700; }

.hub-section { display: grid; grid-template-columns: 1fr 1fr; min-height: 760px; background: var(--navy); color: white; }
.hub-visual { position: relative; min-height: 650px; overflow: hidden; background: radial-gradient(circle at 50% 50%, #174e88 0, var(--navy) 58%); }
.hub-center { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); width: 140px; height: 140px; display: grid; place-content: center; text-align: center; border-radius: 50%; background: white; color: var(--navy); box-shadow: 0 0 80px rgba(64,141,255,.45); }
.hub-center span { font-size: 12px; letter-spacing: .12em; }
.hub-center strong { font-size: 38px; line-height: 1; }
.orbit { position: absolute; left: 50%; top: 50%; translate: -50% -50%; border: 1px solid rgba(119,170,255,.25); border-radius: 50%; }
.orbit-one { width: 380px; height: 380px; }
.orbit-two { width: 650px; height: 650px; }
.hub-node { position: absolute; display: grid; place-items: center; width: 104px; height: 104px; padding: 10px; text-align: center; border: 1px solid rgba(255,255,255,.22); border-radius: 50%; background: rgba(255,255,255,.06); font-size: 13px; }
.node-one { left: 18%; top: 24%; }.node-two { right: 14%; top: 20%; }.node-three { right: 16%; bottom: 17%; }.node-four { left: 16%; bottom: 18%; }
.hub-copy { display: flex; flex-direction: column; justify-content: center; padding: 90px clamp(36px, 7vw, 110px); }
.hub-copy h2 { max-width: 650px; }
.hub-copy ul { margin: 38px 0 0; padding: 0; list-style: none; }
.hub-copy li { display: grid; grid-template-columns: 50px 1fr; gap: 12px; padding: 20px 0; border-top: 1px solid rgba(255,255,255,.14); }
.hub-copy li > span { color: #77aaff; font-size: 12px; }
.hub-copy li strong { font-size: 17px; }
.hub-copy li p { margin: 6px 0 0; font-size: 13px; color: rgba(255,255,255,.55); }

.solutions { background: var(--ice); }
.section-heading { display: grid; grid-template-columns: 1.25fr .75fr; gap: 10vw; align-items: end; margin-bottom: 70px; }
.section-heading h2 { margin-bottom: 0; }
.section-heading > p { font-size: 17px; line-height: 1.8; color: var(--muted); }
.service-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 20px; }
.service-card { position: relative; min-height: 500px; display: flex; align-items: flex-end; overflow: hidden; border-radius: var(--radius); color: white; background: var(--navy); }
.service-card img { position: absolute; inset: 0; height: 100%; object-fit: cover; transition: transform .6s ease; }
.service-card:hover img { transform: scale(1.035); }
.service-card::after { content: ""; position: absolute; inset: 30% 0 0; background: linear-gradient(transparent, rgba(4,18,37,.94)); }
.service-card div { position: relative; z-index: 2; padding: 38px; }
.service-card div > span { font-size: 11px; opacity: .7; }
.service-card h3 { margin: 10px 0 12px; font: 700 28px/1.25 "Noto Sans TC", sans-serif; }
.service-card p { max-width: 580px; margin-bottom: 0; line-height: 1.65; color: rgba(255,255,255,.72); }

.ecosystem { min-height: 780px; display: grid; grid-template-columns: 1.2fr .8fr; background: var(--navy); color: white; }
.ecosystem-image { min-height: 600px; background: url("/images/guangzhou-campus-aerial-v2.webp") center/contain no-repeat; background-color: #f6f7f9; }
.ecosystem-panel { display: flex; flex-direction: column; justify-content: center; padding: 90px clamp(40px, 6vw, 100px); }
.ecosystem-panel p:not(.eyebrow) { max-width: 590px; line-height: 1.85; color: rgba(255,255,255,.65); }
.tag-list { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 30px; }
.tag-list span { padding: 10px 16px; border: 1px solid rgba(255,255,255,.2); border-radius: 999px; font-size: 12px; }

.facilities { background: #f4f7fa; }
.facilities-heading { margin-bottom: 54px; }
.facilities-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-template-rows: 330px 390px 330px;
  gap: 18px;
}
.facility-card { position: relative; min-width: 0; overflow: hidden; border-radius: var(--radius); background: var(--navy); color: white; isolation: isolate; }
.facility-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .65s ease; }
.facility-card::after { content: ""; position: absolute; z-index: 1; inset: 28% 0 0; background: linear-gradient(transparent, rgba(3,16,33,.92)); pointer-events: none; }
.facility-card:hover img { transform: scale(1.025); }
.facility-overlay { position: absolute; z-index: 2; inset: auto 0 0; padding: 30px; }
.facility-number { margin-bottom: 9px; color: #8db8ff; font-size: 11px; font-weight: 700; letter-spacing: .16em; }
.facility-overlay h3 { margin-bottom: 10px; font: 700 clamp(20px, 2vw, 29px)/1.25 "Noto Sans TC", sans-serif; }
.facility-overlay > p:last-child { max-width: 600px; margin-bottom: 0; color: rgba(255,255,255,.72); font-size: 14px; line-height: 1.65; }
.facility-apartment { grid-column: 1 / span 7; grid-row: 1 / span 2; }
.facility-innovation { grid-column: 8 / span 5; grid-row: 1 / span 2; }
.facility-cafe { grid-column: 1 / span 4; grid-row: 3; }
.facility-football { grid-column: 5 / span 5; grid-row: 3; }
.facility-ski { grid-column: 10 / span 3; grid-row: 3; }
.facility-apartment img { object-position: 50% 46%; }
.facility-innovation img { object-position: 50% 44%; }
.facility-cafe img { object-position: center; }
.facility-football img { object-position: 50% 55%; }
.facility-ski img { object-position: 50% 38%; }

.partnership { background: white; }
.partnership-list { border-top: 1px solid var(--line); }
.partnership-list a { display: grid; grid-template-columns: 70px 1fr auto; align-items: center; padding: 28px 8px; border-bottom: 1px solid var(--line); transition: .2s; }
.partnership-list a:hover { padding-left: 20px; background: var(--ice); }
.partnership-list span { color: var(--blue); font-size: 12px; }
.partnership-list strong { font: 600 clamp(18px, 2vw, 28px)/1.3 "Noto Sans TC", sans-serif; }
.partnership-list i { font-style: normal; font-size: 22px; }

.contact { position: relative; padding: 120px clamp(24px, 8vw, 130px); background: #0b4482; color: white; overflow: hidden; }
.contact::after { content: "O"; position: absolute; right: -5vw; top: -21vw; font-size: 48vw; line-height: 1; font-weight: 800; color: rgba(255,255,255,.035); pointer-events: none; }
.contact > * { position: relative; z-index: 1; }
.contact h2 { max-width: 960px; }
.contact-button { margin-top: 30px; }
.contact-note { margin: 16px 0 0; font-size: 11px; color: rgba(255,255,255,.55); }

footer { min-height: 150px; padding: 38px clamp(24px, 8vw, 130px); display: flex; align-items: center; gap: 36px; background: var(--navy); color: white; font-size: 11px; }
.footer-brand { margin-right: auto; }
footer p { margin: 0; opacity: .55; }

[data-en] { transition: opacity .15s; }
body.changing [data-en] { opacity: 0; }

.housing-page { background: white; }
.housing-hero { min-height: 840px; padding: 160px clamp(24px, 8vw, 130px) 90px; display: grid; grid-template-columns: 1fr .78fr; gap: 6vw; align-items: center; background: radial-gradient(circle at 88% 18%, rgba(47,124,246,.35), transparent 34%), linear-gradient(135deg, var(--navy), #0b4482); color: white; overflow: hidden; }
.housing-hero-copy h1 { max-width: 840px; }
.housing-hero-card { overflow: hidden; border-radius: 34px; background: rgba(255,255,255,.1); box-shadow: 0 36px 90px rgba(0,0,0,.28); }
.housing-hero-card img { height: 520px; object-fit: cover; object-position: center; }
.housing-hero-card div { padding: 24px 28px 28px; }
.housing-hero-card span { display: block; margin-bottom: 8px; color: #9fc4ff; font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.housing-hero-card strong { font-size: clamp(22px, 2.2vw, 32px); line-height: 1.2; }
.housing-trust { background: white; }
.housing-feature-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; }
.housing-feature-grid article, .availability-grid article, .process-steps article, .faq-list article { border: 1px solid var(--line); border-radius: var(--radius); background: white; }
.housing-feature-grid article { min-height: 260px; padding: 28px; }
.housing-feature-grid span, .process-steps span { display: inline-flex; margin-bottom: 26px; color: var(--blue); font-size: 12px; font-weight: 800; letter-spacing: .14em; }
.housing-feature-grid h3, .availability-grid h3, .process-steps h3, .faq-list h3 { margin-bottom: 12px; font: 700 24px/1.25 "Noto Sans TC", sans-serif; }
.housing-feature-grid p, .availability-grid p, .process-steps p, .faq-list p { margin-bottom: 0; color: var(--muted); line-height: 1.7; }
.housing-availability { background: var(--ice); }
.availability-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.availability-grid article { padding: 30px; }
.status { display: inline-flex; margin-bottom: 24px; padding: 8px 13px; border-radius: 999px; font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.status.available { background: #e8f8ef; color: #0d7a3d; }
.status.limited { background: #fff6dd; color: #a46400; }
.status.inquiry { background: #eaf2ff; color: var(--blue); }
.availability-note { margin: 22px 0 0; color: var(--muted); font-size: 13px; }
.housing-life { display: grid; grid-template-columns: .72fr 1.28fr; gap: 18px; padding: 0 clamp(24px, 8vw, 130px) 130px; background: var(--ice); }
.housing-life-copy { display: flex; flex-direction: column; justify-content: center; padding: 60px; border-radius: var(--radius); background: var(--navy); color: white; }
.housing-life-copy h2 { margin-bottom: 0; }
.housing-life-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.housing-life-grid img { height: 520px; object-fit: cover; border-radius: var(--radius); }
.housing-life-grid img:first-child { object-position: center 40%; }
.housing-life-grid img:nth-child(2) { object-position: center; }
.housing-life-grid img:nth-child(3) { object-position: center 55%; }
.housing-process { background: white; }
.process-steps { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; }
.process-steps article { padding: 28px; }
.housing-faq { background: #f8fafc; }
.faq-list { display: grid; gap: 14px; }
.faq-list article { padding: 28px 32px; }
.housing-inquiry-copy { max-width: 760px; color: rgba(255,255,255,.7); line-height: 1.75; }
.housing-notices { background: white; }
.notice-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.notice-grid article { padding: 30px; border: 1px solid var(--line); border-radius: var(--radius); background: #f8fafc; }
.notice-grid span { display: inline-flex; margin-bottom: 22px; color: var(--blue); font-size: 12px; font-weight: 800; letter-spacing: .14em; }
.notice-grid h3 { margin-bottom: 14px; font: 700 25px/1.25 "Noto Sans TC", sans-serif; }
.notice-grid p, .notice-grid li { color: var(--muted); line-height: 1.72; }
.notice-grid p:last-child { margin-bottom: 0; }
.notice-grid ul { margin: 0; padding-left: 18px; }
.notice-grid li + li { margin-top: 12px; }
.housing-documents { background: white; }
.document-list { display: flex; flex-wrap: wrap; gap: 12px; }
.document-list span { padding: 13px 16px; border: 1px solid var(--line); border-radius: 999px; background: #f8fafc; color: var(--ink); font-size: 14px; font-weight: 600; }
.contact-card-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 14px; margin-top: 36px; }
.contact-card-grid article { padding: 22px; border: 1px solid rgba(255,255,255,.18); border-radius: 20px; background: rgba(255,255,255,.08); backdrop-filter: blur(10px); }
.contact-card-grid span { display: block; margin-bottom: 11px; color: #9fc4ff; font-size: 11px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.contact-card-grid strong { display: block; color: white; font-size: 16px; line-height: 1.35; word-break: break-word; }
.contact-card-grid p { margin: 10px 0 0; color: rgba(255,255,255,.64); font-size: 12px; line-height: 1.6; }

@media (max-width: 960px) {
  nav { position: fixed; inset: 68px 0 auto; display: none; padding: 30px 24px; flex-direction: column; background: var(--navy); font-size: 18px; }
  nav.open { display: flex; }
  .header-actions .button { display: none; }
  .menu-toggle { display: grid; gap: 5px; padding: 8px; border: 0; background: transparent; }
  .menu-toggle span { width: 22px; height: 1px; background: white; }
  .hero-content { width: auto; margin-right: 24px; }
  .hero-stats { left: 0; right: 0; }
  .hero-stats div { padding: 20px 16px; }
  .intro, .section-heading { grid-template-columns: 1fr; gap: 40px; }
  .hub-section, .ecosystem { grid-template-columns: 1fr; }
  .housing-hero { grid-template-columns: 1fr; padding-top: 130px; }
  .housing-hero-card img { height: 430px; }
  .housing-feature-grid, .availability-grid, .process-steps { grid-template-columns: repeat(2,1fr); }
  .notice-grid { grid-template-columns: 1fr; }
  .contact-card-grid { grid-template-columns: repeat(2,1fr); }
  .housing-life { grid-template-columns: 1fr; }
  .housing-life-grid img { height: 360px; }
  .hub-visual { min-height: 600px; }
  .ecosystem-image { min-height: 520px; }
  .facilities-grid { grid-template-rows: 430px 430px 320px 320px; }
  .facility-apartment { grid-column: 1 / span 7; grid-row: 1; }
  .facility-innovation { grid-column: 8 / span 5; grid-row: 1; }
  .facility-cafe { grid-column: 1 / span 6; grid-row: 2; }
  .facility-football { grid-column: 7 / span 6; grid-row: 2; }
  .facility-ski { grid-column: 1 / -1; grid-row: 3 / span 2; }
  .facility-ski img { object-position: center 30%; }
}

@media (max-width: 680px) {
  .site-header { height: 68px; padding: 0 18px; }
  .hero { min-height: 760px; }
  .hero-shade { background: linear-gradient(90deg, rgba(4,18,37,.94), rgba(4,18,37,.52)), linear-gradient(0deg, rgba(4,18,37,.9), transparent 55%); }
  .hero-content { padding-top: 145px; margin-left: 22px; }
  h1 { font-size: 44px; }
  .hero-lead { font-size: 16px; line-height: 1.7; }
  .hero-actions { align-items: flex-start; flex-direction: column; gap: 20px; margin-top: 30px; }
  .hero-stats { grid-template-columns: repeat(2,1fr); }
  .hero-stats div { border-top: 1px solid rgba(255,255,255,.16); }
  .hero-stats strong { font-size: 21px; }
  .section { padding: 90px 22px; }
  h2 { font-size: 36px; }
  .service-grid { grid-template-columns: 1fr; }
  .housing-hero { min-height: auto; padding: 120px 22px 80px; }
  .housing-hero-card img { height: 300px; }
  .housing-feature-grid, .availability-grid, .process-steps, .housing-life-grid { grid-template-columns: 1fr; }
  .contact-card-grid { grid-template-columns: 1fr; }
  .document-list { align-items: flex-start; flex-direction: column; }
  .document-list span { border-radius: 16px; }
  .housing-life { padding: 0 22px 90px; }
  .housing-life-copy { padding: 34px; }
  .housing-life-grid img { height: 300px; }
  .service-card { min-height: 430px; }
  .service-card div { padding: 28px; }
  .hub-visual { min-height: 520px; }
  .orbit-one { width: 280px; height: 280px; }
  .orbit-two { width: 450px; height: 450px; }
  .hub-node { width: 82px; height: 82px; font-size: 11px; }
  .hub-center { width: 112px; height: 112px; }
  .hub-center strong { font-size: 30px; }
  .hub-copy, .ecosystem-panel { padding: 80px 22px; }
  .ecosystem-image { min-height: 400px; }
  .facilities-heading { margin-bottom: 38px; }
  .facilities-grid { display: flex; flex-direction: column; gap: 14px; }
  .facility-card { aspect-ratio: 4 / 5; }
  .facility-apartment, .facility-cafe, .facility-football { aspect-ratio: 4 / 3; }
  .facility-overlay { padding: 25px; }
  .facility-overlay h3 { font-size: 22px; }
  .facility-overlay > p:last-child { font-size: 13px; }
  .facility-apartment img { object-position: center; }
  .facility-innovation img { object-position: center 36%; }
  .facility-ski img { object-position: center 25%; }
  .partnership-list a { grid-template-columns: 42px 1fr auto; }
  .contact { padding: 90px 22px; }
  footer { align-items: flex-start; flex-direction: column; gap: 18px; }
  .footer-brand { margin: 0 0 15px; }
}

/* apartment page */
.apartment-page { background: #f8fafc; }
.apartment-hero { min-height: 860px; padding: 160px clamp(24px, 8vw, 130px) 90px; display: grid; grid-template-columns: 1fr .82fr; gap: 6vw; align-items: center; background: radial-gradient(circle at 90% 12%, rgba(47,124,246,.36), transparent 34%), linear-gradient(135deg, var(--navy), #0b4482); color: white; overflow: hidden; }
.apartment-hero-copy h1 { max-width: 860px; }
.apartment-hero-copy h2 { margin: -8px 0 22px; color: #a9ccff; font-size: clamp(22px, 2.3vw, 34px); letter-spacing: -.02em; }
.apartment-hero-media { overflow: hidden; border-radius: 34px; background: rgba(255,255,255,.1); box-shadow: 0 36px 90px rgba(0,0,0,.28); }
.apartment-hero-media img { height: 540px; object-fit: cover; object-position: center; }
.presale-benefits, .apartment-location { background: white; }
.benefit-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 18px; }
.benefit-grid article { padding: 34px; border-radius: var(--radius); background: linear-gradient(135deg, var(--navy), #0b4482); color: white; }
.benefit-grid span, .transport-grid span { display: inline-flex; margin-bottom: 22px; color: #9fc4ff; font-size: 12px; font-weight: 800; letter-spacing: .14em; }
.benefit-grid h3 { font: 700 clamp(26px, 2.6vw, 42px)/1.14 "Noto Sans SC", sans-serif; }
.benefit-grid p { margin-bottom: 0; color: rgba(255,255,255,.72); line-height: 1.75; }
.apartment-rooms { background: var(--ice); }
.room-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 20px; }
.apartment-room-card { overflow: hidden; border-radius: var(--radius); background: white; border: 1px solid var(--line); box-shadow: 0 22px 60px rgba(7,27,53,.08); }
.room-cover-link { display: block; background: var(--navy); }
.room-cover { aspect-ratio: 4 / 3; height: auto; object-fit: cover; transition: transform .45s ease; }
.room-cover-link:hover .room-cover { transform: scale(1.025); }
.room-card-body { padding: 24px; }
.room-card-topline { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.room-card-topline span { padding: 7px 10px; border-radius: 999px; background: #eef5ff; color: var(--blue); font-size: 11px; font-weight: 700; }
.apartment-room-card h3 { margin-bottom: 10px; font: 700 24px/1.25 "Noto Sans SC", sans-serif; }
.room-highlight { margin-bottom: 18px; color: var(--blue); font-weight: 700; }
.room-price-grid { display: grid; grid-template-columns: 1fr 1.2fr 1fr; gap: 10px; margin-bottom: 16px; }
.room-price-grid div { padding: 12px; border-radius: 16px; background: #f7f9fc; }
.room-price-grid span { display: block; margin-bottom: 5px; color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .08em; }
.room-price-grid strong { font-size: 17px; color: var(--ink); }
.room-price-grid del { color: #8491a3; }
.room-price-grid .presale-price { background: #eaf2ff; border: 1px solid rgba(47,124,246,.25); }
.room-price-grid .presale-price strong { color: var(--blue); font-size: 21px; }
.per-bed-note, .room-note { padding: 12px 14px; border-radius: 16px; background: #fff8e7; color: #8a5a00; font-size: 13px; line-height: 1.55; }
.room-description { color: var(--muted); line-height: 1.75; }
.room-video { width: 100%; margin-top: 18px; border-radius: 18px; background: #071b35; aspect-ratio: 16 / 9; }
.transport-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.transport-grid article, .nearby-grid article, .booking-note-grid article { padding: 28px; border: 1px solid var(--line); border-radius: var(--radius); background: #f8fafc; }
.transport-grid p, .nearby-grid p, .booking-note-grid p { margin-bottom: 0; color: var(--muted); line-height: 1.75; }
.nearby-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 18px; margin-top: 18px; }
.booking-notes { background: white; }
.booking-note-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.booking-note-grid h3 { font: 700 24px/1.25 "Noto Sans SC", sans-serif; }
.apartment-cta-copy { max-width: 760px; color: rgba(255,255,255,.72); line-height: 1.75; }
.apartment-cta-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 26px; margin-top: 32px; }
.apartment-contact-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; margin-top: 34px; }
.apartment-contact-grid article { padding: 20px; border: 1px solid rgba(255,255,255,.18); border-radius: 20px; background: rgba(255,255,255,.08); }
.apartment-contact-grid span { display: block; margin-bottom: 8px; color: #9fc4ff; font-size: 11px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.apartment-contact-grid strong { color: white; font-size: 16px; word-break: break-word; }
@media (max-width: 1080px) {
  .apartment-hero, .room-grid { grid-template-columns: 1fr 1fr; }
  .booking-note-grid, .transport-grid { grid-template-columns: 1fr; }
}
@media (max-width: 680px) {
  .apartment-hero { min-height: auto; grid-template-columns: 1fr; padding: 120px 22px 80px; }
  .apartment-hero-media img { height: 300px; }
  .benefit-grid, .room-grid, .nearby-grid { grid-template-columns: 1fr; }
  .apartment-contact-grid { grid-template-columns: 1fr; }
  .room-price-grid { grid-template-columns: 1fr; }
}
