/* ==========================================================
   M&W AIRWAYS · BOARDING PASS
   Modern, active, motion-rich wedding invitation
   ========================================================== */

:root {
  /* Surface */
  --bg-0: #0a0a0c;
  --bg-1: #101015;
  --bg-2: #16161c;
  --surface: #1c1c24;

  /* Ink */
  --ink: #f3ece0;
  --ink-2: #d6cfc2;
  --ink-3: rgba(243, 236, 224, 0.55);
  --ink-4: rgba(243, 236, 224, 0.28);
  --ink-5: rgba(243, 236, 224, 0.12);

  /* Accent (warm copper) */
  --acc: #d4925c;
  --acc-2: #e8a878;
  --acc-deep: #a36a3c;

  /* Paper */
  --paper: #f3ece0;
  --paper-2: #ebe2d2;
  --paper-ink: #14140f;
  --paper-ink-2: #4a463d;
  --paper-rule: rgba(20, 20, 15, 0.12);

  /* Type */
  --f-display: 'Instrument Serif', 'Cairo', serif;
  --f-arabic-display: 'Cairo', 'IBM Plex Sans Arabic', sans-serif;
  --f-sans: 'Space Grotesk', 'IBM Plex Sans Arabic', sans-serif;
  --f-arabic: 'IBM Plex Sans Arabic', 'Cairo', sans-serif;
  --f-mono: 'Space Mono', 'Courier New', monospace;

  /* Motion */
  --ease: cubic-bezier(0.22, 0.61, 0.36, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body { margin: 0; padding: 0; }
html { background: var(--bg-0); }
body {
  font-family: var(--f-arabic);
  font-weight: 300;
  background: var(--bg-0);
  color: var(--ink);
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

button { font-family: inherit; }
a { color: inherit; text-decoration: none; }
[hidden] { display: none !important; }

/* ============================================================
   PIN GATE
   ============================================================ */
.pin-gate {
  position: fixed;
  inset: 0;
  z-index: 500;
  background:
    radial-gradient(900px 600px at 50% -10%, rgba(212, 146, 92, 0.10), transparent 60%),
    linear-gradient(180deg, #0a0a0c 0%, #0c0c0f 60%, #0a0a0c 100%);
  display: grid;
  place-items: center;
  padding: 24px;
  animation: pin-fade 0.4s ease;
}
@keyframes pin-fade { from { opacity: 0; } to { opacity: 1; } }

.pin-gate.locked-out .pin-card {
  pointer-events: none;
  opacity: 0.6;
}
.pin-gate.is-open {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.5s ease;
}

.pin-card {
  width: 100%;
  max-width: 420px;
  background: var(--paper);
  color: var(--paper-ink);
  border-radius: 12px;
  padding: 40px 36px 32px;
  text-align: center;
  box-shadow:
    0 60px 120px -40px rgba(0,0,0,0.7),
    0 30px 60px -30px rgba(212, 146, 92, 0.2);
  position: relative;
  font-family: var(--f-arabic);
}
.pin-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px dashed rgba(20, 20, 15, 0.12);
  border-radius: 6px;
  pointer-events: none;
}

.pin-brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  margin-bottom: 24px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--paper-rule);
}
.pin-brand .brand-mark {
  font-family: var(--f-display);
  font-style: italic;
  font-size: 36px;
  color: var(--paper-ink);
}
.pin-brand-meta {
  font-family: var(--f-sans);
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--paper-ink-2);
}

.pin-title { margin-bottom: 24px; }
.pin-title .kicker {
  display: block;
  font-family: var(--f-sans);
  font-size: 10px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--paper-ink-2);
  margin-bottom: 8px;
  direction: ltr;
}
.pin-title h2 {
  font-family: var(--f-arabic-display);
  font-weight: 600;
  font-size: 26px;
  margin: 0 0 8px;
  color: var(--paper-ink);
}
.pin-title p {
  margin: 0;
  font-size: 13px;
  color: var(--paper-ink-2);
  line-height: 1.6;
}

