/* Infinity Roleplay — Design System */

:root {
  --background: #0a0a0b;
  --foreground: #fafafa;
  --muted: #71717a;
  --muted-light: #a1a1aa;
  --border: color-mix(in srgb, var(--foreground) 8%, transparent);
  --border-hover: color-mix(in srgb, var(--foreground) 14%, transparent);
  --surface: #0d0d0f;
  --surface-elevated: #141416;
  --panel: #111113;
  --card: #121214;
  --card-hover: #1a1a1e;
  --accent: #5865f2;
  --accent-hover: #4752c4;
  --accent-foreground: #ffffff;
  --accent-muted: #a5b4fc;
  --accent-subtle: color-mix(in srgb, var(--accent) 10%, transparent);
  --accent-dim: color-mix(in srgb, var(--accent) 14%, transparent);
  --accent-glow: color-mix(in srgb, var(--accent) 22%, transparent);
  --grid-fade: color-mix(in srgb, var(--foreground) 3.5%, transparent);
  --success: #22c55e;
  --danger: #ef4444;
  --danger-muted: #fecaca;
  --radius-sm: 0.5rem;
  --radius-md: 0.75rem;
  --radius-lg: 1rem;
  --radius-xl: 1.125rem;
  --radius-full: 9999px;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.28);
  --shadow-md: 0 8px 32px rgba(0, 0, 0, 0.36);
  --shadow-lg: 0 16px 48px rgba(0, 0, 0, 0.44);
  --header-height: 4.25rem;
  --container: 68rem;
  --container-wide: 76rem;
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --section-gap: clamp(3rem, 6vw, 4.5rem);
  --transition: 180ms cubic-bezier(0.4, 0, 0.2, 1);
  --hover-overlay: rgba(255, 255, 255, 0.04);
  --hover-overlay-strong: rgba(255, 255, 255, 0.06);
}

html[data-theme="light"] {
  color-scheme: light;
  --background: #f4f4f5;
  --foreground: #18181b;
  --muted: #71717a;
  --muted-light: #52525b;
  --border: color-mix(in srgb, var(--foreground) 10%, transparent);
  --border-hover: color-mix(in srgb, var(--foreground) 16%, transparent);
  --surface: #ffffff;
  --surface-elevated: #fafafa;
  --panel: #ffffff;
  --card: #ffffff;
  --card-hover: #f4f4f5;
  --accent-subtle: color-mix(in srgb, var(--accent) 10%, transparent);
  --accent-dim: color-mix(in srgb, var(--accent) 14%, transparent);
  --accent-glow: color-mix(in srgb, var(--accent) 20%, transparent);
  --grid-fade: color-mix(in srgb, var(--foreground) 5%, transparent);
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.06);
  --shadow-md: 0 8px 32px rgba(0, 0, 0, 0.08);
  --shadow-lg: 0 16px 48px rgba(0, 0, 0, 0.1);
  --hover-overlay: rgba(0, 0, 0, 0.04);
  --hover-overlay-strong: rgba(0, 0, 0, 0.06);
}

html[data-theme="dark"] {
  color-scheme: dark;
}

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

html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
}

[hidden] {
  display: none !important;
}

#auth-gated-content[hidden] {
  display: none !important;
}

html.is-navigating main,
html.is-navigating .page-bg {
  opacity: 0.92;
  transition: opacity 0.06s ease;
}

html:not(.is-navigating) main,
html:not(.is-navigating) .page-bg {
  transition: opacity 0.18s ease;
}

.portal-shell.is-portal-navigating > :not(.portal-subnav) {
  opacity: 0.92;
  transition: opacity 0.08s ease;
}

.portal-shell:not(.is-portal-navigating) > :not(.portal-subnav) {
  transition: opacity 0.12s ease;
}

.portal-dashboard.is-ready {
  animation: portal-dashboard-in 0.16s ease;
}

@keyframes portal-dashboard-in {
  from { opacity: 0.6; }
  to { opacity: 1; }
}

body {
  font-family: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  background: var(--background);
  color: var(--foreground);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  line-height: 1.6;
  font-size: 0.9375rem;
  overflow-x: hidden;
}

img { display: block; max-width: 100%; height: auto; }
a { color: inherit; }
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
}

/* Scrollbar */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--background); }
::-webkit-scrollbar-thumb {
  background: var(--border-hover);
  border-radius: 3px;
}

/* Custom select */
.custom-select {
  position: relative;
  display: block;
  width: 100%;
}

.custom-select--apply {
  max-width: 100%;
}

@media (min-width: 640px) {
  .custom-select--apply {
    max-width: 22rem;
  }
}

.custom-select__native {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.custom-select__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  width: 100%;
  min-height: 2.875rem;
  padding: 0.75rem 0.875rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  color: var(--foreground);
  font-family: inherit;
  font-size: 0.9375rem;
  line-height: 1.5;
  text-align: left;
  cursor: pointer;
  transition: border-color var(--transition), box-shadow var(--transition), background var(--transition);
}

.custom-select__trigger:hover {
  border-color: color-mix(in srgb, var(--foreground) 14%, transparent);
  background: color-mix(in srgb, var(--foreground) 2%, var(--surface));
}

.custom-select__trigger:focus-visible {
  outline: none;
  border-color: color-mix(in srgb, var(--accent) 38%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 14%, transparent);
}

.custom-select--open .custom-select__trigger {
  border-color: color-mix(in srgb, var(--accent) 38%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 14%, transparent);
}

.custom-select__value {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.custom-select__value--placeholder {
  color: var(--muted);
}

.custom-select__chevron {
  flex-shrink: 0;
  display: flex;
  color: var(--muted);
  transition: transform var(--transition), color var(--transition);
}

.custom-select__chevron svg {
  width: 1rem;
  height: 1rem;
}

.custom-select--open .custom-select__chevron {
  transform: rotate(180deg);
  color: var(--muted-light);
}

.custom-select__menu {
  position: absolute;
  z-index: 60;
  top: calc(100% + 0.375rem);
  left: 0;
  right: 0;
  margin: 0;
  padding: 0.375rem;
  list-style: none;
  border: 1px solid color-mix(in srgb, var(--foreground) 10%, transparent);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--surface-elevated) 96%, transparent);
  backdrop-filter: blur(16px);
  box-shadow: var(--shadow-md);
  max-height: 14rem;
  overflow-y: auto;
}

.custom-select__option {
  padding: 0.625rem 0.75rem;
  border-radius: var(--radius-md);
  font-size: 0.9375rem;
  line-height: 1.4;
  color: var(--muted-light);
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
}

.custom-select__option:hover,
.custom-select__option:focus {
  outline: none;
  background: color-mix(in srgb, var(--foreground) 6%, transparent);
  color: var(--foreground);
}

.custom-select__option--selected {
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--foreground);
  font-weight: 500;
}

.custom-select__option--selected:hover,
.custom-select__option--selected:focus {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
}

.custom-select__option--disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.custom-select--disabled {
  opacity: 0.55;
  pointer-events: none;
}

.custom-select--compact .custom-select__trigger {
  min-height: auto;
  padding: 0.625rem 0.75rem;
  font-size: 0.875rem;
  border-radius: var(--radius-md);
}

.custom-select--compact .custom-select__option {
  font-size: 0.875rem;
  padding: 0.5rem 0.625rem;
}

/* Background */
.page-bg {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: -1;
  background-color: var(--background);
  background-image:
    linear-gradient(to bottom, transparent 0%, var(--background) 68%),
    radial-gradient(ellipse 80% 55% at 50% -10%, var(--accent-dim), transparent 72%),
    linear-gradient(var(--grid-fade) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-fade) 1px, transparent 1px);
  background-size: 100% 100%, 100% 100%, 48px 48px, 48px 48px;
}

.page-bg--scroll {
  position: absolute;
  inset: 0;
  border-bottom: none;
}

/* Layout */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: clamp(1.25rem, 3vw, 1.5rem);
}

.container--wide {
  max-width: var(--container-wide);
}

main {
  display: flex;
  flex: 1;
  flex-direction: column;
  min-height: 0;
}

.page-wrap {
  position: relative;
  flex: 1;
}

.page-content {
  padding: var(--space-10) 0 var(--space-16);
}

@media (min-width: 768px) {
  .page-content {
    padding: var(--space-12) 0 5.5rem;
  }
}

/* Header */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  height: var(--header-height);
  border-bottom: 1px solid var(--border);
  background: color-mix(in srgb, var(--background) 78%, transparent);
  backdrop-filter: blur(20px) saturate(1.25);
  -webkit-backdrop-filter: blur(20px) saturate(1.25);
}

.site-header__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 1rem;
  height: 100%;
  max-width: var(--container-wide);
  margin-inline: auto;
  padding-inline: 1.25rem;
}

.site-logo {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  text-decoration: none;
  flex-shrink: 0;
  grid-column: 1;
  justify-self: start;
}

.site-logo img {
  height: 2.5rem;
  width: auto;
  object-fit: contain;
  transition: transform var(--transition);
}

.site-logo:hover img { transform: scale(1.04); }

.site-logo span {
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: -0.02em;
}

.site-nav {
  display: none;
  align-items: center;
  gap: 0.25rem;
  width: fit-content;
  max-width: 100%;
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  grid-column: 2;
  justify-self: center;
}

@media (min-width: 768px) {
  .site-nav { display: flex; }
}

.site-nav__link,
.site-nav a {
  padding: 0.5rem 1rem;
  font-size: 0.9375rem;
  font-weight: 500;
  letter-spacing: -0.015em;
  line-height: 1.2;
  color: color-mix(in srgb, var(--foreground) 68%, var(--muted));
  text-decoration: none;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  background: transparent;
  white-space: nowrap;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition:
    color 160ms ease,
    background 160ms ease,
    border-color 160ms ease;
}

@media (hover: hover) {
  .site-nav__link:hover:not(.is-current):not(.active),
  .site-nav a:hover:not(.is-current):not(.active) {
    color: var(--foreground);
    background: color-mix(in srgb, var(--foreground) 5%, var(--surface-elevated));
    border-color: color-mix(in srgb, var(--foreground) 8%, transparent);
  }
}

.site-nav__link:active,
.site-nav a:active {
  transform: scale(0.98);
}

.site-nav__link.is-current,
.site-nav a.is-current,
.site-nav a.active {
  color: var(--foreground);
  font-weight: 600;
  background: color-mix(in srgb, var(--foreground) 8%, var(--surface-elevated));
  border-color: color-mix(in srgb, var(--foreground) 10%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--foreground) 6%, transparent);
}

html.is-navigating .site-nav__link:not(.is-current),
html.is-navigating .site-nav a:not(.is-current):not(.active) {
  color: color-mix(in srgb, var(--foreground) 72%, var(--muted));
  background: transparent;
  box-shadow: none;
}

.header-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
  grid-column: 3;
  justify-self: end;
}

.menu-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface);
  color: var(--foreground);
  cursor: pointer;
  transition: background var(--transition), border-color var(--transition);
}

.menu-toggle:hover {
  border-color: var(--border-hover);
  background: var(--surface-elevated);
}

@media (min-width: 768px) {
  .menu-toggle { display: none; }
}

.mobile-menu {
  display: none;
  border-top: 1px solid var(--border);
  padding: 0.75rem 1.25rem 1rem;
  background: color-mix(in srgb, var(--surface) 96%, transparent);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.mobile-menu.open { display: block; }

.mobile-menu nav {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.mobile-menu .site-nav__link,
.mobile-menu a {
  padding: 0.75rem 1rem;
  font-size: 0.9375rem;
  font-weight: 500;
  letter-spacing: -0.015em;
  color: color-mix(in srgb, var(--foreground) 68%, var(--muted));
  text-decoration: none;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  background: transparent;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition: background 160ms ease, color 160ms ease, border-color 160ms ease;
}

@media (hover: hover) {
  .mobile-menu .site-nav__link:hover:not(.is-current):not(.active),
  .mobile-menu a:hover:not(.is-current):not(.active) {
    color: var(--foreground);
    background: color-mix(in srgb, var(--foreground) 5%, var(--surface-elevated));
    border-color: color-mix(in srgb, var(--foreground) 8%, transparent);
  }
}

.mobile-menu .site-nav__link.is-current,
.mobile-menu a.is-current,
.mobile-menu a.active {
  color: var(--foreground);
  font-weight: 600;
  background: color-mix(in srgb, var(--foreground) 8%, var(--surface-elevated));
  border-color: color-mix(in srgb, var(--foreground) 10%, transparent);
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.625rem 1.25rem;
  font-size: 0.875rem;
  font-weight: 600;
  font-family: inherit;
  text-decoration: none;
  border-radius: var(--radius-md);
  border: none;
  cursor: pointer;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
}

.btn svg { width: 1.1rem; height: 1.1rem; flex-shrink: 0; }

.btn--primary {
  background: var(--accent);
  color: var(--accent-foreground);
  box-shadow: 0 1px 8px var(--accent-glow);
}

.btn--primary:hover {
  background: var(--accent-hover);
  box-shadow: 0 2px 12px var(--accent-glow);
}

.btn--secondary {
  background: color-mix(in srgb, var(--surface-elevated) 80%, transparent);
  color: var(--foreground);
  border: 1px solid var(--border);
}

.btn--secondary:hover {
  background: var(--card-hover);
  border-color: var(--border-hover);
}

.btn--ghost {
  background: transparent;
  color: var(--muted-light);
  border: 1px solid var(--border);
}

.btn--ghost:hover {
  color: var(--foreground);
  background: color-mix(in srgb, var(--foreground) 5%, transparent);
  border-color: var(--border-hover);
}

.btn--sm {
  padding: 0.375rem 0.75rem;
  font-size: 0.8125rem;
}

.btn--lg {
  padding: 0.875rem 1.75rem;
  font-size: 0.9375rem;
  border-radius: var(--radius-full);
}

/* Typography */
.eyebrow {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--accent-muted);
}

.eyebrow--admin {
  color: #fbbf24;
}

.page-title {
  margin-top: 0.75rem;
  font-size: clamp(1.875rem, 4vw, 2.375rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.12;
  text-wrap: balance;
}

.page-desc {
  margin-top: 1rem;
  font-size: clamp(0.9375rem, 2vw, 1.0625rem);
  color: var(--muted-light);
  line-height: 1.65;
  max-width: 38rem;
  margin-inline: auto;
  text-wrap: pretty;
}

.page-header {
  text-align: center;
  max-width: 40rem;
  margin-inline: auto;
  padding-bottom: var(--space-8);
  margin-bottom: var(--space-4);
}

.section-title {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.2;
}

.section-desc {
  margin-top: 0.75rem;
  font-size: 0.9375rem;
  color: var(--muted-light);
  max-width: 36rem;
  margin-inline: auto;
}

.text-muted { color: var(--muted-light); }
.text-accent { color: var(--accent-muted); }
.text-link {
  color: var(--accent-muted);
  text-decoration: none;
  font-weight: 500;
  transition: color var(--transition);
}
.text-link:hover { color: var(--accent); text-decoration: underline; }

/* Badges */
.badge {
  display: inline-flex;
  align-items: center;
  padding: 0.3rem 0.75rem;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border-radius: var(--radius-full);
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--muted-light);
}

.badge--accent {
  color: var(--accent-muted);
  background: var(--accent-subtle);
  border-color: rgba(88, 101, 242, 0.2);
}

.badge--danger {
  background: rgba(239, 68, 68, 0.15);
  color: var(--danger-muted);
  border-color: rgba(239, 68, 68, 0.25);
  font-size: 0.6875rem;
  text-transform: none;
  letter-spacing: 0;
  margin-top: 0.5rem;
}

/* Cards */
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  transition: border-color var(--transition), background var(--transition), box-shadow var(--transition), transform var(--transition);
}

.card:hover {
  border-color: var(--border-hover);
  background: var(--card-hover);
}

.card--link {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: var(--space-5) var(--space-6);
  text-decoration: none;
  min-height: 10.5rem;
}

.card--link:hover {
  border-color: color-mix(in srgb, var(--accent) 28%, transparent);
  background: color-mix(in srgb, var(--card-hover) 88%, var(--accent-subtle));
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-elevated) 90%, transparent);
  color: var(--muted-light);
  border: 1px solid var(--border);
  transition: color var(--transition), background var(--transition), border-color var(--transition), transform var(--transition);
}

.card--link:hover .card-icon {
  color: var(--accent-muted);
  background: var(--accent-subtle);
  border-color: color-mix(in srgb, var(--accent) 22%, transparent);
  transform: scale(1.04);
}

.card-icon svg { width: 1.25rem; height: 1.25rem; }

.card-body {
  flex: 1;
  min-width: 0;
  padding-top: var(--space-4);
}

.card-row .card-body {
  padding-top: 0;
}

.card-row {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
}

.card-title {
  font-size: 1.0625rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.35;
  transition: color var(--transition);
}

.card--link:hover .card-title {
  color: var(--foreground);
}

.card-desc {
  margin-top: 0.375rem;
  font-size: 0.875rem;
  color: var(--muted-light);
  line-height: 1.6;
}

.card-meta {
  margin-top: auto;
  padding-top: var(--space-4);
  border-top: 1px solid var(--border);
  font-size: 0.75rem;
  color: var(--muted);
}

/* Unified tile cards — regler, formulär, information, ansökningar */
.card--link.card-tile {
  padding: var(--space-6) var(--space-6) 0;
  min-height: 14rem;
  gap: 0;
}

.card-tile {
  overflow: hidden;
}

.card-tile > .card-body {
  padding-top: var(--space-6);
  padding-bottom: var(--space-6);
  flex: 1;
  display: flex;
  flex-direction: column;
}

.card-tile .card-title {
  font-size: 1.0625rem;
  line-height: 1.45;
}

.card-tile .card-desc {
  margin-top: var(--space-3);
  font-size: 0.875rem;
  line-height: 1.75;
  color: var(--muted-light);
}

.card-tile .badge {
  margin-top: var(--space-3);
  align-self: flex-start;
}

.card-tile > .card-meta {
  margin-top: 0;
  margin-left: calc(-1 * var(--space-6));
  margin-right: calc(-1 * var(--space-6));
  margin-bottom: 0;
  padding: var(--space-4) var(--space-6);
  border-top: 1px solid var(--border);
  background: color-mix(in srgb, var(--surface-elevated) 45%, transparent);
  display: flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.8125rem;
  font-weight: 600;
  line-height: 1.5;
  color: var(--muted-light);
  transition: color var(--transition), background var(--transition);
}

.card-tile > .card-meta svg {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
}

.card-tile:hover > .card-meta {
  background: color-mix(in srgb, var(--accent) 8%, var(--surface-elevated));
}

.card-tile:hover > .card-meta:not(.card-meta--static) {
  color: var(--accent-muted);
}

.card-meta--static {
  font-weight: 400;
  font-size: 0.75rem;
  color: var(--muted);
}

.card-tile:hover > .card-meta--static {
  color: var(--muted);
  background: color-mix(in srgb, var(--accent) 5%, var(--surface-elevated));
}

.card-tile:hover .arrow-nudge {
  transform: translateX(4px);
}

.arrow-nudge {
  display: inline-block;
  margin-left: 0.25rem;
  transition: transform var(--transition);
}

.card-grid {
  display: grid;
  gap: var(--space-5);
  margin-top: var(--space-8);
}

@media (min-width: 768px) {
  .card-grid {
    gap: var(--space-6);
    margin-top: 3rem;
  }
}

.card-grid--2 {
  grid-template-columns: 1fr;
  max-width: 56rem;
  margin-inline: auto;
}

.card-grid--3 {
  grid-template-columns: 1fr;
}

@media (min-width: 640px) {
  .card-grid--2 { grid-template-columns: repeat(2, 1fr); gap: var(--space-6); }
  .card-grid--3 { grid-template-columns: repeat(2, 1fr); gap: var(--space-5); }
}

@media (min-width: 1024px) {
  .card-grid--3 { grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
}

/* Stat cards */
.stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
  margin-top: 1.5rem;
  max-width: 64rem;
  margin-inline: auto;
}

.stat-card {
  position: relative;
  padding: 1.25rem 1.5rem;
  overflow: hidden;
  text-align: center;
  border-radius: var(--radius-xl);
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel) 88%, transparent);
}

