:root {
  --bg-950: #030e1a;
  --bg-900: #051827;
  --bg-850: #062238;
  --bg-800: #083150;
  --surface-900: rgba(6, 29, 46, 0.88);
  --surface-850: rgba(8, 39, 61, 0.84);
  --surface-800: rgba(10, 50, 78, 0.76);
  --surface-750: rgba(11, 65, 99, 0.68);
  --line-soft: rgba(68, 193, 248, 0.22);
  --line-strong: rgba(89, 215, 255, 0.46);
  --text-strong: #edf9ff;
  --text-main: #c4deee;
  --text-soft: #8bb4cb;
  --cyan-500: #00bfff;
  --cyan-400: #37dfff;
  --cyan-300: #7ceeff;
  --blue-500: #1991ff;
  --blue-400: #3bb8ff;
  --accent-mix: linear-gradient(118deg, var(--cyan-400), var(--blue-500));
  --accent-glow: 0 16px 42px rgba(0, 174, 255, 0.34);
  --radius-xs: 10px;
  --radius-sm: 14px;
  --radius-md: 18px;
  --radius-lg: 24px;
  --radius-xl: 32px;
  --shadow-1: 0 14px 34px rgba(2, 16, 29, 0.35);
  --shadow-2: 0 28px 70px rgba(1, 10, 20, 0.46);
  --shadow-glass: 0 26px 68px rgba(1, 12, 22, 0.56);
  --glass-border: rgba(122, 226, 255, 0.32);
  --glass-highlight: rgba(169, 242, 255, 0.2);
  --liquid-rim: rgba(73, 210, 255, 0.46);
}

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

html {
  min-height: 100%;
  scroll-behavior: smooth;
  overscroll-behavior-y: none;
  background: var(--bg-950);
}

body {
  margin: 0;
  min-height: 100vh;
  color: var(--text-main);
  font-family: "Outfit", sans-serif;
  font-size: 16px;
  line-height: 1.6;
  letter-spacing: 0.01em;
  background:
    radial-gradient(900px 560px at -12% -16%, rgba(30, 170, 225, 0.28), transparent 58%),
    radial-gradient(900px 620px at 112% 5%, rgba(15, 145, 209, 0.18), transparent 62%),
    linear-gradient(160deg, var(--bg-950), var(--bg-900) 44%, var(--bg-850) 72%, var(--bg-800));
  background-color: var(--bg-950);
  overflow-x: hidden;
  overscroll-behavior-y: none;
  position: relative;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  background: url("event2.png") center top / cover no-repeat;
  opacity: 0.14;
  filter: saturate(0.92) brightness(0.72) blur(0.3px);
  pointer-events: none;
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(180deg, rgba(2, 11, 18, 0.66) 0%, rgba(2, 14, 23, 0.74) 34%, rgba(3, 18, 30, 0.84) 100%),
    radial-gradient(1300px 500px at 50% -14%, rgba(73, 211, 255, 0.14), transparent 66%),
    radial-gradient(900px 420px at 10% 24%, rgba(26, 130, 203, 0.1), transparent 68%),
    radial-gradient(900px 420px at 90% 24%, rgba(29, 142, 215, 0.1), transparent 68%);
  pointer-events: none;
}

main {
  position: relative;
  isolation: isolate;
}

main::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -40px;
  height: 980px;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(680px 280px at 50% 120px, rgba(89, 221, 255, 0.16), transparent 70%),
    radial-gradient(520px 260px at 16% 330px, rgba(51, 166, 255, 0.12), transparent 72%),
    radial-gradient(520px 260px at 84% 350px, rgba(37, 152, 245, 0.11), transparent 72%);
}

[hidden] {
  display: none !important;
}

html.js body.page-leaving {
  opacity: 0;
  transform: translateY(10px) scale(0.992);
  filter: blur(2px);
  transition: opacity 0.24s ease, transform 0.24s ease, filter 0.24s ease;
  pointer-events: none;
}

::selection {
  color: #032036;
  background: rgba(81, 225, 255, 0.9);
}

::-webkit-scrollbar {
  width: 11px;
}

::-webkit-scrollbar-track {
  background: rgba(1, 14, 24, 0.95);
}

::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, rgba(0, 189, 255, 0.92), rgba(14, 111, 201, 0.92));
  border: 2px solid rgba(2, 16, 29, 0.95);
  border-radius: 999px;
}

