/* =========================================================================
   Pr Mauricio Salles — design system (inspirado em Sympla)
   Raleway (display) + Open Sans (body), magenta vibrante sobre branco puro
   ========================================================================= */

:root {
  /* Cores — base Sympla */
  --bg:           #FFFFFF;
  --bg-soft:      #F5F5F5;
  --surface:      #FFFFFF;
  --surface-2:    #FAFAFA;
  --ink:          #191F28;
  --ink-soft:     #414651;
  --muted:        #535862;
  --muted-soft:   #717680;
  --border:       #E4E7EC;
  --border-soft:  #F0F2F5;

  --primary:        #C31162;
  --primary-hover:  #A00D52;
  --primary-soft:   #FDE8F0;
  --primary-strong: #800940;
  --primary-ink:    #5C0530;

  --accent:        #FFBD00;
  --accent-hover:  #E0A300;
  --accent-soft:   #FFF6D9;

  --secondary:     #7839EE;
  --secondary-soft:#EFE7FD;

  --danger:        #F03844;
  --danger-soft:   #FDE2E4;
  --success:       #17B26A;
  --success-soft:  #DEFBEB;
  --warning:       #EF6820;
  --warning-soft:  #FEEBD9;
  --info:          #0097FF;
  --info-soft:     #DFF0FF;

  /* Tipografia (Sympla usa Raleway + Open Sans) */
  --font-display: "Raleway", "Helvetica Neue", Arial, sans-serif;
  --font-body:    "Open Sans", "Segoe UI", Roboto, system-ui, -apple-system, sans-serif;
  --font-mono:    ui-monospace, "JetBrains Mono", "Cascadia Code", Consolas, monospace;

  /* Escala fluida */
  --fs-xs:    0.78rem;
  --fs-sm:    0.875rem;
  --fs-base:  1rem;
  --fs-md:    1.0625rem;
  --fs-lg:    1.25rem;
  --fs-xl:    1.5rem;
  --fs-2xl:   clamp(1.75rem, 1.3rem + 1.6vw, 2.4rem);
  --fs-3xl:   clamp(2.2rem, 1.4rem + 3vw, 3.4rem);
  --fs-hero:  clamp(2.6rem, 1.6rem + 4.5vw, 4.6rem);

  /* Espaçamento */
  --space-1:  0.25rem;
  --space-2:  0.5rem;
  --space-3:  0.75rem;
  --space-4:  1rem;
  --space-5:  1.5rem;
  --space-6:  2rem;
  --space-7:  2.5rem;
  --space-8:  3rem;
  --space-10: 4.5rem;
  --space-12: 6rem;
  --space-16: 9rem;

  --radius-sm:  6px;
  --radius:     10px;
  --radius-md:  14px;
  --radius-lg:  18px;
  --radius-pill: 999px;

  --shadow-xs:  0 1px 2px rgba(16, 24, 40, 0.04);
  --shadow-sm:  0 1px 3px rgba(16, 24, 40, 0.08), 0 1px 2px rgba(16, 24, 40, 0.04);
  --shadow-md:  0 4px 12px -2px rgba(16, 24, 40, 0.10), 0 2px 4px -2px rgba(16, 24, 40, 0.06);
  --shadow-lg:  0 12px 24px -8px rgba(16, 24, 40, 0.14), 0 4px 8px -4px rgba(16, 24, 40, 0.06);
  --shadow-magenta: 0 8px 28px -12px rgba(195, 17, 98, 0.45);

  --ease-out:    cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --dur-fast:    140ms;
  --dur-base:    240ms;
  --dur-slow:    400ms;

  --header-h: 68px;
  --content-max: 1180px;
  --content-narrow: 720px;
}

/* =========================================================================
   Reset & base
   ========================================================================= */

*,
*::before,
*::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
html, body { margin: 0; padding: 0; }

/* O atributo `hidden` do HTML precisa vencer regras com `display` mais
   específico (ex: `.qcard-choices { display: grid }`). */
[hidden] { display: none !important; }

body {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  color: var(--ink);
  background: var(--bg);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img, svg { display: block; max-width: 100%; }

a {
  color: var(--primary);
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease-out);
}
a:hover { color: var(--primary-hover); }

