/* assets/css/style.css */
html, body {
    margin: 0;
    padding: 0;
    height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
    background-color: var(--bs-dark);
}

#app-container {
    display: flex;
    flex-direction: column;
    height: 100vh;
    overflow: hidden;
}

#main-content {
    display: flex;
    flex-grow: 1;
    overflow: hidden;
}

#map {
    flex: 1;
    height: 100%;
    background: #1e1e1e;
    cursor: default;
}

    #map.crosshair-cursor {
        cursor: crosshair;
    }

#sidebar {
    width: 50vw;
    min-width: 320px;
    max-width: 600px;
    flex-shrink: 0;
    height: 100%;
    overflow-y: hidden; /* Let the content div handle scrolling */
    transition: width 0.3s ease, padding 0.3s ease, transform 0.3s ease;
    background: #2c3034;
    border-left: 1px solid #444;
    padding: 0; /* HYAC-006: Remove padding here to allow full-width footer */
    position: relative;
    display: flex;
    flex-direction: column;
}

    #sidebar.collapsed {
        width: 0;
        padding: 0;
        overflow: hidden;
        border-left: none;
        min-width: 0;
    }

    #sidebar > h5 {
        padding: 1rem 1rem 0.5rem 1rem;
        margin-bottom: 0;
        border-bottom: 1px solid #444;
        flex-shrink: 0;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    #sidebar.collapsed > h5 {
        display: none;
    }

    #sidebar > hr {
        display: none;
    }

#sidebarContent {
    flex-grow: 1;
    overflow-y: auto;
    padding: 1rem; /* HYAC-006: Restore padding to the main content area */
}

#sidebarStatusMessages {
    flex-shrink: 0;
    border-top: 1px solid #444;
}

/* HYAC-006: Floating Action Button Styling START */
.form-action-footer {
    position: sticky;
    bottom: 0;
    left: 0;
    width: 100%;
    background-color: #2c3034; /* Match sidebar background */
    padding: 0.75rem 1rem;
    margin-top: auto; /* Push to bottom if content is short */
    border-top: 1px solid #444;
    box-shadow: 0 -2px 5px rgba(0, 0, 0, 0.2);
    z-index: 10;
}
/* HYAC-006: END */

#sidebarStatusMessages .alert {
    margin-bottom: 0;
    border-radius: 0;
    border-left: 0;
    border-right: 0;
    border-bottom: 0;
}

#sidebar.collapsed > #sidebarContent,
#sidebar.collapsed > #sidebarStatusMessages {
    display: none;
}

.navbar {
    flex-shrink: 0;
}

.nav-login-form {
    display: flex;
    gap: 5px;
    align-items: center;
}

    .nav-login-form input {
        width: 120px;
        font-size: 0.85rem;
        padding: 0.25rem 0.5rem;
    }

.nav-admin-links .nav-link,
.nav-view-selector .nav-link {
    padding: 0.3rem 0.6rem;
    font-size: 0.9rem;
}

.nav-view-selector {
    margin-left: 15px;
}

#sidebarContent img.img-fluid {
    max-width: 100%;
    height: auto;
    border-radius: 4px;
    border: 1px solid #444;
}

#sidebarContent h5 {
    margin-top: 0.8rem;
    margin-bottom: 0.3rem;
}

#sidebarContent p {
    margin-bottom: 0.6rem;
    line-height: 1.5;
}

#sidebarContent .table {
    font-size: 0.85rem;
}

    #sidebarContent .table td, #sidebarContent .table th {
        padding: 0.4rem;
    }

#sidebarContent form label {
    font-weight: bold;
    font-size: 0.85rem;
    margin-bottom: 0.2rem;
    display: block;
}

#sidebarContent form .form-control,
#sidebarContent form .form-select {
    font-size: 0.9rem;
    margin-bottom: 0.75rem;
}

#sidebarContent form textarea.form-control {
    min-height: 60px;
}

#sidebarContent form button {
    margin-right: 5px;
}

#sidebarContent .form-check {
    margin-bottom: 0.3rem;
}

#sidebarContent .form-check-label {
    font-weight: normal;
    font-size: 0.9rem;
}

.emoji-icon div {
    text-shadow: 1px 1px 2px rgba(0,0,0,0.7);
}

.loading-indicator {
    text-align: center;
    padding: 20px;
    font-style: italic;
    color: #aaa;
}

.needs-validation .form-control:invalid,
.needs-validation .form-select:invalid {
    border-color: var(--bs-form-invalid-border-color);
}

.needs-validation .form-control:valid,
.needs-validation .form-select:valid {
    border-color: var(--bs-form-valid-border-color);
}

