/* === Globale Tabellen-Styles (PMPro + Theme) === */

:root {
  --gwl-hellrot: var(--e-global-color-800958e);
}

.pmpro * {
  border: none !important;
  border-width: 0 !important;
  border-style: none !important;
  border-color: transparent !important;
}

/* Reset PMPro Typography to Elementor Global Defaults */
.pmpro_card_title,
.pmpro_member_display_name,
.pmpro_section h2,
.pmpro_section h3,
.pmpro_section label
 {
  font-family: var(--e-global-typography-primary-font-family) !important;
  font-size: var(--e-global-typography-secondary-font-size);
  font-weight: var(--e-global-typography-primary-font-weight) !important;
  line-height: var(--e-global-typography-primary-line-height) !important;
  letter-spacing: var(--e-global-typography-primary-letter-spacing) !important;
  text-transform: var(--e-global-typography-primary-text-transform) !important;
  color: var(--e-global-color-primary) !important;
}

/* ===== Typografie in Lowercase und mit Shadow =====
.pmpro_section input,
.pmpro_section textarea,
.pmpro_section select,
.pmpro_section p,
.pmpro_form_label,
.pmpro_message,
.pmpro_btn-submit,
.pmpro_message.pmpro_error,
abbr {
  color: #fff;
  text-shadow:
    -1px -1px 0 #000,
     1px -1px 0 #000,
    -1px  1px 0 #000,
     1px  1px 0 #000;
	font-variant:lowercase;
} */
.pmpro_error {
    background-color: #ff0000 !important;
    padding: 25px;
}

dd {
    margin: 0 0 0 10px;
    padding-bottom: 10px;
    line-height: 1;
}

.pmpro_levels-3col .pmpro_level {
  flex: 1 1 300px;
  max-width: 300px;
  box-sizing: border-box;
}
@media (max-width: 1024px) {
  .pmpro_levels-3col .pmpro_level {
    flex: 1 1 calc(50% - 20px);
    max-width: calc(50% - 20px);
  }
}

#abo-buttons .pmpro_btn {
  display: block!important;          /* von inline auf block */
  width: 100%!important;             /* volle Breite der Card */
  text-align: center!important;      /* Text mittig halten */
  box-sizing: border-box!important;  /* Padding zählt zur Gesamtbreite */
  margin: 0!important;               /* optional, falls Abstand stört */
  padding:10px !important;
  white-space: nowrap;
  line-height:1.5;
  background-color: #e60000 !important; /* Rot */
  color: #ffffff !important;            /* Textfarbe Weiß */
  border: none !important;              /* Rahmen entfernen */
  border-radius: 4px;                   /* leicht abgerundet */
  text-decoration: none;                 /* kein Unterstrich */
}


@media (min-width: 320px) {
  section.elementor-element {
    margin-top: 0 !important;
    padding: 0 !important;
  }
  .pmpro_levels-3col {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-evenly; /* gleiche Abstände zwischen den Spalten, aber kein Außenrand. */
  align-items: flex-start;
  width: 100vw !important;      /* überschreibt die 450 px */
  max-width: 100vw !important;  /* killt evtl. Elementor-Limits */
  margin-left: calc(-50vw + 50%); /* gleicht zentrierte Elementor-Spalte aus */
  padding: 0 !important;
  margin: 0 auto;
  }
  .pmpro_levels-3col .pmpro_level {
  flex: 1 1 32%;
  max-width: 32%;
  padding: 0 !important;
  }
/*  .pmpro_card {
  margin: 0 !important;
  padding-top: 0 !important;
  width: 91% !important;
  padding: 0 !important;
}
*/
a.pmpro_btn.pmpro_btn-select {
    font-size: 70%!important;
    }
.pmpro_level-select a {
  display: block!important;          /* von inline auf block */
  width: 100%!important;             /* volle Breite der Card */
  text-align: center!important;      /* Text mittig halten */
  box-sizing: border-box!important;  /* Padding zählt zur Gesamtbreite */
  margin: 0!important;               /* optional, falls Abstand stört */
}
.pmpro_level-description {
/*  hyphens: auto;
  -moz-hyphens: auto;
  -ms-hyphens: auto;
  -webkit-hyphens: auto; */
  margin-top:25px;
  font-size: 60%!important;
  line-height: 1.2;
  display: inline-block;      /* nötig, damit transform wirkt */
  transform: scaleX(0.85);     /* 0.9 = 90 % Breite → schmaler */
  transform-origin: left;     /* optional, verhindert Verschieben */
}
.pmpro_level-description li,
.pmpro_level-description dt,
.pmpro_level-description dd {line-height:1;padding-bottom:5px;}

}
.pmpro_level-description dt:first-child,
.pmpro_level-description li:first-child {padding-bottom:15px;}

    .pmpro_card_title.pmpro_font-large {
    font-size: 54px!important;
}  
  
