* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-width: 1440px;
  background: #D8C7B5;
  color: #1F2933;
  font-family: "Noto Sans SC", "Microsoft YaHei", "PingFang SC", Arial, sans-serif;
  letter-spacing: 0;
}

body {
  overflow-x: auto;
}

a {
  color: inherit;
  text-decoration: none;
}

p,
h1,
h2,
h3,
figure,
ul,
ol {
  margin: 0;
}

ul,
ol {
  padding: 0;
  list-style: none;
}

.home-page {
  width: 1440px;
  margin: 0 auto;
  overflow: hidden;
  background: linear-gradient(90deg, #D8C7B5 0%, #F1E4D4 100%);
  outline: 1px solid rgba(203, 182, 159, 0.88);
  box-shadow: 0 10px 24px -10px rgba(107, 79, 54, 0.06);
}

.home-page a {
  color: inherit;
  display: block;
}

.text-ellipsis {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.home-page .line2,
.home-page .line3 {
  display: -webkit-box;
}

.container {
  width: 1200px;
  margin: 0 auto;
}

.tag {
  display: inline-flex!important;
  align-items: center;
  justify-content: center;
  height: 24px;
  padding: 0 10px;
  color: #8A7661!important;
  font-size: 12px;
  font-weight: 500;
  line-height: 14px;
  white-space: nowrap;
  border-radius: 4px;
}

.tag-fill {
  background: #D8C8B8;
}

.tag-outline {
  background: linear-gradient(90deg, #D8C7B5 0%, #F1E4D4 100%);
  border: 1px solid rgba(203, 182, 159, 0.88);
}

.image-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: linear-gradient(90deg, #D8C7B5 0%, #F1E4D4 100%);
  border: 1px solid rgba(203, 182, 159, 0.88);
  color: #8A7661;
  font-size: 13px;
  font-weight: 400;
  line-height: 16px;
  text-align: center;
}

.image-placeholder img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (min-width: 769px) and (max-width: 1439px) {
  html,
  body {
    min-width: 0;
  }

  body {
    overflow-x: hidden;
  }

  .home-page {
    width: 100%;
    min-height: 0;
  }

  .container {
    width: calc(100% - 80px);
    max-width: 1200px;
  }
}

@media (max-width: 768px) {
  html,
  body {
    min-width: 0;
  }

  body {
    overflow-x: hidden;
  }

  .home-page {
    width: 100%;
    min-height: 0;
  }

  .container {
    width: auto;
    margin-right: 16px;
    margin-left: 16px;
  }
}

@media (max-width: 480px) {
  .container {
    margin-right: 12px;
    margin-left: 12px;
  }
}

.culture-utility-bar {
  height: 38px;
  background: #EFE2D2;
}

.utility-inner {
  display: flex;
  align-items: center;
  height: 100%;
  overflow: hidden;
  background: #EFE1D1;
  color: #8A7661;
  font-size: 12px;
  font-weight: 400;
  line-height: 14px;
  white-space: nowrap;
}

.utility-inner time {
  flex: 0 0 auto;
  margin-right: 23px;
}

.utility-inner strong {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  height: 24px;
  margin-right: auto;
  padding: 0 10px;
  background: #F6E8D6;
  font-weight: 500;
}

.utility-inner nav {
  display: flex;
  gap: 24px;
  margin-left: auto;
}

.brand-header {
  height: 112px;
  background: #F7F1E8;
  border: 1px solid rgba(217, 200, 181, 0.85);
}

.brand-inner {
  position: relative;
  height: 100%;
  background: #F7F1E8;
  /* border: 1px solid rgba(217, 200, 181, 0.85); */
}

.brand-lockup {
  position: absolute;
  top: 17.5px;
  left: 0;
  width: 210px;
  height: 75px;
}

.brand-lockup h1 {
  height: 50px;
  color: #243136;
  font-size: 42px;
  font-weight: 500;
  line-height: 50px;
  white-space: nowrap;
}

.brand-lockup p {
  height: 17px;
  margin-top: 8px;
  color: #9A5A3C;
  font-size: 14px;
  font-weight: 500;
  line-height: 17px;
  white-space: nowrap;
}

.coordinate-line {
  position: absolute;
  top: 51px;
  left: 430px;
  width: 332px;
  height: 8px;
  background: #C9B39D;
}

.header-tools {
  position: absolute;
  top: 43px;
  right: 0;
  display: flex;
  gap: 10px;
}

.header-tools .tag {
  width: 66px;
  padding: 0;
}

.culture-navigation {
  height: 7px;
  background: #C9B39D;
}

@media (min-width: 1025px) and (max-width: 1439px) {
  .coordinate-line {
    left: 36%;
    width: min(332px, 26%);
  }
}

@media (min-width: 769px) and (max-width: 1024px) {
  .culture-utility-bar {
    height: auto;
  }

  .utility-inner {
    min-height: 38px;
    padding: 8px 0;
    flex-wrap: wrap;
    gap: 8px 20px;
    white-space: normal;
  }

  .utility-inner time,
  .utility-inner strong,
  .utility-inner nav {
    margin: 0;
  }

  .utility-inner nav {
    gap: 20px;
  }

  .brand-header {
    height: auto;
  }

  .brand-inner {
    position: static;
    display: grid;
    grid-template-columns: minmax(230px, 1fr) auto;
    gap: 14px 24px;
    height: auto;
    padding: 17px 0;
    align-items: center;
  }

  .brand-lockup,
  .coordinate-line,
  .header-tools {
    position: static;
  }

  .brand-lockup {
    width: auto;
    height: auto;
  }

  .coordinate-line {
    width: 100%;
    max-width: 332px;
    justify-self: end;
  }

  .header-tools {
    grid-column: 1 / -1;
    justify-self: end;
  }
}

@media (max-width: 768px) {
  .culture-utility-bar {
    height: auto;
  }

  .utility-inner {
    min-height: 38px;
    padding: 8px 0;
    flex-wrap: wrap;
    gap: 8px 14px;
    white-space: normal;
  }

  .utility-inner time,
  .utility-inner strong,
  .utility-inner nav {
    margin: 0;
  }

  .utility-inner nav {
    flex-wrap: wrap;
    gap: 10px 18px;
  }

  .brand-header {
    height: auto;
  }

  .brand-inner {
    position: static;
    display: flex;
    flex-direction: column;
    gap: 12px;
    height: auto;
    padding: 15px 0;
  }

  .brand-lockup,
  .coordinate-line,
  .header-tools {
    position: static;
  }

  .brand-lockup {
    width: auto;
    height: auto;
  }

  .brand-lockup h1 {
    height: auto;
    font-size: 34px;
    line-height: 42px;
  }

  .brand-lockup p {
    height: auto;
    margin-top: 4px;
    white-space: normal;
  }

  .coordinate-line {
    width: 100%;
    height: 6px;
  }

  .header-tools {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }
}

@media (max-width: 480px) {
  .utility-inner {
    display: block;
  }

  .utility-inner strong,
  .utility-inner nav {
    margin-top: 8px;
  }

  .utility-inner nav {
    display: flex;
  }

  .brand-lockup h1 {
    font-size: 31px;
    line-height: 39px;
  }
}

.main-band {
  background: #F7F1E8;
  padding-top: calc(47px + 157px);
  padding-bottom: 47px;
}

.main-content {
  width: 1200px;
  margin: 0 auto;
  background: #F7F1E8;
}

@media (min-width: 769px) and (max-width: 1439px) {
  .main-content {
    width: calc(100% - 80px);
    max-width: 1200px;
  }
}

@media (max-width: 768px) {
  .main-band {
    padding-top: 20px;
    padding-bottom: 28px;
  }

  .main-content {
    width: auto;
    margin: 0 16px;
  }
}

@media (max-width: 480px) {
  .main-content {
    margin-right: 12px;
    margin-left: 12px;
  }
}

.visual-story-hero {
  height: 690px;
  overflow: hidden;
  background: #F7F1E8;
  box-shadow: 0 10px 24px -10px rgba(107, 79, 54, 0.06);
}

.hero-top-row {
  display: grid;
  grid-template-columns: 728px 444px;
  gap: 28px;
  height: 446px;
  overflow: hidden;
}

.lead-image-frame {
  height: 446px;
  padding: 12px 15px;
  overflow: hidden;
  background: linear-gradient(90deg, #D8C7B5 0%, #F1E4D4 100%);
  border: 1px solid rgba(203, 182, 159, 0.88);
}

.lead-image {
  height: 392px;
}

.lead-image-frame figcaption {
  height: 20px;
  margin-top: 10px;
  overflow: hidden;
  color: #8A7661;
  font-size: 13px;
  font-weight: 400;
  line-height: 20px;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.lead-story-text {
  height: 446px;
  overflow: hidden;
  background: #F7F1E8;
  box-shadow: 0 10px 24px -10px rgba(107, 79, 54, 0.06);
}

.lead-region-tags {
  display: flex;
  gap: 8px;
  height: 24px;
  overflow: hidden;
}

.lead-region-tags .wide {
  width: 66px;
}

.lead-story-text h2 {
  height: 104px;
  margin-top: 18px;
  overflow: hidden;
  color: #263238;
  font-size: 40px;
  font-weight: 500;
  line-height: 52px;
}

.lead-story-text > p {
  height: 84px;
  margin-top: 18px;
  overflow: hidden;
  color: #5E6A66;
  font-size: 16px;
  font-weight: 400;
  line-height: 28px;
}

.editor-note {
  height: 114px;
  margin-top: 18px;
  padding: 14px 15px;
  overflow: hidden;
  background: #FBF8F2;
  border: 1px solid rgba(217, 200, 181, 0.85);
}

.editor-note strong {
  display: block;
  height: 16px;
  color: #8A7661;
  font-size: 13px;
  font-weight: 500;
  line-height: 16px;
}

.editor-note p {
  height: 48px;
  margin-top: 8px;
  overflow: hidden;
  color: #5E6A66;
  font-size: 14px;
  font-weight: 400;
  line-height: 24px;
}

.extended-link {
  display: block;
  height: 48px;
  margin-top: 18px;
  padding: 12px 16px;
  overflow: hidden;
  background: #FBF8F2;
  border: 1px solid #DDD2C4;
  color: #9A5A3C;
  font-size: 15px;
  font-weight: 500;
  line-height: 24px;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.small-story-strip {
  display: grid;
  grid-template-columns: repeat(3, 388px);
  gap: 18px;
  height: 220px;
  margin-top: 24px;
  overflow: hidden;
}

.small-story-strip article {
  height: 220px;
  padding: 13px;
  overflow: hidden;
  background: #FBF8F2;
  border: 1px solid rgba(217, 200, 181, 0.85);
  box-shadow: 0 10px 24px -10px rgba(107, 79, 54, 0.06);
}

.small-image {
  height: 128px;
}

.small-story-strip p {
  height: 14px;
  margin-top: 12px;
  overflow: hidden;
  color: #8A7661;
  font-size: 12px;
  font-weight: 500;
  line-height: 14px;
  white-space: nowrap;
}

.small-story-strip h3 {
  height: 26px;
  margin-top: 10px;
  overflow: hidden;
  color: #3B3128;
  font-size: 18px;
  font-weight: 500;
  line-height: 26px;
  white-space: nowrap;
  text-overflow: ellipsis;
}

@media (min-width: 769px) and (max-width: 1180px) {
  .visual-story-hero {
    height: auto;
    overflow: visible;
  }

  .hero-top-row {
    grid-template-columns: minmax(0, 1.25fr) minmax(330px, 0.8fr);
    height: auto;
    overflow: visible;
  }

  .lead-image-frame,
  .lead-story-text {
    height: auto;
    min-height: 446px;
  }

  .lead-story-text h2,
  .lead-story-text > p,
  .editor-note p {
    height: auto;
  }

  .small-story-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    height: auto;
    overflow: visible;
  }

  .small-story-strip article {
    height: auto;
    min-height: 220px;
  }
}

@media (max-width: 768px) {
  .visual-story-hero {
    height: auto;
    overflow: visible;
  }

  .hero-top-row {
    display: block;
    height: auto;
    overflow: visible;
  }

  .lead-image-frame {
    height: auto;
    padding: 12px;
    overflow: visible;
  }

  .lead-image {
    height: 210px;
  }

  .lead-image-frame figcaption {
    height: auto;
    white-space: normal;
  }

  .lead-story-text {
    height: auto;
    margin-top: 18px;
    overflow: visible;
  }

  .lead-region-tags {
    height: auto;
    flex-wrap: wrap;
    overflow: visible;
  }

  .lead-story-text h2 {
    height: auto;
    margin-top: 14px;
    font-size: 28px;
    line-height: 38px;
  }

  .lead-story-text > p,
  .editor-note,
  .editor-note p,
  .extended-link {
    height: auto;
  }

  .lead-story-text > p {
    margin-top: 12px;
    font-size: 15px;
    line-height: 25px;
  }

  .small-story-strip {
    grid-template-columns: 1fr;
    height: auto;
    margin-top: 18px;
    overflow: visible;
  }

  .small-story-strip article {
    height: auto;
  }

  .small-story-strip h3 {
    height: auto;
    white-space: normal;
  }
}

@media (max-width: 480px) {
  .lead-image {
    height: 172px;
  }

  .lead-story-text h2 {
    font-size: 24px;
    line-height: 32px;
  }

  .small-image {
    height: 112px;
  }
}

.regional-topic-guide {
  height: 228px;
  margin-top: 56px;
  overflow: hidden;
  background: #F7F1E8;
}

.section-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  height: 30px;
}

.section-head h2 {
  position: relative;
  height: 30px;
  padding-left: 16px;
  color: #3B3128;
  font-size: 22px;
  font-weight: 500;
  line-height: 30px;
}

.section-head h2::before {
  content: "";
  position: absolute;
  top: 5px;
  left: 0;
  width: 5px;
  height: 20px;
  background: #9A5A3C;
}

.section-head p {
  margin-top: 7px;
  color: #8A7661;
  font-size: 13px;
  font-weight: 400;
  line-height: 16px;
}

.region-topic-cards {
  display: grid;
  grid-template-columns: repeat(6, 186px);
  gap: 16px;
  height: 178px;
  margin-top: 20px;
  overflow: hidden;
}

.region-topic-cards article {
  height: 178px;
  padding: 13px;
  overflow: hidden;
  background: #FBF8F2;
  border: 1px solid rgba(217, 200, 181, 0.85);
  box-shadow: 0 10px 24px -10px rgba(107, 79, 54, 0.06);
}

.topic-image {
  height: 88px;
}

.region-topic-cards h3 {
  height: 22px;
  margin-top: 12px;
  overflow: hidden;
  color: #3B3128;
  font-size: 18px;
  font-weight: 500;
  line-height: 22px;
  white-space: nowrap;
}

.region-topic-cards p {
  height: 16px;
  margin-top: 12px;
  overflow: hidden;
  color: #8A7661;
  font-size: 13px;
  font-weight: 400;
  line-height: 16px;
  white-space: nowrap;
}

@media (min-width: 769px) and (max-width: 1180px) {
  .regional-topic-guide {
    height: auto;
    overflow: visible;
  }

  .region-topic-cards {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    height: auto;
    overflow: visible;
  }
}

@media (max-width: 768px) {
  .regional-topic-guide {
    height: auto;
    margin-top: 28px;
    overflow: visible;
  }

  .section-head {
    height: auto;
    gap: 12px;
  }

  .section-head h2 {
    height: auto;
    font-size: 20px;
    line-height: 28px;
  }

  .section-head p {
    text-align: right;
  }

  .region-topic-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    height: auto;
    gap: 14px;
    margin-top: 16px;
    overflow: visible;
  }
}

@media (max-width: 480px) {
  .region-topic-cards {
    grid-template-columns: 1fr;
  }
}

.main-feature-story {
  display: grid;
  grid-template-columns: 520px minmax(0, 596px);
  gap: 28px;
  height: 344px;
  margin-top: 56px;
  padding: 26px;
  overflow: hidden;
  background: #FBF8F2;
  box-shadow: 0 10px 24px -10px rgba(107, 79, 54, 0.06);
}

.feature-image {
  height: 292px;
}

.feature-text {
  min-width: 0;
  height: 254px;
  overflow: hidden;
}

.eyebrow {
  height: 16px;
  overflow: hidden;
  color: #8A7661;
  font-size: 13px;
  font-weight: 500;
  line-height: 16px;
  white-space: nowrap;
}

.feature-text h2 {
  height: 40px;
  margin-top: 16px;
  overflow: hidden;
  color: #263238;
  font-size: 30px;
  font-weight: 500;
  line-height: 40px;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.feature-summary {
  height: 54px;
  margin-top: 16px;
  overflow: hidden;
  color: #5E6A66;
  font-size: 15px;
  font-weight: 400;
  line-height: 27px;
}

.deep-story-list {
  margin-top: 16px;
}

.deep-story-list li {
  display: grid;
  grid-template-columns: 26px minmax(0, 1fr);
  gap: 12px;
  height: 24px;
  align-items: center;
}

.deep-story-list li + li {
  margin-top: 12px;
}

.deep-story-list span {
  color: #8A7661;
  font-size: 13px;
  font-weight: 500;
  line-height: 16px;
}

.deep-story-list a {
  overflow: hidden;
  color: #1F2933;
  font-size: 16px;
  font-weight: 400;
  line-height: 24px;
  white-space: nowrap;
  text-overflow: ellipsis;
}

@media (min-width: 769px) and (max-width: 1180px) {
  .main-feature-story {
    grid-template-columns: minmax(300px, 0.85fr) minmax(0, 1fr);
    height: auto;
    overflow: visible;
  }

  .feature-image {
    height: 260px;
  }

  .feature-text,
  .feature-text h2,
  .feature-summary {
    height: auto;
  }
}

@media (max-width: 768px) {
  .main-feature-story {
    display: block;
    height: auto;
    margin-top: 28px;
    padding: 15px;
    overflow: visible;
  }

  .feature-image {
    height: 190px;
  }

  .feature-text {
    height: auto;
    margin-top: 16px;
    overflow: visible;
  }

  .feature-text h2 {
    height: auto;
    font-size: 24px;
    line-height: 32px;
    white-space: normal;
  }

  .feature-summary {
    height: auto;
  }

  .deep-story-list li {
    height: auto;
    align-items: flex-start;
  }

  .deep-story-list a {
    white-space: normal;
  }
}

@media (max-width: 480px) {
  .main-feature-story {
    padding: 13px;
  }

  .feature-image {
    height: 158px;
  }
}

.slow-reading-ranking {
  display: grid;
  grid-template-columns: 570px 546px;
  gap: 36px;
  height: 508px;
  margin-top: 56px;
  padding: 24px;
  overflow: hidden;
  background: #FBF8F2;
  box-shadow: 0 10px 24px -10px rgba(107, 79, 54, 0.06);
}

.editor-picks,
.slow-reading-list {
  min-width: 0;
  overflow: hidden;
}

.editor-picks h2,
.slow-reading-list h2 {
  height: 26px;
  overflow: hidden;
  color: #3B3128;
  font-size: 22px;
  font-weight: 500;
  line-height: 26px;
}

.editor-list {
  margin-top: 14px;
}

.editor-list li {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 12px;
  height: 24px;
  align-items: center;
}

.editor-list li + li {
  margin-top: 20px;
}

.editor-list span {
  color: #8A7661;
  font-size: 13px;
  font-weight: 500;
  line-height: 16px;
}

.editor-list a {
  overflow: hidden;
  color: #1F2933;
  font-size: 16px;
  font-weight: 400;
  line-height: 24px;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.slow-reading-list ol {
  margin-top: 14px;
}

.slow-reading-list li {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  height: 47px;
  padding: 0 12px;
  background: #FBF8F2;
}

.slow-reading-list li:nth-child(odd) {
  background: #F4EFE6;
}

.slow-reading-list li + li {
  margin-top: 14px;
}

.slow-reading-list span {
  color: #9A5A3C;
  font-size: 14px;
  font-weight: 500;
  line-height: 17px;
}

.slow-reading-list a {
  overflow: hidden;
  color: #1F2933;
  font-size: 15px;
  font-weight: 400;
  line-height: 23px;
  white-space: nowrap;
  text-overflow: ellipsis;
}

@media (min-width: 769px) and (max-width: 1180px) {
  .slow-reading-ranking {
    grid-template-columns: 1fr;
    height: auto;
    overflow: visible;
  }

  .editor-picks,
  .slow-reading-list {
    overflow: visible;
  }

  .editor-list a,
  .slow-reading-list a {
    white-space: normal;
  }
}

@media (max-width: 768px) {
  .slow-reading-ranking {
    display: block;
    height: auto;
    margin-top: 28px;
    padding: 15px;
    overflow: visible;
  }

  .editor-picks,
  .slow-reading-list {
    overflow: visible;
  }

  .slow-reading-list {
    margin-top: 24px;
  }

  .editor-list li,
  .slow-reading-list li {
    height: auto;
    min-height: 28px;
    align-items: flex-start;
  }

  .editor-list a,
  .slow-reading-list a {
    white-space: normal;
  }
}

@media (max-width: 480px) {
  .slow-reading-ranking {
    padding: 13px;
  }

  .editor-list li,
  .slow-reading-list li {
    grid-template-columns: 30px minmax(0, 1fr);
  }
}

.site-footer {
  height: 196px;
  overflow: hidden;
  background: #263238;
}

.footer-inner {
  display: flex;
  justify-content: space-between;
  height: 124px;
  padding-top: 36px;
}

.footer-brand {
  width: 360px;
}

.footer-brand h2 {
  height: 34px;
  color: #FFFFFF;
  font-size: 28px;
  font-weight: 500;
  line-height: 34px;
}

.footer-brand p {
  height: 22px;
  margin-top: 10px;
  overflow: hidden;
  color: rgba(244, 233, 220, 0.84);
  font-size: 13px;
  font-weight: 400;
  line-height: 22px;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.footer-links {
  display: grid;
  grid-template-columns: repeat(3, 110px);
  gap: 42px;
  color: rgba(244, 233, 220, 0.84);
}

.footer-links h3 {
  height: 17px;
  color: rgba(244, 233, 220, 0.84);
  font-size: 14px;
  font-weight: 500;
  line-height: 17px;
}

.footer-links a {
  display: block;
  height: 23px;
  overflow: hidden;
  color: rgba(244, 233, 220, 0.84);
  font-size: 12px;
  font-weight: 400;
  line-height: 23px;
  white-space: nowrap;
}

.footer-links h3 + a {
  margin-top: 10px;
}

@media (min-width: 769px) and (max-width: 1024px) {
  .site-footer {
    height: auto;
    min-height: 196px;
  }

  .footer-inner {
    height: auto;
    padding: 32px 0;
  }

  .footer-links {
    gap: 24px;
  }
}

@media (max-width: 768px) {
  .site-footer {
    height: auto;
  }

  .footer-inner {
    display: block;
    height: auto;
    padding: 28px 0;
  }

  .footer-brand {
    width: auto;
  }

  .footer-brand p {
    height: auto;
    white-space: normal;
  }

  .footer-links {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    margin-top: 24px;
  }
}

@media (max-width: 480px) {
  .footer-links {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}
