@import url("https://fonts.googleapis.com/css2?family=Cinzel:wght@600;700;800;900&family=IM+Fell+English+SC&family=Alegreya+Sans:wght@400;500;700;800;900&display=swap");

:root {
  color-scheme: dark;
  --bg: oklch(8.8% 0.018 25);
  --panel: oklch(13.5% 0.02 24);
  --panel-2: oklch(17% 0.022 25);
  --ink: oklch(92% 0.018 38);
  --muted: oklch(72% 0.026 37);
  --faint: oklch(56% 0.029 34);
  --line: oklch(27% 0.033 24);
  --line-soft: oklch(21.5% 0.025 25);
  --blood: oklch(44% 0.18 24);
  --blood-bright: oklch(58% 0.2 24);
  --red-dim: oklch(25% 0.095 24);
  --gold: oklch(63% 0.18 25);
  --green: oklch(66% 0.1 145);
}

* {
  box-sizing: border-box;
}

html {
  background: var(--bg);
}

body {
  min-width: 320px;
  margin: 0;
  color: var(--ink);
  background:
    radial-gradient(circle at 18% -12%, color-mix(in oklch, var(--blood) 28%, transparent), transparent 36%),
    linear-gradient(180deg, oklch(12% 0.026 23), var(--bg) 300px),
    var(--bg);
  font-family:
    "Alegreya Sans", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    sans-serif;
  font-size: 16px;
  line-height: 1.45;
}

button,
input,
select {
  font: inherit;
}

button {
  cursor: pointer;
}

button:disabled {
  cursor: not-allowed;
  opacity: 0.55;
}

.app-shell {
  width: min(100% - 32px, 1440px);
  margin: 0 auto;
  padding: 22px 0 36px;
}

.topbar,
.control-panel,
.library-panel {
  border: 1px solid var(--line);
  background: color-mix(in oklch, var(--panel) 88%, transparent);
  border-radius: 6px;
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 24px;
}

.kicker {
  margin: 0 0 4px;
  color: var(--blood-bright);
  font-size: 0.74rem;
  font-weight: 850;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

h1,
h2,
h3,
h4,
p {
  margin-top: 0;
}

h1 {
  margin-bottom: 6px;
  font-family: "Cinzel", "IM Fell English SC", Georgia, serif;
  font-size: 2.15rem;
  font-weight: 900;
  font-variant-caps: small-caps;
  line-height: 1.05;
  letter-spacing: 0;
  text-transform: uppercase;
}

h2 {
  margin-bottom: 0;
  font-size: 1.1rem;
}

.subtitle {
  margin-bottom: 0;
  color: var(--muted);
  font-style: italic;
  max-width: 64ch;
}

.top-actions,
.profile-grid,
.quick-profiles,
.discipline-focus-list,
.power-toggle-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.top-actions {
  justify-content: flex-end;
}

main {
  display: grid;
  gap: 16px;
  margin-top: 16px;
}

.panel-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px;
  border-bottom: 1px solid var(--line-soft);
}

.control-panel,
.library-panel {
  overflow: hidden;
}

.profile-grid {
  display: grid;
  grid-template-columns: minmax(220px, 0.8fr) minmax(260px, 1.2fr) auto auto auto;
  align-items: end;
  padding: 16px 18px 12px;
}

.field {
  display: grid;
  gap: 6px;
}

label,
.field label {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 750;
}

input,
select {
  width: 100%;
  min-height: 42px;
  padding: 9px 11px;
  color: var(--ink);
  background: oklch(10% 0.012 30);
  border: 1px solid var(--line);
  border-radius: 4px;
  outline: none;
}

input:focus,
select:focus {
  border-color: var(--blood-bright);
  box-shadow: 0 0 0 2px color-mix(in oklch, var(--blood-bright) 25%, transparent);
}

#importInput {
  display: none;
}

.primary-button,
.secondary-button,
.ghost-button,
.danger-button,
.file-label {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 9px 13px;
  color: var(--ink);
  border: 1px solid transparent;
  border-radius: 4px;
  font-weight: 800;
  text-decoration: none;
}

.primary-button {
  background: var(--blood);
}

.primary-button:hover {
  background: var(--blood-bright);
}

.secondary-button {
  background: var(--panel-2);
  border-color: var(--line);
}

.ghost-button,
.file-label {
  background: transparent;
  border-color: var(--line);
}

.danger-button {
  background: color-mix(in oklch, var(--blood) 34%, transparent);
  border-color: color-mix(in oklch, var(--blood-bright) 66%, transparent);
}

