/* INCON Portal — Shell, Farben, Komponenten (wird auch nach public/css kopiert für Deploy ohne Vite) */

html {
    height: 100%;
}

body.portal-app {
    margin: 0;
    min-height: 100%;
}

/* INCON Farbwelt */
:root {
    --incon-primary: #00234f;
    --incon-primary-80: #23426e;
    --incon-primary-60: #51678f;
    --incon-primary-40: #8592b3;
    --incon-primary-20: #bfc5d9;
    --incon-secondary: #4a5154;
    --incon-secondary-80: #71787c;
    --incon-secondary-60: #959ca0;
    --incon-accent: #009ee3;
    --incon-accent-hover: #0080b8;
    --incon-sidebar-bg: #eceff3;
    --incon-main-bg: #e4e7ec;

    --bs-primary: var(--incon-accent);
    --bs-primary-rgb: 0, 158, 227;
    --bs-link-color: var(--incon-accent);
    --bs-link-hover-color: var(--incon-accent-hover);
    --bs-body-color: var(--incon-secondary);
    --bs-secondary: var(--incon-secondary-60);
    --bs-secondary-rgb: 149, 156, 160;
    --bs-border-color: var(--incon-primary-20);
}

/* App-Shell */
.portal-app {
    display: flex;
    min-height: 100vh;
    color: var(--incon-secondary);
}

.portal-sidebar {
    width: 4.5rem;
    flex-shrink: 0;
    background: var(--incon-sidebar-bg);
    border-right: 1px solid rgba(0, 35, 79, 0.08);
    display: flex;
    flex-direction: column;
    align-items: stretch;
    padding-top: 0.5rem;
}

.portal-sidebar-nav {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    padding: 0 0.35rem;
}

.portal-sidebar-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    aspect-ratio: 1;
    max-height: 3rem;
    color: var(--incon-secondary-80);
    border-radius: 0.5rem;
    text-decoration: none;
    position: relative;
    transition:
        color 0.15s ease,
        background-color 0.15s ease;
}

.portal-sidebar-link:hover:not(.portal-sidebar-link--disabled) {
    color: var(--incon-primary);
    background: rgba(0, 35, 79, 0.06);
}

.portal-sidebar-link.is-active {
    color: var(--incon-primary);
    background: rgba(0, 158, 227, 0.1);
}

.portal-sidebar-link.is-active::before {
    content: '';
    position: absolute;
    left: -0.35rem;
    top: 50%;
    transform: translateY(-50%);
    width: 4px;
    height: 60%;
    background: var(--incon-accent);
    border-radius: 0 2px 2px 0;
}

.portal-sidebar-link--disabled {
    opacity: 0.38;
    cursor: not-allowed;
    pointer-events: none;
}

.portal-sidebar-link i {
    font-size: 1.35rem;
}

.portal-shell {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

/* Topbar */
.portal-topbar {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.6fr) minmax(0, 1.1fr);
    gap: 0.75rem 1rem;
    align-items: center;
    padding: 0.65rem 1.25rem;
    background: var(--incon-primary);
    color: #fff;
    box-shadow: 0 0.125rem 1rem rgba(0, 35, 79, 0.22);
}

@media (max-width: 991.98px) {
    .portal-topbar {
        grid-template-columns: 1fr;
        justify-items: center;
        text-align: center;
    }

    .portal-topbar__brand {
        order: 1;
    }

    .portal-topbar__titles {
        order: 3;
    }

    .portal-topbar__actions {
        order: 2;
    }
}

.portal-topbar__logo-link {
    display: inline-block;
    line-height: 0;
    text-decoration: none;
}

.portal-topbar__logo-link:hover {
    opacity: 0.92;
}

/* Externes incon-vm.de-Logo (SVG als <img>, inkl. Claim): für dunkle Topbar einheitlich weiß */
.portal-topbar .portal-logo-topbar {
    height: 2.65rem;
    width: auto;
    max-width: min(100%, 320px);
    display: block;
    filter: brightness(0) invert(1);
}

