/* ── Variables ── */
:root {
  --font: 'Cormorant Garamond', Georgia, serif;

  /* Dark theme (default) */
  --bg:              #1a1208;
  --bg-radial:       #2e1f0a;
  --title-color:     #f4e8c1;
  --subtitle-color:  #a08060;
  --ornament-color:  #b8860b;
  --divider-color:   #b8860b;

  --tab-bg:          #2a1c0a;
  --tab-bg-hover:    #3a2810;
  --tab-bg-active:   linear-gradient(180deg, #4a3010 0%, #3a2208 100%);
  --tab-color:       #a08060;
  --tab-color-hover: #e8d49a;
  --tab-color-active:#d4a820;
  --tab-border:      #5c3d20;

  --card-bg:         linear-gradient(160deg, #f7edca 0%, #f0e0a8 40%, #e8d494 100%);
  --card-border:     #b8960a;
  --card-outline1:   #2a1a0e;
  --card-outline2:   #7a5a18;
  --card-shadow:     rgba(0,0,0,0.7);
  --card-inset:      rgba(139,90,20,0.15);

  --ink:             #2a1a0e;
  --ink-dim:         #5c3d20;
  --desc-bg:         rgba(139,90,20,0.06);
  --entry-odd-bg:    transparent;
  --entry-even-bg:   rgba(139,90,20,0.06);
  --entry-type-bg:   rgba(139,90,20,0.10);
  --entry-border:    rgba(92,61,32,0.3);

  --input-bg:        rgba(255,255,255,0.5);
  --input-bg-focus:  rgba(255,255,255,0.8);
  --input-border:    #5c3d20;
  --input-color:     #2a1a0e;

  --red:             #8b1a1a;
  --gold:            #b8860b;
  --gold-lt:         #d4a820;

  --ctrl-bg:         rgba(26,18,8,0.92);
  --ctrl-border:     #5c3d20;
  --ctrl-color:      #c8a870;
  --ctrl-bg-hover:   rgba(50,35,12,0.95);
}

[data-theme="light"] {
  --bg:              #ddd0a8;
  --bg-radial:       #c8b880;
  --title-color:     #2a1a0e;
  --subtitle-color:  #6a4820;
  --ornament-color:  #8a6010;
  --divider-color:   #9a7020;

  --tab-bg:          #c8b070;
  --tab-bg-hover:    #b8a060;
  --tab-bg-active:   linear-gradient(180deg, #a07828 0%, #8a6018 100%);
  --tab-color:       #4a3010;
  --tab-color-hover: #2a1a08;
  --tab-color-active:#fdf0cc;
  --tab-border:      #9a7828;

  --card-bg:         linear-gradient(160deg, #fdf8ec 0%, #f8efd4 40%, #f2e4b8 100%);
  --card-border:     #c8a030;
  --card-outline1:   #c8a030;
  --card-outline2:   #d4b040;
  --card-shadow:     rgba(0,0,0,0.18);
  --card-inset:      rgba(139,90,20,0.06);

  --input-bg:        rgba(255,255,255,0.7);
  --input-bg-focus:  rgba(255,255,255,0.95);
  --input-border:    #9a7020;

  --ctrl-bg:         rgba(220,204,160,0.96);
  --ctrl-border:     #9a7828;
  --ctrl-color:      #3a2408;
  --ctrl-bg-hover:   rgba(200,180,120,0.98);
}

/* ── Reset ── */
* { box-sizing: border-box; margin: 0; padding: 0; }

/* ── Body ── */
body {
  background-color: var(--bg);
  background-image:
    radial-gradient(ellipse at 50% 0%, var(--bg-radial) 0%, transparent 70%),
    url("data:image/svg+xml,%3Csvg width='200' height='200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 2.5rem 1rem 4rem;
  font-family: var(--font);
  color: var(--ink);
  transition: background-color 0.3s, color 0.3s;
}

/* ── Controls ── */
.controls {
  position: fixed;
  top: 0.8rem;
  right: 0.9rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--ctrl-bg);
  border: 1px solid var(--ctrl-border);
  border-radius: 4px;
  padding: 0.3rem 0.5rem;
  z-index: 100;
  backdrop-filter: blur(4px);
}

.ctrl-btn {
  background: none;
  border: none;
  color: var(--ctrl-color);
  font-size: 1.1rem;
  cursor: pointer;
  padding: 0.1rem 0.3rem;
  border-radius: 3px;
  line-height: 1;
  transition: background 0.15s;
}
.ctrl-btn:hover { background: var(--ctrl-bg-hover); }

.ctrl-select {
  background: transparent;
  border: none;
  color: var(--ctrl-color);
  font-family: var(--font);
  font-size: 0.82rem;
  cursor: pointer;
  outline: none;
  padding: 0.1rem 0.2rem;
}
.ctrl-select option { background: #2a1a0e; color: #e8d4a0; }

/* ── Header ── */
.site-header {
  text-align: center;
  margin-bottom: 2rem;
}

.header-ornament {
  color: var(--ornament-color);
  font-size: 1.4rem;
  letter-spacing: 0.3em;
  display: block;
  margin-bottom: 0.2rem;
  opacity: 0.75;
}

h1 {
  font-size: 2.6rem;
  color: var(--title-color);
  text-shadow: 0 2px 8px rgba(0,0,0,0.4), 0 0 30px rgba(184,134,11,0.2);
  letter-spacing: 0.06em;
  line-height: 1.1;
  transition: color 0.3s;
}

.subtitle {
  font-style: italic;
  color: var(--subtitle-color);
  font-size: 0.9rem;
  margin-top: 0.4rem;
  letter-spacing: 0.05em;
}

/* ── Divider ── */
.divider {
  width: 100%;
  max-width: 660px;
  margin: 0 auto 1.8rem;
  display: flex;
  align-items: center;
  gap: 0.8rem;
}
.divider::before, .divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--divider-color), transparent);
  opacity: 0.5;
}
.divider-gem { color: var(--divider-color); font-size: 1rem; opacity: 0.7; }

/* ── Tabs ── */
.tabs {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 1.8rem;
  border: 1px solid var(--tab-border);
  border-radius: 3px;
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(0,0,0,0.3);
}

.tab {
  padding: 0.55rem 1.3rem;
  background: var(--tab-bg);
  border: none;
  border-right: 1px solid var(--tab-border);
  color: var(--tab-color);
  cursor: pointer;
  font-family: var(--font);
  font-size: 0.95rem;
  transition: all 0.15s;
  letter-spacing: 0.02em;
}
.tab:last-child { border-right: none; }
.tab:hover { background: var(--tab-bg-hover); color: var(--tab-color-hover); }
.tab.active { background: var(--tab-bg-active); color: var(--tab-color-active); }

/* ── Panel ── */
.panel { display: none; width: 100%; max-width: 660px; }
.panel.active { display: block; }

/* ── Parchment card ── */
.parchment {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 3px;
  box-shadow:
    0 0 0 3px var(--card-outline1),
    0 0 0 4px var(--card-outline2),
    0 4px 24px var(--card-shadow),
    inset 0 0 40px var(--card-inset);
  padding: 1.6rem 1.8rem;
  position: relative;
  transition: background 0.3s, box-shadow 0.3s;
}
.parchment::before, .parchment::after {
  content: '✦';
  position: absolute;
  color: var(--gold);
  opacity: 0.5;
  font-size: 0.8rem;
}
.parchment::before { top: 6px; left: 8px; }
.parchment::after  { bottom: 6px; right: 8px; }

/* ── Description ── */
.description {
  border-left: 3px solid var(--gold);
  padding: 0.7rem 1rem;
  font-style: italic;
  font-size: 0.85rem;
  color: var(--ink-dim);
  line-height: 1.65;
  margin-bottom: 1.4rem;
  background: var(--desc-bg);
}

/* ── Dice row ── */
.dice-row {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  margin-bottom: 1.4rem;
  flex-wrap: wrap;
}
.dice-group { display: flex; align-items: center; gap: 0.5rem; }
.dice-label {
  font-size: 1rem;
  color: var(--red);
  font-weight: bold;
  min-width: 2.2rem;
  font-style: italic;
}

.dice-input {
  width: 4.8rem;
  padding: 0.45rem 0.5rem;
  background: var(--input-bg);
  border: 1px solid var(--input-border);
  border-bottom: 2px solid var(--input-border);
  color: var(--input-color);
  font-family: var(--font);
  font-size: 1.2rem;
  text-align: center;
  border-radius: 2px;
  outline: none;
  transition: border-color 0.15s, background 0.15s;
}
.dice-input:focus {
  background: var(--input-bg-focus);
  border-color: var(--gold);
  border-bottom-color: var(--red);
}

/* ── Buttons ── */
.btn {
  padding: 0.5rem 1.6rem;
  background: linear-gradient(180deg, #6b2020 0%, #4a1010 100%);
  border: 1px solid #8b3030;
  border-bottom: 2px solid #2a0808;
  color: #f4e8c1;
  font-family: var(--font);
  font-size: 0.95rem;
  cursor: pointer;
  border-radius: 2px;
  letter-spacing: 0.04em;
  text-shadow: 0 1px 2px rgba(0,0,0,0.5);
  box-shadow: 0 2px 6px rgba(0,0,0,0.35);
  transition: all 0.12s;
}
.btn:hover { background: linear-gradient(180deg, #8b2828 0%, #5a1818 100%); box-shadow: 0 3px 10px rgba(0,0,0,0.4); }
.btn:active { transform: translateY(1px); box-shadow: 0 1px 3px rgba(0,0,0,0.3); }

.btn-roll {
  background: linear-gradient(180deg, #1a4a1a 0%, #0e3010 100%);
  border-color: #2a6a2a;
  border-bottom-color: #081808;
}
.btn-roll:hover { background: linear-gradient(180deg, #226022 0%, #143814 100%); }

/* ── Result ── */
.result { display: none; animation: unfurl 0.25s ease; }
.result.show { display: block; }

@keyframes unfurl {
  from { opacity: 0; transform: translateY(6px) scaleY(0.97); }
  to   { opacity: 1; transform: none; }
}

.result-header {
  display: flex;
  align-items: baseline;
  gap: 1rem;
  margin-bottom: 0.9rem;
  padding-bottom: 0.6rem;
  border-bottom: 1px solid var(--gold);
}
.table-number { font-size: 1.4rem; color: var(--red); font-style: italic; }
.table-dice   { color: var(--ink-dim); font-size: 0.85rem; font-style: italic; }

/* ── Entries ── */
.entries { border: 1px solid var(--entry-border); overflow: hidden; }

.entry {
  display: grid;
  grid-template-columns: 10rem 1fr;
  border-bottom: 1px solid var(--entry-border);
}
.entry:last-child { border-bottom: none; }
.entry:nth-child(even) .entry-text { background: var(--entry-even-bg); }

.entry-type {
  padding: 0.75rem 1.1rem;
  background: var(--entry-type-bg);
  color: var(--red);
  font-size: 0.78rem;
  font-weight: bold;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  border-right: 1px solid var(--entry-border);
  font-style: normal;
}
.entry-text {
  padding: 0.75rem 1rem;
  line-height: 1.6;
  font-size: 0.88rem;
  color: var(--ink);
}

/* ── Error ── */
.error {
  color: var(--red);
  font-size: 0.88rem;
  font-style: italic;
  padding: 0.4rem 0;
  min-height: 1.4rem;
}

/* ── Mobile ── */
@media (max-width: 500px) {
  h1 { font-size: 1.9rem; }
  .parchment { padding: 1.2rem; }
  .entry { grid-template-columns: 1fr; }
  .entry-type { border-right: none; border-bottom: 1px solid var(--entry-border); }
}