@media (max-width: 375px) and (orientation: portrait) {
  .pmpro_levels-3col {
  display: block;
  } 
  .pmpro_levels-3col .pmpro_level {
        max-width: 100%;
    }

p.pmpro_level-price {
    font-size: 220%;
}
a.pmpro_btn.pmpro_btn-select {
    font-size: 200%!important;
    }
   .pmpro_btn{padding-top:15px;}
.pmpro_level-description {
  text-align: center;        /* Container zentriert den inline-block */
  max-width: 100%;
  padding:50px;
  margin-top:25px;
  font-size: 100%!important;
  line-height: 1.2;
  display: inline-block;      /* nötig, damit transform wirkt */
  transform: scaleX(1);     /* 0.9 = 90 % Breite → schmaler */
  transform-origin: left;     /* optional, verhindert Verschieben */
}
.pmpro_level-description dl {
  display: inline-block;     /* erlaubt Zentrierung wie Text */
  text-align: left;          /* Inhalt bleibt linksbündig */
  margin: 0 auto;            /* zentriert im Container */
}
dd {
    margin: 0 0 15px 10px;
    line-height: 1.2!important;
}
p.pmpro_level_name_text{line-height:1.2!important;}
p.pmpro_level_name_text:after{content: " Das Paket enthält:"}
}

/* Feintuning für iPhone SE & ähnliche (Landscape) */
@media (max-width: 667px) and (orientation: landscape) {
  a.pmpro_btn.pmpro_btn-select {
    font-size: 100%!important;
    }
    .pmpro_level-description {
    font-size: 100% !important;     /* etwas größer als im Portrait-Layout */
    line-height: 1.3;
    transform: none !important;    /* keine horizontale Stauchung */
    transform-origin: unset;
    letter-spacing: 0.01em;
    margin-top: 20px;
  }
}



/* ===========================
   PMPRO Advanced Levels
   =========================== */

/* Reihenfolge der Pakete. Die Level sind die Paket-IDs */

#pmpro_level-1 { order: 1; } /* kostenlos */
#pmpro_level-4 { order: 2; } /* Dieter */
#pmpro_level-3 { order: 3; } /* Eduard */
#pmpro_level-5 { order: 4; } /* Hank */



body .pmpro_card_title,
.page .pmpro_card_title {
        color: var(--e-global-color-primary);
        font-weight: 700;
        margin: 0;
        padding: var(--pmpro--base--spacing--large) var(--pmpro--base--spacing--large) 0;
}



.pmpro_level {
  flex: 1 1 32%;
  max-width: 32%;
  box-sizing: border-box;
}

/* Container der einzelnen Level-Karte */
.pmpro_level {
  font-family: 'Special Elite', Courier, monospace;
}

/* Letzte Karte ohne rechten Abstand */
.pmpro_level:last-child {
  margin-right: 0;
}


/* Karten-Design */
body .pmpro_card {
  width:20vw;
  background: transparent !important;
/*  backdrop-filter: blur(3px);
  color: #fff;*/
  margin:0 auto !important;
  padding:0;
  /* Ränder komplett entfernen */
  border: none !important;
  border-width: 0 !important;
  border-style: none !important;
  border-color: transparent !important;
  box-shadow: none !important;
  outline: none !important;

  /* Rahmen-Optik
	border-radius: 12px;
  padding: 1.5rem;
 	*/
 	
  /* Layout */
  text-align: left;
/*  display: flex;
  flex-direction: column;*/
}

/* Name / Title 
.pmpro_card_title {
  font-size: 2rem;
  font-weight: bold;
  margin: 0 0 1rem 0;
}
*/
/* Karten-Design – Die Listen innerhalb der Karte */
.pmpro_list.pmpro_list-plain, 
.pmpro_list.pmpro_list-plain .pmpro_list_item,
div.pmpro_card_actions {
display:
  list-style: none;
  margin: 0;
  padding: 0;
  line-height: 1.2;
  font-size: var(--e-global-typography-secondary-font-size);
}

 
/* PMPro Card Actions erben Font Style der Card */
.pmpro_card .pmpro_card_actions a,
.pmpro_card_actions {
  font-size: inherit !important;
text-shadow:
  1px 1px 4px rgba(0, 0, 0, 1),
 -2px -2px 4px rgba(0, 0, 0, 1);
 }
 
