@charset "utf-8";

/* =========================================================
   0) Design Tokens
   ========================================================= */
:root{
  --header-h: 60px;
  --footer-h: 40px;
  --sidebar-w: 200px;

  --radius-s: 4px;
  --radius-m: 8px;

  --shadow-1: 0 1px 2px rgba(0,0,0,.06), 0 1px 8px rgba(0,0,0,.04);
  --shadow-2: 0 6px 20px rgba(0,0,0,.10);

  --font-sans: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue",
               Arial, "Noto Sans JP", "Hiragino Kaku Gothic ProN",
               "Yu Gothic UI", "Yu Gothic", "Meiryo", sans-serif;

  --fs-1: 0.875rem;
  --fs-2: 1rem;
  --fs-3: 1.125rem;
  --fs-4: 1.5rem;

  --bg: #f5f6f8;
  --surface: #ffffff;
  --surface-2: #f1f3f5;
  --text: #111317;
  --muted: #5b626a;
  --border: #d8dbe1;

  --accent: #3b82f6;
  --accent-hover: #2563eb;
  --accent-on: #ffffff;

  --header-bg: #1f2937;
  --footer-bg: #1f2937;

  --sidebar-bg: #374151;
  --sidebar-on: #ffffff;

  --table-head-bg: #2b2f36;
  --table-head-on: #ffffff;
  --table-row: #ffffff;
  --table-row-alt: #f0f2f5;

  --dropzone-bg: #fafafa;
  --dropzone-border: #cfd3da;
  --dropzone-hover: #e7eaef;

  --hl-bg: #fff3bf;
  --hl-on: #111317;
  --hl-ring: #f59e0b;

  --control-h: 38px;

  --danger: #ef4444;
  --danger-hover: #dc2626;
  --danger-on: #fff;

  /* Tarot */
  --tarot-card-w: 120px;
}

@media (prefers-color-scheme: dark){
  :root{
    --bg: #0b0f14;
    --surface: #121821;
    --surface-2: #0f141c;
    --text: #e9edf1;
    --muted: #9aa4b2;
    --border: #253141;

    --accent: #60a5fa;
    --accent-hover: #3b82f6;
    --accent-on: #0b0f14;

    --header-bg: #0f172a;
    --footer-bg: #0f172a;
    --sidebar-bg: #111827;
    --sidebar-on: #e5e7eb;

    --table-head-bg: #1d2430;
    --table-head-on: #e9edf1;
    --table-row: #141a24;
    --table-row-alt: #101621;

    --dropzone-bg: #141a24;
    --dropzone-border: #2a3748;
    --dropzone-hover: #1a2130;

    --hl-bg: #1a2f4a;
    --hl-on: #e9edf1;
    --hl-ring: #93c5fd;
  }
}

/* =========================================================
   1) Base / Reset
   ========================================================= */
*{ margin:0; padding:0; box-sizing:border-box; }
html,body{ height:100%; }

body{
  font-family: var(--font-sans);
  background-color: var(--bg);
  color: var(--text);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  color-scheme: light dark;
  accent-color: var(--accent);
}

