.elementor-12505 .elementor-element.elementor-element-25c7ade{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-12505 .elementor-element.elementor-element-9dc222b > .elementor-widget-container{margin:50px 0px 0px 0px;}.elementor-widget .tippy-tooltip .tippy-content{text-align:center;}/* Start custom CSS for html, class: .elementor-element-9dc222b */@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;700&display=swap');



#pointsstore-content .completion-badge { 
  display: none !important;
  /* Alte Styles auskommentiert für später:
  position: absolute; 
  top: 15px; 
  right: 15px; 
  font-size: 24px; 
  color: #14b8a6; 
  filter: drop-shadow(0 0 10px rgba(20, 184, 166, 0.6)); 
  */
} 

#pointsstore-content .completion-badge.incomplete { 
  display: none !important;
  /* Alte Styles auskommentiert für später:
  color: #444; 
  opacity: 0.3; 
  filter: none; 
  */
}

#pointsstore-content .completion-badge.complete {
  display: none !important;
  /* Alte Styles auskommentiert für später:
  color: #14b8a6 !important;
  opacity: 1 !important;
  filter: drop-shadow(0 0 10px rgba(20, 184, 166, 0.6)) !important;
  */
}

/* ===== CUSTOM CSS - NUR FÜR COURSES TAB ===== */

/* WICHTIG: Grid Layout für den Container */
#courses-content .mpcs-cards {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  gap: 24px !important;
  margin: 0 auto !important;
  padding: 20px !important;
  max-width: 1200px !important;
}

/* Card Wrapper für Grid Layout */
#courses-content .mpcs-card-wrapper {
  flex: 0 0 calc(50% - 12px) !important;
  min-width: 350px !important;
  max-width: 550px !important;
  margin: 0 !important;
}

/* Einzelne Card */
#courses-content .mpcs-card {
  position: relative !important;
  display: block !important;  /* <-- !important hinzufügen */
  width: 100% !important;
  height: 360px !important;
  background: transparent !important;
  border: 1.5px solid rgba(255,255,255,0.13) !important;
  border-radius: 22px !important;
  box-shadow: 0 10px 38px 0 rgba(19,231,196,0.13), 0 2px 32px 0 #13171f33 !important;
  overflow: hidden !important;
  margin: 0 !important;
  padding: 0 !important;
  transition: box-shadow 0.16s, transform 0.16s !important;
}ition: box-shadow 0.16s, transform 0.16s;
}

#courses-content .mpcs-card:hover {
  box-shadow: 0 20px 44px 0 rgba(19,231,196,0.19), 0 2px 36px 0 #13e7c477;
  transform: translateY(-2px) scale(1.018);
}

#courses-content .mpcs-card-thumb {
  position: absolute;
  inset: 0;
  width: 100%; 
  height: 100%;
  z-index: 1;
  margin: 0; 
  padding: 0;
  display: flex; 
  align-items: stretch; 
  justify-content: stretch;
  background: none !important;
}

#courses-content .mpcs-card-thumb img {
  width: 100%; 
  height: 100%;
  object-fit: cover;
  object-position: center;
  border-radius: 0;
  box-shadow: none;
  display: block;
}

#courses-content .mpcs-card-title {
  position: absolute;
  left: 0; 
  right: 0; 
  bottom: 0;
  margin: 0 !important;
  padding: 0.7rem 0 !important;
  font-size: 1.07rem !important;
  color: #fff !important;
  font-family: 'Space Grotesk',sans-serif !important;
  font-weight: 600 !important;
  letter-spacing: 0.01em;
  text-align: center !important;
  background: rgba(20,24,26,0.74);
  box-shadow: 0 8px 32px 0 rgba(20,24,26,0.26);
  border-radius: 0 0 16px 16px;
  backdrop-filter: blur(22px) saturate(140%);
  -webkit-backdrop-filter: blur(22px) saturate(140%);
  border-top: 1.2px solid rgba(255,255,255,0.10);
  z-index: 2;
  text-shadow: 0 2px 8px #000c, 0 1px 2px #000b;
  transition: backdrop-filter 0.18s, background 0.18s;
  display: flex;
  align-items: center;
  justify-content: center;
}

#courses-content .mpcs-card-title a,
#courses-content .mpcs-card-title span,
#courses-content .mpcs-card-title strong {
  color: #fff !important;
  text-align: center !important;
  margin: 0 auto !important;
  display: inline-block !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  font-family: inherit !important;
  letter-spacing: inherit !important;
  text-shadow: inherit !important;
  box-shadow: none !important;
  background: none !important;
}

#courses-content .mpcs-card-content,
#courses-content .mpcs-card-footer { 
  display: none !important; 
}

#courses-content .mpcs-card-link {
  color: #fff !important;
  font-size: 1.07em !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  letter-spacing: 0.01em;
  margin: 1.1rem 0 0.3rem 0 !important;
  display: inline-block;
  transition: color 0.13s;
  position: relative;
  z-index: 3;
  text-align: center;
}

#courses-content .mpcs-card-link:hover { 
  text-decoration: underline !important; 
  color: #4fd1c5 !important; 
}

/* Responsive */
@media (max-width: 900px) {
  #courses-content .mpcs-card-wrapper {
    flex: 0 0 100% !important;
    max-width: 500px !important;
  }
  #courses-content .mpcs-card {
    height: 320px !important;
  }
}

@media (max-width: 600px) {
  #courses-content .mpcs-cards {
    padding: 10px !important;
    gap: 16px !important;
  }
  #courses-content .mpcs-card-wrapper {
    min-width: 280px !important;
  }
  #courses-content .mpcs-card-title { 
    font-size: 0.95rem !important; 
    padding: 0.6rem 0 !important; 
  }
  #courses-content .mpcs-card { 
    border-radius: 12px; 
    height: 280px !important;
  }
}


/* --- Account Nav, Form, Container Styles (aus deiner Basis, leicht bereinigt) --- */
#custom-account-nav, .custom-card-look {
  max-width: 1240px !important; margin: 0 auto !important;
  background: #141619 !important;
}
.custom-card-look { width: 100% !important; box-sizing: border-box; }
#tab-data .mepr-account-form {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem 2rem; align-items: start; margin-top: 1rem;
}
#tab-data .mepr-account-form label {
  font-weight: 600; font-size: 0.95em; color: #b6bbc6; margin-bottom: 0.25rem;
}
#tab-data .mepr-account-form input,
#tab-data .mepr-account-form select,
#tab-data .mepr-account-form textarea {
  width: 100%; padding: 0.5rem 0.75rem; border-radius: 6px;
  border: 1px solid #333; background: #181A1D !important; color: #fff;
  font-size: 0.95em; box-sizing: border-box;
}
#tab-data .mepr-account-form input:focus,
#tab-data .mepr-account-form select:focus,
#tab-data .mepr-account-form textarea:focus {
  border-color: #4FD1C5 !important;
  box-shadow: 0 0 6px rgba(79,209,197,0.35) !important;
  outline: none;
}
#tab-data .mepr-account-form .mepr-submit {
  grid-column: 1 / -1; justify-self: start;
  background: #4FD1C5 !important; border: none;
  padding: 0.75rem 1.5rem; border-radius: 999px;
  font-weight: 700; font-size: 1em; cursor: pointer;
  color: #222 !important; transition: background 0.2s;
}
#tab-data .mepr-account-form .mepr-submit:hover {
  background: #3bb6ac !important; color: #fff !important;
}

/* --- Nav Buttons --- */
.custom-nav-btn {
  padding: 0.58em 2em; border-radius: 999px;
  background: #23262e !important; color: #4FD1C5 !important;
  font-weight: 700; font-family: 'Space Grotesk', sans-serif !important;
  text-decoration: none; font-size: 1.08em; border: none;
  display: flex; align-items: center; gap: 12px;
  box-shadow: 0 2px 24px 0 #181c245a;
  transition: background 0.15s, color 0.15s, box-shadow 0.18s;
  cursor: pointer; position: relative; z-index: 1;
}
.custom-nav-btn.active {
  background: #16191f !important; color: #fff !important;
  box-shadow: 0 0 0 4px #4FD1C555 !important;
}
.custom-nav-btn:focus { outline: 2px solid #4FD1C5 !important; }
.custom-nav-btn:hover:not(.active) { background: #292c33 !important; color: #fff !important; }

/* --- Optional: Switch (notification toggle) --- */
.notif-switch-container {
  display: inline-block; position: relative; width: 46px; height: 26px; cursor: pointer;
}
.notif-switch-container .notif-switch { opacity: 0; width: 0; height: 0; position: absolute; }
.notif-switch-container .slider {
  position: absolute; top: 0; left: 0; right: 0; bottom: 0;
  background: #ddd; border-radius: 999px; transition: background 0.18s;
}
.notif-switch-container .slider::before {
  content: ""; position: absolute; height: 20px; width: 20px;
  left: 3px; bottom: 3px; background: #fff; border-radius: 50%; transition: transform 0.18s;
}
.notif-switch-container .notif-switch:checked + .slider {
  background: linear-gradient(90deg, #13e7c4 40%, #4fd1c5 100%);
}
.notif-switch-container .notif-switch:checked + .slider::before {
  transform: translateX(20px);
}

.settings-cog-btn {
  display: none !important;
}



/* ===== Tooltip & Disabled-Card Styling ===== */
.settings-card.disabled {
  position: relative;    /* für das absolute Tooltip */
  opacity: 0.5;          /* ausgegraut */
  cursor: not-allowed;   /* Maus-Cursor */
  /* NICHT pointer-events: none; – so kommen Hover-Events an */
}

/* Switch selbst bleibt nicht klickbar */
.settings-card.disabled .notif-switch {
  cursor: not-allowed;
}

/* Desktop-Hover-Tooltip */
.settings-card.disabled[title]:hover::after {
  content: attr(title);
  position: absolute;
  top: -2.2em;
  left: 0.5em;
  background: rgba(0,0,0,0.8);
  color: #fff;
  padding: 4px 8px;
  border-radius: 4px;
  white-space: nowrap;
  font-size: 0.85em;
  pointer-events: none;
  z-index: 10;
}

/* Mobile-/Click-Tooltip (fade in/out) */
@keyframes fade-in-out {
  0%, 100% { opacity: 0; }
  10%, 90% { opacity: 1; }
}
.custom-disabled-tooltip {
  position: absolute;
  top: 0.5em;
  right: 0.5em;
  background: rgba(0,0,0,0.8);
  color: #fff;
  padding: 4px 8px;
  border-radius: 4px;
  font-size: 0.85em;
  pointer-events: none;
  animation: fade-in-out 1.8s ease forwards;
}



@media (max-width: 700px) {
  #tab-affiliate,
  #tab-affiliate * {
    font-size: 0.95em !important;
    /* Optional weniger Zeilenabstand und Padding */
    line-height: 1.2 !important;
  }
  #tab-affiliate h1, 
  #tab-affiliate h2, 
  #tab-affiliate h3 {
    font-size: 1.08em !important;
    margin-bottom: 0.55em !important;
  }
  #tab-affiliate .btn,
  #tab-affiliate button,
  #tab-affiliate input {
    font-size: 0.92em !important;
    padding: 6px 13px !important;
  }
  #tab-affiliate .affiliate-dashboard,
  #tab-affiliate .custom-card-look {
    padding: 9px 3px !important;
  }
}