.portal-topbar__heading {
    font-size: clamp(1.15rem, 2.5vw, 1.5rem);
    font-weight: 700;
    color: #fff;
    line-height: 1.2;
}

.portal-topbar__sub {
    color: rgba(255, 255, 255, 0.82);
    font-size: clamp(0.78rem, 0.7rem + 0.35vw, 0.875rem);
    line-height: 1.45;
    max-width: min(100%, 34rem);
    margin-inline: auto;
    padding-inline: clamp(0.35rem, 3vw, 0.75rem);
    box-sizing: border-box;
    hyphens: auto;
    overflow-wrap: break-word;
    text-wrap: pretty;
}

@media (min-width: 768px) {
    .portal-topbar__sub {
        line-height: 1.38;
    }
}

.portal-topbar__sub strong {
    color: #fff;
    font-weight: 600;
}

/* Lesbarkeit: Fließtext im Dashboard nicht über die volle Breite */
.portal-intro-copy {
    max-width: 42rem;
}

.portal-topbar__brand {
    justify-self: start;
}

.portal-topbar__brand-inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.85rem 1.75rem;
}

.portal-topbar__ix-link {
    display: inline-block;
    line-height: 0;
    text-decoration: none;
    border-left: 1px solid rgba(255, 255, 255, 0.42);
    padding-left: 1.35rem;
}

.portal-topbar__ix-link:hover {
    opacity: 0.92;
}

/* IX-Promo-Grafik (externes SVG); bei Bedarf ohne Invert, damit Farben erhalten bleiben */
.portal-topbar .portal-logo-ix-topbar {
    height: 2.4rem;
    width: auto;
    max-width: min(100%, 280px);
    display: block;
}

.portal-topbar__titles {
    justify-self: center;
    text-align: center;
}

.portal-topbar__actions {
    justify-self: end;
}

@media (max-width: 991.98px) {
    .portal-topbar__brand,
    .portal-topbar__titles,
    .portal-topbar__actions {
        justify-self: center;
        text-align: center;
    }
}

.portal-topbar .btn-outline-light {
    --bs-btn-color: #fff;
    --bs-btn-border-color: rgba(255, 255, 255, 0.65);
    --bs-btn-hover-bg: rgba(255, 255, 255, 0.12);
    --bs-btn-hover-border-color: #fff;
    --bs-btn-hover-color: #fff;
    --bs-btn-active-bg: rgba(255, 255, 255, 0.2);
    --bs-btn-active-border-color: #fff;
}

/* Verschachtelte Modals: Vertragsdetails über „Ticket anlegen“ */
#portalTicketAnlegenModal.modal {
    z-index: 1055;
}

#portalVertragModal.modal {
    z-index: 1065;
}

/* Modal „Ticket anlegen“: Vertragsliste */
.portal-ticket-anlegen-scroll {
    max-height: min(50vh, 22rem);
}

.portal-ticket-anlegen-row {
    cursor: pointer;
}

.portal-ticket-anlegen-sm-badge {
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.02em;
}

.portal-ticket-anlegen-iban--ok {
    border-color: rgba(25, 135, 84, 0.6) !important;
    background-color: rgba(25, 135, 84, 0.05) !important;
}

.portal-ticket-anlegen-iban--bad {
    border-color: rgba(220, 53, 69, 0.6) !important;
    background-color: rgba(220, 53, 69, 0.05) !important;
}

.portal-ticket-anlegen-boolean-col {
    display: flex;
    flex-direction: column;
    min-height: 6rem;
}

.portal-ticket-anlegen-boolean-label {
    margin-bottom: 0 !important;
}

.portal-ticket-anlegen-boolean-col .form-select {
    display: block;
    margin-top: auto !important;
}

.portal-main {
    flex: 1;
    background: var(--incon-main-bg);
    overflow-y: auto;
}

/* column: sonst wird die .row als Flex-Item in der Zeile auf Mindestbreite gequetscht */
.portal-main--centered > .container-fluid {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 100%;
    max-width: 100%;
    min-height: calc(100vh - 11rem);
    box-sizing: border-box;
}