:focus-visible{
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

/* Scrollbar */
*{
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}
*::-webkit-scrollbar{ width:10px; height:10px; }
*::-webkit-scrollbar-thumb{ background: var(--border); border-radius: 10px; }
*::-webkit-scrollbar-track{ background: transparent; }

/* =========================================================
   2) Header / Footer
   ========================================================= */
header{
  background-color: var(--header-bg);
  color:#fff;
  text-align:center;
  padding: 0 1rem;
  position: fixed;
  inset-block-start: 0;
  inset-inline: 0;
  height: var(--header-h);
  z-index: 1000;
  display: grid;
  align-items: center;
  box-shadow: var(--shadow-1);
}

header h1{ font-size: var(--fs-4); line-height: 1.2; }
header h3{ font-size: var(--fs-2); font-weight: 500; opacity: .9; }

.menu-toggle,
.theme-toggle{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border: none;
  padding: .5rem .75rem;
  border-radius: var(--radius-s);
  font-size: var(--fs-2);
  cursor: pointer;
  z-index: 1000;
  transition: background-color .2s ease, color .2s ease, opacity .2s ease;
}

.menu-toggle{
  left: 1rem;
  background: transparent;
  color: #fff;
}
.menu-toggle:hover{ opacity: .85; }

.theme-toggle{
  right: 1rem;
  background-color: rgba(255,255,255,.12);
  color:#fff;
}
.theme-toggle:hover{ background-color: rgba(255,255,255,.2); }

footer{
  background-color: var(--footer-bg);
  color:#fff;
  text-align:center;
  padding: .75rem 1rem;
  position: fixed;
  inset-block-end: 0;
  inset-inline: 0;
  height: var(--footer-h);
  z-index: 1000;
  display: grid;
  align-items: center;
  box-shadow: var(--shadow-1);
}

/* =========================================================
   3) Shell Layout
   ========================================================= */
.container{
  display:flex;
  flex-direction: column;
  min-height: 100dvh;
  padding-block-start: var(--header-h);
  padding-block-end: var(--footer-h);
}

.main-content{
  display:flex;
  flex: 1 1 auto;
  overflow: hidden;
}

/* Sidebar */
.sidebar{
  background-color: var(--sidebar-bg);
  color: var(--sidebar-on);
  width: var(--sidebar-w);
  position: fixed;
  top: var(--header-h);
  bottom: var(--footer-h);
  left: 0;
  z-index: 999;
  padding: 10px;
  overflow-y: auto;
  transform: translateX(0);
  transition: transform .25s ease, box-shadow .25s ease;
  box-shadow: var(--shadow-1);
}
.sidebar.collapsed{ transform: translateX(-100%); }

.sidebar .tablinks{
  display:block;
  width:100%;
  background: transparent;
  color: var(--sidebar-on);
  border: 1px solid transparent;
  padding: .6rem .75rem;
  text-align:left;
  cursor:pointer;
  margin-bottom: 6px;
  border-radius: var(--radius-s);
  font-size: var(--fs-2);
  transition: background-color .15s ease, border-color .15s ease;
}
.sidebar .tablinks:hover{ background-color: rgba(255,255,255,.08); }
.sidebar .tablinks.active{
  background-color: #e5e7eb;
  color:#111;
  border-color:#cfd3da;
}

/* Content */
.content{
  flex: 1 1 auto;
  background-color: var(--surface);
  color: var(--text);
  margin-left: var(--sidebar-w);
  padding: 20px;
  overflow-y: auto;
  border-radius: var(--radius-m);
  box-shadow: var(--shadow-2);
  transition: margin-left .25s ease, background-color .2s ease, color .2s ease, box-shadow .2s ease;
  height: calc(100dvh - var(--header-h) - var(--footer-h));
}
.content.collapsed{ margin-left: 0; }

.tabcontent{ display:none; }
.tabcontent.is-active{ display:block; }

/* Iframes / game zones */
#Clicker,
#Maze,
#mazeContainer{
  position: relative;
  width:100%;
  height:100%;
  display:block;
}
.gameFrame,
#mazeIframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:none;
}

/* =========================================================
   4) Common Components
   ========================================================= */
/* Drop Zone */
#dropZone{
  border: 2px dashed var(--dropzone-border);
  padding: 20px;
  text-align:center;
  background-color: var(--dropzone-bg);
  margin-bottom: 20px;
  border-radius: var(--radius-m);
  transition: background-color .2s ease, border-color .2s ease;
  color: var(--muted);
}
#dropZone.dragover{ background-color: var(--dropzone-hover); }

/* Buttons */
.button,
.close-button,
.deleteButton{
  display:inline-block;
  border:none;
  border-radius: var(--radius-s);
  padding: .6rem 1rem;
  font-size: var(--fs-2);
  cursor:pointer;
  transition: background-color .15s ease, transform .05s ease;
  user-select:none;
}

.button{
  background-color: var(--accent);
  color: var(--accent-on);
}
.button:hover{ background-color: var(--accent-hover); }
.button:active{ transform: translateY(1px); }

.close-button{
  width:100%;
  background-color: var(--header-bg);
  color:#fff;
}
.close-button:hover{ background-color: #2b3a53; }

.deleteButton{
  background-color: var(--danger);
  color: var(--danger-on);
  width: 28px;
  height: 28px;
  cursor:pointer;
  margin-left: 10px;
}
.deleteButton:hover{ background-color: var(--danger-hover); }

/* Forms */
.FormGroup{
  margin-bottom: 12px;
  display:flex;
  align-items:center;
  gap: 10px;
}
.FormGroup label{
  min-width: 60px;
  color: var(--muted);
  font-size: var(--fs-1);
}
.FormGroup input{
  padding: 6px 8px;
  border: 1px solid var(--border);
  border-radius: var(--radius-s);
  background-color: var(--surface-2);
  color: var(--text);
}

#skills .FormGroup{
  margin-bottom: 6px;
  color: var(--sidebar-on);
}

.skillValue{ width:110px; }

.skills-group{ display:flex; flex-direction: column; gap:6px; }
.skills-group .FormGroup{ margin-bottom: 0; }
.skills-group label{ width:auto; margin-right: 10px; }