/* Desktop versteckt mobile Tabs */
@media (min-width: 701px) {
  #mobile-tab-container { display: none; }
}

/* Desktop versteckt mobile Tabs */
@media (min-width: 701px) {
  #mobile-tab-container {
    display: none;
  }
}

/* Mobile zeigt nur mobile Tabs, versteckt Desktop-Nav */
@media (max-width: 700px) {
  /* Desktop-Navigation ausblenden */
  #custom-account-nav {
    display: none !important;
  }

  /* echtes Label ausblenden */
  #mobile-tab-active-label {
    display: none;
  }
  /* statisches Pseudo-Label vor dem Chevron einfügen */
  #mobile-tab-active-btn::before {
    content: "Funktionsübersicht";
    font-family: 'Space Grotesk', sans-serif;
    font-size: 1em;
    color: #b8c4dc;
    margin-right: 0.5rem;
  }

  #mobile-tab-container {
    display: block;
    width: 100%;
    margin-bottom: 1rem;
  }
  .mobile-tab-button {
    width: 100%;
    background: #262b38;
    color: #b8c4dc;
    padding: 0.75rem 1rem;
    border: none;
    border-radius: 8px;
    text-align: left;
    font-size: 1em;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .mobile-tab-sheet {
    display: none;
    flex-direction: column;
    margin-top: 0.5rem;
    gap: 0.5rem;
  }
  .mobile-tab-sheet .custom-nav-btn {
    width: 100%;
    justify-content: flex-start;
    padding: 0.6rem 1rem;
    font-size: 0.95em;
    border-radius: 6px;
  }
  .mobile-tab-sheet .custom-nav-btn:hover {
    background: #32384c;
  }
}

/* ============ MINI-NAVIGATION (Downloads/Guides/...) ============ */
.downloads-sidebar {
  display: flex;
  flex-direction: column;
  gap: 13px;
  margin-top: 36px;
  margin-bottom: 34px;
  min-width: 172px;
  max-width: 200px;
}
.downloads-sidebar-btn {
  background: none;
  border: 2px solid #3bb6ac;
  color: #4FD1C5;
  font: 700 1.09em 'Space Grotesk', sans-serif;
  padding: 0.65em 0.8em;
  border-radius: 10px;
  cursor: pointer;
  text-align: left;
  transition: background 0.14s, color 0.14s, border 0.15s;
  outline: none;
}
.downloads-sidebar-btn:hover,
.downloads-sidebar-btn.active {
  background: #13e7c4;
  color: #1b2d36;
  border-color: #13e7c4;
}
@media (max-width: 1000px) {
  .downloads-sidebar {
    min-width: 0;
    flex-direction: row;
    gap: 7px;
    margin: 14px 0 18px 0;
    justify-content: center;
    align-items: stretch;
    max-width: 100%;
  }
  .downloads-sidebar-btn {
    padding: 0.58em 0.7em;
    font-size: 1em;
    min-width: 96px;
    text-align: center;
  }
}

/* ============= DOWNLOADS GRID: DESKTOP ============= */
.downloads-content {
  flex: 1;
  width: 100%;
}
.downloads-grid {
  display: flex;
  justify-content: flex-start;
  gap: 27px;
  margin: 0 0 15px 0;
  flex-wrap: wrap;
}
.downloads-card {
  background: rgba(28,34,40,0.92);
  border-radius: 14px;
  padding: 20px 16px 12px 16px;
  box-shadow: 0 4px 24px #1be7c420, 0 1.5px 10px #13e7c420;
  text-align: center;
  width: 220px;
  max-width: 95vw;
  display: flex;
  flex-direction: column;
  align-items: center;
  transition: box-shadow 0.16s, transform 0.14s;
  cursor: pointer;
  border: 1.5px solid transparent;
  position: relative;
}
.downloads-card:hover {
  box-shadow: 0 8px 28px #13e7c440, 0 6px 28px #232c3650;
  border: 1.5px solid #13e7c4;
  transform: translateY(-2px) scale(1.025);
}
.downloads-card img {
  width: 150px;
  height: 150px;
  object-fit: contain;
  margin-bottom: 14px;
  background: none;
  border-radius: 9px;
  box-shadow: 0 2px 18px #13e7c430;
  display: block;
  transition: transform 0.15s;
}
.downloads-card:hover img {
  transform: scale(1.06) rotate(-2deg);
}
.downloads-title {
  font: 700 1.05em 'Space Grotesk', sans-serif;
  color: #fff;
  letter-spacing: 0.01em;
  margin-top: 0;
  margin-bottom: 0;
  line-height: 1.18;
  text-shadow: 0 2px 10px #0e223580;
  white-space: normal;
  word-break: break-word;
}
.downloads-hint {
  margin: 24px auto 0;
  padding: 0.7em 1.1em;
  max-width: 780px;
  background: rgba(24,29,34,0.8);
  color: #b8c4dc;
  border-radius: 8px;
  text-align: center;
  font-size: 1em;
}

/* ============= MOBILE: MINI NAV & DOWNLOADS ============= */
@media (max-width: 700px) {
  /* Mini-NAV: unter der Hauptnavigation, nebeneinander */
  .downloads-sidebar {
    flex-direction: row !important;
    justify-content: space-between;
    align-items: stretch;
    margin: 0 0 16px 0;
    gap: 6px;
    width: 100%;
    max-width: 100%;
  }
  .downloads-sidebar-btn {
    flex: 1 1 0;
    min-width: 0;
    font-size: 0.97em;
    padding: 0.6em 0.4em;
    border-radius: 8px;
    text-align: center;
  }

  /* Downloads Grid: 2x2, kompakt & schick */
  .downloads-grid {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 12px 7px !important;
    justify-content: space-between !important;
    width: 100%;
    margin: 0 0 5px 0;
  }
  .downloads-card {
    width: 48%;
    min-width: 0;
    max-width: 100%;
    padding: 12px 7px 9px 7px;
    margin-bottom: 0;
    border-radius: 9px;
  }
  .downloads-card img {
    width: 192px !important;
    height: 192px !important;
    margin-bottom: 6px !important;
    border-radius: 7px !important;
    box-shadow: 0 1.5px 12px #13e7c425 !important;
  }
  .downloads-title {
    font-size: 0.73em !important;
    font-weight: 600 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    white-space: normal !important;
    word-break: break-word !important;
  }
  .downloads-hint {
    font-size: 0.84em !important;
    padding: 0.55em 0.5em !important;
    margin-top: 11px !important;
    border-radius: 6px !important;
  }
}

/* ============= Downloads-Menü rechts neben Einstellungen ============= */
@media (min-width: 701px) {
  #custom-account-nav {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: flex-start;
    align-items: center;
    gap: 0;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .custom-nav-btn {
    margin-right: 14px !important;
    min-width: 0 !important;
    white-space: nowrap !important;
    font-size: 1em !important;
    padding: 0.44em 1.18em !important;
    height: 38px !important;
    border-radius: 999px !important;
  }
  .custom-nav-btn:last-child { margin-right: 0 !important; }
}

/* --- Mini-Menü nebeneinander auf Desktop --- */
@media (min-width: 701px) {
  .downloads-sidebar {
    flex-direction: row;
    gap: 18px;
    justify-content: flex-start;
    align-items: stretch;
    min-width: 0;
    margin-bottom: 26px;
  }
  .downloads-sidebar-btn {
    min-width: 180px;
    flex: 0 1 auto;
    text-align: center;
    margin-bottom: 0;
  }
}

/* Grundzustand */
.downloads-toast {
  position: fixed !important;
  left: 50% !important;
  bottom: 38px !important;
  transform: translateX(-50%) !important;
  background: #232a2c !important;
  color: #fff !important;
  border-radius: 10px !important;
  padding: 13px 36px !important;
  min-width: 160px !important;
  max-width: 96vw !important;
  text-align: center !important;
  font-weight: 600 !important;
  font-size: 1.07em !important;
  box-shadow: 0 2px 16px #13e7c440 !important;
  opacity: 0 !important;
  pointer-events: none !important;
  display: block !important;      /* sicherstellen, dass es block-level ist */
  transition: opacity .38s, transform .26s !important;
  z-index: 2900 !important;
}

