:root {
  --bg: #f6efe6;
  --panel: #fbf6ef;
  --card: #fff9f3;
  --muted: #746a5f;
  --fg: #2b241f;
  --pri: #8b5e34;
  --accent: #b0855b;
  --warn: #b45309;
  --err: #7a1f1f;
  --border: #e9dfd3;
}

:root[data-theme="light"] {
  --bg: #f3f4f6;
  --panel: #ffffff;
  --muted: #6b7280;
  --fg: #111827;
  --pri: #3b82f6;
  --accent: #16a34a;
  --warn: #d97706;
  --err: #dc2626;
  --card: #f9fafb;
  --border: #e5e7eb;
}

:root[data-theme="light2"] {
  --bg: #f3f4f6;
  --panel: #ffffff;
  --muted: #6b7280;
  --fg: #111827;
  --pri: #3b82f6;
  --accent: #16a34a;
  --warn: #d97706;
  --err: #dc2626;
  --card: #f9fafb;
  --border: #d1d5db;
}

:root[data-theme="blue"] {
  --bg: #0a1930;
  --panel: #0d223f;
  --muted: #93c5fd;
  --fg: #e0f2fe;
  --pri: #60a5fa;
  --accent: #38bdf8;
  --warn: #f59e0b;
  --err: #ef4444;
  --card: #0b1f3a;
  --border: #1e3a8a;
}

:root[data-theme="gold"] {
  --bg: #15100a;
  --panel: #1c150b;
  --muted: #f5d38c;
  --fg: #fff7e6;
  --pri: #f59e0b;
  --accent: #fbbf24;
  --warn: #d97706;
  --err: #ef4444;
  --card: #1a1309;
  --border: #3f2d0f;
}

:root[data-theme="pink"] {
  --bg: #170f1c;
  --panel: #1f1326;
  --muted: #f9a8d4;
  --fg: #fde7f3;
  --pri: #ec4899;
  --accent: #f472b6;
  --warn: #f59e0b;
  --err: #ef4444;
  --card: #1b1122;
  --border: #4c1d95;
}

:root[data-theme="DarkPlus"] {
  --bg: #0d1116;
  --panel: #161b21;
  --card: #12171d;
  --border: #1f2a33;
  --fg: #e5e7eb;
  --muted: #8b96a3;
  --pri: #f97316;
  --accent: #ea580c;
  --warn: #f59e0b;
  --err: #ef4444;
}

:root[data-theme="deepDark"] {
  --bg: #0b0c10;
  --panel: #0e1015;
  --muted: #9aa3ad;
  --fg: #e5e7eb;
  --pri: #60a5fa;
  --accent: #22c55e;
  --warn: #f59e0b;
  --err: #ef4444;
  --card: #0a0c12;
  --border: #1a1f2a;
}

:root[data-theme="darkColorblind"] {
  --bg: #0b0c10;
  --panel: #0e1015;
  --muted: #9aa3ad;
  --fg: #e5e7eb;
  --pri: #fb923c;
  --accent: #f59e0b;
  --warn: #f59e0b;
  --err: #ef4444;
  --card: #0a0c12;
  --border: #1a1f2a;
}

:root[data-theme="darkTritanopia"] {
  --bg: #0b0c10;
  --panel: #0e1015;
  --muted: #9aa3ad;
  --fg: #e5e7eb;
  --pri: #f87171;
  --accent: #ef4444;
  --warn: #f59e0b;
  --err: #ef4444;
  --card: #0a0c12;
  --border: #1a1f2a;
}

:root[data-theme="lightGray"] {
  --bg: #e5e7eb;
  --panel: #f3f4f6;
  --muted: #4b5563;
  --fg: #1f2937;
  --pri: #2563eb;
  --accent: #15803d;
  --warn: #b45309;
  --err: #b91c1c;
  --card: #f9fafb;
  --border: #d1d5db;
}

:root[data-theme="lightGrayPlus"] {
  --bg: #e5e7eb;
  --panel: #f3f4f6;
  --muted: #4b5563;
  --fg: #1f2937;
  --pri: #2563eb;
  --accent: #15803d;
  --warn: #b45309;
  --err: #b91c1c;
  --card: #f9fafb;
  --border: #d1d5db;
}

