/* 104 Broadway — Bayfront Editorial */
:root{
  --sand: #f5f1e8;
  --sand-2: #ebe4d2;
  --paper: #fbf9f3;
  --ink: #1a3a47;
  --ink-2: #244a5a;
  --muted: #6b7680;
  --rule: #d8d1bd;
  --accent: #c97c3a;
  --accent-2: #a35a1d;
  --water: #6b9aa6;
  --ok: #2a7a4f;
  --warn: #b35900;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--sand);
  color:var(--ink);
  font-family:'Inter',system-ui,sans-serif;
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:'ss01','ss02';
}
img{display:block;max-width:100%;height:auto}
a{color:inherit}

.wrap{max-width:1240px;margin:0 auto;padding:0 32px}
.kicker{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--accent-2);
  margin-bottom:16px;
}
.kicker--light{color:var(--sand-2);opacity:.85}
.display{
  font-family:'Cormorant Garamond',serif;
  font-weight:500;
  font-size:clamp(36px,5vw,64px);
  line-height:1.05;
  letter-spacing:-.01em;
  margin:0 0 24px;
  text-wrap:balance;
}
h2.display{font-size:clamp(32px,4vw,52px)}
.lede{font-size:18px;color:var(--ink-2);max-width:62ch;text-wrap:pretty}
.micro{font-size:12px;color:var(--muted);font-family:'JetBrains Mono',ui-monospace,monospace;letter-spacing:.05em;margin-top:24px}

/* topbar */
.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(245,241,232,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--rule);
}
.topbar__row{
  display:flex;align-items:center;justify-content:space-between;
  height:64px;
}
.brand{display:flex;align-items:baseline;gap:8px;text-decoration:none;color:var(--ink)}
.brand__num{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:24px;letter-spacing:-.02em}
.brand__name{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2)}
.nav{display:flex;gap:28px;font-size:13px}
.nav a{color:var(--ink-2);text-decoration:none;letter-spacing:.02em}
.nav a:hover{color:var(--accent-2)}
@media (max-width:880px){.nav{display:none}}

