/* =========================================================
   Abiball Portal – Premium Theme (Black / White / Gold)
   - Bootstrap 5 friendly
   - Dark Mode via html.dark (and .dark body)
   ========================================================= */

/* =========================================================
   Design Tokens
   ========================================================= */
:root {
  /* Typography */
  --font-sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, "Noto Sans", sans-serif;
  --font-serif: ui-serif, "Cormorant Garamond", "Times New Roman", Times, serif;

  /* Colors (Light) */
  --bg: #fbfbfd;
  --surface: rgba(255, 255, 255, .86);
  --surface-2: rgba(255, 255, 255, .68);
  --text: #0b0b0f;
  --muted: rgba(11, 11, 15, .62);
  --border: rgba(11, 11, 15, .14);

  --gold: #c9a227;
  --gold-2: #f0d27a;
  --gold-3: #b0891d;
  --gold-glow: rgba(201, 162, 39, .18);

  --primary: var(--gold);
  --primary-600: var(--gold-3);
  --primary-100: rgba(201, 162, 39, .12);

  --success: #2bd47d;
  --danger: #ff4d5a;

  --shadow: 0 12px 34px rgba(0, 0, 0, .08);
  --shadow-sm: 0 8px 22px rgba(0, 0, 0, .08);

  --radius: 18px;
  --radius-sm: 14px;

  --focus: 0 0 0 .18rem rgba(201, 162, 39, .24);
  --nav-glass: rgba(251, 251, 253, .72);

  --theme-transition: 180ms ease;

  /* CTA single-tone gold */
  --cta-gold: #c9a227;
  --cta-gold-hover: #d6b24a;
  --cta-glow: rgba(201, 162, 39, .22);

  /* Responsive glow sizing (default desktop) */
  --glow1-w: 900px;
  --glow1-h: 600px;
  --glow2-w: 1200px;
  --glow2-h: 900px;
  --glow3-w: 1400px;
  --glow3-h: 1000px;

  --glow-x: 50%;
  --glow-y: 35%;
  --glow-y2: 45%;

  /* Landing Page Variables (Light) */
  --star-color: #b0891d;
  /* Darker gold for better visibility on white */
  --landing-grad: radial-gradient(ellipse at bottom, #fbfbfd 0%, #eef0f5 100%);
  --glow-color-1: rgba(201, 162, 39, .28);
  /* More prominent gold glow */
  --glow-color-2: rgba(0, 102, 255, .08);
  /* Subtle blue shimmer */
}

/* Dark mode variables */
html.dark,
.dark body {
  --bg: #07070a;
  --surface: rgba(18, 18, 24, .80);
  --surface-2: rgba(18, 18, 24, .62);
  --text: #f3f3f6;
  --muted: rgba(243, 243, 246, .68);
  --border: rgba(243, 243, 246, .14);

  --primary: var(--gold);
  --primary-600: #d7b24b;
  --primary-100: rgba(201, 162, 39, .16);

  --shadow: 0 14px 40px rgba(0, 0, 0, .35);
  --shadow-sm: 0 10px 28px rgba(0, 0, 0, .28);

  --focus: 0 0 0 .18rem rgba(201, 162, 39, .25);
  --nav-glass: rgba(7, 7, 10, .65);

  /* Landing Page Variables (Dark) */
  --star-color: #FFF;
  --landing-grad: radial-gradient(ellipse at bottom, #1B2735 0%, #090A0F 100%);
  --glow-color-1: rgba(201, 162, 39, .16);
  --glow-color-2: rgba(201, 162, 39, .08);
}

/* =========================================================
   Base
   ========================================================= */
* {
  box-sizing: border-box;
}

html,
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-sans);
}

/* Skip to content link for accessibility */
.skip-to-content {
  position: absolute;
  top: -100px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 9999;
  padding: 0.75rem 1.5rem;
  background: var(--gold);
  color: #0b0b0f;
  font-weight: 700;
  border-radius: 0 0 12px 12px;
  text-decoration: none;
  box-shadow: 0 4px 12px rgba(0, 0, 0, .2);
  transition: top 0.2s ease;
}

.skip-to-content:focus {
  top: 0;
  outline: 3px solid var(--gold);
  outline-offset: 2px;
}

a {
  color: var(--primary);
  text-decoration: none;
}

@media (hover: hover) {
  a:hover {
    color: var(--primary-600);
    text-decoration: underline;
  }
}

.text-muted {
  color: var(--muted) !important;
}

h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6 {
  color: var(--text) !important;
}

.h-serif {
  font-family: var(--font-serif);
  letter-spacing: -0.02em;
}

.fw-semibold,
.fw-bold,
strong {
  color: var(--text) !important;
}

hr {
  border-color: var(--border) !important;
  opacity: 1;
}

.text-danger {
  color: var(--danger) !important;
}

.text-success {
  color: var(--success) !important;
}

/* Theme transitions (global) */
html,
body,
*,
*::before,
*::after {
  transition:
    background-color var(--theme-transition),
    color var(--theme-transition),
    border-color var(--theme-transition),
    box-shadow var(--theme-transition),
    filter var(--theme-transition),
    fill var(--theme-transition),
    stroke var(--theme-transition),
    text-decoration-color var(--theme-transition),
    opacity var(--theme-transition);
}

html.no-theme-transition,
html.no-theme-transition * {
  transition: none !important;
}

/* Fix sticky hover/focus on mobile with fade-out transition */
@media (hover: none) {

  button,
  a,
  .btn,
  .navbar-toggler,
  [data-theme-toggle] {
    -webkit-tap-highlight-color: transparent;
    transition: background-color 0.4s ease, border-color 0.4s ease, box-shadow 0.4s ease, opacity 0.4s ease;
  }

  button:focus,
  a:focus,
  .btn:focus,
  .navbar-toggler:focus,
  [data-theme-toggle]:focus,
  button:active,
  a:active,
  .btn:active,
  .navbar-toggler:active,
  [data-theme-toggle]:active {
    outline: none !important;
    box-shadow: none !important;
    background-image: none !important;
  }
}

/* Fix Bootstrap Accordion for Dark Mode */
.accordion-button {
  color: var(--text);
  background-color: transparent;
  box-shadow: none;
}

.accordion-button:not(.collapsed) {
  color: var(--primary);
  background-color: rgba(201, 162, 39, .08);
  box-shadow: none;
}

.accordion-button::after {
  filter: saturate(0) brightness(1.5);
  /* Make default arrow lighter in dark mode if needed, or replace */
  transition: transform .2s;
}

/* Use gold arrow if possible, or filter logic */
html.dark .accordion-button::after {
  filter: invert(1);
}

/* Better: use custom SVG globally if desired, but this simple fix handles text color */

/* =========================================================
   Premium Background (Redesigned)
   Light: Marble + Gold Geometry
   Dark:  Deep Space + Stars
   ========================================================= */
.bg-starfield {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  /* Light Mode Base */
  background-color: #fbfbfd;
}

html:not(.dark) .bg-starfield::before {
  /* Light Mode Layer 1: Static Gold/Marble Veins */
  content: "";
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;

  /* User Texture - Static & Premium */
  background-image: url('/images/marble-bg.png');
  background-repeat: repeat;
  background-position: top left;

  /* Mobile: 50% of width visible (Zoomed In) -> Image width = 200% of container */
  background-size: 200% auto;
  opacity: 1;
}

/* Desktop: 1.5 tiles horizontal -> 100% / 1.5 = ~66.66% width */
@media (min-width: 992px) {
  html:not(.dark) .bg-starfield::before {
    background-size: 66.667% auto;
  }
}






/* Dark Mode Overrides - Restore Stars */
html.dark .bg-starfield {
  background: var(--landing-grad);
}

html.dark .bg-starfield::before {
  /* Glows */
  inset: -15%;
  width: auto;
  height: auto;
  filter: blur(.25px);
  animation: none;
  background:
    radial-gradient(var(--glow1-w) var(--glow1-h) at var(--glow-x) var(--glow-y),
      var(--glow-color-1),
      transparent 62%),
    radial-gradient(var(--glow2-w) var(--glow2-h) at var(--glow-x) var(--glow-y2),
      var(--glow-color-2),
      transparent 70%),
    radial-gradient(var(--glow3-w) var(--glow3-h) at 50% 50%,
      transparent 58%,
      rgba(0, 51, 153, .04) 100%);
  opacity: .90;
}

