/* ═══════════════════════════════════════════════════════
   TAIPING DAO THEME — MAIN CSS
   Yellow Heaven · 黄天
   Amber-gold dominant · ink dark · vermillion accent
   ═══════════════════════════════════════════════════════ */

:root{
  --gold:#d4920a; --gold-light:#f0b429; --gold-bright:#ffd166;
  --gold-pale:#faeac7; --gold-dim:rgba(212,146,10,.22); --gold-glow:rgba(240,180,41,.12);
  --ink:#0c0905; --ink-deep:#080604; --silk:#140e07; --silk-mid:#1e1509;
  --silk-light:#2a1d0e; --panel:rgba(20,14,7,.92);
  --vermillion:#9b1b1b; --verm-light:#c0392b; --verm-bright:#e74c3c;
  --text-primary:#f0e0b8; --text-secondary:rgba(240,224,184,.82);
  --text-muted:rgba(240,224,184,.45); --text-faint:rgba(240,224,184,.22);
  --ff-zh:'Noto Serif SC','STSong',serif;
  --ff-en:'Cinzel',Georgia,serif;
  --ff-body:'IM Fell DW Pica','Cormorant Garamond',Georgia,serif;
  --max-w:1200px; --sidebar-w:300px;
  --ease:cubic-bezier(.4,0,.2,1);
  /* Mode-switchable tokens */
  --body-bg: var(--ink);
  --body-color: var(--text-primary);
  /* Typography scale — adjustable via Customizer Additional CSS */
  --font-size-base: 15px;   /* compact for text-heavy pages */
  --font-size-content: 1rem;
  --line-height-content: 1.95;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:var(--font-size-base);scroll-behavior:smooth;}
