/* Shared stylesheet for the bazi report experience (both /bazi.html streaming
   and /r/{id} server-rendered view). All selectors are scoped to the report
   structure so they don't collide with the form page. */

:root{
  --black:#050505; --off-black:#0e0e0e; --charcoal:#1a1a1a; --slate:#2a2a2a;
  --dim:#666; --muted:#999; --light:#ccc; --white:#f2f0ed; --cream:#faf8f5;
  --vermillion:#c23b22; --vermillion-glow:rgba(194,59,34,0.12);
  --gold:#c9a96e; --gold-bright:#dcb87c; --gold-deep:#8a6f3d;
  --gold-dim:rgba(201,169,110,0.08); --jade:#6b9e6b;
  --display:'EB Garamond',Georgia,serif;
  --body:'Outfit',system-ui,sans-serif;
  --cn:'Noto Serif SC','Songti SC',serif;
}

/* ====== NAV ====== */
nav.top-nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:18px 48px;background:rgba(5,5,5,0.85);backdrop-filter:blur(24px);border-bottom:1px solid rgba(255,255,255,0.04);}
.nav-back{font-family:var(--body);font-size:13px;color:var(--muted);letter-spacing:0.3px;display:flex;align-items:center;gap:8px;transition:color 0.2s;}
.nav-back:hover{color:var(--white);}
.nav-title{font-family:var(--display);font-size:15px;color:var(--muted);letter-spacing:0.5px;}
.nav-title span{font-family:var(--cn);font-size:11px;color:var(--vermillion);margin-left:8px;letter-spacing:2px;}
.nav-tools{display:flex;gap:18px;align-items:center;}
.nav-share{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);border:1px solid rgba(201,169,110,0.25);padding:8px 16px;cursor:pointer;background:transparent;font-family:var(--body);transition:all 0.25s;}
.nav-share:hover{background:var(--gold);color:var(--black);border-color:var(--gold);}

/* ====== ATMOSPHERE ====== */
.page-atmosphere{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0;}
.page-atmosphere::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 40% at 50% 10%,rgba(194,59,34,0.05) 0%,transparent 100%),radial-gradient(ellipse 40% 30% at 90% 35%,rgba(201,169,110,0.04) 0%,transparent 100%),radial-gradient(ellipse 50% 30% at 10% 70%,rgba(201,169,110,0.03) 0%,transparent 100%);}
.bg-glyph{position:absolute;font-family:var(--cn);color:rgba(255,255,255,0.018);font-weight:900;line-height:1;pointer-events:none;user-select:none;}
.bg-glyph.g1{top:6%;left:4%;font-size:200px;transform:rotate(-8deg);}
.bg-glyph.g2{top:35%;right:5%;font-size:160px;transform:rotate(7deg);}
.bg-glyph.g3{top:58%;left:7%;font-size:180px;transform:rotate(-4deg);}
.bg-glyph.g4{bottom:4%;right:8%;font-size:140px;transform:rotate(11deg);}
.bg-glyph.g5{bottom:30%;left:48%;font-size:120px;transform:rotate(-15deg);opacity:0.6;}

/* ====== HEADER ====== */
.report-header{position:relative;z-index:1;padding:130px 24px 40px;text-align:center;max-width:760px;margin:0 auto;}
.report-header .seal{display:inline-flex;align-items:center;gap:10px;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:24px;}
.report-header .seal::before,.report-header .seal::after{content:'';display:block;width:32px;height:1px;background:linear-gradient(90deg,transparent,var(--gold-deep),transparent);}
.report-header h1{font-family:var(--display);font-weight:400;font-size:clamp(36px,4.5vw,58px);line-height:1.08;letter-spacing:-0.5px;margin-bottom:18px;}
.report-header h1 em{font-style:italic;color:var(--gold);}
.report-header .subject-line{font-family:var(--display);font-style:italic;font-size:17px;color:var(--muted);letter-spacing:0.3px;margin-bottom:8px;}
.report-header .meta-line{font-size:11px;color:var(--dim);letter-spacing:2px;text-transform:uppercase;}
.report-header .meta-line .dot{margin:0 10px;color:var(--gold-deep);}
.report-header .author-line{margin-top:32px;display:inline-flex;align-items:center;gap:12px;padding:10px 20px;border:1px solid rgba(201,169,110,0.15);background:rgba(201,169,110,0.04);}
.report-header .author-line .author-cn{font-family:var(--cn);font-size:13px;color:var(--gold);font-weight:500;}
.report-header .author-line .author-en{font-family:var(--display);font-size:13px;color:var(--light);font-style:italic;}