html.dark .bg-starfield::after {
  /* Static Stars */
  inset: -20%;
  width: auto;
  height: auto;
  mask-image: none;
  -webkit-mask-image: none;
  background-image:
    radial-gradient(circle, rgba(201, 162, 39, .4) 0.8px, transparent 1.8px),
    radial-gradient(circle, rgba(255, 255, 255, .4) 0.8px, transparent 1.8px);
  background-size: 700px 700px, 900px 900px;
  background-position: 120px 180px, 420px 260px;
  animation: none;
  opacity: .5;
}

.bg-starfield>* {
  position: relative;
  z-index: 1;
}

/* Hide star layers in Light Mode, show in Dark */
html:not(.dark) .stars-layer-1,
html:not(.dark) .stars-layer-2,
html:not(.dark) .stars-layer-3 {
  display: none !important;
}

/* =========================================================
   Animated Starfield Background (Dark Mode Only)
   Seamless infinite loop - stars are duplicated at +2000px for smooth cycling
   ========================================================= */
@keyframes moveUp {
  from {
    transform: translateY(0);
  }

  to {
    transform: translateY(-2000px);
  }
}

.stars-layer-1,
.stars-layer-2,
.stars-layer-3 {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
  z-index: 0;
  pointer-events: none;
  will-change: transform;
}

.stars-layer-1 {
  width: 1px;
  height: 1px;
  background: transparent;
  box-shadow:
    /* Original stars */
    124px 345px var(--gold), 1746px 234px var(--star-color), 432px 876px var(--star-color),
    890px 123px var(--star-color), 1678px 876px var(--gold), 234px 678px var(--star-color),
    456px 167px var(--star-color), 1234px 543px var(--star-color), 678px 1234px var(--gold),
    150px 800px var(--star-color), 900px 300px var(--star-color), 50px 50px var(--star-color),
    1900px 100px var(--star-color), 100px 900px var(--star-color), 1500px 500px var(--star-color),
    600px 600px var(--gold), 300px 1100px var(--star-color), 1100px 200px var(--star-color),
    1300px 800px var(--star-color), 700px 400px var(--star-color), 200px 200px var(--star-color),
    1800px 900px var(--star-color), 1600px 100px var(--star-color), 400px 400px var(--gold),
    1400px 700px var(--star-color), 800px 800px var(--star-color), 1000px 1000px var(--star-color),
    20px 1200px var(--star-color), 1950px 1150px var(--star-color), 550px 50px var(--star-color),
    1700px 1200px var(--star-color), 250px 1050px var(--star-color), 1350px 350px var(--gold),
    950px 650px var(--star-color), 50px 1250px var(--star-color), 1850px 450px var(--star-color),
    450px 950px var(--star-color), 1150px 150px var(--star-color), 1550px 750px var(--star-color),
    350px 250px var(--star-color), 1250px 1250px var(--star-color), 750px 550px var(--star-color),
    2000px 50px var(--star-color), 100px 1200px var(--star-color), 1900px 300px var(--star-color),
    650px 850px var(--star-color), 1450px 950px var(--star-color), 850px 150px var(--gold),
    /* Duplicated at +2000px for seamless loop */
    124px 2345px var(--gold), 1746px 2234px var(--star-color), 432px 2876px var(--star-color),
    890px 2123px var(--star-color), 1678px 2876px var(--gold), 234px 2678px var(--star-color),
    456px 2167px var(--star-color), 1234px 2543px var(--star-color), 678px 3234px var(--gold),
    150px 2800px var(--star-color), 900px 2300px var(--star-color), 50px 2050px var(--star-color),
    1900px 2100px var(--star-color), 100px 2900px var(--star-color), 1500px 2500px var(--star-color),
    600px 2600px var(--gold), 300px 3100px var(--star-color), 1100px 2200px var(--star-color),
    1300px 2800px var(--star-color), 700px 2400px var(--star-color), 200px 2200px var(--star-color),
    1800px 2900px var(--star-color), 1600px 2100px var(--star-color), 400px 2400px var(--gold),
    1400px 2700px var(--star-color), 800px 2800px var(--star-color), 1000px 3000px var(--star-color),
    20px 3200px var(--star-color), 1950px 3150px var(--star-color), 550px 2050px var(--star-color),
    1700px 3200px var(--star-color), 250px 3050px var(--star-color), 1350px 2350px var(--gold),
    950px 2650px var(--star-color), 50px 3250px var(--star-color), 1850px 2450px var(--star-color),
    450px 2950px var(--star-color), 1150px 2150px var(--star-color), 1550px 2750px var(--star-color),
    350px 2250px var(--star-color), 1250px 3250px var(--star-color), 750px 2550px var(--star-color),
    2000px 2050px var(--star-color), 100px 3200px var(--star-color), 1900px 2300px var(--star-color),
    650px 2850px var(--star-color), 1450px 2950px var(--star-color), 850px 2150px var(--gold);
  animation: moveUp 100s linear infinite;
}

.stars-layer-2 {
  width: 2px;
  height: 2px;
  background: transparent;
  box-shadow:
    /* Original stars */
    453px 765px var(--star-color), 1234px 432px var(--star-color), 678px 1234px var(--star-color),
    1567px 876px var(--gold), 345px 890px var(--star-color), 987px 234px var(--star-color),
    1876px 543px var(--star-color), 543px 210px var(--star-color), 100px 100px var(--gold),
    1600px 1100px var(--star-color), 200px 900px var(--star-color), 1400px 200px var(--star-color),
    800px 600px var(--star-color), 400px 1200px var(--gold), 1800px 400px var(--star-color),
    1200px 800px var(--star-color), 600px 300px var(--star-color), 1000px 1000px var(--star-color),
    1950px 50px var(--star-color), 50px 1250px var(--star-color), 1300px 700px var(--gold),
    1500px 150px var(--star-color), 300px 650px var(--star-color), 900px 1150px var(--star-color),
    1700px 950px var(--star-color), 650px 50px var(--gold), 1100px 450px var(--star-color),
    250px 350px var(--star-color), 1350px 1250px var(--star-color), 750px 850px var(--star-color),
    150px 450px var(--star-color), 1850px 1250px var(--gold), 950px 50px var(--star-color),
    550px 950px var(--star-color), 1650px 350px var(--star-color), 50px 550px var(--star-color),
    /* Duplicated at +2000px for seamless loop */
    453px 2765px var(--star-color), 1234px 2432px var(--star-color), 678px 3234px var(--star-color),
    1567px 2876px var(--gold), 345px 2890px var(--star-color), 987px 2234px var(--star-color),
    1876px 2543px var(--star-color), 543px 2210px var(--star-color), 100px 2100px var(--gold),
    1600px 3100px var(--star-color), 200px 2900px var(--star-color), 1400px 2200px var(--star-color),
    800px 2600px var(--star-color), 400px 3200px var(--gold), 1800px 2400px var(--star-color),
    1200px 2800px var(--star-color), 600px 2300px var(--star-color), 1000px 3000px var(--star-color),
    1950px 2050px var(--star-color), 50px 3250px var(--star-color), 1300px 2700px var(--gold),
    1500px 2150px var(--star-color), 300px 2650px var(--star-color), 900px 3150px var(--star-color),
    1700px 2950px var(--star-color), 650px 2050px var(--gold), 1100px 2450px var(--star-color),
    250px 2350px var(--star-color), 1350px 3250px var(--star-color), 750px 2850px var(--star-color),
    150px 2450px var(--star-color), 1850px 3250px var(--gold), 950px 2050px var(--star-color),
    550px 2950px var(--star-color), 1650px 2350px var(--star-color), 50px 2550px var(--star-color);
  animation: moveUp 150s linear infinite;
}

.stars-layer-3 {
  width: 3px;
  height: 3px;
  background: transparent;
  box-shadow:
    /* Original stars */
    678px 345px var(--star-color), 1432px 876px var(--star-color), 234px 1098px var(--gold),
    876px 123px var(--star-color), 1654px 543px var(--star-color), 432px 654px var(--star-color),
    123px 765px var(--gold), 1876px 234px var(--star-color), 987px 987px var(--star-color),
    200px 200px var(--star-color), 1700px 1100px var(--gold), 500px 800px var(--star-color),
    1300px 300px var(--star-color), 800px 1200px var(--star-color), 1500px 600px var(--gold),
    300px 500px var(--star-color), 1100px 900px var(--star-color), 1900px 100px var(--star-color),
    600px 1000px var(--gold), 1400px 400px var(--star-color), 50px 50px var(--star-color),
    1950px 1250px var(--star-color), 150px 1150px var(--gold), 1600px 750px var(--star-color),
    750px 150px var(--star-color), 1050px 650px var(--star-color), 550px 1350px var(--star-color),
    /* Duplicated at +2000px for seamless loop */
    678px 2345px var(--star-color), 1432px 2876px var(--star-color), 234px 3098px var(--gold),
    876px 2123px var(--star-color), 1654px 2543px var(--star-color), 432px 2654px var(--star-color),
    123px 2765px var(--gold), 1876px 2234px var(--star-color), 987px 2987px var(--star-color),
    200px 2200px var(--star-color), 1700px 3100px var(--gold), 500px 2800px var(--star-color),
    1300px 2300px var(--star-color), 800px 3200px var(--star-color), 1500px 2600px var(--gold),
    300px 2500px var(--star-color), 1100px 2900px var(--star-color), 1900px 2100px var(--star-color),
    600px 3000px var(--gold), 1400px 2400px var(--star-color), 50px 2050px var(--star-color),
    1950px 3250px var(--star-color), 150px 3150px var(--gold), 1600px 2750px var(--star-color),
    750px 2150px var(--star-color), 1050px 2650px var(--star-color), 550px 3350px var(--star-color);
  animation: moveUp 200s linear infinite;
}

