/* ============================================================
   BUTTONS
   ============================================================ */
button,
input[type="submit"],
.btn {
  font-family: var(--font-ui);
  font-size: 0.75rem;
  letter-spacing: 0.14em;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid var(--accent-blood);
  border-radius: var(--radius);
  /* WCAG 2.5.5 touch target */
  min-height: var(--touch-target);
  padding: 0 1.4rem;
  transition: background-color 0.2s, box-shadow 0.2s, color 0.2s;
}

/* Primary — blood red */
input[type="submit"],
button[type="submit"],
.btn--primary {
  background-color: var(--accent-blood);
  color: var(--text-bright);
}

input[type="submit"]:hover,
button[type="submit"]:hover,
.btn--primary:hover {
  background-color: var(--accent-crimson);
  box-shadow: var(--glow-red-lg);
  color: #fff;
}

/* Secondary / ghost */
button:not([type="submit"]),
.btn--ghost {
  background-color: transparent;
  color: var(--text-muted);
  border-color: var(--border-mid);
}

button:not([type="submit"]):hover,
.btn--ghost:hover {
  border-color: var(--accent-blood);
  color: var(--text-body);
}

/* Destructive button (turbo_confirm "Remove", "Delete") */
button[data-turbo-confirm] {
  background-color: transparent;
  border-color: var(--accent-rust);
  color: #c07050;
  font-size: 0.7rem;
  min-height: var(--touch-target);
  padding: 0 0.9rem;
}

button[data-turbo-confirm]:hover {
  background-color: rgba(122, 59, 30, 0.3);
  box-shadow: 0 0 8px rgba(122, 59, 30, 0.5);
  color: #e08050;
}

/* ============================================================
   CARDS / PANELS
   ============================================================ */
.card {
  background-color: var(--bg-surface);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  margin-bottom: 1.25rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.card:hover {
  border-color: var(--border-mid);
  box-shadow: 0 4px 24px rgba(0,0,0,0.5);
}

/* Campaign partial cards */
#campaigns > div[id^="campaign_"] {
  background-color: var(--bg-surface);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius-lg);
  padding: 1.25rem 1.5rem;
  margin-bottom: 1rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}

#campaigns > div[id^="campaign_"]:hover {
  border-color: var(--border-glow);
  box-shadow: 0 4px 20px rgba(0,0,0,0.6), inset 0 0 0 1px rgba(139,26,26,0.1);
}

#campaigns > div[id^="campaign_"] + p {
  margin-top: -0.5rem;
  margin-bottom: 1.5rem;
  padding-left: 1.5rem;
  font-family: var(--font-ui);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
}

/* ============================================================
   FLASH MESSAGES
   ============================================================ */
.flash {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  padding: 0.75rem 1.25rem;
  margin-bottom: 1.5rem;
  border-left: 3px solid;
  border-radius: var(--radius);
}

.flash--notice {
  background-color: rgba(58, 92, 46, 0.15);
  border-color: var(--accent-sickly);
  color: #7ab860;
}

.flash--alert {
  background-color: rgba(139, 26, 26, 0.2);
  border-color: var(--accent-crimson);
  color: #e07070;
}

/* Legacy inline flash overrides (belt-and-suspenders for any missed views) */
p[style*="color: green"] {
  all: unset;
  display: block;
  font-family: var(--font-ui);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  padding: 0.75rem 1.25rem;
  margin-bottom: 1.5rem;
  border-left: 3px solid var(--accent-sickly);
  background-color: rgba(58, 92, 46, 0.15);
  color: #7ab860 !important;
  border-radius: var(--radius);
}

p[style*="color: red"] {
  all: unset;
  display: block;
  font-family: var(--font-ui);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  padding: 0.75rem 1.25rem;
  margin-bottom: 1.5rem;
  border-left: 3px solid var(--accent-crimson);
  background-color: rgba(139, 26, 26, 0.2);
  color: #e07070 !important;
  border-radius: var(--radius);
}

div[style*="color:red"], div[style*="color: red"] {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  padding: 0.75rem 1.25rem;
  margin-bottom: 1.5rem;
  border-left: 3px solid var(--accent-crimson);
  background-color: rgba(139, 26, 26, 0.2);
  color: #e07070 !important;
  border-radius: var(--radius);
}

div[style*="color:green"], div[style*="color: green"] {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  padding: 0.75rem 1.25rem;
  margin-bottom: 1.5rem;
  border-left: 3px solid var(--accent-sickly);
  background-color: rgba(58, 92, 46, 0.15);
  color: #7ab860 !important;
  border-radius: var(--radius);
}