.pin-form {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.pin-row {
  display: flex;
  justify-content: center;
  gap: 10px;
  direction: ltr;
}
.pin-cell {
  width: 56px;
  height: 68px;
  border: 1.5px solid var(--paper-ink);
  border-radius: 6px;
  background: transparent;
  text-align: center;
  font-family: var(--f-mono);
  font-weight: 700;
  font-size: 28px;
  color: var(--paper-ink);
  outline: none;
  transition: all 0.2s var(--ease);
}
.pin-cell:focus {
  border-color: var(--acc);
  background: rgba(212, 146, 92, 0.08);
  box-shadow: 0 0 0 4px rgba(212, 146, 92, 0.15);
  transform: translateY(-2px);
}
.pin-cell.filled {
  background: var(--paper-ink);
  color: var(--paper);
  border-color: var(--paper-ink);
}
.pin-cell.error {
  border-color: #c44545;
  animation: shake 0.4s var(--ease);
}

.pin-msg {
  min-height: 18px;
  font-size: 13px;
  color: #c44545;
}
.pin-msg.ok { color: #2e8a4d; }

.pin-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 24px;
  background: var(--paper-ink);
  color: var(--paper);
  border: 0;
  border-radius: 6px;
  cursor: pointer;
  font-family: var(--f-arabic);
  font-size: 15px;
  font-weight: 500;
  transition: all 0.25s var(--ease);
  position: relative;
  overflow: hidden;
}
.pin-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--acc), var(--acc-2));
  opacity: 0;
  transition: opacity 0.25s;
}
.pin-cta > * { position: relative; z-index: 1; }
.pin-cta:hover:not(:disabled) { transform: translateY(-2px); }
.pin-cta:hover:not(:disabled)::before { opacity: 1; }
.pin-cta:disabled { opacity: 0.5; cursor: not-allowed; }

.pin-foot {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px dashed var(--paper-rule);
  font-size: 12px;
  color: var(--paper-ink-2);
}

@media (max-width: 480px) {
  .pin-card { padding: 32px 24px 24px; }
  .pin-cell { width: 48px; height: 60px; font-size: 24px; }
}

/* ============================================================
   AMBIENT BACKGROUND
   ============================================================ */
.ambient {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
  background:
    radial-gradient(900px 600px at 75% -10%, rgba(212, 146, 92, 0.10), transparent 60%),
    radial-gradient(700px 500px at 15% 110%, rgba(212, 146, 92, 0.06), transparent 60%),
    linear-gradient(180deg, #0a0a0c 0%, #0c0c0f 60%, #0a0a0c 100%);
}
.grain {
  position: absolute; inset: -10%;
  background-image: radial-gradient(circle at 1px 1px, rgba(255,255,255,0.025) 1px, transparent 0);
  background-size: 3px 3px;
  opacity: 0.6;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
}
.flight-path {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  opacity: 0.7;
}
.stars { position: absolute; inset: 0; }
.stars::before, .stars::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(1px 1px at 20% 30%, rgba(255,255,255,0.4), transparent),
    radial-gradient(1px 1px at 80% 60%, rgba(255,255,255,0.3), transparent),
    radial-gradient(1px 1px at 50% 80%, rgba(255,255,255,0.35), transparent),
    radial-gradient(1px 1px at 35% 15%, rgba(255,255,255,0.25), transparent),
    radial-gradient(1px 1px at 70% 25%, rgba(212,146,92,0.4), transparent),
    radial-gradient(1px 1px at 10% 70%, rgba(255,255,255,0.3), transparent),
    radial-gradient(1.5px 1.5px at 90% 85%, rgba(212,146,92,0.3), transparent);
  background-size: 100% 100%;
  animation: twinkle 8s ease-in-out infinite alternate;
}
.stars::after { animation-duration: 6s; animation-delay: -3s; opacity: 0.6; }
@keyframes twinkle {
  0%, 100% { opacity: 0.4; }
  50% { opacity: 0.9; }
}

/* ============================================================
   TOP BAR
   ============================================================ */
.topbar {
  position: relative;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 22px 36px;
  border-bottom: 1px solid var(--ink-5);
  font-family: var(--f-sans);
  font-size: 12px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  direction: ltr;
}
.brand { display: flex; align-items: center; gap: 14px; }
.brand-mark {
  font-family: var(--f-display);
  font-size: 22px;
  font-style: italic;
  letter-spacing: 0;
  text-transform: none;
  color: var(--ink);
}
.brand-divider { width: 28px; height: 1px; background: var(--ink-4); }
.brand-meta { color: var(--ink-3); font-size: 11px; }
.topbar-meta { display: flex; align-items: center; gap: 10px; color: var(--ink-3); }
.status-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #4ade80;
  box-shadow: 0 0 0 0 rgba(74, 222, 128, 0.7);
  animation: pulse-dot 2s ease-out infinite;
}
@keyframes pulse-dot {
  0%   { box-shadow: 0 0 0 0 rgba(74, 222, 128, 0.6); }
  100% { box-shadow: 0 0 0 10px rgba(74, 222, 128, 0); }
}
.status-text { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; }

