/* Worksite Briefportal – Kunden-Frontend */
.wbp-login-wrap {
    display: flex;
    justify-content: center;
    padding: 40px 16px;
}
.wbp-login-box {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    padding: 36px 40px;
    width: 100%;
    max-width: 400px;
    box-shadow: 0 2px 12px rgba(0,0,0,.07);
}
.wbp-login-box h2 { margin-top: 0; font-size: 22px; text-align: center; }

.wbp-alert {
    padding: 10px 14px;
    border-radius: 6px;
    margin-bottom: 16px;
    font-size: 14px;
}
.wbp-alert--error { background: #fee2e2; color: #991b1b; border: 1px solid #fca5a5; }

.wbp-form .wbp-field { margin-bottom: 16px; }
.wbp-form label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 5px; }
.wbp-form input[type="email"],
.wbp-form input[type="password"] {
    width: 100%;
    padding: 9px 12px;
    border: 1px solid #d1d5db;
    border-radius: 6px;
    font-size: 14px;
    box-sizing: border-box;
    transition: border-color .15s;
}
.wbp-form input:focus { outline: none; border-color: #2563eb; box-shadow: 0 0 0 3px rgba(37,99,235,.15); }

.wbp-remember { font-size: 13px; display: flex; align-items: center; gap: 6px; margin-bottom: 18px; }

.wbp-btn { display: inline-block; padding: 10px 20px; border-radius: 6px; font-size: 14px; font-weight: 600; cursor: pointer; border: none; transition: background .15s; text-decoration: none; }
.wbp-btn--primary { background: #1d4ed8; color: #fff; width: 100%; text-align: center; }
.wbp-btn--primary:hover { background: #1e40af; color: #fff; }
.wbp-btn--sm { padding: 5px 12px; font-size: 12px; background: #f3f4f6; color: #374151; border: 1px solid #d1d5db; border-radius: 5px; }
.wbp-btn--sm:hover { background: #e5e7eb; color: #111; }
.wbp-link { color: #2563eb; font-size: 13px; display: block; text-align: center; margin-top: 12px; }

/* Postfach */
.wbp-inbox { max-width: 760px; margin: 0 auto; padding: 16px; }
.wbp-inbox__header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; flex-wrap: wrap; gap: 10px; }
.wbp-inbox__header h2 { margin: 0; }
.wbp-search-form { display: flex; gap: 6px; }
.wbp-search-form input { padding: 7px 10px; border: 1px solid #d1d5db; border-radius: 6px; font-size: 13px; }
.wbp-search-form button { padding: 7px 14px; background: #1d4ed8; color: #fff; border: none; border-radius: 6px; cursor: pointer; font-size: 13px; }

.wbp-doc-list { display: flex; flex-direction: column; gap: 8px; }
.wbp-doc-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    transition: box-shadow .15s;
}
.wbp-doc-item:hover { box-shadow: 0 2px 8px rgba(0,0,0,.08); }
.wbp-doc-item--unread { border-left: 4px solid #2563eb; }
.wbp-doc-item__icon { font-size: 28px; flex-shrink: 0; }
.wbp-doc-item__info { flex: 1; }
.wbp-doc-item__info strong { display: block; font-size: 15px; }
.wbp-doc-item__meta { font-size: 12px; color: #6b7280; margin-top: 2px; display: block; }
.wbp-doc-item__actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }

.wbp-badge--new { background: #dbeafe; color: #1e40af; font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 10px; }

.wbp-empty { text-align: center; padding: 40px; color: #6b7280; font-size: 15px; }
.wbp-inbox__footer { margin-top: 24px; text-align: center; font-size: 13px; color: #6b7280; }

.wbp-profile-box {
    background: #f9fafb;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 24px;
    margin-top: 24px;
    max-width: 380px;
}
.wbp-profile-box h3 { margin-top: 0; }
.wbp-field { margin-bottom: 14px; }
.wbp-field label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 4px; }
.wbp-input { width: 100%; padding: 8px 10px; border: 1px solid #d1d5db; border-radius: 6px; font-size: 14px; box-sizing: border-box; }

@media (max-width: 600px) {
    .wbp-login-box { padding: 24px 20px; }
    .wbp-doc-item { flex-wrap: wrap; }
    .wbp-inbox__header { flex-direction: column; align-items: flex-start; }
}
