/* ====== Wanchun Neighborhood Park · Main Styles ====== */
/* palette: 工业混凝土 × 苔藓绿 × 锈红 × 暖米白 */

:root{
  --paper:        #f3efe6;
  --paper-2:      #ebe5d7;
  --ink:          #1c1c1a;
  --ink-soft:     #2d2c28;
  --concrete:     #8b8b85;
  --concrete-2:   #c9c5bb;
  --moss:         #4a5d3a;
  --moss-deep:    #2f3d24;
  --moss-soft:    #b6c0a0;
  --rust:         #b1502c;
  --rust-deep:    #7a3417;
  --gold:         #c9a559;
  --shadow:       rgba(28,28,26,.08);
  --line:         rgba(28,28,26,.18);
  --line-soft:    rgba(28,28,26,.08);

  --serif:      "Noto Sans SC", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
  --serif-poem: "Noto Serif SC", "Songti SC", "STSong", serif;
  --sans:    "Noto Sans SC", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
  --mono:    "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;

  --maxw: 1320px;
  --pad:  clamp(20px, 4vw, 56px);
}

*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{ scroll-behavior:smooth; }

body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  cursor:default;
}

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }

/* ============ paper grain overlay ============ */
.grain{
  position:fixed; inset:0; z-index:9999; pointer-events:none;
  opacity:.35; mix-blend-mode:multiply;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.10  0 0 0 0 0.10  0 0 0 0 0.10  0 0 0 0.55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ============ cursor glow ============ */
.cursor-glow{
  position:fixed; top:0; left:0; width:520px; height:520px;
  margin:-260px 0 0 -260px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(177,80,44,.18), rgba(177,80,44,0) 60%);
  pointer-events:none; z-index:1;
  transform:translate3d(-9999px,-9999px,0);
  transition:opacity .4s;
  mix-blend-mode:multiply;
}
@media (hover:none){ .cursor-glow{ display:none; } }

/* ============ scroll progress ============ */
.scroll-progress{
  position:fixed; left:0; top:0; height:2px; width:100%;
  background:transparent; z-index:9000;
}
.scroll-progress span{
  display:block; height:100%; width:0%;
  background:linear-gradient(90deg, var(--moss), var(--rust));
  transition:width .1s linear;
}

/* ============ nav ============ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:200;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--pad);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  background:rgba(243,239,230,.7);
  border-bottom:1px solid var(--line-soft);
}
.nav__brand{ display:flex; flex-direction:column; line-height:1.1; }
.nav__logo-img{ height:40px; width:auto; object-fit:contain; align-self:center; }
.nav__brand-cn{ font-family:var(--sans); font-size:17px; font-weight:700; letter-spacing:.18em; }
.nav__brand-en{ font-family:var(--mono); font-size:10px; letter-spacing:.22em; color:var(--concrete); margin-top:4px; }

.nav__links{ display:flex; gap:6px; }
.nav__links a{
  font-family:var(--mono); font-size:11.5px; letter-spacing:.1em;
  padding:8px 12px; border-radius:99px; position:relative;
  transition:background .25s, color .25s;
  display:flex; align-items:baseline; gap:6px;
  text-transform:uppercase;
}
.nav__links a i{ font-style:normal; color:var(--concrete); font-size:9px; }
.nav__links a:hover{ background:var(--ink); color:var(--paper); }
.nav__links a:hover i{ color:var(--gold); }

.nav__menu{ display:none; width:36px; height:36px; flex-direction:column; justify-content:center; align-items:center; gap:5px; }
.nav__menu span{ width:22px; height:1.5px; background:var(--ink); transition:transform .3s, opacity .3s; }
.nav__menu[aria-expanded="true"] span:nth-child(1){ transform:translateY(3px) rotate(45deg); }
.nav__menu[aria-expanded="true"] span:nth-child(2){ transform:translateY(-3px) rotate(-45deg); }

@media (max-width: 920px){
  .nav__links{
    position:absolute; top:100%; left:0; right:0;
    flex-direction:column; gap:0; padding:8px 12px 16px;
    background:var(--paper); border-bottom:1px solid var(--line);
    transform:translateY(-110%); opacity:0; pointer-events:none;
    transition:transform .35s, opacity .25s;
  }
  .nav__links a{ width:100%; padding:14px 12px; border-bottom:1px solid var(--line-soft); border-radius:0; }
  .nav.is-open .nav__links{ transform:translateY(0); opacity:1; pointer-events:auto; }
  .nav__menu{ display:flex; }
}

/* ============ hero ============ */
.hero{
  position:relative;
  min-height:100vh; min-height:100svh;
  padding:140px var(--pad) 80px;
  display:flex; flex-direction:column; justify-content:flex-end;
  overflow:hidden;
  isolation:isolate;
}

.hero__bg{ position:absolute; inset:0; z-index:-1; }
.hero__bg-layer{ position:absolute; inset:0; }
.hero__bg-layer--a{
  background:
    radial-gradient(ellipse 70% 60% at 80% 20%, rgba(74,93,58,.22), transparent 60%),
    radial-gradient(ellipse 80% 60% at 10% 80%, rgba(177,80,44,.16), transparent 60%);
  filter:blur(2px);
  animation: drift 28s ease-in-out infinite alternate;
}
.hero__bg-layer--b{
  background:
    radial-gradient(circle at 50% 50%, rgba(28,28,26,.08), transparent 50%);
  animation: drift 36s ease-in-out infinite alternate-reverse;
}
.hero__bg-grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(to right, var(--line-soft) 1px, transparent 1px),
    linear-gradient(to bottom, var(--line-soft) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image:radial-gradient(ellipse at center, black 30%, transparent 80%);
}
@keyframes drift{
  from{ transform:translate(0,0) scale(1); }
  to  { transform:translate(40px,-30px) scale(1.05); }
}

.hero__meta{
  display:flex; flex-wrap:wrap; gap:10px;
  margin-bottom:auto;
}
.tag{
  font-family:var(--mono); font-size:10.5px; letter-spacing:.18em;
  padding:6px 12px; border:1px solid var(--line); border-radius:99px;
  text-transform:uppercase; color:var(--ink-soft);
  background:rgba(255,255,255,.4);
}
.tag--dot::before{
  content:""; display:inline-block; width:6px; height:6px; border-radius:50%;
  background:var(--rust); margin-right:8px; vertical-align:middle;
  animation:pulse 2s infinite;
}
@keyframes pulse{
  0%,100%{ opacity:1; transform:scale(1); }
  50%   { opacity:.4; transform:scale(.7); }
}

