:root {
  --bg: #0a0d12;
  --panel: #0f131a;
  --text: #e8f1f8;
  --muted: #8ea0b3;
  --accent: #00e5ff;    /* ネオンサイアン */
  --accent-2: #00ff9c;  /* ネオングリーン */
  --accent-3: #ff3f81;  /* ネオンマゼンタ */
  --danger: #ff5c77;
  --border: #1c2430;
  --glow-red: #ff2e6a;
  --glow-cyan: #2efcff;
  --glow-purple: #b35bff;
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Hiragino Kaku Gothic ProN", "Noto Sans JP", sans-serif;
  color: var(--text);
  background:
    radial-gradient(1200px 800px at 20% -10%, #121a28, #0a0d12 60%),
    linear-gradient(115deg, rgba(0,229,255,0.07), rgba(255,63,129,0.06) 40%, rgba(0,255,156,0.06));
}

/* スキャンラインと粒状ノイズ */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,0.02) 0 2px, transparent 2px 4px),
    radial-gradient(1200px 800px at 80% 20%, rgba(179,91,255,0.06), transparent 60%);
  mix-blend-mode: overlay;
  opacity: 0.4;
  animation: scanGlow 7s ease-in-out infinite;
  z-index: 0;
}
@keyframes scanGlow { 0%,100%{opacity:.35} 50%{opacity:.55} }

.app-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(0,229,255,0.08), rgba(0,0,0,0));
  position: sticky;
  top: 0;
  z-index: 10;
}
.app-header h1 {
  font-size: 18px;
  margin: 0;
  letter-spacing: 1px;
  text-transform: uppercase;
  font-weight: 700;
  font-family: Orbitron, Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Hiragino Kaku Gothic ProN", "Noto Sans JP", sans-serif;
  text-shadow: 0 0 12px rgba(0,229,255,0.4), 0 0 24px rgba(255,63,129,0.2);
}
/* グリッチ演出 */
.glitch { position: relative; display:inline-block; }
.glitch::before, .glitch::after { content: attr(data-text); position: absolute; left:0; top:0; pointer-events:none; }
.glitch::before { color: var(--glow-cyan); transform: translate(1px,0); opacity:.9; mix-blend-mode: screen; filter: blur(.5px); }
.glitch::after { color: var(--glow-red); transform: translate(-1px,0); opacity:.9; mix-blend-mode: screen; filter: blur(.5px); }
.glitch:hover { animation: glitchShift .7s steps(2,end) infinite; }
@keyframes glitchShift { 0%,100%{ transform:none } 25%{ transform:translateY(-0.5px) } 50%{ transform:translateX(0.5px) } 75%{ transform:translate(-0.5px,0.5px) } }