.compact-button {
  min-height: 34px;
  padding: 7px 10px;
  font-size: 0.78rem;
}

.save-status {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 750;
}

.save-status.active {
  color: var(--green);
}

.quick-profiles {
  padding: 0 18px 18px;
}

.profile-chip,
.discipline-choice,
.power-toggle {
  min-height: 36px;
  color: var(--muted);
  background: oklch(13% 0.014 30);
  border: 1px solid var(--line);
  border-radius: 4px;
  font-weight: 780;
  transition: background 150ms ease, border-color 150ms ease, color 150ms ease;
}

.profile-chip {
  display: grid;
  gap: 1px;
  min-width: 148px;
  padding: 8px 11px;
  text-align: left;
}

.profile-chip small {
  color: var(--faint);
  font-size: 0.72rem;
}

.profile-chip.active,
.discipline-choice.active,
.power-toggle.active {
  color: var(--ink);
  background:
    linear-gradient(180deg, color-mix(in oklch, var(--discipline-accent, var(--blood-bright)) 60%, var(--panel-2)), color-mix(in oklch, var(--discipline-accent, var(--blood)) 34%, var(--blood)));
  border-color: color-mix(in oklch, var(--discipline-accent, var(--blood-bright)) 78%, var(--ink));
  box-shadow: inset 0 -2px 0 color-mix(in oklch, var(--discipline-accent, var(--blood-bright)) 36%, transparent);
}

.profile-chip.active small,
.power-toggle.active span {
  color: oklch(88% 0.055 38);
}

.library-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  font-weight: 780;
}

.library-toggle input {
  width: 18px;
  min-height: 18px;
  accent-color: var(--blood-bright);
}

.discipline-workspace {
  display: grid;
  grid-template-columns: 290px minmax(0, 1fr);
  align-items: start;
  gap: 16px;
  padding: 16px 18px 18px;
}

.discipline-sidebar {
  min-width: 0;
  display: grid;
  gap: 12px;
  position: sticky;
  top: 16px;
}

.sidebar-block,
.discipline-editor {
  min-width: 0;
  background: oklch(11% 0.012 30);
  border: 1px solid var(--line);
  border-radius: 5px;
}

.sidebar-block {
  padding: 12px;
}

.sidebar-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 850;
  text-transform: uppercase;
}

.sidebar-title strong {
  min-width: 26px;
  min-height: 24px;
  display: inline-grid;
  place-items: center;
  color: var(--ink);
  background: var(--blood);
  border-radius: 4px;
  font-size: 0.78rem;
}

.discipline-focus-list {
  min-width: 0;
  display: grid;
  gap: 7px;
}

.discipline-focus {
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 9px 10px;
  color: var(--muted);
  background: transparent;
  border: 1px solid var(--line-soft);
  border-radius: 4px;
  font-weight: 820;
  text-align: left;
}

.discipline-focus span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.discipline-focus small {
  flex: 0 0 auto;
  color: var(--faint);
  font-size: 0.72rem;
  font-weight: 780;
}

.discipline-focus.active {
  color: var(--ink);
  background:
    linear-gradient(180deg, color-mix(in oklch, var(--discipline-accent, var(--blood-bright)) 58%, var(--panel-2)), color-mix(in oklch, var(--discipline-accent, var(--blood)) 34%, var(--blood)));
  border-color: color-mix(in oklch, var(--discipline-accent, var(--blood-bright)) 78%, var(--ink));
  box-shadow: inset 4px 0 0 color-mix(in oklch, var(--discipline-accent, var(--blood-bright)) 82%, var(--ink));
}

.discipline-focus.active small {
  color: oklch(88% 0.055 38);
}

.discipline-editor {
  overflow: hidden;
}

.discipline-editor summary {
  padding: 11px 12px;
  color: var(--ink);
  cursor: pointer;
  font-size: 0.86rem;
  font-weight: 850;
}

.discipline-choice-list {
  max-height: 260px;
  display: grid;
  gap: 7px;
  overflow: auto;
  padding: 0 12px 12px;
}

.discipline-choice {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 9px;
  font-size: 0.82rem;
  text-align: left;
}

.discipline-choice span {
  order: 2;
  color: var(--faint);
  font-size: 0.68rem;
  font-weight: 880;
  text-transform: uppercase;
}

.discipline-choice.active span {
  color: oklch(88% 0.055 38);
}

