:root {
  --page: #fbfcff;
  --ink: #11131a;
  --ink-soft: #343948;
  --muted: #757b8c;
  --line: #e8ebf2;
  --surface: #ffffff;
  --surface-2: #f4f7fb;
  --teal: #0a8f82;
  --teal-dark: #05665e;
  --coral: #ff6148;
  --blue: #2f68ff;
  --violet: #7c5cff;
  --gold: #f4b942;
  --danger: #bd2d21;
  --ok: #0d8a55;
  --radius: 8px;
  --shadow-sm: 0 8px 24px rgba(17, 19, 26, .07);
  --shadow-md: 0 18px 55px rgba(24, 31, 54, .13);
  --shadow-lg: 0 32px 90px rgba(24, 31, 54, .18);
}

* { box-sizing: border-box; }
html { min-height: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100%;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background:
    linear-gradient(180deg, #ffffff 0, #f7f9fd 42rem, #ffffff 100%);
  letter-spacing: 0;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
img { display: block; max-width: 100%; }
input, select, textarea { font-weight: 400; }

.app-shell { min-height: 100vh; }
.app-shell.is-ajax-loading {
  cursor: progress;
}
.app-shell.is-ajax-loading .page {
  opacity: .64;
  transition: opacity .16s ease;
}
.ajax-shell-message {
  margin-bottom: 16px;
}
.page {
  width: min(1240px, calc(100% - 40px));
  margin: 28px auto 96px;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 14px max(20px, calc((100vw - 1240px) / 2));
  background: rgba(255, 255, 255, .86);
  border-bottom: 1px solid rgba(232, 235, 242, .86);
  backdrop-filter: blur(20px);
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  font-weight: 950;
  font-size: 18px;
}
.brand-mark {
  position: relative;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  overflow: hidden;
  color: #fff;
  border-radius: 13px;
  background:
    linear-gradient(135deg, #0a8f82 0%, #1c8ad8 52%, #ff7a32 100%);
  box-shadow: 0 14px 26px rgba(10, 143, 130, .22);
}
.brand-mark::after {
  content: "";
  position: absolute;
  inset: 1px;
  border: 1px solid rgba(255,255,255,.34);
  border-radius: 12px;
  pointer-events: none;
}
.brand-mark span {
  position: relative;
  z-index: 1;
  color: #fff;
  font-size: 16px;
  font-weight: 950;
  line-height: 1;
  letter-spacing: 0;
}
.main-nav {
  display: flex;
  align-items: center;
  gap: 4px;
  color: var(--muted);
  font-size: 14px;
  font-weight: 800;
}
.main-nav a {
  padding: 10px 12px;
  border-radius: var(--radius);
}
.main-nav a:hover {
  color: var(--ink);
  background: var(--surface-2);
}
.top-actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 10px;
}
.user-pill, .badge {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 5px 11px;
  border-radius: 999px;
  color: var(--teal-dark);
  background: #e9f8f5;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}
.badge.status-ok {
  color: #05623f;
  background: #e5f8ef;
}
.badge.status-warn {
  color: #8a5a00;
  background: #fff5d8;
}
.badge.status-danger {
  color: #a32b21;
  background: #ffe9e5;
}
.badge.status-info {
  color: #2351b8;
  background: #e9efff;
}
.badge.status-neutral {
  color: var(--ink-soft);
  background: var(--surface-2);
}
.impersonation-bar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 10px 18px;
  color: #fff;
  background: #151820;
}
.impersonation-bar form { margin: 0; }

.primary-button, .ghost-button, .link-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 11px 16px;
  border-radius: var(--radius);
  border: 0;
  font-size: 14px;
  font-weight: 950;
  line-height: 1;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}
.primary-button {
  color: #fff;
  background: linear-gradient(135deg, var(--teal), var(--blue));
  box-shadow: 0 14px 30px rgba(10, 143, 130, .24);
}
.ghost-button {
  color: var(--ink);
  background: #fff;
  border: 1px solid var(--line);
}
.link-button {
  min-height: 0;
  padding: 0;
  color: #fff;
  background: transparent;
  text-decoration: underline;
}
.primary-button:hover, .ghost-button:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

.hero-panel {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 520px);
  gap: clamp(28px, 6vw, 72px);
  align-items: center;
  min-height: 620px;
  padding: clamp(28px, 7vw, 84px);
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, #ffffff 0%, #f4fbff 48%, #fff3ef 100%);
  box-shadow: var(--shadow-lg);
}
.hero-panel::before {
  content: "";
  position: absolute;
  inset: auto -10% -42% 42%;
  height: 70%;
  background: linear-gradient(135deg, rgba(10,143,130,.16), rgba(47,104,255,.14), rgba(255,97,72,.12));
  transform: rotate(-7deg);
  border-radius: 48px;
  filter: blur(12px);
}
.hero-copy, .hero-visual { position: relative; z-index: 1; min-width: 0; }
.hero-copy p, .event-summary p { overflow-wrap: break-word; }
.hero-copy h1, .event-summary h1, .empty-state h1 {
  margin: 0;
  max-width: 760px;
  font-size: clamp(42px, 7vw, 82px);
  line-height: .92;
  letter-spacing: 0;
}
.hero-copy p, .event-summary p {
  max-width: 620px;
  margin: 22px 0 0;
  color: var(--ink-soft);
  font-size: clamp(17px, 2vw, 21px);
  line-height: 1.55;
}
.hero-controls {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(170px, .8fr);
  gap: 12px;
  width: min(620px, 100%);
  margin-top: 34px;
  padding: 10px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(232,235,242,.9);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.hero-controls.region-city-controls {
  grid-template-columns: minmax(150px, .78fr) minmax(220px, 1.08fr) minmax(170px, .72fr);
}
.hero-controls .primary-button { min-height: 54px; }
.city-picker {
  display: grid;
  gap: 6px;
}
.city-picker label, .stack-form label, .form-grid label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}
.field-with-hint span,
.file-button-field span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.35;
  text-transform: none;
}
.file-button-field input[type="file"] {
  padding: 8px;
  cursor: pointer;
}
.file-button-field input[type="file"]::file-selector-button {
  min-height: 42px;
  margin-right: 12px;
  padding: 10px 16px;
  color: #fff;
  background: linear-gradient(135deg, var(--teal), var(--blue));
  border: 0;
  border-radius: 12px;
  font-weight: 900;
  cursor: pointer;
}
input, select, textarea {
  width: 100%;
  min-height: 42px;
  padding: 11px 12px;
  color: var(--ink);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  outline: none;
  box-shadow: none;
}
select {
  appearance: none;
  padding-right: 42px;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--teal-dark) 50%),
    linear-gradient(135deg, var(--teal-dark) 50%, transparent 50%);
  background-position:
    calc(100% - 20px) 19px,
    calc(100% - 14px) 19px;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}
textarea { resize: vertical; }
input:focus, select:focus, textarea:focus {
  border-color: rgba(10,143,130,.55);
  box-shadow: 0 0 0 4px rgba(10,143,130,.11);
}
.city-search-field {
  position: relative;
}
.city-suggestions {
  position: absolute;
  z-index: 40;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  display: none;
  max-height: 310px;
  overflow: auto;
  padding: 8px;
  background: rgba(255,255,255,.98);
  border: 1px solid rgba(232,235,242,.96);
  border-radius: 14px;
  box-shadow: var(--shadow-md);
}
.city-suggestions.is-open {
  display: grid;
  gap: 6px;
}
.city-suggestion {
  display: grid;
  gap: 3px;
  width: 100%;
  padding: 11px 12px;
  color: var(--ink);
  text-align: left;
  background: transparent;
  border: 0;
  border-radius: 10px;
}
.city-suggestion:hover,
.city-suggestion:focus {
  background: #f0f8fb;
  outline: none;
}
.city-suggestion strong {
  font-size: 15px;
  line-height: 1.1;
}
.city-suggestion span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}
.city-suggestion-empty {
  padding: 12px;
  color: var(--muted);
  font-size: 14px;
}
button:disabled,
select:disabled {
  cursor: not-allowed;
  opacity: .55;
}

