/* Multi-Hosting Management Interface – unified UI */

:root {
    --app-navbar-height: 56px;
    --app-content-max-width: 1400px;
    --app-flash-icon-size: 1.1rem;
}

body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.navbar-brand {
    font-weight: 600;
}

/* Single flash area – clear, no duplicates */
#app-flash-container {
    flex-shrink: 0;
}

.app-flash {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
}

.app-flash .bi {
    font-size: var(--app-flash-icon-size);
    flex-shrink: 0;
    margin-top: 0.15rem;
}

.app-flash-message {
    flex: 1;
    word-break: break-word;
}

/* Bootstrap uses alert-danger; Nette flash type is often "error" */
.alert-error { background-color: var(--bs-danger-bg-subtle, #f8d7da); color: var(--bs-danger); border-color: var(--bs-danger-border-subtle); }
.app-flash.alert-danger .bi,
.app-flash.alert-error .bi { color: var(--bs-danger); }
.app-flash.alert-warning .bi { color: var(--bs-warning); }
.app-flash.alert-success .bi { color: var(--bs-success); }
.app-flash.alert-info .bi { color: var(--bs-info); }

/* Main content */
main.container-fluid {
    flex: 1;
    max-width: 100%;
}

/* Cards – consistent spacing */
.card {
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
}

.card-header {
    font-weight: 600;
}

/* Tables – responsive */
.table-responsive {
    -webkit-overflow-scrolling: touch;
}

@media (max-width: 767.98px) {
    .table-responsive .btn {
        padding: 0.25rem 0.5rem;
        font-size: 0.875rem;
    }
}

/* Forms – consistent */
.form-label {
    font-weight: 500;
}

/* Loading overlay */
#global-loading-overlay {
    backdrop-filter: blur(2px);
}

#global-loading-overlay.d-flex {
    flex-direction: column;
}

/* Buttons in nav / content */
.btn-sm i.bi {
    vertical-align: -0.15em;
}

/* Responsive padding for content blocks */
@media (max-width: 575.98px) {
    main.container-fluid {
        padding-left: 0.75rem !important;
        padding-right: 0.75rem !important;
    }
}