::selection { background: var(--primary); color: #fff; }

/* Tipografia — Raleway nas headings */
h1, h2, h3, h4, h5 {
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: 0 0 var(--space-4);
}
h1 { font-size: var(--fs-3xl); font-weight: 800; letter-spacing: -0.02em; }
h2 { font-size: var(--fs-2xl); }
h3 { font-size: var(--fs-xl); font-weight: 600; }
h4 { font-size: var(--fs-lg); font-weight: 600; }

p { margin: 0 0 var(--space-4); color: var(--ink-soft); }
small { font-size: var(--fs-sm); color: var(--muted); }
code {
  font-family: var(--font-mono);
  font-size: 0.92em;
  background: var(--bg-soft);
  padding: 0.1em 0.4em;
  border-radius: 4px;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: var(--space-3);
}
.eyebrow::before {
  content: "";
  width: 1.5em;
  height: 2px;
  background: var(--primary);
  border-radius: 2px;
}

.lead {
  font-size: var(--fs-md);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 60ch;
}

.muted { color: var(--muted); }
.center { text-align: center; }

/* =========================================================================
   Layout
   ========================================================================= */

.container {
  width: 100%;
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 0 clamp(1rem, 4vw, 2rem);
}
.container-narrow {
  width: 100%;
  max-width: var(--content-narrow);
  margin: 0 auto;
  padding: 0 clamp(1rem, 4vw, 2rem);
}

.section { padding: var(--space-10) 0; }
.section-sm { padding: var(--space-6) 0; }
.section-lg { padding: var(--space-12) 0; }

.divider {
  border: 0;
  border-top: 1px solid var(--border);
  margin: var(--space-8) 0;
}

/* =========================================================================
   Header & footer
   ========================================================================= */

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: saturate(160%) blur(12px);
  -webkit-backdrop-filter: saturate(160%) blur(12px);
  border-bottom: 1px solid var(--border);
}
.site-header-inner {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 0 clamp(1rem, 4vw, 2rem);
  height: var(--header-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-5);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.45em;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.15rem;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.brand:hover { color: var(--primary); }
.brand-dot {
  display: inline-block;
  width: 0.6em;
  height: 0.6em;
  border-radius: 50%;
  background: var(--primary);
}
.brand-tagline {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted);
  margin-left: 0.6em;
}

.nav { display: flex; align-items: center; gap: var(--space-5); }
.nav a {
  color: var(--ink-soft);
  font-weight: 600;
  font-size: var(--fs-sm);
}
.nav a:hover { color: var(--primary); }

.site-footer {
  margin-top: var(--space-12);
  padding: var(--space-8) 0;
  border-top: 1px solid var(--border);
  background: var(--bg-soft);
}
.site-footer-inner {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 0 clamp(1rem, 4vw, 2rem);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--space-4);
  color: var(--muted);
  font-size: var(--fs-sm);
}
.site-footer-brand {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--fs-md);
  color: var(--ink);
}

/* =========================================================================
   Buttons
   ========================================================================= */

.btn {
  --btn-bg: var(--bg-soft);
  --btn-fg: var(--ink);
  --btn-border: var(--border);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55em;
  padding: 0.78em 1.4em;
  background: var(--btn-bg);
  color: var(--btn-fg);
  border: 1px solid var(--btn-border);
  border-radius: var(--radius);
  font: 700 var(--fs-sm) / 1 var(--font-body);
  letter-spacing: -0.005em;
  cursor: pointer;
  text-decoration: none;
  transition:
    transform var(--dur-fast) var(--ease-out),
    background var(--dur-fast) var(--ease-out),
    color var(--dur-fast) var(--ease-out),
    border-color var(--dur-fast) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out),
    filter var(--dur-fast) var(--ease-out);
  white-space: nowrap;
}
.btn:hover { text-decoration: none; transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--primary) 32%, transparent);
}

.btn-primary {
  --btn-bg: var(--primary);
  --btn-fg: #fff;
  --btn-border: var(--primary);
  box-shadow: var(--shadow-magenta);
}
.btn-primary:hover {
  --btn-bg: var(--primary-hover);
  --btn-border: var(--primary-hover);
}

.btn-accent { --btn-bg: var(--accent); --btn-fg: var(--ink); --btn-border: var(--accent); }
.btn-accent:hover { --btn-bg: var(--accent-hover); --btn-border: var(--accent-hover); }

.btn-outline { --btn-bg: transparent; --btn-fg: var(--ink); --btn-border: var(--border); }
.btn-outline:hover { --btn-border: var(--primary); --btn-fg: var(--primary); }

.btn-ghost {
  --btn-bg: transparent;
  --btn-fg: var(--muted);
  --btn-border: transparent;
  padding: 0.55em 0.9em;
}
.btn-ghost:hover { --btn-fg: var(--ink); --btn-bg: var(--bg-soft); }

.btn-danger { --btn-bg: var(--danger); --btn-fg: #fff; --btn-border: var(--danger); }
.btn-danger:hover { filter: brightness(0.92); }

.btn-success { --btn-bg: var(--success); --btn-fg: #fff; --btn-border: var(--success); }

.btn-lg { padding: 1em 1.8em; font-size: var(--fs-base); border-radius: var(--radius-md); }
.btn-sm { padding: 0.5em 0.9em; font-size: var(--fs-xs); }
.btn-block { width: 100%; }

.icon-arrow {
  display: inline-block;
  transition: transform var(--dur-base) var(--ease-out);
}
.btn:hover .icon-arrow { transform: translateX(3px); }

/* =========================================================================
   Forms
   ========================================================================= */

.form-stack { display: grid; gap: var(--space-5); }
.form-grid { display: grid; gap: var(--space-4); grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }

label.field, .form-stack > label, .form-grid > label {
  display: grid;
  gap: var(--space-2);
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--ink);
}

input[type="text"], input[type="email"], input[type="tel"], input[type="url"],
input[type="number"], input[type="date"], input[type="datetime-local"],
input[type="password"], input[type="file"],
select, textarea {
  width: 100%;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.78em 1em;
  font: 400 var(--fs-base) / 1.4 var(--font-body);
  color: var(--ink);
  transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
textarea { min-height: 8rem; resize: vertical; line-height: 1.5; }

input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--primary) 18%, transparent);
}

