:root {
  color-scheme: dark;
  --vp-bg-1: #07111f;
  --vp-bg-2: #0b172a;
  --vp-bg-3: #101e36;
  --vp-card: rgba(13, 24, 43, 0.72);
  --vp-card-strong: rgba(16, 29, 52, 0.9);
  --vp-card-soft: rgba(12, 20, 38, 0.66);
  --vp-line: rgba(148, 179, 255, 0.16);
  --vp-line-strong: rgba(148, 179, 255, 0.28);
  --vp-text: #f5f9ff;
  --vp-text-soft: #c3d2ea;
  --vp-text-muted: #87a0c3;
  --vp-accent: #2b8cff;
  --vp-accent-2: #27d3ff;
  --vp-violet: #8f5cff;
  --vp-success: #2ad384;
  --vp-warning: #ffb547;
  --vp-danger: #ff5d79;
  --vp-shadow: 0 24px 80px rgba(0, 0, 0, 0.42);
  --vp-shadow-soft: 0 18px 48px rgba(7, 17, 31, 0.4);
  --vp-radius: 24px;
  --vp-radius-lg: 30px;
  --vp-safe-bottom: max(1rem, env(safe-area-inset-bottom));
}

* { box-sizing: border-box; }
html, body { min-height: 100%; background: var(--vp-bg-1); }
body.vp-standalone-app {
  margin: 0;
  color: var(--vp-text);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at 8% 8%, rgba(39, 211, 255, 0.12), transparent 24rem),
    radial-gradient(circle at 95% 18%, rgba(143, 92, 255, 0.12), transparent 22rem),
    radial-gradient(circle at 55% 100%, rgba(43, 140, 255, 0.16), transparent 28rem),
    linear-gradient(180deg, var(--vp-bg-1) 0%, var(--vp-bg-2) 56%, #06101d 100%);
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; }
button, input { font: inherit; }

.vp-app-shell {
  min-height: 100svh;
}

.vp-loading-shell,
.vp-auth-card,
.vp-app-phone {
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
}

.vp-loading-shell {
  width: min(100% - 1.25rem, 28rem);
  min-height: calc(100svh - 1.25rem);
  margin: 0 auto;
  display: grid;
  place-content: center;
  justify-items: center;
  gap: .75rem;
  text-align: center;
  position: relative;
}

.vp-loading-shell img,
.vp-auth-card img {
  border-radius: 1.2rem;
  box-shadow: 0 18px 34px rgba(43, 140, 255, 0.25);
}

.vp-loading-orb {
  position: absolute;
  width: 12rem;
  height: 12rem;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(39,211,255,.34) 0%, rgba(39,211,255,.1) 30%, transparent 70%);
  filter: blur(8px);
}

.vp-loading-shell h1,
.vp-auth-card h1,
.vp-section-title,
.vp-hero-title,
.vp-screen-title,
.vp-profile-name,
.vp-stat-value,
.vp-admin-value,
.vp-list-title,
.vp-event-title {
  letter-spacing: -0.03em;
}

.vp-app-frame {
  width: 100%;
  min-height: 100svh;
  padding: 0;
}

.vp-app-phone {
  width: 100%;
  min-height: 100svh;
  margin: 0 auto;
  position: relative;
  background:
    radial-gradient(circle at top left, rgba(39, 211, 255, 0.08), transparent 15rem),
    radial-gradient(circle at top right, rgba(143, 92, 255, 0.08), transparent 18rem),
    linear-gradient(180deg, rgba(8, 17, 31, 0.96) 0%, rgba(7, 15, 29, 0.98) 100%);
  overflow: hidden;
}

@media (min-width: 720px) {
  .vp-app-frame {
    padding: 1.25rem;
  }
  .vp-app-phone {
    width: min(100%, 29rem);
    min-height: calc(100svh - 2.5rem);
    border-radius: 2.25rem;
    border: 1px solid rgba(148, 179, 255, 0.12);
    box-shadow: var(--vp-shadow);
  }
}

.vp-statusbar {
  height: calc(1.1rem + env(safe-area-inset-top));
}

.vp-shell {
  padding: calc(.45rem + env(safe-area-inset-top)) 1rem calc(6rem + var(--vp-safe-bottom));
}

.vp-topbar,
.vp-screen-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  margin-bottom: 1rem;
}

.vp-brand {
  display: flex;
  align-items: center;
  gap: .8rem;
  min-width: 0;
}

.vp-brand img {
  width: 3rem;
  height: 3rem;
  border-radius: 1rem;
  box-shadow: 0 16px 28px rgba(43, 140, 255, 0.25);
}

.vp-brand-text {
  min-width: 0;
}

.vp-brand-text strong,
.vp-screen-title {
  display: block;
  font-size: 1rem;
  font-weight: 800;
}

.vp-brand-text span,
.vp-screen-subtitle,
.vp-muted,
.vp-mini-label,
.vp-doc-meta,
.vp-list-meta,
.vp-news-meta,
.vp-feature-text,
.vp-hint,
.vp-inline-meta {
  color: var(--vp-text-muted);
}

.vp-brand-text span { font-size: .8rem; }

.vp-top-actions {
  display: flex;
  align-items: center;
  gap: .55rem;
}