.stat-card::before {
  content: '';
  pointer-events: none;
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 60% at 100% 0%, color-mix(in srgb, var(--accent) 12%, transparent), transparent 55%);
}

.stat-card > * {
  position: relative;
}

@media (min-width: 640px) {
  .stat-card {
    text-align: left;
  }
}

.stat-card__label {
  font-size: 0.625rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--accent-muted);
}

.stat-card__value {
  margin-top: 0.5rem;
  font-size: 2.5rem;
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

.stat-card__value--accent { color: var(--accent); }

.stat-card__sub {
  margin-top: 0.375rem;
  font-size: 0.8125rem;
  color: var(--muted);
}

.live-dot {
  position: absolute;
  top: 1.25rem;
  right: 1.25rem;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background: var(--success);
  box-shadow: 0 0 8px rgba(34, 197, 94, 0.6);
}

.live-dot::before {
  content: '';
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  background: rgba(34, 197, 94, 0.4);
  animation: pulse 2s ease-in-out infinite;
}

.live-indicator {
  position: absolute;
  top: 0.875rem;
  right: 0.875rem;
  display: flex;
  width: 0.625rem;
  height: 0.625rem;
}

.live-indicator__ping {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 50%, transparent);
  animation: live-ping 2s ease-out infinite;
}

.live-indicator__dot {
  position: relative;
  width: 0.625rem;
  height: 0.625rem;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 10px var(--accent-glow);
  outline: 2px solid color-mix(in srgb, var(--accent) 35%, transparent);
}

@keyframes pulse {
  0%, 100% { transform: scale(1); opacity: 0.6; }
  50% { transform: scale(1.8); opacity: 0; }
}

@keyframes live-ping {
  0% { transform: scale(1); opacity: 0.75; }
  75%, 100% { transform: scale(2.2); opacity: 0; }
}

/* Notice box */
.notice {
  max-width: 32rem;
  margin: var(--space-6) auto 0;
  padding: var(--space-4) var(--space-5);
  text-align: center;
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--muted-light);
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in srgb, var(--accent) 16%, transparent);
  background: color-mix(in srgb, var(--accent) 5%, var(--surface));
}

/* Breadcrumb navigation */
.site-breadcrumb,
.info-breadcrumb,
.portal-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.375rem;
  margin-bottom: var(--space-6);
  font-size: 0.8125rem;
  color: var(--muted);
}

.site-breadcrumb a,
.info-breadcrumb a,
.portal-breadcrumb a {
  font-weight: 500;
  color: var(--accent-muted);
  text-decoration: none;
  transition: color var(--transition);
}

.site-breadcrumb a:hover,
.info-breadcrumb a:hover,
.portal-breadcrumb a:hover {
  color: var(--foreground);
}

.site-breadcrumb__sep,
.info-breadcrumb__sep {
  color: var(--muted);
  opacity: 0.5;
}

.site-breadcrumb__current,
.info-breadcrumb__current,
.portal-breadcrumb .site-breadcrumb__current,
.portal-breadcrumb span:last-child:not(.site-breadcrumb__sep):not(.info-breadcrumb__sep) {
  color: var(--foreground);
  font-weight: 500;
}

.site-breadcrumb--login {
  position: fixed;
  top: var(--space-6);
  left: var(--space-6);
  z-index: 10;
  margin-bottom: 0;
}

@media (min-width: 768px) {
  .site-breadcrumb--login {
    top: var(--space-8);
    left: var(--space-8);
  }
}

/* Sections */
.section {
  padding: var(--section-gap) 0;
  border-top: 1px solid var(--border);
}

.section--alt {
  background: color-mix(in srgb, var(--surface) 50%, transparent);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.section-header {
  text-align: center;
  margin-bottom: clamp(1.75rem, 4vw, 2.5rem);
  max-width: 36rem;
  margin-inline: auto;
}

.section-header .section-desc {
  margin-top: var(--space-3);
}

.section-header--compact {
  margin-bottom: var(--space-5);
}

.section-header--ruled {
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--border);
  margin-bottom: clamp(2rem, 4vw, 2.75rem);
}

.hero {
  position: relative;
  padding: clamp(2.5rem, 5vw, 4rem) 0 clamp(2.5rem, 5vw, 3.5rem);
}

.hero__layout {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2.5rem;
  text-align: center;
}

@media (min-width: 1024px) {
  .hero__layout {
    flex-direction: row;
    align-items: flex-start;
    gap: 4rem;
    text-align: left;
  }
}

.hero__content {
  min-width: 0;
  flex: 1;
}

.hero__stats {
  margin-top: clamp(2.5rem, 5vw, 3.5rem);
}

.hero__stats > .eyebrow {
  text-align: center;
  margin-bottom: 1.25rem;
}

.section--bleed {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding-left: max(1.25rem, calc(50vw - 36rem));
  padding-right: max(1.25rem, calc(50vw - 36rem));
}

.section-actions {
  display: flex;
  justify-content: center;
  margin-top: 2rem;
}

.hero__logo-wrap {
  position: relative;
  display: flex;
  flex-shrink: 0;
  justify-content: center;
  padding-top: 0.25rem;
}

.hero__logo-wrap::before {
  content: '';
  position: absolute;
  inset: -1.25rem;
  background: var(--accent-glow);
  filter: blur(3rem);
  border-radius: 1.5rem;
  opacity: 0.9;
}

.hero__logo {
  position: relative;
  width: 7.5rem;
  height: 7.5rem;
  object-fit: contain;
  filter: drop-shadow(0 16px 32px rgba(0, 0, 0, 0.35));
}

.hero__badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem;
  margin-bottom: 1.25rem;
}

@media (min-width: 1024px) {
  .hero__badges {
    justify-content: flex-start;
  }
}

.hero__title {
  font-size: clamp(2.25rem, 5vw, 3.15rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.08;
  color: var(--foreground);
}

.hero__text {
  margin-top: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  font-size: 1rem;
  color: var(--muted);
  line-height: 1.7;
  max-width: 36rem;
  margin-inline: auto;
}

@media (min-width: 1024px) {
  .hero__text {
    margin-inline: 0;
    font-size: 1.0625rem;
  }
}

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.75rem;
  margin-top: 1.5rem;
}

@media (min-width: 1024px) {
  .hero__actions {
    justify-content: flex-start;
  }
}

.hero__rules {
  margin-top: 1rem;
  font-size: 0.75rem;
  color: var(--muted);
  text-align: center;
}

@media (min-width: 1024px) {
  .hero__rules {
    text-align: left;
  }
}

.hero__rules a {
  font-weight: 500;
  color: var(--accent-muted);
  text-decoration: none;
  text-underline-offset: 2px;
}

.hero__rules a:hover {
  text-decoration: underline;
}

/* Portal steps */
.portal-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  max-width: 48rem;
  margin-inline: auto;
}

@media (min-width: 768px) {
  .portal-grid { grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
}

.portal-step {
  position: relative;
  padding: 1.5rem 1.25rem;
  text-align: center;
  text-decoration: none;
}

.portal-step__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  margin-bottom: 1rem;
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--accent);
  background: var(--accent-subtle);
  border: 1px solid rgba(88, 101, 242, 0.25);
  border-radius: 50%;
}

.portal-step__tag {
  display: block;
  font-size: 0.625rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  margin-bottom: 0.375rem;
}

.portal-step__title {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}

.portal-step__desc {
  font-size: 0.8125rem;
  color: var(--muted-light);
  line-height: 1.55;
}

/* Feature cards */
.feature-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.875rem;
}

@media (min-width: 640px) {
  .feature-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }
}

@media (min-width: 1024px) {
  .feature-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
  }
}

.feature-card {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  padding: var(--space-5);
  border-radius: var(--radius-xl);
  border: 1px solid var(--border);
  background: var(--card);
  transition: background var(--transition), border-color var(--transition);
}

.feature-card:hover {
  background: var(--card-hover);
  border-color: color-mix(in srgb, var(--accent) 16%, transparent);
}

.feature-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: var(--radius-md);
  background: var(--accent-subtle);
  color: var(--accent-muted);
  border: 1px solid rgba(88, 101, 242, 0.15);
}

.feature-card__icon svg { width: 1.25rem; height: 1.25rem; }

.feature-card__body { min-width: 0; }

.feature-card__title {
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.35;
}

.feature-card__desc {
  margin-top: 0.375rem;
  font-size: 0.8125rem;
  color: var(--muted);
  line-height: 1.6;
}

/* Process steps */
.process-row {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

@media (min-width: 768px) {
  .process-row {
    flex-direction: row;
    align-items: stretch;
    gap: 0.75rem;
  }
}

.process-step {
  flex: 1;
  padding: 1.5rem;
  border-radius: var(--radius-xl);
  border: 1px solid color-mix(in srgb, var(--foreground) 10%, transparent);
  background: color-mix(in srgb, var(--surface-elevated) 35%, transparent);
}

.process-step__label {
  font-size: 0.625rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--accent-muted);
}

.process-step__title {
  margin-top: 0.75rem;
  font-size: 1.0625rem;
  font-weight: 600;
}

.process-step__desc {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  color: var(--muted-light);
  line-height: 1.6;
}

.process-arrow {
  display: none;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  flex-shrink: 0;
}

.process-arrow svg { width: 1.25rem; height: 1.25rem; }

@media (min-width: 768px) {
  .process-arrow { display: flex; }
}

/* CTA */
.cta-section {
  padding: 3rem 0 5rem;
  border-top: none;
}

.cta-box {
  position: relative;
  overflow: hidden;
  padding: clamp(2rem, 4vw, 3rem) clamp(1.5rem, 4vw, 2.5rem);
  text-align: center;
  border-radius: var(--radius-xl);
  border: 1px solid color-mix(in srgb, var(--accent) 18%, transparent);
  background:
    radial-gradient(ellipse 80% 60% at 50% -15%, var(--accent-dim), transparent 65%),
    var(--card);
}

.cta-box::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 80% 80%, rgba(88, 101, 242, 0.06), transparent 45%);
  pointer-events: none;
}

.cta-box > * { position: relative; }

.cta-box .section-title {
  font-size: clamp(1.5rem, 3vw, 2rem);
  letter-spacing: -0.03em;
}

.cta-box .section-desc {
  margin-top: 0.875rem;
  font-size: 1rem;
  max-width: 28rem;
}

.cta-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.875rem;
  margin-top: 2rem;
}

.btn--discord {
  background: rgba(255, 255, 255, 0.05);
  color: var(--foreground);
  border: 1px solid var(--border-hover);
  box-shadow: none;
}

.btn--discord:hover {
  background: rgba(88, 101, 242, 0.12);
  border-color: rgba(88, 101, 242, 0.35);
}

/* Footer */
.site-footer {
  margin-top: auto;
  border-top: 1px solid var(--border);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
}

.site-footer__inner {
  max-width: var(--container-wide);
  margin-inline: auto;
  padding: clamp(2.5rem, 5vw, 3.5rem) var(--space-5) var(--space-6);
}

.site-footer__main {
  display: grid;
  gap: clamp(2rem, 4vw, 3rem);
}

@media (min-width: 768px) {
  .site-footer__main {
    grid-template-columns: minmax(220px, 1.4fr) repeat(3, minmax(0, 1fr));
    align-items: start;
  }
}

.site-footer__intro {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}

.site-footer__brand {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  text-decoration: none;
}

.site-footer__brand img {
  height: 2.25rem;
  width: auto;
  object-fit: contain;
  opacity: 0.95;
}

.site-footer__brand-name {
  display: block;
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: -0.02em;
}

.site-footer__brand-sub {
  display: block;
  margin-top: 0.125rem;
  font-size: 0.6875rem;
  color: var(--muted);
}

.site-footer__tagline {
  font-size: 0.8125rem;
  line-height: 1.65;
  color: var(--muted-light);
  max-width: 22rem;
}

.site-footer__col-title {
  margin: 0 0 0.875rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--foreground);
}

.site-footer__col-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.site-footer__col-list a {
  font-size: 0.8125rem;
  color: var(--muted-light);
  text-decoration: none;
  transition: color var(--transition);
}

.site-footer__col-list a:hover {
  color: var(--foreground);
}

.site-footer__bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem 1.5rem;
  margin-top: clamp(2rem, 4vw, 2.75rem);
  padding-top: 1.25rem;
  border-top: 1px solid var(--border);
}

.site-footer__bar-left {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem 1.5rem;
}

.site-footer__bar-left p {
  margin: 0;
  font-size: 0.75rem;
  color: var(--muted);
}

.site-footer__bar-right {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
  font-size: 0.75rem;
  color: var(--muted);
}

.site-footer__server {
  display: inline-flex;
  align-items: baseline;
  gap: 0.375rem;
}

.site-footer__mono {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.75rem;
}

.site-footer__online {
  font-weight: 600;
  color: var(--accent);
  font-variant-numeric: tabular-nums;
}

/* Legacy footer selectors (pre-upgrade markup) */
.site-footer__top {
  display: grid;
  gap: var(--space-6);
}

@media (min-width: 768px) {
  .site-footer__top {
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: var(--space-8);
  }
}

.site-footer__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-4) var(--space-6);
  font-size: 0.8125rem;
}

@media (min-width: 768px) {
  .site-footer__meta {
    justify-content: flex-end;
  }
}

.site-footer__meta-item {
  display: flex;
  align-items: baseline;
  gap: 0.375rem;
}

.site-footer__meta-label { color: var(--muted); }

.site-footer__links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-top: var(--space-5);
  padding-top: var(--space-5);
  border-top: 1px solid var(--border);
  font-size: 0.8125rem;
}

.site-footer__links a {
  color: var(--muted);
  text-decoration: none;
  transition: color var(--transition);
}

.site-footer__links a:hover {
  color: var(--foreground);
  text-decoration: underline;
}

.site-footer__bottom {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 0.875rem;
  font-size: 0.75rem;
  color: var(--muted);
}

/* Rule content pages */
.rule-item {
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: var(--card);
  padding: var(--space-4) var(--space-5);
  margin-bottom: var(--space-3);
}

.rule-item:last-child { margin-bottom: 0; }

.rule-letter {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--accent-muted);
}

.rule-title {
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.35;
}

.rule-def {
  margin-top: 0.625rem;
  font-size: 0.9375rem;
  line-height: 1.65;
  color: var(--muted-light);
  white-space: pre-line;
}

.rule-example {
  margin-top: 0.875rem;
  padding: 0.875rem 1rem;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(88, 101, 242, 0.2);
  background: var(--accent-subtle);
  font-size: 0.875rem;
  line-height: 1.6;
  white-space: pre-line;
}

.example-label {
  font-weight: 600;
  color: var(--accent-muted);
}

.section-h2 {
  scroll-margin-top: calc(var(--header-height) + 1rem);
  margin-top: 3rem;
  margin-bottom: 1rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--border);
  font-size: 1.25rem;
  font-weight: 600;
  letter-spacing: -0.02em;
}

.body-p {
  margin-top: 1rem;
  font-size: 0.9375rem;
  line-height: 1.65;
  color: var(--muted-light);
}

.content-panel {
  max-width: 48rem;
  margin-inline: auto;
  padding: var(--space-6);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background: var(--card);
}

/* Scroll hint */
.scroll-hint {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  margin-top: 3rem;
  color: var(--muted);
  font-size: 0.875rem;
}

.scroll-hint svg { opacity: 0.5; }

@keyframes scroll-wheel {
  0%, 100% { transform: translateY(0); opacity: 1; }
  50% { transform: translateY(6px); opacity: 0.3; }
}

.scroll-hint circle { animation: scroll-wheel 2s ease-in-out infinite; }

/* Price tables (prislista) */
.price-page {
  max-width: 52rem;
  margin-inline: auto;
}

.price-page__updated {
  margin-top: var(--space-3);
  font-size: 0.8125rem;
  color: var(--muted);
}

.price-info-bar {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-8);
  padding: var(--space-4) var(--space-5);
  border: 1px solid color-mix(in srgb, var(--accent) 16%, transparent);
  border-radius: var(--radius-xl);
  background: color-mix(in srgb, var(--accent) 5%, var(--card));
}

@media (min-width: 640px) {
  .price-info-bar {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-4) var(--space-6);
  }
}

.price-info-bar__item {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  font-size: 0.875rem;
}

@media (min-width: 640px) {
  .price-info-bar__item--grow {
    flex: 1;
    min-width: 12rem;
  }
}

.price-info-bar__label {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
}

.price-info-bar__value {
  color: var(--foreground);
  font-weight: 500;
}

.price-info-bar__note {
  font-size: 0.8125rem;
  line-height: 1.55;
  color: var(--muted-light);
}

.price-sections {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

.price-section__title {
  margin-bottom: var(--space-3);
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: -0.01em;
}

/* Köpvillkor */
.terms-page {
  max-width: 52rem;
  margin-inline: auto;
}

.terms-page__updated {
  margin-top: var(--space-3);
  font-size: 0.8125rem;
  color: var(--muted);
}

.terms-info-bar {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-6);
  padding: var(--space-4) var(--space-5);
  border: 1px solid color-mix(in srgb, var(--accent) 16%, transparent);
  border-radius: var(--radius-xl);
  background: color-mix(in srgb, var(--accent) 5%, var(--card));
}

@media (min-width: 640px) {
  .terms-info-bar {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-4) var(--space-6);
  }
}

.terms-info-bar__item {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

@media (min-width: 640px) {
  .terms-info-bar__item--grow {
    flex: 1;
    min-width: 12rem;
  }
}

.terms-info-bar__label {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
}

.terms-info-bar__value {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--foreground);
}

.terms-info-bar__note {
  font-size: 0.8125rem;
  line-height: 1.55;
  color: var(--muted-light);
}

.terms-intro {
  margin-bottom: var(--space-6);
  padding: var(--space-5) var(--space-6);
  border-color: color-mix(in srgb, var(--accent) 14%, var(--border));
  background: color-mix(in srgb, var(--accent) 4%, var(--card));
}

.terms-intro p {
  font-size: 0.9375rem;
  line-height: 1.7;
  color: var(--muted-light);
}

.terms-sections {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.terms-section {
  padding: var(--space-6);
}

@media (min-width: 640px) {
  .terms-section {
    padding: var(--space-6) 1.75rem;
  }
}

.terms-section__head {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--border);
}

.terms-section__index {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 22%, transparent);
  font-size: 0.75rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--accent-muted);
}

.terms-section__title {
  font-size: 1.0625rem;
  font-weight: 600;
  letter-spacing: -0.02em;
}

.terms-section__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.terms-section__body p {
  font-size: 0.9375rem;
  line-height: 1.75;
  color: var(--muted-light);
}

.terms-section__body p strong {
  color: var(--foreground);
  font-weight: 600;
}

.terms-contact {
  margin-top: var(--space-8);
  padding: var(--space-6);
  text-align: center;
}

@media (min-width: 640px) {
  .terms-contact {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    text-align: left;
  }
}

.terms-contact__title {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.terms-contact__text {
  margin-top: var(--space-2);
  max-width: 28rem;
  font-size: 0.875rem;
  line-height: 1.65;
  color: var(--muted-light);
}

@media (min-width: 640px) {
  .terms-contact__text {
    flex: 1;
    margin-top: 0;
  }

  .terms-contact .btn {
    flex-shrink: 0;
  }
}

.price-table-panel {
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background: var(--card);
}

.price-table-wrap {
  overflow-x: auto;
  margin-top: 0;
}

.price-table {
  width: 100%;
  text-align: left;
  font-size: 0.875rem;
  border-collapse: collapse;
}

.price-table thead tr {
  border-bottom: 1px solid var(--border);
  background: color-mix(in srgb, var(--surface-elevated) 80%, transparent);
}

.price-table thead th {
  padding: 0.75rem 1.125rem;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  white-space: nowrap;
}

.price-table thead th:last-child,
.price-table td.right {
  text-align: right;
}

.price-table tbody tr {
  border-bottom: 1px solid var(--border);
  color: var(--muted-light);
  transition: background var(--transition);
}

.price-table tbody tr:last-child { border-bottom: none; }
.price-table tbody tr:hover { background: var(--hover-overlay); }
.price-table td {
  padding: 0.8125rem 1.125rem;
  vertical-align: middle;
  line-height: 1.45;
}

.price-table td:first-child {
  color: var(--foreground);
  font-weight: 500;
}

.price-table td.right {
  white-space: nowrap;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--accent-muted);
}

