:root {
  color-scheme: dark;
  --ink: #14171f;
  --muted: #6b5f7d;
  --paper: #070715;
  --surface: #fff8fb;
  --line: rgba(255, 91, 199, 0.34);
  --blue: #00a7ff;
  --green: #2ce889;
  --red: #ff4f6d;
  --gold: #ffc342;
  --pink: #ff4fcb;
  --violet: #8b5cff;
  --cyan: #00e5ff;
  --orange: #ff8a2a;
  --shadow: 0 14px 34px rgba(0, 0, 0, 0.24), 0 0 28px rgba(255, 79, 203, 0.14);
}

* {
  box-sizing: border-box;
}

html {
  min-height: 100%;
  background: #070715;
}

body {
  position: relative;
  min-height: 100%;
  margin: 0;
  color: var(--ink);
  background:
    linear-gradient(130deg, rgba(255, 79, 203, 0.18), transparent 32%),
    linear-gradient(225deg, rgba(0, 229, 255, 0.18), transparent 34%),
    linear-gradient(180deg, #080817 0%, #111027 46%, #070715 100%);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.45;
}

body::before {
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  content: "";
  background:
    repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.07) 0 1px, transparent 1px 58px),
    repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.045) 0 1px, transparent 1px 46px),
    linear-gradient(90deg, rgba(255, 195, 66, 0.08), rgba(0, 229, 255, 0.06), rgba(255, 79, 203, 0.08));
  mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.86), rgba(0, 0, 0, 0.24));
}

button,
input,
select,
textarea {
  font: inherit;
}

button,
.mini-button,
.file-button {
  min-height: 42px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255, 79, 203, 0.95), rgba(139, 92, 255, 0.95) 48%, rgba(0, 229, 255, 0.95));
  color: #fffdfa;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.2), 0 0 18px rgba(255, 79, 203, 0.22);
  text-decoration: none;
  padding: 10px 12px;
  font-weight: 800;
  cursor: pointer;
  text-align: center;
}

button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 3px solid var(--gold);
  outline-offset: 2px;
}

button.active,
button.selected {
  background:
    linear-gradient(135deg, var(--green), var(--cyan));
  border-color: rgba(255, 255, 255, 0.72);
  color: #06111d;
}

input,
select,
textarea {
  width: 100%;
  min-height: 44px;
  border: 1px solid rgba(255, 91, 199, 0.46);
  border-radius: 8px;
  background: #fff;
  color: var(--ink);
  padding: 10px 12px;
  box-shadow: inset 0 0 0 1px rgba(0, 229, 255, 0.08);
}

textarea {
  resize: vertical;
}

label {
  display: grid;
  gap: 6px;
  color: #7e2879;
  font-size: 0.82rem;
  font-weight: 800;
}

label input,
label select,
label textarea {
  color: var(--ink);
  font-size: 1rem;
  font-weight: 600;
}

.app-shell {
  width: min(100%, 720px);
  margin: 0 auto;
  padding: max(14px, env(safe-area-inset-top)) 14px max(28px, env(safe-area-inset-bottom));
}

.topbar {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 -14px;
  padding: 14px 14px 16px;
  color: #fffdfa;
  background:
    linear-gradient(135deg, rgba(255, 79, 203, 0.94), rgba(139, 92, 255, 0.92) 38%, rgba(0, 229, 255, 0.92) 74%, rgba(255, 195, 66, 0.92));
  box-shadow: 0 16px 38px rgba(0, 0, 0, 0.28);
}

.topbar::after {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 4px;
  content: "";
  background:
    repeating-linear-gradient(90deg, #fff 0 10px, var(--gold) 10px 20px, var(--pink) 20px 31px, var(--cyan) 31px 42px);
  animation: neon-runway 7s linear infinite;
}

.topbar h1 {
  position: relative;
  margin: 0;
  font-size: 1.75rem;
  line-height: 1.1;
  letter-spacing: 0;
  text-shadow: 0 2px 0 rgba(0, 0, 0, 0.2), 0 0 18px rgba(255, 255, 255, 0.44);
}

.brand-lockup {
  display: flex;
  align-items: center;
  min-width: 0;
  gap: 10px;
}

.brand-lockup > div {
  min-width: 0;
}

.app-icon {
  flex: 0 0 auto;
  width: 48px;
  height: 48px;
  border: 1px solid rgba(255, 255, 255, 0.58);
  border-radius: 8px;
  background: #080817;
  box-shadow: 0 0 20px rgba(0, 229, 255, 0.28), 0 8px 18px rgba(0, 0, 0, 0.2);
}

.eyebrow {
  margin: 0 0 4px;
  color: #fff7c8;
  font-size: 0.76rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0;
}

.powered-line {
  margin: 3px 0 0;
  color: #ffffff;
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0;
  text-shadow: 0 0 10px rgba(0, 0, 0, 0.28);
}

.status-pill {
  flex: 0 0 auto;
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 8px;
  background: rgba(5, 8, 24, 0.72);
  color: #fffdfa;
  padding: 8px 10px;
  font-size: 0.76rem;
  font-weight: 900;
  box-shadow: 0 0 18px rgba(0, 229, 255, 0.22);
}

.status-pill.ready {
  border-color: var(--green);
  color: #bdf0cf;
}

.quick-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 12px 0;
}