.pmpro_form_fields input,
.pmpro_form_fields textarea,
.pmpro_form_fields select {
  background-color: #fff !important;
  color: #000 !important;
  border: none !important;
  box-shadow:
    2px 2px 6px rgba(0, 0, 0, 0.6),
   -2px -2px 6px rgba(0, 0, 0, 0.6) !important;
  border-radius: 8px;
}

/* Label und Input fürs aktuelle Passwort enger zusammensetzen */
.pmpro_form_field label[for="current_pass"] {
  margin-bottom: 0.2em;
}

/* "Show Password" optisch näher an das Eingabefeld ranrücken */
.pmpro_form_field .password-toggle {
  margin-top: 0.3em;
  font-size: 0.9em;
  opacity: 0.8;
  display: block;
}
/* Zusätzlicher Abstand VOR dem neuen Passwortblock */
.pmpro_form_fields #pass1-wrap {
  margin-top: 2em;
}
#pmpro_change_password .pmpro_form_field-password-toggle,
#pmpro_change_password .pmpro_form_field-password-toggle .pmpro_btn {
display: block !important;
float: none !important;
clear: both !important;
width: 100% !important;
margin: 0 !important;
text-align: left !important;
}

.pmpro_form_fields input:focus,
.pmpro_form_fields textarea:focus,
.pmpro_form_fields select:focus {
  box-shadow: 0 0 0 3px rgba(255, 140, 0, 0.3); /* leichter Fokus-Ring */
  outline: none;
}

 
.pmpro_card .pmpro_card_actions a:hover{
  color: var(--e-global-color-primary) !important;
}

/* Features / Beschreibung */
.pmpro_level-description {
  font-size: 1rem;
  font-style: normal;
  line-height: 1.5;
  margin: 0 0 1rem 0;
}

/* Preis */
.pmpro_level-price {
  font-size: 1.25rem;
  font-weight: bold;
  margin: 1rem 0;
}

/* Button & Expiration Container */
.pmpro_card_actions {
  margin-top: auto;
}

/* Button Styles */
.pmpro_btn,
.pmpro_level-meta .pmpro_btn {
  font-size: 1rem;
  padding: 0.5rem 1rem;
  border-radius: 4px;
  text-decoration: none;
  background: #000;
  background-color: var(--e-global-color-secondary);
  color: #000;
  font-weight: bold;
  font-family:inherit!important;
  display: block;
  margin: 1rem 0 0;
  transition: background 0.2s ease;
}

.pmpro_btn-cancel{background-color:red!important;color:black!important;border:unset!important;}

/* Block-Anordnung in den Level-Karten */
.pmpro_level-meta {
 display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.pmpro_level-meta .pmpro_level-price {
  order: 1;
}

/* Eliminiert Button-Margin aus pmpro-advanced-levels.css */
.pmpro_advanced_levels-div .pmpro_level-meta .pmpro_btn {
    margin-left:unset;
}

.pmpro
.pmpro_card_content {
padding:0;
}

.pmpro
.pmpro_card_content + .pmpro_card_actions {
border-top: none;
border-bottom: none;
padding:10px 0 0;
}


/* Se Boetten*/
.pmpro_level-meta .pmpro_btn {
  order: 2;
  display: block;
  width: 100%;           /* Füllt den parent */
  padding: 0.5rem 1rem;
  text-align: center;
  box-sizing: border-box;
}

.pmpro_level-meta .pmpro_btn:hover {
  background: #222;
}

p.pmpro_level-expiration {
  display: none!important;
}

/* Expiration Info */
.pmpro_level-expiration {
  font-size: 0.9rem;
  font-style: italic;
  color: #f3f3f3;
  margin: 0.5rem 0 0;
}
.pmpro_level-description ul  {
	padding:0;
	list-style-type: none;
}

/* END PMPRO Advanced Level Shortcode */

fieldset {
  all: unset;
  display: block;
  width: 100%;
}
main .elementor-widget-heading h1.elementor-heading-title:only-child {
  display: none;
}

#pmpro_account-profile > div > h3{    font-size: calc(var(--e-global-typography-primary-font-size) * 0.6) !important;
}

a,span{font-size:inherit!important;}

nav ul li a {font-size:24px!important;}

table, td,th,tr{background-color:unset!important;}

#pmpro_account-links {
  display: none;
}

