:root{--ink: #131008;--gold: #c9a227;--gold-bright: #e8c34a;--paper: #ece2cc;--east: #c8402e;--west: #4a6fc8;--turn: #d9a72c;--serif: "Shippori Mincho", "Hiragino Mincho ProN", "Yu Mincho", "Noto Serif JP", serif;--sans: "Zen Kaku Gothic New", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", "Noto Sans JP", "Meiryo", system-ui, sans-serif}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;background:var(--ink);font-family:var(--sans);color:var(--paper);-webkit-font-smoothing:antialiased}body{overflow:hidden;overscroll-behavior-y:none}#view{position:fixed;inset:0;width:100%;height:100%;display:block}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:40;background:radial-gradient(ellipse at center,transparent 55%,rgba(10,8,4,.42) 100%)}body:after{content:"";position:fixed;inset:-50%;pointer-events:none;z-index:41;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");animation:grain 1.2s steps(4) infinite}@keyframes grain{0%{transform:translate(0)}25%{transform:translate(-2%,1%)}50%{transform:translate(1%,-2%)}75%{transform:translate(-1%,2%)}to{transform:translate(2%,-1%)}}.letterbox{position:fixed;left:0;right:0;height:42px;background:#0a0805;z-index:50;pointer-events:none}.letterbox.top{top:0;border-bottom:1px solid rgba(201,162,39,.35)}.letterbox.bottom{bottom:0;border-top:1px solid rgba(201,162,39,.35)}#home-link{position:fixed;top:12px;left:30px;z-index:56;font-size:12px;font-weight:700;letter-spacing:.14em;color:#ece2ccb8;text-decoration:none;transition:color .2s ease}#home-link:hover{color:var(--gold-bright)}#title{position:fixed;top:64px;left:30px;z-index:55;display:flex;flex-direction:row-reverse;align-items:flex-start;gap:14px;text-shadow:0 2px 14px rgba(0,0,0,.7);pointer-events:none}#title h1{writing-mode:vertical-rl;font-family:var(--serif);font-weight:800;font-size:52px;letter-spacing:.22em;color:var(--paper);line-height:1;white-space:nowrap}#title .sub{writing-mode:vertical-rl;font-family:var(--serif);font-weight:600;font-size:14px;letter-spacing:.3em;color:var(--gold-bright);padding-top:6px}#clock{position:fixed;top:60px;right:34px;z-index:55;text-align:right;text-shadow:0 2px 12px rgba(0,0,0,.8);pointer-events:none}#clock-time{display:block;font-family:var(--serif);font-weight:700;font-size:38px;letter-spacing:.04em;color:var(--paper)}#clock-phase{display:inline-block;margin-top:6px;font-family:var(--serif);font-weight:600;font-size:15px;letter-spacing:.34em;color:var(--gold-bright);border-top:1px solid rgba(201,162,39,.6);padding-top:5px}#legend{position:fixed;top:168px;right:34px;z-index:55;display:flex;gap:8px}.chip{font-size:12px;font-weight:700;letter-spacing:.18em;padding:4px 10px 4px 22px;border-radius:999px;background:#0c0905a8;border:1px solid rgba(255,255,255,.16);position:relative}.chip:before{content:"";position:absolute;left:8px;top:50%;transform:translateY(-50%);width:9px;height:9px;border-radius:50%;background:var(--chip-color, var(--paper))}.chip.east{--chip-color: var(--east)}.chip.west{--chip-color: var(--west)}.chip.turn{--chip-color: var(--turn)}#telop{position:fixed;top:38%;left:50%;transform:translate(-50%,-50%);z-index:56;font-family:var(--serif);font-weight:800;font-size:clamp(34px,6vw,74px);letter-spacing:.3em;color:var(--paper);text-shadow:0 4px 30px rgba(0,0,0,.9);opacity:0;pointer-events:none;white-space:nowrap}#telop.show{animation:telop 3.4s ease forwards}#telop.show:after{content:"";position:absolute;left:50%;bottom:-18px;transform:translate(-50%);width:0;height:2px;background:var(--gold);animation:telop-rule 3.4s ease forwards}@keyframes telop{0%{opacity:0;letter-spacing:.55em}12%{opacity:1;letter-spacing:.3em}78%{opacity:1}to{opacity:0}}@keyframes telop-rule{0%{width:0}20%{width:110%}78%{width:110%;opacity:1}to{width:110%;opacity:0}}#narration{position:fixed;left:34px;bottom:118px;z-index:55;max-width:520px;background:#0c0905b8;border-left:3px solid var(--gold);border-radius:0 10px 10px 0;padding:16px 22px 17px;backdrop-filter:blur(6px)}#narration.fade-in{animation:narr-in .9s ease both}@keyframes narr-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}#narr-title{font-family:var(--serif);font-weight:700;font-size:21px;letter-spacing:.12em;color:var(--gold-bright);margin-bottom:7px}#narr-text{font-size:13.5px;line-height:1.95;letter-spacing:.04em;color:#ece2ccf0}#controls{position:fixed;left:50%;bottom:54px;transform:translate(-50%);z-index:57;display:flex;align-items:center;gap:14px;width:min(940px,calc(100vw - 60px));background:#0c0905c7;border:1px solid rgba(201,162,39,.3);border-radius:999px;padding:10px 18px;backdrop-filter:blur(8px);box-shadow:0 8px 30px #00000080}#controls button{font-family:var(--sans);font-weight:700;color:var(--paper);background:transparent;border:1px solid rgba(236,226,204,.28);border-radius:999px;cursor:pointer;transition:all .2s ease;flex-shrink:0}#controls button:hover{border-color:var(--gold);color:var(--gold-bright)}#btn-play{width:auto;min-width:46px;height:46px;padding:0 18px;font-size:14px;white-space:nowrap;background:var(--gold)!important;color:var(--ink)!important;border:none!important;box-shadow:0 2px 12px #c9a22766}#btn-play:hover{background:var(--gold-bright)!important}#btn-speed{width:52px;height:34px;font-size:13px}#btn-settings{height:34px;padding:0 14px;font-size:12px;letter-spacing:.1em}#btn-settings.on{border-color:var(--gold);color:var(--gold-bright)}#btn-cam{height:34px;padding:0 14px;font-size:12px;letter-spacing:.1em}#btn-cam.on{border-color:var(--gold);color:var(--gold-bright)}#settings-panel{position:absolute;right:10px;bottom:calc(100% + 10px);display:flex;flex-direction:column;gap:8px;min-width:210px;padding:12px;background:#0c0905eb;border:1px solid rgba(201,162,39,.4);border-radius:14px;box-shadow:0 10px 30px #0000008c;backdrop-filter:blur(8px)}#settings-panel[hidden]{display:none}#settings-panel button{width:100%;height:38px;font-size:12px;letter-spacing:.1em}#settings-panel a{display:flex;align-items:center;justify-content:center;width:100%;height:38px;font-size:12px;font-weight:700;letter-spacing:.1em;color:var(--paper);text-decoration:none;border:1px solid rgba(236,226,204,.28);border-radius:999px;transition:border-color .2s ease,color .2s ease}#settings-panel a:hover{border-color:var(--gold);color:var(--gold-bright)}#settings-panel a[hidden]{display:none}#btn-audio,#btn-labels{opacity:.55}#btn-audio.on,#btn-labels.on{opacity:1;border-color:var(--gold);color:var(--gold-bright)}#volume-control{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;height:38px;padding:0 12px;border:1px solid rgba(236,226,204,.28);border-radius:999px;color:#ece2ccdb;font-size:12px;font-weight:700;letter-spacing:.08em}#audio-volume{width:110px;accent-color:var(--gold-bright)}#seek{position:relative;flex:1;height:34px;cursor:pointer;touch-action:none}#seek-track{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);height:5px;border-radius:3px;background:#ece2cc2e}#seek-fill{position:absolute;left:0;top:50%;transform:translateY(-50%);height:5px;border-radius:3px;background:linear-gradient(90deg,#8f6f14,var(--gold-bright));width:0;pointer-events:none}#seek-thumb{position:absolute;top:50%;left:0;transform:translate(-50%,-50%);width:15px;height:15px;border-radius:50%;background:var(--gold-bright);box-shadow:0 0 10px #e8c34ab3;pointer-events:none}.seek-marker{position:absolute;top:50%;width:2px;height:11px;transform:translate(-50%,-50%);background:#ece2cc80;pointer-events:none}.seek-marker span{position:absolute;top:14px;left:50%;transform:translate(-50%);font-size:10px;letter-spacing:.06em;color:#ece2cc99;white-space:nowrap;font-weight:500}#hint{position:fixed;bottom:128px;left:50%;transform:translate(-50%);z-index:58;max-width:min(760px,calc(100vw - 28px));text-align:center;font-size:13px;font-weight:700;letter-spacing:.04em;line-height:1.5;color:#ece2ccf5;background:#0c0905d1;border:1px solid rgba(201,162,39,.42);border-radius:999px;padding:10px 22px;backdrop-filter:blur(6px);pointer-events:none;transition:opacity .5s ease}#hint.hide{opacity:0}#loading{position:fixed;inset:0;z-index:99;background:var(--ink);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;transition:opacity .8s ease}#loading.done{opacity:0;pointer-events:none}.loading-mark{font-family:var(--serif);font-weight:800;font-size:clamp(26px,7vw,64px);letter-spacing:.22em;color:var(--paper);text-align:center;padding:0 16px;white-space:nowrap;animation:pulse 2s ease infinite}.loading-sub{font-size:13px;letter-spacing:.3em;color:var(--gold)}#loading-bar{width:min(260px,60vw);height:3px;margin-top:4px;border-radius:3px;background:#c9a2272e;overflow:hidden}#loading-bar-fill{width:0;height:100%;border-radius:3px;background:linear-gradient(90deg,#8f6f14,var(--gold-bright));transition:width .4s ease}@keyframes pulse{0%,to{opacity:.55}50%{opacity:1}}@media(max-width:760px){.letterbox{display:none}#title{top:46px;left:10px;gap:8px}#title h1{font-size:22px;letter-spacing:.16em}#title .sub{font-size:10px;letter-spacing:.22em;padding-top:4px}#clock{top:12px;right:10px}#clock-time{font-size:19px}#clock-phase{font-size:10px;letter-spacing:.18em;margin-top:3px;padding-top:3px}#home-link{top:10px;left:10px;right:auto;font-size:11px;padding:5px 10px;border-radius:999px;background:#0c0905a8;border:1px solid rgba(255,255,255,.16)}#telop{font-size:clamp(20px,6vw,34px);letter-spacing:.22em}#narration{left:10px;right:10px;max-width:none;bottom:calc(112px + env(safe-area-inset-bottom,0px));padding:9px 26px 9px 12px;border-radius:0 8px 8px 0;cursor:pointer}#narration:after{content:"▼";position:absolute;right:9px;top:11px;font-size:9px;color:var(--gold-bright);transition:transform .2s ease}#narration.expanded:after{transform:rotate(180deg)}#narr-title{font-size:14px;margin-bottom:3px}#narr-text{font-size:11.5px;line-height:1.65;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}#narration.expanded #narr-text{display:block;-webkit-line-clamp:unset;overflow:visible}#controls{bottom:calc(8px + env(safe-area-inset-bottom,0px));width:calc(100vw - 16px);flex-wrap:wrap;justify-content:center;gap:6px 7px;padding:6px 10px 8px;border-radius:16px}#controls button{min-height:38px;font-size:11px;letter-spacing:.04em}#btn-play{width:auto;height:38px;padding:0 14px;font-size:12px}#btn-speed{width:44px;height:38px;font-size:12px}#btn-settings{height:38px;padding:0 12px;font-size:12px}#settings-panel{right:4px;min-width:200px}#seek{order:-1;flex:1 0 100%;height:30px}#seek-track,#seek-fill{height:6px}#seek-thumb{width:20px;height:20px}.seek-marker span,#legend{display:none}#hint{top:50%;bottom:auto;left:50%;transform:translate(-50%,-50%);width:min(86vw,320px);max-width:none;border-radius:16px;padding:16px 18px;font-size:13px;line-height:1.9;letter-spacing:.03em;background:#0c0905e0}}.unit-modal{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:24px;background:#05040294;opacity:0;pointer-events:none;transition:opacity .18s ease}.unit-modal.show{opacity:1;pointer-events:auto}.unit-modal-panel{position:relative;width:min(460px,100%);border:1px solid rgba(201,162,39,.48);border-radius:8px;background:#0c0905f0;box-shadow:0 20px 70px #0000009e;padding:24px;outline:none;transform:translateY(8px);transition:transform .18s ease}.unit-modal.show .unit-modal-panel{transform:translateY(0)}.unit-modal-close{position:absolute;top:12px;right:12px;width:34px;height:34px;border:1px solid rgba(236,226,204,.28);border-radius:50%;background:transparent;color:var(--paper);font-size:22px;line-height:1;cursor:pointer}.unit-modal-close:hover{border-color:var(--gold);color:var(--gold-bright)}.unit-modal-kicker{margin-right:44px;color:var(--gold-bright);font-size:12px;font-weight:800;letter-spacing:.22em}.unit-modal h2{margin-top:10px;font-family:var(--serif);font-size:34px;line-height:1.2;letter-spacing:0;color:var(--paper)}.unit-modal-kana{margin-top:4px;color:#ece2cc8f;font-size:13px}.unit-modal-summary{margin-top:16px;color:#ece2ccdb;font-size:14px;line-height:1.9}.unit-modal-list{display:grid;gap:8px;margin-top:18px;padding-top:16px;border-top:1px solid rgba(201,162,39,.24)}.unit-modal-list div{display:grid;grid-template-columns:72px 1fr;gap:14px}.unit-modal-list dt{color:#e8c34ad1;font-size:12px;font-weight:800}.unit-modal-list dd{color:#ece2cce6}.unit-modal-link{display:inline-flex;margin-top:20px;border-radius:999px;background:var(--gold);color:var(--ink);padding:10px 16px;font-weight:800;text-decoration:none}.unit-modal-link:hover{background:var(--gold-bright)}@media(max-width:760px){.unit-modal{align-items:end;padding:14px}.unit-modal-panel{width:100%;padding:22px 18px}.unit-modal h2{font-size:29px}}body.directory-page{min-height:100%;height:auto;overflow:auto;overscroll-behavior-y:auto;background:linear-gradient(#131008db,#131008f5),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.72' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.16'/%3E%3C/svg%3E")}.directory-page:before,.directory-page:after{position:fixed}.site-header{position:sticky;top:0;z-index:20;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:18px clamp(20px,5vw,64px);background:#0a0805d6;border-bottom:1px solid rgba(201,162,39,.28);backdrop-filter:blur(10px)}.brand,.site-header a{color:var(--paper);text-decoration:none}.brand{font-family:var(--serif);font-weight:800;font-size:22px;letter-spacing:.16em}.site-header nav{display:flex;gap:18px}.site-header nav a{font-weight:700;font-size:13px;letter-spacing:.16em;color:#ece2ccb8}.site-header nav a[aria-current=page],.site-header nav a:hover{color:var(--gold-bright)}.directory-shell{width:min(1120px,calc(100% - 40px));margin:0 auto;padding:56px 0 80px}.directory-hero{padding:46px 0 52px;border-bottom:1px solid rgba(201,162,39,.24)}.directory-hero.compact{padding-bottom:34px}.eyebrow,.card-kicker{color:var(--gold-bright);font-weight:700;font-size:12px;letter-spacing:.22em;text-transform:uppercase}.directory-hero h1,.detail-panel h1{margin-top:12px;font-family:var(--serif);font-size:clamp(40px,7vw,78px);line-height:1.12;letter-spacing:0}.directory-hero p:not(.eyebrow),.lead{margin-top:18px;max-width:720px;color:#ece2ccc7;line-height:2}.directory-section{padding-top:36px}.section-heading{display:flex;justify-content:space-between;align-items:end;gap:20px;margin-bottom:18px}.section-heading h2{font-family:var(--serif);font-size:28px}.section-heading a,.inline-links a{color:var(--gold-bright);text-decoration:none}.directory-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.directory-card,.detail-panel{border:1px solid rgba(201,162,39,.28);border-radius:8px;background:#0c0905b8;padding:22px;box-shadow:0 10px 34px #00000047}.directory-card h2{margin-top:10px;font-family:var(--serif);font-size:26px}.directory-card p{margin-top:10px;color:#ece2ccc7;line-height:1.8}.kana{color:#ece2cc94!important}.directory-card dl,.detail-list{display:grid;gap:8px;margin-top:18px}.directory-card dl div,.detail-list div{display:grid;grid-template-columns:72px 1fr;gap:12px}.directory-card dt,.detail-list dt{color:#e8c34ac2;font-size:12px;font-weight:700}.directory-card dd,.detail-list dd{color:#ece2ccdb}.primary-link{display:inline-flex;margin-top:22px;color:var(--ink);background:var(--gold);border-radius:999px;padding:10px 16px;font-weight:800;text-decoration:none}.primary-link:hover{background:var(--gold-bright)}.detail-shell{padding-top:56px}.detail-panel{max-width:760px}.inline-links{display:flex;flex-wrap:wrap;gap:10px}.battle-roles{margin-top:28px;padding-top:22px;border-top:1px solid rgba(201,162,39,.24)}.battle-roles h2{font-family:var(--serif);font-size:22px;letter-spacing:.08em;margin-bottom:4px}.battle-role{padding:16px 0 10px;border-bottom:1px dashed rgba(236,226,204,.16)}.battle-role:last-child{border-bottom:none}.battle-role h3{font-family:var(--serif);font-size:19px;margin-top:6px}.battle-role h3 a{color:var(--paper);text-decoration:none;transition:color .2s ease}.battle-role h3 a:hover{color:var(--gold-bright)}.battle-role p{margin-top:8px;color:#ece2ccd1;line-height:1.9;font-size:14px}.battle-role .battle-role-strength{margin-top:6px;color:#e8c34ad9;font-size:12.5px;font-weight:700;letter-spacing:.06em}.general-card-epithet{margin-top:6px!important;font-family:var(--serif);font-weight:600;font-size:14px;letter-spacing:.1em;color:#e8c34ad1!important}@media(max-width:760px){.site-header{align-items:flex-start;flex-direction:column}.directory-shell{width:min(100% - 28px,1120px);padding-top:30px}.section-heading{align-items:flex-start;flex-direction:column}}.general-detail{max-width:880px;padding-bottom:40px}.gd-back{margin-bottom:26px}.gd-back a,.gd-footnav a{color:#e8c34ad1;text-decoration:none;font-size:13px;letter-spacing:.1em;transition:color .2s ease}.gd-back a:hover,.gd-footnav a:hover{color:var(--gold-bright)}.gd-hero{position:relative;padding:4px 0 30px;border-bottom:1px solid rgba(201,162,39,.22)}.gd-kicker{color:var(--gold-bright);font-weight:700;font-size:12px;letter-spacing:.2em}.gd-name{margin-top:14px;font-family:var(--serif);font-weight:800;font-size:clamp(44px,8vw,84px);line-height:1.08;letter-spacing:.02em}.gd-kana{margin-top:12px;font-size:13px;letter-spacing:.22em;color:#ece2cc8c}.gd-epithet{margin-top:16px;font-family:var(--serif);font-weight:600;font-size:clamp(18px,2.4vw,24px);letter-spacing:.12em;color:var(--gold-bright)}.gd-tate{position:absolute;right:2px;top:8px;writing-mode:vertical-rl;font-family:var(--serif);font-weight:600;font-size:clamp(15px,1.8vw,19px);letter-spacing:.5em;color:#c9a22766;pointer-events:none}.gd-lead{margin-top:28px;font-size:16px;line-height:2.1;color:#ece2cce6}.gd-facts{display:flex;flex-wrap:wrap;gap:18px 0;margin-top:30px;padding:22px 0;border-top:1px solid rgba(201,162,39,.18);border-bottom:1px solid rgba(201,162,39,.18)}.gd-fact{flex:0 1 auto;padding:2px 26px;border-left:1px solid rgba(201,162,39,.22)}.gd-fact:first-child{border-left:none;padding-left:0}.gd-fact dt{font-size:10.5px;font-weight:700;letter-spacing:.16em;color:#e8c34ab8}.gd-fact dd{margin-top:7px;font-family:var(--serif);font-size:16px;letter-spacing:.04em;color:var(--paper)}ruby{ruby-align:center}rt{font-family:var(--sans);font-size:.56em;font-weight:400;letter-spacing:.02em;color:#ece2cc9e}.gd-deepen-note{margin-bottom:14px;font-size:13px;letter-spacing:.04em;color:#ece2cc99}.gd-deepen-list{list-style:none;display:flex;flex-direction:column;gap:10px}.gd-quote{margin:36px 0 8px;padding:6px 0 6px 24px;border-left:3px solid var(--gold)}.gd-quote p{font-family:var(--serif);font-weight:600;font-size:clamp(19px,2.6vw,26px);line-height:1.75;letter-spacing:.04em;color:var(--gold-bright)}.gd-quote cite{display:block;margin-top:14px;font-style:normal;font-size:12px;letter-spacing:.16em;color:#ece2cc8c}.gd-quote cite:before{content:"── "}.gd-section{margin-top:46px}.gd-section-title{display:flex;align-items:center;gap:16px;font-family:var(--serif);font-weight:700;font-size:22px;letter-spacing:.2em;color:var(--paper)}.gd-section-title:before{content:"";width:28px;height:2px;background:var(--gold)}.gd-section-count{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.16em;color:#e8c34ab3}.gd-life{list-style:none;margin-top:18px}.gd-life-entry{position:relative;display:grid;grid-template-columns:minmax(70px,100px) 1fr;gap:0 28px;align-items:baseline;padding:20px 4px;border-top:1px solid rgba(201,162,39,.14)}.gd-life-entry:last-child{border-bottom:1px solid rgba(201,162,39,.14)}.gd-life-year{font-family:var(--serif);font-weight:800;font-size:clamp(28px,4.4vw,44px);line-height:1;color:#c9a22714;-webkit-text-stroke:1px rgba(201,162,39,.4)}.gd-life-body{display:block}.gd-life-note{display:block;font-family:var(--serif);font-size:12px;letter-spacing:.16em;color:var(--gold-bright)}.gd-life-title{display:block;margin-top:5px;font-family:var(--serif);font-weight:700;font-size:18px;letter-spacing:.04em;color:var(--paper)}.gd-life-text{display:block;margin-top:8px;font-size:14px;line-height:1.9;color:#ece2cccc}.gd-roles{list-style:none;margin-top:16px}.gd-role-link{position:relative;display:grid;grid-template-columns:minmax(74px,104px) 1fr auto;gap:0 26px;align-items:center;padding:22px 4px;border-top:1px solid rgba(201,162,39,.14);text-decoration:none;color:inherit}.gd-roles li:last-child .gd-role-link{border-bottom:1px solid rgba(201,162,39,.14)}.gd-role-year{font-family:var(--serif);font-weight:800;font-size:clamp(30px,4.6vw,46px);line-height:1;color:#c9a22714;-webkit-text-stroke:1px rgba(201,162,39,.38);transition:-webkit-text-stroke-color .3s ease}.gd-role-link:hover .gd-role-year{-webkit-text-stroke-color:rgba(232,195,74,.66)}.gd-role-title{display:block;font-family:var(--serif);font-weight:700;font-size:21px;letter-spacing:.04em;transition:color .2s ease}.gd-role-link:hover .gd-role-title{color:var(--gold-bright)}.gd-role-place{display:block;margin-top:5px;font-size:11.5px;letter-spacing:.12em;color:#ece2cc8c}.gd-role-desc{display:block;margin-top:10px;font-size:13.5px;line-height:1.85;color:#ece2ccd1}.gd-role-meta{display:block;margin-top:8px;font-size:12px;font-weight:700;letter-spacing:.08em;color:#e8c34ad1}.gd-role-cta{font-family:var(--serif);font-weight:700;font-size:13px;letter-spacing:.18em;color:var(--gold);white-space:nowrap;transition:color .2s ease}.gd-role-link:hover .gd-role-cta{color:var(--gold-bright)}.gd-battles-empty{margin-top:16px;color:#ece2cc8c;line-height:1.9;font-size:14px}.gd-related-list{display:flex;flex-wrap:wrap;gap:12px 30px;list-style:none;margin-top:18px}.gd-related-list a{display:inline-flex;align-items:baseline;gap:10px;padding:6px 0;text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s ease}.gd-related-list a:hover{border-bottom-color:var(--gold)}.gd-related-name{font-family:var(--serif);font-weight:700;font-size:17px;color:var(--paper)}.gd-related-epithet{font-size:11.5px;letter-spacing:.1em;color:#e8c34ab3}.gd-footnav{display:flex;flex-wrap:wrap;gap:14px 34px;margin-top:50px;padding-top:24px;border-top:1px solid rgba(201,162,39,.2)}@media(max-width:760px){.general-detail{padding-bottom:28px}.gd-tate{display:none}.gd-lead{font-size:15px;line-height:2}.gd-fact{flex:1 1 44%;padding:2px 0 2px 16px}.gd-fact:nth-child(odd){border-left:none;padding-left:0}.gd-life-entry{grid-template-columns:1fr;gap:4px;padding:18px 2px}.gd-life-year{font-size:30px}.gd-role-link{grid-template-columns:1fr;gap:6px;padding:18px 2px}.gd-role-year{position:absolute;right:2px;top:12px;font-size:38px}.gd-role-cta{margin-top:12px}}.home-hero{position:relative;border-bottom:none;padding:64px 0 54px}.home-hero h1{font-size:clamp(40px,7.5vw,86px);line-height:1.18;letter-spacing:.04em}.home-hero h1 .accent{color:var(--gold-bright)}.home-hero h1:after{content:"";display:block;width:76px;height:2px;margin-top:26px;background:var(--gold)}.hero-cta{display:inline-flex;align-items:center;gap:12px;margin-top:30px;padding:14px 30px;border:1px solid rgba(201,162,39,.55);border-radius:999px;color:var(--gold-bright);font-weight:700;font-size:14px;letter-spacing:.14em;text-decoration:none;transition:border-color .2s ease,background-color .2s ease}.hero-cta:before{content:"▶";font-size:11px;color:var(--gold)}.hero-cta:hover{border-color:var(--gold-bright);background:#c9a22714}.home-hero p.hero-note{margin-top:16px;font-size:11.5px;letter-spacing:.22em;line-height:1.6;color:#ece2cc80}.hero-tate{position:absolute;right:4px;top:56px;writing-mode:vertical-rl;font-family:var(--serif);font-weight:600;font-size:14px;letter-spacing:.46em;color:#c9a22780}.battle-section .section-heading h2{display:flex;align-items:center;gap:16px}.battle-section .section-heading h2:before{content:"";width:30px;height:2px;background:var(--gold)}.list-controls{display:flex;flex-direction:column;gap:10px;margin:4px 0 26px}.control-group{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.control-label{font-size:11px;font-weight:700;letter-spacing:.22em;color:#ece2cc80;margin-right:4px}.filter-chip{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.08em;color:var(--paper);background:#0c090599;border:1px solid rgba(236,226,204,.22);border-radius:999px;padding:8px 15px;cursor:pointer;opacity:.66;transition:border-color .2s ease,color .2s ease,opacity .2s ease}.filter-chip:hover{border-color:var(--gold);color:var(--gold-bright);opacity:1}.filter-chip.on{opacity:1;border-color:var(--gold);color:var(--gold-bright);background:#c9a22714}.control-search{width:100%;max-width:380px;background:#0c090599;border:1px solid rgba(236,226,204,.22);border-radius:999px;padding:11px 20px;color:var(--paper);font-family:var(--sans);font-size:13px;letter-spacing:.04em;transition:border-color .2s ease}.control-search:focus{outline:none;border-color:var(--gold)}.control-search::placeholder{color:#ece2cc61}.list-empty{padding:34px 4px;color:#ece2cc8c;font-size:13px;letter-spacing:.06em}.battle-scroll{list-style:none;display:flex;flex-direction:column;gap:clamp(28px,4vw,38px)}.battle-series-heading{display:flex;align-items:center;gap:22px;margin:clamp(18px,4vw,46px) 0 calc(10px - clamp(28px,4vw,38px));font-family:var(--serif);font-weight:800;font-size:clamp(28px,4.4vw,44px);letter-spacing:.1em;color:var(--gold-bright)}.battle-series-heading:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,rgba(201,162,39,.45),transparent)}.battle-scroll .battle-series-heading:first-child,.battle-series-heading.is-lead{margin-top:0}.battle-series-heading[hidden]{display:none}.battle-entry-link{position:relative;display:grid;grid-template-columns:190px minmax(0,1fr) auto;gap:6px 38px;align-items:center;padding:30px 10px;overflow:hidden;text-decoration:none;color:inherit}.battle-ghost-year{position:absolute;left:0;top:50%;transform:translateY(-50%);font-family:var(--serif);font-weight:800;font-size:clamp(96px,11vw,150px);line-height:1;color:#c9a2270d;-webkit-text-stroke:1px rgba(201,162,39,.3);pointer-events:none;transition:-webkit-text-stroke-color .3s ease}.battle-entry-link:hover .battle-ghost-year{-webkit-text-stroke-color:rgba(232,195,74,.6)}.battle-era{position:relative;display:block}.battle-date{display:block;font-family:var(--serif);font-weight:700;font-size:13.5px;letter-spacing:.2em;color:var(--gold-bright)}.battle-period{display:block;margin-top:8px;font-size:11px;letter-spacing:.2em;color:#ece2cc8c}.battle-main{position:relative;display:block}.battle-title{display:block;font-family:var(--serif);font-weight:700;font-size:clamp(24px,2.8vw,33px);letter-spacing:.06em;line-height:1.3;transition:color .2s ease}.battle-entry-link:hover .battle-title{color:var(--gold-bright)}.battle-place{display:block;margin-top:6px;font-size:12px;letter-spacing:.16em;color:#ece2cc99}.battle-summary{display:block;margin-top:10px;max-width:560px;font-size:13.5px;line-height:1.9;color:#ece2ccc7}.battle-cta{display:inline-flex;align-items:center;gap:8px;font-family:var(--serif);font-weight:700;font-size:14px;letter-spacing:.2em;color:var(--gold);white-space:nowrap;transition:color .2s ease}.battle-cta:after{content:"▸";transition:transform .2s ease}.battle-entry-link:hover .battle-cta{color:var(--gold-bright)}.battle-entry-link:hover .battle-cta:after{transform:translate(5px)}.battle-scroll,.directory-grid[data-general-list]{padding-bottom:clamp(40px,6vw,64px)}.filter-fab{position:fixed;right:clamp(16px,3vw,30px);bottom:calc(clamp(16px,3vw,30px) + env(safe-area-inset-bottom));z-index:60;display:inline-flex;align-items:center;gap:9px;padding:13px 22px;border-radius:999px;border:1px solid var(--gold);background:#0c0905db;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--gold-bright);font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.14em;cursor:pointer;box-shadow:0 8px 26px #00000073;transition:border-color .2s ease,color .2s ease,background .2s ease}.filter-fab:hover{border-color:var(--gold-bright);background:#c9a22724}.filter-fab.active{border-color:var(--gold-bright);background:#c9a22733}.filter-fab-icon{display:block}.filter-panel{position:fixed;inset:0;z-index:70;visibility:hidden}.filter-panel.open{visibility:visible}.filter-panel-scrim{position:absolute;inset:0;background:#0806038c;opacity:0;transition:opacity .25s ease}.filter-panel.open .filter-panel-scrim{opacity:1}.filter-panel-sheet{position:absolute;right:clamp(16px,3vw,30px);bottom:calc(clamp(16px,3vw,30px) + 60px + env(safe-area-inset-bottom));width:min(400px,calc(100vw - 32px));max-height:min(72vh,620px);overflow-y:auto;padding:22px 22px 20px;border-radius:16px;border:1px solid rgba(201,162,39,.32);background:#100c06fa;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 18px 50px #0000008c;opacity:0;transform:translateY(14px) scale(.98);transform-origin:bottom right;transition:opacity .26s ease,transform .26s cubic-bezier(.22,1,.36,1)}.filter-panel.open .filter-panel-sheet{opacity:1;transform:translateY(0) scale(1)}.filter-panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.filter-panel-head h2{font-family:var(--serif);font-weight:800;font-size:18px;letter-spacing:.08em;color:var(--gold-bright)}.filter-panel-close{width:34px;height:34px;border-radius:999px;border:1px solid rgba(236,226,204,.22);background:transparent;color:var(--paper);font-size:20px;line-height:1;cursor:pointer;transition:border-color .2s ease,color .2s ease}.filter-panel-close:hover{border-color:var(--gold);color:var(--gold-bright)}.filter-panel .control-search{width:100%;max-width:none;margin-bottom:16px}.filter-panel .list-controls{margin:0;gap:14px}.filter-panel-done{width:100%;margin-top:18px;padding:13px;border-radius:10px;border:1px solid var(--gold);background:#c9a2271a;color:var(--gold-bright);font-family:var(--sans);font-weight:700;font-size:14px;letter-spacing:.1em;cursor:pointer;transition:background .2s ease,border-color .2s ease}.filter-panel-done:hover{background:#c9a22733;border-color:var(--gold-bright)}.filter-result-count{font-variant-numeric:tabular-nums}@media(max-width:760px){.home-hero{padding:34px 0 38px}.home-hero h1{font-size:clamp(34px,10.5vw,44px)}.hero-tate{display:none}.hero-cta{width:100%;justify-content:center}.battle-entry-link{display:block;padding:16px 2px 6px}.battle-ghost-year{left:auto;right:0;top:-14px;transform:none;font-size:78px}.battle-era{display:flex;align-items:baseline;gap:12px}.battle-period{margin-top:0}.battle-title{margin-top:10px}.battle-cta{margin-top:14px}.filter-panel-sheet{right:0;left:0;bottom:0;width:auto;max-height:82vh;border-radius:18px 18px 0 0;border-left:0;border-right:0;border-bottom:0;padding:18px 18px calc(20px + env(safe-area-inset-bottom));transform:translateY(100%);transform-origin:bottom center}.filter-panel.open .filter-panel-sheet{transform:translateY(0)}}