.portal-main--centered > .container-fluid > .row {
    width: 100%;
    max-width: 100%;
}

.portal-footer-dark {
    flex-shrink: 0;
    background: var(--incon-primary);
    color: rgba(255, 255, 255, 0.82);
    border-top: 3px solid var(--incon-accent);
    padding: 0.85rem 1rem;
    font-size: 0.8125rem;
}

.portal-footer-dark a {
    color: #fff;
    text-decoration: none;
    opacity: 0.92;
}

.portal-footer-dark a:hover {
    color: #fff;
    opacity: 1;
    text-decoration: underline;
}

.portal-footer-dark .portal-footer-sep {
    opacity: 0.45;
    user-select: none;
}

.portal-card {
    border: 1px solid var(--incon-primary-20);
    box-shadow: 0 0.35rem 1.25rem rgba(0, 35, 79, 0.07);
    border-radius: 0.5rem;
    background: #fff;
}

.portal-card .card-title,
.portal-card h1,
.portal-card h2 {
    color: var(--incon-primary);
}

/* Bootstrap setzt code oft auf Pink — INCON-Farben durchsetzen */
.portal-app code {
    color: var(--incon-primary);
}

.portal-code {
    color: var(--incon-primary) !important;
    background-color: rgba(0, 158, 227, 0.1) !important;
    border: 1px solid rgba(0, 158, 227, 0.35) !important;
    padding: 0.15rem 0.4rem;
    border-radius: 0.25rem;
    font-size: 0.9em;
}

.btn-primary {
    --bs-btn-bg: var(--incon-accent);
    --bs-btn-border-color: var(--incon-accent);
    --bs-btn-hover-bg: var(--incon-accent-hover);
    --bs-btn-hover-border-color: var(--incon-accent-hover);
    --bs-btn-active-bg: var(--incon-accent-hover);
    --bs-btn-active-border-color: var(--incon-accent-hover);
    font-weight: 600;
}

.form-control:focus {
    border-color: var(--incon-accent);
    box-shadow: 0 0 0 0.2rem rgba(0, 158, 227, 0.2);
}

/* Tickets: horizontales Scrollen, Tabelle wächst mit Inhalt — keine gequetschten Kopfzeilen */
.tickets-table-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
}

.tickets-data-table {
    width: max-content;
    max-width: none;
    table-layout: auto;
}

/* Verträge: nur zwei Spalten — volle Containerbreite (Tickets bleiben bei max-content) */
.portal-vertraege-table .tickets-data-table {
    width: 100%;
    max-width: 100%;
    table-layout: fixed;
}

.portal-vertraege-table .tickets-data-table__th {
    min-width: 0;
}

.portal-vertraege-table .tickets-data-table__head-row {
    min-width: 0;
}

.portal-vertraege-table .tickets-data-table thead th:first-child,
.portal-vertraege-table .tickets-data-table tbody td:first-child {
    width: 72%;
}

.portal-vertraege-table .tickets-data-table thead th:last-child,
.portal-vertraege-table .tickets-data-table tbody td:last-child {
    width: 28%;
}

.tickets-data-table__th {
    min-width: 10.5rem;
    max-width: none;
    vertical-align: top;
}

.tickets-data-table__head-row {
    min-width: max-content;
}

.tickets-data-table__icons .tickets-data-table__icon-btn {
    min-width: 1.35rem;
    text-decoration: none;
}

.tickets-data-table__icons .tickets-data-table__icon-btn:hover,
.tickets-data-table__icons .tickets-data-table__icon-btn:focus-visible {
    color: var(--incon-accent) !important;
}

.tickets-data-table__filter {
    min-width: 0;
}

.tickets-data-table__filter-collapse:not(.show) {
    margin: 0;
    padding: 0;
    border: 0;
}

/*
 * Ticket-Status als Badges (Controlling-Werte).
 * .portal-app td … zusätzlich zu .tickets-data-table: auf dem Server darf die Tabelle ohne
 * Klasse tickets-data-table oder mit anderer Verschachtelung sein — Log zeigte korrektes statusColumnKey.
 */