.hero__title{
  font-family:var(--sans);
  font-weight:700;
  font-size: clamp(40px, 7.6vw, 116px);
  line-height: 1.02;
  letter-spacing:-.03em;
  margin: 28px 0 22px;
  word-break:keep-all;
  overflow-wrap:normal;
}
.hero__title span{ display:inline; }
.hero__title em{
  font-style:normal; font-weight:800;
  color:var(--moss-deep);
  position:relative;
  display:inline;
}
@media (min-width:760px){
  .hero__title{
    font-size: clamp(64px, 9vw, 144px);
    line-height:.98;
    margin: 36px 0 26px;
  }
  .hero__title > span{ display:block; }
  .hero__title em{ display:inline; }
}
.hero__title em::after{
  content:""; position:absolute; left:0; right:0; bottom:0.08em; height:.18em;
  background:var(--rust); opacity:.25; z-index:-1;
  transform-origin:left;
  animation: underline 1.6s ease 1.2s both;
}
@keyframes underline{
  from{ transform:scaleX(0); }
  to{ transform:scaleX(1); }
}

[data-reveal-chars] span{ overflow:hidden; }
[data-reveal-chars] .char{
  display:inline-block; transform:translateY(110%); opacity:0;
  animation:charIn .9s cubic-bezier(.2,.7,.2,1) both;
}
@keyframes charIn{
  to{ transform:translateY(0); opacity:1; }
}

.hero__sub{
  max-width:62ch;
  font-size: clamp(15px, 1.6vw, 18px);
  color:var(--ink-soft);
  margin: 0 0 60px;
}

.hero__foot{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:30px; flex-wrap:wrap;
}

.btn-arrow{
  display:inline-flex; flex-direction:column; gap:14px;
  font-family:var(--mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase;
}
.btn-arrow__txt{ color:var(--concrete); }
.btn-arrow:hover .btn-arrow__txt{ color:var(--ink); }
.btn-arrow__line{
  display:block; width:80px; height:1.5px; background:var(--ink);
  position:relative; overflow:hidden;
}
.btn-arrow__line::after{
  content:""; position:absolute; right:-2px; top:-3px;
  width:8px; height:8px; border-right:1.5px solid var(--ink); border-bottom:1.5px solid var(--ink);
  transform:rotate(-45deg);
}
.btn-arrow:hover .btn-arrow__line{ animation:slide 1s ease infinite; }
@keyframes slide{
  0%   { transform:translateX(-12px); }
  100% { transform:translateX(0); }
}

.hero__counter{
  display:flex; gap:36px;
}
.hero__counter > div{
  display:flex; flex-direction:column; gap:2px;
  border-left:1px solid var(--line); padding-left:14px;
}
.hero__counter b{
  font-family:var(--serif); font-size:36px; font-weight:600; line-height:1;
  color:var(--ink);
}
.hero__counter i{
  font-style:normal; font-family:var(--mono); font-size:10px; letter-spacing:.18em;
  color:var(--concrete); text-transform:uppercase;
}

/* ============ marquee ============ */
.marquee{
  border-block:1px solid var(--line);
  overflow:hidden; padding:18px 0;
  background:var(--paper-2);
}
.marquee__track{
  display:flex; gap:0;
  animation:marqueeMove 44s linear infinite;
  white-space:nowrap;
  font-family:var(--serif); font-size:22px; font-weight:500; letter-spacing:.04em;
  color:var(--ink-soft);
}
.marquee__track span{ flex-shrink:0; padding-right:40px; }
@keyframes marqueeMove{
  from{ transform:translateX(0); }
  to  { transform:translateX(-50%); }
}

/* ============ section head ============ */
.section-head{
  padding: 0 var(--pad);
  max-width: var(--maxw);
  margin: 0 auto 56px;
  position:relative;
}
.section-head__no{
  font-family:var(--mono); font-size:11px; letter-spacing:.22em;
  color:var(--rust); display:inline-block; margin-bottom:18px;
}
.section-head__title{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(34px, 5.2vw, 64px); line-height:1.05;
  margin:0 0 18px; letter-spacing:-.01em;
}
.section-head__title em{
  font-style:italic; font-weight:400;
  color:var(--concrete);
  font-size:.7em; margin-left:.3em;
}
.section-head__lead{
  max-width:60ch; color:var(--ink-soft);
  font-size:clamp(14px, 1.4vw, 17px);
}

/* ============ about ============ */
.about{ padding:120px 0 60px; }
.about__grid{
  max-width:var(--maxw); margin:0 auto; padding:0 var(--pad);
  display:grid; gap:18px;
  grid-template-columns: repeat(2, 1fr);
}
.about__card{
  border:1px solid var(--line); border-radius:6px;
  padding:32px; min-height:260px;
  background:var(--paper-2);
  display:flex; flex-direction:column; justify-content:space-between;
  transition:transform .5s, box-shadow .5s;
  position:relative; overflow:hidden;
}
.about__card::before{
  content:""; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg, var(--moss), var(--rust));
  transform:scaleX(0); transform-origin:left;
  transition:transform .8s cubic-bezier(.2,.7,.2,1);
}
.about__card.in-view::before{ transform:scaleX(1); }
.about__card:hover{ transform:translateY(-3px); box-shadow:0 18px 40px var(--shadow); }

.about__card-hd{
  display:flex; align-items:baseline; gap:10px;
  font-family:var(--mono); font-size:11px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--concrete);
}
.about__card-hd i{
  font-style:normal; font-family:var(--serif); font-size:14px;
  color:var(--rust); font-weight:600;
}
.about__card-hd span{ margin-left:auto; color:var(--ink-soft); letter-spacing:.05em; text-transform:none; font-family:var(--sans); }

.about__card-quote{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(26px, 3.2vw, 40px); line-height:1.25;
  margin:32px 0 0;
}
.about__card-quote em{ font-style:normal; color:var(--moss-deep); font-weight:700; }

.about__card--dark{
  background:var(--ink); color:var(--paper);
  border-color:var(--ink);
}
.about__card--dark .about__card-hd{ color:var(--concrete-2); }
.about__card--dark .about__card-hd i{ color:var(--gold); }
.about__card--dark .about__card-hd span{ color:var(--paper-2); }
.about__card--dark .about__card-quote em{ color:var(--moss-soft); }

.about__card--wide{
  grid-column: span 2;
  background: var(--paper);
  display:block; min-height:auto;
}
.about__card--wide p{
  font-family:var(--serif); font-size:clamp(17px, 1.7vw, 21px);
  line-height:1.7; color:var(--ink-soft); max-width:75ch;
  margin:18px 0 0;
}
.about__card--wide strong{ color:var(--rust); font-weight:600; }

@media (max-width:760px){
  .about__grid{ grid-template-columns:1fr; }
  .about__card--wide{ grid-column:auto; }
}

