﻿:root {
  --bg-0: #0b0320;
  --bg-1: #1c0840;
  --bg-2: #2f0d68;
  --nebula: #8d55ff;
  --neon: #bc8cff;
  --cyan: #6ce6ff;
  --text: #f5f1ff;
  --muted: #d7c9f6;
  --glass: rgba(255, 255, 255, 0.08);
  --glass-strong: rgba(255, 255, 255, 0.14);
  --border: rgba(255, 255, 255, 0.2);
  --shadow: 0 20px 50px rgba(3, 0, 13, 0.45);
  --radius: 16px;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
}

body {
  font-family: "Manrope", sans-serif;
  color: var(--text);
  background: linear-gradient(145deg, var(--bg-0), var(--bg-1) 45%, var(--bg-2));
  overflow-x: hidden;
}

.bg-stars,
.bg-rings {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -2;
}

.bg-stars {
  background-image:
    radial-gradient(circle at 20% 25%, rgba(255, 255, 255, 0.35) 0 1px, transparent 1.5px),
    radial-gradient(circle at 70% 80%, rgba(255, 255, 255, 0.35) 0 1px, transparent 1.5px),
    radial-gradient(circle at 85% 30%, rgba(255, 255, 255, 0.25) 0 1px, transparent 1.5px),
    radial-gradient(circle at 40% 75%, rgba(255, 255, 255, 0.35) 0 1px, transparent 1.5px);
  background-size: 220px 220px, 260px 260px, 320px 320px, 180px 180px;
  opacity: 0.5;
  animation: drift 80s linear infinite;
}

.bg-rings {
  background:
    radial-gradient(circle at 15% 10%, rgba(188, 140, 255, 0.4), transparent 45%),
    radial-gradient(circle at 80% 20%, rgba(108, 230, 255, 0.2), transparent 42%),
    radial-gradient(circle at 60% 85%, rgba(141, 85, 255, 0.4), transparent 50%);
  filter: blur(22px);
  z-index: -1;
}

.hero,
main {
  width: min(1200px, calc(100% - 2.4rem));
  margin: 0 auto;
}

.hero {
  padding: 1.2rem 0 2rem;
}

.topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
}

.brand-orb {
  width: 22px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #fff, var(--neon) 40%, var(--bg-0) 70%);
  box-shadow: 0 0 22px var(--neon);
}

.brand-text {
  font-family: "Sora", sans-serif;
  letter-spacing: 0.08em;
  font-weight: 900;
}

.brand-text span {
  color: var(--cyan);
}

.hero-content {
  margin-top: 2.2rem;
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 1.2rem;
  align-items: stretch;
}

.eyebrow {
  text-transform: uppercase;
  font-size: 0.76rem;
  letter-spacing: 0.17em;
  color: var(--cyan);
  margin-bottom: 0.5rem;
}

h1,
h2,
h3 {
  font-family: "Sora", sans-serif;
  margin: 0;
}

h1 {
  font-size: clamp(1.85rem, 3.6vw, 3.2rem);
  line-height: 1.15;
}

.hero-copy {
  color: var(--muted);
  max-width: 62ch;
}

.hero-actions {
  display: flex;
  gap: 0.8rem;
  flex-wrap: wrap;
}

.status-panel,
.panel,
.event-card,
.post-card,
.post-form,
.ticket-form,
.purchase-item {
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.05));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
}

.status-panel {
  padding: 1rem;
}

.status-panel h2 {
  font-size: 1rem;
}

.status-line {
  color: var(--muted);
  font-size: 0.94rem;
}

.account-panel {
  margin-top: 0.8rem;
  padding: 0.75rem;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(8, 4, 24, 0.45);
  display: grid;
  gap: 0.55rem;
}

.profile-card {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.45rem;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.08);
}

.profile-card img {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.24);
  object-fit: cover;
}

.profile-card strong,
.profile-card small {
  display: block;
}

.profile-card small {
  color: var(--muted);
  font-size: 0.76rem;
}

.hidden {
  display: none !important;
}

.kpi-grid {
  margin-top: 1rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.6rem;
}

.kpi-grid article {
  padding: 0.7rem;
  background: rgba(8, 4, 24, 0.5);
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.12);
}

.kpi-grid span {
  display: block;
  font-size: 1.2rem;
  font-weight: 700;
}

.kpi-grid small {
  color: var(--muted);
  font-size: 0.75rem;
}

main {
  padding-bottom: 2.6rem;
  display: grid;
  gap: 1rem;
}

.panel {
  padding: 1rem;
}

.section-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.8rem;
}

.filters {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.7rem;
  margin-bottom: 1rem;
}

label {
  display: grid;
  gap: 0.35rem;
  font-size: 0.84rem;
  color: var(--muted);
}

input,
select,
textarea {
  width: 100%;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.25);
  padding: 0.65rem 0.75rem;
  background: rgba(8, 4, 24, 0.68);
  color: var(--text);
  font: inherit;
}

textarea {
  resize: vertical;
}

.btn {
  border: 0;
  border-radius: 999px;
  color: var(--text);
  cursor: pointer;
  padding: 0.58rem 1rem;
  font-weight: 700;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform 180ms ease, box-shadow 200ms ease, background 200ms ease;
}

.btn:hover {
  transform: translateY(-1px);
}

.btn-primary {
  background: linear-gradient(90deg, var(--nebula), var(--neon));
  box-shadow: 0 9px 22px rgba(141, 85, 255, 0.45);
}

