/**
 * style.css
 * Enthält alle benutzerdefinierten Stile für die Schneider Rohrtransporte Webseite.
 */

/* * =============================================
 * Variablen und Grundstile
 * =============================================
 */

/* Definition von zentralen Werten für einfache Wartung */
:root {
    --accent-color: #f0af00;
    --text-color-dark: #1f2937;
    --text-color-light: #4a5568;
    --background-light: #ffffff;
    --background-gray: #f3f4f6;
    --font-main: 'Inter', sans-serif;
}

/* Verhindert das "Gummiband"-Scrollen auf der obersten Ebene */
html {
    overscroll-behavior-y: contain;
}

/* Basis-Styling für den gesamten Body */
body {
    font-family: var(--font-main);
    opacity: 0; /* Seite ist initial unsichtbar für den Fade-In-Effekt */
    transition: opacity 0.5s ease-in-out;
}

/* Klasse, die hinzugefügt wird, wenn die Seite fertig geladen ist */
body.loaded {
    opacity: 1;
}

/* * =============================================
 * Preloader / Lade-Spinner
 * =============================================
 */

#preloader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--background-light);
    z-index: 9999;
    display: flex;
    justify-content: center;
    align-items: center;
    /* Übergang für das sanfte Ausblenden */
    transition: opacity 0.75s ease-in-out, visibility 0.75s;
}

#preloader.hidden {
    opacity: 0;
    visibility: hidden;
}

.spinner {
    width: 50px;
    height: 50px;
    border: 5px solid rgba(0, 0, 0, 0.1);
    border-left-color: var(--accent-color); /* Nutzt die Akzentfarbe */
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

/* Keyframe-Animation für die Drehung des Spinners */
@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}


/* * =============================================
 * Wiederverwendbare Hilfsklassen
 * =============================================
 */

.accent-color {
    color: var(--accent-color);
}

.bg-accent-color {
    background-color: var(--accent-color);
}

.border-accent-color {
    border-color: var(--accent-color);
}


/* * =============================================
 * Komponenten-spezifische Stile
 * =============================================
 */

/* Hintergrundbild für die Hero-Sektion */
.bg-hero {
    background-image: url('../img/banner.webp');
    background-size: cover;
    background-position: center;
    position: relative; /* Wichtig: Damit die absolute Positionierung von ::before relativ zu .bg-hero ist */
}

.bg-hero::before {
    content: ''; /* Erforderlich für Pseudo-Elemente */
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.3); /* Schwarzer Overlay mit 30% Deckkraft */
    z-index: 1; /* Sicherstellen, dass der Overlay über dem Bild, aber unter dem Text liegt */
}

/* Damit der Text über dem Overlay liegt, gib dem Container des Textes einen höheren z-index */
.bg-hero .container {
    position: relative; /* Muss relativ sein, damit z-index wirkt */
    z-index: 2; /* Höher als der z-index des Overlays (1) */
}

/* Kleiner Schwebe-Effekt für die Leistungskarten */
.group:hover .group-hover-effect {
    transform: translateY(-5px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}


/* * =============================================
 * Typografie für Text-Seiten (Impressum, Datenschutz)
 * =============================================
 */

.prose h1 {
    font-size: 2.25rem; /* 36px */
    font-weight: 800;
    margin-bottom: 1.5rem;
    padding-bottom: 0.75rem;
    border-bottom: 2px solid var(--background-gray);
    color: var(--text-color-dark);
}

.prose h2 {
    font-size: 1.875rem; /* 30px */
    font-weight: 700;
    margin-top: 2.5rem;
    margin-bottom: 1rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--background-gray);
    color: var(--text-color-dark);
}

.prose h3 {
    font-size: 1.5rem; /* 24px */
    font-weight: 600;
    margin-top: 2rem;
    margin-bottom: 1rem;
    color: var(--text-color-dark);
}

.prose p,
.prose ul li,
.prose address {
    color: var(--text-color-light);
    line-height: 1.7;
}

.prose ul {
    list-style-position: inside;
    padding-left: 1rem;
}

.prose a {
    color: var(--accent-color);
    text-decoration: none;
    font-weight: 500;
}

.prose a:hover {
    text-decoration: underline;
}

.prose strong {
    color: var(--text-color-dark);
}

#mobile-menu {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background-color: rgba(255, 255, 255, 0.95);
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
    z-index: 40;
    transition: all 0.3s ease-in-out;
    backdrop-filter: blur(8px);
    border-bottom: 1px solid #e5e7eb;
}

#mobile-menu a {
    display: block;
    padding: 1rem 1.5rem;
    font-size: 1rem;
    font-weight: 500;
    color: var(--text-color-dark);
    transition: background-color 0.3s, color 0.3s;
}

#mobile-menu a:hover {
    background-color: #fef3c7;
    color: var(--accent-color);
}

/* Optionale Slide-In Animation */
#mobile-menu.hidden {
    opacity: 0;
    transform: translateY(-10px);
    pointer-events: none;
}

#mobile-menu.visible {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

/* * =============================================
 * Stile für die Kernkompetenzen-Karten
 * =============================================
 */

/* Basis-Styling für die klickbaren Karten */
.kompetenz-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    height: 100%;
    border-radius: 0.5rem; /* Abgerundete Ecken */
    background-color: rgba(255, 255, 255, 0.05); /* Leichter, subtiler Hintergrund */
    border: 1px solid transparent; /* Unsichtbarer Rand für den Hover-Effekt */
    transition: transform 0.3s ease, background-color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
    text-decoration: none; /* Entfernt Standard-Link-Unterstreichung */
    color: inherit; /* Vererbt die Textfarbe */
}

/* Hover-Effekt für die klickbaren Karten */
.kompetenz-link:hover {
    transform: translateY(-5px); /* Hebt die Karte leicht an */
    background-color: rgba(255, 255, 255, 0.1); /* Hellerer Hintergrund beim Hover */
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.25); /* Deutlicherer Schatten */
    cursor: pointer;
}

/* Ändert die Farbe der Hauptüberschrift beim Hover */
.kompetenz-link:hover .font-bold {
    color: var(--accent-color); /* Nutzt Ihre definierte Akzentfarbe */
}