/* =====================================================================
   GOKUDO — Theory(理念页)专属版式。1:1 还原自设计稿 theory.html。
   仅在 /theory/ 加载;通用 banner/footer/reveal 见 site.css。
   ===================================================================== */

/* ============ EDITORIAL HERO ============ */
.ehero{position:relative;background:var(--bg);border-bottom:1px solid var(--line);overflow:hidden;padding:50px 0 0}
.ehero .crumb{display:flex;align-items:center;gap:10px;color:var(--faint);margin-bottom:54px}
.ehero .crumb a{color:var(--faint);transition:color .2s}
.ehero .crumb a:hover{color:var(--accent)}
.ehero .crumb .sep{color:var(--line)}
.ehero .crumb .cur{color:var(--ink)}
.ehero-grid{display:grid;grid-template-columns:1fr auto;gap:40px;align-items:end}
.eh-kicker{display:flex;align-items:center;gap:14px;color:var(--accent);font-family:var(--mono);font-size:12px;letter-spacing:.24em;text-transform:uppercase;margin-bottom:26px}
.eh-kicker .ln{width:54px;height:1px;background:var(--accent)}
.ehero h1{font-family:var(--display);font-weight:900;font-size:clamp(74px,13vw,210px);line-height:.78;
	text-transform:uppercase;letter-spacing:-.025em}
.ehero h1 em{font-style:normal;color:var(--accent)}
.eh-han-col{writing-mode:vertical-rl;text-orientation:upright;font-family:var(--han);font-size:clamp(40px,5vw,74px);
	line-height:1.05;color:var(--ink);letter-spacing:.08em;align-self:stretch;display:flex;align-items:flex-start;padding-bottom:8px}
.eh-han-col .red{color:var(--accent)}
/* lede with drop cap */
.ehero-lede{border-top:1px solid var(--line);margin-top:54px;padding:46px 0 60px;display:grid;grid-template-columns:1fr 1.5fr;gap:60px}
.ehero-lede .lab{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);line-height:1.8}
.ehero-lede .lab .han{font-family:var(--han);color:var(--accent);font-size:15px;letter-spacing:.1em;display:block;margin-bottom:8px}
.lede-body{font-size:clamp(19px,2vw,25px);line-height:1.65;color:var(--ink);max-width:680px;text-wrap:pretty}
.lede-body p:first-of-type::first-letter{initial-letter:3;-webkit-initial-letter:3;font-family:var(--display);font-weight:900;color:var(--accent);margin-right:14px;text-transform:uppercase}
.lede-body p+p{margin-top:22px}