.pmpro_card_title {
  font-family: var(--e-global-typography-text-font-family);
  font-size: var(--e-global-typography-text-font-size);
  font-weight: var(--e-global-typography-text-font-weight);
  line-height: var(--e-global-typography-text-line-height);
  letter-spacing: var(--e-global-typography-text-letter-spacing);
  text-transform: none;
  margin: 0; /* 👈 gleich hier mitrein, um Punkt 2 zu lösen */
}


div.pmpro_card_actions{
  font-size: calc(var(--e-global-typography-primary-font-size) * 0.35) !important;
}
 
.pmpro .pmpro_card_action_separator {
margin: 0 calc( var(--pmpro--base--spacing--small) / 10 );
opacity: 0;
width: 0;
}
 
/* Label für "Angemeldet bleiben" gezielt anpassen */
.login-remember label {
  font-size: var(--e-global-typography-primary-font-size) !important;
  font-family: var(--e-global-typography-primary-font-family) !important;
  font-weight: var(--e-global-typography-primary-font-weight) !important;
  line-height: var(--e-global-typography-primary-line-height) !important;
  letter-spacing: var(--e-global-typography-primary-letter-spacing) !important;
  color: var(--e-global-color-primary) !important;
}


.pmpro_card,
.pmpro_card_title {
  margin:0;
  padding: 0 !important;
  border: none !important;
  border-radius: 0 !important;
  background: transparent !important;
}

  .pmpro_card_title {
    margin-top: 0 !important;
  }

svg.feather.feather-eye {
stroke: var(--e-global-color-primary);
}
.pmpro_card_content{
color:var(--e-global-color-primary);
border: none;
}
  .pmpro_login_wrap,
  .pmpro {
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box;
  }
   
	/* Label für "Angemeldet bleiben" gezielt anpassen */
    .login-remember label {
    font-size: calc(var(--e-global-typography-primary-font-size) * 0.6) !important;

	}  
	.login-remember label {
    display: inline-flex;
    align-items: center;
    gap: 8px; /* etwas Luft zwischen Checkbox & Text */
    font-size: 12px; /* oder deine gewünschte mobile Größe */
    position: relative;
    top: 10px; /* oder mehr/weniger je nach Look */
  }
  .field-password-toggle.pmpro_btn{background:transparent!important;}

  .login-remember input[type="checkbox"] {
    transform: translateY(-2px); /* optionaler Finetune, je nach Browser */
  }

/* Das gesamte Wrapper-Element: zwing auf Block und raus aus dem Flex */
.pmpro_form_field-password-toggle,
.pmpro_form_field-password-toggle .pmpro_btn {
  display: block !important;
  float: none !important;
  clear: both !important;
  width: 100% !important;
  margin: 8px 0 16px 0 !important;
  text-align: left !important;
}
label.pmpro_form_field-password-toggle {
  display: block !important;
  float: none !important;
  clear: both !important;
  width: 100% !important;
}
p.pmpro_level_name_text{line-height:1.2!important;}
p.pmpro_level_name_text:after{content: " Das Paket enthält:"}

.pmpro_card_title.pmpro_font-large {
  font-size: 24px;
}
#pmpro_account-membership-1 .pmpro_card_title.pmpro_font-large:before {
  content: "Paket: ";
  display: inline;
  margin-right: 0.3em;
  color: var(--gwl-hellrot);
  }
  
  
.pmpro #pmpro_user_fields .pmpro_form_field-password:has(.pmpro_form_field-password-toggle), .pmpro_section #loginform .login-password {
display: block!important;
}

.pmpro
.pmpro_form_field-password-toggle button, .pmpro_form_field-password-toggle button:hover, .pmpro_form_field-password-toggle button:focus, .pmpro_form_field-password-toggle button:active {
background: transparent!important;
}

.pmpro .pmpro_form_field-password-toggle .pmpro_icon-eye {
display: unset;
position:relative;
top:5px;
margin-right:5px;
background:transparent!important;
}

.pmpro
#pmpro_user_fields .pmpro_form_field-password:has(.pmpro_form_field-password-toggle) input {
grid-area: input;
background-color: transparent!important;
}
.pmpro_section #loginform .login-password input {width:100%;}

.pmpro input[type="text"],
.pmpro input[type="email"],
.pmpro input[type="password"],
.pmpro input[type="search"] {
  color: #000 !important;
}