.hero-visual {
  display: grid;
  gap: 14px;
  transform: rotate(1.5deg);
}
.hero-feature {
  position: relative;
  min-height: 330px;
  padding: 22px;
  color: #fff;
  overflow: hidden;
  border-radius: var(--radius);
  background: #171b25;
  box-shadow: var(--shadow-lg);
}
.hero-feature::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(17,19,26,.12), rgba(17,19,26,.68)),
    var(--hero-poster, linear-gradient(135deg, #0a8f82, #2f68ff));
  background-size: cover;
  background-position: center;
}
.hero-feature > * { position: relative; z-index: 1; }
.hero-feature h2 {
  margin: 150px 0 10px;
  max-width: 360px;
  font-size: 34px;
  line-height: 1;
}
.hero-feature p { margin: 0; color: rgba(255,255,255,.78); }
.mini-ticket {
  display: grid;
  grid-template-columns: 1fr 86px;
  gap: 16px;
  align-items: center;
  margin-left: 42px;
  padding: 16px;
  color: var(--ink);
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(232,235,242,.9);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
}
.mini-qr {
  width: 86px;
  aspect-ratio: 1;
  border-radius: 6px;
  background:
    linear-gradient(90deg, #111 10%, transparent 10% 20%, #111 20% 30%, transparent 30% 42%, #111 42% 52%, transparent 52% 64%, #111 64% 76%, transparent 76%),
    linear-gradient(#111 10%, transparent 10% 20%, #111 20% 30%, transparent 30% 42%, #111 42% 52%, transparent 52% 64%, #111 64% 76%, transparent 76%);
  background-size: 20px 20px;
  background-color: #fff;
  border: 8px solid #fff;
  box-shadow: inset 0 0 0 1px var(--line);
}

.home-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(360px, .74fr);
  gap: clamp(34px, 6vw, 86px);
  align-items: center;
  min-height: 590px;
  padding: clamp(34px, 7vw, 86px);
  overflow: hidden;
  border-radius: 28px;
  background:
    radial-gradient(circle at 82% 18%, rgba(244,185,66,.26), transparent 28%),
    radial-gradient(circle at 70% 86%, rgba(47,104,255,.16), transparent 34%),
    linear-gradient(135deg, #ffffff 0%, #f1fbff 56%, #fff7ee 100%);
  border: 1px solid rgba(210, 223, 237, .82);
  box-shadow: 0 34px 100px rgba(24, 31, 54, .13);
}
.home-hero::before {
  content: "";
  position: absolute;
  inset: auto -12% -35% 45%;
  height: 68%;
  background: linear-gradient(135deg, rgba(10,143,130,.18), rgba(47,104,255,.16), rgba(255,97,72,.13));
  border-radius: 44px;
  transform: rotate(-8deg);
  filter: blur(10px);
}
.home-hero-copy,
.home-feature-stack {
  position: relative;
  z-index: 1;
}
.home-hero-copy h1 {
  max-width: 720px;
  margin: 0;
  font-size: clamp(48px, 7.3vw, 86px);
  font-weight: 760;
  line-height: .94;
  letter-spacing: 0;
}
.home-hero-copy p {
  max-width: 610px;
  margin: 22px 0 0;
  color: var(--ink-soft);
  font-size: clamp(18px, 2vw, 22px);
  line-height: 1.55;
}
.home-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 32px;
}
.home-hero-actions .primary-button,
.home-hero-actions .ghost-button {
  min-height: 54px;
  padding-inline: 22px;
}
.home-location-line {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-top: 24px;
  color: var(--muted);
  font-size: 15px;
}
.home-location-line strong {
  color: var(--ink);
}
.home-location-line a {
  color: var(--teal-dark);
  font-weight: 850;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.home-feature-stack {
  display: grid;
  gap: 18px;
}
.home-feature-card {
  position: relative;
  display: flex;
  min-height: 0;
  aspect-ratio: 1.56;
  flex-direction: column;
  justify-content: flex-end;
  overflow: hidden;
  padding: 28px;
  color: #fff;
  border-radius: 22px;
  background: #151820;
  box-shadow: 0 28px 72px rgba(24, 31, 54, .2);
  transform: rotate(1.2deg);
}
.home-feature-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(17,19,26,.02) 0%, rgba(17,19,26,.22) 42%, rgba(17,19,26,.76) 100%),
    var(--feature-poster);
  background-position: center;
  background-size: cover;
  transition: transform .35s ease;
}
.home-feature-card:hover::before {
  transform: scale(1.04);
}
.home-feature-card > * {
  position: relative;
  z-index: 1;
}
.home-feature-date {
  align-self: flex-start;
  margin-bottom: 12px;
  padding: 7px 10px;
  color: #11131a;
  background: rgba(255,255,255,.88);
  border-radius: 999px;
  font-size: 13px;
  font-weight: 850;
}
.home-feature-card strong {
  max-width: 440px;
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.02;
}
.home-feature-card span:last-child {
  margin-top: 10px;
  color: rgba(255,255,255,.82);
  font-size: 16px;
}
.home-qr-card {
  display: grid;
  grid-template-columns: 1fr 86px;
  gap: 18px;
  align-items: center;
  width: min(440px, calc(100% - 32px));
  margin-left: auto;
  padding: 18px;
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(232,235,242,.95);
  border-radius: 20px;
  box-shadow: var(--shadow-md);
}
.home-qr-card strong {
  display: block;
  font-size: 18px;
}
.home-qr-card span:not(.mini-qr) {
  display: block;
  margin-top: 6px;
  color: var(--muted);
  line-height: 1.45;
}
.home-city-strip {
  display: grid;
  grid-template-columns: minmax(220px, .36fr) minmax(0, 1fr);
  gap: 22px;
  align-items: center;
  margin: 26px 0 34px;
  padding: 18px 20px;
  background: rgba(255,255,255,.76);
  border: 1px solid var(--line);
  border-radius: 20px;
  box-shadow: 0 12px 36px rgba(24,31,54,.08);
}
.home-city-strip strong {
  display: block;
  font-size: 18px;
}
.home-city-strip span {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 14px;
}
.home-city-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}
.home-city-chips a {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 10px 15px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 999px;
  box-shadow: 0 8px 18px rgba(17,19,26,.04);
  color: var(--ink);
  font-size: 14px;
  font-weight: 850;
}
.home-city-chips a:hover {
  border-color: rgba(10,143,130,.48);
  transform: translateY(-1px);
}
.city-modal {
  position: fixed;
  z-index: 80;
  inset: 0;
  display: none;
  place-items: center;
  padding: 24px;
}
.city-modal:target,
.city-modal.is-open {
  display: grid;
}
.city-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 16, 28, .5);
  backdrop-filter: blur(10px);
}
.city-dialog {
  position: relative;
  width: min(760px, 100%);
  max-height: min(760px, calc(100vh - 48px));
  overflow: visible;
  padding: clamp(22px, 4vw, 34px);
  background: rgba(255,255,255,.98);
  border: 1px solid rgba(232,235,242,.96);
  border-radius: 26px;
  box-shadow: 0 34px 100px rgba(4, 10, 24, .28);
}
.city-dialog .panel-title-row {
  align-items: flex-start;
}
.city-dialog .city-modal-close {
  flex: 0 0 auto;
}
.city-dialog h2 {
  margin: 0;
  font-size: clamp(32px, 5vw, 52px);
  line-height: 1;
}
.city-modal-form {
  display: grid;
  grid-template-columns: minmax(190px, .8fr) minmax(220px, 1fr) auto;
  gap: 12px;
  align-items: end;
  margin-top: 28px;
}
.city-modal-form label {
  display: grid;
  gap: 8px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}
.city-modal-form .primary-button {
  min-height: 50px;
  padding-inline: 20px;
}

.section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 20px;
  margin: 46px 0 18px;
}
.section-head h1, .section-head h2 {
  margin: 0;
  font-size: clamp(30px, 4vw, 52px);
  line-height: .96;
}
.section-head p, .muted { color: var(--muted); }
.section-head p { margin: 10px 0 0; }

.city-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 12px;
  margin-bottom: 28px;
}
.city-card {
  display: grid;
  gap: 8px;
  padding: 18px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.city-card:hover { border-color: rgba(10,143,130,.45); transform: translateY(-1px); }
.city-card strong { font-size: 18px; }
.city-card span { color: var(--muted); }
.city-compact-panel {
  display: grid;
  grid-template-columns: minmax(260px, .74fr) minmax(0, 1fr);
  gap: 22px;
  align-items: start;
  margin: 34px 0 30px;
  padding: 22px;
  background: rgba(255,255,255,.86);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.city-compact-panel h2 {
  margin: 0;
  font-size: clamp(24px, 3vw, 38px);
  line-height: 1.04;
}
.city-compact-panel p {
  max-width: 520px;
  margin: 10px 0 0;
  color: var(--muted);
  line-height: 1.55;
}
.popular-city-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}
.city-chip {
  display: inline-grid;
  gap: 2px;
  min-width: 150px;
  padding: 12px 14px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 999px;
  box-shadow: 0 8px 18px rgba(17,19,26,.04);
}
.city-chip:hover {
  border-color: rgba(10,143,130,.5);
  transform: translateY(-1px);
}
.city-chip strong {
  font-size: 15px;
  line-height: 1.1;
}
.city-chip span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.1;
}

.event-grid, .ticket-grid, .metric-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 18px;
}
.event-card, .ticket-card, .metric {
  overflow: hidden;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.event-card {
  display: grid;
  min-height: 420px;
  grid-template-rows: 220px 1fr;
}
.event-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: rgba(47,104,255,.28);
}
.event-card.plain { min-height: auto; grid-template-rows: 1fr; }
.poster, .event-cover {
  background:
    linear-gradient(160deg, rgba(17,19,26,.05), rgba(17,19,26,.18)),
    url("/assets/img/demo/poster-festival.svg");
  background-position: center;
  background-size: cover;
}
.event-body {
  display: grid;
  gap: 9px;
  padding: 18px;
}
.event-body strong {
  font-size: 22px;
  line-height: 1.08;
}
.event-date {
  color: var(--coral);
  font-size: 13px;
  font-weight: 950;
}
.price {
  align-self: end;
  color: var(--teal-dark);
  font-size: 20px;
  font-weight: 950;
}

