/* Bestehende Styles beibehalten, ergänze darunter: */
body {
  margin: 0;
  font-family: Arial, sans-serif;
  background-color: #f4f4f4;
  color: #333;
}

header {
  background-color: #b30000;
  color: white;
  padding: 1rem;
  text-align: center;
}
.top-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #e60000;
  padding: 0.5rem 1rem;
  flex-wrap: wrap;
}

.nav-left {
  display: flex;
  align-items: center;
}

.menu-icons {
  text-align: left;
  color: white; /* ggf. anpassen */
}

.nav-right {
  display: flex;
  align-items: center;
}

.top-nav a {
  color: white;
  text-decoration: none;
  margin-left: 1rem;
  font-weight: bold;
}

.top-nav a:hover {
  text-decoration: underline;
}

.top-nav .nav-link {
  color: white;
  text-decoration: none;
  margin-left: 1rem;
  font-weight: bold;
}

.top-nav .nav-link:hover {
  text-decoration: underline;
}

.container {
  display: flex;
  flex-direction: row;
  min-height: calc(100vh - 160px); /* passt sich Header + Nav an */
}

.sidebar {
  background-color: #fff;
  width: 220px;
  padding: 1rem;
  border-right: 1px solid #ccc;
}

.sidebar ul {
  list-style: none;
  padding: 0;
}

.sidebar li {
  margin: 0.5rem 0;
}

.sidebar li.level_0{
	position: relative;
}

.sidebar li.level_0.has-submenu .submenu {
	display: none;
}

.sidebar li.level_0.has-submenu.expanded .submenu {
	display: block;
}

.sidebar li.level_0.has-submenu .menu-toggle {
	cursor: pointer;
	display: inline-block;
	margin-left: 0.5rem;
	padding: 0 0.25rem;
	color: #b30000;
}

.sidebar li.level_0.has-submenu .menu-toggle i {
	font-size: 0.8rem;
	transition: transform 0.3s ease;
}

.sidebar li.level_0.has-submenu.expanded .menu-toggle i {
	transform: rotate(180deg);
}

.sidebar li.level_1{
	padding-left:1rem;
}

.sidebar .submenu {
	position: relative;
	background: #fff;
	border-left: 2px solid #b30000;
	margin: 0.5rem 0 0.5rem 1rem;
	padding: 0;
	min-width: 200px;
	list-style: none;
}

.sidebar .submenu li {
	margin: 0;
	padding: 0;
}

.sidebar .submenu li a {
	padding: 0.5rem 1rem;
	display: block;
	border-radius: 0;
}

.sidebar .submenu li a:hover {
	background-color: #f8f9fa;
	color: #b30000;
}

.sidebar a {
  color: #b30000;
  text-decoration: none;
  font-weight: bold;
}

.sidebar a:hover {
  text-decoration: underline;
}

.content {
  flex: 1;
  padding: 2rem;
}

/* Responsive Anpassung */
@media (max-width: 768px) {
  .container {
    flex-direction: column;
  }

  .sidebar {
    width: 100%;
    border-right: none;
    border-bottom: 1px solid #ccc;
  }
}

.layout {
  display: flex;
  flex-direction: row;
  min-height: calc(100vh - 160px); /* abhängig von header + nav */
}

.sidebar {
  background-color: #fff;
  width: 220px;
  padding: 1rem;
  border-right: 1px solid #ccc;
}

.sidebar ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.sidebar li {
  margin: 0.5rem 0;
}

.sidebar a {
  color: #b30000;
  text-decoration: none;
  font-weight: bold;
}

.sidebar a:hover {
  text-decoration: underline;
}

.content {
  flex: 1;
  padding: 2rem;
}

/* Responsive Anpassung */
@media (max-width: 768px) {
  .layout {
    flex-direction: column;
  }

  .sidebar {
    width: 100%;
    border-right: none;
    border-bottom: 1px solid #ccc;
  }
}

.modal{
	display:none;
}
/* -----------------------------------------------------------
   LOGIN-FORMULAR (id="login_form")
   Modernes Card-Design, farblich an Feuerwehr-Rot angepasst
   ----------------------------------------------------------- */

/* Grundfläche des Formulars */
#login_form{
    max-width:420px;             /* Kartenbreite */
    margin:3rem auto 2rem;       /* Zentriert */
    padding:2.5rem 2rem 2rem;
    background:#fff;
    border-radius:12px;
    box-shadow:0 12px 28px rgba(0,0,0,.20);
    font-family:'Segoe UI',Roboto,'Open Sans',sans-serif;
}

/* Überschrift (<h2> Anmelden) im Content-Bereich oberhalb des Forms */
.content > h2{
    text-align:center;
    color:#b30000;
    margin:2rem auto 1.2rem;
    font-size:1.8rem;
}

/* Labels */
#login_form label{
    display:block;
    margin:.8rem 0 .35rem;
    font-weight:600;
    color:#333;
}

