: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: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", "Meiryo", system-ui, sans-serif;--font-serif: "Noto Serif JP", "Hiragino Mincho ProN", "Yu Mincho", serif;--glow: 0 0 40px rgba(87, 224, 214, .28);--ease: cubic-bezier(.22, 1, .36, 1)}h1,h2,.hero h1,.page-head h1,.faction-hero-inner h1,.char-info h1,.section h2,.faction-card h3,.story-faction h3{font-family:var(--font-serif);font-weight:700;letter-spacing:.04em}*{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}.f-residents{--fa: #57e0d6;--fa2: #3aa7b5}.f-regulation{--fa: #ff5a5a;--fa2: #8f1119}.f-badlands{--fa: #c86bff;--fa2: #7a2fd0}.faction-card .area,.story-faction .area,.char-card .char-faction{color:var(--fa, var(--accent-2))}.faction-card .area,.story-faction .area{border-color:color-mix(in srgb,var(--fa, var(--accent)) 45%,var(--line))}.faction-card .more,.story-faction .more{color:var(--fa, var(--accent))}.faction-card:hover,.story-faction:hover,.char-card:hover{border-color:color-mix(in srgb,var(--fa, var(--accent)) 55%,transparent);box-shadow:0 8px 30px color-mix(in srgb,var(--fa, var(--accent)) 16%,transparent)}.faction-card .thumb{background:radial-gradient(120% 80% at 50% 30%,color-mix(in srgb,var(--fa, var(--accent)) 12%,transparent),transparent 70%),repeating-linear-gradient(45deg,rgba(255,255,255,.02) 0 12px,transparent 12px 24px),var(--panel)}.char-card .portrait{background:radial-gradient(120% 80% at 50% 20%,color-mix(in srgb,var(--fa, #1b2740) 30%,#101826),#0a0f1a 82%)}.char-card .silhouette{fill:color-mix(in srgb,var(--fa, #8ab) 40%,rgba(120,150,190,.35))}body.theme-residents{--accent: #57e0d6;--accent-2: #3aa7b5}body.theme-regulation{--accent: #ff5a5a;--accent-2: #ff8a8a;--bg-soft: #0a0608;--panel: #17090b;--line: rgba(255,90,90,.16)}body.theme-badlands{--accent: #c86bff;--accent-2: #d79bff;--panel: #150e22;--line: rgba(200,107,255,.16)}body[class*=theme-] .faction-hero{background:radial-gradient(80% 60% at 50% 0%,color-mix(in srgb,var(--accent) 18%,transparent),transparent 65%)}.faction-card,.char-card,.story-faction{position:relative;will-change:transform}.faction-card:after,.char-card:after,.story-faction:after{content:"";position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .3s ease;border-radius:inherit;background:radial-gradient(circle at var(--mx, 50%) var(--my, 50%),color-mix(in srgb,var(--fa, var(--accent)) 24%,transparent),transparent 46%)}.faction-card.lit:after,.char-card.lit:after,.story-faction.lit:after{opacity:1}.faction-card.lit,.char-card.lit,.story-faction.lit{box-shadow:0 16px 46px color-mix(in srgb,var(--fa, var(--accent)) 24%,transparent);border-color:color-mix(in srgb,var(--fa, var(--accent)) 60%,transparent)}@media(prefers-reduced-motion:reduce){.faction-card:after,.char-card:after,.story-faction:after{display:none}}.grain{position:fixed;inset:0;z-index:200;pointer-events:none;opacity:.05;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:140px 140px}.js .reveal{opacity:0;transform:translateY(20px);transition:opacity .9s var(--ease),transform .9s var(--ease);will-change:opacity,transform}.js .reveal.is-in{opacity:1;transform:none}@media(prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none}}.audio-toggle{position:fixed;right:18px;bottom:18px;z-index:210;width:44px;height:44px;border-radius:999px;display:grid;place-items:center;cursor:pointer;background:#0b111db3;backdrop-filter:blur(8px);border:1px solid var(--line);color:var(--text-dim);transition:color .3s,border-color .3s,box-shadow .3s}.audio-toggle:hover{color:var(--text)}.audio-toggle.on{color:var(--accent);border-color:#57e0d680;box-shadow:0 0 18px #57e0d640}.audio-toggle svg{width:20px;height:20px}.audio-toggle .wave{opacity:0;transition:opacity .3s}.audio-toggle.on .wave{opacity:1}.sound-tree{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}.sound-tree .glow{position:absolute;left:50%;top:46%;width:520px;height:520px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(87,224,214,.22),rgba(87,224,214,.05) 45%,transparent 70%);animation:treePulse 6s var(--ease) infinite}.sound-tree .ripples{position:absolute;left:50%;top:62%;transform:translate(-50%,-50%)}.sound-tree .ripples span{position:absolute;left:50%;top:50%;width:120px;height:120px;margin:-60px 0 0 -60px;border:1px solid rgba(87,224,214,.22);border-radius:50%;transform:scale(.2);opacity:0;animation:ripple 9s linear infinite}.sound-tree .ripples span:nth-child(2){animation-delay:3s}.sound-tree .ripples span:nth-child(3){animation-delay:6s}.sound-tree .tree{position:absolute;left:50%;top:50%;width:min(70vw,460px);transform:translate(-50%,-50%)}.sound-tree .tree path,.sound-tree .tree line{stroke:#96ebe18c;stroke-width:1.4;fill:none;filter:drop-shadow(0 0 6px rgba(87,224,214,.5))}.sound-tree .tree .note{fill:#b4f5ebe6;stroke:none;filter:drop-shadow(0 0 6px rgba(87,224,214,.8))}.sound-tree .tree .note{animation:twinkle 5s ease-in-out infinite}.sound-tree .tree .note:nth-child(odd){animation-delay:1.5s}.sound-tree .tree .note:nth-child(3n){animation-delay:2.6s}@keyframes treePulse{0%,to{opacity:.55;transform:translate(-50%,-50%) scale(.96)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.04)}}@keyframes ripple{0%{transform:scale(.2);opacity:0}12%{opacity:.5}to{transform:scale(2.6);opacity:0}}@keyframes twinkle{0%,to{opacity:.35}50%{opacity:1}}@media(prefers-reduced-motion:reduce){.sound-tree .glow,.sound-tree .ripples span,.sound-tree .tree .note{animation:none}}@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}}.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}@keyframes astroFadeInOut{0%{opacity:1}to{opacity:0}}@keyframes astroFadeIn{0%{opacity:0;mix-blend-mode:plus-lighter}to{opacity:1;mix-blend-mode:plus-lighter}}@keyframes astroFadeOut{0%{opacity:1;mix-blend-mode:plus-lighter}to{opacity:0;mix-blend-mode:plus-lighter}}@keyframes astroSlideFromRight{0%{transform:translate(100%)}}@keyframes astroSlideFromLeft{0%{transform:translate(-100%)}}@keyframes astroSlideToRight{to{transform:translate(100%)}}@keyframes astroSlideToLeft{to{transform:translate(-100%)}}@media(prefers-reduced-motion){::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){animation:none!important}[data-astro-transition-scope]{animation:none!important}}