.container {
  width: min(1240px, calc(100% - 2.8rem));
  margin: 0 auto;
}

.ambient {
  position: fixed;
  border-radius: 999px;
  filter: blur(62px);
  z-index: -1;
  pointer-events: none;
}

.ambient-1 {
  width: 370px;
  height: 370px;
  left: -110px;
  top: 120px;
  background: rgba(38, 191, 248, 0.2);
}

.ambient-2 {
  width: 330px;
  height: 330px;
  right: -110px;
  top: 360px;
  background: rgba(24, 156, 222, 0.2);
}

h1,
h2,
h3,
h4 {
  margin: 0;
  color: var(--text-strong);
  line-height: 1;
  letter-spacing: 0.01em;
  font-family: "Oxanium", sans-serif;
}

h1 {
  font-size: clamp(3rem, 8vw, 6.4rem);
  font-weight: 700;
}

h2 {
  font-size: clamp(2rem, 4.2vw, 3rem);
  font-weight: 700;
}

h3 {
  font-size: clamp(1.4rem, 2.8vw, 2rem);
  font-weight: 600;
}

p {
  margin: 0;
}

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

.eyebrow {
  margin: 0;
  color: var(--cyan-400);
  text-transform: uppercase;
  letter-spacing: 0.17em;
  font-weight: 700;
  font-size: 0.78rem;
}

.hero-text,
.status-card p,
.event-body p,
.empty-panel p,
.form-message,
.timeline-list div,
.admin-storage-note {
  color: var(--text-main);
  line-height: 1.64;
}

.hero-text {
  font-size: 1.06rem;
}

.page-title {
  margin-top: 0.45rem;
}

.text-gradient {
  background: var(--accent-mix);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.center {
  text-align: center;
}

.center-text {
  max-width: 760px;
  margin: 0.75rem auto 0;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  border-bottom: 1px solid rgba(71, 194, 245, 0.28);
  background:
    linear-gradient(140deg, rgba(7, 39, 61, 0.82), rgba(5, 29, 45, 0.9)),
    radial-gradient(700px 180px at 50% 0%, rgba(65, 208, 255, 0.12), transparent 70%);
  backdrop-filter: blur(16px) saturate(1.18);
  box-shadow: 0 14px 40px rgba(0, 10, 18, 0.44);
}

.topbar::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(130, 232, 255, 0.54), transparent);
}

.topbar::before {
  content: "";
  position: absolute;
  left: 18%;
  top: -60%;
  width: 180px;
  height: 220%;
  background: linear-gradient(90deg, transparent, rgba(172, 239, 255, 0.11), transparent);
  filter: blur(6px);
  pointer-events: none;
  animation: nav-gloss 7.2s linear infinite;
}

.topbar-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 1rem;
  padding: 0.8rem 0;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.76rem;
  color: var(--text-strong);
  text-decoration: none;
  font-weight: 700;
  font-size: 1.08rem;
}

.brand img {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  object-fit: cover;
  border: 1px solid rgba(90, 221, 255, 0.44);
  box-shadow: 0 10px 24px rgba(0, 14, 24, 0.42);
}

.nav {
  justify-self: center;
  display: inline-flex;
  align-items: center;
  gap: 1.6rem;
}

.nav a {
  position: relative;
  color: var(--text-soft);
  text-decoration: none;
  font-weight: 600;
  font-size: 1rem;
  padding: 0.3rem 0.12rem;
  transition: color 0.2s ease;
}

.nav a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -0.2rem;
  height: 2px;
  border-radius: 999px;
  background: var(--accent-mix);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.22s ease;
}

.nav a:hover,
.nav a.active {
  color: var(--text-strong);
}

.nav a:hover::after,
.nav a.active::after {
  transform: scaleX(1);
}

.top-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.56rem;
}

.btn {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  text-decoration: none;
  border: 0;
  border-radius: 12px;
  cursor: pointer;
  font-weight: 700;
  font-size: 0.94rem;
  padding: 0.82rem 1.18rem;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background 0.2s ease, filter 0.2s ease;
}

.btn::before {
  content: "";
  position: absolute;
  top: -120%;
  bottom: -120%;
  left: -40%;
  width: 26%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.25), transparent);
  transform: translateX(-240%) rotate(20deg);
  transition: transform 0.6s ease;
  pointer-events: none;
}

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

