:root {
  --kiosk-font-family: "Space Grotesk", sans-serif;
  --kiosk-container-bg: radial-gradient(circle at top, #f4f1ea, #e8edf3);
  --kiosk-container-text: #1b1c1e;
  --kiosk-accent: #f4a261;
  --kiosk-selection-border: #1b1c1e;
  --kiosk-selection-border-width: 2px;
  --kiosk-button-bg: #1b1c1e;
  --kiosk-button-text: #ffffff;
  --kiosk-button-secondary-bg: #f4a261;
  --kiosk-button-secondary-text: #1b1c1e;
  --kiosk-input-bg: #ffffff;
  --kiosk-input-border: rgba(27, 28, 30, 0.2);
  --kiosk-panel-border: rgba(27, 28, 30, 0.1);
  --kiosk-card-bg: #ffffff;
  --kiosk-card-border: rgba(27, 28, 30, 0.1);
  --kiosk-toast-bg: #1b1c1e;
  --kiosk-toast-text: #ffffff;
  --kiosk-message-panel-bg: rgba(18, 28, 44, 0.9);
  --kiosk-message-panel-border: #59dcff;
  --kiosk-message-panel-text: #f6fbff;
  --kiosk-message-panel-heading: #f6fbff;
  --kiosk-loader-bg: rgba(128, 95, 65, 0.9);
  --kiosk-loader-border: #dab881;
  --kiosk-loader-text: #f4e8d1;
  --kiosk-loader-accent: #f6e5bf;
  --kiosk-priority-message-bg: rgba(34, 16, 16, 0.92);
  --kiosk-priority-message-border: #ffcc5a;
  --kiosk-priority-message-heading: #ffe6a8;
  --kiosk-priority-message-glow: #ff7840;
  --kiosk-priority-message-ring: #ff4a4a;
  --kiosk-priority-message-pulse-speed: 1.6s;
  --kiosk-priority-message-scale: 1.01;
  --kiosk-priority-message-saturate: 1.2;
  --kiosk-priority-message-enabled: 1;
  --kiosk-priority-banner-enabled: 1;
  --kiosk-priority-stripes-enabled: 1;
  --kiosk-priority-sweep-enabled: 1;
  --kiosk-priority-icon-pulse-enabled: 1;
  --kiosk-radius: 24px;
  --kiosk-button-radius: 999px;
  --kiosk-input-radius: 14px;
  --kiosk-base-font-size: 16px;
  --kiosk-motion-fast: 180ms;
  --kiosk-motion-medium: 320ms;
  --kiosk-motion-slow: 700ms;
  --kiosk-panel-exit: 420ms;
  --kiosk-glow-speed: 14s;
  --kiosk-glow-speed-secondary: 18s;
  --kiosk-glow-opacity: 0.7;
  --kiosk-grid-opacity: 0.08;
  --kiosk-sheen-speed: 5s;
  --kiosk-scanline-speed: 2s;
  --kiosk-glow-enabled: 1;
  --kiosk-grid-enabled: 1;
  --kiosk-sheen-enabled: 1;
  --kiosk-scanline-enabled: 1;
  --kiosk-blur-enabled: 1;
  --kiosk-hover-enabled: 1;
  --kiosk-hover-lift: 1px;
  --kiosk-card-hover-lift: 1px;
  --kiosk-hover-shadow: 0.18;
  --kiosk-card-hover-shadow: 0.12;
  --kiosk-ease-main: cubic-bezier(0.2, 0.8, 0.2, 1);
}

.kiosk-checkin {
  font-family: var(--kiosk-font-family);
  width: 100vw;
  min-height: 100vh;
  margin: 0;
  padding: 0;
  border-radius: 0;
  background: var(--kiosk-container-bg);
  box-shadow: none;
  color: var(--kiosk-container-text);
  font-size: var(--kiosk-base-font-size);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.kiosk-checkin * {
  box-sizing: border-box;
}

.kiosk-background {
  position: absolute;
  inset: 0;
  background: var(--kiosk-container-bg);
  z-index: 0;
  overflow: hidden;
}

.kiosk-checkin[data-bg-mode="image"] .kiosk-background {
  background: var(--kiosk-bg-image) center/cover no-repeat;
}

.kiosk-checkin[data-bg-mode="preset"] .kiosk-background {
  background: radial-gradient(circle at top, #0d1023, #05060d);
}

.kiosk-checkin[data-bg-preset="aurora"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -10% -20%;
  background: conic-gradient(from 0deg, rgba(69,242,255,0.35), rgba(154,230,255,0.08), rgba(109,99,255,0.25), rgba(69,242,255,0.35));
  filter: blur(40px);
  animation: kiosk-aurora 18s ease-in-out infinite;
  opacity: 0.8;
}

.kiosk-checkin[data-bg-preset="waves"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -20%;
  background: radial-gradient(circle, rgba(69,242,255,0.2), transparent 60%),
    radial-gradient(circle, rgba(255,255,255,0.2), transparent 60%);
  animation: kiosk-waves 16s ease-in-out infinite;
  opacity: 0.8;
}

.kiosk-checkin[data-bg-preset="nebula"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -30%;
  background: radial-gradient(circle, rgba(69,242,255,0.25), transparent 55%),
    radial-gradient(circle, rgba(255,255,255,0.2), transparent 65%),
    radial-gradient(circle, rgba(244,162,97,0.2), transparent 60%);
  animation: kiosk-nebula 20s ease-in-out infinite;
  opacity: 0.9;
}

.kiosk-checkin[data-bg-preset="hyperdrive"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -20%;
  background:
    repeating-linear-gradient(
      110deg,
      rgba(69,242,255,0.08) 0 2px,
      transparent 2px 14px
    ),
    radial-gradient(circle at center, rgba(255,255,255,0.12), transparent 55%);
  animation: kiosk-hyperdrive 10s linear infinite;
  opacity: 0.85;
}

.kiosk-checkin[data-bg-preset="photon"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -25%;
  background:
    radial-gradient(circle, rgba(69,242,255,0.18), transparent 60%),
    radial-gradient(circle, rgba(255,255,255,0.12), transparent 65%),
    radial-gradient(circle, rgba(255,209,102,0.14), transparent 60%);
  filter: blur(20px);
  animation: kiosk-photon 22s ease-in-out infinite;
  opacity: 0.9;
}

.kiosk-checkin[data-bg-preset="synthgrid"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -30% -10%;
  background:
    linear-gradient(to top, rgba(76,29,149,0.6), transparent 60%),
    linear-gradient(90deg, rgba(244,114,182,0.25) 1px, transparent 1px),
    linear-gradient(rgba(244,114,182,0.25) 1px, transparent 1px);
  background-size: auto, 40px 40px, 40px 40px;
  animation: kiosk-synthgrid 12s linear infinite;
  opacity: 0.9;
}

.kiosk-checkin[data-bg-preset="particle"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -20%;
  background:
    radial-gradient(circle, rgba(255,255,255,0.18) 1px, transparent 2px),
    radial-gradient(circle, rgba(69,242,255,0.2) 1px, transparent 2px),
    radial-gradient(circle, rgba(244,162,97,0.2) 1px, transparent 2px);
  background-size: 120px 120px, 160px 160px, 200px 200px;
  animation: kiosk-particle 28s linear infinite;
  opacity: 0.9;
}

.kiosk-checkin[data-bg-preset="circuit"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -10%;
  background:
    linear-gradient(90deg, rgba(69,242,255,0.12) 1px, transparent 1px),
    linear-gradient(rgba(69,242,255,0.12) 1px, transparent 1px),
    radial-gradient(circle, rgba(69,242,255,0.25), transparent 60%);
  background-size: 60px 60px, 60px 60px, auto;
  animation: kiosk-circuit 14s linear infinite;
  opacity: 0.85;
}

.kiosk-checkin[data-bg-preset="holo"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -25%;
  background: conic-gradient(
    from 90deg,
    rgba(255,255,255,0.1),
    rgba(69,242,255,0.28),
    rgba(244,162,97,0.2),
    rgba(255,255,255,0.1)
  );
  filter: blur(30px);
  animation: kiosk-holo-pulse 16s ease-in-out infinite;
  opacity: 0.9;
}

.kiosk-checkin[data-bg-preset="vortex"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -30%;
  background:
    radial-gradient(circle, rgba(69,242,255,0.25), transparent 55%),
    radial-gradient(circle, rgba(255,255,255,0.15), transparent 60%);
  animation: kiosk-vortex 18s ease-in-out infinite;
  opacity: 0.9;
}

.kiosk-checkin[data-bg-preset="matrix"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -20%;
  background:
    repeating-linear-gradient(
      to bottom,
      rgba(120, 255, 200, 0.12) 0 2px,
      transparent 2px 10px
    ),
    linear-gradient(to bottom, rgba(10,20,20,0.4), rgba(10,20,20,0.8));
  animation: kiosk-matrix 8s linear infinite;
  opacity: 0.8;
}

.kiosk-checkin[data-bg-preset="quantum"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -25%;
  background:
    radial-gradient(circle, rgba(128, 255, 219, 0.2), transparent 60%),
    radial-gradient(circle, rgba(99, 102, 241, 0.18), transparent 65%),
    radial-gradient(circle, rgba(255, 255, 255, 0.12), transparent 70%);
  filter: blur(22px);
  animation: kiosk-quantum 24s ease-in-out infinite;
  opacity: 0.9;
}

.kiosk-checkin[data-bg-preset="solar"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -30%;
  background:
    conic-gradient(from 20deg, rgba(255,196,0,0.35), rgba(255,120,0,0.25), rgba(255,255,255,0.1), rgba(255,196,0,0.35));
  filter: blur(16px);
  animation: kiosk-solar 14s ease-in-out infinite;
  opacity: 0.9;
}

.kiosk-checkin[data-bg-preset="prism"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -25%;
  background:
    conic-gradient(from 0deg, rgba(255,0,128,0.2), rgba(0,208,255,0.2), rgba(129,0,255,0.2), rgba(255,0,128,0.2));
  filter: blur(24px);
  animation: kiosk-prism 18s linear infinite;
  opacity: 0.85;
}

.kiosk-checkin[data-bg-preset="plasma"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -30%;
  background:
    radial-gradient(circle, rgba(255, 0, 128, 0.2), transparent 60%),
    radial-gradient(circle, rgba(0, 208, 255, 0.2), transparent 60%),
    radial-gradient(circle, rgba(255, 255, 255, 0.12), transparent 70%);
  animation: kiosk-plasma 20s ease-in-out infinite;
  opacity: 0.9;
}

.kiosk-checkin[data-bg-preset="rift"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -30%;
  background:
    radial-gradient(circle, rgba(69,242,255,0.25), transparent 55%),
    radial-gradient(circle, rgba(255,255,255,0.1), transparent 65%);
  animation: kiosk-rift 16s ease-in-out infinite;
  opacity: 0.9;
}

.kiosk-checkin[data-bg-preset="pulse"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -25%;
  background:
    radial-gradient(circle, rgba(69,242,255,0.25), transparent 55%),
    radial-gradient(circle, rgba(255,255,255,0.12), transparent 70%);
  animation: kiosk-pulse 6s ease-in-out infinite;
  opacity: 0.85;
}

.kiosk-checkin[data-bg-preset="ion"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -20%;
  background:
    radial-gradient(circle, rgba(69,242,255,0.18), transparent 60%),
    radial-gradient(circle, rgba(255,255,255,0.12), transparent 70%);
  filter: blur(18px);
  animation: kiosk-ion 26s linear infinite;
  opacity: 0.85;
}

.kiosk-checkin[data-bg-preset="ether"] .kiosk-background::before {
  content: "";
  position: absolute;
  inset: -25%;
  background:
    radial-gradient(circle, rgba(255,255,255,0.18), transparent 60%),
    radial-gradient(circle, rgba(69,242,255,0.16), transparent 70%);
  filter: blur(28px);
  animation: kiosk-ether 30s ease-in-out infinite;
  opacity: 0.9;
}

.kiosk-bg-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.9;
}

.kiosk-bg-overlay {
  position: absolute;
  inset: 0;
  background: var(--kiosk-bg-overlay);
  z-index: 1;
}

.kiosk-surface {
  width: min(900px, 92vw);
  margin: clamp(16px, 3vw, 48px);
  padding: clamp(24px, 4vw, 56px);
  border-radius: calc(var(--kiosk-radius) + 8px);
  background:
    radial-gradient(circle at top left, rgba(255,255,255,0.24), transparent 55%),
    radial-gradient(circle at bottom right, rgba(69,242,255,0.18), transparent 60%),
    linear-gradient(135deg, rgba(255,255,255,0.18), rgba(255,255,255,0.04));
  backdrop-filter: blur(18px) saturate(140%);
  border: calc(var(--kiosk-bevel-enabled) * 1px) solid rgba(255,255,255,0.25);
  box-shadow:
    0 24px 60px rgba(8, 12, 28, 0.35),
    inset 0 1px 0 rgba(255,255,255,0.35),
    0 0 40px rgba(69,242,255, calc(var(--kiosk-glow-rim) * 0.35));
  position: relative;
  overflow: hidden;
  z-index: 3;
}

.kiosk-surface::before {
  content: "";
  position: absolute;
  inset: -40% -20% auto auto;
  width: 280px;
  height: 280px;
  background: radial-gradient(circle, rgba(255,255,255,0.45), transparent 65%);
  opacity: 0.5;
  filter: blur(4px);
  pointer-events: none;
  animation: kiosk-liquid-float 10s ease-in-out infinite;
}

.kiosk-surface::after {
  content: "";
  position: absolute;
  inset: auto auto -50% -20%;
  width: 320px;
  height: 320px;
  background: radial-gradient(circle, rgba(69,242,255,0.35), transparent 70%);
  opacity: 0.5;
  filter: blur(6px);
  pointer-events: none;
  animation: kiosk-liquid-float 14s ease-in-out infinite reverse;
}

.kiosk-surface .kiosk-noise {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/></filter><rect width='120' height='120' filter='url(%23n)' opacity='0.6'/></svg>");
  opacity: calc(var(--kiosk-noise-enabled) * var(--kiosk-noise-opacity));
  mix-blend-mode: soft-light;
  pointer-events: none;
  z-index: 1;
}

.kiosk-surface .kiosk-streaks {
  position: absolute;
  inset: -40% -20%;
  background:
    linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.08) 45%, transparent 70%),
    linear-gradient(135deg, transparent 0%, rgba(69, 242, 255, 0.07) 50%, transparent 80%),
    linear-gradient(100deg, transparent 0%, rgba(255, 255, 255, 0.06) 40%, transparent 75%);
  background-size: 320% 320%, 260% 260%, 380% 380%;
  background-position: 0 0, 0 0, 0 0;
  opacity: calc(var(--kiosk-streaks-enabled) * 0.2);
  filter: blur(2px);
  animation: kiosk-streaks var(--kiosk-streaks-speed) linear infinite;
  pointer-events: none;
  z-index: 2;
}