.btn-secondary {
  background: linear-gradient(90deg, #2b145f, #401986);
}

.btn-glass {
  border: 1px solid var(--border);
  background: var(--glass);
}

.event-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.8rem;
}

#map {
  min-height: 480px;
  border-radius: 14px;
  border: 1px solid var(--border);
  overflow: hidden;
}

.event-list {
  display: grid;
  gap: 0.7rem;
  max-height: 480px;
  overflow-y: auto;
  padding-right: 0.2rem;
}

.event-card {
  padding: 0.8rem;
  animation: rise-in 350ms ease;
}

.event-card-clickable {
  cursor: pointer;
}

.event-card-clickable:hover {
  border-color: rgba(108, 230, 255, 0.5);
}

.event-card-selected {
  border-color: var(--cyan);
  box-shadow: 0 0 0 1px rgba(108, 230, 255, 0.55), 0 18px 42px rgba(3, 0, 13, 0.5);
}

.event-top,
.event-bottom,
.post-head,
.post-actions,
.comment {
  display: flex;
  justify-content: space-between;
  gap: 0.7rem;
}

.event-top {
  align-items: center;
}

.event-tag {
  margin: 0;
  display: inline-block;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.event-distance,
.event-meta,
.event-description,
.event-availability,
.post-event,
.post-time,
.comment small {
  color: var(--muted);
}

.event-card h3 {
  margin: 0.35rem 0;
  font-size: 1.1rem;
}

.event-meta,
.event-description {
  margin: 0.2rem 0;
  font-size: 0.92rem;
}

.event-bottom {
  margin-top: 0.6rem;
  align-items: flex-end;
}

.event-price {
  display: block;
  font-size: 1.2rem;
}

.purchase-list,
.feed {
  display: grid;
  gap: 0.75rem;
}

.purchase-item {
  padding: 0.8rem;
}

.post-form {
  padding: 0.9rem;
  margin-bottom: 0.8rem;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem;
  align-items: end;
}

.post-form .post-text {
  grid-column: 1 / -1;
}

.feed {
  max-height: 520px;
  overflow-y: auto;
  padding-right: 0.2rem;
}

.post-card {
  padding: 0.85rem;
}

.post-head {
  align-items: center;
}

.post-head p,
.post-card p,
.post-event,
.post-time {
  margin: 0;
}

.post-text {
  margin: 0.65rem 0;
  line-height: 1.4;
}

.comments {
  display: grid;
  gap: 0.3rem;
  margin-bottom: 0.55rem;
}

.comment {
  align-items: center;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 9px;
  padding: 0.36rem 0.5rem;
  background: rgba(0, 0, 0, 0.16);
}

.comment p {
  margin: 0;
  font-size: 0.88rem;
}

.comment-form {
  display: grid;
  grid-template-columns: 0.5fr 1fr auto;
  gap: 0.42rem;
}

dialog {
  border: 0;
  padding: 0;
  background: transparent;
  color: var(--text);
}

dialog::backdrop {
  background: rgba(0, 0, 0, 0.72);
}

.ticket-form {
  width: min(430px, calc(100vw - 2rem));
  padding: 1rem;
  display: grid;
  gap: 0.72rem;
}

.event-details {
  width: min(640px, calc(100vw - 2rem));
  padding: 1rem;
  display: grid;
  gap: 0.8rem;
  color: var(--text);
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.05));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
}

.event-details-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.8rem;
}

.event-details-meta,
.event-details-description {
  margin: 0;
  color: var(--muted);
}

.event-details-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.6rem;
}

.event-details-grid article {
  padding: 0.6rem;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 10px;
  background: rgba(8, 4, 24, 0.42);
}

.event-details-grid small {
  display: block;
  color: var(--muted);
  margin-bottom: 0.2rem;
}

.event-details-actions {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.event-details a {
  color: var(--text);
}

.event-details a:visited,
.event-details a:hover,
.event-details a:active {
  color: var(--text);
}

.leaflet-popup-content-wrapper,
.leaflet-popup-tip {
  background: rgba(16, 8, 36, 0.95);
  color: var(--text);
  border: 1px solid rgba(255, 255, 255, 0.2);
}

.leaflet-popup-content {
  color: var(--text);
}

.ticket-form menu {
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
}

.ticket-total {
  margin: 0;
}

.empty {
  border: 1px dashed rgba(255, 255, 255, 0.3);
  border-radius: 12px;
  color: var(--muted);
  text-align: center;
  padding: 1rem;
}

.map-pill {
  background: #2f0d68;
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: #fff;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: "Sora", sans-serif;
  font-size: 0.8rem;
  box-shadow: 0 0 16px rgba(188, 140, 255, 0.55);
}

.user-marker {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #fff, var(--cyan));
  border: 2px solid #02172c;
  box-shadow: 0 0 14px rgba(108, 230, 255, 0.7);
}

@keyframes drift {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(-200px, -70px, 0);
  }
}

@keyframes rise-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 1100px) {
  .hero-content,
  .event-layout {
    grid-template-columns: 1fr;
  }

  #map {
    min-height: 340px;
  }

  .event-list,
  .feed {
    max-height: none;
  }
}

@media (max-width: 760px) {
  .hero,
  main {
    width: min(1200px, calc(100% - 1.2rem));
  }

  .filters,
  .post-form {
    grid-template-columns: 1fr;
  }

  .kpi-grid {
    grid-template-columns: 1fr;
  }

  .comment-form {
    grid-template-columns: 1fr;
  }

  .event-details-grid {
    grid-template-columns: 1fr;
  }

  .topbar {
    flex-direction: column;
    align-items: flex-start;
  }
}