/* Privacy notice on entry page */
.privacy-notice {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  background: rgba(212, 146, 92, 0.06);
  border: 1px solid rgba(212, 146, 92, 0.22);
  border-radius: 8px;
  margin-bottom: 28px;
  max-width: 520px;
}
.privacy-icon {
  flex: 0 0 auto;
  width: 32px; height: 32px;
  border-radius: 50%;
  display: grid; place-items: center;
  background: rgba(212, 146, 92, 0.15);
  color: var(--acc);
}
.privacy-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
  line-height: 1.5;
}
.privacy-text strong {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
}
.privacy-text span {
  font-size: 12px;
  color: var(--ink-3);
}

/* Privacy notice strip on the boarding pass card */
.pass-notice {
  margin-top: 20px;
  padding: 10px 14px;
  background: rgba(20, 20, 15, 0.04);
  border: 1px dashed var(--paper-rule);
  border-radius: 6px;
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--paper-ink-2);
  font-family: var(--f-arabic);
  font-size: 12px;
  letter-spacing: 0.02em;
}
.pass-notice svg { color: var(--paper-ink-2); flex: 0 0 auto; }

/* Admin link in topbar */
.admin-link {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: var(--ink-3);
  transition: all 0.2s;
}
.admin-link:hover {
  color: var(--ink);
  background: rgba(255,255,255,0.05);
}

/* Tweak topbar-meta to fit the admin link */
.topbar-meta { gap: 14px; }

/* ============================================================
   STAGE
   ============================================================ */
.stage {
  position: relative;
  z-index: 1;
  min-height: calc(100vh - 64px);
  padding: 80px 36px 60px;
}

/* ------------------------------------------------------------
   STAGE 1 · ENTRY
   ------------------------------------------------------------ */
.entry-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 80px;
  max-width: 1280px;
  margin: 0 auto;
  align-items: center;
  min-width: 0;
}
.entry-grid > * { min-width: 0; }

.entry-copy { opacity: 1; }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--f-sans);
  font-size: 11px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--acc);
  margin-bottom: 32px;
  direction: ltr;
  padding: 8px 14px;
  border: 1px solid rgba(212, 146, 92, 0.3);
  border-radius: 999px;
  background: rgba(212, 146, 92, 0.06);
}
.eyebrow-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--acc);
  box-shadow: 0 0 8px var(--acc);
}

.display {
  font-family: var(--f-display);
  font-size: clamp(72px, 9vw, 132px);
  line-height: 0.95;
  font-weight: 400;
  letter-spacing: -0.03em;
  margin: 0 0 28px;
  color: var(--ink);
}
.display .line-en {
  display: block;
  direction: ltr;
  text-align: start;
}
.display .line-en em {
  font-style: italic;
  background: linear-gradient(135deg, var(--acc-2), var(--acc), var(--acc-deep));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.display .line-ar {
  display: block;
  font-family: var(--f-arabic-display);
  font-weight: 200;
  font-size: 0.65em;
  margin-top: 8px;
  color: var(--ink-2);
}

.lede {
  font-family: var(--f-arabic);
  font-size: 18px;
  line-height: 1.85;
  color: var(--ink-3);
  max-width: 520px;
  margin: 0 0 42px;
}
.lede .hl {
  color: var(--ink);
  font-weight: 500;
  border-bottom: 1px solid var(--acc);
  padding-bottom: 2px;
}

/* Ticker */
.ticker {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  border-top: 1px solid var(--ink-5);
  border-bottom: 1px solid var(--ink-5);
  padding: 14px 0;
  overflow: hidden;
  position: relative;
  mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
}
.ticker-track {
  display: flex;
  gap: 32px;
  white-space: nowrap;
  animation: tickslide 38s linear infinite;
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  color: var(--ink-2);
  width: max-content;
}
.ticker-track .t-dot { color: var(--acc); }
@keyframes tickslide {
  from { transform: translateX(0); }
  to   { transform: translateX(50%); }
}
[dir="rtl"] .ticker-track { animation-direction: reverse; }

/* Entry card */
.entry-card {
  position: relative;
  background: var(--paper);
  color: var(--paper-ink);
  border-radius: 4px;
  padding: 36px 36px 40px;
  box-shadow:
    0 60px 120px -40px rgba(0,0,0,0.6),
    0 30px 60px -30px rgba(212, 146, 92, 0.2),
    inset 0 0 0 1px rgba(20, 20, 15, 0.06);
  opacity: 1;
  font-family: var(--f-arabic);
}
.entry-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px dashed rgba(20, 20, 15, 0.12);
  border-radius: 2px;
  pointer-events: none;
}

.card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.15em;
  color: var(--paper-ink-2);
  margin-bottom: 28px;
  direction: ltr;
}
.card-stamp { display: flex; align-items: center; gap: 8px; }
.stamp-num {
  font-family: var(--f-display);
  font-size: 18px;
  font-style: italic;
  letter-spacing: 0;
}
.stamp-id { color: var(--paper-ink); }
.card-route {
  padding: 4px 10px;
  border: 1px solid var(--paper-ink);
  border-radius: 2px;
}