.btn:hover::before {
  transform: translateX(600%) rotate(20deg);
}

.btn-small {
  padding: 0.56rem 0.9rem;
  font-size: 0.88rem;
}

.btn-primary {
  color: #03263e;
  background: var(--accent-mix);
  border: 1px solid rgba(168, 244, 255, 0.35);
  box-shadow: inset 0 1px 0 rgba(231, 252, 255, 0.52), var(--accent-glow);
  filter: saturate(1.05);
}

.btn-primary:hover {
  box-shadow: inset 0 1px 0 rgba(231, 252, 255, 0.62), 0 24px 52px rgba(0, 180, 255, 0.48);
  filter: saturate(1.1);
}

.btn-secondary {
  color: var(--text-strong);
  border: 1px solid rgba(96, 217, 255, 0.35);
  background:
    linear-gradient(140deg, rgba(10, 79, 120, 0.48), rgba(8, 55, 88, 0.7)),
    radial-gradient(130px 62px at 50% 0, rgba(164, 239, 255, 0.1), transparent 70%);
  backdrop-filter: blur(8px) saturate(1.16);
  box-shadow: inset 0 1px 0 rgba(200, 243, 255, 0.13), 0 8px 18px rgba(0, 10, 22, 0.3);
}

.btn-secondary:hover {
  border-color: rgba(124, 229, 255, 0.56);
  background:
    linear-gradient(140deg, rgba(13, 95, 141, 0.62), rgba(9, 65, 100, 0.82)),
    radial-gradient(130px 62px at 50% 0, rgba(192, 246, 255, 0.14), transparent 70%);
}

.section {
  padding: 3rem 0;
}

.section-top {
  padding-top: 3.8rem;
}

.section-head {
  margin-bottom: 1.2rem;
}

.glass {
  position: relative;
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border);
  background:
    linear-gradient(145deg, rgba(8, 40, 62, 0.68), rgba(8, 56, 84, 0.64)),
    radial-gradient(420px 140px at 50% -24%, rgba(157, 239, 255, 0.14), transparent 70%);
  box-shadow: var(--shadow-glass), inset 0 1px 0 rgba(209, 247, 255, 0.08);
  backdrop-filter: blur(14px) saturate(1.22);
  overflow: hidden;
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.glass::after {
  content: "";
  position: absolute;
  left: 1px;
  right: 1px;
  top: 1px;
  height: 1px;
  border-radius: inherit;
  background: linear-gradient(90deg, transparent, rgba(160, 238, 255, 0.56), transparent);
  pointer-events: none;
}

.glass::before {
  content: "";
  position: absolute;
  top: -130%;
  bottom: -130%;
  left: -50%;
  width: 38%;
  background: linear-gradient(90deg, transparent, rgba(181, 244, 255, 0.16), transparent);
  transform: translateX(-220%) rotate(12deg);
  transition: transform 0.7s ease;
  pointer-events: none;
}

.glass:hover {
  transform: translateY(-4px);
  border-color: rgba(129, 231, 255, 0.56);
  box-shadow: 0 32px 80px rgba(1, 10, 20, 0.58), 0 0 0 1px rgba(102, 221, 255, 0.16);
}

.glass:hover::before {
  transform: translateX(520%) rotate(12deg);
}

.hero {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 1.15rem;
  align-items: center;
  padding: 4.4rem 0 2.2rem;
}

.hero-home {
  grid-template-columns: 1fr;
  text-align: center;
  padding-bottom: 0.8rem;
}

.hero-home .hero-copy {
  width: min(980px, 100%);
  margin: 0 auto;
  padding: 2rem 1.4rem 1.5rem;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(110, 224, 255, 0.32);
  background:
    linear-gradient(160deg, rgba(7, 48, 77, 0.42), rgba(6, 31, 51, 0.58)),
    radial-gradient(680px 220px at 50% -18%, rgba(165, 243, 255, 0.16), transparent 68%);
  backdrop-filter: blur(16px) saturate(1.2);
  box-shadow: 0 24px 70px rgba(1, 13, 24, 0.52), inset 0 1px 0 rgba(208, 247, 255, 0.08);
  overflow: hidden;
}

.hero-home .hero-copy::before {
  content: "";
  position: absolute;
  inset: auto -20% -56% -20%;
  height: 260px;
  pointer-events: none;
  background: radial-gradient(50% 70% at 50% 0%, rgba(57, 202, 255, 0.22), transparent 70%);
}