.was-validated .form-control:invalid,
.was-validated .form-select:invalid {
    background-image: var(--bs-form-invalid-bg-image);
    background-repeat: no-repeat;
    background-position: right calc(0.375em + 0.1875rem) center;
    background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}

.was-validated .invalid-feedback {
    display: block;
}

.leaflet-popup-content-wrapper, .leaflet-popup-tip {
    background: #333;
    color: #eee;
    box-shadow: 0 3px 14px rgba(0,0,0,0.4);
}

.leaflet-popup-close-button {
    color: #ccc;
}

    .leaflet-popup-close-button:hover {
        color: #fff;
    }

.leaflet-popup-content h6 {
    margin-bottom: 0.2rem;
}

#sidebarContent .list-group-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    padding: 0.5rem 0.75rem;
}

#sidebarContent .tag-details {
    display: flex;
    align-items: center;
    flex-grow: 1;
    margin-right: 1rem;
    margin-bottom: 0.5rem;
}

#sidebarContent .tag-icon {
    font-size: 1.5em;
    margin-right: 0.75rem;
    width: 30px;
    text-align: center;
}

#sidebarContent .tag-name {
    font-weight: 500;
}

#sidebarContent .tag-count {
    font-size: 0.8em;
    color: var(--bs-secondary-color);
    margin-left: 0.5rem;
}

#sidebarContent .tag-actions button {
    margin-left: 0.5rem;
}

#sidebarContent .edit-tag-controls {
    display: flex;
    align-items: center;
    flex-grow: 1;
    gap: 0.5rem;
    margin-right: 1rem;
    margin-bottom: 0.5rem;
}

    #sidebarContent .edit-tag-controls input, #sidebarContent .edit-tag-controls select {
        max-width: 180px;
    }

#fixedAlertContainer {
    position: fixed;
    top: 60px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2000;
    min-width: 300px;
    max-width: 80%;
    pointer-events: none;
}

    #fixedAlertContainer .alert {
        pointer-events: auto;
    }

.navbar-dark .navbar-nav .nav-link {
    transition: color 0.2s ease-in-out, background-color 0.2s ease-in-out;
    border-radius: 0.25rem;
    margin-right: 2px;
    margin-left: 2px;
}

    .navbar-dark .navbar-nav .nav-link:hover,
    .navbar-dark .navbar-nav .nav-link:focus {
        color: #ffffff;
        background-color: #007bff;
    }

    .navbar-dark .navbar-nav .nav-link.active {
        color: #fff;
        background-color: #0056b3;
    }

.navbar-dark .navbar-nav .dropdown-toggle:hover,
.navbar-dark .navbar-nav .dropdown-toggle:focus {
    color: #ffffff;
    background-color: #007bff;
}

.dropdown-menu {
    background-color: #343a40;
}

.dropdown-item {
    color: #f8f9fa;
    transition: color 0.2s ease-in-out, background-color 0.2s ease-in-out;
}

    .dropdown-item:hover,
    .dropdown-item:focus {
        color: #ffffff;
        background-color: #007bff;
    }

    .dropdown-item.active, .dropdown-item:active {
        color: #fff;
        background-color: #0056b3;
    }

.plant-image-carousel .carousel-item img {
    max-height: 300px;
    object-fit: contain;
    margin: auto;
    border-radius: 0.25rem;
    border: 1px solid #444;
}

.plant-image-carousel .carousel-control-prev-icon,
.plant-image-carousel .carousel-control-next-icon {
    background-color: rgba(0, 0, 0, 0.5);
    border-radius: 50%;
    padding: 10px;
}

.plant-image-carousel .carousel-control-prev,
.plant-image-carousel .carousel-control-next {
    width: 5%;
}

.image-watermark {
    position: absolute;
    bottom: 5px;
    right: 5px;
    background-color: rgba(0, 0, 0, 0.5);
    color: white;
    padding: 2px 5px;
    font-size: 0.7rem;
    border-radius: 3px;
    z-index: 10;
}

.text-content-box {
    background-color: #272b30;
    border: 1px solid #3e444a;
    border-radius: 0.375rem;
    padding: 0.75rem 1rem;
    margin-bottom: 1rem;
    color: #ced4da;
}

    .text-content-box h5 {
        border-bottom: none;
        padding-bottom: 0;
        margin-bottom: 0.5rem;
        color: #e9ecef;
    }

    .text-content-box p {
        margin-bottom: 0;
        line-height: 1.6;
        font-size: 0.9rem;
    }

.default-plant-icon,
[class^="plant-icon-cat-"],
[class*=" plant-icon-tag-"] {
    font-size: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    line-height: 1;
    font-weight: normal;
    color: #fff;
}

.special-banner-marker-icon {
    padding: 2px;
    box-sizing: border-box;
}

.leaflet-div-icon {
    background: transparent;
    border: none;
}