.card-title { margin-bottom: 24px; }
.kicker {
  font-family: var(--f-sans);
  font-size: 10px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--paper-ink-2);
  display: block;
  margin-bottom: 8px;
  direction: ltr;
}
.card-title h2 {
  font-family: var(--f-arabic-display);
  font-weight: 600;
  font-size: 32px;
  margin: 0;
  color: var(--paper-ink);
  line-height: 1.2;
}

/* Code input */
.code-form { display: flex; flex-direction: column; gap: 24px; }
.code-input-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  direction: ltr;
}
.code-cell {
  width: 48px;
  height: 60px;
  border: 1.5px solid var(--paper-ink);
  border-radius: 4px;
  background: transparent;
  text-align: center;
  font-family: var(--f-mono);
  font-weight: 700;
  font-size: 24px;
  color: var(--paper-ink);
  text-transform: uppercase;
  transition: all 0.2s var(--ease);
  outline: none;
}
.code-cell:focus {
  border-color: var(--acc);
  background: rgba(212, 146, 92, 0.08);
  box-shadow: 0 0 0 4px rgba(212, 146, 92, 0.15);
  transform: translateY(-2px);
}
.code-cell.filled {
  background: var(--paper-ink);
  color: var(--paper);
  border-color: var(--paper-ink);
}
.code-cell.error {
  border-color: #c44545;
  animation: shake 0.4s var(--ease);
}
@keyframes shake {
  10%, 90% { transform: translateX(-2px); }
  20%, 80% { transform: translateX(3px); }
  30%, 50%, 70% { transform: translateX(-4px); }
  40%, 60% { transform: translateX(4px); }
}
.code-sep {
  font-family: var(--f-mono);
  font-size: 22px;
  color: var(--paper-ink-2);
  padding: 0 4px;
}

.name-field { display: flex; flex-direction: column; gap: 6px; }
.name-field label {
  font-family: var(--f-sans);
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--paper-ink-2);
  direction: ltr;
}
.name-field input {
  border: 0;
  border-bottom: 1.5px solid var(--paper-ink);
  background: transparent;
  font-family: var(--f-arabic);
  font-size: 18px;
  font-weight: 500;
  padding: 10px 4px;
  color: var(--paper-ink);
  outline: none;
  transition: border-color 0.2s;
}
.name-field input::placeholder { color: rgba(20,20,15,0.35); font-weight: 300; }
.name-field input:focus { border-color: var(--acc); }

.cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: 18px 28px;
  background: var(--paper-ink);
  color: var(--paper);
  border: 0;
  border-radius: 4px;
  cursor: pointer;
  font-family: var(--f-arabic);
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.02em;
  transition: all 0.25s var(--ease);
  position: relative;
  overflow: hidden;
}
.cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--acc), var(--acc-2));
  opacity: 0;
  transition: opacity 0.25s;
}
.cta > * { position: relative; z-index: 1; }
.cta:hover { transform: translateY(-2px); }
.cta:hover::before { opacity: 1; }
.cta:active { transform: translateY(0); }
.cta-arrow {
  display: grid; place-items: center;
  transition: transform 0.25s var(--ease);
}
.cta:hover .cta-arrow { transform: translateX(-4px); }
[dir="rtl"] .cta:hover .cta-arrow { transform: translateX(4px); }
[dir="rtl"] .cta-arrow svg { transform: scaleX(-1); }

