/* =============================================================================
   HOMEPAGE — PAGE-SPECIFIC STYLES
   Load after common.css
   ============================================================================= */

body { background-color: var(--paper); color: var(--ink); font-family: var(--font-body); font-size: 1rem; line-height: 1.72; font-weight: 400; }
h1 { font-size: clamp(2rem, 5vw, 3.5rem); letter-spacing: -0.02em; }
h2 { font-size: clamp(1.5rem, 3vw, 2.25rem); letter-spacing: -0.015em; }
h3 { font-size: clamp(1.15rem, 2vw, 1.5rem); letter-spacing: -0.01em; }
p { margin-bottom: 1.2em; }
ul, ol { padding-left: 1.4em; }
li { margin-bottom: 0.4em; }
.mono { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--mid); }
.rule-top    { border-top: 1px solid var(--rule); }
.rule-bottom { border-bottom: 1px solid var(--rule); }
.site-logo:hover .site-logo__wordmark { color: var(--paper); }
.site-logo__wordmark .point-dot { color: var(--red); font-weight: 900; }
.site-nav {  }
.site-nav__item a { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(247, 244, 238, 0.65); text-decoration: none; padding-bottom: 2px; border-bottom: 1px solid transparent; }
.site-nav__item a:visited { color: rgba(247, 244, 238, 0.65); }
.site-nav__item--coming a { color: rgba(247, 244, 238, 0.3); cursor: default; pointer-events: none; }
.lead-question { background-color: var(--ink); color: var(--paper); padding-block: var(--space-xl) var(--space-xxl); border-bottom: 1px solid rgba(212, 207, 197, 0.15); }
.lead-question__inner { max-width: 860px; }
.lead-question__kicker { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--red); margin-bottom: var(--space-m); display: flex; align-items: center; gap: var(--space-s); }
.lead-question__kicker::before { content: ''; display: block; width: 32px; height: 1px; background-color: var(--red); flex-shrink: 0; }
.lead-question__text { font-family: var(--font-display); font-size: clamp(1.9rem, 4.5vw, 4rem); font-weight: 900; font-style: italic; line-height: 1.1; letter-spacing: -0.025em; color: var(--paper); margin-bottom: var(--space-l); }
.lead-question__sub { font-family: var(--font-body); font-size: 1.05rem; line-height: 1.7; color: rgba(247, 244, 238, 0.6); max-width: 580px; font-weight: 300; }
.verticals { padding-block: var(--space-xl); background-color: var(--paper); }
.section-header { margin-bottom: var(--space-l); }
.section-header__label { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--mid); display: block; margin-bottom: var(--space-xs); }
.section-header__title { font-family: var(--font-display); font-size: clamp(1.3rem, 2.5vw, 1.9rem); font-weight: 700; letter-spacing: -0.015em; color: var(--ink); }
.verticals__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-s); list-style: none; padding: 0; }
@media (min-width: 560px) {
.verticals__grid {
grid-template-columns: repeat(2, 1fr);
}
}
@media (min-width: 900px) {
.verticals__grid {
grid-template-columns: repeat(5, 1fr);
}
}
.vertical-card { border: 1px solid var(--rule); padding: var(--space-m); background-color: var(--paper); display: flex; flex-direction: column; gap: var(--space-s); }
.vertical-card--active { border-color: var(--ink); border-width: 1px; }
.vertical-card--active .vertical-card__name { color: var(--ink); }
.vertical-card--coming { background-color: var(--paper-tint); opacity: 0.7; }
.vertical-card__point { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--red); }
.vertical-card__name { font-family: var(--font-display); font-size: 1.15rem; font-weight: 700; color: var(--mid); line-height: 1.2; }
.vertical-card__desc { font-size: 0.88rem; line-height: 1.5; color: var(--mid); flex-grow: 1; margin-bottom: 0; }
.vertical-card__link { font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.1em; text-transform: uppercase; text-decoration: none; color: var(--link); display: inline-flex; align-items: center; gap: 0.4em; }
.vertical-card__link::after { content: '→'; font-style: normal; }
.vertical-card__link:hover { color: var(--red); }
.vertical-card__coming { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--light); }
.featured { padding-block: var(--space-xl); border-top: 1px solid var(--rule); }
.featured__inner { display: grid; grid-template-columns: 1fr; gap: var(--space-l); align-items: start; }
@media (min-width: 700px) {
.featured__inner {
grid-template-columns: 1fr 1fr;
gap: var(--space-xl);
}
}
.featured__image {  background-color: var(--paper-tint); border: 1px solid var(--rule); aspect-ratio: 4 / 3; display: flex; align-items: center; justify-content: center; }
.featured__image-placeholder { font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--light); text-align: center; padding: var(--space-m); }
.featured__content { display: flex; flex-direction: column; gap: var(--space-s); }
.featured__label { font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--red); }
.featured__title { font-family: var(--font-display); font-size: clamp(1.5rem, 3vw, 2.4rem); font-weight: 700; letter-spacing: -0.02em; line-height: 1.15; color: var(--ink); }
.featured__title a { text-decoration: none; color: inherit; }
.featured__title a:hover { color: var(--red); }
.featured__excerpt { font-size: 1rem; line-height: 1.7; color: var(--ink); }
.featured__meta { font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.08em; color: var(--mid); display: flex; flex-wrap: wrap; gap: var(--space-s); }
.featured__cta { display: inline-block; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink); text-decoration: none; border-bottom: 2px solid var(--red); padding-bottom: 2px; margin-top: var(--space-xs); }
.featured__cta:hover { color: var(--red); }
.signal-feed { padding-block: var(--space-xl); border-top: 1px solid var(--rule); background-color: var(--paper-tint); }
.signal-feed__grid { display: grid; grid-template-columns: 1fr; gap: 0; list-style: none; padding: 0; }
@media (min-width: 768px) {
.signal-feed__grid {
grid-template-columns: 1fr 1fr;
}
}
@media (min-width: 1060px) {
.signal-feed__grid {
grid-template-columns: repeat(3, 1fr);
}
}
.feed-item { padding: var(--space-m); border: 1px solid var(--rule); margin: -1px 0 0 -1px; display: flex; flex-direction: column; gap: var(--space-xs); background-color: var(--paper); }
.feed-item:hover { background-color: var(--paper-tint); }
.feed-item__vertical { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--red); }
.feed-item__title { font-family: var(--font-display); font-size: 1.05rem; font-weight: 700; line-height: 1.3; color: var(--ink); }
.feed-item__title a { text-decoration: none; color: inherit; }
.feed-item__title a:hover { color: var(--red); }
.feed-item__desc { font-size: 0.88rem; line-height: 1.55; color: var(--mid); margin-bottom: 0; }
.feed-item__meta { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.08em; color: var(--light); margin-top: auto; padding-top: var(--space-xs); }
.manifesto { padding-block: var(--space-xxl); border-top: 1px solid var(--rule); }
.manifesto__inner { max-width: 720px; margin-inline: auto; text-align: center; }
.manifesto__rule { width: 48px; height: 2px; background-color: var(--red); margin: 0 auto var(--space-l); }
.manifesto__text { font-family: var(--font-display); font-size: clamp(1.25rem, 2.5vw, 1.75rem); font-style: italic; font-weight: 400; line-height: 1.55; color: var(--ink); letter-spacing: -0.01em; margin-bottom: var(--space-m); }
.manifesto__sub { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mid); }
.decode-preview { padding-block: var(--space-xl); border-top: 3px solid var(--ink); background-color: var(--paper); }
.decode-preview__header { display: grid; grid-template-columns: 1fr; gap: var(--space-m); margin-bottom: var(--space-l); padding-bottom: var(--space-l); border-bottom: 1px solid var(--rule); }
@media (min-width: 700px) {
.decode-preview__header {
grid-template-columns: 1fr 1fr;
align-items: end;
}
}
.decode-preview__intro { font-size: 0.95rem; line-height: 1.7; color: var(--mid); }
.decode-preview__browse { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase; text-decoration: none; color: var(--link); text-align: right; display: block; }
.decode-preview__browse:hover { color: var(--red); }
.decode-cards { display: grid; grid-template-columns: 1fr; gap: var(--space-s); list-style: none; padding: 0; }
@media (min-width: 640px) {
.decode-cards {
grid-template-columns: repeat(2, 1fr);
}
}
@media (min-width: 960px) {
.decode-cards {
grid-template-columns: repeat(3, 1fr);
}
}
.decode-card { border-top: 2px solid var(--ink); padding: var(--space-m) 0; display: flex; flex-direction: column; gap: var(--space-xs); }
.decode-card__type { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mid); }
.decode-card__chinese { font-family: var(--font-display); font-size: 1.6rem; color: var(--ink); line-height: 1; margin-bottom: 0.1rem; }
.decode-card__pinyin { font-family: var(--font-mono); font-size: 0.72rem; color: var(--mid); letter-spacing: 0.05em; }
.decode-card__title { font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; line-height: 1.25; color: var(--ink); }
.decode-card__title a { text-decoration: none; color: inherit; }
.decode-card__title a:hover { color: var(--red); }
.decode-card__mistranslation { font-size: 0.85rem; color: var(--mid); font-style: italic; margin-bottom: 0; }
.decode-card__mistranslation strong { font-style: normal; font-weight: 400; color: var(--light); text-decoration: line-through; }
.newsletter { background-color: var(--ink); color: var(--paper); padding-block: var(--space-xl); border-top: 3px solid var(--red); }
.newsletter__inner { display: grid; grid-template-columns: 1fr; gap: var(--space-l); align-items: center; }
@media (min-width: 700px) {
.newsletter__inner {
grid-template-columns: 1fr auto;
gap: var(--space-xl);
}
}
.newsletter__label { font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--red); display: block; margin-bottom: var(--space-xs); }
.newsletter__title { font-family: var(--font-display); font-size: clamp(1.25rem, 2.5vw, 1.75rem); font-weight: 700; color: var(--paper); margin-bottom: var(--space-xs); }
.newsletter__desc { font-size: 0.92rem; color: rgba(247, 244, 238, 0.6); margin-bottom: 0; font-weight: 300; }
.newsletter__form { display: flex; flex-direction: column; gap: var(--space-xs); min-width: 280px; }
.newsletter__input { background-color: rgba(247, 244, 238, 0.08); border: 1px solid rgba(247, 244, 238, 0.2); color: var(--paper); font-family: var(--font-body); font-size: 0.95rem; padding: 0.65rem var(--space-s); width: 100%; }
.newsletter__input::placeholder { color: rgba(247, 244, 238, 0.35); }
.newsletter__input:focus { outline: 2px solid var(--red); outline-offset: 2px; border-color: var(--red); }
.newsletter__submit { background-color: var(--red); color: var(--paper); border: none; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; padding: 0.65rem var(--space-m); cursor: pointer; width: 100%; }
.newsletter__submit:hover { background-color: #9a2828; }
.newsletter__note { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.06em; color: rgba(247, 244, 238, 0.3); }
.site-footer { background-color: var(--ink); color: var(--paper); padding-block: var(--space-xl) var(--space-l); border-top: 1px solid rgba(212, 207, 197, 0.12); }
.site-footer__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-l); padding-bottom: var(--space-l); border-bottom: 1px solid rgba(212, 207, 197, 0.12); margin-bottom: var(--space-m); }
@media (min-width: 640px) {
.site-footer__grid {
grid-template-columns: repeat(2, 1fr);
}
}
@media (min-width: 960px) {
.site-footer__grid {
grid-template-columns: repeat(4, 1fr);
}
}
.footer-col__heading { font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(247, 244, 238, 0.45); margin-bottom: var(--space-s); }
.footer-col p { font-size: 0.88rem; color: rgba(247, 244, 238, 0.55); line-height: 1.6; margin-bottom: var(--space-xs); }
.footer-col__nav a { font-size: 0.88rem; color: rgba(247, 244, 238, 0.55); text-decoration: none; }
.footer-col__nav a:visited { color: rgba(247, 244, 238, 0.45); }
.footer-form__input { background-color: rgba(247, 244, 238, 0.06); border: 1px solid rgba(247, 244, 238, 0.15); color: var(--paper); font-family: var(--font-body); font-size: 0.88rem; padding: 0.55rem 0.75rem; }
.footer-form__input::placeholder { color: rgba(247, 244, 238, 0.25); }
.footer-form__submit { background-color: transparent; border: 1px solid rgba(247, 244, 238, 0.25); color: rgba(247, 244, 238, 0.6); font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.12em; text-transform: uppercase; padding: 0.55rem 0.75rem; cursor: pointer; }
.site-footer__copyright { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.08em; color: rgba(247, 244, 238, 0.3); }
.site-footer__editorial { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.08em; color: rgba(247, 244, 238, 0.3); text-decoration: none; }
hr.section-rule { border: none; border-top: 1px solid var(--rule); margin: 0; }

@media print {
  a { color: black; text-decoration: underline; }
  figure, table { page-break-inside: avoid; }
}