.hero-home .hero-stats,
.hero-home .hero-actions {
  justify-content: center;
}

.hero-copy {
  position: relative;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  padding: 0.35rem 0.7rem;
  border-radius: 999px;
  border: 1px solid rgba(91, 218, 255, 0.4);
  background:
    linear-gradient(140deg, rgba(10, 112, 161, 0.5), rgba(8, 86, 128, 0.66)),
    radial-gradient(120px 42px at 50% 0%, rgba(180, 243, 255, 0.14), transparent 70%);
  color: #c7efff;
  font-size: 0.78rem;
  font-weight: 600;
  margin-bottom: 0.9rem;
}

.hero-copy h1 {
  text-wrap: balance;
}

.hero-actions {
  margin-top: 1.35rem;
  display: flex;
  gap: 0.68rem;
  flex-wrap: wrap;
}

.hero-stats {
  margin-top: 1.04rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.54rem;
}

.hero-stat-pill,
.status-pill,
.admin-count-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid rgba(82, 209, 255, 0.34);
  background:
    linear-gradient(140deg, rgba(9, 102, 149, 0.56), rgba(8, 78, 122, 0.66)),
    radial-gradient(100px 34px at 50% 0, rgba(177, 241, 255, 0.12), transparent 70%);
  color: #d7f4ff;
  font-size: 0.8rem;
  font-weight: 600;
  padding: 0.34rem 0.68rem;
}

.status-pill-warning {
  border-color: rgba(255, 186, 159, 0.46);
  background: rgba(112, 57, 52, 0.68);
  color: #ffd9cf;
}

.status-pill-confirmed {
  border-color: rgba(105, 225, 255, 0.42);
  background: rgba(9, 108, 161, 0.66);
}

.status-card,
.app-card,
.cta-panel,
.details-card,
.empty-panel {
  padding: 1.24rem;
}

.status-card h2 {
  margin-bottom: 0.58rem;
}

.status-list {
  margin-top: 0.62rem;
  display: grid;
  gap: 0.48rem;
}

.status-list div {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.35rem;
}

.status-list strong {
  color: var(--text-strong);
}

.metrics-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.9rem;
  align-items: stretch;
}

.metric-card {
  padding: 1.04rem;
  min-height: 208px;
  background:
    linear-gradient(150deg, rgba(8, 47, 72, 0.66), rgba(8, 38, 62, 0.72)),
    radial-gradient(320px 100px at 50% -20%, rgba(174, 244, 255, 0.12), transparent 72%);
}

.metric-top {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  color: #d6f4ff;
  font-weight: 600;
}

.metric-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(84, 213, 255, 0.44);
  background: rgba(9, 112, 164, 0.56);
  box-shadow: inset 0 0 0 1px rgba(148, 236, 255, 0.12);
}

.metric-card p {
  margin-top: 0.66rem;
  color: var(--text-soft);
  font-size: 0.95rem;
}

.metric-card:hover .metric-icon {
  box-shadow: 0 0 0 1px rgba(146, 239, 255, 0.34), 0 0 26px rgba(65, 201, 255, 0.34);
  border-color: rgba(134, 233, 255, 0.7);
}

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

.app-card h2,
.cta-panel h2 {
  margin-top: 0.26rem;
}

.app-card .btn {
  margin-top: 0.9rem;
}

.cta-panel {
  display: grid;
  gap: 0.82rem;
  align-items: center;
  grid-template-columns: 1fr auto;
}

.cta-panel p {
  color: var(--text-main);
}

.filter-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.56rem;
}

.chip {
  appearance: none;
  cursor: pointer;
  border-radius: 999px;
  border: 1px solid rgba(78, 206, 255, 0.32);
  background: rgba(8, 88, 132, 0.5);
  color: #d4f2ff;
  font-size: 0.9rem;
  font-weight: 500;
  padding: 0.46rem 0.86rem;
  transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.chip:hover {
  transform: translateY(-1px);
  border-color: var(--line-strong);
  background: rgba(8, 112, 164, 0.62);
}

.chip-active {
  color: #03263c;
  background: var(--accent-mix);
  border-color: transparent;
  font-weight: 700;
}

.events-sections-layout {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  align-items: start;
}

.events-sections-layout.events-sections-single {
  grid-template-columns: 1fr;
}

.section-compact {
  padding-top: 1.6rem;
}

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

.events-grid-single {
  grid-template-columns: 1fr;
}

.event-card {
  display: block;
  color: inherit;
  text-decoration: none;
  overflow: hidden;
  position: relative;
}

.event-cover {
  position: relative;
  overflow: hidden;
  height: 230px;
  border-bottom: 1px solid rgba(73, 201, 251, 0.22);
}

.event-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.35s ease, filter 0.35s ease;
}