.form-msg {
  min-height: 18px;
  font-family: var(--f-arabic);
  font-size: 13px;
  color: #c44545;
  text-align: center;
}
.form-msg.ok { color: #2e8a4d; }

.hint {
  font-family: var(--f-arabic);
  font-size: 12px;
  color: var(--paper-ink-2);
  text-align: center;
  border-top: 1px dashed rgba(20,20,15,0.15);
  padding-top: 16px;
}
.hint code {
  font-family: var(--f-mono);
  font-weight: 700;
  background: rgba(20,20,15,0.06);
  padding: 2px 8px;
  border-radius: 3px;
  color: var(--paper-ink);
  letter-spacing: 0.1em;
}

/* Departure board */
.board {
  max-width: 100%;
  width: 1280px;
  margin: 80px auto 0;
  border: 1px solid var(--ink-5);
  border-radius: 4px;
  background: rgba(0,0,0,0.3);
  backdrop-filter: blur(8px);
  overflow: hidden;
  box-sizing: border-box;
}
.board-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr 0.7fr 1fr;
  padding: 14px 24px;
  font-family: var(--f-mono);
  font-size: 13px;
  letter-spacing: 0.12em;
  direction: ltr;
}
.board-head {
  background: rgba(255,255,255,0.02);
  border-bottom: 1px solid var(--ink-5);
  color: var(--ink-3);
  font-size: 10px;
  letter-spacing: 0.25em;
  text-transform: uppercase;
}
.board-data {
  color: var(--ink);
  font-size: 16px;
  font-weight: 700;
}
.flip {
  position: relative;
  display: inline-block;
}
.flip.ok { color: #4ade80; }

/* ------------------------------------------------------------
   STAGE 2 · BOARDING PASS
   ------------------------------------------------------------ */
.pass-wrap {
  max-width: 1240px;
  margin: 0 auto;
}

.pass-meta {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
  margin-bottom: 40px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--ink-5);
}
.ghost-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  background: transparent;
  border: 1px solid var(--ink-5);
  border-radius: 999px;
  color: var(--ink-2);
  font-family: var(--f-arabic);
  font-size: 13px;
  cursor: pointer;
  transition: all 0.2s;
}
.ghost-btn:hover { border-color: var(--ink-3); color: var(--ink); transform: translateX(2px); }
[dir="rtl"] .ghost-btn:hover { transform: translateX(-2px); }
[dir="rtl"] .ghost-btn svg { transform: scaleX(-1); }

.pass-meta-title { text-align: center; }
.pass-meta-title .kicker { color: var(--acc); margin-bottom: 6px; }
.pass-meta-title h2 {
  font-family: var(--f-arabic-display);
  font-weight: 600;
  font-size: 22px;
  margin: 0;
  color: var(--ink);
}

.issued { text-align: end; }
.issued .k {
  font-family: var(--f-sans);
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 4px;
  direction: ltr;
}
.issued .v { font-family: var(--f-mono); font-size: 13px; color: var(--ink); direction: ltr; }

/* THE PASS CARD */
.pass-card {
  display: grid;
  grid-template-columns: 1fr 320px;
  background: var(--paper);
  color: var(--paper-ink);
  border-radius: 6px;
  overflow: hidden;
  box-shadow:
    0 80px 140px -40px rgba(0,0,0,0.7),
    0 40px 80px -30px rgba(212, 146, 92, 0.25);
  position: relative;
  font-family: var(--f-arabic);
  opacity: 1;
}
@keyframes pass-in {
  from { opacity: 0; transform: translateY(40px) rotateX(8deg); }
  to   { opacity: 1; transform: none; }
}

/* perforation between main and stub */
.pass-card::before {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  right: 320px;
  width: 1px;
  background-image: linear-gradient(180deg, var(--paper-ink) 0 8px, transparent 8px 16px);
  background-size: 1px 16px;
  background-repeat: repeat-y;
  opacity: 0.3;
}
.pass-card::after {
  content: "";
  position: absolute;
  width: 28px; height: 28px;
  background: var(--bg-0);
  border-radius: 50%;
  top: -14px;
  right: calc(320px - 14px);
  box-shadow: 0 calc(100% + 14px) 0 -14px var(--bg-0);
}

.pass-main {
  padding: 40px 44px 36px;
  position: relative;
}

.pass-airline {
  display: flex;
  align-items: baseline;
  gap: 16px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--paper-rule);
  margin-bottom: 28px;
}
.airline-mark {
  font-family: var(--f-display);
  font-style: italic;
  font-size: 38px;
  letter-spacing: -0.02em;
  color: var(--paper-ink);
}
.airline-name {
  font-family: var(--f-sans);
  font-size: 11px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--paper-ink-2);
}

.pass-class {
  display: flex;
  align-items: baseline;
  gap: 16px;
  margin-bottom: 24px;
  font-family: var(--f-mono);
  direction: ltr;
}
.cls-tag { font-size: 10px; letter-spacing: 0.3em; color: var(--paper-ink-2); text-transform: uppercase; }
.cls-value { font-size: 13px; font-weight: 700; color: var(--paper-ink); letter-spacing: 0.1em; }

.pass-route {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 24px;
  margin: 8px 0 36px;
}
.route-col { text-align: center; }
.route-col:first-child { text-align: start; }
.route-col:last-child { text-align: end; }
.route-code {
  font-family: var(--f-display);
  font-size: 76px;
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--paper-ink);
  font-style: italic;
}
.route-place {
  font-family: var(--f-sans);
  font-size: 11px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  margin-top: 8px;
  color: var(--paper-ink-2);
  direction: ltr;
}
.route-place-ar {
  font-family: var(--f-arabic);
  font-size: 13px;
  color: var(--paper-ink);
  margin-top: 2px;
}
.route-line {
  position: relative;
  min-width: 200px;
  color: var(--paper-ink-2);
}
.route-arc {
  position: relative;
  width: 200px;
  height: 60px;
}
.route-arc svg { width: 100%; height: 100%; }
.route-arc .plane {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%) rotate(0deg);
  color: var(--acc);
  animation: plane-glide 4s var(--ease) infinite;
}
@keyframes plane-glide {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%      { transform: translateX(-50%) translateY(-4px); }
}
.route-duration {
  text-align: center;
  margin-top: 6px;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.15em;
  color: var(--paper-ink-2);
}

