:root {
  --black: #111;
  --paper: #f5f1e8;
  --red: #e63b2e;
  --yellow: #f2c94c;
  --blue: #2d5d88;
  --line: rgba(17,17,17,.25);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--black); background: var(--paper); font-family: Arial, "Microsoft YaHei", sans-serif; }
a { color: inherit; text-decoration: none; }

.masthead {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 22px 3vw 16px;
  border-bottom: 1px solid var(--black);
}
.edition { font: 11px/1.2 Arial, sans-serif; letter-spacing: .12em; }
.logo { display: flex; align-items: baseline; gap: 8px; font-family: "Noto Serif SC", "Songti SC", SimSun, serif; }
.logo span { font-size: clamp(42px, 6vw, 86px); font-weight: 900; letter-spacing: -.12em; }
.logo b { padding: 5px 7px; color: var(--paper); background: var(--red); font-size: 14px; transform: rotate(-5deg); }
.menu-toggle { justify-self: end; padding: 0; background: none; border: 0; font: 700 13px/1 Arial, sans-serif; letter-spacing: .1em; }
.main-nav { display: flex; justify-content: center; gap: 50px; padding: 13px; border-bottom: 1px solid var(--black); font-size: 13px; font-weight: 700; }
.main-nav a:hover { color: var(--red); }