.quick-stats div {
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 248, 251, 0.96), rgba(255, 239, 252, 0.94));
  box-shadow: var(--shadow);
  padding: 10px;
}

.quick-stats strong,
.quick-stats span {
  display: block;
}

.quick-stats strong {
  overflow-wrap: anywhere;
  color: #220f35;
  font-size: 1.15rem;
  line-height: 1.1;
}

.quick-stats span {
  color: #7e2879;
  font-size: 0.76rem;
  font-weight: 800;
  text-transform: uppercase;
}

.tabs {
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  overflow-x: auto;
  gap: 6px;
  margin: 0 -14px 12px;
  padding: 8px 14px;
  background: rgba(10, 9, 28, 0.86);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.14);
  scrollbar-width: none;
}

.tabs::-webkit-scrollbar {
  display: none;
}

.tabs button {
  flex: 1 0 86px;
  min-height: 40px;
  border-color: rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.08);
  color: #f9edff;
  box-shadow: none;
  padding: 8px 4px;
  font-size: 0.78rem;
}

.tabs button.active {
  border-color: rgba(255, 255, 255, 0.82);
  background:
    linear-gradient(135deg, var(--gold), var(--pink) 52%, var(--cyan));
  color: #13071e;
  box-shadow: 0 0 18px rgba(255, 79, 203, 0.28);
}

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

.panel,
.event-card,
.pin-card {
  min-width: 0;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 250, 253, 0.98), rgba(255, 240, 252, 0.94));
  box-shadow: var(--shadow);
}

.local-profile-panel,
.offline-panel,
.prep-home {
  border-color: rgba(0, 229, 255, 0.32);
}

