/* =====================================================================
   SAARNER KIOSK – Eigenes CSS (Vantaris Obsidian Look)
   Ergänzt Tailwind CDN um Custom-Farben, Fonts, Animationen und
   Sprachpicker-Styles. Kein Tailwind-Build nötig - Tailwind läuft
   über CDN mit Inline-Config in index.html.
   ===================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Space+Grotesk:wght@500;700;800&display=swap');

:root {
  --sk-orange: #f97316;
  --sk-orange-dark: #ea580c;
  --sk-amber: #f59e0b;
  --sk-black: #000000;
  --sk-zinc-950: #09090b;
  --sk-zinc-900: #18181b;
  --sk-zinc-850: #1f1f23;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  background-color: #000;
}

.font-display {
  font-family: 'Space Grotesk', 'Inter', sans-serif;
}

/* Marquee / Laufband Animation */
@keyframes sk-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.sk-marquee-track {
  display: flex;
  width: max-content;
  animation: sk-marquee 45s linear infinite;
}
.sk-marquee-track:hover {
  animation-play-state: paused;
}

/* Custom scrollbar (dark) */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: #09090b; }
::-webkit-scrollbar-thumb { background: #27272a; border-radius: 999px; }
::-webkit-scrollbar-thumb:hover { background: #f97316; }

/* Zinc-750/650/350 helpers (nicht in Standard-Tailwind enthalten) */
.text-zinc-650 { color: #5c5c63; }
.text-zinc-350 { color: #b8b8c0; }
.border-zinc-750 { border-color: #3a3a40; }
.bg-zinc-850\/40 { background-color: rgba(31, 31, 35, 0.4); }

/* Sprachpicker (matches original .sk-lang-picker structure) */
.sk-lang-picker {
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 2147483000;
  font-family: 'Inter', Arial, sans-serif;
  color: #fff;
}
.sk-lang-picker[data-open="true"] .sk-lang-picker__menu {
  display: block;
}
.sk-lang-picker__button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 0 14px;
  background: rgba(17, 17, 17, 0.96);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
  color: #fff;
  font-size: 13px;
  cursor: pointer;
}
.sk-lang-picker__menu {
  display: none;
  position: absolute;
  right: 0;
  bottom: calc(100% + 10px);
  min-width: 190px;
  max-height: 60vh;
  overflow-y: auto;
  padding: 8px;
  background: rgba(17, 17, 17, 0.98);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 16px;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.45);
}
.sk-lang-picker__option {
  display: block;
  width: 100%;
  padding: 10px 12px;
  margin: 0;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: #fff;
  text-align: left;
  font-size: 14px;
  cursor: pointer;
}
.sk-lang-picker__option[data-active="true"] {
  background: rgba(245, 158, 11, 0.24);
  font-weight: 700;
}
.sk-lang-picker__option:hover,
.sk-lang-picker__option:focus-visible {
  background: rgba(245, 158, 11, 0.18);
  outline: none;
}

/* RTL support for Arabic */
html[dir="rtl"] .sk-lang-picker {
  right: auto;
  left: 16px;
}
html[dir="rtl"] .sk-lang-picker__menu {
  right: auto;
  left: 0;
}
html[dir="rtl"] .sk-lang-picker__option {
  text-align: right;
}

html.lenis,
html.lenis body {
  height: auto;
}

.lenis.lenis-smooth {
  scroll-behavior: auto !important;
}

.lenis.lenis-smooth [data-lenis-prevent] {
  overscroll-behavior: contain;
}

.lenis.lenis-stopped {
  overflow: hidden;
}

.lenis.lenis-scrolling iframe {
  pointer-events: none;
}

/* WYSIWYG edit-mode highlight */
[data-sk-editable].sk-edit-mode {
  outline: 1.5px dashed rgba(249, 115, 22, 0.6);
  outline-offset: 2px;
  border-radius: 4px;
  cursor: pointer;
  transition: outline-color 0.15s, background-color 0.15s;
}
[data-sk-editable].sk-edit-mode:hover {
  outline-color: #f97316;
  background-color: rgba(249, 115, 22, 0.08);
}

/* Leaflet popup dark theme tweaks */
.leaflet-popup-content-wrapper,
.leaflet-popup-tip {
  background: #18181b;
  color: #f4f4f5;
}
.leaflet-container a.leaflet-popup-close-button {
  color: #a1a1aa;
}

/* Gallery lightbox */
.sk-lightbox-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.92);
  z-index: 2147482000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.sk-lightbox-backdrop img {
  max-width: 100%;
  max-height: 88vh;
  border-radius: 18px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.6);
}

/* Hero slide fade */
.sk-hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1.2s ease-in-out;
}
.sk-hero-slide.active {
  opacity: 1;
}