/* =========================================================
   Shooting Stars (Dark Mode Only) - Subtle Style
   ========================================================= */
html:not(.dark) .shooting-stars {
  display: none !important;
}

.shooting-stars {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

.shooting-star {
  position: absolute;
  width: 80px;
  height: 1px;
  background: linear-gradient(90deg,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0.15) 40%,
      rgba(255, 255, 255, 0.5) 100%);
  border-radius: 999px;
  opacity: 0;
}

.shooting-star::after {
  content: '';
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 2px;
  height: 2px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 0 3px 1px rgba(255, 255, 255, 0.6);
}

/* Different directions for variety */
@keyframes shootingStarDiagLeft {
  0% {
    opacity: 0;
    transform: rotate(-45deg) translateX(0);
  }

  10% {
    opacity: 1;
  }

  90% {
    opacity: 0.5;
  }

  100% {
    opacity: 0;
    transform: rotate(-45deg) translateX(-300px);
  }
}

@keyframes shootingStarDiagRight {
  0% {
    opacity: 0;
    transform: rotate(45deg) translateX(0);
  }

  10% {
    opacity: 1;
  }

  90% {
    opacity: 0.5;
  }

  100% {
    opacity: 0;
    transform: rotate(45deg) translateX(300px);
  }
}

@keyframes shootingStarDown {
  0% {
    opacity: 0;
    transform: rotate(80deg) translateX(0);
  }

  10% {
    opacity: 1;
  }

  90% {
    opacity: 0.5;
  }

  100% {
    opacity: 0;
    transform: rotate(80deg) translateX(250px);
  }
}

@keyframes shootingStarUp {
  0% {
    opacity: 0;
    transform: rotate(-80deg) translateX(0);
  }

  10% {
    opacity: 1;
  }

  90% {
    opacity: 0.5;
  }

  100% {
    opacity: 0;
    transform: rotate(-80deg) translateX(-250px);
  }
}

@keyframes shootingStarHorizontal {
  0% {
    opacity: 0;
    transform: rotate(-10deg) translateX(0);
  }

  10% {
    opacity: 1;
  }

  90% {
    opacity: 0.5;
  }

  100% {
    opacity: 0;
    transform: rotate(-10deg) translateX(-350px);
  }
}

.shooting-star:nth-child(1) {
  top: 15%;
  left: 60%;
  animation: shootingStarDiagLeft 2s ease-out infinite;
  animation-delay: 2s;
}

.shooting-star:nth-child(2) {
  top: 30%;
  left: 20%;
  width: 60px;
  animation: shootingStarDiagRight 1.8s ease-out infinite;
  animation-delay: 8s;
}

.shooting-star:nth-child(3) {
  top: 10%;
  left: 40%;
  width: 100px;
  animation: shootingStarDown 2.2s ease-out infinite;
  animation-delay: 15s;
}

.shooting-star:nth-child(4) {
  top: 50%;
  left: 70%;
  width: 70px;
  animation: shootingStarHorizontal 1.5s ease-out infinite;
  animation-delay: 22s;
}

.shooting-star:nth-child(5) {
  top: 25%;
  left: 85%;
  width: 90px;
  animation: shootingStarUp 2s ease-out infinite;
  animation-delay: 30s;
}






/* =========================================================
   Glass Hero Header
   ========================================================= */
.glass-hero-header {
  display: block;
  width: 100%;
  max-width: 900px;
  margin: 0 auto;

  /* Light Mode Appearance */
  background: rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(201, 162, 39, 0.3);
  border-radius: var(--radius);
  padding: 2.5rem 4rem;
  box-shadow: 0 16px 48px rgba(201, 162, 39, 0.22);
}

/* Dark Mode Appearance */
html.dark .glass-hero-header {
  background: rgba(7, 7, 10, 0.3);
  backdrop-filter: blur(5px) brightness(1.2);
  -webkit-backdrop-filter: blur(5px) brightness(1.2);
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.3);
  padding: 2.5rem 4rem;
}

/* Smaller variant for internal pages */
.glass-hero-header.sm {
  max-width: 820px;
  padding: 1.5rem 2rem !important;
}

/* =========================================================
   Entry Animations
   ========================================================= */
.animate-fade-up {
  opacity: 0;
  transform: translateY(20px);
  animation: fadeInUp 0.8s ease-out forwards;
}

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

.delay-100 {
  animation-delay: 0.1s;
}

.delay-200 {
  animation-delay: 0.2s;
}

.delay-300 {
  animation-delay: 0.3s;
}

.delay-400 {
  animation-delay: 0.4s;
}

/* =========================================================
   Premium Micro-Interactions
   ========================================================= */