.kiosk-surface > :not(.kiosk-noise):not(.kiosk-streaks) {
  position: relative;
  z-index: 3;
}

.kiosk-checkin::before {
  content: "";
  position: absolute;
  inset: -40% auto auto -40%;
  width: 280px;
  height: 280px;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.22), transparent 60%);
  opacity: calc(var(--kiosk-glow-enabled) * var(--kiosk-glow-opacity));
  pointer-events: none;
  transform: translateZ(0);
  animation: kiosk-orbit var(--kiosk-glow-speed) linear infinite;
  animation-duration: calc(var(--kiosk-glow-enabled) * var(--kiosk-glow-speed));
}

.kiosk-checkin::after {
  content: "";
  position: absolute;
  inset: auto -40% -40% auto;
  width: 320px;
  height: 320px;
  background: radial-gradient(circle, rgba(244, 162, 97, 0.25), transparent 65%);
  opacity: calc(var(--kiosk-glow-enabled) * var(--kiosk-glow-opacity));
  pointer-events: none;
  transform: translateZ(0);
  animation: kiosk-orbit var(--kiosk-glow-speed-secondary) linear infinite reverse;
  animation-duration: calc(var(--kiosk-glow-enabled) * var(--kiosk-glow-speed-secondary));
}

.kiosk-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: linear-gradient(
      rgba(255, 255, 255, 0.08) 1px,
      transparent 1px
    ),
    linear-gradient(90deg, rgba(255, 255, 255, 0.08) 1px, transparent 1px);
  background-size: 26px 26px;
  opacity: calc(var(--kiosk-grid-enabled) * var(--kiosk-grid-opacity));
  mix-blend-mode: screen;
  animation: kiosk-grid-drift var(--kiosk-motion-slow) linear infinite;
  animation-duration: calc(var(--kiosk-grid-enabled) * var(--kiosk-motion-slow));
  z-index: 2;
}

