/* ============================================
   GAME APP COMMUNITY - REDESIGNED UI
   ============================================ */

/* --- CSS Variables --- */
:root {
  --bg: #0d0118;
  --surface: #ffffff;
  --surface-soft: #fff8ff;
  --primary: #7c3aed;
  --primary-2: #a855f7;
  --primary-dark: #1a0533;
  --accent: #fbbf24;
  --accent-2: #f472b6;
  --neon-blue: #38bdf8;
  --neon-pink: #ec4899;
  --neon-purple: #a855f7;
  --text: #1e1b2e;
  --text-light: #f8f5ff;
  --muted: #6b6280;
  --line: rgba(124, 58, 237, 0.12);
  --success: #d1fae5;
  --success-text: #065f46;
  --error: #ffe4e6;
  --error-text: #9f1239;
  --radius-xl: 24px;
  --radius-lg: 20px;
  --radius-md: 14px;
  --shadow: 0 20px 60px rgba(30, 0, 80, 0.15);
  --shadow-card: 0 8px 32px rgba(30, 0, 80, 0.1);
  --shadow-glow: 0 0 40px rgba(124, 58, 237, 0.3);
}

/* --- Reset & Base --- */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

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

body {
  min-height: 100%;
  margin: 0;
  background: var(--bg);
  background-image:
    radial-gradient(ellipse at 20% 0%, rgba(124, 58, 237, 0.25) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 100%, rgba(236, 72, 153, 0.15) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 50%, rgba(56, 189, 248, 0.08) 0%, transparent 60%);
  color: var(--text);
  font-family: "Kanit", sans-serif;
  font-weight: 400;
  line-height: 1.6;
}

body.is-menu-open {
  overflow: hidden;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input,
select {
  font: inherit;
}

img {
  max-width: 100%;
  display: block;
}

/* --- App Shell --- */
.app-shell {
  width: min(100%, 430px);
  margin: 0 auto;
  min-height: 100vh;
  background: linear-gradient(180deg, #f8f4ff 0%, #ffffff 15%, #fff9fc 60%, #f5f0ff 100%);
  position: relative;
  overflow: hidden;
  box-shadow:
    -1px 0 0 rgba(124, 58, 237, 0.08),
    1px 0 0 rgba(124, 58, 237, 0.08),
    0 0 80px rgba(124, 58, 237, 0.1);
}

/* --- Top Bar --- */
.topbar {
  position: sticky;
  top: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: calc(12px + env(safe-area-inset-top)) 16px 14px;
  background: linear-gradient(135deg, #1a0533 0%, #2d1065 50%, #1a0533 100%);
  color: #fff;
  border-bottom: 1px solid rgba(168, 85, 247, 0.2);
}

.topbar::after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--neon-purple), var(--neon-pink), var(--neon-blue), transparent);
  opacity: 0.6;
}

.topbar-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}

.topbar__menu-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  border: 0;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  cursor: pointer;
  transition: background 0.2s, transform 0.15s;
}

.topbar__menu-btn:active {
  transform: scale(0.92);
  background: rgba(255, 255, 255, 0.15);
}

.topbar__icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  padding: 0;
  border: 0;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  cursor: pointer;
  transition: all 0.2s;
}

.topbar__icon-btn:hover {
  background: rgba(255, 255, 255, 0.16);
}

.topbar__icon-btn--ghost {
  opacity: 0.5;
  cursor: default;
}

/* --- Drawer Menu --- */
.menu-backdrop {
  position: fixed;
  top: 0;
  bottom: 0;
  left: calc(50% - min(100%, 430px) / 2);
  width: min(100%, 430px);
  background: rgba(7, 4, 16, 0.42);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.24s ease;
  z-index: 110;
}

.menu-drawer {
  position: fixed;
  top: 0;
  bottom: 0;
  left: calc(50% - min(100%, 430px) / 2);
  width: min(88vw, 360px);
  padding: calc(18px + env(safe-area-inset-top)) 18px calc(18px + env(safe-area-inset-bottom));
  background: linear-gradient(180deg, rgba(18, 3, 34, 0.98) 0%, rgba(35, 10, 66, 0.98) 100%);
  color: #fff;
  transform: translateX(calc(-100% - 24px));
  transition: transform 0.28s cubic-bezier(0.16, 1, 0.3, 1);
  z-index: 120;
  display: flex;
  flex-direction: column;
  gap: 18px;
  box-shadow: 18px 0 40px rgba(9, 1, 19, 0.3);
}