.vp-icon-btn,
.vp-avatar-btn,
.vp-chip,
.vp-segment,
.vp-doc-filter,
.vp-action-tile,
.vp-admin-tile,
.vp-link-row,
.vp-mini-card,
.vp-kpi,
.vp-news-card,
.vp-quick-link,
.vp-doc-item,
.vp-calendar-item,
.vp-hero,
.vp-member-card,
.vp-panel,
.vp-event-card,
.vp-important-card,
.vp-search,
.vp-bottom-nav,
.vp-nav-item,
.vp-auth-card,
.vp-checkin-card,
.vp-note {
  background: var(--vp-card);
  border: 1px solid var(--vp-line);
  box-shadow: var(--vp-shadow-soft);
}

.vp-icon-btn,
.vp-avatar-btn {
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 1rem;
  color: var(--vp-text);
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  position: relative;
}

.vp-avatar-btn {
  overflow: hidden;
  background: linear-gradient(135deg, rgba(39, 211, 255, 0.18), rgba(143, 92, 255, 0.18));
}

.vp-avatar-initials,
.vp-profile-avatar,
.vp-people-avatar,
.vp-news-thumb,
.vp-doc-icon,
.vp-admin-icon,
.vp-action-icon,
.vp-feature-icon,
.vp-hero-logo {
  display: inline-grid;
  place-items: center;
}

.vp-avatar-initials,
.vp-profile-avatar {
  width: 100%;
  height: 100%;
  border-radius: inherit;
  font-weight: 800;
  color: white;
  background: linear-gradient(135deg, var(--vp-accent), var(--vp-violet));
}

.vp-badge-dot {
  position: absolute;
  top: -.1rem;
  right: -.1rem;
  min-width: 1.2rem;
  height: 1.2rem;
  padding: 0 .3rem;
  border-radius: 999px;
  display: inline-grid;
  place-items: center;
  font-size: .68rem;
  font-weight: 700;
  background: linear-gradient(135deg, var(--vp-danger), #ff7a8f);
  color: white;
  border: 2px solid rgba(7, 17, 31, 0.96);
}

.vp-hero {
  position: relative;
  overflow: hidden;
  border-radius: 1.75rem;
  padding: 1.15rem;
  margin-bottom: 1rem;
  background:
    linear-gradient(135deg, rgba(16, 29, 52, .95), rgba(22, 42, 74, .82) 55%, rgba(32, 64, 124, .82) 100%);
}

.vp-hero::before,
.vp-member-card::before,
.vp-auth-card::before {
  content: "";
  position: absolute;
  inset: auto auto -2rem -1rem;
  width: 10rem;
  height: 10rem;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(39, 211, 255, 0.22), transparent 70%);
  filter: blur(2px);
  pointer-events: none;
}

.vp-hero::after,
.vp-member-card::after,
.vp-auth-card::after {
  content: "";
  position: absolute;
  inset: -3rem -2rem auto auto;
  width: 11rem;
  height: 11rem;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(143, 92, 255, 0.2), transparent 70%);
  pointer-events: none;
}

.vp-hero-top,
.vp-hero-bottom,
.vp-member-card-grid,
.vp-card-grid,
.vp-kpi-grid,
.vp-admin-stats,
.vp-admin-grid,
.vp-actions-grid,
.vp-feature-grid {
  display: grid;
  gap: .75rem;
}

.vp-hero-top {
  grid-template-columns: 1fr auto;
  align-items: start;
  position: relative;
  z-index: 1;
}

.vp-hero-title {
  margin: .35rem 0 .25rem;
  font-size: clamp(1.55rem, 6vw, 2rem);
  font-weight: 800;
}

.vp-hero-copy {
  margin: 0;
  color: var(--vp-text-soft);
  font-size: .92rem;
}

.vp-pill-row,
.vp-chip-row,
.vp-filter-row,
.vp-doc-filters,
.vp-segments,
.vp-event-actions,
.vp-kpi-grid,
.vp-mini-grid,
.vp-member-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.vp-chip,
.vp-segment,
.vp-doc-filter,
.vp-status-pill,
.vp-tag,
.vp-note-badge {
  border-radius: 999px;
  padding: .42rem .72rem;
  font-size: .72rem;
  line-height: 1;
  font-weight: 700;
}

.vp-chip,
.vp-doc-filter,
.vp-segment {
  color: var(--vp-text-soft);
}

.vp-chip.is-active,
.vp-segment.is-active,
.vp-doc-filter.is-active,
.vp-nav-item.is-active,
.vp-button,
.vp-action-pill {
  background: linear-gradient(135deg, rgba(43, 140, 255, 0.95), rgba(39, 211, 255, 0.9));
  border-color: rgba(39, 211, 255, 0.24);
  color: #fff;
  box-shadow: 0 14px 30px rgba(31, 147, 255, 0.28);
}

.vp-tag-success,
.vp-status-active,
.vp-status-paid,
.vp-tag-active,
.vp-note-badge.success {
  background: rgba(42, 211, 132, 0.14);
  border: 1px solid rgba(42, 211, 132, 0.28);
  color: #85efbd;
}

.vp-tag-warning,
.vp-status-open,
.vp-note-badge.warning {
  background: rgba(255, 181, 71, 0.14);
  border: 1px solid rgba(255, 181, 71, 0.26);
  color: #ffd493;
}