.price-table--triple thead th:nth-child(2),
.price-table--triple thead th:nth-child(3),
.price-table--triple td.right {
  text-align: right;
  width: 8.5rem;
}

.price-disclaimer {
  margin-top: var(--space-8);
  padding: var(--space-4) var(--space-5);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  font-size: 0.8125rem;
  line-height: 1.6;
  color: var(--muted-light);
  background: color-mix(in srgb, var(--surface-elevated) 40%, transparent);
}

.price-page__intro {
  margin-bottom: var(--space-6);
  font-size: 0.9375rem;
  line-height: 1.65;
  color: var(--muted-light);
}

/* Article layout */
article > header {
  border-bottom: 1px solid var(--border);
  padding-bottom: 2rem;
}

article > header + .card,
article > header + .content-panel {
  margin-top: 2.5rem;
}

details summary {
  display: flex;
  cursor: pointer;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
  font-size: 0.875rem;
  font-weight: 600;
  list-style: none;
}

details summary::-webkit-details-marker { display: none; }

details[open] .chevron { transform: rotate(180deg); }

.chevron {
  color: var(--accent-muted);
  transition: transform var(--transition);
}

article iframe {
  display: block;
  width: 100%;
  min-height: min(85vh, 52rem);
  border: none;
  background: var(--background);
}

/* Login page */
.login-page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 2.5rem 1.25rem;
}

.login-page__bg {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: -1;
  background-color: var(--background);
  background-image:
    linear-gradient(to bottom, transparent 0%, var(--background) 68%),
    radial-gradient(ellipse 70% 50% at 50% 30%, var(--accent-dim), transparent 72%),
    linear-gradient(var(--grid-fade) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-fade) 1px, transparent 1px);
  background-size: 100% 100%, 100% 100%, 48px 48px, 48px 48px;
}

.login-card {
  width: 100%;
  max-width: 26rem;
  padding: var(--space-8) var(--space-6);
  text-align: center;
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background: var(--card);
  box-shadow: var(--shadow-lg);
}

.login-card__logo-wrap {
  position: relative;
  display: inline-flex;
  margin-bottom: 2rem;
}

.login-card__logo-wrap::before {
  content: '';
  position: absolute;
  inset: -1.25rem;
  background: var(--accent-glow);
  filter: blur(2.5rem);
  border-radius: 50%;
  opacity: 0.65;
}

.login-card__logo {
  position: relative;
  width: 100px;
  height: 100px;
  object-fit: contain;
}

.login-card__title {
  font-size: clamp(1.625rem, 4vw, 1.875rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.2;
}

.login-card__desc {
  margin-top: 0.875rem;
  font-size: 0.9375rem;
  line-height: 1.65;
  color: var(--muted-light);
}

.login-card__actions {
  margin-top: 2rem;
}

.login-discord-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.625rem;
  width: 100%;
  padding: 0.875rem 1.5rem;
  font-family: inherit;
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--accent-foreground);
  text-decoration: none;
  border: none;
  border-radius: var(--radius-full);
  background: var(--accent);
  box-shadow: 0 4px 20px var(--accent-glow);
  cursor: pointer;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
}

.login-discord-btn:hover {
  background: var(--accent-hover);
  box-shadow: 0 4px 20px var(--accent-glow);
}

.login-discord-btn svg {
  width: 1.25rem;
  height: 1.25rem;
  flex-shrink: 0;
}

.login-card__terms {
  margin-top: 1.25rem;
  font-size: 0.75rem;
  line-height: 1.55;
  color: var(--muted);
}

.login-card__terms a {
  color: var(--muted-light);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color var(--transition);
}

.login-card__terms a:hover {
  color: var(--foreground);
}

.login-card__error {
  margin-top: 1rem;
  padding: 0.75rem 1rem;
  border-radius: var(--radius-md);
  border: 1px solid rgba(239, 68, 68, 0.25);
  background: rgba(239, 68, 68, 0.1);
  font-size: 0.8125rem;
  color: var(--danger-muted);
  line-height: 1.5;
}

.user-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  max-width: 12rem;
  padding: 0.35rem 0.75rem 0.35rem 0.35rem;
  border-radius: var(--radius-full);
  border: 1px solid var(--border);
  background: var(--surface-elevated);
  text-decoration: none;
  transition: border-color var(--transition), background var(--transition);
}

.user-chip:hover {
  border-color: var(--border-hover);
  background: var(--card-hover);
}

.user-chip img {
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

.user-chip span {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--foreground);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 480px) {
  .user-chip span { display: none; }
  .user-chip { padding: 0.35rem; }
}

/* ——— Portal ——— */
.container--narrow {
  max-width: 64rem;
}

.container--wide {
  max-width: var(--container-wide);
}

.container--medium {
  max-width: 68rem;
}

.portal-shell {
  padding: clamp(2.25rem, 5vw, 3.25rem) 0 clamp(3.5rem, 7vw, 5.5rem);
}

.portal-subnav {
  position: relative;
  z-index: 20;
  width: fit-content;
  max-width: 100%;
  margin-bottom: clamp(1.25rem, 3vw, 2rem);
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  overflow: visible;
}

.portal-subnav__track {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  max-width: 100%;
}

.portal-subnav__scroll {
  display: flex;
  min-width: 0;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.portal-subnav__scroll::-webkit-scrollbar {
  display: none;
}

.portal-subnav__links {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.25rem;
}

.portal-subnav__divider {
  flex-shrink: 0;
  width: 1px;
  height: 1.125rem;
  margin-inline: 0.375rem;
  background: color-mix(in srgb, var(--foreground) 10%, transparent);
}

.portal-subnav__link {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  padding: 0.5rem 1rem;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  font-size: 0.9375rem;
  font-weight: 500;
  letter-spacing: -0.015em;
  line-height: 1.2;
  color: color-mix(in srgb, var(--foreground) 68%, var(--muted));
  text-decoration: none;
  white-space: nowrap;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition:
    color 160ms ease,
    background 160ms ease,
    border-color 160ms ease;
}

.portal-subnav__link:hover:not(.portal-subnav__link--active) {
  color: var(--foreground);
  background: color-mix(in srgb, var(--foreground) 5%, var(--surface-elevated));
  border-color: color-mix(in srgb, var(--foreground) 8%, transparent);
}

.portal-subnav__link--active {
  color: var(--foreground);
  font-weight: 600;
  background: color-mix(in srgb, var(--foreground) 8%, var(--surface-elevated));
  border-color: color-mix(in srgb, var(--foreground) 10%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--foreground) 6%, transparent);
  cursor: default;
}

.portal-subnav__link--active:hover {
  color: var(--foreground);
  background: color-mix(in srgb, var(--foreground) 8%, var(--surface-elevated));
  border-color: color-mix(in srgb, var(--foreground) 10%, transparent);
}

.portal-subnav__admin {
  position: relative;
  flex-shrink: 0;
}

.portal-subnav__admin-btn {
  position: relative;
  cursor: pointer;
  font-family: inherit;
  font-size: 0.9375rem;
  font-weight: 500;
  letter-spacing: -0.015em;
  line-height: 1.2;
  gap: 0.375rem;
  background: transparent;
  border: 1px solid transparent;
  color: color-mix(in srgb, var(--foreground) 68%, var(--muted));
  -webkit-appearance: none;
  appearance: none;
}

.portal-subnav__admin-btn:hover:not(.portal-subnav__link--active):not([aria-expanded="true"]) {
  color: var(--foreground);
  background: color-mix(in srgb, var(--foreground) 5%, var(--surface-elevated));
  border-color: color-mix(in srgb, var(--foreground) 8%, transparent);
}

.portal-subnav__admin-btn.portal-subnav__link--active,
.portal-subnav__admin-btn[aria-expanded="true"] {
  color: var(--foreground);
  font-weight: 600;
  background: color-mix(in srgb, var(--foreground) 8%, var(--surface-elevated));
  border-color: color-mix(in srgb, var(--foreground) 10%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--foreground) 6%, transparent);
}

.portal-subnav__chevron {
  width: 0.875rem;
  height: 0.875rem;
  opacity: 0.7;
  transition: transform 160ms ease;
}

.portal-subnav__admin-btn[aria-expanded="true"] .portal-subnav__chevron {
  transform: rotate(180deg);
}

.portal-subnav__admin-menu {
  position: absolute;
  top: calc(100% + 0.5rem);
  right: 0;
  z-index: 60;
  min-width: 15rem;
  padding: 0.375rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--surface-elevated) 96%, transparent);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: var(--shadow-md);
}

.portal-subnav__admin-menu[hidden] {
  display: none;
}

@media (max-width: 767px) {
  .portal-subnav__admin-menu {
    right: 0;
    left: auto;
    min-width: 13rem;
    max-width: min(16rem, calc(100vw - 2.5rem));
  }
}

.portal-subnav__admin-item {
  position: relative;
  display: block;
  padding: 0.625rem 0.75rem;
  border-radius: 0.5rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: color-mix(in srgb, var(--foreground) 68%, var(--muted));
  text-decoration: none;
  transition: background 160ms ease, color 160ms ease;
}

.portal-subnav__admin-item--badged {
  padding-right: 2.25rem;
}

.portal-subnav__admin-badge {
  position: absolute;
  top: 0.4375rem;
  right: 0.5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.125rem;
  height: 1.125rem;
  padding: 0 0.3rem;
  font-size: 0.625rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  color: #fff;
  border-radius: var(--radius-full);
  background: #ef4444;
  box-shadow: 0 0 0 2px var(--card);
  pointer-events: none;
}

.portal-subnav__admin-btn--badged {
  padding-right: 1.75rem;
}

.portal-subnav__admin-btn-badge {
  position: absolute;
  top: -0.2rem;
  right: -0.125rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1rem;
  height: 1rem;
  padding: 0 0.25rem;
  font-size: 0.5625rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  color: #fff;
  border-radius: var(--radius-full);
  background: #ef4444;
  box-shadow: 0 0 0 2px var(--surface-elevated);
  pointer-events: none;
}

.portal-subnav__admin-item:hover:not(.portal-subnav__admin-item--active) {
  color: var(--foreground);
  background: color-mix(in srgb, var(--foreground) 5%, var(--surface-elevated));
}

.portal-subnav__admin-item--active {
  color: var(--foreground);
  font-weight: 600;
  background: color-mix(in srgb, var(--foreground) 8%, var(--surface-elevated));
  cursor: default;
}

.portal-subnav__admin-item--active:hover {
  color: var(--foreground);
  background: color-mix(in srgb, var(--foreground) 8%, var(--surface-elevated));
}

.portal-page-header {
  margin-bottom: clamp(1.25rem, 3vw, 2rem);
  max-width: 36rem;
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--border);
}

.portal-page-header__title {
  margin-top: 0.75rem;
  font-size: clamp(1.625rem, 3.5vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.15;
  text-wrap: balance;
}

.portal-page-header__desc {
  margin-top: 0.875rem;
  font-size: 0.9375rem;
  line-height: 1.65;
  color: var(--muted-light);
  text-wrap: pretty;
}

.portal-back {
  display: inline-block;
  margin-bottom: 1.5rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--accent-muted);
  text-decoration: none;
  transition: color var(--transition);
}

.portal-back:hover { color: var(--foreground); }

.portal-card {
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background: var(--card);
}

.portal-profile {
  position: relative;
  padding: clamp(1.625rem, 3.5vw, 2.125rem) clamp(1.625rem, 3.5vw, 2.25rem);
  overflow: hidden;
}

.portal-profile__glow {
  pointer-events: none;
  position: absolute;
  inset: 0;
  opacity: 0.5;
  background:
    radial-gradient(ellipse 80% 60% at 12% -15%, var(--accent-glow), transparent 55%),
    linear-gradient(135deg, color-mix(in srgb, var(--surface-elevated) 18%, transparent), transparent 50%);
}

.portal-profile__label,
.portal-profile__layout {
  position: relative;
}

.portal-profile__label {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent-muted);
  margin-bottom: 1.125rem;
}

.portal-profile__layout {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

@media (min-width: 640px) {
  .portal-profile__layout {
    flex-direction: row;
    align-items: flex-start;
    gap: 2rem;
  }
}

.portal-profile__aside {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 6.5rem;
  flex-shrink: 0;
  margin-inline: auto;
}

@media (min-width: 640px) {
  .portal-profile__aside { margin-inline: 0; }
}

.portal-profile__avatar {
  width: 4.75rem;
  height: 4.75rem;
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in srgb, var(--foreground) 10%, transparent);
  object-fit: cover;
  box-shadow: 0 8px 28px -12px color-mix(in srgb, var(--accent) 40%, transparent);
}

.portal-profile__main {
  flex: 1;
  min-width: 0;
  text-align: center;
}

@media (min-width: 640px) {
  .portal-profile__main { text-align: left; }
}

.portal-profile__name {
  font-size: clamp(1.125rem, 2.5vw, 1.3125rem);
  font-weight: 700;
  letter-spacing: -0.02em;
}

.portal-profile__hint {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--muted-light);
  max-width: 32rem;
}

.portal-details {
  margin-top: 1.5rem;
  display: grid;
  gap: 0.625rem;
  max-width: 100%;
}

@media (min-width: 640px) {
  .portal-details { max-width: 40rem; }
}

.portal-details__row {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  padding: 0.75rem 1rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--background) 40%, transparent);
}

@media (min-width: 640px) {
  .portal-details__row {
    flex-direction: row;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
  }
}

.portal-details__row dt {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.portal-details__row dd {
  font-size: 0.875rem;
  font-weight: 500;
  word-break: break-word;
}

@media (min-width: 640px) {
  .portal-details__row dd { text-align: right; }
}

.portal-details__row code {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.75rem;
  padding: 0.25rem 0.5rem;
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--surface-elevated) 88%, transparent);
  color: var(--accent-muted);
}

.reputation-bar {
  position: relative;
  width: 100%;
  margin-top: 0.5rem;
}

.reputation-bar__track {
  height: 0.375rem;
  width: 100%;
  overflow: hidden;
  border-radius: var(--radius-full);
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--background) 55%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--foreground) 5%, transparent);
}

.reputation-bar__fill {
  height: 100%;
  border-radius: inherit;
  background: color-mix(in srgb, var(--accent) 78%, var(--surface-elevated));
  transition: width 500ms ease;
}

.reputation-bar__tooltip {
  display: none;
  position: absolute;
  left: calc(100% + 0.5rem);
  top: 50%;
  transform: translateY(-50%);
  z-index: 20;
  min-width: 10rem;
  max-width: 16rem;
  padding: 0.5rem 0.75rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-elevated) 96%, transparent);
  box-shadow: var(--shadow-md);
  text-align: left;
}

.reputation-bar.group:hover .reputation-bar__tooltip { display: block; }

.reputation-bar__tooltip-title {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
}

.reputation-bar__tooltip-sub {
  display: block;
  margin-top: 0.25rem;
  font-size: 0.6875rem;
  line-height: 1.4;
  color: var(--muted);
}

.role-icons {
  display: flex;
  justify-content: center;
  gap: 0.375rem;
  margin-top: 0.875rem;
  width: 100%;
}

.role-icon {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-elevated) 55%, transparent);
  color: var(--muted);
  opacity: 0.38;
  transition: opacity var(--transition), border-color var(--transition), transform var(--transition);
}

.role-icon--active {
  opacity: 1;
  color: var(--accent-muted);
  border-color: color-mix(in srgb, var(--accent) 28%, transparent);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
}

.role-icon__svg { width: 1rem; height: 1rem; }

.role-icon__tip {
  display: none;
  position: absolute;
  top: calc(100% + 0.35rem);
  left: 50%;
  transform: translateX(-50%);
  padding: 0.25rem 0.5rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--surface-elevated) 96%, transparent);
  font-size: 0.6875rem;
  font-weight: 500;
  white-space: nowrap;
  box-shadow: var(--shadow-sm);
  z-index: 20;
}

.role-icon:hover .role-icon__tip,
.role-icon:focus-visible .role-icon__tip { display: block; }

.portal-nav-grid {
  display: grid;
  gap: 1rem;
  margin-top: clamp(2rem, 4vw, 2.75rem);
}

@media (min-width: 640px) {
  .portal-nav-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
  }
}

@media (min-width: 1024px) {
  .portal-nav-grid { gap: 1.375rem; }
}

.portal-nav-card {
  display: flex;
  flex-direction: column;
  min-height: 11.25rem;
  padding: clamp(1.25rem, 2.5vw, 1.5rem) clamp(1.375rem, 2.5vw, 1.625rem);
  text-decoration: none;
  transition: border-color var(--transition), background var(--transition), transform var(--transition), box-shadow var(--transition);
}

.portal-nav-card:hover {
  border-color: color-mix(in srgb, var(--accent) 24%, transparent);
  background: var(--card-hover);
  box-shadow: var(--shadow-sm);
}

.portal-nav-card__head {
  display: flex;
  gap: 0.875rem;
  align-items: flex-start;
  flex: 1;
}

.portal-nav-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  flex-shrink: 0;
  border-radius: var(--radius-md);
  background: var(--accent-subtle);
  color: var(--accent-muted);
  border: 1px solid color-mix(in srgb, var(--accent) 15%, transparent);
}

.portal-nav-card__icon svg { width: 1.25rem; height: 1.25rem; }

.portal-nav-card h2 {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  transition: color var(--transition);
}

.portal-nav-card:hover h2 { color: var(--accent-muted); }

.portal-nav-card p {
  margin-top: 0.375rem;
  font-size: 0.8125rem;
  line-height: 1.6;
  color: var(--muted-light);
}

.portal-nav-card__link {
  margin-top: auto;
  padding-top: 1rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--accent-muted);
}

.portal-sub-placeholder {
  padding: 1.5rem;
  color: var(--muted);
  font-size: 0.9375rem;
  line-height: 1.6;
}

/* ——— Portal dashboard (översikt) ——— */
.portal-dashboard {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

@media (min-width: 768px) {
  .portal-dashboard { gap: 1.5rem; }
}

.portal-dashboard__welcome {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem 1.25rem;
  padding: 1.125rem 1.25rem;
}

@media (min-width: 640px) {
  .portal-dashboard__welcome { padding: 1.25rem 1.5rem; }
}

.portal-dashboard__avatar {
  width: 3rem;
  height: 3rem;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  object-fit: cover;
  flex-shrink: 0;
}

.portal-dashboard__welcome-text {
  flex: 1;
  min-width: 12rem;
}

.portal-dashboard__greeting {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.portal-dashboard__meta {
  margin-top: 0.25rem;
  font-size: 0.8125rem;
  color: var(--muted-light);
}

.portal-dashboard__status-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.375rem;
  width: 100%;
}

@media (min-width: 768px) {
  .portal-dashboard__status-pills {
    width: auto;
    margin-left: auto;
  }
}

.portal-dashboard__pill {
  display: inline-flex;
  padding: 0.3rem 0.625rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-full);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-elevated) 50%, transparent);
}

.portal-dashboard__pill--active {
  color: var(--accent-muted);
  border-color: color-mix(in srgb, var(--accent) 28%, transparent);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
}

.portal-stats-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.875rem;
}

@media (min-width: 1024px) {
  .portal-stats-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
  }
}

.portal-stat-card {
  padding: 1rem 1.125rem;
}

@media (min-width: 640px) {
  .portal-stat-card { padding: 1.125rem 1.25rem; }
}

.portal-stat-card__label {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
}

.portal-stat-card__value {
  margin-top: 0.375rem;
  font-size: clamp(1.375rem, 3vw, 1.625rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}

.portal-stat-card__sub {
  margin-top: 0.25rem;
  font-size: 0.75rem;
  line-height: 1.45;
  color: var(--muted-light);
}

.portal-dashboard__panels {
  display: grid;
  gap: 1rem;
}

@media (min-width: 1024px) {
  .portal-dashboard__panels {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
  }
}

.portal-dashboard__panel {
  padding: 1.125rem 1.25rem;
}

@media (min-width: 640px) {
  .portal-dashboard__panel { padding: 1.25rem 1.5rem; }
}

.portal-dashboard__panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.portal-dashboard__panel-head h2 {
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.portal-dashboard__panel-link {
  font-size: 0.8125rem;
  font-weight: 500;
  white-space: nowrap;
}

.portal-dashboard__rep-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
  margin-top: 1rem;
}

.portal-dashboard__rep-stat {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  padding: 0.625rem 0.75rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--background) 35%, transparent);
}