.discipline-focus[data-focus-id="animalism"],
.discipline-choice[data-discipline-id="animalism"],
.discipline-card[data-discipline-id="animalism"] {
  --discipline-accent: oklch(61% 0.12 130);
}

.discipline-focus[data-focus-id="auspex"],
.discipline-choice[data-discipline-id="auspex"],
.discipline-card[data-discipline-id="auspex"] {
  --discipline-accent: oklch(66% 0.14 295);
}

.discipline-focus[data-focus-id="blood-sorcery"],
.discipline-choice[data-discipline-id="blood-sorcery"],
.discipline-card[data-discipline-id="blood-sorcery"] {
  --discipline-accent: oklch(61% 0.19 28);
}

.discipline-focus[data-focus-id="celerity"],
.discipline-choice[data-discipline-id="celerity"],
.discipline-card[data-discipline-id="celerity"] {
  --discipline-accent: oklch(76% 0.15 78);
}

.discipline-focus[data-focus-id="dominate"],
.discipline-choice[data-discipline-id="dominate"],
.discipline-card[data-discipline-id="dominate"] {
  --discipline-accent: oklch(58% 0.18 15);
}

.discipline-focus[data-focus-id="fortitude"],
.discipline-choice[data-discipline-id="fortitude"],
.discipline-card[data-discipline-id="fortitude"] {
  --discipline-accent: oklch(68% 0.09 105);
}

.discipline-focus[data-focus-id="obfuscate"],
.discipline-choice[data-discipline-id="obfuscate"],
.discipline-card[data-discipline-id="obfuscate"] {
  --discipline-accent: oklch(62% 0.08 235);
}

.discipline-focus[data-focus-id="oblivion"],
.discipline-choice[data-discipline-id="oblivion"],
.discipline-card[data-discipline-id="oblivion"] {
  --discipline-accent: oklch(64% 0.14 292);
}

.discipline-focus[data-focus-id="potence"],
.discipline-choice[data-discipline-id="potence"],
.discipline-card[data-discipline-id="potence"] {
  --discipline-accent: oklch(62% 0.17 38);
}

.discipline-focus[data-focus-id="presence"],
.discipline-choice[data-discipline-id="presence"],
.discipline-card[data-discipline-id="presence"] {
  --discipline-accent: oklch(71% 0.13 345);
}

.discipline-focus[data-focus-id="protean"],
.discipline-choice[data-discipline-id="protean"],
.discipline-card[data-discipline-id="protean"] {
  --discipline-accent: oklch(63% 0.11 155);
}

.discipline-focus[data-focus-id="thin-blood-alchemy"],
.discipline-choice[data-discipline-id="thin-blood-alchemy"],
.discipline-card[data-discipline-id="thin-blood-alchemy"] {
  --discipline-accent: oklch(72% 0.12 190);
}

.discipline-content {
  min-width: 0;
  display: grid;
  gap: 12px;
}

.content-toolbar {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 420px);
  align-items: end;
  gap: 12px;
  padding: 12px;
  background: color-mix(in oklch, var(--panel) 84%, var(--bg));
  border: 1px solid var(--line);
  border-radius: 5px;
}

.toolbar-label {
  margin: 0 0 3px;
  color: var(--gold);
  font-size: 0.72rem;
  font-weight: 850;
  text-transform: uppercase;
}

.discipline-summary {
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 750;
}

.disciplines-list {
  display: grid;
  gap: 12px;
}

.discipline-card {
  --discipline-accent: var(--blood-bright);
  min-width: 0;
  background:
    linear-gradient(90deg, color-mix(in oklch, var(--discipline-accent) 12%, transparent), transparent 34%),
    oklch(11% 0.012 30);
  border: 1px solid color-mix(in oklch, var(--discipline-accent) 18%, var(--line-soft));
  border-left: 5px solid color-mix(in oklch, var(--discipline-accent) 78%, var(--line));
  border-radius: 5px;
  overflow: hidden;
}

.discipline-card.focused {
  border-color: color-mix(in oklch, var(--discipline-accent) 64%, var(--line));
  box-shadow:
    0 0 0 2px color-mix(in oklch, var(--discipline-accent) 17%, transparent),
    inset 0 1px 0 color-mix(in oklch, var(--discipline-accent) 25%, transparent);
}

.discipline-card summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 12px;
  padding: 16px 18px;
  background:
    linear-gradient(180deg, color-mix(in oklch, var(--panel-2) 90%, var(--discipline-accent) 10%), color-mix(in oklch, var(--panel) 88%, var(--bg))),
    var(--panel);
  list-style: none;
  cursor: pointer;
}