/* ============ vision / 三场试验 ============ */
.vision{ padding:120px 0; background:var(--paper-2); border-block:1px solid var(--line-soft); }
.vision__list{
  max-width:var(--maxw); margin:0 auto; padding:0 var(--pad);
  list-style:none;
}
.vision__item{
  display:grid;
  grid-template-columns: 120px 1fr auto;
  gap:32px; align-items:start;
  padding:42px 0;
  border-top:1px solid var(--line);
  transition: padding-left .4s;
  position:relative;
  opacity:0; transform:translateY(20px);
  transition: opacity .8s, transform .8s, padding-left .4s;
}
.vision__item:last-child{ border-bottom:1px solid var(--line); }
.vision__item.in-view{ opacity:1; transform:translateY(0); }
.vision__item:hover{ padding-left:18px; }
.vision__item:hover::before{
  content:""; position:absolute; left:0; top:50%; height:1px; width:10px;
  background:var(--rust); transform:translateY(-50%);
}
.vision__no{
  font-family:var(--serif); font-size:64px; font-weight:500;
  color:var(--rust); line-height:1;
}
.vision__item h3{
  font-family:var(--serif); font-size:clamp(22px, 2.4vw, 32px);
  font-weight:600; margin:0 0 8px;
}
.vision__item p{
  margin:0; color:var(--ink-soft); max-width:60ch;
  font-size:clamp(14px, 1.3vw, 16px);
}
.vision__tag{
  font-family:var(--mono); font-size:10.5px; letter-spacing:.22em;
  color:var(--concrete); font-style:normal; align-self:end;
  text-transform:uppercase;
}
@media (max-width:760px){
  .vision__item{ grid-template-columns: auto 1fr; gap:16px; }
  .vision__tag{ display:none; }
}

/* ============ origin / 起源 ============ */
.origin{
  background:var(--ink); color:var(--paper);
  padding: clamp(120px, 18vw, 220px) var(--pad);
  position:relative; overflow:hidden;
}
.origin::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(circle at 20% 30%, rgba(74,93,58,.35), transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(177,80,44,.25), transparent 55%);
  filter:blur(40px);
  animation: drift 24s ease-in-out infinite alternate;
}
.origin__inner{ position:relative; max-width:var(--maxw); margin:0 auto; text-align:center; }
.origin__label{
  font-family:var(--mono); font-size:11px; letter-spacing:.3em;
  color:var(--concrete); text-transform:uppercase;
}
.origin__poem{
  font-family:var(--serif-poem); font-weight:400;
  font-size:clamp(36px, 6.5vw, 88px); line-height:1.5;
  margin: 38px 0 28px;
  letter-spacing:.05em;
}
.origin__poem span{
  display:inline-block;
  opacity:0; transform:translateY(20px) rotate(-3deg);
  transition: opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1);
}
.origin.in-view .origin__poem span{
  opacity:1; transform:translateY(0) rotate(0);
}
.origin.in-view .origin__poem span{ transition-delay: calc(var(--i, 0) * 80ms); }

.origin__cite{
  font-style:normal; font-family:var(--mono); font-size:12px; letter-spacing:.18em;
  color:var(--concrete);
}
.origin__interp{
  margin: 60px auto 0; max-width:60ch;
  font-family:var(--sans); font-style:normal; font-weight:300;
  font-size:clamp(16px, 1.6vw, 20px); line-height:1.7;
  color:var(--paper-2);
}
.origin__note{
  margin: 36px auto 0; max-width:60ch;
  font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--concrete);
}

/* ============ renewal / before-after ============ */
.renewal{ padding:120px 0; }
.ba{
  position:relative;
  max-width:var(--maxw); margin:0 auto;
  width:calc(100% - var(--pad)*2);
  aspect-ratio: 16/9;
  border-radius:6px; overflow:hidden;
  border:1px solid var(--line);
  user-select:none;
  background:var(--ink);
  cursor: ew-resize;
}
.ba__before, .ba__after{ position:absolute; inset:0; }
.ba__after{
  clip-path: inset(0 0 0 50%);
  will-change: clip-path;
}
.ba__art{ position:absolute; inset:0; }