.vp-tag-danger,
.vp-note-badge.danger {
  background: rgba(255, 93, 121, 0.12);
  border: 1px solid rgba(255, 93, 121, 0.24);
  color: #ffadc0;
}

.vp-tag-violet {
  background: rgba(143, 92, 255, 0.14);
  border: 1px solid rgba(143, 92, 255, 0.28);
  color: #d3b8ff;
}

.vp-tag-cyan {
  background: rgba(39, 211, 255, 0.12);
  border: 1px solid rgba(39, 211, 255, 0.24);
  color: #9ceeff;
}

.vp-hero-logo {
  width: 3rem;
  height: 3rem;
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.08);
  overflow: hidden;
}

.vp-hero-logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.vp-member-card {
  position: relative;
  overflow: hidden;
  border-radius: 1.6rem;
  padding: 1rem;
  margin-bottom: 1rem;
  background: linear-gradient(135deg, rgba(8, 22, 42, 0.96), rgba(23, 43, 76, 0.88));
}

.vp-panel {
  border-radius: 1.45rem;
  padding: 1rem;
  margin-bottom: 1rem;
}

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

.vp-section-title {
  font-size: 1rem;
  margin: 0;
  font-weight: 800;
}

.vp-link-btn,
.vp-text-btn {
  background: none;
  border: 0;
  color: var(--vp-accent-2);
  cursor: pointer;
  font-weight: 700;
  padding: 0;
}

.vp-member-card-grid {
  grid-template-columns: 1fr auto;
  align-items: center;
  position: relative;
  z-index: 1;
}

.vp-member-card-title,
.vp-card-title,
.vp-event-subtitle,
.vp-kpi-title,
.vp-list-title,
.vp-doc-title,
.vp-admin-title,
.vp-feature-title {
  color: var(--vp-text);
  font-weight: 700;
}

.vp-card-title,
.vp-member-card-title,
.vp-event-subtitle { margin: 0 0 .65rem; font-size: .92rem; }
.vp-mini-label { font-size: .72rem; display: block; margin-bottom: .15rem; }
.vp-card-value, .vp-inline-value { font-size: .88rem; }
.vp-member-card .vp-card-value { color: var(--vp-text-soft); }

.vp-qr {
  width: 5.65rem;
  height: 5.65rem;
  border-radius: 1rem;
  background: #fff;
  padding: .45rem;
  box-shadow: 0 12px 26px rgba(0,0,0,.28);
}

.vp-qr svg { width: 100%; height: 100%; display: block; }

.vp-button-row {
  display: flex;
  gap: .6rem;
  flex-wrap: wrap;
  margin-top: .9rem;
}

.vp-button,
.vp-button-secondary,
.vp-button-danger {
  min-height: 2.85rem;
  border-radius: 1rem;
  padding: 0 .95rem;
  border: 1px solid var(--vp-line-strong);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
}

.vp-button {
  min-width: 10rem;
}

.vp-button-secondary {
  background: rgba(255,255,255,.04);
  color: var(--vp-text);
}

.vp-button-danger {
  background: rgba(255, 93, 121, 0.12);
  color: #ffc1ce;
  border-color: rgba(255,93,121,.22);
}

.vp-kpi-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .7rem;
  margin-bottom: 1rem;
}

.vp-kpi {
  padding: .9rem;
  border-radius: 1.2rem;
  position: relative;
}

.vp-kpi::after {
  content: "";
  position: absolute;
  inset: auto .8rem .8rem auto;
  width: 2.3rem;
  height: 2.3rem;
  border-radius: .85rem;
  background: linear-gradient(135deg, rgba(39, 211, 255, 0.18), rgba(143, 92, 255, 0.18));
}

.vp-kpi-title,
.vp-doc-title,
.vp-admin-title,
.vp-action-title { font-size: .82rem; }
.vp-stat-value,
.vp-admin-value {
  margin-top: .25rem;
  font-size: 1.15rem;
  font-weight: 800;
}

.vp-event-card,
.vp-important-card,
.vp-news-card,
.vp-calendar-item,
.vp-doc-item,
.vp-checkin-card,
.vp-note,
.vp-auth-card {
  border-radius: 1.35rem;
  padding: .95rem;
}

.vp-event-card {
  background: linear-gradient(180deg, rgba(12, 22, 40, 0.9), rgba(10, 18, 34, 0.9));
}

.vp-event-top,
.vp-inline-row,
.vp-news-head,
.vp-doc-row,
.vp-admin-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .75rem;
}

.vp-event-title {
  font-size: 1.1rem;
  margin: .15rem 0 .4rem;
  font-weight: 800;
}

.vp-inline-list {
  display: grid;
  gap: .4rem;
  margin-top: .75rem;
}

.vp-inline-row {
  align-items: center;
  color: var(--vp-text-soft);
  font-size: .86rem;
}

.vp-inline-row .vp-inline-meta {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
}

.vp-inline-icon,
.vp-doc-icon,
.vp-news-thumb,
.vp-action-icon,
.vp-admin-icon,
.vp-feature-icon {
  width: 2.15rem;
  height: 2.15rem;
  border-radius: .9rem;
  background: linear-gradient(135deg, rgba(39, 211, 255, 0.16), rgba(143, 92, 255, 0.16));
  color: var(--vp-accent-2);
}

.vp-people {
  display: flex;
  align-items: center;
  gap: .4rem;
  margin-top: .8rem;
}