:root[data-theme="lightCool"] {
  --bg: #eef2ff;
  --panel: #f5f8ff;
  --muted: #475569;
  --fg: #0f172a;
  --pri: #2563eb;
  --accent: #0ea5e9;
  --warn: #d97706;
  --err: #b91c1c;
  --card: #ffffff;
  --border: #dbeafe;
}

:root[data-theme="lightSepia"] {
  --bg: #f6efe6;
  --panel: #fbf6ef;
  --muted: #746a5f;
  --fg: #2b241f;
  --pri: #8b5e34;
  --accent: #b0855b;
  --warn: #b45309;
  --err: #7a1f1f;
  --card: #fff9f3;
  --border: #e9dfd3;
}

:root[data-theme="lightGreen"] {
  --bg: #eefaf3;
  --panel: #f6fbf8;
  --muted: #476257;
  --fg: #0f2a24;
  --pri: #15803d;
  --accent: #34d399;
  --warn: #b45309;
  --err: #9b1f1f;
  --card: #ffffff;
  --border: #dbeee6;
}

:root[data-theme="lightHighContrast"] {
  --bg: #ffffff;
  --panel: #ffffff;
  --muted: #4b5563;
  --fg: #0b0b0b;
  --pri: #0b5cff;
  --accent: #0b8a4a;
  --warn: #b45309;
  --err: #a41616;
  --card: #ffffff;
  --border: #d1d5db;
}

:root[data-theme="softGray"] {
  --bg: #d6d6d1;
  --panel: #dfdfd9;
  --muted: #6b6b64;
  --fg: #3b3b36;
  --pri: #6b7a8a;
  --accent: #7b8f7f;
  --warn: #9a7a46;
  --err: #8f4c4c;
  --card: #e8e8e2;
  --border: #c7c7c1;
}

:root[data-theme="warmPaper"] {
  --bg: #f1eadf;
  --panel: #f7f1e7;
  --muted: #6f655a;
  --fg: #3f362d;
  --pri: #8a6b4f;
  --accent: #9c7f63;
  --warn: #a26e3f;
  --err: #8a4b4b;
  --card: #fbf6ee;
  --border: #e0d7c9;
}

:root[data-theme="mistBlue"] {
  --bg: #e3e8ee;
  --panel: #edf1f5;
  --muted: #5d6a78;
  --fg: #2c3642;
  --pri: #5d7a92;
  --accent: #6f8ea4;
  --warn: #9a7a45;
  --err: #8a4d4d;
  --card: #f6f8fa;
  --border: #d2d9e1;
}

:root[data-theme="darkAsh"] {
  --bg: #141414;
  --panel: #1b1b1b;
  --muted: #a6a09a;
  --fg: #d7d2cc;
  --pri: #b48b6a;
  --accent: #c8a784;
  --warn: #c38b3a;
  --err: #c06a6a;
  --card: #181818;
  --border: #262626;
}

:root[data-theme="graphiteSoft"] {
  --bg: #202124;
  --panel: #26272b;
  --muted: #9aa0a8;
  --fg: #d3d6da;
  --pri: #8a98a8;
  --accent: #9aa6b2;
  --warn: #b08a55;
  --err: #b06b6b;
  --card: #232429;
  --border: #2f3036;
}

:root[data-theme="darkMoss"] {
  --bg: #0f1210;
  --panel: #151a14;
  --muted: #9aa396;
  --fg: #d3d8cf;
  --pri: #93a273;
  --accent: #a4b68c;
  --warn: #c1995b;
  --err: #b96c6c;
  --card: #121613;
  --border: #1e2520;
}