/* Generic fade-in for dynamically loaded content */
.sk-fade-in {
  animation: sk-fade 0.4s ease-out;
}
@keyframes sk-fade {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  position: relative;
  background:
    radial-gradient(circle at 18% 12%, var(--sk-theme-glow-soft, rgba(249, 115, 22, 0.16)) 0, transparent 30%),
    radial-gradient(circle at 85% 14%, var(--sk-theme-secondary-soft, rgba(245, 158, 11, 0.10)) 0, transparent 24%),
    linear-gradient(180deg, var(--sk-theme-primary, #050506) 0%, var(--sk-theme-secondary, #09090b) 100%);
  transition: background 0.45s ease, color 0.3s ease;
}

body > * {
  position: relative;
  z-index: 1;
}

.sk-theme-stage {
  position: fixed;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}

.sk-theme-stage__aura,
.sk-theme-pattern,
.sk-theme-ornaments,
.sk-theme-particles {
  position: absolute;
  inset: 0;
}

#sk-theme-topbar-shell {
  transition: opacity 0.35s ease, transform 0.35s ease;
}

#sk-theme-topbar-shell.is-active {
  display: block !important;
}

#sk-theme-topbar-shell .max-w-7xl,
#sk-theme-topbar-shell .sk-theme-topbar-frame {
  box-shadow: 0 26px 80px rgba(0, 0, 0, 0.34);
}

#sk-theme-topbar-image {
  display: block;
  filter: saturate(1.08) contrast(1.03);
}

.sk-theme-topbar-frame::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, transparent 0 12%, rgba(255, 255, 255, 0.08) 12% 12.4%, transparent 12.4% 100%),
    linear-gradient(180deg, transparent 0%, rgba(255, 255, 255, 0.05) 100%);
  opacity: 0.35;
  mix-blend-mode: screen;
  pointer-events: none;
}

#sk-theme-hero-shell {
  box-shadow: 0 28px 90px rgba(0, 0, 0, 0.4);
}

#sk-theme-hero-image {
  transition: transform 0.7s ease, opacity 0.45s ease;
}

#sk-theme-hero-visual.is-active {
  opacity: 1 !important;
  pointer-events: auto;
}

#sk-theme-hero-visual.is-active #sk-theme-hero-image {
  transform: scale(1.04);
}

#sk-theme-hero-shell[data-theme-mode="campaign"] #sk-hero-slides,
#sk-theme-hero-shell[data-theme-mode="campaign"] #sk-hero-dots {
  opacity: 0;
  pointer-events: none;
}

#sk-theme-hero-shell[data-theme-mode="campaign"] #sk-theme-media-tag-shell,
#sk-theme-hero-shell[data-theme-mode="campaign"] #sk-theme-media-label-shell {
  background: rgba(9, 9, 11, 0.55);
  border-color: rgba(255, 255, 255, 0.18);
  color: rgba(255, 255, 255, 0.88);
}

#sk-theme-feature-list:empty {
  display: none;
}

.sk-theme-feature-pill {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.68) 0%, rgba(2, 6, 23, 0.88) 100%);
  border: 1px solid var(--sk-theme-border-soft, rgba(255, 255, 255, 0.12));
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.18);
}

.sk-theme-feature-pill__icon {
  width: 42px;
  height: 42px;
  flex: 0 0 auto;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--sk-theme-accent-deep, rgba(249, 115, 22, 0.18));
  color: var(--sk-theme-accent, #f97316);
  font-size: 1.15rem;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.sk-theme-feature-pill__text {
  color: rgba(244, 244, 245, 0.9);
  font-size: 0.88rem;
  line-height: 1.45;
}

#sk-theme-story-section {
  transition: opacity 0.35s ease, transform 0.35s ease;
}

#sk-theme-story-section.is-active {
  display: block !important;
}

