/*
 * File: components-sidenav.css
 * Project: ABC Miet-WC Touren-Planer PWA
 * Erstellt: 2024 (umbenannt 2026 von src/style.sidenav.v2.css)
 * Autor: Dirk Stegelmann (dirk.stegelmann@abc-miet-wc.de)
 * Copyright 2014 - 2026 BoA Betriebs GmbH & Co.KG
 *
 * Seitennavigation der PWA (Off-Canvas-Panel).
 * Bewusst theme-unabhängig dunkel: das Panel dient als visuell abgegrenzte
 * Steuerungsfläche und behält in beiden Modi das gleiche Erscheinungsbild
 * (analog Spotify/Discord-Drawer). Sämtliche Farben kommen aus den
 * --sidenav-*-Tokens in tokens.css.
 *
 * Aufbau:
 *   1. Sidenav Panel (Off-Canvas-Rahmen)
 *   2. Sidenav Links / Headlines
 *   3. Tour Choice (Tourenauswahl)
 *   4. ZEF Buttons (Zeiterfassungssteuerung)
 *   5. Theme Toggle (Light/Dark-Umschalter)
 *   6. Active State
 *   7. Close Button
 *   8. Checkbox / Select
 *   9. Input / Buttons
 *  10. Responsive Breakpoints
 */

/* ============================================================
   1. SIDENAV PANEL
   Off-Canvas-Panel: startet mit width:0, öffnet sich per JS auf eine
   feste Breite. Material-Ease-Kurve (cubic-bezier) für natürliche
   Animation. z-index 99 – unterhalb des Popup-Overlays (998/999).
   ============================================================ */
.sidenav {
    height: 100%;
    width: 0;
    position: fixed;
    z-index: 99;
    top: 0;
    left: 0;
    background: linear-gradient(180deg, var(--sidenav-bg-from) 0%, var(--sidenav-bg-to) 100%);
    overflow-x: hidden;
    transition: width var(--duration-slow) var(--ease-standard);
    box-shadow: 4px 0 20px rgba(0, 0, 0, .35);
}

/* ============================================================
   2. HEADLINES + NAV LINKS
   h2 – Abschnittsüberschriften (gelber Verlauf, Großbuchstaben).
   a.nav-item – Einträge erster Ebene mit feiner Trennlinie.
   a.nav-item-first – Einträge zweiter Ebene (eingerückt, kleiner).
   label.small – deskriptive Unterschriften.
   ============================================================ */
.sidenav h2,
.sidenav h3 {
    padding: .4rem .6rem;
    margin: .2rem 0;
}
.sidenav h2 {
    font-size: 1.1rem;
    color: var(--sidenav-bg-from);
    background: linear-gradient(90deg, var(--sidenav-yellow-from), var(--sidenav-yellow-to));
    border-radius: 0;
    letter-spacing: .03em;
    text-transform: uppercase;
}
.sidenav h2 span {
    padding-top: .2rem;
    display: inline-block;
}

.sidenav > div a,
.sidenav > div.main-item {
    padding: .3rem .2rem .3rem .9rem;
    text-decoration: none;
    font-size: 1.15rem;
    color: var(--sidenav-text);
    transition: background-color var(--transition), color var(--transition), padding-left var(--transition);
    display: block;
}
.sidenav a.nav-item,
.sidenav div.nav-item {
    background-color: transparent;
    border-bottom: .0625rem solid var(--sidenav-divider);
}

.sidenav a.nav-item-first {
    font-size: 1.05rem;
    color: var(--sidenav-text-muted);
    padding: .25rem .2rem .25rem 1.1rem;
    border-bottom: .0625rem solid var(--sidenav-divider-soft);
    display: block;
    transition: background-color var(--transition), color var(--transition);
}
.sidenav a.nav-item-first:hover {
    background-color: var(--sidenav-hover-bg);
    color: var(--sidenav-text-strong);
}
.sidenav a.nav-item-first.active {
    background-color: var(--sidenav-active-bg);
    color: var(--sidenav-text-strong);
    border-left: .2rem solid var(--sidenav-active-border);
}

.sidenav label.small {
    font-size: .82rem;
    margin-left: .5rem;
    line-height: 1rem;
    display: block;
    color: var(--sidenav-text-subtle);
}
.sidenav div.main-item { margin-bottom: .1rem; }

/* ============================================================
   3. TOUR CHOICE
   #pwa-sidenav-tourchoice – Liste aller verfügbaren Touren als Links.
   #pwa-sidenav-tourname a – kompakter grüner Badge der aktuell aktiven Tour.
   ============================================================ */