body{
  background:var(--body-bg); color:var(--body-color);
  font-family:var(--ff-body); font-size:1rem; line-height:1.8;
  overflow-x:hidden; min-height:100vh;
  transition: background .35s ease, color .35s ease;
}
body::before{
  content:''; position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 50% -10%,rgba(212,146,10,.06) 0%,transparent 70%),
    radial-gradient(ellipse 60% 40% at 80% 80%,rgba(155,27,27,.04) 0%,transparent 60%);
}
body::after{
  content:''; position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.3;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.06'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}
#page{position:relative;z-index:1;display:flex;flex-direction:column;min-height:100vh;}
.site-content{flex:1;}

/* ── HEADER ─────────────────────────────────────── */
#masthead{
  position:sticky;top:0;z-index:100;
  background:rgba(8,6,4,.97);
  border-bottom:1px solid var(--gold-dim);
  backdrop-filter:blur(12px);
  box-shadow:0 2px 40px rgba(0,0,0,.6);
  transition:box-shadow .3s;
}
.site-header-inner{
  max-width:var(--max-w); margin:0 auto;
  padding:0 2rem; display:flex;
  align-items:center; gap:2rem; height:72px;
}
.site-branding{
  display:flex;align-items:center;gap:1rem;
  flex-shrink:0;text-decoration:none;
}
.site-branding-seal{
  width:44px;height:44px;border:1px solid var(--gold);border-radius:50%;
  background:radial-gradient(ellipse,var(--vermillion) 0%,var(--ink) 100%);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-zh);font-size:1.3rem;font-weight:900;color:var(--gold-light);
  box-shadow:0 0 20px rgba(212,146,10,.2);flex-shrink:0;
  animation:sealBreath 5s ease-in-out infinite;
}
@keyframes sealBreath{
  0%,100%{box-shadow:0 0 16px rgba(212,146,10,.18);}
  50%{box-shadow:0 0 36px rgba(212,146,10,.38);}
}
.site-branding-text{display:flex;flex-direction:column;gap:.1rem;}
.site-title{
  font-family:var(--ff-zh);font-size:1rem;font-weight:700;
  color:var(--gold-bright);letter-spacing:.12em;line-height:1.1;
  text-decoration:none;transition:color .18s;
}
.site-title:hover{color:#fff;}
.site-tagline{font-family:var(--ff-en);font-size:.52rem;color:var(--text-muted);letter-spacing:.25em;}
.site-nav{flex:1;display:flex;justify-content:flex-end;align-items:center;gap:.5rem;}
.main-navigation ul{list-style:none;display:flex;gap:0;align-items:center;}
.main-navigation li{position:relative;}
.main-navigation a{
  display:block;padding:.55rem .85rem;
  font-family:var(--ff-en);font-size:.6rem;letter-spacing:.2em;
  color:var(--text-muted);text-decoration:none;text-transform:uppercase;
  transition:color .18s;white-space:nowrap;
}
.main-navigation a:hover,.main-navigation .current-menu-item>a{color:var(--gold-light);}
.main-navigation ul ul{
  display:none;flex-direction:column;position:absolute;top:100%;left:0;
  min-width:220px;background:rgba(12,9,5,.99);
  border:1px solid var(--gold-dim);border-top:2px solid var(--gold);
  box-shadow:0 8px 40px rgba(0,0,0,.7);z-index:200;padding:.5rem 0;
}
.main-navigation li:hover>ul{display:flex;}
.main-navigation ul ul a{
  padding:.5rem 1.1rem;font-size:.58rem;
  border-bottom:1px solid rgba(212,146,10,.06);
}
.main-navigation ul ul li:last-child a{border-bottom:none;}
.main-navigation ul ul a:hover{background:var(--gold-glow);color:var(--gold-bright);}
.menu-toggle{
  display:none;background:none;border:1px solid var(--gold-dim);
  color:var(--gold-light);padding:.5rem .7rem;cursor:pointer;font-size:1.1rem;
  transition:border-color .18s;
}
.menu-toggle:hover{border-color:var(--gold);}
.mode-toggle{
  background:none;border:1px solid var(--gold-dim);
  color:var(--gold-light);width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:.95rem;flex-shrink:0;
  transition:border-color .18s,color .18s;
}
.mode-toggle:hover{border-color:var(--gold);color:var(--gold-bright);}

/* ── HERO ───────────────────────────────────────── */
.hero-banner{
  position:relative;overflow:hidden;min-height:560px;
  display:flex;align-items:center;
  background:
    linear-gradient(180deg,rgba(8,6,4,0) 0%,rgba(8,6,4,.85) 100%),
    radial-gradient(ellipse 120% 100% at 50% 0%,rgba(212,146,10,.09) 0%,transparent 70%);
}
.hero-banner-bg{
  position:absolute;inset:0;
  background:linear-gradient(135deg,#0c0905 0%,#1c1208 50%,#0c0905 100%);
  opacity:.8;
}
.hero-banner-decor::before{
  content:'太平道';
  position:absolute;right:4%;top:50%;transform:translateY(-50%);
  font-family:var(--ff-zh);font-size:clamp(5rem,14vw,13rem);font-weight:900;
  color:rgba(212,146,10,.04);line-height:1;letter-spacing:.05em;writing-mode:vertical-rl;
}
.hero-inner{
  position:relative;z-index:2;
  max-width:var(--max-w);margin:0 auto;
  padding:5rem 2rem 4rem;width:100%;
}
.hero-kicker{
  font-family:var(--ff-en);font-size:.62rem;letter-spacing:.4em;
  color:var(--vermillion);text-transform:uppercase;margin-bottom:1rem;
  display:flex;align-items:center;gap:.75rem;
}
.hero-kicker::before,.hero-kicker::after{
  content:'';flex:0 0 40px;height:1px;
  background:linear-gradient(90deg,transparent,var(--vermillion));
}
.hero-kicker::after{transform:scaleX(-1);}
.hero-title{
  font-family:var(--ff-zh);font-size:clamp(2.6rem,7vw,5.5rem);font-weight:900;
  color:var(--gold-bright);line-height:1.1;letter-spacing:.08em;
  text-shadow:0 0 80px rgba(212,146,10,.28),0 4px 12px rgba(0,0,0,.8);
  margin-bottom:.5rem;animation:heroReveal .9s .1s both;
}
.hero-title-en{
  font-family:var(--ff-body);font-size:clamp(.95rem,2.5vw,1.45rem);
  font-style:italic;color:var(--text-secondary);letter-spacing:.05em;
  margin-bottom:1.5rem;animation:heroReveal .9s .3s both;
}
@keyframes heroReveal{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}
.hero-tagline{
  font-family:var(--ff-en);font-size:.7rem;letter-spacing:.35em;
  color:var(--gold);text-transform:uppercase;margin-bottom:2rem;
  animation:heroReveal .9s .5s both;
}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;animation:heroReveal .9s .65s both;}

/* ── BUTTONS ────────────────────────────────────── */
.btn-primary{
  background:linear-gradient(135deg,var(--vermillion),#b52020);
  border:1px solid rgba(212,146,10,.35);color:var(--gold-pale);
  padding:.85rem 2rem;font-family:var(--ff-en);font-size:.68rem;
  letter-spacing:.22em;text-transform:uppercase;text-decoration:none;
  cursor:pointer;transition:all .25s var(--ease);
  box-shadow:0 4px 20px rgba(155,27,27,.3);display:inline-block;
}
.btn-primary:hover{
  background:linear-gradient(135deg,#b52020,#c0392b);
  box-shadow:0 6px 30px rgba(155,27,27,.5);transform:translateY(-2px);color:#fff;
}
.btn-outline{
  background:transparent;border:1px solid var(--gold-dim);color:var(--gold-light);
  padding:.85rem 2rem;font-family:var(--ff-en);font-size:.68rem;
  letter-spacing:.22em;text-transform:uppercase;text-decoration:none;
  cursor:pointer;transition:all .25s var(--ease);display:inline-block;
}
.btn-outline:hover{background:var(--gold-glow);border-color:var(--gold);transform:translateY(-2px);}

/* ── DIVIDERS ───────────────────────────────────── */
.tpd-divider{display:flex;align-items:center;gap:1.25rem;margin:2rem 0;}
.tpd-divider-line{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);}
.tpd-divider-glyph{font-family:var(--ff-zh);font-size:1.1rem;color:var(--gold);opacity:.55;}
.section-kicker{
  font-family:var(--ff-en);font-size:.6rem;letter-spacing:.35em;
  color:var(--vermillion);text-transform:uppercase;display:block;margin-bottom:.6rem;
}
.section-title{
  font-family:var(--ff-zh);font-size:clamp(1.6rem,4vw,2.6rem);
  font-weight:700;color:var(--gold-bright);letter-spacing:.08em;line-height:1.2;
}
.section-title-en{
  font-family:var(--ff-body);font-style:italic;font-size:1rem;
  color:var(--text-muted);display:block;margin-top:.35rem;
}

/* ── LAYOUT ─────────────────────────────────────── */
.content-area{max-width:var(--max-w);margin:0 auto;padding:4rem 2rem;}
.content-with-sidebar{
  display:grid;grid-template-columns:1fr var(--sidebar-w);gap:3rem;align-items:start;
}

/* ── CARDS ──────────────────────────────────────── */
.card{
  background:var(--panel);border:1px solid rgba(212,146,10,.18);
  position:relative;overflow:hidden;
  transition:border-color .3s,box-shadow .3s,transform .3s;
}
.card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--vermillion),var(--gold),var(--vermillion),transparent);
  opacity:0;transition:opacity .3s;
}
.card:hover{
  border-color:rgba(212,146,10,.4);
  box-shadow:0 8px 40px rgba(0,0,0,.5),0 0 30px rgba(212,146,10,.06);
  transform:translateY(-3px);
}
.card:hover::before{opacity:1;}
.card::after{content:'❖';position:absolute;bottom:.6rem;right:.7rem;font-size:.55rem;color:var(--gold);opacity:.25;}
.card-img{
  width:100%;height:200px;object-fit:cover;
  border-bottom:1px solid rgba(212,146,10,.12);
  filter:brightness(.8) sepia(.15);transition:filter .3s;
}
.card:hover .card-img{filter:brightness(.9) sepia(.08);}
.card-body{padding:1.4rem;}
.card-kicker{font-family:var(--ff-en);font-size:.55rem;letter-spacing:.3em;color:var(--vermillion);text-transform:uppercase;margin-bottom:.5rem;display:block;}
.card-title{font-family:var(--ff-zh);font-size:1.1rem;font-weight:700;color:var(--gold-light);line-height:1.3;margin-bottom:.5rem;text-decoration:none;display:block;}
.card-title:hover{color:var(--gold-bright);}
.card-excerpt{font-size:.88rem;color:var(--text-secondary);line-height:1.75;margin-bottom:1rem;}
.card-link{
  font-family:var(--ff-en);font-size:.58rem;letter-spacing:.2em;
  color:var(--gold);text-decoration:none;text-transform:uppercase;
  transition:color .18s;display:inline-flex;align-items:center;gap:.4rem;
}
.card-link:hover{color:var(--gold-bright);}
.card-link::after{content:'→';}
.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;}