.menu-drawer__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.menu-drawer__eyebrow {
  margin: 0 0 4px;
  color: rgba(224, 203, 255, 0.72);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.menu-drawer__head h2 {
  margin: 0;
  font-size: 1.4rem;
  line-height: 1.1;
}

.menu-drawer__close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border: 0;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  cursor: pointer;
}

.menu-drawer__nav {
  display: grid;
  gap: 10px;
}

.menu-link {
  display: flex;
  align-items: center;
  min-height: 50px;
  padding: 0 16px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: rgba(248, 245, 255, 0.88);
  font-weight: 600;
  transition: background 0.2s, border-color 0.2s, transform 0.2s;
}

.menu-link.is-active {
  background: linear-gradient(135deg, rgba(124, 58, 237, 0.3), rgba(236, 72, 153, 0.18));
  border-color: rgba(244, 114, 182, 0.34);
  color: #fff;
}

.menu-link:active {
  transform: scale(0.98);
}

.menu-drawer__logout {
  margin-top: auto;
}

body.is-menu-open .menu-backdrop {
  opacity: 1;
  pointer-events: auto;
}

body.is-menu-open .menu-drawer {
  transform: translateX(0);
}

/* --- Logo --- */
.logo-mark {
  display: flex;
  flex-direction: column;
  align-items: center;
  line-height: 1;
  transform: translateY(-1px);
}

.logo-mark__main {
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  background: linear-gradient(180deg, #c084fc 0%, #f0abfc 30%, #fbbf24 60%, #f472b6 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));
  text-shadow: none;
}

.logo-mark__sub {
  font-size: 0.52rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  color: rgba(196, 181, 253, 0.7);
  margin-top: 2px;
}

/* --- Page Content --- */
.page {
  padding: 20px 14px calc(90px + env(safe-area-inset-bottom));
}

/* --- Flash Messages --- */
.flash {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  padding: 14px 16px;
  border-radius: var(--radius-md);
  font-size: 0.92rem;
  font-weight: 500;
  animation: flashSlideIn 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.flash__icon {
  display: flex;
  flex-shrink: 0;
}

.flash--success {
  background: var(--success);
  color: var(--success-text);
  border: 1px solid rgba(6, 95, 70, 0.15);
}

.flash--error {
  background: var(--error);
  color: var(--error-text);
  border: 1px solid rgba(159, 18, 57, 0.15);
}

@keyframes flashSlideIn {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ============================================
   HERO PANEL
   ============================================ */
.hero-panel {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  margin-bottom: 24px;
  min-height: 280px;
  display: flex;
  align-items: flex-end;
  box-shadow: var(--shadow);
}

.hero-panel__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

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

.hero-panel__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(26, 5, 51, 0.1) 0%,
    rgba(26, 5, 51, 0.3) 40%,
    rgba(26, 5, 51, 0.85) 100%
  );
}

.hero-panel__content {
  position: relative;
  z-index: 2;
  padding: 24px 20px;
  width: 100%;
}

.hero-panel__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin: 0 0 10px;
  padding: 5px 12px;
  border-radius: 999px;
  background: rgba(124, 58, 237, 0.25);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(168, 85, 247, 0.3);
  color: #e0cbff;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.68rem;
  font-weight: 700;
}

.hero-panel__eyebrow-icon {
  font-size: 0.9rem;
}

.hero-panel h1 {
  margin: 0;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 800;
  line-height: 1.2;
  text-shadow: 0 2px 20px rgba(0, 0, 0, 0.4);
}

.hero-panel__copy {
  margin: 10px 0 0;
  color: rgba(255, 255, 255, 0.7);
  font-size: 0.88rem;
  line-height: 1.5;
  font-weight: 400;
}

/* ============================================
   SECTION TITLE
   ============================================ */
.section-title {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
  padding: 0 4px;
}

.section-title__line {
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(124, 58, 237, 0.2), transparent);
}

.section-title__text {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--primary);
  white-space: nowrap;
  letter-spacing: 0.02em;
}

.section-title__icon {
  font-size: 1.1rem;
}

/* ============================================
   BUTTONS
   ============================================ */