.pass-info-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px 32px;
  padding: 24px 0;
  border-top: 1px solid var(--paper-rule);
  border-bottom: 1px solid var(--paper-rule);
}
.info-cell .k {
  font-family: var(--f-sans);
  font-size: 9px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--paper-ink-2);
  margin-bottom: 6px;
  direction: ltr;
}
.info-cell .v {
  font-family: var(--f-arabic);
  font-size: 16px;
  font-weight: 500;
  color: var(--paper-ink);
}
.info-cell .v.big {
  font-family: var(--f-display);
  font-style: italic;
  font-size: 28px;
  font-weight: 400;
  letter-spacing: -0.01em;
  line-height: 1.1;
}

.couple-strip {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 16px;
  align-items: center;
  padding-top: 24px;
  margin-top: 4px;
}
.couple-side { text-align: center; }
.couple-side:first-child { text-align: start; }
.couple-side:last-child { text-align: end; }
.couple-label {
  font-family: var(--f-sans);
  font-size: 9px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--paper-ink-2);
  margin-bottom: 4px;
  direction: ltr;
}
.couple-name {
  font-family: var(--f-arabic-display);
  font-weight: 600;
  font-size: 20px;
  color: var(--paper-ink);
}
.couple-amp {
  font-family: var(--f-display);
  font-style: italic;
  font-size: 38px;
  color: var(--acc);
  line-height: 1;
}

/* Stub */
.pass-stub {
  background: var(--paper-2);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
}
.stub-top {
  display: flex;
  justify-content: space-between;
  gap: 16px;
}
.stub-mini .k {
  font-family: var(--f-sans);
  font-size: 9px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--paper-ink-2);
  margin-bottom: 4px;
  direction: ltr;
}
.stub-mini .v {
  font-family: var(--f-mono);
  font-weight: 700;
  font-size: 15px;
  color: var(--paper-ink);
}
.qr-wrap {
  background: var(--paper);
  padding: 12px;
  border-radius: 4px;
  margin: 4px auto;
  width: fit-content;
  border: 1px solid var(--paper-rule);
}
#qrcode img, #qrcode canvas { display: block; }
.stub-id .k {
  font-family: var(--f-sans);
  font-size: 9px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--paper-ink-2);
  margin-bottom: 4px;
  direction: ltr;
}
.stub-id .v {
  font-family: var(--f-mono);
  font-size: 13px;
  color: var(--paper-ink);
  letter-spacing: 0.1em;
  word-break: break-all;
}
.stub-foot {
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px dashed var(--paper-rule);
}
.stub-name {
  font-family: var(--f-display);
  font-style: italic;
  font-size: 22px;
  color: var(--paper-ink);
  margin-bottom: 4px;
  line-height: 1.1;
}
.stub-class {
  font-family: var(--f-sans);
  font-size: 9px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--paper-ink-2);
  direction: ltr;
}

/* ============================================================
   PASS ACTIONS
   ============================================================ */
.pass-actions { margin-top: 48px; }
.wallet-row {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 48px;
}
.wallet-btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 22px;
  border-radius: 10px;
  border: 0;
  cursor: pointer;
  font-family: inherit;
  transition: transform 0.2s var(--ease), box-shadow 0.2s;
}
.wallet-btn:hover { transform: translateY(-2px); }
.wallet-btn.apple { background: #000; color: #fff; }
.wallet-btn.google { background: #fff; color: #1f1f1f; }
.wallet-btn.calendar {
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--ink-5);
}
.wallet-btn .w-ico { display: grid; place-items: center; }
.wallet-btn .w-stack {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  line-height: 1.15;
  direction: ltr;
  text-align: start;
}
.wallet-btn .w-small { font-size: 10px; opacity: 0.7; letter-spacing: 0.04em; }
.wallet-btn .w-big { font-size: 15px; font-weight: 600; }

/* Details grid */
.details-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.details-card {
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--ink-5);
  border-radius: 10px;
  padding: 24px;
  transition: border-color 0.2s, background 0.2s;
}
.details-card:hover { border-color: rgba(212,146,92,0.3); background: rgba(212,146,92,0.04); }
.details-card .kicker { color: var(--acc); margin-bottom: 12px; }
.details-card h3 {
  font-family: var(--f-arabic-display);
  font-weight: 600;
  font-size: 22px;
  margin: 0 0 8px;
  color: var(--ink);
}
.details-card p {
  font-size: 14px;
  color: var(--ink-3);
  margin: 0 0 16px;
}
.link {
  display: inline-block;
  color: var(--acc);
  font-family: var(--f-sans);
  font-size: 13px;
  letter-spacing: 0.05em;
  margin-inline-end: 16px;
  transition: color 0.2s;
  border-bottom: 1px solid transparent;
}
.link:hover { color: var(--acc-2); border-bottom-color: var(--acc-2); }
.map-actions { display: flex; gap: 16px; flex-wrap: wrap; }