.portal-dashboard__rep-stat-label {
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.portal-dashboard__rep-stat-value {
  font-size: 1.125rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

.portal-dashboard__panel-note {
  margin-top: 0.875rem;
  font-size: 0.8125rem;
  line-height: 1.55;
  color: var(--muted-light);
}

.portal-dashboard__alert {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem 1.25rem;
  border: 1px solid color-mix(in srgb, #fbbf24 28%, transparent);
  border-radius: var(--radius-xl);
  background:
    linear-gradient(135deg, color-mix(in srgb, #fbbf24 8%, transparent), transparent 55%),
    var(--card);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fbbf24 10%, transparent);
}

.portal-dashboard__alert::before {
  content: '';
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: var(--radius-md);
  background: color-mix(in srgb, #fbbf24 14%, transparent);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='1.5' stroke='%23fbbf24'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M12 9v3.75m-9.303 3.376c-.866 1.5.217 3.374 1.948 3.374h14.71c1.73 0 2.813-1.874 1.948-3.374L13.949 3.378c-.866-1.5-3.032-1.5-3.898 0L2.697 16.126zM12 15.75h.007v.008H12v-.008z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 1.125rem;
}

.portal-dashboard__alert-title {
  margin: 0 0 0.3rem;
  font-size: 0.875rem;
  font-weight: 700;
  color: #fbbf24;
}

.portal-dashboard__alert-text {
  margin: 0;
  font-size: 0.875rem;
  line-height: 1.55;
  color: var(--muted-light);
}

.portal-dashboard__alert-link {
  display: inline-block;
  margin-top: 0.625rem;
  font-size: 0.8125rem;
}

.portal-dashboard__roles {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}

.portal-dashboard__role {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 0.875rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--background) 30%, transparent);
  opacity: 0.72;
  transition: opacity var(--transition), border-color var(--transition);
}

.portal-dashboard__role--active {
  opacity: 1;
  border-color: color-mix(in srgb, var(--accent) 22%, transparent);
}

.portal-dashboard__role-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  flex-shrink: 0;
  border-radius: var(--radius-md);
  background: var(--accent-subtle);
  color: var(--accent-muted);
}

.portal-dashboard__role-icon svg {
  width: 1.125rem;
  height: 1.125rem;
}

.portal-dashboard__role-name {
  font-size: 0.875rem;
  font-weight: 600;
}

.portal-dashboard__role-desc {
  margin-top: 0.125rem;
  font-size: 0.75rem;
  line-height: 1.45;
  color: var(--muted-light);
}

.portal-dashboard__role .portal-status-badge {
  margin-left: auto;
  flex-shrink: 0;
}

.portal-dashboard__activity {
  padding: 1.125rem 1.25rem;
}

@media (min-width: 640px) {
  .portal-dashboard__activity { padding: 1.25rem 1.5rem; }
}

.portal-dashboard__activity-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.portal-dashboard__activity-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.25rem 1rem;
  align-items: center;
  padding: 0.75rem 0.875rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--background) 30%, transparent);
}

@media (min-width: 640px) {
  .portal-dashboard__activity-item {
    grid-template-columns: 1fr auto auto;
  }
}

.portal-dashboard__activity-title {
  font-size: 0.875rem;
  font-weight: 600;
}

.portal-dashboard__activity-desc {
  margin-top: 0.125rem;
  font-size: 0.75rem;
  color: var(--muted-light);
}

.portal-dashboard__activity-date {
  font-size: 0.75rem;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.portal-dashboard__activity-link {
  grid-column: 2;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--accent-muted);
  text-decoration: none;
}

@media (min-width: 640px) {
  .portal-dashboard__activity-link { grid-column: auto; }
}

.portal-dashboard__activity-empty {
  padding: 1.5rem 1rem;
  border: 1px dashed color-mix(in srgb, var(--foreground) 10%, transparent);
  border-radius: var(--radius-lg);
  text-align: center;
  font-size: 0.875rem;
  color: var(--muted-light);
}

/* ——— Admin ——— */
.admin-page .portal-page-header {
  max-width: 48rem;
}

.admin-applications-row {
  cursor: pointer;
  transition: background var(--transition);
}

.admin-applications-row:hover {
  background: color-mix(in srgb, var(--foreground) 3%, transparent);
}

/* ——— Admin application review page ——— */
.admin-review-page {
  padding-bottom: 2rem;
}

.admin-review-back {
  margin-bottom: 1.25rem;
}

.admin-review-back__link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--muted-light);
  text-decoration: none;
  transition: color var(--transition);
}

.admin-review-back__link:hover {
  color: var(--foreground);
}

.admin-review-state {
  padding: 3rem 1.5rem;
  text-align: center;
}

.admin-review-state--error {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}

.admin-review-state__text {
  margin: 0;
  color: var(--muted-light);
  font-size: 0.9375rem;
}

.admin-review-hero {
  display: grid;
  gap: 1.5rem;
  padding: 1.5rem;
  margin-bottom: 1.25rem;
}

@media (min-width: 768px) {
  .admin-review-hero {
    grid-template-columns: 1fr auto;
    align-items: start;
    padding: 1.75rem 2rem;
  }
}

.admin-review-hero__profile {
  display: flex;
  align-items: flex-start;
  gap: 1.125rem;
  min-width: 0;
}

.admin-review-hero__avatar {
  flex-shrink: 0;
  width: 4.5rem;
  height: 4.5rem;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  object-fit: cover;
}

.admin-review-hero__avatar--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, var(--accent) 12%, var(--background));
  color: var(--accent-muted);
  font-size: 1.125rem;
  font-weight: 700;
}

.admin-review-hero__identity {
  min-width: 0;
}

.admin-review-hero__title {
  margin: 0.25rem 0 0.375rem;
  font-size: clamp(1.25rem, 2.5vw, 1.625rem);
  font-weight: 700;
  line-height: 1.2;
}

.admin-review-hero__applicant {
  margin: 0;
  font-size: 0.9375rem;
  color: var(--muted-light);
}

.admin-review-hero__username {
  color: var(--muted);
}

.admin-review-hero__aside {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.admin-review-hero__badge {
  align-self: flex-start;
}

.admin-review-meta {
  display: grid;
  gap: 0.625rem;
  margin: 0;
}

@media (min-width: 768px) {
  .admin-review-meta {
    min-width: 14rem;
  }
}

.admin-review-meta__item {
  display: grid;
  gap: 0.15rem;
}

.admin-review-meta__item dt {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.admin-review-meta__item dd {
  margin: 0;
  font-size: 0.875rem;
  color: var(--foreground);
}

.admin-review-meta__code {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.8125rem;
  word-break: break-all;
}

.admin-review-grid {
  display: grid;
  gap: 1.25rem;
  margin-bottom: 1.25rem;
}

@media (min-width: 1024px) {
  .admin-review-grid {
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
    align-items: start;
  }
}

.admin-review-panel {
  padding: 1.25rem;
}

@media (min-width: 640px) {
  .admin-review-panel {
    padding: 1.5rem;
  }
}

.admin-review-panel__head {
  margin-bottom: 1.125rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--border);
}

.admin-review-panel__title {
  margin: 0 0 0.25rem;
  font-size: 1rem;
  font-weight: 600;
}

.admin-review-panel__desc {
  margin: 0;
  font-size: 0.8125rem;
  color: var(--muted);
}

.admin-review-answers {
  display: grid;
  gap: 0.875rem;
}

.admin-review-answers__empty {
  margin: 0;
  padding: 2rem 1rem;
  border: 1px dashed var(--border);
  border-radius: var(--radius-md);
  text-align: center;
  color: var(--muted);
  font-size: 0.875rem;
}

.admin-review-answer {
  padding: 1rem 1.125rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--background) 35%, transparent);
}

.admin-review-answer__label {
  margin: 0 0 0.5rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.admin-review-answer__value {
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--foreground);
  word-break: break-word;
  white-space: pre-wrap;
}

.admin-review-panel--chat .app-chat__messages {
  max-height: min(52vh, 28rem);
}

.admin-review-panel--chat .app-chat {
  min-height: 12rem;
}

.admin-review-bar {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1.125rem 1.25rem;
  border-color: color-mix(in srgb, #fbbf24 22%, var(--border));
  background: color-mix(in srgb, #fbbf24 5%, var(--surface-elevated));
}

@media (min-width: 640px) {
  .admin-review-bar {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 1.125rem 1.5rem;
  }
}

.admin-review-bar__hint {
  margin: 0;
  font-size: 0.875rem;
  color: var(--muted-light);
}

.admin-review-bar__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.625rem;
}

.admin-review-bar__default {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  width: 100%;
}

@media (min-width: 640px) {
  .admin-review-bar__default {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}

.admin-review-reject {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  width: 100%;
}

.admin-review-reject__head {
  display: grid;
  gap: 0.2rem;
}

.admin-review-reject__title {
  margin: 0;
  font-size: 0.9375rem;
  font-weight: 600;
}

.admin-review-reject__desc {
  margin: 0;
  font-size: 0.8125rem;
  color: var(--muted);
}

.admin-review-reject__input {
  width: 100%;
  min-height: 6.5rem;
  resize: vertical;
  padding: 0.75rem 0.875rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--background);
  color: var(--text);
  font: inherit;
  line-height: 1.5;
}

.admin-review-reject__input:focus {
  outline: 2px solid color-mix(in srgb, var(--danger, #ef4444) 35%, transparent);
  outline-offset: 1px;
  border-color: color-mix(in srgb, var(--danger, #ef4444) 30%, var(--border));
}

.admin-review-reject__actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.625rem;
}

.admin-review-reject__confirm {
  color: color-mix(in srgb, var(--danger, #ef4444) 85%, var(--text));
  border-color: color-mix(in srgb, var(--danger, #ef4444) 35%, var(--border));
}

.admin-review-rejection-notice {
  margin-bottom: 1.25rem;
  padding: 1rem 1.25rem;
  border-color: color-mix(in srgb, var(--danger, #ef4444) 22%, var(--border));
  background: color-mix(in srgb, var(--danger, #ef4444) 6%, var(--surface-elevated));
}

.admin-review-rejection-notice__label {
  margin: 0 0 0.375rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--danger, #ef4444) 75%, var(--muted));
}

.admin-review-rejection-notice__text {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.55;
  white-space: pre-wrap;
  word-break: break-word;
}

.admin-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1.25rem;
}

.admin-tabs__btn {
  position: relative;
  padding: 0.5rem 0.875rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--surface-elevated) 60%, transparent);
  color: var(--muted-light);
  font-size: 0.8125rem;
  font-weight: 500;
  font-family: inherit;
  cursor: pointer;
  transition: background var(--transition), color var(--transition), border-color var(--transition);
}

.admin-tabs__btn--badged {
  padding-right: 1.75rem;
}

.admin-tabs__btn-badge {
  position: absolute;
  top: -0.25rem;
  right: -0.125rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.125rem;
  height: 1.125rem;
  padding: 0 0.3rem;
  font-size: 0.625rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  color: #fff;
  border-radius: var(--radius-full);
  background: #ef4444;
  box-shadow: 0 0 0 2px var(--background);
  pointer-events: none;
}

.admin-tabs__btn:hover {
  color: var(--foreground);
  background: color-mix(in srgb, var(--foreground) 5%, transparent);
}

.admin-tabs__btn--active {
  color: var(--foreground);
  border-color: color-mix(in srgb, #fbbf24 35%, transparent);
  background: color-mix(in srgb, #fbbf24 10%, transparent);
}

.admin-search {
  margin-bottom: 1.25rem;
}

.admin-search__input {
  width: 100%;
  max-width: 28rem;
  padding: 0.625rem 0.875rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--background) 50%, transparent);
  color: var(--foreground);
  font-family: inherit;
  font-size: 0.875rem;
}

.admin-search__input:focus {
  outline: none;
  border-color: color-mix(in srgb, var(--accent) 40%, transparent);
}

.admin-table-wrap {
  margin-top: 0;
}

.admin-user-cell {
  display: flex;
  align-items: center;
  gap: 0.625rem;
}

.admin-user-cell__avatar {
  width: 2rem;
  height: 2rem;
  border-radius: var(--radius-md);
  object-fit: cover;
  flex-shrink: 0;
}

.admin-user-cell__name {
  display: block;
  font-weight: 600;
  font-size: 0.875rem;
}

.admin-user-cell__sub {
  display: block;
  font-size: 0.75rem;
  color: var(--muted);
}

.admin-code {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.75rem;
  color: var(--accent-muted);
}

.admin-muted {
  color: var(--muted);
  font-size: 0.8125rem;
}

.admin-modal {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.admin-modal[hidden] {
  display: none;
}

body.admin-modal-open {
  overflow: hidden;
}

.admin-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  backdrop-filter: blur(4px);
}

.admin-modal__dialog {
  position: relative;
  width: min(100%, 36rem);
  max-height: min(90vh, 40rem);
  overflow: auto;
  padding: 0;
}

.admin-modal__dialog--wide {
  width: min(100%, 44rem);
  max-height: min(92vh, 52rem);
}

.admin-modal__head-main {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.75rem 1rem;
  min-width: 0;
}

.admin-modal__edit-link {
  font-size: 0.8125rem;
  font-weight: 500;
}

.admin-modal__body--chat {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.admin-detail-meta--compact {
  margin-bottom: 0.25rem;
}

.app-chat {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  min-height: 0;
}

.app-chat__loading,
.app-chat__error,
.app-chat__empty {
  margin: 0;
  padding: 0.875rem 1rem;
  border: 1px dashed var(--border);
  border-radius: var(--radius-md);
  color: var(--muted);
  font-size: 0.875rem;
  text-align: center;
}

.app-chat__error {
  border-color: color-mix(in srgb, var(--danger, #ef4444) 35%, var(--border));
  color: color-mix(in srgb, var(--danger, #ef4444) 80%, var(--text));
}

.app-chat__messages {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  max-height: min(40vh, 18rem);
  overflow-y: auto;
  padding: 0.25rem 0.125rem;
}

.app-chat__message {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  max-width: 88%;
  align-self: flex-start;
}

.app-chat__message--mine {
  align-self: flex-end;
}

.app-chat__message-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  font-size: 0.75rem;
}

.app-chat__message--mine .app-chat__message-head {
  justify-content: flex-end;
}

.app-chat__author {
  font-weight: 600;
  color: var(--text);
}

.app-chat__role {
  color: var(--muted);
}

.app-chat__time {
  color: var(--muted-light);
}

.app-chat__bubble {
  padding: 0.625rem 0.875rem;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--background) 40%, transparent);
  font-size: 0.875rem;
  line-height: 1.5;
  word-break: break-word;
}

.app-chat__message--mine .app-chat__bubble {
  background: color-mix(in srgb, var(--accent) 14%, var(--background));
  border-color: color-mix(in srgb, var(--accent) 28%, var(--border));
}

.app-chat__message--staff:not(.app-chat__message--mine) .app-chat__bubble {
  background: color-mix(in srgb, var(--accent) 8%, var(--background));
  border-color: color-mix(in srgb, var(--accent) 18%, var(--border));
}

.app-chat__composer {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding-top: 0.25rem;
  border-top: 1px solid var(--border);
}

.app-chat__input {
  width: 100%;
  min-height: 4.5rem;
  resize: vertical;
  padding: 0.75rem 0.875rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--background);
  color: var(--text);
  font: inherit;
  line-height: 1.45;
}

.app-chat__input:focus {
  outline: 2px solid color-mix(in srgb, var(--accent) 45%, transparent);
  outline-offset: 1px;
  border-color: color-mix(in srgb, var(--accent) 35%, var(--border));
}

.app-chat__composer-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.app-chat__hint {
  color: var(--muted);
  font-size: 0.75rem;
}

.admin-modal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.125rem 1.25rem;
  border-bottom: 1px solid var(--border);
}

.admin-modal__head h2 {
  font-size: 1rem;
  font-weight: 600;
}

.admin-modal__close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--muted-light);
  font-size: 1.25rem;
  line-height: 1;
  cursor: pointer;
}

.admin-modal__body {
  padding: 1.25rem;
}

.admin-modal__actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.625rem;
  padding: 1rem 1.25rem;
  border-top: 1px solid var(--border);
}

.admin-detail-meta,
.admin-detail-answers {
  display: grid;
  gap: 0.5rem;
}

.admin-detail-row {
  display: grid;
  gap: 0.25rem;
  padding: 0.625rem 0.75rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--background) 35%, transparent);
}

@media (min-width: 640px) {
  .admin-detail-row {
    grid-template-columns: 8rem 1fr;
    align-items: baseline;
  }
}

.admin-detail-row dt {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.admin-detail-row dd {
  font-size: 0.875rem;
  word-break: break-word;
}

.admin-detail-section-title {
  margin: 1.25rem 0 0.75rem;
  font-size: 0.875rem;
  font-weight: 600;
}

.admin-member-detail__head {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
}

.admin-member-detail__avatar {
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
}

.admin-member-detail__name {
  font-size: 1.0625rem;
  font-weight: 700;
}

.admin-member-detail__sub {
  font-size: 0.8125rem;
  color: var(--muted);
}

.admin-member-detail__roles {
  display: flex;
  flex-wrap: wrap;
  gap: 0.375rem;
}

.admin-member-detail__apps {
  list-style: none;
  display: grid;
  gap: 0.375rem;
  font-size: 0.875rem;
  color: var(--muted-light);
}

.admin-form-grid {
  display: grid;
  gap: 0.875rem;
}

@media (min-width: 640px) {
  .admin-form-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.admin-form-field {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--muted-light);
}

.admin-form-field input {
  padding: 0.625rem 0.75rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--background) 50%, transparent);
  color: var(--foreground);
  font-family: inherit;
  font-size: 0.875rem;
}

.admin-form-hint {
  margin-top: 0.75rem;
  font-size: 0.75rem;
  line-height: 1.5;
  color: var(--muted);
}

.admin-points-form .admin-modal__actions {
  border-top: none;
  padding-top: 0;
  padding-bottom: 1.25rem;
}

.admin-points-form__player {
  margin-bottom: 1rem;
  font-weight: 600;
}

.admin-page-toolbar {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 1.25rem;
}

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

@media (min-width: 640px) {
  .admin-form-grid--2 {
    grid-template-columns: repeat(2, 1fr);
  }
}

.admin-form-field--full {
  grid-column: 1 / -1;
}

.admin-form-field--checkbox {
  flex-direction: row;
  align-items: center;
  gap: 0.5rem;
}

.admin-form-field select {
  width: 100%;
}

.admin-form-fields-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 1.25rem;
}

.admin-field-row {
  padding: 1rem;
  margin-bottom: 0.75rem;
}

.admin-field-row__remove {
  margin-top: 0.75rem;
}

.btn--danger {
  color: #fca5a5;
  border-color: color-mix(in srgb, #ef4444 30%, transparent);
}

.btn--danger:hover {
  color: #fecaca;
  background: color-mix(in srgb, #ef4444 12%, transparent);
}

.forms-list-empty {
  grid-column: 1 / -1;
  padding: 2rem 1rem;
  text-align: center;
  color: var(--muted-light);
  font-size: 0.9375rem;
}

.apply-form-empty {
  padding: 2rem 1.5rem;
  text-align: center;
  color: var(--muted-light);
  font-size: 0.9375rem;
  line-height: 1.6;
}

/* ——— Header auth (logged in) ——— */
.header-auth {
  display: flex;
  align-items: center;
  gap: 0.375rem;
}

@media (min-width: 640px) {
  .header-auth { gap: 0.5rem; }
}

.notif-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-elevated) 60%, transparent);
  color: var(--muted);
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
}

.notif-btn--badged {
  color: var(--foreground);
}

.notif-btn__badge {
  position: absolute;
  top: -0.25rem;
  right: -0.125rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.125rem;
  height: 1.125rem;
  padding: 0 0.3rem;
  font-size: 0.625rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  color: #fff;
  border-radius: var(--radius-full);
  background: #ef4444;
  box-shadow: 0 0 0 2px var(--background);
  pointer-events: none;
}

.notif-btn:hover {
  background: rgba(255, 255, 255, 0.05);
  color: var(--foreground);
}

.notif-btn svg { width: 1.25rem; height: 1.25rem; }

.notif-menu {
  position: relative;
  z-index: 50;
}

.notif-btn[aria-expanded="true"] {
  background: rgba(255, 255, 255, 0.05);
  color: var(--foreground);
}

.notif-menu__dropdown {
  position: absolute;
  top: calc(100% + 0.375rem);
  right: 0;
  width: 18rem;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface-elevated);
  box-shadow: var(--shadow-lg);
}