.offline-panel {
  display: grid;
  gap: 10px;
  background:
    linear-gradient(135deg, #eafff3, #e2fbff 52%, #fff2fd);
}

.registration-panel {
  display: grid;
  gap: 10px;
  border-color: rgba(255, 195, 66, 0.58);
  background:
    linear-gradient(135deg, #fff7d8, #ffe7fa 48%, #d8fbff);
}

.legal-panel {
  display: grid;
  gap: 10px;
  border-color: rgba(139, 92, 255, 0.42);
  background:
    linear-gradient(135deg, #f6efff, #eefbff 52%, #fff8dc);
}

.legal-footer {
  margin: 12px 0 0;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 8px;
  background: rgba(8, 8, 23, 0.68);
  color: #e9e3ff;
  padding: 10px;
  font-size: 0.74rem;
  font-weight: 700;
  line-height: 1.35;
}

.consent-list {
  display: grid;
  gap: 8px;
}

.consent-list label {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 40px;
  border: 1px solid rgba(255, 79, 203, 0.24);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.7);
  color: #37133d;
  padding: 8px;
  font-size: 0.88rem;
}

.consent-list input {
  flex: 0 0 18px;
  width: 18px;
  min-height: 18px;
  accent-color: var(--pink);
}

.signup-count {
  margin: 0;
  border: 1px solid rgba(0, 229, 255, 0.32);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.72);
  color: #502052;
  padding: 9px 10px;
  font-size: 0.86rem;
  font-weight: 900;
}

.offline-panel .lost-grid {
  margin-top: 0;
}

.offline-panel button {
  width: 100%;
}

.panel {
  position: relative;
  overflow: hidden;
  padding: 12px;
}

.panel::before,
.event-card::before,
.catalog-card::before,
.plan-card::before,
.reminder-card::before,
.pin-card::before,
.weather-card::before {
  position: absolute;
  inset: 0 0 auto;
  height: 4px;
  pointer-events: none;
  content: "";
  background:
    linear-gradient(90deg, var(--pink), var(--gold), var(--green), var(--cyan), var(--violet));
}

.panel h2,
.event-card h2,
.pin-card h2 {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.2;
  letter-spacing: 0;
}

.compact-panel {
  box-shadow: none;
}

.search-box {
  margin-bottom: 10px;
}

.search-box input {
  border-color: rgba(0, 229, 255, 0.54);
  background:
    linear-gradient(180deg, #fff, #fff7fd);
  box-shadow: 0 0 0 3px rgba(0, 229, 255, 0.08);
}

.search-box span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

.filter-strip {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 2px 0 10px;
  scrollbar-width: none;
}

.filter-strip::-webkit-scrollbar {
  display: none;
}

.filter-strip button,
.quick-add-grid button {
  flex: 0 0 auto;
  border-color: rgba(255, 79, 203, 0.34);
  background:
    linear-gradient(180deg, #fff, #fff1fb);
  color: #291235;
  box-shadow: 0 5px 16px rgba(64, 26, 92, 0.1);
  white-space: nowrap;
}

.filter-strip button.active {
  border-color: rgba(255, 255, 255, 0.78);
  background:
    linear-gradient(135deg, var(--gold), var(--pink), var(--violet));
  color: #fff;
  text-shadow: 0 1px 0 rgba(0, 0, 0, 0.24);
}

.toggle-line {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.toggle-line label {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  color: var(--ink);
  font-size: 0.9rem;
}

.toggle-line input {
  width: 18px;
  min-height: 18px;
}

.text-button {
  border: 0;
  background: transparent;
  color: #007ca4;
  padding: 6px;
  box-shadow: none;
}

.event-list,
.pin-list,
.weather-list,
.reminder-list,
.catalog-list {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.weather-mini {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  align-items: center;
  border: 1px solid rgba(255, 195, 66, 0.58);
  border-radius: 8px;
  background:
    linear-gradient(135deg, #fff3c7, #ffd6ee 42%, #d8f9ff);
  box-shadow: var(--shadow);
  padding: 12px;
}

.weather-mini-temp {
  display: grid;
  place-items: center;
  min-width: 62px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, #ff4f6d, #ff8a2a);
  color: #fffdfa;
  padding: 8px;
  box-shadow: 0 0 20px rgba(255, 79, 109, 0.28);
}

.weather-mini-temp span,
.weather-icon {
  font-size: 0.7rem;
  font-weight: 900;
}

.weather-mini-temp strong {
  font-size: 1.45rem;
  line-height: 1;
}

.weather-mini p,
.weather-card-head p {
  margin: 0 0 3px;
  color: #8a2d6f;
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.weather-mini h2 {
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.22;
  letter-spacing: 0;
}

.weather-mini button {
  min-height: 38px;
  padding: 8px 10px;
  background:
    linear-gradient(135deg, #0af0ff, #51ff99);
  color: #081222;
}

.event-card {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 10px;
  padding: 12px;
}

.event-card:nth-child(6n + 1)::before {
  background: linear-gradient(90deg, #ff4fcb, #ffc342);
}

.event-card:nth-child(6n + 2)::before {
  background: linear-gradient(90deg, #00e5ff, #2ce889);
}

.event-card:nth-child(6n + 3)::before {
  background: linear-gradient(90deg, #8b5cff, #ff4f6d);
}

.event-card:nth-child(6n + 4)::before {
  background: linear-gradient(90deg, #ff8a2a, #fff35c);
}

.event-card:nth-child(6n + 5)::before {
  background: linear-gradient(90deg, #2ce889, #ff4fcb);
}

.event-card:nth-child(6n)::before {
  background: linear-gradient(90deg, #00a7ff, #8b5cff);
}

.card-topline {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  align-items: start;
}

.icon-badge {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, var(--cyan), var(--violet));
  color: #fff;
  font-size: 0.78rem;
  font-weight: 900;
  box-shadow: 0 0 16px rgba(0, 229, 255, 0.28);
}

.icon-button {
  min-width: 58px;
  min-height: 36px;
  padding: 8px;
  font-size: 0.78rem;
}

.time-label {
  margin: 0 0 3px;
  color: #a43b84;
  font-size: 0.82rem;
  font-weight: 900;
}

.meta-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.meta-grid span,
.pin-type {
  border: 1px solid rgba(255, 79, 203, 0.32);
  border-radius: 8px;
  background:
    linear-gradient(180deg, #fff7d8, #fff0fd);
  color: #502052;
  padding: 4px 7px;
  font-size: 0.75rem;
  font-weight: 900;
}

.location-line,
.notes,
.pin-card p,
.helper-text,
.gps-line {
  margin: 0;
  color: var(--muted);
  font-size: 0.92rem;
}

.form-hint {
  margin: -4px 0 2px;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.35;
}

.location-line {
  color: var(--ink);
  font-weight: 800;
}

.action-row,
.map-tools {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.action-row > button,
.action-row > .file-button,
.action-row > .mini-button,
.map-tools > button,
.map-tools > .file-button {
  flex: 1 1 auto;
}

.event-card .action-row {
  display: grid !important;
  grid-template-columns: 1fr;
}

.event-card .action-row > button,
.event-card .action-row > .mini-button {
  min-width: 0;
  width: 100%;
}

@media (min-width: 430px) {
  .event-card .action-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .reminder-card .action-row,
  .alert-dialog .action-row,
  .catalog-card .action-row,
  .catalog-preview .action-row,
  .plan-card .action-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 390px) {
  .sun-grid {
    grid-template-columns: 1fr;
  }
}

.mini-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  background:
    linear-gradient(180deg, #fff, #effbff);
  color: var(--ink);
}

.file-button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.file-button input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.map-panel {
  display: grid;
  gap: 10px;
}

.map-stage {
  border: 1px solid rgba(0, 229, 255, 0.45);
  border-radius: 8px;
  background:
    linear-gradient(135deg, #170822, #0b1632);
  box-shadow: 0 16px 44px rgba(0, 0, 0, 0.36), 0 0 28px rgba(0, 229, 255, 0.16);
  overflow: hidden;
}

.map-canvas {
  position: relative;
  width: 100%;
  aspect-ratio: 1320 / 1750;
  overflow: hidden;
  touch-action: manipulation;
  isolation: isolate;
}

.map-canvas::before,
.map-canvas::after {
  position: absolute;
  inset: 0;
  pointer-events: none;
  content: "";
}

.map-canvas::before {
  z-index: 1;
  background:
    repeating-linear-gradient(115deg, transparent 0 34px, rgba(255, 79, 203, 0.18) 34px 36px, transparent 36px 72px),
    repeating-linear-gradient(24deg, transparent 0 46px, rgba(0, 229, 255, 0.14) 46px 48px, transparent 48px 92px);
  animation: sparkle-drift 5.6s linear infinite;
  mix-blend-mode: screen;
}

.map-canvas::after {
  z-index: 2;
  background: linear-gradient(115deg, transparent 0 42%, rgba(255, 243, 92, 0.22) 48%, transparent 54% 100%);
  transform: translateX(-70%);
  animation: map-sweep 6s ease-in-out infinite;
}

.map-canvas img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  user-select: none;
  -webkit-user-drag: none;
}

.map-pin,
.pending-pin {
  position: absolute;
  transform: translate(-50%, -50%);
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  min-height: 34px;
  border: 2px solid #fff;
  border-radius: 50%;
  background:
    linear-gradient(135deg, var(--pink), var(--violet));
  box-shadow: 0 2px 10px rgba(20, 23, 31, 0.34), 0 0 18px rgba(255, 79, 203, 0.36);
  color: #fff;
  padding: 0;
  font-size: 0.62rem;
  font-weight: 900;
  z-index: 3;
  animation: pin-bob 2.4s ease-in-out infinite;
}

.map-pin.water {
  background: linear-gradient(135deg, #00a7ff, #00e5ff);
  animation-name: water-pulse;
}

.map-pin.medical {
  background: linear-gradient(135deg, #ff4f6d, #ff8a2a);
  animation-name: urgent-pulse;
}

.map-pin.access {
  background: linear-gradient(135deg, #2ce889, #fff35c);
  color: #09121f;
}

.map-pin.bathroom {
  background: linear-gradient(135deg, #8b5cff, #00e5ff);
}

.pending-pin {
  background: linear-gradient(135deg, var(--gold), var(--pink));
  width: 42px;
  height: 42px;
  font-size: 0.68rem;
  z-index: 4;
  animation: pin-bob 1.4s ease-in-out infinite;
}

.pin-card {
  position: relative;
  overflow: hidden;
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  padding: 12px;
}

.pin-card > div {
  display: grid;
  gap: 5px;
}

.pin-card button {
  flex: 0 0 auto;
  background:
    linear-gradient(180deg, #fff, #fff1fb);
  color: var(--ink);
}

.weather-card {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 12px;
  border: 1px solid rgba(255, 255, 255, 0.26);
  border-radius: 8px;
  background: var(--surface);
  box-shadow: var(--shadow);
  padding: 12px;
}

.weather-card-head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: center;
}

.weather-icon {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, var(--pink), var(--orange));
  color: #fffdfa;
  box-shadow: 0 0 16px rgba(255, 79, 203, 0.28);
}

.weather-card h2 {
  margin: 0;
  font-size: 1.12rem;
  line-height: 1.15;
  letter-spacing: 0;
}

.weather-heat {
  border-color: rgba(255, 138, 42, 0.58);
  background: linear-gradient(135deg, #fff3c8, #ffd3e8);
}

.weather-wind,
.weather-dry {
  border-color: rgba(0, 229, 255, 0.52);
  background: linear-gradient(135deg, #e9fbff, #f3e8ff);
}

.weather-nice {
  border-color: rgba(44, 232, 137, 0.52);
  background: linear-gradient(135deg, #e9fff3, #fff8d8);
}

.weather-rain {
  border-color: rgba(0, 167, 255, 0.52);
  background: linear-gradient(135deg, #e5f6ff, #edf0ff);
}

.weather-cold {
  border-color: rgba(139, 92, 255, 0.48);
  background: linear-gradient(135deg, #f2efff, #eaf9ff);
}

.condition-line {
  margin: 0;
  color: var(--ink);
  font-weight: 800;
}

.alert-stack {
  display: grid;
  gap: 8px;
}

.alert-stack div {
  display: grid;
  gap: 4px;
  border-left: 4px solid var(--pink);
  background: rgba(255, 255, 255, 0.58);
  border-radius: 0 8px 8px 0;
  padding: 9px 10px;
}

.alert-stack strong {
  font-size: 0.76rem;
  text-transform: uppercase;
}

.alert-stack span {
  color: #343a44;
  font-size: 0.95rem;
}

.sun-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.sun-card {
  display: grid;
  gap: 6px;
  border: 1px solid rgba(255, 195, 66, 0.45);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.76), rgba(255, 246, 203, 0.78));
  padding: 10px;
}

.sun-card strong {
  color: #8a2d6f;
  font-size: 0.72rem;
  text-transform: uppercase;
}

.sun-card span {
  color: #14171f;
  font-size: 1.16rem;
  font-weight: 900;
}

.sun-card p {
  margin: 0;
  color: #5e506e;
  font-size: 0.82rem;
}

.sun-card button {
  min-height: 36px;
  padding: 7px 8px;
  background:
    linear-gradient(135deg, #fff, #fff1fb);
  color: var(--ink);
}

.prep-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.prep-list span {
  border: 1px solid rgba(255, 79, 203, 0.22);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.78);
  color: #502052;
  padding: 6px 8px;
  font-size: 0.78rem;
  font-weight: 900;
}

.weather-card > button {
  background:
    linear-gradient(135deg, #fff, #fff1fb);
  color: var(--ink);
}

.alert-control {
  display: grid;
  gap: 12px;
}

.alert-control.armed {
  border-color: rgba(44, 232, 137, 0.58);
  background:
    linear-gradient(135deg, #eafff3, #e8fbff);
}

.alert-control-head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: center;
}

.alert-icon {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, var(--pink), var(--violet), var(--cyan));
  color: #fffdfa;
  font-size: 0.72rem;
  font-weight: 900;
}

.eyebrow-dark {
  margin: 0 0 3px;
  color: #9a2f81;
  font-size: 0.76rem;
  font-weight: 900;
  text-transform: uppercase;
}

.alert-control h2,
.reminder-card h2,
.plan-card h2,
.day-section h2,
.conflict-section h2,
.conflict-choice h3,
.stage-board h2,
.stage-set h3,
.strip-card h3,
.venue-section h2,
.venue-card h3,
.alert-dialog h2 {
  margin: 0;
  letter-spacing: 0;
}

.alert-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.permission-line {
  margin: 0;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
}

.mode-panel {
  display: grid;
  gap: 12px;
}

.edc-mode-panel {
  border-color: rgba(0, 229, 255, 0.48);
}

.strip-mode-panel {
  border-color: rgba(255, 195, 66, 0.5);
}

.day-pill-row {
  padding-bottom: 4px;
}

.stage-chip-row {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 2px;
  scrollbar-width: none;
}

.stage-chip-row::-webkit-scrollbar,
.stage-swipe::-webkit-scrollbar,
.venue-swipe::-webkit-scrollbar {
  display: none;
}

.stage-chip-row span {
  color: var(--muted);
  font-weight: 900;
}

.stage-chip {
  flex: 0 0 auto;
  min-height: 38px;
  border-color: rgba(255, 79, 203, 0.28);
  background: linear-gradient(180deg, #fff, #fff1fb);
  color: #291235;
  box-shadow: none;
  white-space: nowrap;
}

.stage-chip.active {
  border-color: rgba(255, 255, 255, 0.82);
  background: linear-gradient(135deg, var(--gold), var(--pink), var(--cyan));
  color: #12071e;
}

.stage-swipe {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  overflow-x: auto;
  margin-inline: -14px;
  padding: 0 14px 6px;
  scroll-padding-inline: 14px;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
}

.stage-board {
  position: relative;
  flex: 0 0 min(88vw, 420px);
  overflow: hidden;
  display: grid;
  align-content: start;
  gap: 10px;
  min-width: 0;
  border: 1px solid rgba(255, 255, 255, 0.26);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(255, 250, 253, 0.98), rgba(245, 249, 255, 0.94));
  box-shadow: var(--shadow);
  padding: 12px;
  scroll-snap-align: center;
}

.stage-board::before {
  position: absolute;
  inset: 0 0 auto;
  height: 6px;
  content: "";
  background: linear-gradient(90deg, var(--pink), var(--gold), var(--cyan));
}

.stage-board.stage-circuit-grounds::before,
.stage-chip.stage-circuit-grounds.active {
  background: linear-gradient(90deg, #00e5ff, #00a7ff, #8b5cff);
}

.stage-board.stage-cosmic-meadow::before,
.stage-chip.stage-cosmic-meadow.active {
  background: linear-gradient(90deg, #2ce889, #fff35c, #00e5ff);
}

.stage-board.stage-basspod::before,
.stage-chip.stage-basspod.active {
  background: linear-gradient(90deg, #ff8a2a, #ffc342, #ff4f6d);
}

.stage-board.stage-neon-garden::before,
.stage-chip.stage-neon-garden.active {
  background: linear-gradient(90deg, #ff4f6d, #ff4fcb, #ffc342);
}

.stage-board.stage-quantum-valley::before,
.stage-chip.stage-quantum-valley.active {
  background: linear-gradient(90deg, #ff4fcb, #8b5cff, #00e5ff);
}

.stage-board.stage-stereobloom::before,
.stage-chip.stage-stereobloom.active {
  background: linear-gradient(90deg, #00e5ff, #ff4fcb, #2ce889);
}

.stage-board.stage-wasteland::before,
.stage-chip.stage-wasteland.active {
  background: linear-gradient(90deg, #2ce889, #ff8a2a, #ff4f6d);
}

.stage-board.stage-bionic-jungle::before,
.stage-chip.stage-bionic-jungle.active {
  background: linear-gradient(90deg, #00a7ff, #2ce889, #ffc342);
}

.stage-board-head {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: start;
}

.stage-board-head button {
  min-height: 38px;
  padding: 8px 10px;
}

.stage-board h2 {
  color: #1b1028;
  line-height: 1.05;
}

.stage-lineup {
  display: grid;
  gap: 8px;
}

.stage-set {
  display: grid;
  grid-template-columns: 78px 1fr;
  gap: 8px;
  align-items: center;
  min-width: 0;
  border: 1px solid rgba(255, 79, 203, 0.22);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.72);
  padding: 9px;
}

.stage-set.saved {
  border-color: rgba(44, 232, 137, 0.52);
  background: linear-gradient(135deg, rgba(234, 255, 243, 0.92), rgba(248, 255, 220, 0.9));
}

.stage-set-time {
  color: #9a2f81;
  font-size: 0.78rem;
  font-weight: 900;
  line-height: 1.2;
}

.stage-set-main {
  min-width: 0;
}

.stage-set-main h3 {
  overflow-wrap: anywhere;
  color: #161324;
  font-size: 0.96rem;
  line-height: 1.14;
}

.stage-set-main p {
  margin: 3px 0 0;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 900;
}

.stage-set-actions {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.stage-set-actions button {
  min-height: 36px;
  padding: 8px;
}

.strip-list {
  display: grid;
  gap: 10px;
}

.venue-section {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.venue-section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 12px;
}

.venue-section h2 {
  color: #f9edff;
  font-size: 1rem;
  text-transform: uppercase;
  text-shadow: 0 0 16px rgba(255, 79, 203, 0.28);
}

.venue-section-head span {
  flex: 0 0 auto;
  color: #fff7c8;
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.venue-swipe {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  overflow-x: auto;
  margin-inline: -14px;
  padding: 0 14px 6px;
  scroll-padding-inline: 14px;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
}

.venue-card {
  position: relative;
  flex: 0 0 min(84vw, 430px);
  overflow: hidden;
  display: grid;
  gap: 10px;
  min-width: 0;
  border: 1px solid rgba(255, 255, 255, 0.26);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(255, 250, 253, 0.98), rgba(245, 249, 255, 0.94));
  box-shadow: var(--shadow);
  padding: 12px;
  scroll-snap-align: center;
}

.venue-card::before {
  position: absolute;
  inset: 0 0 auto;
  height: 6px;
  content: "";
  background: linear-gradient(90deg, var(--gold), var(--pink), var(--violet), var(--cyan));
}

.venue-card-head {
  display: grid;
  gap: 5px;
}

.venue-card h3 {
  overflow-wrap: anywhere;
  color: #161324;
  font-size: 1.22rem;
  line-height: 1.08;
}

.venue-card-head p:last-child {
  margin: 0;
  color: #3d334a;
  font-size: 0.88rem;
  font-weight: 900;
  text-transform: uppercase;
}

.venue-map-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.venue-week {
  display: grid;
  gap: 8px;
}

.venue-day {
  display: grid;
  grid-template-columns: 74px 1fr;
  gap: 8px;
  min-width: 0;
  border: 1px solid rgba(255, 79, 203, 0.2);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.7);
  padding: 8px;
}

.venue-day.empty {
  background: rgba(255, 255, 255, 0.42);
}

.venue-day-label {
  color: #9a2f81;
  font-size: 0.76rem;
  font-weight: 900;
  line-height: 1.15;
  text-transform: uppercase;
}

.venue-day-events {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.venue-event {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.venue-event.saved strong {
  color: #087046;
}

.venue-event span,
.venue-empty {
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 900;
}

.venue-event strong {
  overflow-wrap: anywhere;
  color: #171326;
  font-size: 0.9rem;
  line-height: 1.12;
}

.strip-card {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: 82px 1fr;
  gap: 8px 10px;
  min-width: 0;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(255, 250, 253, 0.98), rgba(245, 249, 255, 0.94));
  box-shadow: var(--shadow);
  padding: 12px;
}

.strip-card::before {
  position: absolute;
  inset: 0 0 auto;
  height: 4px;
  content: "";
  background: linear-gradient(90deg, var(--gold), var(--pink), var(--cyan));
}

.strip-card.saved {
  border-color: rgba(44, 232, 137, 0.54);
  background: linear-gradient(135deg, #eafff3, #fff8d8);
}

.strip-time {
  color: #9a2f81;
  font-size: 0.8rem;
  font-weight: 900;
  line-height: 1.2;
}

.strip-main {
  min-width: 0;
}

.strip-main h3 {
  overflow-wrap: anywhere;
  color: #161324;
  font-size: 1rem;
  line-height: 1.14;
}

.strip-main p {
  margin: 4px 0 0;
  color: #3d334a;
  font-size: 0.9rem;
  font-weight: 800;
}

.strip-card .meta-grid,
.strip-card .action-row {
  grid-column: 1 / -1;
}

.reminder-card {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 10px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 8px;
  background: var(--surface);
  box-shadow: var(--shadow);
  padding: 12px;
}

.catalog-panel,
.catalog-preview,
.catalog-card,
.plan-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 250, 253, 0.98), rgba(245, 249, 255, 0.94));
  box-shadow: var(--shadow);
  padding: 12px;
}

.catalog-panel {
  display: grid;
  gap: 12px;
}

.plan-panel {
  display: grid;
  gap: 12px;
}

.weekend-builder .plan-share-row,
.quick-plan-panel,
.builder-section,
.builder-results,
.weekend-overview,
.weekend-mini-list {
  display: grid;
  gap: 10px;
}

.quick-plan-panel {
  border-color: rgba(255, 195, 66, 0.52);
  background:
    linear-gradient(135deg, rgba(255, 245, 201, 0.97), rgba(255, 225, 250, 0.95) 48%, rgba(226, 251, 255, 0.94));
}

.quick-plan-panel .section-head > span {
  color: #8a2d6f;
}

.section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 12px;
  min-width: 0;
}

.section-head > div {
  min-width: 0;
}

.section-head h2 {
  margin: 0;
}

.section-head > span {
  flex: 0 0 auto;
  color: #fff7c8;
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.section-head > button {
  flex: 0 0 auto;
  min-height: 38px;
}

.plan-search {
  border-color: rgba(0, 229, 255, 0.65);
  box-shadow: 0 0 24px rgba(0, 229, 255, 0.14);
}

.builder-result {
  scroll-margin-top: 12px;
}

.day-section .section-head h2 {
  color: #f9edff;
  font-size: 1rem;
  text-transform: uppercase;
  text-shadow: 0 0 16px rgba(255, 79, 203, 0.28);
}

.other-day-matches {
  display: grid;
  gap: 8px;
  border: 1px solid rgba(0, 229, 255, 0.3);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.08);
  padding: 10px;
}

.other-day-matches button {
  min-height: 38px;
}

.weekend-overview {
  border: 1px solid rgba(0, 229, 255, 0.26);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255, 79, 203, 0.15), rgba(0, 229, 255, 0.14)),
    rgba(255, 255, 255, 0.06);
  box-shadow: var(--shadow);
  padding: 12px;
}

.weekend-overview .section-head h2 {
  color: #f9edff;
  text-transform: uppercase;
  text-shadow: 0 0 16px rgba(255, 79, 203, 0.28);
}

.weekend-day {
  display: grid;
  gap: 8px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 250, 253, 0.98), rgba(240, 253, 255, 0.94));
  padding: 10px;
}

.weekend-day.empty {
  opacity: 0.78;
}

.weekend-day-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.weekend-day-head .text-button {
  color: #251039;
  font-weight: 1000;
  text-align: left;
}

.weekend-day-head span {
  color: #8a2d6f;
  font-size: 0.72rem;
  font-weight: 900;
  text-transform: uppercase;
}

.weekend-mini-event {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 8px;
  border: 1px solid rgba(255, 79, 203, 0.2);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.74);
  padding: 9px;
}

.weekend-mini-event.conflicted {
  border-color: rgba(255, 79, 109, 0.68);
  background: #fff0f4;
}

.weekend-mini-event span {
  color: #9a2f81;
  font-size: 0.72rem;
  font-weight: 900;
}

.weekend-mini-event strong {
  display: block;
  overflow-wrap: anywhere;
  color: #171326;
  line-height: 1.12;
}

.weekend-mini-event p {
  margin: 3px 0 0;
  color: var(--muted);
  font-size: 0.82rem;
}

.mini-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.mini-actions button {
  min-height: 36px;
  padding: 8px;
}

.day-stat-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.day-stat-grid div {
  border: 1px solid rgba(255, 79, 203, 0.25);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.72);
  padding: 10px;
}

.day-stat-grid strong,
.day-stat-grid span {
  display: block;
}

.day-stat-grid strong {
  color: #251039;
  font-size: 1.2rem;
  line-height: 1;
}

.day-stat-grid span {
  color: #8a2d6f;
  font-size: 0.72rem;
  font-weight: 900;
  text-transform: uppercase;
}

.catalog-head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: center;
}

.catalog-preview {
  display: grid;
  gap: 10px;
  border-color: rgba(255, 195, 66, 0.6);
  background:
    linear-gradient(135deg, #fff5c9, #ffe1fa 50%, #e2fbff);
}

.catalog-preview h2,
.catalog-card h2,
.plan-card h2 {
  margin: 0;
  letter-spacing: 0;
  line-height: 1.15;
}

.catalog-card,
.plan-card,
.day-section {
  display: grid;
  gap: 10px;
}

.day-section > h2 {
  font-size: 1rem;
  text-transform: uppercase;
  color: #f9edff;
  text-shadow: 0 0 16px rgba(255, 79, 203, 0.28);
}

.plan-card.saved {
  border-color: rgba(44, 232, 137, 0.58);
  background:
    linear-gradient(135deg, #eafff3, #f4ffdc);
}

.plan-card.conflicted {
  border-color: rgba(255, 79, 109, 0.68);
  background:
    linear-gradient(135deg, #ffe6ed, #fff2d5);
}

.plan-card.conflicted .meta-grid span:last-child {
  border-color: rgba(255, 79, 109, 0.68);
  background: #ffe1ee;
  color: #8b2339;
}

.conflict-section {
  display: grid;
  gap: 10px;
  border: 1px solid rgba(255, 79, 109, 0.68);
  border-radius: 8px;
  background:
    linear-gradient(135deg, #ffe6ed, #fff2d5);
  box-shadow: var(--shadow);
  padding: 12px;
}

.conflict-head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: center;
}

.conflict-card {
  display: grid;
  gap: 8px;
  border: 1px solid rgba(255, 79, 109, 0.36);
  border-radius: 8px;
  background: rgba(255, 253, 250, 0.78);
  padding: 10px;
}

.conflict-grid {
  display: grid;
  gap: 8px;
}

.conflict-choice,
.conflict-preview {
  display: grid;
  gap: 6px;
  min-width: 0;
  border: 1px solid rgba(255, 79, 203, 0.24);
  border-radius: 8px;
  background: #fffdfa;
  padding: 10px;
}

.conflict-choice h3 {
  font-size: 0.96rem;
  line-height: 1.16;
}

.conflict-choice p,
.conflict-preview p {
  margin: 0;
  color: var(--muted);
  font-size: 0.86rem;
}

.conflict-choice .action-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.conflict-focus {
  display: grid;
  gap: 8px;
}

.conflict-preview span {
  color: #9a2f81;
  font-size: 0.72rem;
  font-weight: 900;
  text-transform: uppercase;
}

.conflict-preview strong {
  overflow-wrap: anywhere;
  line-height: 1.14;
}

.conflict-dialog {
  border-color: rgba(255, 79, 109, 0.68);
  background:
    linear-gradient(135deg, #ffe6ed, #fff2d5);
}

.catalog-card .action-row,
.catalog-preview .action-row,
.plan-card .action-row {
  display: grid;
  grid-template-columns: 1fr;
}

.reminder-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.reminder-meta span {
  border: 1px solid rgba(0, 229, 255, 0.25);
  border-radius: 8px;
  background:
    linear-gradient(180deg, #eafcff, #fff2fd);
  color: #302050;
  padding: 5px 8px;
  font-size: 0.78rem;
  font-weight: 900;
}

.reminder-card .action-row {
  display: grid;
  grid-template-columns: 1fr;
}

.alert-overlay {
  position: fixed;
  inset: 0;
  z-index: 30;
  display: grid;
  align-items: end;
  background: rgba(5, 6, 20, 0.7);
  padding: 16px;
}

.alert-dialog {
  display: grid;
  gap: 10px;
  width: min(100%, 520px);
  margin: 0 auto max(4px, env(safe-area-inset-bottom));
  border: 1px solid rgba(255, 195, 66, 0.58);
  border-radius: 8px;
  background:
    linear-gradient(135deg, #fff5c9, #ffe1fa 50%, #e2fbff);
  box-shadow: 0 18px 60px rgba(20, 23, 31, 0.44), 0 0 32px rgba(255, 79, 203, 0.2);
  padding: 14px;
}

.alert-dialog .alert-icon {
  width: 48px;
  height: 48px;
}

.alert-dialog h2 {
  font-size: 1.24rem;
  line-height: 1.18;
}

.alert-dialog .action-row {
  display: grid;
  grid-template-columns: 1fr;
}

.edit-dialog {
  max-height: min(88vh, 760px);
  overflow: auto;
}

.edit-dialog .section-head {
  align-items: center;
}

.edit-dialog .section-head button {
  min-height: 36px;
  padding: 8px 10px;
}

.stack-form {
  display: grid;
  gap: 12px;
  margin-top: 12px;
}

.field-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.quick-add-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin-top: 12px;
}

.lost-card {
  background:
    linear-gradient(135deg, #e8fbff, #f8e9ff);
}

.lost-note {
  margin: 10px 0;
  border: 1px solid rgba(255, 79, 203, 0.22);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.86), rgba(255, 246, 222, 0.84));
  color: #281731;
  padding: 11px;
  font-weight: 900;
  line-height: 1.35;
}

.lost-actions {
  margin: 10px 0 2px;
}

.lost-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  margin-top: 10px;
  font-size: 0.95rem;
}

.lost-grid span {
  color: var(--muted);
}

.checklist {
  margin: 10px 0 14px;
  padding-left: 20px;
  color: var(--muted);
}

.checklist li + li {
  margin-top: 6px;
}

.empty-state {
  border: 1px dashed rgba(255, 255, 255, 0.34);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.08);
  color: #f5d9ff;
  padding: 18px;
  text-align: center;
}

.toast {
  position: fixed;
  left: 14px;
  right: 14px;
  bottom: max(14px, env(safe-area-inset-bottom));
  z-index: 20;
  max-width: 680px;
  margin: 0 auto;
  border-radius: 8px;
  background:
    linear-gradient(135deg, #15152f, #3b145d);
  color: #fff;
  box-shadow: 0 12px 38px rgba(0, 0, 0, 0.36), 0 0 28px rgba(255, 79, 203, 0.28);
  padding: 13px 14px;
  font-weight: 800;
  text-align: center;
}

@keyframes pin-bob {
  0%,
  100% {
    transform: translate(-50%, -50%) translateY(0);
  }

  50% {
    transform: translate(-50%, -50%) translateY(-4px);
  }
}

@keyframes water-pulse {
  0%,
  100% {
    transform: translate(-50%, -50%) scale(1);
    box-shadow: 0 2px 10px rgba(20, 23, 31, 0.34), 0 0 0 0 rgba(0, 229, 255, 0.42);
  }

  50% {
    transform: translate(-50%, -50%) scale(1.08);
    box-shadow: 0 2px 10px rgba(20, 23, 31, 0.34), 0 0 0 9px rgba(0, 229, 255, 0);
  }
}

@keyframes urgent-pulse {
  0%,
  100% {
    transform: translate(-50%, -50%) scale(1);
  }

  50% {
    transform: translate(-50%, -50%) scale(1.12);
  }
}

@keyframes sparkle-drift {
  0% {
    transform: translateY(0);
    opacity: 0.55;
  }

  50% {
    opacity: 0.9;
  }

  100% {
    transform: translateY(-24px);
    opacity: 0.55;
  }
}

@keyframes map-sweep {
  0%,
  28% {
    transform: translateX(-80%);
  }

  72%,
  100% {
    transform: translateX(80%);
  }
}

@keyframes neon-runway {
  0% {
    background-position: 0 0;
  }

  100% {
    background-position: 168px 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
  }
}

@media (min-width: 560px) {
  .app-shell {
    padding-inline: 18px;
  }

  .topbar,
  .tabs {
    margin-inline: -18px;
    padding-inline: 18px;
  }

  .field-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .field-row:has(label:nth-child(3)) {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .conflict-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .weekend-mini-event {
    grid-template-columns: minmax(0, 1fr) 170px;
    align-items: center;
  }
}