.skillSet,
.damageSet{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom: 10px;
  width:100%;
}
.skillSet input,
.damageSet input{
  padding: 6px 8px;
  border: 1px solid var(--border);
  border-radius: var(--radius-s);
  background-color: var(--surface-2);
  color: var(--text);
}

/* History / Results containers */
#historyContainer,
#detailedResultsContainer{
  margin-top: 20px;
  border: 1px solid var(--border);
  padding: 10px;
  background-color: var(--surface);
  border-radius: var(--radius-m);
  box-shadow: var(--shadow-1);
}
#historyContainer{
  max-height: 300px;
  overflow-y:auto;
}

.history-item{
  border: 1px solid var(--border);
  padding: 10px;
  margin-bottom: 10px;
  border-radius: var(--radius-m);
  background-color: var(--surface);
  box-shadow: var(--shadow-1);
}
.history-item h4{ margin-bottom: 6px; color: var(--text); }

/* Collapsible character panels */
.character-container{
  margin-bottom: 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius-s);
  overflow:hidden;
  background: var(--surface);
}
.character-header{
  background-color: var(--surface-2);
  padding: 10px;
  cursor:pointer;
  font-weight: 700;
  color: var(--text);
}
.character-content{
  padding: 10px;
  background-color: var(--surface);
  border-top: 1px solid var(--border);
}

/* Table */
table{
  width:100%;
  border-collapse: collapse;
  margin-top: 14px;
  background-color: var(--surface);
  border-radius: var(--radius-m);
  overflow:hidden;
  box-shadow: var(--shadow-1);
}
th,td{
  border: 1px solid var(--border);
  padding: 10px;
}
th{
  background-color: var(--table-head-bg);
  color: var(--table-head-on);
  text-align:left;
  font-weight: 700;
}
td{
  background-color: var(--table-row);
  color: var(--text);
  text-align:center;
}
tr:nth-child(even) td{ background-color: var(--table-row-alt); }

/* Highlight cells */
td.highlight{
  position: relative;
  background-color: var(--hl-bg) !important;
  color: var(--hl-on);
  font-weight: 700;
  border-radius: 6px;
  box-shadow:
    inset 0 0 0 2px var(--hl-ring),
    0 1px 0 rgba(0,0,0,.06);
  transition: filter .15s ease, box-shadow .15s ease, background-color .15s ease;
}
tr:nth-child(even) td.highlight{ background-color: var(--hl-bg) !important; }
.history-item td.highlight,
.character-content td.highlight{ background-color: var(--hl-bg) !important; }

td.highlight:hover{ filter: brightness(1.04); }

@media (forced-colors: active){
  td.highlight{
    outline: 2px solid Highlight;
    outline-offset: -2px;
    box-shadow:none;
  }
}
@media (prefers-contrast: more){
  td.highlight{ box-shadow: inset 0 0 0 3px var(--hl-ring); }
}

.history-item table{ margin-top: 10px; box-shadow:none; }
.history-item th{ background-color: var(--table-head-bg); }
.history-item tr:nth-child(even) td{ background-color: var(--table-row-alt); }

/* =========================================================
   5) Responsive / Motion
   ========================================================= */
@media (max-width: 768px){
  .sidebar{
    position: fixed;
    transform: translateX(-100%);
    box-shadow: var(--shadow-2);
  }
  .sidebar.collapsed{ transform: translateX(0); }
  .content{
    margin-left: 0;
    padding: 14px;
    border-radius: 0;
    height: calc(100dvh - var(--header-h) - var(--footer-h));
  }
}

@media (prefers-reduced-motion: reduce){
  *{ transition:none !important; animation:none !important; }
}

/* =========================================================
   6) DataViewer 視認性UP
   ========================================================= */
.dv-toolbar{
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
  align-items:center;
  margin: 10px 0 12px;
}
.dv-toolbar input[type="search"]{
  flex: 1 1 320px;
  min-width: 240px;
  height: var(--control-h);
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius-s);
  background: var(--surface-2);
  color: var(--text);
}
.dv-toolbar select{
  height: var(--control-h);
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius-s);
  background: var(--surface-2);
  color: var(--text);
}

/* Growth：技能チップ */
.dv-chiplist{
  display:flex;
  flex-wrap:wrap;
  gap: 6px;
}
.dv-chip{
  padding: 2px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--surface-2);
  color: var(--text);
  font-size: var(--fs-1);
  line-height: 1.8;
  white-space: nowrap;
}

/* TFNum：中身だけスクロール */
.character-content{
  max-height: 62vh;
  overflow:auto;
}