/* Eingabefelder */
#login_form input[type="text"],
#login_form input[type="password"]{
    width:100%;
    padding:.7rem .8rem;
    border:1px solid #ccc;
    border-radius:6px;
    font-size:.95rem;
    transition:border-color .15s,box-shadow .15s;
	box-sizing: border-box;
}
#login_form input:focus{
    border-color:#b30000;
    box-shadow:0 0 0 2px rgba(179,0,0,.15);
    outline:none;
}

/* Checkbox-Zeile „Angemeldet bleiben“  */
#login_form .checkbox label{
    display:flex;
    align-items:center;
    gap:.5rem;
    font-size:.9rem;
}
#login_form .checkbox input{
    accent-color:#b30000;             /* modernes Browser-Feature */
}

/* Login-Button */
#btn_login{
    display:block;
    width:100%;
    margin-top:1.6rem;
    padding:.8rem;
    background:#b30000;
    color:#fff;
    border:none;
    border-radius:6px;
    font-size:1rem;
    font-weight:700;
    cursor:pointer;
    transition:background .15s,transform .1s;
}
#btn_login:hover{
    background:#a00000;
}
#btn_login:active{
    transform:scale(.98);
}

/* Fehlermeldungsbox (wird von Admidio/JS eingeblendet) */
#login_form .form-alert{
    margin-top:1rem;
    background:#ffe5e5;
    border:1px solid #ffb3b3;
    color:#900;
    padding:.75rem;
    border-radius:6px;
    font-size:.9rem;
}

/* Link „Passwort vergessen“ unter dem Formular */
#login_forgot_password_link{
    text-align:center;
    margin-top:1.2rem;
}
#login_forgot_password_link a{
    color:#b30000;
    text-decoration:none;
    font-size:.9rem;
}
#login_forgot_password_link a:hover{
    color:#e60000;
}

/* Bootstrap-Klassen (falls geladen) leicht anpassen, 
   damit die Spalten-Abstände auf schmalen Bildschirmen nicht zu groß werden */
@media(max-width:576px){
    #login_form .form-group.row{
        margin-left:0;
        margin-right:0;
    }
    #login_form .col-sm-3,
    #login_form .offset-sm-3,
    #login_form .col-sm-9{
        padding-left:0;
        padding-right:0;
        max-width:100%;
        flex:0 0 100%;
    }
    #btn_login{
        margin-left:0;
    }
}

/* ---------- 8 | Footer / Imprint ------------------------------ */

#imprint{
    margin:3rem 0 1.5rem;
    font-size:.8rem;
    text-align:center;
    color:#666;
}
#imprint a{
    color:var(--fvo-red-dark);
}
#imprint a:hover{
    text-decoration:underline;
}

/* ------- Buttons ------------------------*/

.btn-primary{
    background:var(--fvo-red);border:none;border-radius:var(--fvo-radius);
    padding:.65rem 1.4rem;font-weight:700;transition:background .15s,transform .1s;
	text-decoration:none;
	color: #fff;
}
.btn-primary:hover{background:var(--fvo-red-dark);}
.btn-primary:active{transform:scale(.98);}


.btn-secondary{
    background:#666;color:#fff;border:none;border-radius:var(--fvo-radius);
    padding:.55rem 1.1rem;font-weight:600;
}
.btn-secondary:hover{background:#4d4d4d;}


/* =========================================================
   1 | TABS (Reiter)
   ========================================================= */

#tabs{
	margin-block-end: 0.2em;
    display:flex;flex-wrap:wrap;list-style:none;padding:0;
}
#tabs .nav-item{margin-right:.25rem;}
#tabs .nav-link{
    display:block;padding:.65rem 1.4rem;font-family:var(--fvo-font);font-weight:600;
    color:var(--fvo-red);background:#fff;
	/*border:1px solid transparent;*/
	border:1px solid var(--fvo-red);
    border-radius:var(--fvo-radius) var(--fvo-radius) 0 0;
    transition:background .15s,color .15s,border-color .15s;
    position:relative;top:2px;
}
#tabs .nav-link:not(.active):hover{
    background:#fff6f6;
	border-color:var(--fvo-red);
	color:var(--fvo-red-dark);
}
#tabs .nav-link.active{
    background:#fff;
	border:1px solid var(--fvo-red);
	border-bottom-color:#fff!important;
    color:var(--fvo-red-dark);font-weight:700;top:0;z-index:2;
}

#accordion_modules{
	display:none;
}

/* =========================================================
   2 | TAB-INHALT (weiße Karte)
   ========================================================= */

#tab-content{
    background:#fff;border:1px solid var(--fvo-red);
    border-radius:0 var(--fvo-radius) var(--fvo-radius) var(--fvo-radius);
    padding:1.8rem 1.4rem 1.4rem;box-shadow:0 8px 24px rgba(0,0,0,.08);
    margin-top:-2px;
}
main.content{padding-bottom:3rem;}
@media(max-width:768px){
    #preferences-tab-content{padding:1.4rem 1rem;}
}

