/* Character status page — the full-screen Spell appraisal sheet. */

.sheet-mount {
  position: relative;
  z-index: 1;
  max-width: 1020px;
  margin: 34px auto 80px;
  padding: 0 18px;
}

.sheet {
  padding: 30px 34px 34px;
}

/* ---- Head ---- */

.sheet-head { text-align: center; }

.char-name {
  margin: 10px 0 2px;
  font-size: clamp(30px, 5.5vw, 46px);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--frame-bright);
  text-shadow: 0 0 26px var(--glow), 0 0 3px currentColor;
}

.alias-line {
  min-height: 22px;
  font-size: 13px;
  font-style: italic;
  color: var(--dim);
}

.head-divider {
  position: relative;
  height: 1px;
  margin: 18px auto 4px;
  max-width: 420px;
  background: linear-gradient(90deg, transparent, var(--frame-dim) 20%, var(--frame-dim) 80%, transparent);
}
.head-divider::after {
  content: '';
  position: absolute;
  left: 50%;
  top: -3.5px;
  width: 8px;
  height: 8px;
  transform: translateX(-50%) rotate(45deg);
  background: var(--frame-bright);
  box-shadow: 0 0 9px var(--frame-bright);
}

/* ---- Layout ---- */

.sheet-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-top: 22px;
}

.spell-panel.sub {
  margin-top: 18px;
  padding: 18px 20px;
  box-shadow: inset 0 0 34px rgba(0, 0, 0, 0.45), 0 0 12px rgba(0, 0, 0, 0.3);
}
.sheet-grid .spell-panel.sub { margin-top: 0; }

.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 26px;
}

/* ---- Memories ---- */

.mem-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 12px;
}

.mem-card {
  display: block;
  width: 100%;
  padding: 12px 14px;
  text-align: left;
  color: var(--text);
  cursor: pointer;
  font: inherit;
  transition: box-shadow 0.25s ease, transform 0.25s ease;
}
.mem-card:hover, .mem-card:focus-visible {
  box-shadow: 0 0 22px var(--glow), inset 0 0 30px rgba(0, 0, 0, 0.5);
  transform: translateY(-1px);
  outline: none;
}
.mem-name {
  font-family: 'Cinzel', Georgia, serif;
  font-size: 13.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--frame-bright);
}
.mem-rank {
  margin-top: 3px;
  font-size: 11.5px;
  color: var(--dim);
}
.mem-fate-tag {
  margin-top: 6px;
  display: inline-block;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--danger);
  border: 1px solid rgba(198, 83, 83, 0.4);
  padding: 1px 7px;
}
.mem-gone .mem-name { opacity: 0.55; }
.mem-gone .mem-rank { opacity: 0.55; }

.detail-panel .rune-rows { margin-top: 10px; }

/* ---- Evolution scrubber ---- */

.scrubber {
  display: flex;
  gap: 0;
  overflow-x: auto;
  padding: 12px 4px 16px;
  scrollbar-width: thin;
  scrollbar-color: var(--frame-dim) transparent;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent);
}

.tl-node {
  position: relative;
  flex: 0 0 auto;
  width: 130px;
  padding: 26px 10px 0;
  text-align: center;
}
.tl-node::before {
  /* the rail */
  content: '';
  position: absolute;
  top: 15px;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--frame-dim);
}
.tl-node:first-child::before { left: 50%; }
.tl-node:last-child::before { right: 50%; }

.tl-dot {
  position: absolute;
  top: 11px;
  left: 50%;
  width: 9px;
  height: 9px;
  transform: translateX(-50%) rotate(45deg);
  background: var(--frame);
  box-shadow: 0 0 8px var(--glow);
}
.tl-ch {
  font-family: ui-monospace, 'SF Mono', Menlo, monospace;
  font-size: 10px;
  color: var(--dim);
}
.tl-label {
  font-size: 11.5px;
  line-height: 1.35;
  color: var(--text);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* node type tints */
.tl-rank .tl-dot   { background: var(--frame-bright); box-shadow: 0 0 12px var(--frame-bright); }
.tl-class .tl-dot  { background: var(--danger); box-shadow: 0 0 9px rgba(198, 83, 83, 0.6); }
.tl-cores .tl-dot  { background: var(--danger); }
.tl-memory .tl-dot { background: var(--obscure); box-shadow: 0 0 8px var(--obscure); }
.tl-rank .tl-label, .tl-class .tl-label { color: var(--frame-bright); }

.tl-now .tl-dot {
  background: transparent;
  border: 1.5px solid var(--frame-bright);
  animation: now-pulse 2.4s ease-in-out infinite;
}
.tl-now .tl-label {
  color: var(--dim);
  font-style: italic;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
}
@keyframes now-pulse {
  0%, 100% { box-shadow: 0 0 4px var(--glow); }
  50%      { box-shadow: 0 0 14px var(--frame-bright); }
}

/* ---- Feats ---- */

.feat-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.feat-row {
  padding: 9px 2px;
  border-bottom: 1px solid var(--frame-faint);
}
.feat-row:last-child { border-bottom: none; }

.feat-top {
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
}
.feat-ch {
  font-family: ui-monospace, 'SF Mono', Menlo, monospace;
  font-size: 11px;
  color: var(--dim);
  min-width: 52px;
}
.feat-res {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 1px 8px;
  border: 1px solid;
}
.feat-W { color: var(--ok); border-color: rgba(127, 176, 105, 0.45); }
.feat-L { color: var(--danger); border-color: rgba(198, 83, 83, 0.45); }
.feat-S { color: var(--accent); border-color: var(--frame-faint); }
.feat-F { color: var(--obscure); border-color: var(--frame-faint); }

.feat-vs { font-size: 13px; }
.feat-methods {
  font-size: 10.5px;
  font-family: ui-monospace, 'SF Mono', Menlo, monospace;
  color: var(--dim);
}
.feat-note {
  margin-top: 2px;
  padding-left: 62px;
  font-size: 12px;
  color: var(--dim);
}

/* ---- Empty sheet ---- */

.empty-sheet { text-align: center; padding: 60px 30px; }
.empty-text { color: var(--dim); font-style: italic; }

/* ---- Responsive ---- */

@media (max-width: 760px) {
  .sheet { padding: 22px 16px 26px; }
  .sheet-grid { grid-template-columns: 1fr; gap: 14px; }
  .two-col { grid-template-columns: 1fr; }
  .feat-note { padding-left: 0; }
  .site-header { gap: 10px; padding: 10px 14px; }
  .site-title .dim { display: none; }
  #chapterNum { display: none; }
  .chapter-control output { min-width: 0; white-space: nowrap; font-size: 11px; }
}