.kiosk-landing,
.kiosk-panel {
  transition: opacity var(--kiosk-motion-medium) var(--kiosk-ease-main),
    transform var(--kiosk-motion-medium) var(--kiosk-ease-main);
  opacity: 0;
  transform: translateY(16px) scale(0.98);
  filter: none;
  position: relative;
  will-change: transform, opacity, filter;
  backface-visibility: hidden;
}

.kiosk-landing.is-active::before,
.kiosk-panel.is-active::before {
  content: "";
  position: absolute;
  inset: -20% -30%;
  background: linear-gradient(
    120deg,
    transparent,
    rgba(255, 255, 255, 0.35),
    rgba(69, 242, 255, 0.25),
    transparent
  );
  transform: translateX(-120%) skewX(-10deg);
  opacity: 0.7;
  pointer-events: none;
  animation: kiosk-lens-sweep var(--kiosk-motion-medium) var(--kiosk-ease-main) both;
  mix-blend-mode: screen;
}

.kiosk-landing.is-active,
.kiosk-panel.is-active {
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: none;
}

.kiosk-landing.is-exiting,
.kiosk-panel.is-exiting {
  opacity: 0;
  transform: translateY(-8px) scale(0.98);
}

.kiosk-checkin[data-transition="warp"] .kiosk-landing,
.kiosk-checkin[data-transition="warp"] .kiosk-panel {
  transition: none;
  opacity: 0;
  transform: perspective(900px) translateY(26px) rotateX(12deg) scale(0.96);
  filter: blur(calc(var(--kiosk-blur-enabled) * 10px));
}

