  :root {
    --bg:    #0e0e0c;
    --bg2:   #141412;
    --line:  #252520;
    --white: #f0efe8;
    --muted: #4a4a44;
    --dim:   #2a2a26;
    --accent:#666660;
  }
  * { margin:0; padding:0; box-sizing:border-box; }
  body { font-family:'Helvetica Neue',Helvetica,Arial,sans-serif; background:var(--bg); color:var(--white); }

  /* ── NAV ── */
  .nav { display:flex; align-items:center; justify-content:space-between; padding:20px 40px; border-bottom:0.5px solid var(--line); position:sticky; top:0; background:var(--bg); z-index:200; }
  .nav-logo { font-size:10px; font-weight:300; letter-spacing:0.26em; text-transform:uppercase; color:var(--white); text-decoration:none; }
  .nav-links { display:flex; gap:28px; }
  .nav-link { font-size:9px; font-weight:300; letter-spacing:0.22em; text-transform:uppercase; color:var(--muted); text-decoration:none; padding-bottom:2px; border-bottom:0.5px solid transparent; transition:all 0.2s; }
  .nav-link:hover, .nav-link.active { color:var(--white); border-color:var(--white); }

  /* ── BACK ── */
  .back { display:inline-block; padding:20px 40px 0; font-size:9px; font-weight:300; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); text-decoration:none; transition:color 0.2s; }
  .back:hover { color:var(--white); }

  /* ── HERO ── */
  .hero-img { width:100%; height:85vh; overflow:hidden; position:relative; margin-top:18px; }
  .hero-img img { width:100%; height:100%; object-fit:cover; object-position:center 50%; display:block; }
  .hero-overlay { position:absolute; bottom:0; left:0; right:0; padding:40px 48px; background:linear-gradient(transparent, rgba(14,14,12,0.9)); pointer-events:none; }
  .hero-title { font-size:36px; font-weight:300; color:var(--white); letter-spacing:0.04em; margin-bottom:10px; }
  .hero-meta { display:flex; gap:12px; align-items:center; }
  .hero-type { font-size:9px; color:var(--muted); letter-spacing:0.22em; text-transform:uppercase; }
  .hero-dot { width:2px; height:2px; background:var(--muted); border-radius:50%; }

  /* ── TEXT AREA ── */
  .intro { max-width:640px; padding:80px 60px; margin:0; }
  .desc-zh { font-size:15px; line-height:2.1; color:#c8c7c0; margin-bottom:28px; }
  .desc-en { font-size:13px; line-height:1.9; color:#8a8a82; font-style:italic; }

  /* Floor plan */
  .plan { padding:40px 60px; max-width:640px; }
  .plan-label { font-size:8px; letter-spacing:0.28em; text-transform:uppercase; color:var(--muted); margin-bottom:14px; }
  .plan img { width:100%; height:auto; display:block; }

  /* ── PHOTO AREA ── */
  .photos { width:100%; padding: 0 50px; }

  .p-full img { width:100%; height:auto; display:block; }

  .p-2col { display:grid; grid-template-columns:1fr 1fr; gap:3px; }
  .p-cell { position:relative; }
  .p-cell img { width:100%; height:auto; display:block; }

  .p-asymm { display:grid; grid-template-columns:1fr 1fr; gap:3px; align-items:stretch; }
  .p-asymm-left img { width:100%; height:100%; object-fit:cover; display:block; }
  .p-asymm-right { display:flex; flex-direction:column; gap:3px; }
  .p-asymm-right .p-cell { flex:1; }
  .p-asymm-right .p-cell img { width:100%; height:100%; object-fit:cover; display:block; }

  /* 雜誌文字段落 */
  .editorial { max-width:640px; padding:64px 60px; }
  .editorial p { font-size:13px; font-weight:300; color:#8a8a82; line-height:2.1; }
  .editorial p + p { margin-top:20px; }

  .gap-row { height:3px; background:var(--bg); }

  /* ── THUMBNAIL STRIP ── */
  .thumb-label { font-size:8px; font-weight:300; letter-spacing:0.28em; text-transform:uppercase; color:var(--muted); padding:32px 40px 12px; }
  .thumb-strip { display:flex; overflow-x:auto; gap:4px; padding:4px 0 32px; scrollbar-width:none; }
  .thumb-strip::-webkit-scrollbar { display:none; }
  .thumb { flex-shrink:0; width:120px; height:80px; overflow:hidden; cursor:pointer; opacity:0.6; transition:opacity 0.2s; }
  .thumb:hover { opacity:1; }
  .thumb img { width:100%; height:100%; object-fit:cover; display:block; }

  /* ── LIGHTBOX ── */
  .lightbox { position:fixed; inset:0; background:rgba(0,0,0,0.95); z-index:1000; display:flex; align-items:center; justify-content:center; }
  #lb-img { max-width:90vw; max-height:90vh; object-fit:contain; }
  .lb-close { position:absolute; top:24px; right:32px; font-size:32px; color:var(--white); cursor:pointer; font-weight:300; line-height:1; user-select:none; }
  .lb-prev, .lb-next { position:absolute; top:50%; transform:translateY(-50%); font-size:48px; color:var(--white); cursor:pointer; font-weight:300; padding:0 24px; opacity:0.5; transition:opacity 0.2s; user-select:none; line-height:1; }
  .lb-prev { left:0; } .lb-next { right:0; }
  .lb-prev:hover, .lb-next:hover { opacity:1; }

  /* ── BOTTOM ── */
  .bottom { padding:28px 40px; border-top:0.5px solid var(--line); display:flex; justify-content:space-between; align-items:center; margin-top:16px; }
  .bottom-nav { font-size:9px; font-weight:300; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted); text-decoration:none; transition:color 0.2s; }
  .bottom-nav:hover { color:var(--white); }
  .bowerbird { font-size:9px; font-weight:300; letter-spacing:0.22em; text-transform:uppercase; color:var(--muted); text-decoration:none; border:0.5px solid var(--line); padding:10px 20px; transition:all 0.2s; }
  .bowerbird:hover { color:var(--white); border-color:var(--accent); }

  /* ── RWD ── */
  @media (max-width: 768px) {
    .intro { padding:48px 24px; max-width:100%; }
    .plan { padding:24px 24px 40px; max-width:100%; }
    .desc-zh { font-size:14px; }
    .desc-en { font-size:12px; }
    .p-2col { grid-template-columns:1fr; }
    .p-asymm { grid-template-columns:1fr; }
    .p-asymm-left { display:none; }
    .editorial { padding:40px 24px; max-width:100%; }
    .thumb { width:90px; height:60px; }
    .thumb-label { padding:24px 20px 10px; }
    .hero-img { height:60vh; }
    .nav { padding:16px 20px; }
    .back { padding:16px 20px 0; }
    .bottom { padding:20px 20px; }
  }
.ed-zh { font-size:13px; font-weight:300; color:#8a8a82; line-height:2.1; margin-bottom:16px; }
.ed-en { font-size:12px; font-weight:300; color:#6a6a62; line-height:2.0; font-style:italic; }