/* DataViewer専用 table tuning */
table.data-table td.skill{ text-align:left; }
table.data-table td.num,
table.data-table td.rate{
  text-align:right;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
table.data-table tr:hover td{ filter: brightness(1.06); }
table.data-table th{
  position: sticky;
  top: 0;
  z-index: 2;
}

/* Toast */
.dv-toast-root{
  position: fixed;
  top: calc(var(--header-h) + 10px);
  right: 12px;
  display:grid;
  gap: 8px;
  z-index: 2000;
  pointer-events:none;
}
.dv-toast{
  pointer-events:none;
  padding: 10px 12px;
  border-radius: var(--radius-m);
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  box-shadow: var(--shadow-2);
  opacity: 0;
  transform: translateY(-6px);
  animation: dvToastIn .18s ease forwards;
  max-width: min(380px, calc(100vw - 24px));
}
.dv-toast.is-leaving{ animation: dvToastOut .25s ease forwards; }
@keyframes dvToastIn{ to{ opacity:1; transform: translateY(0); } }
@keyframes dvToastOut{ to{ opacity:0; transform: translateY(-6px); } }

.dv-growth-header{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
}
.dv-growth-hint{
  font-size: var(--fs-1);
  color: var(--muted);
  opacity: .9;
  white-space: nowrap;
}
.dv-growth-header:hover .dv-growth-hint{ opacity: 1; }

/* =========================================================
   7) Tarot
   ========================================================= */
#Tarot .tarot-board{
  display:grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(var(--tarot-card-w), 1fr));
  justify-items:center;
  align-items:start;
}
#Tarot .tarot-slot{
  width:100%;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-m);
  padding: 10px;
  box-shadow: var(--shadow-1);
}
#Tarot .tarot-slot h4{
  font-size: var(--fs-2);
  margin-bottom: 8px;
  color: var(--muted);
}
#Tarot .tarot-card{
  width: var(--tarot-card-w);
  aspect-ratio: 5 / 8;
  perspective: 1000px;
  border-radius: 14px;
  box-shadow: var(--shadow-2);
  position: relative;
  cursor: pointer;
  transition: transform .15s ease, filter .15s ease;
}
#Tarot .tarot-card:hover{ transform: translateY(-1px); filter: brightness(1.02); }

#Tarot .tarot-card-inner{
  position: relative;
  width:100%;
  height:100%;
  transform-style: preserve-3d;
  transition: transform .6s ease;
  border-radius: 14px;
}
#Tarot .tarot-card.is-flipped .tarot-card-inner{ transform: rotateY(180deg); }

#Tarot .tarot-face{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  backface-visibility:hidden;
  border-radius: 14px;
  overflow:hidden;
  border: 1px solid var(--border);
  background: var(--surface-2);
}
#Tarot .tarot-face.front{ transform: rotateY(180deg); }

#Tarot .tarot-pill{
  position:absolute;
  top: 6px;
  left: 6px;
  font-size: .75rem;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--surface);
  color: var(--muted);
  border: 1px solid var(--border);
  display:none;
}

#Tarot .tarot-card svg{ width:96%; height:96%; }

#Tarot .reading-block{
  border: 1px solid var(--border);
  border-radius: var(--radius-m);
  padding: 12px;
  background: var(--surface);
  box-shadow: var(--shadow-1);
  margin-bottom: 10px;
}
#Tarot .reading-block h4{ margin-bottom: 6px; }
#Tarot .reading-block .meta{ color: var(--muted); font-size: var(--fs-1); margin-bottom: 4px; }
#Tarot .reading-block p{ margin: 4px 0; }

/* =========================================================
   8-b) CharCreater Redesign (compact grid — one‐screen)
   ========================================================= */

#CharCreater .cc-panel-top{ padding: 12px 16px; }

#CharCreater .cc-title{
  font-size: var(--fs-3);
  font-weight: 800;
  margin-bottom: 8px;
}

/* --- Mode row (single line) --- */
#CharCreater .cc-mode-row{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 16px;
  margin-bottom: 6px;
}

#CharCreater .cc-mode-fieldset{
  border: 1px solid var(--border);
  border-radius: var(--radius-s);
  padding: 2px 8px 4px;
  display: flex;
  gap: 2px;
  margin: 0;
}
#CharCreater .cc-legend{
  font-size: .7rem;
  color: var(--muted);
  padding: 0 4px;
  font-weight: 600;
}
#CharCreater .cc-mode-option{
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 2px 8px;
  border-radius: var(--radius-s);
  cursor: pointer;
  font-size: .8rem;
  user-select: none;
  transition: background-color .12s ease;
}
#CharCreater .cc-mode-option:hover{ background: rgba(255,255,255,.06); }
#CharCreater .cc-mode-option:has(input:checked){
  background: color-mix(in srgb, var(--accent) 18%, transparent);
}