input::placeholder, textarea::placeholder { color: var(--muted-soft); }

input[type="file"] {
  padding: 0.55em 0.8em;
  font-size: var(--fs-sm);
}
input[type="file"]::file-selector-button {
  margin-right: 1em;
  padding: 0.6em 1em;
  border: 0;
  border-radius: var(--radius-sm);
  background: var(--primary);
  color: #fff;
  font: 700 var(--fs-sm) var(--font-body);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
}
input[type="file"]::file-selector-button:hover { background: var(--primary-hover); }

.form-help { color: var(--muted); font-size: var(--fs-sm); margin: 0; }

.form-row-inline {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: end;
}

fieldset {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  margin: 0;
  background: var(--surface);
}
fieldset legend {
  padding: 0 var(--space-2);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--fs-md);
  color: var(--ink);
}

.field-error { color: var(--danger); font-size: var(--fs-sm); }
.inline-error { display: block; margin-top: 0.3em; }

/* Borda vermelha em inputs inválidos (após blur), incluindo email nativo */
input[aria-invalid="true"],
input[type="email"]:not(:placeholder-shown):invalid {
  border-color: var(--danger);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--danger) 14%, transparent);
}

input[type="checkbox"], input[type="radio"] {
  width: 1.05em; height: 1.05em;
  accent-color: var(--primary);
  vertical-align: middle;
  margin-right: 0.4em;
}

/* Campos de múltipla escolha (radio/checkbox) no formulário público */
.choice-field {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface);
  padding: var(--space-4) var(--space-5);
  margin: 0;
}
.choice-field > legend {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--fs-md);
  color: var(--ink);
  padding: 0 var(--space-2);
}
.choice-options {
  display: grid;
  gap: var(--space-2);
  margin-top: var(--space-2);
}
.choice-option {
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  padding: 0.55em 0.8em;
  border-radius: var(--radius);
  cursor: pointer;
  font-size: var(--fs-base);
  color: var(--ink);
  transition: background var(--dur-fast) var(--ease-out);
}
.choice-option:hover { background: var(--bg-soft); }
.choice-option input[type="radio"], .choice-option input[type="checkbox"] {
  margin-right: 0;
}
.choice-option.choice-other {
  display: grid;
  grid-template-columns: max-content max-content 1fr;
  align-items: center;
}
.choice-option.choice-other input[type="text"] {
  width: 100%;
  border: none;
  border-bottom: 1px solid var(--border);
  border-radius: 0;
  padding: 0.35em 0.4em;
  font-size: var(--fs-sm);
  background: transparent;
}
.choice-option.choice-other input[type="text"]:focus {
  outline: none;
  border-bottom-color: var(--primary);
  box-shadow: 0 1px 0 0 var(--primary);
}

/* =========================================================================
   Flash messages
   ========================================================================= */

.flash {
  padding: var(--space-3) var(--space-4);
  margin-bottom: var(--space-4);
  border-radius: var(--radius);
  background: var(--surface);
  border: 1px solid var(--border);
  border-left-width: 4px;
  box-shadow: var(--shadow-xs);
  font-size: var(--fs-sm);
}
.flash-success { border-left-color: var(--success); background: var(--success-soft); }
.flash-info    { border-left-color: var(--info);    background: var(--info-soft); }
.flash-warning { border-left-color: var(--warning); background: var(--warning-soft); }
.flash-danger  { border-left-color: var(--danger);  background: var(--danger-soft); }

/* =========================================================================
   Cards
   ========================================================================= */

.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-xs);
}
.card + .card { margin-top: var(--space-4); }
.card-soft { background: var(--bg-soft); border-color: var(--border-soft); }
.card-flush { padding: 0; overflow: hidden; }

/* =========================================================================
   Hero — homepage
   ========================================================================= */