.notif-menu__header {
  padding: 0.875rem 1rem;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--foreground);
}

.notif-menu__body {
  max-height: 18rem;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  padding: 0.5rem;
}

.notif-menu__empty {
  margin: 0;
  padding: 1rem 0.75rem;
  text-align: center;
  font-size: 0.875rem;
  line-height: 1.55;
  color: var(--muted);
}

.notif-menu__item {
  display: block;
  padding: 0.625rem 0.75rem;
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background var(--transition);
}

.notif-menu__item--unread {
  background: color-mix(in srgb, var(--accent) 8%, transparent);
}

.notif-menu__item-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
}

.notif-menu__item + .notif-menu__item {
  margin-top: 0;
}

.notif-menu__item:hover {
  background: rgba(255, 255, 255, 0.05);
}

.notif-menu__item-title {
  display: block;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--foreground);
}

.notif-menu__item-time {
  flex-shrink: 0;
  font-size: 0.6875rem;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.notif-menu__item-text {
  display: block;
  margin-top: 0.125rem;
  font-size: 0.75rem;
  line-height: 1.45;
  color: var(--muted);
}

.notif-menu__footer {
  padding: 0.75rem 1rem;
  border-top: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
  text-align: center;
}

.notif-menu__footer-link {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--foreground);
  text-decoration: none;
  transition: color var(--transition);
}

.notif-menu__footer-link:hover {
  color: var(--accent-muted);
}

.header-admin-menu {
  position: relative;
  z-index: 50;
}

.header-admin-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-elevated) 60%, transparent);
  color: var(--muted);
  cursor: pointer;
  transition: background var(--transition), color var(--transition), border-color var(--transition);
}

.header-admin-btn:hover,
.header-admin-btn[aria-expanded="true"] {
  background: rgba(255, 255, 255, 0.05);
  color: var(--foreground);
}

.header-admin-btn--active {
  color: var(--foreground);
  border-color: color-mix(in srgb, var(--foreground) 12%, var(--border));
  background: color-mix(in srgb, var(--foreground) 8%, var(--surface-elevated));
}

.header-admin-btn--badged {
  color: var(--foreground);
}

.header-admin-btn svg {
  width: 1.25rem;
  height: 1.25rem;
}

.header-admin-btn__badge {
  position: absolute;
  top: -0.25rem;
  right: -0.125rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.125rem;
  height: 1.125rem;
  padding: 0 0.3rem;
  font-size: 0.625rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  color: #fff;
  border-radius: var(--radius-full);
  background: #ef4444;
  box-shadow: 0 0 0 2px var(--background);
  pointer-events: none;
}

.header-admin-menu__dropdown {
  position: absolute;
  top: calc(100% + 0.375rem);
  right: 0;
  z-index: 60;
  min-width: 15rem;
  padding: 0.375rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface-elevated);
  box-shadow: var(--shadow-lg);
}

.header-admin-menu__dropdown[hidden] {
  display: none;
}

.header-admin-item {
  position: relative;
  display: block;
  padding: 0.625rem 0.75rem;
  border-radius: 0.5rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: color-mix(in srgb, var(--foreground) 68%, var(--muted));
  text-decoration: none;
  transition: background 160ms ease, color 160ms ease;
}

.header-admin-item--badged {
  padding-right: 2.25rem;
}

.header-admin-item__badge {
  position: absolute;
  top: 0.4375rem;
  right: 0.5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.125rem;
  height: 1.125rem;
  padding: 0 0.3rem;
  font-size: 0.625rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  color: #fff;
  border-radius: var(--radius-full);
  background: #ef4444;
  box-shadow: 0 0 0 2px var(--surface-elevated);
  pointer-events: none;
}

.header-admin-item:hover:not(.header-admin-item--active) {
  color: var(--foreground);
  background: color-mix(in srgb, var(--foreground) 5%, var(--surface-elevated));
}

.header-admin-item--active {
  color: var(--foreground);
  font-weight: 600;
  background: color-mix(in srgb, var(--foreground) 8%, var(--surface-elevated));
  cursor: default;
}

.header-admin-item--active:hover {
  color: var(--foreground);
  background: color-mix(in srgb, var(--foreground) 8%, var(--surface-elevated));
}

.profile-menu {
  position: relative;
  z-index: 50;
}

.profile-menu__trigger {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.25rem;
  border: none;
  border-radius: var(--radius-md);
  background: transparent;
  color: inherit;
  cursor: pointer;
  text-align: left;
  transition: background var(--transition);
}

@media (min-width: 768px) {
  .profile-menu__trigger {
    gap: 0.625rem;
    padding: 0.25rem 0.375rem;
    align-items: flex-start;
  }
}

.profile-menu__trigger:hover { background: var(--hover-overlay); }

.profile-menu__trigger[aria-expanded="true"] {
  background: var(--hover-overlay);
}

.profile-menu__avatar {
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 50%;
  border: 1px solid var(--border);
  object-fit: cover;
  flex-shrink: 0;
}

@media (min-width: 768px) {
  .profile-menu__avatar { width: 2.5rem; height: 2.5rem; }
}

.profile-menu__info {
  display: none;
  flex-direction: column;
  min-width: 0;
  max-width: 8rem;
}

@media (min-width: 768px) {
  .profile-menu__info { display: flex; }
}

.profile-menu__name-row {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  min-width: 0;
}

.profile-menu__name {
  font-size: 0.875rem;
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.profile-menu__badge {
  margin-top: 0.25rem;
  align-self: flex-start;
  padding: 0 0.375rem;
  border: 1px solid color-mix(in srgb, var(--accent) 28%, transparent);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  font-size: 0.625rem;
  font-weight: 500;
  color: var(--accent-muted);
  line-height: 1.4;
}

.profile-menu__chevron {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  color: var(--muted);
  transition: transform var(--transition);
}

.profile-menu__trigger[aria-expanded="true"] .profile-menu__chevron {
  transform: rotate(180deg);
}

.profile-menu__chevron--desktop { display: none; }

@media (min-width: 768px) {
  .profile-menu__chevron--desktop { display: block; }
  .profile-menu__chevron--mobile { display: none; }
}

.profile-menu__dropdown {
  position: absolute;
  top: calc(100% + 0.375rem);
  right: 0;
  width: 18.5rem;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface-elevated);
  box-shadow: var(--shadow-lg);
}

.profile-menu__panel {
  padding: 1rem 1rem 0.875rem;
}

.profile-menu__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.profile-menu__header .profile-menu__eyebrow {
  flex: 1;
  min-width: 0;
}

.theme-toggle {
  display: inline-flex;
  flex-shrink: 0;
  padding: 0.1875rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-full);
  background: var(--surface-elevated);
}

.theme-toggle__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.5rem;
  padding: 0.3125rem 0.625rem;
  border: none;
  border-radius: var(--radius-full);
  background: transparent;
  color: var(--muted);
  font: inherit;
  font-size: 0.6875rem;
  font-weight: 600;
  line-height: 1;
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
}

.theme-toggle__btn:hover {
  color: var(--foreground);
  background: var(--hover-overlay);
}

.theme-toggle__btn--active {
  background: var(--accent-subtle);
  color: var(--accent-muted);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 22%, transparent);
}

html[data-theme="light"] .theme-toggle__btn--active {
  color: var(--accent);
}

.profile-menu__eyebrow {
  margin: 0;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent-muted);
}

.profile-menu__eyebrow::after {
  content: "";
  display: block;
  width: 2.75rem;
  height: 2px;
  margin-top: 0.375rem;
  border-radius: 9999px;
  background: var(--accent);
}

.profile-menu__summary {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  margin-top: 1rem;
}

.profile-menu__summary-avatar {
  width: 3rem;
  height: 3rem;
  flex-shrink: 0;
  border-radius: 50%;
  border: 1px solid var(--border);
  object-fit: cover;
}

.profile-menu__summary-text {
  min-width: 0;
  flex: 1;
}

.profile-menu__summary-name {
  margin: 0;
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--foreground);
}

.profile-menu__summary-handle,
.profile-menu__summary-role {
  margin: 0.125rem 0 0;
  font-size: 0.8125rem;
  line-height: 1.4;
  color: var(--muted);
}

.profile-menu__since {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  margin: 0.875rem 0 0;
  font-size: 0.75rem;
  line-height: 1.4;
}

.profile-menu__since-label {
  color: var(--muted);
}

.profile-menu__since-value {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--foreground);
}

.profile-menu__since-icon {
  width: 0.875rem;
  height: 0.875rem;
  flex-shrink: 0;
  color: var(--accent-muted);
}

.profile-menu__nav {
  display: flex;
  flex-direction: column;
  margin-top: 1rem;
  padding-top: 0.25rem;
  border-top: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
}

.profile-menu__nav a {
  display: block;
  padding: 0.625rem 0;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--foreground);
  text-decoration: none;
  transition: color var(--transition);
}

.profile-menu__nav a:hover {
  color: var(--accent-muted);
}

.profile-menu__divider {
  margin: 0.375rem 0;
  border: none;
  border-top: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
}

.profile-menu__logout-wrap {
  margin-top: 0.75rem;
  padding-top: 0.75rem;
  border-top: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
}

.profile-menu__logout {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.625rem 1rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: transparent;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--foreground);
  text-decoration: none;
  transition: background var(--transition), border-color var(--transition);
}

.profile-menu__logout svg {
  width: 1.125rem;
  height: 1.125rem;
  flex-shrink: 0;
}

.profile-menu__logout:hover {
  background: var(--hover-overlay);
  border-color: color-mix(in srgb, var(--foreground) 14%, transparent);
}

/* ——— Om mig ——— */
.portal-about-page .site-breadcrumb {
  margin-bottom: var(--space-5);
}

.portal-page-header--compact {
  margin-bottom: var(--space-8);
  padding-bottom: 0;
  border-bottom: none;
}

.portal-about-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  padding-bottom: var(--space-12);
}

@media (min-width: 768px) {
  .portal-about-wrap {
    gap: var(--space-8);
  }
}

/* Profile hero */
.portal-about-hero {
  position: relative;
  overflow: hidden;
}

.portal-about-hero__glow {
  pointer-events: none;
  position: absolute;
  inset: 0;
  opacity: 0.6;
  background:
    radial-gradient(ellipse 80% 90% at 0% -30%, var(--accent-glow), transparent 58%),
    radial-gradient(ellipse 50% 60% at 100% 100%, color-mix(in srgb, var(--accent) 8%, transparent), transparent 55%);
}

.portal-about-hero__inner {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  padding: clamp(1.5rem, 3vw, 2rem);
}

@media (min-width: 768px) {
  .portal-about-hero__inner {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-8);
    padding: clamp(1.75rem, 3vw, 2.25rem) clamp(1.75rem, 3vw, 2.5rem);
  }
}

.portal-about-hero__profile {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
  text-align: center;
}

@media (min-width: 640px) {
  .portal-about-hero__profile {
    flex-direction: row;
    align-items: center;
    text-align: left;
  }
}

.portal-about-hero__avatar-wrap {
  flex-shrink: 0;
  padding: 3px;
  border-radius: calc(var(--radius-xl) + 3px);
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--accent) 55%, transparent),
    color-mix(in srgb, var(--foreground) 12%, transparent)
  );
  box-shadow: 0 16px 48px -20px color-mix(in srgb, var(--accent) 55%, transparent);
}

.portal-about-hero__avatar {
  display: block;
  width: 5.5rem;
  height: 5.5rem;
  border-radius: var(--radius-xl);
  border: 2px solid var(--background);
  object-fit: cover;
}

@media (min-width: 768px) {
  .portal-about-hero__avatar {
    width: 6rem;
    height: 6rem;
  }
}

.portal-about-hero__name {
  font-size: clamp(1.375rem, 3.5vw, 1.75rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.2;
}

.portal-about-hero__handle {
  margin-top: 0.25rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--muted);
}

.portal-about-hero__pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.375rem;
  margin-top: var(--space-3);
}

@media (min-width: 640px) {
  .portal-about-hero__pills {
    justify-content: flex-start;
  }
}

.portal-about-hero__nav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
}

@media (min-width: 768px) {
  .portal-about-hero__nav {
    flex-direction: column;
    align-items: stretch;
    min-width: 11rem;
  }
}

.portal-about-hero__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.625rem 1rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--surface-elevated) 45%, transparent);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--muted-light);
  text-decoration: none;
  transition: color var(--transition), background var(--transition), border-color var(--transition);
}

.portal-about-hero__link:hover {
  color: var(--foreground);
  border-color: color-mix(in srgb, var(--accent) 28%, transparent);
  background: color-mix(in srgb, var(--accent) 8%, var(--surface-elevated));
}

/* Content grid */
.portal-about-grid {
  display: grid;
  gap: var(--space-6);
}

@media (min-width: 1024px) {
  .portal-about-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-6);
    align-items: stretch;
  }
}

.portal-about-panel {
  padding: clamp(1.25rem, 2.5vw, 1.75rem);
}

.portal-about-panel__head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-5);
}

.portal-about-panel__title {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.portal-about-panel__desc {
  margin-top: 0.375rem;
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--muted-light);
}

.portal-about-panel__link {
  flex-shrink: 0;
  font-size: 0.8125rem;
  font-weight: 600;
}

/* Account facts */
.portal-about-facts {
  display: grid;
  gap: var(--space-3);
  margin-top: var(--space-5);
}

@media (min-width: 640px) {
  .portal-about-facts {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
  }
}

.portal-about-facts__item {
  padding: var(--space-4) var(--space-5);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--surface-elevated) 35%, transparent);
}

.portal-about-facts__item dt {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
}

.portal-about-facts__item dd {
  margin-top: 0.375rem;
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.45;
  word-break: break-word;
}

.portal-about-facts__item code {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.8125rem;
  padding: 0.2rem 0.45rem;
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--accent-muted);
}

.portal-about-facts__status--muted {
  color: var(--muted);
  font-weight: 500;
}

/* Reputation panel */
.portal-about-reputation {
  display: flex;
  flex-direction: column;
}

.portal-about-reputation__head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  margin-top: var(--space-5);
}

.portal-about-reputation__label {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.portal-about-reputation__level {
  margin-top: 0.25rem;
  font-size: clamp(1.5rem, 3vw, 1.875rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.15;
}

.portal-about-reputation__stats {
  display: flex;
  gap: var(--space-6);
  font-variant-numeric: tabular-nums;
}

.portal-about-reputation__stat {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.125rem;
}

.portal-about-reputation__stat-value {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--foreground);
}

.portal-about-reputation__stat-label {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.portal-about-reputation .reputation-bar--lg {
  margin-top: var(--space-5);
}

.portal-about-reputation__note {
  margin-top: var(--space-4);
  font-size: 0.8125rem;
  line-height: 1.6;
  color: var(--muted-light);
}

.portal-about-reputation__link {
  margin-top: var(--space-4);
  font-size: 0.8125rem;
  font-weight: 600;
}

/* Applications list */
.portal-about-applications .portal-about-panel__title {
  font-size: 1rem;
  letter-spacing: -0.01em;
  text-transform: none;
  color: var(--foreground);
}

.portal-about-apps {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  list-style: none;
  margin: 0;
  padding: 0;
}

.portal-about-apps__item {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--surface-elevated) 35%, transparent);
  transition: border-color var(--transition), background var(--transition);
}

.portal-about-apps__item:hover {
  border-color: color-mix(in srgb, var(--accent) 22%, transparent);
  background: color-mix(in srgb, var(--accent) 4%, var(--surface-elevated));
}

.portal-about-apps__title {
  font-size: 0.9375rem;
  font-weight: 600;
}

.portal-about-apps__meta {
  margin-top: 0.125rem;
  font-size: 0.75rem;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}

.portal-about-apps__action {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--accent-muted);
  text-decoration: none;
  white-space: nowrap;
  transition: color var(--transition);
}

.portal-about-apps__action:hover {
  color: var(--foreground);
}

@media (max-width: 639px) {
  .portal-about-apps__item {
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
  }

  .portal-about-apps__action {
    grid-column: 2;
    grid-row: 1 / span 2;
    align-self: center;
  }
}

.reputation-panel {
  margin-top: 2rem;
  width: 100%;
  padding: 1.25rem 1.375rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background: color-mix(in srgb, var(--surface-elevated) 45%, transparent);
}

.reputation-panel__head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.reputation-panel__title {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}

.reputation-panel__desc {
  margin-top: 0.25rem;
  max-width: 28rem;
  font-size: 0.75rem;
  line-height: 1.55;
  color: var(--muted);
}

.reputation-panel__desc strong {
  font-weight: 500;
  color: color-mix(in srgb, var(--foreground) 75%, var(--muted));
}

.reputation-panel__stats {
  display: flex;
  flex-shrink: 0;
  flex-wrap: wrap;
  gap: 1rem;
  font-variant-numeric: tabular-nums;
}

.reputation-panel__stat {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--foreground);
}

.reputation-panel__stat-label {
  margin-left: 0.25rem;
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--muted);
}

.reputation-panel__footnote {
  margin-top: 0.5rem;
  font-size: 0.6875rem;
  line-height: 1.45;
  color: var(--muted);
}

.reputation-bar--lg .reputation-bar__track {
  height: 0.75rem;
  margin-top: 0.75rem;
}

.reputation-bar__fill--excellent {
  background: #10b981;
  box-shadow: 0 0 14px rgba(16, 185, 129, 0.35);
}

.reputation-bar__fill--good {
  background: #84cc16;
  box-shadow: 0 0 14px rgba(132, 204, 22, 0.28);
}

.reputation-bar__fill--warning {
  background: #f59e0b;
  box-shadow: 0 0 14px rgba(245, 158, 11, 0.3);
}

.reputation-bar__fill--danger {
  background: #ef4444;
  box-shadow: 0 0 14px rgba(239, 68, 68, 0.35);
}

.reputation-bar__tooltip--above {
  left: 50%;
  bottom: calc(100% + 0.5rem);
  top: auto;
  transform: translateX(-50%);
  text-align: center;
}


.portal-empty-state {
  padding: 2rem 1.25rem;
  border: 1px dashed color-mix(in srgb, var(--foreground) 10%, transparent);
  border-radius: var(--radius-xl);
  background: color-mix(in srgb, var(--surface-elevated) 35%, transparent);
  text-align: center;
  font-size: 0.875rem;
  line-height: 1.65;
  color: var(--muted-light);
}

/* ——— Mina ansökningar ——— */
.portal-applications-intro {
  font-size: 0.9375rem;
  line-height: 1.65;
  color: var(--muted-light);
}

.portal-applications-table-wrap {
  margin-top: 2.5rem;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--foreground) 7%, transparent);
  border-radius: var(--radius-xl);
  background: color-mix(in srgb, var(--surface-elevated) 88%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--foreground) 5%, transparent);
}

@media (min-width: 768px) {
  .portal-applications-table-wrap { margin-top: 2.5rem; }
}

.portal-applications-table-scroll {
  overflow-x: auto;
}

.portal-applications-table {
  width: 100%;
  min-width: 35rem;
  border-collapse: collapse;
  text-align: left;
  font-size: 0.875rem;
}

.portal-applications-table thead tr {
  border-bottom: 1px solid color-mix(in srgb, var(--foreground) 8%, transparent);
  background: color-mix(in srgb, var(--foreground) 4%, transparent);
}

.portal-applications-table th {
  padding: 0.75rem 1rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}

.portal-applications-table td {
  padding: 0.75rem 1rem;
  vertical-align: middle;
  border-bottom: 1px solid color-mix(in srgb, var(--foreground) 5%, transparent);
}

.portal-applications-table tbody tr:last-child td {
  border-bottom: none;
}

.portal-applications-table__col--sm {
  display: none;
}

