
:root{
  --bg:#050a1e;
  --bg2:#081130;
  --glass:rgba(13,23,48,.66);
  --glass2:rgba(20,33,66,.55);
  --line:rgba(110,140,200,.18);
  --line-hi:rgba(65,217,255,.32);
  --amber:#41d9ff;
  --copper:#3b82ff;
  --cyan:#8fb6ff;
  --violet:#ff3d6e;
  --text:#dce6f7;
  --muted:#93a3c4;
  --faint:#5d6c95;
  --ok:#6fe3a5;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --serif:'Shippori Mincho',serif;
  --sans:'Zen Kaku Gothic New',sans-serif;
  --glow-amber:0 0 28px rgba(65,217,255,.22);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:96px}
body{
  background:
    radial-gradient(1100px 540px at 80% -8%, rgba(255,61,110,.10), transparent 60%),
    radial-gradient(900px 480px at 10% 6%, rgba(59,130,255,.10), transparent 55%),
    radial-gradient(1300px 700px at 50% 112%, rgba(65,217,255,.13), transparent 62%),
    var(--bg);
  color:var(--text);font-family:var(--sans);font-size:16px;line-height:1.95;
  -webkit-font-smoothing:antialiased;min-height:100vh;
}
::selection{background:var(--amber);color:var(--bg)}
a{color:var(--cyan);text-decoration:none;border-bottom:1px solid transparent;transition:.2s}
a:hover{color:var(--amber);border-bottom-color:var(--amber)}
code{font-family:var(--mono);font-size:.85em;background:rgba(10,15,25,.8);border:1px solid var(--line);border-radius:4px;padding:.1em .45em;color:var(--amber)}
kbd{font-family:var(--mono);font-size:.78em;background:var(--glass2);border:1px solid var(--line);border-bottom-width:2px;border-radius:5px;padding:.14em .5em;color:var(--text)}
:focus-visible{outline:2px solid var(--amber);outline-offset:2px;border-radius:3px}

/* ===== 固定ナビ（ガラス） ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;
  background:rgba(7,11,20,.72);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line)}
.nav-in{max-width:1180px;margin:0 auto;display:flex;align-items:center;gap:22px;padding:0 24px;height:60px}
.nav-brand{font-family:var(--mono);font-size:13px;color:var(--muted);white-space:nowrap;border-bottom:0}
.nav-brand b{color:var(--amber);font-weight:500}
.nav-links{display:flex;gap:2px;overflow-x:auto;scrollbar-width:none;flex:1}
.nav-links::-webkit-scrollbar{display:none}
.nav-links a{font-family:var(--mono);font-size:12px;color:var(--muted);padding:6px 11px;border-radius:6px;white-space:nowrap;border-bottom:0}
.nav-links a:hover{color:var(--text);background:var(--glass2)}
.nav-links a.on{color:var(--amber);background:var(--glass2);box-shadow:inset 0 0 0 1px var(--line-hi)}

/* ===== レイアウト ===== */
.wrap{max-width:880px;margin:0 auto;padding:108px 24px 80px}
.wrap-wide{max-width:1180px;margin:0 auto;padding:0 24px}

/* ===== ホーム・ヒーロー（奥行き） ===== */
.hero{position:relative;overflow:hidden;padding:150px 0 90px}
.hero-floor{position:absolute;left:50%;bottom:-2%;width:200vw;height:62%;transform:translateX(-50%) perspective(560px) rotateX(63deg);transform-origin:center bottom;
  background:
    linear-gradient(rgba(65,217,255,.18) 1px,transparent 1px),
    linear-gradient(90deg,rgba(65,217,255,.18) 1px,transparent 1px);
  background-size:54px 54px;
  -webkit-mask-image:linear-gradient(to top,rgba(0,0,0,.85),transparent 78%);
  mask-image:linear-gradient(to top,rgba(0,0,0,.85),transparent 78%);
  animation:floor 9s linear infinite;pointer-events:none}
@keyframes floor{to{background-position-y:54px}}
.hero-glow{position:absolute;left:50%;bottom:6%;width:760px;height:240px;transform:translateX(-50%);
  background:radial-gradient(closest-side,rgba(65,217,255,.22),transparent);filter:blur(8px);pointer-events:none}