.hero {
  position: relative;
  padding: clamp(3.5rem, 5vw + 2rem, 6.5rem) 0 clamp(2rem, 3vw + 1rem, 3.5rem);
  overflow: hidden;
  background:
    radial-gradient(80% 60% at 90% 0%, var(--primary-soft) 0%, transparent 60%),
    radial-gradient(50% 40% at 0% 100%, var(--secondary-soft) 0%, transparent 60%),
    var(--bg);
}
.hero-content { max-width: 780px; position: relative; z-index: 1; }
.hero h1 {
  font-size: var(--fs-hero);
  font-weight: 800;
  line-height: 1.02;
  letter-spacing: -0.025em;
}
.hero h1 .highlight {
  background: linear-gradient(120deg, var(--primary) 0%, var(--secondary) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero .lead { margin-top: var(--space-4); font-size: var(--fs-lg); }
.hero-stats {
  display: flex; gap: var(--space-6); flex-wrap: wrap;
  margin-top: var(--space-6);
}
.hero-stat strong {
  display: block;
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 800;
  color: var(--primary);
}
.hero-stat span { color: var(--muted); font-size: var(--fs-sm); }

/* =========================================================================
   Carrossel da home
   ========================================================================= */

.carousel-section {
  padding: var(--space-10) 0;
}

.event-carousel {
  position: relative;
}

.event-carousel-track {
  display: flex;
  gap: var(--space-5);
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: var(--space-2) 0 var(--space-4);
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
  -webkit-overflow-scrolling: touch;
}
.event-carousel-track::-webkit-scrollbar {
  height: 8px;
}
.event-carousel-track::-webkit-scrollbar-track {
  background: transparent;
}
.event-carousel-track::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 4px;
}
.event-carousel-track::-webkit-scrollbar-thumb:hover {
  background: var(--muted-soft);
}

.event-card-slide {
  flex: 0 0 auto;
  width: clamp(280px, 90vw, 380px);
  scroll-snap-align: start;
}

.carousel-nav {
  position: absolute;
  top: 38%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--ink);
  display: grid;
  place-items: center;
  cursor: pointer;
  box-shadow: var(--shadow-md);
  z-index: 2;
  transition: background var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out),
              transform var(--dur-fast) var(--ease-out);
}
.carousel-nav:hover {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary);
  transform: translateY(-50%) scale(1.05);
}
.carousel-nav:active {
  transform: translateY(-50%) scale(0.96);
}
.carousel-nav-prev { left: -16px; }
.carousel-nav-next { right: -16px; }

@media (max-width: 720px) {
  .carousel-nav { display: none; }
  .event-card-slide { width: min(85vw, 320px); }
}

/* =========================================================================
   Event cards (Sympla-style)
   ========================================================================= */

.events-grid {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: repeat(auto-fill, minmax(min(320px, 100%), 1fr));
}

.event-card {
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  text-decoration: none;
  color: var(--ink);
  transition:
    transform var(--dur-base) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out),
    border-color var(--dur-base) var(--ease-out);
  position: relative;
}
.event-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: var(--primary);
  color: var(--ink);
  text-decoration: none;
}

.event-card-cover {
  aspect-ratio: 16 / 9;
  background:
    linear-gradient(135deg, var(--primary-soft) 0%, var(--secondary-soft) 100%);
  position: relative;
  overflow: hidden;
}
.event-card-cover img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--dur-slow) var(--ease-out);
}
.event-card:hover .event-card-cover img { transform: scale(1.04); }
.event-card-cover::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(25, 31, 40, 0.30), transparent 50%);
  pointer-events: none;
}

.date-tag {
  position: absolute;
  top: var(--space-3); left: var(--space-3);
  background: var(--surface);
  border-radius: var(--radius-sm);
  padding: var(--space-2) var(--space-3);
  text-align: center;
  box-shadow: var(--shadow-sm);
  min-width: 52px;
  font-family: var(--font-display);
  z-index: 2;
}
.date-tag .day {
  display: block;
  font-size: 1.45rem;
  font-weight: 800;
  line-height: 1;
  color: var(--ink);
  letter-spacing: -0.02em;
}
.date-tag .month {
  display: block;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--primary);
  font-weight: 800;
  margin-top: 0.25em;
}

.event-card-body {
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  flex: 1;
}
.event-card-title {
  font-family: var(--font-display);
  font-size: 1.25rem;
  line-height: 1.2;
  letter-spacing: -0.012em;
  font-weight: 700;
  margin: 0;
  color: var(--ink);
}
.event-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-4);
  font-size: var(--fs-sm);
  color: var(--muted);
}
.event-card-meta .meta-row { display: inline-flex; align-items: center; gap: 0.4em; }
.event-card-desc {
  color: var(--ink-soft);
  font-size: var(--fs-sm);
  line-height: 1.55;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.event-card-foot {
  margin-top: auto;
  padding-top: var(--space-4);
  border-top: 1px solid var(--border-soft);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}
.price-tag {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--fs-lg);
  color: var(--primary);
  letter-spacing: -0.012em;
}
.price-tag small { font-weight: 600; color: var(--muted); font-size: var(--fs-xs); }

/* =========================================================================
   Event detail page
   ========================================================================= */

.event-hero {
  position: relative;
  margin-top: var(--space-5);
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--surface);
}
.event-hero-cover {
  aspect-ratio: 21 / 9;
  background: linear-gradient(135deg, var(--primary-soft), var(--secondary-soft));
  position: relative;
  overflow: hidden;
}
.event-hero-cover img { width: 100%; height: 100%; object-fit: cover; }
.event-hero-cover::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(25, 31, 40, 0.55), transparent 60%);
}
.event-hero-body { padding: clamp(1.5rem, 2vw + 1rem, 2.5rem); }
.event-hero-body h1 {
  font-size: var(--fs-3xl);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.022em;
  max-width: 22ch;
}