/* Wenn die Klasse .show hinzugefügt wird */
.downloads-toast.show {
  opacity: 1 !important;
  pointer-events: auto !important;
  transform: translateX(-50%) scale(1.05) !important;
}

/* === Material / Guides: Icons deutlich größer machen === */
#downloads-tab-material .downloads-card img {
  width: 300px !important;
  height: auto !important;
}

/* === Richtlinien / Dokumente: Icons kleiner halten === */
#downloads-tab-richtlinien .downloads-card img {
  width: 80px !important;
  height: auto !important;
}


/* hide the entire TikTok-username row (including label & error) */
div.mp-form-row.mepr_custom_field.mepr_mepr_tiktok_benutzername {
  display: none !important;
}

/* hide the Instagram-username input */
input#mepr_instagram_benutzername {
  display: none !important;
}

/* hide the Instagram-username label */
label[for="mepr_instagram_benutzername"] {
  display: none !important;
}

/* — OPTIONAL: if the Instagram field is wrapped in a similar row container, you can hide it all at once: */

div.mp-form-row.mepr_custom_field.mepr_mepr_instagram_benutzername {
  display: none !important;
}

.mepr_updated {
  background-color: rgba(0, 128, 128, 0.1) !important;  // translucent teal
  color: #004d4d !important;                          // darker teal text
  border-left: 4px solid #008080;                     // bold left accent
  padding: 0.75em 1em;
  border-radius: 0 4px 4px 0;                         // pill-style on right
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);            // soft drop-shadow
}





/* Nur „Neues Passwort“ & „Passwort bestätigen“ */
#mepr-new-password,
#mepr-confirm-password {
  color: #fff !important;               /* Text schwarz */
  background-color: #181A1D !important;    /* Hintergrund weiß */
}

/* Falls du auch den Placeholder-Ton anpassen willst: */
#mepr-new-password::placeholder,
#mepr-confirm-password::placeholder {
  color: #000 !important;
}







/* Affiliate-Shortcode in Container zwingen */
.affiliate-wrapper {
  width: 100%; /* Vollbreite im Container */
  max-width: 100%; /* Kein Überlaufen */
  overflow-x: auto; /* Horizontal scrollen, falls zu breit */
  box-sizing: border-box; /* Padding/Margin einbeziehen */
  padding: 1rem; /* Etwas Luft */
  background: var(--card-bg); /* Passend zum Theme */
  border-radius: 12px;
  border: 1px solid var(--border-subtle);
}
/* Tabellen responsiv machen (falls der Shortcode Tabellen rendert) */
.affiliate-wrapper table {
  width: 100%;
  table-layout: auto; /* Auto-Anpassung */
  border-collapse: collapse;
}
.affiliate-wrapper th, .affiliate-wrapper td {
  padding: 0.75rem;
  word-break: break-word; /* Lange Wörter umbrechen */
}
/* Mobile: Noch mehr Anpassung */
@media (max-width: 768px) {
  .affiliate-wrapper {
    padding: 0.5rem;
  }
  .affiliate-wrapper table {
    display: block; /* Tabellen als Block für Mobile */
    overflow-x: auto;
  }
}





/* === Overlay: wirklich Fullscreen & klarer Blur === */
.modal-backdrop-custom,
.settings-modal-backdrop {
  position: fixed !important;
  inset: 0 !important;                 /* statt width/height */
  width: auto !important;
  height: auto !important;
  background: rgba(10,11,13,0.55) !important;
  backdrop-filter: blur(12px) saturate(110%) !important;
  -webkit-backdrop-filter: blur(12px) saturate(110%) !important;
  z-index: 30000 !important;           /* über allem */
}

/* === Modal: verlässliche Größe + internes Scrollen === */
.modal-custom,
.settings-modal {
  position: fixed !important;
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
  box-sizing: border-box;
  width: min(94dvw, 720px) !important;
  max-width: 96dvw !important;
  min-width: 320px;
  max-height: 88dvh !important;        /* nie zu klein/zu groß */
  grid-template-rows: auto 1fr auto;
  overflow: hidden !important;         /* Scroll nur im Body */
  padding: 18px 18px 14px 18px !important;
  border-radius: 16px !important;
  background: var(--bg-modal, #23262a) !important;
  z-index: 30010 !important;
}

/* Titelzeile fix, Close-Button klicksicher */
.modal-custom .modal-header,
.settings-modal .settings-modal-title {
  margin: 0 0 10px 0 !important;
  border-bottom: 1px solid #323339 !important;
  padding-bottom: 8px !important;
}
.modal-custom .close-x,
.settings-modal .close-x {
  z-index: 1 !important;
}

/* Der eigentliche Inhalt scrollt – keine Mini-Box mehr */
.modal-custom .modal-body,
.settings-modal .settings-section {
  overflow: auto !important;
  max-height: calc(88dvh - 120px) !important; /* Puffer für Header/Buttons */
}

/* Tooltips sicher platzieren */
.info-btn { position: relative; overflow: visible; }
.info-btn .infotext {
  right: 0; left: auto; transform: none;
  max-width: min(280px, 80vw);
}

/* Mobile Kompaktansicht */
@media (max-width: 480px) {
  .modal-custom,
  .settings-modal {
    width: 96dvw !important;
    max-height: 92dvh !important;
    padding: 14px 12px !important;
  }
  .modal-custom .modal-title { font-size: 1rem !important; }
  .modal-custom .modal-body { max-height: calc(92dvh - 110px) !important; }
}

/* Optional: Seite darf unter Overlay nicht scrollen */
body.has-open-modal {
  overflow: hidden !important;
}


/* --- OVERRIDE: Absolute-Zentrierung des Plugins neutralisieren --- */
.sc-modal .sc-modal-content{
  position: relative !important;
  top: auto !important;
  left: auto !important;
  transform: none !important;
  margin: 0 !important;
}

/* Backdrop sicher als Flex-Container rendern, immer exakt mittig */
.sc-modal{
  display: none;               /* baseline; JS setzt display:block */
  align-items: center !important;
  justify-content: center !important;
  text-align: left;            /* nur Optik */
  overflow: auto;              /* falls Inhalt höher als Viewport */
}

/* Wenn per Inline style:block → als Flex anzeigen */
.sc-modal[style*="display: block"]{
  display: flex !important;
}

/* Optionale Feinheiten – gleiche Optik wie Lead-Modal */
.sc-modal .sc-modal-content{
  width: min(94dvw, 720px);
  max-width: 96dvw;
  max-height: 88dvh;
  border-radius: 16px;
  border: 1px solid #2a2e35;
  background: #141518;
  box-shadow: 0 18px 64px rgba(0,0,0,.6);
  display: grid;
  grid-template-rows: auto 1fr auto;
}
.sc-modal .sc-modal-content > #affiliate-links{
  overflow: auto;
  max-height: calc(88dvh - 140px);
}
@media (max-width: 480px){
  .sc-modal .sc-modal-content{
    width: 96dvw;
    max-height: 92dvh;
    border-radius: 14px;
    padding: 14px 12px;
  }
  .sc-modal .sc-modal-content > #affiliate-links{
    max-height: calc(92dvh - 130px);
  }
}




/* === Affiliate Tab: kompakter Look nur innerhalb #affiliate-content === */
#affiliate-content .content-header { margin-bottom: 1.25rem; }
#affiliate-content .content-title { font-size: 1.5rem; }
#affiliate-content .content-subtitle { font-size: .95rem; }

#affiliate-content .placeholder-content { padding: 1.5rem 1rem; }

/* Shortcode-Wrapper etwas kleiner “fahren” */
#affiliate-content .affiliate-wrapper {
  font-size: 0.94rem;          /* global kleiner */
  line-height: 1.45;
}

/* Karten & UI aus dem Shortcode dezent straffen */
#affiliate-content .affiliate-card { padding: 10px 12px; gap: 14px; }
#affiliate-content .affiliate-icon { width: 28px; height: 28px; font-size: 1.05em; }
#affiliate-content .affiliate-title { font-size: 1rem; }
#affiliate-content .affiliate-url { font-size: .95rem; padding: 4px 10px; }
#affiliate-content .card-actions i { font-size: 1.2em; padding: 6px; }

/* Link-Modal-Items kompakter */
#affiliate-content .affiliate-link-item { padding: 8px 10px; }
#affiliate-content .affiliate-link-text { font-size: .95rem; }
#affiliate-content .affiliate-link-text .title { font-size: 1.02rem; }

/* Buttons unten im Links-Modal etwas kleiner */
#affiliate-content .button-container button { padding: 6px 12px; font-size: .9rem; }

/* Mobile Feinschliff */
@media (max-width: 700px){
  #affiliate-content .affiliate-wrapper { font-size: .92rem; }
  #affiliate-content .affiliate-link-text .title { font-size: .95rem; }
}

/* === Affiliate Modal: Center + größere Typo === */
.sc-modal {
  position: fixed !important;
  inset: 0 !important;
  display: none;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(10,11,13,.55) !important;
  backdrop-filter: blur(12px) saturate(110%) !important;
  -webkit-backdrop-filter: blur(12px) saturate(110%) !important;
  z-index: 30000 !important;
}
.sc-modal[style*="display: block"]{ display:flex !important; }