#sk-theme-story-shell {
  background:
    linear-gradient(180deg, rgba(8, 13, 30, 0.88) 0%, rgba(10, 10, 18, 0.94) 100%),
    radial-gradient(circle at 85% 10%, var(--sk-theme-accent-soft, rgba(249, 115, 22, 0.16)) 0, transparent 34%);
}

.sk-theme-mini-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.55rem 0.9rem;
  border-radius: 999px;
  border: 1px solid var(--sk-theme-border-soft, rgba(255, 255, 255, 0.14));
  background: rgba(255, 255, 255, 0.05);
  color: rgba(244, 244, 245, 0.84);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.sk-theme-story-box {
  position: relative;
  overflow: hidden;
  border-radius: 1.6rem;
  border: 1px solid var(--sk-theme-border-soft, rgba(255, 255, 255, 0.14));
  background:
    linear-gradient(180deg, rgba(8, 13, 30, 0.9) 0%, rgba(7, 9, 18, 0.97) 100%);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.24);
}

.sk-theme-story-box::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(120deg, transparent 0 36%, rgba(255, 255, 255, 0.06) 36% 37%, transparent 37% 100%),
    radial-gradient(circle at 85% 10%, var(--sk-theme-accent-soft, rgba(249, 115, 22, 0.16)) 0, transparent 30%);
  opacity: 0.8;
  pointer-events: none;
}

.sk-theme-story-box__inner {
  position: relative;
  z-index: 1;
  padding: 1.2rem 1.2rem 1.25rem;
}

.sk-theme-story-box__icon {
  width: 3rem;
  height: 3rem;
  border-radius: 1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.85rem;
  background: linear-gradient(180deg, var(--sk-theme-accent-deep, rgba(249, 115, 22, 0.22)) 0%, rgba(17, 24, 39, 0.5) 100%);
  border: 1px solid var(--sk-theme-border-soft, rgba(255, 255, 255, 0.14));
  color: var(--sk-theme-accent, #f97316);
  font-size: 1.2rem;
}

.sk-theme-story-box__title {
  color: #fff;
  font-weight: 800;
  font-size: 1.05rem;
  line-height: 1.2;
  margin-bottom: 0.45rem;
}

.sk-theme-story-box__text {
  color: rgba(228, 228, 231, 0.78);
  font-size: 0.92rem;
  line-height: 1.55;
}

body[data-sk-theme-mode="campaign"] .sk-theme-section {
  position: relative;
  isolation: isolate;
}

body[data-sk-theme-mode="campaign"] .sk-theme-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, transparent 0 8%, rgba(255, 255, 255, 0.035) 8% 8.15%, transparent 8.15% 100%),
    radial-gradient(circle at 12% 18%, var(--sk-theme-accent-soft, rgba(249, 115, 22, 0.09)) 0, transparent 28%);
  opacity: 0.75;
  pointer-events: none;
  animation: sk-theme-scan 18s linear infinite;
}

body[data-sk-theme-mode="campaign"] .sk-theme-card::after,
body[data-sk-theme-mode="campaign"] .sk-theme-panel::after,
body[data-sk-theme-mode="campaign"] #sk-theme-hero-shell::after,
body[data-sk-theme-mode="campaign"] #sk-theme-story-shell::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(120deg, rgba(255,255,255,0.08), var(--sk-theme-accent-soft, rgba(249,115,22,0.18)), rgba(255,255,255,0.04));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  opacity: 0.85;
}

@keyframes sk-theme-scan {
  0% { transform: translate3d(0, 0, 0); opacity: 0.48; }
  50% { transform: translate3d(0, 8px, 0); opacity: 0.72; }
  100% { transform: translate3d(0, 0, 0); opacity: 0.48; }
}

#sk-theme-cta-art-shell {
  transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
}

#sk-theme-cta-art-shell:hover {
  transform: translateY(-4px);
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.22);
}

.sk-theme-stage__aura {
  opacity: var(--sk-theme-aura-opacity, 0.9);
  filter: blur(22px);
  transition: opacity 0.4s ease;
}

.sk-theme-pattern {
  opacity: var(--sk-theme-pattern-opacity, 0.18);
  mix-blend-mode: screen;
}

.sk-theme-pattern[data-pattern="none"] {
  background: none;
}