.event-meta-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
  font-size: var(--fs-sm);
  color: var(--muted);
}
.meta-chip {
  display: inline-flex; align-items: center; gap: 0.4em;
  padding: 0.45em 0.9em;
  border-radius: var(--radius-pill);
  background: var(--bg-soft);
  color: var(--ink-soft);
  font-size: var(--fs-sm);
  font-weight: 600;
  border: 1px solid var(--border);
}

.event-description {
  font-size: var(--fs-md);
  line-height: 1.65;
  color: var(--ink-soft);
  white-space: pre-wrap;
}

.event-layout {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  margin-top: var(--space-8);
}
@media (max-width: 880px) { .event-layout { grid-template-columns: 1fr; } }
.event-sidebar {
  position: sticky;
  top: calc(var(--header-h) + var(--space-4));
  align-self: start;
}

/* =========================================================================
   Ticket types
   ========================================================================= */

.ticket-list { display: grid; gap: var(--space-3); }

.ticket-card {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-5);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  transition: border-color var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.ticket-card:hover {
  border-color: var(--primary);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.ticket-card-head {
  display: flex; justify-content: space-between; align-items: flex-start; gap: var(--space-3);
}
.ticket-card h3 {
  margin: 0;
  font-size: var(--fs-lg);
  font-weight: 700;
}
.ticket-card .price-tag { font-size: var(--fs-xl); }
.ticket-card-desc { color: var(--muted); font-size: var(--fs-sm); margin: 0; }
.ticket-tiers {
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  background: var(--primary-soft);
  border-radius: var(--radius);
  padding: var(--space-3) var(--space-4);
}
.ticket-tiers ul { margin: 0; padding-left: 1.2em; }
.ticket-tiers li + li { margin-top: 0.2em; }

/* =========================================================================
   Form page
   ========================================================================= */

.form-page-head {
  padding: var(--space-8) 0 var(--space-5);
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--space-8);
}

.quantity-fieldset { padding: var(--space-4) var(--space-5); }
.quantity-field { max-width: 110px; }
.quantity-field input {
  text-align: center;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--fs-lg);
  padding: 0.4em 0.6em;
}

.price-preview {
  display: flex; flex-wrap: wrap;
  align-items: baseline; gap: 0.4em var(--space-3);
  padding: var(--space-4) var(--space-5);
  background: var(--primary-soft);
  border: 1px solid color-mix(in oklab, var(--primary) 20%, var(--border));
  border-radius: var(--radius-md);
}
.price-preview .total {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 800;
  color: var(--primary);
}
.price-preview .label { font-size: var(--fs-sm); color: var(--muted); font-weight: 600; }
.price-preview .tier  { font-size: var(--fs-sm); color: var(--primary-hover); font-weight: 700; }

.participant-block {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface);
  overflow: hidden;
}
.participant-block + .participant-block { margin-top: var(--space-3); }
.participant-block > summary {
  list-style: none;
  cursor: pointer;
  padding: var(--space-4) var(--space-5);
  background: var(--bg-soft);
  font-weight: 700;
  font-size: var(--fs-sm);
  letter-spacing: -0.005em;
  color: var(--ink);
  display: flex; align-items: center; justify-content: space-between;
}
.participant-block > summary::-webkit-details-marker { display: none; }
.participant-block > summary::after {
  content: "+";
  font-size: 1.4rem;
  color: var(--primary);
  font-weight: 800;
  transition: transform var(--dur-fast) var(--ease-out);
}
.participant-block[open] > summary::after { transform: rotate(45deg); }
.participant-block-body { padding: var(--space-5); }

/* =========================================================================
   Histórico de alterações do PIX (admin)
   ========================================================================= */

.pix-history {
  margin-bottom: var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: var(--bg-soft);
  border-radius: var(--radius);
  border: 1px solid var(--border);
  font-size: var(--fs-sm);
}
.pix-history summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--ink-soft);
}
.pix-history ul { margin-top: var(--space-3); padding-left: 1.2em; }
.pix-history li + li {
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px dashed var(--border);
}

/* =========================================================================
   Comprador (pagador) opcional
   ========================================================================= */

.payer-fieldset { background: var(--surface); }
.payer-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.55em;
  cursor: pointer;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--ink);
  padding: var(--space-3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-soft);
  transition: border-color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
}
.payer-toggle:hover { border-color: var(--primary); background: var(--primary-soft); }
.payer-toggle input[type="checkbox"] { margin: 0; }
.payer-fields {
  margin-top: var(--space-2);
  padding-top: var(--space-3);
  border-top: 1px dashed var(--border);
}

/* =========================================================================
   Cupom de desconto
   ========================================================================= */

.coupon-block {
  margin-top: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}
.coupon-block summary {
  cursor: pointer;
  font-weight: 600;
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  list-style: none;
}
.coupon-block summary::-webkit-details-marker { display: none; }
.coupon-block summary:hover { color: var(--primary); }