.event-card:hover .event-cover img {
  transform: scale(1.06);
  filter: saturate(1.1);
}

.event-card:hover::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  box-shadow: inset 0 0 0 1px rgba(130, 231, 255, 0.18), 0 0 42px rgba(40, 182, 241, 0.2);
}

.event-cover::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(2, 15, 26, 0.04), rgba(3, 16, 28, 0.45));
}

.event-tag {
  position: absolute;
  top: 0.64rem;
  left: 0.64rem;
  z-index: 2;
  border-radius: 999px;
  padding: 0.3rem 0.6rem;
  border: 1px solid rgba(255, 176, 152, 0.46);
  background: rgba(111, 51, 51, 0.74);
  color: #ffd7cd;
  font-size: 0.75rem;
  font-weight: 700;
}

.event-tag-upcoming {
  border-color: rgba(103, 219, 255, 0.46);
  background: rgba(8, 104, 153, 0.78);
  color: #d7f4ff;
}

.event-body {
  padding: 1rem;
}

.event-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
}

.event-side-tag {
  flex: 0 0 auto;
  border-radius: 999px;
  border: 1px solid rgba(96, 216, 255, 0.38);
  background: rgba(8, 106, 159, 0.6);
  color: #dbf7ff;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  padding: 0.26rem 0.52rem;
}

.event-meta {
  margin-top: 0.54rem;
  font-size: 0.88rem;
  color: var(--text-soft);
}

.event-meta-alert {
  color: #ffd0c5;
}

.empty-panel {
  border-style: dashed;
  border-width: 1px;
  text-align: center;
}

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

.details-map {
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(81, 206, 255, 0.3);
  margin-top: 0.74rem;
}

.check-list {
  list-style: none;
  margin: 0.76rem 0 0;
  padding: 0;
  display: grid;
  gap: 0.56rem;
}

.check-list li {
  position: relative;
  padding-left: 1.34rem;
  color: var(--text-main);
}

.check-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.48rem;
  width: 0.56rem;
  height: 0.56rem;
  border-radius: 999px;
  background: var(--accent-mix);
  box-shadow: 0 0 0 3px rgba(80, 212, 255, 0.2);
}

.video-wrap iframe {
  width: 100%;
  border: 0;
  border-radius: 14px;
  aspect-ratio: 16 / 9;
}

.timeline-list {
  margin-top: 0.78rem;
  display: grid;
  gap: 0.56rem;
}

.timeline-list div {
  border-left: 3px solid rgba(64, 199, 255, 0.64);
  padding-left: 0.7rem;
}

.notice-banner {
  margin-top: 0.94rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(98, 223, 255, 0.32);
  background: linear-gradient(145deg, rgba(8, 96, 142, 0.62), rgba(8, 73, 111, 0.66));
  padding: 0.84rem 0.98rem;
}

.notice-banner p {
  color: #dbf7ff;
}

.form-shell {
  width: min(980px, 100%);
  margin: 0 auto;
  display: grid;
  gap: 1rem;
}

.gform-header {
  border-radius: var(--radius-lg);
  border: 1px solid rgba(77, 205, 255, 0.32);
  border-top: 6px solid #25cfff;
  background: linear-gradient(145deg, rgba(8, 61, 92, 0.9), rgba(8, 52, 80, 0.92));
  padding: 1.3rem;
  box-shadow: var(--shadow-1);
}

.gform-intro,
.gform-body {
  padding: 1.16rem;
}

.gform-form {
  display: grid;
  gap: 0.82rem;
}

.form-stack {
  margin-top: 0.74rem;
  display: grid;
  gap: 0.66rem;
}

.form-stack label,
.question-card label {
  display: grid;
  gap: 0.38rem;
  color: #d8f3ff;
  font-size: 0.95rem;
  font-weight: 500;
}