.vp-people-avatar {
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  color: white;
  font-size: .68rem;
  font-weight: 800;
  border: 2px solid rgba(10, 18, 34, 0.95);
  margin-left: -.38rem;
  background: linear-gradient(135deg, var(--vp-accent), var(--vp-violet));
}
.vp-people-avatar:first-child { margin-left: 0; }
.vp-people-count { color: var(--vp-text-muted); font-size: .76rem; }

.vp-note {
  display: flex;
  gap: .8rem;
  align-items: center;
}

.vp-news-card,
.vp-important-card {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: .8rem;
}

.vp-important-card {
  background: linear-gradient(135deg, rgba(50, 24, 68, 0.72), rgba(26, 20, 58, 0.82));
}

.vp-news-thumb {
  width: 4.25rem;
  height: 4.25rem;
  overflow: hidden;
  background: rgba(255,255,255,.06);
}

.vp-news-thumb img,
.vp-event-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.vp-news-title,
.vp-doc-title,
.vp-action-title,
.vp-admin-title { margin: 0 0 .3rem; }
.vp-news-copy,
.vp-doc-subline,
.vp-auth-copy,
.vp-event-copy,
.vp-card-subline { color: var(--vp-text-soft); font-size: .84rem; margin: 0; }
.vp-news-meta, .vp-doc-meta { margin-top: .35rem; font-size: .75rem; display: flex; gap: .5rem; flex-wrap: wrap; }

.vp-quick-grid,
.vp-admin-grid,
.vp-actions-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .75rem;
}

.vp-quick-link,
.vp-action-tile,
.vp-admin-tile {
  min-height: 5.7rem;
  border-radius: 1.15rem;
  padding: .8rem .65rem;
  display: grid;
  align-content: space-between;
  gap: .65rem;
  text-align: left;
}

.vp-quick-link { text-decoration: none; }

.vp-action-title,
.vp-admin-title { font-weight: 700; }
.vp-action-subtitle,
.vp-admin-subtitle { color: var(--vp-text-muted); font-size: .72rem; }

.vp-calendar-toolbar {
  display: grid;
  gap: .75rem;
  margin-bottom: 1rem;
}

.vp-segments {
  background: rgba(255,255,255,.04);
  border: 1px solid var(--vp-line);
  padding: .25rem;
  border-radius: 1rem;
  width: fit-content;
}

.vp-segment {
  cursor: default;
  border: 0;
}

.vp-calendar-grid {
  background: rgba(7, 15, 29, 0.72);
  border: 1px solid var(--vp-line);
  border-radius: 1.4rem;
  padding: .8rem;
  margin-bottom: 1rem;
}

.vp-calendar-month,
.vp-calendar-weekdays,
.vp-calendar-days {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: .45rem;
}

.vp-calendar-month { align-items: center; margin-bottom: .8rem; }
.vp-calendar-month strong { grid-column: 2 / span 5; text-align: center; }
.vp-calendar-month button,
.vp-back-btn {
  width: 2rem;
  height: 2rem;
  border-radius: .8rem;
  color: var(--vp-text);
  border: 1px solid var(--vp-line);
  background: rgba(255,255,255,.04);
}

.vp-calendar-weekdays span,
.vp-calendar-day {
  text-align: center;
}

.vp-calendar-weekdays span {
  color: var(--vp-text-muted);
  font-size: .74rem;
  padding-bottom: .25rem;
}

.vp-calendar-day {
  min-height: 2.3rem;
  border-radius: .85rem;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,.02);
  color: var(--vp-text-soft);
  font-size: .88rem;
}

.vp-calendar-day.is-selected {
  background: linear-gradient(135deg, rgba(43, 140, 255, 0.95), rgba(39, 211, 255, 0.9));
  color: white;
  box-shadow: 0 12px 22px rgba(31, 147, 255, 0.28);
}

.vp-calendar-list { display: grid; gap: .75rem; }
.vp-calendar-item { display: grid; gap: .65rem; }
.vp-calendar-item-top { display: flex; gap: .85rem; align-items: flex-start; }
.vp-calendar-date-badge {
  width: 3.2rem;
  border-radius: 1rem;
  padding: .55rem .3rem;
  text-align: center;
  background: rgba(255,255,255,.05);
}
.vp-calendar-date-badge strong { display: block; font-size: 1.1rem; }
.vp-calendar-date-badge span { font-size: .7rem; color: var(--vp-text-muted); text-transform: uppercase; }

.vp-event-hero {
  position: relative;
  overflow: hidden;
  border-radius: 1.6rem;
  min-height: 12rem;
  margin-bottom: 1rem;
  border: 1px solid var(--vp-line);
}

.vp-event-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(7,17,31,.12), rgba(7,17,31,.86));
}

.vp-event-hero-content {
  position: absolute;
  inset: auto 1rem 1rem 1rem;
  z-index: 1;
}

.vp-event-copy { line-height: 1.5; }
.vp-contact-card,
.vp-checkin-card { margin-top: 1rem; }
.vp-checkin-card { display: grid; grid-template-columns: 1fr auto; gap: .75rem; align-items: center; }

.vp-search {
  display: flex;
  align-items: center;
  gap: .65rem;
  border-radius: 1rem;
  padding: .9rem 1rem;
  color: var(--vp-text-muted);
}