.kiosk-checkin[data-transition="warp"] .kiosk-landing.is-active,
.kiosk-checkin[data-transition="warp"] .kiosk-panel.is-active {
  animation: kiosk-warp-in var(--kiosk-motion-medium) var(--kiosk-ease-main) both;
}

.kiosk-checkin[data-transition="warp"] .kiosk-landing.is-exiting,
.kiosk-checkin[data-transition="warp"] .kiosk-panel.is-exiting {
  animation: kiosk-warp-out var(--kiosk-panel-exit) var(--kiosk-ease-main) both;
}

.kiosk-checkin[data-transition="holo"] .kiosk-landing,
.kiosk-checkin[data-transition="holo"] .kiosk-panel {
  transition: none;
  opacity: 0;
  transform: perspective(900px) translateX(-24px) rotateY(-18deg) scale(0.98);
  filter: blur(calc(var(--kiosk-blur-enabled) * 6px));
}

.kiosk-checkin[data-transition="holo"] .kiosk-landing.is-active,
.kiosk-checkin[data-transition="holo"] .kiosk-panel.is-active {
  animation: kiosk-holo-in var(--kiosk-motion-medium) var(--kiosk-ease-main) both;
}

.kiosk-checkin[data-transition="holo"] .kiosk-landing.is-exiting,
.kiosk-checkin[data-transition="holo"] .kiosk-panel.is-exiting {
  animation: kiosk-holo-out var(--kiosk-panel-exit) var(--kiosk-ease-main) both;
}

.kiosk-checkin[data-transition="dust"] .kiosk-landing,
.kiosk-checkin[data-transition="dust"] .kiosk-panel {
  transition: none;
  opacity: 0;
  transform: translateY(18px) scale(0.96) translateZ(0);
  filter: blur(calc(var(--kiosk-blur-enabled) * 6px));
}

.kiosk-checkin[data-transition="dust"] .kiosk-landing.is-active,
.kiosk-checkin[data-transition="dust"] .kiosk-panel.is-active {
  animation: kiosk-dust-in var(--kiosk-motion-slow) var(--kiosk-ease-main) both;
}

.kiosk-checkin[data-transition="dust"] .kiosk-landing.is-exiting,
.kiosk-checkin[data-transition="dust"] .kiosk-panel.is-exiting {
  animation: kiosk-dust-out var(--kiosk-panel-exit) var(--kiosk-ease-main) both;
}

.kiosk-checkin[data-transition="dust"] .kiosk-landing::after,
.kiosk-checkin[data-transition="dust"] .kiosk-panel::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: radial-gradient(circle, rgba(255, 255, 255, 0.25) 1px, transparent 1px),
    radial-gradient(circle, rgba(244, 162, 97, 0.25) 1px, transparent 1px);
  background-size: 14px 14px, 18px 18px;
  background-position: 0 0, 8px 10px;
  opacity: 0;
  mix-blend-mode: screen;
}

.kiosk-checkin[data-transition="dust"] .kiosk-landing.is-active::after,
.kiosk-checkin[data-transition="dust"] .kiosk-panel.is-active::after {
  animation: kiosk-dust-specks var(--kiosk-motion-slow) var(--kiosk-ease-main) both;
}

.kiosk-checkin[data-transition="dust"] .kiosk-landing.is-exiting::after,
.kiosk-checkin[data-transition="dust"] .kiosk-panel.is-exiting::after {
  animation: kiosk-dust-specks-out var(--kiosk-panel-exit) var(--kiosk-ease-main) both;
}

.kiosk-header h1 {
  font-size: 36px;
  margin: 0 0 8px;
  letter-spacing: 0.5px;
}

.kiosk-header p {
  margin: 0 0 24px;
  font-size: 18px;
}