.primary-button,
.secondary-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 48px;
  padding: 0 22px;
  border-radius: 14px;
  border: 0;
  cursor: pointer;
  font-weight: 700;
  font-size: 0.95rem;
  transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}

.primary-button {
  margin-top: 16px;
  background: linear-gradient(135deg, #7c3aed 0%, #a855f7 50%, #ec4899 100%);
  color: #fff;
  box-shadow: 0 8px 24px rgba(124, 58, 237, 0.35);
  position: relative;
  overflow: hidden;
}

.primary-button::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.2), transparent);
  opacity: 0;
  transition: opacity 0.2s;
}

.primary-button:active {
  transform: scale(0.96);
}

.primary-button:active::before {
  opacity: 1;
}

.primary-button--glow {
  animation: buttonPulse 3s ease-in-out infinite;
}

@keyframes buttonPulse {
  0%, 100% {
    box-shadow: 0 8px 24px rgba(124, 58, 237, 0.35);
  }
  50% {
    box-shadow: 0 8px 36px rgba(124, 58, 237, 0.55), 0 0 20px rgba(168, 85, 247, 0.2);
  }
}

.primary-button__icon {
  display: flex;
  align-items: center;
}

.primary-button--full,
.secondary-button--compact {
  width: 100%;
}

.secondary-button {
  background: rgba(124, 58, 237, 0.08);
  color: var(--primary);
  border: 1px solid rgba(124, 58, 237, 0.12);
}

.secondary-button:active {
  background: rgba(124, 58, 237, 0.15);
}

/* ============================================
   FEED LIST & CARDS
   ============================================ */
.feed-list,
.audit-list {
  display: grid;
  gap: 20px;
}

.feed-card {
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(124, 58, 237, 0.06);
  box-shadow: var(--shadow-card);
  transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.3s;
}

.feed-card:active {
  transform: scale(0.98);
}

.feed-card__link {
  display: block;
}

/* --- Banner with Image --- */
.banner {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
}

.banner__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.feed-card:active .banner__image {
  transform: scale(1.05);
}

.banner__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0, 0, 0, 0.15) 100%);
  pointer-events: none;
}

.banner__labels {
  position: absolute;
  top: 10px;
  left: 10px;
  right: 10px;
  display: flex;
  justify-content: space-between;
  z-index: 3;
}

.banner__label {
  padding: 4px 10px;
  border-radius: 8px;
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.banner__label--left {
  background: rgba(255, 255, 255, 0.92);
  color: var(--primary);
  backdrop-filter: blur(8px);
}

.banner__label--right {
  background: linear-gradient(135deg, #ec4899, #f472b6);
  color: #fff;
  box-shadow: 0 2px 8px rgba(236, 72, 153, 0.3);
}

.banner__badge-wrap {
  position: absolute;
  bottom: 12px;
  left: 12px;
  z-index: 3;
}

.banner__badge {
  display: inline-block;
  padding: 5px 14px;
  border-radius: 10px;
  background: linear-gradient(135deg, #fbbf24, #f59e0b);
  color: #78350f;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  box-shadow: 0 4px 12px rgba(251, 191, 36, 0.35);
}

/* --- Feed Card Body --- */
.feed-card__body {
  padding: 16px 18px 18px;
}

.feed-card__meta {
  margin-bottom: 8px;
}

.feed-card__date {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 0.78rem;
  color: var(--muted);
  font-weight: 500;
}

.feed-card__date svg {
  opacity: 0.6;
}

.feed-card__body h3 {
  margin: 0 0 6px;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.2;
  color: var(--text);
}

.feed-card__subtitle {
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.5;
}

.feed-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 14px;
  padding: 8px 16px;
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(124, 58, 237, 0.08), rgba(168, 85, 247, 0.12));
  color: var(--primary);
  font-size: 0.82rem;
  font-weight: 600;
  transition: background 0.2s;
}

/* ============================================
   PANELS (Profile, Admin, etc.)
   ============================================ */
.hero-panel.panel-style,
.panel {
  background: #fff;
  border: 1px solid rgba(124, 58, 237, 0.06);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-card);
}

.panel {
  padding: 20px;
}

.panel--narrow {
  margin: 0 auto;
}

.profile-panel {
  margin-bottom: 18px;
}

.profile-card {
  display: grid;
  grid-template-columns: 104px 1fr;
  gap: 16px;
  align-items: center;
}