/* Wichtig: alte absolute-Zentrierung neutralisieren */
.sc-modal .sc-modal-content{
  position: relative !important;
  top:auto !important; left:auto !important; transform:none !important; margin:0 !important;

  /* Größe/Typo */
  width: min(94dvw, 720px);
  max-width: 96dvw;
  max-height: 88dvh;
  display: grid;
  grid-template-rows: auto 1fr auto;
  overflow: hidden;           /* Scroll nur im Body-Bereich */
  box-sizing: border-box;

  background:#141518;
  border:1px solid #2a2e35;
  border-radius:16px;
  box-shadow:0 18px 64px rgba(0,0,0,.6);

  /* größere Basis-Schrift */
  font-size: 1.03rem;
  line-height: 1.5;
  padding: 18px 16px;         /* gleichmäßigere Ränder */
}

/* Titel ein bisschen größer */
.sc-modal .sc-modal-content h2,
.sc-modal .sc-modal-content h3{
  font-size: 1.22rem;
}

/* Close-Button fixiert oben rechts */
.sc-modal .close{
  position:absolute; right:12px; top:10px; z-index:1;
}

/* Scrollbereich innerhalb des Body-Blocks */
.sc-modal .sc-modal-content > #affiliate-links{
  overflow:auto;
  max-height: calc(88dvh - 140px);
}

/* Mobile */
@media (max-width: 480px){
  .sc-modal .sc-modal-content{
    width: 96dvw; max-height: 92dvh; border-radius: 14px;
    font-size: .98rem;            /* auf Mobile ebenfalls gut lesbar */
    padding: 16px 12px;
  }
  .sc-modal .sc-modal-content h2,
  .sc-modal .sc-modal-content h3{ font-size: 1.08rem; }
  .sc-modal .sc-modal-content > #affiliate-links{
    max-height: calc(92dvh - 130px);
  }
}



/* Globaler Seiten-Toast */
#toast{
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%) translateY(20px);
  background: rgba(35,35,35,.95);
  color: #fff;
  padding: .7rem 1rem;
  border-radius: 10px;
  border: 1px solid var(--border-subtle);
  box-shadow: var(--shadow-soft);
  font-size: .95rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease;

  /* Z über allen Backdrops/Modals */
  z-index: 50000;
}
#toast.show{
  opacity:1; transform: translateX(-50%) translateY(0);
}



/* Shortcode-Toast über Affiliate-Modal heben */
.sc-modal ~ #toast,
#affiliate-links ~ #toast,
#affiliate-content #toast{
  z-index: 50001 !important;
}

.calendar-root {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    background: #141518;
    padding: 20px;
}
      .container-calendar {
        max-width: 1400px;
        margin: 0 auto;
        background: #181a1f;
        border-radius: 20px;
        box-shadow: 0 20px 40px rgba(0, 0, 0, 0.7);
        overflow: hidden;
      }

      .calendar-header-main {
        background: #181a1f;
        color: #f1f6ef;
        padding: 30px;
        text-align: center;
      }

      .calendar-header-main h1 {
        font-size: 2.5rem;
        margin-bottom: 10px;
        font-weight: 600;
        color: #f1f6ef;
      }

      .calendar-header-main p {
        font-size: 1.2rem;
        opacity: 0.9;
        color: #37bfb7;
      }

      .calendar-calendar-container {
        padding: 30px;
        background: #141518;
      }

      .calendar-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 30px;
      }

      .calendar-month-year {
        font-size: 2rem;
        font-weight: 600;
        color: #f1f6ef;
      }

      .calendar-nav-buttons {
        display: flex;
        gap: 10px;
      }

      .calendar-nav-btn {
        background: linear-gradient(135deg, #37bfb7 0%, #01eab2 100%);
        color: #101114;
        border: none;
        padding: 10px 20px;
        border-radius: 25px;
        cursor: pointer;
        font-size: 1rem;
        font-weight: 600;
        transition: all 0.3s ease;
        box-shadow: 0 2px 8px rgba(55, 191, 183, 0.15);
      }

      .calendar-nav-btn:hover {
        filter: brightness(1.2) drop-shadow(0 0 8px #01eab2);
      }

      .mobile-nav {
        display: none;
      }

      .desktop-nav {
        display: block;
      }

      .weekly-calendar {
        display: grid;
        grid-template-columns: 80px repeat(7, 1fr);
        background: #101114;
        border-radius: 15px;
        overflow: hidden;
        box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
        position: relative;
      }

      .timezone-header {
        background: #181a1f;
        color: #f1f6ef;
        padding: 15px 10px;
        text-align: center;
        font-size: 0.9rem;
        border-bottom: 1px solid #23262b;
        border-right: 1px solid #23262b;
      }

      .day-header {
        background: #181a1f;
        color: #37bfb7;
        padding: 15px 10px;
        text-align: center;
        font-weight: 600;
        font-size: 1.1rem;
        border-bottom: 1px solid #23262b;
      }

      .day-header .day-name {
        display: block;
        font-size: 0.9rem;
        margin-bottom: 5px;
      }

      .day-header .day-date {
        display: block;
        font-size: 1.3rem;
        color: #f1f6ef;
      }

      .day-header .current-day {
        background: #ffd700;
        color: #101114;
        border-radius: 50%;
        width: 30px;
        height: 30px;
        display: flex;
        align-items: center;
        justify-content: center;
        margin: 0 auto;
        margin-top: 5px;
      }

      .time-slot {
        background: #181a1f;
        border-right: 1px solid #23262b;
        border-bottom: 1px solid #23262b;
        padding: 5px;
        font-size: 0.9rem;
        color: #f1f6ef;
        text-align: center;
        min-height: 60px;
        display: flex;
        align-items: center;
        justify-content: center;
      }

      .day-cell {
        background: #181a1f;
        border-right: 1px solid #23262b;
        border-bottom: 1px solid #23262b;
        position: relative;
        min-height: 60px;
      }

      .day-cell:last-child {
        border-right: none;
      }

      .event-block {
        position: absolute;
        left: 2px;
        right: 2px;
        border-radius: 6px;
        padding: 8px;
        font-size: 0.85rem;
        color: #f1f6ef;
        cursor: pointer;
        transition: all 0.3s ease;
        overflow: hidden;
        z-index: 10;
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
      }

      .event-block:hover {
        transform: scale(1.02);
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
        z-index: 20;
      }

      .event-block.blue {
        background: #4285f4;
      }

      .event-block.orange {
        background: #ff9800;
      }

      .event-block.yellow {
        background: #ffc107;
        color: #101114;
      }

      .event-block .event-title {
        font-weight: 600;
        margin-bottom: 2px;
        white-space: normal;
        line-height: 1.2;
      }

      .event-block .event-time {
        font-size: 0.8rem;
        opacity: 0.9;
        margin-bottom: 2px;
        line-height: 1.2
      }

      .event-block .event-link {
        font-size: 0.75rem;
        opacity: 0.8;
        margin-top: 2px;
        word-break: break-all;
        white-space: normal;
        line-height: 1.1;
      }

      .current-time-line {
        position: absolute;
        left: 0;
        right: 0;
        height: 2px;
        background: #4285f4;
        z-index: 30;
        pointer-events: none;
      }

      .current-time-line::before {
        content: "";
        position: absolute;
        left: -4px;
        top: -3px;
        width: 10px;
        height: 10px;
        background: #4285f4;
        border-radius: 50%;
      }

      @media (max-width: 768px) {
        .weekly-calendar {
          grid-template-columns: 60px 1fr;
          font-size: 0.8rem;
        }

        .timezone-header {
          border-right: 1px solid #23262b;
        }

        .day-header {
          display: none;
        }

        .day-header.mobile-visible {
          display: block;
          grid-column: 2;
        }

        .day-cell {
          display: none;
          min-height: 40px;
        }

        .day-cell.mobile-visible {
          display: block;
          grid-column: 2;
        }

        .time-slot {
          min-height: 40px;
          font-size: 0.8rem;
        }

        .event-block {
          padding: 4px;
          font-size: 0.75rem;
        }

        .calendar-header-main h1 {
          font-size: 1.8rem;
        }

        .calendar-month-year {
          font-size: 1.4rem;
        }

        .calendar-nav-buttons {
          flex-direction: column;
          gap: 5px;
        }

        .calendar-nav-btn {
          font-size: 0.9rem;
          padding: 8px 16px;
        }

        .mobile-nav {
          display: block;
        }

        .desktop-nav {
          display: none;
        }
      }



.sca-roadmap-container {
  position: relative;
  width: 100%;
  height: 70vw;
  scale: 1;
  left: 0vw;
  top: 2vw;
  margin-left:20px;
}

.sca-content-title-header {
  position: absolute;
  left: 0vw;
  top: 0vw;
  color: white;
  font-size: 35px;
}

#sca-monat-1 {
  top: 15vw;
  left: 0vw;
}

#sca-monat-2 {
  top: 30.2vw;
  left: 26.2vw;
}

#sca-monat-3 {
  top: 15vw;
  left: 52.5vw;
}

.sca-roadmap-q {
  color: #fff;
  font-size: 3.5vw;
  position: absolute;
}

.sca-hexagon-container {  
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 30vw;
  height: 30vw;
  position: absolute;
}

.sca-hexagon-container:hover {
  scale: 1.1;
  z-index: 10;
  transition: 0.3s;
}

.sca-hexagon {
  width: 100%;
  height: calc(100% * 1.1547);
  position: absolute;
  background-color: #2B4552;
  transform: rotate(30deg);
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
}

.sca-trapezoid {
  width: 85%;
  height: 25%;
  background-color: black;
  margin-top: 10%;
  clip-path: polygon(0% 100%, 100% 100%, 83% 0%, 17% 0%);
} 

.sca-header-container {
  height: 40%;
  width: 100%;
  overflow: hidden;
}

.sca-hexagon-content-header {
  position: absolute;
  top: 13%;
  color: #fff;
  font-size: 2.9vw;
}