@media (min-width: 640px) {
  .portal-applications-table__col--sm { display: table-cell; }
}

.portal-applications-table__col--md {
  display: none;
}

@media (min-width: 768px) {
  .portal-applications-table__col--md { display: table-cell; }
}

.portal-applications-table__col--action {
  text-align: right;
}

.portal-applications-table__col--status {
  min-width: 8rem;
}

.portal-applications-rejection {
  margin: 0.5rem 0 0;
  font-size: 0.75rem;
  line-height: 1.45;
  color: var(--muted-light);
}

.portal-applications-rejection__label {
  font-weight: 600;
  color: color-mix(in srgb, var(--danger, #ef4444) 70%, var(--muted));
}

.portal-rejection-notice {
  margin-bottom: 1rem;
  padding: 0.875rem 1rem;
  border: 1px solid color-mix(in srgb, var(--danger, #ef4444) 22%, var(--border));
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--danger, #ef4444) 6%, var(--background));
}

.portal-rejection-notice__label {
  margin: 0 0 0.35rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--danger, #ef4444) 75%, var(--muted));
}

.portal-rejection-notice__text {
  margin: 0;
  font-size: 0.875rem;
  line-height: 1.5;
  color: var(--foreground);
  white-space: pre-wrap;
  word-break: break-word;
}

.portal-applications-table__history-btn {
  display: inline-flex;
  align-items: center;
  padding: 0.3125rem 0.75rem;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: normal;
  text-transform: none;
  color: var(--foreground);
  text-decoration: none;
  white-space: nowrap;
  border: 1px solid color-mix(in srgb, var(--foreground) 12%, transparent);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--foreground) 4%, transparent);
  transition: background var(--transition), border-color var(--transition), color var(--transition);
}

.portal-applications-table__history-btn:hover {
  color: var(--foreground);
  background: color-mix(in srgb, var(--foreground) 8%, transparent);
  border-color: color-mix(in srgb, var(--foreground) 18%, transparent);
}

.portal-applications-table__empty td {
  padding: 3rem 1.5rem;
  text-align: center;
  font-size: 0.9375rem;
  line-height: 1.65;
  color: var(--muted-light);
}

.portal-applications-table__row {
  transition: background var(--transition);
}

.portal-applications-table__row:hover {
  background: color-mix(in srgb, var(--foreground) 3%, transparent);
}

.portal-applications-table__category {
  font-weight: 500;
  color: var(--foreground);
}

.portal-applications-table__action {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--accent-muted);
  text-decoration: none;
  transition: color var(--transition);
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  font: inherit;
}

.portal-applications-table__action:hover {
  color: var(--foreground);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.portal-status-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.5rem;
  border-radius: var(--radius-sm);
  font-size: 0.75rem;
  font-weight: 600;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--surface-elevated) 80%, transparent);
  color: var(--muted);
}

.portal-status-badge--pending {
  color: #fbbf24;
  border-color: color-mix(in srgb, #fbbf24 25%, transparent);
  background: color-mix(in srgb, #fbbf24 10%, transparent);
}

.portal-status-badge--approved {
  color: #34d399;
  border-color: color-mix(in srgb, #34d399 25%, transparent);
  background: color-mix(in srgb, #34d399 10%, transparent);
}

.portal-status-badge--rejected {
  color: #f87171;
  border-color: color-mix(in srgb, #f87171 25%, transparent);
  background: color-mix(in srgb, #f87171 10%, transparent);
}

/* ——— Historik ——— */
.portal-history-page {
  padding-inline: 0;
}

.portal-history-empty {
  margin-top: 1rem;
  padding: 2.5rem 1.5rem;
  border: 1px dashed color-mix(in srgb, var(--foreground) 10%, transparent);
  border-radius: var(--radius-xl);
  background: color-mix(in srgb, var(--surface-elevated) 35%, transparent);
  font-size: 0.9375rem;
  line-height: 1.7;
  color: var(--muted-light);
  text-align: center;
}

.portal-history-content {
  margin-top: clamp(2rem, 4vw, 2.75rem);
}

.portal-history-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.625rem;
  margin-bottom: 1.5rem;
}

.portal-history-tabs__btn {
  padding: 0.5rem 0.875rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-elevated) 60%, transparent);
  color: var(--muted);
  font-size: 0.8125rem;
  font-weight: 500;
  cursor: pointer;
  transition: background var(--transition), color var(--transition), border-color var(--transition);
}

.portal-history-tabs__btn:hover {
  color: var(--foreground);
  background: color-mix(in srgb, var(--foreground) 5%, transparent);
}

.portal-history-tabs__btn--active {
  color: var(--foreground);
  border-color: color-mix(in srgb, var(--accent) 35%, transparent);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
}

.portal-history-table-wrap {
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--foreground) 7%, transparent);
  border-radius: var(--radius-xl);
  background: color-mix(in srgb, var(--surface-elevated) 88%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--foreground) 5%, transparent);
}

.portal-history-table-scroll {
  max-height: min(32rem, 70vh);
  overflow: auto;
}

.portal-history-table {
  width: 100%;
  min-width: 36rem;
  border-collapse: collapse;
  text-align: left;
  font-size: 0.875rem;
}

.portal-history-table thead {
  position: sticky;
  top: 0;
  z-index: 1;
}

.portal-history-table thead tr {
  border-bottom: 1px solid color-mix(in srgb, var(--foreground) 8%, transparent);
  background: color-mix(in srgb, var(--surface-elevated) 96%, transparent);
  backdrop-filter: blur(8px);
}

.portal-history-table th {
  padding: 0.75rem 1rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}

.portal-history-table td {
  padding: 0.75rem 1rem;
  vertical-align: top;
  border-bottom: 1px solid color-mix(in srgb, var(--foreground) 5%, transparent);
}

.portal-history-table tbody tr:last-child td {
  border-bottom: none;
}

.portal-history-table tbody tr:hover {
  background: color-mix(in srgb, var(--foreground) 3%, transparent);
}

.portal-history-table__date {
  width: 8.5rem;
  flex-shrink: 0;
  font-variant-numeric: tabular-nums;
  color: var(--muted);
  white-space: nowrap;
}

.portal-history-table__title {
  width: 28%;
  font-weight: 500;
  color: var(--foreground);
}

.portal-history-table__desc {
  color: var(--muted);
  line-height: 1.55;
}

.portal-history-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 1.25rem;
}

.portal-history-pagination__btn {
  padding: 0.5rem 0.875rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-elevated) 70%, transparent);
  color: var(--foreground);
  font-size: 0.8125rem;
  font-weight: 500;
  cursor: pointer;
  transition: background var(--transition);
}

.portal-history-pagination__btn:hover:not(:disabled) {
  background: color-mix(in srgb, var(--foreground) 6%, transparent);
}

.portal-history-pagination__btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.portal-history-pagination__info {
  font-size: 0.8125rem;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}

/* ——— Min status ——— */
.portal-status-page {
  padding-inline: 0;
}

.portal-status-sections {
  display: flex;
  flex-direction: column;
  gap: clamp(2rem, 4vw, 2.75rem);
  margin-top: 0.5rem;
}

.portal-status-reputation {
  padding: clamp(1.25rem, 2.5vw, 1.625rem) clamp(1.25rem, 2.5vw, 1.75rem);
}

.portal-status-reputation__head {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

@media (min-width: 1024px) {
  .portal-status-reputation__head {
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
  }
}

.portal-status-reputation__label {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-muted);
}

.portal-status-reputation__level {
  margin-top: 0.25rem;
  font-size: clamp(1.625rem, 4vw, 1.875rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  transition: color var(--transition);
}

.portal-status-reputation__level--excellent { color: #34d399; }
.portal-status-reputation__level--good { color: #a3e635; }
.portal-status-reputation__level--warning { color: #fbbf24; }
.portal-status-reputation__level--danger { color: #f87171; }

.portal-about-reputation__level--excellent { color: #34d399; }
.portal-about-reputation__level--good { color: #a3e635; }
.portal-about-reputation__level--warning { color: #fbbf24; }
.portal-about-reputation__level--danger { color: #f87171; }

.portal-status-reputation__desc {
  margin-top: 0.75rem;
  max-width: 40rem;
  font-size: 0.9375rem;
  line-height: 1.65;
  color: var(--muted-light);
}

.portal-status-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  width: 100%;
}

@media (min-width: 640px) {
  .portal-status-stats { max-width: 20rem; }
}

@media (min-width: 1024px) {
  .portal-status-stats {
    width: auto;
    flex-shrink: 0;
  }
}

.portal-status-stat {
  padding: 0.875rem 1rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--surface-elevated) 40%, transparent);
  text-align: center;
}

.portal-status-stat__label {
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
}

.portal-status-stat__value {
  margin-top: 0.125rem;
  font-size: 1.25rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

.reputation-bar--status {
  margin-top: 1rem;
}

.reputation-bar--status .reputation-bar__track {
  height: 0.625rem;
}

.portal-status-reputation__footnote {
  margin-top: 0.375rem;
  font-size: 0.625rem;
  line-height: 1.45;
  color: var(--muted);
}

.portal-status-roles__head {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

@media (min-width: 640px) {
  .portal-status-roles__head {
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
  }
}

.portal-status-roles__title {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.portal-status-roles__desc {
  margin-top: 0.25rem;
  max-width: 36rem;
  font-size: 0.875rem;
  line-height: 1.55;
  color: var(--muted);
}

.portal-status-roles__link {
  flex-shrink: 0;
  font-size: 0.875rem;
  font-weight: 500;
}

.portal-status-roles__grid {
  display: grid;
  gap: 1rem;
}

@media (min-width: 640px) {
  .portal-status-roles__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.125rem;
  }
}

@media (min-width: 1024px) {
  .portal-status-roles__grid { grid-template-columns: repeat(3, 1fr); }
}

.portal-status-role {
  display: flex;
  flex-direction: column;
  padding: 1.125rem 1.25rem;
  border-radius: var(--radius-xl);
}

@media (min-width: 640px) {
  .portal-status-role { padding: 1.25rem 1.375rem; }
}

.portal-status-role--missing {
  border: 1px dashed color-mix(in srgb, var(--foreground) 14%, transparent);
  background: color-mix(in srgb, var(--surface-elevated) 28%, transparent);
}

.portal-status-role__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.portal-status-role--missing h3 {
  font-size: 0.875rem;
  font-weight: 500;
  color: color-mix(in srgb, var(--muted) 92%, transparent);
}

.portal-status-role h3 {
  font-size: 0.875rem;
  font-weight: 600;
}

.portal-status-badge {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  padding: 0.25rem 0.75rem;
  border: 1px solid color-mix(in srgb, var(--foreground) 12%, transparent);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--foreground) 6%, transparent);
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.4;
  color: var(--muted);
}

.portal-status-badge--active {
  color: #34d399;
  border-color: color-mix(in srgb, #34d399 25%, transparent);
  background: color-mix(in srgb, #34d399 10%, transparent);
}

.portal-status-badge--warning {
  color: #fbbf24;
  border-color: color-mix(in srgb, #fbbf24 25%, transparent);
  background: color-mix(in srgb, #fbbf24 10%, transparent);
}

.portal-status-role__text {
  margin-top: 0.5rem;
  flex: 1;
  font-size: 0.875rem;
  line-height: 1.55;
  color: var(--muted);
}

.portal-status-role--missing .portal-status-role__text {
  color: color-mix(in srgb, var(--muted) 88%, transparent);
}

.portal-status-role__action {
  margin-top: 1rem;
}

.portal-status-apply-btn {
  display: inline-flex;
  width: 100%;
  align-items: center;
  justify-content: center;
  padding: 0.625rem 1rem;
  border: 1px solid color-mix(in srgb, var(--accent) 32%, transparent);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--accent-muted);
  text-decoration: none;
  transition: border-color var(--transition), background var(--transition);
}

.portal-status-apply-btn:hover {
  border-color: color-mix(in srgb, var(--accent) 42%, transparent);
  background: color-mix(in srgb, var(--accent) 16%, transparent);
}

.portal-status-warnings-wrap {
  display: flex;
  justify-content: center;
  padding-top: 0.5rem;
}

.portal-status-warnings-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 15rem), 1fr));
  gap: 1.5rem;
  width: 100%;
  max-width: 72rem;
}

@media (min-width: 1024px) {
  .portal-status-warnings-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.75rem;
  }
}

.portal-status-warnings-col__head {
  margin-bottom: 1rem;
  text-align: center;
}

.portal-status-warnings-col__head h2 {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.portal-status-warnings-col__head p {
  margin: 0.25rem auto 0;
  max-width: 22rem;
  font-size: 0.875rem;
  line-height: 1.55;
  color: var(--muted);
}

/* —— Portal: Varningar page —— */

.portal-warnings-page {
  padding-inline: 0;
}

.portal-warnings-wrap {
  display: flex;
  flex-direction: column;
  gap: clamp(1.25rem, 2.5vw, 1.75rem);
  margin-top: 0.5rem;
}

.portal-warnings-hero {
  position: relative;
  overflow: hidden;
  padding: clamp(1.25rem, 2.5vw, 1.625rem) clamp(1.25rem, 2.5vw, 1.75rem);
}

.portal-warnings-hero__glow {
  pointer-events: none;
  position: absolute;
  inset: 0;
  opacity: 0.55;
  background:
    radial-gradient(ellipse 70% 80% at 8% -20%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 58%),
    radial-gradient(ellipse 50% 60% at 92% 110%, color-mix(in srgb, #fbbf24 8%, transparent), transparent 55%);
}

.portal-warnings-hero__inner {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

@media (min-width: 768px) {
  .portal-warnings-hero__inner {
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
  }
}

.portal-warnings-hero__label {
  margin: 0;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-muted);
}

.portal-warnings-hero__title {
  margin: 0.375rem 0 0;
  font-size: clamp(1.375rem, 3.5vw, 1.625rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.portal-warnings-hero__title--clean {
  color: #34d399;
}

.portal-warnings-hero__title--attention {
  color: #fbbf24;
}

.portal-warnings-hero__title--alert {
  color: #f87171;
}

.portal-warnings-hero__desc {
  margin: 0.625rem 0 0;
  max-width: 28rem;
  font-size: 0.9375rem;
  line-height: 1.65;
  color: var(--muted-light);
}

.portal-warnings-hero__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.625rem;
  width: 100%;
}

@media (min-width: 768px) {
  .portal-warnings-hero__stats {
    width: auto;
    min-width: 18rem;
  }
}

.portal-warnings-hero__stat {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0.75rem 0.875rem;
  border: 1px solid color-mix(in srgb, var(--foreground) 7%, transparent);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--surface-elevated) 55%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--foreground) 4%, transparent);
}

.portal-warnings-hero__stat-value {
  font-size: 1.375rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
}

.portal-warnings-hero__stat-label {
  font-size: 0.6875rem;
  font-weight: 500;
  line-height: 1.35;
  color: var(--muted);
}

.portal-warnings-hero__footer {
  position: relative;
  margin-top: 1.25rem;
  padding-top: 1.125rem;
  border-top: 1px solid color-mix(in srgb, var(--foreground) 7%, transparent);
}

.portal-warnings-hero__link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--accent-muted);
  text-decoration: none;
  transition: color var(--transition);
}

.portal-warnings-hero__link::after {
  content: "→";
  transition: transform var(--transition);
}

.portal-warnings-hero__link:hover {
  color: var(--foreground);
}

.portal-warnings-hero__link:hover::after {
  transform: translateX(0.15rem);
}

.portal-warnings__notice {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem 1.25rem;
  border: 1px solid color-mix(in srgb, #f87171 24%, transparent);
  border-radius: var(--radius-xl);
  background:
    linear-gradient(135deg, color-mix(in srgb, #f87171 8%, transparent), transparent 55%),
    var(--card);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #f87171 8%, transparent);
}

.portal-warnings__notice-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--radius-md);
  background: color-mix(in srgb, #f87171 12%, transparent);
  color: #f87171;
}

.portal-warnings__notice-icon svg {
  width: 1.25rem;
  height: 1.25rem;
}

.portal-warnings__notice-title {
  margin: 0;
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.45;
  color: var(--foreground);
}

.portal-warnings__notice-title strong {
  color: #fca5a5;
  font-weight: 700;
}

.portal-warnings__notice-meta {
  margin: 0.375rem 0 0;
  font-size: 0.8125rem;
  line-height: 1.55;
  color: var(--muted-light);
}

.portal-warnings {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.portal-warnings__tabs {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.3125rem;
  border: 1px solid color-mix(in srgb, var(--foreground) 8%, transparent);
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--surface-elevated) 70%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--foreground) 4%, transparent);
}

.portal-warnings__tab {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0;
  padding: 0.5rem 1rem;
  font: inherit;
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1.2;
  color: color-mix(in srgb, var(--foreground) 62%, var(--muted));
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius-full);
  cursor: pointer;
  white-space: nowrap;
  -webkit-tap-highlight-color: transparent;
  transition:
    color var(--transition),
    background var(--transition),
    border-color var(--transition),
    box-shadow var(--transition);
}

.portal-warnings__tab:hover:not(.portal-warnings__tab--active) {
  color: var(--foreground);
  background: color-mix(in srgb, var(--foreground) 5%, var(--surface-elevated));
  border-color: color-mix(in srgb, var(--foreground) 7%, transparent);
}

.portal-warnings__tab--active {
  color: var(--foreground);
  font-weight: 600;
  background: var(--card);
  border-color: color-mix(in srgb, var(--foreground) 10%, transparent);
  box-shadow:
    var(--shadow-sm),
    inset 0 1px 0 color-mix(in srgb, var(--foreground) 5%, transparent);
}

.portal-warnings__tab-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.375rem;
  padding: 0.125rem 0.45rem;
  font-size: 0.6875rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  color: var(--muted);
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--foreground) 6%, transparent);
  transition: color var(--transition), background var(--transition);
}

.portal-warnings__tab--active .portal-warnings__tab-count {
  color: var(--accent-muted);
  background: var(--accent-subtle);
}

.portal-warnings__panel {
  padding: clamp(1rem, 2vw, 1.375rem);
  min-height: 10rem;
}

.portal-warnings__panel[hidden] {
  display: none !important;
}

.portal-warnings__empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: clamp(2.5rem, 5vw, 3.25rem) 1.5rem;
  text-align: center;
}

.portal-warnings__empty-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  margin-bottom: 0.375rem;
  border-radius: var(--radius-full);
  background: color-mix(in srgb, #34d399 10%, transparent);
  color: #34d399;
}

.portal-warnings__empty-icon svg {
  width: 1.5rem;
  height: 1.5rem;
}

.portal-warnings__empty-title {
  margin: 0;
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--foreground);
}

.portal-warnings__empty-desc {
  margin: 0;
  max-width: 20rem;
  font-size: 0.8125rem;
  line-height: 1.6;
  color: var(--muted-light);
}

.portal-warnings__list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.portal-warnings__card {
  position: relative;
  display: flex;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--foreground) 7%, transparent);
  border-radius: var(--radius-xl);
  background: color-mix(in srgb, var(--surface-elevated) 50%, transparent);
  transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}

.portal-warnings__card:hover {
  border-color: color-mix(in srgb, var(--foreground) 12%, transparent);
  box-shadow: var(--shadow-sm);
}

.portal-warnings__card-accent {
  flex-shrink: 0;
  width: 3px;
  background: var(--accent);
}

.portal-warnings__card--moderation .portal-warnings__card-accent {
  background: var(--accent);
}

.portal-warnings__card--active .portal-warnings__card-accent {
  background: #fbbf24;
}

.portal-warnings__card--inactive .portal-warnings__card-accent {
  background: color-mix(in srgb, var(--muted) 50%, transparent);
}

.portal-warnings__card--inactive {
  opacity: 0.72;
}

.portal-warnings__card-inner {
  flex: 1;
  min-width: 0;
  padding: 1rem 1.125rem 1.125rem;
}

.portal-warnings__card-head {
  display: flex;
  align-items: flex-start;
  gap: 0.875rem;
}

.portal-warnings__card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: var(--radius-md);
  background: var(--accent-subtle);
  color: var(--accent-muted);
}