.portal-app td .portal-status-badge,
.tickets-data-table td .portal-status-badge,
.portal-vertrag-modal__schaeden .portal-status-badge {
    display: inline-block;
    padding: 0.22em 0.6em;
    border-radius: 0.35rem;
    font-size: 0.8125em;
    font-weight: 600;
    line-height: 1.25;
    white-space: nowrap;
    vertical-align: middle;
}

.portal-app td .portal-status-badge--offen,
.tickets-data-table td .portal-status-badge--offen,
.portal-vertrag-modal__schaeden .portal-status-badge--offen {
    background-color: #dcdfe1 !important;
    color: #2f3438 !important;
}

.portal-app td .portal-status-badge--bearbeitung,
.tickets-data-table td .portal-status-badge--bearbeitung,
.portal-vertrag-modal__schaeden .portal-status-badge--bearbeitung {
    background-color: #009ee3 !important;
    color: #fff !important;
}

.portal-app td .portal-status-badge--abgelehnt,
.portal-app td .portal-status-badge--abgeschlossen,
.tickets-data-table td .portal-status-badge--abgelehnt,
.tickets-data-table td .portal-status-badge--abgeschlossen,
.portal-vertrag-modal__schaeden .portal-status-badge--abgelehnt,
.portal-vertrag-modal__schaeden .portal-status-badge--abgeschlossen {
    background-color: #00234f !important;
    color: #fff !important;
}

.portal-app td .portal-status-badge--default,
.tickets-data-table td .portal-status-badge--default,
.portal-vertrag-modal__schaeden .portal-status-badge--default {
    background-color: #e8eaed !important;
    color: var(--incon-secondary) !important;
}

/* Vertrags-Modal: Schäden-Kacheln */
.portal-vertrag-schaeden-tile {
    border-color: var(--incon-primary-20) !important;
    background: #fafbfc !important;
    transition:
        box-shadow 0.15s ease,
        border-color 0.15s ease,
        transform 0.15s ease;
}

.portal-vertrag-schaeden-tile:hover {
    border-color: var(--incon-accent) !important;
    box-shadow: 0 0.2rem 0.75rem rgba(0, 35, 79, 0.08);
    transform: translateY(-1px);
}

/* Vertrag-Modal: Deckungen (INCON-Blau aktiv, Grau inaktiv) */
.portal-vertrag-cover__icon {
    font-size: 1.35rem;
    line-height: 1;
    flex-shrink: 0;
}

.portal-vertrag-cover__icon--on,
.portal-vertrag-cover__icon--on::before {
    color: #009ee3 !important;
}

.portal-vertrag-cover__icon--off,
.portal-vertrag-cover__icon--off::before {
    color: #adb5bd !important;
}

.portal-vertrag-deckungen-info:hover,
.portal-vertrag-deckungen-info:focus {
    color: #009ee3 !important;
}

.portal-vertrag-deckungen-tooltip .tooltip-inner {
    max-width: min(320px, 90vw);
    text-align: left;
    font-size: 0.8125rem;
}

.portal-vertrag-documents-list .list-group-item {
    border-color: rgba(var(--bs-secondary-rgb), 0.22);
}

.portal-vertrag-doc-link:hover .fw-semibold {
    text-decoration: underline;
}

.portal-vertrag-doc__icon {
    font-size: 1.65rem;
    line-height: 1;
    color: #009ee3;
}

.portal-vertrag-doc__icon--muted {
    color: #adb5bd;
}

/* VDIV-Premiumpartner (Controlling kunden.vdidv / kunden.vdiv = 1) */
@media (min-width: 992px) {
    .portal-vdiv-partner {
        padding-left: 1.5rem;
        border-left: 1px solid var(--incon-primary-20);
        min-height: 100%;
    }
}

.portal-vdiv-partner__lead {
    max-width: 22rem;
}

.portal-vdiv-partner__logo {
    max-width: min(100%, 280px);
    max-height: 4.75rem;
    width: auto;
    height: auto;
    object-fit: contain;
}

