﻿/* DR 12.02.2026: PrjVW ist jetzt der Capo di tutti Capi — die Basis für ALLE Themes.
   Drei Farben rein, der Rest wird ausgerechnet wie ein perfektes Risotto.
   "I'll be back... als Standard-Main." Kunden-Themes erben von hier.
   Wie Rocky's Trainingsplan — eine Vorlage, viele Champions. (Claude-generated) */

/* ================================================================
   PrjVW Base Theme Engine (standard-main)
   ================================================================
   This is the BASE stylesheet loaded by index.html.
   Customer theme files (enntec, localhost, lisorect, etc.) override
   only the brand colors via :root — all derived variables here
   auto-recalculate via CSS var() resolution.

   Customer themes define:
     --primary-color   (Color 1) → Nav top, buttons, prominent borders
     --secondary-color (Color 2) → Page bg (darkened), dividers, subtle borders
     --accent-color    (Color 3) → Reserved for future highlights
     --primary-text-color        → Text on primary-colored surfaces
     --secondary-text-color      → Text on secondary-colored surfaces
     --customer-logo-url         → Brand logo
     --customer-logo-alt         → Logo alt text

   WCAG AA: --text-main (#F0F0F0) on --bg-main achieves >13:1 contrast.
   ================================================================ */

/* === PrjVW Default Brand Colors (overridden by customer themes) === */
:root {
    --primary-color: #FABF8F;
    --secondary-color: #34495E;
    --accent-color: #D4A76A;
    --primary-text-color: black;
    --secondary-text-color: white;
    --customer-logo-url: url('/localhost-logo.png');
    --customer-logo-alt: "PrjVW";
    --spacing-small: 0.5rem;
    --spacing-large: 2rem;
    --sidebar-width: 250px;
    --general-small-distance: 30px;
    --general-min-distance: 10px;
    /* --- Icon URLs (default = dark mode → light SVGs for dark background) --- */
    --icon-assembly: url('/assembly-light.svg');
    --icon-boot: url('/boot-light.svg');
    --icon-boot-template: url('/boot-template-light.svg');
    --icon-template: url('/template-light.svg');
    --icon-stopwatch: url('/stopwatch-light.svg');
    --icon-assembly-template: url('/assembly-template-light.svg');
    --icon-insurance-template: url('/insurance-template-light.svg');
    --icon-messages-template: url('/messages-template-light.svg');
    --icon-time-template: url('/time-template-light.svg');
    --icon-document-template: url('/document-template-light.svg');
    --icon-assembly-due: url('/assembly-due-light.svg');
    --icon-insurance-due: url('/insurance-due-light.svg');
    --icon-messages-due: url('/messages-due-light.svg');
    --icon-time-due: url('/time-due-light.svg');
    --icon-time: url('/time-light.svg');
    --icon-costs: url('/costs-light.svg');
    --icon-travel: url('/travel-light.svg');
    --icon-import: url('/import-light.svg');
    --icon-overview: url('/overview-light.svg');
    --icon-project: url('/project-light.svg');
    --icon-user: url('/user-light.svg');
    --icon-category: url('/category-light.svg');
    --icon-messages: url('/messages-light.svg');
    --icon-overtime: url('/overtime-light.svg');
    --icon-key: url('/key-light.svg');
    --icon-invoice: url('/invoice-light.svg');
    --icon-logout: url('/logout-light.svg');
    --icon-openclosemenu: url('/openclosemenu-light.svg');
    --icon-openclosemenu-open: url('/openclosemenu_open-light.svg');
    --icon-openclosemenu-close: url('/openclosemenu_close-light.svg');
    --icon-settings: url('/settings-light.svg');
}