.ba__art--before{
  background:
    repeating-linear-gradient(135deg, rgba(0,0,0,.18) 0 4px, transparent 4px 18px),
    radial-gradient(ellipse at 30% 80%, rgba(177,80,44,.4), transparent 60%),
    linear-gradient(160deg, #4a463e, #2a2722 70%);
  filter: contrast(.95) saturate(.7);
}
.ba__art--before::after{
  content:"旧 · 封 头 厂"; position:absolute; bottom:30px; left:30px;
  font-family:var(--serif); font-size:clamp(28px, 4vw, 56px); font-weight:600;
  color:rgba(243,239,230,.55); letter-spacing:.1em;
}
.ba__art--after{
  background:
    radial-gradient(circle at 70% 30%, rgba(255,255,255,.18), transparent 50%),
    radial-gradient(ellipse at 20% 90%, rgba(74,93,58,.6), transparent 60%),
    linear-gradient(160deg, #b1502c, #6b452a 60%, #3a4d2e);
}
.ba__art--after::after{
  content:"万 春 · 近 邻 公 园"; position:absolute; bottom:30px; left:30px;
  font-family:var(--serif); font-size:clamp(28px, 4vw, 56px); font-weight:600;
  color:rgba(243,239,230,.95); letter-spacing:.1em;
}

.ba__label{
  position:absolute; top:18px; left:18px;
  font-family:var(--mono); font-size:11px; letter-spacing:.22em;
  padding:6px 12px; border:1px solid rgba(243,239,230,.5); border-radius:99px;
  color:var(--paper); background:rgba(0,0,0,.3); backdrop-filter:blur(4px);
}
.ba__label--after{ left:auto; right:18px; }

.ba__handle{
  position:absolute; top:0; bottom:0; left:50%; width:2px;
  background:var(--paper);
  transform:translateX(-50%);
  pointer-events:none;
}
.ba__handle span{
  position:absolute; top:50%; left:50%; transform:translate(-50%, -50%);
  width:48px; height:48px; border-radius:50%;
  background:var(--paper); border:1.5px solid var(--ink);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 18px rgba(0,0,0,.3);
}
.ba__handle span::before, .ba__handle span::after{
  content:""; position:absolute;
  border-style:solid; border-color:var(--ink);
}
.ba__handle span::before{ left:11px; border-width:5px 7px 5px 0; border-color:transparent var(--ink) transparent transparent; }
.ba__handle span::after { right:11px; border-width:5px 0 5px 7px; border-color:transparent transparent transparent var(--ink); }

.renewal__notes{
  list-style:none;
  max-width:var(--maxw); margin:48px auto 0; padding:0 var(--pad);
  display:grid; grid-template-columns:repeat(3,1fr); gap:32px;
}
.renewal__notes li{
  border-top:1px solid var(--ink); padding-top:14px;
}
.renewal__notes b{
  display:block; font-family:var(--serif); font-size:20px; font-weight:600; margin-bottom:6px;
}
.renewal__notes span{ color:var(--ink-soft); font-size:14.5px; }
@media (max-width:760px){ .renewal__notes{ grid-template-columns:1fr; gap:18px; } }

/* ============ gallery ============ */
.gallery{ padding:120px 0; background:var(--paper-2); border-block:1px solid var(--line-soft); }
.gallery__grid{
  max-width:var(--maxw); margin:0 auto; padding:0 var(--pad);
  display:grid; gap:6px;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 180px;
}
.g{
  position:relative; overflow:hidden;
  background:transparent;
  border:none;
  outline:none;
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
  border-radius:3px;
  box-shadow: 0 4px 20px rgba(0,0,0,.25);
}
.g img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  display:block;
}
.g::before,
.g::after{ display:none; }
.g__tag{ display:none; }
.g:hover{ transform:scale(1.03); }
.g:hover img{ transform:scale(1.08); transition:transform .6s cubic-bezier(.2,.7,.2,1); }
.g img{ transition:transform .6s cubic-bezier(.2,.7,.2,1); }

.g--1{ grid-column: span 3; grid-row: span 2; }
.g--2{ grid-column: span 3; }
.g--3{ grid-column: span 2; }
.g--4{ grid-column: span 1; }
.g--5{ grid-column: span 2; }
.g--6{ grid-column: span 4; }

@media (max-width:900px){
  .gallery__grid{ grid-template-columns:repeat(2, 1fr); grid-auto-rows:160px; }
  .g--1,.g--2,.g--3,.g--4,.g--5,.g--6{ grid-column:span 1; grid-row:auto; }
  .g--1{ grid-column:span 2; }
}

.gallery__more{
  max-width:var(--maxw); margin:0 auto; padding:24px var(--pad) 0;
  text-align:center;
}
.gallery__more .btn-ghost{
  display:inline-block;
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--ink-soft);
  border:1px solid var(--line);
  padding:14px 32px;
  transition:border-color .25s, color .25s;
}
.gallery__more .btn-ghost:hover{ border-color:var(--ink); color:var(--ink); }
.gallery-mosaic{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 12px;
}
.mosaic-item{
  position: relative;
  overflow: hidden;
  background:transparent;
  border: none;
  padding: 0;
  cursor: pointer;
  display: block;
  width: 100%;
  box-shadow: 0 4px 20px rgba(0,0,0,.25) !important;
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
  border-radius:3px;
}
.mosaic-item img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .5s cubic-bezier(.2,.7,.2,1);
}
.mosaic-item::after{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0);
  transition: background .35s;
  pointer-events:none;
}
.mosaic-item:hover{ transform: scale(.98); }
.mosaic-item:hover img{ transform: scale(1.04); }
.mosaic-item:hover::after{ background: rgba(0,0,0,.15); }

@media (max-width: 640px){
  .gallery-mosaic{ grid-template-columns: repeat(2, 1fr); gap: 8px; }
}

/* renewal log timeline */
.events__list{
  list-style:none;
  max-width:var(--maxw); margin:0 auto; padding:0 var(--pad);
}
.event{
  display:grid;
  grid-template-columns: 160px 1fr auto;
  gap:32px; align-items:center;
  padding:30px 0;
  border-top:1px solid var(--line);
  transition: background .35s;
  position:relative;
}
.event:last-child{ border-bottom:1px solid var(--line); }
.event time{
  font-family:var(--mono); font-size:12px; letter-spacing:.18em;
  color:var(--rust); text-transform:uppercase;
}
.event h3{
  font-family:var(--serif); font-size:clamp(20px, 2vw, 26px); font-weight:600;
  margin:0 0 6px;
}
.event p{ margin:0; color:var(--ink-soft); font-size:14.5px; max-width:60ch; }
.event__more{
  font-family:var(--mono); font-size:11px; letter-spacing:.22em;
  color:var(--ink); padding:8px 0; position:relative;
  transition:transform .3s;
}
.event:hover{ background:var(--paper-2); padding-left:18px; }
.event:hover .event__more{ transform:translateX(4px); color:var(--rust); }

@media (max-width:760px){
  .event{ grid-template-columns:1fr; gap:6px; padding:22px 0; }
  .event__more{ margin-top:8px; }
}

/* ============ press ============ */
.press{ padding:120px 0; background:var(--paper-2); border-block:1px solid var(--line-soft); }
.press__list{
  list-style:none;
  max-width:var(--maxw); margin:0 auto; padding:0 var(--pad);
  display:grid; gap:0;
}
.press li{
  display:grid;
  grid-template-columns: 220px 1fr 80px;
  gap:24px; align-items:center;
  padding:24px 0;
  border-top:1px solid var(--line);
  transition: padding-left .35s;
}
.press li:last-child{ border-bottom:1px solid var(--line); }
.press li:hover{ padding-left:18px; }
.press__from{
  font-family:var(--mono); font-size:11.5px; letter-spacing:.2em;
  color:var(--concrete); text-transform:uppercase;
}
.press__title{
  font-family:var(--serif); font-size:clamp(17px, 1.6vw, 21px); font-weight:500;
}
.press__kind{
  font-family:var(--mono); font-size:10px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--moss);
  padding:4px 10px; border:1px solid var(--moss); border-radius:99px;
  justify-self:start;
}
.press__ext{
  font-family:var(--mono); font-size:10px; letter-spacing:.2em;
  color:var(--ink); text-transform:uppercase;
}
.event__category{
  font-family:var(--mono); font-size:10px; letter-spacing:.2em;
  text-transform:uppercase; padding:4px 10px;
  border:1px solid var(--moss); color:var(--moss); border-radius:99px;
  align-self:flex-start;
}
.album-item{
  position:relative; overflow:hidden;
  background:linear-gradient(135deg, var(--concrete-2), var(--moss-soft));
  border:1px solid var(--line);
  display:block;
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
}
.album-item:hover{ transform:scale(1.01); }
.album-item img{ width:100%; height:100%; object-fit:cover; }
.album-item::after{
  content:attr(data-cap); position:absolute; left:14px; bottom:12px;
  font-family:var(--mono); font-size:10px; letter-spacing:.2em;
  color:var(--paper); background:rgba(28,28,26,.55);
  padding:6px 10px; text-transform:uppercase;
  opacity:0; transform:translateY(6px); transition:opacity .35s, transform .35s;
}
.album-item:hover::after{ opacity:1; transform:translateY(0); }

.press li time{
  font-family:var(--mono); font-size:11px; color:var(--rust); letter-spacing:.18em;
  text-align:right;
}
@media (max-width:760px){
  .press li{ grid-template-columns:1fr; gap:4px; padding:18px 0; }
  .press li time{ text-align:left; }
}