/* 1. Masked Text Reveal */
.reveal-text {
  /* Initial state */
  clip-path: inset(0 0 100% 0);
  transform: translateY(40px);
  opacity: 0;
  animation: revealText 1.1s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes revealText {
  to {
    clip-path: inset(0 -20% -20% -20%);
    transform: translateY(0);
    opacity: 1;
  }
}

/* 2. Button Shimmer (Background Sweep)
   Uses background-image gradient to avoid overflow:hidden which kills shadows */
.btn-shimmer {
  background-size: 200% auto !important;
  background-image: linear-gradient(120deg,
      transparent 0%,
      transparent 20%,
      rgba(255, 255, 255, 0.3) 40%,
      transparent 60%,
      transparent 100%) !important;
  background-position: 200% center !important;
  transition: background-position 0.6s ease-out, transform 0.2s, box-shadow 0.2s;
}

@media (hover: hover) {
  .btn-shimmer:hover {
    background-position: -100% center !important;
  }
}

/* 3. Hover Float (Card Lift) */
.hover-float {
  transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.4s ease;
}

@media (hover: hover) {
  .hover-float:hover {
    transform: translateY(-8px);
    box-shadow: 0 14px 40px rgba(0, 0, 0, 0.12);
    /* Enhanced shadow lift */
  }

  html.dark .hover-float:hover {
    box-shadow: 0 14px 40px rgba(0, 0, 0, 0.45);
  }
}


/* =========================================================
   Navbar
   ========================================================= */
.navbar {
  background: var(--nav-glass) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid transparent;
  border-image: linear-gradient(to right, transparent, var(--border), transparent) 1;
  box-shadow: 0 4px 30px rgba(0, 0, 0, .03);
  z-index: 1030;
}

html.dark .navbar,
.dark .navbar {
  box-shadow: 0 4px 30px rgba(0, 0, 0, .2);
  border-image: linear-gradient(to right, transparent, rgba(255, 255, 255, 0.1), transparent) 1;
}

.navbar-brand {
  letter-spacing: .22em;
  text-transform: uppercase;
  font-weight: 600;
  font-size: .9rem;
  color: var(--text) !important;
  transition: transform 0.3s ease, filter 0.3s ease, color var(--theme-transition);
}

.navbar-brand:hover {
  transform: scale(1.02);
  filter: drop-shadow(0 0 8px var(--glow-color-1));
}

.navbar .nav-link {
  color: var(--muted) !important;
  text-decoration: none !important;
}

.navbar .nav-link {
  color: var(--muted) !important;
  text-decoration: none !important;
  position: relative;
  padding-bottom: 2px;
}

.navbar .nav-link:hover {
  color: var(--text) !important;
}

/* Animated Underline for Desktop Nav Links */
@media (min-width: 992px) {
  .navbar .nav-link {
    height: 44px;
    display: inline-flex;
    align-items: center;
    padding-bottom: 5px;
    /* Visual lift */
  }

  .navbar .nav-link::after {
    content: '';
    position: absolute;
    width: 0;
    height: 1px;
    bottom: 0;
    left: 0;
    background-color: var(--gold);
    transition: width 0.3s ease-out;
  }

  .navbar .nav-link:hover::after {
    width: 100%;
  }
}

/* Navbar links & footer links: no underline, gold hover */
.navbar a,
footer a {
  text-decoration: none !important;
  transition: color var(--theme-transition);
}

.navbar a:hover,
footer a:hover {
  color: var(--gold, #c9a227) !important;
  text-decoration: none !important;
}

.navbar a:focus,
.navbar a:focus-visible,
.navbar a:active,
footer a:focus,
footer a:focus-visible,
footer a:active {
  outline: none !important;
  box-shadow: none !important;
  text-decoration: none !important;
}

.navbar-toggler {
  border-color: var(--border) !important;
}

.navbar-toggler:focus {
  box-shadow: none !important;
}

@media (hover: hover) {
  .navbar-toggler:focus {
    box-shadow: var(--focus) !important;
  }
}

html.dark .navbar-toggler-icon,
.dark .navbar-toggler-icon {
  filter: invert(1);
}

/* Navbar user badge */
.navbar-user {
  transition:
    background-color var(--theme-transition),
    color var(--theme-transition),
    border-color var(--theme-transition),
    box-shadow var(--theme-transition),
    opacity var(--theme-transition),
    filter var(--theme-transition);
  text-decoration: none !important;
}

.navbar-user:hover {
  background: rgba(201, 162, 39, .08);
  border-color: rgba(201, 162, 39, .25);
  color: var(--gold, #c9a227) !important;
  text-decoration: none !important;
}

.navbar-user:focus,
.navbar-user:focus-visible,
.navbar-user:active {
  outline: none !important;
  box-shadow: none !important;
  text-decoration: none !important;
}

/* Theme toggle button: no ring */
.btn.btn-ghost[data-theme-toggle] {
  outline: none !important;
  box-shadow: none !important;
  border-color: transparent !important;
}

.btn.btn-ghost[data-theme-toggle]:hover {
  color: var(--gold, #c9a227) !important;
}

.btn.btn-ghost[data-theme-toggle]:focus,
.btn.btn-ghost[data-theme-toggle]:focus-visible,
.btn.btn-ghost[data-theme-toggle]:active {
  outline: none !important;
  box-shadow: none !important;
}

.btn.btn-ghost[data-theme-toggle]:focus-visible {
  --bs-btn-focus-shadow-rgb: 0, 0, 0;
}

/* =========================================================
   Footer
   ========================================================= */
footer {
  margin-top: auto;
  position: relative;
  background: linear-gradient(to bottom, var(--bg), rgba(201, 162, 39, .03));
  border-top: 1px solid transparent;
  border-image: linear-gradient(to right, transparent, var(--border), transparent) 1;
}

html.dark footer {
  background: linear-gradient(to bottom, var(--bg), rgba(255, 255, 255, .02));
  border-image: linear-gradient(to right, transparent, rgba(255, 255, 255, 0.1), transparent) 1;
}

.footer-links {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 1.5rem;
  margin-top: 1rem;
}

.footer-links a {
  position: relative;
  font-weight: 500;
  transition: color 0.3s ease, transform 0.3s ease;
}

.footer-links a:hover {
  color: var(--gold) !important;
  transform: translateY(-2px);
}


/* Theme toggle icon fix */
#themeToggleBtn svg {
  filter: none !important;
  box-shadow: none !important;
}

#themeToggleBtn::before,
#themeToggleBtn::after {
  content: none !important;
}

/* =========================================================
   Payment Page Components
   ========================================================= */
.zahl-card {
  background: rgba(201, 162, 39, .10);
  border: 1px solid rgba(201, 162, 39, .35);
  border-radius: .75rem;
}

.zahl-pill {
  font-size: .95rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  background: rgba(201, 162, 39, .22);
  border: 1px solid rgba(201, 162, 39, .45);
  color: var(--primary);
}

.zahl-acc .accordion-item {
  border: none;
  background: transparent;
}

.zahl-acc .accordion-button {
  font-size: 1.15rem;
  font-weight: 400;
  background: transparent;
  border-radius: .75rem;
  width: 100%;
  color: var(--text);
}

.zahl-acc .accordion-button:not(.collapsed) {
  color: var(--text);
  background: transparent;
  box-shadow: none;
}

.zahl-acc .accordion-button::after {
  filter: var(--accordion-icon-filter, none);
}

html.dark .zahl-acc .accordion-button::after {
  filter: invert(1) brightness(0.9);
}

.zahl-acc .accordion-button:focus {
  box-shadow: none;
}

.zahl-acc .accordion-body {
  color: var(--text);
}

.zahl-acc .accordion-body a {
  color: var(--primary);
}

.zahl-acc .accordion-body code {
  color: var(--text);
  background: rgba(201, 162, 39, .12);
  padding: 2px 6px;
  border-radius: 4px;
}

/* =========================================================
   Cards
   ========================================================= */
.card {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow-sm);
  backdrop-filter: blur(10px);
}

.card .card-header {
  background: transparent;
  border-bottom: 1px solid var(--border);
}

.shadow-sm {
  box-shadow: var(--shadow-sm) !important;
}

/* =========================================================
   Tables
   ========================================================= */
.table {
  color: var(--text);
}

.table thead th {
  background: var(--surface-2);
  color: var(--text);
  border-bottom: 1px solid var(--border);
}

.table td,
.table th {
  border-color: var(--border) !important;
}

.table-hover tbody tr:hover {
  background: rgba(201, 162, 39, .06);
}

/* =========================================================
   Forms
   ========================================================= */
.form-control {
  background: var(--surface);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: .55rem .75rem;
}

.form-control::placeholder {
  color: var(--muted);
}

.form-control:focus {
  background: var(--surface);
  color: var(--text);
  border-color: var(--primary);
  box-shadow: var(--focus);
}

.form-check-input {
  border-color: var(--border);
  background-color: var(--surface);
}

.form-check-input:focus {
  box-shadow: var(--focus);
  border-color: var(--primary);
}

.form-check-input:checked {
  background-color: var(--primary);
  border-color: var(--primary);
}

/* =========================================================
   Buttons
   ========================================================= */
.btn {
  border-radius: 999px;
  padding: .55rem 1.05rem;
}

.btn-primary {
  background: linear-gradient(180deg, var(--gold-2), var(--gold));
  border-color: rgba(0, 0, 0, .12);
  color: #0b0b0f;
  box-shadow: 0 12px 30px var(--gold-glow);
}

.btn-primary:hover {
  background: linear-gradient(180deg, #f6dd90, var(--gold));
  border-color: rgba(0, 0, 0, .12);
  filter: brightness(1.01);
}

.btn-primary:focus {
  box-shadow: var(--focus), 0 12px 30px var(--gold-glow);
}

.btn-outline-secondary {
  color: var(--text);
  border-color: rgba(201, 162, 39, .45);
  background: transparent;
  border-radius: 12px;
}

.btn-outline-secondary:hover {
  background: rgba(201, 162, 39, .08);
  border-color: rgba(201, 162, 39, .55);
}

.btn-outline-danger {
  border-radius: 12px;
}

.btn-ghost {
  background: transparent;
  border: 1px solid transparent;
  color: var(--text);
}

.btn-ghost:hover {
  background: rgba(201, 162, 39, .08);
  border-color: rgba(201, 162, 39, .25);
}

.btn-ghost:focus {
  box-shadow: var(--focus);
}

/* Premium save buttons */
.btn-save {
  background: var(--cta-gold-hover) !important;
  border: 1px solid rgba(0, 0, 0, .18) !important;
  color: #0b0b0f !important;
  border-radius: 12px !important;
  font-weight: 700;
  box-shadow: 0 12px 26px var(--cta-glow);
}

.btn-save:hover {
  filter: brightness(1.02);
  box-shadow: 0 14px 30px var(--cta-glow);
}

.btn-save:focus {
  box-shadow: var(--focus), 0 14px 30px var(--cta-glow);
}

.btn-save-strong {
  background: var(--cta-gold-hover) !important;
  border: 1px solid rgba(0, 0, 0, .18) !important;
  color: #0b0b0f !important;
  border-radius: 12px !important;
  padding: .72rem 1.2rem !important;
  font-weight: 800;
  letter-spacing: .02em;
  box-shadow: 0 14px 34px var(--cta-glow);
}

.btn-save-strong:hover {
  filter: brightness(1.02);
  box-shadow: 0 16px 40px var(--cta-glow);
}

/* =========================================================
   Premium CTA Button (anchor-safe)
   ========================================================= */
a.btn-cta,
a.btn-cta:visited,
button.btn-cta {
  position: relative;
  isolation: isolate;
  background: rgba(255, 255, 255, 0.6) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: 999px !important;
  /* Pill shape for modern look */
  padding: .6rem 1.4rem !important;
  font-family: var(--font-sans);
  font-weight: 600;
  letter-spacing: .02em;
  border: 1px solid rgba(11, 11, 15, .15) !important;
  color: var(--text) !important;
  text-decoration: none !important;
  transition:
    color 200ms ease,
    border-color 200ms ease,
    background-color 200ms ease,
    box-shadow 260ms ease,
    transform 120ms ease;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.03);
  cursor: pointer;
}

html.dark a.btn-cta,
.dark a.btn-cta,
html.dark button.btn-cta,
.dark button.btn-cta {
  background: rgba(255, 255, 255, 0.04) !important;
  border-color: rgba(255, 255, 255, .15) !important;
  color: #f3f3f6 !important;
}

a.btn-cta:hover,
a.btn-cta:focus-visible,
button.btn-cta:hover,
button.btn-cta:focus-visible {
  text-decoration: none !important;
  transform: translateY(-1px);
  background: linear-gradient(135deg, rgba(201, 162, 39, .18), rgba(11, 11, 15, .02)) !important;
  border-color: rgba(201, 162, 39, .40) !important;
  color: var(--text) !important;
  box-shadow:
    0 16px 38px rgba(0, 0, 0, .10),
    0 10px 26px var(--gold-glow),
    inset 0 0 0 1px rgba(255, 255, 255, .18);
}

html.dark a.btn-cta:hover,
html.dark a.btn-cta:focus-visible,
html.dark button.btn-cta:hover,
html.dark button.btn-cta:focus-visible {
  box-shadow:
    0 18px 44px rgba(0, 0, 0, .40),
    0 10px 26px rgba(201, 162, 39, .18),
    inset 0 0 0 1px rgba(255, 255, 255, .10);
}

a.btn-cta:active,
button.btn-cta:active {
  transform: translateY(0);
  box-shadow: 0 10px 24px var(--cta-glow);
}

a.btn-cta:focus-visible,
button.btn-cta:focus-visible {
  outline: none;
  box-shadow: var(--focus), 0 14px 34px var(--cta-glow);
}

/* Navbar compact CTA */
a.btn-cta.btn-cta-sm,
button.btn-cta.btn-cta-sm {
  padding: 0 1.2rem !important;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  font-weight: 500;
  min-width: unset;
  letter-spacing: normal;
  text-transform: none;
  /* Keep it natural */
}

/* Large CTA button for login forms */
button.btn-cta.btn-cta-lg {
  padding: .85rem 2rem !important;
  font-size: 1.1rem;
  font-weight: 700;
}

/* =========================================================
   Dashboard – Aktionen Kachel (einheitlicher Luxus-Stil)
   ========================================================= */
.actions-kicker {
  letter-spacing: .18em;
  text-transform: uppercase;
  font-size: .7rem;
  color: var(--muted);
}

/* Optional: add class "actions-card" to the card if desired */
.actions-card {
  overflow: hidden;
}

/* Modern luxe action button (neutral) */
.btn-action {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .52rem 1.05rem !important;
  border-radius: 14px !important;
  font-size: .84rem !important;
  font-weight: 650;
  letter-spacing: .02em;
  text-decoration: none !important;

  color: var(--text) !important;
  background: linear-gradient(135deg, rgba(11, 11, 15, .06), rgba(11, 11, 15, .02));
  border: 1px solid rgba(11, 11, 15, .18);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .18),
    0 10px 22px rgba(0, 0, 0, .06);

  transition: transform 140ms ease, box-shadow 220ms ease, background-color 220ms ease, border-color 180ms ease, color 180ms ease;
}