/* ============================================================
   FORMS
   ============================================================ */
form, .form-wrapper {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  max-width: 520px;
}

form > div, .field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

label {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  color: var(--text-muted);
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="number"],
textarea,
select {
  background-color: var(--bg-raised);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius);
  color: var(--text-bright);
  font-family: var(--font-body);
  font-size: 0.95rem;
  /* Ensure inputs meet touch target height */
  min-height: var(--touch-target);
  padding: 0.6rem 0.85rem;
  transition: border-color 0.2s, box-shadow 0.2s;
  width: 100%;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
textarea:focus,
select:focus {
  border-color: var(--accent-link);
  box-shadow: 0 0 0 2px rgba(217, 83, 79, 0.25);
}

input::placeholder,
textarea::placeholder {
  color: var(--text-faint);
}

textarea {
  min-height: 120px;
  resize: vertical;
  line-height: 1.6;
}

select {
  appearance: none;
  /* Arrow uses updated muted colour #8a8799 */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238a8799' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.85rem center;
  padding-right: 2.5rem;
  cursor: pointer;
}

select option {
  background-color: var(--bg-raised);
  color: var(--text-bright);
}

/* Inline form fields (sessions/new uses <br>) */
form input[type="email"] + br,
form input[type="password"] + br {
  display: none;
}

/* Error list */
form div:has(h2) {
  background-color: rgba(139, 26, 26, 0.15);
  border: 1px solid var(--accent-blood);
  border-radius: var(--radius);
  padding: 1rem 1.25rem;
}

form div:has(h2) h2 {
  font-size: 0.75rem;
  font-family: var(--font-ui);
  letter-spacing: 0.08em;
  color: #e07070;
  margin-bottom: 0.5rem;
}

form div:has(h2) ul {
  color: #e07070;
  font-size: 0.9rem;
}

/* ============================================================
   PROFILE PAGE
   ============================================================ */
.profile-page {
  max-width: 520px;
}

.profile-page__header {
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--border-dim);
}

.profile-page__title {
  margin: 0 0 0.25rem;
}

.profile-page__email {
  font-family: var(--font-ui);
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  margin: 0;
}

.profile-page__section {
  margin-bottom: 2rem;
}

.profile-page__section-title {
  font-size: 0.85rem;
  font-family: var(--font-ui);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-muted);
  margin: 0 0 1.25rem;
}

.profile-form {
  max-width: 520px;
}

/* ============================================================
   GAME SYSTEMS — INDEX / CARD
   ============================================================ */
.gs-index { max-width: 860px; }
.gs-index__header { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 2rem; }
.gs-index__title  { margin: 0; }
.gs-index__section { margin-bottom: 2.5rem; }
.gs-index__section-title {
  font-family: var(--font-ui); font-size: 0.7rem; text-transform: uppercase;
  letter-spacing: 0.12em; color: var(--text-muted); margin: 0 0 1rem;
}

.gs-list { display: flex; flex-direction: column; gap: 0.75rem; }