.discipline-card summary::-webkit-details-marker {
  display: none;
}

.discipline-card summary::after {
  content: "+";
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  color: var(--ink);
  background: color-mix(in oklch, var(--discipline-accent) 24%, var(--bg));
  border: 1px solid color-mix(in oklch, var(--discipline-accent) 62%, var(--line));
  border-radius: 3px;
  font-weight: 900;
}

.discipline-card[open] summary {
  border-bottom: 1px solid color-mix(in oklch, var(--discipline-accent) 38%, var(--line-soft));
}

.discipline-card[open] summary::after {
  content: "-";
}

.discipline-card h3 {
  margin-bottom: 4px;
  font-size: 1rem;
  color: color-mix(in oklch, var(--ink) 86%, var(--discipline-accent));
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.discipline-card p {
  margin-bottom: 0;
  color: var(--muted);
  max-width: 72ch;
}

.count-pill {
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  padding: 5px 10px;
  color: var(--ink);
  background: color-mix(in oklch, var(--discipline-accent) 32%, var(--blood));
  border: 1px solid color-mix(in oklch, var(--discipline-accent) 64%, var(--line));
  font-size: 0.76rem;
  font-weight: 850;
}

.power-picker {
  min-width: 0;
  display: grid;
  gap: 10px;
  padding: 14px 18px;
  background:
    linear-gradient(180deg, color-mix(in oklch, var(--discipline-accent) 9%, var(--panel-2)), color-mix(in oklch, var(--panel-2) 70%, var(--bg)));
  border-bottom: 1px solid color-mix(in oklch, var(--discipline-accent) 30%, var(--line-soft));
}

.power-picker-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.power-picker-head strong {
  display: block;
  font-size: 0.88rem;
}

.power-picker-head span {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: 0.8rem;
}

.power-toggle-list {
  min-width: 0;
  max-height: 132px;
  overflow: auto;
}

.power-toggle {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 10px;
  font-size: 0.8rem;
}

.power-toggle span {
  color: var(--discipline-accent);
  font-size: 0.7rem;
}

.power-list {
  min-width: 0;
  display: grid;
  gap: 10px;
  padding: 14px 18px 18px;
}

.power-row {
  display: grid;
  grid-template-columns: 48px minmax(250px, 0.82fr) minmax(360px, 1.18fr);
  gap: 16px;
  padding: 16px;
  background:
    linear-gradient(90deg, color-mix(in oklch, var(--discipline-accent) 8%, transparent), transparent 28%),
    color-mix(in oklch, var(--panel-2) 55%, var(--bg));
  border: 1px solid color-mix(in oklch, var(--discipline-accent) 24%, var(--line-soft));
  border-left: 3px solid color-mix(in oklch, var(--discipline-accent) 72%, var(--line));
  border-radius: 4px;
}

.power-rank {
  min-height: 34px;
  display: inline-grid;
  place-items: center;
  justify-self: start;
  padding: 0 10px;
  color: var(--ink);
  background: color-mix(in oklch, var(--discipline-accent) 30%, var(--bg));
  border: 1px solid color-mix(in oklch, var(--discipline-accent) 68%, var(--line));
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 900;
}

.power-row h4 {
  margin-bottom: 8px;
  font-size: 0.96rem;
}

.power-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
  margin: 0;
}

.power-meta div {
  display: grid;
  gap: 3px;
  min-width: 0;
  padding: 8px 9px;
  background: color-mix(in oklch, var(--bg) 56%, var(--panel-2));
  border: 1px solid color-mix(in oklch, var(--discipline-accent) 18%, var(--line));
  border-radius: 4px;
}

.power-meta dt {
  color: var(--discipline-accent);
  font-size: 0.72rem;
  font-weight: 820;
  text-transform: uppercase;
}

.power-meta dd {
  margin: 0;
  color: var(--ink);
  font-size: 0.84rem;
  overflow-wrap: anywhere;
}

.power-copy {
  color: color-mix(in oklch, var(--ink) 82%, var(--muted));
  max-width: 72ch;
  font-size: 0.98rem;
  line-height: 1.64;
}

.power-copy p + p {
  margin-top: 10px;
}

.power-copy strong {
  color: var(--ink);
}

.empty-state {
  padding: 28px;
  color: var(--muted);
  text-align: center;
  border: 1px dashed var(--line);
  border-radius: 4px;
}