.vp-search input {
  flex: 1;
  border: 0;
  background: transparent;
  color: var(--vp-text);
  outline: none;
  min-width: 0;
}

.vp-doc-list,
.vp-link-list,
.vp-feature-grid,
.vp-news-list { display: grid; gap: .75rem; }

.vp-doc-item,
.vp-link-row {
  display: flex;
  align-items: center;
  gap: .8rem;
}

.vp-doc-item { justify-content: space-between; }
.vp-doc-main { display: flex; align-items: center; gap: .8rem; min-width: 0; flex: 1; }
.vp-doc-body { min-width: 0; }
.vp-doc-title { font-size: .9rem; }
.vp-doc-subline { font-size: .76rem; margin-top: .15rem; }
.vp-doc-flag { color: #ffd97c; }

.vp-link-row {
  width: 100%;
  justify-content: space-between;
  text-decoration: none;
  border-radius: 1.1rem;
  padding: .9rem 1rem;
}

.vp-link-row .vp-link-copy { flex: 1; min-width: 0; }
.vp-link-row .vp-link-copy strong { display: block; font-size: .88rem; }
.vp-link-row .vp-link-copy span { display: block; font-size: .76rem; color: var(--vp-text-muted); }

.vp-profile-card {
  display: grid;
  justify-items: center;
  text-align: center;
  gap: .8rem;
}

.vp-profile-avatar {
  width: 5.9rem;
  height: 5.9rem;
  border-radius: 999px;
  border: 3px solid rgba(39, 211, 255, 0.34);
  box-shadow: 0 18px 28px rgba(39, 211, 255, 0.16);
  font-size: 1.45rem;
}

.vp-profile-name { font-size: 1.35rem; font-weight: 800; margin: 0; }
.vp-profile-id { color: var(--vp-text-muted); margin: 0; font-size: .82rem; }

.vp-finance-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  border-radius: 1.2rem;
  padding: .9rem 1rem;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--vp-line);
}

.vp-admin-badge {
  border-radius: 999px;
  padding: .38rem .65rem;
  font-size: .72rem;
  font-weight: 700;
  background: rgba(255, 181, 71, 0.15);
  border: 1px solid rgba(255, 181, 71, 0.28);
  color: #ffd493;
}

.vp-admin-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem;
  margin-top: .8rem;
}

.vp-admin-stat {
  border-radius: 1.1rem;
  padding: .85rem;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--vp-line);
}

.vp-admin-meta { color: var(--vp-text-muted); font-size: .75rem; }
.vp-admin-change { color: #85efbd; font-size: .75rem; font-weight: 700; }

.vp-note-icon {
  width: 2.35rem;
  height: 2.35rem;
  border-radius: .9rem;
  background: linear-gradient(135deg, rgba(255, 181, 71, 0.2), rgba(255, 93, 121, 0.16));
  display: inline-grid;
  place-items: center;
}

.vp-bottom-nav {
  position: fixed;
  left: 50%;
  bottom: calc(.8rem + env(safe-area-inset-bottom));
  transform: translateX(-50%);
  width: min(calc(100% - 1.2rem), 27rem);
  border-radius: 1.45rem;
  padding: .45rem;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: .35rem;
  z-index: 20;
}

@media (min-width: 720px) {
  .vp-bottom-nav {
    width: min(calc(100% - 3rem), 26rem);
  }
}

.vp-nav-item {
  min-height: 4.15rem;
  border-radius: 1.1rem;
  border: 1px solid transparent;
  background: transparent;
  color: var(--vp-text-muted);
  display: grid;
  justify-items: center;
  align-content: center;
  gap: .28rem;
  cursor: pointer;
}

.vp-nav-item span { font-size: .7rem; font-weight: 700; }
.vp-nav-item svg { width: 1.15rem; height: 1.15rem; }

.vp-auth-wrap {
  min-height: 100svh;
  display: grid;
  place-items: center;
  padding: 1rem;
}

.vp-auth-card {
  position: relative;
  overflow: hidden;
  width: min(100%, 28rem);
  border-radius: 2rem;
  padding: 1.25rem;
}

.vp-auth-head {
  text-align: center;
  margin-bottom: 1rem;
}
.vp-auth-head p { margin: .35rem 0 0; color: var(--vp-text-soft); }
.vp-auth-head h1 { margin: .75rem 0 .35rem; font-size: 1.8rem; }

.vp-field {
  display: grid;
  gap: .45rem;
  margin-bottom: .9rem;
}
.vp-field span { color: var(--vp-text-soft); font-size: .84rem; }
.vp-field input {
  width: 100%;
  min-height: 3rem;
  padding: 0 .95rem;
  border-radius: 1rem;
  border: 1px solid var(--vp-line-strong);
  background: rgba(7, 15, 29, 0.76);
  color: var(--vp-text);
}

.vp-alert {
  border-radius: 1rem;
  padding: .9rem 1rem;
  margin-bottom: 1rem;
  border: 1px solid rgba(255, 93, 121, 0.24);
  background: rgba(255, 93, 121, 0.12);
  color: #ffc1ce;
}

.vp-auth-footer { display: flex; align-items: center; justify-content: space-between; gap: .75rem; margin-top: .8rem; }
.vp-auth-footer .vp-hint { font-size: .74rem; }

.vp-empty { color: var(--vp-text-muted); font-size: .9rem; }

.vp-feature-strip {
  margin-top: 1rem;
}

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

.vp-feature-card {
  border-radius: 1.15rem;
  padding: .9rem;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--vp-line);
}