.gs-card {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem;
  background: var(--bg-surface); border: 1px solid var(--border-dim);
  border-radius: var(--radius-lg); padding: 1rem 1.25rem;
  transition: border-color 0.2s;
}
.gs-card:hover { border-color: var(--border-mid); }
.gs-card__body  { flex: 1 1 auto; min-width: 0; }
.gs-card__name  { margin: 0 0 0.25rem; font-size: 1rem; }
.gs-card__name a { color: var(--text-bright); text-decoration: none; }
.gs-card__name a:hover { color: #c4b5fd; }
.gs-card__description { font-size: 0.85rem; color: var(--text-muted); margin: 0 0 0.5rem; }
.gs-card__meta  { display: flex; gap: 0.4rem; flex-wrap: wrap; margin-top: 0.5rem; }
.gs-card__actions { display: flex; gap: 0.5rem; flex-shrink: 0; align-items: flex-start; }

.gs-card__badge {
  font-family: var(--font-ui); font-size: 0.65rem; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  padding: 2px 7px; border-radius: 3px;
}
.gs-card__badge--builtin  { background: rgba(100,116,139,0.2); color: #94a3b8; }
.gs-card__badge--public   { background: rgba(52,211,153,0.15); color: #6ee7b7; }
.gs-card__badge--private  { background: rgba(251,146,60,0.15);  color: #fdba74; }
.gs-card__badge--mine     { background: rgba(139,92,246,0.2);   color: #c4b5fd; }
.gs-card__badge--template { background: rgba(56,189,248,0.15);  color: #7dd3fc; }

/* ── Show page ── */
.gs-show { max-width: 860px; }
.gs-show__header { margin-bottom: 2rem; padding-bottom: 1.5rem; border-bottom: 1px solid var(--border-dim); }
.gs-show__title-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; margin-bottom: 0.5rem; }
.gs-show__title { margin: 0; }
.gs-show__actions { display: flex; gap: 0.5rem; flex-shrink: 0; }
.gs-show__meta  { display: flex; gap: 0.5rem; align-items: center; margin-bottom: 0.75rem; }
.gs-show__description { color: var(--text-muted); margin: 0; }
.gs-show__section-title {
  font-family: var(--font-ui); font-size: 0.7rem; text-transform: uppercase;
  letter-spacing: 0.12em; color: var(--text-muted); margin: 0 0 1rem;
}

.gs-template-preview { display: flex; flex-direction: column; gap: 0.75rem; }
.gs-template-preview__section { border: 1px solid var(--border-dim); border-radius: var(--radius-lg); overflow: hidden; }
.gs-template-preview__section-name {
  padding: 0.6rem 1rem; cursor: pointer; list-style: none;
  font-family: var(--font-ui); font-size: 0.75rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.1em; color: #c4b5fd;
  background: var(--bg-surface);
}
.gs-template-preview__section-name::-webkit-details-marker { display: none; }
.gs-template-preview__table { width: 100%; border-collapse: collapse; font-size: 0.82rem; }
.gs-template-preview__table th,
.gs-template-preview__table td {
  padding: 0.4rem 0.75rem; text-align: left; border-bottom: 1px solid var(--border-dim);
}
.gs-template-preview__table th { font-family: var(--font-ui); font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-muted); background: var(--bg-raised); }
.gs-template-preview__table td { color: var(--text-body); }
.gs-template-preview__table td code { font-size: 0.78rem; color: #a78bfa; background: rgba(139,92,246,0.1); padding: 1px 5px; border-radius: 3px; }
.gs-template-preview__table tr:last-child td { border-bottom: none; }

/* ============================================================
   TEMPLATE BUILDER
   ============================================================ */
.tb { margin-top: 2rem; max-width: 900px; }
.tb__header { margin-bottom: 1.25rem; }
.tb__title { margin: 0 0 0.25rem; font-size: 1rem; }
.tb__hint  { font-size: 0.82rem; color: var(--text-muted); margin: 0; }
.tb__sections { display: flex; flex-direction: column; gap: 1rem; margin-bottom: 0.75rem; }
.tb__add-section { align-self: flex-start; }

.tb-section {
  border: 1px solid var(--border-dim); border-radius: var(--radius-lg);
  background: var(--bg-surface); overflow: hidden;
}
.tb-section__header {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.6rem 0.75rem;
  background: var(--bg-raised);
  border-bottom: 1px solid var(--border-dim);
}
.tb-section__name-input {
  flex: 1 1 auto; background: transparent; border: none;
  font-family: var(--font-ui); font-size: 0.8rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--text-bright); padding: 0;
}
.tb-section__name-input:focus { outline: none; }
.tb-section__name-input::placeholder { color: var(--text-faint); }
.tb-section__remove { margin-left: auto; flex-shrink: 0; }
.tb-section__fields { display: flex; flex-direction: column; gap: 0; }
.tb-section__add-field { margin: 0.5rem 0.75rem; }

.tb-field {
  border-bottom: 1px solid rgba(255,255,255,0.05);
  padding: 0.5rem 0.75rem;
}
.tb-field:last-child { border-bottom: none; }
.tb-field__row {
  display: grid;
  grid-template-columns: 2fr 1.5fr 1fr 1fr auto;
  gap: 0.5rem; align-items: end;
}
.tb-field__label-text {
  display: block; font-family: var(--font-ui); font-size: 0.65rem;
  text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-muted);
  margin-bottom: 3px;
}
.tb-field__col input,
.tb-field__col select { width: 100%; margin: 0; min-height: 32px; padding: 0.3rem 0.5rem; font-size: 0.82rem; }
.tb-field__remove {
  background: none; border: none; color: var(--text-faint); cursor: pointer;
  font-size: 1.1rem; line-height: 1; padding: 4px 6px; border-radius: 4px;
  align-self: end; margin-bottom: 2px;
}
.tb-field__remove:hover { background: rgba(220,38,38,0.15); color: #f87171; }
.tb-field__options-row { margin-top: 0.5rem; }
.tb-field__options-row textarea { width: 100%; margin: 0; font-size: 0.8rem; min-height: 70px; }