.sca-hexagon-content-body {
  position: absolute;
  top: 43%;
  text-align: center;
  color: #fff;
  font-size: 2.1vw;
  line-height: 140%
}
@media only screen and (min-width: 805px) {
.sca-hexagon-container {  
  width: 186px;
  height: 186px;
}

#sca-monat-1 {
  top: 78.7px;
  left: 154.4px;
}

#sca-monat-2 {
  top: 175.71px;
  left: 317.8px;
}

#sca-monat-3 {
  top: 78.7px;
  left:480.93px;
}

.sca-roadmap-q {
  font-size: 56px;

}
.sca-content-title-header {
    left:162.2px;
}
.sca-hexagon-content-header {
  font-size: 16px;
  
}

.sca-hexagon-content-body {

  font-size: 12px;

}
.sca-roadmap-container {
    height: 450px;
    margin-left:0px;
    
}
}
.sca-hexagon-links{
    color: #37BFB7;
    font-weight:900;
}
.sca-hexagon-links:hover {
    color: #01EAB2;
    transition: 0.2s;
}


.roadmap-container {
  position: relative;
  width: 100%;
  height: 40vw;
  scale: 1;
  left: 0vw;
  top: 2vw;
  margin-left:80px;
}

.content-title-header {
  position: absolute;
  left: 10vw;
  top: 0vw;
  color: white;
  font-size: 35px;
}

#q-1 {
  top: 20.6vw;
  left: 10.4vw;
}

#q-2 {
  top: 20.6vw;
  left: 26vw;
}


#q-3 {
  top: 11.8vw;
  left: 41.5vw;
}


#q-4 {
  top: 11.8vw;
  left: 57.4vw;
}


#monat-1 {
  top: 14.1vw;
  left: 0vw;
}

#monat-2 {
  top: 23.2vw;
  left: 0vw;
}

#monat-3 {
  top: 27.8vw;
  left: 7.8vw;
}

#monat-4 {
  top: 23.2vw;
  left: 15.7vw;
}

#monat-5 {
  top: 14.1vw;
  left: 15.7vw;
}

#monat-6 {
  top: 9.6vw;
  left: 23.6vw;
}

#monat-7 {
  top: 14.1vw;
  left: 31.5vw;
}

#monat-8 {
  top: 18.65vw;
  left: 39.35vw;
}

#monat-9 {
  top: 14.1vw;
  left: 47.2vw;
}

#monat-10 {
  top: 5vw;
  left: 47.2vw;
}

#monat-11 {
  top: 0.5vw;
  left: 55.13vw;
}

#monat-12 {
  top: 5vw;
  left: 63vw;
}

.roadmap-q {
  color: #fff;
  font-size: 3.5vw;
  position: absolute;
}

.hexagon-container {  
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 9vw;
  height: 9vw;
  position: absolute;
}

.hexagon-container:hover {
  scale: 1.1;
  z-index: 10;
  transition: 0.3s;
}

#monat-21:hover, #monat-22:hover, #monat-23:hover {
  scale: 1.75;
  transition: 0.3s;
}

.hexagon {
  width: 100%;
  height: calc(100% * 1.1547);
  position: absolute;
  background-color: #2B4552;
  transform: rotate(30deg);
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
}

.trapezoid {
  width: 85%;
  height: 25%;
  background-color: black;
  margin-top: 10%;
  clip-path: polygon(0% 100%, 100% 100%, 83% 0%, 17% 0%);
} 

.header-container {
  height: 40%;
  width: 100%;
  overflow: hidden;
}

.hexagon-content-header {
  position: absolute;
  top: 13%;
  color: #fff;
  font-size: 1vw;
}

.hexagon-content-body {
  position: absolute;
  top: 43%;
  text-align: center;
  color: #fff;
  font-size: 0.6vw;
  line-height: 140%
}
@media only screen and (min-width: 1350px) {
  .hexagon-container {  
  width: 146px;
  height: 146px;
}
#q-1 {
  top: 334.17px;
  left: 168.7px;
}

#q-2 {
  top: 334.17px;
  left: 421.72px;
}


#q-3 {
  top: 191.4px;
  left: 673.13px;
}


#q-4 {
  top: 191.4px;
  left: 931.03px;
}


#monat-1 {
  top: 228.7px;
  left: 0px;
}

#monat-2 {
  top: 376px;
  left: 0px;
}

#monat-3 {
  top: 450.92px;
  left: 126.5px;
}

#monat-4 {
  top: 376px;
  left: 254.4px;
}

#monat-5 {
  top: 228.7px;
  left: 254.4px;
}

#monat-6 {
  top: 155.71px;
  left: 382.8px;
}

#monat-7 {
  top: 228.7px;
  left: 510.93px;
}

#monat-8 {
  top: 302.5px;
  left: 638.3px;
}

#monat-9 {
  top: 228.7px;
  left: 765.58px;
}

#monat-10 {
  top: 81.1px;
  left: 765.58px;
}

#monat-11 {
  top: 8.11px;
  left: 894.21px;
}

#monat-12 {
  top: 81.1px;
  left: 1021.86px;
}


.roadmap-q {
  font-size: 56px;

}
.content-title-header {
    left:162.2px;
}
.hexagon-content-header {
  font-size: 16px;
  
}

.hexagon-content-body {

  font-size: 10px;

}
.roadmap-container {
    height: 650px;
    margin-left:0px;
}
}
.hexagon-links{
    color: #37BFB7;
    font-weight:900;
}
.hexagon-links:hover {
    color: #01EAB2;
    transition: 0.2s;
}


.roadmap-container-m {
  position: relative;
  width: 100%;
  height: 41vw;
  scale: 1;
  left: 0vw;
  top: 2vw;
}

.content-title-header-m {
  position: absolute;
  left: 10vw;
  top: 0vw;
  color: white;
  font-size: 25px;
}

#qm-1 {
  top: 18.5vw;
  left: 12.9vw;
}

#qm-2 {
  top: 18.5vw;
  left: 32vw;
}


#qm-3 {
  top: 18.5vw;
  left: 51vw;
}


#qm-4 {
  top: 18.5vw;
  left: 70.5vw;
}


#monatm-1 {
  top: 10vw;
  left: 0vw;
}

#monatm-2 {
  top: 21.2vw;
  left: 0vw;
}

#monatm-3 {
  top: 26.7vw;
  left: 9.6vw;
}

#monatm-4 {
  top: 21.1vw;
  left: 19.2vw;
}

#monatm-5 {
  top: 10vw;
  left: 19.2vw;
}

#monatm-6 {
  top: 4.4vw;
  left: 28.9vw;
}

#monatm-7 {
  top: 10vw;
  left: 38.5vw;
}

#monatm-8 {
  top: 21.1vw;
  left: 38.5vw;
}

#monatm-9 {
  top:  26.7vw;
  left: 48.1vw;
}

#monatm-10 {
  top: 21.1vw;
  left: 57.7vw;
}

#monatm-11 {
  top: 10vw;
  left: 57.7vw;
}

#monatm-12 {
  top: 4.4vw;
  left: 67.4vw;
}

#monatm-21 {
  top: 13vw;
  left: 20vw;
  scale: 1.7;
}

#monatm-22 {
  top: 19vw;
  left: 30.5vw;
  scale: 1.7;
}

#monatm-23 {
  top: 13vw;
  left: 41.1vw;
  scale: 1.7;
}

.roadmap-q-m {
  color: #fff;
  font-size: 3.5vw;
  position: absolute;
}

.hexagon-container-m {  
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 11vw;
  height: 11vw;
  position: absolute;
}

.hexagon-container-m:hover {
  scale: 1.1;
  z-index: 10;
  transition: 0.3s;
}

#monatm-21:hover, #monatm-22:hover, #monatm-23:hover {
  scale: 1.75;
  transition: 0.3s;
}

.hexagon-m {
  width: 100%;
  height: calc(100% * 1.1547);
  position: absolute;
  background-color: #2B4552;
  transform: rotate(30deg);
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
}

.trapezoid-m {
  width: 85%;
  height: 25%;
  background-color: black;
  margin-top: 10%;
  clip-path: polygon(0% 100%, 100% 100%, 83% 0%, 17% 0%);
} 

.header-container-m {
  height: 40%;
  width: 100%;
  overflow: hidden;
}

.hexagon-content-header-m {
  position: absolute;
  top: 13%;
  color: #fff;
  font-size:10px;
}

.hexagon-content-body-m {
  position: absolute;
  top: 43%;
  text-align: center;
  color: #fff;
  font-size: 0.75vw;
  line-height: 140%
}

.roadmap-container-s {
  position: relative;
  width: 100%;
  height: 280vw;
  scale: 1;
  left: 0vw;
  top: 2vw;
}

.content-title-header-s {
  position: absolute;
  left: 10vw;
  top: 0vw;
  color: white;
  font-size: 35px;
}

#qs-1 {
  top: 55vw;
  left: 35vw;
}

#qs-2 {
  top: 116vw;
  left: 35vw;
}


#qs-3 {
  top: 177vw;
  left: 35vw;
}


#qs-4 {
  top: 238vw;
  left: 35vw;
}


#monats-1 {
  top: 17.1vw;
  left: 26.2vw;
}

#monats-2 {
  top: 32vw;
  left: 52.5vw;
}

#monats-3 {
  top: 62.5vw;
  left: 52.5vw;
}

#monats-4 {
  top: 77.6vw;
  left: 26.2vw;
}

#monats-5 {
  top: 93vw;
  left: 0vw;
}
#monats-6 {
  top: 123.2vw;
  left: 0vw;
}

#monats-7 {
  top: 138.5vw;
  left: 26.2vw;
}

#monats-8 {
  top: 153.5vw;
  left: 52.5vw;
}

#monats-9 {
  top:  183.8vw;
  left: 52.5vw;
}