/* ============ contact / footer ============ */
.contact{
  background:var(--ink); color:var(--paper);
  padding:120px var(--pad) 24px;
}
.contact__inner{ max-width:var(--maxw); margin:0 auto; }
.contact__title{
  font-family:var(--serif); font-weight:500;
  font-size: clamp(40px, 6vw, 88px); line-height:1.1;
  margin:0 0 60px;
}
.contact__title em{ font-style:italic; color:var(--moss-soft); }
.contact__title span{
  display:block;
  font-family:var(--mono); font-size:12px; letter-spacing:.22em;
  color:var(--concrete); margin-top:18px; text-transform:uppercase;
}
.contact__cols{
  display:grid; grid-template-columns: 1fr 1.3fr 1.3fr; gap:clamp(48px, 7vw, 96px) clamp(64px, 9vw, 128px);
  padding-top:50px; border-top:1px solid rgba(243,239,230,.18);
}

/* ---- contact strip (subpages) ---- */
.contact-strip{
  max-width:var(--maxw);
  margin:80px auto 0;
  padding:48px var(--pad) 0;
  border-top:1px solid var(--line);
}
.contact-strip__cols{
  display:grid;
  grid-template-columns: 1fr 1.3fr 1.3fr;
  gap:clamp(32px, 5vw, 72px) clamp(48px, 7vw, 96px);
}
.contact-strip__col h4{
  font-family:var(--mono); font-size:11px; letter-spacing:.2em;
  color:var(--concrete-2); text-transform:uppercase; margin-bottom:14px;
}
.contact-strip__col p{ color:var(--ink-soft); font-size:14px; line-height:1.8; }
.contact-strip__col .socials{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:1fr 1fr; column-gap:36px; row-gap:0; }
.contact-strip__col .socials a{
  display:flex; align-items:baseline; justify-content:space-between; gap:12px;
  padding:12px 0; border-top:1px solid var(--line-soft);
  font-size:14px; color:var(--ink);
  transition:padding-left .25s;
}
.contact-strip__col .socials a:hover{ padding-left:8px; color:var(--ink); }
.contact-strip__col .socials li:nth-last-child(-n+2) a{ border-bottom:1px solid var(--line-soft); }
.contact-strip__col .socials a i{ font-style:normal; font-family:var(--mono); font-size:10px; letter-spacing:.2em; color:var(--concrete); }

/* ---- footer filings ---- */
.footer__filings{
  display:flex; gap:20px; flex-wrap:wrap;
}
.filing-item{
  display:flex; align-items:center; gap:8px;
}
.filing-label{
  font-family:var(--mono); font-size:11px; letter-spacing:.16em;
  color:var(--concrete); text-transform:uppercase;
}
.filing-link{
  color:var(--concrete);
  text-decoration:none;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.filing-link:hover{ color:var(--paper); }

/* ---- booking card ---- */
.booking{
  display:grid;
  grid-template-columns: minmax(220px, 280px) 1fr;
  gap:clamp(32px, 5vw, 72px);
  align-items:center;
  margin: 12px 0 80px;
  padding: clamp(32px, 4vw, 56px);
  border:1px solid rgba(243,239,230,.16);
  background:
    radial-gradient(120% 180% at 100% 0%, rgba(177,80,44,.18), transparent 55%),
    radial-gradient(120% 180% at 0% 100%, rgba(74,93,58,.22), transparent 55%),
    rgba(243,239,230,.03);
  border-radius:6px;
  position:relative;
  overflow:hidden;
}
.booking::before{
  content:""; position:absolute; inset:auto auto 0 0; width:64px; height:1px;
  background:var(--rust);
}
.booking__qr{
  display:flex; flex-direction:column; align-items:center; gap:14px;
}
.qr{
  width:100%; aspect-ratio:1/1; padding:14px;
  background:var(--paper); border-radius:4px;
  box-shadow: 0 24px 48px -20px rgba(0,0,0,.6), 0 0 0 1px rgba(243,239,230,.08);
  position:relative;
}
.qr svg{ width:100%; height:100%; display:block; }
.qr .qr-img{ position:absolute; inset:14px; width:calc(100% - 28px); height:calc(100% - 28px); object-fit:contain; }
.qr::after{
  content:""; position:absolute; inset:-10px;
  border:1px solid rgba(177,80,44,.35);
  border-radius:6px; pointer-events:none;
  transform:rotate(-1.2deg);
}
.booking__qr-cap{
  font-family:var(--mono); font-size:11px; letter-spacing:.22em;
  color:var(--concrete); text-transform:uppercase;
}
.booking__copy{ min-width:0; }
.booking__kicker{
  display:inline-block; font-family:var(--mono); font-size:11px; letter-spacing:.22em;
  color:var(--rust); text-transform:uppercase;
  padding:4px 10px; border:1px solid rgba(177,80,44,.5); border-radius:99px;
}
.booking__title{
  font-family:var(--sans); font-weight:700;
  font-size: clamp(28px, 3.6vw, 48px); line-height:1.15;
  letter-spacing:-.02em;
  margin: 18px 0 16px;
}
.booking__title em{
  font-style:normal; font-weight:800;
  color:var(--moss-soft);
  background:linear-gradient(transparent 70%, rgba(177,80,44,.35) 70%);
  padding: 0 .08em;
}
.booking__lede{
  margin:0 0 26px; max-width:60ch;
  color:var(--paper-2); font-size:15px; line-height:1.75;
}
.booking__meta{
  list-style:none; margin:0; padding:0;
  display:grid; grid-template-columns: repeat(2, 1fr); gap:14px 28px;
}
.booking__meta li{
  display:grid; grid-template-columns: auto auto 1fr; align-items:baseline;
  gap:10px;
  padding:10px 0; border-top:1px solid rgba(243,239,230,.12);
}
.booking__meta i{
  font-style:normal; font-family:var(--mono); font-size:10px; letter-spacing:.18em;
  color:var(--concrete);
}
.booking__meta b{
  font-weight:500; font-size:13px; color:var(--paper); letter-spacing:.04em;
}
.booking__meta span{
  font-family:var(--mono); font-size:12px; letter-spacing:.04em;
  color:var(--moss-soft); text-align:right;
}
.contact__col h4{
  font-family:var(--mono); font-size:11px; letter-spacing:.22em;
  color:var(--concrete); text-transform:uppercase; margin:0 0 14px;
}
.contact__col p{ margin:0; color:var(--paper-2); font-size:15px; line-height:1.7; }
.contact__col strong{ color:var(--gold); font-weight:600; }
.link{
  position:relative; color:var(--moss-soft); white-space:nowrap;
  border-bottom:1px solid rgba(182,192,160,.4); padding-bottom:1px;
  transition: color .25s, border-color .25s;
}
.link:hover{ color:var(--paper); border-color:var(--paper); }

.socials{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:1fr 1fr; column-gap:36px; row-gap:0; }
.socials a{
  display:flex; align-items:baseline; justify-content:space-between; gap:12px;
  padding:12px 0; border-top:1px solid rgba(243,239,230,.15);
  font-size:14px;
  transition: padding-left .25s, color .25s;
}
.socials li:nth-last-child(-n+2) a{ /* keep border */ }
.socials a i{
  font-style:normal; font-family:var(--mono); font-size:10px; letter-spacing:.2em;
  color:var(--concrete);
}
.socials a:hover{ padding-left:8px; color:var(--gold); }
.socials a:hover i{ color:var(--gold); }

.footer{
  display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap;
  max-width:var(--maxw);
  margin:80px auto 0; padding:24px var(--pad) 32px;
  border-top:1px solid var(--line);
  font-family:var(--mono); font-size:11px; letter-spacing:.16em;
  color:var(--concrete); text-transform:uppercase;
}
.footer .muted{ opacity:.7; }
.footer > div{ display:flex; flex-wrap:wrap; gap:14px; }
.contact .footer{
  max-width:none; margin:80px 0 0; padding:24px 0 0;
  border-top-color:rgba(243,239,230,.15);
}

@media (max-width:760px){
  .contact__cols{ grid-template-columns:1fr; gap:36px; }
  .socials{ grid-template-columns:1fr; }
  .booking{
    grid-template-columns: 1fr; gap:28px;
    padding: 28px 22px;
  }
  .booking__qr{ flex-direction:row; align-items:center; gap:18px; }
  .qr{ width:140px; padding:10px; }
  .qr::after{ inset:-6px; }
  .booking__meta{ grid-template-columns:1fr; gap:0; }
}

/* ============ utility ============ */
.muted{ color:var(--concrete); }
[data-reveal]{ opacity:0; transform:translateY(18px); transition:opacity .9s, transform .9s; }
[data-reveal].in-view{ opacity:1; transform:translateY(0); }

/* ============ char reveal (hero title) ============ */
.rch{
  display:inline-block;
  opacity:0;
  transform:translateY(.45em) rotate(2deg);
  transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1);
  will-change: opacity, transform;
}
.is-on .rch{ opacity:1; transform:none; }