/* ── MODULE CARDS ───────────────────────────────── */
.modules-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;}
.module-card{
  position:relative;overflow:hidden;padding:1.75rem 1.5rem;
  background:var(--panel);border:1px solid rgba(212,146,10,.15);
  transition:all .3s var(--ease);cursor:pointer;text-decoration:none;display:block;
}
.module-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--vermillion),var(--gold));
}
.module-card-glyph{
  font-family:var(--ff-zh);font-size:3.5rem;font-weight:900;
  color:var(--gold);opacity:.14;
  position:absolute;bottom:.75rem;right:1rem;line-height:1;pointer-events:none;
  transition:opacity .3s,transform .4s;
}
.module-card:hover .module-card-glyph{opacity:.28;}
.module-card:hover{
  border-color:rgba(212,146,10,.38);background:rgba(25,17,8,.97);
  transform:translateY(-4px);box-shadow:0 10px 40px rgba(0,0,0,.5),0 0 30px rgba(212,146,10,.08);
}
.module-card-icon{
  width:42px;height:42px;border:1px solid var(--gold-dim);
  display:flex;align-items:center;justify-content:center;font-size:1.4rem;
  margin-bottom:1rem;color:var(--gold-light);transition:border-color .18s;
}
.module-card:hover .module-card-icon{border-color:var(--gold);}
.module-card-title-zh{font-family:var(--ff-zh);font-size:1.1rem;font-weight:700;color:var(--gold-light);letter-spacing:.1em;display:block;margin-bottom:.25rem;}
.module-card-title-en{font-family:var(--ff-en);font-size:.62rem;letter-spacing:.2em;color:var(--text-muted);display:block;margin-bottom:.75rem;}
.module-card-desc{font-size:.82rem;color:var(--text-secondary);line-height:1.65;}