#monats-10 {
  top: 198.9vw;
  left: 26.2vw;
}

#monats-11 {
  top: 214.3vw;
  left: 0vw;
}

#monats-12 {
  top: 244.7vw;
  left: 0vw;
}

#monats-21 {
  top: 13vw;
  left: 20vw;
  scale: 1.7;
}

#monats-22 {
  top: 19vw;
  left: 30.5vw;
  scale: 1.7;
}

#monats-23 {
  top: 13vw;
  left: 41.1vw;
  scale: 1.7;
}

.roadmap-q-s {
  color: #fff;
  font-size: 10vw;
  position: absolute;
}

.hexagon-container-s {  
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 30vw;
  height: 30vw;
  position: absolute;
}

.hexagon-container-s:hover {
  scale: 1.1;
  z-index: 10;
  transition: 0.3s;
}

#monats-21:hover, #monats-22:hover, #monats-23:hover {
  scale: 1.75;
  transition: 0.3s;
}

.hexagon-s {
  width: 100%;
  height: calc(100% * 1.1547);
  position: absolute;
  background-color: #2B4552;
  transform: rotate(30deg);
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
}

.trapezoid-s {
  width: 85%;
  height: 25%;
  background-color: black;
  margin-top: 10%;
  clip-path: polygon(0% 100%, 100% 100%, 83% 0%, 17% 0%);
} 

.header-container-s {
  height: 40%;
  width: 100%;
  overflow: hidden;
}

.hexagon-content-header-s {
  position: absolute;
  top: 13%;
  color: #fff;
  font-size:14px;
}

.hexagon-content-body-s {
  position: absolute;
  top: 43%;
  text-align: center;
  color: #fff;
  font-size: 2.1vw;
  line-height: 140%
}


.scm-roadmap-container-m {
  position: relative;
  width: 100%;
  height: 61vw;
  scale: 1;
  left: 0vw;
  top: 2vw;
}

.scm-content-title-header-m {
  position: absolute;
  left: 10vw;
  top: 0vw;
  color: white;
  font-size: 25px;
}

.scm-onboarding-contentm {
    text-align: center;
    font-size: 1.2vw;
    position: absolute;
    line-height: 130%;
    color: white;
}
#scm-onboardingm{
    top: 18vw;
    left: 2.3vw;
}


#scm-qm-1 {
  top: 18.5vw;
  left: 12.9vw;
}

#scm-qm-2 {
  top: 18.5vw;
  left: 32vw;
}


#scm-qm-3 {
  top: 18.5vw;
  left: 51vw;
}


#scm-qm-4 {
  top: 18.5vw;
  left: 70.5vw;
}


/*#scm-monatm-1 {*/
/*  top: 10vw;*/
/*  left: 0vw;*/
/*}*/

#scm-monatm-1 {
  top: 21.2vw;
  left: 0vw;
}

#scm-monatm-2 {
  top: 26.7vw;
  left: 9.6vw;
}

#scm-monatm-3 {
  top: 21.1vw;
  left: 19.2vw;
}

#scm-monatm-4 {
  top: 10vw;
  left: 19.2vw;
}

#scm-monatm-5 {
  top: 4.4vw;
  left: 28.9vw;
}

#scm-monatm-6 {
  top: 10vw;
  left: 38.5vw;
}

#scm-monatm-7 {
  top: 21.1vw;
  left: 38.5vw;
}

#scm-monatm-8 {
  top:  26.7vw;
  left: 48.1vw;
}

#scm-monatm-9 {
  top: 21.1vw;
  left: 57.7vw;
}

#scm-monatm-10 {
  top: 10vw;
  left: 57.7vw;
}

#scm-monatm-11 {
  top: 4.4vw;
  left: 67.4vw;
}

#scm-monatm-12 {
  top: 10vw;
  left: 77vw;
}

#scm-monatm-13 {
  top: 21.1vw;
  left: 77vw;
}

#scm-monatm-21 {
  top: 13vw;
  left: 20vw;
  scale: 1.7;
}

#scm-monatm-22 {
  top: 19vw;
  left: 30.5vw;
  scale: 1.7;
}

#scm-monatm-23 {
  top: 13vw;
  left: 41.1vw;
  scale: 1.7;
}

#scm-monatm-founder-1{
  top: 38.7vw;
  left: 11.6vw;
}

#scm-monatm-founder-2{
  top: 44.3vw;
  left: 21.2vw;
}

#scm-monatm-founder-3{
  top: 38.7vw;
  left: 33vw;
}

#scm-monatm-founder-4{
  top: 44.3vw;
  left: 42.7vw;
}

#scm-monatm-founder-5{
  top: 38.7vw;
  left: 54vw;
}

#scm-monatm-founder-6{
  top: 44.3vw;
  left: 63.7vw;
}

.scm-roadmap-q-m {
  color: #fff;
  font-size: 3.5vw;
  position: absolute;
}

.scm-hexagon-container-m {  
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 11vw;
  height: 11vw;
  position: absolute;
}

.scm-hexagon-container-m:hover {
  scale: 1.1;
  z-index: 10;
  transition: 0.3s;
}

#scm-monatm-21:hover, #scm-monatm-22:hover, #scm-monatm-23:hover {
  scale: 1.75;
  transition: 0.3s;
}

.scm-hexagon-m {
  width: 100%;
  height: calc(100% * 1.1547);
  position: absolute;
  background-color: #2B4552;
  transform: rotate(30deg);
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
}

.scm-trapezoid-m {
  width: 85%;
  height: 25%;
  background-color: black;
  margin-top: 10%;
  clip-path: polygon(0% 100%, 100% 100%, 83% 0%, 17% 0%);
} 

.scm-header-container-m {
  height: 40%;
  width: 100%;
  overflow: hidden;
}

.scm-hexagon-content-header-m {
  position: absolute;
  top: 13%;
  color: #fff;
  font-size:10px;
}

.scm-hexagon-content-body-m {
  position: absolute;
  top: 36.5%;
  text-align: center;
  color: #fff;
  font-size: 0.7vw;
  line-height: 140%
}

@media only screen and (min-width: 1350px) {


.scm-hexagon-container-m {  
  width: 146px;
  height: 146px;
}

#scm-onboardingm{
  top: 170px;
  left: 10px;
}

#scm-qm-1 {
  top: 334.17px;
  left: 168.7px;
}

#scm-qm-2 {
  top: 334.17px;
  left: 421.72px;
}


#scm-qm-3 {
  top: 191.4px;
  left: 673.13px;
}


#scm-qm-4 {
  top: 191.4px;
  left: 931.03px;
}


#scm-monatm-12 {
  top: 228.7px;
  left: 0px;
}

#scm-monatm-1 {
  top: 376px;
  left: 0px;
}

#scm-monatm-2 {
  top: 450.92px;
  left: 126.5px;
}

#scm-monatm-3 {
  top: 376px;
  left: 254.4px;
}

#scm-monatm-4 {
  top: 228.7px;
  left: 254.4px;
}

#scm-monatm-5 {
  top: 155.71px;
  left: 382.8px;
}

#scm-monatm-6 {
  top: 228.7px;
  left: 510.93px;
}

#scm-monatm-7 {
  top: 376px;
  left: 510.93px;
}

#scm-monatm-8 {
  top: 450.92px;;
  left: 636.93px;
}

#scm-monatm-9 {
  top: 376px;
  left: 764.33px;
}

#scm-monatm-10 {
  top: 228.7px;
  left: 764.33px;
}

#scm-monatm-11 {
  top: 155.71px;
  left: 892.73px;
}

#scm-monatm-12 {
  top: 228.7px;
  left: 1021.13px;
}

#scm-monatm-13 {
  top: 376px;
  left: 1021.13px;
}

#scm-monatm-founder-1{
  top: 625px;
  left: 210px;
}

#scm-monatm-founder-2{
  top: 698px;
  left: 338.6px;
}

#scm-monatm-founder-3{
  top: 625px;
  left: 500px;
}

#scm-monatm-founder-4{
  top: 698px;
  left: 628.6px
}

#scm-monatm-founder-5{
  top: 625px;
  left: 790px;
}

#scm-monatm-founder-6{
  top: 698px;
  left: 918.6px
}

.scm-roadmap-q-m {
  font-size: 56px;

}
.scm-content-title-header-m {
    left:162.2px;
}
.scm-hexagon-content-header-m {
  font-size: 16px;
  
}
.scm-onboarding-content-m{
    font-size: 16px;
}

.scm-hexagon-content-body-m {

  font-size: 9.2px;

}
.scm-roadmap-container-m {
    height: 950px;
    margin-left:0px;
}
}
.scm-hexagon-links-m{
    color: #37BFB7;
    font-weight:900;
}
.scm-hexagon-links-m:hover {
    color: #01EAB2;
    transition: 0.2s;
}


.scm-roadmap-container-s {
  position: relative;
  width: 100%;
  height: 410vw;
  scale: 1;
  left: 0vw;
  top: 2vw;
}

.scm-content-title-header-s {
  position: absolute;
  left: 10vw;
  top: 0vw;
  color: white;
  font-size: 35px;
}

.scm-onboarding-contents {
    text-align: center;
    font-size: 4.5vw;
    position: absolute;
    line-height: 130%;
    color: white;
}
#scm-onboardings{
    top: 36vw;
    left: 0vw;
}

#scm-qs-1 {
  top: 55vw;
  left: 35vw;
}

#scm-qs-2 {
  top: 116vw;
  left: 35vw;
}


#scm-qs-3 {
  top: 177vw;
  left: 35vw;
}


#scm-qs-4 {
  top: 238vw;
  left: 35vw;
}


#scm-monats-1 {
  top: 17.1vw;
  left: 26.2vw;
}

