:root{--bg: #05070d;--bg-soft: #0b111d;--panel: #111a2b;--panel-2: #16223a;--line: rgba(120, 200, 220, .14);--text: #e7eef6;--text-dim: #9fb0c4;--accent: #57e0d6;--accent-2: #7aa2ff;--danger: #ff6b8a;--maxw: 1080px;--radius: 14px;--font: "Hiragino Kaku Gothic ProN", "Noto Sans JP", "Yu Gothic", "Meiryo", system-ui, sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:radial-gradient(1200px 700px at 50% -10%,rgba(87,224,214,.1),transparent 60%),radial-gradient(900px 600px at 90% 20%,rgba(122,162,255,.08),transparent 55%),var(--bg);color:var(--text);font-family:var(--font);line-height:1.85;letter-spacing:.02em;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}.section{padding:84px 0;border-top:1px solid var(--line)}.section:first-of-type{border-top:0}.eyebrow{color:var(--accent);font-size:.8rem;letter-spacing:.28em;text-transform:uppercase;margin:0 0 12px}.section h2{font-size:clamp(1.5rem,3.5vw,2.2rem);margin:0 0 28px;font-weight:700}.lead-text{color:var(--text-dim);max-width:46em}.ph{display:grid;place-items:center;background:repeating-linear-gradient(45deg,rgba(255,255,255,.02) 0 12px,transparent 12px 24px),var(--panel);border:1px dashed var(--line);border-radius:var(--radius);color:var(--text-dim);font-size:.8rem;letter-spacing:.1em;min-height:180px}.btn{display:inline-block;padding:13px 26px;border-radius:999px;font-weight:700;background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#04121a;border:0}.btn:hover{text-decoration:none;opacity:.92}.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--line)}.hero{position:relative;min-height:78vh;display:grid;place-items:center;text-align:center;overflow:hidden}.hero .ph-bg{position:absolute;inset:0;background:repeating-linear-gradient(45deg,rgba(255,255,255,.015) 0 14px,transparent 14px 28px),linear-gradient(180deg,#081222,#05070d);z-index:0}.hero .inner{position:relative;z-index:1;padding:40px 20px}.hero h1{font-size:clamp(2.2rem,7vw,4.4rem);margin:0 0 18px;letter-spacing:.08em;text-shadow:0 0 40px rgba(87,224,214,.35)}.hero .sub{color:var(--text-dim);font-size:clamp(.95rem,2vw,1.15rem);margin:0 auto 26px;max-width:34em}.keyphrases{list-style:none;padding:0;margin:30px auto 0;max-width:30em;color:var(--accent)}.keyphrases li{margin:6px 0;font-size:.98rem;opacity:.9}.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:10px}.pillar{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:24px}.pillar h3{margin:0 0 8px;color:var(--accent);font-size:1.05rem}.pillar p{margin:0;color:var(--text-dim);font-size:.92rem}.factions{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.faction{background:linear-gradient(180deg,var(--panel),var(--bg-soft));border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}.faction .thumb{min-height:150px;border:0;border-bottom:1px dashed var(--line);border-radius:0}.faction .body{padding:22px;display:flex;flex-direction:column;gap:14px}.faction .area{font-size:.72rem;letter-spacing:.2em;color:var(--accent-2);border:1px solid var(--line);border-radius:999px;padding:3px 10px;width:fit-content}.faction h3{margin:0;font-size:1.35rem}.faction .tagline{color:var(--text-dim);font-size:.86rem;margin:0}.faction .intro{font-size:.9rem;color:var(--text)}.chars{display:grid;gap:12px;margin-top:4px}.char{background:#ffffff05;border:1px solid var(--line);border-radius:10px;padding:12px 14px}.char .name{font-weight:700;color:var(--accent);font-size:.95rem}.char .desc{color:var(--text-dim);font-size:.82rem;margin-top:4px}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:24px}.card h3{margin:0 0 10px;font-size:1.05rem}.card p{margin:4px 0;color:var(--text-dim);font-size:.9rem}.card .big{color:var(--text);font-size:1.1rem;font-weight:700}.linklist{list-style:none;padding:0;margin:0;display:grid;gap:10px}.linklist a{display:block;padding:14px 18px;background:var(--panel);border:1px solid var(--line);border-radius:10px}.footer{padding:48px 0;border-top:1px solid var(--line);color:var(--text-dim);font-size:.82rem;text-align:center}.nav{position:sticky;top:0;z-index:50;background:#05070db8;backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:60px;gap:16px}.nav-logo{color:var(--text);font-weight:700;font-size:.95rem;letter-spacing:.06em;white-space:nowrap}.nav-logo:hover{text-decoration:none;color:var(--accent)}.nav-links{display:flex;gap:4px;list-style:none;margin:0;padding:0;flex-wrap:wrap}.nav-links a{display:block;padding:8px 12px;border-radius:8px;color:var(--text-dim);font-size:.88rem}.nav-links a:hover{color:var(--text);background:#ffffff0a;text-decoration:none}.nav-links a.active{color:var(--accent)}main{min-height:60vh}.area{display:inline-block;font-size:.72rem;letter-spacing:.2em;color:var(--accent-2);border:1px solid var(--line);border-radius:999px;padding:3px 10px}.page-head{padding:64px 0 40px;border-bottom:1px solid var(--line)}.page-head h1{font-size:clamp(1.9rem,5vw,3rem);margin:10px 0 14px;letter-spacing:.06em}.page-lead{color:var(--text-dim);max-width:44em}.wrap.narrow{max-width:760px}.hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.faction-card{background:linear-gradient(180deg,var(--panel),var(--bg-soft));border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;color:var(--text);transition:transform .18s ease,border-color .18s ease}.faction-card:hover{transform:translateY(-4px);border-color:#57e0d666;text-decoration:none}.faction-card .thumb{min-height:150px;border:0;border-bottom:1px dashed var(--line);border-radius:0}.faction-card .body{padding:22px;display:flex;flex-direction:column;gap:12px}.faction-card h3{margin:0;font-size:1.35rem}.faction-card .tagline{color:var(--text-dim);font-size:.86rem;margin:0}.faction-card .more{color:var(--accent);font-size:.85rem;margin-top:4px}.story-factions{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:24px}.story-faction{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px;color:var(--text);display:flex;flex-direction:column;gap:10px;transition:transform .18s ease,border-color .18s ease}.story-faction:hover{transform:translateY(-4px);border-color:#57e0d666;text-decoration:none}.story-faction h3{margin:0;font-size:1.2rem}.story-faction p{color:var(--text-dim);font-size:.85rem;margin:0}.story-faction .more{color:var(--accent);font-size:.84rem}.faction-hero{position:relative;overflow:hidden}.faction-hero-bg{min-height:300px;border:0;border-radius:0;border-bottom:1px solid var(--line)}.faction-hero-inner{padding:28px 20px 8px}.faction-hero-inner h1{font-size:clamp(2rem,6vw,3.2rem);margin:12px 0 10px}.faction-hero-inner .tagline{color:var(--text-dim);margin:0}.char-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:18px}.char-card{display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;color:var(--text);transition:transform .18s ease,border-color .18s ease}.char-card:hover{transform:translateY(-4px);border-color:#57e0d666;text-decoration:none}.portrait{position:relative;aspect-ratio:3 / 4;display:grid;place-items:center;background:radial-gradient(120% 80% at 50% 20%,#1b2740,#0a0f1a 80%)}.portrait img{width:100%;height:100%;object-fit:cover}.silhouette{width:62%;height:62%;fill:#7896be59}.portrait.is-open .silhouette{filter:drop-shadow(0 0 20px rgba(87,224,214,.15))}.recruit-badge{position:absolute;top:10px;right:10px;font-size:.68rem;letter-spacing:.08em;font-weight:700;background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#04121a;padding:4px 9px;border-radius:999px}.char-meta{padding:12px 14px;display:flex;flex-direction:column;gap:3px}.char-faction{color:var(--text-dim);font-size:.72rem}.char-name{font-weight:700;font-size:1rem}.char-detail-inner{display:grid;grid-template-columns:320px 1fr;gap:36px;align-items:start}.char-portrait{position:relative;aspect-ratio:3 / 4;border-radius:var(--radius);overflow:hidden;background:radial-gradient(120% 80% at 50% 20%,#1b2740,#0a0f1a 80%);border:1px solid var(--line);display:grid;place-items:center}.char-portrait img{width:100%;height:100%;object-fit:cover}.char-info h1{font-size:clamp(1.8rem,4vw,2.6rem);margin:10px 0 18px}.char-faction-link{display:inline-flex;align-items:center;gap:8px;color:var(--text-dim);font-size:.85rem}.cast-note{margin:24px 0;padding:20px;border:1px dashed var(--line);border-radius:var(--radius);background:#57e0d60a}.cast-note p{margin:0 0 14px;color:var(--text-dim);font-size:.9rem}.card.highlight{border-color:#57e0d666}.steps{padding-left:1.2em;color:var(--text-dim)}.steps li{margin:10px 0}.badge-inline{display:inline-block;font-size:.72rem;font-weight:700;color:#04121a;background:linear-gradient(120deg,var(--accent),var(--accent-2));padding:2px 8px;border-radius:999px}.pager{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:28px}.footer-links{list-style:none;padding:0;margin:0 0 20px;display:flex;flex-wrap:wrap;gap:8px 20px;justify-content:center}.footer .note{opacity:.7}@media(max-width:860px){.pillars,.factions,.cards,.story-factions{grid-template-columns:1fr}.section{padding:60px 0}.char-detail-inner{grid-template-columns:1fr}.char-portrait{max-width:300px}.nav-inner{height:auto;padding-top:10px;padding-bottom:10px;flex-direction:column;align-items:flex-start}}