.cover-story { display: grid; grid-template-columns: 1.25fr .75fr; min-height: 700px; border-bottom: 1px solid var(--black); }
.cover-image { position: relative; overflow: hidden; min-height: 630px; background: #7d9eba; border-right: 1px solid var(--black); }
.sun { position: absolute; top: 11%; right: 12%; width: 180px; aspect-ratio: 1; background: var(--yellow); border-radius: 50%; }
.building { position: absolute; bottom: 0; background: var(--black); }
.building::before, .building::after { content: ""; position: absolute; background: repeating-linear-gradient(90deg, transparent 0 18px, #d5e0e8 18px 28px); opacity: .72; }
.building-one { left: 6%; width: 30%; height: 63%; }
.building-one::before { inset: 15% 8%; }
.building-two { left: 39%; width: 24%; height: 47%; background: #e8e3d6; border: 1px solid var(--black); }
.building-two::before { inset: 12%; background: repeating-linear-gradient(0deg, transparent 0 22px, #345d73 22px 30px); }
.building-three { right: 5%; width: 26%; height: 72%; background: var(--red); }
.building-three::before { inset: 10%; background: repeating-linear-gradient(90deg, transparent 0 16px, #f3cbbd 16px 23px); }
.photo-credit { position: absolute; left: 16px; bottom: 12px; color: white; font-size: 9px; letter-spacing: .12em; writing-mode: vertical-rl; }
.cover-copy { display: flex; flex-direction: column; justify-content: center; padding: 6vw 4.5vw; }
.kicker { margin: 0 0 22px; color: var(--red); font-size: 12px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
h1 { margin: 0; font: 900 clamp(46px, 5.6vw, 82px)/1.08 "Noto Serif SC", "Songti SC", serif; letter-spacing: -.07em; }
.dek { margin: 30px 0; font: 18px/1.8 "Noto Serif SC", "Songti SC", serif; }
.byline { display: flex; justify-content: space-between; gap: 20px; padding-top: 15px; border-top: 1px solid var(--black); font-size: 11px; }
.read-more { align-self: flex-start; margin-top: 35px; padding: 13px 18px; color: var(--paper); background: var(--black); font-size: 13px; font-weight: 700; }

.ticker { overflow: hidden; padding: 13px 0; color: var(--paper); background: var(--red); white-space: nowrap; }
.ticker div { width: max-content; font: 800 13px/1 Arial, sans-serif; letter-spacing: .12em; animation: ticker 18s linear infinite; }
@keyframes ticker { to { transform: translateX(-35%); } }

.story-grid, .notes { padding: 90px 4vw; }
.section-title { display: grid; grid-template-columns: 60px 1fr auto; align-items: baseline; padding-bottom: 18px; border-bottom: 3px solid var(--black); }
.section-title > span { font-size: 12px; font-weight: 800; }
.section-title h2 { margin: 0; font: 900 clamp(38px, 4.8vw, 65px)/1 "Noto Serif SC", serif; letter-spacing: -.06em; }
.section-title a { font-size: 12px; border-bottom: 1px solid; }
.story-grid { display: grid; grid-template-columns: 1.3fr .7fr .7fr; gap: 25px; }
.story-grid .section-title { grid-column: 1 / -1; }
.story { padding-top: 10px; border-top: 1px solid var(--black); }
.story-lead { grid-row: span 1; }
.story-image { position: relative; overflow: hidden; min-height: 340px; margin-bottom: 20px; border: 1px solid var(--black); }
.story-lead .story-image { min-height: 500px; }
.image-river { background: linear-gradient(165deg, #d1d5c1 0 47%, #496d7b 47% 63%, #a9a07e 63%); }
.image-river::before { content: ""; position: absolute; left: 11%; bottom: 25%; width: 55%; height: 6px; background: var(--black); transform: rotate(-8deg); box-shadow: 0 15px 0 rgba(17,17,17,.45); }
.image-label { position: absolute; right: 16px; top: 16px; padding: 7px 9px; color: white; background: var(--red); font-size: 10px; letter-spacing: .1em; }
.image-market { display: flex; align-items: flex-end; padding: 22px; color: white; background: repeating-linear-gradient(90deg, #e48b47 0 42px, #f1c56b 42px 84px); font: 800 35px/1 Arial, sans-serif; }
.image-market::before { content: ""; position: absolute; inset: 18% 15%; background: #3f6e54; border-radius: 50% 50% 10% 10%; }
.image-market span { position: relative; z-index: 2; }
.image-cinema { display: grid; place-items: center; background: #24324a; }
.cinema-sign { padding: 20px 25px; color: #f6d45b; border: 5px double #f6d45b; text-align: center; font: 700 28px/1.2 "Noto Serif SC", serif; transform: rotate(-3deg); }
.category { margin: 0 0 10px; color: var(--red); font-size: 11px; font-weight: 800; letter-spacing: .1em; }
.story-copy h3 { margin: 0 0 12px; font: 800 25px/1.35 "Noto Serif SC", serif; }
.story-lead .story-copy h3 { font-size: 34px; }
.story-copy > p:not(.category) { color: #555; line-height: 1.7; }
.meta { font-size: 10px; letter-spacing: .08em; }

.people-section { padding: 90px 4vw 110px; color: var(--paper); background: var(--black); }
.section-title.light { border-color: var(--paper); }
.portrait-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; margin-top: 35px; }
.portrait { position: relative; height: 460px; overflow: hidden; background: #aaa; }
.portrait::before, .portrait::after { content: ""; position: absolute; border-radius: 50%; }
.portrait::before { width: 42%; aspect-ratio: 1; left: 29%; top: 18%; background: #c48e69; }
.portrait::after { width: 78%; height: 52%; left: 11%; bottom: -15%; background: #596f88; border-radius: 45% 45% 0 0; }
.portrait-two { background: #d4bd7e; }
.portrait-two::before { background: #8e6049; }
.portrait-two::after { background: #773e34; }
.portrait-three { background: #7f9a80; }
.portrait-three::before { background: #d5a278; }
.portrait-three::after { background: #d3c59f; }
.portrait span { position: absolute; z-index: 2; top: 15px; left: 15px; font: 800 12px Arial; }
.portrait-grid h3 { margin: 18px 0 8px; font: 700 25px "Noto Serif SC", serif; }
.portrait-grid p { margin: 0; color: #b8b8b8; line-height: 1.7; }

.note-list article { display: grid; grid-template-columns: 110px 1fr auto; align-items: center; gap: 25px; padding: 25px 0; border-bottom: 1px solid var(--line); }
.note-list time { font: 700 25px Georgia, serif; }
.note-list p { margin: 0 0 7px; color: var(--red); font-size: 11px; font-weight: 800; }
.note-list h3 { margin: 0; font: 700 25px "Noto Serif SC", serif; }
.note-list > article > span { font-size: 10px; }

.newsletter { display: grid; grid-template-columns: 1fr 1fr; gap: 9vw; padding: 85px 7vw; color: var(--paper); background: var(--blue); }
.newsletter h2 { margin: 0; font: 900 clamp(36px, 5vw, 64px)/1.15 "Noto Serif SC", serif; letter-spacing: -.05em; }
.newsletter > div > p:last-child { max-width: 600px; color: #d3e0ea; line-height: 1.8; }
.newsletter form { align-self: center; }
.newsletter label { display: block; margin-bottom: 13px; font-size: 12px; font-weight: 700; }
.form-row { display: flex; border-bottom: 2px solid var(--paper); }
input { flex: 1; min-width: 0; padding: 15px 0; color: white; background: transparent; border: 0; outline: 0; font-size: 17px; }
input::placeholder { color: #b9cad8; }
form button { color: var(--paper); background: transparent; border: 0; font-weight: 800; cursor: pointer; }
.form-message { min-height: 20px; margin: 12px 0 0; color: var(--yellow); font-size: 12px; }

footer { padding: 55px 4vw 25px; color: var(--paper); background: var(--red); }
.footer-logo { display: block; font: 900 clamp(55px, 11vw, 160px)/1 "Noto Serif SC", serif; letter-spacing: -.11em; }
footer > p { max-width: 560px; font-size: 16px; line-height: 1.7; }
footer > div { display: flex; justify-content: space-between; margin-top: 60px; padding-top: 15px; border-top: 1px solid rgba(255,255,255,.45); font-size: 11px; }

@media (max-width: 900px) {
  .cover-story { grid-template-columns: 1fr; }
  .cover-image { border-right: 0; border-bottom: 1px solid var(--black); }
  .story-grid { grid-template-columns: 1fr 1fr; }
  .story-lead { grid-column: 1 / -1; }
  .portrait-grid { grid-template-columns: 1fr; }
  .portrait { height: 520px; }
  .newsletter { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .masthead { grid-template-columns: 1fr auto; }
  .edition { display: none; }
  .logo { justify-self: start; }
  .main-nav { display: none; flex-direction: column; align-items: center; gap: 22px; }
  .main-nav.open { display: flex; }
  .cover-image { min-height: 480px; }
  .cover-copy { padding: 50px 6vw; }
  .story-grid { grid-template-columns: 1fr; padding: 65px 5vw; }
  .story-lead { grid-column: auto; }
  .section-title { grid-template-columns: 35px 1fr; }
  .section-title a { display: none; }
  .story-lead .story-image, .story-image { min-height: 380px; }
  .people-section, .notes { padding: 65px 5vw; }
  .portrait { height: 430px; }
  .note-list article { grid-template-columns: 70px 1fr; }
  .note-list > article > span { display: none; }
}