.hero-in{position:relative;max-width:1180px;margin:0 auto;padding:0 24px;text-align:center}
.hero-eyebrow{font-family:var(--mono);font-size:13px;letter-spacing:.22em;color:var(--copper);margin-bottom:22px}
.hero h1{font-family:var(--serif);font-weight:700;font-size:clamp(36px,5.4vw,64px);line-height:1.32;margin-bottom:22px;
  text-shadow:0 0 44px rgba(65,217,255,.18)}
.hero h1 em{font-style:normal;color:var(--amber)}
.hero .lede{max-width:640px;margin:0 auto 44px;color:var(--muted);font-size:17px}
.hero-meta{font-family:var(--mono);font-size:12px;color:var(--faint);letter-spacing:.08em;margin-top:46px}

/* ヒーロー・ターミナル（傾き＋浮遊） */
.term{position:relative;max-width:720px;margin:0 auto;text-align:left;
  background:rgba(8,12,21,.9);border:1px solid var(--line);border-radius:12px;overflow:hidden;
  box-shadow:0 40px 90px rgba(0,0,0,.55), var(--glow-amber), inset 0 1px 0 rgba(190,242,255,.05);
  transform:perspective(1300px) rotateX(5deg);transform-origin:center bottom}
.term-bar{display:flex;align-items:center;gap:8px;background:var(--glass);padding:11px 15px;border-bottom:1px solid var(--line)}
.term-bar .dot{width:11px;height:11px;border-radius:50%;background:var(--line)}
.term-bar .dot:first-child{background:#3a2f2a}
.term-bar .title{font-family:var(--mono);font-size:12px;color:var(--faint);margin-left:8px}
.term-body{font-family:var(--mono);font-size:13.5px;line-height:1.9;padding:20px 22px;min-height:215px;color:#c9d2e0}
.term-body .ln{display:block;white-space:pre-wrap;word-break:break-all}
.term-body .p{color:var(--amber)}
.term-body .c{color:var(--faint)}
.term-body .g{color:var(--ok)}
.term-body .v{color:var(--violet)}
.cursor{display:inline-block;width:.6em;height:1.15em;background:var(--amber);vertical-align:-0.18em;animation:blink 1.05s steps(1) infinite}
@keyframes blink{50%{opacity:0}}

/* ===== ホーム：学習マップ（深度カード） ===== */
.map{padding:80px 0 110px}
.map h2{font-family:var(--serif);font-size:clamp(24px,3vw,32px);font-weight:600;text-align:center;margin-bottom:8px}
.map .sub{text-align:center;color:var(--muted);margin-bottom:48px;font-size:15px}
.map-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(252px,1fr));gap:18px}
.mcard{position:relative;display:block;background:var(--glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid var(--line);border-radius:12px;padding:26px 24px 22px;border-bottom:1px solid var(--line);
  transition:transform .3s cubic-bezier(.2,.8,.3,1), box-shadow .3s, border-color .3s;color:var(--text)}
.mcard:hover{transform:translateY(-6px);border-color:var(--line-hi);box-shadow:0 26px 56px rgba(0,0,0,.5), var(--glow-amber);color:var(--text)}
.mcard .num{font-family:var(--mono);font-size:12px;color:var(--copper);letter-spacing:.14em;margin-bottom:12px;display:flex;justify-content:space-between}
.mcard .num .new{color:var(--violet);border:1px solid rgba(255,61,110,.5);border-radius:4px;padding:0 7px;font-size:10.5px;letter-spacing:.1em}
.mcard h3{font-family:var(--serif);font-size:19px;font-weight:600;margin-bottom:10px;line-height:1.55}
.mcard p{font-size:13.5px;color:var(--muted);line-height:1.85}
.mcard .go{position:absolute;right:20px;bottom:16px;font-family:var(--mono);font-size:12px;color:var(--faint);transition:.25s}
.mcard:hover .go{color:var(--amber);transform:translateX(4px)}

/* ===== 記事ページ共通 ===== */
.page-head{padding:34px 0 40px;border-bottom:1px solid var(--line);margin-bottom:48px;text-align:center}
.crumb{font-family:var(--mono);font-size:12px;color:var(--faint);letter-spacing:.1em;margin-bottom:16px}
.crumb b{color:var(--copper);font-weight:500}
.page-head h1{font-family:var(--serif);font-weight:700;font-size:clamp(28px,4vw,42px);line-height:1.42;margin-bottom:14px}
.page-head .lede{color:var(--muted);max-width:680px;font-size:16px;margin:0 auto}
h2{font-family:var(--serif);font-weight:600;font-size:clamp(22px,2.6vw,28px);margin:64px 0 16px;line-height:1.55;display:flex;gap:14px;align-items:baseline}
h2 .pm{font-family:var(--mono);font-size:15px;color:var(--copper);flex-shrink:0}
h3{font-family:var(--serif);font-weight:600;font-size:19.5px;margin:44px 0 14px;padding-left:14px;border-left:3px solid var(--amber);line-height:1.6}
h4{font-size:15.5px;font-weight:700;margin:28px 0 10px}
p{margin-bottom:14px}
ul,ol{margin:0 0 18px 1.4em}
li{margin-bottom:9px}
li::marker{color:var(--copper)}

/* コード */
.code{position:relative;background:rgba(8,12,21,.92);border:1px solid var(--line);border-radius:10px;margin:16px 0 24px;max-width:100%;
  box-shadow:0 12px 32px rgba(0,0,0,.35)}
.code pre{padding:17px 19px;overflow-x:auto;font-family:var(--mono);font-size:13.5px;line-height:1.85;color:#c9d2e0}
.code .lang{position:absolute;top:0;right:48px;font-family:var(--mono);font-size:10.5px;color:var(--faint);padding:7px 8px;letter-spacing:.06em}
.copy{position:absolute;top:7px;right:7px;background:var(--glass);border:1px solid var(--line);color:var(--muted);border-radius:5px;font-family:var(--mono);font-size:11px;padding:4px 9px;cursor:pointer;transition:.2s}
.copy:hover{color:var(--amber);border-color:var(--copper)}
.copy.done{color:var(--ok);border-color:var(--ok)}
.code .cm{color:var(--faint)}
.code .am{color:var(--amber)}
.code .cy{color:var(--cyan)}
.code .vi{color:var(--violet)}

/* プロンプトカード（日本語テンプレ用） */
.pcard{background:linear-gradient(160deg,rgba(26,35,56,.6),rgba(14,20,34,.7));border:1px solid var(--line);border-left:3px solid var(--violet);
  border-radius:0 10px 10px 0;padding:18px 20px;margin:16px 0 24px;max-width:100%;position:relative}
.pcard .pt{font-family:var(--mono);font-size:11px;color:var(--violet);letter-spacing:.12em;margin-bottom:10px}
.pcard pre{font-family:var(--sans);font-size:14.5px;line-height:2;white-space:pre-wrap;color:var(--text)}
.pcard .copy{top:12px}

/* タブ */
.tabs{max-width:100%;margin:18px 0 28px}
.tab-row{display:flex;gap:4px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.tab-btn{background:none;border:0;border-bottom:2px solid transparent;color:var(--muted);font-family:var(--mono);font-size:13px;padding:9px 16px;cursor:pointer;transition:.2s;margin-bottom:-1px}
.tab-btn:hover{color:var(--text)}
.tab-btn.active{color:var(--amber);border-bottom-color:var(--amber)}
.tab-panel{display:none;padding-top:6px}
.tab-panel.active{display:block}

/* カード・表 */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(218px,1fr));gap:14px;max-width:100%;margin:22px 0 14px}
.card{background:var(--glass);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:10px;padding:18px 18px 16px;transition:.25s}
.card:hover{border-color:var(--line-hi);transform:translateY(-3px)}
.card .ct{font-family:var(--mono);font-size:13px;color:var(--amber);margin-bottom:8px}
.card p{font-size:13.5px;color:var(--muted);line-height:1.85;margin:0;max-width:none}
.tbl-wrap{overflow-x:auto;max-width:100%;margin:18px 0 28px;border:1px solid var(--line);border-radius:10px;background:rgba(10,15,26,.5)}
table{width:100%;border-collapse:collapse;font-size:14px;min-width:560px}
th{font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.05em;color:var(--copper);text-align:left;background:var(--glass);padding:11px 16px;border-bottom:1px solid var(--line);white-space:nowrap}
td{padding:12px 16px;border-bottom:1px solid var(--line);vertical-align:top}
tr:last-child td{border-bottom:0}
td.k{font-family:var(--mono);font-size:13px;color:var(--amber);white-space:nowrap}
td .sub{color:var(--muted);font-size:13px}

/* 検証バッジ */
.bdg{display:inline-block;font-family:var(--mono);font-size:11.5px;border-radius:5px;padding:2px 9px;white-space:nowrap}
.bdg.ok{color:var(--ok);border:1px solid rgba(158,206,106,.45)}
.bdg.mid{color:#ffc24d;border:1px solid rgba(255,194,77,.5)}
.bdg.ng{color:#ff5d80;border:1px solid rgba(255,93,128,.5)}

/* 注意・ヒント */
.note{display:flex;gap:12px;background:var(--glass);border:1px solid var(--line);border-left:3px solid var(--cyan);border-radius:0 10px 10px 0;padding:15px 18px;max-width:100%;margin:18px 0 24px;font-size:14.5px;color:var(--muted)}
.note.warn{border-left-color:var(--copper)}
.note b{color:var(--text)}
.note .ic{font-family:var(--mono);color:var(--cyan);flex-shrink:0}
.note.warn .ic{color:var(--copper)}

/* 手順 */
.flow{max-width:100%;margin:26px 0;counter-reset:step}
.step{position:relative;padding:0 0 34px 58px;counter-increment:step}
.step::before{content:counter(step,decimal-leading-zero);position:absolute;left:0;top:2px;font-family:var(--mono);font-size:13px;color:var(--bg);background:linear-gradient(150deg,var(--amber),var(--copper));width:37px;height:37px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;box-shadow:var(--glow-amber)}
.step::after{content:'';position:absolute;left:18px;top:48px;bottom:6px;width:1px;background:linear-gradient(var(--line-hi),var(--line))}
.step:last-child::after{display:none}
.step h4{margin:5px 0 8px}
.step p,.step ul{font-size:14.5px;color:var(--muted)}

/* ゲージ */
.gauge{max-width:100%;background:var(--glass);border:1px solid var(--line);border-radius:10px;padding:20px 22px;margin:24px 0 32px}
.gauge .glabel{display:flex;justify-content:space-between;font-family:var(--mono);font-size:12px;color:var(--muted);margin-bottom:9px}
.gauge .track{height:14px;background:rgba(8,12,21,.9);border:1px solid var(--line);border-radius:7px;overflow:hidden}
.gauge .fill{height:100%;width:0;border-radius:7px;background:linear-gradient(90deg,var(--ok),var(--amber) 55%,var(--violet));transition:width 1.6s cubic-bezier(.25,.7,.3,1)}
.gauge .cap{font-size:13px;color:var(--faint);margin-top:10px;font-family:var(--mono)}

/* オーケストレーション図 */
.orch{max-width:100%;margin:26px 0 32px;background:var(--glass);border:1px solid var(--line);border-radius:12px;padding:30px 24px;text-align:center;overflow-x:auto}
.orch .lead-node{display:inline-block;font-family:var(--mono);font-size:14px;color:var(--bg);background:linear-gradient(150deg,var(--amber),var(--copper));border-radius:9px;padding:10px 24px;font-weight:700;box-shadow:var(--glow-amber)}
.orch .pipe{width:1px;height:26px;background:var(--line-hi);margin:0 auto}
.orch .branch{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:0;padding-top:14px;border-top:1px dashed var(--line);max-width:640px;margin-inline:auto}
.orch .sub-node{font-family:var(--mono);font-size:12px;color:var(--text);background:rgba(8,12,21,.85);border:1px solid var(--line);border-radius:8px;padding:9px 14px;min-width:128px}
.orch .sub-node em{display:block;font-style:normal;color:var(--violet);font-size:11px;margin-top:3px}
.orch .cap{font-size:13px;color:var(--faint);margin-top:18px;font-family:var(--mono)}

/* リビール */
.rv{opacity:0;transform:translateY(22px);transition:opacity .7s ease, transform .7s cubic-bezier(.2,.8,.3,1)}
.rv.in{opacity:1;transform:none}

/* 前後ナビ・フッター */
.pn{display:flex;justify-content:space-between;gap:14px;margin-top:84px;border-top:1px solid var(--line);padding-top:26px}
.pn a{flex:1;max-width:48%;background:var(--glass);border:1px solid var(--line);border-radius:10px;padding:15px 18px;border-bottom:1px solid var(--line);transition:.25s;color:var(--muted)}
.pn a:hover{border-color:var(--line-hi);color:var(--text);transform:translateY(-3px)}
.pn .dir{font-family:var(--mono);font-size:11px;color:var(--faint);display:block;margin-bottom:5px;letter-spacing:.08em}
.pn .t{font-family:var(--serif);font-size:15.5px;line-height:1.5}
.pn a.next{text-align:right;margin-left:auto}
footer{border-top:1px solid var(--line);margin-top:64px;padding:26px 0 8px;font-size:12.5px;color:var(--faint);font-family:var(--mono);line-height:2.1}
footer a{color:var(--muted)}

/* ===================== 要塞シェル ===================== */
/* スキャンライン */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:90;
  background:repeating-linear-gradient(0deg,rgba(255,255,255,.013) 0 1px,transparent 1px 3px)}
/* HUDコーナーブラケット */
.hud{position:fixed;width:30px;height:30px;z-index:95;pointer-events:none;opacity:.75}
.hud.tl{top:10px;left:10px;border-top:2px solid var(--amber);border-left:2px solid var(--amber)}
.hud.tr{top:10px;right:10px;border-top:2px solid var(--amber);border-right:2px solid var(--amber)}
.hud.bl{bottom:10px;left:10px;border-bottom:2px solid var(--amber);border-left:2px solid var(--amber)}
.hud.br{bottom:10px;right:10px;border-bottom:2px solid var(--amber);border-right:2px solid var(--amber)}

/* 角を断ち落とした装甲パネル */
.mcard,.card,.pn a{border-radius:0;
  clip-path:polygon(0 0,calc(100% - 16px) 0,100% 16px,100% 100%,16px 100%,0 calc(100% - 16px))}

/* ===== 隔壁ドア（ページ遷移） ===== */
.door{position:fixed;inset:0;z-index:100;display:flex;pointer-events:none}
.door-half{flex:1;position:relative;
  background:
    repeating-linear-gradient(90deg,rgba(255,255,255,.028) 0 2px,transparent 2px 96px),
    repeating-linear-gradient(0deg,rgba(0,0,0,.22) 0 1px,transparent 1px 120px),
    linear-gradient(180deg,#0d1735,#070f26 55%,#0c1a3e);
  box-shadow:inset 0 0 90px rgba(0,0,0,.6);
  transition:transform .55s cubic-bezier(.75,0,.25,1) .12s}
.door-half.l{border-right:1px solid rgba(65,217,255,.55)}
.door-half.r{border-left:1px solid rgba(65,217,255,.55)}
.door-half.l::before,.door-half.r::before{content:'';position:absolute;top:0;bottom:0;width:16px;
  background:repeating-linear-gradient(45deg,var(--amber) 0 12px,#081126 12px 24px);opacity:.9}
.door-half.l::before{right:0}
.door-half.r::before{left:0}
.door-half.l::after,.door-half.r::after{content:'';position:absolute;top:0;bottom:0;width:60px;
  background:linear-gradient(90deg,transparent,rgba(65,217,255,.08))}
.door-half.l::after{right:16px}
.door-half.r::after{left:16px;transform:scaleX(-1)}
.door.open .door-half.l{transform:translateX(-101%)}
.door.open .door-half.r{transform:translateX(101%)}
.door-lock{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2;text-align:center;
  opacity:1;transition:opacity .25s .62s,transform .25s .62s}
.door-lock i{display:block;width:86px;height:86px;margin:0 auto 12px;border-radius:50%;
  border:2px solid var(--amber);position:relative;box-shadow:0 0 26px rgba(65,217,255,.45),inset 0 0 18px rgba(65,217,255,.2)}
.door-lock i::before{content:'';position:absolute;inset:9px;border-radius:50%;
  border:1px dashed rgba(65,217,255,.75);animation:spin 3.4s linear infinite}
.door-lock i::after{content:'';position:absolute;left:50%;top:50%;width:12px;height:12px;margin:-6px;
  border-radius:50%;background:var(--amber);box-shadow:0 0 16px var(--amber);animation:pulse 1.4s ease-in-out infinite}
.door-lock span{font-family:var(--mono);font-size:11px;letter-spacing:.3em;color:var(--muted)}
.door.open .door-lock{opacity:0;transform:translate(-50%,-50%) scale(.55);transition:opacity .16s 0s,transform .16s 0s}
.door.noanim{display:none}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{50%{opacity:.45}}

/* ===== コア・スフィア（ホーム中枢） ===== */
.core-stage{position:relative;width:min(460px,86vw);height:330px;margin:4px auto 18px;perspective:950px}
.core{position:absolute;left:50%;top:45%;width:196px;height:196px;margin:-98px 0 0 -98px;border-radius:50%;
  background:radial-gradient(circle at 33% 28%,
    rgba(234,252,255,.97),rgba(127,233,255,.93) 22%,rgba(47,139,255,.95) 52%,
    rgba(10,42,102,.98) 80%,#04102e 100%);
  box-shadow:0 0 64px rgba(65,217,255,.5),0 0 160px rgba(47,139,255,.25),
    inset -20px -26px 64px rgba(2,8,26,.65),inset 12px 14px 44px rgba(190,242,255,.3);
  animation:floatY 5.4s ease-in-out infinite}
.core::before{content:'';position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 0deg,transparent 0 38%,rgba(190,242,255,.16) 50%,transparent 62% 100%);
  animation:spin 10s linear infinite;mix-blend-mode:screen}
.core::after{content:'';position:absolute;inset:30%;border-radius:50%;
  background:radial-gradient(circle,rgba(240,253,255,.9),rgba(127,233,255,.3) 65%,transparent 75%);
  filter:blur(2px);animation:pulse 2.6s ease-in-out infinite}
.core-orbit{position:absolute;left:50%;top:45%;border:1px solid rgba(65,217,255,.42);border-radius:50%;
  pointer-events:none}
.core-orbit.o1{width:300px;height:300px;margin:-150px;animation:orbitA 13s linear infinite}
.core-orbit.o2{width:360px;height:360px;margin:-180px;border-color:rgba(255,61,110,.4);animation:orbitB 21s linear infinite reverse}
.core-orbit i{position:absolute;top:-4px;left:50%;width:8px;height:8px;border-radius:50%;
  background:var(--amber);box-shadow:0 0 12px var(--amber)}
.core-orbit.o2 i{background:var(--violet);box-shadow:0 0 12px var(--violet)}
@keyframes orbitA{from{transform:rotateX(73deg) rotateZ(0)}to{transform:rotateX(73deg) rotateZ(360deg)}}
@keyframes orbitB{from{transform:rotateX(76deg) rotateY(12deg) rotateZ(0)}to{transform:rotateX(76deg) rotateY(12deg) rotateZ(360deg)}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
.core-shadow{position:absolute;left:50%;bottom:2px;width:200px;height:30px;transform:translateX(-50%);
  background:radial-gradient(closest-side,rgba(65,217,255,.4),transparent);filter:blur(7px);
  animation:shadowB 5.4s ease-in-out infinite}
@keyframes shadowB{0%,100%{opacity:.95;transform:translateX(-50%) scaleX(1)}50%{opacity:.55;transform:translateX(-50%) scaleX(.82)}}
.ctag{position:absolute;font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;color:var(--muted);
  padding-bottom:4px;border-bottom:1px solid var(--line-hi)}
.ctag.t1{left:0;top:14%}
.ctag.t2{right:0;top:32%}
.ctag.t3{left:3%;bottom:8%}
@media(max-width:560px){.ctag{display:none}.core-orbit.o2{display:none}}

/* ホーム：コンソール小節 */
.console-sec{max-width:820px;margin:-22px auto 0;padding:0 24px;position:relative;z-index:2}

/* ===== 記事ページ：読みやすい中央カラム（トップページは対象外） ===== */
.page-head,.page-head~*{max-width:min(860px,calc(100% - 48px));margin-left:auto;margin-right:auto}
.page-head{padding-top:104px}
@media(max-width:680px){
  .page-head,.page-head~*{max-width:calc(100% - 36px)}
  .page-head{padding-top:92px}
}

@media(max-width:680px){
  .wrap{padding-top:96px}
  .hero{padding:110px 0 70px}
  .term{transform:none}
  .pn{flex-direction:column}
  .pn a{max-width:100%}
  .pn a.next{text-align:left}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .rv{opacity:1;transform:none}
}