.portal-warnings__card--active .portal-warnings__card-icon {
  background: color-mix(in srgb, #fbbf24 12%, transparent);
  color: #fbbf24;
}

.portal-warnings__card--inactive .portal-warnings__card-icon {
  background: color-mix(in srgb, var(--foreground) 5%, transparent);
  color: var(--muted);
}

.portal-warnings__card-icon svg {
  width: 1.125rem;
  height: 1.125rem;
}

.portal-warnings__card-heading {
  flex: 1;
  min-width: 0;
}

.portal-warnings__card-title {
  margin: 0;
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.35;
}

.portal-warnings__card-date {
  display: block;
  margin-top: 0.2rem;
  font-size: 0.75rem;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}

.portal-warnings__badge {
  flex-shrink: 0;
  align-self: flex-start;
  padding: 0.25rem 0.625rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-radius: var(--radius-full);
}

.portal-warnings__badge--active {
  color: #fbbf24;
  background: color-mix(in srgb, #fbbf24 12%, transparent);
  border: 1px solid color-mix(in srgb, #fbbf24 22%, transparent);
}

.portal-warnings__badge--inactive {
  color: var(--muted);
  background: color-mix(in srgb, var(--foreground) 5%, transparent);
  border: 1px solid var(--border);
}

.portal-warnings__badge--moderation {
  color: var(--accent-muted);
  background: var(--accent-subtle);
  border: 1px solid color-mix(in srgb, var(--accent) 20%, transparent);
}

.portal-warnings__card-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem;
  margin-top: 0.875rem;
}

@media (min-width: 480px) {
  .portal-warnings__card-stats--triple {
    grid-template-columns: repeat(3, 1fr);
  }
}

.portal-warnings__stat {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  padding: 0.625rem 0.75rem;
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--background) 35%, transparent);
  border: 1px solid color-mix(in srgb, var(--foreground) 5%, transparent);
}

.portal-warnings__stat-label {
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.portal-warnings__stat-value {
  font-size: 0.8125rem;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  line-height: 1.35;
}

.portal-warnings__card-details {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 0.875rem;
  padding-top: 0.875rem;
  border-top: 1px solid color-mix(in srgb, var(--foreground) 6%, transparent);
}

.portal-warnings__card-detail-label {
  display: block;
  margin-bottom: 0.25rem;
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.portal-warnings__card-detail p {
  margin: 0;
  font-size: 0.8125rem;
  line-height: 1.6;
  color: var(--muted-light);
}

.portal-warnings__card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-top: 0.875rem;
  padding-top: 0.875rem;
  border-top: 1px solid color-mix(in srgb, var(--foreground) 6%, transparent);
}

.portal-warnings__staff {
  font-size: 0.75rem;
  color: var(--muted);
}

.portal-warnings__card-footer .portal-status-record__proof-btn {
  margin-left: auto;
}

.portal-warnings__card--ban .portal-warnings__card-accent {
  background: linear-gradient(180deg, #f87171, color-mix(in srgb, #f87171 40%, transparent));
}

.portal-warnings__card--ban.portal-warnings__card--active .portal-warnings__card-icon {
  background: color-mix(in srgb, #f87171 14%, transparent);
  color: #f87171;
}

.portal-warnings-hero__glow--ban {
  background:
    radial-gradient(ellipse 70% 80% at 8% -20%, color-mix(in srgb, #f87171 16%, transparent), transparent 58%),
    radial-gradient(ellipse 50% 60% at 92% 110%, color-mix(in srgb, #f87124 8%, transparent), transparent 55%);
}

/* —— Portal: Avstängningar page (delar layout med varningar) —— */

.portal-bans-page .portal-page-header {
  margin-bottom: 0;
}

.portal-status-record {
  padding: 0.875rem 1rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--surface-elevated) 50%, transparent);
}

.portal-status-record + .portal-status-record {
  margin-top: 0.5rem;
}

.portal-status-record__title {
  font-size: 0.875rem;
  font-weight: 600;
}

.portal-status-record__meta {
  margin-top: 0.125rem;
  font-size: 0.75rem;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}

.portal-status-record__desc {
  margin-top: 0.375rem;
  font-size: 0.8125rem;
  line-height: 1.5;
  color: var(--muted);
}

.portal-status-record__label {
  font-weight: 600;
  color: var(--text);
}

.portal-status-record__actions {
  margin-top: 0.625rem;
}

.portal-status-record__proof-btn {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.75rem;
  font: inherit;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text);
  background: color-mix(in srgb, var(--surface-elevated) 80%, transparent);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease;
}

.portal-status-record__proof-btn:hover {
  border-color: color-mix(in srgb, var(--accent) 40%, var(--border));
  background: color-mix(in srgb, var(--accent) 8%, var(--surface-elevated));
}

.portal-status-proof-modal {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.portal-status-proof-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgb(0 0 0 / 0.55);
}

.portal-status-proof-modal__panel {
  position: relative;
  width: min(100%, 28rem);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  box-shadow: var(--shadow-lg);
}

.portal-status-proof-modal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 1rem 1.125rem;
  border-bottom: 1px solid var(--border);
}

.portal-status-proof-modal__head h2 {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
}

.portal-status-proof-modal__close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  padding: 0;
  font-size: 1.25rem;
  line-height: 1;
  color: var(--muted);
  background: transparent;
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
}

.portal-status-proof-modal__close:hover {
  color: var(--text);
  background: color-mix(in srgb, var(--surface-elevated) 70%, transparent);
}

.portal-status-proof-modal__body {
  padding: 1rem 1.125rem 1.125rem;
}

.portal-status-proof-text {
  margin: 0;
  font-size: 0.875rem;
  line-height: 1.55;
  color: var(--text);
  white-space: pre-wrap;
  word-break: break-word;
}

.portal-status-proof-text--empty {
  color: var(--muted);
  font-style: italic;
}

.portal-status-proof-link {
  font-size: 0.875rem;
  line-height: 1.55;
  word-break: break-all;
}

/* ── Apply / formulär ── */

.apply-page {
  max-width: 72rem;
  padding-bottom: var(--space-16);
}

.apply-page .site-breadcrumb {
  margin-bottom: var(--space-6);
}

.apply-header {
  max-width: 40rem;
  margin-inline: auto;
  text-align: center;
}

.apply-header.page-header {
  margin-bottom: var(--space-8);
}

.apply-header__title {
  margin-top: 0;
}

.apply-header__desc {
  margin-top: var(--space-3);
}

.apply-layout {
  display: grid;
  gap: var(--space-6);
  align-items: start;
}

@media (min-width: 1024px) {
  .apply-layout {
    grid-template-columns: minmax(15rem, 17rem) minmax(0, 1fr);
    gap: var(--space-8);
  }
}

.apply-sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

@media (min-width: 1024px) {
  .apply-sidebar {
    position: sticky;
    top: calc(var(--header-height) + var(--space-6));
  }
}

.apply-sidebar__card {
  padding: var(--space-5);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background: var(--card);
}

.apply-sidebar__card--note {
  background: color-mix(in srgb, var(--card) 88%, var(--accent-subtle));
}

.apply-sidebar__eyebrow {
  margin-bottom: var(--space-3);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent-muted);
}

.apply-sidebar__hint {
  margin-top: var(--space-3);
  font-size: 0.8125rem;
  line-height: 1.55;
  color: var(--muted);
}

.apply-sidebar__list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding-left: 1.1rem;
  font-size: 0.8125rem;
  line-height: 1.55;
  color: var(--muted-light);
}

.apply-sidebar__link {
  display: inline-block;
  margin-top: var(--space-4);
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--accent-muted);
  text-decoration: none;
}

.apply-sidebar__link:hover {
  color: var(--foreground);
}

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

.apply-card {
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background: var(--card);
  overflow: hidden;
}

.apply-form {
  display: flex;
  flex-direction: column;
}

.apply-panel + .apply-panel {
  border-top: 1px solid var(--border);
}

.apply-panel__head {
  padding: var(--space-5) var(--space-6) 0;
}

@media (min-width: 768px) {
  .apply-panel__head {
    padding: var(--space-6) var(--space-8) 0;
  }
}

.apply-panel__title {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent-muted);
}

.apply-panel__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  padding: var(--space-5) var(--space-6) var(--space-6);
}

@media (min-width: 768px) {
  .apply-panel__body {
    gap: var(--space-6);
    padding: var(--space-5) var(--space-8) var(--space-8);
  }
}

.apply-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.apply-field__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
}

.apply-label {
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.45;
  color: var(--foreground);
}

.apply-field__badge {
  flex-shrink: 0;
  padding: 0.2rem 0.5rem;
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: var(--radius-full);
  border: 1px solid transparent;
}

.apply-field__badge--required {
  color: var(--accent-muted);
  background: var(--accent-subtle);
  border-color: color-mix(in srgb, var(--accent) 18%, transparent);
}

.apply-field__badge--optional {
  color: var(--muted);
  background: color-mix(in srgb, var(--foreground) 4%, transparent);
  border-color: var(--border);
}

.apply-required {
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--accent-muted);
}

.apply-input {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  padding: 0.75rem 0.875rem;
  font-size: 0.9375rem;
  line-height: 1.5;
  color: var(--foreground);
  outline: none;
  transition: border-color var(--transition), box-shadow var(--transition);
}

.apply-input::placeholder {
  color: var(--muted);
}

.apply-input:focus {
  border-color: color-mix(in srgb, var(--accent) 38%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 14%, transparent);
}

.apply-input--textarea {
  resize: vertical;
  min-height: 4.5rem;
}

.apply-input--textarea:not(.apply-input--sm) {
  min-height: 7rem;
}

.apply-input--date,
.apply-input--select {
  max-width: 100%;
  min-height: 2.875rem;
}

@media (min-width: 640px) {
  .apply-input--date,
  .apply-input--select {
    max-width: 22rem;
  }
}

.apply-hint {
  font-size: 0.75rem;
  line-height: 1.55;
  color: var(--muted);
}

.apply-hint + .apply-hint {
  margin-top: calc(var(--space-1) * -1);
}

.apply-discord-chip {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  width: 100%;
  padding: 0.625rem 0.75rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
}

.apply-discord-chip__avatar {
  width: 2.5rem;
  height: 2.5rem;
  flex-shrink: 0;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  object-fit: cover;
}

.apply-discord-chip__text {
  min-width: 0;
  flex: 1;
}

.apply-discord-chip__text p:first-child {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--foreground);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.apply-discord-chip__text p:last-child {
  font-size: 0.75rem;
  color: var(--muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.apply-form-footer {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding: var(--space-6);
  border-top: 1px solid var(--border);
  background: color-mix(in srgb, var(--surface) 55%, var(--card));
}

@media (min-width: 768px) {
  .apply-form-footer {
    padding: var(--space-6) var(--space-8);
  }
}

.apply-form-footer__note {
  font-size: 0.8125rem;
  line-height: 1.55;
  color: var(--muted);
  text-align: center;
}

.apply-form-footer__actions {
  display: flex;
  justify-content: center;
}

.apply-submit {
  min-width: 12rem;
}

.apply-submit svg {
  width: 1rem;
  height: 1rem;
}

.apply-message {
  text-align: center;
  font-size: 0.875rem;
  line-height: 1.6;
  padding: 0.75rem 1rem;
  border-radius: var(--radius-lg);
}

.apply-message--success {
  color: var(--accent-muted);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 24%, transparent);
}

.apply-message--error {
  color: #fca5a5;
  background: color-mix(in srgb, #ef4444 10%, transparent);
  border: 1px solid color-mix(in srgb, #ef4444 24%, transparent);
}

.apply-pending {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 1rem;
  padding: clamp(2rem, 5vw, 3rem) clamp(1.25rem, 4vw, 2rem);
}

.apply-pending__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  color: var(--accent-muted);
  background: var(--accent-subtle);
  border: 1px solid color-mix(in srgb, var(--accent) 22%, transparent);
}

.apply-pending__icon svg {
  width: 1.5rem;
  height: 1.5rem;
}

.apply-pending__title {
  margin: 0;
  font-size: clamp(1.25rem, 3vw, 1.5rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.25;
}

.apply-pending__desc {
  margin: 0;
  max-width: 34rem;
  font-size: 0.9375rem;
  line-height: 1.65;
  color: var(--muted-light);
}

.apply-pending__meta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.25rem 2rem;
  margin: 0.25rem 0 0;
  padding: 1rem 1.25rem;
  border-radius: var(--radius-xl);
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--surface-elevated) 50%, transparent);
}

.apply-pending__meta-item {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  margin: 0;
}

.apply-pending__meta-item dt {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.apply-pending__meta-item dd {
  margin: 0;
  font-size: 0.875rem;
  color: var(--foreground);
}

.apply-pending__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.75rem;
  margin-top: 0.5rem;
}

.card-tile--pending {
  border-color: color-mix(in srgb, var(--accent) 20%, transparent);
}

.card-tile--pending .card-meta {
  color: var(--accent-muted);
}

/* Legacy aliases */
.apply-form-wrap,
.apply-form-stack {
  max-width: none;
  margin: 0;
}

.apply-discord-note,
.apply-submit-wrap {
  display: none;
}

.apply-section {
  display: none;
}

/* ——— Global polish ——— */
.process-step {
  border-radius: var(--radius-xl);
}

/* ——— Information hub ——— */
/* Breadcrumb styles live in global .site-breadcrumb block */

/* Information landing (hub) */
.info-landing .page-header {
  max-width: 40rem;
}

.info-landing .card-grid {
  max-width: 56rem;
  margin-inline: auto;
}

/* Rules landing (trådar) */
.rules-landing .page-header {
  max-width: 40rem;
}

.rules-landing .card-grid {
  margin-top: var(--space-8);
}

.rules-landing .card-grid--2 {
  max-width: 56rem;
  margin-inline: auto;
}

.info-hub-grid {
  display: grid;
  gap: var(--space-4);
  max-width: 52rem;
  margin-inline: auto;
}

@media (min-width: 640px) {
  .info-hub-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-5);
  }
}

.info-hub-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding: var(--space-6);
  min-height: 12rem;
}

.info-hub-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: var(--radius-lg);
  background: var(--accent-subtle);
  color: var(--accent-muted);
  border: 1px solid color-mix(in srgb, var(--accent) 18%, transparent);
}

.info-hub-card__icon svg {
  width: 1.375rem;
  height: 1.375rem;
}

.info-hub-card__icon--muted {
  background: color-mix(in srgb, var(--surface-elevated) 80%, transparent);
  color: var(--muted-light);
  border-color: var(--border);
}

.info-hub-card__body {
  flex: 1;
  min-width: 0;
}

.info-hub-card__title {
  font-size: 1.125rem;
  font-weight: 600;
  letter-spacing: -0.02em;
}

.info-hub-card__desc {
  margin-top: 0.375rem;
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--muted-light);
}

.info-hub-card__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border);
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--accent-muted);
}

.info-hub-card__count {
  font-size: 0.75rem;
  color: var(--muted);
  font-weight: 400;
}

.thread-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  max-width: 48rem;
  margin-inline: auto;
}

.thread-card {
  display: block;
  padding: var(--space-5);
  text-decoration: none;
}

.thread-card__inner {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
}

.thread-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: var(--radius-md);
  background: var(--surface-elevated);
  color: var(--muted-light);
  border: 1px solid var(--border);
  transition: color var(--transition), background var(--transition), border-color var(--transition);
}

.thread-card:hover .thread-card__icon {
  color: var(--accent-muted);
  background: var(--accent-subtle);
  border-color: color-mix(in srgb, var(--accent) 18%, transparent);
}

.thread-card__icon svg {
  width: 1.25rem;
  height: 1.25rem;
}

.thread-card__body {
  flex: 1;
  min-width: 0;
}

.thread-card__section {
  display: block;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
}

.thread-card__title {
  margin-top: 0.25rem;
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.35;
  transition: color var(--transition);
}

.thread-card:hover .thread-card__title {
  color: var(--accent-muted);
}

.thread-card__desc {
  margin-top: 0.375rem;
  font-size: 0.8125rem;
  line-height: 1.55;
  color: var(--muted-light);
}

.thread-card__arrow {
  flex-shrink: 0;
  width: 1.125rem;
  height: 1.125rem;
  margin-top: 0.25rem;
  color: var(--muted);
  opacity: 0;
  transform: translateX(-4px);
  transition: opacity var(--transition), transform var(--transition), color var(--transition);
}

.thread-card:hover .thread-card__arrow {
  opacity: 1;
  transform: translateX(0);
  color: var(--accent-muted);
}

.thread-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-top: var(--space-4);
  padding-top: var(--space-3);
  border-top: 1px solid var(--border);
  font-size: 0.75rem;
  color: var(--muted);
}

.page-header--left {
  text-align: left;
  margin-inline: 0;
  max-width: 40rem;
}

.page-header--left .page-desc {
  margin-inline: 0;
}

.info-page-layout .page-header {
  text-align: left;
  margin-inline: 0;
  max-width: 40rem;
}

.info-page-layout .page-desc {
  margin-inline: 0;
}

/* ——— Home page ——— */
.home-page {
  position: relative;
  flex: 1;
}

.home-hero-backdrop {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: -1;
  background-color: var(--background);
  background-image:
    linear-gradient(to bottom, transparent 0%, var(--background) 58%),
    radial-gradient(ellipse 85% 55% at 50% -12%, var(--accent-dim), transparent),
    linear-gradient(var(--grid-fade) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-fade) 1px, transparent 1px);
  background-size: 100% 100%, 100% 100%, 44px 44px, 44px 44px;
}

/* Hero */
.hero--home .hero__title-gradient {
  background: linear-gradient(135deg, var(--foreground) 0%, var(--accent-muted) 55%, var(--accent) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.hero__logo-wrap--animated {
  animation: hero-float 6s ease-in-out infinite;
}

@keyframes hero-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

.badge--live {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  color: var(--success);
  border-color: color-mix(in srgb, var(--success) 30%, transparent);
  background: color-mix(in srgb, var(--success) 8%, transparent);
}

.badge--live__dot {
  width: 0.375rem;
  height: 0.375rem;
  border-radius: 50%;
  background: var(--success);
  box-shadow: 0 0 6px color-mix(in srgb, var(--success) 60%, transparent);
  animation: live-pulse 2s ease-in-out infinite;
}

.badge--live.is-offline {
  color: var(--muted);
  border-color: var(--border);
  background: color-mix(in srgb, var(--foreground) 4%, transparent);
}

.badge--live.is-offline .badge--live__dot {
  background: var(--muted);
  box-shadow: none;
  animation: none;
}

@keyframes live-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

.home-page .hero__actions .btn--primary {
  border-radius: var(--radius-xl);
  padding-inline: 2rem;
  box-shadow: 0 8px 32px var(--accent-glow);
}

.home-page .hero__actions .btn--primary:hover {
  filter: brightness(1.1);
}

.home-page .hero__stats {
  max-width: 56rem;
  margin-inline: auto;
}

.home-page .stat-grid {
  gap: 1rem;
}

@media (min-width: 1024px) {
  .home-page .stat-grid {
    gap: 1.25rem;
  }
}

.home-page .stat-card__value {
  font-size: clamp(2.25rem, 5vw, 2.75rem);
}

.home-section {
  padding: clamp(3.5rem, 7vw, 5rem) 0;
}

.home-section .section-header {
  max-width: 40rem;
  margin-bottom: clamp(2rem, 4vw, 2.5rem);
}

.home-page .section--bleed {
  padding-block: clamp(3.5rem, 7vw, 5rem);
}

/* Scroll reveal */
.reveal {
  opacity: 0;
  transform: translateY(1.25rem);
  transition:
    opacity 0.6s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: var(--reveal-delay, 0ms);
}

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

@media (prefers-reduced-motion: reduce) {
  .reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .hero__logo-wrap--animated {
    animation: none;
  }

  .badge--live__dot {
    animation: none;
  }
}

/* Portal cards */
.home-portal-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

@media (min-width: 768px) {
  .home-portal-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
  }
}

.home-portal-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 1.5rem;
  text-decoration: none;
  border-radius: var(--radius-xl);
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel) 90%, transparent);
  overflow: hidden;
  transition:
    border-color var(--transition),
    background var(--transition),
    transform var(--transition),
    box-shadow var(--transition);
}

.home-portal-card::before {
  content: '';
  pointer-events: none;
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 60% at 100% 0%, color-mix(in srgb, var(--accent) 10%, transparent), transparent 55%);
  opacity: 0;
  transition: opacity var(--transition);
}