/* --- Stage --- */
#CharCreater .cc-stage-wrap{ display: flex; align-items: center; gap: 6px; }
#CharCreater .cc-stage-label{
  font-size: .8rem; color: var(--muted); font-weight: 600; white-space: nowrap;
}
#CharCreater .cc-stage-select{
  height: 32px; min-width: 120px; padding: 4px 8px;
  border: 1px solid var(--border); border-radius: var(--radius-s);
  background: var(--surface-2); color: var(--text); font-size: .8rem;
}

/* --- Reroll badge --- */
#CharCreater .cc-reroll-badge{
  margin-left: auto;
  padding: 2px 10px; border-radius: 999px;
  border: 1px solid var(--border); background: var(--surface-2);
  color: var(--muted); font-size: .75rem; font-weight: 600;
  font-variant-numeric: tabular-nums; white-space: nowrap;
}

/* --- Action buttons --- */
#CharCreater .cc-actions-row{
  display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 4px;
}
#CharCreater .cc-actions-row .button{
  padding: .4rem .8rem; font-size: .85rem;
}
#CharCreater .cc-btn-primary{ background: var(--accent); color: var(--accent-on); }
#CharCreater .cc-btn-primary:hover{ background: var(--accent-hover); }

#CharCreater .cc-btn-secondary{
  background: var(--surface-2); color: var(--text); border: 1px solid var(--border);
}
#CharCreater .cc-btn-secondary:hover{ border-color: var(--accent); }
#CharCreater .cc-btn-secondary.cc-swap-active{
  background: color-mix(in srgb, var(--accent) 20%, var(--surface));
  border-color: var(--accent); color: var(--accent); font-weight: 700;
}

#CharCreater .cc-btn-confirm{ background: #059669; color: #fff; }
#CharCreater .cc-btn-confirm:hover{ background: #047857; }
#CharCreater .cc-btn-danger{ background: var(--danger); color: var(--danger-on); }
#CharCreater .cc-btn-danger:hover{ background: var(--danger-hover); }

/* --- Notes --- */
#CharCreater .cc-notes{
  display: flex; flex-wrap: wrap; gap: 2px 14px;
  font-size: .7rem; color: var(--muted); line-height: 1.4;
}
#CharCreater .cc-notes span::before{
  content: "●"; margin-right: 3px; opacity: .4;
}

/* =========================================================
   Stat grid — 5列固定で 5+3 = 全8枠を一画面に
   ========================================================= */
#CharCreater .cc-stat-grid{
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  margin-top: 8px;
}

/* --- Stat card: compact --- */
#CharCreater .cc-stat-card{
  position: relative;
  border: 1px solid var(--border);
  border-radius: var(--radius-s);
  background: var(--surface-2);
  padding: 8px 10px 8px 14px;
  transition: border-color .15s ease, box-shadow .15s ease;
  overflow: hidden;
  min-width: 0;
}

/* Group color stripe */
#CharCreater .cc-stat-card::before{
  content: "";
  position: absolute; top: 0; left: 0;
  width: px; height: 100%;
  border-radius: var(--radius-s) 0 0 var(--radius-s);
}
#CharCreater .cc-stat-card.cc-group-a::before{ background: var(--accent); }
#CharCreater .cc-stat-card.cc-group-b::before{ background: #f59e0b; }

#CharCreater .cc-stat-card:hover{
  border-color: color-mix(in srgb, var(--accent) 40%, var(--border));
}

/* Slotting glow */
#CharCreater .cc-stat-card.slotting{
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent), 0 0 10px color-mix(in srgb, var(--accent) 20%, transparent);
  animation: cc-pulse .9s ease infinite alternate;
}
@keyframes cc-pulse{
  from{ box-shadow: 0 0 0 1px var(--accent), 0 0 6px color-mix(in srgb, var(--accent) 12%, transparent); }
  to  { box-shadow: 0 0 0 1px var(--accent), 0 0 14px color-mix(in srgb, var(--accent) 30%, transparent); }
}

/* Swap */
#CharCreater .swap-mode-on .cc-stat-card{ cursor: pointer; }
#CharCreater .cc-stat-card.swap-picked{
  outline: 2px solid var(--accent); outline-offset: 1px;
}

/* --- stat-head: name + value --- */
#CharCreater .cc-stat-card .stat-head{
  display: flex; align-items: center;
  justify-content: space-between; gap: 4px; margin-bottom: 2px;
}
#CharCreater .cc-stat-id{
  display: flex; align-items: baseline; gap: 4px; min-width: 0;
}
#CharCreater .cc-stat-card .stat-name{
  font-size: .95rem; font-weight: 800; letter-spacing: .5px;
}
#CharCreater .cc-stat-card .stat-dice-label{
  font-size: .6rem; color: var(--muted);
}
#CharCreater .cc-stat-input{
  width: 48px; padding: 2px 4px;
  border: 1px solid var(--border); border-radius: var(--radius-s);
  background: var(--surface); color: var(--text);
  text-align: right; font-weight: 800; font-size: .95rem;
  font-variant-numeric: tabular-nums;
}