/* =========================================================
   3 | ACCORDION (Karten)
   ========================================================= */

.accordion .card{
    border:1px solid var(--fvo-gray-border);border-radius:var(--fvo-radius);
    margin-bottom:1.2rem;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,.05);
}
.accordion .card-header{
    padding:.8rem 1rem;background:var(--fvo-gray-light);font-size:.97rem;
    font-weight:600;cursor:pointer;user-select:none;display:flex;align-items:center;
    gap:.6rem;transition:background .15s;
}
.accordion .card-header i{color:var(--fvo-red);}
.accordion .card-header[aria-expanded="false"]:hover{background:#fff2f2;}
.accordion .card-header[aria-expanded="true"]{background:var(--fvo-red);color:#fff;}
.accordion .card-header[aria-expanded="true"] i{color:#fff;}

.accordion .collapse{ /*display:none;*/ transition:height .25s ease;}
.accordion .collapse.show{display:block;border-top:1px solid var(--fvo-gray-border);}
.accordion .card-body{padding:1.5rem 1rem 1.2rem;background:#fff;}

/* =========================================================
   4 | FORMULARE in Cards – Zwei-Spalten-Layout
   ========================================================= */

/* --- Grundraster ------------------------------------------------ */
.form-preferences .form-group.row{
    display:flex;align-items:flex-start;margin-bottom:1.15rem;
}
.form-preferences .form-group.row > .control-label{
    flex:0 0 35%;max-width:20%;padding-right:.75rem;
    font-weight:600;font-size:.95rem;margin:0;color:#333;
}
.form-preferences .form-group.row > .col-sm-9,
.form-preferences .form-group.row > .offset-sm-3{
    flex:0 0 65%;max-width:65%;
}

/* Checkbox-Zeilen (haben kein Label links) */
.form-preferences .form-group.row .checkbox{
    display:flex;align-items:center;gap:.45rem;
}
.form-preferences .checkbox input{accent-color:var(--fvo-red);}

/* Eingabefelder & Select */
.form-preferences .form-control{
    font-size:.95rem;padding:.55rem .75rem;border-radius:var(--fvo-radius);
    border:1px solid #ccc;box-sizing:border-box;
    transition:border-color .15s,box-shadow .15s;
}
.form-preferences .form-control:focus{
    border-color:var(--fvo-red);box-shadow:0 0 0 2px rgba(179,0,0,.15);
    outline:none;
}

/* Hilfe-Text rechts unter dem Eingabefeld */
.form-preferences .help-block{font-size:.85rem;margin-top:.3rem;color:#555;}

/* Statikzeilen */
.form-control-static{
    padding:.55rem .75rem;background:var(--fvo-gray-light);
    border-radius:var(--fvo-radius);
}


.form-notice{
    background:#deffda;border:1px solid #66da58;border-radius:var(--fvo-radius);
    padding:.75rem .9rem;font-size:.85rem;margin-bottom:1rem;color:#1aa609;
}

/* Pflicht-Hinweis & Alerts */
.form-required-notice,
.form-alert{
    background:#ffe5e5;border:1px solid #ffb3b3;border-radius:var(--fvo-radius);
    padding:.75rem .9rem;font-size:.85rem;margin-bottom:1rem;color:#900;
}
.form-alert{display:none;}

/* Fortschrittsbalken */
.progress{
    height:1rem;background:var(--fvo-gray-light);
    border-radius:var(--fvo-radius);overflow:hidden;
}
.progress-bar{background:var(--fvo-red);}

/* --- Mobile: Spalten umbrechen --------------------------------- */
@media(max-width:575.98px){
    .form-preferences .form-group.row{flex-direction:column;}
    .form-preferences .form-group.row > .control-label,
    .form-preferences .form-group.row > .col-sm-9,
    .form-preferences .form-group.row > .offset-sm-3{
        max-width:100%;flex:0 0 100%;padding-right:0;
    }
    /* Offset bei Buttons entfernen */
    .btn.offset-sm-3{margin-left:0 !important;}
}

/* -----------Widgets -------------------------*/
.widget-container {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin: 1rem 0;
}

/* Header-Streifen */
.widget-header {
  background-color: #007bff;
  color: white;
  padding: 0.75rem 1rem;
  font-weight: bold;
  font-size: 1.1rem;
  border-bottom: 1px solid #0056b3;
}

/* Hauptbereich des Widgets */
.widget-content {
  padding: 1rem;
  font-size: 0.95rem;
  color: #333;
  flex: 1; /* damit Inhalt flexibel mitwächst */
}

.widget {
  background: #ffffff;
  border: 1px solid #dee2e6;
  border-radius: 0.75rem;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
  transition: all 0.3s ease-in-out;
  width: calc(33.333% - 1rem); /* 3 nebeneinander bei genügend Platz */
  min-width: 250px;
  display: flex;
  flex-direction: column;
}

/* Optional: Hover-Effekt */
.widget:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.1);
}

