/* =============================================
   STYLE-RETRO.CSS - KOMPLETTE & FINALE VERSION
   ============================================= */

/* 1. GRUNDEINSTELLUNGEN & FARBSCHEMA */
:root { --color-background: #141414; --color-text: #EAEAEA; --color-primary: #00A8E8; --color-secondary: #282828; --color-dark: #000000; --font-headline: 'Bebas Neue', sans-serif; --font-body: 'Lato', sans-serif; --header-height: 70px; }

/* 2. GLOBALE STYLES */
body { background-color: var(--color-background); color: var(--color-text); font-family: var(--font-body); line-height: 1.6; margin: 0; padding-top: var(--header-height); }
h1, h2, h3, h4, h5, h6 { font-family: var(--font-headline); color: white; letter-spacing: 1.5px; text-transform: uppercase; }
a { color: var(--color-primary); text-decoration: none; transition: color 0.3s ease; }
a:hover { color: white; }
main { min-height: calc(100vh - var(--header-height) - 200px); }
.container { max-width: 1200px; }

/* 3. HEADER & SUCHE */
.main-header { background: transparent; height: var(--header-height); width: 100%; position: fixed; top: 0; left: 0; z-index: 1000; transition: background-color 0.4s ease; display: flex; align-items: center; border-bottom: 1px solid transparent; }
.main-header.scrolled { background-color: var(--color-background); border-bottom: 1px solid var(--color-secondary); }
.main-header nav { display: flex; justify-content: space-between; align-items: center; width: 100%; padding: 0 50px; }
.main-header .logo { font-family: var(--font-headline); font-size: 1.8rem; color: var(--color-primary); letter-spacing: 1px; text-decoration: none; white-space: nowrap; }
.main-header .logo:hover { color: white; }
.main-header .main-nav { list-style: none; display: flex; gap: 25px; margin: 0; padding: 0; }
.main-header .main-nav a { color: var(--color-text); text-transform: uppercase; font-size: 0.9rem; font-weight: 700; letter-spacing: 1px; padding: 5px 0; border-bottom: 2px solid transparent; white-space: nowrap; }
.main-header .main-nav a:hover, .main-header .main-nav a.active { color: white; border-bottom: 2px solid var(--color-primary); }
.user-nav { display: flex; align-items: center; gap: 15px; }
.user-nav .nav-button { background-color: var(--color-primary); color: var(--color-dark); padding: 8px 15px; border-radius: 4px; text-transform: uppercase; font-weight: bold; font-size: 0.8rem; letter-spacing: 1px; transition: background-color 0.3s ease, color 0.3s ease; white-space: nowrap; }
.user-nav .nav-button:hover { background-color: white; color: var(--color-dark); }
.user-nav .nav-button-secondary { background: none; border: 1px solid var(--color-secondary); color: white; }
.user-nav .nav-button-secondary:hover { background: var(--color-secondary); }

/* PERMANENTES SUCHFELD - Ersetze den Abschnitt "KORREKTUR FÜR PERMANENT SICHTBARE SUCHE" */

.header-search-form { 
    position: relative; 
    display: flex; 
    align-items: center;
    margin-left: 20px; /* Abstand zur Navigation */
}

.search-input { 
    background-color: var(--color-secondary); 
    border: 1px solid #444; 
    border-radius: 20px; 
    color: var(--color-text); 
    width: 220px; /* Feste Breite - immer sichtbar */
    padding: 8px 40px 8px 15px; /* Mehr Padding rechts für den Button */
    transition: border-color 0.3s ease, background-color 0.3s ease; /* Nur noch sanfte Farbübergänge */
    outline: none;
    font-size: 0.9rem;
}

.search-input::placeholder {
    color: #888;
}

.search-input:focus { 
    border-color: var(--color-primary); 
    background-color: #333; 
}

.search-button { 
    background: none; 
    border: none; 
    cursor: pointer; 
    padding: 5px; 
    position: absolute; 
    right: 8px; 
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
}

.search-button svg { 
    stroke: #888; 
    transition: stroke 0.3s ease;
    width: 18px;
    height: 18px;
}

.search-button:hover svg,
.search-input:focus + .search-button svg { 
    stroke: var(--color-primary); 
}

/* Responsive Anpassung für kleinere Bildschirme */
@media (max-width: 1200px) {
    .search-input {
        width: 180px; /* Etwas schmaler auf mittleren Bildschirmen */
    }
}

@media (max-width: 992px) {
    .header-search-form {
        margin-left: 10px;
    }
    
    .search-input {
        width: 150px; /* Noch schmaler auf kleineren Bildschirmen */
        font-size: 0.85rem;
    }
}

/* 4. FOOTER */
.main-footer { background-color: var(--color-dark); color: #888; padding: 40px 0 20px 0; font-size: 0.9rem; }
.main-footer h5 { color: white; font-size: 1.2rem; margin-bottom: 15px; }
.main-footer a { color: #888; }
.main-footer a:hover { color: var(--color-primary); }
.main-footer .copyright { color: #666; margin-top: 20px; font-size: 0.8rem; }

/* 5. HOMEPAGE */
.hero { position: relative; height: 70vh; display: flex; align-items: center; justify-content: center; text-align: center; color: white; margin-top: -70px; }
.hero-background video { position: absolute; top: 50%; left: 50%; width: 100%; height: 100%; object-fit: cover; transform: translate(-50%, -50%); z-index: 1; }
.hero-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.5); z-index: 2; }
.hero-content { position: relative; z-index: 3; max-width: 800px; padding: 0 20px; }
.hero-headline { font-size: 6rem; line-height: 1.1; margin-bottom: 1rem; }
.hero-phone-button { display: inline-block; margin-top: 1.5rem; padding: 12px 30px; background-color: var(--color-primary); color: var(--color-dark) !important; border-radius: 5px; text-decoration: none; transition: background-color 0.3s ease; cursor: default; pointer-events: none; }
.hero-phone-button .phone-number { display: block; font-size: 1.5rem; font-weight: bold; letter-spacing: 1px; }
.hero-phone-button .phone-cta { display: block; font-size: 0.8rem; text-transform: uppercase; letter-spacing: 1px; opacity: 0.8; }
@media (max-width: 768px) {
    .hero-headline { font-size: 3.5rem; }
    .hero-phone-button { cursor: pointer; pointer-events: auto; }
    .hero-phone-button:hover { background-color: white; }
}
.homepage-content-wrapper { background-color: var(--color-background); }
.service-box, .mission-box { background-color: var(--color-secondary); padding: 30px; border-radius: 8px; height: 100%; border: 1px solid #333; transition: transform 0.3s ease, box-shadow 0.3s ease; text-align: left; }
.service-box:hover, .mission-box:hover { transform: translateY(-5px); box-shadow: 0 10px 20px rgba(0,0,0,0.4); }
.service-box h3, .mission-box h3 { color: var(--color-primary); font-size: 1.5rem; }
.mission-box ul { list-style: none; padding: 0; }
.bg-darker { background-color: var(--color-dark); }

/* 6. ALLGEMEINE ARTIKEL-KARTEN & GRID */
.prop-card-static, .prop-card { display: block; aspect-ratio: 16 / 9; background-color: var(--color-secondary); border-radius: 6px; overflow: hidden; position: relative; transition: transform 0.3s ease, box-shadow 0.3s ease; }
.prop-card-static:hover, .prop-card:hover { transform: scale(1.05); box-shadow: 0 10px 20px rgba(0,0,0,0.5); z-index: 10; }
.prop-card-static img, .prop-card img { width: 100%; height: 100%; object-fit: cover; }
.prop-card-static .prop-card-overlay, .prop-card .prop-card-overlay { position: absolute; bottom: 0; left: 0; width: 100%; padding: 15px; background: linear-gradient(to top, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0) 100%); }
.prop-card-static .prop-card-overlay h3, .prop-card .prop-card-overlay h3 { font-size: 1.2rem; margin: 0; color: white; text-transform: none; font-family: var(--font-body); }
.page-content { padding-bottom: 50px; }
.prop-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }

/* 7. PAGINIERUNG */
.pagination .page-link { background-color: var(--color-secondary); border-color: var(--color-dark); color: var(--color-text); }
.pagination .page-link:hover { background-color: #333; }
.pagination .page-item.active .page-link { background-color: var(--color-primary); border-color: var(--color-primary); color: var(--color-dark); }
.pagination .page-item.disabled .page-link { background-color: #111; border-color: var(--color-secondary); color: #555; }

/* 8. ARTIKEL ÜBERSICHT */
.overview-header { padding: 40px 0; background-color: var(--color-secondary); }
.overview-header h1 { font-size: 3rem; margin: 0; }
.category-dropdown-wrapper { position: absolute; top: 100px; left: 20px; z-index: 1050; }
.btn-filter { background-color: var(--color-primary); color: var(--color-dark) !important; font-family: var(--font-body); font-weight: bold; text-transform: uppercase; letter-spacing: 1px; }
.category-dropdown-menu { background-color: var(--color-dark); border: 1px solid var(--color-secondary); padding: 0; width: 350px; --bs-dropdown-min-width: none; }
.category-dropdown-menu .accordion { --bs-accordion-bg: transparent; --bs-accordion-border-color: var(--color-secondary); }
.category-dropdown-menu .accordion-item { border: none; }
.category-dropdown-menu .accordion-header { display: flex; align-items: stretch; border-bottom: 1px solid var(--color-secondary); }
.category-dropdown-menu .accordion-button-link { color: var(--color-text); text-decoration: none; padding: 1rem 1.25rem; flex-grow: 1; font-size: 1.2rem; font-family: var(--font-headline); letter-spacing: 1px; }
.category-dropdown-menu .accordion-button-link:hover, .category-dropdown-menu .accordion-button-link.active { color: var(--color-primary); }
.category-dropdown-menu .accordion-button { flex-grow: 0; width: 50px; border-left: 1px solid var(--color-secondary); box-shadow: none; }
.category-dropdown-menu .accordion-body { padding: 0; }
.category-dropdown-menu .accordion-body ul a { display: block; padding: 0.75rem 2.5rem; color: #ccc; }
.category-dropdown-menu .accordion-body ul a:hover { background-color: var(--color-secondary); color: white; }
.category-dropdown-menu .accordion-body ul a.active { color: var(--color-primary); font-weight: bold; }

/* 9. ARTIKEL DETAILSEITE */
#main-content:has(.detail-hero) .main-header { background-color: var(--color-background) !important; }
.detail-hero { height: 50vh; background-size: cover; background-position: center; position: relative; }
.detail-hero-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(to top, var(--color-background) 0%, rgba(0,0,0,0.5) 50%, rgba(0,0,0,0) 100%); }
.detail-content { margin-top: -150px; position: relative; z-index: 5; }
.detail-sidebar img { border: 4px solid var(--color-dark); }
.btn-add-to-cart, .btn-add-to-cart-disabled, .btn-software-demo, .btn-back-to-overview { width: 100%; text-align: center; padding: 12px; border-radius: 4px; text-transform: uppercase; font-weight: bold; letter-spacing: 1px; transition: all 0.3s ease; display: block; }
.btn-add-to-cart { background-color: var(--color-primary); color: var(--color-dark); border: none; font-size: 1rem; }
.btn-software-demo { background-color: #5a5a5a; color: white; font-size: 0.9rem; margin-top: 10px; }
.btn-back-to-overview { background: none; border: 1px solid var(--color-secondary); color: white; margin-top: 10px; }
.detail-main h1 { font-size: 3.5rem; }
.specs-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; background-color: var(--color-secondary); padding: 20px; border-radius: 8px; margin-bottom: 2rem; }
.price-list { background-color: var(--color-dark); padding: 20px; border-radius: 8px; }
.price-on-request { font-size: 1.1rem; color: #ccc; }
.main-image-container { position: relative; }
.main-image-container img { cursor: pointer; }
.download-icon { position: absolute; top: 10px; right: 10px; background-color: rgba(0, 0, 0, 0.6); color: white; padding: 8px; border-radius: 50%; display: flex; align-items: center; justify-content: center; transition: all 0.3s ease; opacity: 0.7; }
.main-image-container:hover .download-icon { opacity: 1; }
.download-icon:hover { background-color: var(--color-primary); color: var(--color-dark); transform: scale(1.1); }
.img-thumbnail.active { border-color: var(--color-primary); }
.related-props-section .prop-carousel { display: flex; gap: 15px; overflow-x: auto; padding-bottom: 20px; scrollbar-width: thin; scrollbar-color: var(--color-primary) var(--color-secondary); }
.related-props-section .prop-carousel::-webkit-scrollbar { height: 8px; }
.related-props-section .prop-carousel::-webkit-scrollbar-track { background: var(--color-secondary); border-radius: 4px; }
.related-props-section .prop-carousel::-webkit-scrollbar-thumb { background-color: var(--color-primary); border-radius: 4px; }