/* =====================================================
   DESIGN SYSTEM – Münchner Archiv Stil
===================================================== */

:root {

    /* =====================================================
       PRIMARY COLORS
    ===================================================== */

    --color-primary: #ff0000;
    --color-primary-soft: #ff4d4d;
    --color-primary-dark: #cc0000;

    /* =====================================================
       ACCENT COLORS
    ===================================================== */

    --color-accent: #c8a96a;
    --color-accent-soft: #e0c38f;

    /* =====================================================
       TEXT COLORS
    ===================================================== */

    --color-text: #2e2e2e;
    --color-text-light: #666666;
    --color-text-white: #ffffff;

    /* =====================================================
       BACKGROUNDS
    ===================================================== */

    --color-white: #ffffff;

    --color-bg: #f8f6f2;
    --color-bg-soft: #f1eee8;
    --color-bg-hover: #e7f1ff;

    /* =====================================================
       BORDERS
    ===================================================== */

    --color-border: #ddd6c8;
    --color-border-light: #dee2e6;

    /* =====================================================
       NAVIGATION
    ===================================================== */

    --color-nav-link:
        rgba(255, 255, 255, .9);

    --color-nav-link-dim:
        rgba(255, 255, 255, .85);

    --color-overlay:
        rgba(255, 255, 255, .08);

    /* =====================================================
       SLIDER / MAP
    ===================================================== */

    --color-slider-track: #dddddd;

    --color-map-active: #0d6efd;

    /* =====================================================
       NEWSLETTER
    ===================================================== */

    --color-newsletter-badge-bg: #fff4f3;

    --color-newsletter-badge-border: #ffe5e2;

    /* =====================================================
       BREADCRUMB
    ===================================================== */

    --color-breadcrumb-separator: #aaaaaa;

    /* =====================================================
       SHADOWS
    ===================================================== */

    --color-shadow:
        rgba(0, 0, 0, 0.05);

    --color-shadow-strong:
        rgba(0, 0, 0, 0.1);

    /* =====================================================
       TYPOGRAPHY
    ===================================================== */

    --font-serif:
        Georgia,
        "Times New Roman",
        serif;

    --font-sans:
        system-ui,
        -apple-system,
        "Segoe UI",
        Roboto,
        Arial,
        sans-serif;

    /* =====================================================
       SPACING
    ===================================================== */

    --space-xs: 4px;
    --space-sm: 8px;
    --space-md: 16px;
    --space-lg: 24px;
    --space-xl: 40px;

    /* =====================================================
       RADIUS
    ===================================================== */

    --radius-sm: 4px;
    --radius-md: 8px;

    /* =====================================================
       SHADOWS
    ===================================================== */

    --shadow-soft:
        0 2px 8px var(--color-shadow);

    --shadow-dropdown:
        0 6px 20px var(--color-shadow-strong);

    /* =====================================================
       LAYOUT
    ===================================================== */

    --header-height: 130px;
}

/* =====================================================
   BASE
===================================================== */

body {
    background: var(--color-bg);
    color: var(--color-text);
    font-family: 'Happy Monkey', cursive, Arial, sans-serif;
    font-size: 15px;
    line-height: 1.6;
    margin: 0;
}

/* =====================================================
   LINKS
===================================================== */