.form-stack input,
.form-stack textarea,
.form-stack select,
.gform-form input,
.gform-form textarea,
.gform-form select {
  width: 100%;
  border-radius: 12px;
  border: 1px solid rgba(78, 205, 255, 0.3);
  background: rgba(8, 90, 134, 0.56);
  color: var(--text-strong);
  padding: 0.68rem 0.76rem;
  resize: vertical;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.form-stack input::placeholder,
.form-stack textarea::placeholder,
.gform-form input::placeholder,
.gform-form textarea::placeholder {
  color: rgba(195, 230, 245, 0.68);
}

.form-stack input:focus,
.form-stack textarea:focus,
.form-stack select:focus,
.gform-form input:focus,
.gform-form textarea:focus,
.gform-form select:focus {
  outline: none;
  border-color: rgba(108, 227, 255, 0.72);
  background: rgba(10, 110, 161, 0.62);
  box-shadow: 0 0 0 3px rgba(64, 207, 255, 0.16);
}

.question-card {
  border-radius: 14px;
  border: 1px solid rgba(72, 199, 251, 0.24);
  background: rgba(8, 86, 126, 0.58);
  padding: 0.95rem;
  transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.question-card:hover {
  transform: translateY(-2px);
  border-color: rgba(106, 225, 255, 0.44);
  background: rgba(9, 99, 145, 0.64);
}

.question-check-grid {
  margin-top: 0.62rem;
  display: grid;
  gap: 0.48rem;
}

.checkbox-field {
  display: inline-flex !important;
  align-items: center;
  gap: 0.58rem !important;
  line-height: 1.5;
  color: #e4f8ff !important;
}

.checkbox-field input[type="checkbox"],
.checkbox-field input[type="radio"] {
  margin: 0 !important;
  width: 18px !important;
  height: 18px !important;
  min-width: 18px;
  flex: 0 0 18px;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  accent-color: #2dd6ff;
}

.question-note {
  margin: 0.5rem 0 0;
  color: var(--text-main);
  font-size: 0.86rem;
}

.question-note a {
  color: #84eaff;
}

.question-note a:hover {
  color: #b8f5ff;
}

.submit-row {
  display: grid;
  gap: 0.66rem;
}

.form-message {
  margin: 0;
  color: #91f7c4;
  font-size: 0.9rem;
}

.error-message {
  color: #ffc1cf;
}

.admin-only-mode .ambient {
  display: none;
}

.admin-overlay {
  min-height: 100vh;
  padding: 2.2rem 1rem;
  background:
    radial-gradient(900px 560px at -12% -14%, rgba(43, 188, 246, 0.22), transparent 58%),
    radial-gradient(900px 560px at 110% 10%, rgba(29, 160, 223, 0.2), transparent 58%),
    linear-gradient(160deg, #041424, #072136 46%, #093155);
}

.admin-center {
  min-height: calc(100vh - 4.4rem);
  display: grid;
  place-items: center;
}

.admin-login-card {
  width: min(520px, 100%);
  padding: 1.22rem;
}

.admin-panel-wrap {
  width: min(1340px, 100%);
  margin: 0 auto;
  display: grid;
  gap: 1rem;
}

.admin-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  border-radius: var(--radius-md);
  border: 1px solid var(--line-soft);
  background: linear-gradient(145deg, rgba(8, 67, 100, 0.86), rgba(7, 55, 83, 0.9));
  padding: 1rem;
}

.admin-head-actions {
  display: inline-flex;
  gap: 0.42rem;
}

.admin-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.84rem;
  padding: 0.88rem 1rem;
}

.admin-toolbar-main {
  display: grid;
  gap: 0.4rem;
}

.admin-search-wrap {
  display: block;
  width: min(420px, 100%);
}

.admin-search-input {
  width: 100%;
  border-radius: 11px;
  border: 1px solid rgba(98, 222, 255, 0.34);
  background: linear-gradient(145deg, rgba(8, 84, 123, 0.66), rgba(9, 67, 98, 0.7));
  color: #e6f9ff;
  padding: 0.56rem 0.75rem;
  font-size: 0.92rem;
}

.admin-search-input::placeholder {
  color: rgba(210, 239, 250, 0.72);
}

.admin-search-input:focus {
  outline: none;
  border-color: rgba(126, 231, 255, 0.74);
  box-shadow: 0 0 0 3px rgba(91, 216, 255, 0.2);
}

.admin-counts {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.admin-filter-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.45rem;
}

.admin-panel-grid {
  display: grid;
  grid-template-columns: 390px 1fr;
  gap: 1rem;
}

.admin-list,
.admin-detail {
  border-radius: var(--radius-md);
  border: 1px solid var(--line-soft);
  background: linear-gradient(145deg, rgba(8, 70, 103, 0.85), rgba(7, 55, 82, 0.9));
  padding: 0.92rem;
  min-height: 72vh;
}

.admin-list {
  display: flex;
  flex-direction: column;
  gap: 0.62rem;
  max-height: 72vh;
  overflow: auto;
}

.admin-detail {
  overflow: auto;
}

.admin-app-card {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  border-radius: 13px;
  border: 1px solid rgba(81, 208, 255, 0.3);
  background: rgba(10, 104, 153, 0.56);
  color: var(--text-strong);
  text-align: left;
  padding: 0;
  min-height: 140px;
  overflow: hidden;
  transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.admin-app-card:hover {
  transform: translateY(-2px);
  border-color: var(--line-strong);
  background: rgba(10, 120, 173, 0.62);
}

.admin-app-main {
  display: block;
  flex: 1 1 auto;
  width: 100%;
  text-align: left;
  color: inherit;
  border: 0;
  background: transparent;
  padding: 0.74rem;
  cursor: pointer;
}

.admin-app-title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.7rem;
}

.admin-app-card h3 {
  margin: 0;
  font-size: 1.36rem;
}

.admin-app-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  padding: 0.16rem 0.52rem;
  border-radius: 999px;
  border: 1px solid rgba(122, 228, 255, 0.44);
  background: rgba(8, 95, 139, 0.62);
  color: #dff7ff;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1.2;
}

