/* ===================================================
   Bekendmakingen Widget — Stylesheet
   =================================================== */

:root {
    --bmw-primary:       #1a4fa0;
    --bmw-primary-light: #2563c4;
    --bmw-accent:        #e85d04;
    --bmw-bg:            #f8faff;
    --bmw-card-bg:       #ffffff;
    --bmw-border:        #d1ddf5;
    --bmw-text:          #1c2b4a;
    --bmw-muted:         #5a6f94;
    --bmw-badge-bg:      #e8effc;
    --bmw-badge-text:    #1a4fa0;
    --bmw-radius:        10px;
    --bmw-shadow:        0 2px 12px rgba(26, 79, 160, 0.08);
    --bmw-transition:    0.2s ease;
    --bmw-font:          'Segoe UI', system-ui, -apple-system, sans-serif;
}

/* Container */
.bmw-wrapper {
    font-family: var(--bmw-font);
    color: var(--bmw-text);
    max-width: 700px;
    position: relative;
}

/* Meta row */
.bmw-meta {
    display: flex;
    align-items: center;
    margin-bottom: 1rem;
    font-size: 0.82rem;
    color: var(--bmw-muted);
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

/* Record list */
.bmw-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.75rem;
}

/* Single record card */
.bmw-record {
    background: var(--bmw-card-bg);
    border: 1px solid var(--bmw-border);
    border-radius: var(--bmw-radius);
    padding: 1.1rem 1.25rem;
    box-shadow: var(--bmw-shadow);
    transition: box-shadow var(--bmw-transition), transform var(--bmw-transition), border-color var(--bmw-transition);
    position: relative;
    overflow: hidden;
}

.bmw-record::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 4px;
    background: var(--bmw-primary);
    border-radius: var(--bmw-radius) 0 0 var(--bmw-radius);
    opacity: 0;
    transition: opacity var(--bmw-transition);
}

.bmw-record:hover {
    box-shadow: 0 6px 24px rgba(26, 79, 160, 0.14);
    transform: translateY(-2px);
    border-color: var(--bmw-primary-light);
}

.bmw-record:hover::before {
    opacity: 1;
}

/* Record header */
.bmw-record-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 0.5rem;
}

/* Badge */
.bmw-badge {
    display: inline-block;
    background: var(--bmw-badge-bg);
    color: var(--bmw-badge-text);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    padding: 0.2em 0.65em;
    border-radius: 4px;
    border: 1px solid rgba(26, 79, 160, 0.15);
    white-space: nowrap;
}

/* Date */
.bmw-date {
    font-size: 0.78rem;
    color: var(--bmw-muted);
    margin-left: auto;
}

/* Title */
.bmw-title {
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.35;
    margin: 0 0 0.4rem;
    color: var(--bmw-text);
}

.bmw-title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--bmw-transition);
}

.bmw-title a:hover {
    color: var(--bmw-primary-light);
}

/* Creator */
.bmw-creator {
    font-size: 0.82rem;
    color: var(--bmw-muted);
    margin: 0 0 0.4rem;
    display: flex;
    align-items: center;
    gap: 0.3rem;
}

.bmw-icon {
    font-size: 0.9em;
}

/* Abstract */
.bmw-abstract {
    font-size: 0.88rem;
    color: var(--bmw-muted);
    line-height: 1.5;
    margin: 0 0 0.6rem;
}

/* Read more link */
.bmw-read-more {
    display: inline-flex;
    align-items: center;
    gap: 0.3em;
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--bmw-primary);
    text-decoration: none;
    letter-spacing: 0.02em;
    transition: color var(--bmw-transition), gap var(--bmw-transition);
}

.bmw-read-more:hover {
    color: var(--bmw-accent);
    gap: 0.5em;
}

/* Pagination */
.bmw-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-top: 1.25rem;
    flex-wrap: wrap;
}

.bmw-page-info {
    font-size: 0.85rem;
    color: var(--bmw-muted);
    text-align: center;
    flex: 1;
}

.bmw-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.3em;
    background: var(--bmw-primary);
    color: #fff;
    border: none;
    border-radius: 6px;
    padding: 0.45em 1em;
    font-size: 0.85rem;
    font-weight: 700;
    cursor: pointer;
    transition: background var(--bmw-transition), transform var(--bmw-transition);
    font-family: inherit;
}

.bmw-btn:hover:not(:disabled) {
    background: var(--bmw-primary-light);
    transform: translateY(-1px);
}

.bmw-btn:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

/* Loading */
.bmw-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    padding: 2rem;
    color: var(--bmw-muted);
    font-size: 0.9rem;
}

.bmw-spinner {
    width: 22px;
    height: 22px;
    border: 3px solid var(--bmw-border);
    border-top-color: var(--bmw-primary);
    border-radius: 50%;
    animation: bmw-spin 0.75s linear infinite;
}

@keyframes bmw-spin {
    to { transform: rotate(360deg); }
}

/* Error / empty */
.bmw-error,
.bmw-empty {
    background: var(--bmw-bg);
    border: 1px dashed var(--bmw-border);
    border-radius: var(--bmw-radius);
    padding: 2rem 1.5rem;
    text-align: center;
    color: var(--bmw-muted);
}

.bmw-error-icon,
.bmw-empty-icon {
    display: block;
    font-size: 2rem;
    margin-bottom: 0.5rem;
}

.bmw-error p,
.bmw-empty p {
    margin: 0;
    font-size: 0.9rem;
}

/* Source attribution */
.bmw-source {
    font-size: 0.75rem;
    color: var(--bmw-muted);
    text-align: right;
    margin-top: 0.75rem;
    margin-bottom: 0;
}

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

.bmw-source a:hover {
    text-decoration: underline;
}

/* Responsive */
@media (max-width: 480px) {
    .bmw-pagination {
        flex-direction: column;
        align-items: stretch;
    }
    .bmw-btn {
        justify-content: center;
    }
    .bmw-page-info {
        order: -1;
    }
}