.profile-card__media,
.user-card__avatar {
  width: 104px;
  height: 104px;
  border-radius: 28px;
  overflow: hidden;
  background: linear-gradient(135deg, #ede9fe, #fce7f3);
  display: grid;
  place-items: center;
  color: var(--muted);
  text-align: center;
  font-weight: 600;
  box-shadow: 0 4px 16px rgba(124, 58, 237, 0.1);
}

.profile-card__media img,
.user-card__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.profile-card__media.is-empty {
  border: 2px dashed rgba(124, 58, 237, 0.2);
}

.profile-card__content h1 {
  margin: 0 0 10px;
}

.story-panel {
  display: grid;
  gap: 18px;
}

.story-backlink {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  color: var(--primary);
  font-weight: 600;
}

.story-banner {
  overflow: hidden;
  border-radius: var(--radius-lg);
  aspect-ratio: 16 / 9;
  background: #f4edff;
}

.story-banner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.story-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.story-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(124, 58, 237, 0.08);
  color: var(--primary);
  font-size: 0.82rem;
  font-weight: 600;
}

.story-grid {
  display: grid;
  gap: 14px;
}

.story-card {
  padding: 16px;
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, #fff 0%, #fcf9ff 100%);
  border: 1px solid rgba(124, 58, 237, 0.08);
}

.story-card h2 {
  margin: 0 0 6px;
  font-size: 1rem;
}

.story-card p {
  margin: 0;
  color: var(--muted);
}

/* --- Role Pills --- */
.role-pill {
  display: inline-flex;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.role-pill--power_admin {
  background: linear-gradient(135deg, rgba(236, 72, 153, 0.12), rgba(244, 114, 182, 0.18));
  color: #be185d;
  border: 1px solid rgba(236, 72, 153, 0.15);
}

.role-pill--admin {
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.12), rgba(245, 158, 11, 0.18));
  color: #92400e;
  border: 1px solid rgba(251, 191, 36, 0.2);
}

.role-pill--h_admin {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.12), rgba(14, 165, 233, 0.18));
  color: #1d4ed8;
  border: 1px solid rgba(59, 130, 246, 0.18);
}

.role-pill--user {
  background: rgba(124, 58, 237, 0.08);
  color: var(--primary);
  border: 1px solid rgba(124, 58, 237, 0.1);
}

.role-pill--banned {
  background: rgba(239, 68, 68, 0.12);
  color: #b91c1c;
  border: 1px solid rgba(239, 68, 68, 0.2);
}

/* --- Forms --- */
.stack-form {
  display: grid;
  gap: 16px;
}

.field {
  display: grid;
  gap: 8px;
}

.field span {
  font-weight: 600;
  font-size: 0.92rem;
  color: var(--text);
}

.field input,
.field textarea,
.field select,
.inline-form select {
  width: 100%;
  min-height: 48px;
  padding: 0 16px;
  border: 1.5px solid rgba(124, 58, 237, 0.12);
  border-radius: 14px;
  background: #fff;
  color: var(--text);
  font-size: 0.95rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.field textarea {
  min-height: 110px;
  padding: 14px 16px;
  resize: vertical;
}

.field select {
  appearance: none;
}

.field input:focus,
.field textarea:focus,
.field select:focus,
.inline-form select:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.1);
}

.field input[type="file"] {
  padding: 12px;
}

.checkbox-row {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--muted);
}

/* --- Section Headers --- */
.section-head--split {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 18px;
}

.section-head__eyebrow {
  margin: 0 0 8px;
  color: var(--primary-2);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.72rem;
  font-weight: 700;
}

.section-head h1,
.section-head h2 {
  margin: 0;
  line-height: 1.2;
}

.section-head p {
  margin: 10px 0 0;
  color: var(--muted);
  line-height: 1.5;
}

/* --- Admin & Audit Cards --- */
.admin-grid {
  display: grid;
  gap: 14px;
}

.admin-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.admin-section {
  margin-top: 18px;
}

.user-card,
.audit-card {
  background: #fff;
  border: 1px solid rgba(124, 58, 237, 0.06);
  border-radius: var(--radius-lg);
  padding: 16px;
  box-shadow: 0 2px 12px rgba(30, 0, 80, 0.05);
  transition: box-shadow 0.2s;
}

.user-card {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 14px;
  align-items: start;
}

.user-card__media {
  display: grid;
  justify-items: center;
  gap: 8px;
}