.event-hero {
  display: grid;
  grid-template-columns: minmax(280px, 520px) minmax(0, 1fr);
  min-height: 520px;
  overflow: hidden;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
}
.event-cover { min-height: 520px; }
.event-summary {
  display: grid;
  align-content: center;
  padding: clamp(28px, 6vw, 72px);
}
.eyebrow {
  margin: 0 0 12px;
  color: var(--coral);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0;
  text-transform: uppercase;
}
.content-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 34px;
  align-items: start;
  justify-content: start;
  margin-top: 26px;
}
.prose {
  color: var(--ink-soft);
  font-size: 17px;
  line-height: 1.7;
}
.prose h2, .prose h3 { color: var(--ink); }
.ticket-panel {
  position: static;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  width: 100%;
  margin-top: 8px;
}
.ticket-panel > h2,
.ticket-panel > .alert {
  grid-column: 1 / -1;
}
.ticket-buy {
  display: grid;
  min-width: 0;
  gap: 14px;
  padding: 18px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.ticket-buy.has-seat-picker {
  grid-column: 1 / -1;
}
.ticket-buy.has-seat-picker .public-seat-map {
  max-width: 980px;
}
.ticket-buy.has-seat-picker .public-seat-dot {
  width: 24px;
  height: 24px;
  font-size: 10px;
}
.ticket-image {
  display: block;
  width: 100%;
  max-height: 220px;
  margin-bottom: 12px;
  object-fit: cover;
  border-radius: 16px;
  border: 1px solid var(--line);
}
.ticket-buy h3 { margin: 8px 0 4px; font-size: 20px; }
.ticket-buy p { margin: 0; color: var(--muted); line-height: 1.45; }
.buy-controls {
  display: grid;
  grid-template-columns: 1fr 88px;
  gap: 10px;
  align-items: center;
}
.buy-controls strong { font-size: 26px; }
.buyer-fields { display: grid; gap: 8px; }
.ticket-goods-public {
  display: grid;
  gap: 12px;
  margin-top: 14px;
  padding: 14px;
  background: #f8fbff;
  border: 1px solid var(--line);
  border-radius: 16px;
}
.ticket-goods-public strong {
  display: block;
  margin-bottom: 6px;
  color: var(--ink);
}
.ticket-goods-public p {
  margin: 4px 0 0;
}
.optional-goods {
  display: grid;
  gap: 8px;
}
.optional-goods label {
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  cursor: pointer;
}
.optional-goods span {
  color: var(--ink-soft);
  font-weight: 800;
  line-height: 1.35;
}
.optional-goods input:disabled + span {
  color: var(--muted);
}
.form-result { min-height: 20px; color: var(--danger); font-weight: 900; }
.participant-fields {
  display: grid;
  gap: 12px;
  padding: 14px;
  background: #f6fafc;
  border: 1px solid var(--line);
  border-radius: 14px;
}
.participant-title {
  color: var(--ink);
  font-size: 15px;
  font-weight: 900;
}
.participant-card {
  display: grid;
  gap: 10px;
  padding: 12px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
}
.participant-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
}
.seat-picker {
  display: grid;
  gap: 10px;
  margin-top: 14px;
  padding: 14px;
  background: #f8fbff;
  border: 1px solid var(--line);
  border-radius: 14px;
}
.seat-picker-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-size: 14px;
}
.seat-picker-head span {
  color: var(--muted);
  font-weight: 700;
}
.public-seat-map {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
}
.public-seat-map img {
  width: 100%;
  height: auto;
}
.public-seat-dot,
.hall-seat-dot {
  position: absolute;
  transform: translate(-50%, -50%);
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  min-height: 0;
  padding: 0;
  color: #fff;
  background: var(--teal);
  border: 2px solid #fff;
  border-radius: 999px;
  box-shadow: 0 7px 16px rgba(15,23,42,.2);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
}
.public-seat-dot {
  width: 22px;
  height: 22px;
  font-size: 9px;
  border-width: 1px;
}
.public-seat-dot.is-busy {
  color: #fff;
  background: #9aa6b8;
  opacity: .72;
}
.public-seat-dot.is-selected {
  background: var(--coral);
  box-shadow: 0 9px 20px rgba(255,97,72,.32);
}
.seat-quantity-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 10px 12px;
  color: var(--teal-dark);
  background: #e9f8f5;
  border: 1px solid rgba(10,143,130,.18);
  border-radius: var(--radius);
  font-weight: 800;
}

.panel, .auth-card, .scanner-panel, .scan-result {
  padding: clamp(22px, 4vw, 38px);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.auth-card {
  width: min(520px, 100%);
  margin: 72px auto;
}
.auth-card.wide { width: min(760px, 100%); }
.stack-form { display: grid; gap: 15px; }
.form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}
.embed-code-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
}
.embed-code-grid label {
  display: grid;
  gap: 10px;
  align-content: start;
}
.embed-code {
  min-height: 104px;
  font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
  font-size: 13px;
  line-height: 1.5;
  resize: vertical;
}
.embed-panel .compact-button {
  width: fit-content;
}
.segmented, .check-row, .button-row, .inline-form {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}
.segmented {
  padding: 6px;
  background: var(--surface-2);
  border-radius: var(--radius);
}
.segmented label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 11px;
  color: var(--ink);
  background: #fff;
  border-radius: var(--radius);
  font-weight: 900;
}
.segmented input, .check-row input { width: auto; min-height: 0; }
.check-row label {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 44px;
  padding: 10px 14px;
  color: var(--ink-soft);
  background: #f7fafc;
  border: 1px solid var(--line);
  border-radius: 12px;
  font-weight: 850;
  cursor: pointer;
  user-select: none;
}
.check-row label:has(input[type="checkbox"]:checked) {
  color: var(--teal-dark);
  background: #edfdfa;
  border-color: rgba(10,143,130,.42);
}
input[type="checkbox"] {
  appearance: none;
  position: relative;
  flex: 0 0 auto;
  width: 22px;
  height: 22px;
  min-width: 22px;
  min-height: 22px;
  margin: 0;
  padding: 0;
  background: #fff;
  border: 2px solid #b9c6d8;
  border-radius: 6px;
  cursor: pointer;
  z-index: 1;
}
input[type="checkbox"]:checked {
  background:
    linear-gradient(135deg, rgba(255,255,255,0) 0 100%),
    var(--blue);
  border-color: var(--blue);
  box-shadow: inset 0 0 0 4px var(--blue);
}
input[type="checkbox"]:checked::after {
  content: "";
  display: block;
  width: 7px;
  height: 12px;
  margin: 2px 0 0 6px;
  border: solid #fff;
  border-width: 0 3px 3px 0;
  transform: rotate(45deg);
}
input[type="checkbox"]:focus {
  outline: none;
  box-shadow: 0 0 0 4px rgba(47,104,255,.16);
}
.alert {
  padding: 14px 16px;
  color: #8a2b1f;
  background: #fff1ed;
  border: 1px solid #ffd5ca;
  border-radius: var(--radius);
  font-weight: 850;
}
.empty-state {
  display: grid;
  justify-items: center;
  gap: 14px;
  padding: 72px 20px;
  text-align: center;
}
.empty-state.compact {
  padding: 46px 20px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
}
.table-wrap { width: 100%; overflow-x: auto; }
table {
  width: 100%;
  min-width: 760px;
  border-collapse: collapse;
}
th, td {
  padding: 14px 12px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: top;
}
th {
  color: var(--muted);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}