/* hero */
.hero{
  position:relative;
  height:88vh;min-height:620px;max-height:880px;
  overflow:hidden;
  color:#fff;
  background:#1a2a32;
}
.hero__img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center 40%;
}
.hero__scrim{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(20,40,50,.55) 0%, rgba(20,40,50,.15) 35%, rgba(20,40,50,.0) 55%, rgba(20,40,50,.65) 100%);
}
.hero__inner{
  position:relative;z-index:2;
  height:100%;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding-bottom:72px;
}
.hero__inner .kicker{color:#f0d9b8;margin-bottom:20px}
.hero__title{
  font-family:'Cormorant Garamond',serif;
  font-weight:400;
  font-size:clamp(44px,7vw,96px);
  line-height:1;
  letter-spacing:-.02em;
  margin:0 0 24px;
  max-width:18ch;
  text-wrap:balance;
}
.hero__sub{font-size:19px;max-width:62ch;color:#f5ebd8;line-height:1.5;margin:0 0 36px}
.hero__meta{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid rgba(255,255,255,.25);
  padding-top:20px;
  max-width:920px;
}
.hero__meta > div{padding-right:24px;border-right:1px solid rgba(255,255,255,.15)}
.hero__meta > div:last-child{border-right:0}
.hero__meta span{display:block;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:#d6c5a3;margin-bottom:6px}
.hero__meta b{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:22px;letter-spacing:-.01em}
@media (max-width:720px){.hero__meta{grid-template-columns:repeat(2,1fr);row-gap:16px}.hero__meta > div:nth-child(2){border-right:0}}
.hero__credit{
  position:absolute;right:24px;bottom:16px;z-index:2;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;
  color:rgba(255,255,255,.7);
}

/* bands */
.band{padding:120px 0;border-top:1px solid var(--rule)}
.band--cream{background:var(--sand)}
.band--paper{background:var(--paper)}
.band--ink{background:var(--ink);color:#f0e9d6;border-color:#0f2832}
.band--ink .display{color:#fff}
.band--ink .kicker{color:#e0b27e}
.band--ink figcaption{color:#cdc3a8}

.section-head{margin-bottom:56px;max-width:760px}

/* grid layouts */
.grid-2{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:start}
@media (max-width:880px){.grid-2{grid-template-columns:1fr;gap:40px}}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:880px){.grid-3{grid-template-columns:1fr}}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media (max-width:1080px){.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:540px){.grid-4{grid-template-columns:1fr}}

.col-text p{margin:0 0 16px;color:var(--ink-2);max-width:62ch}
.col-text em{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.05em}
.bul{list-style:none;padding:0;margin:24px 0 0;border-top:1px solid var(--rule)}
.bul li{padding:14px 0 14px 24px;border-bottom:1px solid var(--rule);position:relative;color:var(--ink-2)}
.bul li::before{content:"";position:absolute;left:0;top:22px;width:10px;height:1px;background:var(--accent)}

/* figures */
.fig{margin:0}
.fig img{
  width:100%;height:auto;
  border-radius:2px;
  box-shadow:0 1px 0 rgba(26,58,71,.06), 0 12px 32px -16px rgba(26,58,71,.25);
}
.fig figcaption{
  margin-top:12px;
  font-size:13px;color:var(--muted);
  line-height:1.5;
}
.fig figcaption b{color:var(--ink);font-weight:500}
.fig--tall img{aspect-ratio:3/4;object-fit:cover}

/* cameras */
.cam__frame{
  background:var(--ink);
  aspect-ratio:4/3;
  overflow:hidden;
  position:relative;
  border-radius:2px;
}
.cam__frame img{width:100%;height:100%;object-fit:cover}
.cam__placeholder{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:'JetBrains Mono',monospace;font-size:12px;
  color:#9aaeb8;letter-spacing:.05em;
  background:repeating-linear-gradient(45deg,#1a3a47 0 12px,#1f4554 12px 24px);
}
.cam__placeholder span{margin-top:8px;color:#e0b27e;font-size:11px}
.cam figcaption{margin-top:14px;display:flex;flex-direction:column;gap:2px}
.cam figcaption b{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:18px;color:var(--ink);letter-spacing:-.01em}
.cam figcaption span{font-size:13px;color:var(--muted)}

/* time-lapse cards */
.card{background:#fff;border:1px solid var(--rule);border-radius:2px;overflow:hidden;display:flex;flex-direction:column}
.card__media{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--ink)}
.card__media img{width:100%;height:100%;object-fit:cover;filter:saturate(.85)}
.card__play{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:54px;height:54px;border-radius:50%;
  background:rgba(245,241,232,.92);color:var(--ink);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;text-decoration:none;
  box-shadow:0 6px 18px -6px rgba(0,0,0,.4);
  transition:transform .2s,background .2s;
}
.card__play:hover{transform:translate(-50%,-50%) scale(1.06);background:#fff}
.card__body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:8px}
.card__body h4{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:22px;margin:0;letter-spacing:-.01em}
.card__body p{margin:0;font-size:14px;color:var(--muted);line-height:1.5}
.link{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.05em;color:var(--accent-2);text-decoration:none;margin-top:6px}
.link:hover{color:var(--accent)}

/* ledger */
.ledger{border-top:1px solid var(--rule)}
.ledger__row{
  display:grid;grid-template-columns:160px 1.4fr 2fr 120px;
  gap:32px;padding:24px 0;border-bottom:1px solid var(--rule);
  align-items:baseline;
}
.ledger__yr{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.06em;color:var(--accent-2);text-transform:uppercase}
.ledger__what{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:22px;letter-spacing:-.01em}
.ledger__desc{font-size:14px;color:var(--ink-2);line-height:1.55;max-width:62ch}
.ledger__stat{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.14em;text-align:right;color:var(--muted)}
.ledger__stat.ok{color:var(--ok)}
.ledger__stat.warn{color:var(--warn)}
@media (max-width:900px){
  .ledger__row{grid-template-columns:1fr;gap:6px;padding:20px 0}
  .ledger__stat{text-align:left}
}

/* concepts */
.concepts{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:48px}
@media (max-width:1080px){.concepts{grid-template-columns:1fr}}
.concept{background:#20424f;border:1px solid rgba(255,255,255,.12);border-radius:2px;overflow:hidden;display:flex;flex-direction:column}
.concept__media{margin:0;aspect-ratio:4/3;overflow:hidden;background:#13303a}
.concept__media img{width:100%;height:100%;object-fit:cover}
.concept__body{padding:26px 26px 28px;display:flex;flex-direction:column;gap:10px}
.concept__tag{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#e0b27e}
.concept h3{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:32px;margin:0;color:#fff;letter-spacing:-.01em}
.concept__sub{font-size:13px;color:#cdc3a8;font-family:'JetBrains Mono',monospace;letter-spacing:.05em;margin:0 0 10px}
.concept p{margin:0;color:#d8d0bb;font-size:14px;line-height:1.55}
.concept__stats{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px;margin:18px 0 0;padding-top:18px;border-top:1px solid rgba(255,255,255,.14)}
.concept__stats > div{display:flex;flex-direction:column;gap:2px}
.concept__stats dt{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#9aaeb8}
.concept__stats dd{margin:0;font-family:'Cormorant Garamond',serif;font-size:20px;color:#fff;font-weight:500;letter-spacing:-.01em}

.recco{
  border:1px solid rgba(255,255,255,.18);
  padding:32px 36px;
  display:grid;grid-template-columns:180px 1fr;gap:32px;align-items:start;
  background:rgba(245,241,232,.04);
}
.recco__mark{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#e0b27e;padding-top:6px}
.recco p{margin:0;font-size:17px;color:#ece2c8;line-height:1.55;font-family:'Cormorant Garamond',serif;font-weight:400}
.recco em{font-style:normal;color:#fff;font-weight:500}
@media (max-width:760px){.recco{grid-template-columns:1fr;gap:14px;padding:24px}}

/* dossier */
.docs{margin-bottom:64px}
.doc{
  display:grid;grid-template-columns:84px 1fr 24px;gap:24px;align-items:start;
  background:#fff;border:1px solid var(--rule);padding:28px;
  text-decoration:none;color:inherit;transition:border-color .2s,transform .2s;
}
.doc:hover{border-color:var(--accent);transform:translateY(-2px)}
.doc__sheet{
  width:64px;height:84px;background:var(--sand-2);
  border:1px solid var(--ink-2);
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;
  display:flex;align-items:flex-end;justify-content:center;padding-bottom:8px;
  position:relative;color:var(--ink);
}
.doc__sheet::before{
  content:"";position:absolute;top:0;right:0;width:14px;height:14px;
  background:var(--sand);border-left:1px solid var(--ink-2);border-bottom:1px solid var(--ink-2);
}
.doc__body h4{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:24px;margin:0 0 8px;letter-spacing:-.01em}
.doc__body p{margin:0 0 10px;font-size:14px;color:var(--ink-2);line-height:1.55;max-width:54ch}
.doc__meta{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}
.doc__arrow{font-family:'JetBrains Mono',monospace;color:var(--accent);font-size:18px;align-self:center}

.indexlist{border-top:1px solid var(--rule);padding-top:32px}
.indexlist__head{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:16px}
.indexlist ul{list-style:none;padding:0;margin:0}
.indexlist li{
  display:grid;grid-template-columns:1fr auto;gap:16px;
  padding:14px 0;border-bottom:1px solid var(--rule);
  font-size:14px;color:var(--ink-2);align-items:baseline;
}
.indexlist li:last-child{border-bottom:0}
.mono{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase;white-space:nowrap}

/* contacts */
.contacts{gap:0;border:1px solid var(--rule);background:#fff}
.contacts .contact{padding:32px 28px;border-right:1px solid var(--rule)}
.contacts .contact:last-child{border-right:0}
.contact__role{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-2);margin-bottom:14px}
.contact h4{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:26px;letter-spacing:-.01em;margin:0 0 4px}
.contact__firm{margin:0 0 18px;font-size:13px;color:var(--muted)}
.contact__line{display:block;font-size:14px;color:var(--ink-2);text-decoration:none}
.contact__line b{color:var(--ink);font-weight:500}
@media (max-width:880px){
  .contacts{grid-template-columns:1fr}
  .contacts .contact{border-right:0;border-bottom:1px solid var(--rule)}
  .contacts .contact:last-child{border-bottom:0}
}

/* footer */
.foot{background:var(--sand-2);border-top:1px solid var(--rule);padding:64px 0 32px;color:var(--ink-2)}
.foot__row{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px}
@media (max-width:880px){.foot__row{grid-template-columns:1fr;gap:28px}}
.foot__desc{margin:14px 0 0;font-size:13px;color:var(--muted);max-width:42ch}
.foot h5{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);margin:0 0 14px}
.foot ul{list-style:none;padding:0;margin:0}
.foot li{padding:5px 0;font-size:13px}
.foot li a{color:var(--ink-2);text-decoration:none}
.foot li a:hover{color:var(--accent-2)}
.foot__bot{
  margin-top:36px;padding-top:20px;border-top:1px solid var(--rule);
  display:flex;justify-content:space-between;align-items:center;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--muted);
}
@media (max-width:600px){.foot__bot{flex-direction:column;gap:8px;align-items:flex-start}}