.kiosk-actions,
.kiosk-inline-actions {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

.kiosk-btn {
  background: var(--kiosk-button-bg);
  color: var(--kiosk-button-text);
  border: none;
  padding: 14px 22px;
  border-radius: var(--kiosk-button-radius);
  font-size: 16px;
  cursor: pointer;
  transition: transform var(--kiosk-motion-fast) var(--kiosk-ease-main),
    box-shadow var(--kiosk-motion-fast) var(--kiosk-ease-main),
    background var(--kiosk-motion-fast) var(--kiosk-ease-main);
  box-shadow: 0 8px 16px rgba(20, 30, 50, 0.12);
  position: relative;
  overflow: hidden;
}

.kiosk-btn::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    120deg,
    transparent,
    rgba(255, 255, 255, 0.35),
    transparent
  );
  transform: translateX(-120%);
  animation: kiosk-sheen var(--kiosk-sheen-speed) linear infinite;
  animation-duration: calc(var(--kiosk-sheen-enabled) * var(--kiosk-sheen-speed));
  opacity: calc(var(--kiosk-sheen-enabled) * 0.6);
}

.kiosk-btn:hover {
  transform: translateY(calc(-1 * var(--kiosk-hover-enabled) * var(--kiosk-hover-lift)));
  box-shadow: 0 12px 24px rgba(20, 30, 50, var(--kiosk-hover-shadow));
}

.kiosk-btn:active {
  transform: translateY(1px) scale(0.98);
  box-shadow: 0 6px 12px rgba(20, 30, 50, 0.14);
}

.kiosk-btn-secondary {
  background: var(--kiosk-button-secondary-bg);
  color: var(--kiosk-button-secondary-text);
}

.kiosk-btn-text {
  background: transparent;
  color: #1b1c1e;
  text-decoration: underline;
  padding: 10px 0;
}

.kiosk-btn-small {
  padding: 10px 16px;
  font-size: 14px;
}

.kiosk-panel {
  margin-top: 24px;
  padding-top: 12px;
  border-top: 1px solid var(--kiosk-panel-border);
}

.kiosk-field {
  margin-bottom: 16px;
}

.kiosk-field label {
  display: block;
  font-weight: 600;
  margin-bottom: 6px;
}

.kiosk-input {
  width: 100%;
  padding: 12px 16px;
  border-radius: var(--kiosk-input-radius);
  border: 1px solid var(--kiosk-input-border);
  background: var(--kiosk-input-bg);
  font-size: 16px;
  transition: border-color var(--kiosk-motion-fast) var(--kiosk-ease-main),
    box-shadow var(--kiosk-motion-fast) var(--kiosk-ease-main);
  box-shadow: 0 4px 10px rgba(20, 30, 50, 0.08);
}

.kiosk-input:focus {
  outline: none;
  border-color: var(--kiosk-accent);
  box-shadow: 0 0 0 4px rgba(244, 162, 97, 0.2);
}

.kiosk-field-row {
  display: flex;
  gap: 12px;
}

.kiosk-results {
  margin-top: 16px;
  display: grid;
  gap: 10px;
  width: 100%;
}

.kiosk-result {
  border: 1px solid var(--kiosk-card-border);
  border-radius: 16px;
  padding: 12px 16px;
  text-align: left;
  background: var(--kiosk-card-bg);
  cursor: pointer;
  display: grid;
  gap: 4px;
  width: 100%;
  transition: transform var(--kiosk-motion-fast) var(--kiosk-ease-main),
    box-shadow var(--kiosk-motion-fast) var(--kiosk-ease-main),
    border-color var(--kiosk-motion-fast) var(--kiosk-ease-main);
}

.kiosk-result.is-selected {
  border-color: var(--kiosk-selection-border);
  border-width: var(--kiosk-selection-border-width);
  box-shadow: 0 12px 26px rgba(20, 30, 50, 0.18);
}

.kiosk-result:hover {
  transform: translateY(calc(-1 * var(--kiosk-hover-enabled) * var(--kiosk-card-hover-lift)));
  box-shadow: 0 10px 20px rgba(20, 30, 50, var(--kiosk-card-hover-shadow));
}

.kiosk-result strong {
  font-size: 16px;
}

.kiosk-search-loading {
  position: relative;
  margin-top: 14px;
  padding: 14px 16px;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 14px;
  background: var(--kiosk-loader-bg);
  border: 1px solid var(--kiosk-loader-border);
  border-radius: 14px;
  opacity: 0;
  pointer-events: none;
  transform: scale(0.98);
  transition: opacity 200ms ease, transform 200ms ease;
  z-index: 6;
}

.kiosk-search-loading[hidden] {
  display: none !important;
}

.kiosk-action-loading {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  background: var(--kiosk-loader-bg);
  border: 1px solid var(--kiosk-loader-border);
  border-radius: inherit;
  backdrop-filter: blur(2px);
  opacity: 0;
  pointer-events: none;
  transform: scale(0.98);
  transition: opacity 200ms ease, transform 200ms ease;
  z-index: 20;
}

.kiosk-action-loading[hidden] {
  display: none !important;
}

.kiosk-action-loading.is-active {
  opacity: 1;
  transform: scale(1);
  pointer-events: auto;
}

.kiosk-action-loading p {
  margin: 0;
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--kiosk-loader-text);
  text-shadow: 0 1px 0 rgba(58, 40, 28, 0.8);
}

.kiosk-search-loading.is-active {
  opacity: 1;
  transform: scale(1);
}

.kiosk-search-loading p {
  margin: 0;
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--kiosk-loader-text);
  text-shadow: 0 1px 0 rgba(58, 40, 28, 0.8);
}

.kiosk-oldtime-loader {
  display: inline-flex;
  align-items: flex-end;
  gap: 6px;
  min-height: 18px;
}

.kiosk-oldtime-loader span {
  width: 7px;
  height: 8px;
  border-radius: 2px;
  background: linear-gradient(to bottom, var(--kiosk-loader-accent), var(--kiosk-loader-border));
  box-shadow: 0 1px 0 rgba(63, 42, 25, 0.7);
  animation: kiosk-ledger-tick 1.2s ease-in-out infinite;
}