/* === 3-Color Auto-Derive Engine === */
:root {
    /* --- System Aliases --- */
    --color-primary: var(--primary-color);
    --color-secondary: var(--secondary-color);
    --color-accent: var(--accent-color);

    /* --- Main Background & Text --- */
    --bg-main: #5c5c5c;
    --text-main: #F0F0F0;

    /* --- Derived Colors --- */
    --card-background: #333333;
    --hover-background: #2a2a2a;
    --primary-gray: #505050;
    --secondary-gray: #7A7A7A;
    --tertiary-gray: #5C5C5C;

    /* --- Borders & Dividers --- */
    --border-color: color-mix(in srgb, var(--secondary-color, #34495E) 15%, #333);
    --border-primary: color-mix(in srgb, var(--primary-color, #888) 25%, #333);
    --divider-color: color-mix(in srgb, var(--secondary-color, #34495E) 20%, #2a2a2a);

    /* --- Inputs --- */
    --input-background: #333333;
    --input-text-color: color-mix(in srgb, var(--primary-color, #888) 10%, #E0E0E0);
    --input-border-color: color-mix(in srgb, var(--primary-color, #888) 12%, #444);

    /* --- Text --- */
    --page-text-color: color-mix(in srgb, var(--primary-color, #888) 5%, var(--text-main));
    --table-footer-color: var(--primary-text-color, white);

    /* --- Shadows for Depth --- */
    --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.25);
    --shadow-md: 0 2px 8px rgba(0, 0, 0, 0.35);
    --shadow-lg: 0 4px 16px rgba(0, 0, 0, 0.45);

    --lisorect-logo: url('/lisorect_main_logo.png');
    --action-green: #28a745;
}

/* ================================================================
   Global Styles
   ================================================================ */

body {
    color: var(--page-text-color);
}

.lisorect-alerts {
    margin-top: var(--general-min-distance);
}

.full-page-flex {
    display: flex;
    flex-direction: column;
    /*flex: 1;*/
    height: calc(100vh - 12px);
}

.lisorect-form-column {
    display: flex;
    flex-direction: column;
    gap: var(--general-min-distance);
}

.lisorect-form-row {
    display: flex;
    flex-direction: row;
    align-items: end;
    width: 100%;
    gap: var(--general-min-distance);
}

    .lisorect-form-row.lowgap {
        gap: calc(var(--general-min-distance) / 2);
    }

.lisorect-page {
    display: flex;
    flex-direction: column;
}

.lisorect-projects {
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: var(--general-min-distance);
    overflow: auto;
}

.lisorect-button-container {
    display: flex;
    align-items: center;
    padding: 8px var(--general-min-distance);
    border-bottom: 1px solid var(--border-color);
    background-color: var(--card-background);
}

.calendar-header {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--general-min-distance);
    flex: 1;
}

    .calendar-header input,
    .calendar-header select {
        height: 32px;
        padding: 0 8px;
        font-size: 0.875rem;
        border: 1px solid var(--input-border-color);
        border-radius: 4px;
        background-color: var(--input-background);
        color: var(--input-text-color);
        min-width: 120px;
    }

    .calendar-header input:focus,
    .calendar-header select:focus {
        outline: none;
        border-color: var(--color-primary);
        box-shadow: 0 0 0 2px color-mix(in srgb, var(--primary-color) 25%, transparent);
    }

    .calendar-header input[type="text"],
    .calendar-header input:not([type]) {
        min-width: 200px;
    }

.lisorect-page-container {
    display: flex;
    overflow-y: auto;
    height: 100%;
    padding-bottom: 12px;
}

/* ================================================================
   Form Controls
   ================================================================ */
/* DR 12.02.2026: Bootstrap form-control override für Dark Mode.
   "Yo Adrian, die Inputs sehen aus wie Nachtsicht-Geräte!"
   Jetzt mit Shadow auf Focus — wie ein Spotlight im Ring. (Claude-generated) */
.form-control {
    background-color: var(--input-background);
    color: var(--input-text-color);
    border-color: var(--input-border-color);
}

    .form-control:focus {
        background-color: var(--input-background);
        color: var(--input-text-color);
        border-color: var(--color-primary);
        box-shadow: 0 0 0 2px color-mix(in srgb, var(--primary-color) 25%, transparent);
    }

    .form-control::placeholder {
        color: color-mix(in srgb, var(--input-text-color) 50%, transparent);
    }

select.form-control option {
    background-color: var(--input-background);
    color: var(--input-text-color);
}

.lisorect-small-input {
    display: block;
    width: 100%;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: var(--input-text-color);
    background-color: var(--input-background);
    background-clip: padding-box;
    border: 1px solid var(--input-border-color);
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: .25rem;
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}

    .lisorect-small-input:focus {
        border-color: var(--color-primary);
        box-shadow: 0 0 0 2px color-mix(in srgb, var(--primary-color) 25%, transparent);
    }

.lisorect-select-group {
    display: flex;
    flex-direction: column;
}

.lisorect-select-inside {
    display: flex;
    gap: 0.4rem;
    align-items: center;
}
/* ================================================================
   Tables
   ================================================================ */
/* Override Bootstrap .table hardcoded color (#212529) for dark/light mode */
.table {
    color: var(--page-text-color);
}

.table-container {
    height: 100%;
    width: 100%;
    overflow-y: auto;
    display: block;
}

.lisorect-table {
    width: 100%;
    border-collapse: collapse;
    bottom: 12px;
    box-shadow: var(--shadow-md);
}

    .lisorect-table th, .lisorect-table td {
        text-align: left;
    }

    .lisorect-table thead {
        background-color: var(--color-primary);
        color: var(--primary-text-color);
        position: sticky;
        top: 0;
        z-index: 1;
    }

    .lisorect-table tbody tr:nth-child(odd) {
        background-color: var(--primary-gray);
    }

    .lisorect-table tbody tr:nth-child(even) {
        background-color: var(--secondary-gray);
    }

    .lisorect-table tbody tr:hover {
        background-color: var(--hover-background);
        cursor: pointer;
    }

    .lisorect-table tfoot {
        position: sticky;
        border-top: 3px solid var(--border-primary);
        bottom: 0px;
        color: var(--table-footer-color);
        background-color: var(--color-primary);
        box-shadow: 0 -2px 5px rgba(0, 0, 0, 0.2);
    }

/* ================================================================
   Buttons
   ================================================================ */
/* DR 12.02.2026: Buttons con ombra — wie Rocky's Fäuste.
   "If I can change, and you can change, then these buttons can change." (Claude-generated) */
.lisorect-button {
    background-color: var(--color-primary);
    border-radius: 6px;
    border: 1px solid var(--border-primary);
    box-shadow: var(--shadow-sm);
    transition: background-color 0.2s, transform 0.15s, box-shadow 0.2s;
}

    .lisorect-button:hover {
        background-color: color-mix(in srgb, var(--primary-color) 80%, black);
        transform: scale(1.05);
        box-shadow: var(--shadow-md);
    }

.lisorect-confirm-button {
    background-color: #28a745;
    border-radius: 6px;
    border: 1px solid #1e7e34;
    color: white;
    box-shadow: var(--shadow-sm);
    transition: background-color 0.2s, transform 0.15s, box-shadow 0.2s;
}

    .lisorect-confirm-button:hover {
        background-color: #218838;
        transform: scale(1.05);
        box-shadow: var(--shadow-md);
    }

.lisorect-delete-button {
    background-color: #dc3545;
    border-radius: 6px;
    border: 1px solid #bd2130;
    color: white;
    box-shadow: var(--shadow-sm);
    transition: background-color 0.2s, transform 0.15s, box-shadow 0.2s;
}

    .lisorect-delete-button:hover {
        background-color: #c82333;
        transform: scale(1.05);
        box-shadow: var(--shadow-md);
    }

.lisorect-cancel-button {
    background-color: #707070;
    border-radius: 6px;
    border: 1px solid #555;
    color: white;
    box-shadow: var(--shadow-sm);
    transition: background-color 0.2s, transform 0.15s, box-shadow 0.2s;
}

    .lisorect-cancel-button:hover {
        background-color: #353535;
        transform: scale(1.05);
        box-shadow: var(--shadow-md);
    }

/* ================================================================
   Animations
   ================================================================ */

/* Global page fade-in animation */
@keyframes fadeSlideIn {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

.full-page-flex,
.lisorect-page-container,
.categories-page-container {
    animation: fadeSlideIn 0.5s ease-out forwards;
}

@keyframes slideOutLeft {
    from {
        transform: translateX(0);
        opacity: 1;
    }

    to {
        transform: translateX(-100%);
        opacity: 0;
    }
}

@keyframes slideInRight {
    from {
        transform: translateX(-100%);
        opacity: 0;
    }

    to {
        transform: translateX(0);
        opacity: 1;
    }
}

@keyframes rollFromTop {
    from {
        transform: translateY(-100%);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

tr.slide-out-left {
    animation: slideOutLeft 1.5s forwards;
}

tr.slide-in-right {
    animation: slideInRight 1.5s forwards;
}

tr.roll-from-top {
    animation: rollFromTop 1.5s forwards;
}

/* ================================================================
   Light Mode Overrides
   ================================================================
   DR 12.02.2026: Light Mode — "Let there be light!" sagte der Terminator
   und drückte den Toggle. Adesso si vede tutto come in Sicilia a mezzogiorno.
   Icons wechseln zurück zu den dunklen Originalen. (Claude-generated)
   ================================================================ */
body.light-mode {
    /* --- Icon URLs (light mode → original dark SVGs for light background) --- */
    --icon-assembly: url('/assembly.svg');
    --icon-boot: url('/boot.svg');
    --icon-boot-template: url('/boot-template.svg');
    --icon-stopwatch: url('/stopwatch.svg');
    --icon-template: url('/template.svg');
    --icon-assembly-template: url('/assembly-template.svg');
    --icon-insurance-template: url('/insurance-template.svg');
    --icon-messages-template: url('/messages-template.svg');
    --icon-time-template: url('/time-template.svg');
    --icon-document-template: url('/document-template.svg');
    --icon-assembly-due: url('/assembly-due.svg');
    --icon-insurance-due: url('/insurance-due.svg');
    --icon-messages-due: url('/messages-due.svg');
    --icon-time-due: url('/time-due.svg');
    --icon-time: url('/time.svg');
    --icon-costs: url('/costs.svg');
    --icon-travel: url('/travel.svg');
    --icon-overview: url('/overview.svg');
    --icon-import: url('/import.svg');
    --icon-project: url('/project.svg');
    --icon-user: url('/user.svg');
    --icon-category: url('/category.svg');
    --icon-messages: url('/messages.svg');
    --icon-overtime: url('/overtime.svg');
    --icon-key: url('/key.svg');
    --icon-invoice: url('/invoice.svg');
    --icon-logout: url('/logout.svg');
    --icon-openclosemenu: url('/openclosemenu.svg');
    --icon-openclosemenu-open: url('/openclosemenu_open.svg');
    --icon-openclosemenu-close: url('/openclosemenu_close.svg');
    --icon-settings: url('/settings.svg');
    /* --- Light Background & Text --- */
    --bg-main: #F5F5F5;
    --text-main: #1A1A1A;
    /* --- Derived Colors (Light Mode) --- */
    --tertiary-color: color-mix(in srgb, var(--primary-color, #888) 70%, #333);
    --tertiary-gray: #F5F5F5;
    --card-background: #FFFFFF;
    --primary-gray: #D4D4D4;
    --secondary-gray: #E5E5E5;
    --hover-background: color-mix(in srgb, var(--primary-color, #888) 10%, #E8E8E8);
    /* --- Borders & Dividers --- */
    --border-color: #D0D0D0;
    --border-primary: color-mix(in srgb, var(--primary-color, #888) 30%, #CCC);
    --divider-color: #E0E0E0;
    /* --- Inputs --- */
    --input-background: #FFFFFF;
    --input-text-color: #1A1A1A;
    --input-border-color: #C0C0C0;
    /* --- Text --- */
    --page-text-color: #1A1A1A;
    --table-footer-color: var(--primary-text-color, black);
    /* --- Shadows (softer for light mode) --- */
    --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.08);
    --shadow-md: 0 2px 8px rgba(0, 0, 0, 0.12);
    --shadow-lg: 0 4px 16px rgba(0, 0, 0, 0.15);
}