@media (max-width: 980px) {
  .topbar,
  .panel-heading {
    align-items: flex-start;
    flex-direction: column;
  }

  .top-actions {
    justify-content: flex-start;
  }

  .profile-grid,
  .discipline-workspace,
  .content-toolbar,
  .power-row {
    grid-template-columns: 1fr;
  }

  .discipline-sidebar {
    position: static;
  }
}

@media (max-width: 640px) {
  body {
    font-size: 15px;
  }

  .app-shell {
    width: min(100% - 12px, 1440px);
    padding: 6px 0 22px;
  }

  .topbar,
  .panel-heading {
    padding: 12px;
  }

  .topbar {
    gap: 12px;
  }

  .subtitle {
    font-size: 0.92rem;
  }

  .profile-grid,
  .discipline-workspace {
    padding-left: 12px;
    padding-right: 12px;
  }

  h1 {
    font-size: 1.48rem;
  }

  h2 {
    font-size: 1rem;
  }

  .top-actions {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .top-actions > * {
    width: 100%;
  }

  #resetButton {
    grid-column: 1 / -1;
  }

  .profile-grid {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    padding-top: 12px;
  }

  .profile-grid .field {
    grid-column: 1 / -1;
  }

  .profile-grid > button {
    width: 100%;
    min-height: 40px;
    padding: 8px 9px;
    font-size: 0.9rem;
  }

  #deleteProfileButton {
    grid-column: 1 / -1;
  }

  .quick-profiles {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding: 0 12px 12px;
    scroll-snap-type: x proximity;
  }

  .profile-chip {
    flex: 0 0 168px;
    scroll-snap-align: start;
  }

  .library-toggle {
    min-height: 32px;
  }

  .discipline-workspace {
    gap: 10px;
    padding-top: 10px;
    max-width: 100%;
    overflow: hidden;
  }

  .sidebar-block {
    padding: 10px;
    background: color-mix(in oklch, var(--panel) 94%, var(--bg));
  }

  .sidebar-title {
    margin-bottom: 8px;
    font-size: 0.7rem;
  }

  .discipline-focus-list {
    display: flex;
    flex-wrap: nowrap;
    gap: 7px;
    max-width: 100%;
    overflow-x: auto;
    padding-bottom: 2px;
    scroll-snap-type: x proximity;
  }

  .discipline-focus {
    flex: 0 0 auto;
    min-width: 132px;
    min-height: 42px;
    scroll-snap-align: start;
  }

  .discipline-focus span {
    white-space: normal;
  }

  .discipline-focus small {
    font-size: 0.68rem;
  }

  .discipline-editor summary {
    min-height: 42px;
    display: flex;
    align-items: center;
  }

  .discipline-choice-list {
    max-height: 220px;
  }

  .content-toolbar {
    padding: 10px;
    gap: 10px;
    max-width: 100%;
  }

  .discipline-summary {
    font-size: 0.84rem;
    line-height: 1.35;
  }

  input,
  select,
  .primary-button,
  .secondary-button,
  .ghost-button,
  .danger-button,
  .file-label {
    min-height: 40px;
  }

  .disciplines-list {
    padding: 0;
  }

  .discipline-card summary {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 9px;
    padding: 13px 12px;
  }

  .discipline-card h3 {
    font-size: 1.04rem;
  }

  .discipline-card p {
    font-size: 0.9rem;
    line-height: 1.45;
  }

  .power-picker-head {
    align-items: stretch;
    flex-direction: column;
    gap: 8px;
  }

  .power-picker {
    padding: 11px 12px;
  }

  .power-toggle-list {
    flex-wrap: nowrap;
    max-height: none;
    max-width: 100%;
    overflow-x: auto;
    padding-bottom: 3px;
    scroll-snap-type: x proximity;
  }

  .power-toggle {
    flex: 0 0 auto;
    scroll-snap-align: start;
  }

  .count-pill {
    grid-column: 1;
    grid-row: 2;
    justify-self: start;
  }

  .discipline-card summary::after {
    grid-column: 2;
    grid-row: 2;
    align-self: center;
  }

  .power-list {
    gap: 9px;
    padding: 11px 12px 12px;
  }

  .power-row {
    grid-template-columns: 38px minmax(0, 1fr);
    gap: 8px 10px;
    padding: 12px;
  }

  .power-rank {
    padding-top: 2px;
  }

  .power-row h4 {
    margin-bottom: 7px;
    font-size: 1rem;
  }

  .power-meta {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .power-copy {
    grid-column: 1 / -1;
    font-size: 0.92rem;
    line-height: 1.54;
  }
}