.coupon-status {
  margin-top: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius);
  font-size: var(--fs-sm);
  line-height: 1.5;
}
.coupon-status code {
  background: rgba(255, 255, 255, 0.5);
  padding: 0.05em 0.4em;
  font-family: var(--font-mono);
}
.coupon-status-success {
  background: var(--success-soft);
  color: var(--success);
  border: 1px solid color-mix(in oklab, var(--success) 30%, transparent);
}
.coupon-status-success-strong {
  background: linear-gradient(120deg, var(--primary-soft), var(--secondary-soft));
  color: var(--primary-strong);
  border: 2px solid var(--primary);
}
.coupon-status-danger {
  background: var(--danger-soft);
  color: var(--danger);
  border: 1px solid color-mix(in oklab, var(--danger) 30%, transparent);
}
.coupon-status-info {
  background: var(--info-soft);
  color: var(--info);
  border: 1px solid color-mix(in oklab, var(--info) 30%, transparent);
}

/* =========================================================================
   Security alert (verificação de recebedor no PIX)
   ========================================================================= */

.security-alert {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: var(--space-3) var(--space-4);
  align-items: start;
  padding: var(--space-4) var(--space-5);
  background: var(--warning-soft);
  border: 1px solid color-mix(in oklab, var(--warning) 35%, var(--border));
  border-left-width: 5px;
  border-left-color: var(--warning);
  border-radius: var(--radius-md);
  color: var(--ink);
  margin-bottom: var(--space-5);
}
.security-alert-icon {
  background: var(--warning);
  color: #fff;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.security-alert ul {
  margin: var(--space-2) 0;
  padding-left: 1.2em;
  font-size: var(--fs-sm);
}
.security-alert li + li { margin-top: 0.3em; }
.security-alert small { display: block; margin-top: var(--space-2); }

/* =========================================================================
   Terms / política de aceite no formulário
   ========================================================================= */

.terms-fieldset {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  padding: var(--space-5);
}
.terms-fieldset > legend {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--fs-md);
  color: var(--ink);
}
.terms-box {
  max-height: 240px;
  overflow-y: auto;
  padding: var(--space-3) var(--space-4);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  white-space: pre-wrap;
  color: var(--ink-soft);
  font-size: var(--fs-sm);
  line-height: 1.55;
  margin-bottom: var(--space-3);
}
.terms-accept {
  display: flex;
  align-items: flex-start;
  gap: 0.6em;
  font-size: var(--fs-sm);
  color: var(--ink);
  font-weight: 600;
  cursor: pointer;
  padding: var(--space-3);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: border-color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
}
.terms-accept:hover { border-color: var(--primary); background: var(--primary-soft); }
.terms-accept input[type="checkbox"] {
  margin-top: 0.15em;
  flex-shrink: 0;
}
.terms-accept input[type="checkbox"]:checked + span {
  color: var(--primary-strong);
}

/* =========================================================================
   Payment page
   ========================================================================= */

.payment-layout {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: minmax(280px, 360px) 1fr;
  align-items: start;
  margin-top: var(--space-6);
}
@media (max-width: 880px) { .payment-layout { grid-template-columns: 1fr; } }

.qr-box {
  background: var(--surface);
  border: 2px solid var(--primary);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  text-align: center;
}
.qr-box img { width: 100%; max-width: 300px; margin: 0 auto; }
.qr-box small { display: block; margin-top: var(--space-3); }

.pix-copia {
  width: 100%;
  font-family: var(--font-mono);
  font-size: 0.76rem;
  line-height: 1.5;
  padding: var(--space-3);
  background: var(--bg-soft);
  border: 1px dashed var(--border);
  border-radius: var(--radius-sm);
  resize: none;
  color: var(--ink-soft);
}

.copy-btn { margin-top: var(--space-3); }

.summary-card dl {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: var(--space-2) var(--space-5);
  margin: 0;
}
.summary-card dt { color: var(--muted); font-size: var(--fs-sm); font-weight: 600; }
.summary-card dd { margin: 0; color: var(--ink); font-weight: 600; }
.summary-card dd.total {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 800;
  color: var(--primary);
}

/* Step number badge (1, 2 etc) na tela de pagamento */
.step-badge {
  display: inline-flex; align-items: center; justify-content: center;
  width: 1.8em; height: 1.8em;
  border-radius: 50%;
  background: var(--primary);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--fs-sm);
}

/* =========================================================================
   Badges
   ========================================================================= */

.badge {
  display: inline-flex; align-items: center; gap: 0.4em;
  padding: 0.3em 0.85em;
  border-radius: var(--radius-pill);
  background: var(--bg-soft);
  color: var(--ink-soft);
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  border: 1px solid var(--border);
}
.badge-published, .badge-confirmed { background: var(--success-soft); color: var(--success); border-color: transparent; }
.badge-draft   { background: var(--bg-soft); color: var(--muted); }
.badge-closed  { background: var(--danger-soft); color: var(--danger); border-color: transparent; }
.badge-pending { background: var(--warning-soft); color: var(--warning); border-color: transparent; }
.badge-review  { background: var(--info-soft); color: var(--info); border-color: transparent; }
.badge-rejected{ background: var(--danger-soft); color: var(--danger); border-color: transparent; }
.badge-canceled{ background: var(--bg-soft); color: var(--muted); }

/* =========================================================================
   Date range field
   ========================================================================= */

