/* ============================================================
   craftagent — CỬA VÀO extra page templates (spoke article · pillar hero)
   Same system tokens. Loaded AFTER styles.css/diagrams.css/cua-vao.css on
   the cua-vao cluster's article pages. Ported from the Claude Design handoff
   (GARDEN-044); the homepage "fork" variant was intentionally dropped.
   ============================================================ */

/* ============================================================
   SPOKE — scene masthead + light reading column + one exit door
   ============================================================ */
.spoke-mast{position:relative;z-index:1;border-bottom:1px solid var(--line);background:linear-gradient(180deg,color-mix(in srgb,var(--wash) 50%,var(--paper)),var(--paper))}
.spoke-mast-in{max-width:1000px;margin:0 auto;padding:44px 30px 40px;display:flex;flex-direction:column;align-items:flex-start}
.spoke-crumb{display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:30px;flex-wrap:wrap}
.spoke-crumb a{color:var(--ink-mute);text-decoration:none;display:inline-flex;align-items:center;gap:7px}
.spoke-crumb a:hover{color:var(--accent)}
.spoke-crumb a svg{width:14px;height:14px}
.spoke-crumb .sep{width:4px;height:4px;border-radius:50%;background:var(--line-2)}
.spoke-crumb .role{color:var(--accent);font-weight:600}
.spoke-sk{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-weight:600;display:inline-flex;align-items:center;gap:.7em;margin-bottom:16px}
.spoke-sk::before{content:"";width:18px;height:1.5px;background:var(--accent)}
.spoke-scene{position:relative;font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(25px,3.7vw,42px);line-height:1.2;letter-spacing:-.02em;color:var(--ink);margin:0;max-width:22ch;padding-left:24px}
.spoke-scene::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:4px;border-radius:3px;background:linear-gradient(var(--accent),var(--accent-ink))}
.spoke-title{font-family:var(--serif);font-weight:500;font-size:clamp(18px,2vw,23px);line-height:1.4;color:var(--ink-soft);margin:26px 0 0;max-width:48ch}
.spoke-title b{color:var(--ink);font-weight:600}
.spoke-meta{display:flex;align-items:center;gap:0;margin:26px 0 0;border-top:1px solid var(--line);flex-wrap:wrap;max-width:640px}
.spoke-meta .cell{padding:12px 22px 2px;display:flex;flex-direction:column;gap:3px;border-right:1px solid var(--line)}
.spoke-meta .cell:first-child{padding-left:0}
.spoke-meta .cell:last-child{border-right:0}
.spoke-meta .k{font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute)}
.spoke-meta .v{font-family:var(--sans);font-size:13.5px;font-weight:600;color:var(--ink)}
.spoke-meta .v a{color:var(--accent)}

.spoke-wrap{max-width:var(--read);margin:0 auto;padding:46px 30px 0;position:relative;z-index:1}
/* TL;DR */
.spoke-tldr{margin:0 0 10px;background:var(--wash);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:0 14px 14px 0;padding:18px 22px}
.spoke-tldr .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:600;display:block;margin-bottom:8px}
.spoke-tldr p{font-family:var(--serif);font-style:italic;font-size:17px;line-height:1.55;color:var(--ink-soft);margin:0}
.spoke-tldr em{font-style:normal;font-weight:600;color:var(--ink)}