.pmpro_table,
.pmpro_table th,
.pmpro_table td,
.pmpro_table tr {
  font-size: 24px;
  line-height: 0.7;
  padding: 0.5em 0.75em;
  vertical-align: top;
  border:none;  border: none !important;
  border-bottom: none !important;
  outline: none !important;
  box-shadow: none !important;
}

.pmpro_tag-success {
  background: none;
  padding: 0;
  border-radius: 0;
  border:none!important;
  color: #00C040 !important;
  text-shadow: 2px 2px 3px rgba(0, 0, 0, 0.4); /* optional für Kontrast */
  font-weight: bold;
  font-size: 1.1em;
  font-weight: normal;
position: relative;
top: -1px;
text-align: left;
}

.pmpro_table td span.pmpro_status.paid {
  all: unset;
  color: #00C040;
  font-weight: bold;
  font-size: 1.1em;
  text-shadow: 2px 2px 3px rgba(0,0,0,0.4);
  vertical-align: middle;
  line-height: 1.2;
}

.pmpro a, 
.pmpro button, 
.pmpro span, 
.pmpro .pmpro_print_button {
  background: transparent !important;
  background-color: transparent !important;
}
.pmpro *, .pmpro *::before, .pmpro *::after {
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
}
.pmpro_btn-plain.pmpro_btn-print {
  justify-content: flex-start !important;
  text-align: left !important;
  display: flex !important; /* falls noch nicht gesetzt */
}
.pmpro_card_actions {
  padding: 0 !important;
  margin: 0 0 25px 0 !important;
  min-height: auto !important;
  height: auto !important;
  line-height: 1 !important;
}

.pmpro_card_actions span {
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1 !important;
  display: inline !important;
}

/* Sichtbare Inputs mit weißem Hintergrund */
.pmpro_form_fields input,
.pmpro_form_fields textarea,
.pmpro_form_fields select {
  background-color: #fff !important;
  color: #000 !important;
}

/* Große Überschrift oben */
#pmpro_change_password h2.pmpro_form_heading {
  font-size: var(--e-global-typography-primary-font-size) !important;
}
#pmpro_change_password .pmpro_section label {
  font-size: var(--e-global-typography-secondary-font-size) !important;
}

.pmpro_card_title, 
.pmpro_member_display_name, 
.pmpro_section h2, 
.pmpro_section h3, 
.pmpro_section label, 
.pmpro_section input, 
.pmpro_section textarea, 
.pmpro_section select, 
.pmpro_section p {
font-family: var(--e-global-typography-primary-font-family) !important;
font-size: var(--e-global-typography-secondary-font-size);
font-weight: var(--e-global-typography-primary-font-weight) !important;
line-height: var(--e-global-typography-primary-line-height) !important;
letter-spacing: var(--e-global-typography-primary-letter-spacing) !important;
text-transform: var(--e-global-typography-primary-text-transform) !important;
color: var(--e-global-color-primary) !important;
}


input[type="text"],
input[type="email"],
input[type="password"],
input[type="checkbox"],
textarea,
select {
  display: inline-block !important;
  opacity: 1 !important;
  background: #fff !important;
  border: 1px solid #ccc !important;
  color: #000 !important;
}



@media print {

header,
.site-header,
.elementor-location-header {
  display: none !important;
}

footer,
.elementor-location-footer {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  overflow: hidden !important;
  margin: 0 !important;
  padding: 0 !important;
}
  /* ALLE Schrift schwarz, KEINE Schatten */
  * {
    color: #000 !important;
    text-shadow: none !important;
    box-shadow: none !important;
    background: none !important;
    border: none !important;
  }

  /* Grüne „bezahlt“-Schrift neutralisieren */
  .status-paid,
  .status-bezahlt {
    color: #000 !important;
    background: none !important;
    font-weight: bold !important;
  }

  /* Unnötige Navigationslinks ausblenden */
  a[href*="membership-orders"],
  a[href*="kontodaten"],
  .pmpro_actions_nav,
  .pmpro_card_actions {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    overflow: hidden !important;
  }

  /* Kein Seitenumbruch nach Titel */
  h2, h3, h4 {
    page-break-after: avoid;
  }

  /* Überschriften nicht übergroß darstellen */
  h1, h2, h3 {
    font-size: 16pt !important;
  }

  /* Link-Texte OHNE URLs anzeigen */
  a[href]:after {
    content: "" !important;
  }

  /* Abstände neutralisieren */
  .pmpro_invoice,
  .pmpro_order_single,
  .pmpro_section {
    margin: 0 0 1em 0 !important;
    padding: 0 !important;
  }
}