/* --- Dice visual: tiny --- */
#CharCreater .cc-dice-visual{
  display: flex; align-items: center; gap: 3px;
  min-height: 22px; margin-bottom: 2px;
}
#CharCreater .cc-dice-visual .die{
  width: 20px; height: 20px; font-size: .7rem;
}
#CharCreater .cc-dice-visual .plus-badge{
  font-size: .6rem; padding: 1px 3px;
}

/* --- Footer: button + breakdown --- */
#CharCreater .cc-stat-footer{
  display: flex; align-items: center; gap: 4px; flex-wrap: nowrap;
}
#CharCreater .cc-btn-roll{
  font-size: .85rem; padding: .6rem .5rem; white-space: nowrap; flex-shrink: 0;
}
#CharCreater .cc-breakdown{
  font-size: .9rem; color: var(--muted); line-height: 1.2;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  min-width: 0;
}

/* --- Totals --- */
#CharCreater .cc-totals{
  margin: 8px 0; padding: 6px 12px;
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--radius-s);
  font-weight: 700; font-size: .9rem;
  font-variant-numeric: tabular-nums; color: var(--text); text-align: center;
}

/* --- いあきゃら --- */
#CharCreater .cc-ia-panel{
  display: flex; justify-content: center; padding: 8px;
}
#CharCreater .cc-btn-ia{
  background: linear-gradient(135deg, #6366f1, #8b5cf6);
  color: #fff; padding: .4rem 1.4rem; font-size: .85rem;
  font-weight: 700; border-radius: var(--radius-m);
  transition: opacity .15s ease;
}
#CharCreater .cc-btn-ia:hover:not(:disabled){ opacity: .9; }
#CharCreater .cc-btn-ia:disabled{
  background: var(--surface-2); color: var(--muted);
  border: 1px solid var(--border); cursor: not-allowed;
}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 900px){
  #CharCreater .cc-stat-grid{ grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 640px){
  #CharCreater .cc-stat-grid{ grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 420px){
  #CharCreater .cc-stat-grid{ grid-template-columns: repeat(2, 1fr); }
  #CharCreater .cc-mode-row{ flex-direction: column; align-items: stretch; }
  #CharCreater .cc-reroll-badge{ margin-left: 0; text-align: center; }
}

/* =========================================================
   9) NPCCreater (Layout + UI polish, preserve behavior)
   ========================================================= */
#NPCCreater{
  max-width: 1100px;
  margin: 0 auto;
  overflow-x: clip;

  /* ability grid tuning */
  --ab-lb: 44px;
  --ab-in: clamp(68px, 9vw, 96px);
}

#NPCCreater form{
  display:grid;
  gap: 14px;
}

/* FormGroup: narrow friendly */
#NPCCreater .FormGroup{
  flex-wrap: wrap;
  align-items:center;
  gap: 8px 10px;
}
#NPCCreater .FormGroup label{
  min-width: unset;
  white-space: nowrap;
}

/* shrink-friendly controls */
#NPCCreater input,
#NPCCreater select,
#NPCCreater button{
  min-width: 0;
  max-width: 100%;
}

#NPCCreater input[type="text"]{
  flex: 1 1 260px;
  min-width: 180px;
}
#NPCCreater input[type="number"]{
  width: 92px;
}

/* ---------- Job controls: pair layout (final) ---------- */
#NPCCreater #jobControls{
  display: grid;
  grid-template-columns: max-content minmax(240px, 1fr) max-content minmax(240px, 1fr);
  grid-template-areas:
    "catL catS jobL jobS"
    "btn1 btn1 btn2 btn2";
  gap: 10px 12px;
  align-items: center;
  justify-content: start;
}
#NPCCreater #jobControls select{
  width: 100%;
  min-width: 0;
  height: var(--control-h);
  padding: 6px 8px;
  border: 1px solid var(--border);
  border-radius: var(--radius-s);
  background: var(--surface-2);
  color: var(--text);
}

#NPCCreater #jobControls label[for="jobCategory"],
#NPCCreater #jobControls .cat-label{ grid-area: catL; }
#NPCCreater #jobControls #jobCategory{ grid-area: catS; }

#NPCCreater #jobControls label[for="jobSelect"],
#NPCCreater #jobControls .job-label{ grid-area: jobL; }
#NPCCreater #jobControls #jobSelect{ grid-area: jobS; }