#pwa-sidenav-tourchoice a.tour {
    font-size: 1rem;
    color: var(--sidenav-text-muted);
}
#pwa-sidenav-tourname a {
    background: linear-gradient(135deg, var(--color-green-500), var(--color-green-700));
    color: var(--sidenav-text-strong);
    padding: .3rem 0;
    margin-left: 1rem;
    font-size: 1.05rem;
    width: 8rem;
    text-align: center;
    font-weight: bold;
    vertical-align: top;
    line-height: 1rem;
    border-radius: var(--radius-sm);
    display: inline-block;
    box-shadow: 0 2px 6px rgba(0, 0, 0, .25);
    transition: filter var(--transition);
}
#pwa-sidenav-tourname a:hover { filter: brightness(1.15); }

/* ============================================================
   4. ZEF BUTTONS (Zeiterfassung)
   zef-start – grüner Verlauf, zef-end – roter Verlauf.
   .disabled – Deaktivierter Zustand (pointer-events:none, grau).
   .fullsize – Sonderzustand: gelber Vollbreite-Badge als Leseanzeige.
   ============================================================ */
#pwa-sidenav-zef a {
    width: calc(50% - 1.8rem);
    margin: .3rem .25rem;
    line-height: 1.3rem;
    text-align: center;
    font-weight: bold;
    font-size: .85rem;
    vertical-align: top;
    border-radius: var(--radius-sm);
    display: inline-block;
    box-shadow: 0 2px 8px rgba(0, 0, 0, .25);
    transition: filter var(--transition), transform var(--transition);
}
#pwa-sidenav-zef a:active { transform: scale(.95); }

#pwa-sidenav-zef a.zef-start {
    background: linear-gradient(135deg, var(--sidenav-zef-start-from), var(--sidenav-zef-start-to));
    color: #000;
    padding: .55rem;
}
#pwa-sidenav-zef a.zef-end {
    background: linear-gradient(135deg, var(--sidenav-zef-end-from), var(--sidenav-zef-end-to));
    color: var(--sidenav-text-strong);
    padding: .55rem;
}
#pwa-sidenav-zef a.disabled {
    pointer-events: none;
    background: var(--sidenav-zef-disabled) !important;
    color: var(--sidenav-zef-disabled-fg) !important;
    font-style: italic;
    box-shadow: none;
}
#pwa-sidenav-zef a.fullsize {
    pointer-events: none;
    width: 16rem !important;
    background: linear-gradient(135deg, #f9fd00, #d4d800) !important;
    color: #000 !important;
    padding: .3rem !important;
    white-space: normal !important;
    font-size: 1rem !important;
    line-height: 1.05rem !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, .2);
}

/* ============================================================
   5. THEME TOGGLE
   Schaltet zwischen Light- und Dark-Mode. data-theme wird auf <html>
   gesetzt (siehe ThemeManager.js). Der Button selbst bleibt theme-
   unabhängig dunkel, da er Teil der dauerhaft dunklen Sidenav ist.
   Das Label-span wird per ThemeManager auf "LIGHT" oder "DARK" gesetzt.
   ============================================================ */
#pwa-sidenav-theme {
    padding: .3rem .9rem .6rem;
}
#pwa-sidenav-theme button {
    width: 100%;
    margin: .15rem 0;
    padding: .45rem .8rem;
    font-size: .9rem;
    font-weight: bold;
    font-family: var(--font-brand);
    color: var(--sidenav-text);
    background: var(--sidenav-input-bg);
    border: .125rem solid var(--sidenav-input-border);
    border-radius: var(--radius-sm);
    box-shadow: var(--sidenav-shadow);
    cursor: pointer;
    text-align: left;
    transition: background-color var(--transition), border-color var(--transition), filter var(--transition);
}
#pwa-sidenav-theme button:hover  { background-color: var(--sidenav-input-bg-focus); border-color: var(--sidenav-active-border); }
#pwa-sidenav-theme button:active { filter: brightness(.88); }
#pwa-sidenav-theme button img.iconset {
    width: 1.2rem;
    height: 1.2rem;
    vertical-align: text-bottom;
    margin-right: .5rem;
}

/* ============================================================
   6. ACTIVE STATE (global)
   Globale Hover- und Aktiv-Stile für alle Links in der Sidenav.
   ============================================================ */
.sidenav a:hover  { color: var(--sidenav-text-strong); }
.sidenav a.active {
    background-color: var(--sidenav-active-bg);
    border-left: .2rem solid var(--sidenav-active-border);
    color: var(--sidenav-text-strong);
}