:root {
  --radius: 14px;
  --radius-tight: 10px;
  --space: 8px;
  --font-sans: "Bahnschrift", "Franklin Gothic Medium", "Trebuchet MS", sans-serif;
  --font-mono: "Cascadia Mono", "Consolas", "Courier New", monospace;
  --shadow-strong: 0 18px 36px color-mix(in srgb, var(--fg) 25%, transparent);
  --shadow-soft: 0 2px 0 color-mix(in srgb, var(--fg) 20%, transparent);
  --pattern-line: color-mix(in srgb, var(--fg) 8%, transparent);
  --input-bg: color-mix(in srgb, var(--panel) 70%, var(--card));
  --chip-bg: color-mix(in srgb, var(--panel) 80%, var(--fg) 10%);
  --chip-border: color-mix(in srgb, var(--border) 80%, var(--fg) 5%);
  --chip-accent-bg: color-mix(in srgb, var(--accent) 20%, var(--panel));
  --chip-accent-border: color-mix(in srgb, var(--accent) 45%, var(--border));
  --chip-muted-bg: color-mix(in srgb, var(--pri) 12%, var(--panel));
  --chip-muted-border: color-mix(in srgb, var(--pri) 30%, var(--border));
  --dashed-border: color-mix(in srgb, var(--pri) 40%, var(--border));
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: var(--font-sans);
  color: var(--fg);
  background: var(--bg);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background-image: repeating-linear-gradient(
    120deg,
    var(--pattern-line),
    var(--pattern-line) 1px,
    transparent 1px,
    transparent 16px
  );
  pointer-events: none;
  opacity: 0.55;
}

.app {
  position: relative;
  max-width: 1420px;
  margin: 0 auto;
  padding: 28px 20px 48px;
}

.hero {
  padding: 12px 8px 24px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
}

.hero-title {
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 700;
  letter-spacing: 0.5px;
}

.hero-subtitle {
  color: var(--muted);
  font-size: 16px;
  letter-spacing: 0.2px;
}

.hero-links {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  margin-top: 4px; /* つじつまあわせ */
  gap: 4px;
  text-align: right;
}

.hero-left {
  text-align: left;
}

.hero-link {
  color: var(--accent);
  text-decoration: none;
  font-weight: 600;
}

.hero-link:hover {
  text-decoration: underline;
}

.hero-note {
  color: var(--muted);
  font-size: 16px;
}

.grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: minmax(160px, auto);
}

.panel {
  background: var(--panel);
  border-radius: var(--radius);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-strong), var(--shadow-soft);
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 160px;
  animation: rise 520ms ease-out both;
  animation-delay: var(--delay, 0ms);
}

.panel-dump {
  grid-column: span 2;
  grid-row: span 3;
}

.panel-ledger-table {
  grid-column: span 2;
  grid-row: span 2;
}

.panel-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}

h2 {
  margin: 0;
  font-size: 18px;
  letter-spacing: 0.3px;
}

.hint {
  font-size: 12px;
  color: var(--muted);
}

.chip {
  font-size: 12px;
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--chip-bg);
  color: var(--muted);
  border: 1px solid var(--chip-border);
}

.chip-accent {
  background: var(--chip-accent-bg);
  color: var(--accent);
  border-color: var(--chip-accent-border);
}

.chip-muted {
  background: var(--chip-muted-bg);
  color: var(--pri);
  border-color: var(--chip-muted-border);
}


.emulator-select {
  height: 54px;
  font-size: 18px;
  font-weight: 600;
  padding: 0 14px;
  border-radius: var(--radius-tight);
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--fg);
}

.meta-line {
  color: var(--muted);
  font-size: 13px;
}

.field-row {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: end;
}

.field span {
  display: block;
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 6px;
}

.field input,
.field select {
  width: 100%;
  height: 42px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--input-bg);
  padding: 0 12px;
  font-size: 16px;
  color: var(--fg);
}

.run-button {
  height: 42px;
  padding: 0 18px;
  font-size: 16px;
  font-weight: 600;
  border-radius: 12px;
  border: none;
  background: color-mix(in srgb, var(--accent) 65%, var(--panel));
  color: var(--fg);
  cursor: pointer;
  border: 1px solid color-mix(in srgb, var(--accent) 55%, var(--border));
  box-shadow: 0 10px 20px color-mix(in srgb, var(--accent) 30%, transparent);
}

