/* =========================================
   Kaaspakhuis Portal – algemene layout
   ========================================= */

.kaasportal-app {
    padding: 40px 0;
    margin: 120px 0;
}

.kaasportal-app__container {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 15px;
    display: flex;
    gap: 24px;
    align-items: flex-start;
}

/* Sidebar links */

.kaasportal-app__sidebar {
    flex: 0 0 260px;
    background: #ffffff;
    border-radius: 12px;
    padding: 20px 18px;
    box-shadow: 0 10px 25px rgba(0,0,0,0.05);
}

.kaasportal-app__title {
    font-size: 22px;
    margin: 0 0 6px;
}

.kaasportal-app__welcome {
    font-size: 13px;
    color: #777;
    margin: 0 0 16px;
}

.kaasportal-app__menu {
    list-style: none;
    margin: 0;
    padding: 0;
}

.kaasportal-app__menu li {
    margin-bottom: 6px;
}

.kaasportal-app__menu a {
    display: block;
    padding: 10px 12px;
    border-radius: 8px;
    text-decoration: none;
    font-size: 14px;
    color: #333;
    background: transparent;
    transition: background 0.15s, color 0.15s;
}

.kaasportal-app__menu li.is-active a {
    background: #ffd34d;
    color: #000;
    font-weight: 600;
}

.kaasportal-app__menu li:not(.is-active) a:hover {
    background: #f0f0f0;
}

.kaasportal-app__menu--logout a {
    color: #b02a37;
}

/* Main content rechts */

.kaasportal-app__main {
    flex: 1;
    background: #ffffff;
    border-radius: 12px;
    padding: 24px 22px;
    box-shadow: 0 10px 25px rgba(0,0,0,0.05);
}

.kaasportal-app__main h2 {
    margin-top: 0;
}

/* =========================================
   Dashboard
   ========================================= */

.kaasportal-dashboard__totals {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    margin: 20px 0 5px;
}

.kaasportal-dashboard__total {
    background: #f8f8f8;
    border: 1px solid #e0e0e0;
    border-radius: 6px;
    padding: 12px 16px;
    min-width: 220px;
}

.kaasportal-dashboard__total .label {
    display: block;
    font-size: 13px;
    color: #666;
    margin-bottom: 4px;
}

.kaasportal-dashboard__total .value {
    font-size: 18px;
    font-weight: 600;
}

.kaasportal-dashboard__note {
    font-size: 12px;
    color: #777;
    margin-bottom: 20px;
}

/* Details in bestellingen */

.kaasportal-dashboard__details table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 8px;
    font-size: 13px;
}

.kaasportal-dashboard__details th,
.kaasportal-dashboard__details td {
    border: 1px solid #e0e0e0;
    padding: 4px 6px;
}

.kaasportal-dashboard__details th {
    background: #f3f3f3;
    font-weight: 600;
}

/* =========================================
   Tabel + alerts (hergebruikt bij bestellen)
   ========================================= */

.kaasportal-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 15px;
    font-size: 14px;
}

.kaasportal-table thead {
    background: #f3f3f3;
}

.kaasportal-table th,
.kaasportal-table td {
    padding: 8px 10px;
    border: 1px solid #e0e0e0;
    text-align: left;
}

.kaasportal-table th {
    font-weight: 600;
    white-space: nowrap;
}

.kaasportal-table tbody tr:nth-child(even) {
    background: #fafafa;
}

.kaasportal-table input[type="number"] {
    width: 80px;
    padding: 4px 6px;
    font-size: 14px;
    background: #e3e3e3;
}

/* Alerts */

.kaasportal-alert {
    padding: 12px 16px;
    border-radius: 4px;
    margin-bottom: 20px;
    font-size: 14px;
}

.kaasportal-alert--success {
    background: #e7f7ec;
    border: 1px solid #5cb85c;
    color: #256b2b;
}

.kaasportal-alert--error {
    background: #fbeaea;
    border: 1px solid #d9534f;
    color: #7c1c1a;
}

/* =========================================
   Bestellen-tab: layout lijst + formulier
   ========================================= */

.kaasportal-layout {
    display: flex;
    gap: 30px;
    align-items: flex-start;
}

/* Sidebar met bestellijsten */

.kaasportal-sidebar {
    flex: 0 0 260px;
    background: #f8f8f8;
    border: 1px solid #e0e0e0;
    border-radius: 6px;
    padding: 16px;
}

.kaasportal-sidebar h3 {
    margin-top: 0;
    font-size: 18px;
    margin-bottom: 10px;
}

.kaasportal-sidebar ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.kaasportal-sidebar li {
    margin-bottom: 4px;
}

.kaasportal-sidebar a {
    display: block;
    padding: 8px 10px;
    border-radius: 4px;
    text-decoration: none;
    font-size: 14px;
    border: 1px solid transparent;
    color: #333;
}

.kaasportal-sidebar li.is-active a {
    background: #f4e7bf;
    border-color: #e2c86b;
    font-weight: 600;
}

.kaasportal-sidebar li:not(.is-active) a:hover {
    background: #eeeeee;
}

/* Content rechts */

.kaasportal-content {
    flex: 1;
}

.kaasportal-content h3 {
    margin-top: 0;
    margin-bottom: 10px;
}

.kaasportal-content p {
    max-width: 800px;
}

/* Form velden */

.kaasportal-form__row {
    margin-top: 20px;
}

.kaasportal-form__row label {
    display: block;
    font-weight: 500;
    margin-bottom: 6px;
}

.kaasportal-form__row textarea {
    width: 100%;
    max-width: 600px;
    padding: 8px;
    font-size: 14px;
}

/* Submit button */

.kaasportal-form__actions {
    margin-top: 20px;
}

.kaasportal-form__actions button[type="submit"] {
    background: #e2c86b;
    color: #000;
    border: none;
    border-radius: 4px;
    padding: 10px 18px;
    font-size: 15px;
    cursor: pointer;
    font-weight: 600;
}

.kaasportal-form__actions button[type="submit"]:hover {
    background: #d4b654;
}

/* =========================================
   Responsive
   ========================================= */

@media (max-width: 900px) {
    .kaasportal-app__container {
        flex-direction: column;
    }

    .kaasportal-app__sidebar {
        width: 100%;
    }

    .kaasportal-layout {
        flex-direction: column;
    }

    .kaasportal-sidebar {
        width: 100%;
    }
}

/* Submenu onder "Kaas bestellen" */

.kaasportal-app__menu li.has-submenu > a {
    font-weight: 600;
}

.kaasportal-app__submenu {
    list-style: none;
    margin: 4px 0 0;
    padding: 0 0 0 10px;
    border-left: 1px solid #ececec;
}

.kaasportal-app__submenu li {
    margin-bottom: 3px;
}

.kaasportal-app__submenu a {
    font-size: 13px;
    padding: 6px 10px;
}

.kaasportal-app__submenu li.is-active a {
    background: #ffd34d;
    border-radius: 6px;
}