:root {
  --ink: #12100f;
  --paper: #f2efe8;
  --cream: #e6dfd2;
  --red: #b63a2d;
  --red-dark: #78261f;
  --line: rgba(18, 16, 15, .18);
  --muted: #766f67;
  --sidebar: 232px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: "PingFang SC", "Noto Sans CJK SC", "Microsoft YaHei", sans-serif; }
button, input { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
a { color: inherit; text-decoration: none; }
img { display: block; width: 100%; }

.noise { position: fixed; inset: 0; z-index: 100; pointer-events: none; opacity: .18; mix-blend-mode: multiply; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.15'/%3E%3C/svg%3E"); }
.sidebar { position: fixed; inset: 0 auto 0 0; width: var(--sidebar); z-index: 30; color: var(--paper); background: var(--ink); border-right: 1px solid #2e2a27; display: flex; flex-direction: column; }
.sidebar-close { display: none; position: absolute; right: 14px; top: 14px; z-index: 2; width: 36px; height: 36px; border: 1px solid #514a45; border-radius: 50%; color: #fff; background: transparent; cursor: pointer; font-size: 21px; }
.brand { min-height: 128px; padding: 28px 24px; display: flex; gap: 14px; align-items: center; border-bottom: 1px solid #37322f; }
.brand-mark { width: 48px; height: 48px; display: grid; place-items: center; border: 1px solid #655d56; border-radius: 50%; font: 700 21px/1 Georgia, serif; }
.brand-mark span { color: var(--red); font-size: 11px; transform: translateY(-9px); }
.brand-copy { display: flex; flex-direction: column; gap: 5px; }
.brand-copy b { letter-spacing: .18em; font-size: 15px; }
.brand-copy small { font: 9px/1.2 Arial, sans-serif; color: #8f8881; letter-spacing: .12em; white-space: nowrap; }
.side-nav { display: flex; flex-direction: column; padding: 25px 0; }
.side-nav a { position: relative; padding: 16px 24px; color: #8f8881; font-size: 13px; letter-spacing: .08em; transition: .25s; }
.side-nav a span { display: inline-block; width: 32px; color: #55504b; font: 10px Arial, sans-serif; }
.side-nav a::after { content: ""; position: absolute; right: 0; top: 50%; width: 0; height: 1px; background: var(--red); transition: .25s; }
.side-nav a:hover, .side-nav a.active { color: #fff; }
.side-nav a.active::after { width: 30px; }
.sidebar-foot { margin-top: auto; padding: 24px; color: #67615b; font: 9px/1.8 Arial, sans-serif; letter-spacing: .15em; border-top: 1px solid #37322f; }
.sidebar-foot p { margin: 0; }
.sidebar-foot span { display: block; color: var(--red); margin-top: 14px; }
main { margin-left: var(--sidebar); overflow: hidden; }
.section-pad { padding-left: clamp(32px, 6vw, 100px); padding-right: clamp(32px, 6vw, 100px); }
.topbar { height: 68px; padding: 0 clamp(28px, 4vw, 64px); display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--line); }
.topbar > p { margin: 0; font: 10px Arial, sans-serif; letter-spacing: .17em; }
.topbar > p i { width: 6px; height: 6px; display: inline-block; margin-right: 8px; border-radius: 50%; background: #55a15c; box-shadow: 0 0 0 4px rgba(85,161,92,.12); }
.top-actions { display: flex; gap: 8px; align-items: center; }
.icon-button, .saved-button, .menu-button, .add-button, .share-button { border: 0; background: transparent; cursor: pointer; color: inherit; }
.icon-button { width: 38px; height: 38px; font-size: 22px; }
.share-button { min-height: 38px; padding: 0 12px; display: inline-flex; align-items: center; gap: 7px; border: 1px solid var(--line); font-size: 10px; }
.share-button span { color: var(--red); font-size: 15px; }
.share-button b { font-weight: 400; }
.add-button { min-height: 38px; padding: 0 13px; border: 1px solid var(--ink); font-size: 10px; }
.add-button span { color: var(--red); font-size: 14px; }
.saved-button { min-height: 38px; padding: 0 12px; border: 1px solid var(--line); border-radius: 30px; font-size: 12px; }
.saved-button b { margin-left: 6px; color: var(--red); }
.saved-button[aria-pressed="true"] { background: var(--ink); color: #fff; }
.menu-button { display: none; }

.hero { min-height: calc(100vh - 68px); display: grid; grid-template-columns: minmax(360px, .85fr) minmax(440px, 1.15fr); gap: clamp(40px, 6vw, 100px); align-items: center; position: relative; padding-top: 70px; padding-bottom: 70px; }
.eyebrow { display: flex; align-items: center; gap: 14px; margin: 0 0 26px; font: 10px Arial, sans-serif; letter-spacing: .19em; }
.eyebrow span { padding-bottom: 5px; border-bottom: 1px solid var(--ink); }
.eyebrow i { color: var(--red); font: italic 21px Georgia, serif; }
.hero h1 { margin: 0; font: 400 clamp(88px, 10vw, 154px)/.78 "Songti SC", SimSun, serif; letter-spacing: -.08em; }
.hero h1 em { color: var(--red); font-weight: 400; padding-left: .42em; }
.hero-intro { width: min(450px, 100%); margin: 48px 0 35px; color: #4f4944; font-size: 14px; line-height: 2; }
.hero-cta { display: flex; gap: 24px; align-items: center; flex-wrap: wrap; }
.primary-button { min-width: 165px; padding: 15px 18px; color: #fff; background: var(--ink); display: flex; align-items: center; justify-content: space-between; font-size: 12px; transition: .25s; }
.primary-button:hover { background: var(--red); }
.text-button { border: 0; background: transparent; cursor: pointer; border-bottom: 1px solid var(--line); padding: 12px 0; font-size: 12px; }
.text-button span { color: var(--red); margin-left: 6px; }
.hero-radar { width: min(560px, 100%); margin-top: 42px; display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--ink); border-left: 1px solid var(--line); }
.hero-radar p { min-height: 82px; margin: 0; padding: 16px 12px; display: flex; flex-direction: column; justify-content: space-between; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.hero-radar b { color: var(--red); font: 400 34px/1 Georgia, serif; }
.hero-radar span { color: var(--muted); font-size: 9px; letter-spacing: .12em; }
.hero-visual { position: relative; max-width: 760px; justify-self: end; }
.hero-image-wrap { position: relative; overflow: hidden; background: #d5cec2; }
.hero-image-wrap::after { content: ""; position: absolute; inset: 0; box-shadow: inset 0 0 0 1px rgba(255,255,255,.35); pointer-events: none; }
.hero-image-wrap img { aspect-ratio: 4 / 3; object-fit: cover; filter: saturate(.72) contrast(1.03); transition: transform .8s ease; }
.hero-visual:hover img { transform: scale(1.02); }
.hero-stamp { position: absolute; right: 18px; bottom: 18px; width: 76px; height: 76px; color: #fff; border: 1px solid rgba(255,255,255,.7); border-radius: 50%; display: grid; place-content: center; text-align: center; font: 8px/1.25 Arial, sans-serif; letter-spacing: .13em; transform: rotate(8deg); }
.hero-stamp b { color: #f4c3b6; margin-top: 4px; }
.vertical-note { position: absolute; margin: 0; right: -27px; top: 50%; font: 8px Arial, sans-serif; letter-spacing: .12em; writing-mode: vertical-rl; color: var(--muted); }
.hero-caption { margin-top: 18px; display: flex; justify-content: space-between; gap: 20px; align-items: end; }
.hero-caption span { color: var(--muted); font-size: 10px; }
.hero-caption b { font: 400 16px "Songti SC", serif; }
.hero-index { position: absolute; right: -18px; bottom: -50px; color: rgba(18,16,15,.035); font: 400 240px/1 Georgia, serif; pointer-events: none; }

.ticker { background: var(--red); color: #fff; height: 46px; display: flex; align-items: center; overflow: hidden; white-space: nowrap; font: 10px Arial, sans-serif; letter-spacing: .16em; }
.ticker div { min-width: max-content; animation: ticker 24s linear infinite; }
.ticker i { padding: 0 34px; color: #e7b1a9; }
@keyframes ticker { to { transform: translateX(-100%); } }

.archive { padding-top: 110px; padding-bottom: 130px; }
.section-head { display: flex; align-items: end; justify-content: space-between; gap: 30px; padding-bottom: 34px; border-bottom: 1px solid var(--ink); }
.section-number { margin: 0 0 12px; color: var(--red); font: 9px Arial, sans-serif; letter-spacing: .18em; }
.section-head h2 { margin: 0; font: 400 clamp(38px, 4vw, 62px)/1 "Songti SC", SimSun, serif; }
.section-head > p { margin: 0 0 4px; color: var(--muted); font-size: 11px; }
.section-head > p b { color: var(--red); font-size: 16px; }
.archive-tools { min-height: 95px; display: flex; align-items: center; justify-content: space-between; gap: 30px; }
.filters { display: flex; gap: 8px; flex-wrap: wrap; }
.filters button { border: 1px solid var(--line); background: transparent; border-radius: 30px; padding: 9px 15px; font-size: 11px; cursor: pointer; transition: .2s; }
.filters button:hover, .filters button.active { color: #fff; background: var(--ink); border-color: var(--ink); }
.search-field { width: 250px; height: 40px; display: flex; align-items: center; gap: 8px; border-bottom: 1px solid var(--ink); }
.search-field span { font-size: 18px; }
.search-field input { min-width: 0; width: 100%; border: 0; outline: 0; background: transparent; font-size: 11px; }
.platform-row { min-height: 58px; margin: -8px 0 34px; display: flex; align-items: center; gap: 22px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.platform-row > span { color: var(--muted); font-size: 9px; letter-spacing: .12em; }
.platform-filters { display: flex; gap: 4px; flex-wrap: wrap; }
.platform-filters button { padding: 5px 10px; border: 0; border-radius: 20px; color: var(--muted); background: transparent; cursor: pointer; font-size: 10px; }
.platform-filters button.active { color: #fff; background: var(--red); }
.card-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 38px 18px; }
.moment-card { grid-column: span 4; min-width: 0; }
.moment-card:nth-child(7n + 1), .moment-card:nth-child(7n + 5) { grid-column: span 6; }
.card-image { position: relative; overflow: hidden; background: #d9d3c8; cursor: zoom-in; }
.card-image img { aspect-ratio: 16 / 11; object-fit: cover; filter: saturate(.78); transition: transform .6s ease, filter .3s; }
.moment-card:nth-child(7n + 1) .card-image img, .moment-card:nth-child(7n + 5) .card-image img { aspect-ratio: 16 / 10; }
.moment-card:hover .card-image img { transform: scale(1.025); filter: saturate(1); }
.card-badge { position: absolute; left: 12px; top: 12px; color: #fff; background: rgba(18,16,15,.72); backdrop-filter: blur(8px); padding: 6px 8px; font: 8px Arial, sans-serif; letter-spacing: .12em; }
.card-save { position: absolute; right: 10px; top: 10px; width: 34px; height: 34px; border: 0; border-radius: 50%; background: rgba(242,239,232,.86); cursor: pointer; font-size: 17px; }
.card-save.saved { color: #fff; background: var(--red); }
.play-dot { position: absolute; left: 50%; top: 50%; width: 52px; height: 52px; transform: translate(-50%,-50%); border: 1px solid rgba(255,255,255,.8); border-radius: 50%; color: #fff; display: grid; place-items: center; background: rgba(0,0,0,.12); backdrop-filter: blur(2px); opacity: 0; transition: .25s; }
.card-image:hover .play-dot { opacity: 1; }
.card-meta { display: flex; justify-content: space-between; gap: 14px; color: var(--muted); padding: 12px 0 9px; font: 8px Arial, sans-serif; letter-spacing: .1em; border-bottom: 1px solid var(--line); }
.moment-card h3 { margin: 12px 0 6px; font: 500 16px/1.55 "Songti SC", serif; }
.moment-card > p { margin: 0; color: var(--muted); font-size: 11px; line-height: 1.8; }
.empty-state { padding: 90px 0; text-align: center; color: var(--muted); }
.empty-state span { font-size: 40px; }
.empty-state h3 { margin: 16px 0 4px; color: var(--ink); font: 400 22px serif; }
.empty-state p { font-size: 12px; }

.social { padding-top: 110px; padding-bottom: 125px; color: var(--paper); background: #171311; }
.social-head { border-color: #4a403b; }
.social-head > p { color: #867c75; }
.account-strip { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; margin-top: 46px; background: #453b36; border: 1px solid #453b36; }
.account-card { min-height: 126px; padding: 24px; display: flex; align-items: center; gap: 18px; background: #211b18; transition: background .25s; }
.account-card:hover { background: #2b211e; }
.account-avatar { flex: 0 0 57px; width: 57px; height: 57px; display: grid; place-items: center; border: 1px solid #7a504a; border-radius: 50%; color: #fff; background: var(--red-dark); font: 400 23px "Songti SC", serif; }
.pu-avatar { color: var(--ink); background: var(--cream); }
.topic-card .account-avatar { color: var(--red); background: transparent; font-family: Georgia, serif; }
.account-card div { min-width: 0; display: flex; flex-direction: column; gap: 5px; }
.account-card small { color: #827872; font-size: 9px; }
.account-card b { font: 400 17px "Songti SC", serif; }
.account-card em { color: #ad756d; font-size: 9px; font-style: normal; }
.social-layout { display: grid; grid-template-columns: 1fr 310px; gap: 70px; margin-top: 66px; }
.weibo-feed { border-top: 1px solid #534943; }
.weibo-post { padding: 27px 0 28px; border-bottom: 1px solid #403834; }
.weibo-post.featured { padding: 32px; background: #211b18; border: 1px solid #4c403b; }
.weibo-post header { display: flex; align-items: center; gap: 12px; }
.wb-logo { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 50%; color: #fff; background: var(--red); font: italic 10px Georgia, serif; }
.weibo-post header div { display: flex; flex-direction: column; gap: 3px; }
.weibo-post header b { font-size: 12px; }
.weibo-post header small { color: #7d746e; font-size: 9px; }
.weibo-post header > em { margin-left: auto; padding: 4px 7px; border: 1px solid #594c46; border-radius: 20px; color: #a99990; font-size: 8px; font-style: normal; }
.weibo-post > p { margin: 20px 0 16px 46px; max-width: 730px; color: #b0a6a0; font-size: 12px; line-height: 2; }
.post-tags { margin: 0 0 18px 46px; display: flex; flex-wrap: wrap; gap: 6px; }
.post-tags span { color: #b37369; font-size: 9px; }
.weibo-post > a { margin-left: 46px; display: inline-flex; gap: 55px; padding-bottom: 7px; border-bottom: 1px solid #65504a; color: #d3c5bd; font-size: 9px; }
.social-note { align-self: start; position: sticky; top: 30px; padding-left: 34px; border-left: 1px solid #453c37; }
.pulse-orbit { width: 190px; height: 190px; margin-bottom: 45px; display: grid; place-content: center; text-align: center; border: 1px solid #594842; border-radius: 50%; position: relative; }
.pulse-orbit::after { content: ""; position: absolute; inset: 17px; border: 1px dashed #493d38; border-radius: 50%; }
.pulse-orbit span, .pulse-orbit i { color: #776a64; font: 8px Arial, sans-serif; letter-spacing: .18em; }
.pulse-orbit b { color: var(--red); font: 400 62px/1 Georgia, serif; }
.social-note h3 { margin: 0 0 24px; font: 400 24px "Songti SC", serif; }
.social-note p { color: #988d86; font-size: 10px; line-height: 1.9; }
.social-note p b { color: #ddd1ca; }
.social-note .note-small { margin-top: 24px; padding-top: 18px; border-top: 1px solid #403733; color: #6f6661; }

.instagram { padding-top: 110px; padding-bottom: 125px; }
.insta-head { border-color: var(--ink); }
.insta-layout { display: grid; grid-template-columns: minmax(0, 1.4fr) minmax(280px, .6fr); gap: 70px; margin-top: 60px; }
.insta-collage { display: grid; grid-template-columns: 1.15fr .85fr; grid-template-rows: repeat(2, 300px); gap: 10px; }
.insta-tile { position: relative; overflow: hidden; background: var(--cream); }
.insta-tile.large { grid-row: 1 / 3; }
.insta-tile img { height: 100%; object-fit: cover; filter: saturate(.7); transition: .5s ease; }
.insta-tile:hover img { transform: scale(1.025); filter: saturate(1); }
.insta-tile::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 55%, rgba(18,16,15,.65)); }
.insta-tile > span { position: absolute; z-index: 1; left: 18px; right: 18px; bottom: 17px; display: flex; align-items: end; justify-content: space-between; gap: 15px; color: #fff; }
.insta-tile b { font: 11px Arial, sans-serif; letter-spacing: .16em; }
.insta-tile small { font-size: 9px; }
.insta-info { padding-top: 5px; }
.insta-wordmark { margin: 0 0 28px; color: var(--red); font: italic 24px Georgia, serif; }
.insta-info h3 { margin: 0 0 25px; font: 400 clamp(32px, 3vw, 48px)/1.25 "Songti SC", serif; }
.insta-info > p:not(.insta-wordmark) { color: var(--muted); font-size: 11px; line-height: 2; }
.insta-status { margin: 35px 0 28px; border-top: 1px solid var(--ink); }
.insta-status p { min-height: 66px; margin: 0; display: grid; grid-template-columns: 1fr 1fr auto; align-items: center; gap: 12px; border-bottom: 1px solid var(--line); }
.insta-status span { font: 9px Arial, sans-serif; letter-spacing: .12em; }
.insta-status b { font: 400 12px "Songti SC", serif; }
.insta-status em { color: var(--red); font: 7px Arial, sans-serif; font-style: normal; letter-spacing: .08em; }
.insta-info > button { min-height: 46px; width: 100%; padding: 0 16px; border: 1px solid var(--ink); color: #fff; background: var(--ink); cursor: pointer; font-size: 10px; }

.explore { color: #fff; background: var(--red-dark); padding-top: 105px; padding-bottom: 115px; }
.explore .section-head.light { border-color: #a85f56; }
.explore .section-head.light > p { color: #d6aaa4; }
.explore-grid { margin-top: 58px; display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid #b66a61; border-left: 1px solid #b66a61; }
.explore-grid a { min-height: 210px; position: relative; padding: 26px; display: flex; flex-direction: column; border-right: 1px solid #b66a61; border-bottom: 1px solid #b66a61; transition: background .25s, color .25s; }
.explore-grid a:hover { color: var(--ink); background: var(--paper); }
.explore-grid span { color: #dda9a2; font: 8px Arial, sans-serif; letter-spacing: .16em; }
.explore-grid a:hover span { color: var(--red); }
.explore-grid b { margin-top: auto; font: 400 27px "Songti SC", serif; }
.explore-grid p { margin: 8px 0 0; color: #d6aaa4; font-size: 10px; }
.explore-grid a:hover p { color: var(--muted); }
.explore-grid em { position: absolute; right: 22px; top: 22px; font: 20px Georgia, serif; font-style: normal; }
.source-standard { min-height: 62px; display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 16px; color: #d6aaa4; font-size: 9px; letter-spacing: .06em; }
.source-standard b { color: #fff; }
.source-standard i { color: #b66a61; }

.leads { padding-top: 110px; padding-bottom: 120px; background: #f7f2e9; }
.lead-board { margin-top: 54px; display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--ink); border-left: 1px solid var(--line); }
.lead-board article { min-height: 278px; padding: 28px; display: flex; flex-direction: column; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: rgba(255,255,255,.24); }
.lead-board article:nth-child(2n) { background: rgba(230,223,210,.45); }
.lead-board article > span { color: var(--red); font: 9px Arial, sans-serif; letter-spacing: .16em; }
.lead-board h3 { margin: 36px 0 14px; font: 400 27px/1.25 "Songti SC", serif; }
.lead-board p { margin: 0; color: var(--muted); font-size: 11px; line-height: 1.9; }
.lead-board div { margin-top: auto; display: flex; flex-wrap: wrap; gap: 8px; }
.lead-board a, .lead-board button { min-height: 38px; padding: 0 13px; display: inline-flex; align-items: center; border: 1px solid var(--ink); background: transparent; cursor: pointer; font-size: 10px; }
.lead-board button { color: #fff; background: var(--ink); }

.submit-panel { min-height: 330px; display: grid; grid-template-columns: minmax(0, 1fr) minmax(260px, .45fr); align-items: center; gap: 70px; color: #fff; background: var(--red); }
.submit-panel h2 { margin: 0 0 22px; font: 400 clamp(44px, 5vw, 74px)/1 "Songti SC", serif; }
.submit-panel p:not(.section-number) { max-width: 760px; margin: 0; color: #f0c9c2; font-size: 12px; line-height: 2; }
.submit-panel .section-number { color: #f4c7c0; }
.submit-actions { display: grid; gap: 12px; }
.submit-actions button, .submit-actions a { min-height: 54px; padding: 0 18px; display: flex; align-items: center; justify-content: space-between; border: 1px solid rgba(255,255,255,.78); color: #fff; background: transparent; cursor: pointer; font-size: 11px; }
.submit-actions button { color: var(--ink); background: var(--paper); border-color: var(--paper); }
.submit-actions span { font-size: 18px; }

.timeline { color: var(--paper); background: var(--ink); padding-top: 105px; padding-bottom: 120px; }
.section-head.light { border-color: #4b4540; }
.section-head.light > p { color: #837c75; }
.timeline-track { margin-top: 68px; display: grid; grid-template-columns: repeat(6, 1fr); border-top: 1px solid #524b45; }
.timeline-track article { position: relative; min-height: 260px; padding: 42px 28px 24px 0; border-right: 1px solid #393431; }
.timeline-track article::before { content: ""; position: absolute; left: 0; top: -5px; width: 9px; height: 9px; background: var(--red); border-radius: 50%; }
.timeline-track time { display: block; color: var(--red); font: 10px Arial, sans-serif; letter-spacing: .12em; margin-bottom: 45px; }
.timeline-track b { display: block; font: 400 20px "Songti SC", serif; margin-bottom: 16px; }
.timeline-track p { color: #928a83; font-size: 11px; line-height: 1.9; }

.profiles { padding-top: 115px; padding-bottom: 130px; }
.profile-layout { display: grid; grid-template-columns: 1fr 90px 1fr; gap: 20px; align-items: center; margin-top: 62px; }
.profile-card { display: grid; grid-template-columns: 1.15fr .85fr; background: var(--cream); min-height: 410px; }
.profile-card.pu { direction: rtl; }
.profile-card.pu > * { direction: ltr; }
.profile-photo { overflow: hidden; }
.profile-photo img { height: 100%; object-fit: cover; filter: grayscale(.2) saturate(.7); }
.profile-copy { padding: 34px 25px; display: flex; flex-direction: column; justify-content: end; }
.profile-copy span { color: var(--red); font: 9px Arial, sans-serif; letter-spacing: .15em; }
.profile-copy h3 { margin: 6px 0 20px; font: 400 42px "Songti SC", serif; }
.profile-copy p { margin: 0; color: var(--muted); font-size: 11px; line-height: 1.9; }
.profile-x { display: flex; align-items: center; flex-direction: column; color: var(--muted); gap: 12px; }
.profile-x span { font-size: 9px; writing-mode: vertical-rl; letter-spacing: .16em; }
.profile-x b { color: var(--red); font: italic 42px Georgia, serif; }
.name-map { margin-top: 55px; border-top: 1px solid var(--ink); }
.name-map p { margin: 0; min-height: 65px; display: grid; grid-template-columns: 100px 1fr 40px 1.4fr .8fr; align-items: center; border-bottom: 1px solid var(--line); }
.name-map span { color: var(--muted); font-size: 10px; }
.name-map b { font: 400 18px "Songti SC", serif; }
.name-map i { color: var(--red); }
.name-map em { text-align: right; color: var(--muted); font-size: 11px; }

.about { color: #fff; background: var(--red-dark); padding-top: 110px; }
.about .section-number { color: #e6a39a; }
.about-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 100px; padding: 30px 0 100px; }
.about h2 { margin: 0; font: 400 clamp(45px, 5.2vw, 78px)/1.2 "Songti SC", serif; }
.about h2 em { color: #e9aaa1; font-weight: 400; }
.about-grid > div { padding-top: 16px; }
.about-grid p { color: #d5b3ae; font-size: 12px; line-height: 2; margin: 0 0 18px; }
.about-grid a { display: inline-flex; gap: 60px; border-bottom: 1px solid #c98076; padding: 14px 0; font-size: 11px; }
.about-links { display: flex; flex-direction: column; align-items: flex-start; }
.about footer { min-height: 92px; display: flex; align-items: center; justify-content: space-between; gap: 20px; color: #c58c84; border-top: 1px solid #a35b51; font: 9px Arial, sans-serif; letter-spacing: .13em; }
.about footer p { margin: 0; }

.moment-dialog { width: min(1080px, calc(100% - 44px)); max-height: calc(100vh - 44px); padding: 0; border: 0; color: var(--ink); background: var(--paper); box-shadow: 0 30px 100px rgba(0,0,0,.42); }
.moment-dialog::backdrop { background: rgba(18,16,15,.82); backdrop-filter: blur(5px); }
.dialog-close { position: absolute; right: 15px; top: 15px; z-index: 2; width: 42px; height: 42px; border: 0; border-radius: 50%; background: var(--paper); cursor: pointer; font-size: 24px; }
.dialog-layout { display: grid; grid-template-columns: 1.3fr .7fr; min-height: 580px; }
.dialog-image { background: #181513; }
.dialog-image img { height: 100%; object-fit: contain; }
.dialog-copy { padding: 68px 42px 42px; display: flex; flex-direction: column; }
.dialog-copy .section-number { margin-bottom: 30px; }
.dialog-copy h2 { margin: 0 0 15px; font: 400 34px/1.3 "Songti SC", serif; }
.dialog-copy > p { color: var(--muted); font-size: 12px; line-height: 2; }
.dialog-tags { display: flex; flex-wrap: wrap; gap: 6px; margin: 20px 0; }
.dialog-tags span { border: 1px solid var(--line); border-radius: 20px; padding: 6px 9px; font-size: 9px; }
.dialog-actions { margin-top: auto; display: grid; gap: 8px; }
.dialog-actions a, .dialog-actions button { min-height: 44px; display: flex; align-items: center; justify-content: space-between; padding: 0 15px; border: 1px solid var(--ink); background: transparent; cursor: pointer; font-size: 11px; }
.dialog-actions a { color: #fff; background: var(--ink); }

.add-dialog { width: min(820px, calc(100% - 36px)); max-height: calc(100vh - 36px); padding: 0; border: 0; color: var(--ink); background: var(--paper); box-shadow: 0 30px 100px rgba(0,0,0,.42); }
.add-dialog::backdrop { background: rgba(18,16,15,.82); backdrop-filter: blur(5px); }
.add-dialog-head { padding: 55px 54px 25px; border-bottom: 1px solid var(--line); }
.add-dialog-head h2 { margin: 0 0 12px; font: 400 38px "Songti SC", serif; }
.add-dialog-head > p:last-child { margin: 0; color: var(--muted); font-size: 10px; line-height: 1.8; }
.add-dialog form { padding: 30px 54px; display: grid; grid-template-columns: repeat(2, 1fr); gap: 19px 16px; }
.add-dialog label { display: flex; flex-direction: column; gap: 7px; }
.add-dialog label.wide, .add-dialog .wide { grid-column: 1 / -1; }
.add-dialog label > span { color: var(--muted); font-size: 9px; letter-spacing: .08em; }
.add-dialog input, .add-dialog select, .add-dialog textarea { width: 100%; border: 1px solid var(--line); border-radius: 0; outline: 0; color: var(--ink); background: #f7f4ee; padding: 11px 12px; font-size: 11px; }
.add-dialog input:focus, .add-dialog select:focus, .add-dialog textarea:focus { border-color: var(--red); }
.add-dialog textarea { resize: vertical; }
.image-upload input { padding: 9px; border-style: dashed; cursor: pointer; }
.image-upload input::file-selector-button { margin-right: 14px; padding: 8px 12px; border: 0; color: #fff; background: var(--ink); cursor: pointer; }
.image-preview { height: 150px; position: relative; overflow: hidden; background: var(--cream); }
.image-preview img { height: 100%; object-fit: contain; }
.image-preview span { position: absolute; right: 9px; bottom: 9px; padding: 5px 7px; color: #fff; background: var(--red); font-size: 8px; }
.form-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 6px; }
.form-actions button, .import-button { min-height: 44px; padding: 0 16px; border: 1px solid var(--ink); display: inline-flex !important; flex-direction: row !important; align-items: center; justify-content: space-between; gap: 35px !important; color: #fff; background: var(--ink); cursor: pointer; font-size: 10px; }
.form-actions button.secondary, .import-button { color: var(--ink); background: transparent; }
.form-actions button.publish-now { background: var(--red); border-color: var(--red); }
.import-button input { display: none; }
.save-note { padding: 18px 54px 26px; display: flex; gap: 20px; color: var(--muted); background: var(--cream); font-size: 9px; }
.save-note b { color: var(--red); white-space: nowrap; }
.save-note p { margin: 0; line-height: 1.7; }
.save-note code { color: var(--ink); }
.save-note a { display: inline-block; margin-left: 8px; color: var(--red); border-bottom: 1px solid currentColor; }
.dialog-delete { color: #fff !important; background: var(--red) !important; border-color: var(--red) !important; }
.site-toast { position: fixed; right: 24px; bottom: 24px; z-index: 120; max-width: min(360px, calc(100% - 40px)); padding: 13px 17px; color: #fff; background: var(--ink); box-shadow: 0 12px 35px rgba(0,0,0,.28); font-size: 11px; line-height: 1.6; opacity: 0; transform: translateY(12px); pointer-events: none; transition: .25s ease; }
.site-toast.show { opacity: 1; transform: translateY(0); }

@media (max-width: 1150px) {
  :root { --sidebar: 190px; }
  .hero { grid-template-columns: .9fr 1.1fr; gap: 45px; }
  .hero h1 { font-size: 92px; }
  .profile-card { grid-template-columns: 1fr; }
  .profile-photo { height: 310px; }
  .profile-copy { min-height: 210px; }
  .timeline-track { grid-template-columns: repeat(3, 1fr); }
  .social-layout { grid-template-columns: 1fr 250px; gap: 40px; }
  .insta-layout { gap: 40px; }
  .insta-collage { grid-template-rows: repeat(2, 240px); }
  .lead-board { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 850px) {
  :root { --sidebar: 0px; }
  .sidebar { width: 270px; transform: translateX(-100%); transition: transform .3s ease; box-shadow: 20px 0 50px rgba(0,0,0,.2); }
  .sidebar.open { transform: translateX(0); }
  .sidebar-close { display: block; }
  .menu-button { width: 35px; height: 35px; display: grid; place-content: center; gap: 6px; }
  .menu-button span { width: 18px; height: 1px; background: var(--ink); }
  main { margin-left: 0; }
  .hero { grid-template-columns: 1fr; min-height: auto; }
  .hero-copy { padding-top: 30px; }
  .hero-visual { width: min(100%, 650px); justify-self: start; }
  .hero h1 { font-size: clamp(85px, 20vw, 130px); }
  .moment-card, .moment-card:nth-child(7n + 1), .moment-card:nth-child(7n + 5) { grid-column: span 6; }
  .timeline-track { grid-template-columns: repeat(2, 1fr); }
  .account-strip { grid-template-columns: 1fr; }
  .social-layout { grid-template-columns: 1fr; }
  .social-note { position: static; padding: 40px 0 0; border-left: 0; border-top: 1px solid #453c37; }
  .insta-layout { grid-template-columns: 1fr; }
  .explore-grid { grid-template-columns: repeat(2, 1fr); }
  .submit-panel { grid-template-columns: 1fr; gap: 35px; padding-top: 70px; padding-bottom: 70px; }
  .profile-layout { grid-template-columns: 1fr; }
  .profile-x { flex-direction: row; justify-content: center; }
  .profile-x span { writing-mode: horizontal-tb; }
  .profile-card { grid-template-columns: 1.15fr .85fr; }
  .profile-card.pu { direction: ltr; }
  .about-grid { gap: 50px; }
  .dialog-layout { grid-template-columns: 1fr; }
  .dialog-image { height: 48vh; }
}

@media (max-width: 580px) {
  .section-pad { padding-left: 20px; padding-right: 20px; }
  .topbar { padding: 0 14px; }
  .topbar > p { display: none; }
  .hero { padding-top: 48px; padding-bottom: 65px; gap: 55px; }
  .share-button { width: 38px; padding: 0; justify-content: center; }
  .share-button b { display: none; }
  .add-button { width: 38px; padding: 0; font-size: 0; }
  .add-button span { font-size: 17px; }
  .hero h1 { font-size: 78px; }
  .hero-intro { margin-top: 35px; }
  .hero-radar { grid-template-columns: repeat(2, 1fr); }
  .hero-caption { align-items: start; flex-direction: column; }
  .vertical-note { display: none; }
  .archive { padding-top: 80px; padding-bottom: 90px; }
  .section-head { align-items: start; flex-direction: column; padding-bottom: 24px; }
  .archive-tools { align-items: stretch; flex-direction: column; padding: 24px 0 32px; }
  .platform-row { align-items: flex-start; flex-direction: column; gap: 10px; padding: 14px 0; }
  .search-field { width: 100%; }
  .moment-card, .moment-card:nth-child(7n + 1), .moment-card:nth-child(7n + 5) { grid-column: span 12; }
  .card-image img, .moment-card:nth-child(7n + 1) .card-image img, .moment-card:nth-child(7n + 5) .card-image img { aspect-ratio: 4 / 3; }
  .timeline { padding-top: 80px; padding-bottom: 85px; }
  .social { padding-top: 80px; padding-bottom: 85px; }
  .instagram { padding-top: 80px; padding-bottom: 85px; }
  .explore { padding-top: 80px; padding-bottom: 85px; }
  .explore-grid { grid-template-columns: 1fr; }
  .explore-grid a { min-height: 165px; }
  .leads { padding-top: 80px; padding-bottom: 85px; }
  .lead-board { grid-template-columns: 1fr; }
  .lead-board article { min-height: 235px; padding: 22px; }
  .submit-panel { min-height: auto; }
  .insta-collage { grid-template-columns: 1fr 1fr; grid-template-rows: 340px 190px; }
  .insta-tile.large { grid-column: 1 / 3; grid-row: auto; }
  .account-card { min-height: 110px; padding: 18px; }
  .weibo-post.featured { padding: 22px 18px; }
  .weibo-post > p, .post-tags, .weibo-post > a { margin-left: 0; }
  .timeline-track { grid-template-columns: 1fr; }
  .timeline-track article { min-height: 220px; }
  .profile-card, .profile-card.pu { grid-template-columns: 1fr; direction: ltr; }
  .name-map p { grid-template-columns: 65px 1fr 22px 1.5fr; padding: 12px 0; }
  .name-map em { grid-column: 2 / 5; text-align: left; margin-top: 8px; }
  .about-grid { grid-template-columns: 1fr; gap: 30px; padding-bottom: 70px; }
  .about footer { align-items: start; flex-direction: column; padding: 24px 0; }
  .moment-dialog { width: calc(100% - 18px); max-height: calc(100vh - 18px); }
  .dialog-copy { padding: 50px 24px 24px; }
  .add-dialog { width: calc(100% - 18px); max-height: calc(100vh - 18px); }
  .add-dialog-head { padding: 48px 22px 22px; }
  .add-dialog form { padding: 24px 22px; grid-template-columns: 1fr; }
  .add-dialog label.wide, .add-dialog .wide { grid-column: auto; }
  .site-toast { right: 14px; bottom: 14px; }
  .form-actions { flex-direction: column; }
  .form-actions button, .import-button { width: 100%; }
  .save-note { padding: 18px 22px; flex-direction: column; gap: 6px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
}