/* the one exit door */
.spoke-exit{max-width:var(--read);margin:54px auto 0;padding:0 30px;position:relative;z-index:1}
.exit-card{position:relative;background:var(--raise);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:0 20px 20px 0;padding:30px 32px 28px;box-shadow:var(--shadow);overflow:hidden}
.exit-card::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(80% 70% at 100% 0,var(--wash),transparent 58%);opacity:.6}
.exit-k{position:relative;font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-weight:600;display:inline-flex;align-items:center;gap:.7em;margin-bottom:14px}
.exit-k::before{content:"";width:18px;height:1.5px;background:var(--accent)}
.exit-h{position:relative;font-family:var(--serif);font-weight:500;font-size:clamp(21px,2.4vw,27px);line-height:1.25;letter-spacing:-.015em;color:var(--ink);margin:0;max-width:30ch}
.exit-h em{font-style:italic;color:var(--accent)}
.exit-targets{position:relative;display:flex;flex-direction:column;gap:10px;margin-top:22px}
.exit-target{display:flex;align-items:center;gap:16px;background:var(--paper-2);border:1px solid var(--line);border-radius:13px;padding:15px 18px;text-decoration:none;color:inherit;transition:transform .2s var(--ease),border-color .2s,box-shadow .2s;position:relative;overflow:hidden}
.exit-target::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);transform:scaleX(1) scaleY(0);transform-origin:top;transition:transform .25s}
.exit-target:hover{transform:translateY(-2px);border-color:var(--line-2);box-shadow:var(--shadow-sm)}
.exit-target:hover::after{transform:scaleY(1)}
.exit-target .et-tx{flex:1;min-width:0}
.exit-target .et-cl{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-weight:600;display:block;margin-bottom:4px}
.exit-target .et-h{font-family:var(--serif);font-weight:500;font-size:16px;line-height:1.25;color:var(--ink);display:block}
.exit-target .et-go{flex:0 0 auto;color:var(--accent)}
.exit-target .et-go svg{width:20px;height:20px;transition:transform .25s var(--spring)}
.exit-target:hover .et-go svg{transform:translateX(4px)}

/* lateral: the other pains as a slim strip */
.spoke-doors{max-width:var(--read);margin:34px auto 0;padding:0 30px;position:relative;z-index:1}
.spoke-doors .sd-h{display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:16px}
.spoke-doors .sd-h .ln{flex:1;height:1px;background:var(--line)}
.sd-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.sd-item{display:flex;align-items:center;gap:11px;background:var(--raise);border:1px solid var(--line);border-radius:11px;padding:11px 13px;text-decoration:none;color:inherit;transition:border-color .2s,transform .15s,background .2s}
.sd-item:hover{border-color:var(--accent);transform:translateX(2px)}
.sd-item.cur{background:var(--wash);border-color:var(--accent-ink)}
.sd-item .sd-n{font-family:var(--mono);font-size:11px;color:var(--ink-mute);flex:0 0 auto;width:20px}
.sd-item.cur .sd-n{color:var(--accent);font-weight:600}
.sd-item b{font-family:var(--sans);font-size:12.5px;font-weight:600;color:var(--ink);line-height:1.25}
.spoke-back{max-width:var(--read);margin:30px auto 0;padding:0 30px;position:relative;z-index:1}
.spoke-back a{font-family:var(--sans);font-size:13px;font-weight:600;color:var(--ink-mute);text-decoration:none;display:inline-flex;align-items:center;gap:8px}
.spoke-back a:hover{color:var(--accent)}
.spoke-back a svg{width:15px;height:15px}

/* ============================================================
   PILLAR — interactive pain-map sits as the hero (reuses .doormap)
   ============================================================ */
.pillar-hero{max-width:var(--maxw);margin:0 auto;padding:54px 30px 10px;position:relative;z-index:1}
.pillar-head{max-width:780px;margin-bottom:34px}
.pillar-head .ph-k{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-weight:600;display:inline-flex;align-items:center;gap:.7em}
.pillar-head .ph-k::before{content:"";width:18px;height:1.5px;background:var(--accent)}
.pillar-head h1{font-family:var(--serif);font-weight:500;font-size:clamp(32px,4.6vw,58px);line-height:1.03;letter-spacing:-.03em;margin:16px 0 0;color:var(--ink)}
.pillar-head h1 em{font-style:italic;color:var(--accent)}
.pillar-head .ph-dek{font-family:var(--serif);font-style:italic;font-size:20px;line-height:1.5;color:var(--ink-soft);margin:18px 0 0;max-width:44ch}
.pillar-mapnote{font-family:var(--sans);font-size:13.5px;color:var(--ink-mute);line-height:1.6;margin:18px 0 0;max-width:60ch}
.pillar-mapnote b{color:var(--ink);font-weight:600}
/* the pillar's article body keeps the standard reading column width, centered */
.pillar-body{max-width:var(--read);margin:0 auto;padding:8px 30px 0;position:relative;z-index:1}

@media(max-width:860px){.sd-grid{grid-template-columns:1fr}}