/* ── ENTRY / ARTICLE ────────────────────────────── */
.entry-header{
  padding:4rem 2rem 2rem;max-width:var(--max-w);margin:0 auto;
  border-bottom:1px solid var(--gold-dim);margin-bottom:3rem;
}
.entry-kicker{font-family:var(--ff-en);font-size:.6rem;letter-spacing:.35em;color:var(--vermillion);text-transform:uppercase;display:block;margin-bottom:.75rem;}
.entry-title{font-family:var(--ff-zh);font-size:clamp(1.6rem,3vw,2.4rem);font-weight:900;color:var(--gold-bright);letter-spacing:.06em;line-height:1.2;text-shadow:0 0 60px rgba(212,146,10,.2);}
.entry-meta{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;margin-top:1.25rem;font-family:var(--ff-en);font-size:.58rem;letter-spacing:.2em;color:var(--text-muted);}
.entry-meta a{color:var(--gold);text-decoration:none;}
.entry-meta a:hover{color:var(--gold-bright);}

.entry-content{
  font-family:var(--ff-body);
  font-size:var(--font-size-content);
  line-height:var(--line-height-content);
  color:var(--text-primary);
}
/* Reading width — applied on standard pages without sidebar */
.entry-content--page {
  max-width: 820px; /* overridden by inline PHP from Customizer */
}

/* ── HEADINGS — Daoist amulet style: vermillion on dark, red on yellow ── */
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6{
  font-family:var(--ff-zh);
  color:#fff;
  background:var(--vermillion);
  display:inline-block;
  padding:.15em .6em .1em;
  margin:2.5rem 0 1rem;
  line-height:1.35;
  letter-spacing:.08em;
  box-decoration-break:clone;
  -webkit-box-decoration-break:clone;
  text-shadow:0 1px 4px rgba(0,0,0,.4);
  box-shadow:inset 0 -2px 0 rgba(0,0,0,.2), 2px 2px 0 rgba(0,0,0,.15);
}
.entry-content h2{font-size:1.45rem;letter-spacing:.08em;}
.entry-content h3{font-size:1.15rem;}
.entry-content h4{
  font-family:var(--ff-en);font-size:.72rem;letter-spacing:.3em;
  text-transform:uppercase;
  background:rgba(155,27,27,.15);
  color:var(--vermillion);
  border-left:3px solid var(--vermillion);
  padding:.35em .8em;
  box-shadow:none; text-shadow:none;
}
.entry-content p{margin-bottom:1.4rem;}
.entry-content a{color:var(--gold-light);text-decoration:underline;text-decoration-color:rgba(240,180,41,.3);transition:color .18s;}
.entry-content a:hover{color:var(--gold-bright);}
.entry-content blockquote{
  border-left:3px solid var(--gold);margin:2rem 0;padding:1rem 1.5rem;
  background:rgba(212,146,10,.06);font-style:italic;color:var(--gold-pale);
  font-size:1.05rem;line-height:1.75;
}
.entry-content blockquote cite{font-style:normal;font-family:var(--ff-en);font-size:.65rem;letter-spacing:.2em;color:var(--text-muted);display:block;margin-top:.5rem;}
.entry-content ul,.entry-content ol{padding-left:1.5rem;margin-bottom:1.4rem;}
.entry-content li{margin-bottom:.5rem;}
.entry-content ul li::marker{color:var(--gold);}
.entry-content img{max-width:100%;height:auto;filter:brightness(.85) sepia(.12);margin:1.5rem 0;border:1px solid rgba(212,146,10,.15);}
.entry-content hr{border:none;height:1px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);margin:2.5rem 0;}
.entry-content table{width:100%;border-collapse:collapse;margin-bottom:1.5rem;font-size:.9rem;}
.entry-content th{font-family:var(--ff-en);font-size:.6rem;letter-spacing:.2em;color:var(--gold);border-bottom:1px solid var(--gold-dim);padding:.6rem .8rem;text-align:left;text-transform:uppercase;}
.entry-content td{padding:.55rem .8rem;border-bottom:1px solid rgba(212,146,10,.07);color:var(--text-secondary);}
.entry-content tr:hover td{background:var(--gold-glow);}