.user-card__avatar {
  width: 72px;
  height: 72px;
  border-radius: 22px;
}

.user-card__media .role-pill,
.user-card__toggle-form {
  justify-content: center;
  width: 100%;
  max-width: 96px;
}

.user-card__media .role-pill {
  padding-inline: 10px;
  font-size: 0.7rem;
}

.user-card__status-trigger {
  appearance: none;
  cursor: pointer;
  font: inherit;
  text-align: center;
}

.user-card__status-trigger:hover {
  filter: brightness(0.98);
}

.user-card__role-form {
  display: none;
}

.user-card__toggle-form {
  display: flex;
}

.user-card__toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 34px;
  padding: 0 14px;
  border: 0;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  cursor: pointer;
}

.user-card__toggle--ban {
  background: rgba(239, 68, 68, 0.12);
  color: #b91c1c;
}

.user-card__toggle--active {
  background: rgba(16, 185, 129, 0.12);
  color: #047857;
}

.user-card__ban-note {
  color: #b91c1c;
  font-weight: 500;
}

.user-card__action-row {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.user-card__action-row.is-single {
  grid-template-columns: 1fr;
}

.user-card__action-form {
  display: flex;
}

.user-card__action-row .secondary-button {
  width: 100%;
  justify-content: center;
}

.user-card__delete-button {
  width: 100%;
  border-color: rgba(239, 68, 68, 0.22);
  color: #b91c1c;
  background: rgba(254, 242, 242, 0.92);
}

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

.is-role-picker-open {
  overflow: hidden;
}

.role-picker-modal {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: grid;
  place-items: end center;
  padding: 16px;
}

.role-picker-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.52);
  backdrop-filter: blur(6px);
}

.role-picker-modal__dialog {
  position: relative;
  width: min(100%, 420px);
  padding: 20px;
  border-radius: 28px;
  background: #fff;
  box-shadow: 0 20px 50px rgba(15, 23, 42, 0.22);
}

.role-picker-modal__options {
  display: grid;
  gap: 10px;
  margin: 16px 0 18px;
}

.role-picker-modal__option {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 16px;
  border: 1px solid rgba(124, 58, 237, 0.12);
  border-radius: 16px;
  background: #fff;
  color: var(--text);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}

.role-picker-modal__option.is-current {
  border-color: rgba(124, 58, 237, 0.22);
  background: rgba(124, 58, 237, 0.06);
  color: var(--primary);
}

.role-picker-modal__cancel {
  width: 100%;
  justify-content: center;
}

.user-card__avatar.is-empty {
  border: 1.5px dashed rgba(124, 58, 237, 0.18);
}

.user-card__body h2,
.audit-card__header h2 {
  margin: 0 0 4px;
  font-size: 1.05rem;
}

.user-card__body p,
.audit-card__header p,
.audit-card__grid p {
  margin: 0;
  color: var(--muted);
  word-break: break-word;
  font-size: 0.88rem;
}

.inline-form {
  grid-column: 1 / -1;
  display: grid;
  gap: 10px;
}

.promo-grid {
  display: grid;
  gap: 18px;
}

.promo-card {
  border: 1px solid rgba(124, 58, 237, 0.08);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, #fff 0%, #fcf9ff 100%);
  overflow: hidden;
  box-shadow: 0 4px 18px rgba(30, 0, 80, 0.06);
}

.promo-card__preview {
  aspect-ratio: 16 / 9;
  background: #f4edff;
}

.promo-card__preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.promo-card__meta {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 16px 0;
}

.promo-card__meta h3 {
  margin: 0 0 4px;
  font-size: 1.05rem;
}

.promo-card__meta p {
  margin: 0;
  color: var(--muted);
  font-size: 0.85rem;
}

.promo-form {
  padding: 16px;
}

.promo-form__grid {
  display: grid;
  gap: 14px;
}

.promo-form__full {
  grid-column: 1 / -1;
}

.promo-status {
  display: inline-flex;
  align-items: center;
  height: fit-content;
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  white-space: nowrap;
}

.promo-status.is-active {
  background: rgba(16, 185, 129, 0.12);
  color: #047857;
}

.promo-status.is-inactive {
  background: rgba(148, 163, 184, 0.16);
  color: #475569;
}

.promo-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.promo-actions__grow {
  flex: 1 1 210px;
}