.kiosk-oldtime-loader span:nth-child(2) {
  animation-delay: 0.15s;
}

.kiosk-oldtime-loader span:nth-child(3) {
  animation-delay: 0.3s;
}

.kiosk-empty {
  font-style: italic;
  color: rgba(27, 28, 30, 0.6);
}

.kiosk-video {
  width: 100%;
  border-radius: 18px;
  margin-bottom: 12px;
  background: #000;
  max-height: 320px;
  min-height: 220px;
  object-fit: cover;
  display: block;
}

.kiosk-scan-frame {
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  min-height: 220px;
}

.kiosk-scan-frame.kiosk-quagga-active .kiosk-video {
  display: none;
}

.kiosk-scan-frame.kiosk-quagga-active video {
  width: 100%;
  min-height: 220px;
  height: 320px;
  object-fit: cover;
  border-radius: 18px;
  display: block;
}

.kiosk-scan-frame.kiosk-quagga-active canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.kiosk-scan-overlay {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    transparent 0%,
    rgba(244, 162, 97, 0.25) 50%,
    transparent 100%
  );
  animation: kiosk-scanline var(--kiosk-scanline-speed) linear infinite;
  animation-duration: calc(var(--kiosk-scanline-enabled) * var(--kiosk-scanline-speed));
  mix-blend-mode: screen;
  opacity: calc(var(--kiosk-scanline-enabled) * 1);
}

.kiosk-toast {
  margin-top: 20px;
  padding: 12px 16px;
  border-radius: 12px;
  background: var(--kiosk-toast-bg);
  color: var(--kiosk-toast-text);
  animation: kiosk-pop var(--kiosk-motion-fast) var(--kiosk-ease-main);
}

.kiosk-panel-messages {
  border: 1px solid var(--kiosk-message-panel-border);
  border-radius: 16px;
  padding: 20px;
  background: var(--kiosk-message-panel-bg);
  color: var(--kiosk-message-panel-text);
}

.kiosk-panel-messages h2 {
  margin-top: 0;
  margin-bottom: 12px;
  color: var(--kiosk-message-panel-heading);
}

.kiosk-message-body {
  margin-top: 0;
  margin-bottom: 16px;
  line-height: 1.5;
}

.kiosk-message-body p,
.kiosk-message-body ul,
.kiosk-message-body ol {
  margin-top: 0;
  margin-bottom: 12px;
}

.kiosk-message-body img {
  max-width: 100%;
  height: auto;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.25);
  box-shadow: 0 10px 24px rgba(8, 12, 28, 0.3);
}

.kiosk-panel-messages.is-priority.kiosk-priority-effects-on {
  border: 2px solid var(--kiosk-priority-message-border);
  background:
    radial-gradient(circle at 10% 0%, var(--kiosk-priority-message-border), transparent 45%),
    radial-gradient(circle at 90% 100%, var(--kiosk-priority-message-ring), transparent 45%),
    var(--kiosk-priority-message-bg);
  box-shadow:
    0 0 0 2px var(--kiosk-priority-message-ring),
    0 0 28px var(--kiosk-priority-message-glow),
    0 20px 40px rgba(8, 8, 12, 0.5);
  animation: kiosk-priority-alert var(--kiosk-priority-message-pulse-speed) ease-in-out infinite;
  overflow: hidden;
  position: relative;
}

.kiosk-panel-messages.is-priority.kiosk-priority-effects-on.kiosk-priority-stripes-on::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(
      -45deg,
      rgba(255, 0, 0, 0.12) 0 10px,
      rgba(20, 0, 0, 0.08) 10px 20px
    );
  opacity: 0.35;
  pointer-events: none;
  animation: kiosk-alert-stripes 1.4s linear infinite;
}

.kiosk-panel-messages.is-priority.kiosk-priority-effects-on.kiosk-priority-sweep-on::after {
  content: "";
  position: absolute;
  inset: -35%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.18), transparent 55%);
  pointer-events: none;
  mix-blend-mode: screen;
  animation: kiosk-alert-sweep 2.2s linear infinite;
}

.kiosk-panel-messages.is-priority.kiosk-priority-effects-on h2 {
  color: var(--kiosk-priority-message-heading);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  text-shadow: 0 0 10px var(--kiosk-priority-message-glow);
}

.kiosk-priority-banner {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 12px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(120, 0, 0, 0.55);
  border: 1px solid var(--kiosk-priority-message-border);
  color: #ffe9c0;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  font-size: 12px;
  font-weight: 700;
  position: relative;
  z-index: 2;
}

.kiosk-panel-messages.kiosk-priority-banner-flash-on .kiosk-priority-banner {
  animation: kiosk-alert-flash 0.9s steps(2, end) infinite;
}