/* Classical text */
.tpd-quote{border-left:3px solid var(--gold);margin:2rem 0;padding:1rem 1.5rem;background:rgba(212,146,10,.05);}
.tpd-quote-zh{font-family:var(--ff-zh);font-size:1.3rem;color:var(--gold-pale);display:block;letter-spacing:.15em;margin-bottom:.5rem;}
.tpd-quote-en{font-family:var(--ff-body);font-style:italic;font-size:.95rem;color:var(--text-secondary);display:block;}
.tpd-quote cite{font-style:normal;font-family:var(--ff-en);font-size:.62rem;letter-spacing:.2em;color:var(--text-muted);display:block;margin-top:.5rem;}

/* ── SIDEBAR ─────────────────────────────────────── */
.widget-area{position:sticky;top:92px;min-width:0;}
.widget{margin-bottom:2rem;border:1px solid rgba(212,146,10,.15);position:relative;overflow:hidden;}
.widget::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--vermillion),var(--gold));}
.widget-title{font-family:var(--ff-zh);font-size:.95rem;font-weight:700;color:var(--gold-light);letter-spacing:.1em;padding:.9rem 1.2rem;border-bottom:1px solid rgba(212,146,10,.1);background:rgba(212,146,10,.04);display:flex;align-items:center;gap:.6rem;margin:0;}
.widget-title::before{content:'⊡';font-size:.7rem;color:var(--vermillion);opacity:.7;}
.widget-body,.widget > ul,.widget > p,.widget > div{padding:1.1rem 1.2rem;}
/* Override ALL default widget link styles */
.widget ul{list-style:none;padding:0;margin:0;}
.widget ul li{padding:.4rem 1.2rem;border-bottom:1px solid rgba(212,146,10,.07);font-size:.85rem;color:var(--text-secondary);margin:0;}
.widget ul li:last-child{border-bottom:none;}
.widget ul li a{color:var(--text-secondary) !important;text-decoration:none !important;transition:color .18s;display:flex;align-items:baseline;gap:.4rem;font-family:var(--ff-body);font-size:.85rem;}
.widget ul li a::before{content:'·';color:var(--gold);opacity:.6;flex-shrink:0;}
.widget ul li a:hover{color:var(--gold-light) !important;}
.widget p{font-size:.88rem;color:var(--text-secondary);line-height:1.7;margin-bottom:.75rem;padding:0 1.2rem;}
.widget .tagcloud{padding:1.1rem 1.2rem;}
.widget .tagcloud a{display:inline-block;margin:.2rem;padding:.25rem .65rem;border:1px solid rgba(212,146,10,.2);color:var(--text-muted) !important;font-family:var(--ff-en);font-size:.62rem;letter-spacing:.1em;text-decoration:none !important;text-transform:uppercase;transition:all .18s;}
.widget .tagcloud a:hover{border-color:var(--gold);color:var(--gold-light) !important;background:var(--gold-glow);}
/* Search widget */
.widget_search .search-form,.widget_search form{display:flex;padding:1.1rem 1.2rem;}
.widget_search input[type="search"],.widget_search input[type="text"]{flex:1;background:rgba(10,7,4,.8);border:1px solid var(--gold-dim);border-right:none;color:var(--text-primary);padding:.55rem .8rem;font-family:var(--ff-body);font-size:.9rem;outline:none;border-radius:0;-webkit-appearance:none;}
.widget_search input[type="search"]:focus,.widget_search input[type="text"]:focus{border-color:var(--gold);}
.widget_search button,.widget_search input[type="submit"]{background:var(--vermillion);border:1px solid var(--vermillion);color:var(--gold-pale);padding:.55rem .9rem;cursor:pointer;font-family:var(--ff-en);font-size:.65rem;letter-spacing:.1em;border-radius:0;}
.widget_search button:hover,.widget_search input[type="submit"]:hover{background:var(--verm-light);}
/* Recent posts widget */
.widget_recent_entries ul li a{font-weight:400;}
.widget_recent_entries .post-date{font-family:var(--ff-en);font-size:.6rem;letter-spacing:.15em;color:var(--text-muted);display:block;margin-top:.15rem;padding-left:1rem;}