a {
    color: var(--color-primary);
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

/* =====================================================
   FOCUS
===================================================== */

a:focus,
button:focus {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
}

/* =====================================================
   HEADLINES
===================================================== */

h1,
h2,
h3 {
    font-weight: 500;
    color: var(--color-primary);
    margin-top: 0;
}

/* =====================================================
   LAYOUT
===================================================== */

.container-fluid {
    max-width: 1400px;
    margin: 0 auto;
}

header {
    position: relative;
    z-index: 2000;
    background: var(--color-white);
}

.page-title-box {
    position: relative;
    z-index: 1;
}

/* =====================================================
   NAVIGATION
===================================================== */

.nav-main {
    background: var(--color-primary);
    border-bottom:
        1px solid rgba(0, 0, 0, .1);
}

.nav-clean {
    display: flex;
    align-items: center;
    gap: 40px;
    padding: 14px 0;
    font-family: var(--font-sans);
}

.nav-clean .nav-link {

    color: var(--color-nav-link);

    font-size: 18px;

    transition: .2s;
}

.nav-clean .nav-link:hover {
    color: var(--color-text-white);
}

.nav-clean .nav-link.active {
    color: var(--color-text-white);
    font-weight: 500;
}

.nav-clean .dropdown-menu {
    border-radius: 6px;
    border: none;
    box-shadow: var(--shadow-dropdown);
}

/* =====================================================
   BREADCRUMB
===================================================== */

.breadcrumb {
    font-size: 14px;
    background: transparent;
}

.breadcrumb-item {
    color: var(--color-text-light);
}

.breadcrumb-item+.breadcrumb-item::before {
    content: "›";
    padding: 0 6px;
    color: var(--color-breadcrumb-separator);
}

/* =====================================================
   CONTENT
===================================================== */

.text-content {
    font-size: 16px;
    line-height: 1.8;
}

/* =====================================================
   CARDS
===================================================== */

.card {

    background: var(--color-white);

    border:
        1px solid var(--color-border);

    border-radius: var(--radius-md);

    padding: var(--space-md);

    box-shadow: var(--shadow-soft);

    margin-bottom: var(--space-md);
}

/* =====================================================
   BUTTONS
===================================================== */

.btn-primary-custom {
    background: var(--color-primary);
    color: var(--color-text-white);
    border-radius: var(--radius-sm);
}

.btn-primary-custom:hover {
    background: var(--color-primary-soft);
}

/* =====================================================
   TABLES
===================================================== */

.table {
    width: 100%;
    border-collapse: collapse;
}

.table th {
    width: 30%;
    color: var(--color-primary);
}

/* =====================================================
   SIDEBAR
===================================================== */

aside {
    font-size: 14px;
}

@media (min-width: 992px) {
    aside {
        padding-left: var(--space-md);
    }
}

/* =====================================================
   MAP SYSTEM
===================================================== */

body.map-page {
    height: 100%;
}

#mapWrap {
    display: flex;
    flex-direction: column;
    height:
        calc(100vh - var(--header-height));
}

.filter-bar {
    position: sticky;
    top: 0;
    z-index: 500;
    background: var(--color-white);
    border-bottom:
        1px solid var(--color-border);
    padding: 10px 20px;
    display: flex;
    gap: 20px;
    box-shadow: var(--shadow-soft);
}

/* =====================================================
   SLIDER
===================================================== */

.slider-box {
    flex: 1;
    padding: 5px 15px;
    border-right:
        1px solid var(--color-border);
}

.slider-ui {
    height: 8px;
    margin-top: 10px;
}

/* =====================================================
   MAIN CONTENT
===================================================== */

.main-content {
    display: flex;
    flex: 1;
    overflow: hidden;
}

#map {
    flex: 1;
}

#sidebar {

    width: 380px;

    background: var(--color-white);

    border-left:
        1px solid var(--color-border);

    overflow-y: auto;
}

/* =====================================================
   ENTRY ITEMS
===================================================== */

.entry-item {
    padding: var(--space-md);
    border-bottom:
        1px solid var(--color-border);
    cursor: pointer;
}

.entry-item:hover {
    background: var(--color-bg-soft);
}

.entry-item.active-item {
    background: var(--color-bg-hover);
    border-left:
        4px solid var(--color-map-active);
}

/* =====================================================
   NOUISLIDER
===================================================== */

.noUi-connect {
    background:
        var(--color-primary) !important;
}

.noUi-handle {

    background:
        var(--color-primary) !important;

    border:
        2px solid var(--color-text-white) !important;
}

.noUi-target {
    background:
        var(--color-slider-track) !important;
}

.noUi-horizontal .noUi-tooltip {

    background:
        var(--color-primary);

    color:
        var(--color-text-white);

    border: none;
}

/* =====================================================
   MOBILE
===================================================== */