/* nav active link highlight */
.nav__links a.is-active{
  background:var(--ink);
  color:var(--paper);
}
.nav__links a.is-active i{ color:var(--gold); }

@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{ animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; }
  .rch{ opacity:1 !important; transform:none !important; }
}

/* =================================================== */
/* ============ subpage shared components ============ */
/* =================================================== */

.subpage-hero{
  position:relative; isolation:isolate;
  padding: 160px var(--pad) 80px;
  min-height: 60vh;
  display:flex; flex-direction:column; justify-content:flex-end; gap:28px;
  border-bottom:1px solid var(--line);
  overflow:hidden;
}
.subpage-hero::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(ellipse 70% 60% at 80% 30%, rgba(74,93,58,.18), transparent 60%),
    radial-gradient(ellipse 80% 60% at 10% 90%, rgba(177,80,44,.12), transparent 60%);
  filter:blur(2px);
  animation: drift 32s ease-in-out infinite alternate;
}
.subpage-hero::after{
  content:""; position:absolute; inset:0; z-index:-1;
  background-image:
    linear-gradient(to right, var(--line-soft) 1px, transparent 1px),
    linear-gradient(to bottom, var(--line-soft) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image:radial-gradient(ellipse at center, black 30%, transparent 80%);
}
.subpage-hero .crumb{
  display:flex; gap:10px; align-items:center;
  font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  color:var(--concrete); text-transform:uppercase;
}
.subpage-hero .crumb a{ color:var(--concrete); }
.subpage-hero .crumb a:hover{ color:var(--ink); }
.subpage-hero .crumb span{ opacity:.4; }
.subpage-hero h1{
  font-family:var(--sans); font-weight:700; letter-spacing:.04em;
  font-size:clamp(22px, 4vw, 42px); line-height:1.1;
  margin:0;
}
.subpage-hero h1 em{
  font-style:normal; font-family:var(--mono); font-weight:400;
  display:block; font-size:clamp(13px, 1.4vw, 16px);
  color:var(--moss); letter-spacing:.22em; text-transform:uppercase;
  margin-bottom:14px;
}
.subpage-hero .lede{
  max-width:60ch; font-size:clamp(15px, 1.4vw, 17px);
  color:var(--ink-soft);
}
.subpage-hero .meta{
  display:flex; gap:20px; flex-wrap:wrap;
  font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  color:var(--concrete); text-transform:uppercase;
  border-top:1px solid var(--line); padding-top:18px;
}
.subpage-hero .meta b{ color:var(--ink); font-weight:500; margin-right:8px; }

/* generic content container */
.subpage{ padding: 80px var(--pad) 140px; }
.post-content{
  max-width:960px; margin:0 auto;
  font-size:clamp(15px, 1.4vw, 17px); line-height:1.85;
  color:var(--ink);
}
.post-content > *{ max-width:100%; }
.post-content img{ max-width:100%; width:100%; height:auto; display:block; }

/* filter chips */
.chips{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:36px; }
.chips button{
  font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  padding:8px 14px; border:1px solid var(--line); border-radius:99px;
  background:transparent; color:var(--ink-soft);
  transition:background .25s, color .25s, border-color .25s;
}
.chips button:hover{ border-color:var(--ink); }
.chips button.is-on{ background:var(--ink); color:var(--paper); border-color:var(--ink); }

.gallery__more{
  max-width:var(--maxw); margin:0 auto; padding:24px var(--pad) 0;
  text-align:center;
}
.gallery__more .btn-ghost{
  display:inline-block;
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--ink-soft);
  border:1px solid var(--line);
  padding:14px 32px;
  transition:border-color .25s, color .25s;
}
.gallery__more .btn-ghost:hover{ border-color:var(--ink); color:var(--ink); }
.gallery-mosaic{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 12px;
}
.mosaic-item{
  position: relative;
  overflow: hidden;
  border-radius: 6px;
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
  box-shadow: 0 4px 20px rgba(0,0,0,.25);
  display: block;
  width: 100%;
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
}
.mosaic-item img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .5s cubic-bezier(.2,.7,.2,1);
}
.mosaic-item__cap{
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 28px 16px 14px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .15em;
  color: var(--paper);
  text-transform: uppercase;
  background: linear-gradient(to top, rgba(0,0,0,.65) 0%, transparent 100%);
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .35s, transform .35s;
  text-align: left;
}
.mosaic-item::after{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0);
  transition: background .35s;
  pointer-events:none;
}
.mosaic-item:hover{ transform: scale(.98); }
.mosaic-item:hover img{ transform: scale(1.04); }
.mosaic-item:hover .mosaic-item__cap{ opacity: 1; transform: translateY(0); }
.mosaic-item:hover::after{ background: rgba(0,0,0,.15); }