#scm-monats-2 {
  top: 32vw;
  left: 52.5vw;
}

#scm-monats-3 {
  top: 62.5vw;
  left: 52.5vw;
}

#scm-monats-4 {
  top: 77.6vw;
  left: 26.2vw;
}

#scm-monats-5 {
  top: 93vw;
  left: 0vw;
}
#scm-monats-6 {
  top: 123.2vw;
  left: 0vw;
}

#scm-monats-7 {
  top: 138.5vw;
  left: 26.2vw;
}

#scm-monats-8 {
  top: 153.5vw;
  left: 52.5vw;
}

#scm-monats-9 {
  top:  183.8vw;
  left: 52.5vw;
}

#scm-monats-10 {
  top: 198.9vw;
  left: 26.2vw;
}

#scm-monats-11 {
  top: 214.3vw;
  left: 0vw;
}

#scm-monats-12 {
  top: 244.7vw;
  left: 0vw;
}

#scm-monats-13 {
  top: 260vw;
  left: 26.2vw;
}

#scm-monats-founder-1{
  top: 290vw;
  left: 0vw;
}

#scm-monats-founder-2{
  top: 320.4vw;
  left: 0vw;
}

#scm-monats-founder-3{
  top: 290vw;
  left: 52.5vw;
}

#scm-monats-founder-4{
  top: 320.4vw;
  left: 52.5vw;
}

#scm-monats-founder-5{
  top: 344vw;
  left: 26.2vw;
}

#scm-monats-founder-6{
  top: 374.4vw;
  left: 26.2vw;
}
.scm-roadmap-q-s {
  color: #fff;
  font-size: 10vw;
  position: absolute;
}

.scm-hexagon-container-s {  
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 30vw;
  height: 30vw;
  position: absolute;
}

.scm-hexagon-container-s:hover {
  scale: 1.1;
  z-index: 10;
  transition: 0.3s;
}

#scm-monats-21:hover, #scm-monats-22:hover, #scm-monats-23:hover {
  scale: 1.75;
  transition: 0.3s;
}

.scm-hexagon-s {
  width: 100%;
  height: calc(100% * 1.1547);
  position: absolute;
  background-color: #2B4552;
  transform: rotate(30deg);
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
}

.scm-trapezoid-s {
  width: 85%;
  height: 25%;
  background-color: black;
  margin-top: 10%;
  clip-path: polygon(0% 100%, 100% 100%, 83% 0%, 17% 0%);
} 

.scm-header-container-s {
  height: 40%;
  width: 100%;
  overflow: hidden;
}

.scm-hexagon-content-header-s {
  position: absolute;
  top: 13%;
  color: #fff;
  font-size:2.8vw
}

.scm-hexagon-content-body-s {
  position: absolute;
  top: 43%;
  text-align: center;
  color: #fff;
  font-size: 1.7vw;
  line-height: 140%
}