#NPCCreater #jobControls .button:nth-of-type(1){ grid-area: btn1; }
#NPCCreater #jobControls .button:nth-of-type(2){ grid-area: btn2; }
#NPCCreater #jobControls .button{
  height: var(--control-h);
  width: 100%;
  white-space: nowrap;
}

/* narrow: stack */
@media (max-width: 980px){
  #NPCCreater #jobControls{
    grid-template-columns: 1fr;
    grid-template-areas:
      "catL"
      "catS"
      "jobL"
      "jobS"
      "btn1"
      "btn2";
  }
}

/* Panels */
#NPCCreater #choosePanel,
#NPCCreater #emphasisPanel{
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-s);
  padding: 10px;
  margin: 8px 0;
}
#NPCCreater #choosePanel .hint{
  color: var(--muted);
  font-size: var(--fs-1);
}
#NPCCreater .emphasis-list{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 6px 12px;
}
#NPCCreater #jobSkillsContainer .skillName[readonly]{
  opacity: .9;
  background: var(--surface-2);
}

/* ---------- Checkbox: no mismatch (final) ---------- */
#NPCCreater label:has(> input[type="checkbox"]){
  position: relative;
  display: inline-flex;
  align-items:center;
  gap: 8px;
  padding: 6px 12px 6px 38px;
  min-height: 34px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--surface-2);
  cursor:pointer;
  user-select:none;
  line-height: 1;
}

#NPCCreater label:has(> input[type="checkbox"]) > input[type="checkbox"]{
  position:absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  opacity: 0;
  margin: 0;
}

#NPCCreater label:has(> input[type="checkbox"])::before{
  content:"";
  position:absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  border-radius: 4px;
  border: 1px solid var(--border);
  background: var(--surface);
}

#NPCCreater label:has(> input[type="checkbox"])::after{
  content:"";
  position:absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%) scale(0);
  width: 10px;
  height: 10px;
  border-radius: 2px;
  background: var(--accent);
  transition: transform .12s ease;
}

#NPCCreater label:has(> input[type="checkbox"]:checked){
  border-color: var(--accent);
  box-shadow: inset 0 0 0 1px var(--accent);
}
#NPCCreater label:has(> input[type="checkbox"]:checked)::after{
  transform: translateY(-50%) scale(1);
}
#NPCCreater label:has(> input[type="checkbox"]:focus-visible){
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

/* ---------- skillSet: grid (final) ---------- */
#NPCCreater .skillSet{
  display:grid;
  grid-template-columns: 70px minmax(180px, 1fr) 92px 32px;
  gap: 8px;
  align-items:center;
}
#NPCCreater .skillSet input{ width:100%; }
#NPCCreater .skillSet .deleteButton{
  width: 32px;
  height: 32px;
  margin-left: 0;
}
@media (max-width: 560px){
  #NPCCreater .skillSet{ grid-template-columns: 1fr 92px 32px; }
  #NPCCreater .skillSet > :first-child{ grid-column: 1 / -1; }
}

/* ---------- Ability layout: stable (final) ---------- */
#NPCCreater .FormGroup:has(#hp):has(#mp):has(#san){
  display:grid;
  grid-template-columns: repeat(3, var(--ab-lb) var(--ab-in));
  justify-content: start;
  gap: 8px 10px;
  align-items:center;
}
#NPCCreater .FormGroup:has(#hp):has(#mp):has(#san) label{
  width: var(--ab-lb);
  justify-self:end;
  white-space: nowrap;
}

#NPCCreater .FormGroup:has(#str):has(#con):has(#pow):has(#dex):has(#app):has(#siz):has(#int):has(#edu){
  display:grid;
  grid-template-columns: repeat(5, var(--ab-lb) var(--ab-in));
  justify-content: start;
  gap: 8px 10px;
  align-items:center;
}
#NPCCreater .FormGroup:has(#str) label{
  width: var(--ab-lb);
  justify-self:end;
  white-space: nowrap;
}

#NPCCreater .FormGroup:has(#hp) input[type="number"],
#NPCCreater .FormGroup:has(#str) input[type="number"]{
  width: 100%;
  min-width: 0;
}

/* =========================================================
   10) NPC Modal / Popup (alert/confirm replacement)
   ========================================================= */
.npc-modal-overlay{
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: grid;
  place-items: center;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  opacity: 0;
  transition: opacity .18s ease;
}
.npc-modal-overlay.is-visible{ opacity: 1; }

.npc-modal{
  width: min(420px, calc(100vw - 32px));
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-m);
  box-shadow: 0 12px 40px rgba(0,0,0,.25);
  padding: 20px 24px;
  transform: translateY(10px) scale(.97);
  transition: transform .2s ease;
}
.npc-modal-overlay.is-visible .npc-modal{
  transform: translateY(0) scale(1);
}

