/* Neuer Banner-Bereich */
.hero-banner {
    background: url('/assets/images/banner.jpg') center/cover no-repeat;
    background-color: rgba(0, 0, 0, 0.5);
    position: relative;
    z-index: 1;
}

.hero-banner::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.4), rgba(0, 0, 0, 0.6));
    z-index: -1;
}

.hero-slogan {
    font-size: 1.25rem;
    margin-top: 10px;
}

#toggle-container {
    margin-bottom: 20px;
}

.modern-toggle button {
    margin: 0 10px;
    transition: background 0.3s ease, transform 0.3s ease;
}

.modern-toggle button:hover {
    transform: scale(1.05);
}

/* --- Modern Accordion System --- */

:root {
    --acc-red: #E64B5F;
    --acc-blue: #427CBF;
    --acc-grey: #6c757d;
    --acc-green: #B8D043;
    --acc-violet: #8347AD;
    --acc-radius: 12px;
    --acc-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
    --acc-transition: 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

/* Accordion Container */
.accordion {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

/* Accordion Item - Card Style */
.accordion-item {
    border: 1px solid rgba(0,0,0,0.06) !important;
    border-radius: var(--acc-radius) !important;
    background: #fff;
    box-shadow: var(--acc-shadow);
    overflow: hidden;
    transition: transform var(--acc-transition), box-shadow var(--acc-transition);
    margin-bottom: 0; /* Gap handles spacing */
}

.accordion-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.08);
    z-index: 2;
}

/* Accordion Button */
.accordion-button {
    font-weight: 600;
    font-size: 1.1rem;
    padding: 1.25rem 1.5rem;
    border-radius: 0 !important;
    transition: all var(--acc-transition);
    background: #fff;
    color: var(--color-fg);
    position: relative;
}

.accordion-button:not(.collapsed) {
    box-shadow: none;
}

.accordion-button:focus {
    box-shadow: none;
    border-color: rgba(0,0,0,0.1);
    z-index: 3;
}

/* Color Variants - Solid Style (Strong Colors) */
.accordion-button.custom-red-header { 
    background: var(--acc-red); 
    color: #fff;
}
.accordion-button.custom-blue-header { 
    background: var(--acc-blue); 
    color: #fff;
}
.accordion-button.custom-grey-header { 
    background: var(--acc-grey); 
    color: #fff;
}
.accordion-button.custom-green-header { 
    background: var(--acc-green); 
    color: #fff;
}
.accordion-button.custom-violet-header { 
    background: var(--acc-violet); 
    color: #fff;
}

/* Ensure arrow is white for all these colored headers */
.accordion-button.custom-red-header::after,
.accordion-button.custom-blue-header::after,
.accordion-button.custom-grey-header::after,
.accordion-button.custom-green-header::after,
.accordion-button.custom-violet-header::after {
    filter: brightness(0) invert(1);
    opacity: 0.9;
}