.home-portal-card:hover,
.home-portal-card:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 35%, transparent);
  background: color-mix(in srgb, var(--card-hover) 80%, var(--panel));
  transform: translateY(-3px);
  box-shadow: 0 12px 40px -12px var(--accent-glow);
  outline: none;
}

.home-portal-card:hover::before,
.home-portal-card:focus-visible::before {
  opacity: 1;
}

.home-portal-card--featured {
  border-color: color-mix(in srgb, var(--accent) 28%, transparent);
  background:
    radial-gradient(ellipse 90% 70% at 0% 0%, var(--accent-dim), transparent 60%),
    color-mix(in srgb, var(--panel) 92%, transparent);
}

@media (min-width: 768px) {
  .home-portal-card--featured {
    grid-row: span 1;
  }
}

.home-portal-card > * {
  position: relative;
}

.home-portal-card__step {
  position: absolute;
  top: 1rem;
  right: 1.25rem;
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.04em;
  color: color-mix(in srgb, var(--foreground) 6%, transparent);
  font-variant-numeric: tabular-nums;
  pointer-events: none;
}

.home-portal-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--radius-md);
  color: var(--accent-muted);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 20%, transparent);
}

.home-portal-card__icon svg {
  width: 1.25rem;
  height: 1.25rem;
}

.home-portal-card__tag {
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent-muted);
}

.home-portal-card__title {
  font-size: 1.0625rem;
  font-weight: 600;
  line-height: 1.35;
  color: var(--foreground);
}

.home-portal-card__desc {
  flex: 1;
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--muted);
}

.home-portal-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  margin-top: 0.5rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--accent-muted);
  transition: gap var(--transition), color var(--transition);
}

.home-portal-card__cta svg {
  width: 1rem;
  height: 1rem;
  transition: transform var(--transition);
}

.home-portal-card:hover .home-portal-card__cta,
.home-portal-card:focus-visible .home-portal-card__cta {
  color: var(--foreground);
  gap: 0.5rem;
}

.home-portal-card:hover .home-portal-card__cta svg,
.home-portal-card:focus-visible .home-portal-card__cta svg {
  transform: translateX(2px);
}

/* Home features */
.home-features {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.875rem;
  max-width: 52rem;
  margin-inline: auto;
}

@media (min-width: 640px) {
  .home-features {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }
}

.home-feature {
  position: relative;
  padding: 1.375rem 1.5rem;
  border-radius: var(--radius-xl);
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--surface-elevated) 40%, transparent);
  transition:
    border-color var(--transition),
    background var(--transition),
    transform var(--transition);
}

.home-feature:hover {
  border-color: color-mix(in srgb, var(--accent) 22%, transparent);
  background: color-mix(in srgb, var(--card-hover) 60%, var(--surface-elevated));
  transform: translateY(-2px);
}

.home-feature__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  margin-bottom: 0.875rem;
  border-radius: var(--radius-md);
  color: var(--accent-muted);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
}

.home-feature__icon svg {
  width: 1.125rem;
  height: 1.125rem;
}

.home-feature__title {
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.35;
  color: var(--foreground);
}

.home-feature__desc {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--muted);
}

/* Process */
.home-page .process-step {
  position: relative;
  background: color-mix(in srgb, var(--surface-elevated) 30%, transparent);
  border-color: color-mix(in srgb, var(--foreground) 10%, transparent);
}

.home-page .process-step__num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  margin-bottom: 0.75rem;
  font-size: 0.875rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--accent);
  border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--accent) 35%, transparent);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
}

.home-page .process-step__label {
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent-muted);
  background: none;
  border: none;
  padding: 0;
  min-width: 0;
}

.home-page .cta-section {
  padding-bottom: clamp(4rem, 8vw, 5.5rem);
}

/* ——— Bablo-inspired global components ——— */

.theme-toggle--header {
  padding: 0;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface) 80%, transparent);
}

.theme-toggle__btn--icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  min-width: 0;
  padding: 0;
  border: none;
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--muted-light);
  cursor: pointer;
  transition: color var(--transition), background var(--transition);
}

.theme-toggle__btn--icon:hover {
  color: var(--foreground);
  background: var(--hover-overlay);
}

.theme-toggle__btn--icon svg {
  width: 1.125rem;
  height: 1.125rem;
}

.hero--home .hero__layout {
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.hero--home .hero__badges,
.hero--home .hero__actions {
  justify-content: center;
}

.hero--home .hero__text {
  margin-inline: auto;
}

.hero--home .hero__title {
  font-size: clamp(2.5rem, 6vw, 3.75rem);
  max-width: 18ch;
  margin-inline: auto;
}

.faq-list {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  max-width: 48rem;
  margin-inline: auto;
}

.faq-item {
  border-radius: var(--radius-xl);
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel) 90%, transparent);
  overflow: hidden;
  transition: border-color var(--transition);
}

.faq-item[open] {
  border-color: color-mix(in srgb, var(--accent) 22%, transparent);
}

.faq-item__question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.25rem;
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  cursor: pointer;
  list-style: none;
  transition: color var(--transition);
}

.faq-item__question::-webkit-details-marker {
  display: none;
}

.faq-item__question::after {
  content: '+';
  flex-shrink: 0;
  font-size: 1.125rem;
  font-weight: 400;
  color: var(--muted);
  transition: transform var(--transition), color var(--transition);
}

.faq-item[open] .faq-item__question::after {
  content: '−';
  color: var(--accent-muted);
}

.faq-item__answer {
  padding: 0 1.25rem 1.125rem;
  font-size: 0.875rem;
  line-height: 1.65;
  color: var(--muted-light);
}

.faq-item__answer p {
  margin: 0;
}

.faq-item__answer code {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.8125rem;
  padding: 0.125rem 0.375rem;
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--foreground) 6%, transparent);
  border: 1px solid var(--border);
}

.page-content .card-grid {
  margin-top: var(--space-6);
}

.portal-card,
.portal-dashboard__welcome,
.portal-stat-card,
.portal-dashboard__panel,
.portal-dashboard__activity {
  border-radius: var(--radius-xl);
  border-color: var(--border);
  background: color-mix(in srgb, var(--panel) 92%, transparent);
  box-shadow: var(--shadow-sm);
}

.cta-box {
  border-radius: var(--radius-xl);
  border: 1px solid color-mix(in srgb, var(--accent) 22%, transparent);
  background:
    radial-gradient(ellipse 80% 80% at 50% 0%, var(--accent-dim), transparent 65%),
    color-mix(in srgb, var(--panel) 94%, transparent);
}

.section--subtle {
  background: color-mix(in srgb, var(--surface) 45%, transparent);
  border-block: 1px solid var(--border);
}

html[data-theme="light"] .page-bg,
html[data-theme="light"] .home-hero-backdrop,
html[data-theme="light"] .login-page__bg {
  background-image:
    linear-gradient(to bottom, transparent 0%, var(--background) 68%),
    radial-gradient(ellipse 80% 55% at 50% -10%, var(--accent-dim), transparent 72%),
    linear-gradient(var(--grid-fade) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-fade) 1px, transparent 1px);
  background-size: 100% 100%, 100% 100%, 48px 48px, 48px 48px;
}

/* ——— Donation ——— */
.portal-donation-page .site-breadcrumb {
  margin-bottom: var(--space-5);
}

.portal-donation-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  padding-bottom: var(--space-12);
}

@media (min-width: 768px) {
  .portal-donation-wrap {
    gap: var(--space-8);
  }
}

.portal-donation-wrap.is-ready {
  animation: portal-dashboard-in 0.16s ease;
}

/* Hero */
.portal-donation-hero {
  position: relative;
  overflow: hidden;
  border-color: color-mix(in srgb, var(--foreground) 7%, transparent);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface-elevated) 40%, transparent) 0%, var(--card) 100%);
}

.portal-donation-hero__glow {
  pointer-events: none;
  position: absolute;
  inset: 0;
  opacity: 0.35;
  transition: opacity var(--transition);
  background:
    radial-gradient(ellipse 60% 70% at 8% -10%, var(--accent-glow), transparent 55%),
    radial-gradient(ellipse 40% 50% at 95% 100%, color-mix(in srgb, var(--accent) 4%, transparent), transparent 50%);
}

.portal-donation-hero--donator .portal-donation-hero__glow {
  opacity: 0.42;
  background:
    radial-gradient(ellipse 55% 65% at 6% -5%, color-mix(in srgb, #60a5fa 22%, transparent), transparent 55%),
    radial-gradient(ellipse 35% 45% at 98% 105%, color-mix(in srgb, #60a5fa 5%, transparent), transparent 50%);
}

.portal-donation-hero--platinum .portal-donation-hero__glow {
  opacity: 0.45;
  background:
    radial-gradient(ellipse 55% 65% at 6% -5%, color-mix(in srgb, #a78bfa 24%, transparent), transparent 55%),
    radial-gradient(ellipse 35% 45% at 98% 105%, color-mix(in srgb, #c4b5fd 6%, transparent), transparent 50%);
}

.portal-donation-hero--elite .portal-donation-hero__glow {
  opacity: 0.48;
  background:
    radial-gradient(ellipse 55% 65% at 6% -5%, color-mix(in srgb, #fbbf24 26%, transparent), transparent 55%),
    radial-gradient(ellipse 35% 45% at 98% 105%, color-mix(in srgb, #f59e0b 6%, transparent), transparent 50%);
}

.portal-donation-hero__inner {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  padding: clamp(1.5rem, 3vw, 2rem) clamp(1.5rem, 3vw, 2.5rem);
}

@media (min-width: 768px) {
  .portal-donation-hero__inner {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-8);
    padding: clamp(1.75rem, 3vw, 2.25rem) clamp(1.75rem, 3vw, 2.5rem);
  }
}

.portal-donation-hero__profile {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  text-align: center;
}

@media (min-width: 640px) {
  .portal-donation-hero__profile {
    flex-direction: row;
    align-items: center;
    text-align: left;
  }
}

.portal-donation-hero__badge {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.75rem;
  height: 3.75rem;
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in srgb, var(--foreground) 8%, transparent);
  background: color-mix(in srgb, var(--surface-elevated) 60%, transparent);
  color: var(--muted);
  transition: color var(--transition), border-color var(--transition), box-shadow var(--transition);
}

.portal-donation-hero--donator .portal-donation-hero__badge {
  color: #93c5fd;
  border-color: color-mix(in srgb, #60a5fa 22%, transparent);
  background: color-mix(in srgb, #60a5fa 8%, var(--surface-elevated));
  box-shadow: 0 8px 24px -12px color-mix(in srgb, #60a5fa 35%, transparent);
}

.portal-donation-hero--platinum .portal-donation-hero__badge {
  color: #c4b5fd;
  border-color: color-mix(in srgb, #a78bfa 24%, transparent);
  background: color-mix(in srgb, #a78bfa 9%, var(--surface-elevated));
  box-shadow: 0 8px 24px -12px color-mix(in srgb, #a78bfa 38%, transparent);
}

.portal-donation-hero--elite .portal-donation-hero__badge {
  color: #fcd34d;
  border-color: color-mix(in srgb, #fbbf24 26%, transparent);
  background: color-mix(in srgb, #fbbf24 9%, var(--surface-elevated));
  box-shadow: 0 8px 24px -12px color-mix(in srgb, #fbbf24 40%, transparent);
}

.portal-donation-hero__label {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.portal-donation-hero__name {
  margin-top: 0.125rem;
  font-size: clamp(1.5rem, 3.5vw, 1.875rem);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.15;
  transition: color var(--transition);
}

.portal-donation-hero__name--donator { color: #93c5fd; }
.portal-donation-hero__name--platinum { color: #c4b5fd; }
.portal-donation-hero__name--elite { color: #fcd34d; }
.portal-donation-hero__name--none { color: var(--muted-light); }

.portal-donation-hero__desc {
  margin-top: 0.375rem;
  max-width: 28rem;
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--muted-light);
}

.portal-donation-hero__stats {
  display: flex;
  gap: var(--space-6);
  width: 100%;
}

@media (min-width: 768px) {
  .portal-donation-hero__stats {
    width: auto;
    flex-shrink: 0;
    gap: var(--space-8);
  }
}

.portal-donation-stat {
  text-align: center;
}

@media (min-width: 768px) {
  .portal-donation-stat {
    text-align: right;
  }
}

.portal-donation-stat__label {
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.portal-donation-stat__value {
  margin-top: 0.125rem;
  font-size: 1.125rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
}

.portal-donation-hero__body {
  position: relative;
  padding: var(--space-5) clamp(1.5rem, 3vw, 2.5rem) 0;
}

.portal-donation-hero__footer {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding: var(--space-5) clamp(1.5rem, 3vw, 2.5rem) clamp(1.5rem, 3vw, 2rem);
}

@media (min-width: 640px) {
  .portal-donation-hero__footer {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-6);
  }
}

.portal-donation-hero__footnote {
  font-size: 0.8125rem;
  line-height: 1.55;
  color: var(--muted);
}

.portal-donation-hero__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}

.portal-donation-hero__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4375rem;
  padding: 0.5rem 0.9375rem;
  border: 1px solid color-mix(in srgb, var(--foreground) 9%, transparent);
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--foreground) 3.5%, transparent);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--muted-light);
  text-decoration: none;
  white-space: nowrap;
  transition: color var(--transition), background var(--transition), border-color var(--transition), box-shadow var(--transition);
}

.portal-donation-hero__link svg {
  width: 0.9375rem;
  height: 0.9375rem;
  flex-shrink: 0;
  opacity: 0.75;
  transition: opacity var(--transition);
}

.portal-donation-hero__link:hover {
  color: var(--foreground);
  border-color: color-mix(in srgb, var(--foreground) 16%, transparent);
  background: color-mix(in srgb, var(--foreground) 7%, transparent);
  box-shadow: 0 1px 0 color-mix(in srgb, var(--foreground) 4%, transparent);
}

.portal-donation-hero__link:hover svg {
  opacity: 1;
}

.portal-donation-hero__link:not(.portal-donation-hero__link--staff):hover {
  color: #93c5fd;
  border-color: color-mix(in srgb, #60a5fa 28%, transparent);
  background: color-mix(in srgb, #60a5fa 10%, transparent);
  box-shadow: 0 4px 16px -8px color-mix(in srgb, #60a5fa 35%, transparent);
}

.portal-donation-hero__link--staff:hover {
  color: #c4b5fd;
  border-color: color-mix(in srgb, #a78bfa 28%, transparent);
  background: color-mix(in srgb, #a78bfa 10%, transparent);
  box-shadow: 0 4px 16px -8px color-mix(in srgb, #a78bfa 35%, transparent);
}

/* Stepper */
.portal-donation-stepper {
  position: relative;
  width: 100%;
}

.portal-donation-stepper__rail {
  position: relative;
  padding-bottom: 0.25rem;
}

.portal-donation-stepper__track {
  position: absolute;
  top: 0.9375rem;
  left: calc(100% / 6);
  right: calc(100% / 6);
  height: 3px;
  overflow: hidden;
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--foreground) 6%, transparent);
}

.portal-donation-stepper__fill {
  height: 100%;
  border-radius: inherit;
  background: var(--accent-muted);
  transition: width 600ms cubic-bezier(0.4, 0, 0.2, 1);
}

.portal-donation-stepper__fill--donator {
  background: linear-gradient(90deg, #3b82f6, #60a5fa);
}

.portal-donation-stepper__fill--platinum {
  background: linear-gradient(90deg, #8b5cf6, #a78bfa);
}

.portal-donation-stepper__fill--elite {
  background: linear-gradient(90deg, #f59e0b, #fbbf24);
}

.portal-donation-stepper__tooltip {
  display: none;
  position: absolute;
  left: 50%;
  bottom: calc(100% + 0.625rem);
  transform: translateX(-50%);
  z-index: 20;
  min-width: 10rem;
  max-width: 16rem;
  padding: 0.5rem 0.75rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-elevated) 98%, transparent);
  box-shadow: var(--shadow-md);
  text-align: center;
}

.portal-donation-stepper.group:hover .portal-donation-stepper__tooltip {
  display: block;
}

.portal-donation-stepper__tooltip-title {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
}

.portal-donation-stepper__tooltip-sub {
  display: block;
  margin-top: 0.2rem;
  font-size: 0.6875rem;
  line-height: 1.4;
  color: var(--muted);
}

/* Milestones */
.portal-donation-milestones {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}

.portal-donation-milestone {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.625rem;
  padding: 0 0.5rem;
  text-align: center;
}

.portal-donation-milestone__dot {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.875rem;
  height: 1.875rem;
  border-radius: 50%;
  border: 2px solid var(--card);
  background: color-mix(in srgb, var(--foreground) 10%, var(--card));
  color: transparent;
  transition: background var(--transition), color var(--transition), box-shadow var(--transition);
}

.portal-donation-milestone--active .portal-donation-milestone__dot {
  border-color: var(--card);
  color: var(--background);
}

.portal-donation-milestone--donator.portal-donation-milestone--active .portal-donation-milestone__dot {
  background: #60a5fa;
}

.portal-donation-milestone--platinum.portal-donation-milestone--active .portal-donation-milestone__dot {
  background: #a78bfa;
}

.portal-donation-milestone--elite.portal-donation-milestone--active .portal-donation-milestone__dot {
  background: #fbbf24;
}

.portal-donation-milestone--current .portal-donation-milestone__label {
  color: var(--foreground);
}

.portal-donation-milestone__dot svg {
  width: 0.75rem;
  height: 0.75rem;
}

.portal-donation-milestone__label {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--muted);
  line-height: 1.3;
}

.portal-donation-milestone--active .portal-donation-milestone__label {
  color: var(--foreground);
}

.portal-donation-milestone__threshold {
  font-size: 0.6875rem;
  font-weight: 500;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
  line-height: 1.3;
}

.portal-donation-milestone--active .portal-donation-milestone__threshold {
  color: var(--muted-light);
}

/* Content grid */
.portal-donation-grid {
  display: grid;
  gap: var(--space-6);
}

@media (min-width: 1024px) {
  .portal-donation-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-6);
    align-items: start;
  }
}

.portal-donation-panel {
  padding: clamp(1.25rem, 2.5vw, 1.75rem);
  border-color: color-mix(in srgb, var(--foreground) 7%, transparent);
}

.portal-donation-panel__head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-5);
}

.portal-donation-panel__title {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
}

.portal-donation-panel__desc {
  margin-top: 0.25rem;
  font-size: 0.8125rem;
  line-height: 1.55;
  color: var(--muted-light);
}

.portal-donation-panel__link {
  flex-shrink: 0;
  font-size: 0.8125rem;
  font-weight: 500;
}

/* Rows */
.portal-donation-rows {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.portal-donation-row {
  display: flex;
  align-items: center;
  gap: 0.875rem;
  padding: 0.75rem 0.875rem;
  border: 1px solid color-mix(in srgb, var(--foreground) 6%, transparent);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--surface-elevated) 30%, transparent);
  transition: border-color var(--transition), background var(--transition);
}

.portal-donation-row:hover {
  border-color: color-mix(in srgb, var(--foreground) 10%, transparent);
  background: color-mix(in srgb, var(--surface-elevated) 50%, transparent);
}

.portal-donation-row__icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--accent) 8%, var(--surface-elevated));
  color: var(--accent-muted);
}

.portal-donation-row__icon--credit {
  background: color-mix(in srgb, #34d399 12%, var(--surface-elevated));
  color: #34d399;
}

.portal-donation-row__icon svg {
  width: 1rem;
  height: 1rem;
}

.portal-donation-row__body {
  flex: 1;
  min-width: 0;
}

.portal-donation-row__title {
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.portal-donation-row__desc {
  margin-top: 0.125rem;
  font-size: 0.75rem;
  line-height: 1.45;
  color: var(--muted-light);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.portal-donation-row__meta {
  margin-top: 0.125rem;
  font-size: 0.6875rem;
  font-weight: 500;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}

.portal-donation-row__value {
  flex-shrink: 0;
  font-size: 0.875rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--accent);
  letter-spacing: -0.01em;
}

.portal-donation-row__id {
  font-family: 'Geist Mono', ui-monospace, monospace;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.02em;
}