.npc-modal-title{
  font-size: var(--fs-3);
  font-weight: 700;
  margin-bottom: 8px;
  color: var(--text);
}

.npc-modal-body{
  color: var(--text);
  line-height: 1.65;
  margin-bottom: 18px;
  white-space: pre-wrap;
}

.npc-modal-actions{
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.npc-modal-ok{
  background: var(--accent);
  color: var(--accent-on);
  min-width: 80px;
}
.npc-modal-ok:hover{ background: var(--accent-hover); }

.npc-modal-cancel{
  background: var(--surface-2);
  color: var(--muted);
  border: 1px solid var(--border);
}
.npc-modal-cancel:hover{
  background: var(--border);
  color: var(--text);
}

/* =========================================================
   11) NPC Command Toggle Panel
   ========================================================= */
.npc-cmd-panel{
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-m);
  padding: 14px 16px;
  margin: 16px 0;
}

.npc-cmd-panel-title{
  font-size: var(--fs-2);
  font-weight: 700;
  margin-bottom: 2px;
  color: var(--text);
}

.npc-cmd-panel-desc{
  font-size: var(--fs-1);
  color: var(--muted);
  margin-bottom: 12px;
}

.npc-cmd-toggles{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 8px;
}

/* --- Custom toggle switch --- */
.npc-toggle-label{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-s);
  background: var(--surface);
  cursor: pointer;
  transition: border-color .15s ease, background-color .15s ease;
  user-select: none;
}
.npc-toggle-label:hover{
  border-color: var(--accent);
}

/* Hide real checkbox */
.npc-toggle-label > input[type="checkbox"]{
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}

/* Track */
.npc-toggle-track{
  position: relative;
  flex-shrink: 0;
  width: 38px;
  height: 22px;
  border-radius: 999px;
  background: var(--border);
  transition: background-color .2s ease;
}

/* Thumb */
.npc-toggle-thumb{
  position: absolute;
  top: 3px;
  left: 3px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.2);
  transition: transform .2s ease;
}

/* Checked state */
.npc-toggle-label > input:checked + .npc-toggle-track{
  background: var(--accent);
}
.npc-toggle-label > input:checked + .npc-toggle-track .npc-toggle-thumb{
  transform: translateX(16px);
}

/* Focus ring */
.npc-toggle-label > input:focus-visible + .npc-toggle-track{
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

/* Text */
.npc-toggle-text{
  display: flex;
  flex-direction: column;
  gap: 1px;
  min-width: 0;
}
.npc-toggle-text strong{
  font-size: var(--fs-1);
  color: var(--text);
  line-height: 1.3;
}
.npc-toggle-text small{
  font-size: .75rem;
  color: var(--muted);
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Unchecked → dim the text */
.npc-toggle-label:has(> input:not(:checked)) .npc-toggle-text strong{
  opacity: .5;
}
.npc-toggle-label:has(> input:not(:checked)) .npc-toggle-text small{
  opacity: .4;
}

.button.is-danger{ background: var(--danger); color: var(--danger-on); }
.button.is-danger:hover{ background: var(--danger-hover); }

#jobControls [hidden] { display: none !important; }

.gas-embed-wrap{
  margin-top: 10px;
  width: 100%;
  height: min(78vh, 900px); /* とりあえずいい感じの高さ */
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  overflow: hidden;
  background: rgba(0,0,0,.08);
}

.gas-embed{
  width: 100%;
  height: 100%;
  border: 0;
  background: transparent;
}

/* ---------- Loaded-files badge bar ---------- */
.dv-loaded-files{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin-bottom: 12px;
  min-height: 0;            /* 空のとき潰れる */
}
.dv-loaded-files:empty{ display: none; }

.dv-loaded-label{
  font-weight: 700;
  font-size: var(--fs-1);
  color: var(--muted);
  white-space: nowrap;
}

.dv-badge{
  display: inline-block;
  padding: 2px 10px;
  border-radius: 999px;
  border: 1px solid var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, var(--surface));
  color: var(--accent);
  font-size: var(--fs-1);
  font-weight: 600;
  line-height: 1.6;
  white-space: nowrap;
}

.dv-reset-btn{
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-left: 4px;
  padding: 2px 10px;
  border: 1px solid var(--danger);
  border-radius: 999px;
  background: transparent;
  color: var(--danger);
  font-size: var(--fs-1);
  font-weight: 600;
  cursor: pointer;
  transition: background-color .15s ease, color .15s ease;
}
.dv-reset-btn:hover{
  background: var(--danger);
  color: var(--danger-on);
}