.shop-root {
        font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
        background: #141518;
        min-height: 100vh;
        padding: 20px;
      }
      .container-shop {
        max-width: 1400px;
        margin: 0 auto;
        background: #181a1f;
        border-radius: 20px;
        box-shadow: 0 20px 40px rgba(0, 0, 0, 0.7);
        overflow: hidden;
      }
      .shop-header-main {
        background: #181a1f;
        color: #f1f6ef;
        padding: 40px 30px;
        text-align: center;
        position: relative;
        overflow: hidden;
      }
      .shop-header-main::before {
        content: "";
        position: absolute;
        top: 0;
        left: -100%;
        width: 100%;
        height: 100%;
        background: linear-gradient(
          90deg,
          transparent,
          rgba(55, 191, 183, 0.1),
          transparent
        );
        animation: shimmer 3s infinite;
      }
      @keyframes shimmer {
        0% {
          left: -100%;
        }
        100% {
          left: 100%;
        }
      }
      .shop-header-main h1 {
        font-size: 3rem;
        margin-bottom: 15px;
        font-weight: 700;
        color: #f1f6ef;
        position: relative;
        z-index: 2;
      }
      .shop-header-main p {
        font-size: 1.3rem;
        opacity: 0.9;
        color: #37bfb7;
        position: relative;
        z-index: 2;
      }
      .shop-content {
        padding: 40px 30px;
        background: #141518;
      }
      .shop-section {
        margin-bottom: 50px;
      }
      .shop-section-title {
        font-size: 2.2rem;
        font-weight: 600;
        color: #f1f6ef;
        margin-bottom: 30px;
        text-align: center;
        position: relative;
      }
      .shop-section-title::after {
        content: "";
        position: absolute;
        bottom: -10px;
        left: 50%;
        transform: translateX(-50%);
        width: 100px;
        height: 3px;
        background: linear-gradient(135deg, #37bfb7 0%, #01eab2 100%);
        border-radius: 2px;
      }
      .shop-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
        gap: 25px;
        margin-bottom: 40px;
      }
      .shop-card {
        background: #181a1f;
        border-radius: 15px;
        padding: 30px;
        position: relative;
        overflow: hidden;
        transition: all 0.4s ease;
        cursor: pointer;
        border: 2px solid transparent;
      }
      .shop-card::before {
        content: "";
        position: absolute;
        top: 0;
        left: -100%;
        width: 100%;
        height: 100%;
        background: linear-gradient(
          90deg,
          transparent,
          rgba(55, 191, 183, 0.15),
          transparent
        );
        transition: left 0.6s ease;
      }
      .shop-card:hover::before {
        left: 100%;
      }
      .shop-card:hover {
        transform: translateY(-8px) scale(1.02);
        border-color: #37bfb7;
        box-shadow: 0 0 25px #01eab2, 0 10px 30px rgba(0, 0, 0, 0.3);
      }
      .shop-card-header {
        display: flex;
        align-items: center;
        margin-bottom: 20px;
      }
      .shop-card-icon {
        width: 60px;
        height: 60px;
        background: linear-gradient(135deg, #37bfb7 0%, #01eab2 100%);
        border-radius: 12px;
        display: flex;
        align-items: center;
        justify-content: center;
        margin-right: 20px;
        font-size: 1.8rem;
        color: #101114;
        font-weight: bold;
      }
      .shop-card-title {
        font-size: 1.4rem;
        font-weight: 600;
        color: #f1f6ef;
        margin-bottom: 5px;
      }
      .shop-card-subtitle {
        font-size: 1rem;
        color: #37bfb7;
        opacity: 0.9;
      }
      .shop-card-description {
        color: #f1f6ef;
        line-height: 1.6;
        margin-bottom: 25px;
        font-size: 1rem;
      }
      .shop-card-price {
        font-size: 2rem;
        font-weight: 700;
        color: #01eab2;
        margin-bottom: 20px;
        text-align: center;
      }
      .shop-card-features {
        list-style: none;
        padding: 0;
        margin-bottom: 25px;
      }
      .shop-card-features li {
        color: #f1f6ef;
        padding: 8px 0;
        position: relative;
        padding-left: 25px;
      }
      .shop-card-features li::before {
        content: "✓";
        position: absolute;
        left: 0;
        color: #37bfb7;
        font-weight: bold;
      }
      .shop-card-button {
        width: 100%;
        background: linear-gradient(135deg, #37bfb7 0%, #01eab2 100%);
        color: #101114;
        border: none;
        padding: 15px 25px;
        border-radius: 25px;
        cursor: pointer;
        font-size: 1.1rem;
        font-weight: 600;
        transition: all 0.3s ease;
        text-decoration: none;
        display: inline-block;
        text-align: center;
        box-shadow: 0 4px 15px rgba(55, 191, 183, 0.3);
      }
      .shop-card-button:hover {
        filter: brightness(1.2) drop-shadow(0 0 12px #01eab2);
        transform: translateY(-2px);
      }
      .shop-card-badge {
        position: absolute;
        top: 15px;
        right: 15px;
        background: linear-gradient(135deg, #01eab2 0%, #37bfb7 100%);
        color: #101114;
        padding: 5px 12px;
        border-radius: 15px;
        font-size: 0.8rem;
        font-weight: 600;
        text-transform: uppercase;
      }
      .shop-card-popular {
        border-color: #01eab2;
        box-shadow: 0 0 20px rgba(1, 234, 178, 0.3);
      }
      .shop-card-popular::after {
        content: "Most Popular";
        position: absolute;
        top: -10px;
        left: 50%;
        transform: translateX(-50%);
        background: linear-gradient(135deg, #01eab2 0%, #37bfb7 100%);
        color: #101114;
        padding: 5px 15px;
        border-radius: 15px;
        font-size: 0.8rem;
        font-weight: 600;
        text-transform: uppercase;
      }
      .shop-category-tabs {
        display: flex;
        justify-content: center;
        margin-bottom: 40px;
        flex-wrap: wrap;
        gap: 15px;
      }
      .shop-tab {
        background: #23262b;
        color: #f1f6ef;
        border: 2px solid transparent;
        padding: 12px 25px;
        border-radius: 25px;
        cursor: pointer;
        font-size: 1rem;
        font-weight: 600;
        transition: all 0.3s ease;
      }
      .shop-tab:hover {
        background: linear-gradient(135deg, #37bfb7 0%, #01eab2 100%);
        color: #101114;
        transform: translateY(-2px);
      }
      .shop-tab.active {
        background: linear-gradient(135deg, #37bfb7 0%, #01eab2 100%);
        color: #101114;
        border-color: #01eab2;
      }
      .shop-category {
        display: none;
      }
      .shop-category.active {
        display: block;
      }
      .shop-info-box {
        background: linear-gradient(135deg, #23262b 0%, #181a1f 100%);
        border-radius: 15px;
        padding: 25px;
        margin-bottom: 30px;
        border-left: 4px solid #37bfb7;
      }
      .shop-info-title {
        color: #f1f6ef;
        font-size: 1.3rem;
        font-weight: 600;
        margin-bottom: 10px;
      }
      .shop-info-text {
        color: #f1f6ef;
        line-height: 1.6;
        opacity: 0.9;
      }
      .shop-current-role {
        background: linear-gradient(135deg, #01eab2 0%, #37bfb7 100%);
        color: #101114;
        padding: 15px 25px;
        border-radius: 15px;
        text-align: center;
        font-weight: 600;
        font-size: 1.1rem;
        margin-bottom: 30px;
      }

      .shop-card-disabled {
          opacity: 0.5;
          filter: grayscale(1);
          cursor: not-allowed;
          pointer-events: none;
      }
      .shop-card-disabled .shop-card-button {
          background: #666 !important;
          color: #999 !important;
          cursor: not-allowed;
          pointer-events: none;
      }
      .shop-card-disabled .shop-card-button:hover {
          filter: none !important;
          transform: none !important;
      }
      .shop-card-disabled .shop-card-price {
          color: #666 !important;
      }
      .shop-card-disabled .shop-card-title,
      .shop-card-disabled .shop-card-subtitle,
      .shop-card-disabled .shop-card-description {
          color: #999 !important;
      }
      .shop-card-disabled .shop-card-features li {
          color: #999 !important;
      }
      .shop-card-disabled .shop-card-features li::before {
          color: #666 !important;
      }
      .shop-card-disabled .shop-card-icon {
          background: #666 !important;
          color: #999 !important;
      }
      .shop-card-disabled:hover {
          transform: none !important;
          border-color: transparent !important;
          box-shadow: none !important;
      }
      .shop-card-disabled::before {
          display: none !important;
      }
      .shop-card-disabled:hover::before {
          display: none !important;
      }
      @media (max-width: 768px) {
        .shop-header-main h1 {
          font-size: 2rem;
        }
        .shop-header-main p {
          font-size: 1.1rem;
        }
        .shop-content {
          padding: 20px 15px;
        }
        .shop-section-title {
          font-size: 1.8rem;
        }
        .shop-grid {
          grid-template-columns: 1fr;
          gap: 20px;
        }
        .shop-card {
          padding: 25px;
        }
        .shop-card-header {
          flex-direction: column;
          text-align: center;
        }
        .shop-card-icon {
          margin-right: 0;
          margin-bottom: 15px;
        }
        .shop-category-tabs {
          flex-direction: column;
          align-items: center;
        }
        .shop-tab {
          width: 100%;
          max-width: 300px;
          text-align: center;
        }
      }
     .shop-category-dropdown-wrapper {
            position: relative;
            width: 100%;
            margin-bottom: 30px;
            display: none;
            z-index: 20;
        }
        .shop-category-dropdown-custom {
            background: linear-gradient(135deg, #181A1F 80%, #23262B 100%);
            border: 2px solid #37BFB7;
            border-radius: 25px;
            color: #F1F6EF;
            font-size: 1.1rem;
            font-weight: 600;
            padding: 14px 48px 14px 20px;
            box-shadow: 0 4px 15px rgba(55, 191, 183, 0.10);
            cursor: pointer;
            position: relative;
            transition: border 0.2s, box-shadow 0.2s;
            outline: none;
            user-select: none;
        }
        .shop-category-dropdown-custom:after {
            content: '';
            position: absolute;
            right: 22px;
            top: 50%;
            width: 0;
            height: 0;
            border-left: 8px solid transparent;
            border-right: 8px solid transparent;
            border-top: 8px solid #37BFB7;
            transform: translateY(-50%);
            pointer-events: none;
        }
        .shop-category-dropdown-list {
            display: none;
            position: absolute;
            left: 0;
            right: 0;
            top: 110%;
            background: #181A1F;
            border: 2px solid #37BFB7;
            border-radius: 18px;
            box-shadow: 0 8px 32px rgba(1, 234, 178, 0.12);
            z-index: 100;
            padding: 0;
            margin: 0;
            list-style: none;
            overflow: hidden;
        }
        .shop-category-dropdown-list.open {
            display: block;
            animation: fadeIn 0.2s;
        }
        @keyframes fadeIn {
            from { opacity: 0; transform: translateY(-10px);}
            to { opacity: 1; transform: translateY(0);}
        }
        .shop-category-dropdown-list li {
            padding: 16px 24px;
            color: #F1F6EF;
            font-size: 1.1rem;
            cursor: pointer;
            transition: background 0.15s, color 0.15s;
        }
        .shop-category-dropdown-list li:hover,
        .shop-category-dropdown-list li.active {
            background: linear-gradient(135deg, #37BFB7 0%, #01EAB2 100%);
            color: #101114;
        }
        @media (max-width: 768px) {
            .shop-category-tabs {
                display: none !important;
            }
            .shop-category-dropdown-wrapper {
                display: block !important;
            }
        }
        
        
        /* === Safe Button Layout Fix === */

/* Remove the problematic form structure changes */
#memberpress-form form {
  display: block !important; /* Keep original form display */
}

/* Target the specific button containers more precisely */
#memberpress-form .mepr-submit-row,
#memberpress-form form > p:has(.mepr-submit),
#memberpress-form form > div:has(.mepr-submit) {
  display: flex !important;
  justify-content: flex-end !important;
  align-items: center !important;
  gap: 1rem !important;
  margin-top: 2rem !important;
  padding-top: 1.5rem !important;
  border-top: 1px solid var(--border-subtle, #2a2a2a) !important;
}

/* Move password link to the same row without breaking structure */
#memberpress-form .mepr-change-password-link,
#memberpress-form a[href*="password"],
#memberpress-form a[href*="change"] {
  position: static !important;
  margin-left: auto !important;
}

/* If password link is in a separate container, move it */
#memberpress-form span.mepr-account-change-password {
  order: 2 !important;
  margin-left: 1rem !important;
}

/* Ensure buttons have consistent sizing */
#memberpress-form .mepr-submit,
#memberpress-form button[type="submit"],
#memberpress-form input[type="submit"],
#memberpress-form .mepr-change-password-link,
#memberpress-form a[href*="password"],
#memberpress-form a[href*="change"] {
  min-width: 160px !important;
  height: 48px !important;
  padding: 0 1.4rem !important;
  font-size: 0.95rem !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  border: none !important;
  border-radius: 12px !important;
  text-decoration: none !important;
  box-sizing: border-box !important;
}

/* Different colors for distinction */
#memberpress-form .mepr-submit,
#memberpress-form button[type="submit"],
#memberpress-form input[type="submit"] {
  background: var(--gradient-primary, linear-gradient(135deg,#14b8a6,#2dd4bf)) !important;
  color: #fff !important;
  box-shadow: 0 10px 25px rgba(20,184,166,.28) !important;
}

#memberpress-form .mepr-change-password-link,
#memberpress-form a[href*="password"],
#memberpress-form a[href*="change"] {
  background: linear-gradient(135deg, #6366f1, #8b5cf6) !important;
  color: #fff !important;
  box-shadow: 0 10px 25px rgba(99,102,241,.25) !important;
}

/* JavaScript-based solution for moving the password button */
/* Add this script tag after your form */
        
        
        
        
        /* =========================
   GLOBAL FONT SHRINK (Roadmap)
   ========================= */
/* 1) Basisschrumpfung für alles im Roadmap-Bereich */
#roadmap-content { font-size: 90% !important; }              /* ~10% kleiner */
#roadmap-content * { line-height: 1.25 !important; }

/* 2) SCA: Header/Body in den Hexagons kleiner */
.sca-hexagon-content-header { font-size: 0.7vw !important; } /* vorher 0.8vw */
.sca-hexagon-content-body   { font-size: 0.44vw !important; }/* vorher 0.48vw */

@media (min-width:1350px){
  .sca-hexagon-content-header { font-size: 10px !important; } /* vorher 12px */
  .sca-hexagon-content-body   { font-size: 7px  !important; } /* vorher 7.5–8px */
}

@media (max-width:768px){
  .sca-hexagon-content-header { font-size: 4.2vw !important; } /* vorher 4.8vw */
  .sca-hexagon-content-body   { font-size: 3.1vw !important; } /* vorher 3.5vw */
}

/* 3) SCU: Header/Body in den Hexagons kleiner */
.hexagon-content-header { font-size: 0.8vw !important; }     /* vorher ~0.88vw */
.hexagon-content-body   { font-size: 0.48vw !important; }    /* vorher ~0.52vw */

@media (min-width:1350px){
  .hexagon-content-header { font-size: 11px !important; }    /* vorher 13px */
  .hexagon-content-body   { font-size: 8px  !important; }    /* vorher 8.5px */
}

@media (max-width:768px){
  .hexagon-content-header { font-size: 4.2vw !important; }   /* vorher 4.8vw */
  .hexagon-content-body   { font-size: 3.1vw !important; }   /* vorher 3.5vw */
}

/* 4) SCM: Header/Body in den Hexagons kleiner */
.scm-hexagon-content-header-m { font-size: 9px  !important; } /* vorher 10–16px */
.scm-hexagon-content-body-m   { font-size: 0.64vw !important; }/* vorher ~0.7–0.92vw */

@media (max-width:768px){
  .scm-hexagon-content-header-m { font-size: 4.2vw !important; } /* vorher 4.8vw */
  .scm-hexagon-content-body-m   { font-size: 3.1vw !important; } /* vorher 3.5vw */
}

/* 5) Titel/Untertitel leicht reduzieren */
.content-title,
.sca-content-title-header,
.content-title-header,
.scm-content-title-header-m { font-size: 90% !important; }
.content-subtitle { font-size: 90% !important; }/* End custom CSS */