/* Color Variants - Filled Style (Expanded) */
.accordion-button:not(.collapsed).custom-red-header { background: var(--acc-red); color: #fff; }
.accordion-button:not(.collapsed).custom-blue-header { background: var(--acc-blue); color: #fff; }
.accordion-button:not(.collapsed).custom-grey-header { background: var(--acc-grey); color: #fff; }
.accordion-button:not(.collapsed).custom-green-header { background: var(--acc-green); color: #fff; }
.accordion-button:not(.collapsed).custom-violet-header { background: var(--acc-violet); color: #fff; }

/* Arrow Handling */
.accordion-button::after {
    transition: transform var(--acc-transition), filter var(--acc-transition);
    background-size: 1.1rem;
    opacity: 0.6;
}

.accordion-button:not(.collapsed)::after {
    filter: brightness(0) invert(1);
    opacity: 1;
}

.accordion-button:hover::after {
    opacity: 1;
}

/* Collection Section Count Badge */
.accordion-button .section-count-badge {
    position: absolute;
    top: 50%;
    right: 3.5rem; /* Adjusted position */
    transform: translateY(-50%);
    background: rgba(0, 0, 0, 0.06);
    color: inherit;
    border-radius: 2rem;
    min-width: 2rem;
    height: 1.75rem;
    padding: 0 .75rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .8rem;
    font-weight: 700;
    line-height: 1;
    pointer-events: none;
    transition: all var(--acc-transition);
}

.accordion-button:not(.collapsed) .section-count-badge {
    background: rgba(255, 255, 255, 0.25);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.3);
}

.accordion-button .section-count-badge.badge-pulse {
    animation: badgePulse .6s ease;
}

@keyframes badgePulse {
    0% { transform: translateY(-50%) scale(.8); opacity: .6; }
    50% { transform: translateY(-50%) scale(1.1); opacity: 1; }
    100% { transform: translateY(-50%) scale(1); opacity: 1; }
}

.cat-count-badge {
    display: none !important;
}

/* Accordion Body */
.accordion-body {
    padding: 1.5rem;
    background: #fff;
}

/* Moderne Card-Styles mit Glassmorphism */
.modern-card {
    border: none;
    background: var(--card-bg);
    backdrop-filter: blur(12px);
    transition: transform 0.4s ease, box-shadow 0.4s ease;
    margin-bottom: 10px;
    /* Reduziert den Abstand zwischen den Cards */
}

.modern-card:hover {
    transform: scale(1.02) rotate(0.3deg);
    box-shadow: 0 12px 36px rgba(0, 0, 0, 0.3);
}

.modern-card:last-child {
    margin-bottom: 0;
}

/* Animation Utility */
.animated {
    animation: fadeIn 0.6s ease-out both;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Benutzerdefinierte Header-Stile (kompakter) */
.card-header.custom-blue-header,
.card-header.custom-red-header,
.card-header.custom-grey-header {
    padding: 15px;
    /* Reduziert von 25px */
    border-bottom: 1px solid rgba(255, 255, 255, 0.4);
    text-shadow: var(--hdr-text-shadow);
}

.card-header.custom-blue-header {
    background: linear-gradient(135deg, #4a90e2, var(--bs-primary));
    color: #fff;
}

.card-header.custom-red-header {
    background: linear-gradient(135deg, #e74c3c, var(--bs-secondary));
    color: #fff;
}

/* Custom Grey Header Style */
.card-header.custom-grey-header {
    background: linear-gradient(135deg, #7f8c8d, #595959);
    color: #fff;
}

/* Accordion-Bereich in der Card */
#accordion {
    border: none;
    padding: 0;
}

/* Modernes Design für Accordion-Sektionen (kompakter) */
.accordion-section {
    background: #f9f9f9;
    border-radius: 8px;
    padding: 10px;
    /* Reduziert von 15px */
    margin-bottom: 8px;
    /* Reduziert von 10px */
    transition: background 0.3s ease, transform 0.3s ease;
}

.accordion-section:hover {
    background: #f1f1f1;
    transform: translateY(-2px);
}

.accordion-section h2 {
    font-size: 1.25rem;
    margin-bottom: 10px;
}

/* Weitere Anpassungen für Links */
.card-body ul {
    list-style: none;
    padding-left: 0;
    margin: 0;
}

.card-body ul li {
    margin-bottom: 8px;
    /* Reduziert von 12px */
}

.card-body ul li a {
    display: block;
    padding: 10px 14px;
    /* Reduziert von 14px 18px */
    border-radius: 10px;
    text-decoration: none;
    color: #333;
    background: #f7f7f7;
    transition: background 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
}

.card-body ul li a:hover {
    background: #eaeaea;
    transform: translateX(5px);
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.12);
}

/* Link Styles mit erhöhter Spezifität */
.link-item {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 8px 12px;
    margin-bottom: 6px;
    min-height: 50px;
    text-decoration: none;
    color: var(--color-fg);
    background: var(--color-neutral-50);
    border-radius: var(--radius-m);
    border: 1px solid var(--color-neutral-200);
    transition:
        background var(--transition-base) ease,
        border-color var(--transition-base) ease,
        color var(--transition-fast) ease,
        transform 260ms ease-out;
}

.link-item:last-child {
    margin-bottom: 0;
    /* Entfernt margin beim letzten Element */
}

.link-item:hover {
    background: var(--color-neutral-100);
    border-color: var(--color-neutral-300);
    transform: translateX(10px);
    text-decoration: none;
}

.link-item i {
    font-size: 20px;
    color: var(--color-primary);
    flex-shrink: 0;
}

.link-item .link-content {
    display: flex;
    flex-direction: column;
    gap: 2px;
    /* Reduziert von 4px */
}

.link-item .link-title {
    font-weight: 600;
    font-size: var(--font-size-base);
    line-height: 1.25;
    color: var(--color-fg);
}

.link-item .link-info {
    font-size: var(--font-size-xs);
    line-height: 1.2;
    color: var(--color-fg-muted) !important;
    text-decoration: none;
}

.link-item .link-info i {
    font-size: 0.8rem;
    /* Kleinere Info-Text */
    line-height: 1.2;
    color: #666 !important;
    /* Erzwinge die Farbe */
    text-decoration: none;
}

.link-item:hover .link-title,
.link-item:hover .link-info {
    color: inherit;
    /* Behält die definierten Farben auch beim Hover */
    text-decoration: none;
}

/* Status Card Structure */
.status-card {
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    margin: 0;
    min-height: 10px;
    height: auto;
    display: flex;
    overflow: hidden;
    background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%);
}

.status-card:hover {
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.status-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: 20px;
}

.status-content h2 {
    font-size: 1.1rem;
    font-weight: 500;
    color: #2c3e50;
    margin: 0;
}

.status-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
}

.status-header h2 {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 1.1rem;
    font-weight: 500;
    color: #2c3e50;
    margin: 0;
}

.status-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 10px;
    overflow-wrap: break-word;
    word-break: break-word;
}

/* Visitenkarten-Styling */
.business-card {
    background: white;
    border-radius: 0.375rem;
    padding: 20px;
    background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.business-card:hover {
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

.profile-section {
    display: flex;
    align-items: center;
    gap: 20px;
}

.profile-info h1 {
    font-size: 1.5rem;
    margin: 0;
    color: #333;
}

.profile-info .position {
    color: #666;
    font-size: 0.9rem;
    margin: 5px 0 0 0;
}

/* Email-Anzeige in der Visitenkarte */
.profile-info .email,
.profile-info .phone {
    color: #666;
    font-size: 0.85rem;
    margin: 5px 0 0 0;
    font-style: italic;
}

.profile-info .email i,
.profile-info .phone i {
    margin-right: 4px;
    color: #357abd;
}

/* Responsive Anpassungen */
@media (max-width: 576px) {
    .business-card {
        padding: 15px;
    }

    .profile-section {
        gap: 15px;
    }

    .profile-image {
        width: 60px;
        height: 60px;
    }

    .profile-info h1 {
        font-size: 1.2rem;
    }
}

@media (max-width: 767px) {
    .business-card {
        padding: 15px;
    }

    .profile-section {
        gap: 15px;
    }

    .profile-image {
        width: 60px;
        height: 60px;
    }

    .profile-info h1 {
        font-size: 1.2rem;
    }
}

/* Accessibility-friendly focus handling for accordion headers */
.accordion-button:focus {
    /* remove default blue ring for mouse focus */
    box-shadow: none !important;
    outline: none !important;
}

/* Keep a subtle focus indicator for keyboard navigation */
.accordion-button:focus-visible {
    box-shadow: 0 0 0 .15rem rgba(255, 255, 255, .35), 0 0 0 .35rem rgba(0, 0, 0, .25);
    outline: none;
}

/* --- Datacenter Enhancements --- */
.composite-link-item.link-item {
    padding: .55rem .85rem;
    flex-direction: column;
    align-items: stretch;
    gap: .35rem;
    transition:
        background var(--transition-base) ease,
        border-color var(--transition-base) ease,
        color var(--transition-fast) ease,
        transform 300ms cubic-bezier(.22,.61,.36,1);
}
.composite-link-item.link-item:hover {
    transform: translateX(10px);
    background: var(--color-neutral-100);
}
.composite-link-item .email-badges-desktop a.badge {
    font-weight: 500;
    background: var(--color-neutral-0);
    border: 1px solid var(--color-neutral-300);
    font-size: .72rem;
    line-height: 1.1;
    padding: .35rem .50rem;
    border-radius: .5rem;
    color: var(--color-fg-muted);
    transition: background var(--transition-fast) ease, border-color var(--transition-fast) ease, color var(--transition-fast) ease;
}
.composite-link-item .email-badges-desktop a.badge:hover {
    background: var(--color-neutral-100);
    border-color: var(--color-neutral-400);
    color: var(--color-fg);
}
.composite-link-item .email-badges-desktop a.badge i { font-size: .8rem; }

/* Tablet: Show icons only for desktop badges when space is tight */
@media (max-width: 1024px) and (min-width: 768px) {
    .composite-link-item .email-badges-desktop a.badge span {
        display: none;
    }
    .composite-link-item .email-badges-desktop a.badge {
        padding: .3rem .35rem;
        min-width: auto;
    }
    .composite-link-item .email-badges-desktop a.badge i {
        font-size: .75rem;
        margin: 0;
    }
}

/* Mobile: Hide email text, show only icon below address */
@media (max-width: 767px) {
    /* Hide desktop email badges */
    .composite-link-item .email-badges-desktop {
        display: none !important;
    }
    
    /* Show mobile email badges below */
    .composite-link-item .email-badges-mobile {
        display: flex !important;
    }
    
    .composite-link-item .email-badges-mobile a.badge span {
        display: none;
    }
    
    .composite-link-item .email-badges-mobile a.badge {
        padding: .3rem .35rem;
        min-width: auto;
        font-weight: 500;
        background: var(--color-neutral-0);
        border: 1px solid var(--color-neutral-300);
        border-radius: .5rem;
        color: var(--color-fg-muted);
    }
    
    .composite-link-item .email-badges-mobile a.badge:hover {
        background: var(--color-neutral-100);
        border-color: var(--color-neutral-400);
        color: var(--color-fg);
    }
    
    .composite-link-item .email-badges-mobile a.badge i {
        font-size: .75rem;
        margin: 0;
    }
}

/* Desktop: Hide mobile email badges */
@media (min-width: 768px) {
    .composite-link-item .email-badges-mobile {
        display: none !important;
    }
}

/* Deep link highlight */
.hash-target-highlight {
    animation: targetFlash 2s ease;
    box-shadow: 0 0 0 3px rgba(255,193,7,.45);
    border-radius: var(--radius-m);
    outline: 2px solid rgba(255,193,7,.5);
}
@keyframes targetFlash {
    0%,100% { background: transparent; }
    40% { background: rgba(255,193,7,.25); }
}

/* Neutralize inherited global link hover color inside link-item */
.link-item a,
.link-item a:visited,
.link-item a:hover,
.link-item a:focus {
    color: var(--color-fg);
    text-decoration: none;
}
.link-item a .link-title { color: var(--color-fg); }
.link-item a i { color: var(--color-primary); }