.run-button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  box-shadow: none;
}

.action-input {
  min-height: 150px;
  max-height: 240px;
  resize: vertical;
  border-radius: 14px;
  border: 1px solid var(--border);
  padding: 12px;
  font-size: 16px;
  font-family: var(--font-mono);
  background: var(--input-bg);
  color: var(--fg);
}

.seed-grid {
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: 10px;
  align-items: center;
  font-family: var(--font-mono);
}

.seed-label {
  font-size: 12px;
  color: var(--muted);
}

.seed-value {
  font-size: 16px;
  font-weight: 600;
  color: var(--fg);
}

.dump-output,
.log-output {
  width: 100%;
  border-radius: 14px;
  border: 1px solid var(--border);
  padding: 12px;
  font-family: var(--font-mono);
  font-size: 16px;
  line-height: 1.5;
  color: color-mix(in srgb, var(--fg) 70%, var(--muted));
  background: color-mix(in srgb, var(--input-bg) 94%, var(--panel));
  resize: none;
}

.dump-output {
  min-height: 720px;
  flex: 1;
}

.log-output {
  min-height: 140px;
}

.memo-title {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.memo-table {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 180px;
}

.memo-empty {
  color: var(--muted);
  font-size: 13px;
}

.memo-scroll {
  border: 1px solid var(--border);
  border-radius: 12px;
  background: color-mix(in srgb, var(--input-bg) 94%, var(--panel));
  padding: 6px;
  max-height: 260px;
  overflow: auto;
}

.memo-grid {
  width: 100%;
  min-width: 1100px;
  table-layout: fixed;
  border-collapse: collapse;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg);
}

.memo-grid th,
.memo-grid td {
  padding: 6px 8px;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
  vertical-align: top;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.memo-grid th {
  text-align: left;
  color: var(--muted);
  font-weight: 600;
}

.memo-row {
  position: relative;
}

.memo-input {
  position: relative;
  padding-right: 36px;
}

.memo-copy {
  position: absolute;
  top: 6px;
  right: 6px;
  font-size: 11px;
  color: var(--accent);
  text-decoration: none;
  opacity: 0;
  transition: opacity 0.15s ease;
}

.memo-row:hover .memo-copy {
  opacity: 1;
}

.memo-note-input {
  width: 100%;
  height: 28px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--input-bg);
  color: var(--fg);
  font-size: 12px;
  padding: 0 8px;
  font-family: var(--font-mono);
}

.memo-link {
  color: var(--accent);
  text-decoration: none;
  font-size: 11px;
}

.memo-link:hover {
  text-decoration: underline;
}

.memo-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.settings-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.field-inline {
  grid-column: span 2;
}

.toggle {
  display: flex;
  align-items: center;
  gap: 10px;
}

.toggle input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.toggle-ui {
  width: 54px;
  height: 30px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel) 80%, var(--fg) 5%);
  position: relative;
  cursor: pointer;
  transition: background 0.2s ease;
}

.toggle-ui::after {
  content: "";
  position: absolute;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--card);
  border: 1px solid var(--border);
  left: 4px;
  top: 3px;
  transition: transform 0.2s ease;
}

.toggle input:checked + .toggle-ui {
  background: color-mix(in srgb, var(--accent) 35%, var(--panel));
}

.toggle input:checked + .toggle-ui::after {
  transform: translateX(22px);
}

@keyframes rise {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

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

  .hero {
    flex-direction: column;
    align-items: stretch;
    gap: 16px;
  }

  .hero-links {
    align-items: flex-start;
    text-align: left;
  }

  .panel-dump {
    grid-column: span 1;
    grid-row: span 1;
  }

  .field-row,
  .settings-grid {
    grid-template-columns: 1fr;
  }

  .run-button {
    width: 100%;
  }

}

@media (prefers-reduced-motion: reduce) {
  .panel {
    animation: none;
  }
}

.panel-copyright {
  grid-column: span 2;
  grid-row: span 1;
  font-size: 13px;
  line-height: 1.6;
  color: var(--muted);
}