.daterange { margin: 0; }
.daterange-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: var(--space-3) var(--space-4);
  align-items: end;
}
@media (max-width: 600px) {
  .daterange-grid { grid-template-columns: 1fr; }
  .daterange-arrow { display: none; }
}
.daterange-arrow {
  font-size: 1.3rem;
  color: var(--muted);
  padding-bottom: 0.8em;
  text-align: center;
}

/* =========================================================================
   Question editor (Google Forms-like)
   ========================================================================= */

.qsection { margin-top: var(--space-7); }
.qsection-head { margin-bottom: var(--space-4); }
.qsection-head h3 {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 700;
  margin: 0 0 var(--space-2);
}

.qlist { display: grid; gap: var(--space-3); margin-bottom: var(--space-4); }

.qcard {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-3);
  align-items: start;
  transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
  scroll-margin-top: var(--space-5);
}
.qsection { scroll-margin-top: var(--space-5); }
.qcard:target,
.qcard-new:target,
.qsection:target .qcard-new {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--primary) 14%, transparent);
  animation: qcard-pulse 1.6s var(--ease-out);
}
@keyframes qcard-pulse {
  0%   { background: color-mix(in oklab, var(--primary) 8%, var(--surface)); }
  100% { background: var(--surface); }
}
.qcard:hover { border-color: var(--border); box-shadow: var(--shadow-sm); }
.qcard:focus-within { border-color: var(--primary); box-shadow: 0 0 0 3px color-mix(in oklab, var(--primary) 14%, transparent); }

.qcard-form { display: grid; gap: var(--space-3); }

.qcard-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 180px;
  gap: var(--space-3);
}
@media (max-width: 600px) {
  .qcard-row { grid-template-columns: 1fr; }
}

input.qcard-label {
  border: none;
  border-bottom: 1px solid var(--border);
  border-radius: 0;
  padding: 0.4em 0;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--fs-md);
  background: transparent;
  color: var(--ink);
}
input.qcard-label:focus {
  outline: none;
  border-bottom-color: var(--primary);
  box-shadow: 0 1px 0 0 var(--primary);
}
input.qcard-label::placeholder { color: var(--muted-soft); font-weight: 500; }

select.qcard-type {
  background: var(--bg-soft);
  border-color: transparent;
  font-weight: 600;
  font-size: var(--fs-sm);
  padding: 0.5em 0.8em;
}
select.qcard-type:focus {
  background: var(--surface);
  border-color: var(--primary);
}

.qcard-advanced summary {
  cursor: pointer;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--muted);
  padding: var(--space-1) 0;
  list-style: none;
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  user-select: none;
}
.qcard-advanced summary::before {
  content: "▸";
  display: inline-block;
  transition: transform var(--dur-fast) var(--ease-out);
  color: var(--muted-soft);
}
.qcard-advanced[open] summary::before { transform: rotate(90deg); }
.qcard-advanced summary:hover { color: var(--primary); }

.qcard-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding-top: var(--space-2);
  border-top: 1px solid var(--border-soft);
}

.qcard-required {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--ink-soft);
  cursor: pointer;
}

.qcard-delete { display: flex; align-items: flex-start; }
.qcard-delete-btn {
  background: transparent;
  border: 1px solid transparent;
  color: var(--muted);
  padding: 0.5em;
  border-radius: var(--radius);
  cursor: pointer;
  transition: color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  display: inline-flex;
  align-items: center;
}
.qcard-delete-btn:hover {
  color: var(--danger);
  background: var(--danger-soft);
  border-color: var(--danger-soft);
}

/* Add-question compact form */
.qcard-new {
  background: var(--bg-soft);
  border: 2px dashed var(--border);
}
.qcard-new:focus-within {
  background: var(--surface);
  border-color: var(--primary);
  border-style: solid;
}
.qcard-new .qcard-label { background: transparent; }
.qcard-add-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding-top: var(--space-2);
  border-top: 1px solid var(--border-soft);
}

/* Choices (options) editor */
.qcard-choices {
  background: var(--bg-soft);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius);
  padding: var(--space-3) var(--space-4);
  display: grid;
  gap: var(--space-2);
}
.qcard-new .qcard-choices { background: var(--surface); }

.qcard-options {
  display: grid;
  gap: var(--space-2);
}
.qcard-option {
  display: grid;
  grid-template-columns: 1.4em 1fr auto;
  align-items: center;
  gap: var(--space-3);
}
.qcard-option-marker {
  font-size: 1.05em;
  color: var(--muted);
  text-align: center;
  line-height: 1;
  user-select: none;
}
.qcard-option input[type="text"] {
  border: none;
  background: transparent;
  border-bottom: 1px solid transparent;
  border-radius: 0;
  padding: 0.35em 0.2em;
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--ink);
}
.qcard-option input[type="text"]:focus {
  outline: none;
  border-bottom-color: var(--primary);
  box-shadow: none;
}
.qcard-option input[type="text"]:read-only {
  color: var(--muted);
  font-style: italic;
}
.qcard-option-other input[readonly] {
  cursor: default;
}
.qcard-option-remove {
  background: transparent;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 1.2rem;
  line-height: 1;
  width: 1.6em;
  height: 1.6em;
  border-radius: var(--radius-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}
.qcard-option-remove:hover {
  background: var(--danger-soft);
  color: var(--danger);
}
.qcard-options-actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-top: var(--space-2);
  padding-top: var(--space-2);
  border-top: 1px dashed var(--border);
}