/* ── FOOTER ─────────────────────────────────────── */
#colophon{background:var(--ink-deep);border-top:1px solid var(--gold-dim);margin-top:4rem;}
.footer-inner{max-width:var(--max-w);margin:0 auto;padding:3.5rem 2rem 2rem;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr;gap:2.5rem;margin-bottom:3rem;}
.footer-brand-name{font-family:var(--ff-zh);font-size:1.3rem;font-weight:900;color:var(--gold-bright);letter-spacing:.15em;display:block;margin-bottom:.35rem;}
.footer-brand-tagline{font-family:var(--ff-en);font-size:.58rem;letter-spacing:.25em;color:var(--text-muted);display:block;margin-bottom:1rem;}
.footer-brand-desc{font-size:.82rem;color:var(--text-muted);line-height:1.7;}
.footer-col-title{font-family:var(--ff-en);font-size:.6rem;letter-spacing:.3em;color:var(--gold);text-transform:uppercase;margin-bottom:1rem;padding-bottom:.6rem;border-bottom:1px solid var(--gold-dim);}
.footer-links{list-style:none;}
.footer-links li{margin-bottom:.45rem;}
.footer-links a{font-size:.82rem;color:var(--text-muted);text-decoration:none;transition:color .18s;display:flex;align-items:center;gap:.4rem;}
.footer-links a::before{content:'道';font-size:.6rem;color:var(--gold);opacity:.45;}
.footer-links a:hover{color:var(--gold-light);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;padding-top:1.5rem;border-top:1px solid rgba(212,146,10,.1);font-family:var(--ff-en);font-size:.58rem;letter-spacing:.15em;color:var(--text-muted);}
.footer-bottom a{color:var(--gold);text-decoration:none;}

/* ── BREADCRUMBS ────────────────────────────────── */
.breadcrumbs{max-width:var(--max-w);margin:0 auto;padding:1rem 2rem 0;font-family:var(--ff-en);font-size:.58rem;letter-spacing:.18em;color:var(--text-muted);display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;}
.breadcrumbs a{color:var(--gold-dim);text-decoration:none;}
.breadcrumbs a:hover{color:var(--gold);}
.breadcrumbs .sep{color:var(--vermillion);opacity:.5;}

/* ── PAGINATION ─────────────────────────────────── */
.pagination{display:flex;justify-content:center;gap:.4rem;margin:3rem 0;flex-wrap:wrap;}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid rgba(212,146,10,.2);color:var(--text-muted);text-decoration:none;font-family:var(--ff-en);font-size:.68rem;letter-spacing:.1em;transition:all .18s;}
.pagination .current,.pagination .page-numbers:hover{background:var(--gold-glow);border-color:var(--gold);color:var(--gold-light);}