/* ============================================================
   7. CLOSE BUTTON
   Absolut positionierter ×-Button oben rechts.
   ============================================================ */
.sidenav #nav-close {
    position: absolute;
    top: 0;
    right: 1rem;
    font-size: 2.2rem;
    margin-left: 3rem;
    color: rgba(255, 255, 255, .7);
    font-weight: bold;
    line-height: 1.1;
    transition: color var(--transition);
}
.sidenav #nav-close:hover { color: var(--sidenav-text-strong); }

/* ============================================================
   8. CHECKBOX / SELECT
   Native checkbox ausgeblendet, label.chkbox:before simuliert die Box.
   :checked → grünes Häkchen via content:"\2713".
   select – Fahrerauswahl-Dropdown im Sidenav-Stil.
   ============================================================ */
.sidenav input[type=checkbox] { display: none; }

.sidenav select {
    font-size: 1.15rem;
    font-weight: bold;
    padding: .3rem .4rem;
    margin: .5rem 0 .5rem .8rem;
    background-color: var(--sidenav-input-bg);
    border-radius: var(--radius-sm);
    border: .125rem solid var(--sidenav-input-border);
    color: var(--sidenav-text);
    width: 90%;
    transition: border-color var(--transition);
}
.sidenav select:focus { border-color: var(--sidenav-active-border); outline: none; }

.sidenav label.chkbox {
    display: inline-block;
    position: relative;
    padding-right: 1.4rem;
    font-size: 1rem;
    line-height: 1.2rem;
    margin: .25rem;
    width: calc(100% - 2.4rem);
    color: var(--sidenav-text-muted);
}
.sidenav label.chkbox:before {
    line-height: 1.2rem;
    content: "";
    display: inline-block;
    width: 1rem;
    height: 1rem;
    position: absolute;
    right: 0;
    background-color: var(--sidenav-text-strong);
    border: .0625rem solid var(--sidenav-active-border);
    border-radius: .2rem;
}
.sidenav input[type=checkbox]:checked + label.chkbox:before {
    content: "\2713";
    color: var(--color-green-700);
    text-align: center;
    line-height: 1rem;
    background-color: var(--sidenav-checkbox-tick-bg);
}

/* ============================================================
   9. INPUT / BUTTONS
   Texteingabe-Stile, einheitliche kleine Aktionsbuttons.
   #filter-set – gelber Primär-Filterbutton.
   button.filter-reset – roter Reset-Button.
   ============================================================ */
.sidenav input[type=text] {
    width: 9rem;
    border: .125rem solid var(--sidenav-input-border);
    background-color: var(--sidenav-input-bg);
    color: var(--sidenav-text);
    padding: .2rem .3rem;
    margin: .15rem .15rem .15rem .5rem;
    font-size: 1.2rem;
    display: inline-block;
    border-radius: var(--radius-sm);
    transition: border-color var(--transition);
}
.sidenav input[type=text]:focus {
    border-color: var(--sidenav-active-border);
    outline: none;
    background-color: var(--sidenav-input-bg-focus);
}

.sidenav button {
    border: none;
    color: var(--sidenav-bg-from);
    font-size: 1.2rem;
    font-weight: bold;
    margin: .15rem;
    padding: .2rem .6rem;
    border-radius: var(--radius-sm);
    box-shadow: var(--sidenav-shadow);
    transition: filter var(--transition);
    font-family: var(--font-brand);
}
.sidenav button:active { filter: brightness(.88); }

.sidenav #filter-set {
    background: linear-gradient(135deg, var(--sidenav-yellow-from), var(--sidenav-yellow-to));
    color: var(--sidenav-bg-from);
}
.sidenav button img.iconset { width: 1.5rem; height: 1.2rem; }
.sidenav button.filter-reset {
    background: linear-gradient(135deg, var(--color-danger), var(--color-danger-strong));
    color: var(--sidenav-text-strong);
}

/* ============================================================
   10. RESPONSIVE
   Querformat-Smartphone (max-height 450px) – kompakteres Padding.
   Tablet/Desktop (min-width 768px) – etwas größere Schrift.
   ============================================================ */
@media screen and (max-height: 450px) {
    .sidenav { padding-top: .5rem; }
    .sidenav a { font-size: 1rem; }
}
@media (min-width: 768px) {
    .sidenav > div a,
    .sidenav > div.main-item { font-size: 1.1rem; padding-left: 1rem; }
}