html.dark .btn-action {
  color: rgba(243, 243, 246, .92) !important;
  background: linear-gradient(135deg, rgba(255, 255, 255, .06), rgba(255, 255, 255, .02));
  border-color: rgba(243, 243, 246, .14);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .08),
    0 14px 34px rgba(0, 0, 0, .30);
}

.btn-action:hover,
.btn-action:focus-visible {
  transform: translateY(-1px);
  background: linear-gradient(135deg, rgba(201, 162, 39, .18), rgba(11, 11, 15, .02));
  border-color: rgba(201, 162, 39, .40);
  text-decoration: none !important;
  box-shadow:
    0 16px 38px rgba(0, 0, 0, .10),
    0 10px 26px var(--gold-glow),
    inset 0 0 0 1px rgba(255, 255, 255, .18);
}

html.dark .btn-action:hover,
html.dark .btn-action:focus-visible {
  box-shadow:
    0 18px 44px rgba(0, 0, 0, .40),
    0 10px 26px rgba(201, 162, 39, .18),
    inset 0 0 0 1px rgba(255, 255, 255, .10);
}

.btn-action:active {
  transform: translateY(0);
}

/* Accent action button (e.g., Zahlung) */
.btn-action-accent {
  background: linear-gradient(180deg, var(--gold-2), var(--gold)) !important;
  border-color: rgba(0, 0, 0, .14) !important;
  color: #0b0b0f !important;
  box-shadow: 0 14px 34px var(--gold-glow);
}

.btn-action-accent:hover,
.btn-action-accent:focus-visible {
  filter: brightness(1.02);
  box-shadow: 0 16px 40px var(--gold-glow);
}

/* =========================================================
   Aktionen – Buttons (Anchor-safe, overrides links)
   ========================================================= */
a.btn-action,
a.btn-action:visited {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;

  padding: .62rem 1.12rem !important;
  border-radius: 14px !important;

  font-size: .86rem !important;
  font-weight: 650 !important;
  letter-spacing: .02em;

  text-decoration: none !important;
  cursor: pointer;

  color: var(--text) !important;
  background: linear-gradient(135deg, rgba(11, 11, 15, .06), rgba(11, 11, 15, .02)) !important;
  border: 1px solid rgba(11, 11, 15, .18) !important;

  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .18),
    0 10px 22px rgba(0, 0, 0, .06);

  transition:
    transform 140ms ease,
    box-shadow 220ms ease,
    background-color 220ms ease,
    border-color 180ms ease,
    color 180ms ease;
}

html.dark a.btn-action,
html.dark a.btn-action:visited {
  color: rgba(243, 243, 246, .92) !important;
  background: linear-gradient(135deg, rgba(255, 255, 255, .06), rgba(255, 255, 255, .02)) !important;
  border-color: rgba(243, 243, 246, .14) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .08),
    0 14px 34px rgba(0, 0, 0, .30);
}

/* Hover / Focus */
a.btn-action:hover,
a.btn-action:focus-visible {
  text-decoration: none !important;

  transform: translateY(-1px);
  background: linear-gradient(135deg, rgba(201, 162, 39, .18), rgba(11, 11, 15, .02)) !important;
  border-color: rgba(201, 162, 39, .40) !important;

  box-shadow:
    0 16px 38px rgba(0, 0, 0, .10),
    0 10px 26px var(--gold-glow),
    inset 0 0 0 1px rgba(255, 255, 255, .18);
}

html.dark a.btn-action:hover,
html.dark a.btn-action:focus-visible {
  box-shadow:
    0 18px 44px rgba(0, 0, 0, .40),
    0 10px 26px rgba(201, 162, 39, .18),
    inset 0 0 0 1px rgba(255, 255, 255, .10);
}

a.btn-action:active {
  transform: translateY(0);
}

/* Accent (Zahlung) */
a.btn-action.btn-action-accent,
a.btn-action.btn-action-accent:visited {
  background: linear-gradient(180deg, var(--gold-2), var(--gold)) !important;
  border-color: rgba(0, 0, 0, .14) !important;
  color: #0b0b0f !important;
  box-shadow: 0 14px 34px var(--gold-glow);
}

a.btn-action.btn-action-accent:hover,
a.btn-action.btn-action-accent:focus-visible {
  filter: brightness(1.02);
  box-shadow: 0 16px 40px var(--gold-glow);
}

/* =========================================================
   Badges
   ========================================================= */
.badge.text-bg-secondary {
  background: rgba(11, 11, 15, .10) !important;
  color: var(--text) !important;
  border: 1px solid var(--border);
}

html.dark .badge.text-bg-secondary,
.dark .badge.text-bg-secondary {
  background: rgba(243, 243, 246, .10) !important;
}