.admin-app-card p {
  margin: 0.3rem 0 0;
  color: #c7eafe;
  letter-spacing: 0.08em;
  font-size: 0.84rem;
}

.admin-app-card small {
  display: block;
  margin-top: 0.35rem;
  color: var(--text-soft);
}

.admin-review-text {
  font-size: 0.72rem;
  letter-spacing: 0.09em;
  font-weight: 700;
  color: #daf4ff;
}

.admin-app-actions {
  display: flex;
  align-items: center;
  gap: 0.38rem;
  justify-content: flex-start;
  margin-top: auto;
  border-top: 1px solid rgba(84, 208, 255, 0.2);
  background: rgba(6, 78, 114, 0.42);
  padding: 0 0.74rem 0.72rem;
}

.admin-review-btn {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  border: 1px solid rgba(106, 220, 255, 0.36);
  background: rgba(11, 92, 133, 0.68);
  color: #dff6ff;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  transition: transform 0.16s ease, border-color 0.16s ease, background 0.16s ease, box-shadow 0.16s ease;
}

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

.admin-review-btn:disabled {
  opacity: 0.7;
  cursor: wait;
}

.admin-review-accept {
  border-color: rgba(108, 235, 164, 0.42);
  color: #d5ffe6;
}

.admin-review-accept:hover,
.admin-review-accept.is-selected {
  border-color: rgba(123, 245, 177, 0.76);
  background: rgba(28, 132, 81, 0.72);
  box-shadow: 0 0 0 2px rgba(115, 232, 168, 0.2);
}

.admin-review-deny {
  border-color: rgba(255, 165, 165, 0.42);
  color: #ffe0e0;
}

.admin-review-deny:hover,
.admin-review-deny.is-selected {
  border-color: rgba(255, 164, 164, 0.76);
  background: rgba(142, 49, 49, 0.7);
  box-shadow: 0 0 0 2px rgba(255, 156, 156, 0.18);
}

.admin-app-card-accepted {
  border-color: rgba(109, 236, 166, 0.74);
  background: linear-gradient(145deg, rgba(22, 102, 72, 0.76), rgba(15, 84, 59, 0.8));
}

.admin-app-card-denied {
  border-color: rgba(255, 161, 161, 0.72);
  background: linear-gradient(145deg, rgba(128, 46, 46, 0.76), rgba(102, 34, 34, 0.82));
}

.admin-app-card.active {
  border-color: rgba(112, 228, 255, 0.82);
  box-shadow: 0 0 0 2px rgba(84, 209, 255, 0.24), 0 14px 30px rgba(0, 20, 36, 0.3);
}