.sk-theme-pattern[data-pattern="aurora"] {
  background-image:
    linear-gradient(125deg, transparent 0%, var(--sk-theme-accent-soft, rgba(249, 115, 22, 0.16)) 36%, transparent 68%),
    radial-gradient(circle at 20% 18%, var(--sk-theme-glow-soft, rgba(249, 115, 22, 0.18)) 0, transparent 32%);
  background-size: 140% 140%, 100% 100%;
}

.sk-theme-pattern[data-pattern="frost"] {
  background-image:
    linear-gradient(135deg, transparent 0 46%, rgba(255, 255, 255, 0.14) 46% 47%, transparent 47% 100%),
    linear-gradient(45deg, transparent 0 52%, rgba(255, 255, 255, 0.08) 52% 53%, transparent 53% 100%);
  background-size: 340px 340px, 260px 260px;
}

.sk-theme-pattern[data-pattern="bloom"] {
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255, 255, 255, 0.16) 0 4px, transparent 5px),
    radial-gradient(circle at 78% 22%, var(--sk-theme-accent-soft, rgba(249, 115, 22, 0.16)) 0 7px, transparent 8px),
    radial-gradient(circle at 62% 72%, rgba(255, 255, 255, 0.10) 0 5px, transparent 6px);
  background-size: 240px 220px, 320px 280px, 290px 260px;
}

.sk-theme-pattern[data-pattern="fog"] {
  background-image:
    radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.14) 0, transparent 34%),
    radial-gradient(circle at 12% 80%, var(--sk-theme-glow-soft, rgba(249, 115, 22, 0.14)) 0, transparent 30%),
    radial-gradient(circle at 88% 75%, rgba(255, 255, 255, 0.10) 0, transparent 28%);
}

.sk-theme-pattern[data-pattern="streamers"] {
  background-image:
    linear-gradient(120deg, transparent 0 25%, rgba(255, 255, 255, 0.14) 25% 27%, transparent 27% 100%),
    linear-gradient(60deg, transparent 0 35%, var(--sk-theme-accent-soft, rgba(249, 115, 22, 0.16)) 35% 37%, transparent 37% 100%),
    radial-gradient(circle at 80% 25%, rgba(255, 255, 255, 0.18) 0 4px, transparent 5px);
  background-size: 280px 220px, 360px 280px, 180px 180px;
}

.sk-theme-pattern[data-pattern="stadium"] {
  background-image:
    linear-gradient(90deg, transparent 0 8%, rgba(255, 255, 255, 0.08) 8% 9%, transparent 9% 100%),
    radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.22) 0, transparent 24%),
    linear-gradient(180deg, transparent 0%, rgba(255, 255, 255, 0.05) 55%, transparent 100%);
  background-size: 180px 180px, 100% 100%, 100% 100%;
}

.sk-theme-ornaments {
  overflow: hidden;
}

.sk-theme-ornament {
  position: absolute;
  top: clamp(18px, 3vw, 36px);
  font-size: clamp(1.6rem, 3.8vw, 3rem);
  line-height: 1;
  opacity: 0.22;
  filter: drop-shadow(0 10px 18px rgba(0, 0, 0, 0.35));
  animation: sk-theme-float 10s ease-in-out infinite;
}

.sk-theme-ornament[data-side="left"] {
  left: clamp(14px, 3vw, 32px);
}

.sk-theme-ornament[data-side="right"] {
  right: clamp(14px, 3vw, 32px);
  animation-delay: -4s;
}

.sk-theme-particles {
  overflow: hidden;
}

.sk-theme-particle {
  position: absolute;
  top: -14vh;
  color: var(--sk-theme-particle-color, rgba(255, 255, 255, 0.72));
  font-size: var(--sk-theme-particle-size, 1rem);
  opacity: var(--sk-theme-particle-opacity, 0.28);
  text-shadow: 0 10px 22px rgba(0, 0, 0, 0.35);
  animation-name: sk-theme-fall;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
}

@keyframes sk-theme-fall {
  0% { transform: translate3d(0, -10vh, 0) rotate(0deg); }
  100% { transform: translate3d(var(--sk-theme-drift, 12px), 118vh, 0) rotate(360deg); }
}

@keyframes sk-theme-float {
  0%, 100% { transform: translate3d(0, 0, 0) rotate(0deg); }
  50% { transform: translate3d(0, 12px, 0) rotate(-6deg); }
}