.dashboard-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, auto);
  gap: 24px;
  align-items: center;
}
.dashboard-hero h1 {
  margin: 0;
  font-size: clamp(38px, 5vw, 64px);
  line-height: 1;
}
.dashboard-hero p {
  margin: 12px 0 0;
  color: var(--muted);
  font-size: 18px;
}
.dashboard-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
  align-items: end;
}
.dashboard-event-switch {
  min-width: min(100%, 360px);
}
.dashboard-event-switch label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}
.dashboard-metrics {
  margin: 22px 0;
  grid-template-columns: repeat(5, minmax(0, 1fr));
}
.dashboard-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.75fr) minmax(330px, .85fr);
  gap: 22px;
  align-items: start;
  margin-top: 22px;
}
.dashboard-layout-wide {
  grid-template-columns: minmax(0, 1.35fr) minmax(330px, .75fr);
}
.dashboard-panel {
  min-width: 0;
}
.dashboard-table {
  min-width: 860px;
}
.dashboard-sales-table {
  min-width: 680px;
}
.dashboard-table td {
  vertical-align: middle;
}
.dashboard-event-row td {
  background: #f8fbff;
  font-weight: 800;
}
.dashboard-category-row td {
  background: #fff;
}
.dashboard-ticket-row td {
  padding-top: 12px;
  padding-bottom: 12px;
  background: #f8fbff;
}
.dashboard-ticket-row td:first-child {
  padding-left: 46px;
}
.dashboard-ticket-row.is-hidden {
  display: none;
}
.dashboard-drill-link {
  color: var(--ink);
  font-weight: 900;
}
.dashboard-drill-link:hover {
  color: var(--teal-dark);
}
.dashboard-toggle {
  display: inline-grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  width: 100%;
  padding: 0;
  color: var(--ink);
  background: transparent;
  border: 0;
  text-align: left;
  cursor: pointer;
}
.dashboard-toggle:disabled {
  cursor: default;
}
.dashboard-toggle strong,
.dashboard-drill-link {
  display: block;
}
.dashboard-toggle-icon {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  color: var(--teal-dark);
  background: #e7f7f4;
  border-radius: 999px;
  font-size: 22px;
  font-weight: 900;
  line-height: 1;
  transition: transform .18s ease, background .18s ease;
}
.dashboard-toggle[aria-expanded="true"] .dashboard-toggle-icon {
  transform: rotate(90deg);
  background: #d8f1ed;
}
.dashboard-toggle:disabled .dashboard-toggle-icon {
  color: var(--muted);
  background: #edf2f7;
}
.dashboard-row-actions {
  gap: 8px;
}
.dashboard-top-list,
.dashboard-stock-list {
  display: grid;
  gap: 10px;
}
.dashboard-top-list a,
.dashboard-stock-list a {
  display: grid;
  gap: 5px;
  padding: 14px;
  background: #f8fbff;
  border: 1px solid var(--line);
  border-radius: 14px;
}
.dashboard-top-list strong,
.dashboard-stock-list strong {
  line-height: 1.25;
}
.dashboard-top-list span,
.dashboard-stock-list span {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.35;
}
.dashboard-chart {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(38px, 1fr);
  gap: 10px;
  align-items: end;
  min-height: 280px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background:
    linear-gradient(#eef3fb 1px, transparent 1px) 0 0 / 100% 25%,
    #fff;
}
.dashboard-chart span {
  display: grid;
  grid-template-rows: 1fr auto;
  gap: 8px;
  height: 240px;
  align-items: end;
}
.dashboard-chart i {
  display: block;
  width: 100%;
  height: var(--bar-height);
  min-height: 8px;
  border-radius: 999px 999px 6px 6px;
  background: linear-gradient(180deg, var(--teal), var(--blue));
  box-shadow: 0 10px 24px rgba(10,143,130,.16);
}
.dashboard-chart b {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
}
.ticket-manager-panel {
  display: grid;
  gap: 20px;
}
.ticket-manager-list {
  display: grid;
  gap: 18px;
}
.ticket-manager-item {
  display: grid;
  gap: 18px;
  padding: 20px;
  background: linear-gradient(180deg, #fff, #f8fbff);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.ticket-manager-main {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(320px, 460px);
  gap: 18px;
  align-items: start;
}
.ticket-manager-title {
  display: grid;
  justify-items: start;
  gap: 8px;
}
.ticket-manager-thumb {
  width: min(100%, 240px);
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border-radius: 14px;
  border: 1px solid var(--line);
}
.ticket-manager-title h3 {
  margin: 0;
  color: var(--ink);
  font-size: clamp(22px, 3vw, 32px);
  line-height: 1.08;
}
.ticket-manager-title p {
  max-width: 680px;
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}
.ticket-manager-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.ticket-manager-stats div {
  min-height: 92px;
  padding: 14px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 16px;
}
.ticket-manager-stats span {
  display: block;
  margin-bottom: 9px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}
.ticket-manager-stats strong {
  color: var(--ink);
  font-size: 24px;
  line-height: 1;
}
.ticket-manager-tools {
  display: grid;
  grid-template-columns: repeat(2, minmax(280px, 1fr));
  gap: 14px;
}
.ticket-manager-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: flex-start;
}
.ticket-edit-details {
  flex: 1 1 420px;
}
.ticket-edit-details summary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 12px 18px;
  color: var(--ink);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: var(--shadow-sm);
  font-weight: 900;
  cursor: pointer;
  list-style: none;
}
.ticket-edit-details summary::-webkit-details-marker {
  display: none;
}
.ticket-edit-details[open] summary {
  color: var(--teal-dark);
  border-color: rgba(10,143,130,.42);
  background: #effdfa;
  margin-bottom: 14px;
}
.ticket-edit-details .category-ticket-create-form {
  padding: 16px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
}
.ticket-tool {
  display: grid;
  align-content: start;
  gap: 14px;
  padding: 16px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
}
.ticket-tool-head {
  display: grid;
  gap: 4px;
}
.ticket-tool-head h4 {
  margin: 0;
  color: var(--ink);
  font-size: 17px;
}
.ticket-tool-head span,
.compact-note {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
}
.compact-note { margin: 0; }
.price-wave-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.price-wave-list li {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px;
  background: #f6fafc;
  border: 1px solid var(--line);
  border-radius: 12px;
}
.price-wave-list li > div {
  display: grid;
  gap: 3px;
}
.price-wave-list strong {
  color: var(--teal-dark);
  font-size: 18px;
}
.price-wave-list span {
  color: var(--muted);
  font-size: 14px;
}
.ticket-tool-form {
  display: grid;
  grid-template-columns: minmax(150px, 1fr) minmax(220px, 1fr) auto;
  gap: 10px;
  align-items: end;
}
.ticket-good-form {
  grid-template-columns: minmax(0, 1fr) 138px;
}
.ticket-tool-form > label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}
.ticket-tool-form input,
.ticket-tool-form select {
  min-width: 0;
  width: 100%;
}
.ticket-tool-form .ghost-button {
  min-height: 52px;
  white-space: nowrap;
}
.ticket-goods-list {
  display: grid;
  gap: 8px;
}
.ticket-good-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px;
  background: #f6fafc;
  border: 1px solid var(--line);
  border-radius: 12px;
}
.ticket-good-row div {
  display: grid;
  gap: 3px;
}
.ticket-good-row strong {
  color: var(--ink);
}
.ticket-good-row span {
  color: var(--muted);
  font-size: 14px;
}
.danger-link {
  color: #d92d20;
}
.ticket-good-mode {
  align-self: stretch;
}
.ticket-good-options {
  display: grid;
  grid-column: 1 / -1;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.ticket-good-mode label {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  width: 100%;
  min-height: 54px;
  padding: 12px 14px;
  border-radius: 14px;
  font-size: 14px;
  line-height: 1.15;
  text-transform: none;
}
.ticket-good-mode label span {
  min-width: 0;
  overflow-wrap: anywhere;
}
.ticket-good-mode input[type="checkbox"] {
  width: 20px;
  height: 20px;
  min-width: 20px;
  min-height: 20px;
}
.ticket-good-form .ghost-button {
  grid-column: 1 / -1;
}
.category-manager-panel {
  display: grid;
  gap: 20px;
}
.category-create-form {
  display: grid;
  grid-template-columns: minmax(220px, 1.4fr) minmax(160px, .9fr) minmax(150px, .8fr) minmax(150px, .8fr) auto;
  gap: 12px;
  align-items: end;
  padding: 16px;
  background: #f8fbff;
  border: 1px solid var(--line);
  border-radius: 18px;
}
.category-create-form label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}
.category-create-form input {
  width: 100%;
  min-width: 0;
}
.form-field-wide {
  display: grid;
  grid-column: 1 / -1;
  gap: 8px;
}
.field-label {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}
.participant-field-picker {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}
.participant-field-summary {
  flex: 1 1 360px;
  min-height: 52px;
  padding: 14px 16px;
  color: var(--ink-soft);
  background: #f8fbff;
  border: 1px solid var(--line);
  border-radius: 14px;
  line-height: 1.35;
}
.field-picker-modal {
  width: min(920px, calc(100vw - 28px));
  padding: 0;
  border: 0;
  border-radius: 24px;
  background: transparent;
}
.field-picker-modal::backdrop {
  background: rgba(10, 18, 32, .42);
  backdrop-filter: blur(3px);
}
.field-picker-card {
  display: grid;
  gap: 18px;
  max-height: min(760px, calc(100vh - 40px));
  padding: clamp(18px, 3vw, 28px);
  overflow: auto;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: var(--shadow);
}
.field-picker-card .panel-title-row {
  align-items: flex-start;
  margin-bottom: 0;
}
.field-picker-card .compact-button {
  flex: 0 0 auto;
  min-height: 46px;
  padding: 11px 16px;
}
.field-picker-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.field-picker-list li,
.field-picker-item {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 0;
  align-items: stretch;
  min-height: 74px;
  padding: 0;
  overflow: hidden;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: 0 10px 28px rgba(15, 23, 42, .04);
  transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.field-picker-list li:has(input[type="checkbox"]:checked) {
  border-color: rgba(10,143,130,.45);
  background: linear-gradient(180deg, #fff, #f3fffc);
}
.field-picker-list li:hover {
  border-color: rgba(47,104,255,.28);
  box-shadow: 0 16px 34px rgba(15, 23, 42, .08);
}
.field-picker-list li.is-dragging {
  opacity: .56;
  transform: scale(.98);
}
.drag-handle {
  display: grid;
  place-items: center;
  color: #8a9ab1;
  background: #f5f8fc;
  border-right: 1px solid var(--line);
  font-size: 18px;
  font-weight: 900;
  letter-spacing: -4px;
  cursor: grab;
}
.field-picker-list label,
.field-picker-choice {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  min-width: 0;
  min-height: 72px;
  margin: 0;
  padding: 14px 16px;
  color: var(--ink);
  font-size: 15px;
  font-weight: 800;
  line-height: 1.25;
  text-transform: none;
  cursor: pointer;
}
.field-picker-list input[type="checkbox"].field-picker-checkbox {
  appearance: none;
  width: 22px;
  height: 22px;
  min-width: 22px;
  min-height: 22px;
  margin: 0;
  padding: 0;
  background: #fff;
  border: 2px solid #b9c6d8;
  border-radius: 7px;
  box-shadow: none;
}
.field-picker-list input[type="checkbox"].field-picker-checkbox:checked {
  background: var(--blue);
  border-color: var(--blue);
  box-shadow: inset 0 0 0 4px var(--blue);
}
.field-picker-list input[type="checkbox"].field-picker-checkbox:checked::after {
  content: "";
  display: block;
  width: 7px;
  height: 12px;
  margin: 2px 0 0 6px;
  border: solid #fff;
  border-width: 0 3px 3px 0;
  transform: rotate(45deg);
}
.field-picker-text {
  min-width: 0;
}
.field-picker-list strong,
.field-picker-list small {
  display: block;
  text-transform: none;
}
.field-picker-list small {
  margin-top: 3px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.2;
}
@media (max-width: 760px) {
  .field-picker-list {
    grid-template-columns: 1fr;
  }
  .field-picker-card .panel-title-row {
    display: grid;
  }
}
.category-create-form .primary-button {
  min-height: 52px;
  white-space: nowrap;
}
.category-overview-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
}
.category-overview-card {
  display: grid;
  gap: 16px;
  min-height: 260px;
  padding: 20px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.category-overview-card.is-archived {
  background: linear-gradient(180deg, #fff, #fff9ed);
}
.category-overview-head {
  display: grid;
  justify-items: start;
  gap: 8px;
}
.category-overview-head h3 {
  margin: 0;
  color: var(--ink);
  font-size: clamp(24px, 3vw, 34px);
  line-height: 1.08;
}
.category-overview-head p {
  margin: 0;
  color: var(--muted);
}
.category-settings {
  display: grid;
  gap: 12px;
  padding-top: 4px;
}
.category-settings summary {
  cursor: pointer;
  color: var(--teal-dark);
  font-weight: 900;
}
.category-settings[open] summary {
  margin-bottom: 12px;
}
.category-workspace {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, .85fr);
  gap: 20px;
  align-items: start;
  margin-bottom: 22px;
}
.category-settings-panel {
  display: grid;
  gap: 16px;
}
.danger-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 11px 16px;
  color: #fff;
  background: linear-gradient(135deg, #d92d20, #f04438);
  border: 0;
  border-radius: var(--radius);
  font-weight: 900;
  cursor: pointer;
}
.danger-button:hover { filter: brightness(.96); }
.category-detail-list,
.category-card-grid {
  display: grid;
  gap: 18px;
}
.category-detail-card,
.category-card {
  display: grid;
  gap: 18px;
  padding: 20px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.category-detail-card.is-archived {
  background: linear-gradient(180deg, #fff, #fff9ed);
}
.category-detail-head {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(320px, 460px);
  gap: 18px;
  align-items: start;
}
.category-detail-card h3,
.category-card h3 {
  margin: 12px 0 4px;
  color: var(--ink);
  font-size: clamp(24px, 3vw, 34px);
  line-height: 1.08;
}
.category-detail-card p,
.category-card p {
  margin: 0;
  color: var(--muted);
}
.category-card-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.category-card-stats span {
  display: grid;
  gap: 4px;
  min-height: 72px;
  padding: 10px;
  color: var(--muted);
  background: #f6fafc;
  border: 1px solid var(--line);
  border-radius: 12px;
  font-size: 12px;
  font-weight: 800;
}
.category-card-stats strong {
  color: var(--ink);
  font-size: 20px;
}
.category-edit-form {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 10px;
  align-items: end;
  padding: 14px;
  background: #f8fbff;
  border: 1px solid var(--line);
  border-radius: 16px;
}
.category-edit-form label,
.category-ticket-create-form > label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}
.category-edit-form input,
.category-edit-form select {
  width: 100%;
  min-width: 0;
}
.category-edit-form .ghost-button,
.category-ticket-create-form .primary-button {
  min-height: 52px;
  white-space: nowrap;
}
.category-delete-form {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  align-items: center;
  padding: 12px 14px;
  background: #fff7f6;
  border: 1px solid #ffd6d1;
  border-radius: 16px;
}
.category-ticket-zone,
.category-ticket-create {
  display: grid;
  gap: 14px;
  padding-top: 4px;
}
.category-ticket-create {
  padding: 16px;
  background: #f8fbff;
  border: 1px solid var(--line);
  border-radius: 18px;
}
.category-ticket-create h4 {
  margin: 0;
  color: var(--ink);
  font-size: 20px;
}
.category-ticket-create-form {
  display: grid;
  gap: 14px;
}
.subnav {
  display: flex;
  gap: 8px;
  margin: 0 0 22px;
  padding: 6px;
  overflow-x: auto;
  background: #eef3fb;
  border-radius: var(--radius);
}
.subnav a {
  flex: 0 0 auto;
  padding: 10px 13px;
  color: var(--ink-soft);
  background: #fff;
  border: 1px solid transparent;
  border-radius: var(--radius);
  font-size: 14px;
  font-weight: 950;
}
.subnav a:hover { border-color: rgba(47,104,255,.24); color: var(--blue); }
.subnav a.active {
  color: #fff;
  background: linear-gradient(135deg, var(--teal), var(--blue));
  box-shadow: 0 12px 24px rgba(47,104,255,.18);
}
.metric {
  display: grid;
  gap: 8px;
  padding: 22px;
}
.metric span { color: var(--muted); font-weight: 850; }
.metric strong { font-size: clamp(30px, 5vw, 48px); }
.ticket-card {
  display: grid;
  grid-template-columns: 1fr 156px;
  gap: 18px;
  align-items: center;
  padding: 18px;
}
.qr {
  width: 156px;
  height: 156px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
}
.ticket-delivery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
  margin: 22px 0;
}
.ticket-delivery-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 132px;
  gap: 18px;
  align-items: center;
  padding: 18px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: 0 14px 30px rgba(23, 37, 84, .08);
}
.ticket-delivery-card h3 {
  margin: 12px 0 6px;
  font-size: 20px;
}
.ticket-number {
  margin: 0;
  color: var(--ink);
  font-size: 18px;
  font-weight: 950;
  letter-spacing: .04em;
}
.ticket-qr {
  width: 132px;
  height: 132px;
  padding: 8px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
}
.scanner-layout {
  display: grid;
  grid-template-columns: minmax(300px, 470px) minmax(0, 1fr);
  gap: 20px;
  align-items: stretch;
}
.scan-result {
  min-height: 420px;
  display: grid;
  align-content: center;
}
.scan-result.ok { background: #eefbf5; border-color: #b8efd1; }
.scan-result.bad { background: #fff1ef; border-color: #ffd2c9; }
.scan-result h2 {
  margin: 0 0 16px;
  font-size: clamp(32px, 5vw, 64px);
  line-height: .96;
}

.admin-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 230px;
  gap: 22px;
  align-items: center;
  margin: 18px 0 22px;
  padding: clamp(26px, 5vw, 52px);
  overflow: hidden;
  color: #fff;
  border-radius: var(--radius);
  background:
    linear-gradient(125deg, rgba(5,102,94,.96), rgba(47,104,255,.9) 58%, rgba(255,97,72,.9)),
    linear-gradient(90deg, #05665e, #2f68ff);
  box-shadow: var(--shadow-lg);
}
.admin-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.14) 0 1px, transparent 1px 26px),
    linear-gradient(90deg, transparent, rgba(255,255,255,.14));
  opacity: .72;
}
.admin-hero > * {
  position: relative;
  z-index: 1;
}
.admin-hero h1 {
  margin: 0;
  max-width: 780px;
  font-size: clamp(34px, 5vw, 62px);
  line-height: .96;
}
.admin-hero p {
  max-width: 650px;
  margin: 16px 0 0;
  color: rgba(255,255,255,.86);
  font-size: 18px;
  line-height: 1.55;
}
.admin-hero-card {
  display: grid;
  gap: 6px;
  padding: 20px;
  color: var(--ink);
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(255,255,255,.64);
  border-radius: var(--radius);
  box-shadow: 0 22px 50px rgba(17,19,26,.2);
}
.admin-hero-card span,
.admin-hero-card small {
  color: var(--muted);
  font-weight: 900;
}
.admin-hero-card strong {
  color: var(--coral);
  font-size: 58px;
  line-height: .9;
}
.admin-metrics .metric {
  position: relative;
  min-height: 148px;
  overflow: hidden;
}
.admin-metrics .metric::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 6px;
  background: var(--metric-color, var(--teal));
}
.admin-metrics .metric strong {
  position: relative;
  z-index: 1;
}
.metric-teal { --metric-color: var(--teal); background: linear-gradient(150deg, #fff, #eafbf7); }
.metric-coral { --metric-color: var(--coral); background: linear-gradient(150deg, #fff, #fff0ec); }
.metric-blue { --metric-color: var(--blue); background: linear-gradient(150deg, #fff, #edf3ff); }
.metric-gold { --metric-color: var(--gold); background: linear-gradient(150deg, #fff, #fff6d7); }
.admin-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
  margin-top: 18px;
}
.admin-actions a {
  display: grid;
  grid-template-columns: 46px 1fr;
  gap: 8px 14px;
  align-items: center;
  padding: 18px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.admin-actions a:hover {
  transform: translateY(-2px);
  border-color: rgba(10,143,130,.34);
  box-shadow: var(--shadow-md);
}
.admin-action-icon {
  display: grid;
  grid-row: span 2;
  place-items: center;
  width: 46px;
  height: 46px;
  color: #fff;
  background: linear-gradient(135deg, var(--teal), var(--coral));
  border-radius: var(--radius);
  font-weight: 950;
}
.admin-actions strong {
  font-size: 18px;
}
.admin-actions small {
  color: var(--muted);
  line-height: 1.45;
}
.admin-section-head h1 {
  font-size: clamp(34px, 5vw, 58px);
}
.admin-panel {
  padding: clamp(18px, 3vw, 28px);
  overflow: hidden;
}
.panel-title-row {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 12px;
}
.panel-title-row h2 {
  margin: 0;
  font-size: clamp(22px, 3vw, 32px);
}
.panel-title-row p {
  margin: 8px 0 0;
}
.admin-table {
  min-width: 980px;
  border-collapse: separate;
  border-spacing: 0 10px;
}
.admin-table th,
.admin-table td {
  border-bottom: 0;
}
.admin-table td {
  background: linear-gradient(180deg, #fff, #fbfcff);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.admin-table td:first-child {
  border-left: 1px solid var(--line);
  border-radius: var(--radius) 0 0 var(--radius);
}
.admin-table td:last-child {
  border-right: 1px solid var(--line);
  border-radius: 0 var(--radius) var(--radius) 0;
}
.row-note {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.35;
}
.status-stack {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
.moderation-form {
  align-items: stretch;
}
.moderation-form select {
  min-width: 190px;
  background-color: #fbfffe;
  border-color: rgba(10,143,130,.22);
}
.moderation-form input {
  min-width: 210px;
}
.event-type-form {
  max-width: 980px;
}
.event-types-table td:last-child {
  min-width: 520px;
}
.event-type-field {
  display: inline-flex;
  margin: 0 6px 7px 0;
  padding: 7px 10px;
  border-radius: 999px;
  background: #eef8f7;
  color: #087f76;
  font-size: 13px;
  font-weight: 800;
}
.event-type-inline-form {
  gap: 12px;
}
.event-type-inline-form textarea {
  min-height: 96px;
}
.event-type-actions {
  justify-content: space-between;
}
.event-type-delete-form {
  margin-top: 10px;
}
.compact-button {
  min-height: 38px;
  padding-inline: 14px;
}
.report-filter-panel {
  display: grid;
  gap: 12px;
  margin-bottom: 18px;
}
.report-filters {
  display: grid;
  grid-template-columns: minmax(240px, 1.6fr) repeat(3, minmax(150px, 1fr)) auto;
  gap: 12px;
  align-items: end;
}
.report-filters label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}
.report-filter-actions {
  display: flex;
  gap: 10px;
}
.report-summary {
  margin-bottom: 18px;
}
.report-ajax-root {
  position: relative;
}
.report-ajax-root.is-loading {
  cursor: progress;
  opacity: .66;
  transition: opacity .16s ease;
}
.report-ajax-root.is-loading a,
.report-ajax-root.is-loading button,
.report-ajax-root.is-loading input,
.report-ajax-root.is-loading select {
  pointer-events: none;
}
.report-ajax-message {
  margin-bottom: 16px;
}
.report-table tr.is-selected td {
  background: linear-gradient(180deg, #f4fffd, #f6f9ff);
  border-color: rgba(10,143,130,.28);
}
.report-table td strong {
  line-height: 1.18;
}
.report-drill-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--ink);
  font-weight: 700;
  line-height: 1.25;
}
.report-drill-link::after {
  content: "";
  width: 7px;
  height: 7px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(-45deg);
  opacity: .45;
}
.report-drill-link:hover {
  color: var(--teal-dark);
}
.report-refund-form input {
  min-width: 170px;
}
.warehouse-layout {
  display: grid;
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
  margin-bottom: 18px;
}
.warehouse-side-panel {
  display: grid;
  gap: 18px;
}
.warehouse-category-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.warehouse-category-pill {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 7px 12px;
  color: var(--teal-dark);
  background: #e9f8f5;
  border: 1px solid rgba(10,143,130,.16);
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
}
.warehouse-groups {
  display: grid;
  gap: 18px;
}
.warehouse-group {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
}
.warehouse-group-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 18px 20px;
  background: linear-gradient(135deg, #f4fffd, #f6f9ff);
  border-bottom: 1px solid var(--line);
}
.warehouse-group-head h3 {
  margin: 0;
  font-size: 22px;
  font-weight: 700;
}
.warehouse-group-head p {
  margin: 4px 0 0;
}
.warehouse-table {
  min-width: 920px;
}
.warehouse-table td strong {
  font-weight: 700;
}
.warehouse-move-form input[name="qty_change"] {
  max-width: 130px;
}
.warehouse-move-form input[name="note"] {
  min-width: 180px;
}
.hall-admin-layout {
  display: grid;
  grid-template-columns: minmax(300px, 380px) minmax(0, 1fr);
  gap: 22px;
  align-items: start;
}
.hall-side-panel {
  display: grid;
  gap: 20px;
}
.hall-list {
  display: grid;
  gap: 10px;
}
.hall-list-item {
  display: grid;
  gap: 5px;
  padding: 14px 16px;
  background: #f8fbff;
  border: 1px solid var(--line);
  border-radius: 14px;
}
.hall-list-item.is-active,
.hall-list-item:hover {
  background: #eefafa;
  border-color: rgba(10,143,130,.35);
}
.hall-list-item span {
  color: var(--muted);
  font-size: 13px;
}
.hall-inline-edit {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(190px, auto) auto;
  gap: 10px;
  align-items: end;
  min-width: min(620px, 100%);
}
.compact-file {
  min-width: 180px;
}
.hall-map-and-tools {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(300px, .75fr);
  gap: 20px;
  align-items: start;
}
.hall-map-wrap {
  position: sticky;
  top: 118px;
}
.hall-map,
.hall-map-placeholder {
  position: relative;
  overflow: hidden;
  min-height: 360px;
  background: #f7fafc;
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.7);
}
.hall-map img {
  width: 100%;
  height: auto;
  min-height: 360px;
  object-fit: contain;
  background: #fff;
}
.hall-map-placeholder {
  display: grid;
  place-items: center;
  padding: 28px;
  color: var(--muted);
  text-align: center;
  font-weight: 700;
}
.hall-section-overlay {
  position: absolute;
  min-width: 42px;
  min-height: 30px;
  background: color-mix(in srgb, var(--section-color) 22%, transparent);
  border: 2px solid var(--section-color);
  border-radius: 12px;
  pointer-events: none;
}
.hall-section-overlay span {
  display: inline-flex;
  margin: 6px;
  padding: 4px 7px;
  color: #fff;
  background: color-mix(in srgb, var(--section-color) 82%, #11131a);
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
}
.hall-tools,
.hall-tool-form {
  display: grid;
  gap: 12px;
}
.hall-tool-form {
  padding: 18px;
  background: #fbfdff;
  border: 1px solid var(--line);
  border-radius: 16px;
}
.hall-tool-form.is-active {
  border-color: rgba(10,143,130,.4);
  box-shadow: 0 0 0 4px rgba(10,143,130,.08);
}
.hall-tool-form.is-pulsing {
  animation: hallPulse .42s ease;
}
.hall-tool-form h3 {
  margin: 0;
}
.coord-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.hall-entity-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, .78fr);
  gap: 20px;
  margin-top: 24px;
}
.hall-entity-list,
.hall-seat-list {
  display: grid;
  gap: 10px;
}
.hall-entity-card,
.hall-seat-row {
  padding: 14px;
  background: #f8fbff;
  border: 1px solid var(--line);
  border-radius: 14px;
}
.hall-entity-card summary {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  cursor: pointer;
}
.hall-entity-card summary span,
.hall-seat-row span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}
.hall-entity-card .hall-tool-form {
  margin-top: 14px;
}
.hall-seat-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
@keyframes hallPulse {
  0%, 100% { transform: none; }
  50% { transform: translateY(-2px); }
}
.visual-editor-source.is-enhanced {
  display: none;
}
.visual-editor {
  overflow: hidden;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
}
.visual-editor:focus-within {
  border-color: rgba(10,143,130,.55);
  box-shadow: 0 0 0 4px rgba(10,143,130,.11);
}
.visual-editor-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 8px;
  background: var(--surface-2);
  border-bottom: 1px solid var(--line);
}
.visual-editor-toolbar button {
  min-height: 34px;
  padding: 7px 10px;
  color: var(--ink-soft);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  font-size: 13px;
  font-weight: 700;
}
.visual-editor-toolbar button:hover {
  color: var(--teal-dark);
  border-color: rgba(10,143,130,.35);
}
.visual-editor-area {
  min-height: 180px;
  padding: 14px;
  color: var(--ink);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.65;
  outline: none;
}
.visual-editor-area h2,
.visual-editor-area h3 {
  margin: 10px 0 8px;
  font-weight: 700;
  line-height: 1.2;
}
.visual-editor-area p {
  margin: 0 0 10px;
}
.visual-editor-area ul,
.visual-editor-area ol {
  margin: 0 0 10px 22px;
  padding: 0;
}
.visual-editor-area blockquote {
  margin: 10px 0;
  padding: 10px 14px;
  color: var(--ink-soft);
  background: #f7fafc;
  border-left: 3px solid var(--teal);
}

body {
  font-family: ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 400;
}
.brand,
.main-nav,
.user-pill,
.badge,
.primary-button,
.ghost-button,
.city-picker label,
.stack-form label,
.form-grid label,
.segmented label,
.alert,
th,
.subnav a,
.metric span,
.admin-hero-card span,
.admin-hero-card small,
.admin-action-icon,
.report-filters label {
  font-weight: 700;
}
.hero-copy h1,
.event-summary h1,
.empty-state h1,
.section-head h1,
.section-head h2,
.admin-hero h1,
.admin-section-head h1,
.panel-title-row h2,
.scan-result h2 {
  font-weight: 700;
  line-height: 1.05;
}
.section-head h1,
.section-head h2 {
  font-size: clamp(28px, 3.4vw, 46px);
}
.admin-hero h1 {
  font-size: clamp(34px, 4.6vw, 56px);
}
.metric strong {
  font-size: clamp(28px, 4vw, 42px);
  font-weight: 600;
}
.admin-hero-card strong {
  font-weight: 600;
}
.event-body strong,
.price,
.event-date,
.eyebrow,
.ticket-buy h3,
.buy-controls strong,
.form-result,
.admin-actions strong,
.report-table td strong {
  font-weight: 700;
}

@media (prefers-reduced-motion: no-preference) {
  .event-card, .city-card, .primary-button, .ghost-button, .admin-actions a {
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  }
}

@media (max-width: 980px) {
  .topbar { align-items: flex-start; flex-direction: column; }
  .top-actions { margin-left: 0; }
  .hero-panel, .event-hero, .content-grid, .scanner-layout { grid-template-columns: 1fr; }
  .home-hero,
  .home-city-strip,
  .city-modal-form {
    grid-template-columns: 1fr;
  }
  .home-hero { min-height: auto; }
  .home-feature-card { transform: none; }
  .home-city-chips { justify-content: flex-start; }
  .city-modal-form .primary-button { width: 100%; }
  .hero-panel { min-height: auto; }
  .hero-visual { transform: none; }
  .city-compact-panel { grid-template-columns: 1fr; }
  .popular-city-list { justify-content: flex-start; }
  .event-cover { min-height: 330px; }
  .ticket-panel { position: static; }
  .ticket-manager-main,
  .ticket-manager-tools,
  .ticket-tool-form,
  .ticket-good-form,
  .category-create-form,
  .category-edit-form,
  .category-detail-head {
    grid-template-columns: 1fr;
  }
  .admin-hero { grid-template-columns: 1fr; }
  .admin-hero-card { width: min(280px, 100%); }
  .report-filters { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .report-filter-actions { grid-column: 1 / -1; }
  .warehouse-layout { grid-template-columns: 1fr; }
  .hall-admin-layout,
  .hall-map-and-tools,
  .hall-entity-grid,
  .hall-inline-edit {
    grid-template-columns: 1fr;
  }
  .hall-map-wrap {
    position: static;
  }
  .dashboard-hero,
  .dashboard-layout,
  .dashboard-layout-wide,
  .category-workspace {
    grid-template-columns: 1fr;
  }
  .dashboard-actions {
    justify-content: flex-start;
  }
  .dashboard-event-switch {
    width: 100%;
  }
  .dashboard-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .category-create-form {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .category-create-form .primary-button {
    grid-column: 1 / -1;
  }
}

@media (max-width: 640px) {
  .page { width: min(100% - 24px, 1240px); margin-top: 16px; }
  .topbar { padding: 12px; }
  .main-nav, .top-actions { width: 100%; }
  .main-nav { overflow-x: auto; }
  .top-actions {
    display: grid;
    grid-template-columns: 1fr;
  }
  .top-actions .primary-button,
  .top-actions .ghost-button {
    width: auto;
    min-width: 0;
    padding-left: 8px;
    padding-right: 8px;
  }
  .hero-panel { padding: 24px; }
  .home-hero { padding: 26px; border-radius: 22px; }
  .home-hero-copy h1 { font-size: 42px; }
  .home-hero-copy p { font-size: 17px; }
  .home-hero-actions { display: grid; grid-template-columns: 1fr; }
  .home-feature-card { aspect-ratio: 1.34; padding: 22px; }
  .home-qr-card { width: 100%; margin-left: 0; grid-template-columns: 1fr; }
  .home-city-strip { padding: 16px; border-radius: 18px; }
  .home-city-chips { display: grid; grid-template-columns: 1fr; }
  .home-city-chips a { justify-content: center; }
  .city-modal { padding: 12px; }
  .city-dialog { max-height: calc(100vh - 24px); overflow: auto; border-radius: 22px; }
  .city-dialog .panel-title-row { align-items: stretch; flex-direction: column; }
  .city-modal-close { width: 100%; }
  .hero-copy h1, .event-summary h1, .empty-state h1 { font-size: 42px; }
  .hero-copy p { max-width: 320px; }
  .hero-controls,
  .hero-controls.region-city-controls { grid-template-columns: 1fr; }
  .city-compact-panel { padding: 18px; }
  .city-chip { min-width: 100%; border-radius: 14px; }
  .ticket-panel { grid-template-columns: 1fr; }
  .mini-ticket { margin-left: 0; grid-template-columns: 1fr; }
  .event-grid, .ticket-grid, .metric-grid { grid-template-columns: 1fr; }
  .dashboard-metrics {
    grid-template-columns: 1fr;
  }
  .ticket-manager-item { padding: 14px; border-radius: 18px; }
  .ticket-manager-stats { grid-template-columns: 1fr; }
  .category-card-stats { grid-template-columns: 1fr; }
  .category-overview-grid {
    grid-template-columns: 1fr;
  }
  .dashboard-chart {
    grid-auto-columns: 44px;
    overflow-x: auto;
  }
  .dashboard-chart span {
    min-width: 44px;
  }
  .ticket-good-options {
    grid-template-columns: 1fr;
  }
  .category-create-form {
    grid-template-columns: 1fr;
  }
  .section-head { align-items: stretch; flex-direction: column; }
  .ticket-card { grid-template-columns: 1fr; }
  .ticket-delivery-card { grid-template-columns: 1fr; }
  .ticket-qr { width: 180px; height: 180px; }
  .primary-button, .ghost-button { width: 100%; }
  .inline-form input, .inline-form select { min-width: 100%; }
  .admin-hero { padding: 24px; }
  .admin-hero h1 { font-size: 36px; }
  .admin-actions a { grid-template-columns: 38px 1fr; }
  .admin-action-icon { width: 38px; height: 38px; }
  .report-filters { grid-template-columns: 1fr; }
  .report-filter-actions { flex-direction: column; }
}

/* Back-office design system */
.is-backoffice {
  --page: #f3f6fb;
  --ink: #0f172a;
  --ink-soft: #334155;
  --muted: #64748b;
  --line: #dfe6f0;
  --surface-2: #eef4fb;
  --shadow-sm: 0 14px 40px rgba(15, 23, 42, .07);
  --shadow-md: 0 24px 70px rgba(15, 23, 42, .12);
  --shadow-lg: 0 34px 100px rgba(15, 23, 42, .16);
  background:
    radial-gradient(circle at 18% -12%, rgba(10,143,130,.14), transparent 32rem),
    radial-gradient(circle at 88% -18%, rgba(47,104,255,.13), transparent 34rem),
    linear-gradient(180deg, #f8fbff 0, #f2f6fb 42rem, #f6f8fb 100%);
}
.is-backoffice .page {
  width: min(1360px, calc(100% - 72px));
  margin: 34px auto 120px;
}
.is-backoffice .topbar {
  gap: 30px;
  padding: 18px max(36px, calc((100vw - 1360px) / 2));
  background: rgba(255,255,255,.9);
  border-bottom: 1px solid rgba(223,230,240,.72);
  box-shadow: 0 12px 40px rgba(15, 23, 42, .055);
}
.is-backoffice .brand {
  gap: 13px;
  font-size: 20px;
  font-weight: 800;
}
.is-backoffice .brand-mark {
  width: 44px;
  height: 44px;
  border-radius: 13px;
  box-shadow: 0 16px 32px rgba(10,143,130,.2);
}
.is-backoffice .main-nav {
  gap: 8px;
  font-size: 15px;
  font-weight: 700;
}
.is-backoffice .main-nav a {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  padding: 11px 15px;
  border-radius: 12px;
}
.is-backoffice .main-nav a:hover {
  color: var(--ink);
  background: #eef4fb;
}
.is-backoffice .top-actions {
  gap: 12px;
}
.is-backoffice .user-pill,
.is-backoffice .badge {
  min-height: 36px;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 700;
}
.is-backoffice .primary-button,
.is-backoffice .ghost-button {
  min-height: 52px;
  padding: 14px 20px;
  border-radius: 12px;
  font-size: 15px;
  font-weight: 700;
}
.is-backoffice .primary-button {
  background: linear-gradient(135deg, #087f76, #2466e8);
  box-shadow: 0 18px 38px rgba(36,102,232,.2);
}
.is-backoffice .ghost-button {
  background: #fff;
  border-color: #dfe6f0;
  box-shadow: 0 8px 22px rgba(15,23,42,.04);
}
.is-backoffice .subnav {
  gap: 10px;
  margin-bottom: 34px;
  padding: 10px;
  background: rgba(226,235,247,.82);
  border: 1px solid rgba(223,230,240,.9);
  border-radius: 16px;
}
.is-backoffice .subnav a {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  padding: 13px 18px;
  border-radius: 12px;
  font-size: 15px;
  font-weight: 700;
  box-shadow: 0 8px 18px rgba(15,23,42,.03);
}
.is-backoffice .subnav a.active {
  background: linear-gradient(135deg, #087f76, #2466e8);
  box-shadow: 0 16px 34px rgba(36,102,232,.2);
}
.is-backoffice .section-head {
  margin: 48px 0 24px;
}
.is-backoffice .section-head:first-child {
  margin-top: 0;
}
.is-backoffice .section-head h1,
.is-backoffice .section-head h2 {
  font-size: clamp(42px, 4.4vw, 64px);
  line-height: 1.02;
  letter-spacing: 0;
}
.is-backoffice .section-head p {
  max-width: 780px;
  margin-top: 12px;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.55;
}
.is-backoffice .panel,
.is-backoffice .auth-card,
.is-backoffice .scanner-panel,
.is-backoffice .scan-result {
  padding: clamp(30px, 4vw, 48px);
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(223,230,240,.9);
  border-radius: 20px;
  box-shadow: var(--shadow-sm);
}
.is-backoffice .panel + .panel,
.is-backoffice .panel + .metric-grid,
.is-backoffice .metric-grid + .panel {
  margin-top: 24px;
}
.is-backoffice .panel h1,
.is-backoffice .panel h2 {
  margin-top: 0;
  color: var(--ink);
  font-weight: 700;
}
.is-backoffice .panel h1 {
  margin-bottom: 28px;
  font-size: clamp(34px, 3.6vw, 48px);
  line-height: 1.08;
}
.is-backoffice .panel h2,
.is-backoffice .panel-title-row h2 {
  font-size: clamp(26px, 2.5vw, 36px);
  line-height: 1.12;
}
.is-backoffice .panel-title-row {
  margin-bottom: 22px;
}
.is-backoffice .panel-title-row p {
  font-size: 16px;
  line-height: 1.55;
}
.is-backoffice .stack-form {
  gap: 22px;
}
.is-backoffice .form-grid {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
}
.is-backoffice .city-picker label,
.is-backoffice .stack-form label,
.is-backoffice .form-grid label,
.is-backoffice .report-filters label {
  gap: 9px;
  color: #516079;
  font-size: 13px;
  font-weight: 700;
}
.is-backoffice input,
.is-backoffice select,
.is-backoffice textarea {
  min-height: 54px;
  padding: 15px 16px;
  border-radius: 12px;
  border-color: #dbe4ef;
  color: var(--ink);
  background-color: #fbfdff;
  font-size: 15px;
}
.is-backoffice select {
  background-position:
    calc(100% - 22px) 24px,
    calc(100% - 16px) 24px;
}
.is-backoffice textarea {
  min-height: 132px;
}
.is-backoffice .embed-code {
  min-height: 118px;
  font-size: 14px;
}
.is-backoffice input:focus,
.is-backoffice select:focus,
.is-backoffice textarea:focus {
  border-color: rgba(8,127,118,.58);
  box-shadow: 0 0 0 5px rgba(8,127,118,.12);
  background: #fff;
}
.is-backoffice .check-row {
  gap: 14px;
}
.is-backoffice .check-row label {
  min-height: 52px;
  padding: 13px 16px;
  background: #f7fbff;
  border-color: #dbe4ef;
  font-size: 15px;
}
.is-backoffice input[type="checkbox"] {
  width: 22px;
  height: 22px;
  min-width: 22px;
  min-height: 22px;
  padding: 0;
  border-radius: 6px;
  background-color: #fff;
}
.is-backoffice .visual-editor {
  border-radius: 14px;
  border-color: #dbe4ef;
  background: #fff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7);
}
.is-backoffice .visual-editor-toolbar {
  gap: 8px;
  padding: 10px;
  background: #eef4fb;
}
.is-backoffice .visual-editor-toolbar button {
  min-height: 38px;
  padding: 9px 12px;
  border-radius: 10px;
  font-size: 14px;
}
.is-backoffice .visual-editor-area {
  min-height: 220px;
  padding: 18px;
  font-size: 17px;
  line-height: 1.7;
}
.is-backoffice .metric-grid {
  gap: 20px;
}
.is-backoffice .metric {
  min-height: 170px;
  padding: 28px;
  border: 1px solid rgba(223,230,240,.9);
  border-radius: 20px;
  box-shadow: var(--shadow-sm);
}
.is-backoffice .metric span {
  font-size: 15px;
  font-weight: 700;
}
.is-backoffice .metric strong {
  margin-top: 8px;
  font-size: clamp(36px, 4vw, 56px);
  font-weight: 600;
  line-height: 1;
}
.is-backoffice .admin-hero {
  min-height: 300px;
  padding: clamp(38px, 5vw, 64px);
  border-radius: 24px;
  background:
    linear-gradient(120deg, rgba(11,31,54,.98), rgba(14,116,144,.92) 54%, rgba(36,102,232,.82)),
    #0b1f36;
}
.is-backoffice .admin-hero h1 {
  font-size: clamp(44px, 5vw, 72px);
}
.is-backoffice .admin-hero-card {
  border-radius: 18px;
}
.is-backoffice .admin-table,
.is-backoffice .report-table,
.is-backoffice .warehouse-table,
.is-backoffice table {
  min-width: 960px;
}
.is-backoffice th,
.is-backoffice td {
  padding: 18px 16px;
}
.is-backoffice th {
  color: #65758c;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .04em;
}
.is-backoffice td {
  font-size: 16px;
  line-height: 1.45;
}
.is-backoffice .admin-table {
  border-spacing: 0 12px;
}
.is-backoffice .admin-table td,
.is-backoffice .report-table tr.is-selected td {
  background: #fff;
}
.is-backoffice .report-table tr.is-selected td,
.is-backoffice .admin-table tr:hover td,
.is-backoffice .report-table tr:hover td {
  background: #f3fbff;
}
.is-backoffice .row-note,
.is-backoffice .muted {
  color: var(--muted);
}
.is-backoffice .warehouse-layout {
  grid-template-columns: minmax(330px, 410px) minmax(0, 1fr);
  gap: 22px;
}
.is-backoffice .warehouse-group {
  border-radius: 18px;
}
.is-backoffice .warehouse-group-head {
  padding: 22px 24px;
  background: linear-gradient(135deg, #f3fbff, #f8fbff);
}
.is-backoffice .warehouse-group-head h3 {
  font-size: 24px;
}
.is-backoffice .scanner-layout {
  gap: 24px;
}
.is-backoffice .scan-result {
  min-height: 520px;
}
.is-backoffice .ticket-card,
.is-backoffice .ticket-buy,
.is-backoffice .event-card.plain {
  border-radius: 18px;
  box-shadow: var(--shadow-sm);
}

@media (max-width: 980px) {
  .is-backoffice .page {
    width: min(100% - 32px, 1360px);
  }
  .is-backoffice .warehouse-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .is-backoffice .page {
    width: min(100% - 24px, 1360px);
    margin-top: 20px;
  }
  .is-backoffice .topbar {
    padding: 16px;
  }
  .is-backoffice .section-head h1,
  .is-backoffice .section-head h2 {
    font-size: 38px;
  }
  .is-backoffice .panel,
  .is-backoffice .auth-card,
  .is-backoffice .scanner-panel,
  .is-backoffice .scan-result {
    padding: 24px;
    border-radius: 18px;
  }
}