.promo-actions__danger {
  min-width: 96px;
}

.audit-card__header {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 12px;
}

.audit-card__header-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
  width: 100%;
}

.audit-card__header-meta > span {
  color: var(--muted);
  font-size: 0.82rem;
}

.audit-card__map-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  background: linear-gradient(135deg, #22c55e, #16a34a);
  color: #fff;
  box-shadow: 0 10px 18px rgba(34, 197, 94, 0.28);
}

.audit-card__map-button:hover {
  filter: brightness(1.04);
}

.audit-card__grid {
  display: grid;
  gap: 12px;
}

.audit-toolbar {
  display: grid;
  gap: 12px;
  margin-bottom: 20px;
}

.audit-search__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.audit-card__user {
  display: flex;
  align-items: center;
  gap: 14px;
}

.audit-card__content {
  flex: 1;
  min-width: 0;
  display: grid;
  gap: 6px;
}

.audit-card__photo {
  width: 64px;
  height: 64px;
  overflow: hidden;
  border-radius: 18px;
  background: #f3eefc;
  flex-shrink: 0;
}

.audit-card__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.audit-card__photo--empty {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #ede9fe, #ddd6fe);
  color: var(--primary-2);
}

.audit-card__photo-fallback {
  font-size: 1.1rem;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.audit-card__label {
  display: block;
  margin-bottom: 4px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--primary-2);
}

.audit-card__inline {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
}

/* ============================================
   MOBILE NAVIGATION
   ============================================ */
.mobile-nav {
  position: fixed;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: min(100%, 430px);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
  padding: 8px 12px calc(8px + env(safe-area-inset-bottom));
  background: rgba(26, 5, 51, 0.96);
  backdrop-filter: blur(20px);
  border-top: 1px solid rgba(168, 85, 247, 0.15);
  z-index: 50;
}

.mobile-nav::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(168, 85, 247, 0.4), rgba(236, 72, 153, 0.4), transparent);
}

.mobile-nav__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  min-height: 48px;
  padding: 6px 8px;
  border-radius: 14px;
  color: rgba(196, 181, 253, 0.6);
  font-size: 0.72rem;
  font-weight: 600;
  transition: all 0.2s;
}

.mobile-nav__item svg {
  opacity: 0.6;
  transition: opacity 0.2s;
}

.mobile-nav__item.is-active {
  color: #e0cbff;
  background: rgba(124, 58, 237, 0.2);
}

.mobile-nav__item.is-active svg {
  opacity: 1;
}

.mobile-nav__button {
  width: 100%;
  border: 0;
  background: none;
  cursor: pointer;
}

.mobile-nav__button:active {
  background: rgba(255, 255, 255, 0.05);
}

/* ============================================
   ANIMATIONS
   ============================================ */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.hero-panel {
  animation: fadeInUp 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

.section-title {
  animation: fadeInUp 0.6s cubic-bezier(0.16, 1, 0.3, 1) 0.1s both;
}

.feed-card:nth-child(1) {
  animation: fadeInUp 0.6s cubic-bezier(0.16, 1, 0.3, 1) 0.15s both;
}

.feed-card:nth-child(2) {
  animation: fadeInUp 0.6s cubic-bezier(0.16, 1, 0.3, 1) 0.25s both;
}

.feed-card:nth-child(3) {
  animation: fadeInUp 0.6s cubic-bezier(0.16, 1, 0.3, 1) 0.35s both;
}

/* ============================================
   DESKTOP RESPONSIVE
   ============================================ */
@media (min-width: 768px) {
  .app-shell {
    width: min(100% - 32px, 1080px);
    margin: 24px auto;
    border-radius: 32px;
    border: 1px solid rgba(124, 58, 237, 0.08);
  }

  .page {
    padding: 28px 24px 110px;
  }

  .menu-backdrop {
    left: calc(50% - min(100% - 32px, 1080px) / 2);
    width: min(100% - 32px, 1080px);
  }

  .menu-drawer {
    left: calc(50% - min(100% - 32px, 1080px) / 2);
    width: min(360px, 42vw);
  }

  .banner {
    border-radius: var(--radius-xl);
  }

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

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

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

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

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

  .audit-toolbar {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
  }

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

  .section-head--split {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
  }

  .hero-panel {
    min-height: 340px;
  }

  .hero-panel h1 {
    font-size: 2rem;
  }
}