.badge-gold {
  background: rgba(201, 162, 39, .12);
  border: 1px solid rgba(201, 162, 39, .28);
  color: var(--primary);
  border-radius: 999px;
}

/* =========================================================
   Alerts / Dropdown / List Group
   ========================================================= */
.alert {
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: var(--radius-sm);
}

.list-group {
  border-radius: 12px;
}

.list-group-item {
  background: var(--surface) !important;
  color: var(--text) !important;
  border-color: var(--border) !important;
}

.list-group-flush {
  border-radius: 12px;
  overflow: hidden;
}

.list-group-item-action:hover {
  background: var(--surface-2) !important;
  color: var(--text) !important;
}

.list-group-item-action:active {
  background: var(--primary-100) !important;
  color: var(--text) !important;
}

.dropdown-menu {
  background: var(--surface) !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
  box-shadow: var(--shadow-sm);
}

.dropdown-item {
  color: var(--text) !important;
}

.dropdown-item:hover {
  background: var(--surface-2) !important;
}

/* =========================================================
   Footer
   ========================================================= */
.site-footer {
  background: var(--surface);
  border-top: 1px solid var(--border);
}

.footer-linkedin {
  display: inline-flex;
  align-items: center;
  color: var(--muted);
}

.footer-linkedin:hover {
  color: var(--primary);
  text-decoration: none;
}

/* Footer layout - prevent text cutoff */
footer .container {
  flex-wrap: wrap !important;
  justify-content: center !important;
  gap: 1.5rem !important;
}

footer .text-muted.d-flex {
  flex-shrink: 0;
  white-space: nowrap;
  justify-content: center;
}

/* Footer responsive links - 3 per row if <6 links, 4 per row if >=6 links */
footer .d-flex.gap-3 {
  flex-wrap: wrap;
  justify-content: center;
  width: 100%;
}

/* Default: 3 links per row */
footer .d-flex.gap-3 a {
  flex-basis: calc(33.33% - 0.75rem);
  text-align: center;
}

/* If 6+ links: 4 per row */
footer .d-flex.gap-3 a:nth-child(6)~a,
footer .d-flex.gap-3 a:nth-child(n+6) {
  flex-basis: calc(25% - 0.75rem);
}

@media (max-width: 768px) {
  footer .text-muted.d-flex {
    width: 100%;
  }
}

/* =========================================================
   Seating UI
   ========================================================= */
.seating-column-title {
  font-weight: 800;
  letter-spacing: .2px;
}

.person-item {
  user-select: none;
  border-radius: 12px !important;
  border: 1px solid var(--border) !important;
  background: var(--surface) !important;
}

.person-item[draggable="true"] {
  cursor: grab;
}

.person-item[draggable="true"]:active {
  cursor: grabbing;
}

.drop-label {
  font-weight: 800;
  font-size: .82rem;
  letter-spacing: .25px;
  color: var(--muted);
  margin-bottom: .35rem;
}

.dropzone {
  min-height: 96px;
  padding: .75rem;
  border: 2px dashed rgba(11, 11, 15, .22);
  border-radius: var(--radius);
  background: var(--surface-2);
}

html.dark .dropzone,
.dark .dropzone {
  border-color: rgba(243, 243, 246, .20);
  background: rgba(255, 255, 255, 0.03);
}

.dropzone.is-over {
  border-color: var(--primary);
  background: var(--primary-100);
}

.group-tools {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  flex-wrap: wrap;
  margin-top: .75rem;
}

.group-tools .form-control {
  max-width: 420px;
}

/* =========================================================
   Sticky Footer Layout
   ========================================================= */
html,
body {
  height: 100%;
}