.countdown-card .cd-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-top: 8px;
}
.cd-grid > div {
  text-align: center;
  padding: 12px 4px;
  background: rgba(212, 146, 92, 0.06);
  border: 1px solid rgba(212, 146, 92, 0.2);
  border-radius: 6px;
}
.cd-n {
  display: block;
  font-family: var(--f-mono);
  font-weight: 700;
  font-size: 28px;
  color: var(--ink);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.cd-l {
  display: block;
  font-family: var(--f-sans);
  font-size: 9px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-top: 6px;
  direction: ltr;
}

/* ============================================================
   VERIFY OVERLAY
   ============================================================ */
.verify-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(12px);
  z-index: 200;
  display: grid;
  place-items: center;
  padding: 24px;
  animation: fade-in 0.3s var(--ease);
}
@keyframes fade-in { from { opacity: 0; } to { opacity: 1; } }
.verify-modal {
  background: var(--paper);
  color: var(--paper-ink);
  border-radius: 12px;
  padding: 36px 32px;
  max-width: 380px;
  width: 100%;
  text-align: center;
  position: relative;
  animation: rise-in 0.5s var(--ease-spring) both;
}
.modal-close {
  position: absolute;
  top: 12px;
  inset-inline-end: 12px;
  background: transparent;
  border: 0;
  cursor: pointer;
  color: var(--paper-ink-2);
  padding: 8px;
  border-radius: 50%;
  transition: background 0.2s;
}
.modal-close:hover { background: rgba(0,0,0,0.06); color: var(--paper-ink); }
.verify-check {
  width: 80px; height: 80px;
  border-radius: 50%;
  background: rgba(46, 138, 77, 0.12);
  border: 2px solid #2e8a4d;
  color: #2e8a4d;
  margin: 0 auto 16px;
  display: grid;
  place-items: center;
  animation: pop-in 0.5s var(--ease-spring) both 0.15s;
}
@keyframes pop-in {
  from { transform: scale(0.3); opacity: 0; }
  to   { transform: scale(1); opacity: 1; }
}
.verify-check svg { width: 44px; height: 44px; }
.verify-status {
  font-family: var(--f-arabic-display);
  font-weight: 700;
  font-size: 22px;
  color: #2e8a4d;
  margin-bottom: 4px;
}
.verify-name {
  font-family: var(--f-display);
  font-style: italic;
  font-size: 24px;
  margin-bottom: 20px;
}
.verify-meta {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  padding: 16px 0;
  border-top: 1px dashed var(--paper-rule);
  border-bottom: 1px dashed var(--paper-rule);
  margin-bottom: 20px;
}
.verify-meta > div {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.verify-meta span {
  font-family: var(--f-sans);
  font-size: 9px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--paper-ink-2);
}
.verify-meta strong {
  font-family: var(--f-mono);
  font-size: 13px;
  font-weight: 700;
  color: var(--paper-ink);
}
.modal-cta {
  width: 100%;
  padding: 14px;
  background: var(--paper-ink);
  color: var(--paper);
  border: 0;
  border-radius: 6px;
  font-family: var(--f-arabic);
  font-size: 15px;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.2s;
}
.modal-cta:hover { background: var(--acc-deep); }

/* ============================================================
   TOAST
   ============================================================ */
.toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%) translateY(80px);
  background: var(--paper);
  color: var(--paper-ink);
  padding: 12px 20px;
  border-radius: 999px;
  font-size: 14px;
  z-index: 300;
  opacity: 0;
  transition: all 0.3s var(--ease);
  box-shadow: 0 20px 40px -10px rgba(0,0,0,0.5);
  font-weight: 500;
}
.toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes rise-in {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: none; }
}

/* Verification loading state */
.verifying .code-cell {
  background: var(--paper-ink);
  color: var(--paper);
  border-color: var(--paper-ink);
  animation: cell-pulse 0.6s var(--ease) infinite;
}
@keyframes cell-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

