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

    :root {
      --orange:       #FF5C00;
      --orange-soft:  #FFF0E8;
      --red:          #E8002D;
      --red-soft:     #FFF0F3;
      --bg:           #F7F4F1;
      --surface:      #FFFFFF;
      --border:       #EAEAF0;
      --border-2:     #F2F2F7;
      --text-1:       #0C0C14;
      --text-2:       #5A5A72;
      --text-3:       #9898B0;
      --radius:       16px;
      --radius-sm:    10px;
      --radius-xs:    7px;
      --shadow-sm:    0 1px 3px rgba(12,12,20,0.07), 0 1px 2px rgba(12,12,20,0.04);
      --shadow-md:    0 4px 16px rgba(12,12,20,0.08), 0 2px 6px rgba(12,12,20,0.05);
      --shadow-lg:    0 20px 60px rgba(12,12,20,0.12), 0 8px 20px rgba(12,12,20,0.06);
      --accent:       #FF5C00;
    }

    html { scroll-behavior: smooth; }

    body {
      font-family: 'Inter', sans-serif;
      background: var(--bg);
      color: var(--text-1);
      min-height: 100vh;
      overflow-x: hidden;
    }

    /* ── NAVBAR ─────────────────────────────────────────────── */
    nav {
      position: fixed;
      top: 0; left: 0; right: 0;
      z-index: 200;
      height: 66px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0 5%;
      background: rgba(255,255,255,0.88);
      backdrop-filter: blur(20px);
      -webkit-backdrop-filter: blur(20px);
      border-bottom: 1px solid var(--border);
      box-shadow: var(--shadow-sm);
    }

    /* logo */
    .nav-logo {
      display: flex;
      align-items: center;
      gap: 10px;
      text-decoration: none;
      flex-shrink: 0;
    }

    .logo-icon {
      width: 38px; height: 38px;
      display: flex; align-items: center; justify-content: center;
      flex-shrink: 0;
    }

    .logo-text {
      font-size: 20px;
      font-weight: 800;
      letter-spacing: -0.6px;
      color: var(--text-1);
    }

    .logo-text em {
      font-style: normal;
      background: linear-gradient(100deg, var(--orange) 0%, var(--red) 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
    }

    /* center nav */
    .nav-center {
      display: flex;
      align-items: center;
      gap: 2px;
    }

    .nav-link {
      font-size: 14px;
      font-weight: 500;
      color: var(--text-2);
      text-decoration: none;
      padding: 7px 13px;
      border-radius: var(--radius-xs);
      transition: color 0.18s, background 0.18s;
      background: none;
      border: none;
      cursor: pointer;
      font-family: inherit;
      white-space: nowrap;
    }

    .nav-link:hover { color: var(--text-1); background: var(--bg); }

    /* dropdown */
    .nav-dropdown { position: relative; }

    .dropdown-trigger {
      display: flex;
      align-items: center;
      gap: 5px;
    }

    .dropdown-trigger svg {
      transition: transform 0.2s;
      color: var(--text-3);
      flex-shrink: 0;
    }

    .nav-dropdown:hover .dropdown-trigger svg { transform: rotate(180deg); color: var(--text-2); }

    .dropdown-panel {
      position: absolute;
      top: 100%;
      left: 50%;
      transform: translateX(-50%) translateY(-6px);
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      box-shadow: var(--shadow-lg);
      padding: 10px;
      padding-top: 18px; /* visual gap without breaking hover — no actual gap between trigger and panel */
      min-width: 300px;
      opacity: 0;
      pointer-events: none;
      transition: opacity 0.18s, transform 0.18s;
      z-index: 300;
    }

    /* Wider panel + scrollable grid for full sport list */
    .dropdown-panel-sports {
      min-width: 480px;
    }
    .dropdown-grid-sports {
      max-height: 400px;
      overflow-y: auto;
      scrollbar-width: thin;
      scrollbar-color: var(--border) transparent;
    }
    .dropdown-grid-sports::-webkit-scrollbar { width: 5px; }
    .dropdown-grid-sports::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

    .nav-dropdown:hover .dropdown-panel {
      opacity: 1;
      pointer-events: all;
      transform: translateX(-50%) translateY(0);
    }

    .dropdown-title {
      font-size: 11px;
      font-weight: 600;
      color: var(--text-3);
      letter-spacing: 1px;
      text-transform: uppercase;
      padding: 4px 8px 8px;
    }

    .dropdown-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 2px;
    }

    .dropdown-item {
      display: flex;
      align-items: center;
      gap: 9px;
      padding: 9px 10px;
      border-radius: var(--radius-xs);
      font-size: 13px;
      font-weight: 500;
      color: var(--text-2);
      text-decoration: none;
      transition: background 0.15s, color 0.15s;
      cursor: pointer;
      border: none;
      background: none;
      font-family: inherit;
      text-align: left;
    }

    .dropdown-item:hover { background: var(--bg); color: var(--text-1); }

    .dropdown-item .di-icon {
      width: 28px; height: 28px;
      border-radius: 7px;
      display: flex; align-items: center; justify-content: center;
      font-size: 14px;
      flex-shrink: 0;
    }

    /* right nav */
    .nav-right {
      display: flex;
      align-items: center;
      gap: 6px;
    }

    .notif-btn {
      width: 36px; height: 36px;
      border-radius: var(--radius-xs);
      background: none;
      border: 1px solid var(--border);
      display: flex; align-items: center; justify-content: center;
      cursor: pointer;
      position: relative;
      transition: background 0.18s, border-color 0.18s;
      color: var(--text-2);
    }

    .notif-btn:hover { background: var(--bg); color: var(--text-1); border-color: var(--border); }

    .notif-dot {
      position: absolute;
      top: 6px; right: 6px;
      width: 7px; height: 7px;
      border-radius: 50%;
      background: var(--red);
      border: 1.5px solid white;
    }

    .btn-signin {
      font-size: 13px;
      font-weight: 600;
      color: #fff;
      background: linear-gradient(130deg, var(--orange) 0%, var(--red) 100%);
      border: none;
      padding: 8px 18px;
      border-radius: var(--radius-xs);
      cursor: pointer;
      font-family: inherit;
      transition: opacity 0.18s, transform 0.15s, box-shadow 0.18s;
      box-shadow: 0 3px 12px rgba(255,92,0,0.28);
    }

    .btn-signin:hover {
      opacity: 0.92;
      transform: translateY(-1px);
      box-shadow: 0 6px 18px rgba(255,92,0,0.38);
    }

    #fanProfileGearBtn {
      display: none;
    }
    /* ── HERO ───────────────────────────────────────────────── */
    .hero {
      display: flex;
      align-items: center;
      padding: 130px 7% 56px;
      position: relative;
      overflow: hidden;
      background: var(--bg);
    }

    .hero-content {
      position: relative;
      z-index: 1;
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      text-align: left;
      max-width: min(580px, 52%);
      animation: hero-fade-in 0.8s ease forwards;
    }

    @keyframes hero-fade-in {
      from { opacity: 0; transform: translateY(20px); }
      to   { opacity: 1; transform: translateY(0); }
    }

    .hero-pitch {
      position: absolute;
      right: 0;
      top: 0;
      bottom: 0;
      width: 50%;
      overflow: hidden;
      z-index: 0;
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .hero-logo-wrap {
      display: flex;
      flex-direction: column;
      align-items: center;
      padding: 0 7% 0 5%;
      width: 100%;
    }

    .hero-logo-text {
      text-align: center;
      margin-top: 22px;
    }

    .hero-logo-headline {
      font-size: 28px;
      font-weight: 700;
      color: var(--text-1);
      margin: 0 0 7px;
      line-height: 1.2;
    }

    .hero-logo-sub {
      font-size: 15px;
      font-weight: 400;
      color: var(--text-2);
      margin: 0;
      line-height: 1.5;
    }

    .hero-logo-text.fade-up {
      opacity: 0;
      transform: translateY(12px);
      animation: heroTextFadeUp 0.5s ease 0.6s forwards;
    }

    @keyframes heroTextFadeUp {
      to { opacity: 1; transform: translateY(0); }
    }

    .hero-pitch-promo {
      display: flex;
      flex-direction: column;
      padding: 0 7% 0 5%;
      width: 100%;
    }

    .hero-promo-label {
      font-size: 11px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 1.4px;
      color: var(--orange);
      margin: 0 0 16px;
    }

    .hero-promo-list {
      list-style: none;
      display: flex;
      flex-direction: column;
      gap: 12px;
      margin: 0 0 28px;
    }

    .hero-promo-list li {
      display: flex;
      align-items: center;
      gap: 10px;
      font-size: 15px;
      color: var(--text-1);
    }

    .hero-promo-list li::before {
      content: '';
      flex-shrink: 0;
      width: 8px;
      height: 8px;
      border-radius: 50%;
      background: var(--orange);
    }

    .hero-promo-actions {
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      gap: 12px;
    }

    .hero-promo-signin {
      background: none;
      border: none;
      padding: 0;
      font-family: inherit;
      font-size: 14px;
      color: var(--text-2);
      cursor: pointer;
    }

    .hero-promo-signin:hover { color: var(--text-1); }

    .hero-pitch-logo {
      display: flex;
      align-items: center;
      justify-content: center;
      width: 100%;
    }

    /* vertical seam accent between text column and decoration */
    .hero-pitch::before {
      content: '';
      position: absolute;
      left: 0;
      top: 10%;
      bottom: 10%;
      width: 1px;
      background: linear-gradient(
        to bottom,
        transparent,
        rgba(255, 92, 0, 0.18) 25%,
        rgba(255, 92, 0, 0.18) 75%,
        transparent
      );
    }

    .hero-eyebrow {
      position: relative;
      z-index: 1;
      display: inline-flex;
      align-items: center;
      gap: 7px;
      font-size: 12px;
      font-weight: 600;
      letter-spacing: 1.2px;
      text-transform: uppercase;
      color: var(--orange);
      background: var(--orange-soft);
      border: 1px solid rgba(255,92,0,0.18);
      padding: 6px 14px;
      border-radius: 100px;
      margin-bottom: 26px;
    }

    .live-pulse {
      width: 7px; height: 7px;
      background: var(--red);
      border-radius: 50%;
      animation: ripple 1.6s infinite;
    }

    @keyframes ripple {
      0%   { box-shadow: 0 0 0 0 rgba(232,0,45,0.55); }
      70%  { box-shadow: 0 0 0 8px rgba(232,0,45,0); }
      100% { box-shadow: 0 0 0 0 rgba(232,0,45,0); }
    }

    .hero h1 {
      position: relative;
      z-index: 1;
      font-size: clamp(44px, 8.5vw, 92px);
      font-weight: 900;
      line-height: 0.96;
      letter-spacing: -4px;
      color: var(--text-1);
      margin-bottom: 22px;
    }

    .hero h1 .grad {
      background: linear-gradient(100deg, var(--orange) 0%, var(--red) 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
    }

    .hero p {
      position: relative;
      z-index: 1;
      font-size: clamp(15px, 2.2vw, 17px);
      color: var(--text-2);
      max-width: 500px;
      line-height: 1.7;
      margin-bottom: 40px;
    }

    .hero-cta {
      position: relative;
      z-index: 1;
      display: flex;
      align-items: center;
      gap: 12px;
      flex-wrap: wrap;
      justify-content: flex-start;
    }

    .btn-primary {
      display: inline-flex;
      align-items: center;
      gap: 9px;
      font-size: 15px;
      font-weight: 700;
      color: #fff;
      background: linear-gradient(130deg, var(--orange) 0%, var(--red) 100%);
      border: none;
      padding: 14px 30px;
      border-radius: var(--radius-sm);
      cursor: pointer;
      font-family: inherit;
      text-decoration: none;
      transition: transform 0.18s, box-shadow 0.18s;
      box-shadow: 0 6px 24px rgba(255,92,0,0.35);
    }

    .btn-primary:hover { transform: translateY(-2px); box-shadow: 0 10px 32px rgba(255,92,0,0.48); }
    .btn-primary svg { transition: transform 0.18s; }
    .btn-primary:hover svg { transform: translateX(3px); }

    .btn-ghost {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-size: 14px;
      font-weight: 600;
      color: var(--text-2);
      background: none;
      border: 1px solid var(--border);
      padding: 13px 22px;
      border-radius: var(--radius-sm);
      cursor: pointer;
      font-family: inherit;
      text-decoration: none;
      transition: color 0.18s, border-color 0.18s, background 0.18s;
    }

    .btn-ghost:hover { color: var(--text-1); border-color: #C8C8D8; background: var(--bg); }

    /* confirm password error */
    .auth-input.input-error {
      border-color: var(--red);
      box-shadow: 0 0 0 3px rgba(232,0,45,0.10);
    }
    .auth-error-msg {
      font-size: 11px;
      color: var(--red);
      font-weight: 600;
      margin-top: 1px;
      display: none;
    }
    .auth-error-msg.show { display: block; }

    /* ── EVENTS SECTION ─────────────────────────────────────── */
    .events-section {
      position: relative;
      overflow: hidden;
      max-width: 1400px;
      margin: 0 auto;
      padding: 48px 5% 96px;
    }

    .events-section::before,
    .events-section::after {
      content: '';
      position: absolute;
      top: 0;
      bottom: 0;
      width: 40px;
      pointer-events: none;
      background: repeating-linear-gradient(
        -45deg,
        rgba(255, 92, 0, 0.03) 0px,
        rgba(255, 92, 0, 0.03) 2px,
        transparent 2px,
        transparent 12px
      );
    }

    .events-section::before {
      left: 0;
      border-right: 1px solid rgba(255, 92, 0, 0.07);
    }

    .events-section::after {
      right: 0;
      border-left: 1px solid rgba(255, 92, 0, 0.07);
    }

    .section-header {
      margin-bottom: 20px;
    }

    /* ── Events search bar ─────────────────────────────────── */
    .events-search-wrap {
      margin-bottom: 14px;
    }
    .events-search-inner {
      position: relative;
      display: flex;
      align-items: center;
    }
    .events-search-icon {
      position: absolute;
      left: 13px;
      color: var(--text-3);
      pointer-events: none;
      flex-shrink: 0;
    }
    .events-search-input {
      width: 100%;
      padding: 10px 40px 10px 38px;
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius-sm);
      color: var(--text-1);
      font-size: 14px;
      font-family: inherit;
      transition: border-color .15s;
      -webkit-appearance: none;
      appearance: none;
    }
    .events-search-input::-webkit-search-cancel-button { display: none; }
    .events-search-input::placeholder { color: var(--text-3); }
    .events-search-input:focus {
      outline: none;
      border-color: var(--orange);
    }
    .events-search-clear {
      position: absolute;
      right: 10px;
      width: 22px;
      height: 22px;
      display: flex;
      align-items: center;
      justify-content: center;
      background: var(--border-2);
      border: none;
      border-radius: 50%;
      color: var(--text-2);
      cursor: pointer;
      padding: 0;
    }
    .events-search-clear:hover { background: var(--border); }

    .filter-bar-wrap {
      overflow-x: auto;
      -webkit-overflow-scrolling: touch;
      margin-bottom: 28px;
      /* hide scrollbar but keep scrollable */
      scrollbar-width: none;
    }
    .filter-bar-wrap::-webkit-scrollbar { display: none; }

    .section-eyebrow {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 1.4px;
      text-transform: uppercase;
      color: var(--orange);
      margin-bottom: 6px;
    }

    .section-title {
      font-size: clamp(24px, 4vw, 34px);
      font-weight: 800;
      letter-spacing: -1px;
      line-height: 1.1;
      color: var(--text-1);
    }

    .filter-bar {
      display: flex;
      gap: 6px;
      flex-wrap: nowrap;    /* single scrollable row */
      width: max-content;   /* allow it to be wider than container */
    }

    .filter-pill {
      font-size: 13px;
      font-weight: 600;
      color: var(--text-2);
      background: var(--surface);
      border: 1px solid var(--border);
      padding: 7px 16px;
      border-radius: 100px;
      cursor: pointer;
      font-family: inherit;
      transition: color 0.18s, background 0.18s, border-color 0.18s, box-shadow 0.18s;
      box-shadow: var(--shadow-sm);
    }

    .filter-pill:hover {
      border-color: rgba(255,92,0,0.3);
      color: var(--orange);
      background: var(--orange-soft);
    }

    .filter-pill.active {
      color: var(--orange);
      background: var(--orange-soft);
      border-color: rgba(255,92,0,0.3);
    }

    /* ── ADVANCED FILTER BAR ────────────────────────────────── */
    .advanced-filter-bar {
      display: flex;
      align-items: center;
      gap: 8px;
      flex-wrap: wrap;
      padding: 10px 14px;
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      margin-bottom: 28px;
      box-shadow: var(--shadow-sm);
    }

    .afb-group {
      display: flex;
      align-items: center;
      gap: 5px;
      flex-wrap: wrap;
    }

    .afb-sep {
      width: 1px;
      height: 22px;
      background: var(--border);
      flex-shrink: 0;
    }

    .afb-select {
      font-size: 13px;
      font-weight: 600;
      color: var(--text-2);
      background: var(--bg);
      border: 1px solid var(--border);
      padding: 6px 28px 6px 10px;
      border-radius: 100px;
      cursor: pointer;
      font-family: inherit;
      appearance: none;
      -webkit-appearance: none;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%239898B0' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
      background-repeat: no-repeat;
      background-position: right 9px center;
      transition: border-color 0.15s, color 0.15s;
    }
    .afb-select:focus { outline: none; border-color: var(--orange); color: var(--text-1); }
    .afb-select:hover { border-color: rgba(255,92,0,0.3); color: var(--orange); }

    .afb-quick {
      font-size: 12px;
      font-weight: 600;
      color: var(--text-2);
      background: var(--bg);
      border: 1px solid var(--border);
      padding: 6px 12px;
      border-radius: 100px;
      cursor: pointer;
      font-family: inherit;
      transition: color 0.15s, background 0.15s, border-color 0.15s;
    }
    .afb-quick:hover { border-color: rgba(255,92,0,0.3); color: var(--orange); background: var(--orange-soft); }
    .afb-quick.active { color: var(--orange); background: var(--orange-soft); border-color: rgba(255,92,0,0.3); }

    .afb-daterange { gap: 5px; }

    .afb-date-input {
      font-size: 12px;
      font-weight: 600;
      color: var(--text-2);
      background: var(--bg);
      border: 1px solid var(--border);
      padding: 5px 9px;
      border-radius: 100px;
      font-family: inherit;
      cursor: pointer;
      transition: border-color 0.15s;
    }
    .afb-date-input:focus { outline: none; border-color: var(--orange); }
    .afb-date-input:hover { border-color: rgba(255,92,0,0.3); }

    .afb-dash { font-size: 12px; color: var(--text-3); }

    .afb-clear {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      font-size: 12px;
      font-weight: 600;
      color: var(--text-2);
      background: none;
      border: 1px solid var(--border);
      padding: 5px 12px;
      border-radius: 100px;
      cursor: pointer;
      font-family: inherit;
      margin-left: auto;
      transition: color 0.15s, border-color 0.15s;
    }
    .afb-clear:hover { color: var(--red); border-color: rgba(232,0,45,0.3); }

    /* empty state */
    .empty-state {
      grid-column: 1 / -1;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      padding: 72px 24px;
      text-align: center;
      gap: 10px;
    }
    .empty-state p { font-size: 15px; color: var(--text-2); font-weight: 500; }

    /* ── CARDS GRID ─────────────────────────────────────────── */
    .events-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 22px;
    }

    @media (max-width: 1100px) { .events-grid { grid-template-columns: repeat(2, 1fr); } }
    @media (max-width: 640px)  { .events-grid { grid-template-columns: 1fr; } }

    /* ── EVENT CARD ─────────────────────────────────────────── */
    .event-card {
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      overflow: hidden;
      transition: transform 0.25s, box-shadow 0.25s, border-color 0.25s;
      cursor: pointer;
      touch-action: manipulation; /* prevents 300ms tap delay on mobile */
      display: flex;
      flex-direction: column;
      box-shadow: var(--shadow-sm);
    }

    .event-card:hover {
      transform: translateY(-5px);
      box-shadow: 0 20px 52px rgba(12,12,20,0.1), 0 6px 16px rgba(12,12,20,0.06);
      border-color: rgba(255,92,0,0.2);
    }

    /* thumbnail */
    .card-thumb {
      position: relative;
      height: 200px;
      overflow: hidden;
      flex-shrink: 0;
    }

    .card-thumb-art {
      position: absolute;
      inset: 0;
      transition: transform 0.35s;
    }

    .event-card:hover .card-thumb-art { transform: scale(1.06); }

    /* hover overlay with View Details */
    .card-thumb-overlay {
      position: absolute;
      inset: 0;
      background: rgba(12,12,20,0.52);
      display: flex;
      align-items: center;
      justify-content: center;
      opacity: 0;
      transition: opacity 0.22s;
    }

    .event-card:hover .card-thumb-overlay { opacity: 1; }

    .btn-view-details {
      font-size: 13px;
      font-weight: 700;
      color: var(--text-1);
      background: #fff;
      border: none;
      padding: 10px 22px;
      border-radius: 100px;
      cursor: pointer;
      font-family: inherit;
      display: flex;
      align-items: center;
      gap: 7px;
      box-shadow: 0 4px 18px rgba(0,0,0,0.25);
      transition: transform 0.15s;
    }

    .btn-view-details:hover { transform: scale(1.04); }

    /* badges on thumb */
    .card-cat-badge {
      position: absolute;
      top: 12px; left: 12px;
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.5px;
      color: #fff;
      background: rgba(12,12,20,0.55);
      backdrop-filter: blur(8px);
      padding: 4px 11px;
      border-radius: 100px;
      border: 1px solid rgba(255,255,255,0.15);
      z-index: 2;
    }

    .card-price-badge {
      position: absolute;
      top: 12px; right: 12px;
      display: inline-flex;
      align-items: center;
      gap: 5px;
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.5px;
      color: #fff;
      padding: 4px 11px;
      border-radius: 100px;
      z-index: 2;
    }

    .card-price-badge.free {
      background: #16A34A;
    }

    .card-price-badge.paid {
      background: var(--orange);
    }

    /* card body */
    .card-body {
      padding: 18px 20px 20px;
      display: flex;
      flex-direction: column;
      flex: 1;
    }

    .card-event-name {
      font-size: 15px;
      font-weight: 700;
      color: var(--text-1);
      line-height: 1.35;
      margin-bottom: 5px;
    }

    .card-organiser {
      font-size: 12px;
      font-weight: 500;
      color: var(--text-3);
      margin-bottom: 10px;
      display: block;
    }
    .card-organiser-link {
      background: none;
      border: none;
      padding: 0;
      font-family: inherit;
      cursor: pointer;
      text-align: left;
      transition: color 0.15s;
    }
    .card-organiser-link:hover { color: var(--orange); }

    .card-meta-list {
      display: flex;
      flex-direction: column;
      gap: 8px;
      flex: 1;
    }

    .card-meta-row {
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 13px;
      color: var(--text-2);
    }

    .meta-icon {
      width: 28px; height: 28px;
      background: var(--bg);
      border-radius: 7px;
      display: flex; align-items: center; justify-content: center;
      flex-shrink: 0;
      color: var(--text-3);
    }

    .meta-icon svg { display: block; }

    .meta-label {
      font-size: 10px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.8px;
      color: var(--text-3);
      margin-right: 2px;
    }

    .meta-value { font-weight: 500; color: var(--text-1); }

    /* ── SPORT THUMBNAILS (CSS art) ──────────────────────── */

    /* Football */
    .thumb-football {
      background: linear-gradient(145deg, #1E7B3A 0%, #155E2C 100%);
    }

    .thumb-football::before {
      content: '';
      position: absolute;
      inset: 0;
      background:
        /* center circle */
        radial-gradient(circle 38px at 50% 50%, transparent 36px, rgba(255,255,255,0.25) 36px, rgba(255,255,255,0.25) 38px, transparent 38px),
        /* center spot */
        radial-gradient(circle 3px at 50% 50%, rgba(255,255,255,0.4) 3px, transparent 3px),
        /* halfway line */
        linear-gradient(90deg, transparent 49.5%, rgba(255,255,255,0.2) 49.5%, rgba(255,255,255,0.2) 50.5%, transparent 50.5%),
        /* penalty areas */
        linear-gradient(180deg, transparent 28%, rgba(255,255,255,0.12) 28%, rgba(255,255,255,0.12) 72%, transparent 72%);
    }

    .thumb-football::after {
      content: '⚽';
      position: absolute;
      bottom: 14px; right: 18px;
      font-size: 42px;
      opacity: 0.55;
      filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3));
    }

    /* Basketball */
    .thumb-basketball {
      background: linear-gradient(145deg, #C45A00 0%, #8F3D00 100%);
    }

    .thumb-basketball::before {
      content: '';
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle 55px at 50% 50%, transparent 52px, rgba(255,255,255,0.18) 52px, rgba(255,255,255,0.18) 55px, transparent 55px),
        linear-gradient(180deg, transparent 44%, rgba(255,255,255,0.15) 44%, rgba(255,255,255,0.15) 56%, transparent 56%);
    }

    .thumb-basketball::after {
      content: '🏀';
      position: absolute;
      bottom: 14px; right: 16px;
      font-size: 44px;
      opacity: 0.55;
      filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3));
    }

    /* Tennis */
    .thumb-tennis {
      background: linear-gradient(145deg, #5B8B3E 0%, #3D6228 100%);
    }

    .thumb-tennis::before {
      content: '';
      position: absolute;
      inset: 0;
      background:
        linear-gradient(90deg, transparent 49%, rgba(255,255,255,0.3) 49%, rgba(255,255,255,0.3) 51%, transparent 51%),
        linear-gradient(180deg, transparent 48%, rgba(255,255,255,0.2) 48%, rgba(255,255,255,0.2) 52%, transparent 52%);
    }

    .thumb-tennis::after {
      content: '🎾';
      position: absolute;
      bottom: 14px; right: 16px;
      font-size: 44px;
      opacity: 0.55;
      filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3));
    }

    /* Combat / Boxing / MMA */
    .thumb-combat {
      background: linear-gradient(145deg, #2A1A1A 0%, #1A0D0D 100%);
    }

    .thumb-combat::before {
      content: '';
      position: absolute;
      inset: 0;
      /* octagon-like clip via box-shadow glow */
      background:
        radial-gradient(ellipse 65% 55% at 50% 50%, rgba(232,0,45,0.15) 0%, transparent 70%);
    }

    .thumb-combat::after {
      content: '🥊';
      position: absolute;
      bottom: 14px; right: 16px;
      font-size: 44px;
      opacity: 0.6;
      filter: drop-shadow(0 4px 8px rgba(0,0,0,0.4));
    }

    /* Cycling */
    .thumb-cycling {
      background: linear-gradient(145deg, #1A3A5C 0%, #0D2240 100%);
    }

    .thumb-cycling::after {
      content: '🚴';
      position: absolute;
      bottom: 14px; right: 16px;
      font-size: 44px;
      opacity: 0.55;
      filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3));
    }

    /* Golf */
    .thumb-golf {
      background: linear-gradient(145deg, #2E5E2E 0%, #1A3D1A 100%);
    }

    .thumb-golf::after {
      content: '⛳';
      position: absolute;
      bottom: 14px; right: 16px;
      font-size: 44px;
      opacity: 0.55;
      filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3));
    }

    /* Running */
    .thumb-running { background: linear-gradient(145deg, #B04A1A 0%, #7A2D0A 100%); }
    .thumb-running::after { content: '🏃'; position: absolute; bottom: 14px; right: 16px; font-size: 44px; opacity: 0.55; filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3)); }

    /* Swimming */
    .thumb-swimming { background: linear-gradient(145deg, #1565A8 0%, #0D3F72 100%); }
    .thumb-swimming::after { content: '🏊'; position: absolute; bottom: 14px; right: 16px; font-size: 44px; opacity: 0.55; filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3)); }

    /* American Football */
    .thumb-american-football { background: linear-gradient(145deg, #7B4A1E 0%, #4A2A08 100%); }
    .thumb-american-football::after { content: '🏈'; position: absolute; bottom: 14px; right: 16px; font-size: 44px; opacity: 0.55; filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3)); }

    /* Volleyball */
    .thumb-volleyball { background: linear-gradient(145deg, #1A5A8A 0%, #0D3358 100%); }
    .thumb-volleyball::after { content: '🏐'; position: absolute; bottom: 14px; right: 16px; font-size: 44px; opacity: 0.55; filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3)); }

    /* Rugby */
    .thumb-rugby { background: linear-gradient(145deg, #1E5C2E 0%, #0D3518 100%); }
    .thumb-rugby::after { content: '🏉'; position: absolute; bottom: 14px; right: 16px; font-size: 44px; opacity: 0.55; filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3)); }

    /* Baseball */
    .thumb-baseball { background: linear-gradient(145deg, #5C3A1E 0%, #3A2008 100%); }
    .thumb-baseball::after { content: '⚾'; position: absolute; bottom: 14px; right: 16px; font-size: 44px; opacity: 0.55; filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3)); }

    /* Hockey */
    .thumb-hockey { background: linear-gradient(145deg, #1A2E50 0%, #0D1A30 100%); }
    .thumb-hockey::after { content: '🏒'; position: absolute; bottom: 14px; right: 16px; font-size: 44px; opacity: 0.55; filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3)); }

    /* Esports */
    .thumb-esports { background: linear-gradient(145deg, #2D1A5C 0%, #180D3A 100%); }
    .thumb-esports::after { content: '🎮'; position: absolute; bottom: 14px; right: 16px; font-size: 44px; opacity: 0.55; filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3)); }

    /* Athletics */
    .thumb-athletics { background: linear-gradient(145deg, #8A2A1A 0%, #581508 100%); }
    .thumb-athletics::after { content: '🏅'; position: absolute; bottom: 14px; right: 16px; font-size: 44px; opacity: 0.55; filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3)); }

    /* Other / fallback */
    .thumb-other { background: linear-gradient(145deg, #3A3A4A 0%, #22222E 100%); }
    .thumb-other::after { content: '🏆'; position: absolute; bottom: 14px; right: 16px; font-size: 44px; opacity: 0.55; filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3)); }

    /* SVG stadium art overlay */
    .thumb-svg {
      position: absolute;
      inset: 0;
      display: flex;
      align-items: center;
      justify-content: center;
      opacity: 0.12;
    }

    /* ── LOAD MORE ───────────────────────────────────────── */
    .load-more-wrap {
      text-align: center;
      margin-top: 48px;
    }

    /* ── FOOTER ──────────────────────────────────────────── */
    footer {
      border-top: 1px solid var(--border);
      background: var(--surface);
      padding: 36px 5%;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      flex-wrap: wrap;
    }

    .footer-left {
      display: flex;
      align-items: center;
      gap: 10px;
    }

    .footer-copy {
      font-size: 13px;
      color: var(--text-3);
    }

    .footer-links {
      display: flex;
      gap: 20px;
      flex-wrap: wrap;
    }

    .footer-links a {
      font-size: 13px;
      font-weight: 500;
      color: var(--text-3);
      text-decoration: none;
      transition: color 0.18s;
    }

    .footer-links a:hover { color: var(--text-1); }

    /* ── STATIC CONTENT PAGES ────────────────────────────── */
    .static-page-body {
      padding: 0;
    }
    .static-page-content {
      max-width: 680px;
      margin: 0 auto;
      padding: 40px 24px 80px;
    }
    .static-hero {
      margin-bottom: 36px;
    }
    .static-h1 {
      font-size: 28px;
      font-weight: 800;
      line-height: 1.2;
      color: var(--text-1);
      margin: 0 0 14px;
    }
    .static-lead {
      font-size: 16px;
      line-height: 1.65;
      color: var(--text-2);
      margin: 0;
    }
    .static-h2 {
      font-size: 16px;
      font-weight: 700;
      color: var(--text-1);
      margin: 32px 0 10px;
    }
    .static-page-content p {
      font-size: 14px;
      line-height: 1.7;
      color: var(--text-2);
      margin: 0 0 14px;
    }
    .static-meta {
      font-size: 12px;
      color: var(--text-3);
      margin-bottom: 24px !important;
    }
    .static-list {
      margin: 0 0 14px;
      padding-left: 20px;
    }
    .static-list li {
      font-size: 14px;
      line-height: 1.7;
      color: var(--text-2);
      margin-bottom: 6px;
    }
    .static-link {
      color: var(--orange);
      text-decoration: none;
    }
    .static-link:hover { text-decoration: underline; }

    /* Contact card */
    .static-contact-card {
      display: flex;
      align-items: flex-start;
      gap: 16px;
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 20px;
      margin-bottom: 36px;
    }
    .static-contact-icon {
      width: 44px;
      height: 44px;
      border-radius: var(--radius-sm);
      background: var(--orange-soft);
      color: var(--orange);
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }
    .static-contact-label {
      font-size: 11px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: .06em;
      color: var(--text-3);
      margin-bottom: 4px;
    }
    .static-contact-email {
      font-size: 15px;
      font-weight: 700;
      color: var(--orange);
      text-decoration: none;
      display: block;
      margin-bottom: 4px;
    }
    .static-contact-email:hover { text-decoration: underline; }
    .static-contact-note {
      font-size: 13px;
      color: var(--text-3);
    }

    /* FAQ */
    .static-faq {
      display: flex;
      flex-direction: column;
      gap: 2px;
      margin-top: 16px;
    }
    .static-faq-item {
      border: 1px solid var(--border);
      border-radius: var(--radius-sm);
      overflow: hidden;
      margin-bottom: 8px;
    }
    .static-faq-q {
      font-size: 14px;
      font-weight: 600;
      color: var(--text-1);
      padding: 14px 16px;
      cursor: default;
    }
    .static-faq-a {
      font-size: 14px;
      line-height: 1.65;
      color: var(--text-2);
      padding: 0 16px 14px;
    }

    .bottom-nav { display: none; }

    /* ── RESPONSIVE ──────────────────────────────────────── */
    @media (max-width: 820px) {
      nav { padding: 0 4%; background: var(--surface); backdrop-filter: none; -webkit-backdrop-filter: none; }
      .overlay-topbar { background: var(--surface); backdrop-filter: none; -webkit-backdrop-filter: none; }
      .nav-center, .notif-btn, .lang-toggle-btn { display: none; }
      #navUser { display: none !important; }
      #fanProfileGearBtn { display: flex; }
      .events-section { padding: 56px 4% 16px; }
      .section-header { margin-bottom: 14px; }
      footer { display: none; }
      body { padding-bottom: calc(60px + env(safe-area-inset-bottom)); }
      .bottom-nav { display: flex; top: auto; }
      #navMyProfile { display: none; }
      .filter-bar-wrap {
        position: sticky;
        top: 66px;
        background: var(--surface);
        z-index: 100;
        border-bottom: 1px solid var(--border);
      }
      .filter-bar {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
      }
      .filter-bar::-webkit-scrollbar { display: none; }
      .card-thumb-overlay { display: none !important; }
      .event-card:hover .card-thumb-art { transform: none; }

      /* ── PULL-TO-REFRESH INDICATOR ── */
      #ptrIndicator {
        display: none;
        justify-content: center;
        align-items: center;
        gap: 8px;
        margin: 0 auto 14px;
        padding: 7px 18px;
        width: fit-content;
        background: var(--surface);
        border: 1px solid var(--border);
        border-radius: 999px;
        font-size: 13px;
        font-weight: 600;
        color: var(--text-2);
        box-shadow: var(--shadow-sm);
      }
      #ptrIndicator.ptr-visible { display: flex; }
      @keyframes ptr-spin {
        to { transform: rotate(360deg); }
      }
      .ptr-spinner {
        width: 14px; height: 14px;
        border: 2px solid var(--border);
        border-top-color: var(--orange);
        border-radius: 50%;
        animation: ptr-spin 0.7s linear infinite;
        flex-shrink: 0;
      }
    }

    /* ── SKELETON SCREENS ─────────────────────────────────────── */
    @keyframes shimmer {
      0%   { transform: translateX(-100%); }
      100% { transform: translateX(100%); }
    }
    .skel {
      display: block;
      border-radius: 6px;
      position: relative;
      overflow: hidden;
      background: var(--border-2);
    }
    .skel::after {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.45) 50%, transparent 100%);
      transform: translateX(-100%);
      animation: shimmer 1.5s ease-in-out infinite;
    }

    @media (max-width: 768px) {
      .hero { padding: 110px 4% 64px; }
      .hero-content { max-width: 100%; }
      .hero-pitch { display: none; }
      .hero h1 { letter-spacing: -2.5px; }
      .hero-stats { gap: 18px; }
      .stat-sep { display: none; }
    }

    @media (max-width: 480px) {
      .hero h1 { letter-spacing: -1.5px; }
      .filter-bar { gap: 5px; }
      .filter-pill { padding: 6px 12px; font-size: 12px; }
    }

    /* ── EMPTY STATE ─────────────────────────────────────── */
    .empty-state {
      grid-column: 1 / -1;
      text-align: center;
      padding: 64px 24px;
    }

    .empty-state p {
      font-size: 15px;
      color: var(--text-3);
    }

    /* ── OVERLAY PAGES ────────────────────────────────────── */
    .overlay-page {
      position: fixed;
      inset: 0;
      z-index: 500;
      background: var(--bg);
      overflow-y: auto;
      overflow-x: hidden;
      transform: translateX(100%);
      transition: transform 0.38s cubic-bezier(0.4, 0, 0.2, 1);
      contain: layout paint;
    }

    .overlay-page.open { transform: translateX(0); }

    .overlay-topbar {
      position: sticky;
      top: 0; z-index: 10;
      background: rgba(255,255,255,0.92);
      backdrop-filter: blur(16px);
      -webkit-backdrop-filter: blur(16px);
      border-bottom: 1px solid var(--border);
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0 5%;
      height: 62px;
      gap: 16px;
    }

    .overlay-back {
      display: flex;
      align-items: center;
      gap: 7px;
      font-size: 14px;
      font-weight: 600;
      color: var(--text-2);
      background: none;
      border: none;
      cursor: pointer;
      font-family: inherit;
      padding: 0;
      transition: color 0.18s;
      white-space: nowrap;
    }

    .overlay-back:hover { color: var(--text-1); }

    .overlay-page-title {
      font-size: 15px;
      font-weight: 700;
      color: var(--text-1);
      flex: 1;
      min-width: 0;
      text-align: center;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }

    .overlay-topbar-right {
      display: flex;
      justify-content: flex-end;
      min-width: 0;
      flex-shrink: 0;
    }

    /* ── CREATE EVENT FORM ────────────────────────────────── */
    .create-body {
      max-width: 780px;
      margin: 0 auto;
      padding: 44px 5% 100px;
    }

    .create-intro {
      margin-bottom: 32px;
    }

    .create-intro h2 {
      font-size: 26px;
      font-weight: 800;
      letter-spacing: -0.8px;
      color: var(--text-1);
      margin-bottom: 6px;
    }

    .create-intro p {
      font-size: 14px;
      color: var(--text-2);
      line-height: 1.6;
    }

    .form-section {
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 26px 28px;
      margin-bottom: 18px;
      box-shadow: var(--shadow-sm);
    }

    .form-section-head {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 22px;
      padding-bottom: 16px;
      border-bottom: 1px solid var(--border-2);
    }

    .form-section-num {
      width: 26px; height: 26px;
      background: var(--orange-soft);
      color: var(--orange);
      border-radius: 7px;
      display: flex; align-items: center; justify-content: center;
      font-size: 12px;
      font-weight: 800;
      flex-shrink: 0;
    }

    .form-section-title {
      font-size: 14px;
      font-weight: 700;
      color: var(--text-1);
    }

    .form-row {
      display: grid;
      gap: 16px;
      margin-bottom: 16px;
    }

    .form-row:last-child { margin-bottom: 0; }
    .form-row.col-1 { grid-template-columns: 1fr; }
    .form-row.col-2 { grid-template-columns: 1fr 1fr; }
    .form-row.col-3 { grid-template-columns: 1fr 1fr 1fr; }

    @media (max-width: 600px) {
      .form-row.col-2, .form-row.col-3 { grid-template-columns: 1fr; }
    }

    .form-field { display: flex; flex-direction: column; gap: 5px; }

    .form-label {
      font-size: 13px;
      font-weight: 600;
      color: var(--text-1);
      display: flex;
      align-items: center;
      gap: 4px;
    }

    .form-label .req { color: var(--red); }

    .form-hint {
      font-size: 12px;
      color: var(--text-3);
      line-height: 1.4;
    }

    .form-input, .form-select, .form-textarea {
      font-family: inherit;
      font-size: 14px;
      color: var(--text-1);
      background: var(--bg);
      border: 1.5px solid var(--border);
      border-radius: var(--radius-xs);
      padding: 10px 13px;
      transition: border-color 0.18s, box-shadow 0.18s, background 0.18s;
      outline: none;
      width: 100%;
      max-width: 100%;
    }

    .form-input:focus, .form-select:focus, .form-textarea:focus {
      border-color: var(--orange);
      box-shadow: 0 0 0 3px rgba(255,92,0,0.1);
      background: #fff;
    }

    .form-input::placeholder, .form-textarea::placeholder { color: var(--text-3); }

    .form-textarea {
      resize: vertical;
      min-height: 130px;
      line-height: 1.65;
    }

    .form-select {
      cursor: pointer;
      appearance: none;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239898B0' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
      background-repeat: no-repeat;
      background-position: right 12px center;
      padding-right: 32px;
    }

    /* radio cards */
    .radio-group { display: flex; gap: 10px; flex-wrap: wrap; }

    .radio-card {
      flex: 1;
      min-width: 160px;
      border: 1.5px solid var(--border);
      border-radius: var(--radius-sm);
      padding: 14px 16px;
      cursor: pointer;
      transition: border-color 0.18s, background 0.18s;
      display: flex;
      align-items: flex-start;
      gap: 10px;
    }

    .radio-card:has(input:checked) {
      border-color: var(--orange);
      background: var(--orange-soft);
    }

    .radio-card input[type="radio"] {
      margin-top: 3px;
      accent-color: var(--orange);
      flex-shrink: 0;
      cursor: pointer;
    }

    .radio-card-label {
      font-size: 14px;
      font-weight: 600;
      color: var(--text-1);
    }

    .radio-card-sub {
      font-size: 12px;
      color: var(--text-3);
      margin-top: 2px;
      line-height: 1.4;
    }

    /* price toggle */
    .price-toggle {
      display: inline-flex;
      background: var(--bg);
      border: 1.5px solid var(--border);
      border-radius: var(--radius-xs);
      overflow: hidden;
      margin-bottom: 14px;
    }

    .price-toggle-btn {
      padding: 8px 22px;
      font-size: 13px;
      font-weight: 600;
      color: var(--text-2);
      background: none;
      border: none;
      cursor: pointer;
      font-family: inherit;
      transition: background 0.18s, color 0.18s;
    }

    .price-toggle-btn.active {
      background: var(--orange);
      color: #fff;
      border-radius: calc(var(--radius-xs) - 2px);
    }

    .paid-fields { display: none; }
    .paid-fields.show { display: block; }

    .price-verify-warning {
      font-size: 12px;
      color: #92400e;
      background: #fffbeb;
      border: 1px solid #fde68a;
      border-radius: var(--radius-xs);
      padding: 8px 12px;
      margin-bottom: 10px;
      line-height: 1.5;
    }

    /* ticket tiers — create form */
    .tiers-header-row {
      display: grid;
      grid-template-columns: 1fr 1fr 100px 80px 36px;
      gap: 8px;
      padding: 0 4px 6px;
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.5px;
      text-transform: uppercase;
      color: var(--text-3);
    }

    .tier-input-row {
      display: grid;
      grid-template-columns: 1fr 1fr 100px 80px 36px;
      gap: 8px;
      align-items: center;
      margin-bottom: 8px;
    }

    .tier-remove-btn {
      width: 36px;
      height: 36px;
      border: 1.5px solid var(--border);
      border-radius: var(--radius-xs);
      background: none;
      color: var(--text-3);
      font-size: 18px;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      transition: border-color 0.15s, color 0.15s;
    }
    .tier-remove-btn:hover { border-color: var(--red); color: var(--red); }

    .tiers-add-btn {
      margin-top: 4px;
      padding: 7px 16px;
      font-size: 13px;
      font-weight: 600;
      font-family: inherit;
      color: var(--orange);
      background: var(--orange-soft);
      border: 1.5px solid var(--orange);
      border-radius: var(--radius-xs);
      cursor: pointer;
      transition: opacity 0.15s;
    }
    .tiers-add-btn:hover { opacity: 0.8; }

    /* ── TEMPLATE BANNER ──────────────────────────────────── */
    .template-banner {
      display: flex;
      align-items: center;
      gap: 10px;
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius-sm);
      padding: 12px 16px;
      margin-bottom: 24px;
    }
    .template-select {
      flex: 1;
      min-width: 0;
    }
    .template-apply-btn {
      padding: 8px 18px;
      background: var(--orange);
      color: #fff;
      border: none;
      border-radius: var(--radius-xs);
      font-size: 13px;
      font-weight: 600;
      cursor: pointer;
      white-space: nowrap;
      transition: opacity 0.15s;
    }
    .template-apply-btn:hover { opacity: 0.85; }
    .template-manage-link {
      background: none;
      border: none;
      color: var(--text-3);
      font-size: 13px;
      cursor: pointer;
      white-space: nowrap;
      padding: 0;
      text-decoration: underline;
      text-underline-offset: 2px;
    }
    .template-manage-link:hover { color: var(--text-2); }

    /* ── BTN-SECONDARY (topbar) ───────────────────────────── */
    .btn-secondary {
      padding: 7px 14px;
      background: var(--surface);
      color: var(--text-2);
      border: 1.5px solid var(--border);
      border-radius: var(--radius-xs);
      font-size: 13px;
      font-weight: 600;
      cursor: pointer;
      transition: border-color 0.15s, color 0.15s;
    }
    .btn-secondary:hover { border-color: var(--text-3); color: var(--text-1); }

    /* ── MANAGE TEMPLATES LIST ────────────────────────────── */
    .manage-template-row {
      display: flex;
      align-items: center;
      gap: 12px;
      padding: 12px 0;
      border-bottom: 1px solid var(--border-2);
    }
    .manage-template-row:last-child { border-bottom: none; }
    .manage-template-info { flex: 1; min-width: 0; }
    .manage-template-name {
      font-size: 14px;
      font-weight: 600;
      color: var(--text-1);
    }
    .manage-template-meta {
      font-size: 12px;
      color: var(--text-3);
      margin-top: 2px;
      text-transform: capitalize;
    }
    .manage-template-delete {
      background: none;
      border: 1.5px solid var(--border);
      border-radius: var(--radius-xs);
      color: var(--red);
      font-size: 12px;
      font-weight: 600;
      padding: 5px 12px;
      cursor: pointer;
      transition: border-color 0.15s;
      white-space: nowrap;
    }
    .manage-template-delete:hover { border-color: var(--red); }

    /* ── TIER CURRENCY ROW ────────────────────────────────── */
    .tier-currency-row {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 10px;
    }
    .tier-currency-label {
      font-size: 13px;
      font-weight: 500;
      color: var(--text-2);
      white-space: nowrap;
    }
    .tier-currency-row .form-select {
      width: auto;
      min-width: 220px;
    }

    @media (max-width: 820px) {
      .tier-currency-row { flex-wrap: wrap; }
      .tier-currency-row .form-select { min-width: 0; width: 100%; }
      .tiers-header-row,
      .tier-input-row {
        grid-template-columns: 1fr 1fr minmax(0, 90px) minmax(0, 70px) 36px;
      }
      .tier-input-row input { min-width: 0; }
    }

    @media (max-width: 480px) {
      .tiers-header-row {
        display: none;
      }

      .tier-input-row {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 6px;
        padding: 12px;
        background: var(--bg);
        border: 1px solid var(--border);
        border-radius: var(--radius-xs);
        margin-bottom: 8px;
      }

      .tier-input-row .tier-remove-btn {
        grid-column: 1 / -1;
        width: 100%;
        margin-top: 2px;
      }
    }

    /* ── COUNTRY COMBOBOX ─────────────────────────────────── */
    .country-combo {
      position: relative;
    }
    .country-dropdown {
      position: absolute;
      top: calc(100% + 4px);
      left: 0;
      right: 0;
      background: var(--surface);
      border: 1.5px solid var(--border);
      border-radius: var(--radius-sm);
      box-shadow: var(--shadow-md);
      max-height: 220px;
      overflow-y: auto;
      z-index: 200;
      scrollbar-width: thin;
    }
    .country-option {
      padding: 9px 14px;
      font-size: 14px;
      color: var(--text-1);
      cursor: pointer;
      transition: background 0.1s;
    }
    .country-option:hover { background: var(--bg); }
    .country-option strong { color: var(--orange); font-weight: 700; }

    /* image upload zone */
    .upload-zone {
      position: relative;
      border: 2px dashed var(--border);
      border-radius: var(--radius-sm);
      padding: 28px 20px;
      text-align: center;
      cursor: pointer;
      transition: border-color 0.2s, background 0.2s;
      background: var(--bg);
    }
    .upload-zone:hover { border-color: var(--orange); background: var(--orange-soft); }
    .upload-zone.has-file { border-color: #16a34a; background: #f0fdf4; }
    .upload-zone input[type="file"] {
      position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; height: 100%;
    }
    .upload-zone-icon { color: var(--text-3); margin-bottom: 8px; }
    .upload-zone-text { font-size: 13px; color: var(--text-2); font-weight: 500; }
    .upload-zone-sub { font-size: 11px; color: var(--text-3); margin-top: 3px; }
    .upload-preview {
      margin-top: 10px;
      width: 100%; max-height: 160px; object-fit: cover;
      border-radius: var(--radius-xs); display: none;
    }

    /* ── AUTH MODAL ──────────────────────────────────────────── */
    .auth-backdrop {
      position: fixed;
      inset: 0;
      background: rgba(12,12,20,0.45);
      backdrop-filter: blur(4px);
      -webkit-backdrop-filter: blur(4px);
      z-index: 1000;
      display: flex;
      align-items: center;
      justify-content: center;
      opacity: 0;
      pointer-events: none;
      transition: opacity 0.22s;
    }
    .auth-backdrop.open {
      opacity: 1;
      pointer-events: all;
    }
    .auth-modal {
      background: var(--surface);
      border-radius: var(--radius);
      box-shadow: var(--shadow-lg);
      width: 100%;
      max-width: 400px;
      margin: 16px;
      transform: translateY(12px) scale(0.98);
      transition: transform 0.22s cubic-bezier(0.4,0,0.2,1);
    }
    .auth-backdrop.open .auth-modal {
      transform: translateY(0) scale(1);
    }
    .auth-modal-header {
      padding: 28px 28px 0;
    }
    .auth-modal-logo {
      display: flex;
      align-items: center;
      gap: 8px;
      margin-bottom: 20px;
    }
    .auth-modal-logo-text {
      font-size: 18px;
      font-weight: 800;
      letter-spacing: -0.5px;
      color: var(--text-1);
    }
    .auth-modal-logo-text em {
      font-style: normal;
      background: linear-gradient(100deg, var(--orange) 0%, var(--red) 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
    }
    .auth-modal-title {
      font-size: 20px;
      font-weight: 800;
      letter-spacing: -0.4px;
      color: var(--text-1);
      margin-bottom: 4px;
    }
    .auth-modal-sub {
      font-size: 13px;
      color: var(--text-3);
      margin-bottom: 0;
    }
    .auth-modal-close {
      position: absolute;
      top: 18px;
      right: 18px;
      width: 32px;
      height: 32px;
      border-radius: 50%;
      background: var(--bg);
      border: none;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      color: var(--text-2);
      transition: background 0.15s;
    }
    .auth-modal-close:hover { background: var(--border); }
    .auth-modal-body {
      padding: 22px 28px 28px;
      display: flex;
      flex-direction: column;
      gap: 14px;
    }
    .auth-field {
      display: flex;
      flex-direction: column;
      gap: 5px;
    }
    .auth-label {
      font-size: 12px;
      font-weight: 600;
      color: var(--text-2);
      letter-spacing: 0.3px;
    }
    .auth-input {
      height: 42px;
      padding: 0 13px;
      border: 1.5px solid var(--border);
      border-radius: var(--radius-xs);
      font-size: 14px;
      font-family: inherit;
      color: var(--text-1);
      background: var(--surface);
      transition: border-color 0.15s, box-shadow 0.15s;
      outline: none;
    }
    .auth-input:focus {
      border-color: var(--orange);
      box-shadow: 0 0 0 3px rgba(255,92,0,0.10);
    }
    .auth-input::placeholder { color: var(--text-3); }
    .auth-submit {
      height: 44px;
      border: none;
      border-radius: var(--radius-xs);
      background: linear-gradient(130deg, var(--orange) 0%, var(--red) 100%);
      color: #fff;
      font-size: 14px;
      font-weight: 700;
      font-family: inherit;
      cursor: pointer;
      box-shadow: 0 4px 16px rgba(255,92,0,0.30);
      transition: opacity 0.18s, transform 0.15s, box-shadow 0.18s;
      margin-top: 2px;
    }
    .auth-submit:hover {
      opacity: 0.92;
      transform: translateY(-1px);
      box-shadow: 0 8px 22px rgba(255,92,0,0.38);
    }
    .auth-switch {
      text-align: center;
      font-size: 13px;
      color: var(--text-3);
      padding-top: 4px;
    }
    .auth-switch-link {
      color: var(--orange);
      font-weight: 600;
      cursor: pointer;
      background: none;
      border: none;
      font-family: inherit;
      font-size: 13px;
      padding: 0;
    }
    .auth-switch-link:hover { text-decoration: underline; }
    .role-pill-group {
      display: flex;
      gap: 8px;
      margin-top: 4px;
    }
    .role-pill {
      flex: 1;
      padding: 9px 14px;
      border-radius: 50px;
      border: 1.5px solid var(--border);
      background: var(--surface);
      color: var(--text-2);
      font-size: 0.875rem;
      font-weight: 600;
      cursor: pointer;
      transition: border-color 0.15s, background 0.15s, color 0.15s;
    }
    .role-pill:hover { border-color: var(--orange); color: var(--orange); }
    .role-pill-active {
      border-color: var(--orange);
      background: #fff4ee;
      color: var(--orange);
    }
    .auth-divider {
      height: 1px;
      background: var(--border-2);
      margin: 2px 0;
    }

    /* logged-in nav state */
    .nav-user {
      display: flex;
      align-items: center;
      gap: 10px;
    }
    .nav-user-greeting {
      font-size: 13px;
      font-weight: 600;
      color: var(--text-1);
    }
    .nav-user-greeting span {
      background: linear-gradient(100deg, var(--orange) 0%, var(--red) 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
    }
    .btn-signout {
      font-size: 13px;
      font-weight: 600;
      color: var(--text-2);
      background: var(--bg);
      border: 1.5px solid var(--border);
      padding: 7px 14px;
      border-radius: var(--radius-xs);
      cursor: pointer;
      font-family: inherit;
      transition: border-color 0.15s, color 0.15s;
    }
    .btn-signout:hover { border-color: var(--text-2); color: var(--text-1); }
    .btn-my-profile {
      font-size: 13px;
      font-weight: 600;
      color: var(--orange);
      background: none;
      border: 1px solid rgba(255,92,0,0.3);
      border-radius: var(--radius-xs);
      padding: 5px 12px;
      cursor: pointer;
      font-family: inherit;
      transition: border-color 0.15s, background 0.15s;
    }
    .btn-my-profile:hover { border-color: var(--orange); background: var(--orange-soft); }

    .auth-submit:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }

    /* form success toast */
    .form-toast {
      position: fixed;
      bottom: 32px;
      left: 50%;
      transform: translateX(-50%) translateY(20px);
      background: var(--text-1);
      color: #fff;
      font-size: 14px;
      font-weight: 600;
      padding: 13px 24px;
      border-radius: 100px;
      box-shadow: 0 8px 32px rgba(0,0,0,0.2);
      opacity: 0;
      transition: opacity 0.3s, transform 0.3s;
      pointer-events: none;
      z-index: 999;
      display: flex;
      align-items: center;
      gap: 8px;
      white-space: nowrap;
    }

    .form-toast.show {
      opacity: 1;
      transform: translateX(-50%) translateY(0);
    }

    /* ── EVENT DETAIL PAGE ────────────────────────────────── */
    .detail-hero {
      position: relative;
      height: 300px;
      overflow: hidden;
    }

    .detail-hero-art {
      position: absolute;
      inset: 0;
    }

    .detail-hero-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, rgba(12,12,20,0.2) 0%, rgba(12,12,20,0.78) 100%);
    }

    .detail-hero-content {
      position: absolute;
      bottom: 0; left: 0; right: 0;
      padding: 0 5% 26px;
    }

    .detail-hero-badges {
      display: flex;
      align-items: center;
      gap: 8px;
      margin-bottom: 10px;
      flex-wrap: wrap;
    }

    .detail-hero-badge {
      font-size: 11px;
      font-weight: 700;
      color: #fff;
      background: rgba(255,255,255,0.18);
      backdrop-filter: blur(8px);
      border: 1px solid rgba(255,255,255,0.2);
      padding: 4px 12px;
      border-radius: 100px;
    }

    .detail-hero-title {
      font-size: clamp(22px, 4vw, 34px);
      font-weight: 900;
      color: #fff;
      letter-spacing: -1px;
      line-height: 1.15;
    }

    .detail-body {
      max-width: 1100px;
      margin: 0 auto;
      padding: 36px 5% 80px;
      display: grid;
      grid-template-columns: 1fr 320px;
      gap: 26px;
      align-items: start;
    }

    @media (max-width: 860px) {
      .detail-body { grid-template-columns: 1fr; }
    }

    .detail-section-label {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 1px;
      text-transform: uppercase;
      color: var(--orange);
      margin-bottom: 10px;
    }

    .detail-type-tag {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      font-size: 12px;
      font-weight: 600;
      color: var(--text-3);
      background: var(--bg);
      border: 1px solid var(--border);
      padding: 5px 12px;
      border-radius: 100px;
      margin-bottom: 16px;
    }

    .detail-event-title {
      font-size: clamp(20px, 3vw, 28px);
      font-weight: 800;
      letter-spacing: -0.8px;
      color: var(--text-1);
      margin-bottom: 22px;
      line-height: 1.2;
    }

    .detail-description {
      font-size: 15px;
      color: var(--text-2);
      line-height: 1.78;
      white-space: pre-line;
      margin-bottom: 32px;
    }

    .detail-organizer {
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 18px 20px;
      display: flex;
      align-items: center;
      gap: 14px;
      box-shadow: var(--shadow-sm);
      flex-wrap: wrap;
    }
    .detail-org-row { display: flex; align-items: center; gap: 12px; }
    .detail-org-label { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.8px; color: var(--accent, #FF5C00); margin-bottom: 2px; }
    .detail-org-vs { font-size: 12px; font-weight: 800; color: var(--text-3); padding: 0 4px; align-self: center; }

    .organizer-avatar {
      width: 44px; height: 44px;
      border-radius: 10px;
      background: linear-gradient(135deg, var(--orange-soft), #FFE4D6);
      border: 1px solid rgba(255,92,0,0.15);
      display: flex; align-items: center; justify-content: center;
      font-size: 18px;
      flex-shrink: 0;
    }

    .organizer-name {
      font-size: 14px;
      font-weight: 700;
      color: var(--text-1);
    }

    .organizer-contact {
      font-size: 13px;
      color: var(--text-3);
      margin-top: 2px;
    }

    /* sidebar info card */
    .detail-info-card {
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 22px;
      box-shadow: var(--shadow-sm);
      position: sticky;
      top: 78px;
    }

    .detail-price-block {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      padding: 14px 0;
      border-top: 1px solid var(--border-2);
      border-bottom: 1px solid var(--border-2);
      margin: 14px 0 18px;
    }

    .detail-price-lbl {
      font-size: 13px;
      font-weight: 600;
      color: var(--text-2);
    }

    .detail-price-val {
      font-size: 22px;
      font-weight: 800;
      letter-spacing: -0.5px;
      color: var(--text-1);
    }

    .detail-price-val.free { color: #16A34A; }

    .detail-meta-list {
      display: flex;
      flex-direction: column;
      gap: 12px;
      margin-bottom: 18px;
    }

    .detail-meta-row {
      display: flex;
      align-items: flex-start;
      gap: 10px;
    }

    .detail-meta-icon {
      width: 30px; height: 30px;
      border-radius: 7px;
      background: var(--bg);
      display: flex; align-items: center; justify-content: center;
      flex-shrink: 0;
      color: var(--text-3);
    }

    .detail-meta-lbl {
      font-size: 11px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.7px;
      color: var(--text-3);
    }

    .detail-meta-val {
      font-size: 14px;
      font-weight: 500;
      color: var(--text-1);
      margin-top: 1px;
    }

    .detail-spots-warn {
      display: flex;
      align-items: center;
      gap: 6px;
      font-size: 13px;
      font-weight: 600;
      color: var(--red);
      background: var(--red-soft);
      border: 1px solid rgba(232,0,45,0.15);
      padding: 9px 12px;
      border-radius: var(--radius-xs);
      margin-bottom: 14px;
    }

    /* ── DETAIL ACTION BUTTONS ───────────────────────────────── */
    .detail-action-btns {
      display: flex;
      flex-direction: column;
      gap: 9px;
      margin-top: 20px;
      padding-top: 20px;
      border-top: 1px solid var(--border);
    }

    .detail-action-btn {
      display: block;
      width: 100%;
      padding: 13px 20px;
      border-radius: var(--radius-sm);
      font-size: 14px;
      font-weight: 700;
      font-family: inherit;
      cursor: pointer;
      text-align: center;
      border: none;
      transition: opacity 0.15s, transform 0.15s, box-shadow 0.15s;
    }
    .detail-action-btn:hover { opacity: 0.88; transform: translateY(-1px); }

    .detail-btn-join {
      background: #16a34a;
      color: #fff;
      box-shadow: 0 4px 14px rgba(22,163,74,0.28);
    }
    .detail-btn-leave {
      background: transparent;
      color: #16a34a;
      border: 1.5px solid rgba(22,163,74,0.4);
    }
    .detail-btn-leave:hover { border-color: #16a34a; opacity: 1; }
    .detail-btn-full {
      background: var(--bg);
      color: var(--text-3);
      border: 1.5px solid var(--border);
      cursor: not-allowed;
    }
    .detail-btn-full:hover { opacity: 1; transform: none; }
    .detail-btn-buy {
      background: linear-gradient(130deg, var(--orange) 0%, var(--red) 100%);
      color: #fff;
      box-shadow: 0 4px 16px rgba(255,92,0,0.30);
    }
    .detail-btn-edit {
      background: transparent;
      color: var(--text-1);
      border: 1.5px solid var(--border);
    }
    .detail-btn-edit:hover { border-color: var(--text-2); opacity: 1; }
    .detail-btn-fav {
      background: transparent;
      color: var(--text-2);
      border: 1.5px solid var(--border);
    }
    .detail-btn-fav:hover { border-color: rgba(255,92,0,0.35); color: var(--orange); opacity: 1; }
    .detail-btn-fav-active {
      background: var(--orange-soft);
      color: var(--orange);
      border: 1.5px solid rgba(255,92,0,0.25);
    }
    .detail-btn-fav-active:hover { opacity: 0.85; }
    .detail-btn-share {
      background: transparent;
      color: var(--orange);
      border: 1.5px solid rgba(255,92,0,0.35);
    }
    .detail-btn-share:hover { background: var(--orange-soft); border-color: var(--orange); opacity: 1; }
    .detail-btn-auth {
      background: var(--bg);
      color: var(--text-2);
      border: 1.5px solid var(--border);
    }
    .detail-btn-auth:hover { border-color: var(--orange); color: var(--orange); opacity: 1; }

    /* ── ORGANISER PROFILE PAGE ──────────────────────────────── */
    .org-hero {
      background: var(--org-primary, #FF5C00);
      padding: 28px 5% 28px;
      display: flex;
      gap: 24px;
      align-items: flex-start;
      position: relative;
      overflow: hidden;
    }
    .org-hero::before {
      content: '';
      position: absolute;
      right: -60px; top: -60px;
      width: 320px; height: 320px;
      border-radius: 50%;
      background: var(--org-secondary, #E8002D);
      opacity: 0.15;
      pointer-events: none;
    }
    .org-hero .org-avatar {
      width: 84px; height: 84px;
      border-radius: 16px;
      background: var(--hero-divider, rgba(255,255,255,0.15));
      color: var(--hero-text, #fff);
      font-size: 2rem; font-weight: 800;
      display: flex; align-items: center; justify-content: center;
      border: 2px solid var(--hero-divider, rgba(255,255,255,0.25));
      flex-shrink: 0;
    }
    .org-hero-info { flex: 1; min-width: 0; }
    .org-name-row {
      display: flex; align-items: center;
      gap: 10px; flex-wrap: wrap;
      margin-bottom: 5px;
    }
    .org-display-name {
      font-size: 1.4rem; font-weight: 800;
      color: var(--hero-text, #fff);
      letter-spacing: -0.5px;
    }
    .org-badge {
      display: inline-block;
      padding: 3px 10px;
      border-radius: 50px;
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.3px;
    }
    .org-hero .org-badge {
      background: var(--hero-divider, rgba(255,255,255,0.18));
      color: var(--hero-text, #fff);
      border: 0.5px solid var(--hero-divider, rgba(255,255,255,0.3));
    }
    .org-hero .org-bio {
      font-size: 14px;
      font-weight: 400;
      color: var(--hero-text-muted, #ffffff);
      line-height: 1.6;
      margin: 8px 0 14px;
    }
    .org-meta-bar {
      display: flex; align-items: center;
      flex-wrap: wrap; gap: 12px;
      margin-bottom: 14px;
    }
    .org-follower-count,
    .org-events-hosted {
      font-size: 13px; font-weight: 700;
      color: var(--hero-text, #fff);
    }
    .org-meta-divider {
      width: 1px; height: 18px;
      background: var(--hero-divider, rgba(255,255,255,0.25));
    }
    .org-sport-tags { display: flex; flex-wrap: wrap; gap: 6px; }
    .org-sport-tag {
      padding: 3px 10px;
      background: var(--hero-divider, rgba(255,255,255,0.12));
      color: var(--hero-text, #fff);
      border: 0.5px solid var(--hero-divider, rgba(255,255,255,0.2));
      border-radius: 50px;
      font-size: 12px; font-weight: 600;
    }
    .org-action-wrap {
      display: flex; flex-direction: column;
      gap: 8px; flex-shrink: 0; min-width: 150px;
    }

    /* ── Rating display (under organiser name) ── */
    #orgRatingDisplay {
      display: flex;
      align-items: center;
      gap: 5px;
      margin-top: 4px;
      flex-wrap: wrap;
    }
    .org-rating-stars { display: flex; gap: 1px; }
    .org-star-fill  { color: var(--orange); font-size: 13px; }
    .org-star-half  { color: var(--orange); font-size: 13px; opacity: 0.55; }
    .org-star-empty { color: var(--border-2); font-size: 13px; }
    .org-rating-score { font-size: 13px; font-weight: 700; color: var(--text-1); }
    .org-rating-count { font-size: 12px; color: var(--text-3); }
    .org-rating-none  { font-size: 12px; color: var(--text-3); font-style: italic; }
    /* Inside the hero, star ratings use hero text colors at full opacity */
    .org-hero .org-star-fill,
    .org-hero .org-star-half  { color: var(--hero-text, #fff); opacity: 1; }
    .org-hero .org-star-empty { color: var(--hero-divider, rgba(255,255,255,0.25)); }
    .org-hero .org-rating-score { color: var(--hero-text, #fff); font-weight: 800; }
    .org-hero .org-rating-count,
    .org-hero .org-rating-none  { color: var(--hero-text-muted, #fff); font-style: normal; }

    @media (max-width: 820px) {
      .org-hero {
        flex-direction: column;
        align-items: stretch;
      }

      .org-hero .org-avatar {
        flex-shrink: 0;
      }

      .org-hero-info {
        width: 100%;
      }

      .org-hero .org-bio {
        margin-bottom: 10px;
      }

      .org-action-wrap {
        width: 100%;
        min-width: 0;
      }
    }

    /* ── Review widget (above events tabs) ── */
    .org-review-widget {
      border-top: 1px solid var(--border);
      padding: 20px 0 24px;
      margin-bottom: 4px;
    }
    .org-review-label {
      font-size: 12px;
      font-weight: 600;
      color: var(--text-2);
      text-transform: uppercase;
      letter-spacing: 0.05em;
      margin-bottom: 10px;
    }
    .org-review-stars {
      display: flex;
      gap: 4px;
    }
    .review-star {
      font-size: 32px;
      color: var(--border-2);
      cursor: pointer;
      transition: color 0.15s, transform 0.1s;
      line-height: 1;
      user-select: none;
    }
    .review-star.filled,
    .review-star.hover { color: var(--orange); }
    .review-star:active { transform: scale(0.9); }
    .org-review-feedback {
      margin-top: 10px;
      font-size: 13px;
      color: var(--orange);
      font-weight: 500;
      opacity: 0;
      transition: opacity 0.4s;
    }
    .org-review-ineligible {
      font-size: 13px;
      font-style: italic;
      color: var(--text-3);
      margin: 0;
      padding: 16px 0;
    }

    .org-social-links { display: flex; flex-wrap: wrap; gap: 7px; }
    .org-social-link {
      display: inline-flex; align-items: center; gap: 5px;
      padding: 5px 12px;
      background: var(--hero-divider, rgba(255,255,255,0.1));
      border: 0.5px solid var(--hero-divider, rgba(255,255,255,0.2));
      border-radius: 8px;
      font-size: 12px; font-weight: 600;
      color: var(--hero-text-muted, rgba(255,255,255,0.65));
      text-decoration: none;
    }

    .org-tabs {
      display: flex;
      gap: 0;
      border-bottom: 2px solid var(--border);
      margin-bottom: 28px;
      overflow-x: auto;
      scrollbar-width: none;
    }
    .org-tabs::-webkit-scrollbar { display: none; }

    .org-tab {
      padding: 10px 20px;
      background: none;
      border: none;
      border-bottom: 2px solid transparent;
      margin-bottom: -2px;
      font-size: 14px;
      font-weight: 600;
      font-family: inherit;
      color: var(--text-3);
      cursor: pointer;
      transition: color 0.15s, border-color 0.15s;
      flex-shrink: 0;
    }
    .org-tab:hover { color: var(--text-1); }
    .org-tab.active { color: var(--orange); border-bottom-color: var(--orange); }

    /* Follow / Unfollow / Verify action buttons */
    .detail-btn-follow {
      background: linear-gradient(130deg, var(--orange) 0%, var(--red) 100%);
      color: #fff;
      box-shadow: 0 4px 14px rgba(255,92,0,0.25);
      border: none;
    }
    .detail-btn-unfollow {
      background: transparent;
      color: #16a34a;
      border: 1.5px solid rgba(22,163,74,0.4);
    }
    .detail-btn-unfollow:hover { border-color: #16a34a; opacity: 1; }
    .detail-btn-verify {
      background: transparent;
      color: #1D6FAB;
      border: 1.5px solid rgba(29,111,171,0.35);
    }
    .detail-btn-verify:hover { border-color: #1D6FAB; opacity: 1; }
    .detail-btn-verify:disabled { opacity: 0.5; cursor: default; transform: none !important; }
    .detail-btn-delete {
      background: transparent;
      color: var(--red);
      border: 1.5px solid rgba(232,0,45,0.3);
    }
    .detail-btn-delete:hover { border-color: var(--red); opacity: 1; }

    /* Owner stats — card */
    .card-owner-stats {
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 11px;
      font-weight: 600;
      color: var(--text-3);
      margin-bottom: 6px;
      padding: 6px 0 2px;
      border-top: 1px solid var(--border);
    }
    .card-stat { display: flex; align-items: center; gap: 3px; }
    .card-stat-divider { width: 1px; height: 10px; background: var(--border); }

    /* Owner stats — detail page */
    .detail-owner-stats {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 10px 14px;
      background: var(--orange-soft);
      border: 1px solid var(--border);
      border-radius: var(--radius-sm);
      margin-bottom: 4px;
    }
    .detail-stat-item {
      display: flex;
      align-items: center;
      gap: 5px;
      font-size: 13px;
      font-weight: 600;
      color: var(--text-1);
    }
    .detail-stat-icon { font-size: 14px; }
    .detail-stat-divider { flex: 1; height: 1px; background: var(--border); }

    /* Card-level delete button */
    .card-delete-btn {
      display: block;
      width: 100%;
      margin-top: 10px;
      padding: 7px 0;
      background: none;
      border: none;
      border-top: 1px solid var(--border-2);
      font-size: 12px;
      font-weight: 600;
      font-family: inherit;
      color: var(--text-3);
      cursor: pointer;
      text-align: center;
      transition: color 0.15s;
    }
    .card-delete-btn:hover { color: var(--red); }

    /* Clickable organiser name in detail page */
    .organizer-name-link {
      cursor: pointer;
      color: var(--orange);
      text-decoration: underline;
      text-decoration-color: rgba(255,92,0,0.3);
      text-underline-offset: 2px;
      transition: color 0.15s;
    }
    .organizer-name-link:hover { color: var(--red); }

    /* Sport category picker (edit profile form) */
    .sport-cat-picker {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 4px;
    }

    .sport-cat-pill {
      padding: 7px 15px;
      border-radius: 50px;
      border: 1.5px solid var(--border);
      background: var(--surface);
      color: var(--text-2);
      font-size: 13px;
      font-weight: 600;
      font-family: inherit;
      cursor: pointer;
      transition: border-color 0.15s, background 0.15s, color 0.15s;
    }
    .sport-cat-pill:hover { border-color: var(--orange); color: var(--orange); }
    .sport-cat-pill.active { border-color: var(--orange); background: var(--orange-soft); color: var(--orange); }

    /* ── AVATAR IMAGE ─────────────────────────────────────────── */
    .org-avatar-img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      border-radius: 14px;
      display: block;
    }

    /* ── ORGANISER EDIT — AVATAR ROW ─────────────────────────── */
    .ep-avatar-row {
      display: flex;
      align-items: center;
      gap: 14px;
      flex-wrap: wrap;
    }

    .ep-avatar-preview {
      width: 60px;
      height: 60px;
      font-size: 1.4rem;
      flex-shrink: 0;
      overflow: hidden;
    }

    .ep-avatar-upload-btn {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 7px 14px;
      border-radius: var(--radius-sm);
      border: 1.5px solid var(--border);
      background: var(--surface);
      color: var(--text-1);
      font-size: 13px;
      font-weight: 600;
      font-family: inherit;
      cursor: pointer;
      transition: border-color 0.15s;
    }
    .ep-avatar-upload-btn:hover { border-color: var(--text-2); }

    /* ── FAN PROFILE PAGE ────────────────────────────────────── */
    .fan-profile-body {
      padding: 32px 5% 80px;
    }

    /* Two-column layout */
    .fan-profile-layout {
      display: grid;
      grid-template-columns: 260px 1fr;
      gap: 32px;
      align-items: start;
    }

    /* ── Sidebar ── */
    .fan-profile-sidebar {
      position: sticky;
      top: 82px;          /* below fixed navbar */
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 24px 20px;
      box-shadow: var(--shadow-sm);
    }

    .fan-sidebar-avatar-wrap {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 10px;
      margin-bottom: 16px;
    }

    .fan-avatar {
      width: 88px;
      height: 88px;
      font-size: 2.2rem;
      overflow: hidden;
    }

    .fan-avatar-upload-btn {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      padding: 5px 12px;
      border-radius: var(--radius-sm);
      border: 1.5px solid var(--border);
      background: var(--bg);
      color: var(--text-2);
      font-size: 12px;
      font-weight: 600;
      font-family: inherit;
      cursor: pointer;
      white-space: nowrap;
      transition: border-color 0.15s, color 0.15s;
    }
    .fan-avatar-upload-btn:hover { border-color: var(--orange); color: var(--orange); }

    .fan-sidebar-identity {
      text-align: center;
      margin-bottom: 20px;
    }

    .fan-profile-nickname {
      font-size: 1.1rem;
      font-weight: 800;
      letter-spacing: -0.3px;
      color: var(--text-1);
    }

    .fan-profile-joined {
      font-size: 12px;
      color: var(--text-3);
      font-weight: 500;
      margin-top: 3px;
    }

    /* Stats block */
    .fan-stats-block {
      background: var(--bg);
      border: 1px solid var(--border);
      border-radius: var(--radius-sm);
      padding: 14px 16px;
      display: flex;
      flex-direction: column;
      gap: 0;
      margin-bottom: 20px;
    }

    .fan-stat {
      padding: 8px 0;
    }

    .fan-stat-value {
      font-size: 1.3rem;
      font-weight: 800;
      color: var(--text-1);
      letter-spacing: -0.5px;
    }

    .fan-stat-label {
      font-size: 12px;
      font-weight: 500;
      color: var(--text-3);
      text-align: right;
    }

    .fan-stat-divider {
      height: 1px;
      background: var(--border);
      margin: 0 -2px;
    }

    /* City + Save */
    .fan-sidebar-fields {
      border-top: 1px solid var(--border);
      padding-top: 16px;
    }
    .fan-sidebar-tickets-btn {
      display: block;
      width: 100%;
      margin-top: 10px;
      padding: 11px;
      font-size: 14px;
      font-weight: 600;
      font-family: inherit;
      color: var(--text-2);
      background: none;
      border: 1.5px solid var(--border);
      border-radius: var(--radius-sm);
      cursor: pointer;
      transition: border-color 0.15s, color 0.15s;
      text-align: center;
    }
    .fan-sidebar-tickets-btn:hover {
      border-color: var(--orange);
      color: var(--orange);
    }

    /* ── Main content ── */
    .fan-profile-main {
      min-width: 0;
    }

    .fan-main-section {
      margin-bottom: 8px;
    }

    .fan-main-section-label {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 1px;
      text-transform: uppercase;
      color: var(--text-3);
      margin-bottom: 10px;
    }

    /* Mobile: single column */
    @media (max-width: 720px) {
      .fan-profile-layout {
        grid-template-columns: 1fr;
      }
      .fan-profile-sidebar {
        position: static;
      }
    }

    /* ── ORGANISER TERMS MODAL ───────────────────────────────── */
    .org-terms-modal {
      max-height: 90vh;
      display: flex;
      flex-direction: column;
    }
    .org-terms-body {
      overflow-y: auto;
      padding: 0 28px 28px;
      flex: 1;
    }
    .org-terms-section {
      margin-bottom: 24px;
    }
    .org-terms-heading {
      font-size: 13px;
      font-weight: 700;
      color: var(--text-1);
      margin-bottom: 8px;
    }
    .org-terms-section p {
      font-size: 13px;
      line-height: 1.65;
      color: var(--text-2);
      margin: 0 0 8px;
    }
    .org-terms-list {
      margin: 6px 0 8px;
      padding-left: 18px;
    }
    .org-terms-list li {
      font-size: 13px;
      line-height: 1.65;
      color: var(--text-2);
      margin-bottom: 5px;
    }
    .org-terms-footer {
      margin-top: 8px;
      padding-top: 20px;
      border-top: 1px solid var(--border);
    }
    .auth-terms-link {
      color: var(--orange);
      text-decoration: underline;
      text-underline-offset: 2px;
    }
    .auth-terms-link:hover { opacity: .8; }

    /* ── ORGANISER SIGN-UP EXTRA FIELDS ─────────────────────── */
    .auth-checkbox-label {
      display: flex;
      align-items: flex-start;
      gap: 10px;
      cursor: pointer;
      font-size: 13px;
      color: var(--text-2);
      line-height: 1.5;
    }
    .auth-checkbox-label input[type="checkbox"] {
      margin-top: 2px;
      flex-shrink: 0;
      width: 16px;
      height: 16px;
      accent-color: var(--orange);
      cursor: pointer;
    }
    #organiserExtraFields .auth-input + .auth-input {
      margin-top: 6px;
    }
    .req { color: var(--red); }

    /* ── VERIFICATION / ID UPLOAD MODAL ─────────────────────── */
    #verifyBackdrop { z-index: 3000; }
    #verifyBackdrop .upload-zone { cursor: pointer; }
    #verifyBackdrop .upload-zone input[type="file"] {
      position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; height: 100%;
    }

    /* ── ADMIN PAGE ──────────────────────────────────────────── */
    .admin-card-list {
      display: flex;
      flex-direction: column;
      gap: 16px;
      padding: 24px 0;
    }

    /* ── Admin verify card ─────────────────────────────────── */
    .admin-verify-card {
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 22px 24px;
      box-shadow: var(--shadow-sm);
    }

    /* Header */
    .admin-verify-header {
      display: flex;
      align-items: center;
      gap: 14px;
      margin-bottom: 14px;
    }

    .admin-verify-avatar {
      width: 48px;
      height: 48px;
      flex-shrink: 0;
      border-radius: 50%;
      background: linear-gradient(135deg, var(--orange) 0%, var(--red) 100%);
      color: #fff;
      font-size: 20px;
      font-weight: 700;
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .admin-verify-header-info {
      flex: 1;
      min-width: 0;
    }

    .admin-verify-name {
      font-size: 16px;
      font-weight: 700;
      color: var(--text-1);
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .admin-verify-requested {
      font-size: 12px;
      color: var(--text-3);
      margin-top: 2px;
      font-weight: 500;
    }

    .admin-verify-country-pill {
      flex-shrink: 0;
      font-size: 12px;
      font-weight: 600;
      color: var(--text-2);
      background: var(--bg);
      border: 1px solid var(--border);
      border-radius: 50px;
      padding: 4px 12px;
      white-space: nowrap;
    }

    /* Meta bar */
    .admin-verify-metabar {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-bottom: 16px;
    }

    .admin-meta-pill {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      font-size: 12px;
      font-weight: 500;
      color: var(--text-2);
      background: var(--bg);
      border: 1px solid var(--border);
      border-radius: 50px;
      padding: 4px 11px;
    }

    .admin-meta-pill svg { color: var(--text-3); flex-shrink: 0; }

    /* Divider */
    .admin-verify-divider {
      height: 1px;
      background: var(--border);
      margin: 14px 0;
    }

    /* Sections */
    .admin-verify-section {
      margin-bottom: 14px;
    }

    .admin-verify-section:last-of-type {
      margin-bottom: 0;
    }

    .admin-verify-section-label {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 1px;
      text-transform: uppercase;
      color: var(--text-3);
      margin-bottom: 6px;
    }

    .admin-verify-bio {
      font-size: 14px;
      color: var(--text-2);
      line-height: 1.6;
    }

    .admin-verify-empty {
      font-size: 13px;
      color: var(--text-3);
      font-style: italic;
    }

    /* Social link buttons */
    .admin-verify-socials {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }

    .admin-social-btn {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      font-size: 13px;
      font-weight: 600;
      color: var(--text-1);
      background: var(--bg);
      border: 1px solid var(--border);
      border-radius: var(--radius-xs);
      padding: 5px 12px;
      text-decoration: none;
      transition: border-color 0.15s, background 0.15s;
    }
    .admin-social-btn:hover { border-color: var(--text-2); background: var(--surface); }

    /* ID document */
    .admin-id-btn {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      font-size: 13px;
      font-weight: 600;
      color: var(--text-1);
      background: var(--bg);
      border: 1px solid var(--border);
      border-radius: var(--radius-xs);
      padding: 6px 14px;
      text-decoration: none;
      transition: border-color 0.15s, background 0.15s;
    }
    .admin-id-btn:hover { border-color: var(--text-2); background: var(--surface); }

    .admin-id-missing {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      font-size: 13px;
      font-weight: 600;
      color: var(--red);
      background: var(--red-soft);
      border-radius: var(--radius-xs);
      padding: 5px 12px;
    }

    /* Actions */
    .admin-verify-actions {
      display: flex;
      gap: 8px;
      flex-wrap: wrap;
    }

    .admin-action-btn {
      flex: 1;
      min-width: 100px;
      padding: 9px 16px;
      border-radius: var(--radius-sm);
      border: 1.5px solid transparent;
      font-size: 13px;
      font-weight: 600;
      font-family: inherit;
      cursor: pointer;
      transition: opacity 0.15s, background 0.15s;
      text-align: center;
    }
    .admin-action-btn:hover { opacity: 0.85; }

    .admin-action-profile {
      background: var(--bg);
      border-color: var(--border);
      color: var(--text-1);
    }
    .admin-action-profile:hover { border-color: var(--text-2); opacity: 1; }

    .admin-action-approve {
      background: var(--orange);
      color: #fff;
    }

    .admin-action-reject {
      background: var(--red-soft);
      border-color: rgba(232,0,45,0.20);
      color: var(--red);
    }

    /* Admin table */
    .admin-table-wrap {
      overflow-x: auto;
      margin-top: 16px;
      border-radius: var(--radius);
      border: 1px solid var(--border);
      background: var(--surface);
    }

    .admin-table {
      width: 100%;
      border-collapse: collapse;
      font-size: 14px;
    }

    .admin-table th {
      text-align: left;
      padding: 12px 16px;
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.8px;
      text-transform: uppercase;
      color: var(--text-3);
      border-bottom: 1px solid var(--border);
      background: var(--bg);
    }

    .admin-table td {
      padding: 12px 16px;
      color: var(--text-1);
      border-bottom: 1px solid var(--border-2);
      vertical-align: middle;
    }

    .admin-table tr:last-child td { border-bottom: none; }
    .admin-table tr:hover td { background: var(--bg); }

    .admin-status-badge {
      display: inline-block;
      padding: 3px 10px;
      border-radius: 50px;
      font-size: 12px;
      font-weight: 600;
    }
    .admin-status-verified   { background: #ECFDF5; color: #16A34A; }
    .admin-status-approved   { background: var(--orange-soft); color: var(--orange); }
    .admin-status-pending    { background: #FEF9C3; color: #A16207; }
    .admin-status-unverified { background: var(--border-2); color: var(--text-3); }

    /* ── BUY TICKET MODAL ────────────────────────────────────── */
    .buy-modal {
      position: relative;
      background: var(--surface);
      border-radius: var(--radius);
      box-shadow: var(--shadow-lg);
      width: 100%;
      max-width: 440px;
      display: flex;
      flex-direction: column;
      overflow: hidden;
    }

    .buy-modal-header {
      padding: 24px 24px 16px;
      border-bottom: 1px solid var(--border);
    }

    .buy-modal-event-name {
      font-size: 17px;
      font-weight: 700;
      color: var(--text-1);
      margin-bottom: 4px;
    }

    .buy-modal-event-date {
      font-size: 13px;
      color: var(--text-3);
    }

    .buy-modal-body {
      padding: 16px 24px;
      display: flex;
      flex-direction: column;
      gap: 16px;
      max-height: 55vh;
      overflow-y: auto;
    }

    .buy-tier-list {
      display: flex;
      flex-direction: column;
      gap: 8px;
    }

    .buy-tier-card {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      padding: 14px 16px;
      border: 2px solid var(--border);
      border-radius: var(--radius-sm);
      cursor: pointer;
      transition: border-color 0.15s, background 0.15s;
      background: var(--bg);
    }

    .buy-tier-card:hover:not(.disabled) {
      border-color: var(--orange);
      background: var(--orange-soft);
    }

    .buy-tier-card.selected {
      border-color: var(--orange);
      background: var(--orange-soft);
    }

    .buy-tier-card.disabled {
      opacity: 0.45;
      cursor: not-allowed;
    }

    .buy-tier-info { flex: 1; min-width: 0; }

    .buy-tier-name {
      font-size: 14px;
      font-weight: 600;
      color: var(--text-1);
    }

    .buy-tier-desc {
      font-size: 12px;
      color: var(--text-3);
      margin-top: 2px;
    }

    .buy-tier-spots {
      font-size: 12px;
      color: var(--text-3);
      margin-top: 4px;
    }

    .buy-tier-spots.low { color: var(--red); font-weight: 600; }

    .buy-tier-price {
      font-size: 15px;
      font-weight: 700;
      color: var(--text-1);
      white-space: nowrap;
    }

    .buy-qty-row {
      display: flex;
      align-items: center;
      justify-content: space-between;
    }

    .buy-qty-label {
      font-size: 14px;
      font-weight: 600;
      color: var(--text-2);
    }

    .buy-qty-controls {
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .buy-qty-btn {
      width: 32px;
      height: 32px;
      border-radius: var(--radius-xs);
      border: 1.5px solid var(--border);
      background: var(--bg);
      font-size: 18px;
      font-weight: 600;
      color: var(--text-1);
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      transition: border-color 0.15s;
    }
    .buy-qty-btn:hover { border-color: var(--orange); color: var(--orange); }

    .buy-qty-value {
      font-size: 16px;
      font-weight: 700;
      color: var(--text-1);
      min-width: 20px;
      text-align: center;
    }

    .buy-modal-footer {
      padding: 16px 24px;
      border-top: 1px solid var(--border);
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
    }

    .buy-total-wrap {
      display: flex;
      flex-direction: column;
      gap: 2px;
    }

    .buy-total-label {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.6px;
      text-transform: uppercase;
      color: var(--text-3);
    }

    .buy-total-price {
      font-size: 20px;
      font-weight: 800;
      color: var(--text-1);
    }

    .buy-confirm-btn {
      padding: 12px 20px;
      background: var(--orange);
      color: #fff;
      border: none;
      border-radius: var(--radius-sm);
      font-size: 14px;
      font-weight: 700;
      font-family: inherit;
      cursor: pointer;
      transition: opacity 0.15s;
      white-space: nowrap;
    }
    .buy-confirm-btn:hover { opacity: 0.88; }

    @media (max-width: 820px) {
      #buyTicketBackdrop {
        align-items: flex-end;
      }

      #buyTicketBackdrop .buy-modal {
        border-radius: 16px 16px 0 0;
        max-width: 100%;
        width: 100%;
        transform: translateY(100%);
        transition: transform 0.32s cubic-bezier(0.4, 0, 0.2, 1);
      }

      #buyTicketBackdrop.open .buy-modal {
        transform: translateY(0);
      }

      #buyTicketBackdrop .buy-modal-body {
        max-height: 50vh;
      }

      #buyTicketBackdrop .buy-modal::before {
        content: '';
        display: block;
        width: 40px;
        height: 4px;
        background: #e5e7eb;
        border-radius: 2px;
        margin: 12px auto 0;
      }

      #buyTicketBackdrop .auth-modal-close {
        display: none;
      }
    }

    @media (max-width: 400px) {
      .buy-modal-footer {
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
      }

      .buy-total-wrap {
        flex-direction: row;
        justify-content: space-between;
        align-items: baseline;
      }

      .buy-total-price {
        font-size: 18px;
      }

      .buy-confirm-btn {
        width: 100%;
      }

      .buy-fee-note {
        font-size: 11px;
      }
    }

    /* ── MY TICKETS PAGE ──────────────────────────────────── */
    .my-tickets-list { padding: 24px 20px; max-width: 680px; margin: 0 auto; display: flex; flex-direction: column; gap: 16px; }

    .tickets-empty { display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 80px 20px; text-align: center; }
    .tickets-empty-icon { font-size: 48px; }
    .tickets-empty-msg { font-size: 15px; color: var(--text-2); margin: 0; }
    .tickets-empty-cta { background: var(--accent, #FF5C00); color: #fff; border: none; border-radius: var(--radius-sm); padding: 10px 22px; font-size: 14px; font-weight: 600; font-family: inherit; cursor: pointer; transition: opacity 0.15s; }
    .tickets-empty-cta:hover { opacity: 0.88; }

    .ticket-card {
      display: flex; gap: 0;
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      overflow: hidden;
      box-shadow: var(--shadow-sm);
      transition: box-shadow 0.15s;
    }
    .ticket-card:hover { box-shadow: var(--shadow-md); }
    .ticket-card-dim { opacity: 0.6; }

    .ticket-card-main { flex: 1; padding: 18px 20px; display: flex; flex-direction: column; gap: 7px; min-width: 0; }

    .ticket-card-header { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
    .ticket-cat-badge { font-size: 12px; font-weight: 600; color: var(--text-2); background: var(--bg); border: 1px solid var(--border); border-radius: 20px; padding: 2px 9px; text-transform: capitalize; }
    .ticket-status-badge { font-size: 11px; font-weight: 700; border-radius: 20px; padding: 2px 9px; letter-spacing: 0.3px; text-transform: uppercase; }
    .ticket-status-confirmed, .ticket-status-paid { background: #ECFDF5; color: #059669; }
    .ticket-status-pending { background: #FFF7ED; color: #EA580C; }
    .ticket-status-cancelled { background: #FEF2F2; color: #DC2626; }
    .ticket-status-refunded { background: #F3F4F6; color: #6B7280; }

    .ticket-event-name { font-size: 17px; font-weight: 700; color: var(--text-1); line-height: 1.3; }

    .ticket-meta-row { display: flex; align-items: center; gap: 6px; }
    .ticket-meta-item { font-size: 13px; color: var(--text-2); }

    .ticket-tier-row { display: flex; align-items: center; gap: 8px; margin-top: 2px; }
    .ticket-tier-name { font-size: 13px; font-weight: 600; color: var(--accent, #FF5C00); background: color-mix(in srgb, var(--accent, #FF5C00) 10%, transparent); border-radius: 4px; padding: 2px 8px; }
    .ticket-qty { font-size: 12px; color: var(--text-3); font-weight: 500; }

    .ticket-ref { font-size: 12px; color: var(--text-3); margin-top: 2px; }
    .ticket-ref-val { font-family: 'Courier New', monospace; letter-spacing: 0.5px; color: var(--text-2); }

    .ticket-card-qr {
      width: 108px; flex-shrink: 0;
      background: var(--bg);
      border-left: 1px dashed var(--border);
      display: flex; flex-direction: column; align-items: center; justify-content: center;
      gap: 6px; padding: 14px 10px;
    }
    .ticket-qr-target { width: 80px; height: 80px; }
    .ticket-qr-target img, .ticket-qr-target canvas { display: block !important; }
    .ticket-qr-label { font-size: 9px; color: var(--text-3); font-family: 'Courier New', monospace; letter-spacing: 0.4px; text-align: center; word-break: break-all; }

    .ticket-card:hover .ticket-card-qr { background: color-mix(in srgb, var(--accent, #FF5C00) 5%, var(--bg)); }

    @media (max-width: 520px) {
      .ticket-card-qr { width: 88px; }
      .ticket-qr-target { width: 64px; height: 64px; }
      .ticket-event-name { font-size: 15px; }
    }

    /* ── TICKET DETAIL MODAL ─────────────────────────────── */
    .ticket-detail-backdrop {
      position: fixed; inset: 0;
      background: rgba(12, 12, 20, 0.72);
      z-index: 9000;
      display: flex; align-items: center; justify-content: center;
      padding: 20px;
      opacity: 0; transition: opacity 0.2s;
    }
    .ticket-detail-backdrop.tdm-open { opacity: 1; }
    .ticket-detail-backdrop.tdm-open .ticket-detail-modal { transform: translateY(0); }

    .ticket-detail-modal {
      position: relative;
      background: var(--surface);
      border-radius: var(--radius);
      box-shadow: 0 24px 64px rgba(0,0,0,0.28);
      padding: 36px 32px 32px;
      width: 100%; max-width: 400px;
      display: flex; flex-direction: column; align-items: center; gap: 0;
      transform: translateY(20px); transition: transform 0.22s;
    }

    .ticket-detail-close {
      position: absolute; top: 14px; right: 14px;
      background: var(--bg); border: 1px solid var(--border);
      border-radius: 50%; width: 34px; height: 34px;
      display: flex; align-items: center; justify-content: center;
      cursor: pointer; color: var(--text-2);
      transition: background 0.15s, color 0.15s;
    }
    .ticket-detail-close:hover { background: var(--border); color: var(--text-1); }

    .tdm-event-name { font-size: 22px; font-weight: 800; color: var(--text-1); text-align: center; line-height: 1.25; margin-bottom: 10px; }

    .tdm-meta { display: flex; flex-direction: column; align-items: center; gap: 4px; margin-bottom: 14px; }
    .tdm-meta span { font-size: 13px; color: var(--text-2); }

    .tdm-tier-row { display: flex; align-items: center; gap: 8px; margin-bottom: 28px; }

    .tdm-qr-wrap {
      background: #FFFFFF;
      border-radius: var(--radius-sm);
      padding: 16px;
      box-shadow: 0 2px 12px rgba(0,0,0,0.1);
      margin-bottom: 20px;
    }
    .tdm-qr-target { width: 256px; height: 256px; display: flex; align-items: center; justify-content: center; }
    .tdm-qr-target img, .tdm-qr-target canvas { display: block !important; }

    .tdm-ref { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; color: var(--text-3); margin-bottom: 4px; }
    .tdm-ref-val { font-family: 'Courier New', monospace; font-size: 14px; font-weight: 700; color: var(--text-1); letter-spacing: 1px; }

    @media (max-width: 460px) {
      .ticket-detail-modal { padding: 28px 18px 24px; }
      .tdm-qr-target { width: 200px; height: 200px; }
      .tdm-qr-wrap { padding: 12px; }
      .tdm-event-name { font-size: 18px; }
    }

    /* ── DUPLICATE EVENT MODAL ──────────────────────────────── */
    .dup-backdrop {
      position: fixed; inset: 0;
      background: rgba(12, 12, 20, 0.7);
      z-index: 9100;
      display: flex; align-items: center; justify-content: center;
      padding: 20px;
      opacity: 0; transition: opacity 0.2s;
    }
    .dup-backdrop.dup-open { opacity: 1; }
    .dup-backdrop.dup-open .dup-modal { transform: translateY(0); }

    .dup-modal {
      background: var(--surface);
      border-radius: var(--radius);
      box-shadow: 0 24px 64px rgba(0,0,0,0.26);
      padding: 28px 26px 24px;
      width: 100%; max-width: 440px;
      display: flex; flex-direction: column; gap: 18px;
      transform: translateY(18px); transition: transform 0.22s;
    }

    .dup-header { display: flex; gap: 12px; align-items: flex-start; }
    .dup-header-icon { font-size: 24px; flex-shrink: 0; line-height: 1; }
    .dup-title { font-size: 17px; font-weight: 700; color: var(--text-1); }
    .dup-subtitle { font-size: 13px; color: var(--text-2); margin-top: 2px; }

    .dup-existing-card {
      background: var(--bg);
      border: 1px solid var(--border);
      border-left: 3px solid var(--accent, #FF5C00);
      border-radius: var(--radius-sm);
      padding: 12px 14px;
    }
    .dup-existing-name { font-size: 15px; font-weight: 700; color: var(--text-1); margin-bottom: 6px; }
    .dup-existing-meta { display: flex; flex-wrap: wrap; gap: 6px 14px; }
    .dup-existing-meta span { font-size: 12px; color: var(--text-2); }

    .dup-question { font-size: 14px; font-weight: 600; color: var(--text-1); }

    .dup-options { display: flex; flex-direction: column; gap: 8px; }
    .dup-opt {
      display: flex; align-items: flex-start; gap: 12px;
      background: var(--bg); border: 1.5px solid var(--border);
      border-radius: var(--radius-sm); padding: 12px 14px;
      cursor: pointer; text-align: left;
      transition: border-color 0.15s, background 0.15s;
    }
    .dup-opt:hover { border-color: var(--accent, #FF5C00); background: var(--surface); }
    .dup-opt-active { border-color: var(--accent, #FF5C00) !important; background: color-mix(in srgb, var(--accent, #FF5C00) 6%, var(--surface)) !important; }
    .dup-opt-indicator {
      width: 16px; height: 16px; border-radius: 50%;
      border: 2px solid var(--border); flex-shrink: 0; margin-top: 2px;
      transition: border-color 0.15s, background 0.15s;
    }
    .dup-opt-active .dup-opt-indicator { border-color: var(--accent, #FF5C00); background: var(--accent, #FF5C00); }
    .dup-opt-label { font-size: 13px; font-weight: 600; color: var(--text-1); display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
    .dup-opt-tag { font-size: 10px; font-weight: 700; background: color-mix(in srgb, var(--accent, #FF5C00) 15%, transparent); color: var(--accent, #FF5C00); padding: 1px 6px; border-radius: 10px; text-transform: uppercase; letter-spacing: 0.4px; }
    .dup-opt-desc { font-size: 12px; color: var(--text-3); margin-top: 2px; }

    .dup-side-toggle { display: flex; flex-direction: column; gap: 8px; }
    .dup-side-label { font-size: 13px; font-weight: 600; color: var(--text-2); }
    .dup-side-btns { display: flex; gap: 8px; }
    .dup-side-btn {
      flex: 1; padding: 10px; border-radius: var(--radius-sm);
      border: 1.5px solid var(--border); background: var(--bg);
      font-size: 13px; font-weight: 600; color: var(--text-2);
      cursor: pointer; transition: border-color 0.15s, color 0.15s;
    }
    .dup-side-btn:hover { border-color: var(--accent, #FF5C00); color: var(--text-1); }
    .dup-side-active { border-color: var(--accent, #FF5C00) !important; color: var(--accent, #FF5C00) !important; background: color-mix(in srgb, var(--accent, #FF5C00) 8%, var(--bg)) !important; }

    .dup-footer { display: flex; align-items: center; gap: 16px; }
    .dup-confirm-btn {
      flex: 1; padding: 11px; border-radius: var(--radius-sm);
      background: var(--accent, #FF5C00); color: #fff;
      border: none; font-size: 14px; font-weight: 700;
      font-family: inherit; cursor: pointer; transition: opacity 0.15s;
    }
    .dup-confirm-btn:disabled { opacity: 0.38; cursor: default; }
    .dup-confirm-btn:not(:disabled):hover { opacity: 0.88; }
    .dup-cancel-link {
      background: none; border: none; font-size: 13px;
      color: var(--text-3); cursor: pointer; font-family: inherit;
      text-decoration: underline; padding: 0; white-space: nowrap;
    }
    .dup-cancel-link:hover { color: var(--text-2); }

    /* ── NOTIFICATION PANEL ──────────────────────────────────── */
    .notif-panel-backdrop {
      display: none;
      position: fixed; inset: 0; z-index: 290;
      background: rgba(12,12,20,0.25);
    }
    .notif-panel-backdrop.open { display: block; }

    .notif-panel {
      position: fixed; top: 0; right: 0; bottom: 0; z-index: 295;
      width: 360px; max-width: 100vw;
      background: var(--surface);
      border-left: 1px solid var(--border);
      box-shadow: var(--shadow-lg);
      display: flex; flex-direction: column;
      transform: translateX(100%);
      transition: transform 0.28s cubic-bezier(0.4,0,0.2,1);
    }
    .notif-panel.open { transform: translateX(0); }

    .notif-panel-header {
      display: flex; align-items: center; gap: 8px;
      padding: 18px 20px 14px;
      border-bottom: 1px solid var(--border);
      flex-shrink: 0;
    }
    .notif-panel-title { font-size: 15px; font-weight: 700; flex: 1; color: var(--text-1); }
    .notif-mark-all-btn {
      font-size: 12px; font-weight: 500; color: var(--orange);
      background: none; border: none; cursor: pointer; font-family: inherit;
      padding: 4px 8px; border-radius: var(--radius-xs);
      transition: background 0.15s;
    }
    .notif-mark-all-btn:hover { background: var(--orange-soft); }
    .notif-close-btn {
      width: 28px; height: 28px; display: flex; align-items: center; justify-content: center;
      border: none; background: none; cursor: pointer; color: var(--text-2);
      border-radius: var(--radius-xs); transition: background 0.15s;
    }
    .notif-close-btn:hover { background: var(--border); }

    .notif-panel-list {
      flex: 1; overflow-y: auto; padding: 8px 0;
    }
    .notif-item {
      padding: 12px 20px; cursor: pointer;
      border-bottom: 1px solid var(--border-2);
      transition: background 0.15s;
    }
    .notif-item:hover { background: var(--bg); }
    .notif-item.unread { background: var(--orange-soft); }
    .notif-item.unread:hover { background: #ffe4d2; }
    .notif-item-title { font-size: 13px; font-weight: 600; color: var(--text-1); margin-bottom: 2px; }
    .notif-item-body { font-size: 12px; color: var(--text-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .notif-item-time { font-size: 11px; color: var(--text-3); margin-top: 4px; }
    .notif-empty {
      padding: 48px 20px; text-align: center;
      font-size: 14px; color: var(--text-3);
    }

    /* ── OWNER PRO PANEL ─────────────────────────────────────── */
    .owner-panel-section {
      padding: 24px;
      border-top: 1px solid var(--border);
      max-width: 1100px; margin: 0 auto; width: 100%;
    }
    .owner-panel-header {
      display: flex; align-items: center; justify-content: space-between;
      margin-bottom: 14px;
    }
    .owner-panel-title { font-size: 15px; font-weight: 700; color: var(--text-1); }
    .btn-export-csv {
      font-size: 12px; font-weight: 600; color: var(--orange);
      background: var(--orange-soft); border: none; cursor: pointer;
      padding: 6px 12px; border-radius: var(--radius-xs);
      font-family: inherit; transition: opacity 0.15s;
    }
    .btn-export-csv:hover { opacity: 0.8; }

    .attendee-list { display: flex; flex-direction: column; gap: 2px; }
    .attendee-row {
      display: grid; grid-template-columns: 1fr 1.4fr auto;
      gap: 12px; align-items: center;
      padding: 8px 10px; border-radius: var(--radius-xs);
      background: var(--bg); font-size: 13px;
    }
    .attendee-name { font-weight: 600; color: var(--text-1); }
    .attendee-email { color: var(--text-2); }
    .attendee-time { color: var(--text-3); white-space: nowrap; }
    .attendee-empty { font-size: 13px; color: var(--text-3); padding: 16px 0; }

    /* Blurred / locked state */
    .pro-lock-wrap { position: relative; }
    .attendee-list-blurred { filter: blur(5px); user-select: none; pointer-events: none; }
    .pro-lock-overlay {
      position: absolute; inset: 0;
      display: flex; flex-direction: column; align-items: center; justify-content: center;
      background: rgba(247,244,241,0.88); gap: 8px;
      padding: 16px;
    }
    .pro-lock-star { font-size: 24px; color: var(--orange); }
    .pro-lock-msg { font-size: 13px; font-weight: 600; color: var(--text-1); text-align: center; }
    .btn-upgrade-pro {
      margin-top: 4px; padding: 8px 18px; border-radius: var(--radius-sm);
      background: var(--orange); color: #fff; border: none;
      font-size: 13px; font-weight: 700; font-family: inherit;
      cursor: pointer; transition: opacity 0.15s;
    }
    .btn-upgrade-pro:hover { opacity: 0.88; }

    /* Broadcast / Pro-locked action button */
    .detail-btn-broadcast {
      background: var(--orange-soft); color: var(--orange);
      border: 1.5px solid var(--orange); font-weight: 600;
    }
    .detail-btn-broadcast:hover:not(:disabled) { background: var(--orange); color: #fff; }
    .detail-btn-pro-locked { opacity: 0.45; cursor: default; }
    .pro-badge-inline {
      display: inline-block; font-size: 10px; font-weight: 700;
      background: var(--orange); color: #fff;
      padding: 1px 5px; border-radius: 4px; vertical-align: middle; margin-left: 4px;
    }

    /* ── OVERLAY ICON BUTTON (gear etc.) ────────────────────── */
    .overlay-icon-btn {
      width: 36px; height: 36px;
      border-radius: var(--radius-xs);
      background: none;
      border: 1px solid var(--border);
      display: flex; align-items: center; justify-content: center;
      cursor: pointer;
      color: var(--text-2);
      transition: background 0.18s, color 0.18s, border-color 0.18s;
    }
    .overlay-icon-btn:hover { background: var(--bg); color: var(--text-1); }

    /* ── SETTINGS PAGE ───────────────────────────────────────── */
    .settings-body {
      max-width: 520px;
      margin: 0 auto;
      padding: 32px 5% 80px;
    }
    .settings-section {
      margin-bottom: 32px;
    }
    .settings-section-title {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--text-3);
      padding: 0 0 10px;
      border-bottom: 1px solid var(--border);
      margin-bottom: 4px;
    }
    .settings-row {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 14px 0;
      border-bottom: 1px solid var(--border);
    }
    .settings-row-label {
      font-size: 14px;
      font-weight: 500;
      color: var(--text-1);
    }
    .lang-pill-group {
      display: flex;
      gap: 6px;
    }
    .lang-pill {
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 0.04em;
      padding: 5px 14px;
      border-radius: 999px;
      border: 1.5px solid var(--border);
      background: none;
      color: var(--text-2);
      cursor: pointer;
      font-family: inherit;
      transition: background 0.15s, color 0.15s, border-color 0.15s;
    }
    .lang-pill.lang-pill-active {
      background: var(--orange);
      border-color: var(--orange);
      color: #fff;
    }
    .settings-link-row {
      display: flex;
      align-items: center;
      justify-content: space-between;
      width: 100%;
      padding: 14px 0;
      border-bottom: 1px solid var(--border);
      background: none;
      border-left: none;
      border-right: none;
      border-top: none;
      cursor: pointer;
      font-family: inherit;
      font-size: 14px;
      font-weight: 500;
      color: var(--text-1);
      text-align: left;
      transition: color 0.15s;
    }
    .settings-link-row:hover { color: var(--orange); }
    .settings-link-row svg { color: var(--text-3); flex-shrink: 0; }
    .settings-plan-badge {
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 0.05em;
      text-transform: uppercase;
      padding: 3px 10px;
      border-radius: 999px;
      background: var(--bg);
      border: 1.5px solid var(--border);
      color: var(--text-2);
    }
    .settings-plan-badge-pro {
      background: linear-gradient(130deg, var(--orange) 0%, var(--red) 100%);
      border-color: transparent;
      color: #fff;
    }
    .btn-cancel-sub {
      font-size: 13px;
      font-weight: 600;
      color: var(--text-2);
      background: none;
      border: 1.5px solid var(--border);
      padding: 8px 16px;
      border-radius: var(--radius-xs);
      cursor: pointer;
      font-family: inherit;
      transition: border-color 0.15s, color 0.15s;
    }
    .btn-cancel-sub:hover {
      border-color: var(--red);
      color: var(--red);
    }

    /* ── LANGUAGE TOGGLE ─────────────────────────────────────── */
    .lang-toggle-btn {
      font-size: 12px; font-weight: 700;
      background: none; border: 1.5px solid var(--border);
      color: var(--text-2); cursor: pointer; font-family: inherit;
      padding: 4px 9px; border-radius: var(--radius-xs);
      transition: border-color 0.15s, color 0.15s;
      letter-spacing: 0.04em;
    }
    .lang-toggle-btn:hover { border-color: var(--orange); color: var(--orange); }

    /* ── BOTTOM NAV ──────────────────────────────────────────── */
    .bottom-nav {
      position: fixed;
      bottom: 0; left: 0; right: 0;
      height: calc(60px + env(safe-area-inset-bottom));
      padding-bottom: env(safe-area-inset-bottom);
      background: var(--surface);
      border-top: 1px solid var(--border);
      z-index: 200;
      align-items: stretch;
      justify-content: space-around;
      box-shadow: 0 -2px 12px rgba(12,12,20,0.06);
    }

    .bn-item {
      flex: 1;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 3px;
      background: none;
      border: none;
      cursor: pointer;
      color: var(--text-3);
      font-family: inherit;
      font-size: 10px;
      font-weight: 500;
      padding: 8px 4px;
      touch-action: manipulation;
      transition: color 0.15s;
      min-width: 0;
      -webkit-tap-highlight-color: transparent;
    }

    .bn-item:active { opacity: 0.65; }

    .bn-item.bn-active { color: var(--orange); }

    .bn-item span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; }

    /* ── UPGRADE TO PRO PAGE ─────────────────────────────────── */
    .btn-upgrade-pro-nav {
      font-size: 13px;
      font-weight: 700;
      color: #fff;
      background: linear-gradient(130deg, var(--orange) 0%, var(--red) 100%);
      border: none;
      padding: 8px 18px;
      border-radius: var(--radius-xs);
      cursor: pointer;
      font-family: inherit;
      transition: opacity 0.18s, transform 0.15s, box-shadow 0.18s;
      box-shadow: 0 3px 12px rgba(255,92,0,0.28);
    }
    .btn-upgrade-pro-nav:hover {
      opacity: 0.92;
      transform: translateY(-1px);
      box-shadow: 0 6px 18px rgba(255,92,0,0.38);
    }

    .upgrade-pro-body {
      padding: 32px 5% 80px;
      display: flex;
      justify-content: center;
    }

    .upgrade-pro-card {
      width: 100%;
      max-width: 520px;
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 36px 32px 32px;
      box-shadow: var(--shadow-md);
    }

    .upgrade-pro-badge {
      display: inline-block;
      background: linear-gradient(130deg, var(--orange) 0%, var(--red) 100%);
      color: #fff;
      font-size: 12px;
      font-weight: 800;
      letter-spacing: 0.06em;
      padding: 4px 12px;
      border-radius: 999px;
      margin-bottom: 16px;
    }

    .upgrade-pro-title {
      font-size: 24px;
      font-weight: 800;
      letter-spacing: -0.5px;
      color: var(--text-1);
      margin: 0 0 8px;
    }

    .upgrade-pro-subtitle {
      font-size: 15px;
      color: var(--text-2);
      margin: 0 0 28px;
    }

    .upgrade-pro-features {
      list-style: none;
      padding: 0;
      margin: 0 0 28px;
      display: flex;
      flex-direction: column;
      gap: 12px;
    }

    .upgrade-pro-features li {
      display: flex;
      align-items: center;
      gap: 10px;
      font-size: 14px;
      font-weight: 500;
      color: var(--text-1);
    }

    .upf-icon {
      font-size: 18px;
      width: 26px;
      flex-shrink: 0;
      text-align: center;
    }

    .upgrade-pro-price {
      padding: 16px 0;
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      margin-bottom: 28px;
      text-align: center;
    }

    .upgrade-pro-coming-soon {
      font-size: 15px;
      font-weight: 700;
      color: var(--orange);
    }

    .upgrade-pro-waitlist-label {
      font-size: 14px;
      font-weight: 600;
      color: var(--text-1);
      margin: 0 0 10px;
    }

    .upgrade-pro-waitlist-row {
      display: flex;
      gap: 8px;
    }

    .upgrade-pro-email-input {
      flex: 1;
      padding: 10px 14px;
      border: 1px solid var(--border);
      border-radius: var(--radius-sm);
      font-size: 14px;
      font-family: inherit;
      background: var(--bg);
      color: var(--text-1);
      outline: none;
      transition: border-color 0.18s;
    }
    .upgrade-pro-email-input:focus { border-color: var(--orange); }

    .upgrade-pro-notify-btn {
      padding: 10px 20px;
      background: linear-gradient(130deg, var(--orange) 0%, var(--red) 100%);
      color: #fff;
      border: none;
      border-radius: var(--radius-sm);
      font-size: 14px;
      font-weight: 700;
      font-family: inherit;
      cursor: pointer;
      white-space: nowrap;
      transition: opacity 0.18s, transform 0.15s;
      box-shadow: 0 3px 12px rgba(255,92,0,0.25);
    }
    .upgrade-pro-notify-btn:hover { opacity: 0.9; transform: translateY(-1px); }

    .upgrade-pro-waitlist-msg {
      margin: 10px 0 0;
      font-size: 13px;
      font-weight: 600;
    }

    /* ── TICKET SCANNER ──────────────────────────────────── */
    .scan-body {
      display: flex;
      flex-direction: column;
      align-items: center;
      padding: 28px 20px 40px;
      gap: 20px;
      background: var(--bg);
      min-height: calc(100vh - 56px);
    }

    .scan-viewport-wrap {
      width: 100%;
      max-width: 360px;
      border-radius: 18px;
      overflow: hidden;
      background: #000;
      aspect-ratio: 1 / 1;
      position: relative;
      box-shadow: 0 8px 32px rgba(12,12,20,0.18);
    }

    /* Html5Qrcode injects its own elements — normalize them */
    #scanReader {
      width: 100% !important;
      height: 100% !important;
      border: none !important;
    }
    #scanReader video {
      width: 100% !important;
      height: 100% !important;
      object-fit: cover !important;
    }
    #scanReader img { display: none !important; }
    #scanReader__dashboard_section_csr,
    #scanReader__dashboard,
    #scanReader__filescan_input { display: none !important; }

    .scan-hint {
      font-size: 14px;
      color: var(--text-2);
      text-align: center;
      margin: 0;
    }

    .scan-result-wrap {
      width: 100%;
      max-width: 360px;
    }

    .scan-result-card {
      border-radius: 16px;
      padding: 22px 24px;
      display: flex;
      flex-direction: column;
      gap: 6px;
    }

    .scan-result-card.valid {
      background: #F0FFF8;
      border: 2px solid #00A86B;
    }

    .scan-result-card.used {
      background: #FFF1F1;
      border: 2px solid #E8002D;
    }

    .scan-result-card.warning {
      background: #FFF7ED;
      border: 2px solid #F97316;
    }

    .scan-result-card.unknown {
      background: #FFFBEB;
      border: 2px solid #F59E0B;
    }

    .scan-result-icon {
      font-size: 32px;
      line-height: 1;
    }

    .scan-result-status {
      font-size: 17px;
      font-weight: 700;
      margin-top: 4px;
    }

    .scan-result-status.valid   { color: #00A86B; }
    .scan-result-status.used    { color: #E8002D; }
    .scan-result-status.warning { color: #F97316; }
    .scan-result-status.unknown { color: #B45309; }

    .scan-result-detail {
      font-size: 14px;
      color: var(--text-2);
      line-height: 1.6;
      margin-top: 2px;
    }

    .scan-manual-wrap {
      width: 100%;
      max-width: 360px;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 12px;
    }

    .scan-manual-toggle {
      background: none;
      border: none;
      color: var(--text-3, #888);
      font-size: 13px;
      cursor: pointer;
      padding: 4px 8px;
      text-decoration: underline;
      text-underline-offset: 3px;
    }

    .scan-manual-body {
      width: 100%;
      display: flex;
      gap: 8px;
    }

    .scan-manual-input {
      flex: 1;
      border: 1.5px solid var(--border, #e0e0e0);
      border-radius: 10px;
      padding: 10px 14px;
      font-size: 15px;
      font-family: monospace;
      letter-spacing: 0.05em;
      background: var(--surface-1, #fff);
      color: var(--text-1);
      outline: none;
    }
    .scan-manual-input:focus {
      border-color: var(--accent, #FF5C00);
    }

    .scan-manual-verify-btn {
      background: var(--accent, #FF5C00);
      color: #fff;
      border: none;
      border-radius: 10px;
      padding: 10px 18px;
      font-size: 15px;
      font-weight: 600;
      cursor: pointer;
    }
    .scan-manual-verify-btn:disabled {
      opacity: 0.5;
      cursor: not-allowed;
    }

    .detail-btn-scan {
      background: #0C0C14;
      color: #fff;
    }
    .detail-btn-scan:hover { background: #2a2a3a; }

    /* Tab active colour — text uses primary, indicator line uses secondary */
    #pageOrgProfile .org-tab.active {
      color: var(--org-primary, #FF5C00);
      border-bottom-color: var(--org-secondary, #E8002D);
    }
    /* Card header accents — primary on white surface */
    #pageOrgProfile .org-sidebar-title,
    #pageOrgProfile .org-panel-title {
      color: var(--org-primary, #FF5C00);
      border-left: 3px solid var(--org-primary, #FF5C00);
      padding-left: 10px;
    }
    /* Stat values — secondary accent underline bar, text stays neutral */
    #pageOrgProfile .org-sidebar-stat-value {
      color: var(--text-1);
      border-bottom: 2px solid var(--org-secondary, #E8002D);
      padding-bottom: 3px;
      display: inline-block;
    }
    /* Paid ticket pill inside org profile uses secondary */
    #pageOrgProfile .card-price-badge.paid {
      background: var(--org-secondary, #E8002D);
      color: var(--hero-secondary-text, #fff);
    }
    /* Upcoming fixture Next badge uses secondary */
    #pageOrgProfile .org-fixture-next {
      background: var(--org-secondary, #E8002D);
      color: var(--hero-secondary-text, #fff);
    }

    .org-color-streak {
      display: block;
      width: 100%;
      pointer-events: none;
    }

    #pageOrgProfile .org-tabs {
      background: var(--surface, #fff);
      border-bottom: 2px solid var(--border);
      overflow-x: auto;
      scrollbar-width: none;
    }

    #pageOrgProfile .org-tab {
      background: none;
      border-radius: 0;
      padding: 10px 20px;
      border: none;
      border-bottom: 2px solid transparent;
      margin: 0 0 -2px;
      color: var(--text-3);
    }

    #pageOrgProfile .org-tab.active {
      background: var(--surface);
      color: var(--orange);
      border-color: var(--orange);
    }

    /* ── HOME FEED TABS ─────────────────────────────────────── */
    .home-feed-tabs {
      display: flex;
      gap: 0;
      padding: 0 5%;
      border-bottom: 1px solid var(--border);
      background: var(--surface);
      position: sticky;
      top: 0;
      z-index: 20;
    }

    .home-feed-tab {
      padding: 12px 24px;
      font-size: 15px;
      font-weight: 500;
      color: var(--text-3);
      border: none;
      background: none;
      border-bottom: 2px solid transparent;
      cursor: pointer;
      transition: color 0.15s, border-color 0.15s;
      font-family: inherit;
    }

    .home-feed-tab.active {
      color: var(--orange);
      border-bottom-color: var(--orange);
    }

    #followingPanel {
      max-width: 680px;
      margin: 0 auto;
      padding: 16px 5% 80px;
    }

    .following-feed-header {
      display: flex;
      justify-content: flex-end;
      margin-bottom: 8px;
    }

    .feed-refresh-btn {
      font-size: 12px;
      color: var(--text-3);
      background: none;
      border: none;
      cursor: pointer;
      padding: 4px 8px;
      border-radius: var(--radius-xs);
      transition: color 0.15s;
      font-family: inherit;
    }

    .feed-refresh-btn:hover { color: var(--orange); }

    .post-author-row {
      display: flex;
      align-items: center;
      gap: 10px;
      padding-bottom: 10px;
      margin-bottom: 10px;
      border-bottom: 1px solid var(--border);
      cursor: pointer;
    }

    .post-author-row:hover .post-author-name { color: var(--orange); }

    .post-author-av {
      width: 32px;
      height: 32px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 12px;
      font-weight: 600;
      color: #fff;
      flex-shrink: 0;
    }

    .post-author-name {
      font-size: 13px;
      font-weight: 500;
      color: var(--text-1);
      flex: 1;
      transition: color 0.15s;
    }

    .post-author-time {
      font-size: 11px;
      color: var(--text-3);
      white-space: nowrap;
    }

    .feed-empty-state {
      text-align: center;
      padding: 48px 20px;
    }

    .feed-empty-title {
      font-size: 16px;
      font-weight: 500;
      color: var(--text-1);
      margin-bottom: 8px;
    }

    .feed-empty-sub {
      font-size: 14px;
      color: var(--text-3);
      line-height: 1.6;
      margin-bottom: 20px;
      max-width: 300px;
      margin-left: auto;
      margin-right: auto;
    }

    .feed-empty-btn {
      display: inline-block;
      background: var(--orange);
      color: #fff;
      border: none;
      border-radius: var(--radius-sm);
      padding: 10px 24px;
      font-size: 13px;
      font-weight: 500;
      cursor: pointer;
      font-family: inherit;
    }

    /* ── ORG / FAN DESKTOP LAYOUTS ──────────────────────────── */
    @media (min-width: 768px) {
      .org-desktop-layout {
        display: grid;
        grid-template-columns: 1fr 300px;
        gap: 24px;
        align-items: start;
        padding: 0 5% 80px;
      }

      .fan-desktop-layout {
        display: grid;
        grid-template-columns: 220px 1fr;
        gap: 24px;
        padding: 16px 5% 80px;
        align-items: start;
      }

      .fan-sidebar-col {
        background: var(--surface);
        border: 1px solid var(--border);
        border-radius: var(--radius);
        padding: 16px;
        position: sticky;
        top: 16px;
      }
    }

    @media (max-width: 767px) {
      .org-desktop-layout  { display: block; }
      .org-sidebar-col     { display: none; }
      .fan-desktop-layout  { display: block; }
      .fan-sidebar-col     { display: none; }
    }

    .org-sidebar-card {
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 16px;
      margin-bottom: 14px;
    }

    .org-sidebar-title {
      font-size: 11px;
      font-weight: 600;
      color: var(--text-3);
      text-transform: uppercase;
      letter-spacing: 0.5px;
      margin-bottom: 12px;
    }

    .org-sidebar-stats-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 8px;
    }

    .org-sidebar-stat-item { text-align: center; }

    .org-sidebar-stat-value {
      font-size: 18px;
      font-weight: 700;
      color: var(--text-1);
    }

    .org-sidebar-stat-label {
      font-size: 10px;
      text-transform: uppercase;
      color: var(--text-3);
      letter-spacing: 0.4px;
    }

    .org-fixture-row {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 6px 0;
      border-bottom: 1px solid var(--border);
    }

    .org-fixture-row:last-child { border-bottom: none; }

    .org-fixture-date {
      font-size: 11px;
      color: var(--text-3);
      min-width: 40px;
      flex-shrink: 0;
    }

    .org-fixture-name {
      flex: 1;
      font-size: 12px;
      color: var(--text-1);
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .org-fixture-next {
      font-size: 10px;
      background: var(--orange-soft);
      color: var(--orange);
      padding: 2px 7px;
      border-radius: 6px;
      white-space: nowrap;
      flex-shrink: 0;
    }

    .org-topfan-row {
      display: flex;
      align-items: center;
      gap: 8px;
      padding: 6px 0;
      border-bottom: 1px solid var(--border);
    }

    .org-topfan-row:last-child { border-bottom: none; }

    .org-topfan-av {
      width: 28px;
      height: 28px;
      border-radius: 50%;
      background: var(--orange-soft);
      color: var(--orange);
      font-size: 11px;
      font-weight: 600;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }

    .org-topfan-info { flex: 1; min-width: 0; }

    .org-topfan-name {
      font-size: 12px;
      color: var(--text-1);
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .org-topfan-sub {
      font-size: 10px;
      color: var(--text-3);
    }

    .org-topfan-rank {
      font-size: 10px;
      color: var(--text-3);
      flex-shrink: 0;
    }

    .fan-sidebar-section-title {
      font-size: 11px;
      font-weight: 600;
      color: var(--text-3);
      text-transform: uppercase;
      letter-spacing: 0.5px;
      margin-bottom: 8px;
      margin-top: 14px;
    }

    .fan-sidebar-section-title:first-child { margin-top: 0; }

    .fan-sidebar-value {
      font-size: 13px;
      color: var(--text-1);
      margin-bottom: 4px;
    }

    /* ── CREATE POST BUTTON (§6) ─────────────────────────────── */
    .detail-btn-create-post {
      background: linear-gradient(135deg, #FF5C00 0%, #e8002d 100%);
      color: #fff;
      border: none;
      border-radius: 10px;
      padding: 9px 16px;
      font-size: 13px;
      font-weight: 500;
    }
    .detail-btn-create-post:hover { opacity: 0.88; transform: translateY(-1px); }

    /* ── POST TYPE SELECTOR (§1) ─────────────────────────────── */
    .post-type-selector {
      display: flex;
      gap: 0;
      background: var(--bg);
      border-radius: 12px;
      padding: 4px;
      margin: 16px 0 20px;
    }

    .post-type-pill {
      flex: 1;
      text-align: center;
      padding: 8px 0;
      font-size: 13px;
      font-weight: 500;
      font-family: inherit;
      border-radius: 9px;
      border: none;
      background: transparent;
      color: var(--text-3);
      cursor: pointer;
      transition: all 0.15s;
      white-space: nowrap;
    }
    .post-type-pill:hover { color: var(--text-1); }
    .post-type-pill.active {
      background: #FF5C00;
      color: #fff;
      box-shadow: 0 1px 4px rgba(255,92,0,0.25);
    }

    /* ── POST FORM BLOCKS ────────────────────────────────────── */
    .post-form-block {
      opacity: 1;
      transition: opacity 0.15s;
    }
    .post-form-block[style*="display: none"],
    .post-form-block[style*="display:none"] {
      opacity: 0;
    }

    /* Score inputs — larger centred numerals */
    #cp-home-score,
    #cp-away-score {
      font-size: 22px;
      font-weight: 500;
      text-align: center;
      height: 56px;
    }

    /* ── WIN / LOSS / DRAW TOGGLE (§2) ──────────────────────── */
    .wld-toggle {
      display: inline-flex;
      background: var(--bg);
      border-radius: 10px;
      padding: 3px;
      gap: 0;
    }

    .wld-btn {
      padding: 6px 18px;
      font-size: 13px;
      font-weight: 500;
      font-family: inherit;
      border-radius: 8px;
      border: none;
      background: transparent;
      color: var(--text-3);
      cursor: pointer;
      transition: all 0.15s;
      white-space: nowrap;
    }
    .wld-btn:hover { color: var(--text-1); }
    .wld-btn[data-val="true"].active  { background: #1a8a4a; color: #fff; }
    .wld-btn[data-val="false"].active { background: #c0392b; color: #fff; }
    .wld-btn[data-val="null"].active  { background: #888;    color: #fff; }

    /* ── SEASON STATS EDITOR (§4) ────────────────────────────── */
    .season-stats-list {
      display: flex;
      flex-direction: column;
      margin-bottom: 4px;
    }

    .season-stat-row {
      display: flex;
      align-items: center;
      gap: 8px;
      margin-bottom: 8px;
    }

    .season-stat-row .stat-label-input { flex: 1.2; }
    .season-stat-row .stat-value-input { flex: 1; }

    .stat-delete-btn {
      width: 32px; height: 32px;
      flex-shrink: 0;
      border-radius: 8px;
      border: 0.5px solid var(--border-2);
      background: transparent;
      color: var(--text-3);
      font-size: 17px;
      line-height: 1;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      transition: border-color 0.15s, color 0.15s;
      font-family: inherit;
    }
    .stat-delete-btn:hover { border-color: #c0392b; color: #c0392b; }

    .btn-add-stat {
      display: block;
      width: 100%;
      padding: 10px;
      margin-top: 4px;
      border-radius: 10px;
      border: 1px dashed var(--border);
      background: transparent;
      color: var(--text-3);
      font-size: 13px;
      font-weight: 500;
      font-family: inherit;
      cursor: pointer;
      text-align: center;
      transition: background 0.15s, color 0.15s;
    }
    .btn-add-stat:hover { background: var(--bg); color: var(--text-1); }

    /* ── COLOR PICKER FIELD (§5) ─────────────────────────────── */
    .form-color-input {
      width: 44px;
      height: 44px;
      border-radius: 10px;
      border: 0.5px solid var(--border-2);
      cursor: pointer;
      padding: 3px;
      background: none;
      flex-shrink: 0;
      -webkit-appearance: none;
      appearance: none;
    }
    .form-color-input:hover { border-color: var(--orange); }
    .form-color-input::-webkit-color-swatch-wrapper { padding: 0; }
    .form-color-input::-webkit-color-swatch { border-radius: 7px; border: none; }

    .color-field-row {
      display: flex;
      align-items: center;
      gap: 12px;
    }
    .color-field-meta {
      display: flex;
      flex-direction: column;
      gap: 2px;
    }

    /* ── ORG PROFILE PANELS ──────────────────────────────────── */
    .org-panel { display: none; }
    .org-panel.active { display: block; }

    .org-sub-tabs {
      margin-top: 4px;
      margin-bottom: 8px;
      border-bottom: none;
      overflow-x: auto;
      scrollbar-width: none;
      -webkit-overflow-scrolling: touch;
    }

    .org-empty-state {
      text-align: center;
      padding: 32px 20px;
      color: var(--text-3);
      font-size: 14px;
      line-height: 1.6;
    }
    .org-empty-state button {
      margin-top: 12px;
      background: var(--orange);
      color: #fff;
      border: none;
      border-radius: var(--radius-sm);
      padding: 9px 20px;
      font-size: 13px;
      font-weight: 600;
      font-family: inherit;
      cursor: pointer;
    }

    /* ── POST CARDS ──────────────────────────────────────────── */
    .post-card {
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 16px;
      margin-bottom: 12px;
    }

    .post-type-label {
      font-size: 11px;
      font-weight: 500;
      color: var(--text-3);
      text-transform: uppercase;
      letter-spacing: 0.5px;
      margin-bottom: 12px;
      display: flex;
      align-items: center;
      gap: 6px;
    }

    .post-type-dot {
      width: 7px; height: 7px;
      border-radius: 50%;
      flex-shrink: 0;
    }
    .post-type-dot.result   { background: #1a8a4a; }
    .post-type-dot.announce { background: #4a90d9; }
    .post-type-dot.promo    { background: var(--orange); }

    .result-badge {
      display: block;
      text-align: center;
      margin-bottom: 10px;
    }
    .win-badge  { display: inline-block; background: #e6f7ed; color: #1a6a3a; font-size: 11px; font-weight: 600; padding: 3px 12px; border-radius: 20px; }
    .loss-badge { display: inline-block; background: #fdecea; color: #922b21; font-size: 11px; font-weight: 600; padding: 3px 12px; border-radius: 20px; }
    .draw-badge { display: inline-block; background: var(--bg); color: var(--text-2); font-size: 11px; font-weight: 600; padding: 3px 12px; border-radius: 20px; }

    .result-score-row {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 20px;
      margin: 8px 0 12px;
    }
    .result-team-block { text-align: center; flex: 1; }
    .result-team-name {
      font-size: 13px;
      color: var(--text-2);
      margin-bottom: 4px;
    }
    .result-team-score {
      font-size: 40px;
      font-weight: 700;
      color: var(--text-1);
      line-height: 1;
    }
    .result-team-score.losing { color: var(--text-3); }
    .result-vs {
      font-size: 16px;
      color: var(--text-3);
      font-weight: 500;
    }

    .post-match-meta {
      font-size: 12px;
      color: var(--text-3);
      text-align: center;
      margin-bottom: 8px;
    }

    .post-body-text {
      font-size: 14px;
      color: var(--text-1);
      line-height: 1.6;
      margin: 8px 0;
    }

    /* ── POST MEDIA GRID ─────────────────────────────────────── */
    .post-media-block {
      margin-top: 10px;
      cursor: default;
    }
    .post-media-grid {
      display: grid;
      gap: 3px;
      border-radius: 10px;
      overflow: hidden;
      width: 100%;
    }
    .post-media-grid.count-1 { grid-template-columns: 1fr; }
    .post-media-grid.count-2 { grid-template-columns: 1fr 1fr; }
    .post-media-grid.count-3 { grid-template-columns: 1fr 1fr; }
    .post-media-grid.count-4 { grid-template-columns: 1fr 1fr; }
    .post-media-img {
      width: 100%;
      height: 220px;
      object-fit: cover;
      display: block;
    }
    .post-media-span { grid-column: span 2; }

    .post-reaction-row {
      display: flex;
      align-items: center;
      gap: 12px;
      padding-top: 12px;
      border-top: 1px solid var(--border);
      margin-top: 12px;
    }
    .post-react-btn {
      font-size: 13px;
      font-family: inherit;
      color: var(--text-2);
      background: none;
      border: 1px solid var(--border);
      border-radius: var(--radius-xs);
      padding: 5px 12px;
      cursor: pointer;
      transition: all 0.15s;
    }
    .post-react-btn:hover { border-color: var(--orange); color: var(--orange); }
    .post-react-btn.reacted {
      background: var(--orange-soft);
      color: var(--orange);
      border-color: var(--orange);
    }
    .post-react-count { font-size: 12px; color: var(--text-3); }
    .post-react-count.reacted { color: var(--orange); }

    /* ── EVENT PROMO PILL ────────────────────────────────────── */
    .post-event-pill {
      display: flex;
      align-items: center;
      gap: 12px;
      background: var(--bg);
      border-radius: var(--radius-sm);
      padding: 10px 12px;
      margin: 8px 0;
    }
    .post-event-date-box {
      background: var(--orange-soft);
      border-radius: 8px;
      width: 44px;
      min-width: 44px;
      padding: 5px 0;
      text-align: center;
    }
    .ped-day { font-size: 18px; font-weight: 700; color: var(--orange); line-height: 1; }
    .ped-mon { font-size: 9px; color: var(--orange); text-transform: uppercase; letter-spacing: 0.3px; }
    .post-event-info { flex: 1; min-width: 0; }
    .post-event-name { font-size: 13px; font-weight: 600; color: var(--text-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .post-event-sub  { font-size: 11px; color: var(--text-3); margin-top: 2px; }
    .post-ticket-btn {
      background: var(--orange);
      color: #fff;
      border: none;
      border-radius: var(--radius-xs);
      padding: 7px 14px;
      font-size: 12px;
      font-weight: 600;
      font-family: inherit;
      cursor: pointer;
      flex-shrink: 0;
      transition: opacity 0.15s;
    }
    .post-ticket-btn:hover { opacity: 0.88; }

    /* ── ABOUT PANEL ─────────────────────────────────────────── */
    .org-about-panel { padding-top: 4px; }
    .about-section { margin-bottom: 20px; }
    .about-label {
      font-size: 11px;
      font-weight: 600;
      color: var(--text-3);
      text-transform: uppercase;
      letter-spacing: 0.5px;
      margin-bottom: 8px;
    }
    .about-text {
      font-size: 14px;
      color: var(--text-1);
      line-height: 1.6;
    }
    .about-empty {
      font-size: 14px;
      color: var(--text-3);
      text-align: center;
      padding: 24px 0;
    }

    /* ── SEASON STATS GRID (about panel) ─────────────────────── */
    .season-stats-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
      gap: 10px;
      margin-top: 8px;
    }
    .season-stat-item {
      background: var(--bg);
      border-radius: var(--radius-sm);
      padding: 12px 10px;
      text-align: center;
    }
    .ssi-value {
      font-size: 22px;
      font-weight: 700;
      color: var(--text-1);
    }
    .ssi-label {
      font-size: 11px;
      color: var(--text-3);
      margin-top: 3px;
      text-transform: uppercase;
      letter-spacing: 0.3px;
    }

    /* ── FAN PROFILE ─────────────────────────────────────────── */
    .fan-profile-header {
      background: var(--surface);
      padding: 20px 20px 0;
      border-bottom: 1px solid var(--border);
    }

    .fan-avatar-row {
      display: flex;
      align-items: flex-start;
      gap: 14px;
      padding-bottom: 16px;
    }

    .fan-identity { flex: 1; min-width: 0; }

    .fan-display-name {
      font-size: 20px;
      font-weight: 500;
      color: var(--text-1);
    }

    .fan-handle {
      font-size: 12px;
      color: var(--text-3);
      margin-top: 3px;
    }

    .fan-bio {
      font-size: 13px;
      color: var(--text-2);
      line-height: 1.5;
      margin-top: 6px;
    }

    .fan-level-pill {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      background: var(--orange-soft);
      color: var(--orange);
      font-size: 11px;
      font-weight: 500;
      padding: 3px 10px;
      border-radius: 20px;
      margin-top: 7px;
    }

    .fan-level-dot {
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: var(--orange);
      flex-shrink: 0;
    }

    .fan-stats-row {
      display: grid;
      grid-template-columns: 1fr 1fr 1fr;
      border-top: 1px solid var(--border);
    }

    .fan-stat {
      padding: 12px 0;
      text-align: center;
      border-right: 1px solid var(--border);
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
    }
    .fan-stat:last-child { border-right: none; }

    .fan-stat-num {
      font-size: 20px;
      font-weight: 500;
      color: var(--text-1);
    }

    .fan-stat-label {
      font-size: 10px;
      color: var(--text-3);
      text-transform: uppercase;
      letter-spacing: 0.4px;
      margin-top: 2px;
    }

    .fan-tabs-body {
      padding: 0 5% 80px;
    }

    /* ── FAN ACTIVITY CARDS ──────────────────────────────────── */
    .fan-attended-card {
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: var(--radius-sm);
      padding: 10px 12px;
      margin-bottom: 8px;
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .fan-att-date {
      background: var(--orange-soft);
      border-radius: 8px;
      width: 40px;
      min-width: 40px;
      padding: 5px 0;
      text-align: center;
    }

    .fan-att-day {
      font-size: 16px;
      font-weight: 600;
      color: var(--orange);
      line-height: 1;
    }

    .fan-att-mon {
      font-size: 9px;
      color: var(--orange);
      text-transform: uppercase;
      letter-spacing: 0.3px;
    }

    .fan-att-info { flex: 1; min-width: 0; }

    .fan-att-name {
      font-size: 13px;
      font-weight: 500;
      color: var(--text-1);
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .fan-att-org {
      font-size: 11px;
      color: var(--text-3);
      margin-top: 2px;
    }

    .fan-checkin-badge {
      font-size: 10px;
      background: #e6f7ed;
      color: #1a6a3a;
      padding: 2px 8px;
      border-radius: 6px;
      white-space: nowrap;
      flex-shrink: 0;
    }

    /* ── FAN CLUBS LIST ──────────────────────────────────────── */
    .fan-club-row {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 10px 0;
      border-bottom: 1px solid var(--border);
      cursor: pointer;
    }
    .fan-club-row:last-child { border-bottom: none; }
    .fan-club-row:active { opacity: 0.7; }

    .fan-club-av {
      width: 38px;
      height: 38px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 14px;
      font-weight: 600;
      color: #fff;
      flex-shrink: 0;
      overflow: hidden;
    }

    .fan-club-info { flex: 1; min-width: 0; }

    .fan-club-name {
      font-size: 13px;
      font-weight: 500;
      color: var(--text-1);
    }

    .fan-club-sport {
      font-size: 11px;
      color: var(--text-3);
      margin-top: 2px;
    }

    /* ── BADGES GRID ─────────────────────────────────────────── */
    .badge-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 8px;
      margin-bottom: 14px;
    }

    .badge-item {
      background: var(--bg);
      border-radius: var(--radius-sm);
      padding: 12px 6px;
      text-align: center;
      opacity: 0.35;
    }

    .badge-icon {
      font-size: 24px;
      display: block;
      margin-bottom: 5px;
    }

    .badge-name {
      font-size: 10px;
      color: var(--text-2);
      line-height: 1.3;
    }

    .badges-coming-soon {
      font-size: 12px;
      color: var(--text-3);
      text-align: center;
      padding: 4px 0 16px;
    }

    .fan-empty-state {
      text-align: center;
      padding: 32px 20px;
      font-size: 14px;
      color: var(--text-3);
      line-height: 1.6;
    }

    /* ── CREATE POST MEDIA ─────────────────────────────────────── */
    .post-media-section {
      margin-top: 8px;
      padding: 20px 0 0;
      border-top: 1px solid var(--border-2);
    }
    .post-media-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin-bottom: 12px;
    }
    .post-media-label {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.8px;
      text-transform: uppercase;
      color: var(--text-3);
    }
    .post-media-add-btn {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      padding: 7px 13px;
      border-radius: var(--radius-xs);
      background: var(--bg);
      border: 1.5px solid var(--border);
      font-size: 13px;
      font-weight: 600;
      color: var(--text-2);
      font-family: inherit;
      cursor: pointer;
      transition: border-color 0.15s, color 0.15s;
    }
    .post-media-add-btn:hover { border-color: var(--orange); color: var(--text-1); }
    .post-media-preview {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-bottom: 10px;
    }
    .post-media-thumb {
      position: relative;
      width: 80px;
      height: 80px;
      border-radius: var(--radius-xs);
      overflow: hidden;
      background: var(--bg);
      border: 1px solid var(--border);
      flex-shrink: 0;
    }
    .post-media-thumb-img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }
    .post-media-thumb-type {
      position: absolute;
      bottom: 4px;
      left: 4px;
      background: rgba(0, 0, 0, 0.6);
      color: #fff;
      font-size: 8px;
      font-weight: 700;
      letter-spacing: 0.5px;
      padding: 2px 5px;
      border-radius: 3px;
    }
    .post-media-remove {
      position: absolute;
      top: 4px;
      right: 4px;
      width: 20px;
      height: 20px;
      border-radius: 50%;
      background: rgba(0, 0, 0, 0.55);
      color: #fff;
      border: none;
      font-size: 10px;
      font-weight: 700;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      line-height: 1;
      padding: 0;
      font-family: inherit;
      transition: background 0.15s;
    }
    .post-media-remove:hover { background: var(--red); }
    .post-media-hint {
      font-size: 11px;
      color: var(--text-3);
      margin: 0;
    }

    /* ── EVENT DELETE / CANCEL MODAL ───────────────────────────────── */
    .ev-modal-backdrop {
      position: fixed; inset: 0;
      background: rgba(12, 12, 20, 0.72);
      z-index: 9200;
      display: flex; align-items: center; justify-content: center;
      padding: 20px;
      opacity: 0; transition: opacity 0.2s;
    }
    .ev-modal-backdrop.ev-modal-open { opacity: 1; }
    .ev-modal-backdrop.ev-modal-open .ev-modal-box { transform: translateY(0); }
    .ev-modal-box {
      background: var(--surface);
      border-radius: var(--radius);
      box-shadow: 0 24px 64px rgba(0,0,0,0.28);
      padding: 28px 26px 24px;
      width: 100%; max-width: 400px;
      display: flex; flex-direction: column; gap: 14px;
      transform: translateY(18px); transition: transform 0.22s;
    }
    .ev-modal-icon { font-size: 26px; line-height: 1; margin-bottom: 2px; }
    .ev-modal-title { font-size: 17px; font-weight: 700; color: var(--text-1); margin-top: 4px; }
    .ev-modal-body { font-size: 13px; color: var(--text-2); line-height: 1.6; }
    .ev-modal-footer { display: flex; gap: 10px; margin-top: 4px; }
    .ev-modal-btn {
      flex: 1; padding: 11px 8px; border-radius: var(--radius-sm);
      font-size: 14px; font-weight: 700; font-family: inherit;
      cursor: pointer; border: none; transition: opacity 0.15s;
    }
    .ev-modal-btn:hover { opacity: 0.88; }
    .ev-modal-btn-danger { background: var(--red); color: #fff; }
    .ev-modal-btn-neutral {
      background: var(--bg); color: var(--text-1);
      border: 1.5px solid var(--border) !important;
    }

    /* Cancelled badge on event cards */
    .card-cancelled-badge {
      display: inline-flex; align-items: center;
      background: var(--red); color: #fff;
      font-size: 10px; font-weight: 700; letter-spacing: 0.6px; text-transform: uppercase;
      padding: 3px 8px; border-radius: 5px;
      margin-bottom: 6px;
    }

    /* Cancelled button in detail action area */
    .detail-btn-cancelled {
      background: var(--bg) !important;
      color: var(--text-3) !important;
      border: 1.5px solid var(--border) !important;
      cursor: default !important;
      opacity: 0.72;
    }

    /* Cancelled banner at top of event detail */
    .detail-cancelled-banner {
      max-width: 1100px;
      margin: 20px auto 0;
      padding: 14px 5%;
      background: #fff0f2;
      border-left: 5px solid var(--red);
      color: var(--red);
      font-size: 15px;
      font-weight: 700;
      letter-spacing: 0.1px;
    }