.dashboard-schaden-card {
    transition: box-shadow 0.15s ease, transform 0.15s ease;
}

.dashboard-schaden-card:hover {
    box-shadow: 0 0.35rem 1rem rgba(0, 35, 79, 0.12) !important;
    transform: translateY(-1px);
}

/* Gespiegelte Event-Sektion — Layout wie incon-vm.de/events-und-termine/ */
.portal-events-mirror {
    --portal-event-navy: var(--incon-primary);
    font-size: 0.9375rem;
    line-height: 1.5;
    background: var(--incon-main-bg);
    border-radius: 0.75rem;
    padding: 1.35rem 1.25rem 1.5rem;
    margin-top: 0.25rem;
}

.portal-events-mirror .kb-row-layout-wrap,
.portal-events-mirror .kt-row-column-wrap {
    margin: 0 !important;
    padding: 0 !important;
    max-width: none !important;
}

.portal-events-mirror h2.wp-block-kadence-advancedheading,
.portal-events-mirror h2.kt-adv-heading {
    font-size: 1.35rem !important;
    font-weight: 700 !important;
    color: var(--portal-event-navy) !important;
    text-align: center;
    margin: 0 0 1.35rem !important;
    padding: 0;
    line-height: 1.25;
}

.portal-events-mirror .event-post-wrapper {
    width: 100%;
}