/* ============================================================
   MOBILE
   ============================================================ */
@media (max-width: 900px) {
  .topbar { padding: 16px 20px; gap: 12px; }
  .brand-meta { display: none; }
  .stage { padding: 40px 20px; }

  .entry-grid {
    grid-template-columns: 1fr;
    gap: 36px;
  }
  .display { font-size: clamp(56px, 14vw, 88px); }
  .ticker { display: none; }

  .board { display: none; }

  .pass-card {
    grid-template-columns: 1fr;
  }
  .pass-card::before {
    top: auto;
    left: 0; right: 0;
    bottom: auto;
    top: calc(100% - 320px);
    width: 100%;
    height: 1px;
    background-image: linear-gradient(90deg, var(--paper-ink) 0 8px, transparent 8px 16px);
    background-size: 16px 1px;
  }
  .pass-card::after { display: none; }
  .pass-main { padding: 28px 24px; }
  .pass-route { gap: 12px; }
  .route-code { font-size: 52px; }
  .route-arc { width: 100px; height: 40px; }
  .pass-info-grid { grid-template-columns: 1fr 1fr; gap: 18px; }

  .details-grid { grid-template-columns: 1fr; }
  .pass-meta { grid-template-columns: 1fr; text-align: center; gap: 12px; }
  .issued { text-align: center; }

  .code-cell { width: 40px; height: 52px; font-size: 20px; }
}

@media (max-width: 480px) {
  .display { font-size: 56px; }
  .display .line-ar { font-size: 0.55em; }
  .code-cell { width: 36px; height: 46px; font-size: 18px; }
  .pass-main { padding: 24px 20px; }
  .route-code { font-size: 42px; }
  .pass-info-grid { grid-template-columns: 1fr; }
  .couple-strip { grid-template-columns: 1fr auto 1fr; }
  .couple-name { font-size: 16px; }
}

/* ============================================================
   STAGE 1 · WELCOME  (replaces stage-entry)
   ============================================================ */
.stage-welcome {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 80px 24px 60px;
}

.welcome-wrap {
  width: 100%;
  max-width: 560px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
}

.welcome-header {
  text-align: center;
}

/* Welcome card */
.welcome-card {
  width: 100%;
  background: var(--paper);
  color: var(--paper-ink);
  border-radius: 20px;
  padding: 44px 40px 36px;
  box-shadow:
    0 60px 120px -40px rgba(0,0,0,0.55),
    0 30px 60px -30px rgba(212,146,92,0.18),
    inset 0 1px 0 rgba(255,255,255,0.12);
  position: relative;
  text-align: center;
}

.welcome-card::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px dashed rgba(20,20,15,0.14);
  border-radius: 12px;
  pointer-events: none;
}

/* Couple strip at top of card */
.wc-couple {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 28px;
  flex-wrap: wrap;
}
.wc-couple-name {
  font-family: var(--f-arabic-display);
  font-size: 13px;
  font-weight: 600;
  color: var(--gold);
  letter-spacing: 0.03em;
}
.wc-amp {
  font-family: var(--f-serif);
  font-size: 18px;
  color: var(--gold);
  opacity: 0.7;
  font-style: italic;
}

/* Guest greeting */
.welcome-greeting {
  margin-bottom: 32px;
}
.welcome-greeting .kicker {
  display: block;
  margin-bottom: 14px;
}
.welcome-name {
  font-family: var(--f-arabic-display);
  font-size: clamp(26px, 6vw, 40px);
  font-weight: 800;
  color: var(--paper-ink);
  line-height: 1.2;
  margin-bottom: 10px;
  letter-spacing: -0.01em;
}
.welcome-sub {
  font-family: var(--f-arabic-display);
  font-size: 14px;
  color: var(--paper-ink-2);
  margin: 0;
  line-height: 1.7;
}

/* CTA button inside card */
.welcome-card .cta {
  width: 100%;
  margin-bottom: 0;
  margin-top: 4px;
}

/* Event quick info */
.event-quick {
  margin-top: 28px;
  padding-top: 24px;
  border-top: 1px solid var(--paper-rule);
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.eq-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}
.eq-k {
  font-family: var(--f-sans);
  font-size: 9px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--paper-ink-2);
  white-space: nowrap;
}
.eq-v {
  font-family: var(--f-arabic-display);
  font-size: 13px;
  font-weight: 600;
  color: var(--paper-ink);
  text-align: left;
}

/* Responsive */
@media (max-width: 480px) {
  .welcome-card { padding: 32px 24px 28px; }
  .welcome-card::before { inset: 6px; }
  .eq-item { flex-direction: column; align-items: flex-start; gap: 2px; }
  .eq-v { text-align: right; width: 100%; }
}