.vp-feature-title { font-size: .86rem; margin: .55rem 0 .25rem; }
.vp-feature-text { font-size: .76rem; line-height: 1.45; }

@media (max-width: 400px) {
  .vp-quick-grid,
  .vp-admin-grid,
  .vp-actions-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .vp-kpi-grid { grid-template-columns: 1fr; }
  .vp-feature-grid { grid-template-columns: 1fr; }
}

/* v000629 reference-style compact Vereins-App UI */
:root {
  --vp-bg-1: #06101f;
  --vp-bg-2: #07182c;
  --vp-card: rgba(9, 25, 48, .72);
  --vp-card-strong: rgba(12, 31, 58, .92);
  --vp-line: rgba(117, 175, 255, .18);
  --vp-line-strong: rgba(117, 175, 255, .34);
  --vp-accent: #2f8cff;
  --vp-accent-2: #38d8ff;
  --vp-shadow-soft: 0 18px 48px rgba(0, 0, 0, .28), inset 0 1px 0 rgba(255,255,255,.03);
}

body.vp-standalone-app {
  background:
    radial-gradient(circle at 50% 0%, rgba(54, 139, 255, .22), transparent 24rem),
    radial-gradient(circle at 12% 18%, rgba(29, 93, 171, .18), transparent 22rem),
    radial-gradient(circle at 90% 30%, rgba(28, 173, 255, .12), transparent 20rem),
    linear-gradient(180deg, #040b17 0%, #061321 42%, #040a14 100%);
}

.vp-app-frame { padding: 0; }

.vp-app-phone {
  background:
    radial-gradient(circle at 60% -3rem, rgba(61, 156, 255, .18), transparent 13rem),
    linear-gradient(180deg, rgba(8, 18, 34, .98), rgba(5, 15, 28, .99));
}

@media (min-width: 720px) {
  .vp-app-frame {
    display: grid;
    place-items: start center;
    padding: 2rem 1rem;
  }
  .vp-app-phone {
    width: min(100%, 25.5rem);
    min-height: 53.5rem;
    max-height: calc(100svh - 4rem);
    overflow-y: auto;
    border-radius: 3.1rem;
    border: 3px solid rgba(255,255,255,.14);
    box-shadow: 0 34px 100px rgba(0,0,0,.62), 0 0 0 1px rgba(56,216,255,.16), inset 0 0 0 1px rgba(255,255,255,.08);
  }
  .vp-app-phone::before {
    content: "";
    position: sticky;
    top: .7rem;
    left: 50%;
    transform: translateX(-50%);
    width: 7.6rem;
    height: 2.05rem;
    border-radius: 999px;
    background: #03070d;
    box-shadow: inset -1.9rem 0 0 rgba(41, 122, 205, .18);
    z-index: 30;
    display: block;
    margin: .7rem auto -2.75rem;
  }
}

.vp-shell {
  padding: calc(.4rem + env(safe-area-inset-top)) 1rem calc(5.7rem + var(--vp-safe-bottom));
}

.vp-statusbar { height: calc(1rem + env(safe-area-inset-top)); }

.vp-ref-topbar,
.vp-ref-screenbar,
.vp-ref-section-head,
.vp-ref-id-head,
.vp-ref-id-person {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .8rem;
}

.vp-ref-topbar { margin: .2rem 0 1.15rem; }
.vp-ref-club { display: flex; align-items: center; gap: .65rem; min-width: 0; }
.vp-ref-appicon { width: 1.9rem; height: 1.9rem; border-radius: .62rem; overflow: hidden; box-shadow: 0 0 22px rgba(47,140,255,.35); flex: 0 0 auto; }
.vp-ref-appicon img { width: 100%; height: 100%; display: block; }
.vp-ref-clubname {
  max-width: 17.5rem;
  border: 0;
  background: transparent;
  color: var(--vp-text);
  font-weight: 760;
  font-size: .92rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding: 0;
}
.vp-ref-clubname span { color: var(--vp-text-muted); }
.vp-ref-bell { width: 2.25rem; height: 2.25rem; border-radius: .8rem; background: rgba(8,24,45,.72); box-shadow: none; }

.vp-ref-hero {
  display: grid;
  grid-template-columns: 1fr 5.35rem;
  gap: .9rem;
  align-items: stretch;
  margin-bottom: 1.15rem;
}
.vp-ref-hero h1 {
  font-size: 2rem;
  line-height: 1.04;
  letter-spacing: -.055em;
  margin: 0 0 .75rem;
}
.vp-ref-hero p { margin: .62rem 0 0; color: var(--vp-text-muted); font-size: .83rem; }
.vp-wave { font-size: 1.35rem; }
.vp-ref-member-mini {
  border-radius: 1.15rem;
  padding: .8rem;
  background: linear-gradient(155deg, rgba(15,41,76,.88), rgba(14,31,58,.72));
  border: 1px solid var(--vp-line);
  box-shadow: var(--vp-shadow-soft);
  display: grid;
  align-content: space-between;
  min-height: 7rem;
}
.vp-ref-member-mini span { color: var(--vp-text-muted); font-size: .72rem; }
.vp-ref-member-mini strong { font-size: .84rem; }
.vp-ref-shield { width: 3.4rem; height: 3.4rem; border-radius: 1rem; display: grid; place-items: center; background: rgba(61,154,255,.12); border: 1px solid rgba(75,190,255,.24); justify-self: center; }
.vp-ref-shield img { width: 2.6rem; height: 2.6rem; border-radius: .78rem; }

.vp-ref-section-head { margin: 1.05rem 0 .72rem; }
.vp-ref-section-head h2 { margin: 0; font-size: .98rem; letter-spacing: -.025em; }
.vp-ref-section-head .vp-text-btn { font-size: .76rem; color: #8cc7ff; }

.vp-ref-kpi-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .72rem;
}
.vp-ref-kpi-card {
  min-height: 7.3rem;
  border-radius: 1.05rem;
  padding: .86rem;
  background: linear-gradient(180deg, rgba(13,35,65,.82), rgba(8,24,46,.78));
  border: 1px solid var(--vp-line);
  box-shadow: var(--vp-shadow-soft);
  position: relative;
  overflow: hidden;
}
.vp-ref-kpi-card::after {
  content: "";
  position: absolute;
  inset: auto -1.2rem -1.4rem auto;
  width: 4.2rem;
  height: 4.2rem;
  border-radius: 999px;
  background: rgba(47,140,255,.08);
}
.vp-ref-kpi-icon { width: 1.85rem; height: 1.85rem; border-radius: .55rem; display: grid; place-items: center; margin-bottom: .7rem; color: #fff; }
.vp-ref-kpi-icon svg { width: 1rem; height: 1rem; }
.vp-ref-kpi-icon.tone-0 { background: linear-gradient(135deg, #18c4ff, #2f8cff); }
.vp-ref-kpi-icon.tone-1 { background: linear-gradient(135deg, #ffd75a, #ff9e2f); }
.vp-ref-kpi-icon.tone-2 { background: linear-gradient(135deg, #ff6bd6, #9d6bff); }
.vp-ref-kpi-icon.tone-3 { background: linear-gradient(135deg, #25d991, #1fbf7c); }
.vp-ref-kpi-icon.tone-4 { background: linear-gradient(135deg, #ffca3a, #e8a800); }
.vp-ref-kpi-icon.tone-5 { background: linear-gradient(135deg, #27dccf, #2f8cff); }
.vp-ref-kpi-card span { color: var(--vp-text-soft); font-size: .74rem; display: block; }
.vp-ref-kpi-card strong { display: block; margin: .42rem 0 .2rem; font-size: 1.24rem; letter-spacing: -.035em; }
.vp-ref-kpi-card small { color: var(--vp-text-muted); font-size: .72rem; line-height: 1.35; display: block; }
.vp-ref-inline-link { position: absolute; left: .86rem; bottom: .72rem; border: 0; padding: 0; background: transparent; color: #69b9ff; font-size: .75rem; font-weight: 700; }

.vp-ref-news-card {
  display: grid;
  grid-template-columns: 1fr 5.2rem;
  gap: .85rem;
  padding: .88rem;
  border-radius: 1.1rem;
  border: 1px solid var(--vp-line);
  background: linear-gradient(180deg, rgba(12,33,61,.82), rgba(8,24,46,.76));
  box-shadow: var(--vp-shadow-soft);
}
.vp-ref-news-card h3 { margin: 0 0 .35rem; font-size: .92rem; }
.vp-ref-news-card p { margin: 0; color: var(--vp-text-soft); font-size: .78rem; line-height: 1.4; }
.vp-ref-news-card small { display: block; margin-top: .55rem; color: var(--vp-text-muted); font-size: .72rem; }
.vp-ref-news-card img { width: 5.2rem; height: 4.4rem; border-radius: .9rem; object-fit: cover; }

.vp-ref-screenbar { margin: .2rem 0 1rem; }
.vp-ref-screenbar strong { font-size: .92rem; }
.vp-back-btn { font-size: 1.2rem; display: grid; place-items: center; }
.vp-ref-screenbar .vp-icon-btn, .vp-ref-screenbar .vp-back-btn { width: 2.15rem; height: 2.15rem; border-radius: .78rem; box-shadow: none; }

.vp-ref-event-hero {
  position: relative;
  min-height: 13.5rem;
  border-radius: 1.25rem;
  overflow: hidden;
  border: 1px solid var(--vp-line);
  box-shadow: var(--vp-shadow-soft);
  margin-bottom: 1rem;
  background: #081727;
}
.vp-ref-event-hero img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: saturate(1.04) contrast(1.04) brightness(.7); }
.vp-ref-event-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(4,12,24,.08), rgba(5,16,30,.92)); }
.vp-ref-event-hero > .vp-tag { position: absolute; top: .75rem; right: .75rem; z-index: 2; }
.vp-ref-event-hero div { position: absolute; left: .95rem; right: .95rem; bottom: .95rem; z-index: 2; }
.vp-ref-event-hero h1 { margin: 0 0 .32rem; font-size: 1.18rem; }
.vp-ref-event-hero p { margin: 0 0 .65rem; color: var(--vp-text-soft); font-size: .82rem; }

.vp-ref-list { display: grid; gap: .78rem; }
.vp-ref-row-card, .vp-ref-service-card {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .86rem;
  border-radius: 1.08rem;
  background: rgba(9, 26, 49, .72);
  border: 1px solid var(--vp-line);
  box-shadow: var(--vp-shadow-soft);
}
.vp-ref-row-card > div, .vp-ref-service-card > div { flex: 1; min-width: 0; }
.vp-ref-row-card strong, .vp-ref-service-card strong { display: block; font-size: .82rem; margin-bottom: .22rem; }
.vp-ref-row-card small, .vp-ref-service-card small { display: block; color: var(--vp-text-muted); font-size: .74rem; line-height: 1.45; }
.vp-ref-row-card.compact { min-height: 4.1rem; }
.vp-ref-map-pin { color: #2fe4d3; font-size: 1.5rem; }
.vp-ref-round { width: 2.1rem; height: 2.1rem; border-radius: 999px; border: 1px solid var(--vp-line); background: rgba(64,145,255,.14); color: #9ed1ff; }
.vp-ref-ok { display: inline-grid; place-items: center; width: 1.55rem; height: 1.55rem; border-radius: 999px; background: rgba(42,211,132,.16); border: 1px solid rgba(42,211,132,.34); color: #78efb7; font-weight: 900; }
.vp-ref-button-pair { display: grid; grid-template-columns: 1fr 1fr; gap: .72rem; margin: .95rem 0; }
.vp-button-secondary.tiny { min-height: 2rem; border-radius: .75rem; font-size: .74rem; padding: 0 .65rem; }

.vp-ref-id-card {
  border-radius: 1.25rem;
  padding: .9rem;
  background:
    radial-gradient(circle at 80% 0%, rgba(47,140,255,.28), transparent 8rem),
    linear-gradient(145deg, rgba(11,34,68,.94), rgba(8,24,47,.86));
  border: 1px solid var(--vp-line-strong);
  box-shadow: var(--vp-shadow-soft), 0 0 42px rgba(47,140,255,.12);
  margin-bottom: 1rem;
}
.vp-ref-id-head strong { display: block; font-size: .82rem; }
.vp-ref-id-head span { color: var(--vp-text-muted); font-size: .72rem; }
.vp-ref-qr-wrap { display: grid; place-items: center; padding: .75rem 0 .95rem; }
.vp-ref-qr-wrap .vp-qr { width: 7.2rem; height: 7.2rem; border-radius: .75rem; }
.vp-ref-id-person {
  border-radius: 1rem;
  padding: .8rem;
  background: rgba(6,17,32,.58);
  border: 1px solid var(--vp-line);
  margin-bottom: .65rem;
}
.vp-ref-id-person strong { display: block; font-size: .88rem; }
.vp-ref-id-person span { color: var(--vp-text-muted); font-size: .72rem; }
.vp-ref-id-action { margin: 0; min-height: 2.7rem; padding: .72rem .85rem; background: rgba(255,255,255,.04); box-shadow: none; }
.vp-ref-id-action svg { width: 1rem; height: 1rem; }

.vp-ref-service-card { margin-bottom: 1rem; }
.vp-ref-shortcut-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: .62rem; }
.vp-ref-shortcut-grid .vp-action-tile { min-height: 4.6rem; padding: .62rem .45rem; justify-items: center; text-align: center; align-content: center; gap: .45rem; box-shadow: none; }
.vp-ref-shortcut-grid .vp-action-tile span:last-child { font-size: .67rem; color: var(--vp-text-soft); line-height: 1.2; }
.vp-ref-shortcut-grid .vp-action-icon { width: 2rem; height: 2rem; border-radius: .72rem; }

.vp-inline-icon { background: rgba(64,145,255,.12); border: 1px solid rgba(117,175,255,.17); color: #8ed4ff; flex: 0 0 auto; }
.vp-status-pill { font-size: .72rem; padding: .45rem .7rem; }
.vp-tag { font-size: .68rem; }
.vp-button, .vp-button-secondary, .vp-button-danger { min-width: 0; min-height: 2.65rem; border-radius: .82rem; font-size: .8rem; }
.vp-button { background: linear-gradient(135deg, #207cff, #3fa2ff); }

.vp-bottom-nav {
  width: min(calc(100% - 1.1rem), 24.3rem);
  bottom: calc(.6rem + env(safe-area-inset-bottom));
  border-radius: 1.4rem;
  padding: .42rem;
  background: rgba(5,15,29,.86);
  border: 1px solid rgba(117,175,255,.16);
  box-shadow: 0 -12px 34px rgba(0,0,0,.35), 0 0 36px rgba(47,140,255,.12);
}
.vp-nav-item { min-height: 3.7rem; border-radius: 1rem; background: transparent; box-shadow: none; }
.vp-nav-item.is-active { background: linear-gradient(180deg, rgba(49,143,255,.25), rgba(49,143,255,.08)); color: #67b7ff; box-shadow: 0 0 22px rgba(47,140,255,.28); }
.vp-nav-item span { font-size: .62rem; }

@media (max-width: 380px) {
  .vp-ref-hero { grid-template-columns: 1fr; }
  .vp-ref-member-mini { grid-template-columns: 1fr auto; align-items: center; min-height: auto; }
  .vp-ref-kpi-grid { grid-template-columns: 1fr; }
  .vp-ref-shortcut-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
}