body[data-sk-theme] #sk-theme-header,
body[data-sk-theme] #sk-theme-ticker,
body[data-sk-theme] #sk-theme-cta,
body[data-sk-theme] footer,
body[data-sk-theme] .sk-theme-card,
body[data-sk-theme] .sk-theme-panel,
body[data-sk-theme] #sk-theme-hero-shell,
body[data-sk-theme] #sk-theme-topbar-shell .max-w-7xl {
  transition: background-color 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease, transform 0.35s ease;
}

body[data-sk-theme] #sk-theme-header {
  background: linear-gradient(180deg, var(--sk-theme-surface-soft, rgba(24, 24, 27, 0.86)) 0%, rgba(10, 10, 14, 0.82) 100%);
  border-color: var(--sk-theme-border-strong, rgba(255, 255, 255, 0.1));
}

body[data-sk-theme] #sk-theme-ticker {
  background-image: linear-gradient(90deg, var(--sk-theme-accent, #f97316), var(--sk-theme-secondary, #f59e0b));
  border-color: var(--sk-theme-border-soft, rgba(255, 255, 255, 0.12));
}

body[data-sk-theme] .sk-theme-card,
body[data-sk-theme] .sk-theme-panel,
body[data-sk-theme] #sk-theme-cta,
body[data-sk-theme] footer,
body[data-sk-theme] #sk-theme-hero-shell,
body[data-sk-theme] #sk-theme-topbar-shell .max-w-7xl {
  border-color: var(--sk-theme-border-soft, rgba(255, 255, 255, 0.1));
  box-shadow: 0 18px 50px rgba(0, 0, 0, 0.18);
}

body[data-sk-theme] .sk-theme-card,
body[data-sk-theme] .sk-theme-panel {
  background: linear-gradient(180deg, var(--sk-theme-surface-soft, rgba(24, 24, 27, 0.54)) 0%, rgba(10, 10, 14, 0.68) 100%);
}

body[data-sk-theme] #sk-theme-cta {
  background-image: linear-gradient(135deg, var(--sk-theme-accent, #f97316), var(--sk-theme-secondary, #f59e0b));
}

body[data-sk-theme] .text-orange-500,
body[data-sk-theme] .text-orange-400 {
  color: var(--sk-theme-accent, #f97316) !important;
}

body[data-sk-theme] .bg-orange-500 {
  background-color: var(--sk-theme-accent, #f97316) !important;
}

body[data-sk-theme] .bg-orange-950 {
  background-color: var(--sk-theme-accent-deep, rgba(249, 115, 22, 0.16)) !important;
}

body[data-sk-theme] .bg-orange-500\/10 {
  background-color: var(--sk-theme-accent-deep, rgba(249, 115, 22, 0.16)) !important;
}

body[data-sk-theme] .border-orange-500,
body[data-sk-theme] .border-orange-500\/30,
body[data-sk-theme] .border-orange-500\/35,
body[data-sk-theme] .hover\:border-orange-500:hover {
  border-color: var(--sk-theme-accent, #f97316) !important;
}

body[data-sk-theme] .hover\:bg-orange-600:hover {
  background-color: var(--sk-theme-accent-strong, #ea580c) !important;
}

body[data-sk-theme] .shadow-orange-500\/20 {
  box-shadow: 0 12px 30px var(--sk-theme-accent-shadow, rgba(249, 115, 22, 0.22)) !important;
}

body[data-sk-theme] .from-orange-600 {
  --tw-gradient-from: var(--sk-theme-accent, #f97316) var(--tw-gradient-from-position) !important;
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) !important;
}

body[data-sk-theme] .to-amber-500 {
  --tw-gradient-to: var(--sk-theme-secondary, #f59e0b) var(--tw-gradient-to-position) !important;
}

.sk-reveal-target {
  opacity: 0;
  transform: translate3d(0, 26px, 0) scale(0.985);
  transition: transform 0.7s cubic-bezier(.22,1,.36,1), opacity 0.55s ease;
  will-change: transform, opacity;
}

.sk-reveal-target.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }

  .sk-marquee-track,
  .sk-theme-particle,
  .sk-theme-ornament,
  .sk-hero-slide {
    animation: none !important;
  }

  .sk-reveal-target {
    opacity: 1;
    transform: none;
    transition: opacity 0.15s ease;
  }

  .sk-theme-particles,
  .sk-theme-ornaments {
    display: none;
  }
}