@media (max-width: 640px){
  .gallery-mosaic{ grid-template-columns: repeat(2, 1fr); gap: 8px; }
}

/* renewal log timeline */
.timeline{ position:relative; padding-left:28px; }
.timeline::before{
  content:""; position:absolute; left:8px; top:8px; bottom:8px; width:1px;
  background:linear-gradient(to bottom, var(--moss), var(--rust));
}
.timeline > li{
  list-style:none; position:relative; padding:0 0 56px 24px;
}
.timeline > li::before{
  content:""; position:absolute; left:-25px; top:6px;
  width:11px; height:11px; border-radius:50%;
  background:var(--paper); border:2px solid var(--moss);
}
.timeline > li.is-rust::before{ border-color:var(--rust); }
.timeline time{
  display:block; font-family:var(--mono); font-size:11px; letter-spacing:.2em;
  color:var(--moss); text-transform:uppercase; margin-bottom:8px;
}
.timeline h3{
  font-family:var(--serif); font-size:clamp(20px, 2vw, 26px); margin:0 0 10px;
}
.timeline p{ color:var(--ink-soft); margin:0 0 12px; max-width:65ch; }
.timeline .thumb{
  display:grid; grid-template-columns:repeat(3,1fr); gap:8px;
  margin-top:14px;
}
.timeline .thumb > div{
  aspect-ratio:4/3;
  background:linear-gradient(135deg, var(--concrete-2), var(--paper-2));
  border:1px solid var(--line);
  position:relative; overflow:hidden;
}
.timeline .thumb > div::after{
  content:attr(data-cap); position:absolute; left:8px; bottom:6px;
  font-family:var(--mono); font-size:9px; letter-spacing:.18em;
  color:var(--ink-soft); text-transform:uppercase;
}