@media (max-width: 992px) {

    .main-content {
        flex-direction: column;
    }

    #sidebar {
        width: 100%;
        height: 40%;
        border-left: none;
        border-top:
            1px solid var(--color-border);
    }

    .filter-bar {
        flex-direction: column;
    }

}

/* =====================================================
   NEWSLETTER
===================================================== */

.newsletter-compact {
    border-radius: 6px;
    overflow: hidden;
}

.newsletter-header {

    background:
        var(--color-primary);

    color:
        var(--color-text-white);

    font-size: .75rem;

    letter-spacing: 1px;
}

.newsletter-header .dot {
    color: var(--color-primary);
}

.newsletter-input {

    padding: .5rem .6rem;

    font-size: .8rem;

    border-radius: 4px;

    border:
        1px solid var(--color-border-light);
}

.newsletter-input:focus {

    border-color:
        var(--color-primary);

    box-shadow: none;
}

.newsletter-check {
    margin-left: 0;
    padding-left: 0;
}

.newsletter-check .form-check-input {
    margin-left: 0;
}

.newsletter-btn {

    font-size: .75rem;

    letter-spacing: 1px;

    border-radius: 4px;

    color:
        var(--color-text-white);

    background:
        var(--color-primary);
}

.newsletter-badge {

    font-size: .65rem;

    background:
        var(--color-newsletter-badge-bg);

    border:
        1px solid var(--color-newsletter-badge-border);

    padding: 2px 6px;

    border-radius: 999px;

    color:
        var(--color-primary);
}

/* =====================================================
   SMALL TEXT
===================================================== */

.x-small {
    font-size: .65rem;
}

/* =====================================================
   FOOTER
===================================================== */

.footer-light {

    background:
        var(--color-bg-soft);

    color:
        var(--color-text);
}

.footer-link {

    color:
        var(--color-text-light);

    text-decoration: none;

    transition: .2s;
}

.footer-link:hover {

    color:
        var(--color-primary);

    padding-left: 4px;
}

.footer-social a {

    display: inline-block;

    margin-right: 10px;

    font-size: 18px;

    color:
        var(--color-text-light);

    transition: .2s;
}

.footer-social a:hover {

    color:
        var(--color-accent);

    transform:
        translateY(-2px);
}

.footer-light hr {
    border-color: var(--color-border);
}

/* =====================================================
   NO SCROLLBAR
===================================================== */

.no-scrollbar::-webkit-scrollbar {
    display: none;
}

.no-scrollbar {
    -ms-overflow-style: none;
    scrollbar-width: none;
    white-space: nowrap;
}

/* =====================================================
   NAVIGATION LINKS
===================================================== */

.nav-main .nav-link {
    transition: opacity .2s;
    font-weight: 500;
}

.nav-main .nav-link:hover {
    opacity: .8;
}

.nav-main .nav-link.active {
    border-bottom:
        2px solid var(--color-text-white);
}

.nav-link {

    font-size: .95rem;

    white-space: nowrap;

    color:
        var(--color-nav-link-dim);

    transition: opacity .2s;
}

.nav-link:hover {

    opacity: 1;

    color:
        var(--color-text-white) !important;
}

.nav-link.active {

    border-bottom:
        2px solid var(--color-primary);

    opacity: 1;
}

/* =====================================================
   LAYER FIXES
===================================================== */

.sticky-top {
    z-index: 1050 !important;
}

.dropdown-menu {
    z-index: 1100 !important;
}

/* =====================================================
   LOGIN DROPDOWN
===================================================== */

.login-dropdown-small {

    width: 240px !important;

    padding: 1rem !important;
}

.login-dropdown-small .form-control-sm {

    font-size: .85rem;

    padding: .25rem .5rem;
}

.login-dropdown-small .btn-sm {

    padding: .25rem;

    font-size: .85rem;
}

.text-gross {
    font-size: 19px;
    line-height: 1.7;
    /* Harmonischer Zeilenabstand für große Schrift */
    color: var(--color-text);
    font-weight: 400;
    margin-bottom: var(--space-lg);
    padding-left: var(--space-md);
}