/* Logo styling */
.logo { display:inline-flex; align-items: baseline; gap: 8px; letter-spacing: 1.2px; position: relative; }
.logo .brand { display:inline-flex; gap: 2px; font-size: 26px; font-weight: 900; line-height: 1; }
.logo .brand .ch {
  display:inline-block;
  -webkit-background-clip: text; background-clip: text; color: transparent;
  -webkit-text-stroke: 0.6px rgba(255,255,255,0.12);
  text-shadow:
    0 0 8px rgba(179,91,255,0.35),
    0 0 18px rgba(124,58,237,0.30),
    0 0 28px rgba(192,132,252,0.22);
  filter: drop-shadow(0 0 6px rgba(179,91,255,0.22));
  background-size: 220% 220%;
  animation: holo var(--holo-speed, 7s) ease-in-out infinite, flicker var(--flicker-speed, 4s) steps(2,end) infinite;
}
.logo .brand .c1 { background-image: linear-gradient(135deg, #e9d5ff, #c084fc, #7c3aed); animation-delay: 0s; }
.logo .brand .c2 { background-image: linear-gradient(135deg, #d8b4fe, #a855f7, #9333ea); animation-delay: .2s; }
.logo .brand .c3 { background-image: linear-gradient(135deg, #c4b5fd, #8b5cf6, #7c3aed); animation-delay: .4s; }
.logo .brand .c4 { background-image: linear-gradient(135deg, #ddd6fe, #a78bfa, #8b5cf6); animation-delay: .6s; }
.logo .sub { display:inline-flex; gap: 1px; font-size: 18px; letter-spacing: .6px; line-height: 1; }
.logo .sub .ch {
  display:inline-block;
  -webkit-background-clip: text; background-clip: text; color: transparent;
  -webkit-text-stroke: 0.5px rgba(255,255,255,0.12);
  text-shadow:
    0 0 8px rgba(56,189,248,0.25),
    0 0 18px rgba(168,85,247,0.25);
  background-size: 220% 220%;
  animation: holo var(--holo-speed, 8s) ease-in-out infinite, flicker var(--flicker-speed, 5s) steps(2,end) infinite;
}
.logo .sub .s1 { background-image: linear-gradient(120deg, #93c5fd, #c084fc, #f472b6); }
.logo .sub .s2 { background-image: linear-gradient(120deg, #22d3ee, #60a5fa, #a78bfa); }
.logo .sub .s3 { background-image: linear-gradient(120deg, #34d399, #22d3ee, #93c5fd); }
.logo .sub .s4 { background-image: linear-gradient(120deg, #a78bfa, #7c3aed, #60a5fa); }
.logo .sub .s5 { background-image: linear-gradient(120deg, #fb7185, #f472b6, #c084fc); }
.logo .sub .s6 { background-image: linear-gradient(120deg, #60a5fa, #34d399, #22d3ee); }
.logo .sub .s7 { background-image: linear-gradient(120deg, #c084fc, #93c5fd, #7c3aed); }
.logo .sub .s8 { background-image: linear-gradient(120deg, #7c3aed, #a78bfa, #60a5fa); }
.logo .sub .s9 { background-image: linear-gradient(120deg, #22d3ee, #34d399, #93c5fd); }
.logo .sub .s10 { background-image: linear-gradient(120deg, #f472b6, #fb7185, #c084fc); }
.logo .sub .s11 { background-image: linear-gradient(120deg, #60a5fa, #a78bfa, #7c3aed); }
.logo .sub .skew { transform: skewX(-6deg); display:inline-block; }
.logo .sub .tilt { transform: rotate(-4deg); transform-origin: 20% 80%; display:inline-block; }
.logo .sub .sp { width: 8px; display:inline-block; }
.logo::after { content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px; background: linear-gradient(90deg, transparent, rgba(179,91,255,.85), transparent); filter: drop-shadow(0 0 10px rgba(179,91,255,.35)); }
@keyframes holo { 0%,100%{ background-position: 0% 0%; } 50%{ background-position: 100% 100%; } }
@keyframes flicker {
  0%, 19%, 21%, 23%, 80%, 100% { opacity: 1; filter: brightness(1); }
  20%, 22% { opacity: .92; filter: brightness(1.05); }
  81% { opacity: .96; }
}
.app-header .meta { display: flex; gap: 12px; align-items: center; color: var(--muted); }

.container { max-width: 1120px; margin: 0 auto; padding: 20px; display: grid; gap: 16px; }
.panel {
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0)) , var(--panel);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 16px;
  box-shadow: 0 0 0 1px rgba(0,229,255,0.06) inset, 0 10px 26px rgba(0,0,0,0.45), 0 0 40px rgba(0,229,255,0.04) inset;
}

.controls { display: grid; grid-template-columns: 1fr auto; gap: 16px; align-items: center; }
.rate-box { display: grid; gap: 6px; }
.rate-label { color: var(--muted); font-size: 12px; }
.rate-value { font-size: 32px; font-weight: 700; text-shadow: 0 0 8px rgba(0,229,255,0.25); }
.hint { color: var(--muted); font-size: 12px; }
.step-control { display: grid; gap: 6px; align-items: center; }
.step-control label { color: var(--muted); font-size: 12px; }
.step-inputs { display: flex; align-items: center; gap: 8px; }
.step-inputs input[type="range"] { width: 200px; accent-color: var(--accent); }
.step-inputs input[type="number"] { width: 80px; background: #0d131d; color: var(--text); border: 1px solid var(--border); padding: 8px; border-radius: 8px; }
.step-inputs .unit { color: var(--muted); font-size: 12px; }
.etf-control { display: grid; gap: 6px; align-items: center; }
.etf-control label { color: var(--muted); font-size: 12px; }
.etf-inputs { display: flex; align-items: center; gap: 8px; }
.etf-inputs input[type="range"] { width: 180px; accent-color: var(--accent-2); }
.etf-inputs input[type="number"] { width: 80px; background: #0d131d; color: var(--text); border: 1px solid var(--border); padding: 8px; border-radius: 8px; }
.etf-switch { display: inline-flex; align-items: center; gap: 6px; }
.buttons { display: flex; gap: 10px; }

button { appearance: none; border: 1px solid var(--border); background: #121823; color: var(--text); padding: 12px 16px; border-radius: 12px; cursor: pointer; font-weight: 700; letter-spacing: 0.2px; transition: 0.15s ease; text-shadow: 0 0 6px rgba(0,229,255,0.18); }
button.primary { background: radial-gradient(120% 180% at 10% -30%, rgba(0,229,255,0.2), transparent), #101622; border-color: rgba(0,229,255,0.35); box-shadow: 0 0 12px rgba(0,229,255,0.15) inset, 0 0 16px rgba(0,229,255,0.12); }
button.primary:hover { box-shadow: 0 0 0 1px rgba(0,229,255,0.6), 0 0 22px rgba(0,229,255,0.35), 0 0 40px rgba(0,229,255,0.2); transform: translateY(-1px) scale(1.01); }
button.danger { background: linear-gradient(180deg, rgba(255,63,129,0.15), rgba(0,0,0,0)), #151221; border-color: rgba(255,63,129,0.35); box-shadow: 0 0 10px rgba(255,63,129,0.15) inset, 0 0 16px rgba(255,63,129,0.12); }
button.danger:hover { box-shadow: 0 0 0 1px rgba(255,63,129,0.7), 0 0 26px rgba(255,63,129,0.35), 0 0 40px rgba(255,63,129,0.2); transform: translateY(-1px) scale(1.01); }
button.secondary { background: #0e141e; border-color: rgba(0,255,156,0.35); box-shadow: 0 0 10px rgba(0,255,156,0.15) inset, 0 0 14px rgba(0,255,156,0.12); }
button.secondary:hover { box-shadow: 0 0 0 1px rgba(0,255,156,0.55), 0 0 20px rgba(0,255,156,0.22); transform: translateY(-1px); }

/* カードをエッジィに */
.card { background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(0,0,0,0)), #0b0f16; border-radius: 14px; box-shadow: 0 1px 0 rgba(255,255,255,0.03) inset, 0 0 0 1px rgba(0,229,255,0.06) inset, 0 12px 28px rgba(0,0,0,0.5); }
.card .value { text-shadow: 0 0 10px rgba(0,229,255,0.25), 0 0 20px rgba(179,91,255,0.15); }

.dashboard { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 12px; }
.card { border: 1px solid var(--border); border-radius: 10px; padding: 12px; background: #131922; display: grid; gap: 8px; }
.card { background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(0,0,0,0)), #0f121a; border-radius: 14px; box-shadow: 0 1px 0 rgba(255,255,255,0.03) inset, 0 0 0 1px rgba(0,229,255,0.05) inset; }
.card .label { color: var(--muted); font-size: 12px; letter-spacing: 0.3px; }
.card .value { font-size: 24px; font-weight: 800; text-shadow: 0 0 8px rgba(0,229,255,0.15); }
canvas { width: 100%; height: 90px; display: block; filter: drop-shadow(0 0 6px rgba(0,229,255,0.12)); border-radius: 6px; }

.news { font-size: 14px; color: var(--muted); border-left: 2px solid rgba(0,229,255,0.35); padding-left: 10px; background: linear-gradient(90deg, rgba(0,229,255,0.06), transparent); }
.consensus { margin-top: 10px; display: grid; gap: 6px; }
.cons-line { display: flex; gap: 8px; align-items: baseline; }
.cons-line .tag { font-weight: 700; color: var(--accent); font-size: 12px; letter-spacing: 0.3px; text-transform: uppercase; }

.footer { display: flex; justify-content: space-between; align-items: center; color: var(--muted); }

@media (max-width: 900px) {
  .controls { grid-template-columns: 1fr; }
}

/* Modal */
.modal-backdrop { position: fixed; inset: 0; background: rgba(4,8,12,0.65); backdrop-filter: blur(4px); display: grid; place-items: center; z-index: 100; }
.modal { width: min(720px, 92vw); border: 1px solid var(--border); border-radius: 16px; background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(0,0,0,0)), #0e1219; box-shadow: 0 20px 60px rgba(0,0,0,0.45), 0 0 0 1px rgba(0,229,255,0.06) inset; }
.modal .title { text-shadow: 0 0 12px rgba(0,229,255,0.3); letter-spacing: 0.8px; }
.options .chip { position: relative; }
.options .chip::after { content:""; position:absolute; inset:0; border-radius:999px; box-shadow: 0 0 24px rgba(0,229,255,0.08), 0 0 48px rgba(255,63,129,0.06); opacity:0; transition: .15s; }
.options .chip:hover::after { opacity: 1; }

/* Cooldown indicator */
.cooldown { margin-left: 8px; padding: 4px 8px; border: 1px solid var(--border); border-radius: 999px; font-size: 12px; color: var(--muted); align-self: center; }
.cooldown.ok { color: var(--accent-2); border-color: rgba(0,255,156,0.45); box-shadow: 0 0 10px rgba(0,255,156,0.15) inset, 0 0 14px rgba(0,255,156,0.12); }
.cooldown.wait { color: #e3a6ff; border-color: rgba(179,91,255,0.45); box-shadow: 0 0 10px rgba(179,91,255,0.12) inset, 0 0 14px rgba(179,91,255,0.10); }
.modal-header { display: flex; align-items: center; justify-content: space-between; padding: 12px 14px; border-bottom: 1px solid var(--border); }
.modal-header .title { font-weight: 800; letter-spacing: 0.6px; text-shadow: 0 0 8px rgba(0,229,255,0.2); }
.icon-btn { border: 1px solid var(--border); background: #111725; color: var(--text); border-radius: 8px; padding: 6px 10px; cursor: pointer; }
.modal-body { padding: 14px; display: grid; gap: 12px; }
.phase { color: var(--muted); font-size: 12px; }
.options { display: flex; flex-wrap: wrap; gap: 8px; }
.options .chip { padding: 10px 12px; border-radius: 999px; border: 1px solid var(--border); cursor: pointer; background: #0f1522; box-shadow: 0 0 0 1px rgba(0,229,255,0.05) inset; }
.options .chip.active { outline: 1px solid rgba(0,229,255,0.55); box-shadow: 0 0 18px rgba(0,229,255,0.25); }
.preview-label { color: var(--muted); font-size: 12px; }
.preview { min-height: 42px; border: 1px dashed var(--border); border-radius: 10px; padding: 10px; line-height: 1.6; background: linear-gradient(180deg, rgba(0,229,255,0.05), rgba(0,0,0,0)); }
.tone-label { color: var(--muted); font-size: 12px; margin-top: 4px; }
.tone { min-height: 28px; border: 1px solid var(--border); border-radius: 10px; padding: 6px 10px; line-height: 1.6; background: #0d121c; font-weight: 700; letter-spacing: 0.3px; }
.tone .dove { color: #00ff9c; }
.tone .neutral { color: #9db2c8; }
.tone .hawk { color: #ff5c77; }
.impact-label { color: var(--muted); font-size: 12px; margin-top: 4px; }
.impact { min-height: 36px; border: 1px solid var(--border); border-radius: 10px; padding: 8px 10px; line-height: 1.6; background: #0c121b; }
.impact .pos { color: #00ff9c; }
.impact .neg { color: #ff5c77; }

/* Taylor gap coloring */
.gap-pos { color: var(--danger); text-shadow: 0 0 8px rgba(255,92,119,0.22); }
.gap-neg { color: var(--accent-2); text-shadow: 0 0 8px rgba(0,255,156,0.22); }
.gap-zero { color: var(--muted); }
.modal-footer { display: flex; gap: 8px; padding: 12px 14px; border-top: 1px solid var(--border); }
.modal-footer .spacer { flex: 1; }

/* Help modal */
.help-body { display: grid; gap: 14px; }
.help-title { font-weight: 800; letter-spacing: .3px; text-shadow: 0 0 8px rgba(0,229,255,.18); margin-bottom: 4px; }
.help-section ul { margin: 6px 0 0 18px; padding: 0; }
.help-section li { margin: 4px 0; }