/* =========================================================================
   Filtros (admin: pedidos e inscritos)
   ========================================================================= */

.filters-bar {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
}
.filters-grid {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: minmax(220px, 2fr) minmax(160px, 1fr) minmax(160px, 1fr) auto;
  align-items: end;
}
@media (max-width: 880px) {
  .filters-grid { grid-template-columns: 1fr 1fr; }
  .filters-actions { grid-column: 1 / -1; justify-self: start; }
}
@media (max-width: 520px) {
  .filters-grid { grid-template-columns: 1fr; }
}
.filters-actions {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

/* =========================================================================
   Tables (admin)
   ========================================================================= */

.table-wrap {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
table.data {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-sm);
}
table.data th, table.data td {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  border-bottom: 1px solid var(--border-soft);
  vertical-align: middle;
}
table.data th {
  background: var(--bg-soft);
  font-weight: 700;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
}
table.data tr:last-child td { border-bottom: none; }
table.data tr:hover td { background: var(--surface-2); }

/* =========================================================================
   Empty state
   ========================================================================= */

.empty-state {
  text-align: center;
  padding: var(--space-10) var(--space-5);
  border: 2px dashed var(--border);
  border-radius: var(--radius-lg);
  background: var(--bg-soft);
  color: var(--muted);
}
.empty-state h3 { color: var(--ink); margin-bottom: var(--space-2); }

/* =========================================================================
   Auth (login)
   ========================================================================= */

.auth-body {
  min-height: 100vh;
  display: grid; place-items: center;
  background:
    radial-gradient(60% 50% at 80% 10%, var(--primary-soft) 0%, transparent 60%),
    radial-gradient(45% 40% at 5% 95%, var(--secondary-soft) 0%, transparent 60%),
    var(--bg);
  padding: var(--space-5);
  font-family: var(--font-body);
}
.auth-card {
  width: min(440px, 100%);
  background: var(--surface);
  border: 1px solid var(--border);
  padding: clamp(2rem, 4vw, 3rem);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
}
.auth-card h1 {
  font-size: var(--fs-2xl);
  font-weight: 800;
  margin-bottom: var(--space-1);
}
.auth-subtitle { color: var(--muted); margin-bottom: var(--space-6); }

/* =========================================================================
   Admin shell
   ========================================================================= */

.admin-shell { min-height: 100vh; display: grid; grid-template-rows: auto 1fr; background: var(--bg-soft); }
.admin-nav {
  background: var(--ink);
  color: #fff;
  padding: var(--space-3) clamp(1rem, 4vw, 2rem);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-3);
}
.admin-nav .brand { color: #fff; }
.admin-nav .brand:hover { color: var(--primary-soft); }
.admin-nav-links { display: flex; gap: var(--space-5); }
.admin-nav-links a { color: rgba(255, 255, 255, 0.75); font-size: var(--fs-sm); font-weight: 600; }
.admin-nav-links a:hover { color: #fff; }
.admin-nav-user { display: flex; align-items: center; gap: var(--space-3); font-size: var(--fs-sm); color: rgba(255, 255, 255, 0.75); }
.admin-nav-user form { margin: 0; }
.admin-nav-user button {
  background: transparent; color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.2);
  padding: 0.45em 1em;
  border-radius: var(--radius);
  font: 700 var(--fs-sm) var(--font-body);
  cursor: pointer;
}
.admin-nav-user button:hover { background: var(--primary); border-color: var(--primary); }

.admin-main { padding: var(--space-7) 0 var(--space-12); }
.admin-page-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: var(--space-4); margin-bottom: var(--space-6); flex-wrap: wrap;
}
.admin-page-head h1 { font-size: var(--fs-2xl); margin: 0 0 var(--space-1); }

/* =========================================================================
   Utilities
   ========================================================================= */

.flex { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; }
.flex-between { display: flex; justify-content: space-between; align-items: center; gap: var(--space-3); flex-wrap: wrap; }
.stack-2 { display: grid; gap: var(--space-2); }
.stack-3 { display: grid; gap: var(--space-3); }
.stack-4 { display: grid; gap: var(--space-4); }
.stack-5 { display: grid; gap: var(--space-5); }

.mt-2 { margin-top: var(--space-2); }
.mt-3 { margin-top: var(--space-3); }
.mt-4 { margin-top: var(--space-4); }
.mt-5 { margin-top: var(--space-5); }
.mt-6 { margin-top: var(--space-6); }
.mt-8 { margin-top: var(--space-8); }
.mb-3 { margin-bottom: var(--space-3); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-5 { margin-bottom: var(--space-5); }
.text-right { text-align: right; }
.no-margin { margin: 0; }

/* =========================================================================
   Motion preferences
   ========================================================================= */

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}
