 /* Base Styles */
 :root {
     --primary-color: #00387B;
     --primary-dark: #002149;
     --primary-light: #2a4ca0;
     --accent-color: #ff9800;
     --text-color: #333333;
     --text-light: #666666;
     --background-color: #ffffff;
     --background-light: #f5f7fa;
     --border-color: #e0e0e0;
     --shadow-color: rgba(0, 0, 0, 0.1);
     --success-color: 76, 175, 80;
     --error-color: 244, 67, 54;
     --border-radius: 8px;
     --transition-speed: 0.3s;
     --alert-danger-bg: var(--error-color);
     --alert-success-bg: var(--success-color);
     --background-login-rgb: 245, 245, 245;
     --header-height: 95px;
     --footer-height: 63px;
     --default-font-size: 22px;
 }

 * {
     margin: 0;
     padding: 0;
     box-sizing: border-box;
 }

 body {
     font-family: Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
     color: var(--text-color);
     line-height: 1.6;
     background-color: #00387bc9;
     min-height: 100vh;
     display: flex;
     flex-direction: column;
     overflow: hidden;
     font-size: var(--default-font-size);
 }

 .container {
     width: 100%;
     margin: 0 auto;
     padding: 0 20px;
 }

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

 a:hover {
     color: var(--primary-light);
 }

 /* Header Styles */
 header {
     /* background-color: var(--background-color); */
     /* background-color: #ffffff12; */
     background-color: #fffffff7;
     box-shadow: 0 2px 10px var(--shadow-color);
     position: fixed;
     z-index: 90;
     width: 100%;
     height: var(--header-height);
 }

 .header-container {
     display: flex;
     justify-content: space-between;
     align-items: center;
     padding: 15px 20px;
     height: var(--header-height);
 }

 .logo img {
     height: 40px;
     width: auto;
     vertical-align: middle;
 }

 nav {
     display: flex;
     align-items: center;
 }

 .main-nav {
     display: flex;
     list-style: none;
     margin-right: 30px;
 }

 .main-nav li {
     margin: 0 15px;
 }

 .main-nav a {
     color: var(--text-color);
     /* color: var(--primary-color); */
     padding: 5px 0;
     position: relative;
     font-size: calc(var(--default-font-size) - 2px);
 }

 .main-nav a::after {
     content: '';
     position: absolute;
     bottom: 0;
     left: 0;
     width: 0;
     height: 2px;
     background-color: var(--primary-color);
     transition: width var(--transition-speed);
 }

 .main-nav a:hover::after {
     width: 100%;
 }

 .auth-buttons {
     display: flex;
     align-items: center;
 }

 .auth-buttons a {
     margin-left: 15px;
 }

 .auth-buttons a.active {
     color: var(--primary-color);
 }

 .btn-register {
     background-color: var(--primary-color);
     color: white !important;
     padding: 8px 20px;
     border-radius: var(--border-radius);
     transition: background-color var(--transition-speed);
 }

 .btn-register:hover {
     background-color: var(--primary-dark);
 }

 .mobile-menu-toggle {
     display: none;
     background: none;
     border: none;
     cursor: pointer;
 }

 .mobile-menu-toggle span {
     display: block;
     width: 25px;
     height: 3px;
     background-color: var(--text-color);
     margin: 5px 0;
     transition: all var(--transition-speed);
 }

 /* Main Content Styles */
 main {
     flex: 1;
     display: flex;
     align-items: stretch;
     position: relative;
     /* Für die absolute Positionierung der Kinder */
     margin-top: var(--header-height);
     height: calc(100vh - var(--header-height) - var(--footer-height));
     overflow: hidden;
 }

 .login-container {
     display: flex;
     margin: 0 auto;
     width: 100%;
     border-radius: 0;
     /* Optional: Entfernt Rundungen für vollflächiges Design */
     overflow: hidden;
     box-shadow: 0 0 50px rgba(0, 0, 0, 0.2);
     background-color: transparent;
     position: relative;
 }

 .login-image {
     flex: none;
     /* Ändert von flex: 0.7 */
     /* background-image: url('login.jpg'); */
     background-size: cover;
     background-position: center;
     display: flex;
     align-items: center;
     justify-content: center;
     position: fixed;
     width: 40%;
     height: calc(100vh - var(--header-height) - var(--footer-height));
     top: var(--header-height);
     left: 0;
 }

 .login-image .overlay {
     position: absolute;
     top: 0;
     left: 0;
     right: 0;
     bottom: 0;
     background: linear-gradient(135deg, rgba(26, 59, 137, 0.8) 0%, rgba(18, 42, 97, 0.9) 100%);
     display: flex;
     align-items: center;
     justify-content: center;
     padding: 40px;
 }

 .quote {
     color: white;
     text-align: center;
     max-width: 100%;
 }

 .quote h2 {
     font-family: 'Montserrat', sans-serif;
     font-size: calc(var(--default-font-size) + 20px);
     margin-bottom: 15px;
     font-weight: 600;
 }

 .quote p {
     font-size: calc(var(--default-font-size) + 4px);
     opacity: 0.9;
 }

 .login-form-container {
     position: absolute;
     left: 40%;
     width: 60%;
     height: calc(100% - var(--footer-height));
     overflow-y: auto;
     padding: 0;
     display: flex;
     align-items: flex-start;
     /* Standardmäßig oben ausrichten */
 }


 .login-form-container>div {
     width: 100%;
     padding: 40px 0;
     margin: auto 10px;
 }

 .login-form-wrapper,
 .ui.card {
     max-width: 800px;
     width: 100%;
     margin: 0 auto;
     /* Horizontale Zentrierung */
     padding: 25px;
     background: rgba(var(--background-login-rgb), 0.95);
     border-radius: var(--border-radius);
 }

 h1 {
     font-size: calc(var(--default-font-size) + 20px);
     margin-bottom: 10px;
     color: var(--primary-color);
 }

 .login-subtitle {
     color: var(--text-light);
     margin-bottom: 30px;
 }

 .form-group {
     margin-bottom: 20px;
 }

 .form-group label {
     display: block;
     margin-bottom: 8px;
     font-weight: 500;
     font-size: calc(var(--default-font-size) - 2px);
     /* 14px; */
 }

 .input-with-icon {
     position: relative;
 }

 .input-with-icon i {
     position: absolute;
     left: 15px;
     top: 50%;
     transform: translateY(-50%);
     color: var(--text-light);
 }

 .input-with-icon input {
     width: 100%;
     padding: 14px 15px 14px 50px;
     border: 1px solid var(--border-color);
     border-radius: var(--border-radius);
     font-size: calc(var(--default-font-size));
     transition: border-color var(--transition-speed), box-shadow var(--transition-speed);
 }

 .input-with-icon input:focus {
     outline: none;
     border-color: var(--primary-color);
     box-shadow: 0 0 0 3px rgba(26, 59, 137, 0.1);
 }


 .password-info {
     font-size: calc(var(--default-font-size) - 4px);
     padding: 0px 14px;
     opacity: 0.4;
 }

 .info-box p {
     font-size: calc(var(--default-font-size) - 4px);
 }

 .toggle-password {
     position: absolute;
     right: 40px;
     top: 50%;
     transform: translateY(-50%);
     background: none;
     border: none;
     color: var(--text-light);
     cursor: pointer;
     padding: 5px;
     z-index: 10;
 }

 .form-options {
     display: flex;
     justify-content: space-between;
     align-items: center;
     margin-bottom: 25px;
     font-size: calc(var(--default-font-size) - 2px);
     /* 14px */
 }

 .remember-me {
     display: flex;
     align-items: center;
 }

 .remember-me input {
     margin-right: 8px;
 }

 .forgot-password {
     color: var(--primary-color);
 }

 .btn-login {
     width: 100%;
     padding: 14px;
     background-color: var(--primary-color);
     color: white;
     border: none;
     border-radius: var(--border-radius);
     font-size: calc(var(--default-font-size));
     font-weight: 500;
     cursor: pointer;
     transition: background-color var(--transition-speed);
 }

 .btn-login:hover {
     background-color: var(--primary-dark);
 }

 .login-divider {
     text-align: center;
     margin: 25px 0;
     position: relative;
 }

 .login-divider::before {
     content: '';
     position: absolute;
     top: 50%;
     left: 0;
     right: 0;
     height: 1px;
     background-color: var(--border-color);
 }

 .login-divider span {
     position: relative;
     background: rgb(235, 237, 240);
     padding: 0 15px;
     color: var(--text-light);
     font-size: calc(var(--default-font-size) - 2px);
 }

 .social-login {
     display: flex;
     flex-direction: column;
     gap: 15px;
     margin-bottom: 25px;
 }

 .btn-social {
     display: flex;
     align-items: center;
     justify-content: center;
     padding: 14px;
     border: 1px solid var(--border-color);
     border-radius: var(--border-radius);
     background-color: white;
     font-size: calc(var(--default-font-size) - 4px);
     cursor: pointer;
     transition: background-color var(--transition-speed);
 }

 .btn-social i {
     margin-right: 10px;
     font-size: calc(var(--default-font-size) - 2px);
 }

 .btn-google i {
     color: #DB4437;
 }

 .btn-microsoft i {
     color: #00A4EF;
 }

 .btn-social:hover {
     background-color: var(--background-light);
 }

 .register-prompt {
     text-align: center;
     margin-top: 20px;
     font-size: calc(var(--default-font-size) - 2px);
     animation: fadeIn 1.3s ease-in-out;
 }

 .register-prompt a {
     font-weight: 500;
 }

 /* Terms Checkbox Styling */
 .terms-container {
     margin: 45px 0;
 }

 .terms-item {
     margin-bottom: 15px;
 }

 .terms-item label {
     display: flex;
     align-items: flex-start;
     font-size: var(--default-font-size);
     color: var(--text-color);
     cursor: pointer;
     user-select: none;
 }

 input[type="checkbox"] {
     margin-right: 10px;
     margin-top: 3px;
     -webkit-appearance: none;
     -moz-appearance: none;
     appearance: none;
     width: 25px;
     height: 25px;
     background-color: white;
     border: 1px solid var(--border-color);
     border-radius: 4px;
     outline: none;
     flex-shrink: 0;
     position: relative;
     transition: border-color var(--transition-speed);
 }

 input[type="checkbox"]:checked {
     background-color: white;
     border-color: var(--primary-color);
     border-width: 1px;
 }

 input[type="checkbox"]:checked::after {
     content: '';
     position: absolute;
     left: 8px;
     top: 1px;
     width: 7px;
     height: 15px;
     border: solid var(--primary-color);
     border-width: 0 2px 2px 0;
     transform: rotate(45deg);
 }

 input[type="checkbox"]:focus {
     border-color: var(--primary-color);
     box-shadow: 0 0 0 3px rgba(26, 59, 137, 0.1);
 }

 .terms-item a {
     color: var(--primary-color);
     font-weight: 500;
     text-decoration: none;
     transition: color var(--transition-speed);
     margin-right: 4px;
     /* Add space after links */
 }

 .terms-item a:hover {
     color: var(--primary-light);
     text-decoration: underline;
 }

 .terms-item .error-message {
     color: rgb(var(--error-color));
     font-size: 12px;
     margin-top: 5px;
     display: block;
 }


 /* Footer Styles */
 footer {
     position: fixed;
     width: 100%;
     background-color: var(--background-color);
     padding: 20px 0;
     border-top: 1px solid var(--border-color);
     font-size: 14px;
     color: var(--text-light);
     z-index: 99;
     bottom: 0;
     height: var(--footer-height);
 }

 .footer-container {
     display: flex;
     justify-content: space-between;
     align-items: center;
 }

 .footer-links a {
     margin-left: 20px;
     color: var(--text-light);
 }

 nav .footer-links-mobile {
     display: none;
 }

 /* Message styles */
 .message {
     padding: 14px 15px;
     margin-bottom: 20px;
     border-radius: var(--border-radius);
     font-size: 14px;
     animation: fadeIn 0.3s ease-in-out;
 }

 .message.error {
     background-color: rgba(244, 67, 54, 0.1);
     border-left: 4px solid rgb(var(--error-color));
     color: rgb(var(--error-color));
 }

 .message.success {
     background-color: rgba(76, 175, 80, 0.1);
     border-left: 4px solid rgb(var(--success-color));
     color: rgb(var(--success-color));
 }

 .login-form-wrapper-spacer {
     height: 20px;
 }

 body.menu-open {
     overflow: hidden;
 }

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

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

 @media (max-width:1200px) {
     .text {
         hyphens: auto;
         -webkit-hyphens: auto;
         -ms-hyphens: auto;
         language: de;
         word-break: normal;
     }

 }

 @media (max-width: 992px) {
     body {
         overflow: auto;
     }

     .login-container {
         flex-direction: column;
         margin: 0 0;
     }

     .login-form-wrapper {
         margin: 0 auto;
     }

     .login-image {
         position: relative;
         width: 100%;
         height: 400px;
         min-height: unset;
         top: 0;
     }

     .login-form-container {
         position: relative;
         left: 0;
         width: 100%;
         margin-top: 0;
         margin-bottom: var(--footer-height);
     }

     main {
         flex-direction: column;
         overflow-y: auto;
     }

     .quote h2 {
         font-size: calc(var(--default-font-size) + 10px);
     }

     .quote p {
         font-size: calc(var(--default-font-size) + 2px);
     }

     .cyber-grid {
         width: 100% !important;
         left: 0 !important;
     }

 }

 @media (max-width: 768px) {

     .main-nav,
     .auth-buttons {
         display: none;
     }

     .mobile-menu-toggle {
         display: block;
     }

     /* Mobile Navigation wenn aktiv */
     nav.active {
         position: absolute;
         top: 70px;
         left: 0;
         right: 0;
         background-color: var(--background-color);
         display: flex;
         flex-direction: column;
         padding: 20px;
         box-shadow: 0 5px 10px var(--shadow-color);
         border-top: 1px solid var(--border-color);
     }

     nav.active .main-nav {
         display: flex;
         flex-direction: column;
         margin-right: 0;
         margin-bottom: 20px;
     }

     nav.active .main-nav li {
         margin: 10px 0;
     }

     nav.active .auth-buttons {
         display: flex;
         flex-direction: column;
         align-items: flex-start;
         width: 100%;
     }

     nav.active .auth-buttons a {
         margin: 5px 0;
         width: 100%;
         text-align: center;
     }

     .login-form-container {
         padding: 30px 20px;
     }

     /* Verbesserte Passwortfeld-Darstellung auf mobilen Geräten */
     .input-with-icon .toggle-password {
         padding: 10px;
     }

     .footer-container {
         flex-direction: column;
         gap: 15px;
         text-align: center;
     }

     .footer-links a {
         margin: 0 10px;
     }

     .footer-links {
         display: none;
     }

     nav .footer-links-mobile {
         display: block;
         margin-top: 20px;
         padding-top: 20px;
         border-top: 1px solid rgba(0, 0, 0, 0.1);
         text-align: center;
     }

     nav .footer-links-mobile a {
         display: block;
         padding: 10px 0;
         color: #333;
         text-decoration: none;
         font-size: 16px;
     }

 }

 @media (max-width: 550px) {

     .overlay .text,
     .overlay p {
         font-size: smaller;
     }
 }

 @media (max-width: 480px) {
     .login-image {
         display: none;
     }

     .quote h2 {
         font-size: 22px;
     }

     .quote p {
         font-size: 14px;
     }

     h1 {
         font-size: 24px;
     }

     .login-subtitle,
     .terms-item label {
         font-size: 14px;
     }

     .form-group {
         margin-bottom: 15px;
     }

     .input-with-icon input {
         padding: 10px 15px 10px 40px;
         font-size: 15px;
     }

     .input-with-icon i {
         left: 12px;
     }

 }


 .background-video {
     position: absolute;
     top: 0;
     left: 0;
     width: 100%;
     height: 100%;
     object-fit: cover;
     z-index: 0;
 }


 /* Alert Styles */
 .alert {
     padding: 14px 15px;
     border-radius: var(--border-radius);
     margin-bottom: 20px;
 }

 .alert,
 .alert a {
     font-size: calc(var(--default-font-size) - 4px);
 }

 .alert i {
     margin-right: 10px;
     margin-top: 3px;
 }

 .alert-warn {
     background-color: rgba(255, 152, 0, 0.1);
     border-left: 4px solid #ff9800;
     color: #e68a00;
 }

 .alert-danger {
     background-color: rgba(var(--error-color), 0.1);
     border-left: 4px solid rgb(var(--error-color));
     color: rgb(var(--error-color));
 }

 .alert-success {
     background-color: rgba(var(--success-color), 0.1);
     border-left: 4px solid rgb(var(--success-color));
     color: rgb(var(--success-color));
 }


 /* Message Styles */
 .message {
     padding: 14px 15px;
     margin-bottom: 20px;
     border-radius: var(--border-radius);
     font-size: 14px;
     animation: fadeIn 0.3s ease-in-out;
 }

 .message.error {
     background-color: rgba(244, 67, 54, 0.1);
     border-left: 4px solid rgb(var(--error-color));
     color: rgb(var(--error-color));
 }

 .message.success {
     background-color: rgba(76, 175, 80, 0.1);
     border-left: 4px solid rgb(var(--success-color));
     color: rgb(var(--success-color));
 }


 /* Scrollbar-Styling für login-form-container */
 .login-form-container::-webkit-scrollbar {
     width: 10px;
 }

 .login-form-container::-webkit-scrollbar-track {
     background: rgba(245, 247, 250, 0.5);
     border-radius: var(--border-radius);
 }

 .login-form-container::-webkit-scrollbar-thumb {
     background: rgba(0, 56, 123, 0.5);
     border-radius: var(--border-radius);
     border: 2px solid rgba(245, 247, 250, 0.5);
 }

 .login-form-container::-webkit-scrollbar-thumb:hover {
     background: var(--primary-color);
 }

 /* Firefox-Scrollbar */
 .login-form-container {
     scrollbar-width: thin;
     scrollbar-color: rgba(0, 56, 123, 0.5) rgba(245, 247, 250, 0.5);
 }

 /* IE und Edge (alte Versionen) */
 .login-form-container {
     -ms-overflow-style: auto;
 }

 /* Verbesserte Scrollverhalten */
 .login-form-container {
     scroll-behavior: smooth;
 }

 /* Mobile Menu Styles */
 @media screen and (max-width: 768px) {
     nav {
         display: none;
         position: fixed;
         top: var(--header-height);
         left: 0;
         width: 100%;
         height: calc(100vh - var(--header-height));
         background: white;
         z-index: 1000;
         padding: 20px;
     }

     nav.active {
         display: block;
     }

     .main-nav {
         flex-direction: column;
         width: 100%;
     }

     .main-nav li {
         margin: 10px 0;
         width: 100%;
         text-align: center;
     }

     .auth-buttons {
         margin-top: 20px;
         text-align: center;
     }

     .mobile-menu-toggle {
         display: block;
         background: none;
         border: none;
         padding: 10px;
         cursor: pointer;
     }

     .mobile-menu-toggle span {
         display: block;
         width: 25px;
         height: 3px;
         background: #333;
         margin: 5px 0;
         transition: all 0.3s ease;
     }

     /* Prevent scrolling when menu is open */
     body.menu-open {
         overflow: hidden;
     }
 }

 /* Desktop Menu Styles */
 @media screen and (min-width: 769px) {
     .mobile-menu-toggle {
         display: none;
     }
 }


 /** moved from legacy */
 .content p {
     margin: 20px 0;
 }