body.layout-root {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

body.layout-root .page-content {
  flex: 1 0 auto;
  display: block;
}

footer {
  flex-shrink: 0;
}

/* =========================================================
   Dark Mode Readability Fix (global)
   ========================================================= */
html.dark body,
html.dark .bg-starfield,
html.dark .card,
html.dark .navbar,
html.dark footer {
  color: var(--text) !important;
}

html.dark .text-muted {
  color: rgba(243, 243, 246, .72) !important;
}

html.dark label,
html.dark .form-label,
html.dark small,
html.dark .small {
  color: rgba(243, 243, 246, .78) !important;
}

html.dark .dropdown-item {
  color: rgba(243, 243, 246, .90) !important;
}

html.dark .dropdown-item:hover {
  color: var(--text) !important;
}

/* Small helper blocks */
.p-soft {
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: .85rem 1rem;
  background: rgba(255, 255, 255, .22);
}

html.dark .p-soft {
  background: rgba(255, 255, 255, .04);
}

/* =========================================================
   Admin Dashboard – Theme-safe (improved dark tables)
   ========================================================= */
.admin-dashboard .admin-kicker {
  letter-spacing: .18em;
  text-transform: uppercase;
}

.admin-dashboard .admin-card {
  border-radius: 18px;
}

html.dark .admin-dashboard .card {
  background: var(--surface) !important;
  color: var(--text) !important;
  border-color: var(--border) !important;
}

/* Panels inside cards */
.admin-dashboard .admin-panel {
  border-radius: 16px;
  border: 1px solid rgba(11, 11, 15, .10);
  background: rgba(11, 11, 15, .03);
  color: var(--text);
}

html.dark .admin-dashboard .admin-panel {
  border-color: rgba(243, 243, 246, .10);
  background: rgba(16, 16, 22, .55);
  color: var(--text);
}

.admin-dashboard .admin-seatgroup {
  border-radius: 16px;
  border: 1px solid rgba(11, 11, 15, .10);
  background: rgba(11, 11, 15, .02);
}

html.dark .admin-dashboard .admin-seatgroup {
  border-color: rgba(243, 243, 246, .10);
  background: rgba(16, 16, 22, .60);
}

.admin-dashboard .admin-seatperson {
  padding: .65rem .75rem;
  border-radius: 14px;
  border: 1px solid rgba(11, 11, 15, .10);
  background: rgba(11, 11, 15, .02);
}

html.dark .admin-dashboard .admin-seatperson {
  border-color: rgba(243, 243, 246, .10);
  background: rgba(0, 0, 0, .18);
}

/* Tables: override Bootstrap white cells in dark mode */
.admin-dashboard .table {
  color: var(--text);
  background-color: transparent;
}

.admin-dashboard .table> :not(caption)>*>* {
  background-color: transparent !important;
  /* kills white cell bg */
  color: inherit;
}

.admin-dashboard .table thead th {
  background: var(--surface-2) !important;
  border-bottom: 1px solid var(--border) !important;
  color: var(--text) !important;
}

.admin-dashboard .table tbody td {
  background-color: transparent !important;
  color: var(--text) !important;
}

.admin-dashboard .table tbody tr:nth-child(odd) td {
  background-color: rgba(11, 11, 15, .02) !important;
}

html.dark .admin-dashboard .table {
  color: rgba(243, 243, 246, .92) !important;
  background-color: transparent;
}

html.dark .admin-dashboard .table> :not(caption)>*>* {
  background-color: transparent !important;
  color: rgba(243, 243, 246, .92) !important;
}

html.dark .admin-dashboard .table thead th {
  background: rgba(16, 16, 22, .70) !important;
  color: rgba(243, 243, 246, .92) !important;
  border-bottom-color: rgba(243, 243, 246, .14) !important;
}

html.dark .admin-dashboard .table tbody td {
  background-color: transparent !important;
  color: rgba(243, 243, 246, .92) !important;
  border-color: rgba(243, 243, 246, .14) !important;
}

html.dark .admin-dashboard .table tbody tr:nth-child(odd) td {
  background-color: rgba(255, 255, 255, .02) !important;
}

html.dark .admin-dashboard .table td,
html.dark .admin-dashboard .table th {
  border-color: rgba(243, 243, 246, .14) !important;
}

/* Striped + hover in dark */
html.dark .admin-dashboard .table-striped>tbody>tr:nth-of-type(odd)>* {
  background-color: rgba(255, 255, 255, .03) !important;
}

html.dark .admin-dashboard .table-hover>tbody>tr:hover>* {
  background-color: rgba(201, 162, 39, .10) !important;
}

/* Inputs in dark mode */
html.dark .admin-dashboard .form-control,
html.dark .admin-dashboard .form-select {
  background-color: rgba(10, 10, 14, .55);
  color: rgba(243, 243, 246, .92);
  border-color: rgba(255, 255, 255, .14);
}

html.dark .admin-dashboard .form-control::placeholder {
  color: rgba(243, 243, 246, .45);
}

/* Buttons: align with site “save” styling */
.admin-dashboard .btn-save {
  border-radius: 12px !important;
}

/* Hide sections smoothly (optional) */
.admin-dashboard .admin-section {
  animation: adminFade .12s ease-out;
}

@keyframes adminFade {
  from {
    opacity: 0;
    transform: translateY(2px);
  }

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

/* General dark mode styling for admin-dashboard */
html.dark .admin-dashboard {
  background-color: var(--bg);
  color: var(--text);
}

html.dark .admin-dashboard div,
html.dark .admin-dashboard span,
html.dark .admin-dashboard p,
html.dark .admin-dashboard h1,
html.dark .admin-dashboard h2,
html.dark .admin-dashboard h3,
html.dark .admin-dashboard h4,
html.dark .admin-dashboard h5,
html.dark .admin-dashboard h6,
html.dark .admin-dashboard a {
  color: inherit;
}

html.dark .admin-dashboard .text-muted {
  color: rgba(243, 243, 246, .65) !important;
}

html.dark .admin-dashboard .alert {
  background-color: rgba(16, 16, 22, .70) !important;
  color: var(--text) !important;
}

/* =========================================================
   Dashboard: dezentes Notiz-Icon
   ========================================================= */
.note-btn {
  border: 1px solid var(--border);
  background: transparent;
  color: var(--muted);
  border-radius: 12px;
  padding: .35rem .5rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background-color 180ms ease, color 180ms ease, border-color 180ms ease;
}

.note-btn:hover {
  background: rgba(201, 162, 39, .08);
  color: var(--text);
  border-color: rgba(201, 162, 39, .35);
}

.note-btn:focus {
  outline: none;
  box-shadow: var(--focus);
}

.note-icon {
  display: inline-flex;
}

/* =========================================================
   Loading States & Spinners
   ========================================================= */
.spinner {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid rgba(201, 162, 39, .2);
  border-top-color: var(--gold);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

.spinner-large {
  width: 40px;
  height: 40px;
  border-width: 3px;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

.btn-loading {
  position: relative;
  color: transparent !important;
  pointer-events: none;
}

.btn-loading::after {
  content: "";
  position: absolute;
  width: 16px;
  height: 16px;
  top: 50%;
  left: 50%;
  margin-left: -8px;
  margin-top: -8px;
  border: 2px solid rgba(255, 255, 255, .3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
}

/* Skeleton Loading */
.skeleton {
  background: linear-gradient(90deg,
      rgba(11, 11, 15, .08) 25%,
      rgba(11, 11, 15, .14) 50%,
      rgba(11, 11, 15, .08) 75%);
  background-size: 200% 100%;
  animation: skeleton-loading 1.5s ease-in-out infinite;
  border-radius: 8px;
}

html.dark .skeleton {
  background: linear-gradient(90deg,
      rgba(255, 255, 255, .04) 25%,
      rgba(255, 255, 255, .08) 50%,
      rgba(255, 255, 255, .04) 75%);
  background-size: 200% 100%;
}

@keyframes skeleton-loading {
  0% {
    background-position: 200% 0;
  }

  100% {
    background-position: -200% 0;
  }
}

.skeleton-text {
  height: 1em;
  margin-bottom: 0.5em;
}

.skeleton-title {
  height: 2em;
  width: 60%;
  margin-bottom: 1em;
}

.skeleton-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
}

/* Fade transitions */
.fade-in {
  animation: fadeIn 0.3s ease-in;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

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

/* =========================================================
   Cookie Banner
   ========================================================= */
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--surface);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-top: 1px solid var(--border);
  box-shadow: 0 -8px 32px rgba(0, 0, 0, .12);
  padding: 20px;
  z-index: 9999;
}

.cookie-banner-content {
  max-width: 800px;
  margin: 0 auto;
}

@keyframes slideUp {
  from {
    transform: translateY(100%);
    opacity: 0;
  }

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

@keyframes slideDown {
  from {
    transform: translateY(0);
    opacity: 1;
  }

  to {
    transform: translateY(100%);
    opacity: 0;
  }
}

/* =========================================================
   Back to Top Button
   ========================================================= */
.back-to-top {
  position: fixed;
  bottom: 30px;
  right: 30px;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--gold);
  color: #fff;
  border: none;
  cursor: pointer;
  z-index: 9998;
  display: none;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(201, 162, 39, .3);
  transition: all 0.3s ease;
  opacity: 0;
  transform: translateY(20px);
}

.back-to-top.visible {
  opacity: 1;
  transform: translateY(0);
}

.back-to-top:hover {
  background: var(--gold-2);
  transform: translateY(-4px);
  box-shadow: 0 6px 24px rgba(201, 162, 39, .4);
}

.back-to-top:active {
  transform: translateY(-2px);
}

@media (max-width: 768px) {
  .back-to-top {
    width: 42px;
    height: 42px;
    bottom: 20px;
    right: 20px;
  }
}

/* =========================================================
   Responsive tuning (Glow + layout)
   ========================================================= */
@media (max-width: 992px) {
  :root {
    --glow1-w: 760px;
    --glow1-h: 520px;
    --glow2-w: 980px;
    --glow2-h: 720px;
    --glow3-w: 1120px;
    --glow3-h: 860px;
  }
}

@media (max-width: 700px) {
  .badge-hide-mobile {
    display: none !important;
  }
}

@media (max-width: 576px) {
  :root {
    --glow1-w: 560px;
    --glow1-h: 420px;
    --glow2-w: 760px;
    --glow2-h: 560px;
    --glow3-w: 920px;
    --glow3-h: 720px;
    --glow-y: 30%;
    --glow-y2: 42%;
  }

  .bg-starfield::before {
    opacity: .82;
  }

  .bg-starfield::after {
    opacity: .10;
  }

  .container {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .card {
    border-radius: 16px !important;
  }

  .card .card-body {
    padding: 1.25rem !important;
  }

  .btn {
    padding: .62rem 1.05rem;
  }

  .navbar .container {
    padding-top: .35rem;
    padding-bottom: .35rem;
  }
}

/* =========================================================
   Aktionen – Lux Kachel + Lux Buttons (matches HTML: btn-lux)
   ========================================================= */
.card-elevated {
  background: linear-gradient(180deg, rgba(11, 11, 15, .04), rgba(11, 11, 15, .02)) !important;
  border: 1px solid var(--border) !important;
  border-radius: 18px !important;
  box-shadow: var(--shadow-sm) !important;
}

html.dark .card-elevated {
  background: linear-gradient(180deg, rgba(255, 255, 255, .05), rgba(255, 255, 255, .02)) !important;
  border-color: rgba(243, 243, 246, .14) !important;
  box-shadow: var(--shadow-sm) !important;
}

.section-label {
  font-size: .72rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
}

/* Anchor-safe Lux Button */
a.btn.btn-lux,
a.btn.btn-lux:visited {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;

  padding: .58rem 1.10rem !important;
  border-radius: 14px !important;
  font-size: .86rem !important;
  font-weight: 650 !important;
  letter-spacing: .02em;

  text-decoration: none !important;
  cursor: pointer;

  color: var(--text) !important;
  background: linear-gradient(135deg, rgba(11, 11, 15, .06), rgba(11, 11, 15, .02)) !important;
  border: 1px solid rgba(11, 11, 15, .18) !important;

  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .18),
    0 10px 22px rgba(0, 0, 0, .06);

  transition:
    transform 140ms ease,
    box-shadow 220ms ease,
    background-color 220ms ease,
    border-color 180ms ease,
    color 180ms ease;
}

html.dark a.btn.btn-lux,
html.dark a.btn.btn-lux:visited {
  color: rgba(243, 243, 246, .92) !important;
  background: linear-gradient(135deg, rgba(255, 255, 255, .06), rgba(255, 255, 255, .02)) !important;
  border-color: rgba(243, 243, 246, .14) !important;

  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .08),
    0 14px 34px rgba(0, 0, 0, .30);
}

a.btn.btn-lux:hover,
a.btn.btn-lux:focus-visible {
  text-decoration: none !important;

  transform: translateY(-1px);
  background: linear-gradient(135deg, rgba(201, 162, 39, .18), rgba(11, 11, 15, .02)) !important;
  border-color: rgba(201, 162, 39, .40) !important;

  box-shadow:
    0 16px 38px rgba(0, 0, 0, .10),
    0 10px 26px var(--gold-glow),
    inset 0 0 0 1px rgba(255, 255, 255, .18);
}

html.dark a.btn.btn-lux:hover,
html.dark a.btn.btn-lux:focus-visible {
  box-shadow:
    0 18px 44px rgba(0, 0, 0, .40),
    0 10px 26px rgba(201, 162, 39, .18),
    inset 0 0 0 1px rgba(255, 255, 255, .10);
}

a.btn.btn-lux:active {
  transform: translateY(0);
}

/* Accent button (Zahlung) */
a.btn.btn-lux.btn-lux-accent,
a.btn.btn-lux.btn-lux-accent:visited {
  background: linear-gradient(180deg, var(--gold-2), var(--gold)) !important;
  border-color: rgba(0, 0, 0, .14) !important;
  color: #0b0b0f !important;
  box-shadow: 0 14px 34px var(--gold-glow);
}

a.btn.btn-lux.btn-lux-accent:hover,
a.btn.btn-lux.btn-lux-accent:focus-visible {
  filter: brightness(1.02);
  box-shadow: 0 16px 40px var(--gold-glow);
}

/* =========================================================
   Soft Outline Buttons – Light Mode
   Text = Gold, Background = subtle highlight
   ========================================================= */
html:not(.dark) .btn.btn-outline-secondary.btn-soft:hover,
html:not(.dark) .btn.btn-outline-secondary.btn-soft:focus-visible {
  background: rgba(201, 162, 39, .10) !important;
  /* leichtes Highlight */
  border-color: var(--gold) !important;
  color: var(--gold) !important;
  /* Text 100% Gold */
  text-decoration: none !important;

  box-shadow:
    0 10px 24px rgba(201, 162, 39, .22),
    inset 0 0 0 1px rgba(201, 162, 39, .25);

  transform: translateY(-1px);
}

/* Active – minimal dunkler */
html:not(.dark) .btn.btn-outline-secondary.btn-soft:active {
  background: rgba(201, 162, 39, .18) !important;
  border-color: var(--gold-3) !important;
  color: var(--gold-3) !important;

  box-shadow:
    0 6px 14px rgba(201, 162, 39, .18);
}

/* =========================================================
   Soft Outline Buttons – Dark Mode (unchanged, elegant)
   ========================================================= */
html.dark .btn.btn-outline-secondary.btn-soft:hover,
html.dark .btn.btn-outline-secondary.btn-soft:focus-visible {
  background: rgba(201, 162, 39, .12) !important;
  border-color: rgba(201, 162, 39, .70) !important;
  color: rgba(243, 243, 246, .98) !important;

  box-shadow:
    0 14px 32px rgba(0, 0, 0, .35);
}

/* =========================================================
   Inline Editing
   ========================================================= */
.companion-name-cell {
  position: relative;
  display: inline-block;
}

.companion-name-display {
  display: inline-block;
}

.edit-companion-btn {
  color: var(--muted);
  transition: color 150ms ease, opacity 150ms ease;
  opacity: 0.7;
  cursor: pointer;
  border: none;
  background: none;
  padding: 0 !important;
}

.edit-companion-btn:hover {
  color: var(--text);
  opacity: 1;
}

.companion-edit-form {
  gap: 0.5rem !important;
  align-items: center;
}

.companion-edit-form input.form-control {
  min-width: 150px;
}

/* Password editing */
.password-cell {
  position: relative;
  display: inline-block;
}

.password-display {
  display: inline-block;
}

.edit-password-btn {
  color: var(--muted);
  transition: color 150ms ease, opacity 150ms ease;
  opacity: 0.7;
  cursor: pointer;
  border: none;
  background: none;
  padding: 0 !important;
}

.edit-password-btn:hover {
  color: var(--text);
  opacity: 1;
}

.password-edit-form {
  gap: 0.5rem !important;
  align-items: center;
}

.password-edit-form input.form-control {
  min-width: 150px;
}

/* =========================================================
   Modals
   ========================================================= */
/* Ensure modals can overlay page content properly */
.page-content {
  z-index: auto;
}

.modal {
  z-index: 1060 !important;
  pointer-events: auto !important;
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  display: flex !important;
}

.modal.fade {
  transition: opacity 0.15s linear;
  pointer-events: auto !important;
}

.modal.show {
  display: flex !important;
  z-index: 1060 !important;
  pointer-events: auto !important;
}

.modal-backdrop {
  z-index: 1059 !important;
  background-color: rgba(11, 11, 15, 0.5) !important;
  pointer-events: none !important;
}

.modal-backdrop.fade {
  opacity: 0;
  transition: opacity 0.15s linear;
  pointer-events: none !important;
}

.modal-backdrop.show {
  opacity: 1;
  pointer-events: none !important;
}

.modal-dialog {
  pointer-events: auto !important;
  z-index: 1060 !important;
}

.modal-content {
  background: var(--surface) !important;
  color: var(--text) !important;
  border: 1px solid var(--border) !important;
  border-radius: 18px;
  box-shadow: var(--shadow);
  pointer-events: auto !important;
}

.modal-header {
  background: var(--surface-2);
  border-bottom: 1px solid var(--border) !important;
  border-radius: 18px 18px 0 0;
  padding: 1.5rem;
  pointer-events: auto !important;
}

.modal-header .modal-title {
  color: var(--text);
  font-weight: 500;
  pointer-events: auto !important;
}

.modal-header .btn-close {
  filter: invert(0);
  opacity: 0.7;
  background-color: transparent;
  pointer-events: auto !important;
}

.modal-header .btn-close:hover,
.modal-header .btn-close:focus {
  opacity: 1;
  background-color: transparent;
  pointer-events: auto !important;
}

.modal-body {
  color: var(--text);
  padding: 1.5rem;
  pointer-events: auto !important;
}

.modal-body .form-label {
  color: var(--text);
  font-weight: 500;
  margin-bottom: 0.5rem;
  pointer-events: auto !important;
}

.modal-body .form-control {
  background: var(--surface);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 0.55rem 0.75rem;
  pointer-events: auto !important;
}

.modal-body .form-control:focus {
  background: var(--surface);
  color: var(--text);
  border-color: var(--primary);
  box-shadow: var(--focus);
  outline: none;
  pointer-events: auto !important;
}

.modal-body .form-control::placeholder {
  color: var(--muted);
}

.modal-footer {
  border-top: 1px solid var(--border) !important;
  background: transparent;
  padding: 1.5rem;
  gap: 0.5rem;
  pointer-events: auto !important;
}

.modal-footer .btn {
  pointer-events: auto !important;
}

/* Dark mode modals */
html.dark .modal-content {
  background: var(--surface) !important;
  color: var(--text) !important;
  border-color: var(--border) !important;
}

html.dark .modal-header {
  background: var(--surface-2);
  border-bottom-color: var(--border) !important;
}

html.dark .modal-header .btn-close {
  filter: brightness(0) invert(1);
  opacity: 0.7;
}

html.dark .modal-header .btn-close:hover,
html.dark .modal-header .btn-close:focus {
  opacity: 1;
}

html.dark .modal-body .form-control {
  background: rgba(10, 10, 14, .55);
  color: rgba(243, 243, 246, .92);
  border-color: rgba(255, 255, 255, .14);
}

html.dark .modal-body .form-control:focus {
  background: rgba(10, 10, 14, .55);
  color: rgba(243, 243, 246, .92);
  border-color: var(--primary);
  box-shadow: var(--focus);
}

html.dark .modal-body .form-control::placeholder {
  color: rgba(243, 243, 246, .45);
}

html.dark .modal-backdrop {
  background-color: rgba(0, 0, 0, 0.6);
}

/* Remove any overflow hidden from parent containers for modals */
body.modal-open {
  overflow: hidden;
}

/* Base: stacks/wraps naturally */
.footer-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: .25rem .75rem;
}

.footer-copy {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  order: 1;
  flex: 0 0 auto;
}

.footer-links {
  order: 2;
  width: 100%;
  min-width: 0;

  display: grid;
  gap: .35rem;
  grid-template-columns: repeat(auto-fit, minmax(8.5rem, 1fr));
}

.footer-links a {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: .25rem .45rem;
  white-space: nowrap;
  border-radius: 10px;
  text-decoration: none;
}

/* Force single row (copyright + links) once wide enough */
@media (min-width: 990px) {
  footer .container {
    justify-content: space-between !important;
    align-items: center !important;
  }

  .footer-inner {
    flex-wrap: nowrap;
    /* prevents links from dropping below */
  }

  footer .text-muted.d-flex {
    justify-content: flex-start;
  }

  .footer-links {
    width: auto;
    /* no longer full-width */
    display: flex;
    /* single row */
    flex-wrap: nowrap;
    justify-content: flex-end;
    gap: .6rem;
    /* smaller horizontal spacing */
  }

  .footer-links a {
    padding: .2rem .4rem;
    /* tighter in one-line mode */
  }
}