.admin-app-card.active.admin-app-card-accepted {
  box-shadow: 0 0 0 2px rgba(115, 232, 168, 0.34), 0 14px 30px rgba(0, 20, 36, 0.3);
}

.admin-app-card.active.admin-app-card-denied {
  box-shadow: 0 0 0 2px rgba(255, 156, 156, 0.3), 0 14px 30px rgba(0, 20, 36, 0.3);
}

.admin-detail-header h3 {
  font-size: clamp(1.7rem, 2.8vw, 2.3rem);
}

.admin-detail-header p {
  color: var(--text-main);
}

.admin-review-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid rgba(101, 220, 255, 0.42);
  background: rgba(10, 104, 150, 0.58);
  color: #e6f8ff;
  font-size: 0.8rem;
  font-weight: 600;
  padding: 0.18rem 0.56rem;
}

.admin-review-pill-pending {
  border-color: rgba(101, 220, 255, 0.42);
  background: rgba(10, 104, 150, 0.58);
  color: #e6f8ff;
}

.admin-review-pill-accepted {
  border-color: rgba(123, 245, 177, 0.72);
  background: rgba(25, 127, 80, 0.64);
  color: #dcffeb;
}

.admin-review-pill-denied {
  border-color: rgba(255, 164, 164, 0.72);
  background: rgba(136, 49, 49, 0.66);
  color: #ffe4e4;
}

.admin-detail-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.52rem;
  margin: 0.68rem 0 0.34rem;
}

.admin-detail-actions .admin-review-btn {
  width: auto;
  min-width: 118px;
  height: 34px;
  padding: 0 0.78rem;
  border-radius: 9px;
  font-size: 0.9rem;
}

.admin-answer-list {
  margin-top: 0.8rem;
  display: grid;
  gap: 0.64rem;
}

.admin-answer-row {
  border-left: 3px solid rgba(73, 204, 255, 0.62);
  border-radius: 10px;
  background: rgba(10, 103, 149, 0.58);
  padding: 0.66rem 0.78rem;
}

.admin-answer-row h4 {
  margin: 0;
  color: #bdeaff;
  font-size: 0.9rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.admin-answer-row p {
  margin: 0.42rem 0 0;
  color: #eefaff;
  line-height: 1.54;
  white-space: pre-wrap;
}

.footer {
  margin-top: 2rem;
  border-top: 1px solid rgba(77, 206, 255, 0.22);
  background: linear-gradient(180deg, rgba(2, 18, 30, 0), rgba(2, 18, 30, 0.42));
}

.footer-inner {
  padding: 1rem 0 2rem;
  display: flex;
  justify-content: space-between;
  gap: 0.6rem;
  color: var(--text-soft);
  font-size: 0.9rem;
}

.reveal {
  opacity: 0;
  transform: translateY(24px) scale(0.986);
  transition: opacity 0.58s ease, transform 0.58s ease;
  transition-delay: var(--reveal-delay, 0ms);
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

@keyframes nav-gloss {
  from {
    transform: translateX(-240px);
  }
  to {
    transform: translateX(1320px);
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0s !important;
    transition-duration: 0s !important;
  }

  .reveal,
  .reveal.is-visible {
    opacity: 1;
    transform: none;
  }
}

@media (max-width: 1180px) {
  .hero,
  .applications,
  .details-layout {
    grid-template-columns: 1fr;
  }

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

  .events-sections-layout,
  .events-grid {
    grid-template-columns: 1fr;
  }

  .cta-panel {
    grid-template-columns: 1fr;
  }

  .admin-panel-grid {
    grid-template-columns: 1fr;
  }

  .admin-list,
  .admin-detail {
    min-height: auto;
    max-height: none;
  }

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

  .admin-filter-row {
    justify-content: flex-start;
  }
}

@media (max-width: 820px) {
  .container {
    width: min(1240px, calc(100% - 1.4rem));
  }

  .topbar-inner {
    grid-template-columns: 1fr;
    justify-items: start;
    gap: 0.75rem;
  }

  .nav {
    justify-self: start;
    gap: 1.1rem;
  }

  .top-actions {
    width: 100%;
    justify-content: flex-end;
  }

  .hero {
    padding-top: 3.2rem;
  }

  .hero-actions {
    width: 100%;
  }

  .hero-actions .btn {
    flex: 1 1 190px;
  }

  .event-cover {
    height: 210px;
  }

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

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