.kiosk-priority-icon {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: radial-gradient(circle at center, #ffd7d7, #ff4444 62%, #7a0000 100%);
  border: 1px solid rgba(255, 255, 255, 0.75);
  box-shadow: 0 0 12px rgba(255, 80, 80, 0.8);
  position: relative;
}

.kiosk-panel-messages.kiosk-priority-icon-pulse-on .kiosk-priority-icon {
  animation: kiosk-alert-icon-pulse 0.8s ease-in-out infinite;
}

.kiosk-priority-icon::before {
  content: "!";
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-weight: 900;
  font-size: 13px;
  color: #3b0000;
}

@keyframes kiosk-pop {
  0% {
    opacity: 0;
    transform: translateY(8px) scale(0.98);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes kiosk-ledger-tick {
  0%, 100% {
    transform: translateY(0);
    opacity: 0.6;
    height: 8px;
  }
  50% {
    transform: translateY(-2px);
    opacity: 1;
    height: 14px;
  }
}

@keyframes kiosk-priority-alert {
  0%, 100% {
    transform: translateY(0) scale(1);
    filter: saturate(1);
  }
  50% {
    transform: translateY(-1px) scale(var(--kiosk-priority-message-scale));
    filter: saturate(var(--kiosk-priority-message-saturate));
  }
}

@keyframes kiosk-alert-flash {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.55; }
}

@keyframes kiosk-alert-stripes {
  0% { transform: translateX(0); }
  100% { transform: translateX(28px); }
}

@keyframes kiosk-alert-sweep {
  0% { transform: translateX(-30%) translateY(-10%) rotate(0deg); opacity: 0.25; }
  50% { opacity: 0.45; }
  100% { transform: translateX(30%) translateY(10%) rotate(6deg); opacity: 0.2; }
}

@keyframes kiosk-alert-icon-pulse {
  0%, 100% {
    transform: scale(1);
    box-shadow: 0 0 12px rgba(255, 80, 80, 0.8);
  }
  50% {
    transform: scale(1.12);
    box-shadow: 0 0 18px rgba(255, 80, 80, 0.95);
  }
}

@keyframes kiosk-lens-sweep {
  0% {
    transform: translateX(-120%) skewX(-12deg);
    opacity: 0;
  }
  40% {
    opacity: 0.7;
  }
  100% {
    transform: translateX(120%) skewX(-12deg);
    opacity: 0;
  }
}

@keyframes kiosk-warp-in {
  0% {
    opacity: 0;
    transform: perspective(900px) translateY(30px) rotateX(14deg) scale(0.94);
    filter: blur(calc(var(--kiosk-blur-enabled) * 12px));
  }
  60% {
    opacity: 1;
    transform: perspective(900px) translateY(4px) rotateX(2deg) scale(1.01);
    filter: blur(calc(var(--kiosk-blur-enabled) * 2px));
  }
  100% {
    opacity: 1;
    transform: perspective(900px) translateY(0) rotateX(0) scale(1);
    filter: blur(calc(var(--kiosk-blur-enabled) * 0px));
  }
}

@keyframes kiosk-warp-out {
  0% {
    opacity: 1;
    transform: perspective(900px) translateY(0) rotateX(0) scale(1);
    filter: blur(calc(var(--kiosk-blur-enabled) * 0px));
  }
  100% {
    opacity: 0;
    transform: perspective(900px) translateY(-20px) rotateX(-10deg) scale(0.96);
    filter: blur(calc(var(--kiosk-blur-enabled) * 10px));
  }
}

@keyframes kiosk-holo-in {
  0% {
    opacity: 0;
    transform: perspective(900px) translateX(-30px) rotateY(-20deg) scale(0.96);
    filter: blur(calc(var(--kiosk-blur-enabled) * 10px));
  }
  60% {
    opacity: 1;
    transform: perspective(900px) translateX(6px) rotateY(4deg) scale(1.02);
    filter: blur(calc(var(--kiosk-blur-enabled) * 2px));
  }
  100% {
    opacity: 1;
    transform: perspective(900px) translateX(0) rotateY(0) scale(1);
    filter: blur(calc(var(--kiosk-blur-enabled) * 0px));
  }
}

@keyframes kiosk-holo-out {
  0% {
    opacity: 1;
    transform: perspective(900px) translateX(0) rotateY(0) scale(1);
    filter: blur(calc(var(--kiosk-blur-enabled) * 0px));
  }
  100% {
    opacity: 0;
    transform: perspective(900px) translateX(22px) rotateY(14deg) scale(0.96);
    filter: blur(calc(var(--kiosk-blur-enabled) * 10px));
  }
}

@keyframes kiosk-dust-in {
  0% {
    opacity: 0;
    transform: translateY(26px) scale(0.92) translateZ(0);
    filter: blur(calc(var(--kiosk-blur-enabled) * 8px));
  }
  45% {
    opacity: 1;
    transform: translateY(6px) scale(1.02) translateZ(0);
    filter: blur(calc(var(--kiosk-blur-enabled) * 2px));
  }
  75% {
    opacity: 1;
    transform: translateY(2px) scale(1.01) translateZ(0);
    filter: blur(calc(var(--kiosk-blur-enabled) * 1px));
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1) translateZ(0);
    filter: blur(calc(var(--kiosk-blur-enabled) * 0px));
  }
}

@keyframes kiosk-dust-out {
  0% {
    opacity: 1;
    transform: translateY(0) scale(1) translateZ(0);
    filter: blur(calc(var(--kiosk-blur-enabled) * 0px));
  }
  55% {
    opacity: 0.7;
    transform: translateY(-6px) scale(0.99) translateZ(0);
    filter: blur(calc(var(--kiosk-blur-enabled) * 3px));
  }
  80% {
    opacity: 0.4;
    transform: translateY(-14px) scale(0.97) translateZ(0);
    filter: blur(calc(var(--kiosk-blur-enabled) * 6px));
  }
  100% {
    opacity: 0;
    transform: translateY(-26px) scale(0.94) translateZ(0);
    filter: blur(calc(var(--kiosk-blur-enabled) * 10px));
  }
}

@keyframes kiosk-dust-specks {
  0% {
    opacity: 0;
    transform: translateY(12px);
  }
  55% {
    opacity: 0.8;
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(-10px);
  }
}

@keyframes kiosk-dust-specks-out {
  0% {
    opacity: 0.5;
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(-18px);
  }
}

@keyframes kiosk-orbit {
  0% {
    transform: translate3d(0, 0, 0);
  }
  50% {
    transform: translate3d(30px, 20px, 0);
  }
  100% {
    transform: translate3d(0, 0, 0);
  }
}

@keyframes kiosk-grid-drift {
  0% {
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(26px, 26px, 0);
  }
}

@keyframes kiosk-sheen {
  0% {
    transform: translateX(-120%);
  }
  100% {
    transform: translateX(120%);
  }
}

@keyframes kiosk-scanline {
  0% {
    transform: translateY(-100%);
  }
  100% {
    transform: translateY(100%);
  }
}

@keyframes kiosk-aurora {
  0% {
    transform: translate3d(0, 0, 0) rotate(0deg);
  }
  50% {
    transform: translate3d(-6%, 3%, 0) rotate(120deg);
  }
  100% {
    transform: translate3d(0, 0, 0) rotate(240deg);
  }
}

@keyframes kiosk-waves {
  0% {
    transform: translate3d(0, 0, 0) scale(1);
  }
  50% {
    transform: translate3d(4%, -2%, 0) scale(1.08);
  }
  100% {
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@keyframes kiosk-nebula {
  0% {
    transform: translate3d(0, 0, 0) scale(1);
  }
  50% {
    transform: translate3d(-3%, 4%, 0) scale(1.1);
  }
  100% {
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@keyframes kiosk-hyperdrive {
  0% {
    transform: translateY(0) scale(1);
  }
  100% {
    transform: translateY(-18%) scale(1.05);
  }
}

@keyframes kiosk-photon {
  0% {
    transform: translate3d(0, 0, 0) scale(1);
  }
  50% {
    transform: translate3d(3%, -4%, 0) scale(1.12);
  }
  100% {
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@keyframes kiosk-synthgrid {
  0% {
    background-position: 0 0, 0 0, 0 0;
  }
  100% {
    background-position: 0 -120px, 0 40px, 40px 0;
  }
}

@keyframes kiosk-particle {
  0% {
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(-8%, 6%, 0);
  }
}

@keyframes kiosk-circuit {
  0% {
    background-position: 0 0, 0 0, 0 0;
  }
  100% {
    background-position: 60px -60px, -60px 60px, 0 0;
  }
}

@keyframes kiosk-holo-pulse {
  0% {
    transform: rotate(0deg) scale(1);
  }
  50% {
    transform: rotate(160deg) scale(1.08);
  }
  100% {
    transform: rotate(320deg) scale(1);
  }
}

@keyframes kiosk-vortex {
  0% {
    transform: rotate(0deg) scale(1);
  }
  50% {
    transform: rotate(180deg) scale(1.12);
  }
  100% {
    transform: rotate(360deg) scale(1);
  }
}

@keyframes kiosk-matrix {
  0% {
    background-position: 0 -100%;
  }
  100% {
    background-position: 0 100%;
  }
}

@keyframes kiosk-quantum {
  0% {
    transform: translate3d(0, 0, 0) scale(1);
  }
  50% {
    transform: translate3d(4%, -3%, 0) scale(1.12);
  }
  100% {
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@keyframes kiosk-solar {
  0% {
    transform: rotate(0deg) scale(1);
  }
  50% {
    transform: rotate(140deg) scale(1.08);
  }
  100% {
    transform: rotate(280deg) scale(1);
  }
}

@keyframes kiosk-prism {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

@keyframes kiosk-plasma {
  0% {
    transform: translate3d(0, 0, 0) scale(1);
  }
  50% {
    transform: translate3d(-4%, 5%, 0) scale(1.1);
  }
  100% {
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@keyframes kiosk-rift {
  0% {
    transform: rotate(0deg) scale(1);
  }
  50% {
    transform: rotate(180deg) scale(1.12);
  }
  100% {
    transform: rotate(360deg) scale(1);
  }
}

@keyframes kiosk-pulse {
  0% {
    transform: scale(0.98);
    opacity: 0.7;
  }
  50% {
    transform: scale(1.06);
    opacity: 1;
  }
  100% {
    transform: scale(0.98);
    opacity: 0.7;
  }
}

@keyframes kiosk-ion {
  0% {
    transform: translateX(-6%);
  }
  100% {
    transform: translateX(6%);
  }
}

@keyframes kiosk-ether {
  0% {
    transform: translate3d(0, 0, 0) scale(1);
  }
  50% {
    transform: translate3d(2%, 3%, 0) scale(1.06);
  }
  100% {
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@keyframes kiosk-streaks {
  0% {
    background-position: 0 0, 0 0, 0 0;
  }
  100% {
    background-position: 320% 0, -260% 0, 380% 0;
  }
}

@keyframes kiosk-liquid-float {
  0% {
    transform: translate3d(0, 0, 0) scale(1);
  }
  50% {
    transform: translate3d(18px, -12px, 0) scale(1.05);
  }
  100% {
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@media (prefers-reduced-motion: reduce) {
  .kiosk-checkin::before,
  .kiosk-checkin::after,
  .kiosk-overlay,
  .kiosk-surface::before,
  .kiosk-surface::after,
  .kiosk-streaks,
  .kiosk-landing,
  .kiosk-panel,
  .kiosk-btn,
  .kiosk-btn::after,
  .kiosk-result,
  .kiosk-toast {
    animation: none !important;
    transition: none !important;
  }
}

@media (max-width: 900px) {
  .kiosk-overlay,
  .kiosk-checkin::before,
  .kiosk-checkin::after,
  .kiosk-surface::before,
  .kiosk-surface::after,
  .kiosk-surface .kiosk-noise,
  .kiosk-surface .kiosk-streaks {
    display: none;
  }
  .kiosk-surface {
    backdrop-filter: blur(10px) saturate(120%);
  }
}

@media (max-width: 640px) {
  .kiosk-checkin {
    padding: 20px;
  }
  .kiosk-field-row {
    flex-direction: column;
  }
}