/* ============ DARK FEATURE(image + text)============ */
.dark{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.dark .theory-jp{position:absolute;left:-2vw;top:50%;transform:translateY(-50%);font-family:var(--display);
	font-size:62vh;line-height:.8;color:rgba(255,255,255,.04);pointer-events:none;user-select:none}
.split{display:grid;grid-template-columns:1fr 1fr;min-height:78vh}
.split-media{position:relative;overflow:hidden;background:#000}
.split-media img{width:100%;height:100%;object-fit:cover;object-position:center}
.split-media .cap{position:absolute;left:24px;bottom:22px;z-index:3;font-family:var(--mono);font-size:10px;
	letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.6);display:flex;align-items:center;gap:10px}
.split-media .cap .han{font-family:var(--han);color:var(--accent);letter-spacing:.1em;font-size:13px}
.split-text{display:flex;flex-direction:column;justify-content:center;padding:clamp(40px,7vw,100px);position:relative;z-index:2}
.split-text .n{font-family:var(--mono);font-size:11px;letter-spacing:.24em;color:var(--accent);margin-bottom:30px;display:flex;align-items:center;gap:12px}
.split-text .n .ln{width:40px;height:1px;background:var(--accent)}
.split-text h2{font-family:var(--display);font-weight:900;font-size:clamp(40px,5.2vw,82px);line-height:.92;text-transform:uppercase;letter-spacing:-.015em}
.split-text h2 em{font-style:normal;color:var(--accent)}
.split-text .han-big{font-family:var(--han);font-size:clamp(30px,4vw,58px);color:var(--gold);margin:18px 0 26px;letter-spacing:.1em}
.split-text p{color:rgba(255,255,255,.72);font-size:17px;line-height:1.8;max-width:480px}
.split-text p+p{margin-top:18px}
.split-text p strong{color:#fff;font-weight:600}

/* ============ MANIFESTO ============ */
.manifesto{padding:130px 0;background:var(--bg);position:relative}
.manifesto .mk{font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin-bottom:40px;display:flex;align-items:center;gap:14px}
.manifesto .mk .ln{width:54px;height:1px;background:var(--accent)}
.manifesto blockquote{font-family:var(--display);font-weight:400;text-transform:uppercase;
	font-size:clamp(34px,5.2vw,86px);line-height:1.0;letter-spacing:-.015em;max-width:1180px;text-wrap:balance}
.manifesto blockquote em{font-style:normal;color:var(--accent)}
.manifesto .attrib{margin-top:46px;font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--faint);display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.manifesto .attrib .han{font-family:var(--han);color:var(--accent);letter-spacing:.12em;font-size:14px}
.manifesto .attrib .dot{width:5px;height:5px;background:var(--line);border-radius:50%}

/* ============ PILLARS ============ */
.pillars-sec{padding:0 0 130px;background:var(--bg)}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.pillar{background:var(--bg);padding:46px 40px 40px;position:relative;transition:background .3s}
.pillar:hover{background:var(--bg2)}
.pillar .n{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.2em;margin-bottom:34px}
.pillar .jp{font-family:var(--han);font-size:96px;line-height:.85;color:var(--ink);margin-bottom:26px}
.pillar:hover .jp{color:var(--accent)}
.pillar h4{font-family:var(--display);font-size:26px;text-transform:uppercase;letter-spacing:.01em;margin-bottom:14px}
.pillar p{color:var(--muted);font-size:15px;line-height:1.7}

/* ============ PROCESS ============ */
.process-sec{padding:120px 0;background:var(--bg2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.process-jp{position:absolute;right:-2vw;top:50%;transform:translateY(-50%);font-family:var(--display);font-size:50vh;line-height:.8;color:rgba(0,0,0,.035);pointer-events:none;user-select:none}
.process-head{position:relative;z-index:2;display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap;margin-bottom:60px}
.process-head h2{font-family:var(--display);font-weight:900;font-size:clamp(40px,5vw,76px);line-height:.92;text-transform:uppercase;letter-spacing:-.015em}
.process-head h2 em{font-style:normal;color:var(--accent)}
.process-head .meta{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);text-align:right}
.process-head .meta .han{font-family:var(--han);color:var(--accent);font-size:14px;letter-spacing:.12em}
.psteps{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;position:relative;z-index:2}
.pstep{position:relative;padding-top:24px;border-top:2px solid var(--ink)}
.pstep .pn{font-family:var(--display);font-size:52px;line-height:.8;color:var(--accent);margin-bottom:20px}
.pstep .jp{font-family:var(--han);font-size:15px;color:var(--faint);margin-bottom:11px;display:block;letter-spacing:.12em}
.pstep h4{font-family:var(--display);font-size:21px;text-transform:uppercase;letter-spacing:.02em;margin-bottom:12px}
.pstep p{color:var(--muted);font-size:14.5px;line-height:1.65}

/* ============ VERTICAL TYPO FEATURE ============ */
.vfeature{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.vfeature-in{display:grid;grid-template-columns:auto 1fr;gap:clamp(40px,8vw,120px);align-items:center;padding:120px 0}
.vstack{writing-mode:vertical-rl;text-orientation:upright;font-family:var(--han);font-size:clamp(44px,7vw,120px);line-height:1.0;letter-spacing:.06em;color:#fff}
.vstack .red{color:var(--accent)}
.vfeature-body{max-width:560px}
.vfeature-body .mk{font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:26px}
.vfeature-body h2{font-family:var(--display);font-weight:900;font-size:clamp(34px,4vw,62px);line-height:.95;text-transform:uppercase;letter-spacing:-.01em;margin-bottom:24px}
.vfeature-body h2 em{font-style:normal;color:var(--accent)}
.vfeature-body p{color:rgba(255,255,255,.72);font-size:17px;line-height:1.8}
.vfeature-body p+p{margin-top:18px}
.vfeature-body p strong{color:#fff;font-weight:600}

/* ============ CLOSING CTA ============ */
.closing{padding:110px 0;background:var(--bg);text-align:center}
.closing .glyph{font-family:var(--han);font-size:clamp(60px,9vw,140px);color:var(--accent);line-height:1;margin-bottom:30px}
.closing h2{font-family:var(--display);font-weight:900;font-size:clamp(36px,5vw,72px);line-height:.95;text-transform:uppercase;letter-spacing:-.01em;max-width:900px;margin:0 auto 18px}
.closing h2 em{font-style:normal;color:var(--accent)}
.closing p{color:var(--muted);font-size:17px;line-height:1.6;max-width:480px;margin:0 auto 38px}
.closing .btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.closing a.btn{display:inline-flex;align-items:center;gap:12px;font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;padding:18px 30px;font-weight:700;transition:.22s}
.closing a.btn.solid{background:var(--accent);color:#fff}
.closing a.btn.solid:hover{background:var(--ink);gap:18px}
.closing a.btn.ghost{border:1px solid var(--line);color:var(--ink)}
.closing a.btn.ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink);gap:18px}

/* ============ RESPONSIVE(Theory 专属)============ */
@media(max-width:980px){
	.ehero-grid{grid-template-columns:1fr}
	.eh-han-col{writing-mode:horizontal-tb;font-size:clamp(36px,8vw,60px)}
	.ehero-lede{grid-template-columns:1fr;gap:24px}
	.split{grid-template-columns:1fr}
	.split-media{min-height:50vh}
	.pillars{grid-template-columns:1fr}
	.psteps{grid-template-columns:1fr 1fr;gap:40px 24px}
	.vfeature-in{grid-template-columns:1fr;gap:50px;padding:80px 0}
	.vstack{writing-mode:horizontal-tb;font-size:clamp(40px,10vw,72px)}
}
@media(max-width:560px){
	.psteps{grid-template-columns:1fr}
}