/* ====== HERO PILLARS ====== */
.pillars-hero{position:relative;z-index:1;max-width:880px;margin:60px auto 0;padding:0 24px;}
.pillars-hero-inner{background:linear-gradient(180deg,var(--off-black),#0a0a0a);border:1px solid rgba(201,169,110,0.12);position:relative;overflow:hidden;padding:48px 40px 40px;}
.pillars-hero-inner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(201,169,110,0.06),transparent 70%);pointer-events:none;}
.pillars-hero-inner::after{content:'命';position:absolute;top:-32px;right:-12px;font-family:var(--cn);font-size:240px;font-weight:900;color:rgba(194,59,34,0.025);line-height:1;pointer-events:none;}
.pillars-eyebrow{display:flex;align-items:center;gap:14px;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:32px;position:relative;z-index:1;}
.pillars-eyebrow .dash{flex:1;height:1px;background:linear-gradient(90deg,var(--gold-deep),transparent);}
.pillars-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;position:relative;z-index:1;}
.pillar{background:var(--charcoal);border:1px solid rgba(255,255,255,0.05);padding:20px 14px 18px;text-align:center;position:relative;transition:transform 0.4s cubic-bezier(0.16,1,0.3,1);}
.pillar:hover{transform:translateY(-3px);border-color:rgba(201,169,110,0.25);}
.pillar .p-label{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:14px;font-weight:600;}
.pillar .p-stem{font-family:var(--cn);font-size:38px;font-weight:600;color:var(--white);line-height:1;}
.pillar .p-branch{font-family:var(--cn);font-size:38px;font-weight:600;color:var(--white);line-height:1;margin-top:4px;}
.pillar .p-pinyin{font-family:var(--display);font-style:italic;font-size:11px;color:var(--dim);letter-spacing:1px;margin-top:10px;}
.pillar .p-element{font-size:9px;color:var(--gold-deep);letter-spacing:1.5px;text-transform:uppercase;margin-top:6px;}
.pillar.day{border-color:rgba(194,59,34,0.4);background:linear-gradient(180deg,#1a1010,#150c0c);box-shadow:0 0 0 1px rgba(194,59,34,0.1),0 0 30px rgba(194,59,34,0.08);}
.pillar.day .p-stem,.pillar.day .p-branch{color:var(--vermillion);text-shadow:0 0 30px rgba(194,59,34,0.4);}
.pillar.day .p-label{color:var(--vermillion);}
.pillar.day::after{content:'日主 · DAY MASTER';position:absolute;bottom:-1px;left:50%;transform:translateX(-50%) translateY(100%);font-size:8px;letter-spacing:2px;color:var(--vermillion);background:var(--black);padding:4px 10px;border:1px solid rgba(194,59,34,0.3);border-top:none;}

.elements-row{margin-top:56px;padding-top:32px;border-top:1px solid rgba(255,255,255,0.04);position:relative;z-index:1;}
.elements-label{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);margin-bottom:18px;display:flex;justify-content:space-between;}
.elements-label .cn{font-family:var(--cn);color:var(--gold);letter-spacing:3px;}
.elements-bars{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;}
.el-bar{display:flex;flex-direction:column;align-items:center;}
.el-bar .el-track{width:100%;height:64px;background:rgba(255,255,255,0.03);position:relative;display:flex;align-items:flex-end;overflow:hidden;}
.el-bar .el-fill{width:100%;background:linear-gradient(180deg,var(--gold-bright),var(--gold-deep));transition:height 1.1s cubic-bezier(0.16,1,0.3,1);}
.el-bar.dim .el-fill{background:linear-gradient(180deg,#3a3a3a,#222);}
.el-bar.zero .el-track::after{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:repeating-linear-gradient(90deg,var(--vermillion) 0,var(--vermillion) 4px,transparent 4px,transparent 8px);}
.el-bar .el-name{font-family:var(--cn);font-size:14px;color:var(--white);margin-top:10px;font-weight:500;}
.el-bar .el-en{font-size:9px;color:var(--dim);letter-spacing:1px;text-transform:uppercase;margin-top:2px;}
.el-bar .el-num{font-family:var(--display);font-size:13px;color:var(--gold);margin-top:4px;}
.el-bar.zero .el-num{color:var(--vermillion);}
.elements-note{margin-top:22px;font-family:var(--display);font-style:italic;font-size:13px;color:var(--muted);text-align:center;line-height:1.6;}
.elements-note strong{color:var(--vermillion);font-style:normal;font-weight:500;}

/* ====== SECTION CONTENT ====== */
.content{position:relative;z-index:1;max-width:780px;margin:0 auto;padding:80px 24px 40px;}
.section{margin-bottom:80px;position:relative;}
.section .s-num{font-family:var(--display);font-size:88px;font-weight:400;color:rgba(201,169,110,0.08);line-height:1;position:absolute;top:-22px;left:-30px;pointer-events:none;letter-spacing:-2px;}
.section .s-eyebrow{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--vermillion);margin-bottom:10px;font-weight:500;}
.section h2{font-family:var(--display);font-size:clamp(28px,3vw,38px);font-weight:400;line-height:1.2;letter-spacing:-0.3px;margin-bottom:6px;}
.section h2 em{font-style:italic;color:var(--gold);}
.section .s-cn{font-family:var(--cn);font-size:13px;color:var(--gold);letter-spacing:4px;margin-bottom:28px;}
.section .s-body{font-family:var(--display);font-size:17px;font-weight:400;color:var(--light);line-height:1.78;min-height:28px;}
.section .s-body p{margin-bottom:18px;}
.section .s-body p:last-child{margin-bottom:0;}
.section .s-body em{color:var(--gold);font-style:italic;}
.section .s-body .cn-inline{font-family:var(--cn);color:var(--vermillion);font-weight:500;padding:0 2px;}
.section .s-body strong{color:var(--white);font-weight:500;}
.section .s-body blockquote{border-left:2px solid var(--gold-deep);padding:6px 16px;margin:12px 0;color:var(--muted);font-style:italic;}
.s-rule{width:48px;height:1px;background:var(--gold-deep);margin-bottom:20px;}

/* Streaming cursor inside an .s-body */
.s-body .stream-cursor{display:inline-block;width:9px;height:1.1em;vertical-align:-0.2em;background:var(--gold);margin-left:2px;animation:streamBlink 1s steps(2,start) infinite;}
@keyframes streamBlink{50%{opacity:0;}}

/* ====== YEAR CARD ====== */
.year-card{position:relative;margin:36px 0;padding:48px 40px 36px;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(194,59,34,0.08),transparent 70%),linear-gradient(180deg,#0f0a07,#0a0706);border:2px solid var(--gold);overflow:hidden;}
.year-card::before{content:'';position:absolute;inset:6px;border:1px solid rgba(201,169,110,0.25);pointer-events:none;}
.year-card::after{content:attr(data-year-gz);position:absolute;top:-20px;right:-30px;font-family:var(--cn);font-size:200px;font-weight:900;color:rgba(201,169,110,0.05);line-height:1;pointer-events:none;}
.year-card .yc-corner{position:absolute;width:24px;height:24px;border-color:var(--gold);}
.year-card .yc-corner.tl{top:10px;left:10px;border-top:2px solid;border-left:2px solid;}
.year-card .yc-corner.tr{top:10px;right:10px;border-top:2px solid;border-right:2px solid;}
.year-card .yc-corner.bl{bottom:10px;left:10px;border-bottom:2px solid;border-left:2px solid;}
.year-card .yc-corner.br{bottom:10px;right:10px;border-bottom:2px solid;border-right:2px solid;}
.year-card .yc-stamp{position:absolute;top:24px;left:50%;transform:translateX(-50%);font-family:var(--cn);font-size:10px;color:var(--gold-deep);letter-spacing:6px;}
.year-card .yc-year{font-family:var(--display);font-size:14px;color:var(--gold);letter-spacing:8px;text-transform:uppercase;text-align:center;margin-top:18px;margin-bottom:24px;}
.year-card blockquote{font-family:var(--display);font-style:italic;font-weight:400;font-size:clamp(22px,2.6vw,30px);line-height:1.45;text-align:center;color:var(--cream);padding:0 20px;margin:0 auto;max-width:580px;position:relative;border:none;}
.year-card blockquote::before{content:'\201C';position:absolute;top:-30px;left:50%;transform:translateX(-50%);font-family:var(--display);font-size:80px;color:var(--gold);line-height:1;font-style:normal;}
.year-card .yc-attrib{text-align:center;margin-top:24px;font-family:var(--cn);font-size:12px;color:var(--gold);letter-spacing:6px;}
.year-card .yc-attrib::before,.year-card .yc-attrib::after{content:'';display:inline-block;width:24px;height:1px;background:var(--gold-deep);vertical-align:middle;margin:0 12px;}
.year-card .yc-share{display:flex;justify-content:center;align-items:center;gap:14px;margin-top:32px;padding-top:24px;border-top:1px solid rgba(201,169,110,0.15);}
.year-card .yc-share-text{font-size:11px;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;}
.year-card .yc-share-btn{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;background:var(--gold);color:var(--black);border:none;font-family:var(--body);font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:all 0.25s;}
.year-card .yc-share-btn:hover{background:var(--gold-bright);box-shadow:0 6px 24px rgba(201,169,110,0.25);}

/* ====== PIVOTAL MONTHS ====== */
.pivotal-months{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:28px 0 8px;}
.pm-card{padding:18px 16px;background:var(--charcoal);border:1px solid rgba(255,255,255,0.05);border-left:2px solid var(--vermillion);}
.pm-card .pm-month{font-family:var(--display);font-size:18px;font-weight:500;color:var(--white);margin-bottom:4px;}
.pm-card .pm-month em{font-style:italic;color:var(--gold);}
.pm-card .pm-text{font-size:12px;color:var(--muted);line-height:1.65;font-weight:300;font-family:var(--body);margin-top:6px;}

/* ====== CLASSICAL REFERENCE ====== */
.classical{margin:32px 0;padding:32px 32px 28px;background:#0a0907;border:1px solid rgba(201,169,110,0.18);position:relative;overflow:hidden;}
.classical::before{content:'';position:absolute;top:-1px;left:24px;right:24px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);}
.classical .cl-eyebrow{display:flex;align-items:center;gap:12px;font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:18px;}
.classical .cl-eyebrow .seal{font-family:var(--cn);font-size:13px;letter-spacing:2px;color:var(--vermillion);font-weight:500;}
.classical .cl-grid{display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:start;}
.classical .cl-zh{font-family:var(--cn);font-size:18px;line-height:2.1;font-weight:400;color:var(--cream);writing-mode:vertical-rl;text-orientation:upright;max-height:280px;letter-spacing:6px;border-right:1px solid rgba(201,169,110,0.15);padding-right:28px;}
.classical .cl-en{font-family:var(--display);font-style:italic;font-size:15px;line-height:1.85;color:var(--light);}
.classical .cl-en p{margin-bottom:10px;}
.classical .cl-source{margin-top:18px;padding-top:14px;border-top:1px dashed rgba(201,169,110,0.18);display:flex;justify-content:space-between;align-items:center;}
.classical .cl-source .src-cn{font-family:var(--cn);font-size:13px;color:var(--gold);letter-spacing:2px;font-weight:500;}
.classical .cl-source .src-en{font-family:var(--display);font-style:italic;font-size:12px;color:var(--dim);}

/* ====== MASTER WHISPER ====== */
.master-whisper{margin:60px 0 40px;padding:48px 40px;background:linear-gradient(180deg,#0d0a06,var(--off-black));border-top:1px solid rgba(201,169,110,0.2);border-bottom:1px solid rgba(201,169,110,0.2);position:relative;}
.master-whisper .mw-sigil{text-align:center;margin-bottom:18px;font-family:var(--cn);font-size:42px;font-weight:300;color:var(--vermillion);text-shadow:0 0 30px rgba(194,59,34,0.3);}
.master-whisper .mw-eyebrow{text-align:center;font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:24px;}
.master-whisper .mw-text{font-family:var(--display);font-style:italic;font-weight:400;font-size:19px;line-height:1.7;text-align:center;color:var(--cream);max-width:520px;margin:0 auto;}
.master-whisper .mw-text p{margin-bottom:12px;}
.master-whisper .mw-sign{margin-top:32px;text-align:center;font-family:var(--display);font-size:13px;color:var(--gold);letter-spacing:2px;}
.master-whisper .mw-sign .cn{font-family:var(--cn);color:var(--vermillion);margin-left:8px;}

/* ====== FOOTER ACTIONS ====== */
.report-footer{position:relative;z-index:1;max-width:780px;margin:0 auto;padding:0 24px 80px;text-align:center;}
.actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:24px;}
.act{padding:13px 24px;border:1px solid rgba(255,255,255,0.1);font-family:var(--body);font-size:11px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);cursor:pointer;background:transparent;transition:all 0.25s;}
.act:hover{color:var(--white);border-color:var(--gold);}
.act.primary{background:var(--vermillion);color:#fff;border-color:var(--vermillion);}
.act.primary:hover{background:#d44a32;color:#fff;border-color:#d44a32;}
.permalink{margin-top:36px;font-size:11px;color:var(--dim);letter-spacing:1px;}
.permalink code{background:var(--charcoal);padding:4px 10px;font-family:'SF Mono',Menlo,monospace;font-size:10px;color:var(--gold);border:1px solid rgba(201,169,110,0.1);}

/* ====== ENTRANCE ANIMATIONS ====== */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}
.reveal{opacity:0;transform:translateY(24px);transition:all 0.85s cubic-bezier(0.16,1,0.3,1);}
.reveal.vis{opacity:1;transform:none;}

/* Pillar drop-in (4-stagger, day last with vermillion glow) */
@keyframes pillarDrop{from{opacity:0;transform:translateY(-18px) scale(0.96);}to{opacity:1;transform:none;}}
.pillar{opacity:0;animation:pillarDrop 0.6s cubic-bezier(0.16,1,0.3,1) forwards;}
.pillar.is-staggered.s0{animation-delay:0.08s;}
.pillar.is-staggered.s1{animation-delay:0.22s;}
.pillar.is-staggered.s3{animation-delay:0.36s;}
.pillar.is-staggered.s2{animation-delay:0.52s;} /* day pillar last */

/* Elements bars: delay the fill + number */
.elements-bars.ready .el-fill{}
.el-bar{opacity:0;transform:translateY(12px);transition:opacity 0.5s,transform 0.5s;}
.elements-bars.ready .el-bar{opacity:1;transform:none;}
.elements-bars.ready .el-bar:nth-child(1){transition-delay:0.9s;}
.elements-bars.ready .el-bar:nth-child(2){transition-delay:1.00s;}
.elements-bars.ready .el-bar:nth-child(3){transition-delay:1.10s;}
.elements-bars.ready .el-bar:nth-child(4){transition-delay:1.20s;}
.elements-bars.ready .el-bar:nth-child(5){transition-delay:1.30s;}

/* Section reveal — triggered when a chunk first hits that section */
.section{opacity:0;transform:translateY(24px);transition:opacity 0.7s cubic-bezier(0.16,1,0.3,1),transform 0.7s cubic-bezier(0.16,1,0.3,1);}
.section.vis{opacity:1;transform:none;}

/* Year card bloom (corners → glow → quote) */
@keyframes yearCardBloom{from{opacity:0;transform:scale(0.94);box-shadow:0 0 0 rgba(194,59,34,0);}70%{box-shadow:0 0 60px rgba(194,59,34,0.2);}to{opacity:1;transform:none;box-shadow:0 0 40px rgba(194,59,34,0.12);}}
.year-card{opacity:0;}
.year-card.vis{animation:yearCardBloom 1.2s cubic-bezier(0.16,1,0.3,1) forwards;}

/* Force-visible: bypass all animation opacity states for html2canvas / print export */
.year-card.force-visible,
.year-card.force-visible blockquote,
.year-card.force-visible .yc-attrib,
.year-card.force-visible .yc-share,
.year-card.force-visible .yc-year,
.year-card.force-visible .yc-corner{
  opacity:1 !important;
  transform:none !important;
  animation:none !important;
}
@keyframes cornerGrow{from{width:0;height:0;}to{width:24px;height:24px;}}
.year-card.vis .yc-corner{animation:cornerGrow 0.6s 0.1s cubic-bezier(0.16,1,0.3,1) both;}
@keyframes quoteRise{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:none;}}
.year-card blockquote,.year-card .yc-attrib,.year-card .yc-share,.year-card .yc-year{opacity:0;}
.year-card.vis blockquote{animation:quoteRise 0.9s 0.5s ease-out forwards;}
.year-card.vis .yc-year{animation:quoteRise 0.7s 0.3s ease-out forwards;}
.year-card.vis .yc-attrib{animation:quoteRise 0.6s 0.9s ease-out forwards;}
.year-card.vis .yc-share{animation:quoteRise 0.6s 1.0s ease-out forwards;}

/* Pivotal months cascade */
.pm-card{opacity:0;transform:translateY(18px);transition:opacity 0.6s cubic-bezier(0.16,1,0.3,1),transform 0.6s cubic-bezier(0.16,1,0.3,1);}
.pm-card.vis{opacity:1;transform:none;}
.pm-card.vis:nth-child(1){transition-delay:0.05s;}
.pm-card.vis:nth-child(2){transition-delay:0.17s;}
.pm-card.vis:nth-child(3){transition-delay:0.29s;}

/* Classical scroll — left gold line sweeps, Chinese reveals as scroll */
@keyframes classicalSweep{from{transform:scaleX(0);transform-origin:left;}to{transform:scaleX(1);}}
.classical{opacity:0;transform:translateY(14px);transition:opacity 0.7s ease-out,transform 0.7s ease-out;}
.classical.vis{opacity:1;transform:none;}
.classical::before{transform:scaleX(0);transform-origin:left;}
.classical.vis::before{animation:classicalSweep 0.9s 0.2s cubic-bezier(0.16,1,0.3,1) forwards;}
@keyframes scrollUnfurl{from{max-height:0;opacity:0;}to{max-height:280px;opacity:1;}}
.classical .cl-zh{max-height:0;overflow:hidden;opacity:0;}
.classical.vis .cl-zh{animation:scrollUnfurl 1.1s 0.4s cubic-bezier(0.16,1,0.3,1) forwards;}
.classical .cl-en{opacity:0;transform:translateY(8px);transition:opacity 0.6s 0.7s,transform 0.6s 0.7s;}
.classical.vis .cl-en{opacity:1;transform:none;}

/* Whisper seal — red stamp bloom */
@keyframes sealBloom{0%{opacity:0;transform:scale(0);filter:blur(6px);}60%{opacity:1;transform:scale(1.08);filter:blur(0);}100%{opacity:1;transform:scale(1);}}
.master-whisper{opacity:0;transform:translateY(14px);transition:opacity 0.7s ease-out,transform 0.7s ease-out;}
.master-whisper.vis{opacity:1;transform:none;}
.master-whisper .mw-sigil{opacity:0;}
.master-whisper.vis .mw-sigil{animation:sealBloom 1.3s 0.3s cubic-bezier(0.34,1.5,0.64,1) forwards;}
.master-whisper .mw-text,.master-whisper .mw-sign,.master-whisper .mw-eyebrow{opacity:0;}
.master-whisper.vis .mw-eyebrow{animation:quoteRise 0.6s 1.0s ease-out forwards;}
.master-whisper.vis .mw-text{animation:quoteRise 0.8s 1.3s ease-out forwards;}
.master-whisper.vis .mw-sign{animation:quoteRise 0.6s 1.8s ease-out forwards;}

/* Report header entrance */
.report-header > *{opacity:0;animation:fadeUp 0.75s ease forwards;}
.report-header .seal{animation-delay:0.05s;}
.report-header h1{animation-delay:0.18s;}
.report-header .subject-line{animation-delay:0.32s;}
.report-header .meta-line{animation-delay:0.42s;}
.report-header .author-line{animation-delay:0.55s;}
.pillars-hero{opacity:0;animation:fadeUp 3.6s 0.45s cubic-bezier(0.16,1,0.3,1) forwards;}

/* ====== RESPONSIVE ====== */
@media (max-width:780px){
  nav.top-nav{padding:14px 18px;}
  .nav-title{display:none;}
  .pillars-hero{padding:0 16px;}
  .pillars-hero-inner{padding:32px 20px 28px;}
  .pillars-grid{grid-template-columns:repeat(2,1fr);gap:10px;}
  .pillar .p-stem,.pillar .p-branch{font-size:32px;}
  .elements-bars{gap:8px;}
  .el-bar .el-track{height:50px;}
  .content{padding:60px 18px 30px;}
  .section{margin-bottom:60px;}
  .section .s-num{font-size:64px;left:0;top:-12px;opacity:0.5;}
  .section .s-body{font-size:16px;}
  .year-card{padding:36px 20px 28px;}
  .pivotal-months{grid-template-columns:1fr !important;}
  .classical .cl-grid{grid-template-columns:1fr;gap:20px;}
  .classical .cl-zh{writing-mode:horizontal-tb;max-height:none;border-right:none;border-bottom:1px solid rgba(201,169,110,0.15);padding-right:0;padding-bottom:18px;letter-spacing:2px;}
  .master-whisper{padding:36px 22px;}
  .actions{flex-direction:column;}
  .act{width:100%;}
}
