:root {
  --ink: #17120f;
  --ink-soft: #2b221d;
  --cream: #f5efe7;
  --cream-2: #ebe1d5;
  --paper: #faf7f2;
  --gold: #c79e60;
  --gold-light: #e5c995;
  --muted: #82756b;
  --line: rgba(23,18,15,.14);
  --shadow: 0 28px 80px rgba(25, 18, 13, .18);
  --serif: "Songti SC", "STSong", "Noto Serif SC", "Times New Roman", serif;
  --sans: "PingFang SC", "Microsoft YaHei", "Noto Sans SC", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; background: var(--ink); }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: var(--sans); overflow-x: hidden; }
body.menu-open, body.lightbox-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button { color: inherit; font: inherit; }
img { display: block; width: 100%; }
::selection { background: var(--gold); color: #fff; }

.page-progress { position: fixed; z-index: 200; left: 0; top: 0; width: 100%; height: 2px; background: transparent; }
.page-progress span { display: block; height: 100%; width: 0; background: linear-gradient(90deg, var(--gold), var(--gold-light)); }
.film-grain { position: fixed; inset: 0; z-index: 180; pointer-events: none; opacity: .035; background-image: url("assets/icons/noise.svg"); mix-blend-mode: multiply; }

.preloader { position: fixed; z-index: 300; inset: 0; display: grid; place-items: center; background: var(--ink); color: var(--cream); transition: opacity .7s ease, visibility .7s ease; }
.preloader.hidden { opacity: 0; visibility: hidden; }
.preloader__inner { width: min(320px, 72vw); text-align: center; }
.preloader__mark { font-family: var(--serif); font-size: clamp(44px, 10vw, 78px); letter-spacing: .12em; margin-left: .12em; }
.preloader__line { height: 1px; background: rgba(255,255,255,.18); margin: 24px 0 14px; overflow: hidden; }
.preloader__line span { display: block; width: 35%; height: 100%; background: var(--gold-light); animation: loadLine 1.3s ease-in-out infinite; }
.preloader p { font-size: 10px; letter-spacing: .28em; color: rgba(255,255,255,.52); }
@keyframes loadLine { 0%{ transform: translateX(-120%);} 100%{transform: translateX(380%);} }

.site-header { position: fixed; z-index: 120; top: 0; left: 0; width: 100%; min-height: 86px; padding: 0 clamp(22px, 4.5vw, 74px); display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; color: #fff; border-bottom: 1px solid rgba(255,255,255,.13); transition: background .4s ease, min-height .4s ease, color .4s ease, border-color .4s ease; }
.site-header.scrolled { min-height: 68px; background: rgba(250,247,242,.9); color: var(--ink); backdrop-filter: blur(18px); border-color: var(--line); }
.brand { justify-self: start; display: inline-flex; flex-direction: column; gap: 2px; }
.brand__cn { font-family: var(--serif); font-size: 22px; letter-spacing: .16em; }
.brand__en { font-size: 8px; letter-spacing: .28em; opacity: .62; }
.desktop-nav { display: flex; gap: clamp(20px, 2.8vw, 48px); font-size: 13px; letter-spacing: .12em; }
.desktop-nav a { position: relative; padding: 12px 0; }
.desktop-nav a::after { content: ""; position: absolute; left: 50%; bottom: 4px; width: 0; height: 1px; background: currentColor; transform: translateX(-50%); transition: width .25s ease; }
.desktop-nav a:hover::after { width: 100%; }
.header-call { justify-self: end; display: flex; flex-direction: column; text-align: right; gap: 2px; }
.header-call span { font-size: 9px; letter-spacing: .18em; opacity: .62; }
.header-call strong { font-size: 13px; letter-spacing: .08em; font-weight: 500; }
.menu-toggle { display: none; justify-self: end; width: 42px; height: 42px; border: 0; background: transparent; padding: 10px; cursor: pointer; }
.menu-toggle span { display: block; height: 1px; background: currentColor; margin: 7px 0; transition: transform .3s ease; }
.menu-toggle.active span:first-child { transform: translateY(4px) rotate(45deg); }
.menu-toggle.active span:last-child { transform: translateY(-4px) rotate(-45deg); }
.mobile-menu { position: fixed; z-index: 110; inset: 0; padding: 120px 30px 50px; background: rgba(23,18,15,.98); color: #fff; display: flex; flex-direction: column; justify-content: space-between; transform: translateY(-105%); transition: transform .55s cubic-bezier(.77,0,.18,1); }
.mobile-menu.open { transform: translateY(0); }
.mobile-menu nav { display: grid; gap: 8px; }
.mobile-menu nav a { font-family: var(--serif); font-size: clamp(32px, 10vw, 54px); padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,.14); }
.mobile-menu__call { font-size: 13px; letter-spacing: .12em; color: var(--gold-light); }

.hero { position: relative; min-height: 100svh; display: grid; align-items: end; color: #fff; background: var(--ink); overflow: hidden; }
.hero__media { position: absolute; inset: 0; }
.hero__media img { height: 100%; object-fit: cover; object-position: 58% 43%; transform: scale(1.06); animation: heroDrift 18s ease-in-out infinite alternate; will-change: transform; }
@keyframes heroDrift { from{transform: scale(1.06) translate3d(0,0,0)} to{transform: scale(1.13) translate3d(-1.5%, -1%, 0)} }
.hero__shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(12,9,7,.88) 0%, rgba(12,9,7,.62) 36%, rgba(12,9,7,.2) 70%, rgba(12,9,7,.38) 100%), linear-gradient(0deg, rgba(12,9,7,.72) 0%, transparent 44%); }
.hero__content { position: relative; z-index: 2; width: min(860px, 86vw); margin: 0 0 clamp(110px, 16vh, 175px) clamp(24px, 8vw, 135px); }
.eyebrow, .kicker { margin: 0 0 20px; font-size: 10px; letter-spacing: .28em; text-transform: uppercase; }
.hero__title { margin: 0; font-family: var(--serif); font-weight: 400; font-size: clamp(58px, 8.8vw, 142px); line-height: .92; letter-spacing: .02em; }
.hero__title span { display: block; }
.hero__title span:last-child { margin-left: clamp(0px, 7vw, 110px); color: var(--gold-light); }
.hero__intro { width: min(560px, 88vw); margin: 34px 0 0 clamp(0px, 7vw, 110px); font-size: clamp(14px, 1.35vw, 18px); line-height: 1.9; color: rgba(255,255,255,.72); }
.hero__actions { margin: 34px 0 0 clamp(0px, 7vw, 110px); display: flex; gap: 12px; flex-wrap: wrap; }
.button { min-height: 50px; padding: 0 24px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid transparent; cursor: pointer; font-size: 12px; letter-spacing: .14em; transition: transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease; }
.button:hover { transform: translateY(-2px); }
.button--gold { background: var(--gold); color: #fff; }
.button--gold:hover { background: var(--gold-light); color: var(--ink); }
.button--ghost { color: inherit; border-color: rgba(255,255,255,.42); background: rgba(255,255,255,.04); }
.button--ghost:hover { border-color: #fff; background: rgba(255,255,255,.1); }
.hero__meta { position: absolute; z-index: 3; right: clamp(22px, 4.5vw, 74px); bottom: 48px; display: flex; gap: 44px; }
.hero__meta div { display: flex; flex-direction: column; gap: 4px; }
.hero__meta span { font-size: 9px; letter-spacing: .18em; color: rgba(255,255,255,.48); }
.hero__meta strong { font-size: 12px; letter-spacing: .08em; font-weight: 500; }
.scroll-cue { position: absolute; z-index: 3; left: clamp(24px, 3.8vw, 66px); bottom: 38px; display: flex; flex-direction: column; align-items: center; gap: 10px; font-size: 8px; letter-spacing: .24em; color: rgba(255,255,255,.65); writing-mode: vertical-rl; }
.scroll-cue i { width: 1px; height: 52px; display: block; background: rgba(255,255,255,.28); position: relative; overflow: hidden; }
.scroll-cue i::after { content: ""; position: absolute; inset: 0; background: #fff; transform: translateY(-100%); animation: scrollCue 2s ease-in-out infinite; }
@keyframes scrollCue { 0%{transform: translateY(-100%)} 60%,100%{transform: translateY(100%)} }

.reveal { opacity: 0; transform: translateY(24px); animation: heroReveal .85s .4s forwards; }
.reveal--delay { animation-delay: .55s; }
.reveal--delay-2 { animation-delay: .72s; }
.reveal--delay-3 { animation-delay: .9s; }
@keyframes heroReveal { to { opacity: 1; transform: none; } }

.ticker { overflow: hidden; background: var(--ink); color: var(--cream-2); border-top: 1px solid rgba(255,255,255,.08); border-bottom: 1px solid rgba(255,255,255,.08); }
.ticker__track { min-width: max-content; display: flex; align-items: center; gap: 28px; padding: 19px 0; animation: ticker 28s linear infinite; }
.ticker span { font-family: var(--serif); font-size: 16px; letter-spacing: .18em; }
.ticker i { width: 4px; height: 4px; background: var(--gold); border-radius: 50%; }
@keyframes ticker { to { transform: translateX(-50%); } }

.section { position: relative; padding: clamp(90px, 12vw, 170px) clamp(22px, 7vw, 112px); }
.section-number { position: absolute; top: 75px; left: 20px; writing-mode: vertical-rl; font-family: var(--serif); color: rgba(23,18,15,.24); font-size: 12px; letter-spacing: .25em; }
.kicker { color: var(--gold); }
.section h2 { margin: 0; font-family: var(--serif); font-weight: 400; font-size: clamp(38px, 5.4vw, 82px); line-height: 1.08; letter-spacing: .01em; }
.section-heading { display: grid; grid-template-columns: 1.15fr .85fr; gap: clamp(36px, 8vw, 140px); align-items: end; margin-bottom: clamp(48px, 7vw, 90px); }
.section-heading > p, .works__header > p { margin: 0; color: var(--muted); line-height: 2; max-width: 520px; }
.reveal-on-scroll { opacity: 0; transform: translateY(34px); transition: opacity .85s ease, transform .85s cubic-bezier(.2,.8,.2,1); }
.reveal-on-scroll.is-visible { opacity: 1; transform: none; }

.intro { display: grid; grid-template-columns: .88fr 1.12fr; gap: clamp(54px, 9vw, 150px); align-items: center; background: var(--paper); }
.intro__copy > p:not(.kicker) { margin: 34px 0; max-width: 570px; color: var(--muted); line-height: 2.05; }
.signature { margin-top: 42px; display: inline-flex; flex-direction: column; gap: 6px; padding-top: 18px; border-top: 1px solid var(--line); }
.signature span { font-family: var(--serif); font-size: 22px; letter-spacing: .18em; }
.signature small { color: var(--muted); letter-spacing: .12em; }
.intro__visual { margin: 0; position: relative; box-shadow: var(--shadow); overflow: hidden; }
.intro__visual img { aspect-ratio: 1.17; object-fit: cover; transition: transform 1.1s ease; }
.intro__visual:hover img { transform: scale(1.035); }
.intro__visual figcaption { position: absolute; left: 0; bottom: 0; width: 100%; padding: 24px; color: #fff; background: linear-gradient(0deg, rgba(15,11,9,.8), transparent); display: flex; justify-content: space-between; align-items: end; }
.intro__visual figcaption span { font-size: 9px; letter-spacing: .2em; opacity: .64; }
.intro__visual figcaption strong { font-family: var(--serif); font-weight: 400; letter-spacing: .08em; }

.services { background: var(--cream); }
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.service-card { position: relative; min-height: 350px; padding: clamp(28px, 3.5vw, 52px); border: 0; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: transparent; text-align: left; overflow: hidden; transition: background .45s ease, color .45s ease; }
.service-card::before { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, var(--ink), var(--ink-soft)); transform: translateY(102%); transition: transform .55s cubic-bezier(.2,.8,.2,1); }
.service-card:hover, .service-card:focus-visible { color: #fff; outline: none; }
.service-card:hover::before, .service-card:focus-visible::before { transform: translateY(0); }
.service-card > * { position: relative; z-index: 1; }
.service-card__no { display: block; font-size: 10px; letter-spacing: .18em; color: var(--gold); }
.service-card__icon { margin: 46px 0 34px; font-family: var(--serif); font-size: 44px; color: var(--gold); }
.service-card h3 { margin: 0 0 16px; font-family: var(--serif); font-size: 26px; font-weight: 400; }
.service-card p { margin: 0; color: var(--muted); line-height: 1.9; font-size: 14px; transition: color .4s ease; }
.service-card:hover p, .service-card:focus-visible p { color: rgba(255,255,255,.66); }
.service-card small { position: absolute; left: clamp(28px, 3.5vw, 52px); bottom: 28px; letter-spacing: .16em; font-size: 8px; opacity: .55; }

.works { background: var(--ink); color: var(--cream); }
.works__header { display: grid; grid-template-columns: 1.15fr .85fr; gap: clamp(36px, 8vw, 140px); align-items: end; margin-bottom: clamp(50px, 8vw, 100px); }
.works__header > p { color: rgba(255,255,255,.5); }
.gallery { display: grid; grid-template-columns: repeat(12, 1fr); grid-auto-rows: 130px; gap: 14px; }
.gallery-card { position: relative; grid-column: span 4; grid-row: span 4; padding: 0; border: 0; background: #211a16; overflow: hidden; cursor: zoom-in; text-align: left; color: #fff; }
.gallery-card--tall { grid-row: span 6; }
.gallery-card--wide { grid-column: span 8; grid-row: span 5; }
.gallery-card img { height: 100%; object-fit: cover; transition: transform 1s cubic-bezier(.2,.8,.2,1), filter .5s ease; }
.gallery-card:hover img { transform: scale(1.045); filter: brightness(.78); }
.gallery-card span { position: absolute; inset: auto 0 0 0; padding: 28px; display: flex; flex-direction: column; gap: 7px; background: linear-gradient(0deg, rgba(8,6,5,.82), transparent); transform: translateY(8px); transition: transform .35s ease; }
.gallery-card:hover span { transform: none; }
.gallery-card small { font-size: 8px; letter-spacing: .2em; color: var(--gold-light); }
.gallery-card strong { font-family: var(--serif); font-weight: 400; font-size: 20px; letter-spacing: .08em; }

.craft { display: grid; grid-template-columns: 1.08fr .92fr; gap: clamp(50px, 8vw, 130px); align-items: center; background: var(--paper); }
.craft__image { overflow: hidden; box-shadow: var(--shadow); }
.craft__image img { aspect-ratio: 1/1.12; object-fit: cover; object-position: 58% center; transition: transform 1s ease; }
.craft__image:hover img { transform: scale(1.04); }
.craft__content ol { list-style: none; padding: 0; margin: 54px 0 0; }
.craft__content li { display: grid; grid-template-columns: 62px 1fr; gap: 22px; padding: 28px 0; border-top: 1px solid var(--line); }
.craft__content li:last-child { border-bottom: 1px solid var(--line); }
.craft__content li > span { font-family: var(--serif); color: var(--gold); }
.craft__content h3 { margin: 0 0 8px; font-family: var(--serif); font-size: 21px; font-weight: 400; }
.craft__content li p { margin: 0; color: var(--muted); line-height: 1.85; font-size: 14px; }

.studio { background: var(--cream); }
.studio-showcase { position: relative; }
.studio-showcase__tabs { display: flex; justify-content: flex-end; gap: 10px; margin-bottom: 20px; }
.studio-showcase__tabs button { border: 1px solid var(--line); background: transparent; padding: 12px 18px; font-size: 10px; letter-spacing: .14em; cursor: pointer; transition: all .3s ease; }
.studio-showcase__tabs button.active { background: var(--ink); color: #fff; border-color: var(--ink); }
.studio-showcase__media { position: relative; min-height: min(70vw, 760px); overflow: hidden; box-shadow: var(--shadow); background: #d8cec2; }
.studio-showcase__media img { position: absolute; inset: 0; height: 100%; object-fit: cover; opacity: 0; transform: scale(1.04); transition: opacity .7s ease, transform 1.2s ease; }
.studio-showcase__media img.active { opacity: 1; transform: scale(1); }
.studio-showcase__media img[data-store-image="night"] { object-position: center 46%; }
.studio-showcase__caption { position: absolute; z-index: 2; left: 30px; right: 30px; bottom: 28px; padding: 24px 0 0; border-top: 1px solid rgba(255,255,255,.45); color: #fff; display: flex; justify-content: space-between; text-shadow: 0 2px 18px rgba(0,0,0,.45); }
.studio-showcase__caption span { font-family: var(--serif); font-size: 24px; letter-spacing: .12em; }
.studio-showcase__caption strong { align-self: end; font-weight: 400; font-size: 12px; letter-spacing: .12em; }

.booking { position: relative; min-height: 86svh; display: flex; align-items: center; color: #fff; overflow: hidden; }
.booking__media, .booking__overlay { position: absolute; inset: 0; }
.booking__media img { height: 100%; object-fit: cover; object-position: center 35%; transform: scale(1.03); }
.booking__overlay { background: linear-gradient(90deg, rgba(18,13,10,.94) 0%, rgba(18,13,10,.78) 46%, rgba(18,13,10,.34) 100%), linear-gradient(0deg, rgba(18,13,10,.5), transparent); }
.booking__content { position: relative; z-index: 2; width: min(780px, 88vw); margin-left: clamp(24px, 9vw, 150px); padding: 100px 0; }
.booking__content > p:not(.kicker) { max-width: 570px; color: rgba(255,255,255,.66); line-height: 2; margin: 30px 0 42px; }
.booking__details { display: grid; grid-template-columns: repeat(3, 1fr); max-width: 800px; border-top: 1px solid rgba(255,255,255,.2); border-bottom: 1px solid rgba(255,255,255,.2); }
.booking__details div { padding: 24px 20px 24px 0; display: flex; flex-direction: column; gap: 8px; }
.booking__details span { font-size: 9px; letter-spacing: .16em; color: var(--gold-light); }
.booking__details a, .booking__details strong { font-size: 13px; font-weight: 400; letter-spacing: .05em; }
.booking__actions { margin-top: 34px; display: flex; gap: 12px; flex-wrap: wrap; }

.faq { display: grid; grid-template-columns: .8fr 1.2fr; gap: clamp(54px, 9vw, 150px); align-items: start; background: var(--paper); }
.faq__title { position: sticky; top: 110px; }
.faq__list details { border-top: 1px solid var(--line); }
.faq__list details:last-child { border-bottom: 1px solid var(--line); }
.faq__list summary { list-style: none; display: flex; justify-content: space-between; gap: 20px; align-items: center; padding: 28px 0; cursor: pointer; font-family: var(--serif); font-size: 19px; }
.faq__list summary::-webkit-details-marker { display: none; }
.faq__list summary span { font-family: var(--sans); font-weight: 300; color: var(--gold); transition: transform .3s ease; }
.faq__list details[open] summary span { transform: rotate(45deg); }
.faq__list details p { margin: -4px 50px 28px 0; color: var(--muted); line-height: 1.9; font-size: 14px; }

.site-footer { background: var(--ink); color: #fff; padding: 70px clamp(22px, 7vw, 112px) 34px; display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 50px; }
.site-footer__brand { display: flex; flex-direction: column; gap: 7px; }
.site-footer__brand strong { font-family: var(--serif); font-size: 30px; font-weight: 400; letter-spacing: .18em; }
.site-footer__brand span { font-size: 8px; letter-spacing: .26em; color: rgba(255,255,255,.45); }
.site-footer__links { display: grid; grid-template-columns: repeat(2, max-content); gap: 14px 30px; font-size: 12px; color: rgba(255,255,255,.68); }
.site-footer__contact { display: flex; flex-direction: column; align-items: flex-end; gap: 9px; }
.site-footer__contact a { font-family: var(--serif); font-size: 24px; letter-spacing: .08em; color: var(--gold-light); }
.site-footer__contact span { font-size: 10px; letter-spacing: .12em; color: rgba(255,255,255,.5); }
.site-footer__bottom { grid-column: 1 / -1; padding-top: 32px; border-top: 1px solid rgba(255,255,255,.12); display: flex; justify-content: space-between; color: rgba(255,255,255,.38); font-size: 9px; letter-spacing: .12em; }

.mobile-booking-bar { display: none; }
.lightbox { position: fixed; z-index: 250; inset: 0; padding: 34px; background: rgba(12,9,7,.96); display: grid; place-items: center; opacity: 0; visibility: hidden; transition: opacity .35s ease, visibility .35s ease; }
.lightbox.open { opacity: 1; visibility: visible; }
.lightbox img { max-width: min(1100px, 88vw); max-height: 82vh; width: auto; height: auto; object-fit: contain; box-shadow: 0 30px 90px rgba(0,0,0,.5); }
.lightbox p { position: absolute; left: 50%; bottom: 22px; transform: translateX(-50%); margin: 0; color: #fff; font-family: var(--serif); letter-spacing: .12em; }
.lightbox__close { position: absolute; z-index: 2; right: 26px; top: 20px; width: 46px; height: 46px; border: 1px solid rgba(255,255,255,.35); border-radius: 50%; background: transparent; color: #fff; font-size: 28px; cursor: pointer; }
.toast { position: fixed; z-index: 260; left: 50%; bottom: 30px; transform: translate(-50%, 30px); padding: 13px 18px; background: var(--ink); color: #fff; font-size: 12px; letter-spacing: .08em; opacity: 0; visibility: hidden; transition: all .35s ease; box-shadow: var(--shadow); }
.toast.show { opacity: 1; visibility: visible; transform: translate(-50%,0); }

@media (max-width: 980px) {
  .site-header { grid-template-columns: 1fr auto; min-height: 72px; }
  .desktop-nav, .header-call { display: none; }
  .menu-toggle { display: block; }
  .hero__content { margin-left: 28px; margin-bottom: 145px; width: calc(100% - 56px); }
  .hero__meta { left: 28px; right: auto; bottom: 34px; gap: 30px; }
  .scroll-cue { display: none; }
  .intro, .craft, .faq { grid-template-columns: 1fr; }
  .intro__copy { max-width: 760px; }
  .section-heading, .works__header { grid-template-columns: 1fr; align-items: start; }
  .service-grid { grid-template-columns: repeat(2, 1fr); }
  .gallery { grid-auto-rows: 110px; }
  .gallery-card { grid-column: span 6; }
  .gallery-card--wide { grid-column: span 12; }
  .craft__image { order: 2; }
  .faq__title { position: static; }
  .site-footer { grid-template-columns: 1fr 1fr; }
  .site-footer__contact { align-items: flex-start; }
}

@media (max-width: 640px) {
  body { padding-bottom: 68px; }
  .film-grain { opacity: .025; }
  .site-header { padding: 0 18px; }
  .brand__cn { font-size: 19px; }
  .hero { min-height: 92svh; }
  .hero__media img { object-position: 56% 38%; }
  .hero__shade { background: linear-gradient(90deg, rgba(12,9,7,.87), rgba(12,9,7,.24)), linear-gradient(0deg, rgba(12,9,7,.85), transparent 58%); }
  .hero__content { margin: 0 20px 156px; width: calc(100% - 40px); }
  .eyebrow { font-size: 8px; line-height: 1.7; }
  .hero__title { font-size: clamp(52px, 17vw, 78px); line-height: .96; }
  .hero__title span:last-child { margin-left: 0; margin-top: 10px; }
  .hero__intro { margin-left: 0; font-size: 13px; line-height: 1.85; }
  .hero__actions { margin-left: 0; width: 100%; }
  .hero__actions .button { flex: 1; min-width: 130px; }
  .hero__meta { left: 20px; right: 20px; bottom: 28px; justify-content: space-between; gap: 12px; }
  .hero__meta strong { font-size: 10px; }
  .ticker__track { padding: 15px 0; gap: 20px; }
  .ticker span { font-size: 13px; }
  .section { padding: 86px 20px; }
  .section-number { display: none; }
  .section h2 { font-size: clamp(36px, 11.5vw, 52px); }
  .section-heading, .works__header { margin-bottom: 46px; }
  .intro { gap: 46px; }
  .intro__copy > p:not(.kicker) { font-size: 14px; }
  .intro__visual img { aspect-ratio: 4/5; }
  .intro__visual figcaption { padding: 18px; flex-direction: column; align-items: flex-start; gap: 5px; }
  .service-grid { grid-template-columns: 1fr; }
  .service-card { min-height: 290px; padding: 28px; }
  .service-card__icon { margin: 28px 0 22px; }
  .service-card small { left: 28px; bottom: 24px; }
  .gallery { display: grid; grid-template-columns: repeat(2, 1fr); grid-auto-rows: auto; gap: 8px; }
  .gallery-card, .gallery-card--tall, .gallery-card--wide { grid-column: span 1; grid-row: auto; aspect-ratio: 3/4; }
  .gallery-card:first-child, .gallery-card--wide { grid-column: span 2; aspect-ratio: 4/5; }
  .gallery-card span { padding: 16px; }
  .gallery-card strong { font-size: 16px; }
  .craft { gap: 46px; }
  .craft__content li { grid-template-columns: 45px 1fr; gap: 14px; }
  .studio-showcase__tabs { justify-content: stretch; }
  .studio-showcase__tabs button { flex: 1; }
  .studio-showcase__media { min-height: 120vw; }
  .studio-showcase__caption { left: 18px; right: 18px; bottom: 18px; flex-direction: column; gap: 6px; }
  .booking { min-height: auto; }
  .booking__content { margin: 0 20px; width: calc(100% - 40px); padding: 100px 0; }
  .booking__details { grid-template-columns: 1fr; }
  .booking__details div { border-bottom: 1px solid rgba(255,255,255,.14); }
  .booking__details div:last-child { border-bottom: 0; }
  .booking__actions .button { width: 100%; }
  .faq__list summary { font-size: 17px; }
  .site-footer { padding: 58px 20px 32px; grid-template-columns: 1fr; gap: 38px; }
  .site-footer__links { grid-template-columns: repeat(2, 1fr); }
  .site-footer__contact { align-items: flex-start; }
  .site-footer__bottom { flex-direction: column; gap: 8px; }
  .mobile-booking-bar { position: fixed; z-index: 130; left: 0; bottom: 0; width: 100%; height: 68px; display: grid; grid-template-columns: 1fr 124px; background: rgba(250,247,242,.96); color: var(--ink); border-top: 1px solid var(--line); backdrop-filter: blur(16px); padding-bottom: env(safe-area-inset-bottom); }
  .mobile-booking-bar a:first-child { padding: 10px 16px; display: flex; flex-direction: column; justify-content: center; }
  .mobile-booking-bar span { font-size: 8px; color: var(--muted); letter-spacing: .12em; }
  .mobile-booking-bar strong { font-family: var(--serif); font-size: 17px; font-weight: 400; }
  .mobile-booking-bar a:last-child { display: grid; place-items: center; background: var(--gold); color: #fff; font-size: 12px; letter-spacing: .1em; }
  .lightbox { padding: 16px; }
  .lightbox img { max-width: 94vw; max-height: 78vh; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
}