/* gallery: masonry-ish grid */
.album-grid{
  display:grid; gap:14px;
  grid-template-columns:repeat(12, 1fr);
  grid-auto-rows: 120px;
}
.album-grid > a{
  position:relative; overflow:hidden;
  background:linear-gradient(135deg, var(--concrete-2), var(--moss-soft));
  border:1px solid var(--line);
  display:block;
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
}
.album-grid > a:hover{ transform:scale(1.01); }
.album-grid > a::after{
  content:attr(data-cap); position:absolute; left:14px; bottom:12px;
  font-family:var(--mono); font-size:10px; letter-spacing:.2em;
  color:var(--paper); background:rgba(28,28,26,.55);
  padding:6px 10px; text-transform:uppercase;
  opacity:0; transform:translateY(6px); transition:opacity .35s, transform .35s;
}
.album-grid > a:hover::after{ opacity:1; transform:translateY(0); }
.album-grid > a.s-1{ grid-column: span 6; grid-row: span 3; background:linear-gradient(135deg,#7a8a66,#3a4a30); }
.album-grid > a.s-2{ grid-column: span 3; grid-row: span 2; background:linear-gradient(135deg,#c0b9a8,#8a8478); }
.album-grid > a.s-3{ grid-column: span 3; grid-row: span 2; background:linear-gradient(135deg,#b1502c,#7a3417); }
.album-grid > a.s-4{ grid-column: span 4; grid-row: span 2; background:linear-gradient(135deg,#2d2c28,#5b5b54); }
.album-grid > a.s-5{ grid-column: span 4; grid-row: span 3; background:linear-gradient(135deg,#a3b59a,#4a5d3a); }
.album-grid > a.s-6{ grid-column: span 4; grid-row: span 2; background:linear-gradient(135deg,#d3c98c,#a08c46); }
.album-grid > a.s-7{ grid-column: span 6; grid-row: span 2; background:linear-gradient(135deg,#5a655a,#2f3d24); }
.album-grid > a.s-8{ grid-column: span 6; grid-row: span 2; background:linear-gradient(135deg,#c3b08c,#7a6a4c); }

/* album-item variants (for configurable gallery) */
.album-item.s-1{ grid-column: span 6; grid-row: span 3; background:linear-gradient(135deg,#7a8a66,#3a4a30); }
.album-item.s-2{ grid-column: span 3; grid-row: span 2; background:linear-gradient(135deg,#c0b9a8,#8a8478); }
.album-item.s-3{ grid-column: span 3; grid-row: span 2; background:linear-gradient(135deg,#b1502c,#7a3417); }
.album-item.s-4{ grid-column: span 4; grid-row: span 2; background:linear-gradient(135deg,#2d2c28,#5b5b54); }
.album-item.s-5{ grid-column: span 4; grid-row: span 3; background:linear-gradient(135deg,#a3b59a,#4a5d3a); }
.album-item.s-6{ grid-column: span 4; grid-row: span 2; background:linear-gradient(135deg,#d3c98c,#a08c46); }
.album-item.s-7{ grid-column: span 6; grid-row: span 2; background:linear-gradient(135deg,#5a655a,#2f3d24); }
.album-item.s-8{ grid-column: span 6; grid-row: span 2; background:linear-gradient(135deg,#c3b08c,#7a6a4c); }

@media (max-width: 920px){
  .album-grid{ grid-template-columns:repeat(6, 1fr); grid-auto-rows:100px; }
  .album-grid > a{ grid-column: span 3 !important; grid-row: span 2 !important; }
  .album-grid > a.s-1, .album-grid > a.s-5{ grid-column: span 6 !important; grid-row: span 3 !important; }
  .album-item{ grid-column: span 3 !important; grid-row: span 2 !important; }
  .album-item.s-1, .album-item.s-5{ grid-column: span 6 !important; grid-row: span 3 !important; }
}

/* events list (subpage) */
.event-list{ list-style:none; margin:0; padding:0; border-top:1px solid var(--line); }
.event-list > li{
  display:grid; grid-template-columns: 110px 1fr; gap:28px;
  padding:28px 0; border-bottom:1px solid var(--line-soft);
  transition:padding .25s, background .25s;
}
.event-list > li:hover{ padding-left:14px; background:rgba(28,28,26,.03); }
.evt-date{
  display:flex; flex-direction:column; gap:4px;
  border-left:2px solid var(--moss); padding-left:14px;
}
.evt-date b{ font-family:var(--sans); font-size:36px; font-weight:700; line-height:1; color:var(--ink); }
.evt-date i{ font-style:normal; font-family:var(--mono); font-size:10px; letter-spacing:.2em; color:var(--concrete); text-transform:uppercase; }
.evt-body{ display:flex; flex-direction:column; gap:8px; }
.evt-tag{
  align-self:flex-start;
  font-family:var(--mono); font-size:10px; letter-spacing:.2em;
  text-transform:uppercase; padding:4px 10px;
  border:1px solid var(--moss); color:var(--moss); border-radius:99px;
}
.evt-body h3{ font-family:var(--sans); font-weight:600; font-size:clamp(20px, 2vw, 24px); margin:4px 0 0; line-height:1.3; }
.evt-body p{ margin:0; color:var(--ink-soft); max-width:65ch; }
.evt-more{
  align-self:flex-start; margin-top:6px;
  font-family:var(--mono); font-size:11px; letter-spacing:.2em;
  color:var(--ink); text-transform:uppercase;
  border-bottom:1px solid var(--ink);
  cursor:pointer;
}
@media (max-width:760px){
  .event-list > li{ grid-template-columns: 1fr; gap:14px; }
}

/* press list (subpage) */
.press-list{ list-style:none; margin:0; padding:0; border-top:1px solid var(--line); }
.press-list > li{
  display:grid;
  grid-template-columns: auto 1fr auto;
  gap:24px; align-items:center;
  padding:22px 0; border-bottom:1px solid var(--line-soft);
  transition:padding .25s, background .25s;
}
.press-list > li:hover{ padding-left:14px; background:rgba(28,28,26,.03); }
.press-line{
  display:flex; align-items:center; gap:8px;
}
.press-list .from{
  font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  color:var(--concrete); text-transform:uppercase; white-space:nowrap;
}
.press-list .year-tag{
  display:inline-block;
  font-family:var(--mono); font-size:10px; letter-spacing:.14em;
  color:var(--moss); text-transform:uppercase;
  padding:3px 8px; border:1px solid var(--moss); border-radius:99px;
  white-space:nowrap; width:fit-content;
}
.press-list .ttl{
  font-family:var(--sans); font-weight:600;
  font-size:clamp(16px, 1.6vw, 19px);
  color:var(--ink); white-space:nowrap;
}
.press-list .ttl:hover{ color:var(--rust); }
.press-list .ext{
  font-family:var(--mono); font-size:10px; letter-spacing:.2em;
  color:var(--ink); text-transform:uppercase; white-space:nowrap;
}
@media (max-width:920px){
  .press-list > li{ grid-template-columns: 1fr auto; gap:6px 16px; }
  .press-list .press-line{ grid-column:1 / -1; flex-direction:row; flex-wrap:wrap; gap:12px; }
  .press-list .ttl{ white-space:normal; }
}

/* contact page */
.contact-page .contact-grid{
  display:grid; gap:36px;
  grid-template-columns: repeat(3, 1fr);
}
.contact-page .ccol{
  border-top:1px solid var(--line); padding-top:18px;
}
.contact-page .ccol--wide{ grid-column: span 3; }
.contact-page .ccol h4{
  font-family:var(--mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--moss); margin:0 0 12px;
}
.contact-page .ccol p{ color:var(--ink-soft); margin:0 0 8px; line-height:1.7; }
.contact-page .ccol p.muted{ color:var(--concrete); font-size:13px; }
.contact-page .ccol .link{ color:var(--rust); border-bottom:1px solid var(--rust); }
.contact-page .ccol .socials{ list-style:none; margin:0; padding:0;
  display:grid; grid-template-columns:repeat(2,1fr); column-gap:36px; row-gap:0;
}
.contact-page .ccol .socials a{
  display:flex; justify-content:space-between; align-items:center;
  padding:12px 0; border-bottom:1px solid var(--line-soft);
  font-family:var(--sans); font-weight:500;
  transition:padding .25s, color .25s;
}
.contact-page .ccol .socials a i{
  font-style:normal; font-family:var(--mono); font-size:10px; letter-spacing:.2em; color:var(--concrete);
}
.contact-page .ccol .socials a:hover{ padding-left:8px; color:var(--rust); }
.contact-page .ccol .socials a:hover i{ color:var(--rust); }

.booking--light{
  margin: 56px 0 0;
  border:1px solid var(--line);
  background:
    radial-gradient(120% 180% at 100% 0%, rgba(177,80,44,.10), transparent 55%),
    radial-gradient(120% 180% at 0% 100%, rgba(74,93,58,.10), transparent 55%),
    var(--paper-2);
  color:var(--ink);
}
.booking--light .booking__qr-cap{ color:var(--concrete); }
.booking--light .booking__title{ color:var(--ink); }
.booking--light .booking__title em{
  color:var(--moss-deep);
  background:linear-gradient(transparent 70%, rgba(177,80,44,.32) 70%);
}
.booking--light .booking__lede{ color:var(--ink-soft); }
.booking--light .booking__meta li{ border-top-color:var(--line); }
.booking--light .booking__meta b{ color:var(--ink); }
.booking--light .booking__meta span{ color:var(--moss-deep); }
.booking--light .qr{ box-shadow: 0 24px 36px -22px rgba(28,28,26,.35), 0 0 0 1px var(--line); }

.contact-page .map{
  margin-top:60px;
  aspect-ratio: 16/6; width:100%;
  background:
    linear-gradient(135deg, rgba(74,93,58,.2), rgba(177,80,44,.1)),
    repeating-linear-gradient(0deg, var(--line-soft) 0 1px, transparent 1px 40px),
    repeating-linear-gradient(90deg, var(--line-soft) 0 1px, transparent 1px 40px),
    var(--paper-2);
  border:1px solid var(--line);
  position:relative;
}
.contact-page .map .pin{
  position:absolute; left:50%; top:50%;
  transform:translate(-50%,-50%);
  font-family:var(--sans); font-weight:700; letter-spacing:.1em;
  background:var(--ink); color:var(--paper); padding:8px 14px;
  font-size:12px;
}
.contact-page .map::before{
  content:""; position:absolute; left:50%; top:50%;
  width:14px; height:14px; border-radius:50%;
  background:var(--rust); transform:translate(-50%, calc(-50% + 28px));
  box-shadow: 0 0 0 6px rgba(177,80,44,.2);
  animation: pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{ box-shadow: 0 0 0 4px rgba(177,80,44,.18); }
  50%   { box-shadow: 0 0 0 12px rgba(177,80,44,0); }
}
@media (max-width:920px){
  .contact-page .contact-grid{ grid-template-columns: 1fr 1fr; }
  .contact-page .ccol--wide{ grid-column: span 2; }
}
@media (max-width:600px){
  .contact-page .contact-grid{ grid-template-columns: 1fr; }
  .contact-page .ccol--wide{ grid-column: span 1; }
  .contact-page .ccol .socials{ grid-template-columns:1fr; }
}