.portal-events-mirror .event-wrapper {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.portal-events-mirror .list-item {
    background: #fff;
    border-radius: 0.75rem;
    box-shadow: 0 2px 14px rgba(0, 35, 79, 0.09);
    margin-bottom: 1rem;
    overflow: hidden;
}

.portal-events-mirror .list-item:last-of-type {
    margin-bottom: 0;
}

.portal-events-mirror .list-item .content {
    padding: 1rem 1.2rem;
}

.portal-events-mirror .list-item .col-wrapper {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    gap: 1rem;
}

.portal-events-mirror .list-item .col-wrapper > .col-left {
    flex-shrink: 0;
}

.portal-events-mirror .list-item .col-wrapper > .col-right {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.portal-events-mirror .list-item .date-wrapper {
    background: var(--portal-event-navy);
    color: #fff;
    border-radius: 0.5rem;
    padding: 0.6rem 0.75rem;
    min-width: 4.35rem;
    min-height: 4.35rem;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    line-height: 1.15;
}

.portal-events-mirror .list-item .date-wrapper .month {
    display: block;
    font-size: 0.7rem;
    font-weight: 500;
    opacity: 0.95;
}

.portal-events-mirror .list-item .date-wrapper .day {
    display: block;
    font-size: 1.35rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    margin-top: 0.15rem;
}

.portal-events-mirror .list-item .text:empty {
    display: none;
}

.portal-events-mirror .list-item .title {
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.35;
}

.portal-events-mirror .list-item .title a {
    color: var(--portal-event-navy) !important;
    text-decoration: none;
    word-break: break-word;
}

.portal-events-mirror .list-item .title a:hover {
    color: var(--incon-accent) !important;
    text-decoration: underline;
}

.portal-events-mirror .meta-wrapper {
    display: flex;
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
    gap: 0.75rem 1rem;
    margin-top: 0.85rem;
    flex-wrap: wrap;
}

.portal-events-mirror .meta-wrapper > .col-left {
    flex: 1 1 auto;
    min-width: 0;
}

.portal-events-mirror .meta-wrapper > .col-right {
    flex-shrink: 0;
}

.portal-events-mirror .location {
    display: flex;
    align-items: flex-start;
    gap: 0.4rem;
    color: var(--incon-secondary-60);
    font-size: 0.875rem;
    line-height: 1.4;
}

.portal-events-mirror .location .icon-location {
    flex-shrink: 0;
    width: 1rem;
    height: 1rem;
    margin-top: 0.12rem;
    background-color: currentcolor;
    mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='black' d='M8 16s6-5.686 6-10A6 6 0 0 0 2 6c0 4.314 6 10 6 10zm0-7a3 3 0 1 1 0-6 3 3 0 0 1 0 6z'/%3E%3C/svg%3E")
        center / contain no-repeat;
    -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='black' d='M8 16s6-5.686 6-10A6 6 0 0 0 2 6c0 4.314 6 10 6 10zm0-7a3 3 0 1 1 0-6 3 3 0 0 1 0 6z'/%3E%3C/svg%3E")
        center / contain no-repeat;
}

/* „Zum Termin“ wie Portal-Primärbutton */
.portal-events-mirror .meta-wrapper > .col-right > a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem 1.1rem;
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.25;
    color: #fff !important;
    text-decoration: none !important;
    white-space: nowrap;
    border-radius: 0.5rem;
    background: var(--incon-accent);
    border: none;
    word-break: normal;
    transition:
        background-color 0.15s ease,
        box-shadow 0.15s ease;
}

.portal-events-mirror .meta-wrapper > .col-right > a:hover {
    background: var(--incon-accent-hover);
    color: #fff !important;
}

.portal-events-mirror img,
.portal-events-mirror svg {
    max-width: 100%;
    height: auto;
}

/* Schadenauswertung (Controlling-ähnliches Layout) */
.portal-schaden-dashboard__filter-card .card-header {
    border-bottom: 1px solid rgba(0, 35, 79, 0.08);
}

.portal-schaden-dashboard__filter-form fieldset {
    min-width: 0;
}

.portal-schaden-dashboard__tabs .nav-link {
    color: var(--incon-secondary-60, #5c6c7a);
    font-weight: 600;
    font-size: 0.9rem;
    border: none;
    border-bottom: 2px solid transparent;
    border-radius: 0;
    padding: 0.5rem 1rem;
}

.portal-schaden-dashboard__tabs .nav-link:hover:not(.disabled) {
    color: var(--incon-accent, #009ee3);
    border-bottom-color: rgba(0, 158, 227, 0.35);
}

.portal-schaden-dashboard__tabs .nav-link.active {
    color: var(--incon-primary, #00234f);
    border-bottom-color: var(--incon-accent, #009ee3);
    background: transparent;
}

.portal-schaden-dashboard__tab-disabled {
    cursor: not-allowed;
    opacity: 0.45;
}

.portal-schaden-dashboard__legend-dot {
    display: inline-block;
    width: 0.65rem;
    height: 0.65rem;
    border-radius: 50%;
    flex-shrink: 0;
}

.portal-schaden-dashboard__table thead th {
    background: rgba(0, 158, 227, 0.08);
    color: var(--incon-primary, #00234f);
    font-weight: 600;
}

.portal-schaden-dashboard__table tfoot td {
    background: rgba(0, 35, 79, 0.04);
}

.portal-schaden-dashboard__line-chart-wrap {
    position: relative;
    width: 100%;
    height: 320px;
}

/* Ticket-Detail-Modal (idwell-HTML)
   modal-body ohne padding-top: vermeidet Lücke zwischen Header und sticky Tabs (scrollable modal).
   Tab-Leiste: volle Breite + deckender Hintergrund, damit Tab-Inhalt nicht durchscheint. */
#portalTicketDetailModal.modal .modal-body.portal-ticket-detail-modal__body {
    padding-top: 0;
}

.portal-ticket-detail-modal__tabs {
    position: sticky;
    top: 0;
    z-index: 15;
    isolation: isolate;
    margin-left: calc(-1 * var(--bs-modal-padding, 1rem));
    margin-right: calc(-1 * var(--bs-modal-padding, 1rem));
    margin-top: 0;
    padding: 0.5rem var(--bs-modal-padding, 1rem) 0.4rem;
    background-color: var(--bs-modal-bg, #fff);
    border-bottom: 1px solid rgba(0, 35, 79, 0.1);
    box-shadow: 0 4px 12px -4px rgba(0, 35, 79, 0.12);
}

.portal-ticket-detail-modal__tabs .nav-item {
    flex-shrink: 0;
}

.portal-ticket-detail-modal__tabs .nav-link {
    border: none;
    border-bottom: 2px solid transparent;
    border-radius: 0;
    padding: 0.45rem 0.65rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--incon-primary-60);
    background: transparent;
    white-space: nowrap;
}

.portal-ticket-detail-modal__tabs .nav-link:hover,
.portal-ticket-detail-modal__tabs .nav-link:focus-visible {
    color: var(--incon-primary);
    border-bottom-color: rgba(0, 158, 227, 0.35);
}

.portal-ticket-detail-modal__tabs .nav-link.active {
    color: var(--incon-accent);
    border-bottom-color: var(--incon-accent);
    background: transparent;
}

.portal-ticket-detail-modal__tab-content {
    position: relative;
    z-index: 0;
    min-height: 12rem;
}

#portalTicketDetailModal .tab-pane > h3.h6 {
    scroll-margin-top: 0.35rem;
}

.portal-ticket-detail-modal__ai-summary {
    border-radius: 0.5rem;
    box-shadow: 0 1px 0 rgba(0, 35, 79, 0.06);
}

.portal-ticket-detail-modal__ai-summary-text {
    line-height: 1.55;
}

.portal-vertrag-modal__ai-summary {
    border-radius: 0.5rem;
    box-shadow: 0 1px 0 rgba(0, 35, 79, 0.06);
}

.portal-vertrag-modal__ai-summary-text {
    line-height: 1.55;
}

@media (max-width: 575.98px) {
    .portal-ticket-detail-modal__tabs .nav-link {
        font-size: 0.75rem;
        padding: 0.4rem 0.5rem;
    }
}

.portal-ticket-detail-modal__description-box {
    background: #f0f3f6;
    border: 1px solid rgba(0, 35, 79, 0.1);
    border-radius: 0.5rem;
    padding: 0.75rem 1rem 0.5rem;
}

.portal-ticket-detail-modal__description-scroll {
    overflow: hidden;
    position: relative;
}

.portal-ticket-detail-modal__description-scroll.is-collapsed {
    overflow: hidden;
}

.portal-ticket-detail-modal__description-scroll.is-collapsed::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 2.25rem;
    background: linear-gradient(to bottom, rgba(240, 243, 246, 0), rgba(240, 243, 246, 1));
    pointer-events: none;
}

.portal-ticket-detail-modal__description-inner {
    line-height: 1.55;
    overflow-wrap: anywhere;
}

.portal-ticket-detail-modal__description-inner p:last-child {
    margin-bottom: 0;
}

.portal-ticket-detail-modal__description-inner table {
    width: 100%;
    font-size: 0.9em;
}

.portal-ticket-detail-modal__description-inner img {
    max-width: 100%;
    height: auto;
}

.portal-ticket-detail-modal__desc-toggle {
    font-weight: 600;
}

.portal-ticket-detail-modal__contact-card {
    background: #fafbfc;
    border: 1px solid rgba(0, 35, 79, 0.1);
    border-radius: 0.45rem;
    padding: 0.65rem 0.85rem;
    margin-bottom: 0.65rem;
}

.portal-ticket-detail-modal__contact-card:last-child {
    margin-bottom: 0;
}

.portal-ticket-detail-modal__contact-dl dt,
.portal-ticket-detail-modal__contact-dl dd {
    min-height: 0;
}

.portal-ticket-detail-modal__contact-dl dd a {
    word-break: break-word;
}

.portal-ticket-detail-modal__email-thread-card {
    cursor: pointer;
    transition: box-shadow 0.15s ease, border-color 0.15s ease;
}

.portal-ticket-detail-modal__email-thread-card:hover,
.portal-ticket-detail-modal__email-thread-card:focus-visible {
    border-color: rgba(13, 110, 253, 0.35) !important;
    box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.08) !important;
    outline: none;
}

.portal-email-thread-msg__body img {
    max-width: 100%;
    height: auto;
}

.portal-email-thread-modal__messages .portal-email-thread-msg:last-child {
    margin-bottom: 0 !important;
}
