/* eBizBoard — Frontend CSS
   BEM-Klassen, theme-neutral, überschreibbar via /themes/xy/ebizboard/
   ========================================================================= */

/* -------------------------------------------------------------------------
   Basis / Reset
   -------------------------------------------------------------------------*/
.ebizboard-directory,
.ebizboard-profile,
.ebizboard-dashboard,
.ebizboard-form {
    font-family: inherit;
    color: inherit;
    line-height: 1.6;
}

/* -------------------------------------------------------------------------
   Buttons
   -------------------------------------------------------------------------*/
.ebizboard-btn {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .55rem 1.25rem;
    border: 1px solid currentColor;
    border-radius: 4px;
    font-size: .875rem;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    transition: background .15s, color .15s;
}
.ebizboard-btn--primary {
    background: #DC2626;
    color: #fff;
    border-color: #DC2626;
}
.ebizboard-btn--primary:hover { background: #b91c1c; border-color: #b91c1c; color: #fff; }
.ebizboard-btn--sm { padding: .35rem .9rem; font-size: .8rem; }

/* -------------------------------------------------------------------------
   Notices
   -------------------------------------------------------------------------*/
.ebizboard-notice {
    padding: .875rem 1.25rem;
    border-left: 4px solid;
    border-radius: 0 4px 4px 0;
    margin-bottom: 1.25rem;
}
.ebizboard-notice--success { background: #f0fdf4; border-color: #22c55e; color: #166534; }
.ebizboard-notice--error   { background: #fef2f2; border-color: #ef4444; color: #991b1b; }
.ebizboard-notice--warning { background: #fffbeb; border-color: #f59e0b; color: #92400e; }
.ebizboard-notice--info    { background: #eff6ff; border-color: #3b82f6; color: #1e40af; }

/* -------------------------------------------------------------------------
   Verzeichnis
   -------------------------------------------------------------------------*/
.ebizboard-directory { padding: 2rem 0; }

.ebizboard-directory__filters {
    margin-bottom: 1.5rem;
}

.ebizboard-directory__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: .75rem;
    margin-bottom: 1.25rem;
}

.ebizboard-result-count { margin: 0; color: #6b7280; font-size: .9rem; }
.ebizboard-result-count--empty { color: #374151; }

.ebizboard-sort { display: flex; align-items: center; gap: .5rem; font-size: .875rem; }
.ebizboard-sort select { padding: .3rem .6rem; border: 1px solid #d1d5db; border-radius: 4px; }

.ebizboard-directory__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 1.25rem;
}

/* -------------------------------------------------------------------------
   Anbieter-Karte
   -------------------------------------------------------------------------*/
.ebizboard-card {
    position: relative;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: .75rem;
    transition: box-shadow .2s, border-color .2s;
}
.ebizboard-card:hover {
    box-shadow: 0 4px 12px rgba(0,0,0,.08);
    border-color: #d1d5db;
}
.ebizboard-card--highlighted {
    border-color: #FBBF24;
    box-shadow: 0 0 0 1px #FBBF24, 0 4px 12px rgba(251,191,36,.15);
}

.ebizboard-card__badge {
    position: absolute;
    top: -10px;
    right: 1rem;
    padding: .2rem .7rem;
    border-radius: 20px;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .03em;
    color: #111;
}

.ebizboard-card__header {
    display: flex;
    align-items: flex-start;
    gap: .875rem;
}
.ebizboard-card__logo { flex-shrink: 0; }
.ebizboard-card__logo img { width: 56px; height: 56px; object-fit: contain; border-radius: 6px; }
.ebizboard-card__title-group { flex: 1; min-width: 0; }
.ebizboard-card__title { margin: 0 0 .25rem; font-size: 1rem; font-weight: 600; }
.ebizboard-card__title a { color: inherit; text-decoration: none; }
.ebizboard-card__title a:hover { color: #DC2626; }
.ebizboard-card__type { font-size: .78rem; color: #6b7280; }

.ebizboard-card__location {
    display: flex;
    align-items: center;
    gap: .35rem;
    font-size: .85rem;
    color: #6b7280;
}
.ebizboard-card__excerpt {
    margin: 0;
    font-size: .875rem;
    color: #4b5563;
    flex: 1;
}

.ebizboard-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: .5rem;
    margin-top: auto;
    padding-top: .75rem;
    border-top: 1px solid #f3f4f6;
}
.ebizboard-card__phone { font-size: .8rem; color: #374151; text-decoration: none; }
.ebizboard-card__phone:hover { color: #DC2626; }

/* -------------------------------------------------------------------------
   Verifiziert-Badge
   -------------------------------------------------------------------------*/
.ebizboard-verified {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    background: #22c55e;
    color: #fff;
    border-radius: 50%;
    font-size: .65rem;
    font-weight: 700;
    vertical-align: middle;
    margin-left: .25rem;
}
.ebizboard-verified--lg { width: 22px; height: 22px; font-size: .75rem; }

/* -------------------------------------------------------------------------
   Filter-Leiste
   -------------------------------------------------------------------------*/
.ebizboard-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: flex-end;
    padding: 1rem;
    background: #f9fafb;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
}
.ebizboard-filter { display: flex; flex-direction: column; gap: .35rem; }
.ebizboard-filter label,
.ebizboard-filter__label { font-size: .8rem; font-weight: 500; color: #374151; }
.ebizboard-filter input[type="text"],
.ebizboard-filter input[type="search"],
.ebizboard-filter select {
    padding: .45rem .7rem;
    border: 1px solid #d1d5db;
    border-radius: 4px;
    font-size: .875rem;
    background: #fff;
}
.ebizboard-filter input:focus,
.ebizboard-filter select:focus { outline: 2px solid #DC2626; outline-offset: 0; border-color: #DC2626; }

.ebizboard-filter--radius .ebizboard-filter__radius-row { display: flex; gap: .5rem; }
.ebizboard-filter--checkbox label { font-weight: 400; display: flex; align-items: center; gap: .4rem; }
.ebizboard-filter__count { color: #9ca3af; font-size: .75rem; }
.ebizboard-filter--submit { flex-direction: row; align-items: flex-end; gap: .5rem; }
.ebizboard-filters__reset { color: #6b7280; border-color: #d1d5db; }

/* -------------------------------------------------------------------------
   Einzelprofil
   -------------------------------------------------------------------------*/
.ebizboard-profile__header {
    background: #374151;
    color: #fff;
    padding: 2rem 0;
    margin-bottom: 2rem;
}
.ebizboard-profile__header-inner {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    flex-wrap: wrap;
}
.ebizboard-profile__logo img { width: 80px; height: 80px; object-fit: contain; border-radius: 8px; background: #fff; padding: 4px; }
.ebizboard-profile__name { margin: 0 0 .5rem; font-size: 1.6rem; color: #fff; }
.ebizboard-profile__meta { display: flex; gap: .5rem; flex-wrap: wrap; }

.ebizboard-tag {
    display: inline-block;
    padding: .2rem .7rem;
    background: rgba(255,255,255,.15);
    color: #fff;
    border-radius: 3px;
    font-size: .8rem;
    text-decoration: none;
}
.ebizboard-tag:hover { background: rgba(255,255,255,.25); color: #fff; }

.ebizboard-badge {
    display: inline-block;
    padding: .2rem .7rem;
    border-radius: 20px;
    font-size: .75rem;
    font-weight: 700;
    color: #111;
    margin-top: .5rem;
}

.ebizboard-profile__layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 2rem;
    align-items: start;
}
@media (max-width: 768px) {
    .ebizboard-profile__layout { grid-template-columns: 1fr; }
}

.ebizboard-section { margin-bottom: 2rem; }
.ebizboard-section__title { font-size: 1.1rem; border-bottom: 2px solid #e5e7eb; padding-bottom: .5rem; margin-bottom: 1rem; }
.ebizboard-section__body { font-size: .95rem; line-height: 1.7; }
.ebizboard-section__body p:last-child { margin-bottom: 0; }

.ebizboard-contact-card {
    background: #f9fafb;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 1.25rem;
    position: sticky;
    top: 1rem;
}
.ebizboard-contact-card h3 { margin-top: 0; font-size: 1rem; }
.ebizboard-contact-card__row {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .5rem 0;
    border-top: 1px solid #e5e7eb;
    font-size: .875rem;
    color: #374151;
}
.ebizboard-contact-card__row a { color: inherit; text-decoration: none; }
.ebizboard-contact-card__row a:hover { color: #DC2626; }
.ebizboard-contact-card__row svg { flex-shrink: 0; color: #9ca3af; }

.ebizboard-breadcrumb { font-size: .8rem; color: #9ca3af; }
.ebizboard-breadcrumb a { color: #6b7280; text-decoration: none; }
.ebizboard-breadcrumb a:hover { color: #DC2626; }

/* -------------------------------------------------------------------------
   Dashboard
   -------------------------------------------------------------------------*/
.ebizboard-dashboard { padding: 1.5rem 0; }
.ebizboard-dashboard__nav {
    display: flex;
    gap: 0;
    border-bottom: 2px solid #e5e7eb;
    margin-bottom: 1.5rem;
}
.ebizboard-dashboard__nav a {
    padding: .65rem 1.25rem;
    text-decoration: none;
    color: #6b7280;
    font-size: .875rem;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
}
.ebizboard-dashboard__nav a:hover,
.ebizboard-dashboard__nav a.active { color: #DC2626; border-bottom-color: #DC2626; }

.ebizboard-dashboard__stats { display: flex; gap: 1.5rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.ebizboard-stat {
    flex: 1;
    min-width: 120px;
    background: #f9fafb;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 1rem;
    text-align: center;
}
.ebizboard-stat__value { display: block; font-size: 1.6rem; font-weight: 700; color: #374151; }
.ebizboard-stat__label { font-size: .78rem; color: #6b7280; }

.ebizboard-dashboard__actions { display: flex; gap: .75rem; flex-wrap: wrap; margin-bottom: 1.5rem; }

.ebizboard-completeness { margin-top: 1.5rem; }
.ebizboard-completeness h4 { margin: 0 0 .5rem; font-size: .875rem; }
.ebizboard-progress { background: #e5e7eb; border-radius: 4px; height: 8px; margin-bottom: .5rem; }

/* -------------------------------------------------------------------------
   Registrierungs- / Profil-Formulare
   -------------------------------------------------------------------------*/
.ebizboard-form { max-width: 680px; }
.ebizboard-form__row { margin-bottom: 1.25rem; }
.ebizboard-form__row label { display: block; font-size: .85rem; font-weight: 500; margin-bottom: .35rem; color: #374151; }
.ebizboard-form__row input[type="text"],
.ebizboard-form__row input[type="email"],
.ebizboard-form__row input[type="tel"],
.ebizboard-form__row input[type="url"],
.ebizboard-form__row input[type="password"],
.ebizboard-form__row select,
.ebizboard-form__row textarea {
    width: 100%;
    padding: .6rem .9rem;
    border: 1px solid #d1d5db;
    border-radius: 4px;
    font-size: .9rem;
    background: #fff;
    box-sizing: border-box;
}
.ebizboard-form__row input:focus,
.ebizboard-form__row select:focus,
.ebizboard-form__row textarea:focus { outline: 2px solid #DC2626; outline-offset: 0; border-color: #DC2626; }
.ebizboard-form__row--half { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.ebizboard-form__row--locked label { color: #9ca3af; }
.ebizboard-form__row--locked input,
.ebizboard-form__row--locked textarea { background: #f9fafb; color: #9ca3af; cursor: not-allowed; }

/* -------------------------------------------------------------------------
   Paginierung
   -------------------------------------------------------------------------*/
.ebizboard-pagination {
    display: flex;
    gap: .4rem;
    justify-content: center;
    margin-top: 2rem;
    flex-wrap: wrap;
}
.ebizboard-pagination__item {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: 1px solid #e5e7eb;
    border-radius: 4px;
    text-decoration: none;
    font-size: .85rem;
    color: #374151;
    transition: background .15s;
}
.ebizboard-pagination__item:hover { background: #f3f4f6; }
.ebizboard-pagination__item.is-current { background: #DC2626; color: #fff; border-color: #DC2626; }

/* -------------------------------------------------------------------------
   Tarif & Abo (Dashboard-Übersicht)
   -------------------------------------------------------------------------*/
.ebizboard-subscription { margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid #e5e7eb; }
.ebizboard-subscription h4 { margin: 0 0 .75rem; }
.ebizboard-subscription__current { margin-bottom: 1rem; }
.ebizboard-subscription__current p { margin: 0 0 .5rem; }

.ebizboard-level-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 1rem;
    margin-top: 1rem;
}
.ebizboard-level-card {
    position: relative;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 1.25rem;
    background: #fff;
    transition: box-shadow .15s;
}
.ebizboard-level-card:hover { box-shadow: 0 2px 8px rgba(0,0,0,.08); }
.ebizboard-level-card.is-highlighted {
    border-color: #FBBF24;
    box-shadow: 0 0 0 2px #FBBF2440;
}
.ebizboard-level-card__badge {
    display: inline-block;
    padding: .15rem .5rem;
    border-radius: 3px;
    font-size: .75rem;
    font-weight: 600;
    margin-bottom: .5rem;
    color: #374151;
}
.ebizboard-level-card h5 { margin: 0 0 .35rem; font-size: 1rem; }
.ebizboard-level-card__price { color: #6b7280; font-size: .875rem; margin: 0 0 1rem; }
.ebizboard-level-card form { margin: 0; }

/* Placeholder für noch nicht implementierte Shortcodes */
.ebizboard-placeholder { color: #9ca3af; font-style: italic; font-size: .875rem; }

/* -------------------------------------------------------------------------
   Anfrage-Formular (inline, Toggle-Prinzip)
   -------------------------------------------------------------------------*/
.ebizboard-inquiry { margin-top: 1rem; }
.ebizboard-inquiry__form { margin-top: 1rem; }
.ebizboard-inquiry__actions { display: flex; gap: .5rem; align-items: center; margin-top: .75rem; flex-wrap: wrap; }
.ebizboard-form__checkbox { display: flex; align-items: flex-start; gap: .5rem; font-size: .85rem; cursor: pointer; }
.ebizboard-form__checkbox input[type="checkbox"] { margin-top: .15rem; flex-shrink: 0; }

/* -------------------------------------------------------------------------
   Anfragen Dashboard-Tab
   -------------------------------------------------------------------------*/
.ebizboard-inquiries__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.25rem;
}
.ebizboard-inquiries__header h3 { margin: 0; }

.ebizboard-inquiry-list { display: flex; flex-direction: column; gap: 1rem; }

.ebizboard-inquiry-item {
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 1.25rem;
    background: #fff;
}
.ebizboard-inquiry-item--answered { border-left: 3px solid #22c55e; }
.ebizboard-inquiry-item--open     { border-left: 3px solid #FBBF24; }
.ebizboard-inquiry-item--closed   { border-left: 3px solid #9ca3af; opacity: .8; }

.ebizboard-inquiry-item__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: .75rem;
    flex-wrap: wrap;
}
.ebizboard-inquiry-item__from {
    display: flex;
    flex-direction: column;
    gap: .2rem;
    font-size: .875rem;
}
.ebizboard-inquiry-item__from strong { font-size: 1rem; }
.ebizboard-inquiry-item__from a { color: #6b7280; text-decoration: none; }
.ebizboard-inquiry-item__from a:hover { color: #DC2626; }

.ebizboard-inquiry-item__aside {
    display: flex;
    align-items: center;
    gap: .5rem;
    flex-shrink: 0;
}
.ebizboard-inquiry-item__date { font-size: .8rem; color: #9ca3af; }
.ebizboard-inquiry-item__meta { font-size: .85rem; color: #6b7280; margin: .25rem 0 .75rem; }
.ebizboard-inquiry-item__body { font-size: .9rem; color: #374151; line-height: 1.6; }

.ebizboard-status-badge {
    display: inline-block;
    padding: .15rem .55rem;
    border-radius: 3px;
    font-size: .78rem;
    font-weight: 600;
}
.ebizboard-status-badge--open     { background: #fef9c3; color: #854d0e; }
.ebizboard-status-badge--answered { background: #dcfce7; color: #166534; }
.ebizboard-status-badge--closed   { background: #f3f4f6; color: #6b7280; }

.ebizboard-inquiry-item__replies {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid #e5e7eb;
    font-size: .875rem;
}
.ebizboard-inquiry-reply {
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 6px;
    padding: .75rem 1rem;
    margin-top: .5rem;
}
.ebizboard-inquiry-reply__date { display: block; font-size: .78rem; color: #9ca3af; margin-bottom: .35rem; }

.ebizboard-inquiry-item__reply-wrap {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid #e5e7eb;
}
.ebizboard-inquiry-item__reply-wrap > summary {
    cursor: pointer;
    font-size: .875rem;
    font-weight: 600;
    color: #DC2626;
    user-select: none;
}
.ebizboard-inquiry-reply-form { margin-top: .75rem; }
.ebizboard-inquiry-reply__textarea {
    width: 100%;
    padding: .6rem .9rem;
    border: 1px solid #d1d5db;
    border-radius: 4px;
    font-size: .9rem;
    box-sizing: border-box;
    resize: vertical;
}

/* -------------------------------------------------------------------------
   Angebots-Karten (Anbieter-Profil: Aktuelle Angebote)
   -------------------------------------------------------------------------*/
.ebizboard-offers {
    display: flex;
    flex-direction: column;
    gap: .75rem;
}
.ebizboard-offer-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    background: #f9fafb;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 1rem 1.25rem;
}
.ebizboard-offer-card__body { flex: 1; min-width: 0; }
.ebizboard-offer-card__title {
    margin: 0 0 .35rem;
    font-size: .95rem;
    font-weight: 600;
}
.ebizboard-offer-card__title a { color: #374151; text-decoration: none; }
.ebizboard-offer-card__title a:hover { color: #DC2626; }
.ebizboard-offer-card__meta {
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
    font-size: .8rem;
    color: #6b7280;
}
.ebizboard-offer-card__cta { white-space: nowrap; flex-shrink: 0; }

/* -------------------------------------------------------------------------
   Angebots-Dashboard-Tab (Anbieter-Dashboard)
   -------------------------------------------------------------------------*/
.ebizboard-offers__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.25rem;
}
.ebizboard-offers__header h3 { margin: 0; }
.ebizboard-offers__table {
    width: 100%;
    border-collapse: collapse;
    font-size: .875rem;
}
.ebizboard-offers__table th,
.ebizboard-offers__table td {
    text-align: left;
    padding: .6rem .75rem;
    border-bottom: 1px solid #e5e7eb;
}
.ebizboard-offers__table th { font-weight: 600; color: #374151; background: #f9fafb; }
.ebizboard-offers__table td { color: #4b5563; vertical-align: middle; }
.ebizboard-offers__table tr:last-child td { border-bottom: none; }
.ebizboard-offers__table .is-expired td { color: #9ca3af; }

/* -------------------------------------------------------------------------
   Single Offer
   -------------------------------------------------------------------------*/
.ebizboard-single-offer { padding: 2rem 0 3rem; }
.ebizboard-offer-meta {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1.5rem;
    font-size: .875rem;
    color: #6b7280;
}
.ebizboard-offer-meta .is-expired-badge {
    background: #fee2e2;
    color: #991b1b;
    padding: .2rem .6rem;
    border-radius: 3px;
    font-weight: 500;
}

/* -------------------------------------------------------------------------
   Banküberweisung-Details (nach Checkout)
   -------------------------------------------------------------------------*/
.ebizboard-transfer-details {
    background: #f0f9ff;
    border: 1px solid #bae6fd;
    border-radius: 6px;
    padding: 1.25rem 1.5rem;
    margin: 1rem 0 1.5rem;
}

.ebizboard-transfer-details h4 {
    margin: 0 0 .875rem;
    font-size: 1rem;
    font-weight: 600;
    color: #0369a1;
}

.ebizboard-transfer-table {
    width: 100%;
    border-collapse: collapse;
}

.ebizboard-transfer-table th,
.ebizboard-transfer-table td {
    padding: .35rem 0;
    text-align: left;
    font-size: .9rem;
    border-bottom: 1px solid #e0f2fe;
    vertical-align: top;
}

.ebizboard-transfer-table tr:last-child th,
.ebizboard-transfer-table tr:last-child td {
    border-bottom: none;
}

.ebizboard-transfer-table th {
    color: #6b7280;
    font-weight: 400;
    width: 38%;
    padding-right: 1rem;
}

.ebizboard-transfer-details__note {
    margin: .875rem 0 0;
    font-size: .825rem;
    color: #0369a1;
}