/* ── FORMS ──────────────────────────────────────── */
input,textarea,select{background:rgba(10,7,4,.8);border:1px solid rgba(212,146,10,.2);border-bottom:2px solid rgba(155,27,27,.4);color:var(--text-primary);padding:.65rem .9rem;font-family:var(--ff-body);font-size:.95rem;outline:none;width:100%;margin-bottom:.8rem;transition:border-color .18s;-webkit-appearance:none;border-radius:0;}
input:focus,textarea:focus,select:focus{border-color:var(--gold);border-bottom-color:var(--vermillion);}
input::placeholder,textarea::placeholder{color:var(--text-faint);}
label{font-family:var(--ff-en);font-size:.6rem;letter-spacing:.2em;color:rgba(212,146,10,.6);text-transform:uppercase;display:block;margin-bottom:.35rem;}
button[type="submit"],input[type="submit"]{background:linear-gradient(135deg,var(--vermillion),#b52020);border:1px solid rgba(212,146,10,.3);color:var(--gold-pale);padding:.8rem 2rem;font-family:var(--ff-en);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;width:auto;margin:0;transition:all .25s var(--ease);}
button[type="submit"]:hover{background:linear-gradient(135deg,#b52020,#c0392b);}

/* ── REVEAL ANIMATIONS ──────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-delay-1{transition-delay:.1s;}
.reveal-delay-2{transition-delay:.22s;}
.reveal-delay-3{transition-delay:.34s;}

/* ── RESPONSIVE ─────────────────────────────────── */
@media(max-width:1100px){.footer-grid{grid-template-columns:1.2fr 1fr 1fr;}}
@media(max-width:900px){
  .modules-grid{grid-template-columns:repeat(2,1fr);}
  .content-with-sidebar{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:768px){
  .main-navigation{display:none;}
  .main-navigation.toggled{display:block;position:fixed;inset:72px 0 0;background:rgba(8,6,4,.98);padding:2rem;overflow-y:auto;z-index:99;}
  .main-navigation.toggled ul{flex-direction:column;gap:0;}
  .main-navigation.toggled ul ul{position:static;display:flex;padding:0 1rem;}
  .menu-toggle{display:block;}
  .site-header-inner{padding:0 1rem;gap:.75rem;}
  .hero-inner{padding:3rem 1.25rem 2.5rem;}
  .content-area{padding:2.5rem 1.25rem;}
  .entry-header{padding:2.5rem 1.25rem 1.5rem;}
  .modules-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
}

/* ── GUTENBERG ──────────────────────────────────── */
.wp-block-quote{border-left:3px solid var(--gold);padding:1rem 1.5rem;margin:2rem 0;background:rgba(212,146,10,.05);font-style:italic;color:var(--gold-pale);}
.wp-block-image img{border:1px solid rgba(212,146,10,.15);}
.wp-block-separator{border:none;height:1px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);}
.wp-block-button__link{background:var(--vermillion)!important;color:var(--gold-pale)!important;border-radius:0!important;font-family:var(--ff-en);letter-spacing:.2em;}

/* Pre-render anti-flash — set by inline head script */
html.taiping-light-init body { background: #FADA5E !important; color: #1a0f00 !important; }

/* ═══════════════════════════════════════════════════════
   LIGHT MODE — Imperial Yellow · 黄天明
   Triggered by body.taiping-light class
   ═══════════════════════════════════════════════════════ */
body.taiping-light {
  --body-bg:    #FADA5E;
  --body-color: #1a0800;

  --ink:        #FADA5E;
  --ink-deep:   #f0c830;
  --silk:       #fbe270;
  --silk-mid:   #fce97a;
  --silk-light: #fdf0a0;
  --panel:      rgba(245,210,80,.85);

  --gold:        #6b3d00;
  --gold-light:  #7a4800;
  --gold-bright: #5a3000;
  --gold-pale:   #3d2000;
  --gold-dim:    rgba(90,50,0,.25);
  --gold-glow:   rgba(90,50,0,.08);

  --vermillion:  #9b0000;
  --verm-light:  #b30000;

  /* HIGH CONTRAST text on yellow */
  --text-primary:   #1a0800;          /* near-black brown — WCAG AA+ */
  --text-secondary: #2d1500;          /* dark brown */
  --text-muted:     rgba(45,21,0,.6);
  --text-faint:     rgba(45,21,0,.35);

  background: #FADA5E;
  color: #1a0800;
}

body.taiping-light::before {
  background:
    radial-gradient(ellipse 80% 60% at 50% -10%, rgba(155,27,27,.04) 0%, transparent 70%),
    radial-gradient(ellipse 60% 40% at 80% 80%, rgba(90,50,0,.04) 0%, transparent 60%);
}
body.taiping-light::after { opacity: .04; }

body.taiping-light #masthead {
  background: rgba(240,200,48,.98);
  border-bottom: 2px solid rgba(90,50,0,.2);
}
body.taiping-light .main-navigation a { color: #2d1500; }
body.taiping-light .main-navigation a:hover,
body.taiping-light .main-navigation .current-menu-item > a { color: #9b0000; }
body.taiping-light .main-navigation ul ul {
  background: rgba(240,200,48,.99);
  border-color: rgba(90,50,0,.25);
}
body.taiping-light .site-title { color: #6b3d00; }
body.taiping-light .site-tagline { color: rgba(45,21,0,.55); }

/* Entry content — high contrast on yellow */
body.taiping-light .entry-content {
  color: #1a0800;
}
body.taiping-light .entry-content p,
body.taiping-light .entry-content li,
body.taiping-light .entry-content td {
  color: #1a0800;
}

/* Headings — RED amulet tag on yellow background */
body.taiping-light .entry-content h1,
body.taiping-light .entry-content h2,
body.taiping-light .entry-content h3 {
  color: #fff;
  background: #9b0000;
  text-shadow: 0 1px 3px rgba(0,0,0,.35);
  box-shadow: inset 0 -2px 0 rgba(0,0,0,.2), 2px 2px 0 rgba(90,0,0,.25);
}
body.taiping-light .entry-content h4 {
  color: #9b0000;
  background: rgba(155,0,0,.08);
  border-left-color: #9b0000;
}

/* Entry title (page title above content) */
body.taiping-light .entry-title {
  color: #6b3d00;
  text-shadow: none;
}
body.taiping-light .entry-kicker { color: #9b0000; }

/* Blockquote */
body.taiping-light .entry-content blockquote {
  background: rgba(90,50,0,.07);
  border-left-color: #9b0000;
  color: #2d1500;
}
body.taiping-light .entry-content a {
  color: #9b0000;
  text-decoration-color: rgba(155,0,0,.3);
}
body.taiping-light .entry-content a:hover { color: #6b3d00; }

/* Cards and panels */
body.taiping-light .card,
body.taiping-light .module-card {
  background: rgba(245,215,90,.85);
  border-color: rgba(90,50,0,.2);
}
body.taiping-light .module-card:hover { background: rgba(240,205,70,.98); }
body.taiping-light .module-card-title-zh { color: #6b3d00; }
body.taiping-light .module-card-title-en,
body.taiping-light .module-card-desc { color: rgba(45,21,0,.7); }

body.taiping-light .widget {
  background: rgba(245,215,90,.8);
  border-color: rgba(90,50,0,.18);
}
body.taiping-light .widget-title { color: #6b3d00; }
body.taiping-light .widget ul li,
body.taiping-light .widget p { color: #2d1500; }

body.taiping-light #colophon {
  background: #f0c830;
  border-top-color: rgba(90,50,0,.2);
  color: #2d1500;
}
body.taiping-light .footer-brand-name { color: #6b3d00; }
body.taiping-light .footer-links a,
body.taiping-light .footer-brand-desc { color: rgba(45,21,0,.65); }
body.taiping-light .footer-links a:hover { color: #9b0000; }
body.taiping-light .footer-bottom { color: rgba(45,21,0,.5); }

body.taiping-light input,
body.taiping-light textarea,
body.taiping-light select {
  background: rgba(255,235,120,.9);
  border-color: rgba(90,50,0,.25);
  color: #1a0800;
}

body.taiping-light .breadcrumbs { color: rgba(45,21,0,.5); }
body.taiping-light .breadcrumbs a { color: rgba(90,50,0,.5); }
body.taiping-light .breadcrumbs a:hover { color: #9b0000; }

body.taiping-light .tpd-quote { border-left-color: #9b0000; }
body.taiping-light .tpd-quote-zh { color: #6b3d00; }
body.taiping-light .tpd-quote-en { color: #2d1500; }

/* ── Mode toggle button ─────────────────────────────── */

/* Wide template — WordPress adds page-template-page-wide to body reliably */
.page-template-page-wide .entry-content,
.page-template-page-wide-cards .entry-content {
  max-width: 100% !important;
}
/* Also target via article class for belt-and-braces */
.template-wide-wrap .entry-content,
.template-full-wrap .entry-content {
  max-width: 100% !important;
}

/* ═══════════════════════════════════════════════════════
   PAGE TEMPLATES
   ═══════════════════════════════════════════════════════ */

/* Wide — full 1200px, no sidebar */
.page-template-page-wide .content-area,
.page-template-page-wide-cards .content-area { max-width: var(--max-w); }
.page-template-page-wide .entry-content,
.page-template-page-wide-cards .entry-content { max-width: 100%; }

/* No title — remove top padding */
.page-template-page-no-title .entry-header { display: none; }
.page-template-page-no-title .site-content { padding-top: 0; }

/* Classical — narrow reading column, centred */
.tpd-classical-content { max-width: 680px; margin: 0 auto; }
.tpd-classical-content .entry-content { max-width: 100%; font-size: 1.05rem; line-height: 2.1; }

/* Cards section below content */
.tpd-cards-section {
  border-top: 1px solid var(--gold-dim);
  padding: 4rem 0;
  margin-top: 2rem;
  background: rgba(10,7,4,.4);
}
.tpd-section-header { margin-bottom: 1.5rem; }

/* No Title — full width */
.page-template-page-no-title .content-area { padding-top: 2rem; }

/* Landing — strip chrome */
.page-template-page-landing #masthead,
.page-template-page-landing #colophon,
.page-template-page-landing .widget-area,
.page-template-page-landing .breadcrumbs { display: none; }
.page-template-page-landing .content-area { max-width: 100%; padding: 0; }

/* ═══════════════════════════════════════════════════════
   PAGINATION STYLES
   ═══════════════════════════════════════════════════════ */

/* Style: Minimal (default — already defined above) */

/* Style: Pill */
body.pagination-pill .pagination .page-numbers {
  border-radius: 999px;
}

/* Style: Large */
body.pagination-large .pagination .page-numbers {
  width: 56px; height: 56px; font-size: .8rem;
}

/* Style: Text links */
body.pagination-text .pagination .page-numbers {
  width: auto; height: auto;
  border: none; padding: .4rem .75rem;
  background: none !important;
}
body.pagination-text .pagination .current {
  color: var(--gold-bright); font-weight: 600;
  border-bottom: 2px solid var(--gold);
}

/* Style: Wide bar */
body.pagination-bar .pagination {
  display: flex; gap: 0;
  border: 1px solid var(--gold-dim);
}
body.pagination-bar .pagination .page-numbers {
  border: none; border-right: 1px solid var(--gold-dim);
  border-radius: 0;
}
body.pagination-bar .pagination .page-numbers:last-child { border-right: none; }

@media(max-width:600px) {
  body.template-full-width .content-area { padding-left:1.25rem; padding-right:1.25rem; }
}
